@taiga-ui/addon-charts 4.52.0-canary.d626d20 → 4.52.0-canary.e07790b

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 (76) hide show
  1. package/README.md +2 -2
  2. package/components/line-chart/line-chart-hint.directive.d.ts +3 -3
  3. package/components/line-chart/line-chart.component.d.ts +4 -3
  4. package/components/line-chart/line-chart.options.d.ts +1 -3
  5. package/fesm2022/taiga-ui-addon-charts-components-arc-chart.mjs +6 -7
  6. package/fesm2022/taiga-ui-addon-charts-components-arc-chart.mjs.map +1 -1
  7. package/fesm2022/taiga-ui-addon-charts-components-axes.mjs +6 -8
  8. package/fesm2022/taiga-ui-addon-charts-components-axes.mjs.map +1 -1
  9. package/fesm2022/taiga-ui-addon-charts-components-bar-chart.mjs +10 -11
  10. package/fesm2022/taiga-ui-addon-charts-components-bar-chart.mjs.map +1 -1
  11. package/fesm2022/taiga-ui-addon-charts-components-bar-set.mjs +6 -6
  12. package/fesm2022/taiga-ui-addon-charts-components-bar-set.mjs.map +1 -1
  13. package/fesm2022/taiga-ui-addon-charts-components-bar.mjs +6 -7
  14. package/fesm2022/taiga-ui-addon-charts-components-bar.mjs.map +1 -1
  15. package/fesm2022/taiga-ui-addon-charts-components-legend-item.mjs +5 -5
  16. package/fesm2022/taiga-ui-addon-charts-components-legend-item.mjs.map +1 -1
  17. package/fesm2022/taiga-ui-addon-charts-components-line-chart.mjs +28 -34
  18. package/fesm2022/taiga-ui-addon-charts-components-line-chart.mjs.map +1 -1
  19. package/fesm2022/taiga-ui-addon-charts-components-line-days-chart.mjs +16 -18
  20. package/fesm2022/taiga-ui-addon-charts-components-line-days-chart.mjs.map +1 -1
  21. package/fesm2022/taiga-ui-addon-charts-components-pie-chart.mjs +18 -17
  22. package/fesm2022/taiga-ui-addon-charts-components-pie-chart.mjs.map +1 -1
  23. package/fesm2022/taiga-ui-addon-charts-components-ring-chart.mjs +6 -6
  24. package/fesm2022/taiga-ui-addon-charts-components-ring-chart.mjs.map +1 -1
  25. package/fesm2022/taiga-ui-addon-charts-utils.mjs +6 -3
  26. package/fesm2022/taiga-ui-addon-charts-utils.mjs.map +1 -1
  27. package/package.json +16 -41
  28. package/esm2022/components/arc-chart/arc-chart.component.mjs +0 -85
  29. package/esm2022/components/arc-chart/index.mjs +0 -2
  30. package/esm2022/components/arc-chart/taiga-ui-addon-charts-components-arc-chart.mjs +0 -5
  31. package/esm2022/components/axes/axes.component.mjs +0 -79
  32. package/esm2022/components/axes/index.mjs +0 -2
  33. package/esm2022/components/axes/taiga-ui-addon-charts-components-axes.mjs +0 -5
  34. package/esm2022/components/bar/bar.component.mjs +0 -35
  35. package/esm2022/components/bar/index.mjs +0 -2
  36. package/esm2022/components/bar/taiga-ui-addon-charts-components-bar.mjs +0 -5
  37. package/esm2022/components/bar-chart/bar-chart.component.mjs +0 -77
  38. package/esm2022/components/bar-chart/index.mjs +0 -2
  39. package/esm2022/components/bar-chart/taiga-ui-addon-charts-components-bar-chart.mjs +0 -5
  40. package/esm2022/components/bar-set/bar-set.component.mjs +0 -50
  41. package/esm2022/components/bar-set/index.mjs +0 -2
  42. package/esm2022/components/bar-set/taiga-ui-addon-charts-components-bar-set.mjs +0 -5
  43. package/esm2022/components/index.mjs +0 -11
  44. package/esm2022/components/legend-item/index.mjs +0 -2
  45. package/esm2022/components/legend-item/legend-item.component.mjs +0 -37
  46. package/esm2022/components/legend-item/taiga-ui-addon-charts-components-legend-item.mjs +0 -5
  47. package/esm2022/components/line-chart/index.mjs +0 -4
  48. package/esm2022/components/line-chart/line-chart-hint.directive.mjs +0 -68
  49. package/esm2022/components/line-chart/line-chart.component.mjs +0 -180
  50. package/esm2022/components/line-chart/line-chart.options.mjs +0 -14
  51. package/esm2022/components/line-chart/taiga-ui-addon-charts-components-line-chart.mjs +0 -5
  52. package/esm2022/components/line-days-chart/index.mjs +0 -3
  53. package/esm2022/components/line-days-chart/line-days-chart-hint.directive.mjs +0 -71
  54. package/esm2022/components/line-days-chart/line-days-chart.component.mjs +0 -194
  55. package/esm2022/components/line-days-chart/taiga-ui-addon-charts-components-line-days-chart.mjs +0 -5
  56. package/esm2022/components/pie-chart/index.mjs +0 -3
  57. package/esm2022/components/pie-chart/pie-chart.component.mjs +0 -115
  58. package/esm2022/components/pie-chart/pie-chart.directive.mjs +0 -48
  59. package/esm2022/components/pie-chart/taiga-ui-addon-charts-components-pie-chart.mjs +0 -5
  60. package/esm2022/components/ring-chart/index.mjs +0 -2
  61. package/esm2022/components/ring-chart/ring-chart.component.mjs +0 -39
  62. package/esm2022/components/ring-chart/taiga-ui-addon-charts-components-ring-chart.mjs +0 -5
  63. package/esm2022/components/taiga-ui-addon-charts-components.mjs +0 -5
  64. package/esm2022/index.mjs +0 -2
  65. package/esm2022/taiga-ui-addon-charts.mjs +0 -5
  66. package/esm2022/types/index.mjs +0 -2
  67. package/esm2022/types/taiga-ui-addon-charts-types.mjs +0 -5
  68. package/esm2022/utils/control-point.mjs +0 -13
  69. package/esm2022/utils/describe-sector.mjs +0 -33
  70. package/esm2022/utils/draw-curve.mjs +0 -8
  71. package/esm2022/utils/draw-line.mjs +0 -4
  72. package/esm2022/utils/draw.mjs +0 -10
  73. package/esm2022/utils/index.mjs +0 -8
  74. package/esm2022/utils/line-angle.mjs +0 -6
  75. package/esm2022/utils/line-length.mjs +0 -6
  76. package/esm2022/utils/taiga-ui-addon-charts-utils.mjs +0 -5
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMtbGVnZW5kLWl0ZW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9sZWdlbmQtaXRlbS90YWlnYS11aS1hZGRvbi1jaGFydHMtY29tcG9uZW50cy1sZWdlbmQtaXRlbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,4 +0,0 @@
1
- export * from './line-chart.component';
2
- export * from './line-chart.options';
3
- export * from './line-chart-hint.directive';
4
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9saW5lLWNoYXJ0L2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyxzQkFBc0IsQ0FBQztBQUNyQyxjQUFjLDZCQUE2QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saW5lLWNoYXJ0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmUtY2hhcnQub3B0aW9ucyc7XG5leHBvcnQgKiBmcm9tICcuL2xpbmUtY2hhcnQtaGludC5kaXJlY3RpdmUnO1xuIl19
@@ -1,68 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { ContentChildren, DestroyRef, Directive, ElementRef, forwardRef, inject, Input, NgZone, Renderer2, } from '@angular/core';
3
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
- import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
5
- import { TuiHoveredService } from '@taiga-ui/cdk/directives/hovered';
6
- import { tuiQueryListChanges, tuiZonefree } from '@taiga-ui/cdk/observables';
7
- import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
8
- import { combineLatest, distinctUntilChanged, filter, map, startWith, switchMap, } from 'rxjs';
9
- import { TuiLineChart } from './line-chart.component';
10
- import * as i0 from "@angular/core";
11
- class TuiLineChartHint {
12
- constructor() {
13
- this.charts = EMPTY_QUERY;
14
- this.chartsRef = EMPTY_QUERY;
15
- this.renderer = inject(Renderer2);
16
- this.destroyRef = inject(DestroyRef);
17
- this.zone = inject(NgZone);
18
- this.hovered$ = inject(TuiHoveredService);
19
- }
20
- ngAfterViewInit() {
21
- combineLatest([tuiLineChartDrivers(this.charts), this.hovered$])
22
- .pipe(filter((result) => !result.some(Boolean)), tuiZonefree(this.zone), takeUntilDestroyed(this.destroyRef))
23
- .subscribe(() => {
24
- this.charts.forEach((chart) => chart.onHovered(NaN));
25
- });
26
- }
27
- // _chart is required by TuiLineDaysChartComponent that impersonates this directive
28
- getContext(index, _chart) {
29
- return this.computeContext(...this.charts.map(({ value }) => value))[index] || [];
30
- }
31
- // _chart is required by TuiLineDaysChartComponent that impersonates this directive
32
- raise(index, _chart) {
33
- const current = this.charts.map((chart) => chart.value[index] ?? [0, 0]);
34
- const sorted = [...current].sort((a, b) => a[1] - b[1]);
35
- this.charts.forEach((chart) => chart.onHovered(index));
36
- this.chartsRef.forEach(({ nativeElement }, index) => this.renderer.setStyle(nativeElement, 'z-index', sorted.indexOf(current[index] ?? [0, 0])));
37
- }
38
- computeContext(...values) {
39
- return (values[0] || []).map((_, index) => values.map((value) => value[index] ?? [0, 0]));
40
- }
41
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineChartHint, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
42
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiLineChartHint, isStandalone: true, selector: "[tuiLineChartHint]", inputs: { hint: ["tuiLineChartHint", "hint"] }, providers: [TuiHoveredService], queries: [{ propertyName: "charts", predicate: i0.forwardRef(function () { return TuiLineChart; }) }, { propertyName: "chartsRef", predicate: i0.forwardRef(function () { return TuiLineChart; }), read: ElementRef }], ngImport: i0 }); }
43
- }
44
- __decorate([
45
- tuiPure
46
- ], TuiLineChartHint.prototype, "computeContext", null);
47
- export { TuiLineChartHint };
48
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineChartHint, decorators: [{
49
- type: Directive,
50
- args: [{
51
- standalone: true,
52
- selector: '[tuiLineChartHint]',
53
- providers: [TuiHoveredService],
54
- }]
55
- }], propDecorators: { charts: [{
56
- type: ContentChildren,
57
- args: [forwardRef(() => TuiLineChart)]
58
- }], chartsRef: [{
59
- type: ContentChildren,
60
- args: [forwardRef(() => TuiLineChart), { read: ElementRef }]
61
- }], hint: [{
62
- type: Input,
63
- args: ['tuiLineChartHint']
64
- }], computeContext: [] } });
65
- export function tuiLineChartDrivers(charts) {
66
- return combineLatest(charts.map(({ drivers }) => tuiQueryListChanges(drivers).pipe(map((drivers) => drivers.map((driver) => driver.pipe(startWith(false))))))).pipe(map((all) => all.reduce((acc, drivers) => acc.concat(drivers), [])), switchMap((drivers) => combineLatest(drivers)), map((values) => values.some(Boolean)), distinctUntilChanged());
67
- }
68
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-chart-hint.directive.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/line-chart/line-chart-hint.directive.ts"],"names":[],"mappings":";AAAA,OAAO,EAEH,eAAe,EACf,UAAU,EACV,SAAS,EACT,UAAU,EACV,UAAU,EACV,MAAM,EACN,KAAK,EACL,MAAM,EAEN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,kBAAkB,EAAC,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAC,iBAAiB,EAAC,MAAM,kCAAkC,CAAC;AACnE,OAAO,EAAC,mBAAmB,EAAE,WAAW,EAAC,MAAM,2BAA2B,CAAC;AAE3E,OAAO,EAAC,OAAO,EAAC,MAAM,mCAAmC,CAAC;AAG1D,OAAO,EACH,aAAa,EACb,oBAAoB,EACpB,MAAM,EACN,GAAG,EAEH,SAAS,EACT,SAAS,GACZ,MAAM,MAAM,CAAC;AAEd,OAAO,EAAC,YAAY,EAAC,MAAM,wBAAwB,CAAC;;AAEpD,MAKa,gBAAgB;IAL7B;QAOqB,WAAM,GAA4B,WAAW,CAAC;QAG9C,cAAS,GAAuC,WAAW,CAAC;QAE5D,aAAQ,GAAG,MAAM,CAAC,SAAS,CAAC,CAAC;QAC7B,eAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC;QAChC,SAAI,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACtB,aAAQ,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;KAgDzD;IA3CU,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,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC;QACzD,CAAC,CAAC,CAAC;IACX,CAAC;IAED,mFAAmF;IAC5E,UAAU,CAAC,KAAa,EAAE,MAAoB;QACjD,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,EAAC,KAAK,EAAC,EAAE,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC;IACpF,CAAC;IAED,mFAAmF;IAC5E,KAAK,CAAC,KAAa,EAAE,MAAoB;QAC5C,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,CAC3B,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,IAAK,CAAC,CAAC,EAAE,CAAC,CAAW,CACrD,CAAC;QAEF,MAAM,MAAM,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAExD,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;QACvD,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,EAAC,aAAa,EAAC,EAAE,KAAK,EAAE,EAAE,CAC9C,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAClB,aAAa,EACb,SAAS,EACT,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAC3C,CACJ,CAAC;IACN,CAAC;IAGO,cAAc,CAClB,GAAG,MAA0C;QAE7C,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE,CACtC,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAChD,CAAC;IACN,CAAC;+GAzDQ,gBAAgB;mGAAhB,gBAAgB,iHAFd,CAAC,iBAAiB,CAAC,oFAGI,YAAY,mFAGZ,YAAY,YAAU,UAAU;;AA+C1D;IADP,OAAO;sDAOP;SAzDQ,gBAAgB;4FAAhB,gBAAgB;kBAL5B,SAAS;mBAAC;oBACP,UAAU,EAAE,IAAI;oBAChB,QAAQ,EAAE,oBAAoB;oBAC9B,SAAS,EAAE,CAAC,iBAAiB,CAAC;iBACjC;8BAGoB,MAAM;sBADtB,eAAe;uBAAC,UAAU,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC;gBAI9B,SAAS;sBADzB,eAAe;uBAAC,UAAU,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,EAAE,EAAC,IAAI,EAAE,UAAU,EAAC;gBAS5D,IAAI;sBADV,KAAK;uBAAC,kBAAkB;gBAuCjB,cAAc;AAS1B,MAAM,UAAU,mBAAmB,CAC/B,MAA4D;IAE5D,OAAO,aAAa,CAChB,MAAM,CAAC,GAAG,CAAC,CAAC,EAAC,OAAO,EAAC,EAAE,EAAE,CACrB,mBAAmB,CAAC,OAAO,CAAC,CAAC,IAAI,CAC7B,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAC3E,CACJ,CACJ,CAAC,IAAI,CACF,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE,EAAE,CAAC,CAAC,EACnE,SAAS,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,EAC9C,GAAG,CAAC,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,EACrC,oBAAoB,EAAE,CACzB,CAAC;AACN,CAAC","sourcesContent":["import {\n    type AfterViewInit,\n    ContentChildren,\n    DestroyRef,\n    Directive,\n    ElementRef,\n    forwardRef,\n    inject,\n    Input,\n    NgZone,\n    type QueryList,\n    Renderer2,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiHoveredService} from '@taiga-ui/cdk/directives/hovered';\nimport {tuiQueryListChanges, tuiZonefree} from '@taiga-ui/cdk/observables';\nimport {type TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {type TuiPoint} from '@taiga-ui/core/types';\nimport {type PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {\n    combineLatest,\n    distinctUntilChanged,\n    filter,\n    map,\n    type Observable,\n    startWith,\n    switchMap,\n} from 'rxjs';\n\nimport {TuiLineChart} from './line-chart.component';\n\n@Directive({\n    standalone: true,\n    selector: '[tuiLineChartHint]',\n    providers: [TuiHoveredService],\n})\nexport class TuiLineChartHint implements AfterViewInit {\n    @ContentChildren(forwardRef(() => TuiLineChart))\n    private readonly charts: QueryList<TuiLineChart> = EMPTY_QUERY;\n\n    @ContentChildren(forwardRef(() => TuiLineChart), {read: ElementRef})\n    private readonly chartsRef: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    private readonly renderer = inject(Renderer2);\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly zone = inject(NgZone);\n    private readonly hovered$ = inject(TuiHoveredService);\n\n    @Input('tuiLineChartHint')\n    public hint: PolymorpheusContent<TuiContext<readonly TuiPoint[]>>;\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.charts.forEach((chart) => chart.onHovered(NaN));\n            });\n    }\n\n    // _chart is required by TuiLineDaysChartComponent that impersonates this directive\n    public getContext(index: number, _chart: TuiLineChart): readonly TuiPoint[] {\n        return this.computeContext(...this.charts.map(({value}) => value))[index] || [];\n    }\n\n    // _chart is required by TuiLineDaysChartComponent that impersonates this directive\n    public raise(index: number, _chart: TuiLineChart): void {\n        const current = this.charts.map(\n            (chart) => chart.value[index] ?? ([0, 0] as const),\n        );\n\n        const sorted = [...current].sort((a, b) => a[1] - b[1]);\n\n        this.charts.forEach((chart) => chart.onHovered(index));\n        this.chartsRef.forEach(({nativeElement}, index) =>\n            this.renderer.setStyle(\n                nativeElement,\n                'z-index',\n                sorted.indexOf(current[index] ?? [0, 0]),\n            ),\n        );\n    }\n\n    @tuiPure\n    private computeContext(\n        ...values: ReadonlyArray<readonly TuiPoint[]>\n    ): ReadonlyArray<readonly TuiPoint[]> {\n        return (values[0] || []).map((_, index) =>\n            values.map((value) => value[index] ?? [0, 0]),\n        );\n    }\n}\n\nexport function tuiLineChartDrivers(\n    charts: QueryList<{drivers: QueryList<Observable<boolean>>}>,\n): Observable<boolean> {\n    return combineLatest(\n        charts.map(({drivers}) =>\n            tuiQueryListChanges(drivers).pipe(\n                map((drivers) => drivers.map((driver) => driver.pipe(startWith(false)))),\n            ),\n        ),\n    ).pipe(\n        map((all) => all.reduce((acc, drivers) => acc.concat(drivers), [])),\n        switchMap((drivers) => combineLatest(drivers)),\n        map((values) => values.some(Boolean)),\n        distinctUntilChanged(),\n    );\n}\n"]}
@@ -1,180 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { AsyncPipe, NgForOf, NgIf } from '@angular/common';
3
- import { ChangeDetectionStrategy, Component, computed, inject, Input, NgZone, signal, ViewChildren, } from '@angular/core';
4
- import { toSignal } from '@angular/core/rxjs-interop';
5
- import { ResizeObserverService } from '@ng-web-apis/resize-observer';
6
- import { tuiDraw } from '@taiga-ui/addon-charts/utils';
7
- import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
8
- import { TuiLet } from '@taiga-ui/cdk/directives/let';
9
- import { tuiZoneOptimized } from '@taiga-ui/cdk/observables';
10
- import { tuiInjectId } from '@taiga-ui/cdk/services';
11
- import { tuiIsPresent, tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
12
- import { TuiHint, TuiHintHover, TuiHintOptionsDirective, tuiHintOptionsProvider, } from '@taiga-ui/core/directives/hint';
13
- import { distinctUntilChanged, map, Subject } from 'rxjs';
14
- import { TUI_LINE_CHART_OPTIONS } from './line-chart.options';
15
- import { TuiLineChartHint } from './line-chart-hint.directive';
16
- import * as i0 from "@angular/core";
17
- import * as i1 from "@taiga-ui/core/directives/hint";
18
- class TuiLineChart {
19
- constructor() {
20
- this.zone = inject(NgZone);
21
- this.options = inject(TUI_LINE_CHART_OPTIONS);
22
- this.hover$ = new Subject();
23
- this.autoId = tuiInjectId();
24
- this.resize = toSignal(inject(ResizeObserverService, { self: true }).pipe(map(([e]) => e?.contentRect.height || 0)), { initialValue: 0 });
25
- this.box = signal('');
26
- this.hintDirective = inject(TuiLineChartHint, { optional: true });
27
- this.hintOptions = inject(TuiHintOptionsDirective, { optional: true });
28
- this.viewBox = computed(() => {
29
- const offset = this.height / Math.max(this.resize(), 1);
30
- const [x = 0, y = 0, width = 0, height = 0] = this.box().split(' ').map(Number);
31
- return `${x} ${y - offset} ${width} ${height + 2 * offset}`;
32
- });
33
- this.drivers = EMPTY_QUERY;
34
- this.x = 0;
35
- this.y = 0;
36
- this.width = 0;
37
- this.height = 0;
38
- this.smoothingFactor = this.options.smoothingFactor;
39
- this.xStringify = null;
40
- this.yStringify = null;
41
- this.filled = this.options.filled;
42
- this.dots = this.options.dots;
43
- this.value = [];
44
- }
45
- set valueSetter(value) {
46
- this.value = value.filter((item) => !item.some(Number.isNaN));
47
- }
48
- ngOnChanges() {
49
- this.box.set(`${this.x} ${this.y} ${this.width} ${this.height}`);
50
- }
51
- onHovered(index) {
52
- this.hover$.next(index);
53
- }
54
- get hovered$() {
55
- return this.hover$.pipe(distinctUntilChanged(), tuiZoneOptimized(this.zone));
56
- }
57
- get hintContent() {
58
- return this.hintOptions?.content || '';
59
- }
60
- get fillId() {
61
- return `tui-line-chart-${this.autoId}`;
62
- }
63
- get fill() {
64
- return this.filled ? `url(#${this.fillId})` : 'none';
65
- }
66
- get d() {
67
- return this.getD(this.value, this.smoothingFactor);
68
- }
69
- get fillD() {
70
- return this.value.length
71
- ? `${this.d}V ${this.y} H ${this.value[0]?.[0]} V ${this.value[0]?.[1]}`
72
- : this.d;
73
- }
74
- get isFocusable() {
75
- return !this.hintDirective && this.hasHints;
76
- }
77
- get hasHints() {
78
- return (!!this.xStringify ||
79
- !!this.yStringify ||
80
- !!this.hintDirective?.hint ||
81
- !!this.hintContent);
82
- }
83
- onMouseLeave() {
84
- if (!this.hintDirective) {
85
- this.onHovered(NaN);
86
- }
87
- }
88
- getX(index) {
89
- if (this.isSinglePoint) {
90
- return (this.value[0]?.[0] || 0) / 2;
91
- }
92
- return index
93
- ? ((this.value[index - 1]?.[0] || 0) + (this.value[index]?.[0] || 0)) / 2
94
- : 2 * (this.value[0]?.[0] || 0) - this.getX(1);
95
- }
96
- getWidth(index) {
97
- return (100 * this.computeWidth(index)) / this.width;
98
- }
99
- getHintId(index) {
100
- return `${this.autoId}_${index}`;
101
- }
102
- getImplicit($implicit) {
103
- return (this.hintDirective?.getContext(this.value.indexOf($implicit), this) ??
104
- $implicit);
105
- }
106
- getHovered(hovered) {
107
- // This checks for NaN and null too since async pipe returns null before first item
108
- return tuiIsPresent(hovered) && Number.isInteger(hovered)
109
- ? (this.value[hovered] ?? null)
110
- : null;
111
- }
112
- getBottom(y) {
113
- return (100 * (y - this.y)) / this.height;
114
- }
115
- getLeft(x) {
116
- return (100 * (x - this.x)) / this.width;
117
- }
118
- getOffset(x) {
119
- return (100 * ((this.value[x]?.[0] || 0) - this.getX(x))) / this.computeWidth(x);
120
- }
121
- onMouseEnter(index) {
122
- if (this.hintDirective) {
123
- this.hintDirective.raise(index, this);
124
- }
125
- else {
126
- this.onHovered(index);
127
- }
128
- }
129
- get isSinglePoint() {
130
- return this.value.length === 1;
131
- }
132
- getD(value, smoothingFactor) {
133
- return value.reduce((d, point, index) => index ? `${d} ${tuiDraw(value, index, smoothingFactor)}` : `M ${point}`, '');
134
- }
135
- computeWidth(index) {
136
- return index === this.value.length - 1
137
- ? 2 * ((this.value[index]?.[0] || 0) - this.getX(index))
138
- : this.getX(index + 1) - this.getX(index);
139
- }
140
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineChart, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
141
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: TuiLineChart, isStandalone: true, selector: "tui-line-chart", inputs: { x: "x", y: "y", width: "width", height: "height", smoothingFactor: "smoothingFactor", xStringify: "xStringify", yStringify: "yStringify", filled: "filled", dots: "dots", valueSetter: ["value", "valueSetter"] }, host: { listeners: { "mouseleave": "onMouseLeave()" } }, providers: [ResizeObserverService], viewQueries: [{ propertyName: "drivers", predicate: TuiHintHover, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<ng-container *tuiLet=\"hovered$ | async as hovered\">\n <svg\n focusable=\"false\"\n height=\"100%\"\n preserveAspectRatio=\"none\"\n width=\"100%\"\n xmlns=\"http://www.w3.org/2000/svg\"\n class=\"t-svg\"\n [attr.viewBox]=\"viewBox()\"\n >\n <defs>\n <linearGradient\n x1=\"0\"\n x2=\"0\"\n y1=\"1\"\n y2=\"0\"\n [attr.id]=\"fillId\"\n >\n <stop\n offset=\"0%\"\n stop-color=\"currentColor\"\n stop-opacity=\"0.5\"\n />\n <stop\n offset=\"100%\"\n stop-color=\"currentColor\"\n stop-opacity=\"0\"\n />\n </linearGradient>\n </defs>\n <path\n stroke=\"none\"\n [attr.d]=\"fillD\"\n [attr.fill]=\"fill\"\n />\n <path\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n vector-effect=\"non-scaling-stroke\"\n [attr.d]=\"d\"\n />\n </svg>\n <ng-container *ngIf=\"dots\">\n <div\n *ngFor=\"let point of value\"\n class=\"t-dot\"\n [style.bottom.%]=\"getBottom(point[1])\"\n [style.left.%]=\"getLeft(point[0])\"\n ></div>\n </ng-container>\n <ng-container *ngIf=\"hasHints\">\n <ng-container *ngFor=\"let point of value; let index = index\">\n <!-- TODO: Fix hint type -->\n <div\n *ngIf=\"value.length > 1 || dots\"\n class=\"t-column\"\n [class.t-column_hint_hovered]=\"drivers.get(index) | async\"\n [class.t-column_hovered]=\"hovered === index\"\n [style.left.%]=\"getLeft(getX(index))\"\n [style.width.%]=\"getWidth(index)\"\n [tuiHint]=\"$any(hintDirective?.hint || hintContent)\"\n [tuiHintContext]=\"{$implicit: getImplicit(point), index: index}\"\n [tuiHintDescribe]=\"isFocusable ? getHintId(index) : null\"\n [tuiHintHost]=\"hintHost\"\n (mouseenter)=\"onMouseEnter(index)\"\n >\n <div\n class=\"t-line t-line_vertical\"\n [style.left.%]=\"getOffset(index)\"\n ></div>\n <div\n #hintHost\n class=\"t-host\"\n [id]=\"getHintId(index)\"\n [style.bottom.%]=\"getBottom(point[1])\"\n [style.left.%]=\"getOffset(index)\"\n [tabIndex]=\"isFocusable ? 0 : -1\"\n ></div>\n </div>\n <div\n *ngIf=\"isFocusable\"\n class=\"t-line t-line_horizontal\"\n [style.bottom.%]=\"getBottom(point[1])\"\n ></div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"getHovered(hovered) as point\">\n <div\n *ngIf=\"xStringify\"\n class=\"t-hint t-hint_x\"\n [style.left.%]=\"getLeft(point[0])\"\n >\n {{ xStringify(point[0]) }}\n </div>\n <div\n *ngIf=\"yStringify\"\n class=\"t-hint t-hint_y\"\n [style.bottom.%]=\"getBottom(point[1])\"\n >\n {{ yStringify(point[1]) }}\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host{display:flex;inline-size:100%;block-size:100%;pointer-events:none}.t-svg{block-size:calc(100% + 1px);transform:scaleY(-1);margin:-.03125rem 0}.t-column{position:absolute;top:0;block-size:100%;pointer-events:auto}.t-dot{position:absolute;inline-size:.375rem;block-size:.375rem;border-radius:100%;background:currentColor;margin:-.1875rem;box-shadow:0 0 0 2px #fff}.t-host{position:absolute;left:50%;inline-size:.5rem;block-size:.5rem;border-radius:100%;opacity:0;background:#fff;margin:-.25rem;box-shadow:0 0 0 2px currentColor,0 .0625rem .1875rem .125rem #0000001a;outline:none;pointer-events:none}.t-host:focus,.t-column_hovered .t-host,.t-column:hover .t-host,.t-column_hint_hovered .t-host{opacity:1}.t-line{position:absolute;opacity:0;background:var(--tui-border-normal)}.t-line_vertical{top:0;bottom:0;left:50%;inline-size:1px}.t-line_horizontal{z-index:-1;inline-size:100%;block-size:1px}:host[style^=\"z-index: 0\"] .t-column_hovered .t-line,:host:not([style]) .t-column:hover .t-line,:host:not([style]) .t-column_hint_hovered .t-line,:host[style^=\"z-index: 0\"] .t-column_hovered+.t-line,:host:not([style]) .t-column:hover+.t-line,:host:not([style]) .t-column_hint_hovered+.t-line{opacity:1}.t-hint{position:absolute;box-shadow:var(--tui-shadow-small);font:var(--tui-font-text-xs);block-size:1.25rem;line-height:1.25rem;margin-block-end:-.625rem;padding:0 .375rem;white-space:nowrap;color:var(--tui-text-primary);background:var(--tui-background-base);transform:translate3d(-50%,0,0)}.t-hint_x{bottom:0}.t-hint_y{left:0}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.TuiHintDirective, selector: "[tuiHint]:not(ng-container):not(ng-template)", inputs: ["tuiHintContext", "tuiHintAppearance", "tuiHint"], outputs: ["tuiHintVisible"] }, { kind: "directive", type: i1.TuiHintDescribe, selector: "[tuiHintDescribe]", inputs: ["tuiHintDescribe"] }, { kind: "directive", type: i1.TuiHintHost, selector: "[tuiHint][tuiHintHost]", inputs: ["tuiHintHost"] }, { kind: "directive", type: TuiLet, selector: "[tuiLet]", inputs: ["tuiLet"] }], viewProviders: [tuiHintOptionsProvider({ direction: 'top', hideDelay: 0 })], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
142
- }
143
- __decorate([
144
- tuiPure
145
- ], TuiLineChart.prototype, "hovered$", null);
146
- __decorate([
147
- tuiPure
148
- ], TuiLineChart.prototype, "getD", null);
149
- export { TuiLineChart };
150
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineChart, decorators: [{
151
- type: Component,
152
- args: [{ standalone: true, selector: 'tui-line-chart', imports: [AsyncPipe, NgForOf, NgIf, TuiHint, TuiLet], changeDetection: ChangeDetectionStrategy.OnPush, providers: [ResizeObserverService], viewProviders: [tuiHintOptionsProvider({ direction: 'top', hideDelay: 0 })], host: {
153
- '(mouseleave)': 'onMouseLeave()',
154
- }, template: "<ng-container *tuiLet=\"hovered$ | async as hovered\">\n <svg\n focusable=\"false\"\n height=\"100%\"\n preserveAspectRatio=\"none\"\n width=\"100%\"\n xmlns=\"http://www.w3.org/2000/svg\"\n class=\"t-svg\"\n [attr.viewBox]=\"viewBox()\"\n >\n <defs>\n <linearGradient\n x1=\"0\"\n x2=\"0\"\n y1=\"1\"\n y2=\"0\"\n [attr.id]=\"fillId\"\n >\n <stop\n offset=\"0%\"\n stop-color=\"currentColor\"\n stop-opacity=\"0.5\"\n />\n <stop\n offset=\"100%\"\n stop-color=\"currentColor\"\n stop-opacity=\"0\"\n />\n </linearGradient>\n </defs>\n <path\n stroke=\"none\"\n [attr.d]=\"fillD\"\n [attr.fill]=\"fill\"\n />\n <path\n fill=\"none\"\n stroke=\"currentColor\"\n stroke-width=\"2\"\n vector-effect=\"non-scaling-stroke\"\n [attr.d]=\"d\"\n />\n </svg>\n <ng-container *ngIf=\"dots\">\n <div\n *ngFor=\"let point of value\"\n class=\"t-dot\"\n [style.bottom.%]=\"getBottom(point[1])\"\n [style.left.%]=\"getLeft(point[0])\"\n ></div>\n </ng-container>\n <ng-container *ngIf=\"hasHints\">\n <ng-container *ngFor=\"let point of value; let index = index\">\n <!-- TODO: Fix hint type -->\n <div\n *ngIf=\"value.length > 1 || dots\"\n class=\"t-column\"\n [class.t-column_hint_hovered]=\"drivers.get(index) | async\"\n [class.t-column_hovered]=\"hovered === index\"\n [style.left.%]=\"getLeft(getX(index))\"\n [style.width.%]=\"getWidth(index)\"\n [tuiHint]=\"$any(hintDirective?.hint || hintContent)\"\n [tuiHintContext]=\"{$implicit: getImplicit(point), index: index}\"\n [tuiHintDescribe]=\"isFocusable ? getHintId(index) : null\"\n [tuiHintHost]=\"hintHost\"\n (mouseenter)=\"onMouseEnter(index)\"\n >\n <div\n class=\"t-line t-line_vertical\"\n [style.left.%]=\"getOffset(index)\"\n ></div>\n <div\n #hintHost\n class=\"t-host\"\n [id]=\"getHintId(index)\"\n [style.bottom.%]=\"getBottom(point[1])\"\n [style.left.%]=\"getOffset(index)\"\n [tabIndex]=\"isFocusable ? 0 : -1\"\n ></div>\n </div>\n <div\n *ngIf=\"isFocusable\"\n class=\"t-line t-line_horizontal\"\n [style.bottom.%]=\"getBottom(point[1])\"\n ></div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"getHovered(hovered) as point\">\n <div\n *ngIf=\"xStringify\"\n class=\"t-hint t-hint_x\"\n [style.left.%]=\"getLeft(point[0])\"\n >\n {{ xStringify(point[0]) }}\n </div>\n <div\n *ngIf=\"yStringify\"\n class=\"t-hint t-hint_y\"\n [style.bottom.%]=\"getBottom(point[1])\"\n >\n {{ yStringify(point[1]) }}\n </div>\n </ng-container>\n</ng-container>\n", styles: [":host{display:flex;inline-size:100%;block-size:100%;pointer-events:none}.t-svg{block-size:calc(100% + 1px);transform:scaleY(-1);margin:-.03125rem 0}.t-column{position:absolute;top:0;block-size:100%;pointer-events:auto}.t-dot{position:absolute;inline-size:.375rem;block-size:.375rem;border-radius:100%;background:currentColor;margin:-.1875rem;box-shadow:0 0 0 2px #fff}.t-host{position:absolute;left:50%;inline-size:.5rem;block-size:.5rem;border-radius:100%;opacity:0;background:#fff;margin:-.25rem;box-shadow:0 0 0 2px currentColor,0 .0625rem .1875rem .125rem #0000001a;outline:none;pointer-events:none}.t-host:focus,.t-column_hovered .t-host,.t-column:hover .t-host,.t-column_hint_hovered .t-host{opacity:1}.t-line{position:absolute;opacity:0;background:var(--tui-border-normal)}.t-line_vertical{top:0;bottom:0;left:50%;inline-size:1px}.t-line_horizontal{z-index:-1;inline-size:100%;block-size:1px}:host[style^=\"z-index: 0\"] .t-column_hovered .t-line,:host:not([style]) .t-column:hover .t-line,:host:not([style]) .t-column_hint_hovered .t-line,:host[style^=\"z-index: 0\"] .t-column_hovered+.t-line,:host:not([style]) .t-column:hover+.t-line,:host:not([style]) .t-column_hint_hovered+.t-line{opacity:1}.t-hint{position:absolute;box-shadow:var(--tui-shadow-small);font:var(--tui-font-text-xs);block-size:1.25rem;line-height:1.25rem;margin-block-end:-.625rem;padding:0 .375rem;white-space:nowrap;color:var(--tui-text-primary);background:var(--tui-background-base);transform:translate3d(-50%,0,0)}.t-hint_x{bottom:0}.t-hint_y{left:0}\n"] }]
155
- }], propDecorators: { drivers: [{
156
- type: ViewChildren,
157
- args: [TuiHintHover]
158
- }], x: [{
159
- type: Input
160
- }], y: [{
161
- type: Input
162
- }], width: [{
163
- type: Input
164
- }], height: [{
165
- type: Input
166
- }], smoothingFactor: [{
167
- type: Input
168
- }], xStringify: [{
169
- type: Input
170
- }], yStringify: [{
171
- type: Input
172
- }], filled: [{
173
- type: Input
174
- }], dots: [{
175
- type: Input
176
- }], valueSetter: [{
177
- type: Input,
178
- args: ['value']
179
- }], hovered$: [], getD: [] } });
180
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-chart.component.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/line-chart/line-chart.component.ts","../../../../../projects/addon-charts/components/line-chart/line-chart.template.html"],"names":[],"mappings":";AAAA,OAAO,EAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAC,MAAM,iBAAiB,CAAC;AACzD,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,QAAQ,EACR,MAAM,EACN,KAAK,EACL,MAAM,EAGN,MAAM,EACN,YAAY,GACf,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,QAAQ,EAAC,MAAM,4BAA4B,CAAC;AACpD,OAAO,EAAC,qBAAqB,EAAC,MAAM,8BAA8B,CAAC;AAEnE,OAAO,EAAC,OAAO,EAAC,MAAM,8BAA8B,CAAC;AACrD,OAAO,EAAC,WAAW,EAAC,MAAM,yBAAyB,CAAC;AACpD,OAAO,EAAC,MAAM,EAAC,MAAM,8BAA8B,CAAC;AACpD,OAAO,EAAC,gBAAgB,EAAC,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EAAC,WAAW,EAAC,MAAM,wBAAwB,CAAC;AAEnD,OAAO,EAAC,YAAY,EAAE,OAAO,EAAC,MAAM,mCAAmC,CAAC;AACxE,OAAO,EACH,OAAO,EACP,YAAY,EACZ,uBAAuB,EACvB,sBAAsB,GACzB,MAAM,gCAAgC,CAAC;AAGxC,OAAO,EAAC,oBAAoB,EAAE,GAAG,EAAmB,OAAO,EAAC,MAAM,MAAM,CAAC;AAEzE,OAAO,EAAC,sBAAsB,EAAC,MAAM,sBAAsB,CAAC;AAC5D,OAAO,EAAC,gBAAgB,EAAC,MAAM,6BAA6B,CAAC;;;AAE7D,MAaa,YAAY;IAbzB;QAcqB,SAAI,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC;QACtB,YAAO,GAAG,MAAM,CAAC,sBAAsB,CAAC,CAAC;QACzC,WAAM,GAAG,IAAI,OAAO,EAAU,CAAC;QAC/B,WAAM,GAAG,WAAW,EAAE,CAAC;QACvB,WAAM,GAAG,QAAQ,CAC9B,MAAM,CAAC,qBAAqB,EAAE,EAAC,IAAI,EAAE,IAAI,EAAC,CAAC,CAAC,IAAI,CAC5C,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,WAAW,CAAC,MAAM,IAAI,CAAC,CAAC,CAC3C,EACD,EAAC,YAAY,EAAE,CAAC,EAAC,CACpB,CAAC;QAEe,QAAG,GAAG,MAAM,CAAC,EAAE,CAAC,CAAC;QAEf,kBAAa,GAAG,MAAM,CAAC,gBAAgB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;QAC3D,gBAAW,GAAG,MAAM,CAAC,uBAAuB,EAAE,EAAC,QAAQ,EAAE,IAAI,EAAC,CAAC,CAAC;QAChE,YAAO,GAAG,QAAQ,CAAC,GAAG,EAAE;YACvC,MAAM,MAAM,GAAG,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC,CAAC;YACxD,MAAM,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;YAEhF,OAAO,GAAG,CAAC,IAAI,CAAC,GAAG,MAAM,IAAI,KAAK,IAAI,MAAM,GAAG,CAAC,GAAG,MAAM,EAAE,CAAC;QAChE,CAAC,CAAC,CAAC;QAGa,YAAO,GAAmC,WAAW,CAAC;QAG/D,MAAC,GAAG,CAAC,CAAC;QAGN,MAAC,GAAG,CAAC,CAAC;QAGN,UAAK,GAAG,CAAC,CAAC;QAGV,WAAM,GAAG,CAAC,CAAC;QAGX,oBAAe,GAAG,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC;QAG/C,eAAU,GAAoC,IAAI,CAAC;QAGnD,eAAU,GAAoC,IAAI,CAAC;QAGnD,WAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC;QAG7B,SAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC;QAEzB,UAAK,GAAwB,EAAE,CAAC;KAmI1C;IAjIG,IACW,WAAW,CAAC,KAA0B;QAC7C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;IAClE,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC;IACrE,CAAC;IAEM,SAAS,CAAC,KAAa;QAC1B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC5B,CAAC;IAGD,IAAc,QAAQ;QAClB,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,oBAAoB,EAAE,EAAE,gBAAgB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IACjF,CAAC;IAED,IAAc,WAAW;QACrB,OAAO,IAAI,CAAC,WAAW,EAAE,OAAO,IAAI,EAAE,CAAC;IAC3C,CAAC;IAED,IAAc,MAAM;QAChB,OAAO,kBAAkB,IAAI,CAAC,MAAM,EAAE,CAAC;IAC3C,CAAC;IAED,IAAc,IAAI;QACd,OAAO,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,MAAM,CAAC;IACzD,CAAC;IAED,IAAc,CAAC;QACX,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;IACvD,CAAC;IAED,IAAc,KAAK;QACf,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM;YACpB,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE;YACxE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IACjB,CAAC;IAED,IAAc,WAAW;QACrB,OAAO,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,QAAQ,CAAC;IAChD,CAAC;IAED,IAAc,QAAQ;QAClB,OAAO,CACH,CAAC,CAAC,IAAI,CAAC,UAAU;YACjB,CAAC,CAAC,IAAI,CAAC,UAAU;YACjB,CAAC,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI;YAC1B,CAAC,CAAC,IAAI,CAAC,WAAW,CACrB,CAAC;IACN,CAAC;IAES,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;YACrB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;SACvB;IACL,CAAC;IAES,IAAI,CAAC,KAAa;QACxB,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;SACxC;QAED,OAAO,KAAK;YACR,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC;YACzE,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IACvD,CAAC;IAES,QAAQ,CAAC,KAAa;QAC5B,OAAO,CAAC,GAAG,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;IACzD,CAAC;IAES,SAAS,CAAC,KAAa;QAC7B,OAAO,GAAG,IAAI,CAAC,MAAM,IAAI,KAAK,EAAE,CAAC;IACrC,CAAC;IAES,WAAW,CAAC,SAAmB;QACrC,OAAO,CACH,IAAI,CAAC,aAAa,EAAE,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC;YACnE,SAAS,CACZ,CAAC;IACN,CAAC;IAES,UAAU,CAAC,OAAsB;QACvC,mFAAmF;QACnF,OAAO,YAAY,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,SAAS,CAAC,OAAO,CAAC;YACrD,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC;YAC/B,CAAC,CAAC,IAAI,CAAC;IACf,CAAC;IAES,SAAS,CAAC,CAAS;QACzB,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;IAC9C,CAAC;IAES,OAAO,CAAC,CAAS;QACvB,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC;IAC7C,CAAC;IAES,SAAS,CAAC,CAAS;QACzB,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IACrF,CAAC;IAES,YAAY,CAAC,KAAa;QAChC,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;SACzC;aAAM;YACH,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;SACzB;IACL,CAAC;IAED,IAAY,aAAa;QACrB,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,CAAC;IACnC,CAAC;IAGO,IAAI,CAAC,KAA0B,EAAE,eAAuB;QAC5D,OAAO,KAAK,CAAC,MAAM,CACf,CAAC,CAAC,EAAE,KAAK,EAAE,KAAK,EAAE,EAAE,CAChB,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,eAAe,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,EAAE,EAC3E,EAAE,CACL,CAAC;IACN,CAAC;IAEO,YAAY,CAAC,KAAa;QAC9B,OAAO,KAAK,KAAK,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC;YAClC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACxD,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAClD,CAAC;+GAvLQ,YAAY;mGAAZ,YAAY,mVANV,CAAC,qBAAqB,CAAC,sDA6BpB,YAAY,qECxE9B,ohHAwGA,ojDDjEc,SAAS,8CAAE,OAAO,mHAAE,IAAI,yfAAW,MAAM,8DAKpC,CAAC,sBAAsB,CAAC,EAAC,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EAAC,CAAC,CAAC;;AA0EzE;IADC,OAAO;4CAGP;AAoGO;IADP,OAAO;wCAOP;SAjLQ,YAAY;4FAAZ,YAAY;kBAbxB,SAAS;iCACM,IAAI,YACN,gBAAgB,WACjB,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,CAAC,mBAGnC,uBAAuB,CAAC,MAAM,aACpC,CAAC,qBAAqB,CAAC,iBACnB,CAAC,sBAAsB,CAAC,EAAC,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,CAAC,EAAC,CAAC,CAAC,QACnE;wBACF,cAAc,EAAE,gBAAgB;qBACnC;8BA0Be,OAAO;sBADtB,YAAY;uBAAC,YAAY;gBAInB,CAAC;sBADP,KAAK;gBAIC,CAAC;sBADP,KAAK;gBAIC,KAAK;sBADX,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIC,eAAe;sBADrB,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIC,UAAU;sBADhB,KAAK;gBAIC,MAAM;sBADZ,KAAK;gBAIC,IAAI;sBADV,KAAK;gBAMK,WAAW;sBADrB,KAAK;uBAAC,OAAO;gBAcA,QAAQ,MAsGd,IAAI","sourcesContent":["import {AsyncPipe, NgForOf, NgIf} from '@angular/common';\nimport {\n    ChangeDetectionStrategy,\n    Component,\n    computed,\n    inject,\n    Input,\n    NgZone,\n    type OnChanges,\n    type QueryList,\n    signal,\n    ViewChildren,\n} from '@angular/core';\nimport {toSignal} from '@angular/core/rxjs-interop';\nimport {ResizeObserverService} from '@ng-web-apis/resize-observer';\nimport {type TuiLineChartHintContext} from '@taiga-ui/addon-charts/types';\nimport {tuiDraw} from '@taiga-ui/addon-charts/utils';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {TuiLet} from '@taiga-ui/cdk/directives/let';\nimport {tuiZoneOptimized} from '@taiga-ui/cdk/observables';\nimport {tuiInjectId} from '@taiga-ui/cdk/services';\nimport {type TuiStringHandler} from '@taiga-ui/cdk/types';\nimport {tuiIsPresent, tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {\n    TuiHint,\n    TuiHintHover,\n    TuiHintOptionsDirective,\n    tuiHintOptionsProvider,\n} from '@taiga-ui/core/directives/hint';\nimport {type TuiPoint} from '@taiga-ui/core/types';\nimport {type PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {distinctUntilChanged, map, type Observable, Subject} from 'rxjs';\n\nimport {TUI_LINE_CHART_OPTIONS} from './line-chart.options';\nimport {TuiLineChartHint} from './line-chart-hint.directive';\n\n@Component({\n    standalone: true,\n    selector: 'tui-line-chart',\n    imports: [AsyncPipe, NgForOf, NgIf, TuiHint, TuiLet],\n    templateUrl: './line-chart.template.html',\n    styleUrls: ['./line-chart.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [ResizeObserverService],\n    viewProviders: [tuiHintOptionsProvider({direction: 'top', hideDelay: 0})],\n    host: {\n        '(mouseleave)': 'onMouseLeave()',\n    },\n})\nexport class TuiLineChart implements OnChanges {\n    private readonly zone = inject(NgZone);\n    private readonly options = inject(TUI_LINE_CHART_OPTIONS);\n    private readonly hover$ = new Subject<number>();\n    private readonly autoId = tuiInjectId();\n    private readonly resize = toSignal(\n        inject(ResizeObserverService, {self: true}).pipe(\n            map(([e]) => e?.contentRect.height || 0),\n        ),\n        {initialValue: 0},\n    );\n\n    private readonly box = signal('');\n\n    protected readonly hintDirective = inject(TuiLineChartHint, {optional: true});\n    protected readonly hintOptions = inject(TuiHintOptionsDirective, {optional: true});\n    protected readonly viewBox = computed(() => {\n        const offset = this.height / Math.max(this.resize(), 1);\n        const [x = 0, y = 0, width = 0, height = 0] = this.box().split(' ').map(Number);\n\n        return `${x} ${y - offset} ${width} ${height + 2 * offset}`;\n    });\n\n    @ViewChildren(TuiHintHover)\n    public readonly drivers: QueryList<Observable<boolean>> = EMPTY_QUERY;\n\n    @Input()\n    public x = 0;\n\n    @Input()\n    public y = 0;\n\n    @Input()\n    public width = 0;\n\n    @Input()\n    public height = 0;\n\n    @Input()\n    public smoothingFactor = this.options.smoothingFactor;\n\n    @Input()\n    public xStringify: TuiStringHandler<number> | null = null;\n\n    @Input()\n    public yStringify: TuiStringHandler<number> | null = null;\n\n    @Input()\n    public filled = this.options.filled;\n\n    @Input()\n    public dots = this.options.dots;\n\n    public value: readonly TuiPoint[] = [];\n\n    @Input('value')\n    public set valueSetter(value: readonly TuiPoint[]) {\n        this.value = value.filter((item) => !item.some(Number.isNaN));\n    }\n\n    public ngOnChanges(): void {\n        this.box.set(`${this.x} ${this.y} ${this.width} ${this.height}`);\n    }\n\n    public onHovered(index: number): void {\n        this.hover$.next(index);\n    }\n\n    @tuiPure\n    protected get hovered$(): Observable<number> {\n        return this.hover$.pipe(distinctUntilChanged(), tuiZoneOptimized(this.zone));\n    }\n\n    protected get hintContent(): PolymorpheusContent<TuiLineChartHintContext<TuiPoint>> {\n        return this.hintOptions?.content || '';\n    }\n\n    protected get fillId(): string {\n        return `tui-line-chart-${this.autoId}`;\n    }\n\n    protected get fill(): string {\n        return this.filled ? `url(#${this.fillId})` : 'none';\n    }\n\n    protected get d(): string {\n        return this.getD(this.value, this.smoothingFactor);\n    }\n\n    protected get fillD(): string {\n        return this.value.length\n            ? `${this.d}V ${this.y} H ${this.value[0]?.[0]} V ${this.value[0]?.[1]}`\n            : this.d;\n    }\n\n    protected get isFocusable(): boolean {\n        return !this.hintDirective && this.hasHints;\n    }\n\n    protected get hasHints(): boolean {\n        return (\n            !!this.xStringify ||\n            !!this.yStringify ||\n            !!this.hintDirective?.hint ||\n            !!this.hintContent\n        );\n    }\n\n    protected onMouseLeave(): void {\n        if (!this.hintDirective) {\n            this.onHovered(NaN);\n        }\n    }\n\n    protected getX(index: number): number {\n        if (this.isSinglePoint) {\n            return (this.value[0]?.[0] || 0) / 2;\n        }\n\n        return index\n            ? ((this.value[index - 1]?.[0] || 0) + (this.value[index]?.[0] || 0)) / 2\n            : 2 * (this.value[0]?.[0] || 0) - this.getX(1);\n    }\n\n    protected getWidth(index: number): number {\n        return (100 * this.computeWidth(index)) / this.width;\n    }\n\n    protected getHintId(index: number): string {\n        return `${this.autoId}_${index}`;\n    }\n\n    protected getImplicit($implicit: TuiPoint): TuiPoint | readonly TuiPoint[] {\n        return (\n            this.hintDirective?.getContext(this.value.indexOf($implicit), this) ??\n            $implicit\n        );\n    }\n\n    protected getHovered(hovered: number | null): TuiPoint | null {\n        // This checks for NaN and null too since async pipe returns null before first item\n        return tuiIsPresent(hovered) && Number.isInteger(hovered)\n            ? (this.value[hovered] ?? null)\n            : null;\n    }\n\n    protected getBottom(y: number): number {\n        return (100 * (y - this.y)) / this.height;\n    }\n\n    protected getLeft(x: number): number {\n        return (100 * (x - this.x)) / this.width;\n    }\n\n    protected getOffset(x: number): number {\n        return (100 * ((this.value[x]?.[0] || 0) - this.getX(x))) / this.computeWidth(x);\n    }\n\n    protected onMouseEnter(index: number): void {\n        if (this.hintDirective) {\n            this.hintDirective.raise(index, this);\n        } else {\n            this.onHovered(index);\n        }\n    }\n\n    private get isSinglePoint(): boolean {\n        return this.value.length === 1;\n    }\n\n    @tuiPure\n    private getD(value: readonly TuiPoint[], smoothingFactor: number): string {\n        return value.reduce(\n            (d, point, index) =>\n                index ? `${d} ${tuiDraw(value, index, smoothingFactor)}` : `M ${point}`,\n            '',\n        );\n    }\n\n    private computeWidth(index: number): number {\n        return index === this.value.length - 1\n            ? 2 * ((this.value[index]?.[0] || 0) - this.getX(index))\n            : this.getX(index + 1) - this.getX(index);\n    }\n}\n","<ng-container *tuiLet=\"hovered$ | async as hovered\">\n    <svg\n        focusable=\"false\"\n        height=\"100%\"\n        preserveAspectRatio=\"none\"\n        width=\"100%\"\n        xmlns=\"http://www.w3.org/2000/svg\"\n        class=\"t-svg\"\n        [attr.viewBox]=\"viewBox()\"\n    >\n        <defs>\n            <linearGradient\n                x1=\"0\"\n                x2=\"0\"\n                y1=\"1\"\n                y2=\"0\"\n                [attr.id]=\"fillId\"\n            >\n                <stop\n                    offset=\"0%\"\n                    stop-color=\"currentColor\"\n                    stop-opacity=\"0.5\"\n                />\n                <stop\n                    offset=\"100%\"\n                    stop-color=\"currentColor\"\n                    stop-opacity=\"0\"\n                />\n            </linearGradient>\n        </defs>\n        <path\n            stroke=\"none\"\n            [attr.d]=\"fillD\"\n            [attr.fill]=\"fill\"\n        />\n        <path\n            fill=\"none\"\n            stroke=\"currentColor\"\n            stroke-width=\"2\"\n            vector-effect=\"non-scaling-stroke\"\n            [attr.d]=\"d\"\n        />\n    </svg>\n    <ng-container *ngIf=\"dots\">\n        <div\n            *ngFor=\"let point of value\"\n            class=\"t-dot\"\n            [style.bottom.%]=\"getBottom(point[1])\"\n            [style.left.%]=\"getLeft(point[0])\"\n        ></div>\n    </ng-container>\n    <ng-container *ngIf=\"hasHints\">\n        <ng-container *ngFor=\"let point of value; let index = index\">\n            <!-- TODO: Fix hint type -->\n            <div\n                *ngIf=\"value.length > 1 || dots\"\n                class=\"t-column\"\n                [class.t-column_hint_hovered]=\"drivers.get(index) | async\"\n                [class.t-column_hovered]=\"hovered === index\"\n                [style.left.%]=\"getLeft(getX(index))\"\n                [style.width.%]=\"getWidth(index)\"\n                [tuiHint]=\"$any(hintDirective?.hint || hintContent)\"\n                [tuiHintContext]=\"{$implicit: getImplicit(point), index: index}\"\n                [tuiHintDescribe]=\"isFocusable ? getHintId(index) : null\"\n                [tuiHintHost]=\"hintHost\"\n                (mouseenter)=\"onMouseEnter(index)\"\n            >\n                <div\n                    class=\"t-line t-line_vertical\"\n                    [style.left.%]=\"getOffset(index)\"\n                ></div>\n                <div\n                    #hintHost\n                    class=\"t-host\"\n                    [id]=\"getHintId(index)\"\n                    [style.bottom.%]=\"getBottom(point[1])\"\n                    [style.left.%]=\"getOffset(index)\"\n                    [tabIndex]=\"isFocusable ? 0 : -1\"\n                ></div>\n            </div>\n            <div\n                *ngIf=\"isFocusable\"\n                class=\"t-line t-line_horizontal\"\n                [style.bottom.%]=\"getBottom(point[1])\"\n            ></div>\n        </ng-container>\n    </ng-container>\n    <ng-container *ngIf=\"getHovered(hovered) as point\">\n        <div\n            *ngIf=\"xStringify\"\n            class=\"t-hint t-hint_x\"\n            [style.left.%]=\"getLeft(point[0])\"\n        >\n            {{ xStringify(point[0]) }}\n        </div>\n        <div\n            *ngIf=\"yStringify\"\n            class=\"t-hint t-hint_y\"\n            [style.bottom.%]=\"getBottom(point[1])\"\n        >\n            {{ yStringify(point[1]) }}\n        </div>\n    </ng-container>\n</ng-container>\n"]}
@@ -1,14 +0,0 @@
1
- import { InjectionToken } from '@angular/core';
2
- import { tuiProvideOptions } from '@taiga-ui/cdk/utils/miscellaneous';
3
- export const TUI_LINE_CHART_DEFAULT_OPTIONS = {
4
- dots: false,
5
- filled: false,
6
- smoothingFactor: 0,
7
- };
8
- export const TUI_LINE_CHART_OPTIONS = new InjectionToken(ngDevMode ? 'TUI_LINE_CHART_OPTIONS' : '', {
9
- factory: () => TUI_LINE_CHART_DEFAULT_OPTIONS,
10
- });
11
- export function tuiLineChartOptionsProvider(options) {
12
- return tuiProvideOptions(TUI_LINE_CHART_OPTIONS, options, TUI_LINE_CHART_DEFAULT_OPTIONS);
13
- }
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS1jaGFydC5vcHRpb25zLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvbGluZS1jaGFydC9saW5lLWNoYXJ0Lm9wdGlvbnMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLGNBQWMsRUFBZ0IsTUFBTSxlQUFlLENBQUM7QUFDNUQsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sbUNBQW1DLENBQUM7QUFRcEUsTUFBTSxDQUFDLE1BQU0sOEJBQThCLEdBQXdCO0lBQy9ELElBQUksRUFBRSxLQUFLO0lBQ1gsTUFBTSxFQUFFLEtBQUs7SUFDYixlQUFlLEVBQUUsQ0FBQztDQUNyQixDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQUcsSUFBSSxjQUFjLENBQ3BELFNBQVMsQ0FBQyxDQUFDLENBQUMsd0JBQXdCLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFDekM7SUFDSSxPQUFPLEVBQUUsR0FBRyxFQUFFLENBQUMsOEJBQThCO0NBQ2hELENBQ0osQ0FBQztBQUVGLE1BQU0sVUFBVSwyQkFBMkIsQ0FDdkMsT0FBcUM7SUFFckMsT0FBTyxpQkFBaUIsQ0FDcEIsc0JBQXNCLEVBQ3RCLE9BQU8sRUFDUCw4QkFBOEIsQ0FDakMsQ0FBQztBQUNOLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0luamVjdGlvblRva2VuLCB0eXBlIFByb3ZpZGVyfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7dHVpUHJvdmlkZU9wdGlvbnN9IGZyb20gJ0B0YWlnYS11aS9jZGsvdXRpbHMvbWlzY2VsbGFuZW91cyc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVHVpTGluZUNoYXJ0T3B0aW9ucyB7XG4gICAgcmVhZG9ubHkgZG90czogYm9vbGVhbjtcbiAgICByZWFkb25seSBmaWxsZWQ6IGJvb2xlYW47XG4gICAgcmVhZG9ubHkgc21vb3RoaW5nRmFjdG9yOiBudW1iZXI7XG59XG5cbmV4cG9ydCBjb25zdCBUVUlfTElORV9DSEFSVF9ERUZBVUxUX09QVElPTlM6IFR1aUxpbmVDaGFydE9wdGlvbnMgPSB7XG4gICAgZG90czogZmFsc2UsXG4gICAgZmlsbGVkOiBmYWxzZSxcbiAgICBzbW9vdGhpbmdGYWN0b3I6IDAsXG59O1xuXG5leHBvcnQgY29uc3QgVFVJX0xJTkVfQ0hBUlRfT1BUSU9OUyA9IG5ldyBJbmplY3Rpb25Ub2tlbihcbiAgICBuZ0Rldk1vZGUgPyAnVFVJX0xJTkVfQ0hBUlRfT1BUSU9OUycgOiAnJyxcbiAgICB7XG4gICAgICAgIGZhY3Rvcnk6ICgpID0+IFRVSV9MSU5FX0NIQVJUX0RFRkFVTFRfT1BUSU9OUyxcbiAgICB9LFxuKTtcblxuZXhwb3J0IGZ1bmN0aW9uIHR1aUxpbmVDaGFydE9wdGlvbnNQcm92aWRlcihcbiAgICBvcHRpb25zOiBQYXJ0aWFsPFR1aUxpbmVDaGFydE9wdGlvbnM+LFxuKTogUHJvdmlkZXIge1xuICAgIHJldHVybiB0dWlQcm92aWRlT3B0aW9ucyhcbiAgICAgICAgVFVJX0xJTkVfQ0hBUlRfT1BUSU9OUyxcbiAgICAgICAgb3B0aW9ucyxcbiAgICAgICAgVFVJX0xJTkVfQ0hBUlRfREVGQVVMVF9PUFRJT05TLFxuICAgICk7XG59XG4iXX0=
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './index';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMtbGluZS1jaGFydC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWNoYXJ0cy9jb21wb25lbnRzL2xpbmUtY2hhcnQvdGFpZ2EtdWktYWRkb24tY2hhcnRzLWNvbXBvbmVudHMtbGluZS1jaGFydC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsU0FBUyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBHZW5lcmF0ZWQgYnVuZGxlIGluZGV4LiBEbyBub3QgZWRpdC5cbiAqL1xuXG5leHBvcnQgKiBmcm9tICcuL2luZGV4JztcbiJdfQ==
@@ -1,3 +0,0 @@
1
- export * from './line-days-chart.component';
2
- export * from './line-days-chart-hint.directive';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9saW5lLWRheXMtY2hhcnQvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLGtDQUFrQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9saW5lLWRheXMtY2hhcnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGluZS1kYXlzLWNoYXJ0LWhpbnQuZGlyZWN0aXZlJztcbiJdfQ==
@@ -1,71 +0,0 @@
1
- import { __decorate } from "tslib";
2
- import { ContentChildren, DestroyRef, Directive, forwardRef, inject, Input, NgZone, } from '@angular/core';
3
- import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
- import { tuiLineChartDrivers } from '@taiga-ui/addon-charts/components/line-chart';
5
- import { EMPTY_QUERY } from '@taiga-ui/cdk/constants';
6
- import { TuiHoveredService } from '@taiga-ui/cdk/directives/hovered';
7
- import { tuiZonefree } from '@taiga-ui/cdk/observables';
8
- import { tuiPure } from '@taiga-ui/cdk/utils/miscellaneous';
9
- import { combineLatest, filter } from 'rxjs';
10
- import { TuiLineDaysChart } from './line-days-chart.component';
11
- import * as i0 from "@angular/core";
12
- function find(value, current) {
13
- return value.find(([day]) => day.daySame(current)) || [current, NaN];
14
- }
15
- // TODO: Consider extending TuiLineChartHintDirective
16
- class TuiLineDaysChartHint {
17
- constructor() {
18
- this.charts = EMPTY_QUERY;
19
- this.destroyRef = inject(DestroyRef);
20
- this.zone = inject(NgZone);
21
- this.hovered$ = inject(TuiHoveredService);
22
- }
23
- ngAfterContentInit() {
24
- combineLatest([
25
- ...this.charts.map(({ charts }) => tuiLineChartDrivers(charts)),
26
- this.hovered$,
27
- ])
28
- .pipe(filter((result) => !result.some(Boolean)), tuiZonefree(this.zone), takeUntilDestroyed(this.destroyRef))
29
- .subscribe(() => {
30
- this.charts.forEach((chart) => chart.onHovered(NaN));
31
- });
32
- }
33
- getContext(day) {
34
- return this.getMap(...this.charts.map(({ value }) => value)).get(String(day)) || [];
35
- }
36
- raise(day) {
37
- const current = this.charts
38
- .map(({ value }) => (day ? find(value, day) : []))
39
- .filter(([_, value]) => !Number.isNaN(value));
40
- const sorted = [...current].sort((a, b) => a[1] - b[1]);
41
- this.charts.forEach((chart, index) => {
42
- const item = current[index];
43
- chart.onHovered(day);
44
- chart.zIndex = Math.max(item ? sorted.indexOf(item) : 0, 0);
45
- });
46
- }
47
- getMap(...values) {
48
- return (values[0] || []).reduce((map, [day]) => map.set(String(day), values.map((value) => find(value, day))), new Map());
49
- }
50
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineDaysChartHint, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
51
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: TuiLineDaysChartHint, isStandalone: true, selector: "[tuiLineChartHint]", inputs: { hint: ["tuiLineChartHint", "hint"] }, providers: [TuiHoveredService], queries: [{ propertyName: "charts", predicate: i0.forwardRef(function () { return TuiLineDaysChart; }) }], ngImport: i0 }); }
52
- }
53
- __decorate([
54
- tuiPure
55
- ], TuiLineDaysChartHint.prototype, "getMap", null);
56
- export { TuiLineDaysChartHint };
57
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: TuiLineDaysChartHint, decorators: [{
58
- type: Directive,
59
- args: [{
60
- standalone: true,
61
- selector: '[tuiLineChartHint]',
62
- providers: [TuiHoveredService],
63
- }]
64
- }], propDecorators: { charts: [{
65
- type: ContentChildren,
66
- args: [forwardRef(() => TuiLineDaysChart)]
67
- }], hint: [{
68
- type: Input,
69
- args: ['tuiLineChartHint']
70
- }], getMap: [] } });
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line-days-chart-hint.directive.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/line-days-chart/line-days-chart-hint.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    type AfterContentInit,\n    ContentChildren,\n    DestroyRef,\n    Directive,\n    forwardRef,\n    inject,\n    Input,\n    NgZone,\n    type QueryList,\n} from '@angular/core';\nimport {takeUntilDestroyed} from '@angular/core/rxjs-interop';\nimport {tuiLineChartDrivers} from '@taiga-ui/addon-charts/components/line-chart';\nimport {EMPTY_QUERY} from '@taiga-ui/cdk/constants';\nimport {type TuiDay} from '@taiga-ui/cdk/date-time';\nimport {TuiHoveredService} from '@taiga-ui/cdk/directives/hovered';\nimport {tuiZonefree} from '@taiga-ui/cdk/observables';\nimport {type TuiContext} from '@taiga-ui/cdk/types';\nimport {tuiPure} from '@taiga-ui/cdk/utils/miscellaneous';\nimport {type TuiPoint} from '@taiga-ui/core/types';\nimport {type PolymorpheusContent} from '@taiga-ui/polymorpheus';\nimport {combineLatest, filter} from 'rxjs';\n\nimport {TuiLineDaysChart} from './line-days-chart.component';\n\nfunction find(value: ReadonlyArray<[TuiDay, number]>, current: TuiDay): [TuiDay, number] {\n    return value.find(([day]) => day.daySame(current)) || [current, NaN];\n}\n\n// TODO: Consider extending TuiLineChartHintDirective\n@Directive({\n    standalone: true,\n    selector: '[tuiLineChartHint]',\n    providers: [TuiHoveredService],\n})\nexport class TuiLineDaysChartHint implements AfterContentInit {\n    @ContentChildren(forwardRef(() => TuiLineDaysChart))\n    private readonly charts: QueryList<TuiLineDaysChart> = EMPTY_QUERY;\n\n    private readonly destroyRef = inject(DestroyRef);\n    private readonly zone = inject(NgZone);\n    private readonly hovered$ = inject(TuiHoveredService);\n\n    @Input('tuiLineChartHint')\n    public hint: PolymorpheusContent<TuiContext<readonly TuiPoint[]>>;\n\n    public ngAfterContentInit(): void {\n        combineLatest([\n            ...this.charts.map(({charts}) => tuiLineChartDrivers(charts)),\n            this.hovered$,\n        ])\n            .pipe(\n                filter((result) => !result.some(Boolean)),\n                tuiZonefree(this.zone),\n                takeUntilDestroyed(this.destroyRef),\n            )\n            .subscribe(() => {\n                this.charts.forEach((chart) => chart.onHovered(NaN));\n            });\n    }\n\n    public getContext(day: TuiDay): ReadonlyArray<[TuiDay, number]> {\n        return this.getMap(...this.charts.map(({value}) => value)).get(String(day)) || [];\n    }\n\n    public raise(day: TuiDay): void {\n        const current = this.charts\n            .map(({value}) => (day ? find(value, day) : []))\n            .filter(([_, value]) => !Number.isNaN(value));\n        const sorted = [...current].sort((a, b) => a[1] - b[1]);\n\n        this.charts.forEach((chart, index) => {\n            const item = current[index];\n\n            chart.onHovered(day);\n            chart.zIndex = Math.max(item ? sorted.indexOf(item) : 0, 0);\n        });\n    }\n\n    @tuiPure\n    private getMap(\n        ...values: Array<ReadonlyArray<[TuiDay, number]>>\n    ): Map<string, ReadonlyArray<[TuiDay, number]>> {\n        return (values[0] || []).reduce(\n            (map, [day]) =>\n                map.set(\n                    String(day),\n                    values.map((value) => find(value, day)),\n                ),\n            new Map<string, ReadonlyArray<[TuiDay, number]>>(),\n        );\n    }\n}\n"]}