1 | import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
2 | import { area, line } from 'd3-shape';
|
3 | import { id } from '../utils/id';
|
4 | import { sortLinear, sortByTime, sortByDomain } from '../utils/sort';
|
5 | import { BarOrientation } from '../common/types/bar-orientation.enum';
|
6 | import { ScaleType } from '../common/types/scale-type.enum';
|
7 | export class LineSeriesComponent {
|
8 | constructor() {
|
9 | this.animations = true;
|
10 | this.barOrientation = BarOrientation;
|
11 | }
|
12 | ngOnChanges(changes) {
|
13 | this.update();
|
14 | }
|
15 | update() {
|
16 | this.updateGradients();
|
17 | const data = this.sortData(this.data.series);
|
18 | const lineGen = this.getLineGenerator();
|
19 | this.path = lineGen(data) || '';
|
20 | const areaGen = this.getAreaGenerator();
|
21 | this.areaPath = areaGen(data) || '';
|
22 | if (this.hasRange) {
|
23 | const range = this.getRangeGenerator();
|
24 | this.outerPath = range(data) || '';
|
25 | }
|
26 | if (this.hasGradient) {
|
27 | this.stroke = this.gradientUrl;
|
28 | const values = this.data.series.map(d => d.value);
|
29 | const max = Math.max(...values);
|
30 | const min = Math.min(...values);
|
31 | if (max === min) {
|
32 | this.stroke = this.colors.getColor(max);
|
33 | }
|
34 | }
|
35 | else {
|
36 | this.stroke = this.colors.getColor(this.data.name);
|
37 | }
|
38 | }
|
39 | getLineGenerator() {
|
40 | return line()
|
41 | .x(d => {
|
42 | const label = d.name;
|
43 | let value;
|
44 | if (this.scaleType === ScaleType.Time) {
|
45 | value = this.xScale(label);
|
46 | }
|
47 | else if (this.scaleType === ScaleType.Linear) {
|
48 | value = this.xScale(Number(label));
|
49 | }
|
50 | else {
|
51 | value = this.xScale(label);
|
52 | }
|
53 | return value;
|
54 | })
|
55 | .y(d => this.yScale(d.value))
|
56 | .curve(this.curve);
|
57 | }
|
58 | getRangeGenerator() {
|
59 | return area()
|
60 | .x(d => {
|
61 | const label = d.name;
|
62 | let value;
|
63 | if (this.scaleType === ScaleType.Time) {
|
64 | value = this.xScale(label);
|
65 | }
|
66 | else if (this.scaleType === ScaleType.Linear) {
|
67 | value = this.xScale(Number(label));
|
68 | }
|
69 | else {
|
70 | value = this.xScale(label);
|
71 | }
|
72 | return value;
|
73 | })
|
74 | .y0(d => this.yScale(typeof d.min === 'number' ? d.min : d.value))
|
75 | .y1(d => this.yScale(typeof d.max === 'number' ? d.max : d.value))
|
76 | .curve(this.curve);
|
77 | }
|
78 | getAreaGenerator() {
|
79 | const xProperty = d => {
|
80 | const label = d.name;
|
81 | return this.xScale(label);
|
82 | };
|
83 | return area()
|
84 | .x(xProperty)
|
85 | .y0(() => this.yScale.range()[0])
|
86 | .y1(d => this.yScale(d.value))
|
87 | .curve(this.curve);
|
88 | }
|
89 | sortData(data) {
|
90 | if (this.scaleType === ScaleType.Linear) {
|
91 | data = sortLinear(data, 'name');
|
92 | }
|
93 | else if (this.scaleType === ScaleType.Time) {
|
94 | data = sortByTime(data, 'name');
|
95 | }
|
96 | else {
|
97 | data = sortByDomain(data, 'name', 'asc', this.xScale.domain());
|
98 | }
|
99 | return data;
|
100 | }
|
101 | updateGradients() {
|
102 | if (this.colors.scaleType === ScaleType.Linear) {
|
103 | this.hasGradient = true;
|
104 | this.gradientId = 'grad' + id().toString();
|
105 | this.gradientUrl = `url(#${this.gradientId})`;
|
106 | const values = this.data.series.map(d => d.value);
|
107 | const max = Math.max(...values);
|
108 | const min = Math.min(...values);
|
109 | this.gradientStops = this.colors.getLinearGradientStops(max, min);
|
110 | this.areaGradientStops = this.colors.getLinearGradientStops(max);
|
111 | }
|
112 | else {
|
113 | this.hasGradient = false;
|
114 | this.gradientStops = undefined;
|
115 | this.areaGradientStops = undefined;
|
116 | }
|
117 | }
|
118 | isActive(entry) {
|
119 | if (!this.activeEntries)
|
120 | return false;
|
121 | const item = this.activeEntries.find(d => {
|
122 | return entry.name === d.name;
|
123 | });
|
124 | return item !== undefined;
|
125 | }
|
126 | isInactive(entry) {
|
127 | if (!this.activeEntries || this.activeEntries.length === 0)
|
128 | return false;
|
129 | const item = this.activeEntries.find(d => {
|
130 | return entry.name === d.name;
|
131 | });
|
132 | return item === undefined;
|
133 | }
|
134 | }
|
135 | LineSeriesComponent.decorators = [
|
136 | { type: Component, args: [{
|
137 | selector: 'g[ngx-charts-line-series]',
|
138 | template: `
|
139 | <svg:g>
|
140 | <defs>
|
141 | <svg:g
|
142 | ngx-charts-svg-linear-gradient
|
143 | *ngIf="hasGradient"
|
144 | [orientation]="barOrientation.Vertical"
|
145 | [name]="gradientId"
|
146 | [stops]="gradientStops"
|
147 | />
|
148 | </defs>
|
149 | <svg:g
|
150 | ngx-charts-area
|
151 | class="line-highlight"
|
152 | [data]="data"
|
153 | [path]="areaPath"
|
154 | [fill]="hasGradient ? gradientUrl : colors.getColor(data.name)"
|
155 | [opacity]="0.25"
|
156 | [startOpacity]="0"
|
157 | [gradient]="true"
|
158 | [stops]="areaGradientStops"
|
159 | [class.active]="isActive(data)"
|
160 | [class.inactive]="isInactive(data)"
|
161 | [animations]="animations"
|
162 | />
|
163 | <svg:g
|
164 | ngx-charts-line
|
165 | class="line-series"
|
166 | [data]="data"
|
167 | [path]="path"
|
168 | [stroke]="stroke"
|
169 | [animations]="animations"
|
170 | [class.active]="isActive(data)"
|
171 | [class.inactive]="isInactive(data)"
|
172 | />
|
173 | <svg:g
|
174 | ngx-charts-area
|
175 | *ngIf="hasRange"
|
176 | class="line-series-range"
|
177 | [data]="data"
|
178 | [path]="outerPath"
|
179 | [fill]="hasGradient ? gradientUrl : colors.getColor(data.name)"
|
180 | [class.active]="isActive(data)"
|
181 | [class.inactive]="isInactive(data)"
|
182 | [opacity]="rangeFillOpacity"
|
183 | [animations]="animations"
|
184 | />
|
185 | </svg:g>
|
186 | `,
|
187 | changeDetection: ChangeDetectionStrategy.OnPush
|
188 | },] }
|
189 | ];
|
190 | LineSeriesComponent.propDecorators = {
|
191 | data: [{ type: Input }],
|
192 | xScale: [{ type: Input }],
|
193 | yScale: [{ type: Input }],
|
194 | colors: [{ type: Input }],
|
195 | scaleType: [{ type: Input }],
|
196 | curve: [{ type: Input }],
|
197 | activeEntries: [{ type: Input }],
|
198 | rangeFillOpacity: [{ type: Input }],
|
199 | hasRange: [{ type: Input }],
|
200 | animations: [{ type: Input }]
|
201 | };
|
202 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-series.component.js","sourceRoot":"","sources":["../../../../../../projects/swimlane/ngx-charts/src/lib/line-chart/line-series.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, OnChanges, SimpleChanges, ChangeDetectionStrategy } from '@angular/core';\nimport { area, line } from 'd3-shape';\n\nimport { id } from '../utils/id';\nimport { sortLinear, sortByTime, sortByDomain } from '../utils/sort';\nimport { ColorHelper } from '../common/color.helper';\nimport { Series } from '../models/chart-data.model';\nimport { BarOrientation } from '../common/types/bar-orientation.enum';\nimport { ScaleType } from '../common/types/scale-type.enum';\nimport { Gradient } from '../common/types/gradient.interface';\n\n@Component({\n  selector: 'g[ngx-charts-line-series]',\n  template: `\n    <svg:g>\n      <defs>\n        <svg:g\n          ngx-charts-svg-linear-gradient\n          *ngIf=\"hasGradient\"\n          [orientation]=\"barOrientation.Vertical\"\n          [name]=\"gradientId\"\n          [stops]=\"gradientStops\"\n        />\n      </defs>\n      <svg:g\n        ngx-charts-area\n        class=\"line-highlight\"\n        [data]=\"data\"\n        [path]=\"areaPath\"\n        [fill]=\"hasGradient ? gradientUrl : colors.getColor(data.name)\"\n        [opacity]=\"0.25\"\n        [startOpacity]=\"0\"\n        [gradient]=\"true\"\n        [stops]=\"areaGradientStops\"\n        [class.active]=\"isActive(data)\"\n        [class.inactive]=\"isInactive(data)\"\n        [animations]=\"animations\"\n      />\n      <svg:g\n        ngx-charts-line\n        class=\"line-series\"\n        [data]=\"data\"\n        [path]=\"path\"\n        [stroke]=\"stroke\"\n        [animations]=\"animations\"\n        [class.active]=\"isActive(data)\"\n        [class.inactive]=\"isInactive(data)\"\n      />\n      <svg:g\n        ngx-charts-area\n        *ngIf=\"hasRange\"\n        class=\"line-series-range\"\n        [data]=\"data\"\n        [path]=\"outerPath\"\n        [fill]=\"hasGradient ? gradientUrl : colors.getColor(data.name)\"\n        [class.active]=\"isActive(data)\"\n        [class.inactive]=\"isInactive(data)\"\n        [opacity]=\"rangeFillOpacity\"\n        [animations]=\"animations\"\n      />\n    </svg:g>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LineSeriesComponent implements OnChanges {\n  @Input() data: Series;\n  @Input() xScale;\n  @Input() yScale;\n  @Input() colors: ColorHelper;\n  @Input() scaleType: ScaleType;\n  @Input() curve: any;\n  @Input() activeEntries: any[];\n  @Input() rangeFillOpacity: number;\n  @Input() hasRange: boolean;\n  @Input() animations: boolean = true;\n\n  path: string;\n  outerPath: string;\n  areaPath: string;\n  gradientId: string;\n  gradientUrl: string;\n  hasGradient: boolean;\n  gradientStops: Gradient[];\n  areaGradientStops: Gradient[];\n  stroke: string;\n\n  barOrientation = BarOrientation;\n\n  ngOnChanges(changes: SimpleChanges): void {\n    this.update();\n  }\n\n  update(): void {\n    this.updateGradients();\n\n    const data = this.sortData(this.data.series);\n\n    const lineGen = this.getLineGenerator();\n    this.path = lineGen(data) || '';\n\n    const areaGen = this.getAreaGenerator();\n    this.areaPath = areaGen(data) || '';\n\n    if (this.hasRange) {\n      const range = this.getRangeGenerator();\n      this.outerPath = range(data) || '';\n    }\n\n    if (this.hasGradient) {\n      this.stroke = this.gradientUrl;\n      const values = this.data.series.map(d => d.value);\n      const max = Math.max(...values);\n      const min = Math.min(...values);\n      if (max === min) {\n        this.stroke = this.colors.getColor(max);\n      }\n    } else {\n      this.stroke = this.colors.getColor(this.data.name);\n    }\n  }\n\n  getLineGenerator(): any {\n    return line<any>()\n      .x(d => {\n        const label = d.name;\n        let value;\n        if (this.scaleType === ScaleType.Time) {\n          value = this.xScale(label);\n        } else if (this.scaleType === ScaleType.Linear) {\n          value = this.xScale(Number(label));\n        } else {\n          value = this.xScale(label);\n        }\n        return value;\n      })\n      .y(d => this.yScale(d.value))\n      .curve(this.curve);\n  }\n\n  getRangeGenerator(): any {\n    return area<any>()\n      .x(d => {\n        const label = d.name;\n        let value;\n        if (this.scaleType === ScaleType.Time) {\n          value = this.xScale(label);\n        } else if (this.scaleType === ScaleType.Linear) {\n          value = this.xScale(Number(label));\n        } else {\n          value = this.xScale(label);\n        }\n        return value;\n      })\n      .y0(d => this.yScale(typeof d.min === 'number' ? d.min : d.value))\n      .y1(d => this.yScale(typeof d.max === 'number' ? d.max : d.value))\n      .curve(this.curve);\n  }\n\n  getAreaGenerator(): any {\n    const xProperty = d => {\n      const label = d.name;\n      return this.xScale(label);\n    };\n\n    return area<any>()\n      .x(xProperty)\n      .y0(() => this.yScale.range()[0])\n      .y1(d => this.yScale(d.value))\n      .curve(this.curve);\n  }\n\n  sortData(data) {\n    if (this.scaleType === ScaleType.Linear) {\n      data = sortLinear(data, 'name');\n    } else if (this.scaleType === ScaleType.Time) {\n      data = sortByTime(data, 'name');\n    } else {\n      data = sortByDomain(data, 'name', 'asc', this.xScale.domain());\n    }\n\n    return data;\n  }\n\n  updateGradients() {\n    if (this.colors.scaleType === ScaleType.Linear) {\n      this.hasGradient = true;\n      this.gradientId = 'grad' + id().toString();\n      this.gradientUrl = `url(#${this.gradientId})`;\n      const values = this.data.series.map(d => d.value);\n      const max = Math.max(...values);\n      const min = Math.min(...values);\n      this.gradientStops = this.colors.getLinearGradientStops(max, min);\n      this.areaGradientStops = this.colors.getLinearGradientStops(max);\n    } else {\n      this.hasGradient = false;\n      this.gradientStops = undefined;\n      this.areaGradientStops = undefined;\n    }\n  }\n\n  isActive(entry): boolean {\n    if (!this.activeEntries) return false;\n    const item = this.activeEntries.find(d => {\n      return entry.name === d.name;\n    });\n    return item !== undefined;\n  }\n\n  isInactive(entry): boolean {\n    if (!this.activeEntries || this.activeEntries.length === 0) return false;\n    const item = this.activeEntries.find(d => {\n      return entry.name === d.name;\n    });\n    return item === undefined;\n  }\n}\n"]} |
\ | No newline at end of file |