@taiga-ui/addon-charts 4.66.0 → 5.0.0-canary.8b64ec1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (94) hide show
  1. package/README.md +2 -2
  2. package/components/arc-chart/arc-chart.component.d.ts +9 -14
  3. package/components/axes/axes.component.d.ts +18 -20
  4. package/components/bar/bar.component.d.ts +4 -5
  5. package/components/bar-chart/bar-chart.component.d.ts +11 -14
  6. package/components/bar-set/bar-set.component.d.ts +7 -9
  7. package/components/chart-hint/chart-hint.directive.d.ts +8 -0
  8. package/components/chart-hint/index.d.ts +1 -0
  9. package/components/index.d.ts +1 -0
  10. package/components/legend-item/legend-item.component.d.ts +6 -7
  11. package/components/line-chart/line-chart-hint.directive.d.ts +6 -6
  12. package/components/line-chart/line-chart.component.d.ts +20 -25
  13. package/components/line-chart/line-chart.options.d.ts +1 -3
  14. package/components/line-days-chart/line-days-chart-hint.directive.d.ts +3 -3
  15. package/components/line-days-chart/line-days-chart.component.d.ts +13 -14
  16. package/components/pie-chart/pie-chart.component.d.ts +7 -14
  17. package/components/pie-chart/pie-chart.directive.d.ts +2 -3
  18. package/components/ring-chart/ring-chart.component.d.ts +4 -9
  19. package/fesm2022/taiga-ui-addon-charts-components-arc-chart.mjs +29 -55
  20. package/fesm2022/taiga-ui-addon-charts-components-arc-chart.mjs.map +1 -1
  21. package/fesm2022/taiga-ui-addon-charts-components-axes.mjs +27 -67
  22. package/fesm2022/taiga-ui-addon-charts-components-axes.mjs.map +1 -1
  23. package/fesm2022/taiga-ui-addon-charts-components-bar-chart.mjs +28 -58
  24. package/fesm2022/taiga-ui-addon-charts-components-bar-chart.mjs.map +1 -1
  25. package/fesm2022/taiga-ui-addon-charts-components-bar-set.mjs +16 -39
  26. package/fesm2022/taiga-ui-addon-charts-components-bar-set.mjs.map +1 -1
  27. package/fesm2022/taiga-ui-addon-charts-components-bar.mjs +12 -24
  28. package/fesm2022/taiga-ui-addon-charts-components-bar.mjs.map +1 -1
  29. package/fesm2022/taiga-ui-addon-charts-components-chart-hint.mjs +24 -0
  30. package/fesm2022/taiga-ui-addon-charts-components-chart-hint.mjs.map +1 -0
  31. package/fesm2022/taiga-ui-addon-charts-components-legend-item.mjs +15 -28
  32. package/fesm2022/taiga-ui-addon-charts-components-legend-item.mjs.map +1 -1
  33. package/fesm2022/taiga-ui-addon-charts-components-line-chart.mjs +75 -138
  34. package/fesm2022/taiga-ui-addon-charts-components-line-chart.mjs.map +1 -1
  35. package/fesm2022/taiga-ui-addon-charts-components-line-days-chart.mjs +87 -124
  36. package/fesm2022/taiga-ui-addon-charts-components-line-days-chart.mjs.map +1 -1
  37. package/fesm2022/taiga-ui-addon-charts-components-pie-chart.mjs +57 -89
  38. package/fesm2022/taiga-ui-addon-charts-components-pie-chart.mjs.map +1 -1
  39. package/fesm2022/taiga-ui-addon-charts-components-ring-chart.mjs +11 -30
  40. package/fesm2022/taiga-ui-addon-charts-components-ring-chart.mjs.map +1 -1
  41. package/fesm2022/taiga-ui-addon-charts-components.mjs +1 -0
  42. package/fesm2022/taiga-ui-addon-charts-components.mjs.map +1 -1
  43. package/fesm2022/taiga-ui-addon-charts-utils.mjs +6 -3
  44. package/fesm2022/taiga-ui-addon-charts-utils.mjs.map +1 -1
  45. package/package.json +15 -36
  46. package/esm2022/components/arc-chart/arc-chart.component.mjs +0 -85
  47. package/esm2022/components/arc-chart/index.mjs +0 -2
  48. package/esm2022/components/arc-chart/taiga-ui-addon-charts-components-arc-chart.mjs +0 -5
  49. package/esm2022/components/axes/axes.component.mjs +0 -79
  50. package/esm2022/components/axes/index.mjs +0 -2
  51. package/esm2022/components/axes/taiga-ui-addon-charts-components-axes.mjs +0 -5
  52. package/esm2022/components/bar/bar.component.mjs +0 -35
  53. package/esm2022/components/bar/index.mjs +0 -2
  54. package/esm2022/components/bar/taiga-ui-addon-charts-components-bar.mjs +0 -5
  55. package/esm2022/components/bar-chart/bar-chart.component.mjs +0 -77
  56. package/esm2022/components/bar-chart/index.mjs +0 -2
  57. package/esm2022/components/bar-chart/taiga-ui-addon-charts-components-bar-chart.mjs +0 -5
  58. package/esm2022/components/bar-set/bar-set.component.mjs +0 -50
  59. package/esm2022/components/bar-set/index.mjs +0 -2
  60. package/esm2022/components/bar-set/taiga-ui-addon-charts-components-bar-set.mjs +0 -5
  61. package/esm2022/components/index.mjs +0 -11
  62. package/esm2022/components/legend-item/index.mjs +0 -2
  63. package/esm2022/components/legend-item/legend-item.component.mjs +0 -37
  64. package/esm2022/components/legend-item/taiga-ui-addon-charts-components-legend-item.mjs +0 -5
  65. package/esm2022/components/line-chart/index.mjs +0 -4
  66. package/esm2022/components/line-chart/line-chart-hint.directive.mjs +0 -68
  67. package/esm2022/components/line-chart/line-chart.component.mjs +0 -183
  68. package/esm2022/components/line-chart/line-chart.options.mjs +0 -14
  69. package/esm2022/components/line-chart/taiga-ui-addon-charts-components-line-chart.mjs +0 -5
  70. package/esm2022/components/line-days-chart/index.mjs +0 -3
  71. package/esm2022/components/line-days-chart/line-days-chart-hint.directive.mjs +0 -71
  72. package/esm2022/components/line-days-chart/line-days-chart.component.mjs +0 -194
  73. package/esm2022/components/line-days-chart/taiga-ui-addon-charts-components-line-days-chart.mjs +0 -5
  74. package/esm2022/components/pie-chart/index.mjs +0 -3
  75. package/esm2022/components/pie-chart/pie-chart.component.mjs +0 -115
  76. package/esm2022/components/pie-chart/pie-chart.directive.mjs +0 -48
  77. package/esm2022/components/pie-chart/taiga-ui-addon-charts-components-pie-chart.mjs +0 -5
  78. package/esm2022/components/ring-chart/index.mjs +0 -2
  79. package/esm2022/components/ring-chart/ring-chart.component.mjs +0 -39
  80. package/esm2022/components/ring-chart/taiga-ui-addon-charts-components-ring-chart.mjs +0 -5
  81. package/esm2022/components/taiga-ui-addon-charts-components.mjs +0 -5
  82. package/esm2022/index.mjs +0 -2
  83. package/esm2022/taiga-ui-addon-charts.mjs +0 -5
  84. package/esm2022/types/index.mjs +0 -2
  85. package/esm2022/types/taiga-ui-addon-charts-types.mjs +0 -5
  86. package/esm2022/utils/control-point.mjs +0 -13
  87. package/esm2022/utils/describe-sector.mjs +0 -33
  88. package/esm2022/utils/draw-curve.mjs +0 -8
  89. package/esm2022/utils/draw-line.mjs +0 -4
  90. package/esm2022/utils/draw.mjs +0 -10
  91. package/esm2022/utils/index.mjs +0 -8
  92. package/esm2022/utils/line-angle.mjs +0 -6
  93. package/esm2022/utils/line-length.mjs +0 -6
  94. package/esm2022/utils/taiga-ui-addon-charts-utils.mjs +0 -5
