1 | import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
2 | import { select } from 'd3-selection';
|
3 | import { roundedRect } from '../common/shape.helper';
|
4 | import { id } from '../utils/id';
|
5 | import { BarOrientation } from '../common/types/bar-orientation.enum';
|
6 | export class BarComponent {
|
7 | constructor(element) {
|
8 | this.roundEdges = true;
|
9 | this.gradient = false;
|
10 | this.offset = 0;
|
11 | this.isActive = false;
|
12 | this.animations = true;
|
13 | this.noBarWhenZero = true;
|
14 | this.select = new EventEmitter();
|
15 | this.activate = new EventEmitter();
|
16 | this.deactivate = new EventEmitter();
|
17 | this.hasGradient = false;
|
18 | this.hideBar = false;
|
19 | this.element = element.nativeElement;
|
20 | }
|
21 | ngOnChanges(changes) {
|
22 | if (changes.roundEdges) {
|
23 | this.loadAnimation();
|
24 | }
|
25 | this.update();
|
26 | }
|
27 | update() {
|
28 | this.gradientId = 'grad' + id().toString();
|
29 | this.gradientFill = `url(#${this.gradientId})`;
|
30 | if (this.gradient || this.stops) {
|
31 | this.gradientStops = this.getGradient();
|
32 | this.hasGradient = true;
|
33 | }
|
34 | else {
|
35 | this.hasGradient = false;
|
36 | }
|
37 | this.updatePathEl();
|
38 | this.checkToHideBar();
|
39 | }
|
40 | loadAnimation() {
|
41 | this.path = this.getStartingPath();
|
42 | setTimeout(this.update.bind(this), 100);
|
43 | }
|
44 | updatePathEl() {
|
45 | const node = select(this.element).select('.bar');
|
46 | const path = this.getPath();
|
47 | if (this.animations) {
|
48 | node.transition().duration(500).attr('d', path);
|
49 | }
|
50 | else {
|
51 | node.attr('d', path);
|
52 | }
|
53 | }
|
54 | getGradient() {
|
55 | if (this.stops) {
|
56 | return this.stops;
|
57 | }
|
58 | return [
|
59 | {
|
60 | offset: 0,
|
61 | color: this.fill,
|
62 | opacity: this.getStartOpacity()
|
63 | },
|
64 | {
|
65 | offset: 100,
|
66 | color: this.fill,
|
67 | opacity: 1
|
68 | }
|
69 | ];
|
70 | }
|
71 | getStartingPath() {
|
72 | if (!this.animations) {
|
73 | return this.getPath();
|
74 | }
|
75 | let radius = this.getRadius();
|
76 | let path;
|
77 | if (this.roundEdges) {
|
78 | if (this.orientation === BarOrientation.Vertical) {
|
79 | radius = Math.min(this.height, radius);
|
80 | path = roundedRect(this.x, this.y + this.height, this.width, 1, 0, this.edges);
|
81 | }
|
82 | else if (this.orientation === BarOrientation.Horizontal) {
|
83 | radius = Math.min(this.width, radius);
|
84 | path = roundedRect(this.x, this.y, 1, this.height, 0, this.edges);
|
85 | }
|
86 | }
|
87 | else {
|
88 | if (this.orientation === BarOrientation.Vertical) {
|
89 | path = roundedRect(this.x, this.y + this.height, this.width, 1, 0, this.edges);
|
90 | }
|
91 | else if (this.orientation === BarOrientation.Horizontal) {
|
92 | path = roundedRect(this.x, this.y, 1, this.height, 0, this.edges);
|
93 | }
|
94 | }
|
95 | return path;
|
96 | }
|
97 | getPath() {
|
98 | let radius = this.getRadius();
|
99 | let path;
|
100 | if (this.roundEdges) {
|
101 | if (this.orientation === 'vertical') {
|
102 | radius = Math.min(this.height, radius);
|
103 | path = roundedRect(this.x, this.y, this.width, this.height, radius, this.edges);
|
104 | }
|
105 | else if (this.orientation === 'horizontal') {
|
106 | radius = Math.min(this.width, radius);
|
107 | path = roundedRect(this.x, this.y, this.width, this.height, radius, this.edges);
|
108 | }
|
109 | }
|
110 | else {
|
111 | path = roundedRect(this.x, this.y, this.width, this.height, radius, this.edges);
|
112 | }
|
113 | return path;
|
114 | }
|
115 | getRadius() {
|
116 | let radius = 0;
|
117 | if (this.roundEdges && this.height > 5 && this.width > 5) {
|
118 | radius = Math.floor(Math.min(5, this.height / 2, this.width / 2));
|
119 | }
|
120 | return radius;
|
121 | }
|
122 | getStartOpacity() {
|
123 | if (this.roundEdges) {
|
124 | return 0.2;
|
125 | }
|
126 | else {
|
127 | return 0.5;
|
128 | }
|
129 | }
|
130 | get edges() {
|
131 | let edges = [false, false, false, false];
|
132 | if (this.roundEdges) {
|
133 | if (this.orientation === BarOrientation.Vertical) {
|
134 | if (this.data.value > 0) {
|
135 | edges = [true, true, false, false];
|
136 | }
|
137 | else {
|
138 | edges = [false, false, true, true];
|
139 | }
|
140 | }
|
141 | else if (this.orientation === BarOrientation.Horizontal) {
|
142 | if (this.data.value > 0) {
|
143 | edges = [false, true, false, true];
|
144 | }
|
145 | else {
|
146 | edges = [true, false, true, false];
|
147 | }
|
148 | }
|
149 | }
|
150 | return edges;
|
151 | }
|
152 | onMouseEnter() {
|
153 | this.activate.emit(this.data);
|
154 | }
|
155 | onMouseLeave() {
|
156 | this.deactivate.emit(this.data);
|
157 | }
|
158 | checkToHideBar() {
|
159 | this.hideBar =
|
160 | this.noBarWhenZero &&
|
161 | ((this.orientation === BarOrientation.Vertical && this.height === 0) ||
|
162 | (this.orientation === BarOrientation.Horizontal && this.width === 0));
|
163 | }
|
164 | }
|
165 | BarComponent.decorators = [
|
166 | { type: Component, args: [{
|
167 | selector: 'g[ngx-charts-bar]',
|
168 | template: `
|
169 | <svg:defs *ngIf="hasGradient">
|
170 | <svg:g ngx-charts-svg-linear-gradient [orientation]="orientation" [name]="gradientId" [stops]="gradientStops" />
|
171 | </svg:defs>
|
172 | <svg:path
|
173 | class="bar"
|
174 | stroke="none"
|
175 | role="img"
|
176 | tabIndex="-1"
|
177 | [class.active]="isActive"
|
178 | [class.hidden]="hideBar"
|
179 | [attr.d]="path"
|
180 | [attr.aria-label]="ariaLabel"
|
181 | [attr.fill]="hasGradient ? gradientFill : fill"
|
182 | (click)="select.emit(data)"
|
183 | />
|
184 | `,
|
185 | changeDetection: ChangeDetectionStrategy.OnPush
|
186 | },] }
|
187 | ];
|
188 | BarComponent.ctorParameters = () => [
|
189 | { type: ElementRef }
|
190 | ];
|
191 | BarComponent.propDecorators = {
|
192 | fill: [{ type: Input }],
|
193 | data: [{ type: Input }],
|
194 | width: [{ type: Input }],
|
195 | height: [{ type: Input }],
|
196 | x: [{ type: Input }],
|
197 | y: [{ type: Input }],
|
198 | orientation: [{ type: Input }],
|
199 | roundEdges: [{ type: Input }],
|
200 | gradient: [{ type: Input }],
|
201 | offset: [{ type: Input }],
|
202 | isActive: [{ type: Input }],
|
203 | stops: [{ type: Input }],
|
204 | animations: [{ type: Input }],
|
205 | ariaLabel: [{ type: Input }],
|
206 | noBarWhenZero: [{ type: Input }],
|
207 | select: [{ type: Output }],
|
208 | activate: [{ type: Output }],
|
209 | deactivate: [{ type: Output }],
|
210 | onMouseEnter: [{ type: HostListener, args: ['mouseenter',] }],
|
211 | onMouseLeave: [{ type: HostListener, args: ['mouseleave',] }]
|
212 | };
|
213 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar.component.js","sourceRoot":"","sources":["../../../../../../projects/swimlane/ngx-charts/src/lib/bar-chart/bar.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChanges\n} from '@angular/core';\nimport { select } from 'd3-selection';\nimport { roundedRect } from '../common/shape.helper';\nimport { id } from '../utils/id';\nimport { DataItem } from '../models/chart-data.model';\nimport { BarOrientation } from '../common/types/bar-orientation.enum';\nimport { Gradient } from '../common/types/gradient.interface';\n\n@Component({\n  selector: 'g[ngx-charts-bar]',\n  template: `\n    <svg:defs *ngIf=\"hasGradient\">\n      <svg:g ngx-charts-svg-linear-gradient [orientation]=\"orientation\" [name]=\"gradientId\" [stops]=\"gradientStops\" />\n    </svg:defs>\n    <svg:path\n      class=\"bar\"\n      stroke=\"none\"\n      role=\"img\"\n      tabIndex=\"-1\"\n      [class.active]=\"isActive\"\n      [class.hidden]=\"hideBar\"\n      [attr.d]=\"path\"\n      [attr.aria-label]=\"ariaLabel\"\n      [attr.fill]=\"hasGradient ? gradientFill : fill\"\n      (click)=\"select.emit(data)\"\n    />\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class BarComponent implements OnChanges {\n  @Input() fill: string;\n  @Input() data: DataItem;\n  @Input() width: number;\n  @Input() height: number;\n  @Input() x: number;\n  @Input() y: number;\n  @Input() orientation: BarOrientation;\n  @Input() roundEdges: boolean = true;\n  @Input() gradient: boolean = false;\n  @Input() offset: number = 0;\n  @Input() isActive: boolean = false;\n  @Input() stops: Gradient[];\n  @Input() animations: boolean = true;\n  @Input() ariaLabel: string;\n  @Input() noBarWhenZero: boolean = true;\n\n  @Output() select: EventEmitter<DataItem> = new EventEmitter();\n  @Output() activate: EventEmitter<DataItem> = new EventEmitter();\n  @Output() deactivate: EventEmitter<DataItem> = new EventEmitter();\n\n  element: HTMLElement;\n  path: string;\n  gradientId: string;\n  gradientFill: string;\n  gradientStops: Gradient[];\n  hasGradient: boolean = false;\n  hideBar: boolean = false;\n\n  constructor(element: ElementRef) {\n    this.element = element.nativeElement;\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.roundEdges) {\n      this.loadAnimation();\n    }\n    this.update();\n  }\n\n  update(): void {\n    this.gradientId = 'grad' + id().toString();\n    this.gradientFill = `url(#${this.gradientId})`;\n\n    if (this.gradient || this.stops) {\n      this.gradientStops = this.getGradient();\n      this.hasGradient = true;\n    } else {\n      this.hasGradient = false;\n    }\n\n    this.updatePathEl();\n    this.checkToHideBar();\n  }\n\n  loadAnimation(): void {\n    this.path = this.getStartingPath();\n    setTimeout(this.update.bind(this), 100);\n  }\n\n  updatePathEl(): void {\n    const node = select(this.element).select('.bar');\n    const path = this.getPath();\n    if (this.animations) {\n      node.transition().duration(500).attr('d', path);\n    } else {\n      node.attr('d', path);\n    }\n  }\n\n  getGradient(): Gradient[] {\n    if (this.stops) {\n      return this.stops;\n    }\n\n    return [\n      {\n        offset: 0,\n        color: this.fill,\n        opacity: this.getStartOpacity()\n      },\n      {\n        offset: 100,\n        color: this.fill,\n        opacity: 1\n      }\n    ];\n  }\n\n  getStartingPath(): string {\n    if (!this.animations) {\n      return this.getPath();\n    }\n\n    let radius = this.getRadius();\n    let path;\n\n    if (this.roundEdges) {\n      if (this.orientation === BarOrientation.Vertical) {\n        radius = Math.min(this.height, radius);\n        path = roundedRect(this.x, this.y + this.height, this.width, 1, 0, this.edges);\n      } else if (this.orientation === BarOrientation.Horizontal) {\n        radius = Math.min(this.width, radius);\n        path = roundedRect(this.x, this.y, 1, this.height, 0, this.edges);\n      }\n    } else {\n      if (this.orientation === BarOrientation.Vertical) {\n        path = roundedRect(this.x, this.y + this.height, this.width, 1, 0, this.edges);\n      } else if (this.orientation === BarOrientation.Horizontal) {\n        path = roundedRect(this.x, this.y, 1, this.height, 0, this.edges);\n      }\n    }\n\n    return path;\n  }\n\n  getPath(): string {\n    let radius = this.getRadius();\n    let path;\n\n    if (this.roundEdges) {\n      if (this.orientation === 'vertical') {\n        radius = Math.min(this.height, radius);\n        path = roundedRect(this.x, this.y, this.width, this.height, radius, this.edges);\n      } else if (this.orientation === 'horizontal') {\n        radius = Math.min(this.width, radius);\n        path = roundedRect(this.x, this.y, this.width, this.height, radius, this.edges);\n      }\n    } else {\n      path = roundedRect(this.x, this.y, this.width, this.height, radius, this.edges);\n    }\n\n    return path;\n  }\n\n  getRadius(): number {\n    let radius = 0;\n\n    if (this.roundEdges && this.height > 5 && this.width > 5) {\n      radius = Math.floor(Math.min(5, this.height / 2, this.width / 2));\n    }\n\n    return radius;\n  }\n\n  getStartOpacity(): number {\n    if (this.roundEdges) {\n      return 0.2;\n    } else {\n      return 0.5;\n    }\n  }\n\n  get edges(): boolean[] {\n    let edges = [false, false, false, false];\n    if (this.roundEdges) {\n      if (this.orientation === BarOrientation.Vertical) {\n        if (this.data.value > 0) {\n          edges = [true, true, false, false];\n        } else {\n          edges = [false, false, true, true];\n        }\n      } else if (this.orientation === BarOrientation.Horizontal) {\n        if (this.data.value > 0) {\n          edges = [false, true, false, true];\n        } else {\n          edges = [true, false, true, false];\n        }\n      }\n    }\n    return edges;\n  }\n\n  @HostListener('mouseenter')\n  onMouseEnter(): void {\n    this.activate.emit(this.data);\n  }\n\n  @HostListener('mouseleave')\n  onMouseLeave(): void {\n    this.deactivate.emit(this.data);\n  }\n\n  private checkToHideBar(): void {\n    this.hideBar =\n      this.noBarWhenZero &&\n      ((this.orientation === BarOrientation.Vertical && this.height === 0) ||\n        (this.orientation === BarOrientation.Horizontal && this.width === 0));\n  }\n}\n"]} |
\ | No newline at end of file |