1 | import { Component, Input, Output, EventEmitter, ViewEncapsulation, ChangeDetectionStrategy, ContentChild } from '@angular/core';
|
2 | import { trigger, style, animate, transition } from '@angular/animations';
|
3 | import { scaleLinear, scaleTime, scalePoint } from 'd3-scale';
|
4 | import { curveCardinalClosed } 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 { getScaleType } from '../common/domain.helper';
|
9 | import { isDate } from '../utils/types';
|
10 | import { LegendPosition } from '../common/types/legend.model';
|
11 | import { ScaleType } from '../common/types/scale-type.enum';
|
12 | import { Orientation } from '../common/types/orientation.enum';
|
13 | const twoPI = 2 * Math.PI;
|
14 | export class PolarChartComponent extends BaseChartComponent {
|
15 | constructor() {
|
16 | super(...arguments);
|
17 | this.legendTitle = 'Legend';
|
18 | this.legendPosition = LegendPosition.Right;
|
19 | this.showGridLines = true;
|
20 | this.curve = curveCardinalClosed;
|
21 | this.activeEntries = [];
|
22 | this.rangeFillOpacity = 0.15;
|
23 | this.trimYAxisTicks = true;
|
24 | this.maxYAxisTickLength = 16;
|
25 | this.roundDomains = false;
|
26 | this.tooltipDisabled = false;
|
27 | this.showSeriesOnHover = true;
|
28 | this.gradient = false;
|
29 | this.yAxisMinScale = 0;
|
30 | this.labelTrim = true;
|
31 | this.labelTrimSize = 10;
|
32 | this.activate = new EventEmitter();
|
33 | this.deactivate = new EventEmitter();
|
34 | // series: any; // ???
|
35 | this.margin = [10, 20, 10, 20];
|
36 | this.xAxisHeight = 0;
|
37 | this.yAxisWidth = 0;
|
38 | this.orientation = Orientation;
|
39 | }
|
40 | update() {
|
41 | super.update();
|
42 | this.setDims();
|
43 | this.setScales();
|
44 | this.setColors();
|
45 | this.legendOptions = this.getLegendOptions();
|
46 | this.setTicks();
|
47 | }
|
48 | setDims() {
|
49 | this.dims = calculateViewDimensions({
|
50 | width: this.width,
|
51 | height: this.height,
|
52 | margins: this.margin,
|
53 | showXAxis: this.xAxis,
|
54 | showYAxis: this.yAxis,
|
55 | xAxisHeight: this.xAxisHeight,
|
56 | yAxisWidth: this.yAxisWidth,
|
57 | showXLabel: this.showXAxisLabel,
|
58 | showYLabel: this.showYAxisLabel,
|
59 | showLegend: this.legend,
|
60 | legendType: this.schemeType,
|
61 | legendPosition: this.legendPosition
|
62 | });
|
63 | const halfWidth = Math.floor(this.dims.width / 2);
|
64 | const halfHeight = Math.floor(this.dims.height / 2);
|
65 | const outerRadius = (this.outerRadius = Math.min(halfHeight / 1.5, halfWidth / 1.5));
|
66 | const yOffset = Math.max(0, halfHeight - outerRadius);
|
67 | this.yAxisDims = Object.assign(Object.assign({}, this.dims), { width: halfWidth });
|
68 | this.transform = `translate(${this.dims.xOffset}, ${this.margin[0]})`;
|
69 | this.transformYAxis = `translate(0, ${yOffset})`;
|
70 | this.labelOffset = this.dims.height + 40;
|
71 | this.transformPlot = `translate(${halfWidth}, ${halfHeight})`;
|
72 | }
|
73 | setScales() {
|
74 | const xValues = this.getXValues();
|
75 | this.scaleType = getScaleType(xValues);
|
76 | this.xDomain = this.filteredDomain || this.getXDomain(xValues);
|
77 | this.yDomain = this.getYDomain();
|
78 | this.seriesDomain = this.getSeriesDomain();
|
79 | this.xScale = this.getXScale(this.xDomain, twoPI);
|
80 | this.yScale = this.getYScale(this.yDomain, this.outerRadius);
|
81 | this.yAxisScale = this.getYScale(this.yDomain.reverse(), this.outerRadius);
|
82 | }
|
83 | setTicks() {
|
84 | let tickFormat;
|
85 | if (this.xAxisTickFormatting) {
|
86 | tickFormat = this.xAxisTickFormatting;
|
87 | }
|
88 | else if (this.xScale.tickFormat) {
|
89 | tickFormat = this.xScale.tickFormat.apply(this.xScale, [5]);
|
90 | }
|
91 | else {
|
92 | tickFormat = d => {
|
93 | if (isDate(d)) {
|
94 | return d.toLocaleDateString();
|
95 | }
|
96 | return d.toLocaleString();
|
97 | };
|
98 | }
|
99 | const outerRadius = this.outerRadius;
|
100 | const s = 1.1;
|
101 | this.thetaTicks = this.xDomain.map(d => {
|
102 | const startAngle = this.xScale(d);
|
103 | const dd = s * outerRadius * (startAngle > Math.PI ? -1 : 1);
|
104 | const label = tickFormat(d);
|
105 | const startPos = [outerRadius * Math.sin(startAngle), -outerRadius * Math.cos(startAngle)];
|
106 | const pos = [dd, s * startPos[1]];
|
107 | return {
|
108 | innerRadius: 0,
|
109 | outerRadius,
|
110 | startAngle,
|
111 | endAngle: startAngle,
|
112 | value: outerRadius,
|
113 | label,
|
114 | startPos,
|
115 | pos
|
116 | };
|
117 | });
|
118 | const minDistance = 10;
|
119 | /* from pie chart, abstract out -*/
|
120 | for (let i = 0; i < this.thetaTicks.length - 1; i++) {
|
121 | const a = this.thetaTicks[i];
|
122 | for (let j = i + 1; j < this.thetaTicks.length; j++) {
|
123 | const b = this.thetaTicks[j];
|
124 | // if they're on the same side
|
125 | if (b.pos[0] * a.pos[0] > 0) {
|
126 | // if they're overlapping
|
127 | const o = minDistance - Math.abs(b.pos[1] - a.pos[1]);
|
128 | if (o > 0) {
|
129 | // push the second up or down
|
130 | b.pos[1] += Math.sign(b.pos[0]) * o;
|
131 | }
|
132 | }
|
133 | }
|
134 | }
|
135 | this.radiusTicks = this.yAxisScale.ticks(Math.floor(this.dims.height / 50)).map(d => this.yScale(d));
|
136 | }
|
137 | getXValues() {
|
138 | const values = [];
|
139 | for (const results of this.results) {
|
140 | for (const d of results.series) {
|
141 | if (!values.includes(d.name)) {
|
142 | values.push(d.name);
|
143 | }
|
144 | }
|
145 | }
|
146 | return values;
|
147 | }
|
148 | getXDomain(values = this.getXValues()) {
|
149 | if (this.scaleType === ScaleType.Time) {
|
150 | const min = Math.min(...values);
|
151 | const max = Math.max(...values);
|
152 | return [min, max];
|
153 | }
|
154 | else if (this.scaleType === ScaleType.Linear) {
|
155 | values = values.map(v => Number(v));
|
156 | const min = Math.min(...values);
|
157 | const max = Math.max(...values);
|
158 | return [min, max];
|
159 | }
|
160 | return values;
|
161 | }
|
162 | getYValues() {
|
163 | const domain = [];
|
164 | for (const results of this.results) {
|
165 | for (const d of results.series) {
|
166 | if (domain.indexOf(d.value) < 0) {
|
167 | domain.push(d.value);
|
168 | }
|
169 | if (d.min !== undefined) {
|
170 | if (domain.indexOf(d.min) < 0) {
|
171 | domain.push(d.min);
|
172 | }
|
173 | }
|
174 | if (d.max !== undefined) {
|
175 | if (domain.indexOf(d.max) < 0) {
|
176 | domain.push(d.max);
|
177 | }
|
178 | }
|
179 | }
|
180 | }
|
181 | return domain;
|
182 | }
|
183 | getYDomain(domain = this.getYValues()) {
|
184 | let min = Math.min(...domain);
|
185 | const max = Math.max(this.yAxisMinScale, ...domain);
|
186 | min = Math.max(0, min);
|
187 | if (!this.autoScale) {
|
188 | min = Math.min(0, min);
|
189 | }
|
190 | return [min, max];
|
191 | }
|
192 | getSeriesDomain() {
|
193 | return this.results.map(d => d.name);
|
194 | }
|
195 | getXScale(domain, width) {
|
196 | switch (this.scaleType) {
|
197 | case ScaleType.Time:
|
198 | return scaleTime().range([0, width]).domain(domain);
|
199 | case ScaleType.Linear:
|
200 | const scale = scaleLinear().range([0, width]).domain(domain);
|
201 | return this.roundDomains ? scale.nice() : scale;
|
202 | default:
|
203 | return scalePoint()
|
204 | .range([0, width - twoPI / domain.length])
|
205 | .padding(0)
|
206 | .domain(domain);
|
207 | }
|
208 | }
|
209 | getYScale(domain, height) {
|
210 | const scale = scaleLinear().range([0, height]).domain(domain);
|
211 | return this.roundDomains ? scale.nice() : scale;
|
212 | }
|
213 | onClick(data, series) {
|
214 | if (series) {
|
215 | data.series = series.name;
|
216 | }
|
217 | this.select.emit(data);
|
218 | }
|
219 | setColors() {
|
220 | const domain = this.schemeType === ScaleType.Ordinal ? this.seriesDomain : this.yDomain.reverse();
|
221 | this.colors = new ColorHelper(this.scheme, this.schemeType, domain, this.customColors);
|
222 | }
|
223 | getLegendOptions() {
|
224 | if (this.schemeType === ScaleType.Ordinal) {
|
225 | return {
|
226 | scaleType: this.schemeType,
|
227 | colors: this.colors,
|
228 | domain: this.seriesDomain,
|
229 | title: this.legendTitle,
|
230 | position: this.legendPosition
|
231 | };
|
232 | }
|
233 | return {
|
234 | scaleType: this.schemeType,
|
235 | colors: this.colors.scale,
|
236 | domain: this.yDomain,
|
237 | title: undefined,
|
238 | position: this.legendPosition
|
239 | };
|
240 | }
|
241 | updateYAxisWidth({ width }) {
|
242 | this.yAxisWidth = width;
|
243 | this.update();
|
244 | }
|
245 | updateXAxisHeight({ height }) {
|
246 | this.xAxisHeight = height;
|
247 | this.update();
|
248 | }
|
249 | onActivate(item) {
|
250 | const idx = this.activeEntries.findIndex(d => {
|
251 | return d.name === item.name && d.value === item.value;
|
252 | });
|
253 | if (idx > -1) {
|
254 | return;
|
255 | }
|
256 | this.activeEntries = this.showSeriesOnHover ? [item, ...this.activeEntries] : this.activeEntries;
|
257 | this.activate.emit({ value: item, entries: this.activeEntries });
|
258 | }
|
259 | onDeactivate(item) {
|
260 | const idx = this.activeEntries.findIndex(d => {
|
261 | return d.name === item.name && d.value === item.value;
|
262 | });
|
263 | this.activeEntries.splice(idx, 1);
|
264 | this.activeEntries = [...this.activeEntries];
|
265 | this.deactivate.emit({ value: item, entries: this.activeEntries });
|
266 | }
|
267 | deactivateAll() {
|
268 | this.activeEntries = [...this.activeEntries];
|
269 | for (const entry of this.activeEntries) {
|
270 | this.deactivate.emit({ value: entry, entries: [] });
|
271 | }
|
272 | this.activeEntries = [];
|
273 | }
|
274 | trackBy(index, item) {
|
275 | return `${item.name}`;
|
276 | }
|
277 | }
|
278 | PolarChartComponent.decorators = [
|
279 | { type: Component, args: [{
|
280 | selector: 'ngx-charts-polar-chart',
|
281 | template: `
|
282 | <ngx-charts-chart
|
283 | [view]="[width, height]"
|
284 | [showLegend]="legend"
|
285 | [legendOptions]="legendOptions"
|
286 | [activeEntries]="activeEntries"
|
287 | [animations]="animations"
|
288 | (legendLabelClick)="onClick($event)"
|
289 | (legendLabelActivate)="onActivate($event)"
|
290 | (legendLabelDeactivate)="onDeactivate($event)"
|
291 | >
|
292 | <svg:g class="polar-chart chart" [attr.transform]="transform">
|
293 | <svg:g [attr.transform]="transformPlot">
|
294 | <svg:circle class="polar-chart-background" cx="0" cy="0" [attr.r]="this.outerRadius" />
|
295 | <svg:g *ngIf="showGridLines">
|
296 | <svg:circle
|
297 | *ngFor="let r of radiusTicks"
|
298 | class="gridline-path radial-gridline-path"
|
299 | cx="0"
|
300 | cy="0"
|
301 | [attr.r]="r"
|
302 | />
|
303 | </svg:g>
|
304 | <svg:g *ngIf="xAxis">
|
305 | <svg:g
|
306 | ngx-charts-pie-label
|
307 | *ngFor="let tick of thetaTicks"
|
308 | [data]="tick"
|
309 | [radius]="outerRadius"
|
310 | [label]="tick.label"
|
311 | [max]="outerRadius"
|
312 | [value]="showGridLines ? 1 : outerRadius"
|
313 | [explodeSlices]="true"
|
314 | [animations]="animations"
|
315 | [labelTrim]="labelTrim"
|
316 | [labelTrimSize]="labelTrimSize"
|
317 | ></svg:g>
|
318 | </svg:g>
|
319 | </svg:g>
|
320 | <svg:g
|
321 | ngx-charts-y-axis
|
322 | [attr.transform]="transformYAxis"
|
323 | *ngIf="yAxis"
|
324 | [yScale]="yAxisScale"
|
325 | [dims]="yAxisDims"
|
326 | [showGridLines]="showGridLines"
|
327 | [showLabel]="showYAxisLabel"
|
328 | [labelText]="yAxisLabel"
|
329 | [trimTicks]="trimYAxisTicks"
|
330 | [maxTickLength]="maxYAxisTickLength"
|
331 | [tickFormatting]="yAxisTickFormatting"
|
332 | (dimensionsChanged)="updateYAxisWidth($event)"
|
333 | ></svg:g>
|
334 | <svg:g
|
335 | ngx-charts-axis-label
|
336 | *ngIf="xAxis && showXAxisLabel"
|
337 | [label]="xAxisLabel"
|
338 | [offset]="labelOffset"
|
339 | [orient]="orientation.Bottom"
|
340 | [height]="dims.height"
|
341 | [width]="dims.width"
|
342 | ></svg:g>
|
343 | <svg:g [attr.transform]="transformPlot">
|
344 | <svg:g *ngFor="let series of results; trackBy: trackBy" [@animationState]="'active'">
|
345 | <svg:g
|
346 | ngx-charts-polar-series
|
347 | [gradient]="gradient"
|
348 | [xScale]="xScale"
|
349 | [yScale]="yScale"
|
350 | [colors]="colors"
|
351 | [data]="series"
|
352 | [activeEntries]="activeEntries"
|
353 | [scaleType]="scaleType"
|
354 | [curve]="curve"
|
355 | [rangeFillOpacity]="rangeFillOpacity"
|
356 | [animations]="animations"
|
357 | [tooltipDisabled]="tooltipDisabled"
|
358 | [tooltipTemplate]="tooltipTemplate"
|
359 | (select)="onClick($event)"
|
360 | (activate)="onActivate($event)"
|
361 | (deactivate)="onDeactivate($event)"
|
362 | />
|
363 | </svg:g>
|
364 | </svg:g>
|
365 | </svg:g>
|
366 | </ngx-charts-chart>
|
367 | `,
|
368 | encapsulation: ViewEncapsulation.None,
|
369 | changeDetection: ChangeDetectionStrategy.OnPush,
|
370 | animations: [
|
371 | trigger('animationState', [
|
372 | transition(':leave', [
|
373 | style({
|
374 | opacity: 1
|
375 | }),
|
376 | animate(500, style({
|
377 | opacity: 0
|
378 | }))
|
379 | ])
|
380 | ])
|
381 | ],
|
382 | 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)}", ".pie-label{font-size:11px}.pie-label.animation{-webkit-animation:fadeIn .75s ease-in;animation:fadeIn .75s ease-in}@-webkit-keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.pie-label-line{stroke-dasharray:100%}.pie-label-line.animation{-webkit-animation:drawOut 3s linear;animation:drawOut 3s linear;transition:d .75s}@-webkit-keyframes drawOut{0%{stroke-dashoffset:100%}to{stroke-dashoffset:0}}@keyframes drawOut{0%{stroke-dashoffset:100%}to{stroke-dashoffset:0}}", ".polar-chart .polar-chart-background{fill:none}.polar-chart .radial-gridline-path{stroke-dasharray:10 10;fill:none}.polar-chart .pie-label-line{stroke:#2f3646}.polar-charts-series .polar-series-area,.polar-series-path{pointer-events:none}"]
|
383 | },] }
|
384 | ];
|
385 | PolarChartComponent.propDecorators = {
|
386 | legend: [{ type: Input }],
|
387 | legendTitle: [{ type: Input }],
|
388 | legendPosition: [{ type: Input }],
|
389 | xAxis: [{ type: Input }],
|
390 | yAxis: [{ type: Input }],
|
391 | showXAxisLabel: [{ type: Input }],
|
392 | showYAxisLabel: [{ type: Input }],
|
393 | xAxisLabel: [{ type: Input }],
|
394 | yAxisLabel: [{ type: Input }],
|
395 | autoScale: [{ type: Input }],
|
396 | showGridLines: [{ type: Input }],
|
397 | curve: [{ type: Input }],
|
398 | activeEntries: [{ type: Input }],
|
399 | schemeType: [{ type: Input }],
|
400 | rangeFillOpacity: [{ type: Input }],
|
401 | trimYAxisTicks: [{ type: Input }],
|
402 | maxYAxisTickLength: [{ type: Input }],
|
403 | xAxisTickFormatting: [{ type: Input }],
|
404 | yAxisTickFormatting: [{ type: Input }],
|
405 | roundDomains: [{ type: Input }],
|
406 | tooltipDisabled: [{ type: Input }],
|
407 | showSeriesOnHover: [{ type: Input }],
|
408 | gradient: [{ type: Input }],
|
409 | yAxisMinScale: [{ type: Input }],
|
410 | labelTrim: [{ type: Input }],
|
411 | labelTrimSize: [{ type: Input }],
|
412 | activate: [{ type: Output }],
|
413 | deactivate: [{ type: Output }],
|
414 | tooltipTemplate: [{ type: ContentChild, args: ['tooltipTemplate',] }]
|
415 | };
|
416 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"polar-chart.component.js","sourceRoot":"","sources":["../../../../../../projects/swimlane/ngx-charts/src/lib/polar-chart/polar-chart.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  Output,\n  EventEmitter,\n  ViewEncapsulation,\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 { curveCardinalClosed } 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 { getScaleType } from '../common/domain.helper';\nimport { isDate } from '../utils/types';\nimport { LegendPosition } from '../common/types/legend.model';\nimport { ScaleType } from '../common/types/scale-type.enum';\nimport { ViewDimensions } from '../common/types/view-dimension.interface';\nimport { Orientation } from '../common/types/orientation.enum';\n\nconst twoPI = 2 * Math.PI;\n\n@Component({\n  selector: 'ngx-charts-polar-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:g class=\"polar-chart chart\" [attr.transform]=\"transform\">\n        <svg:g [attr.transform]=\"transformPlot\">\n          <svg:circle class=\"polar-chart-background\" cx=\"0\" cy=\"0\" [attr.r]=\"this.outerRadius\" />\n          <svg:g *ngIf=\"showGridLines\">\n            <svg:circle\n              *ngFor=\"let r of radiusTicks\"\n              class=\"gridline-path radial-gridline-path\"\n              cx=\"0\"\n              cy=\"0\"\n              [attr.r]=\"r\"\n            />\n          </svg:g>\n          <svg:g *ngIf=\"xAxis\">\n            <svg:g\n              ngx-charts-pie-label\n              *ngFor=\"let tick of thetaTicks\"\n              [data]=\"tick\"\n              [radius]=\"outerRadius\"\n              [label]=\"tick.label\"\n              [max]=\"outerRadius\"\n              [value]=\"showGridLines ? 1 : outerRadius\"\n              [explodeSlices]=\"true\"\n              [animations]=\"animations\"\n              [labelTrim]=\"labelTrim\"\n              [labelTrimSize]=\"labelTrimSize\"\n            ></svg:g>\n          </svg:g>\n        </svg:g>\n        <svg:g\n          ngx-charts-y-axis\n          [attr.transform]=\"transformYAxis\"\n          *ngIf=\"yAxis\"\n          [yScale]=\"yAxisScale\"\n          [dims]=\"yAxisDims\"\n          [showGridLines]=\"showGridLines\"\n          [showLabel]=\"showYAxisLabel\"\n          [labelText]=\"yAxisLabel\"\n          [trimTicks]=\"trimYAxisTicks\"\n          [maxTickLength]=\"maxYAxisTickLength\"\n          [tickFormatting]=\"yAxisTickFormatting\"\n          (dimensionsChanged)=\"updateYAxisWidth($event)\"\n        ></svg:g>\n        <svg:g\n          ngx-charts-axis-label\n          *ngIf=\"xAxis && showXAxisLabel\"\n          [label]=\"xAxisLabel\"\n          [offset]=\"labelOffset\"\n          [orient]=\"orientation.Bottom\"\n          [height]=\"dims.height\"\n          [width]=\"dims.width\"\n        ></svg:g>\n        <svg:g [attr.transform]=\"transformPlot\">\n          <svg:g *ngFor=\"let series of results; trackBy: trackBy\" [@animationState]=\"'active'\">\n            <svg:g\n              ngx-charts-polar-series\n              [gradient]=\"gradient\"\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              [animations]=\"animations\"\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    </ngx-charts-chart>\n  `,\n  styleUrls: [\n    '../common/base-chart.component.scss',\n    '../pie-chart/pie-chart.component.scss',\n    './polar-chart.component.scss'\n  ],\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 PolarChartComponent 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() showGridLines: boolean = true;\n  @Input() curve: any = curveCardinalClosed;\n  @Input() activeEntries: any[] = [];\n  @Input() schemeType: ScaleType;\n  @Input() rangeFillOpacity: number = 0.15;\n  @Input() trimYAxisTicks: boolean = true;\n  @Input() maxYAxisTickLength: number = 16;\n  @Input() xAxisTickFormatting: (o: any) => any;\n  @Input() yAxisTickFormatting: (o: any) => any;\n  @Input() roundDomains: boolean = false;\n  @Input() tooltipDisabled: boolean = false;\n  @Input() showSeriesOnHover: boolean = true;\n  @Input() gradient: boolean = false;\n  @Input() yAxisMinScale: number = 0;\n  @Input() labelTrim: boolean = true;\n  @Input() labelTrimSize: number = 10;\n\n  @Output() activate: EventEmitter<any> = new EventEmitter();\n  @Output() deactivate: EventEmitter<any> = new EventEmitter();\n\n  @ContentChild('tooltipTemplate') tooltipTemplate: TemplateRef<any>;\n\n  dims: ViewDimensions;\n  yAxisDims: ViewDimensions;\n  labelOffset: number;\n  xDomain: any;\n  yDomain: any;\n  seriesDomain: any;\n  yScale: any; // -> rScale\n  xScale: any; // -> tScale\n  yAxisScale: any; // -> yScale\n  colors: ColorHelper;\n  scaleType: ScaleType;\n  transform: string;\n  transformPlot: string;\n  transformYAxis: string;\n  transformXAxis: string;\n  // series: any; // ???\n  margin: number[] = [10, 20, 10, 20];\n  xAxisHeight: number = 0;\n  yAxisWidth: number = 0;\n  filteredDomain: any;\n  legendOptions: any;\n  thetaTicks: any[];\n  radiusTicks: number[];\n  outerRadius: number;\n\n  orientation = Orientation;\n\n  update(): void {\n    super.update();\n\n    this.setDims();\n\n    this.setScales();\n    this.setColors();\n    this.legendOptions = this.getLegendOptions();\n\n    this.setTicks();\n  }\n\n  setDims() {\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    const halfWidth = Math.floor(this.dims.width / 2);\n    const halfHeight = Math.floor(this.dims.height / 2);\n\n    const outerRadius = (this.outerRadius = Math.min(halfHeight / 1.5, halfWidth / 1.5));\n\n    const yOffset = Math.max(0, halfHeight - outerRadius);\n\n    this.yAxisDims = {\n      ...this.dims,\n      width: halfWidth\n    };\n\n    this.transform = `translate(${this.dims.xOffset}, ${this.margin[0]})`;\n    this.transformYAxis = `translate(0, ${yOffset})`;\n    this.labelOffset = this.dims.height + 40;\n    this.transformPlot = `translate(${halfWidth}, ${halfHeight})`;\n  }\n\n  setScales() {\n    const xValues = this.getXValues();\n    this.scaleType = getScaleType(xValues);\n    this.xDomain = this.filteredDomain || this.getXDomain(xValues);\n\n    this.yDomain = this.getYDomain();\n    this.seriesDomain = this.getSeriesDomain();\n\n    this.xScale = this.getXScale(this.xDomain, twoPI);\n    this.yScale = this.getYScale(this.yDomain, this.outerRadius);\n    this.yAxisScale = this.getYScale(this.yDomain.reverse(), this.outerRadius);\n  }\n\n  setTicks() {\n    let tickFormat;\n    if (this.xAxisTickFormatting) {\n      tickFormat = this.xAxisTickFormatting;\n    } else if (this.xScale.tickFormat) {\n      tickFormat = this.xScale.tickFormat.apply(this.xScale, [5]);\n    } else {\n      tickFormat = d => {\n        if (isDate(d)) {\n          return d.toLocaleDateString();\n        }\n        return d.toLocaleString();\n      };\n    }\n\n    const outerRadius = this.outerRadius;\n    const s = 1.1;\n\n    this.thetaTicks = this.xDomain.map(d => {\n      const startAngle = this.xScale(d);\n      const dd = s * outerRadius * (startAngle > Math.PI ? -1 : 1);\n      const label = tickFormat(d);\n\n      const startPos = [outerRadius * Math.sin(startAngle), -outerRadius * Math.cos(startAngle)];\n      const pos = [dd, s * startPos[1]];\n      return {\n        innerRadius: 0,\n        outerRadius,\n        startAngle,\n        endAngle: startAngle,\n        value: outerRadius,\n        label,\n        startPos,\n        pos\n      };\n    });\n\n    const minDistance = 10;\n\n    /* from pie chart, abstract out -*/\n    for (let i = 0; i < this.thetaTicks.length - 1; i++) {\n      const a = this.thetaTicks[i];\n\n      for (let j = i + 1; j < this.thetaTicks.length; j++) {\n        const b = this.thetaTicks[j];\n        // if they're on the same side\n        if (b.pos[0] * a.pos[0] > 0) {\n          // if they're overlapping\n          const o = minDistance - Math.abs(b.pos[1] - a.pos[1]);\n          if (o > 0) {\n            // push the second up or down\n            b.pos[1] += Math.sign(b.pos[0]) * o;\n          }\n        }\n      }\n    }\n\n    this.radiusTicks = this.yAxisScale.ticks(Math.floor(this.dims.height / 50)).map(d => this.yScale(d));\n  }\n\n  getXValues(): any[] {\n    const values = [];\n    for (const results of this.results) {\n      for (const d of results.series) {\n        if (!values.includes(d.name)) {\n          values.push(d.name);\n        }\n      }\n    }\n    return values;\n  }\n\n  getXDomain(values = this.getXValues()): any[] {\n    if (this.scaleType === ScaleType.Time) {\n      const min = Math.min(...values);\n      const max = Math.max(...values);\n      return [min, max];\n    } else if (this.scaleType === ScaleType.Linear) {\n      values = values.map(v => Number(v));\n      const min = Math.min(...values);\n      const max = Math.max(...values);\n      return [min, max];\n    }\n    return values;\n  }\n\n  getYValues(): any[] {\n    const domain = [];\n\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          if (domain.indexOf(d.min) < 0) {\n            domain.push(d.min);\n          }\n        }\n        if (d.max !== undefined) {\n          if (domain.indexOf(d.max) < 0) {\n            domain.push(d.max);\n          }\n        }\n      }\n    }\n    return domain;\n  }\n\n  getYDomain(domain = this.getYValues()): any[] {\n    let min = Math.min(...domain);\n    const max = Math.max(this.yAxisMinScale, ...domain);\n\n    min = Math.max(0, min);\n    if (!this.autoScale) {\n      min = Math.min(0, min);\n    }\n\n    return [min, max];\n  }\n\n  getSeriesDomain(): any[] {\n    return this.results.map(d => d.name);\n  }\n\n  getXScale(domain, width: number): any {\n    switch (this.scaleType) {\n      case ScaleType.Time:\n        return scaleTime().range([0, width]).domain(domain);\n      case ScaleType.Linear:\n        const scale = scaleLinear().range([0, width]).domain(domain);\n        return this.roundDomains ? scale.nice() : scale;\n      default:\n        return scalePoint()\n          .range([0, width - twoPI / domain.length])\n          .padding(0)\n          .domain(domain);\n    }\n  }\n\n  getYScale(domain, height: number): any {\n    const scale = scaleLinear().range([0, height]).domain(domain);\n\n    return this.roundDomains ? scale.nice() : scale;\n  }\n\n  onClick(data, series?): void {\n    if (series) {\n      data.series = series.name;\n    }\n\n    this.select.emit(data);\n  }\n\n  setColors(): void {\n    const domain = this.schemeType === ScaleType.Ordinal ? this.seriesDomain : this.yDomain.reverse();\n    this.colors = new ColorHelper(this.scheme, this.schemeType, domain, this.customColors);\n  }\n\n  getLegendOptions() {\n    if (this.schemeType === ScaleType.Ordinal) {\n      return {\n        scaleType: this.schemeType,\n        colors: this.colors,\n        domain: this.seriesDomain,\n        title: this.legendTitle,\n        position: this.legendPosition\n      };\n    }\n    return {\n      scaleType: this.schemeType,\n      colors: this.colors.scale,\n      domain: this.yDomain,\n      title: undefined,\n      position: this.legendPosition\n    };\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    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    this.activeEntries = this.showSeriesOnHover ? [item, ...this.activeEntries] : this.activeEntries;\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  trackBy(index: number, item): string {\n    return `${item.name}`;\n  }\n}\n"]} |
\ | No newline at end of file |