@@ -1,194 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { NgForOf } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, DestroyRef, inject, Input, NgZone, ViewChildren, } from '@angular/core';
4
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
5
- import { TUI_LINE_CHART_OPTIONS, TuiLineChart, tuiLineChartDrivers, TuiLineChartHint, } from '@taiga-ui/addon-charts/components/line-chart';
6
- import { EMPTY_ARRAY, EMPTY_QUERY } from '@taiga-ui/cdk/constants';
7
- import { TuiDay, TuiMonth } from '@taiga-ui/cdk/date-time';
8
- import { TuiHoveredService } from '@taiga-ui/cdk/directives/hovered';
9
- import { tuiZonefree } from '@taiga-ui/cdk/observables';
10
- import { tuiIsNumber, tuiIsPresent, tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
11
- import { TuiHint } from '@taiga-ui/core/directives/hint';
12
- import { PolymorpheusOutlet } from '@taiga-ui/polymorpheus';
13
- import { combineLatest, filter } from 'rxjs';
14
- import { TuiLineDaysChartHint } from './line-days-chart-hint.directive';
15
- import * as i0 from "@angular/core";
16
- import * as i1 from "@taiga-ui/core/directives/hint";
17
- const DUMMY = [NaN, NaN];
18
- class TuiLineDaysChart {
19
- constructor() {
20
- this.destroyRef = inject(DestroyRef);
21
- this.zone = inject(NgZone);
22
- this.hovered$ = inject(TuiHoveredService);
23
- this.options = inject(TUI_LINE_CHART_OPTIONS);
24
- this.hintDirective = inject(TuiLineDaysChartHint, {
25
- optional: true,
26
- });
27
- this.charts = EMPTY_QUERY;
28
- this.y = 0;
29
- this.height = 0;
30
- this.smoothingFactor = this.options.smoothingFactor;
31
- this.xStringify = null;
32
- this.yStringify = null;
33
- this.dots = this.options.dots;
34
- this.zIndex = 0;
35
- this.value = [];
36
- this.daysStringify = (index) => {
37
- const day = this.getDay(index);
38
- return this.xStringify && day ? this.xStringify(day) : '';
39
- };
40
- }
41
- set valueSetter(value) {
42
- if (!value.length) {
43
- this.value = [];
44
- return;
45
- }
46
- const start = value[0]?.[0];
47
- const end = value[value.length - 1];
48
- const mutable = [...value];
49
- const length = start && end ? TuiDay.lengthBetween(start, end[0]) + 1 : 0;
50
- this.value = Array.from({ length }, (_, day) => {
51
- const startMutable = mutable[0]?.[0];
52
- const currentDay = start?.append({ day });
53
- const shifted = startMutable && currentDay?.daySame(startMutable)
54
- ? mutable.shift()
55
- : null;
56
- const currentValue = shifted ? shifted[1] : NaN;
57
- return [currentDay, currentValue];
58
- });
59
- }
60
- get hint() {
61
- return this.hintDirective?.hint ?? this.hintContent;
62
- }
63
- ngAfterViewInit() {
64
- combineLatest([tuiLineChartDrivers(this.charts), this.hovered$])
65
- .pipe(filter((result) => !result.some(Boolean)), tuiZonefree(this.zone), takeUntilDestroyed(this.destroyRef))
66
- .subscribe(() => {
67
- this.onHovered(NaN);
68
- });
69
- }
70
- onHovered(day) {
71
- if (tuiIsNumber(day)) {
72
- this.charts.forEach((chart) => chart.onHovered(NaN));
73
- return;
74
- }
75
- const start = this.value[0]?.[0];
76
- const index = start && day ? TuiMonth.lengthBetween(start, day) : 0;
77
- const x = start && day ? TuiDay.lengthBetween(start, day) + start.day - 1 : 0;
78
- const current = this.charts.get(index);
79
- this.charts.forEach((chart) => {
80
- if (chart === current) {
81
- current.onHovered(current.value.findIndex((point) => point[0] === x));
82
- }
83
- else {
84
- chart.onHovered(NaN);
85
- }
86
- });
87
- }
88
- raise(index, { value }) {
89
- const x = value[index]?.[0] || 0;
90
- const month = this.getDay(x);
91
- if (!month) {
92
- return;
93
- }
94
- if (this.hintDirective) {
95
- this.hintDirective.raise(month);
96
- }
97
- else {
98
- this.onHovered(month);
99
- }
100
- }
101
- getContext(index, { value }) {
102
- const x = value[index]?.[0] || 0;
103
- const day = this.getDay(x);
104
- return this.hintDirective && day
105
- ? this.hintDirective.getContext(day)
106
- : this.getHintContext(x, this.value);
107
- }
108
- get months() {
109
- return this.value.length ? this.breakMonths(this.value) : EMPTY_ARRAY;
110
- }
111
- get firstWidth() {
112
- return this.months.length * (this.value[0]?.[0].daysCount || 0);
113
- }
114
- getHintContext(x, value) {
115
- return value[x - (value[0]?.[0]?.day || 0) + 1] ?? null;
116
- }
117
- getX(index) {
118
- const start = this.value[0]?.[0];
119
- const current = this.getDay(index);
120
- const months = start && current ? TuiMonth.lengthBetween(start, current) : 0;
121
- const offset = months * (current?.daysCount || 0);
122
- return index - offset;
123
- }
124
- getWidth(index) {
125
- return (this.getDay(index)?.daysCount || 0) * this.months.length;
126
- }
127
- breakMonths(value) {
128
- const offset = (value[0]?.[0].day || 1) - 1;
129
- const start = value[0]?.[0];
130
- const end = value[value.length - 1]?.[0];
131
- return Array.from({ length: start && end ? TuiMonth.lengthBetween(start, end) + 1 : 0 }, (_, i) => i + (start?.month || 0) + (start?.year || 0) * 12)
132
- .map((absoluteMonth) => value
133
- .map(([{ month, year }, y], index) => month + year * 12 === absoluteMonth ? [index + offset, y] : null)
134
- .filter(tuiIsPresent))
135
- .map((month, index, array) => index === array.length - 1
136
- ? month
137
- : [
138
- ...month,
139
- array[index + 1]?.find((day) => !Number.isNaN(day[1])) || DUMMY,
140
- ]);
141
- }
142
- getDay(index) {
143
- const start = this.value[0]?.[0];
144
- return this.value[index - (start?.day || 0) + 1]?.[0];
145
- }
146
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineDaysChart, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
147
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiLineDaysChart, isStandalone: true, selector: "tui-line-days-chart", inputs: { y: "y", height: "height", smoothingFactor: "smoothingFactor", hintContent: "hintContent", xStringify: "xStringify", yStringify: "yStringify", dots: "dots", valueSetter: ["value", "valueSetter"] }, host: { properties: { "style.zIndex": "zIndex" } }, providers: [
148
- TuiHoveredService,
149
- {
150
- provide: TuiLineChartHint,
151
- useExisting: TuiLineDaysChart,
152
- },
153
- ], viewQueries: [{ propertyName: "charts", predicate: TuiLineChart, descendants: true }], ngImport: i0, template: "<tui-line-chart\n *ngFor=\"let month of months; let first = first\"\n class=\"t-chart\"\n [dots]=\"dots\"\n [height]=\"height\"\n [smoothingFactor]=\"smoothingFactor\"\n [style.zIndex]=\"zIndex\"\n [tuiHintContent]=\"hintContent ? hint : ''\"\n [value]=\"month\"\n [width]=\"first ? firstWidth : getWidth(month[0]?.[0] ?? 0)\"\n [x]=\"first ? 0 : getX(month[0]?.[0] ?? 0)\"\n [xStringify]=\"xStringify ? daysStringify : null\"\n [y]=\"y\"\n [yStringify]=\"yStringify\"\n/>\n<ng-template\n #hint\n let-point\n>\n <ng-container *polymorpheusOutlet=\"hintContent as text; context: {$implicit: getHintContext(point[0], value)}\">\n {{ text }}\n </ng-container>\n</ng-template>\n", styles: [":host{display:block}.t-chart{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"], dependencies: [{ kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: PolymorpheusOutlet, selector: "[polymorpheusOutlet]", inputs: ["polymorpheusOutlet", "polymorpheusOutletContext"] }, { kind: "directive", type: i1.TuiHintOptionsDirective, selector: "[tuiHintContent]", inputs: ["tuiHintContent", "tuiHintDirection", "tuiHintAppearance", "tuiHintShowDelay", "tuiHintHideDelay"] }, { kind: "component", type: TuiLineChart, selector: "tui-line-chart", inputs: ["x", "y", "width", "height", "smoothingFactor", "xStringify", "yStringify", "filled", "dots", "value"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
154
- }
155
- __decorate([
156
- tuiPure
157
- ], TuiLineDaysChart.prototype, "getHintContext", null);
158
- __decorate([
159
- tuiPure
160
- ], TuiLineDaysChart.prototype, "breakMonths", null);
161
- export { TuiLineDaysChart };
162
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineDaysChart, decorators: [{
163
- type: Component,
164
- args: [{ standalone: true, selector: 'tui-line-days-chart', imports: [NgForOf, PolymorpheusOutlet, TuiHint, TuiLineChart], changeDetection: ChangeDetectionStrategy.OnPush, providers: [
165
- TuiHoveredService,
166
- {
167
- provide: TuiLineChartHint,
168
- useExisting: TuiLineDaysChart,
169
- },
170
- ], host: {
171
- '[style.zIndex]': 'zIndex',
172
- }, template: "<tui-line-chart\n *ngFor=\"let month of months; let first = first\"\n class=\"t-chart\"\n [dots]=\"dots\"\n [height]=\"height\"\n [smoothingFactor]=\"smoothingFactor\"\n [style.zIndex]=\"zIndex\"\n [tuiHintContent]=\"hintContent ? hint : ''\"\n [value]=\"month\"\n [width]=\"first ? firstWidth : getWidth(month[0]?.[0] ?? 0)\"\n [x]=\"first ? 0 : getX(month[0]?.[0] ?? 0)\"\n [xStringify]=\"xStringify ? daysStringify : null\"\n [y]=\"y\"\n [yStringify]=\"yStringify\"\n/>\n<ng-template\n #hint\n let-point\n>\n <ng-container *polymorpheusOutlet=\"hintContent as text; context: {$implicit: getHintContext(point[0], value)}\">\n {{ text }}\n </ng-container>\n</ng-template>\n", styles: [":host{display:block}.t-chart{position:absolute;top:0;left:0;inline-size:100%;block-size:100%}\n"] }]
173
- }], propDecorators: { charts: [{
174
- type: ViewChildren,
175
- args: [TuiLineChart]
176
- }], y: [{
177
- type: Input
178
- }], height: [{
179
- type: Input
180
- }], smoothingFactor: [{
181
- type: Input
182
- }], hintContent: [{
183
- type: Input
184
- }], xStringify: [{
185
- type: Input
186
- }], yStringify: [{
187
- type: Input
188
- }], dots: [{
189
- type: Input
190
- }], valueSetter: [{
191
- type: Input,
192
- args: ['value']
193
- }], getHintContext: [], breakMonths: [] } });
194
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-days-chart.component.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/line-days-chart/line-days-chart.component.ts","../../../../../projects/addon-charts/components/line-days-chart/line-days-chart.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,OAAO,EAAC,MAAM,iBAAiB,CAAC;AACxC,OAAO,EAEH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EAEN,YAAY,GACf,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EACH,sBAAsB,EACtB,YAAY,EACZ,mBAAmB,EACnB,gBAAgB,GACnB,MAAM,8CAA8C,CAAC;AACtD,OAAO,EAAC,WAAW,EAAE,WAAW,EAAC,MAAM,yBAAyB,CAAC;AACjE,OAAO,EAAC,MAAM,EAAE,QAAQ,EAAC,MAAM,yBAAyB,CAAC;AACzD,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAC,WAAW,EAAC,MAAM,2BAA2B,CAAC;AAEtD,OAAO,EAAC,WAAW,EAAE,YAAY,EAAE,OAAO,EAAC,MAAM,mCAAmC,CAAC;AACrF,OAAO,EAAC,OAAO,EAAC,MAAM,gCAAgC,CAAC;AAEvD,OAAO,EAA2B,kBAAkB,EAAC,MAAM,wBAAwB,CAAC;AACpF,OAAO,EAAC,aAAa,EAAE,MAAM,EAAC,MAAM,MAAM,CAAC;AAE3C,OAAO,EAAC,oBAAoB,EAAC,MAAM,kCAAkC,CAAC;;;AAEtE,MAAM,KAAK,GAAa,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC;AAEnC,MAkBa,gBAAgB;IAlB7B;QAmBqB,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,SAAI,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACtB,aAAQ,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QACrC,YAAO,GAAG,MAAM,CAAC,sBAAsB,CAAC,CAAC;QACzC,kBAAa,GAAG,MAAM,CAAC,oBAAoB,EAAE;YAC1D,QAAQ,EAAE,IAAI;SACjB,CAAC,CAAC;QAGa,WAAM,GAA4B,WAAW,CAAC;QAGvD,MAAC,GAAG,CAAC,CAAC;QAGN,WAAM,GAAG,CAAC,CAAC;QAGX,oBAAe,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;QAM/C,eAAU,GAAoC,IAAI,CAAC;QAGnD,eAAU,GAAoC,IAAI,CAAC;QAGnD,SAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAEzB,WAAM,GAAG,CAAC,CAAC;QAEX,UAAK,GAAoC,EAAE,CAAC;QA2GhC,kBAAa,GAA6B,CAAC,KAAK,EAAE,EAAE;YACnE,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;YAE/B,OAAO,IAAI,CAAC,UAAU,IAAI,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC9D,CAAC,CAAC;KAiDL;IA9JG,IACW,WAAW,CAAC,KAAsC;QACzD,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE;YACf,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;YAEhB,OAAO;SACV;QAED,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QACpC,MAAM,OAAO,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;QAC3B,MAAM,MAAM,GAAG,KAAK,IAAI,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE1E,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,EAAC,MAAM,EAAC,EAAE,CAAC,CAAC,EAAE,GAAG,EAAE,EAAE;YACzC,MAAM,YAAY,GAAG,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACrC,MAAM,UAAU,GAAG,KAAK,EAAE,MAAM,CAAC,EAAC,GAAG,EAAC,CAAC,CAAC;YACxC,MAAM,OAAO,GACT,YAAY,IAAI,UAAU,EAAE,OAAO,CAAC,YAAY,CAAC;gBAC7C,CAAC,CAAC,OAAO,CAAC,KAAK,EAAE;gBACjB,CAAC,CAAC,IAAI,CAAC;YACf,MAAM,YAAY,GAAG,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;YAEhD,OAAO,CAAC,UAAU,EAAE,YAAY,CAAqB,CAAC;QAC1D,CAAC,CAAC,CAAC;IACP,CAAC;IAED,IAAW,IAAI;QAGX,OAAO,IAAI,CAAC,aAAa,EAAE,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC;IACxD,CAAC;IAEM,eAAe;QAClB,aAAa,CAAC,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC3D,IAAI,CACD,MAAM,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EACzC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EACtB,kBAAkB,CAAC,IAAI,CAAC,UAAU,CAAC,CACtC;aACA,SAAS,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;QACxB,CAAC,CAAC,CAAC;IACX,CAAC;IAEM,SAAS,CAAC,GAAoB;QACjC,IAAI,WAAW,CAAC,GAAG,CAAC,EAAE;YAClB,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;YAErD,OAAO;SACV;QAED,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,KAAK,GAAG,KAAK,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpE,MAAM,CAAC,GAAG,KAAK,IAAI,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC9E,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEvC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YAC1B,IAAI,KAAK,KAAK,OAAO,EAAE;gBACnB,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;aACzE;iBAAM;gBACH,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;aACxB;QACL,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,KAAK,CAAC,KAAa,EAAE,EAAC,KAAK,EAAe;QAC7C,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACjC,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAE7B,IAAI,CAAC,KAAK,EAAE;YACR,OAAO;SACV;QAED,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;SACnC;aAAM;YACH,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SACzB;IACL,CAAC;IAEM,UAAU,CAAC,KAAa,EAAE,EAAC,KAAK,EAAe;QAClD,MAAM,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACjC,MAAM,GAAG,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;QAE3B,OAAO,IAAI,CAAC,aAAa,IAAI,GAAG;YAC5B,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,UAAU,CAAC,GAAG,CAAC;YACpC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IAED,IAAc,MAAM;QAChB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC;IAC1E,CAAC;IAED,IAAc,UAAU;QACpB,OAAO,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,SAAS,IAAI,CAAC,CAAC,CAAC;IACpE,CAAC;IAGS,cAAc,CACpB,CAAS,EACT,KAAsC;QAEtC,OAAO,KAAK,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,IAAI,CAAC;IAC5D,CAAC;IAQS,IAAI,CAAC,KAAa;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QACjC,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACnC,MAAM,MAAM,GAAG,KAAK,IAAI,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7E,MAAM,MAAM,GAAG,MAAM,GAAG,CAAC,OAAO,EAAE,SAAS,IAAI,CAAC,CAAC,CAAC;QAElD,OAAO,KAAK,GAAG,MAAM,CAAC;IAC1B,CAAC;IAES,QAAQ,CAAC,KAAa;QAC5B,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,SAAS,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC;IACrE,CAAC;IAGO,WAAW,CACf,KAAsC;QAEtC,MAAM,MAAM,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAC5B,MAAM,GAAG,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEzC,OAAO,KAAK,CAAC,IAAI,CACb,EAAC,MAAM,EAAE,KAAK,IAAI,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,aAAa,CAAC,KAAK,EAAE,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAC,EACnE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,IAAI,CAAC,CAAC,GAAG,EAAE,CAC9D;aACI,GAAG,CAAC,CAAC,aAAa,EAAE,EAAE,CACnB,KAAK;aACA,GAAG,CAAkB,CAAC,CAAC,EAAC,KAAK,EAAE,IAAI,EAAC,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CAChD,KAAK,GAAG,IAAI,GAAG,EAAE,KAAK,aAAa,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CACnE;aACA,MAAM,CAAC,YAAY,CAAC,CAC5B;aACA,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CACzB,KAAK,KAAK,KAAK,CAAC,MAAM,GAAG,CAAC;YACtB,CAAC,CAAC,KAAK;YACP,CAAC,CAAC;gBACI,GAAG,KAAK;gBACR,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,KAAK;aAClE,CACV,CAAC;IACV,CAAC;IAEO,MAAM,CAAC,KAAa;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;QAEjC,OAAO,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,KAAK,EAAE,GAAG,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAC1D,CAAC;+GAlMQ,gBAAgB;mGAAhB,gBAAgB,qUAXd;YACP,iBAAiB;YACjB;gBACI,OAAO,EAAE,gBAAgB;gBACzB,WAAW,EAAE,gBAAgB;aAChC;SACJ,qDAca,YAAY,gDC7D9B,8tBAuBA,yJDcc,OAAO,mHAAE,kBAAkB,kUAAW,YAAY;;AAsJlD;IADT,OAAO;sDAMP;AAsBO;IADP,OAAO;mDA2BP;SA5LQ,gBAAgB;4FAAhB,gBAAgB;kBAlB5B,SAAS;iCACM,IAAI,YACN,qBAAqB,WACtB,CAAC,OAAO,EAAE,kBAAkB,EAAE,OAAO,EAAE,YAAY,CAAC,mBAG5C,uBAAuB,CAAC,MAAM,aACpC;wBACP,iBAAiB;wBACjB;4BACI,OAAO,EAAE,gBAAgB;4BACzB,WAAW,kBAAkB;yBAChC;qBACJ,QACK;wBACF,gBAAgB,EAAE,QAAQ;qBAC7B;8BAYe,MAAM;sBADrB,YAAY;uBAAC,YAAY;gBAInB,CAAC;sBADP,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIC,eAAe;sBADrB,KAAK;gBAIC,WAAW;sBADjB,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAQK,WAAW;sBADrB,KAAK;uBAAC,OAAO;gBAkGJ,cAAc,MA2BhB,WAAW","sourcesContent":["import {NgForOf} from '@angular/common';\nimport {\n    type AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    DestroyRef,\n    inject,\n    Input,\n    NgZone,\n    type QueryList,\n    ViewChildren,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {\n    TUI_LINE_CHART_OPTIONS,\n    TuiLineChart,\n    tuiLineChartDrivers,\n    TuiLineChartHint,\n} from '@taiga-ui/addon-charts/components/line-chart';\nimport {EMPTY_ARRAY, EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiDay, TuiMonth} from '@taiga-ui/cdk/date-time';\nimport {TuiHoveredService} from '@taiga-ui/cdk/directives/hovered';\nimport {tuiZonefree} from '@taiga-ui/cdk/observables';\nimport {type TuiContext, type TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiIsNumber, tuiIsPresent, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {TuiHint} from '@taiga-ui/core/directives/hint';\nimport {type TuiPoint} from '@taiga-ui/core/types';\nimport {type PolymorpheusContent, PolymorpheusOutlet} from '@taiga-ui/polymorpheus';\nimport {combineLatest, filter} from 'rxjs';\n\nimport {TuiLineDaysChartHint} from './line-days-chart-hint.directive';\n\nconst DUMMY: TuiPoint = [NaN, NaN];\n\n@Component({\n    standalone: true,\n    selector: 'tui-line-days-chart',\n    imports: [NgForOf, PolymorpheusOutlet, TuiHint, TuiLineChart],\n    templateUrl: './line-days-chart.template.html',\n    styleUrls: ['./line-days-chart.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        TuiHoveredService,\n        {\n            provide: TuiLineChartHint,\n            useExisting: TuiLineDaysChart,\n        },\n    ],\n    host: {\n        '[style.zIndex]': 'zIndex',\n    },\n})\nexport class TuiLineDaysChart implements AfterViewInit {\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly zone = inject(NgZone);\n    private readonly hovered$ = inject(TuiHoveredService);\n    private readonly options = inject(TUI_LINE_CHART_OPTIONS);\n    private readonly hintDirective = inject(TuiLineDaysChartHint, {\n        optional: true,\n    });\n\n    @ViewChildren(TuiLineChart)\n    public readonly charts: QueryList<TuiLineChart> = EMPTY_QUERY;\n\n    @Input()\n    public y = 0;\n\n    @Input()\n    public height = 0;\n\n    @Input()\n    public smoothingFactor = this.options.smoothingFactor;\n\n    @Input()\n    public hintContent: PolymorpheusContent<TuiContext<[TuiDay, number]>>;\n\n    @Input()\n    public xStringify: TuiStringHandler<TuiDay> | null = null;\n\n    @Input()\n    public yStringify: TuiStringHandler<number> | null = null;\n\n    @Input()\n    public dots = this.options.dots;\n\n    public zIndex = 0;\n\n    public value: ReadonlyArray<[TuiDay, number]> = [];\n\n    @Input('value')\n    public set valueSetter(value: ReadonlyArray<[TuiDay, number]>) {\n        if (!value.length) {\n            this.value = [];\n\n            return;\n        }\n\n        const start = value[0]?.[0];\n        const end = value[value.length - 1];\n        const mutable = [...value];\n        const length = start && end ? TuiDay.lengthBetween(start, end[0]) + 1 : 0;\n\n        this.value = Array.from({length}, (_, day) => {\n            const startMutable = mutable[0]?.[0];\n            const currentDay = start?.append({day});\n            const shifted =\n                startMutable && currentDay?.daySame(startMutable)\n                    ? mutable.shift()\n                    : null;\n            const currentValue = shifted ? shifted[1] : NaN;\n\n            return [currentDay, currentValue] as [TuiDay, number];\n        });\n    }\n\n    public get hint():\n        | PolymorpheusContent<TuiContext<[TuiDay, number]>>\n        | PolymorpheusContent<TuiContext<readonly TuiPoint[]>> {\n        return this.hintDirective?.hint ?? this.hintContent;\n    }\n\n    public ngAfterViewInit(): void {\n        combineLatest([tuiLineChartDrivers(this.charts), this.hovered$])\n            .pipe(\n                filter((result) => !result.some(Boolean)),\n                tuiZonefree(this.zone),\n                takeUntilDestroyed(this.destroyRef),\n            )\n            .subscribe(() => {\n                this.onHovered(NaN);\n            });\n    }\n\n    public onHovered(day: TuiDay | number): void {\n        if (tuiIsNumber(day)) {\n            this.charts.forEach((chart) => chart.onHovered(NaN));\n\n            return;\n        }\n\n        const start = this.value[0]?.[0];\n        const index = start && day ? TuiMonth.lengthBetween(start, day) : 0;\n        const x = start && day ? TuiDay.lengthBetween(start, day) + start.day - 1 : 0;\n        const current = this.charts.get(index);\n\n        this.charts.forEach((chart) => {\n            if (chart === current) {\n                current.onHovered(current.value.findIndex((point) => point[0] === x));\n            } else {\n                chart.onHovered(NaN);\n            }\n        });\n    }\n\n    public raise(index: number, {value}: TuiLineChart): void {\n        const x = value[index]?.[0] || 0;\n        const month = this.getDay(x);\n\n        if (!month) {\n            return;\n        }\n\n        if (this.hintDirective) {\n            this.hintDirective.raise(month);\n        } else {\n            this.onHovered(month);\n        }\n    }\n\n    public getContext(index: number, {value}: TuiLineChart): unknown {\n        const x = value[index]?.[0] || 0;\n        const day = this.getDay(x);\n\n        return this.hintDirective && day\n            ? this.hintDirective.getContext(day)\n            : this.getHintContext(x, this.value);\n    }\n\n    protected get months(): ReadonlyArray<readonly TuiPoint[]> {\n        return this.value.length ? this.breakMonths(this.value) : EMPTY_ARRAY;\n    }\n\n    protected get firstWidth(): number {\n        return this.months.length * (this.value[0]?.[0].daysCount || 0);\n    }\n\n    @tuiPure\n    protected getHintContext(\n        x: number,\n        value: ReadonlyArray<[TuiDay, number]>,\n    ): [TuiDay, number] | null {\n        return value[x - (value[0]?.[0]?.day || 0) + 1] ?? null;\n    }\n\n    protected readonly daysStringify: TuiStringHandler<number> = (index) => {\n        const day = this.getDay(index);\n\n        return this.xStringify && day ? this.xStringify(day) : '';\n    };\n\n    protected getX(index: number): number {\n        const start = this.value[0]?.[0];\n        const current = this.getDay(index);\n        const months = start && current ? TuiMonth.lengthBetween(start, current) : 0;\n        const offset = months * (current?.daysCount || 0);\n\n        return index - offset;\n    }\n\n    protected getWidth(index: number): number {\n        return (this.getDay(index)?.daysCount || 0) * this.months.length;\n    }\n\n    @tuiPure\n    private breakMonths(\n        value: ReadonlyArray<[TuiDay, number]>,\n    ): ReadonlyArray<readonly TuiPoint[]> {\n        const offset = (value[0]?.[0].day || 1) - 1;\n        const start = value[0]?.[0];\n        const end = value[value.length - 1]?.[0];\n\n        return Array.from(\n            {length: start && end ? TuiMonth.lengthBetween(start, end) + 1 : 0},\n            (_, i) => i + (start?.month || 0) + (start?.year || 0) * 12,\n        )\n            .map((absoluteMonth) =>\n                value\n                    .map<TuiPoint | null>(([{month, year}, y], index) =>\n                        month + year * 12 === absoluteMonth ? [index + offset, y] : null,\n                    )\n                    .filter(tuiIsPresent),\n            )\n            .map((month, index, array) =>\n                index === array.length - 1\n                    ? month\n                    : [\n                          ...month,\n                          array[index + 1]?.find((day) => !Number.isNaN(day[1])) || DUMMY,\n                      ],\n            );\n    }\n\n    private getDay(index: number): TuiDay | undefined {\n        const start = this.value[0]?.[0];\n\n        return this.value[index - (start?.day || 0) + 1]?.[0];\n    }\n}\n","<tui-line-chart\n    *ngFor=\"let month of months; let first = first\"\n    class=\"t-chart\"\n    [dots]=\"dots\"\n    [height]=\"height\"\n    [smoothingFactor]=\"smoothingFactor\"\n    [style.zIndex]=\"zIndex\"\n    [tuiHintContent]=\"hintContent ? hint : ''\"\n    [value]=\"month\"\n    [width]=\"first ? firstWidth : getWidth(month[0]?.[0] ?? 0)\"\n    [x]=\"first ? 0 : getX(month[0]?.[0] ?? 0)\"\n    [xStringify]=\"xStringify ? daysStringify : null\"\n    [y]=\"y\"\n    [yStringify]=\"yStringify\"\n/>\n<ng-template\n    #hint\n    let-point\n>\n    <ng-container *polymorpheusOutlet=\"hintContent as text; context: {$implicit: getHintContext(point[0], value)}\">\n        {{ text }}\n    </ng-container>\n</ng-template>\n"]}
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMtbGluZS1kYXlzLWNoYXJ0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvbGluZS1kYXlzLWNoYXJ0L3RhaWdhLXVpLWFkZG9uLWNoYXJ0cy1jb21wb25lbnRzLWxpbmUtZGF5cy1jaGFydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,3 +0,0 @@
1
- export * from './pie-chart.component';
2
- export * from './pie-chart.directive';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9waWUtY2hhcnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLHVCQUF1QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9waWUtY2hhcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vcGllLWNoYXJ0LmRpcmVjdGl2ZSc7XG4iXX0=
@@ -1,115 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { ChangeDetectionStrategy, Component, EventEmitter, inject, Input, Output, } from '@angular/core';
3
- import { TuiHovered } from '@taiga-ui/cdk/directives/hovered';
4
- import { TuiRepeatTimes } from '@taiga-ui/cdk/directives/repeat-times';
5
- import { tuiInjectId } from '@taiga-ui/cdk/services';
6
- import { tuiSum } from '@taiga-ui/cdk/utils/math';
7
- import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
8
- import { TuiHint, TuiHintOptionsDirective, tuiHintOptionsProvider, } from '@taiga-ui/core/directives/hint';
9
- import { TuiPieChartDirective } from './pie-chart.directive';
10
- import * as i0 from "@angular/core";
11
- import * as i1 from "@taiga-ui/core/directives/hint";
12
- const RADII = {
13
- xs: '50',
14
- s: '50',
15
- m: '77.8',
16
- l: '81.9',
17
- xl: '81.3',
18
- };
19
- const TRANSFORM = {
20
- xs: 1.15,
21
- s: 1.25,
22
- m: 1.11,
23
- l: 1.09,
24
- xl: 1.08,
25
- };
26
- class TuiPieChart {
27
- constructor() {
28
- this.hintOptions = inject(TuiHintOptionsDirective, { optional: true });
29
- this.autoId = tuiInjectId();
30
- this.value = [];
31
- this.size = 'm';
32
- this.masked = false;
33
- this.activeItemIndex = NaN;
34
- this.activeItemIndexChange = new EventEmitter();
35
- if (this.hintOptions) {
36
- this.hintOptions.showDelay = 0;
37
- this.hintOptions.hideDelay = 0;
38
- }
39
- }
40
- get empty() {
41
- return !this.getSum(this.value);
42
- }
43
- get hintContent() {
44
- return this.hintOptions?.content || '';
45
- }
46
- get maskId() {
47
- return `tui-ring-chart-${this.autoId}`;
48
- }
49
- get mask() {
50
- return this.masked ? `url(#${this.maskId})` : null;
51
- }
52
- get radius() {
53
- return RADII[this.size];
54
- }
55
- get segments() {
56
- return this.getSegments(this.value);
57
- }
58
- getTransform(index) {
59
- const transform = this.masked
60
- ? `scale(${TRANSFORM[this.size]})`
61
- : `scale(${TRANSFORM.xs})`;
62
- return index === this.activeItemIndex ? transform : null;
63
- }
64
- onHovered(hovered, index) {
65
- this.updateActiveItemIndex(hovered ? index : NaN);
66
- }
67
- getSum(value) {
68
- return tuiSum(...value);
69
- }
70
- getSegments(value) {
71
- return value
72
- .map((initial, i, array) => array.reduce((sum, current, j) => (j < i ? this.getDeg(current) + sum : sum), this.getDeg(initial)))
73
- .map((angle, index, array) => [
74
- array[index - 1] || 0,
75
- Math.min(angle, 359.9999),
76
- ]);
77
- }
78
- getDeg(value) {
79
- return 360 * (value / this.getSum(this.value)) || 0;
80
- }
81
- updateActiveItemIndex(index) {
82
- if (index === this.activeItemIndex) {
83
- return;
84
- }
85
- this.activeItemIndex = index;
86
- this.activeItemIndexChange.next(index);
87
- }
88
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPieChart, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
89
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiPieChart, isStandalone: true, selector: "tui-pie-chart", inputs: { value: "value", size: "size", masked: "masked", activeItemIndex: "activeItemIndex" }, outputs: { activeItemIndexChange: "activeItemIndexChange" }, host: { properties: { "attr.data-size": "size", "class._empty": "empty" } }, ngImport: i0, template: "<svg\n focusable=\"false\"\n height=\"100%\"\n viewBox=\"-100 -100 200 200\"\n width=\"100%\"\n xmlns=\"http://www.w3.org/2000/svg\"\n class=\"t-svg\"\n>\n <defs>\n <mask [attr.id]=\"maskId\">\n <rect\n fill=\"white\"\n height=\"400\"\n width=\"400\"\n x=\"-200\"\n y=\"-200\"\n />\n <circle\n cx=\"0\"\n cy=\"0\"\n [attr.r]=\"radius\"\n />\n </mask>\n </defs>\n <g [style.mask]=\"mask\">\n <circle\n cx=\"0\"\n cy=\"0\"\n r=\"100\"\n class=\"t-placeholder\"\n />\n <path\n *tuiRepeatTimes=\"let index of segments.length\"\n automation-id=\"tui-pie-chart__segment\"\n d=\"\"\n fill=\"currentColor\"\n tuiHintPointer\n class=\"t-segment\"\n [attr.transform]=\"getTransform(index)\"\n [style.color]=\"'var(--tui-chart-categorical-' + index.toString().padStart(2, '0') + ')'\"\n [tuiHint]=\"hintContent\"\n [tuiHintContext]=\"{$implicit: index}\"\n [tuiPieChart]=\"segments[index] || [0, 0]\"\n (tuiHoveredChange)=\"onHovered($event, index)\"\n />\n </g>\n</svg>\n", styles: [":host{position:relative;display:block;inline-size:var(--t-size);block-size:var(--t-size);border-radius:100%}:host[data-size=xs]{--t-size: 2rem;pointer-events:none}:host[data-size=s]{--t-size: 4rem}:host[data-size=m]{--t-size: 9rem}:host[data-size=l]{--t-size: 11rem}:host[data-size=xl]{--t-size: 16rem}.t-svg{position:relative;overflow:visible;transform:rotate(-90deg)}.t-segment{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}:host._empty .t-segment{display:none}.t-placeholder{fill:var(--tui-background-neutral-1)}\n"], dependencies: [{ kind: "directive", type: i1.TuiHintDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintContext", "tuiHintAppearance", "tuiHint"], outputs: ["tuiHintVisible"] }, { kind: "directive", type: i1.TuiHintPointer, selector: "[tuiHint][tuiHintPointer]" }, { kind: "directive", type: TuiHovered, selector: "[tuiHoveredChange]", outputs: ["tuiHoveredChange"] }, { kind: "directive", type: TuiPieChartDirective, selector: "path[tuiPieChart]", inputs: ["tuiPieChart"] }, { kind: "directive", type: TuiRepeatTimes, selector: "[tuiRepeatTimes][tuiRepeatTimesOf]", inputs: ["tuiRepeatTimesOf"] }], viewProviders: [tuiHintOptionsProvider({ direction: 'top-right', appearance: 'dark' })], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
90
- }
91
- __decorate([
92
- tuiPure
93
- ], TuiPieChart.prototype, "getSum", null);
94
- __decorate([
95
- tuiPure
96
- ], TuiPieChart.prototype, "getSegments", null);
97
- export { TuiPieChart };
98
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPieChart, decorators: [{
99
- type: Component,
100
- args: [{ standalone: true, selector: 'tui-pie-chart', imports: [TuiHint, TuiHovered, TuiPieChartDirective, TuiRepeatTimes], changeDetection: ChangeDetectionStrategy.OnPush, viewProviders: [tuiHintOptionsProvider({ direction: 'top-right', appearance: 'dark' })], host: {
101
- '[attr.data-size]': 'size',
102
- '[class._empty]': 'empty',
103
- }, template: "<svg\n focusable=\"false\"\n height=\"100%\"\n viewBox=\"-100 -100 200 200\"\n width=\"100%\"\n xmlns=\"http://www.w3.org/2000/svg\"\n class=\"t-svg\"\n>\n <defs>\n <mask [attr.id]=\"maskId\">\n <rect\n fill=\"white\"\n height=\"400\"\n width=\"400\"\n x=\"-200\"\n y=\"-200\"\n />\n <circle\n cx=\"0\"\n cy=\"0\"\n [attr.r]=\"radius\"\n />\n </mask>\n </defs>\n <g [style.mask]=\"mask\">\n <circle\n cx=\"0\"\n cy=\"0\"\n r=\"100\"\n class=\"t-placeholder\"\n />\n <path\n *tuiRepeatTimes=\"let index of segments.length\"\n automation-id=\"tui-pie-chart__segment\"\n d=\"\"\n fill=\"currentColor\"\n tuiHintPointer\n class=\"t-segment\"\n [attr.transform]=\"getTransform(index)\"\n [style.color]=\"'var(--tui-chart-categorical-' + index.toString().padStart(2, '0') + ')'\"\n [tuiHint]=\"hintContent\"\n [tuiHintContext]=\"{$implicit: index}\"\n [tuiPieChart]=\"segments[index] || [0, 0]\"\n (tuiHoveredChange)=\"onHovered($event, index)\"\n />\n </g>\n</svg>\n", styles: [":host{position:relative;display:block;inline-size:var(--t-size);block-size:var(--t-size);border-radius:100%}:host[data-size=xs]{--t-size: 2rem;pointer-events:none}:host[data-size=s]{--t-size: 4rem}:host[data-size=m]{--t-size: 9rem}:host[data-size=l]{--t-size: 11rem}:host[data-size=xl]{--t-size: 16rem}.t-svg{position:relative;overflow:visible;transform:rotate(-90deg)}.t-segment{transition-property:transform;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out}:host._empty .t-segment{display:none}.t-placeholder{fill:var(--tui-background-neutral-1)}\n"] }]
104
- }], ctorParameters: function () { return []; }, propDecorators: { value: [{
105
- type: Input
106
- }], size: [{
107
- type: Input
108
- }], masked: [{
109
- type: Input
110
- }], activeItemIndex: [{
111
- type: Input
112
- }], activeItemIndexChange: [{
113
- type: Output
114
- }], getSum: [], getSegments: [] } });
115
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pie-chart.component.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/pie-chart/pie-chart.component.ts","../../../../../projects/addon-charts/components/pie-chart/pie-chart.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    EventEmitter,\n    inject,\n    Input,\n    Output,\n} from '@angular/core';\nimport {TuiHovered} from '@taiga-ui/cdk/directives/hovered';\nimport {TuiRepeatTimes} from '@taiga-ui/cdk/directives/repeat-times';\nimport {tuiInjectId} from '@taiga-ui/cdk/services';\nimport {type TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiSum} from '@taiga-ui/cdk/utils/math';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {\n    TuiHint,\n    TuiHintOptionsDirective,\n    tuiHintOptionsProvider,\n} from '@taiga-ui/core/directives/hint';\nimport {type TuiSizeXL, type TuiSizeXS} from '@taiga-ui/core/types';\nimport {type PolymorpheusContent} from '@taiga-ui/polymorpheus';\n\nimport {TuiPieChartDirective} from './pie-chart.directive';\n\nconst RADII = {\n    xs: '50',\n    s: '50',\n    m: '77.8',\n    l: '81.9',\n    xl: '81.3',\n};\nconst TRANSFORM = {\n    xs: 1.15,\n    s: 1.25,\n    m: 1.11,\n    l: 1.09,\n    xl: 1.08,\n};\n\n@Component({\n    standalone: true,\n    selector: 'tui-pie-chart',\n    imports: [TuiHint, TuiHovered, TuiPieChartDirective, TuiRepeatTimes],\n    templateUrl: './pie-chart.template.html',\n    styleUrls: ['./pie-chart.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    viewProviders: [tuiHintOptionsProvider({direction: 'top-right', appearance: 'dark'})],\n    host: {\n        '[attr.data-size]': 'size',\n        '[class._empty]': 'empty',\n    },\n})\nexport class TuiPieChart {\n    private readonly hintOptions = inject(TuiHintOptionsDirective, {optional: true});\n    private readonly autoId = tuiInjectId();\n\n    @Input()\n    public value: readonly number[] = [];\n\n    @Input()\n    public size: TuiSizeXL | TuiSizeXS = 'm';\n\n    @Input()\n    public masked = false;\n\n    @Input()\n    public activeItemIndex = NaN;\n\n    @Output()\n    public readonly activeItemIndexChange = new EventEmitter<number>();\n\n    constructor() {\n        if (this.hintOptions) {\n            this.hintOptions.showDelay = 0;\n            this.hintOptions.hideDelay = 0;\n        }\n    }\n\n    protected get empty(): boolean {\n        return !this.getSum(this.value);\n    }\n\n    protected get hintContent(): PolymorpheusContent<TuiContext<number>> {\n        return this.hintOptions?.content || '';\n    }\n\n    protected get maskId(): string {\n        return `tui-ring-chart-${this.autoId}`;\n    }\n\n    protected get mask(): string | null {\n        return this.masked ? `url(#${this.maskId})` : null;\n    }\n\n    protected get radius(): string {\n        return RADII[this.size];\n    }\n\n    protected get segments(): ReadonlyArray<[number, number]> {\n        return this.getSegments(this.value);\n    }\n\n    protected getTransform(index: number): string | null {\n        const transform = this.masked\n            ? `scale(${TRANSFORM[this.size]})`\n            : `scale(${TRANSFORM.xs})`;\n\n        return index === this.activeItemIndex ? transform : null;\n    }\n\n    protected onHovered(hovered: boolean, index: number): void {\n        this.updateActiveItemIndex(hovered ? index : NaN);\n    }\n\n    @tuiPure\n    private getSum(value: readonly number[]): number {\n        return tuiSum(...value);\n    }\n\n    @tuiPure\n    private getSegments(value: readonly number[]): ReadonlyArray<[number, number]> {\n        return value\n            .map((initial, i, array) =>\n                array.reduce(\n                    (sum, current, j) => (j < i ? this.getDeg(current) + sum : sum),\n                    this.getDeg(initial),\n                ),\n            )\n            .map((angle, index, array) => [\n                array[index - 1] || 0,\n                Math.min(angle, 359.9999),\n            ]);\n    }\n\n    private getDeg(value: number): number {\n        return 360 * (value / this.getSum(this.value)) || 0;\n    }\n\n    private updateActiveItemIndex(index: number): void {\n        if (index === this.activeItemIndex) {\n            return;\n        }\n\n        this.activeItemIndex = index;\n        this.activeItemIndexChange.next(index);\n    }\n}\n","<svg\n    focusable=\"false\"\n    height=\"100%\"\n    viewBox=\"-100 -100 200 200\"\n    width=\"100%\"\n    xmlns=\"http://www.w3.org/2000/svg\"\n    class=\"t-svg\"\n>\n    <defs>\n        <mask [attr.id]=\"maskId\">\n            <rect\n                fill=\"white\"\n                height=\"400\"\n                width=\"400\"\n                x=\"-200\"\n                y=\"-200\"\n            />\n            <circle\n                cx=\"0\"\n                cy=\"0\"\n                [attr.r]=\"radius\"\n            />\n        </mask>\n    </defs>\n    <g [style.mask]=\"mask\">\n        <circle\n            cx=\"0\"\n            cy=\"0\"\n            r=\"100\"\n            class=\"t-placeholder\"\n        />\n        <path\n            *tuiRepeatTimes=\"let index of segments.length\"\n            automation-id=\"tui-pie-chart__segment\"\n            d=\"\"\n            fill=\"currentColor\"\n            tuiHintPointer\n            class=\"t-segment\"\n            [attr.transform]=\"getTransform(index)\"\n            [style.color]=\"'var(--tui-chart-categorical-' + index.toString().padStart(2, '0') + ')'\"\n            [tuiHint]=\"hintContent\"\n            [tuiHintContext]=\"{$implicit: index}\"\n            [tuiPieChart]=\"segments[index] || [0, 0]\"\n            (tuiHoveredChange)=\"onHovered($event, index)\"\n        />\n    </g>\n</svg>\n"]}
@@ -1,48 +0,0 @@
1
- import { Directive, inject, Input } from '@angular/core';
2
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
3
- import { WA_ANIMATION_FRAME, WA_PERFORMANCE } from '@ng-web-apis/common';
4
- import { tuiDescribeSector } from '@taiga-ui/addon-charts/utils';
5
- import { tuiZonefree } from '@taiga-ui/cdk/observables';
6
- import { tuiInjectElement } from '@taiga-ui/cdk/utils/dom';
7
- import { tuiClamp } from '@taiga-ui/cdk/utils/math';
8
- import { tuiEaseInOutQuad } from '@taiga-ui/cdk/utils/miscellaneous';
9
- import { TUI_ANIMATIONS_SPEED } from '@taiga-ui/core/tokens';
10
- import { tuiGetDuration } from '@taiga-ui/core/utils/miscellaneous';
11
- import { BehaviorSubject, map, pairwise, switchMap, takeWhile } from 'rxjs';
12
- import * as i0 from "@angular/core";
13
- class TuiPieChartDirective {
14
- constructor() {
15
- this.sector$ = new BehaviorSubject([0, 0]);
16
- this.el = tuiInjectElement();
17
- this.performance = inject(WA_PERFORMANCE);
18
- this.animationFrame$ = inject(WA_ANIMATION_FRAME);
19
- this.speed = inject(TUI_ANIMATIONS_SPEED);
20
- this.$ = this.sector$
21
- .pipe(pairwise(), switchMap(([prev, cur]) => {
22
- const now = this.performance.now();
23
- const startDelta = cur[0] - prev[0];
24
- const endDelta = cur[1] - prev[1];
25
- return this.animationFrame$.pipe(map((timestamp) => tuiEaseInOutQuad(tuiClamp((timestamp - now) / tuiGetDuration(this.speed), 0, 1))), takeWhile((progress) => progress < 1, true), map((progress) => [
26
- prev[0] + startDelta * progress,
27
- cur[1] > 359 ? cur[1] : prev[1] + endDelta * progress,
28
- ]));
29
- }), tuiZonefree(), takeUntilDestroyed())
30
- .subscribe(([start, end]) => this.el.setAttribute('d', tuiDescribeSector(start, end)));
31
- }
32
- set tuiPieChart(sector) {
33
- this.sector$.next(sector);
34
- }
35
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPieChartDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
36
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiPieChartDirective, isStandalone: true, selector: "path[tuiPieChart]", inputs: { tuiPieChart: "tuiPieChart" }, ngImport: i0 }); }
37
- }
38
- export { TuiPieChartDirective };
39
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiPieChartDirective, decorators: [{
40
- type: Directive,
41
- args: [{
42
- standalone: true,
43
- selector: 'path[tuiPieChart]',
44
- }]
45
- }], propDecorators: { tuiPieChart: [{
46
- type: Input
47
- }] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGllLWNoYXJ0LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWNoYXJ0cy9jb21wb25lbnRzL3BpZS1jaGFydC9waWUtY2hhcnQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxTQUFTLEVBQUUsTUFBTSxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUN2RCxPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSw0QkFBNEIsQ0FBQztBQUM5RCxPQUFPLEVBQUMsa0JBQWtCLEVBQUUsY0FBYyxFQUFDLE1BQU0scUJBQXFCLENBQUM7QUFDdkUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sOEJBQThCLENBQUM7QUFDL0QsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLDJCQUEyQixDQUFDO0FBQ3RELE9BQU8sRUFBQyxnQkFBZ0IsRUFBQyxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSwwQkFBMEIsQ0FBQztBQUNsRCxPQUFPLEVBQUMsZ0JBQWdCLEVBQUMsTUFBTSxtQ0FBbUMsQ0FBQztBQUNuRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSx1QkFBdUIsQ0FBQztBQUMzRCxPQUFPLEVBQUMsY0FBYyxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDbEUsT0FBTyxFQUFDLGVBQWUsRUFBRSxHQUFHLEVBQUUsUUFBUSxFQUFFLFNBQVMsRUFBRSxTQUFTLEVBQUMsTUFBTSxNQUFNLENBQUM7O0FBRTFFLE1BSWEsb0JBQW9CO0lBSmpDO1FBS3FCLFlBQU8sR0FBRyxJQUFJLGVBQWUsQ0FBNEIsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQztRQUNqRSxPQUFFLEdBQUcsZ0JBQWdCLEVBQWtCLENBQUM7UUFDeEMsZ0JBQVcsR0FBRyxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDckMsb0JBQWUsR0FBRyxNQUFNLENBQUMsa0JBQWtCLENBQUMsQ0FBQztRQUM3QyxVQUFLLEdBQUcsTUFBTSxDQUFDLG9CQUFvQixDQUFDLENBQUM7UUFDbkMsTUFBQyxHQUFHLElBQUksQ0FBQyxPQUFPO2FBQzlCLElBQUksQ0FDRCxRQUFRLEVBQUUsRUFDVixTQUFTLENBQUMsQ0FBQyxDQUFDLElBQUksRUFBRSxHQUFHLENBQUMsRUFBRSxFQUFFO1lBQ3RCLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDbkMsTUFBTSxVQUFVLEdBQUcsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNwQyxNQUFNLFFBQVEsR0FBRyxHQUFHLENBQUMsQ0FBQyxDQUFDLEdBQUcsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBRWxDLE9BQU8sSUFBSSxDQUFDLGVBQWUsQ0FBQyxJQUFJLENBQzVCLEdBQUcsQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFLENBQ2QsZ0JBQWdCLENBQ1osUUFBUSxDQUNKLENBQUMsU0FBUyxHQUFHLEdBQUcsQ0FBQyxHQUFHLGNBQWMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLEVBQzlDLENBQUMsRUFDRCxDQUFDLENBQ0osQ0FDSixDQUNKLEVBQ0QsU0FBUyxDQUFDLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxRQUFRLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxFQUMzQyxHQUFHLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDO2dCQUNkLElBQUksQ0FBQyxDQUFDLENBQUMsR0FBRyxVQUFVLEdBQUcsUUFBUTtnQkFDL0IsR0FBRyxDQUFDLENBQUMsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLEdBQUcsUUFBUSxHQUFHLFFBQVE7YUFDeEQsQ0FBQyxDQUNMLENBQUM7UUFDTixDQUFDLENBQUMsRUFDRixXQUFXLEVBQUUsRUFDYixrQkFBa0IsRUFBRSxDQUN2QjthQUNBLFNBQVMsQ0FBQyxDQUFDLENBQUMsS0FBSyxFQUFFLEdBQUcsQ0FBQyxFQUFFLEVBQUUsQ0FDeEIsSUFBSSxDQUFDLEVBQUUsQ0FBQyxZQUFZLENBQUMsR0FBRyxFQUFFLGlCQUFpQixDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsQ0FBQyxDQUMzRCxDQUFDO0tBTVQ7SUFKRyxJQUNXLFdBQVcsQ0FBQyxNQUFpQztRQUNwRCxJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUM5QixDQUFDOytHQXpDUSxvQkFBb0I7bUdBQXBCLG9CQUFvQjs7U0FBcEIsb0JBQW9COzRGQUFwQixvQkFBb0I7a0JBSmhDLFNBQVM7bUJBQUM7b0JBQ1AsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLFFBQVEsRUFBRSxtQkFBbUI7aUJBQ2hDOzhCQXdDYyxXQUFXO3NCQURyQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEaXJlY3RpdmUsIGluamVjdCwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHt0YWtlVW50aWxEZXN0cm95ZWR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUvcnhqcy1pbnRlcm9wJztcbmltcG9ydCB7V0FfQU5JTUFUSU9OX0ZSQU1FLCBXQV9QRVJGT1JNQU5DRX0gZnJvbSAnQG5nLXdlYi1hcGlzL2NvbW1vbic7XG5pbXBvcnQge3R1aURlc2NyaWJlU2VjdG9yfSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY2hhcnRzL3V0aWxzJztcbmltcG9ydCB7dHVpWm9uZWZyZWV9IGZyb20gJ0B0YWlnYS11aS9jZGsvb2JzZXJ2YWJsZXMnO1xuaW1wb3J0IHt0dWlJbmplY3RFbGVtZW50fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL2RvbSc7XG5pbXBvcnQge3R1aUNsYW1wfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL21hdGgnO1xuaW1wb3J0IHt0dWlFYXNlSW5PdXRRdWFkfSBmcm9tICdAdGFpZ2EtdWkvY2RrL3V0aWxzL21pc2NlbGxhbmVvdXMnO1xuaW1wb3J0IHtUVUlfQU5JTUFUSU9OU19TUEVFRH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdG9rZW5zJztcbmltcG9ydCB7dHVpR2V0RHVyYXRpb259IGZyb20gJ0B0YWlnYS11aS9jb3JlL3V0aWxzL21pc2NlbGxhbmVvdXMnO1xuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIG1hcCwgcGFpcndpc2UsIHN3aXRjaE1hcCwgdGFrZVdoaWxlfSBmcm9tICdyeGpzJztcblxuQERpcmVjdGl2ZSh7XG4gICAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgICBzZWxlY3RvcjogJ3BhdGhbdHVpUGllQ2hhcnRdJyxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUGllQ2hhcnREaXJlY3RpdmUge1xuICAgIHByaXZhdGUgcmVhZG9ubHkgc2VjdG9yJCA9IG5ldyBCZWhhdmlvclN1YmplY3Q8cmVhZG9ubHkgW251bWJlciwgbnVtYmVyXT4oWzAsIDBdKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGVsID0gdHVpSW5qZWN0RWxlbWVudDxTVkdQYXRoRWxlbWVudD4oKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IHBlcmZvcm1hbmNlID0gaW5qZWN0KFdBX1BFUkZPUk1BTkNFKTtcbiAgICBwcml2YXRlIHJlYWRvbmx5IGFuaW1hdGlvbkZyYW1lJCA9IGluamVjdChXQV9BTklNQVRJT05fRlJBTUUpO1xuICAgIHByaXZhdGUgcmVhZG9ubHkgc3BlZWQgPSBpbmplY3QoVFVJX0FOSU1BVElPTlNfU1BFRUQpO1xuICAgIHByb3RlY3RlZCByZWFkb25seSAkID0gdGhpcy5zZWN0b3IkXG4gICAgICAgIC5waXBlKFxuICAgICAgICAgICAgcGFpcndpc2UoKSxcbiAgICAgICAgICAgIHN3aXRjaE1hcCgoW3ByZXYsIGN1cl0pID0+IHtcbiAgICAgICAgICAgICAgICBjb25zdCBub3cgPSB0aGlzLnBlcmZvcm1hbmNlLm5vdygpO1xuICAgICAgICAgICAgICAgIGNvbnN0IHN0YXJ0RGVsdGEgPSBjdXJbMF0gLSBwcmV2WzBdO1xuICAgICAgICAgICAgICAgIGNvbnN0IGVuZERlbHRhID0gY3VyWzFdIC0gcHJldlsxXTtcblxuICAgICAgICAgICAgICAgIHJldHVybiB0aGlzLmFuaW1hdGlvbkZyYW1lJC5waXBlKFxuICAgICAgICAgICAgICAgICAgICBtYXAoKHRpbWVzdGFtcCkgPT5cbiAgICAgICAgICAgICAgICAgICAgICAgIHR1aUVhc2VJbk91dFF1YWQoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgdHVpQ2xhbXAoXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICh0aW1lc3RhbXAgLSBub3cpIC8gdHVpR2V0RHVyYXRpb24odGhpcy5zcGVlZCksXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDAsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIDEsXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgKSxcbiAgICAgICAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICAgICksXG4gICAgICAgICAgICAgICAgICAgIHRha2VXaGlsZSgocHJvZ3Jlc3MpID0+IHByb2dyZXNzIDwgMSwgdHJ1ZSksXG4gICAgICAgICAgICAgICAgICAgIG1hcCgocHJvZ3Jlc3MpID0+IFtcbiAgICAgICAgICAgICAgICAgICAgICAgIHByZXZbMF0gKyBzdGFydERlbHRhICogcHJvZ3Jlc3MsXG4gICAgICAgICAgICAgICAgICAgICAgICBjdXJbMV0gPiAzNTkgPyBjdXJbMV0gOiBwcmV2WzFdICsgZW5kRGVsdGEgKiBwcm9ncmVzcyxcbiAgICAgICAgICAgICAgICAgICAgXSksXG4gICAgICAgICAgICAgICAgKTtcbiAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgdHVpWm9uZWZyZWUoKSxcbiAgICAgICAgICAgIHRha2VVbnRpbERlc3Ryb3llZCgpLFxuICAgICAgICApXG4gICAgICAgIC5zdWJzY3JpYmUoKFtzdGFydCwgZW5kXSkgPT5cbiAgICAgICAgICAgIHRoaXMuZWwuc2V0QXR0cmlidXRlKCdkJywgdHVpRGVzY3JpYmVTZWN0b3Ioc3RhcnQsIGVuZCkpLFxuICAgICAgICApO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgc2V0IHR1aVBpZUNoYXJ0KHNlY3RvcjogcmVhZG9ubHkgW251bWJlciwgbnVtYmVyXSkge1xuICAgICAgICB0aGlzLnNlY3RvciQubmV4dChzZWN0b3IpO1xuICAgIH1cbn1cbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMtcGllLWNoYXJ0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvcGllLWNoYXJ0L3RhaWdhLXVpLWFkZG9uLWNoYXJ0cy1jb21wb25lbnRzLXBpZS1jaGFydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export * from './ring-chart.component';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9yaW5nLWNoYXJ0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL3JpbmctY2hhcnQuY29tcG9uZW50JztcbiJdfQ==
@@ -1,39 +0,0 @@
1
- import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, } from '@angular/core';
2
- import { TuiPieChart } from '@taiga-ui/addon-charts/components/pie-chart';
3
- import * as i0 from "@angular/core";
4
- class TuiRingChart {
5
- constructor() {
6
- this.value = [];
7
- this.size = 'm';
8
- this.activeItemIndex = NaN;
9
- this.activeItemIndexChange = new EventEmitter();
10
- }
11
- onActiveItemIndexChange(index) {
12
- this.updateActiveItemIndex(index);
13
- }
14
- updateActiveItemIndex(index) {
15
- if (index === this.activeItemIndex) {
16
- return;
17
- }
18
- this.activeItemIndex = index;
19
- this.activeItemIndexChange.next(index);
20
- }
21
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRingChart, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
22
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiRingChart, isStandalone: true, selector: "tui-ring-chart", inputs: { value: "value", size: "size", activeItemIndex: "activeItemIndex" }, outputs: { activeItemIndexChange: "activeItemIndexChange" }, host: { properties: { "attr.data-size": "size" } }, ngImport: i0, template: "<div class=\"t-content\">\n <div class=\"t-wrapper\">\n <ng-content />\n </div>\n</div>\n\n<tui-pie-chart\n class=\"t-chart\"\n [activeItemIndex]=\"activeItemIndex\"\n [masked]=\"true\"\n [size]=\"size\"\n [value]=\"value\"\n (activeItemIndexChange)=\"onActiveItemIndexChange($event)\"\n/>\n\n<div class=\"t-shield\"></div>\n", styles: [":host{position:relative;display:block;inline-size:var(--t-size);block-size:var(--t-size);flex-shrink:0;border-radius:100%}:host[data-size=xs]{--t-size: 3rem}:host[data-size=s]{--t-size: 4rem}:host[data-size=m]{--t-size: 9rem}:host[data-size=l]{--t-size: 11rem}:host[data-size=xl]{--t-size: 16rem}.t-content{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;display:flex;font:var(--tui-font-text-m);max-block-size:100%;flex-direction:column;justify-content:center;text-align:center;padding:1.5rem;border-radius:100%;box-sizing:border-box;overflow:hidden;word-break:break-word;white-space:pre-wrap;color:var(--tui-text-secondary)}:host[data-size=m] .t-content{font:var(--tui-font-text-xs)}.t-wrapper:first-line{color:var(--tui-text-primary)}:host[data-size=l] .t-wrapper:first-line{font:var(--tui-font-text-l);font-weight:700}:host[data-size=m] .t-wrapper:first-line{font:var(--tui-font-text-m);font-weight:700}.t-shield{position:absolute;top:25%;left:25%;right:25%;bottom:25%;border-radius:100%}.t-chart{inline-size:100%;block-size:100%}\n"], dependencies: [{ kind: "component", type: TuiPieChart, selector: "tui-pie-chart", inputs: ["value", "size", "masked", "activeItemIndex"], outputs: ["activeItemIndexChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
23
- }
24
- export { TuiRingChart };
25
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiRingChart, decorators: [{
26
- type: Component,
27
- args: [{ standalone: true, selector: 'tui-ring-chart', imports: [TuiPieChart], changeDetection: ChangeDetectionStrategy.OnPush, host: {
28
- '[attr.data-size]': 'size',
29
- }, template: "<div class=\"t-content\">\n <div class=\"t-wrapper\">\n <ng-content />\n </div>\n</div>\n\n<tui-pie-chart\n class=\"t-chart\"\n [activeItemIndex]=\"activeItemIndex\"\n [masked]=\"true\"\n [size]=\"size\"\n [value]=\"value\"\n (activeItemIndexChange)=\"onActiveItemIndexChange($event)\"\n/>\n\n<div class=\"t-shield\"></div>\n", styles: [":host{position:relative;display:block;inline-size:var(--t-size);block-size:var(--t-size);flex-shrink:0;border-radius:100%}:host[data-size=xs]{--t-size: 3rem}:host[data-size=s]{--t-size: 4rem}:host[data-size=m]{--t-size: 9rem}:host[data-size=l]{--t-size: 11rem}:host[data-size=xl]{--t-size: 16rem}.t-content{position:absolute;top:0;left:0;inline-size:100%;block-size:100%;display:flex;font:var(--tui-font-text-m);max-block-size:100%;flex-direction:column;justify-content:center;text-align:center;padding:1.5rem;border-radius:100%;box-sizing:border-box;overflow:hidden;word-break:break-word;white-space:pre-wrap;color:var(--tui-text-secondary)}:host[data-size=m] .t-content{font:var(--tui-font-text-xs)}.t-wrapper:first-line{color:var(--tui-text-primary)}:host[data-size=l] .t-wrapper:first-line{font:var(--tui-font-text-l);font-weight:700}:host[data-size=m] .t-wrapper:first-line{font:var(--tui-font-text-m);font-weight:700}.t-shield{position:absolute;top:25%;left:25%;right:25%;bottom:25%;border-radius:100%}.t-chart{inline-size:100%;block-size:100%}\n"] }]
30
- }], propDecorators: { value: [{
31
- type: Input
32
- }], size: [{
33
- type: Input
34
- }], activeItemIndex: [{
35
- type: Input
36
- }], activeItemIndexChange: [{
37
- type: Output
38
- }] } });
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmluZy1jaGFydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9yaW5nLWNoYXJ0L3JpbmctY2hhcnQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvcmluZy1jaGFydC9yaW5nLWNoYXJ0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUNILHVCQUF1QixFQUN2QixTQUFTLEVBQ1QsWUFBWSxFQUNaLEtBQUssRUFDTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLDZDQUE2QyxDQUFDOztBQUd4RSxNQVdhLFlBQVk7SUFYekI7UUFhVyxVQUFLLEdBQXNCLEVBQUUsQ0FBQztRQUc5QixTQUFJLEdBQTBCLEdBQUcsQ0FBQztRQUdsQyxvQkFBZSxHQUFHLEdBQUcsQ0FBQztRQUdiLDBCQUFxQixHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7S0FjdEU7SUFaYSx1QkFBdUIsQ0FBQyxLQUFhO1FBQzNDLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN0QyxDQUFDO0lBRU8scUJBQXFCLENBQUMsS0FBYTtRQUN2QyxJQUFJLEtBQUssS0FBSyxJQUFJLENBQUMsZUFBZSxFQUFFO1lBQ2hDLE9BQU87U0FDVjtRQUVELElBQUksQ0FBQyxlQUFlLEdBQUcsS0FBSyxDQUFDO1FBQzdCLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQzsrR0F4QlEsWUFBWTttR0FBWixZQUFZLHlRQ3JCekIsc1dBZ0JBLHNsQ0RIYyxXQUFXOztTQVFaLFlBQVk7NEZBQVosWUFBWTtrQkFYeEIsU0FBUztpQ0FDTSxJQUFJLFlBQ04sZ0JBQWdCLFdBQ2pCLENBQUMsV0FBVyxDQUFDLG1CQUdMLHVCQUF1QixDQUFDLE1BQU0sUUFDekM7d0JBQ0Ysa0JBQWtCLEVBQUUsTUFBTTtxQkFDN0I7OEJBSU0sS0FBSztzQkFEWCxLQUFLO2dCQUlDLElBQUk7c0JBRFYsS0FBSztnQkFJQyxlQUFlO3NCQURyQixLQUFLO2dCQUlVLHFCQUFxQjtzQkFEcEMsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gICAgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksXG4gICAgQ29tcG9uZW50LFxuICAgIEV2ZW50RW1pdHRlcixcbiAgICBJbnB1dCxcbiAgICBPdXRwdXQsXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtUdWlQaWVDaGFydH0gZnJvbSAnQHRhaWdhLXVpL2FkZG9uLWNoYXJ0cy9jb21wb25lbnRzL3BpZS1jaGFydCc7XG5pbXBvcnQge3R5cGUgVHVpU2l6ZVhMLCB0eXBlIFR1aVNpemVYU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUvdHlwZXMnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzdGFuZGFsb25lOiB0cnVlLFxuICAgIHNlbGVjdG9yOiAndHVpLXJpbmctY2hhcnQnLFxuICAgIGltcG9ydHM6IFtUdWlQaWVDaGFydF0sXG4gICAgdGVtcGxhdGVVcmw6ICcuL3JpbmctY2hhcnQudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vcmluZy1jaGFydC5zdHlsZS5sZXNzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG4gICAgaG9zdDoge1xuICAgICAgICAnW2F0dHIuZGF0YS1zaXplXSc6ICdzaXplJyxcbiAgICB9LFxufSlcbmV4cG9ydCBjbGFzcyBUdWlSaW5nQ2hhcnQge1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIHZhbHVlOiByZWFkb25seSBudW1iZXJbXSA9IFtdO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgc2l6ZTogVHVpU2l6ZVhMIHwgVHVpU2l6ZVhTID0gJ20nO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgYWN0aXZlSXRlbUluZGV4ID0gTmFOO1xuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIHJlYWRvbmx5IGFjdGl2ZUl0ZW1JbmRleENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xuXG4gICAgcHJvdGVjdGVkIG9uQWN0aXZlSXRlbUluZGV4Q2hhbmdlKGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgdGhpcy51cGRhdGVBY3RpdmVJdGVtSW5kZXgoaW5kZXgpO1xuICAgIH1cblxuICAgIHByaXZhdGUgdXBkYXRlQWN0aXZlSXRlbUluZGV4KGluZGV4OiBudW1iZXIpOiB2b2lkIHtcbiAgICAgICAgaWYgKGluZGV4ID09PSB0aGlzLmFjdGl2ZUl0ZW1JbmRleCkge1xuICAgICAgICAgICAgcmV0dXJuO1xuICAgICAgICB9XG5cbiAgICAgICAgdGhpcy5hY3RpdmVJdGVtSW5kZXggPSBpbmRleDtcbiAgICAgICAgdGhpcy5hY3RpdmVJdGVtSW5kZXhDaGFuZ2UubmV4dChpbmRleCk7XG4gICAgfVxufVxuIiwiPGRpdiBjbGFzcz1cInQtY29udGVudFwiPlxuICAgIDxkaXYgY2xhc3M9XCJ0LXdyYXBwZXJcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgLz5cbiAgICA8L2Rpdj5cbjwvZGl2PlxuXG48dHVpLXBpZS1jaGFydFxuICAgIGNsYXNzPVwidC1jaGFydFwiXG4gICAgW2FjdGl2ZUl0ZW1JbmRleF09XCJhY3RpdmVJdGVtSW5kZXhcIlxuICAgIFttYXNrZWRdPVwidHJ1ZVwiXG4gICAgW3NpemVdPVwic2l6ZVwiXG4gICAgW3ZhbHVlXT1cInZhbHVlXCJcbiAgICAoYWN0aXZlSXRlbUluZGV4Q2hhbmdlKT1cIm9uQWN0aXZlSXRlbUluZGV4Q2hhbmdlKCRldmVudClcIlxuLz5cblxuPGRpdiBjbGFzcz1cInQtc2hpZWxkXCI+PC9kaXY+XG4iXX0=
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMtcmluZy1jaGFydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWNoYXJ0cy9jb21wb25lbnRzL3JpbmctY2hhcnQvdGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMtcmluZy1jaGFydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy90YWlnYS11aS1hZGRvbi1jaGFydHMtY29tcG9uZW50cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
package/esm2022/index.mjs DELETED
@@ -1,2 +0,0 @@
1
- export * from '@taiga-ui/addon-charts/components';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxtQ0FBbUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJ0B0YWlnYS11aS9hZGRvbi1jaGFydHMvY29tcG9uZW50cyc7XG5leHBvcnQgdHlwZSAqIGZyb20gJ0B0YWlnYS11aS9hZGRvbi1jaGFydHMvdHlwZXMnO1xuIl19
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL3RhaWdhLXVpLWFkZG9uLWNoYXJ0cy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvdHlwZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7dHlwZSBUdWlDb250ZXh0fSBmcm9tICdAdGFpZ2EtdWkvY2RrL3R5cGVzJztcblxuLyoqXG4gKiBOYXRpdmUgQ1NTIGJvcmRlci1zdHlsZSBvcHRpb25zXG4gKi9cbmV4cG9ydCB0eXBlIFR1aUxpbmVUeXBlID0gJ2Rhc2hlZCcgfCAnZG90dGVkJyB8ICdoaWRkZW4nIHwgJ25vbmUnIHwgJ3NvbGlkJztcblxuZXhwb3J0IHR5cGUgVHVpTGluZUhhbmRsZXIgPSAoaW5kZXg6IG51bWJlciwgdG90YWw6IG51bWJlcikgPT4gVHVpTGluZVR5cGU7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpTGluZUNoYXJ0SGludENvbnRleHQ8VD4gZXh0ZW5kcyBUdWlDb250ZXh0PFQ+IHtcbiAgICByZWFkb25seSBpbmRleD86IG51bWJlcjtcbn1cbiJdfQ==
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL3R5cGVzL3RhaWdhLXVpLWFkZG9uLWNoYXJ0cy10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,13 +0,0 @@
1
- import { tuiLineAngle } from './line-angle';
2
- import { tuiLineLength } from './line-length';
3
- export function tuiControlPoint(current, previous, next, reverse = false, smoothing = 0.2) {
4
- const fallback = current || [0, 0];
5
- const p = previous || current || [0, 0];
6
- const n = next || current || [0, 0];
7
- const angle = tuiLineAngle(p, n) + (reverse ? Math.PI : 0);
8
- const length = tuiLineLength(p, n) * smoothing;
9
- const x = fallback[0] + Math.cos(angle) * length;
10
- const y = fallback[1] + Math.sin(angle) * length;
11
- return [x, y];
12
- }
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udHJvbC1wb2ludC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWNoYXJ0cy91dGlscy9jb250cm9sLXBvaW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBQyxZQUFZLEVBQUMsTUFBTSxjQUFjLENBQUM7QUFDMUMsT0FBTyxFQUFDLGFBQWEsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUU1QyxNQUFNLFVBQVUsZUFBZSxDQUMzQixPQUFrQixFQUNsQixRQUFtQixFQUNuQixJQUFlLEVBQ2YsT0FBTyxHQUFHLEtBQUssRUFDZixTQUFTLEdBQUcsR0FBRztJQUVmLE1BQU0sUUFBUSxHQUFHLE9BQU8sSUFBSyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQVcsQ0FBQztJQUM5QyxNQUFNLENBQUMsR0FBRyxRQUFRLElBQUksT0FBTyxJQUFLLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBVyxDQUFDO0lBQ25ELE1BQU0sQ0FBQyxHQUFHLElBQUksSUFBSSxPQUFPLElBQUssQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFXLENBQUM7SUFDL0MsTUFBTSxLQUFLLEdBQUcsWUFBWSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFDM0QsTUFBTSxNQUFNLEdBQUcsYUFBYSxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxTQUFTLENBQUM7SUFDL0MsTUFBTSxDQUFDLEdBQUcsUUFBUSxDQUFDLENBQUMsQ0FBQyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEdBQUcsTUFBTSxDQUFDO0lBQ2pELE1BQU0sQ0FBQyxHQUFHLFFBQVEsQ0FBQyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQyxHQUFHLE1BQU0sQ0FBQztJQUVqRCxPQUFPLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ2xCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge3R5cGUgVHVpUG9pbnR9IGZyb20gJ0B0YWlnYS11aS9jb3JlL3R5cGVzJztcblxuaW1wb3J0IHt0dWlMaW5lQW5nbGV9IGZyb20gJy4vbGluZS1hbmdsZSc7XG5pbXBvcnQge3R1aUxpbmVMZW5ndGh9IGZyb20gJy4vbGluZS1sZW5ndGgnO1xuXG5leHBvcnQgZnVuY3Rpb24gdHVpQ29udHJvbFBvaW50KFxuICAgIGN1cnJlbnQ/OiBUdWlQb2ludCxcbiAgICBwcmV2aW91cz86IFR1aVBvaW50LFxuICAgIG5leHQ/OiBUdWlQb2ludCxcbiAgICByZXZlcnNlID0gZmFsc2UsXG4gICAgc21vb3RoaW5nID0gMC4yLFxuKTogVHVpUG9pbnQge1xuICAgIGNvbnN0IGZhbGxiYWNrID0gY3VycmVudCB8fCAoWzAsIDBdIGFzIGNvbnN0KTtcbiAgICBjb25zdCBwID0gcHJldmlvdXMgfHwgY3VycmVudCB8fCAoWzAsIDBdIGFzIGNvbnN0KTtcbiAgICBjb25zdCBuID0gbmV4dCB8fCBjdXJyZW50IHx8IChbMCwgMF0gYXMgY29uc3QpO1xuICAgIGNvbnN0IGFuZ2xlID0gdHVpTGluZUFuZ2xlKHAsIG4pICsgKHJldmVyc2UgPyBNYXRoLlBJIDogMCk7XG4gICAgY29uc3QgbGVuZ3RoID0gdHVpTGluZUxlbmd0aChwLCBuKSAqIHNtb290aGluZztcbiAgICBjb25zdCB4ID0gZmFsbGJhY2tbMF0gKyBNYXRoLmNvcyhhbmdsZSkgKiBsZW5ndGg7XG4gICAgY29uc3QgeSA9IGZhbGxiYWNrWzFdICsgTWF0aC5zaW4oYW5nbGUpICogbGVuZ3RoO1xuXG4gICAgcmV0dXJuIFt4LCB5XTtcbn1cbiJdfQ==