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