1 | import { Component, Input, Output, EventEmitter, ViewEncapsulation, HostListener, ChangeDetectionStrategy, ContentChild } from '@angular/core';
|
2 | import { trigger, style, animate, transition } from '@angular/animations';
|
3 | import { scaleLinear, scaleTime, scalePoint } from 'd3-scale';
|
4 | import { curveLinear } from 'd3-shape';
|
5 | import { calculateViewDimensions } from '../common/view-dimensions.helper';
|
6 | import { ColorHelper } from '../common/color.helper';
|
7 | import { BaseChartComponent } from '../common/base-chart.component';
|
8 | import { id } from '../utils/id';
|
9 | import { getUniqueXDomainValues, getScaleType } from '../common/domain.helper';
|
10 | import { LegendPosition } from '../common/types/legend.model';
|
11 | import { ScaleType } from '../common/types/scale-type.enum';
|
12 | export class LineChartComponent extends BaseChartComponent {
|
13 | constructor() {
|
14 | super(...arguments);
|
15 | this.legendTitle = 'Legend';
|
16 | this.legendPosition = LegendPosition.Right;
|
17 | this.showGridLines = true;
|
18 | this.curve = curveLinear;
|
19 | this.activeEntries = [];
|
20 | this.trimXAxisTicks = true;
|
21 | this.trimYAxisTicks = true;
|
22 | this.rotateXAxisTicks = true;
|
23 | this.maxXAxisTickLength = 16;
|
24 | this.maxYAxisTickLength = 16;
|
25 | this.roundDomains = false;
|
26 | this.tooltipDisabled = false;
|
27 | this.showRefLines = false;
|
28 | this.showRefLabels = true;
|
29 | this.activate = new EventEmitter();
|
30 | this.deactivate = new EventEmitter();
|
31 | this.margin = [10, 20, 10, 20];
|
32 | this.xAxisHeight = 0;
|
33 | this.yAxisWidth = 0;
|
34 | this.timelineHeight = 50;
|
35 | this.timelinePadding = 10;
|
36 | }
|
37 | update() {
|
38 | super.update();
|
39 | this.dims = calculateViewDimensions({
|
40 | width: this.width,
|
41 | height: this.height,
|
42 | margins: this.margin,
|
43 | showXAxis: this.xAxis,
|
44 | showYAxis: this.yAxis,
|
45 | xAxisHeight: this.xAxisHeight,
|
46 | yAxisWidth: this.yAxisWidth,
|
47 | showXLabel: this.showXAxisLabel,
|
48 | showYLabel: this.showYAxisLabel,
|
49 | showLegend: this.legend,
|
50 | legendType: this.schemeType,
|
51 | legendPosition: this.legendPosition
|
52 | });
|
53 | if (this.timeline) {
|
54 | this.dims.height -= this.timelineHeight + this.margin[2] + this.timelinePadding;
|
55 | }
|
56 | this.xDomain = this.getXDomain();
|
57 | if (this.filteredDomain) {
|
58 | this.xDomain = this.filteredDomain;
|
59 | }
|
60 | this.yDomain = this.getYDomain();
|
61 | this.seriesDomain = this.getSeriesDomain();
|
62 | this.xScale = this.getXScale(this.xDomain, this.dims.width);
|
63 | this.yScale = this.getYScale(this.yDomain, this.dims.height);
|
64 | this.updateTimeline();
|
65 | this.setColors();
|
66 | this.legendOptions = this.getLegendOptions();
|
67 | this.transform = `translate(${this.dims.xOffset} , ${this.margin[0]})`;
|
68 | this.clipPathId = 'clip' + id().toString();
|
69 | this.clipPath = `url(#${this.clipPathId})`;
|
70 | }
|
71 | updateTimeline() {
|
72 | if (this.timeline) {
|
73 | this.timelineWidth = this.dims.width;
|
74 | this.timelineXDomain = this.getXDomain();
|
75 | this.timelineXScale = this.getXScale(this.timelineXDomain, this.timelineWidth);
|
76 | this.timelineYScale = this.getYScale(this.yDomain, this.timelineHeight);
|
77 | this.timelineTransform = `translate(${this.dims.xOffset}, ${-this.margin[2]})`;
|
78 | }
|
79 | }
|
80 | getXDomain() {
|
81 | let values = getUniqueXDomainValues(this.results);
|
82 | this.scaleType = getScaleType(values);
|
83 | let domain = [];
|
84 | if (this.scaleType === ScaleType.Linear) {
|
85 | values = values.map(v => Number(v));
|
86 | }
|
87 | let min;
|
88 | let max;
|
89 | if (this.scaleType === ScaleType.Time || this.scaleType === ScaleType.Linear) {
|
90 | min = this.xScaleMin ? this.xScaleMin : Math.min(...values);
|
91 | max = this.xScaleMax ? this.xScaleMax : Math.max(...values);
|
92 | }
|
93 | if (this.scaleType === ScaleType.Time) {
|
94 | domain = [new Date(min), new Date(max)];
|
95 | this.xSet = [...values].sort((a, b) => {
|
96 | const aDate = a.getTime();
|
97 | const bDate = b.getTime();
|
98 | if (aDate > bDate)
|
99 | return 1;
|
100 | if (bDate > aDate)
|
101 | return -1;
|
102 | return 0;
|
103 | });
|
104 | }
|
105 | else if (this.scaleType === ScaleType.Linear) {
|
106 | domain = [min, max];
|
107 | // Use compare function to sort numbers numerically
|
108 | this.xSet = [...values].sort((a, b) => a - b);
|
109 | }
|
110 | else {
|
111 | domain = values;
|
112 | this.xSet = values;
|
113 | }
|
114 | return domain;
|
115 | }
|
116 | getYDomain() {
|
117 | const domain = [];
|
118 | for (const results of this.results) {
|
119 | for (const d of results.series) {
|
120 | if (domain.indexOf(d.value) < 0) {
|
121 | domain.push(d.value);
|
122 | }
|
123 | if (d.min !== undefined) {
|
124 | this.hasRange = true;
|
125 | if (domain.indexOf(d.min) < 0) {
|
126 | domain.push(d.min);
|
127 | }
|
128 | }
|
129 | if (d.max !== undefined) {
|
130 | this.hasRange = true;
|
131 | if (domain.indexOf(d.max) < 0) {
|
132 | domain.push(d.max);
|
133 | }
|
134 | }
|
135 | }
|
136 | }
|
137 | const values = [...domain];
|
138 | if (!this.autoScale) {
|
139 | values.push(0);
|
140 | }
|
141 | const min = this.yScaleMin ? this.yScaleMin : Math.min(...values);
|
142 | const max = this.yScaleMax ? this.yScaleMax : Math.max(...values);
|
143 | return [min, max];
|
144 | }
|
145 | getSeriesDomain() {
|
146 | return this.results.map(d => d.name);
|
147 | }
|
148 | getXScale(domain, width) {
|
149 | let scale;
|
150 | if (this.scaleType === ScaleType.Time) {
|
151 | scale = scaleTime().range([0, width]).domain(domain);
|
152 | }
|
153 | else if (this.scaleType === ScaleType.Linear) {
|
154 | scale = scaleLinear().range([0, width]).domain(domain);
|
155 | if (this.roundDomains) {
|
156 | scale = scale.nice();
|
157 | }
|
158 | }
|
159 | else if (this.scaleType === ScaleType.Ordinal) {
|
160 | scale = scalePoint().range([0, width]).padding(0.1).domain(domain);
|
161 | }
|
162 | return scale;
|
163 | }
|
164 | getYScale(domain, height) {
|
165 | const scale = scaleLinear().range([height, 0]).domain(domain);
|
166 | return this.roundDomains ? scale.nice() : scale;
|
167 | }
|
168 | updateDomain(domain) {
|
169 | this.filteredDomain = domain;
|
170 | this.xDomain = this.filteredDomain;
|
171 | this.xScale = this.getXScale(this.xDomain, this.dims.width);
|
172 | }
|
173 | updateHoveredVertical(item) {
|
174 | this.hoveredVertical = item.value;
|
175 | this.deactivateAll();
|
176 | }
|
177 | hideCircles() {
|
178 | this.hoveredVertical = null;
|
179 | this.deactivateAll();
|
180 | }
|
181 | onClick(data) {
|
182 | this.select.emit(data);
|
183 | }
|
184 | trackBy(index, item) {
|
185 | return `${item.name}`;
|
186 | }
|
187 | setColors() {
|
188 | let domain;
|
189 | if (this.schemeType === ScaleType.Ordinal) {
|
190 | domain = this.seriesDomain;
|
191 | }
|
192 | else {
|
193 | domain = this.yDomain;
|
194 | }
|
195 | this.colors = new ColorHelper(this.scheme, this.schemeType, domain, this.customColors);
|
196 | }
|
197 | getLegendOptions() {
|
198 | const opts = {
|
199 | scaleType: this.schemeType,
|
200 | colors: undefined,
|
201 | domain: [],
|
202 | title: undefined,
|
203 | position: this.legendPosition
|
204 | };
|
205 | if (opts.scaleType === ScaleType.Ordinal) {
|
206 | opts.domain = this.seriesDomain;
|
207 | opts.colors = this.colors;
|
208 | opts.title = this.legendTitle;
|
209 | }
|
210 | else {
|
211 | opts.domain = this.yDomain;
|
212 | opts.colors = this.colors.scale;
|
213 | }
|
214 | return opts;
|
215 | }
|
216 | updateYAxisWidth({ width }) {
|
217 | this.yAxisWidth = width;
|
218 | this.update();
|
219 | }
|
220 | updateXAxisHeight({ height }) {
|
221 | this.xAxisHeight = height;
|
222 | this.update();
|
223 | }
|
224 | onActivate(item) {
|
225 | this.deactivateAll();
|
226 | const idx = this.activeEntries.findIndex(d => {
|
227 | return d.name === item.name && d.value === item.value;
|
228 | });
|
229 | if (idx > -1) {
|
230 | return;
|
231 | }
|
232 | this.activeEntries = [item];
|
233 | this.activate.emit({ value: item, entries: this.activeEntries });
|
234 | }
|
235 | onDeactivate(item) {
|
236 | const idx = this.activeEntries.findIndex(d => {
|
237 | return d.name === item.name && d.value === item.value;
|
238 | });
|
239 | this.activeEntries.splice(idx, 1);
|
240 | this.activeEntries = [...this.activeEntries];
|
241 | this.deactivate.emit({ value: item, entries: this.activeEntries });
|
242 | }
|
243 | deactivateAll() {
|
244 | this.activeEntries = [...this.activeEntries];
|
245 | for (const entry of this.activeEntries) {
|
246 | this.deactivate.emit({ value: entry, entries: [] });
|
247 | }
|
248 | this.activeEntries = [];
|
249 | }
|
250 | }
|
251 | LineChartComponent.decorators = [
|
252 | { type: Component, args: [{
|
253 | selector: 'ngx-charts-line-chart',
|
254 | template: `
|
255 | <ngx-charts-chart
|
256 | [view]="[width, height]"
|
257 | [showLegend]="legend"
|
258 | [legendOptions]="legendOptions"
|
259 | [activeEntries]="activeEntries"
|
260 | [animations]="animations"
|
261 | (legendLabelClick)="onClick($event)"
|
262 | (legendLabelActivate)="onActivate($event)"
|
263 | (legendLabelDeactivate)="onDeactivate($event)"
|
264 | >
|
265 | <svg:defs>
|
266 | <svg:clipPath [attr.id]="clipPathId">
|
267 | <svg:rect
|
268 | [attr.width]="dims.width + 10"
|
269 | [attr.height]="dims.height + 10"
|
270 | [attr.transform]="'translate(-5, -5)'"
|
271 | />
|
272 | </svg:clipPath>
|
273 | </svg:defs>
|
274 | <svg:g [attr.transform]="transform" class="line-chart chart">
|
275 | <svg:g
|
276 | ngx-charts-x-axis
|
277 | *ngIf="xAxis"
|
278 | [xScale]="xScale"
|
279 | [dims]="dims"
|
280 | [showGridLines]="showGridLines"
|
281 | [showLabel]="showXAxisLabel"
|
282 | [labelText]="xAxisLabel"
|
283 | [trimTicks]="trimXAxisTicks"
|
284 | [rotateTicks]="rotateXAxisTicks"
|
285 | [maxTickLength]="maxXAxisTickLength"
|
286 | [tickFormatting]="xAxisTickFormatting"
|
287 | [ticks]="xAxisTicks"
|
288 | (dimensionsChanged)="updateXAxisHeight($event)"
|
289 | ></svg:g>
|
290 | <svg:g
|
291 | ngx-charts-y-axis
|
292 | *ngIf="yAxis"
|
293 | [yScale]="yScale"
|
294 | [dims]="dims"
|
295 | [showGridLines]="showGridLines"
|
296 | [showLabel]="showYAxisLabel"
|
297 | [labelText]="yAxisLabel"
|
298 | [trimTicks]="trimYAxisTicks"
|
299 | [maxTickLength]="maxYAxisTickLength"
|
300 | [tickFormatting]="yAxisTickFormatting"
|
301 | [ticks]="yAxisTicks"
|
302 | [referenceLines]="referenceLines"
|
303 | [showRefLines]="showRefLines"
|
304 | [showRefLabels]="showRefLabels"
|
305 | (dimensionsChanged)="updateYAxisWidth($event)"
|
306 | ></svg:g>
|
307 | <svg:g [attr.clip-path]="clipPath">
|
308 | <svg:g *ngFor="let series of results; trackBy: trackBy" [@animationState]="'active'">
|
309 | <svg:g
|
310 | ngx-charts-line-series
|
311 | [xScale]="xScale"
|
312 | [yScale]="yScale"
|
313 | [colors]="colors"
|
314 | [data]="series"
|
315 | [activeEntries]="activeEntries"
|
316 | [scaleType]="scaleType"
|
317 | [curve]="curve"
|
318 | [rangeFillOpacity]="rangeFillOpacity"
|
319 | [hasRange]="hasRange"
|
320 | [animations]="animations"
|
321 | />
|
322 | </svg:g>
|
323 |
|
324 | <svg:g *ngIf="!tooltipDisabled" (mouseleave)="hideCircles()">
|
325 | <svg:g
|
326 | ngx-charts-tooltip-area
|
327 | [dims]="dims"
|
328 | [xSet]="xSet"
|
329 | [xScale]="xScale"
|
330 | [yScale]="yScale"
|
331 | [results]="results"
|
332 | [colors]="colors"
|
333 | [tooltipDisabled]="tooltipDisabled"
|
334 | [tooltipTemplate]="seriesTooltipTemplate"
|
335 | (hover)="updateHoveredVertical($event)"
|
336 | />
|
337 |
|
338 | <svg:g *ngFor="let series of results">
|
339 | <svg:g
|
340 | ngx-charts-circle-series
|
341 | [xScale]="xScale"
|
342 | [yScale]="yScale"
|
343 | [colors]="colors"
|
344 | [data]="series"
|
345 | [scaleType]="scaleType"
|
346 | [visibleValue]="hoveredVertical"
|
347 | [activeEntries]="activeEntries"
|
348 | [tooltipDisabled]="tooltipDisabled"
|
349 | [tooltipTemplate]="tooltipTemplate"
|
350 | (select)="onClick($event)"
|
351 | (activate)="onActivate($event)"
|
352 | (deactivate)="onDeactivate($event)"
|
353 | />
|
354 | </svg:g>
|
355 | </svg:g>
|
356 | </svg:g>
|
357 | </svg:g>
|
358 | <svg:g
|
359 | ngx-charts-timeline
|
360 | *ngIf="timeline && scaleType != 'ordinal'"
|
361 | [attr.transform]="timelineTransform"
|
362 | [results]="results"
|
363 | [view]="[timelineWidth, height]"
|
364 | [height]="timelineHeight"
|
365 | [scheme]="scheme"
|
366 | [customColors]="customColors"
|
367 | [scaleType]="scaleType"
|
368 | [legend]="legend"
|
369 | (onDomainChange)="updateDomain($event)"
|
370 | >
|
371 | <svg:g *ngFor="let series of results; trackBy: trackBy">
|
372 | <svg:g
|
373 | ngx-charts-line-series
|
374 | [xScale]="timelineXScale"
|
375 | [yScale]="timelineYScale"
|
376 | [colors]="colors"
|
377 | [data]="series"
|
378 | [scaleType]="scaleType"
|
379 | [curve]="curve"
|
380 | [hasRange]="hasRange"
|
381 | [animations]="animations"
|
382 | />
|
383 | </svg:g>
|
384 | </svg:g>
|
385 | </ngx-charts-chart>
|
386 | `,
|
387 | encapsulation: ViewEncapsulation.None,
|
388 | changeDetection: ChangeDetectionStrategy.OnPush,
|
389 | animations: [
|
390 | trigger('animationState', [
|
391 | transition(':leave', [
|
392 | style({
|
393 | opacity: 1
|
394 | }),
|
395 | animate(500, style({
|
396 | opacity: 0
|
397 | }))
|
398 | ])
|
399 | ])
|
400 | ],
|
401 | styles: [".ngx-charts{float:left;overflow:visible}.ngx-charts .arc,.ngx-charts .bar,.ngx-charts .cell,.ngx-charts .circle{cursor:pointer}.ngx-charts .arc.active,.ngx-charts .arc:hover,.ngx-charts .bar.active,.ngx-charts .bar:hover,.ngx-charts .card.active,.ngx-charts .card:hover,.ngx-charts .cell.active,.ngx-charts .cell:hover{opacity:.8;transition:opacity .1s ease-in-out}.ngx-charts .arc:focus,.ngx-charts .bar:focus,.ngx-charts .card:focus,.ngx-charts .cell:focus{outline:none}.ngx-charts .arc.hidden,.ngx-charts .bar.hidden,.ngx-charts .card.hidden,.ngx-charts .cell.hidden{display:none}.ngx-charts g:focus{outline:none}.ngx-charts .area-series.inactive,.ngx-charts .line-series-range.inactive,.ngx-charts .line-series.inactive,.ngx-charts .polar-series-area.inactive,.ngx-charts .polar-series-path.inactive{transition:opacity .1s ease-in-out;opacity:.2}.ngx-charts .line-highlight{display:none}.ngx-charts .line-highlight.active{display:block}.ngx-charts .area{opacity:.6}.ngx-charts .circle:hover{cursor:pointer}.ngx-charts .label{font-size:12px;font-weight:400}.ngx-charts .tooltip-anchor{fill:#000}.ngx-charts .gridline-path{stroke:#ddd;stroke-width:1;fill:none}.ngx-charts .refline-path{stroke:#a8b2c7;stroke-width:1;stroke-dasharray:5;stroke-dashoffset:5}.ngx-charts .refline-label{font-size:9px}.ngx-charts .reference-area{fill-opacity:.05;fill:#000}.ngx-charts .gridline-path-dotted{stroke:#ddd;stroke-width:1;fill:none;stroke-dasharray:1,20;stroke-dashoffset:3}.ngx-charts .grid-panel rect{fill:none}.ngx-charts .grid-panel.odd rect{fill:rgba(0,0,0,.05)}"]
|
402 | },] }
|
403 | ];
|
404 | LineChartComponent.propDecorators = {
|
405 | legend: [{ type: Input }],
|
406 | legendTitle: [{ type: Input }],
|
407 | legendPosition: [{ type: Input }],
|
408 | xAxis: [{ type: Input }],
|
409 | yAxis: [{ type: Input }],
|
410 | showXAxisLabel: [{ type: Input }],
|
411 | showYAxisLabel: [{ type: Input }],
|
412 | xAxisLabel: [{ type: Input }],
|
413 | yAxisLabel: [{ type: Input }],
|
414 | autoScale: [{ type: Input }],
|
415 | timeline: [{ type: Input }],
|
416 | gradient: [{ type: Input }],
|
417 | showGridLines: [{ type: Input }],
|
418 | curve: [{ type: Input }],
|
419 | activeEntries: [{ type: Input }],
|
420 | schemeType: [{ type: Input }],
|
421 | rangeFillOpacity: [{ type: Input }],
|
422 | trimXAxisTicks: [{ type: Input }],
|
423 | trimYAxisTicks: [{ type: Input }],
|
424 | rotateXAxisTicks: [{ type: Input }],
|
425 | maxXAxisTickLength: [{ type: Input }],
|
426 | maxYAxisTickLength: [{ type: Input }],
|
427 | xAxisTickFormatting: [{ type: Input }],
|
428 | yAxisTickFormatting: [{ type: Input }],
|
429 | xAxisTicks: [{ type: Input }],
|
430 | yAxisTicks: [{ type: Input }],
|
431 | roundDomains: [{ type: Input }],
|
432 | tooltipDisabled: [{ type: Input }],
|
433 | showRefLines: [{ type: Input }],
|
434 | referenceLines: [{ type: Input }],
|
435 | showRefLabels: [{ type: Input }],
|
436 | xScaleMin: [{ type: Input }],
|
437 | xScaleMax: [{ type: Input }],
|
438 | yScaleMin: [{ type: Input }],
|
439 | yScaleMax: [{ type: Input }],
|
440 | activate: [{ type: Output }],
|
441 | deactivate: [{ type: Output }],
|
442 | tooltipTemplate: [{ type: ContentChild, args: ['tooltipTemplate',] }],
|
443 | seriesTooltipTemplate: [{ type: ContentChild, args: ['seriesTooltipTemplate',] }],
|
444 | hideCircles: [{ type: HostListener, args: ['mouseleave',] }]
|
445 | };
|
446 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/swimlane/ngx-charts/src/lib/line-chart/line-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\n  HostListener,\n  ChangeDetectionStrategy,\n  ContentChild,\n  TemplateRef\n} from '@angular/core';\nimport { trigger, style, animate, transition } from '@angular/animations';\nimport { scaleLinear, scaleTime, scalePoint } from 'd3-scale';\nimport { curveLinear } from 'd3-shape';\n\nimport { calculateViewDimensions } from '../common/view-dimensions.helper';\nimport { ColorHelper } from '../common/color.helper';\nimport { BaseChartComponent } from '../common/base-chart.component';\nimport { id } from '../utils/id';\nimport { getUniqueXDomainValues, getScaleType } from '../common/domain.helper';\nimport { LegendOptions, LegendPosition } from '../common/types/legend.model';\nimport { ScaleType } from '../common/types/scale-type.enum';\nimport { ViewDimensions } from '../common/types/view-dimension.interface';\n\n@Component({\n  selector: 'ngx-charts-line-chart',\n  template: `\n    <ngx-charts-chart\n      [view]=\"[width, height]\"\n      [showLegend]=\"legend\"\n      [legendOptions]=\"legendOptions\"\n      [activeEntries]=\"activeEntries\"\n      [animations]=\"animations\"\n      (legendLabelClick)=\"onClick($event)\"\n      (legendLabelActivate)=\"onActivate($event)\"\n      (legendLabelDeactivate)=\"onDeactivate($event)\"\n    >\n      <svg:defs>\n        <svg:clipPath [attr.id]=\"clipPathId\">\n          <svg:rect\n            [attr.width]=\"dims.width + 10\"\n            [attr.height]=\"dims.height + 10\"\n            [attr.transform]=\"'translate(-5, -5)'\"\n          />\n        </svg:clipPath>\n      </svg:defs>\n      <svg:g [attr.transform]=\"transform\" class=\"line-chart chart\">\n        <svg:g\n          ngx-charts-x-axis\n          *ngIf=\"xAxis\"\n          [xScale]=\"xScale\"\n          [dims]=\"dims\"\n          [showGridLines]=\"showGridLines\"\n          [showLabel]=\"showXAxisLabel\"\n          [labelText]=\"xAxisLabel\"\n          [trimTicks]=\"trimXAxisTicks\"\n          [rotateTicks]=\"rotateXAxisTicks\"\n          [maxTickLength]=\"maxXAxisTickLength\"\n          [tickFormatting]=\"xAxisTickFormatting\"\n          [ticks]=\"xAxisTicks\"\n          (dimensionsChanged)=\"updateXAxisHeight($event)\"\n        ></svg:g>\n        <svg:g\n          ngx-charts-y-axis\n          *ngIf=\"yAxis\"\n          [yScale]=\"yScale\"\n          [dims]=\"dims\"\n          [showGridLines]=\"showGridLines\"\n          [showLabel]=\"showYAxisLabel\"\n          [labelText]=\"yAxisLabel\"\n          [trimTicks]=\"trimYAxisTicks\"\n          [maxTickLength]=\"maxYAxisTickLength\"\n          [tickFormatting]=\"yAxisTickFormatting\"\n          [ticks]=\"yAxisTicks\"\n          [referenceLines]=\"referenceLines\"\n          [showRefLines]=\"showRefLines\"\n          [showRefLabels]=\"showRefLabels\"\n          (dimensionsChanged)=\"updateYAxisWidth($event)\"\n        ></svg:g>\n        <svg:g [attr.clip-path]=\"clipPath\">\n          <svg:g *ngFor=\"let series of results; trackBy: trackBy\" [@animationState]=\"'active'\">\n            <svg:g\n              ngx-charts-line-series\n              [xScale]=\"xScale\"\n              [yScale]=\"yScale\"\n              [colors]=\"colors\"\n              [data]=\"series\"\n              [activeEntries]=\"activeEntries\"\n              [scaleType]=\"scaleType\"\n              [curve]=\"curve\"\n              [rangeFillOpacity]=\"rangeFillOpacity\"\n              [hasRange]=\"hasRange\"\n              [animations]=\"animations\"\n            />\n          </svg:g>\n\n          <svg:g *ngIf=\"!tooltipDisabled\" (mouseleave)=\"hideCircles()\">\n            <svg:g\n              ngx-charts-tooltip-area\n              [dims]=\"dims\"\n              [xSet]=\"xSet\"\n              [xScale]=\"xScale\"\n              [yScale]=\"yScale\"\n              [results]=\"results\"\n              [colors]=\"colors\"\n              [tooltipDisabled]=\"tooltipDisabled\"\n              [tooltipTemplate]=\"seriesTooltipTemplate\"\n              (hover)=\"updateHoveredVertical($event)\"\n            />\n\n            <svg:g *ngFor=\"let series of results\">\n              <svg:g\n                ngx-charts-circle-series\n                [xScale]=\"xScale\"\n                [yScale]=\"yScale\"\n                [colors]=\"colors\"\n                [data]=\"series\"\n                [scaleType]=\"scaleType\"\n                [visibleValue]=\"hoveredVertical\"\n                [activeEntries]=\"activeEntries\"\n                [tooltipDisabled]=\"tooltipDisabled\"\n                [tooltipTemplate]=\"tooltipTemplate\"\n                (select)=\"onClick($event)\"\n                (activate)=\"onActivate($event)\"\n                (deactivate)=\"onDeactivate($event)\"\n              />\n            </svg:g>\n          </svg:g>\n        </svg:g>\n      </svg:g>\n      <svg:g\n        ngx-charts-timeline\n        *ngIf=\"timeline && scaleType != 'ordinal'\"\n        [attr.transform]=\"timelineTransform\"\n        [results]=\"results\"\n        [view]=\"[timelineWidth, height]\"\n        [height]=\"timelineHeight\"\n        [scheme]=\"scheme\"\n        [customColors]=\"customColors\"\n        [scaleType]=\"scaleType\"\n        [legend]=\"legend\"\n        (onDomainChange)=\"updateDomain($event)\"\n      >\n        <svg:g *ngFor=\"let series of results; trackBy: trackBy\">\n          <svg:g\n            ngx-charts-line-series\n            [xScale]=\"timelineXScale\"\n            [yScale]=\"timelineYScale\"\n            [colors]=\"colors\"\n            [data]=\"series\"\n            [scaleType]=\"scaleType\"\n            [curve]=\"curve\"\n            [hasRange]=\"hasRange\"\n            [animations]=\"animations\"\n          />\n        </svg:g>\n      </svg:g>\n    </ngx-charts-chart>\n  `,\n  styleUrls: ['../common/base-chart.component.scss'],\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  animations: [\n    trigger('animationState', [\n      transition(':leave', [\n        style({\n          opacity: 1\n        }),\n        animate(\n          500,\n          style({\n            opacity: 0\n          })\n        )\n      ])\n    ])\n  ]\n})\nexport class LineChartComponent extends BaseChartComponent {\n  @Input() legend: boolean;\n  @Input() legendTitle: string = 'Legend';\n  @Input() legendPosition: LegendPosition = LegendPosition.Right;\n  @Input() xAxis: boolean;\n  @Input() yAxis: boolean;\n  @Input() showXAxisLabel: boolean;\n  @Input() showYAxisLabel: boolean;\n  @Input() xAxisLabel: string;\n  @Input() yAxisLabel: string;\n  @Input() autoScale: boolean;\n  @Input() timeline: boolean;\n  @Input() gradient: boolean;\n  @Input() showGridLines: boolean = true;\n  @Input() curve: any = curveLinear;\n  @Input() activeEntries: any[] = [];\n  @Input() schemeType: ScaleType;\n  @Input() rangeFillOpacity: number;\n  @Input() trimXAxisTicks: boolean = true;\n  @Input() trimYAxisTicks: boolean = true;\n  @Input() rotateXAxisTicks: boolean = true;\n  @Input() maxXAxisTickLength: number = 16;\n  @Input() maxYAxisTickLength: number = 16;\n  @Input() xAxisTickFormatting: any;\n  @Input() yAxisTickFormatting: any;\n  @Input() xAxisTicks: any[];\n  @Input() yAxisTicks: any[];\n  @Input() roundDomains: boolean = false;\n  @Input() tooltipDisabled: boolean = false;\n  @Input() showRefLines: boolean = false;\n  @Input() referenceLines: any;\n  @Input() showRefLabels: boolean = true;\n  @Input() xScaleMin: number;\n  @Input() xScaleMax: number;\n  @Input() yScaleMin: number;\n  @Input() yScaleMax: number;\n\n  @Output() activate: EventEmitter<any> = new EventEmitter();\n  @Output() deactivate: EventEmitter<any> = new EventEmitter();\n\n  @ContentChild('tooltipTemplate') tooltipTemplate: TemplateRef<any>;\n  @ContentChild('seriesTooltipTemplate') seriesTooltipTemplate: TemplateRef<any>;\n\n  dims: ViewDimensions;\n  xSet: any;\n  xDomain: any;\n  yDomain: [number, number];\n  seriesDomain: any;\n  yScale: any;\n  xScale: any;\n  colors: ColorHelper;\n  scaleType: ScaleType;\n  transform: string;\n  clipPath: string;\n  clipPathId: string;\n  areaPath: any;\n  margin: number[] = [10, 20, 10, 20];\n  hoveredVertical: any; // the value of the x axis that is hovered over\n  xAxisHeight: number = 0;\n  yAxisWidth: number = 0;\n  filteredDomain: any;\n  legendOptions: any;\n  hasRange: boolean; // whether the line has a min-max range around it\n  timelineWidth: any;\n  timelineHeight: number = 50;\n  timelineXScale: any;\n  timelineYScale: any;\n  timelineXDomain: any;\n  timelineTransform: any;\n  timelinePadding: number = 10;\n\n  update(): void {\n    super.update();\n\n    this.dims = calculateViewDimensions({\n      width: this.width,\n      height: this.height,\n      margins: this.margin,\n      showXAxis: this.xAxis,\n      showYAxis: this.yAxis,\n      xAxisHeight: this.xAxisHeight,\n      yAxisWidth: this.yAxisWidth,\n      showXLabel: this.showXAxisLabel,\n      showYLabel: this.showYAxisLabel,\n      showLegend: this.legend,\n      legendType: this.schemeType,\n      legendPosition: this.legendPosition\n    });\n\n    if (this.timeline) {\n      this.dims.height -= this.timelineHeight + this.margin[2] + this.timelinePadding;\n    }\n\n    this.xDomain = this.getXDomain();\n    if (this.filteredDomain) {\n      this.xDomain = this.filteredDomain;\n    }\n\n    this.yDomain = this.getYDomain();\n    this.seriesDomain = this.getSeriesDomain();\n\n    this.xScale = this.getXScale(this.xDomain, this.dims.width);\n    this.yScale = this.getYScale(this.yDomain, this.dims.height);\n\n    this.updateTimeline();\n\n    this.setColors();\n    this.legendOptions = this.getLegendOptions();\n\n    this.transform = `translate(${this.dims.xOffset} , ${this.margin[0]})`;\n\n    this.clipPathId = 'clip' + id().toString();\n    this.clipPath = `url(#${this.clipPathId})`;\n  }\n\n  updateTimeline(): void {\n    if (this.timeline) {\n      this.timelineWidth = this.dims.width;\n      this.timelineXDomain = this.getXDomain();\n      this.timelineXScale = this.getXScale(this.timelineXDomain, this.timelineWidth);\n      this.timelineYScale = this.getYScale(this.yDomain, this.timelineHeight);\n      this.timelineTransform = `translate(${this.dims.xOffset}, ${-this.margin[2]})`;\n    }\n  }\n\n  getXDomain(): any[] {\n    let values = getUniqueXDomainValues(this.results);\n\n    this.scaleType = getScaleType(values);\n    let domain = [];\n\n    if (this.scaleType === ScaleType.Linear) {\n      values = values.map(v => Number(v));\n    }\n\n    let min;\n    let max;\n    if (this.scaleType === ScaleType.Time || this.scaleType === ScaleType.Linear) {\n      min = this.xScaleMin ? this.xScaleMin : Math.min(...values);\n\n      max = this.xScaleMax ? this.xScaleMax : Math.max(...values);\n    }\n\n    if (this.scaleType === ScaleType.Time) {\n      domain = [new Date(min), new Date(max)];\n      this.xSet = [...values].sort((a, b) => {\n        const aDate = a.getTime();\n        const bDate = b.getTime();\n        if (aDate > bDate) return 1;\n        if (bDate > aDate) return -1;\n        return 0;\n      });\n    } else if (this.scaleType === ScaleType.Linear) {\n      domain = [min, max];\n      // Use compare function to sort numbers numerically\n      this.xSet = [...values].sort((a, b) => a - b);\n    } else {\n      domain = values;\n      this.xSet = values;\n    }\n\n    return domain;\n  }\n\n  getYDomain(): [number, number] {\n    const domain = [];\n    for (const results of this.results) {\n      for (const d of results.series) {\n        if (domain.indexOf(d.value) < 0) {\n          domain.push(d.value);\n        }\n        if (d.min !== undefined) {\n          this.hasRange = true;\n          if (domain.indexOf(d.min) < 0) {\n            domain.push(d.min);\n          }\n        }\n        if (d.max !== undefined) {\n          this.hasRange = true;\n          if (domain.indexOf(d.max) < 0) {\n            domain.push(d.max);\n          }\n        }\n      }\n    }\n\n    const values = [...domain];\n    if (!this.autoScale) {\n      values.push(0);\n    }\n\n    const min = this.yScaleMin ? this.yScaleMin : Math.min(...values);\n\n    const max = this.yScaleMax ? this.yScaleMax : Math.max(...values);\n\n    return [min, max];\n  }\n\n  getSeriesDomain(): string[] {\n    return this.results.map(d => d.name);\n  }\n\n  getXScale(domain, width: number): any {\n    let scale;\n\n    if (this.scaleType === ScaleType.Time) {\n      scale = scaleTime().range([0, width]).domain(domain);\n    } else if (this.scaleType === ScaleType.Linear) {\n      scale = scaleLinear().range([0, width]).domain(domain);\n\n      if (this.roundDomains) {\n        scale = scale.nice();\n      }\n    } else if (this.scaleType === ScaleType.Ordinal) {\n      scale = scalePoint().range([0, width]).padding(0.1).domain(domain);\n    }\n\n    return scale;\n  }\n\n  getYScale(domain, height: number): any {\n    const scale = scaleLinear().range([height, 0]).domain(domain);\n\n    return this.roundDomains ? scale.nice() : scale;\n  }\n\n  updateDomain(domain): void {\n    this.filteredDomain = domain;\n    this.xDomain = this.filteredDomain;\n    this.xScale = this.getXScale(this.xDomain, this.dims.width);\n  }\n\n  updateHoveredVertical(item): void {\n    this.hoveredVertical = item.value;\n    this.deactivateAll();\n  }\n\n  @HostListener('mouseleave')\n  hideCircles(): void {\n    this.hoveredVertical = null;\n    this.deactivateAll();\n  }\n\n  onClick(data): void {\n    this.select.emit(data);\n  }\n\n  trackBy(index: number, item): string {\n    return `${item.name}`;\n  }\n\n  setColors(): void {\n    let domain;\n    if (this.schemeType === ScaleType.Ordinal) {\n      domain = this.seriesDomain;\n    } else {\n      domain = this.yDomain;\n    }\n\n    this.colors = new ColorHelper(this.scheme, this.schemeType, domain, this.customColors);\n  }\n\n  getLegendOptions(): LegendOptions {\n    const opts = {\n      scaleType: this.schemeType as any,\n      colors: undefined,\n      domain: [],\n      title: undefined,\n      position: this.legendPosition\n    };\n    if (opts.scaleType === ScaleType.Ordinal) {\n      opts.domain = this.seriesDomain;\n      opts.colors = this.colors;\n      opts.title = this.legendTitle;\n    } else {\n      opts.domain = this.yDomain;\n      opts.colors = this.colors.scale;\n    }\n    return opts;\n  }\n\n  updateYAxisWidth({ width }: { width: number }): void {\n    this.yAxisWidth = width;\n    this.update();\n  }\n\n  updateXAxisHeight({ height }: { height: number }): void {\n    this.xAxisHeight = height;\n    this.update();\n  }\n\n  onActivate(item): void {\n    this.deactivateAll();\n\n    const idx = this.activeEntries.findIndex(d => {\n      return d.name === item.name && d.value === item.value;\n    });\n    if (idx > -1) {\n      return;\n    }\n\n    this.activeEntries = [item];\n    this.activate.emit({ value: item, entries: this.activeEntries });\n  }\n\n  onDeactivate(item): void {\n    const idx = this.activeEntries.findIndex(d => {\n      return d.name === item.name && d.value === item.value;\n    });\n\n    this.activeEntries.splice(idx, 1);\n    this.activeEntries = [...this.activeEntries];\n\n    this.deactivate.emit({ value: item, entries: this.activeEntries });\n  }\n\n  deactivateAll(): void {\n    this.activeEntries = [...this.activeEntries];\n    for (const entry of this.activeEntries) {\n      this.deactivate.emit({ value: entry, entries: [] });\n    }\n    this.activeEntries = [];\n  }\n}\n"]} |
\ | No newline at end of file |