@taiga-ui/addon-charts 3.14.0 → 3.15.0-dev.main-978eec3

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 (54) hide show
  1. package/bundles/taiga-ui-addon-charts-components-arc-chart.umd.js +12 -12
  2. package/bundles/taiga-ui-addon-charts-components-arc-chart.umd.js.map +1 -1
  3. package/bundles/taiga-ui-addon-charts-components-axes.umd.js +10 -10
  4. package/bundles/taiga-ui-addon-charts-components-axes.umd.js.map +1 -1
  5. package/bundles/taiga-ui-addon-charts-components-bar-chart.umd.js +8 -8
  6. package/bundles/taiga-ui-addon-charts-components-bar-chart.umd.js.map +1 -1
  7. package/bundles/taiga-ui-addon-charts-components-bar-set.umd.js +5 -5
  8. package/bundles/taiga-ui-addon-charts-components-bar-set.umd.js.map +1 -1
  9. package/bundles/taiga-ui-addon-charts-components-bar.umd.js +5 -5
  10. package/bundles/taiga-ui-addon-charts-components-bar.umd.js.map +1 -1
  11. package/bundles/taiga-ui-addon-charts-components-legend-item.umd.js +10 -10
  12. package/bundles/taiga-ui-addon-charts-components-legend-item.umd.js.map +1 -1
  13. package/bundles/taiga-ui-addon-charts-components-line-chart.umd.js +15 -15
  14. package/bundles/taiga-ui-addon-charts-components-line-chart.umd.js.map +1 -1
  15. package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.js +10 -10
  16. package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.js.map +1 -1
  17. package/bundles/taiga-ui-addon-charts-components-pie-chart.umd.js +16 -16
  18. package/bundles/taiga-ui-addon-charts-components-pie-chart.umd.js.map +1 -1
  19. package/bundles/taiga-ui-addon-charts-components-ring-chart.umd.js +5 -5
  20. package/bundles/taiga-ui-addon-charts-components-ring-chart.umd.js.map +1 -1
  21. package/esm2015/components/arc-chart/arc-chart.component.js +13 -13
  22. package/esm2015/components/axes/axes.component.js +11 -11
  23. package/esm2015/components/bar/bar.component.js +6 -6
  24. package/esm2015/components/bar-chart/bar-chart.component.js +9 -9
  25. package/esm2015/components/bar-set/bar-set.component.js +6 -6
  26. package/esm2015/components/legend-item/legend-item.component.js +11 -11
  27. package/esm2015/components/line-chart/line-chart-hint.directive.js +5 -5
  28. package/esm2015/components/line-chart/line-chart.component.js +12 -12
  29. package/esm2015/components/line-days-chart/line-days-chart-hint.directive.js +4 -4
  30. package/esm2015/components/line-days-chart/line-days-chart.component.js +8 -8
  31. package/esm2015/components/pie-chart/pie-chart.component.js +15 -15
  32. package/esm2015/components/pie-chart/pie-chart.directive.js +3 -3
  33. package/esm2015/components/ring-chart/ring-chart.component.js +6 -6
  34. package/fesm2015/taiga-ui-addon-charts-components-arc-chart.js +12 -12
  35. package/fesm2015/taiga-ui-addon-charts-components-arc-chart.js.map +1 -1
  36. package/fesm2015/taiga-ui-addon-charts-components-axes.js +10 -10
  37. package/fesm2015/taiga-ui-addon-charts-components-axes.js.map +1 -1
  38. package/fesm2015/taiga-ui-addon-charts-components-bar-chart.js +8 -8
  39. package/fesm2015/taiga-ui-addon-charts-components-bar-chart.js.map +1 -1
  40. package/fesm2015/taiga-ui-addon-charts-components-bar-set.js +5 -5
  41. package/fesm2015/taiga-ui-addon-charts-components-bar-set.js.map +1 -1
  42. package/fesm2015/taiga-ui-addon-charts-components-bar.js +5 -5
  43. package/fesm2015/taiga-ui-addon-charts-components-bar.js.map +1 -1
  44. package/fesm2015/taiga-ui-addon-charts-components-legend-item.js +10 -10
  45. package/fesm2015/taiga-ui-addon-charts-components-legend-item.js.map +1 -1
  46. package/fesm2015/taiga-ui-addon-charts-components-line-chart.js +15 -15
  47. package/fesm2015/taiga-ui-addon-charts-components-line-chart.js.map +1 -1
  48. package/fesm2015/taiga-ui-addon-charts-components-line-days-chart.js +10 -10
  49. package/fesm2015/taiga-ui-addon-charts-components-line-days-chart.js.map +1 -1
  50. package/fesm2015/taiga-ui-addon-charts-components-pie-chart.js +16 -16
  51. package/fesm2015/taiga-ui-addon-charts-components-pie-chart.js.map +1 -1
  52. package/fesm2015/taiga-ui-addon-charts-components-ring-chart.js +5 -5
  53. package/fesm2015/taiga-ui-addon-charts-components-ring-chart.js.map +1 -1
  54. package/package.json +4 -4
@@ -10,22 +10,22 @@ import * as i3 from "rxjs";
10
10
  export class TuiAxesComponent {
11
11
  constructor(mode$) {
12
12
  this.mode$ = mode$;
13
- this.axisX = `solid`;
13
+ this.axisX = 'solid';
14
14
  this.axisXLabels = [];
15
- this.axisY = `solid`;
15
+ this.axisY = 'solid';
16
16
  this.axisYInset = false;
17
17
  this.axisYLabels = [];
18
- this.axisYName = ``;
18
+ this.axisYName = '';
19
19
  this.axisYSecondaryInset = false;
20
20
  this.axisYSecondaryLabels = [];
21
- this.axisYSecondaryName = ``;
21
+ this.axisYSecondaryName = '';
22
22
  this.horizontalLines = 0;
23
23
  this.horizontalLinesHandler = TUI_ALWAYS_SOLID;
24
24
  this.verticalLines = 0;
25
25
  this.verticalLinesHandler = TUI_ALWAYS_DASHED;
26
26
  }
27
27
  get centeredXLabels() {
28
- return this.axisY === `none`;
28
+ return this.axisY === 'none';
29
29
  }
30
30
  get hasXLabels() {
31
31
  return !!this.axisXLabels.length;
@@ -85,13 +85,13 @@ __decorate([
85
85
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiAxesComponent, decorators: [{
86
86
  type: Component,
87
87
  args: [{
88
- selector: `tui-axes`,
89
- templateUrl: `./axes.template.html`,
90
- styleUrls: [`./axes.style.less`],
88
+ selector: 'tui-axes',
89
+ templateUrl: './axes.template.html',
90
+ styleUrls: ['./axes.style.less'],
91
91
  changeDetection: ChangeDetectionStrategy.OnPush,
92
92
  providers: [MODE_PROVIDER],
93
93
  host: {
94
- '($.data-mode.attr)': `mode$`,
94
+ '($.data-mode.attr)': 'mode$',
95
95
  },
96
96
  }]
97
97
  }], ctorParameters: function () { return [{ type: i3.Observable, decorators: [{
@@ -125,6 +125,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
125
125
  type: Input
126
126
  }], centeredXLabels: [{
127
127
  type: HostBinding,
128
- args: [`class._centered`]
128
+ args: ['class._centered']
129
129
  }] } });
130
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"axes.component.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/axes/axes.component.ts","../../../../../projects/addon-charts/components/axes/axes.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    Inject,\n    Input,\n} from '@angular/core';\nimport {TUI_ALWAYS_DASHED, TUI_ALWAYS_SOLID} from '@taiga-ui/addon-charts/constants';\nimport {TuiLineHandler, TuiLineType} from '@taiga-ui/addon-charts/types';\nimport {CHAR_NO_BREAK_SPACE, tuiDefaultProp} from '@taiga-ui/cdk';\nimport {MODE_PROVIDER, TUI_MODE, TuiBrightness} from '@taiga-ui/core';\nimport {Observable} from 'rxjs';\n\n@Component({\n    selector: `tui-axes`,\n    templateUrl: `./axes.template.html`,\n    styleUrls: [`./axes.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [MODE_PROVIDER],\n    host: {\n        '($.data-mode.attr)': `mode$`,\n    },\n})\nexport class TuiAxesComponent {\n    @Input()\n    @tuiDefaultProp()\n    axisX: TuiLineType = `solid`;\n\n    @Input()\n    @tuiDefaultProp()\n    axisXLabels: ReadonlyArray<string | null> = [];\n\n    @Input()\n    @tuiDefaultProp()\n    axisY: TuiLineType = `solid`;\n\n    @Input()\n    @tuiDefaultProp()\n    axisYInset = false;\n\n    @Input()\n    @tuiDefaultProp()\n    axisYLabels: readonly string[] = [];\n\n    @Input()\n    @tuiDefaultProp()\n    axisYName = ``;\n\n    @Input()\n    @tuiDefaultProp()\n    axisYSecondaryInset = false;\n\n    @Input()\n    @tuiDefaultProp()\n    axisYSecondaryLabels: readonly string[] = [];\n\n    @Input()\n    @tuiDefaultProp()\n    axisYSecondaryName = ``;\n\n    @Input()\n    @tuiDefaultProp()\n    horizontalLines = 0;\n\n    @Input()\n    @tuiDefaultProp()\n    horizontalLinesHandler: TuiLineHandler = TUI_ALWAYS_SOLID;\n\n    @Input()\n    @tuiDefaultProp()\n    verticalLines = 0;\n\n    @Input()\n    @tuiDefaultProp()\n    verticalLinesHandler: TuiLineHandler = TUI_ALWAYS_DASHED;\n\n    @HostBinding(`class._centered`)\n    get centeredXLabels(): boolean {\n        return this.axisY === `none`;\n    }\n\n    constructor(@Inject(TUI_MODE) readonly mode$: Observable<TuiBrightness | null>) {}\n\n    get hasXLabels(): boolean {\n        return !!this.axisXLabels.length;\n    }\n\n    get hasYLabels(): boolean {\n        return (!!this.axisYLabels.length && !this.axisYInset) || !!this.axisYName;\n    }\n\n    get hasYSecondaryLabels(): boolean {\n        return (\n            (!!this.axisYSecondaryLabels.length && !this.axisYSecondaryInset) ||\n            !!this.axisYSecondaryName\n        );\n    }\n\n    fallback(label: string | null): string {\n        return label || CHAR_NO_BREAK_SPACE;\n    }\n}\n","<div\n    *ngIf=\"hasYLabels\"\n    class=\"t-side\"\n    [class.t-side_padding]=\"hasXLabels\"\n>\n    <div\n        *ngIf=\"axisYName\"\n        automation-id=\"tui-axex__axis-y-name\"\n        class=\"t-name t-name_primary\"\n    >\n        {{ axisYName }}\n    </div>\n    <div\n        *ngIf=\"!axisYInset\"\n        class=\"t-labels-y t-labels-y_primary\"\n    >\n        <div\n            *ngFor=\"let label of axisYLabels\"\n            automation-id=\"tui-axex__axis-y-label\"\n            class=\"t-label-y\"\n        >\n            {{ fallback(label) }}\n        </div>\n    </div>\n</div>\n<div class=\"t-wrapper\">\n    <div\n        class=\"t-grid\"\n        [style.borderLeftStyle]=\"axisY\"\n        [style.borderBottomStyle]=\"axisX\"\n    >\n        <div class=\"t-vertical\">\n            <div\n                *tuiRepeatTimes=\"let index of verticalLines\"\n                automation-id=\"tui-axex__vertical-line\"\n                class=\"t-line t-line_vertical\"\n                [style.borderRightStyle]=\"verticalLinesHandler(index, verticalLines)\"\n            ></div>\n        </div>\n        <div class=\"t-horizontal\">\n            <div\n                *tuiRepeatTimes=\"let index of horizontalLines\"\n                automation-id=\"tui-axex__horizontal-line\"\n                class=\"t-line\"\n                [style.borderTopStyle]=\"horizontalLinesHandler(index, horizontalLines)\"\n            ></div>\n        </div>\n        <div\n            *ngIf=\"axisYInset\"\n            class=\"t-labels-y t-labels-y_inset\"\n        >\n            <div\n                *ngFor=\"let label of axisYLabels\"\n                automation-id=\"tui-axex__axis-y-label\"\n                class=\"t-label-y\"\n            >\n                {{ fallback(label) }}\n            </div>\n        </div>\n        <div\n            *ngIf=\"axisYSecondaryInset\"\n            class=\"t-labels-y t-labels-y_inset t-labels-y_inset_secondary\"\n        >\n            <div\n                *ngFor=\"let label of axisYSecondaryLabels\"\n                automation-id=\"tui-axex__axis-y-secondary-label\"\n                class=\"t-label-y\"\n            >\n                {{ fallback(label) }}\n            </div>\n        </div>\n        <div class=\"t-content\">\n            <ng-content></ng-content>\n        </div>\n    </div>\n    <div\n        *ngIf=\"hasXLabels\"\n        class=\"t-labels-x\"\n    >\n        <div\n            *ngFor=\"let label of axisXLabels\"\n            automation-id=\"tui-axex__axis-x-label\"\n            class=\"t-label-x\"\n            [class.t-label-x_transparent]=\"label === null\"\n        >\n            {{ fallback(label) }}\n        </div>\n    </div>\n</div>\n<div\n    *ngIf=\"hasYSecondaryLabels\"\n    class=\"t-side\"\n    [class.t-side_padding]=\"hasXLabels\"\n>\n    <div\n        *ngIf=\"!axisYSecondaryInset\"\n        class=\"t-labels-y t-labels-y_secondary\"\n    >\n        <div\n            *ngFor=\"let label of axisYSecondaryLabels\"\n            automation-id=\"tui-axex__axis-y-secondary-label\"\n            class=\"t-label-y\"\n        >\n            {{ fallback(label) }}\n        </div>\n    </div>\n    <div\n        *ngIf=\"axisYSecondaryName\"\n        automation-id=\"tui-axex__axis-y-secondary-name\"\n        class=\"t-name\"\n    >\n        {{ axisYSecondaryName }}\n    </div>\n</div>\n"]}
130
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"axes.component.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/axes/axes.component.ts","../../../../../projects/addon-charts/components/axes/axes.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    HostBinding,\n    Inject,\n    Input,\n} from '@angular/core';\nimport {TUI_ALWAYS_DASHED, TUI_ALWAYS_SOLID} from '@taiga-ui/addon-charts/constants';\nimport {TuiLineHandler, TuiLineType} from '@taiga-ui/addon-charts/types';\nimport {CHAR_NO_BREAK_SPACE, tuiDefaultProp} from '@taiga-ui/cdk';\nimport {MODE_PROVIDER, TUI_MODE, TuiBrightness} from '@taiga-ui/core';\nimport {Observable} from 'rxjs';\n\n@Component({\n    selector: 'tui-axes',\n    templateUrl: './axes.template.html',\n    styleUrls: ['./axes.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [MODE_PROVIDER],\n    host: {\n        '($.data-mode.attr)': 'mode$',\n    },\n})\nexport class TuiAxesComponent {\n    @Input()\n    @tuiDefaultProp()\n    axisX: TuiLineType = 'solid';\n\n    @Input()\n    @tuiDefaultProp()\n    axisXLabels: ReadonlyArray<string | null> = [];\n\n    @Input()\n    @tuiDefaultProp()\n    axisY: TuiLineType = 'solid';\n\n    @Input()\n    @tuiDefaultProp()\n    axisYInset = false;\n\n    @Input()\n    @tuiDefaultProp()\n    axisYLabels: readonly string[] = [];\n\n    @Input()\n    @tuiDefaultProp()\n    axisYName = '';\n\n    @Input()\n    @tuiDefaultProp()\n    axisYSecondaryInset = false;\n\n    @Input()\n    @tuiDefaultProp()\n    axisYSecondaryLabels: readonly string[] = [];\n\n    @Input()\n    @tuiDefaultProp()\n    axisYSecondaryName = '';\n\n    @Input()\n    @tuiDefaultProp()\n    horizontalLines = 0;\n\n    @Input()\n    @tuiDefaultProp()\n    horizontalLinesHandler: TuiLineHandler = TUI_ALWAYS_SOLID;\n\n    @Input()\n    @tuiDefaultProp()\n    verticalLines = 0;\n\n    @Input()\n    @tuiDefaultProp()\n    verticalLinesHandler: TuiLineHandler = TUI_ALWAYS_DASHED;\n\n    @HostBinding('class._centered')\n    get centeredXLabels(): boolean {\n        return this.axisY === 'none';\n    }\n\n    constructor(@Inject(TUI_MODE) readonly mode$: Observable<TuiBrightness | null>) {}\n\n    get hasXLabels(): boolean {\n        return !!this.axisXLabels.length;\n    }\n\n    get hasYLabels(): boolean {\n        return (!!this.axisYLabels.length && !this.axisYInset) || !!this.axisYName;\n    }\n\n    get hasYSecondaryLabels(): boolean {\n        return (\n            (!!this.axisYSecondaryLabels.length && !this.axisYSecondaryInset) ||\n            !!this.axisYSecondaryName\n        );\n    }\n\n    fallback(label: string | null): string {\n        return label || CHAR_NO_BREAK_SPACE;\n    }\n}\n","<div\n    *ngIf=\"hasYLabels\"\n    class=\"t-side\"\n    [class.t-side_padding]=\"hasXLabels\"\n>\n    <div\n        *ngIf=\"axisYName\"\n        automation-id=\"tui-axex__axis-y-name\"\n        class=\"t-name t-name_primary\"\n    >\n        {{ axisYName }}\n    </div>\n    <div\n        *ngIf=\"!axisYInset\"\n        class=\"t-labels-y t-labels-y_primary\"\n    >\n        <div\n            *ngFor=\"let label of axisYLabels\"\n            automation-id=\"tui-axex__axis-y-label\"\n            class=\"t-label-y\"\n        >\n            {{ fallback(label) }}\n        </div>\n    </div>\n</div>\n<div class=\"t-wrapper\">\n    <div\n        class=\"t-grid\"\n        [style.borderLeftStyle]=\"axisY\"\n        [style.borderBottomStyle]=\"axisX\"\n    >\n        <div class=\"t-vertical\">\n            <div\n                *tuiRepeatTimes=\"let index of verticalLines\"\n                automation-id=\"tui-axex__vertical-line\"\n                class=\"t-line t-line_vertical\"\n                [style.borderRightStyle]=\"verticalLinesHandler(index, verticalLines)\"\n            ></div>\n        </div>\n        <div class=\"t-horizontal\">\n            <div\n                *tuiRepeatTimes=\"let index of horizontalLines\"\n                automation-id=\"tui-axex__horizontal-line\"\n                class=\"t-line\"\n                [style.borderTopStyle]=\"horizontalLinesHandler(index, horizontalLines)\"\n            ></div>\n        </div>\n        <div\n            *ngIf=\"axisYInset\"\n            class=\"t-labels-y t-labels-y_inset\"\n        >\n            <div\n                *ngFor=\"let label of axisYLabels\"\n                automation-id=\"tui-axex__axis-y-label\"\n                class=\"t-label-y\"\n            >\n                {{ fallback(label) }}\n            </div>\n        </div>\n        <div\n            *ngIf=\"axisYSecondaryInset\"\n            class=\"t-labels-y t-labels-y_inset t-labels-y_inset_secondary\"\n        >\n            <div\n                *ngFor=\"let label of axisYSecondaryLabels\"\n                automation-id=\"tui-axex__axis-y-secondary-label\"\n                class=\"t-label-y\"\n            >\n                {{ fallback(label) }}\n            </div>\n        </div>\n        <div class=\"t-content\">\n            <ng-content></ng-content>\n        </div>\n    </div>\n    <div\n        *ngIf=\"hasXLabels\"\n        class=\"t-labels-x\"\n    >\n        <div\n            *ngFor=\"let label of axisXLabels\"\n            automation-id=\"tui-axex__axis-x-label\"\n            class=\"t-label-x\"\n            [class.t-label-x_transparent]=\"label === null\"\n        >\n            {{ fallback(label) }}\n        </div>\n    </div>\n</div>\n<div\n    *ngIf=\"hasYSecondaryLabels\"\n    class=\"t-side\"\n    [class.t-side_padding]=\"hasXLabels\"\n>\n    <div\n        *ngIf=\"!axisYSecondaryInset\"\n        class=\"t-labels-y t-labels-y_secondary\"\n    >\n        <div\n            *ngFor=\"let label of axisYSecondaryLabels\"\n            automation-id=\"tui-axex__axis-y-secondary-label\"\n            class=\"t-label-y\"\n        >\n            {{ fallback(label) }}\n        </div>\n    </div>\n    <div\n        *ngIf=\"axisYSecondaryName\"\n        automation-id=\"tui-axex__axis-y-secondary-name\"\n        class=\"t-name\"\n    >\n        {{ axisYSecondaryName }}\n    </div>\n</div>\n"]}
@@ -6,7 +6,7 @@ import * as i1 from "@angular/common";
6
6
  export class TuiBarComponent {
7
7
  constructor() {
8
8
  this.value = [];
9
- this.size = `m`;
9
+ this.size = 'm';
10
10
  }
11
11
  getHeight(value) {
12
12
  return (100 * value) / this.getSum(this.value);
@@ -32,9 +32,9 @@ __decorate([
32
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiBarComponent, decorators: [{
33
33
  type: Component,
34
34
  args: [{
35
- selector: `tui-bar`,
36
- templateUrl: `./bar.template.html`,
37
- styleUrls: [`./bar.style.less`],
35
+ selector: 'tui-bar',
36
+ templateUrl: './bar.template.html',
37
+ styleUrls: ['./bar.style.less'],
38
38
  changeDetection: ChangeDetectionStrategy.OnPush,
39
39
  }]
40
40
  }], propDecorators: { value: [{
@@ -43,6 +43,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
43
43
  type: Input
44
44
  }, {
45
45
  type: HostBinding,
46
- args: [`attr.data-size`]
46
+ args: ['attr.data-size']
47
47
  }], getSum: [] } });
48
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWNoYXJ0cy9jb21wb25lbnRzL2Jhci9iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvYmFyL2Jhci50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFDLGNBQWMsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7QUFTOUQsTUFBTSxPQUFPLGVBQWU7SUFONUI7UUFTSSxVQUFLLEdBQXNCLEVBQUUsQ0FBQztRQUs5QixTQUFJLEdBQXdCLEdBQUcsQ0FBQztLQWNuQztJQVpHLFNBQVMsQ0FBQyxLQUFhO1FBQ25CLE9BQU8sQ0FBQyxHQUFHLEdBQUcsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVELFFBQVEsQ0FBQyxLQUFhO1FBQ2xCLE9BQU8sbUJBQW1CLEtBQUssR0FBRyxDQUFDO0lBQ3ZDLENBQUM7SUFHTyxNQUFNLENBQUMsS0FBd0I7UUFDbkMsT0FBTyxNQUFNLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQztJQUM1QixDQUFDOzs2R0FyQlEsZUFBZTtpR0FBZixlQUFlLGtKQ1g1QixnTUFNQTtBRFFJO0lBREMsY0FBYyxFQUFFOzhDQUNhO0FBSzlCO0lBREMsY0FBYyxFQUFFOzZDQUNlO0FBV2hDO0lBREMsT0FBTzs2Q0FHUDs0RkFyQlEsZUFBZTtrQkFOM0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsU0FBUztvQkFDbkIsV0FBVyxFQUFFLHFCQUFxQjtvQkFDbEMsU0FBUyxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQy9CLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDs4QkFJRyxLQUFLO3NCQUZKLEtBQUs7Z0JBT04sSUFBSTtzQkFISCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLGdCQUFnQjtnQkFhckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7U2FmZVZhbHVlfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcbmltcG9ydCB7dHVpRGVmYXVsdFByb3AsIHR1aVB1cmUsIHR1aVN1bX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aVNpemVMLCBUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogYHR1aS1iYXJgLFxuICAgIHRlbXBsYXRlVXJsOiBgLi9iYXIudGVtcGxhdGUuaHRtbGAsXG4gICAgc3R5bGVVcmxzOiBbYC4vYmFyLnN0eWxlLmxlc3NgXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpQmFyQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgdmFsdWU6IHJlYWRvbmx5IG51bWJlcltdID0gW107XG5cbiAgICBASW5wdXQoKVxuICAgIEBIb3N0QmluZGluZyhgYXR0ci5kYXRhLXNpemVgKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgc2l6ZTogVHVpU2l6ZUwgfCBUdWlTaXplUyA9IGBtYDtcblxuICAgIGdldEhlaWdodCh2YWx1ZTogbnVtYmVyKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuICgxMDAgKiB2YWx1ZSkgLyB0aGlzLmdldFN1bSh0aGlzLnZhbHVlKTtcbiAgICB9XG5cbiAgICBnZXRDb2xvcihpbmRleDogbnVtYmVyKTogU2FmZVZhbHVlIHtcbiAgICAgICAgcmV0dXJuIGB2YXIoLS10dWktY2hhcnQtJHtpbmRleH0pYDtcbiAgICB9XG5cbiAgICBAdHVpUHVyZVxuICAgIHByaXZhdGUgZ2V0U3VtKHZhbHVlOiByZWFkb25seSBudW1iZXJbXSk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiB0dWlTdW0oLi4udmFsdWUpO1xuICAgIH1cbn1cbiIsIjxkaXZcbiAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiB2YWx1ZTsgbGV0IGluZGV4ID0gaW5kZXhcIlxuICAgIGF1dG9tYXRpb24taWQ9XCJ0dWktYmFyX19iYXJcIlxuICAgIFtzdHlsZS5oZWlnaHQuJV09XCJnZXRIZWlnaHQoaXRlbSlcIlxuICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cImdldENvbG9yKGluZGV4KVwiXG4+PC9kaXY+XG4iXX0=
48
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2FkZG9uLWNoYXJ0cy9jb21wb25lbnRzL2Jhci9iYXIuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvYmFyL2Jhci50ZW1wbGF0ZS5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUMsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLFdBQVcsRUFBRSxLQUFLLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFFckYsT0FBTyxFQUFDLGNBQWMsRUFBRSxPQUFPLEVBQUUsTUFBTSxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7QUFTOUQsTUFBTSxPQUFPLGVBQWU7SUFONUI7UUFTSSxVQUFLLEdBQXNCLEVBQUUsQ0FBQztRQUs5QixTQUFJLEdBQXdCLEdBQUcsQ0FBQztLQWNuQztJQVpHLFNBQVMsQ0FBQyxLQUFhO1FBQ25CLE9BQU8sQ0FBQyxHQUFHLEdBQUcsS0FBSyxDQUFDLEdBQUcsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDbkQsQ0FBQztJQUVELFFBQVEsQ0FBQyxLQUFhO1FBQ2xCLE9BQU8sbUJBQW1CLEtBQUssR0FBRyxDQUFDO0lBQ3ZDLENBQUM7SUFHTyxNQUFNLENBQUMsS0FBd0I7UUFDbkMsT0FBTyxNQUFNLENBQUMsR0FBRyxLQUFLLENBQUMsQ0FBQztJQUM1QixDQUFDOzs2R0FyQlEsZUFBZTtpR0FBZixlQUFlLGtKQ1g1QixnTUFNQTtBRFFJO0lBREMsY0FBYyxFQUFFOzhDQUNhO0FBSzlCO0lBREMsY0FBYyxFQUFFOzZDQUNlO0FBV2hDO0lBREMsT0FBTzs2Q0FHUDs0RkFyQlEsZUFBZTtrQkFOM0IsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsU0FBUztvQkFDbkIsV0FBVyxFQUFFLHFCQUFxQjtvQkFDbEMsU0FBUyxFQUFFLENBQUMsa0JBQWtCLENBQUM7b0JBQy9CLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDs4QkFJRyxLQUFLO3NCQUZKLEtBQUs7Z0JBT04sSUFBSTtzQkFISCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLGdCQUFnQjtnQkFhckIsTUFBTSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSG9zdEJpbmRpbmcsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7U2FmZVZhbHVlfSBmcm9tICdAYW5ndWxhci9wbGF0Zm9ybS1icm93c2VyJztcbmltcG9ydCB7dHVpRGVmYXVsdFByb3AsIHR1aVB1cmUsIHR1aVN1bX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aVNpemVMLCBUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3R1aS1iYXInLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9iYXIudGVtcGxhdGUuaHRtbCcsXG4gICAgc3R5bGVVcmxzOiBbJy4vYmFyLnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpQmFyQ29tcG9uZW50IHtcbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgdmFsdWU6IHJlYWRvbmx5IG51bWJlcltdID0gW107XG5cbiAgICBASW5wdXQoKVxuICAgIEBIb3N0QmluZGluZygnYXR0ci5kYXRhLXNpemUnKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgc2l6ZTogVHVpU2l6ZUwgfCBUdWlTaXplUyA9ICdtJztcblxuICAgIGdldEhlaWdodCh2YWx1ZTogbnVtYmVyKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuICgxMDAgKiB2YWx1ZSkgLyB0aGlzLmdldFN1bSh0aGlzLnZhbHVlKTtcbiAgICB9XG5cbiAgICBnZXRDb2xvcihpbmRleDogbnVtYmVyKTogU2FmZVZhbHVlIHtcbiAgICAgICAgcmV0dXJuIGB2YXIoLS10dWktY2hhcnQtJHtpbmRleH0pYDtcbiAgICB9XG5cbiAgICBAdHVpUHVyZVxuICAgIHByaXZhdGUgZ2V0U3VtKHZhbHVlOiByZWFkb25seSBudW1iZXJbXSk6IG51bWJlciB7XG4gICAgICAgIHJldHVybiB0dWlTdW0oLi4udmFsdWUpO1xuICAgIH1cbn1cbiIsIjxkaXZcbiAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiB2YWx1ZTsgbGV0IGluZGV4ID0gaW5kZXhcIlxuICAgIGF1dG9tYXRpb24taWQ9XCJ0dWktYmFyX19iYXJcIlxuICAgIFtzdHlsZS5oZWlnaHQuJV09XCJnZXRIZWlnaHQoaXRlbSlcIlxuICAgIFtzdHlsZS5iYWNrZ3JvdW5kXT1cImdldENvbG9yKGluZGV4KVwiXG4+PC9kaXY+XG4iXX0=
@@ -11,21 +11,21 @@ function valueAssertion(value) {
11
11
  const valid = value.every(array => array.length === value[0].length);
12
12
  return valid;
13
13
  }
14
- const VALUE_ERROR = `All arrays must be of the same length`;
14
+ const VALUE_ERROR = 'All arrays must be of the same length';
15
15
  export class TuiBarChartComponent {
16
16
  constructor(hintOptions, idService) {
17
17
  this.hintOptions = hintOptions;
18
18
  this.drivers = EMPTY_QUERY;
19
19
  this.value = [];
20
20
  this.max = NaN;
21
- this.size = `m`;
21
+ this.size = 'm';
22
22
  this.collapsed = false;
23
23
  this.percentMapper = (set, collapsed, max) => (100 * (collapsed ? tuiSum(...set) : Math.max(...set))) / max;
24
24
  this.autoIdString = idService.generate();
25
25
  }
26
26
  get hintContent() {
27
27
  var _a;
28
- return ((_a = this.hintOptions) === null || _a === void 0 ? void 0 : _a.content) || ``;
28
+ return ((_a = this.hintOptions) === null || _a === void 0 ? void 0 : _a.content) || '';
29
29
  }
30
30
  get transposed() {
31
31
  return this.transpose(this.value);
@@ -46,7 +46,7 @@ export class TuiBarChartComponent {
46
46
  }
47
47
  }
48
48
  TuiBarChartComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiBarChartComponent, deps: [{ token: TuiHintOptionsDirective, optional: true }, { token: TuiIdService }], target: i0.ɵɵFactoryTarget.Component });
49
- TuiBarChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiBarChartComponent, selector: "tui-bar-chart", inputs: { value: "value", max: "max", size: "size", collapsed: "collapsed" }, viewQueries: [{ propertyName: "drivers", predicate: TuiDriver, descendants: true }], ngImport: i0, template: "<div\n *ngFor=\"let set of transposed; let index = index\"\n class=\"t-wrapper\"\n [class.t-wrapper_hoverable]=\"!!hintContent\"\n [class.t-wrapper_hovered]=\"drivers.get(index) | async\"\n [tuiHintHost]=\"hintHost\"\n [tuiHint]=\"hintContent\"\n [tuiHintContext]=\"{$implicit: index}\"\n [tuiHintDescribe]=\"getHintId(index)\"\n (mouseenter.once)=\"(0)\"\n>\n <div\n class=\"t-container\"\n [style.height.%]=\"set | tuiMapper : percentMapper : collapsed : computedMax\"\n >\n <div\n #hintHost\n class=\"t-host\"\n ></div>\n <tui-bar-set\n class=\"t-set\"\n [id]=\"getHintId(index)\"\n [tuiFocusable]=\"!!hintContent\"\n [value]=\"set\"\n [size]=\"size\"\n [collapsed]=\"collapsed\"\n ></tui-bar-set>\n </div>\n</div>\n", styles: [":host{display:flex;flex:1;height:100%}.t-wrapper{transition-property:background-color;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:relative;display:flex;flex:1;align-items:flex-end;justify-content:center;height:100%}.t-wrapper_hoverable{cursor:pointer}.t-wrapper_hoverable:hover,.t-wrapper_hoverable.t-wrapper_hovered{background-color:rgba(0,0,0,.05)}.t-container{flex:1}.t-host{position:absolute;left:50%;right:50%}.t-set{border-radius:var(--tui-radius-m);pointer-events:none;outline:none}.t-set:focus{box-shadow:0 0 0 2px var(--tui-focus)}\n"], components: [{ type: i1.TuiBarSetComponent, selector: "tui-bar-set", inputs: ["value", "size", "collapsed"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.TuiHintDirective, selector: "[tuiHint]:not(ng-container)", inputs: ["tuiHint", "tuiHintContext", "tuiHintAppearance"] }, { type: i3.TuiHintDriverDirective, selector: "[tuiHint]" }, { type: i3.TuiHintHoverDirective, selector: "[tuiHint]:not(ng-container)", inputs: ["tuiHintShowDelay", "tuiHintHideDelay"] }, { type: i3.TuiHintPositionDirective, selector: "[tuiHint]:not([tuiHintCustomPosition])", inputs: ["tuiHintDirection"] }, { type: i3.TuiHintHostDirective, selector: "[tuiHint][tuiHintHost]", inputs: ["tuiHintHost"] }, { type: i3.TuiHintDescribeDirective, selector: "[tuiHintDescribe]", inputs: ["tuiHintDescribe"] }, { type: i4.TuiFocusableDirective, selector: "[tuiFocusable]", inputs: ["tuiFocusable"] }], pipes: { "async": i2.AsyncPipe, "tuiMapper": i4.TuiMapperPipe }, viewProviders: [tuiHintOptionsProvider({ direction: `top` })], changeDetection: i0.ChangeDetectionStrategy.OnPush });
49
+ TuiBarChartComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.16", type: TuiBarChartComponent, selector: "tui-bar-chart", inputs: { value: "value", max: "max", size: "size", collapsed: "collapsed" }, viewQueries: [{ propertyName: "drivers", predicate: TuiDriver, descendants: true }], ngImport: i0, template: "<div\n *ngFor=\"let set of transposed; let index = index\"\n class=\"t-wrapper\"\n [class.t-wrapper_hoverable]=\"!!hintContent\"\n [class.t-wrapper_hovered]=\"drivers.get(index) | async\"\n [tuiHintHost]=\"hintHost\"\n [tuiHint]=\"hintContent\"\n [tuiHintContext]=\"{$implicit: index}\"\n [tuiHintDescribe]=\"getHintId(index)\"\n (mouseenter.once)=\"(0)\"\n>\n <div\n class=\"t-container\"\n [style.height.%]=\"set | tuiMapper : percentMapper : collapsed : computedMax\"\n >\n <div\n #hintHost\n class=\"t-host\"\n ></div>\n <tui-bar-set\n class=\"t-set\"\n [id]=\"getHintId(index)\"\n [tuiFocusable]=\"!!hintContent\"\n [value]=\"set\"\n [size]=\"size\"\n [collapsed]=\"collapsed\"\n ></tui-bar-set>\n </div>\n</div>\n", styles: [":host{display:flex;flex:1;height:100%}.t-wrapper{transition-property:background-color;transition-duration:var(--tui-duration, .3s);transition-timing-function:ease-in-out;position:relative;display:flex;flex:1;align-items:flex-end;justify-content:center;height:100%}.t-wrapper_hoverable{cursor:pointer}.t-wrapper_hoverable:hover,.t-wrapper_hoverable.t-wrapper_hovered{background-color:rgba(0,0,0,.05)}.t-container{flex:1}.t-host{position:absolute;left:50%;right:50%}.t-set{border-radius:var(--tui-radius-m);pointer-events:none;outline:none}.t-set:focus{box-shadow:0 0 0 2px var(--tui-focus)}\n"], components: [{ type: i1.TuiBarSetComponent, selector: "tui-bar-set", inputs: ["value", "size", "collapsed"] }], directives: [{ type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.TuiHintDirective, selector: "[tuiHint]:not(ng-container)", inputs: ["tuiHint", "tuiHintContext", "tuiHintAppearance"] }, { type: i3.TuiHintDriverDirective, selector: "[tuiHint]" }, { type: i3.TuiHintHoverDirective, selector: "[tuiHint]:not(ng-container)", inputs: ["tuiHintShowDelay", "tuiHintHideDelay"] }, { type: i3.TuiHintPositionDirective, selector: "[tuiHint]:not([tuiHintCustomPosition])", inputs: ["tuiHintDirection"] }, { type: i3.TuiHintHostDirective, selector: "[tuiHint][tuiHintHost]", inputs: ["tuiHintHost"] }, { type: i3.TuiHintDescribeDirective, selector: "[tuiHintDescribe]", inputs: ["tuiHintDescribe"] }, { type: i4.TuiFocusableDirective, selector: "[tuiFocusable]", inputs: ["tuiFocusable"] }], pipes: { "async": i2.AsyncPipe, "tuiMapper": i4.TuiMapperPipe }, viewProviders: [tuiHintOptionsProvider({ direction: 'top' })], changeDetection: i0.ChangeDetectionStrategy.OnPush });
50
50
  __decorate([
51
51
  tuiDefaultProp(valueAssertion, VALUE_ERROR)
52
52
  ], TuiBarChartComponent.prototype, "value", void 0);
@@ -68,11 +68,11 @@ __decorate([
68
68
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiBarChartComponent, decorators: [{
69
69
  type: Component,
70
70
  args: [{
71
- selector: `tui-bar-chart`,
72
- templateUrl: `./bar-chart.template.html`,
73
- styleUrls: [`./bar-chart.style.less`],
71
+ selector: 'tui-bar-chart',
72
+ templateUrl: './bar-chart.template.html',
73
+ styleUrls: ['./bar-chart.style.less'],
74
74
  changeDetection: ChangeDetectionStrategy.OnPush,
75
- viewProviders: [tuiHintOptionsProvider({ direction: `top` })],
75
+ viewProviders: [tuiHintOptionsProvider({ direction: 'top' })],
76
76
  }]
77
77
  }], ctorParameters: function () { return [{ type: i3.TuiHintOptionsDirective, decorators: [{
78
78
  type: Optional
@@ -94,4 +94,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
94
94
  }], collapsed: [{
95
95
  type: Input
96
96
  }], transpose: [], getMax: [] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar-chart.component.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/bar-chart/bar-chart.component.ts","../../../../../projects/addon-charts/components/bar-chart/bar-chart.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    ViewChildren,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiIdService,\n    TuiMapper,\n    tuiPure,\n    tuiSum,\n} from '@taiga-ui/cdk';\nimport {\n    TuiDriver,\n    TuiHintOptionsDirective,\n    tuiHintOptionsProvider,\n    TuiSizeL,\n    TuiSizeS,\n} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\n\nfunction valueAssertion(value: ReadonlyArray<readonly number[]>): boolean {\n    const valid = value.every(array => array.length === value[0].length);\n\n    return valid;\n}\n\nconst VALUE_ERROR = `All arrays must be of the same length`;\n\n@Component({\n    selector: `tui-bar-chart`,\n    templateUrl: `./bar-chart.template.html`,\n    styleUrls: [`./bar-chart.style.less`],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    viewProviders: [tuiHintOptionsProvider({direction: `top`})],\n})\nexport class TuiBarChartComponent {\n    private readonly autoIdString: string;\n\n    @ViewChildren(TuiDriver)\n    readonly drivers: QueryList<Observable<boolean>> = EMPTY_QUERY;\n\n    @Input()\n    @tuiDefaultProp(valueAssertion, VALUE_ERROR)\n    value: ReadonlyArray<readonly number[]> = [];\n\n    @Input()\n    @tuiDefaultProp()\n    max = NaN;\n\n    @Input()\n    @tuiDefaultProp()\n    size: TuiSizeL | TuiSizeS | null = `m`;\n\n    @Input()\n    @tuiDefaultProp()\n    collapsed = false;\n\n    constructor(\n        @Optional()\n        @Inject(TuiHintOptionsDirective)\n        private readonly hintOptions: TuiHintOptionsDirective | null,\n        @Inject(TuiIdService) idService: TuiIdService,\n    ) {\n        this.autoIdString = idService.generate();\n    }\n\n    get hintContent(): PolymorpheusContent<TuiContextWithImplicit<number>> {\n        return this.hintOptions?.content || ``;\n    }\n\n    get transposed(): ReadonlyArray<readonly number[]> {\n        return this.transpose(this.value);\n    }\n\n    get computedMax(): number {\n        return this.max || this.getMax(this.value, this.collapsed);\n    }\n\n    readonly percentMapper: TuiMapper<readonly number[], number> = (\n        set,\n        collapsed: boolean,\n        max: number,\n    ) => (100 * (collapsed ? tuiSum(...set) : Math.max(...set))) / max;\n\n    getHintId(index: number): string {\n        return `${this.autoIdString}_${index}`;\n    }\n\n    @tuiPure\n    private transpose(\n        value: ReadonlyArray<readonly number[]>,\n    ): ReadonlyArray<readonly number[]> {\n        return value.reduce<ReadonlyArray<readonly number[]>>(\n            (result, next) =>\n                next.map((_, index) => [...(result[index] || []), next[index]]),\n            [],\n        );\n    }\n\n    @tuiPure\n    private getMax(values: ReadonlyArray<readonly number[]>, collapsed: boolean): number {\n        return collapsed\n            ? Math.max(\n                  ...values.reduce((result, next) =>\n                      result.map((value, index) => value + next[index]),\n                  ),\n              )\n            : values.reduce((max, value) => Math.max(...value, max), 0);\n    }\n}\n","<div\n    *ngFor=\"let set of transposed; let index = index\"\n    class=\"t-wrapper\"\n    [class.t-wrapper_hoverable]=\"!!hintContent\"\n    [class.t-wrapper_hovered]=\"drivers.get(index) | async\"\n    [tuiHintHost]=\"hintHost\"\n    [tuiHint]=\"hintContent\"\n    [tuiHintContext]=\"{$implicit: index}\"\n    [tuiHintDescribe]=\"getHintId(index)\"\n    (mouseenter.once)=\"(0)\"\n>\n    <div\n        class=\"t-container\"\n        [style.height.%]=\"set | tuiMapper : percentMapper : collapsed : computedMax\"\n    >\n        <div\n            #hintHost\n            class=\"t-host\"\n        ></div>\n        <tui-bar-set\n            class=\"t-set\"\n            [id]=\"getHintId(index)\"\n            [tuiFocusable]=\"!!hintContent\"\n            [value]=\"set\"\n            [size]=\"size\"\n            [collapsed]=\"collapsed\"\n        ></tui-bar-set>\n    </div>\n</div>\n"]}
97
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar-chart.component.js","sourceRoot":"","sources":["../../../../../projects/addon-charts/components/bar-chart/bar-chart.component.ts","../../../../../projects/addon-charts/components/bar-chart/bar-chart.template.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    Inject,\n    Input,\n    Optional,\n    QueryList,\n    ViewChildren,\n} from '@angular/core';\nimport {\n    EMPTY_QUERY,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiIdService,\n    TuiMapper,\n    tuiPure,\n    tuiSum,\n} from '@taiga-ui/cdk';\nimport {\n    TuiDriver,\n    TuiHintOptionsDirective,\n    tuiHintOptionsProvider,\n    TuiSizeL,\n    TuiSizeS,\n} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {Observable} from 'rxjs';\n\nfunction valueAssertion(value: ReadonlyArray<readonly number[]>): boolean {\n    const valid = value.every(array => array.length === value[0].length);\n\n    return valid;\n}\n\nconst VALUE_ERROR = 'All arrays must be of the same length';\n\n@Component({\n    selector: 'tui-bar-chart',\n    templateUrl: './bar-chart.template.html',\n    styleUrls: ['./bar-chart.style.less'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    viewProviders: [tuiHintOptionsProvider({direction: 'top'})],\n})\nexport class TuiBarChartComponent {\n    private readonly autoIdString: string;\n\n    @ViewChildren(TuiDriver)\n    readonly drivers: QueryList<Observable<boolean>> = EMPTY_QUERY;\n\n    @Input()\n    @tuiDefaultProp(valueAssertion, VALUE_ERROR)\n    value: ReadonlyArray<readonly number[]> = [];\n\n    @Input()\n    @tuiDefaultProp()\n    max = NaN;\n\n    @Input()\n    @tuiDefaultProp()\n    size: TuiSizeL | TuiSizeS | null = 'm';\n\n    @Input()\n    @tuiDefaultProp()\n    collapsed = false;\n\n    constructor(\n        @Optional()\n        @Inject(TuiHintOptionsDirective)\n        private readonly hintOptions: TuiHintOptionsDirective | null,\n        @Inject(TuiIdService) idService: TuiIdService,\n    ) {\n        this.autoIdString = idService.generate();\n    }\n\n    get hintContent(): PolymorpheusContent<TuiContextWithImplicit<number>> {\n        return this.hintOptions?.content || '';\n    }\n\n    get transposed(): ReadonlyArray<readonly number[]> {\n        return this.transpose(this.value);\n    }\n\n    get computedMax(): number {\n        return this.max || this.getMax(this.value, this.collapsed);\n    }\n\n    readonly percentMapper: TuiMapper<readonly number[], number> = (\n        set,\n        collapsed: boolean,\n        max: number,\n    ) => (100 * (collapsed ? tuiSum(...set) : Math.max(...set))) / max;\n\n    getHintId(index: number): string {\n        return `${this.autoIdString}_${index}`;\n    }\n\n    @tuiPure\n    private transpose(\n        value: ReadonlyArray<readonly number[]>,\n    ): ReadonlyArray<readonly number[]> {\n        return value.reduce<ReadonlyArray<readonly number[]>>(\n            (result, next) =>\n                next.map((_, index) => [...(result[index] || []), next[index]]),\n            [],\n        );\n    }\n\n    @tuiPure\n    private getMax(values: ReadonlyArray<readonly number[]>, collapsed: boolean): number {\n        return collapsed\n            ? Math.max(\n                  ...values.reduce((result, next) =>\n                      result.map((value, index) => value + next[index]),\n                  ),\n              )\n            : values.reduce((max, value) => Math.max(...value, max), 0);\n    }\n}\n","<div\n    *ngFor=\"let set of transposed; let index = index\"\n    class=\"t-wrapper\"\n    [class.t-wrapper_hoverable]=\"!!hintContent\"\n    [class.t-wrapper_hovered]=\"drivers.get(index) | async\"\n    [tuiHintHost]=\"hintHost\"\n    [tuiHint]=\"hintContent\"\n    [tuiHintContext]=\"{$implicit: index}\"\n    [tuiHintDescribe]=\"getHintId(index)\"\n    (mouseenter.once)=\"(0)\"\n>\n    <div\n        class=\"t-container\"\n        [style.height.%]=\"set | tuiMapper : percentMapper : collapsed : computedMax\"\n    >\n        <div\n            #hintHost\n            class=\"t-host\"\n        ></div>\n        <tui-bar-set\n            class=\"t-set\"\n            [id]=\"getHintId(index)\"\n            [tuiFocusable]=\"!!hintContent\"\n            [value]=\"set\"\n            [size]=\"size\"\n            [collapsed]=\"collapsed\"\n        ></tui-bar-set>\n    </div>\n</div>\n"]}
@@ -10,7 +10,7 @@ const FILLER_ARRAY = [1];
10
10
  export class TuiBarSetComponent {
11
11
  constructor() {
12
12
  this.value = [];
13
- this.size = `m`;
13
+ this.size = 'm';
14
14
  this.collapsed = false;
15
15
  }
16
16
  get computedValue() {
@@ -20,7 +20,7 @@ export class TuiBarSetComponent {
20
20
  return this.collapsed ? this.value : EMPTY_ARRAY;
21
21
  }
22
22
  get computedSize() {
23
- return this.size || `m`;
23
+ return this.size || 'm';
24
24
  }
25
25
  getHeight(value) {
26
26
  return Math.abs((PERCENT * value) / this.getLargest(this.computedValue));
@@ -49,9 +49,9 @@ __decorate([
49
49
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiBarSetComponent, decorators: [{
50
50
  type: Component,
51
51
  args: [{
52
- selector: `tui-bar-set`,
53
- templateUrl: `./bar-set.template.html`,
54
- styleUrls: [`./bar-set.style.less`],
52
+ selector: 'tui-bar-set',
53
+ templateUrl: './bar-set.template.html',
54
+ styleUrls: ['./bar-set.style.less'],
55
55
  changeDetection: ChangeDetectionStrategy.OnPush,
56
56
  }]
57
57
  }], propDecorators: { value: [{
@@ -61,4 +61,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
61
61
  }], collapsed: [{
62
62
  type: Input
63
63
  }], getLargest: [] } });
64
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLXNldC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9iYXItc2V0L2Jhci1zZXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvYmFyLXNldC9iYXItc2V0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXhFLE9BQU8sRUFBQyxjQUFjLEVBQUUsT0FBTyxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7O0FBR3RELE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQztBQUNwQixNQUFNLFdBQVcsR0FBc0IsRUFBRSxDQUFDO0FBQzFDLE1BQU0sWUFBWSxHQUFzQixDQUFDLENBQUMsQ0FBQyxDQUFDO0FBUTVDLE1BQU0sT0FBTyxrQkFBa0I7SUFOL0I7UUFTSSxVQUFLLEdBQXNCLEVBQUUsQ0FBQztRQUk5QixTQUFJLEdBQStCLEdBQUcsQ0FBQztRQUl2QyxjQUFTLEdBQUcsS0FBSyxDQUFDO0tBMEJyQjtJQXhCRyxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0RCxDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDaEIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUM7SUFDckQsQ0FBQztJQUVELElBQUksWUFBWTtRQUNaLE9BQU8sSUFBSSxDQUFDLElBQUksSUFBSSxHQUFHLENBQUM7SUFDNUIsQ0FBQztJQUVELFNBQVMsQ0FBQyxLQUFhO1FBQ25CLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO0lBQzdFLENBQUM7SUFFRCxRQUFRLENBQUMsS0FBYTtRQUNsQixPQUFPLG1CQUFtQixLQUFLLEdBQUcsQ0FBQztJQUN2QyxDQUFDO0lBR08sVUFBVSxDQUFDLEtBQXdCO1FBQ3ZDLE9BQU8sS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN0RCxDQUFDOztnSEFwQ1Esa0JBQWtCO29HQUFsQixrQkFBa0IscUhDZi9CLDZvQ0FvQ0E7QURsQkk7SUFEQyxjQUFjLEVBQUU7aURBQ2E7QUFJOUI7SUFEQyxjQUFjLEVBQUU7Z0RBQ3NCO0FBSXZDO0lBREMsY0FBYyxFQUFFO3FEQUNDO0FBdUJsQjtJQURDLE9BQU87b0RBR1A7NEZBcENRLGtCQUFrQjtrQkFOOUIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsV0FBVyxFQUFFLHlCQUF5QjtvQkFDdEMsU0FBUyxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ25DLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDs4QkFJRyxLQUFLO3NCQUZKLEtBQUs7Z0JBTU4sSUFBSTtzQkFGSCxLQUFLO2dCQU1OLFNBQVM7c0JBRlIsS0FBSztnQkF5QkUsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTYWZlVmFsdWV9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHt0dWlEZWZhdWx0UHJvcCwgdHVpUHVyZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aVNpemVMLCBUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5jb25zdCBQRVJDRU5UID0gMTAwO1xuY29uc3QgRU1QVFlfQVJSQVk6IHJlYWRvbmx5IG51bWJlcltdID0gW107XG5jb25zdCBGSUxMRVJfQVJSQVk6IHJlYWRvbmx5IG51bWJlcltdID0gWzFdO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogYHR1aS1iYXItc2V0YCxcbiAgICB0ZW1wbGF0ZVVybDogYC4vYmFyLXNldC50ZW1wbGF0ZS5odG1sYCxcbiAgICBzdHlsZVVybHM6IFtgLi9iYXItc2V0LnN0eWxlLmxlc3NgXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpQmFyU2V0Q29tcG9uZW50IHtcbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgdmFsdWU6IHJlYWRvbmx5IG51bWJlcltdID0gW107XG5cbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgc2l6ZTogVHVpU2l6ZUwgfCBUdWlTaXplUyB8IG51bGwgPSBgbWA7XG5cbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgY29sbGFwc2VkID0gZmFsc2U7XG5cbiAgICBnZXQgY29tcHV0ZWRWYWx1ZSgpOiByZWFkb25seSBudW1iZXJbXSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbGxhcHNlZCA/IEZJTExFUl9BUlJBWSA6IHRoaXMudmFsdWU7XG4gICAgfVxuXG4gICAgZ2V0IGNvbXB1dGVkU2VnbWVudHMoKTogcmVhZG9ubHkgbnVtYmVyW10ge1xuICAgICAgICByZXR1cm4gdGhpcy5jb2xsYXBzZWQgPyB0aGlzLnZhbHVlIDogRU1QVFlfQVJSQVk7XG4gICAgfVxuXG4gICAgZ2V0IGNvbXB1dGVkU2l6ZSgpOiBUdWlTaXplTCB8IFR1aVNpemVTIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc2l6ZSB8fCBgbWA7XG4gICAgfVxuXG4gICAgZ2V0SGVpZ2h0KHZhbHVlOiBudW1iZXIpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gTWF0aC5hYnMoKFBFUkNFTlQgKiB2YWx1ZSkgLyB0aGlzLmdldExhcmdlc3QodGhpcy5jb21wdXRlZFZhbHVlKSk7XG4gICAgfVxuXG4gICAgZ2V0Q29sb3IoaW5kZXg6IG51bWJlcik6IFNhZmVWYWx1ZSB7XG4gICAgICAgIHJldHVybiBgdmFyKC0tdHVpLWNoYXJ0LSR7aW5kZXh9KWA7XG4gICAgfVxuXG4gICAgQHR1aVB1cmVcbiAgICBwcml2YXRlIGdldExhcmdlc3QodmFsdWU6IHJlYWRvbmx5IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHZhbHVlLnJlZHVjZSgoYSwgYikgPT4gKGEgPiBiID8gYSA6IGIpLCAwKTtcbiAgICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwic2l6ZTsgZWxzZSBmbGV4aWJsZVwiPlxuICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgY29tcHV0ZWRWYWx1ZTsgbGV0IGluZGV4ID0gaW5kZXhcIlxuICAgICAgICBbbmdUZW1wbGF0ZU91dGxldF09XCJiYXJcIlxuICAgICAgICBbbmdUZW1wbGF0ZU91dGxldENvbnRleHRdPVwieyRpbXBsaWNpdDogaXRlbSwgaW5kZXg6IGluZGV4LCBmbGV4aWJsZTogZmFsc2V9XCJcbiAgICA+PC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cbjxuZy10ZW1wbGF0ZSAjZmxleGlibGU+XG4gICAgPGRpdlxuICAgICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiBjb21wdXRlZFZhbHVlOyBsZXQgaW5kZXggPSBpbmRleFwiXG4gICAgICAgIGNsYXNzPVwidC13cmFwcGVyXCJcbiAgICA+XG4gICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImJhclwiXG4gICAgICAgICAgICBbbmdUZW1wbGF0ZU91dGxldENvbnRleHRdPVwieyRpbXBsaWNpdDogaXRlbSwgaW5kZXg6IGluZGV4LCBmbGV4aWJsZTogdHJ1ZX1cIlxuICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuPG5nLXRlbXBsYXRlXG4gICAgI2JhclxuICAgIGxldC1pdGVtXG4gICAgbGV0LWluZGV4PVwiaW5kZXhcIlxuICAgIGxldC1mbGV4aWJsZT1cImZsZXhpYmxlXCJcbj5cbiAgICA8dHVpLWJhclxuICAgICAgICBhdXRvbWF0aW9uLWlkPVwidHVpLWJhci1zZXRfX2JhclwiXG4gICAgICAgIGNsYXNzPVwidC1iYXJcIlxuICAgICAgICBbY2xhc3MudC1iYXJfZmxleGlibGVdPVwiZmxleGlibGVcIlxuICAgICAgICBbY2xhc3MudC1iYXJfbmVnYXRpdmVdPVwiaXRlbSA8IDBcIlxuICAgICAgICBbc3R5bGUuaGVpZ2h0LiVdPVwiZ2V0SGVpZ2h0KGl0ZW0pXCJcbiAgICAgICAgW3N0eWxlLmJhY2tncm91bmRdPVwiZ2V0Q29sb3IoaW5kZXgpXCJcbiAgICAgICAgW3ZhbHVlXT1cImNvbXB1dGVkU2VnbWVudHNcIlxuICAgICAgICBbc2l6ZV09XCJjb21wdXRlZFNpemVcIlxuICAgID48L3R1aS1iYXI+XG48L25nLXRlbXBsYXRlPlxuPHNwYW4gY2xhc3M9XCJ0LWxhYmVsXCI+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50Pjwvc3Bhbj5cbiJdfQ==
64
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFyLXNldC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hZGRvbi1jaGFydHMvY29tcG9uZW50cy9iYXItc2V0L2Jhci1zZXQuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvYmFyLXNldC9iYXItc2V0LnRlbXBsYXRlLmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBQyx1QkFBdUIsRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBRXhFLE9BQU8sRUFBQyxjQUFjLEVBQUUsT0FBTyxFQUFDLE1BQU0sZUFBZSxDQUFDOzs7O0FBR3RELE1BQU0sT0FBTyxHQUFHLEdBQUcsQ0FBQztBQUNwQixNQUFNLFdBQVcsR0FBc0IsRUFBRSxDQUFDO0FBQzFDLE1BQU0sWUFBWSxHQUFzQixDQUFDLENBQUMsQ0FBQyxDQUFDO0FBUTVDLE1BQU0sT0FBTyxrQkFBa0I7SUFOL0I7UUFTSSxVQUFLLEdBQXNCLEVBQUUsQ0FBQztRQUk5QixTQUFJLEdBQStCLEdBQUcsQ0FBQztRQUl2QyxjQUFTLEdBQUcsS0FBSyxDQUFDO0tBMEJyQjtJQXhCRyxJQUFJLGFBQWE7UUFDYixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLFlBQVksQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN0RCxDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDaEIsT0FBTyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUM7SUFDckQsQ0FBQztJQUVELElBQUksWUFBWTtRQUNaLE9BQU8sSUFBSSxDQUFDLElBQUksSUFBSSxHQUFHLENBQUM7SUFDNUIsQ0FBQztJQUVELFNBQVMsQ0FBQyxLQUFhO1FBQ25CLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sR0FBRyxLQUFLLENBQUMsR0FBRyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDO0lBQzdFLENBQUM7SUFFRCxRQUFRLENBQUMsS0FBYTtRQUNsQixPQUFPLG1CQUFtQixLQUFLLEdBQUcsQ0FBQztJQUN2QyxDQUFDO0lBR08sVUFBVSxDQUFDLEtBQXdCO1FBQ3ZDLE9BQU8sS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUN0RCxDQUFDOztnSEFwQ1Esa0JBQWtCO29HQUFsQixrQkFBa0IscUhDZi9CLDZvQ0FvQ0E7QURsQkk7SUFEQyxjQUFjLEVBQUU7aURBQ2E7QUFJOUI7SUFEQyxjQUFjLEVBQUU7Z0RBQ3NCO0FBSXZDO0lBREMsY0FBYyxFQUFFO3FEQUNDO0FBdUJsQjtJQURDLE9BQU87b0RBR1A7NEZBcENRLGtCQUFrQjtrQkFOOUIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsYUFBYTtvQkFDdkIsV0FBVyxFQUFFLHlCQUF5QjtvQkFDdEMsU0FBUyxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ25DLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDs4QkFJRyxLQUFLO3NCQUZKLEtBQUs7Z0JBTU4sSUFBSTtzQkFGSCxLQUFLO2dCQU1OLFNBQVM7c0JBRlIsS0FBSztnQkF5QkUsVUFBVSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXR9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHtTYWZlVmFsdWV9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHt0dWlEZWZhdWx0UHJvcCwgdHVpUHVyZX0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aVNpemVMLCBUdWlTaXplU30gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG5jb25zdCBQRVJDRU5UID0gMTAwO1xuY29uc3QgRU1QVFlfQVJSQVk6IHJlYWRvbmx5IG51bWJlcltdID0gW107XG5jb25zdCBGSUxMRVJfQVJSQVk6IHJlYWRvbmx5IG51bWJlcltdID0gWzFdO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3R1aS1iYXItc2V0JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vYmFyLXNldC50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9iYXItc2V0LnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpQmFyU2V0Q29tcG9uZW50IHtcbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgdmFsdWU6IHJlYWRvbmx5IG51bWJlcltdID0gW107XG5cbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgc2l6ZTogVHVpU2l6ZUwgfCBUdWlTaXplUyB8IG51bGwgPSAnbSc7XG5cbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgY29sbGFwc2VkID0gZmFsc2U7XG5cbiAgICBnZXQgY29tcHV0ZWRWYWx1ZSgpOiByZWFkb25seSBudW1iZXJbXSB7XG4gICAgICAgIHJldHVybiB0aGlzLmNvbGxhcHNlZCA/IEZJTExFUl9BUlJBWSA6IHRoaXMudmFsdWU7XG4gICAgfVxuXG4gICAgZ2V0IGNvbXB1dGVkU2VnbWVudHMoKTogcmVhZG9ubHkgbnVtYmVyW10ge1xuICAgICAgICByZXR1cm4gdGhpcy5jb2xsYXBzZWQgPyB0aGlzLnZhbHVlIDogRU1QVFlfQVJSQVk7XG4gICAgfVxuXG4gICAgZ2V0IGNvbXB1dGVkU2l6ZSgpOiBUdWlTaXplTCB8IFR1aVNpemVTIHtcbiAgICAgICAgcmV0dXJuIHRoaXMuc2l6ZSB8fCAnbSc7XG4gICAgfVxuXG4gICAgZ2V0SGVpZ2h0KHZhbHVlOiBudW1iZXIpOiBudW1iZXIge1xuICAgICAgICByZXR1cm4gTWF0aC5hYnMoKFBFUkNFTlQgKiB2YWx1ZSkgLyB0aGlzLmdldExhcmdlc3QodGhpcy5jb21wdXRlZFZhbHVlKSk7XG4gICAgfVxuXG4gICAgZ2V0Q29sb3IoaW5kZXg6IG51bWJlcik6IFNhZmVWYWx1ZSB7XG4gICAgICAgIHJldHVybiBgdmFyKC0tdHVpLWNoYXJ0LSR7aW5kZXh9KWA7XG4gICAgfVxuXG4gICAgQHR1aVB1cmVcbiAgICBwcml2YXRlIGdldExhcmdlc3QodmFsdWU6IHJlYWRvbmx5IG51bWJlcltdKTogbnVtYmVyIHtcbiAgICAgICAgcmV0dXJuIHZhbHVlLnJlZHVjZSgoYSwgYikgPT4gKGEgPiBiID8gYSA6IGIpLCAwKTtcbiAgICB9XG59XG4iLCI8bmctY29udGFpbmVyICpuZ0lmPVwic2l6ZTsgZWxzZSBmbGV4aWJsZVwiPlxuICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgKm5nRm9yPVwibGV0IGl0ZW0gb2YgY29tcHV0ZWRWYWx1ZTsgbGV0IGluZGV4ID0gaW5kZXhcIlxuICAgICAgICBbbmdUZW1wbGF0ZU91dGxldF09XCJiYXJcIlxuICAgICAgICBbbmdUZW1wbGF0ZU91dGxldENvbnRleHRdPVwieyRpbXBsaWNpdDogaXRlbSwgaW5kZXg6IGluZGV4LCBmbGV4aWJsZTogZmFsc2V9XCJcbiAgICA+PC9uZy1jb250YWluZXI+XG48L25nLWNvbnRhaW5lcj5cbjxuZy10ZW1wbGF0ZSAjZmxleGlibGU+XG4gICAgPGRpdlxuICAgICAgICAqbmdGb3I9XCJsZXQgaXRlbSBvZiBjb21wdXRlZFZhbHVlOyBsZXQgaW5kZXggPSBpbmRleFwiXG4gICAgICAgIGNsYXNzPVwidC13cmFwcGVyXCJcbiAgICA+XG4gICAgICAgIDxuZy1jb250YWluZXJcbiAgICAgICAgICAgIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImJhclwiXG4gICAgICAgICAgICBbbmdUZW1wbGF0ZU91dGxldENvbnRleHRdPVwieyRpbXBsaWNpdDogaXRlbSwgaW5kZXg6IGluZGV4LCBmbGV4aWJsZTogdHJ1ZX1cIlxuICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgPC9kaXY+XG48L25nLXRlbXBsYXRlPlxuPG5nLXRlbXBsYXRlXG4gICAgI2JhclxuICAgIGxldC1pdGVtXG4gICAgbGV0LWluZGV4PVwiaW5kZXhcIlxuICAgIGxldC1mbGV4aWJsZT1cImZsZXhpYmxlXCJcbj5cbiAgICA8dHVpLWJhclxuICAgICAgICBhdXRvbWF0aW9uLWlkPVwidHVpLWJhci1zZXRfX2JhclwiXG4gICAgICAgIGNsYXNzPVwidC1iYXJcIlxuICAgICAgICBbY2xhc3MudC1iYXJfZmxleGlibGVdPVwiZmxleGlibGVcIlxuICAgICAgICBbY2xhc3MudC1iYXJfbmVnYXRpdmVdPVwiaXRlbSA8IDBcIlxuICAgICAgICBbc3R5bGUuaGVpZ2h0LiVdPVwiZ2V0SGVpZ2h0KGl0ZW0pXCJcbiAgICAgICAgW3N0eWxlLmJhY2tncm91bmRdPVwiZ2V0Q29sb3IoaW5kZXgpXCJcbiAgICAgICAgW3ZhbHVlXT1cImNvbXB1dGVkU2VnbWVudHNcIlxuICAgICAgICBbc2l6ZV09XCJjb21wdXRlZFNpemVcIlxuICAgID48L3R1aS1iYXI+XG48L25nLXRlbXBsYXRlPlxuPHNwYW4gY2xhc3M9XCJ0LWxhYmVsXCI+PG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50Pjwvc3Bhbj5cbiJdfQ==
@@ -6,13 +6,13 @@ import * as i1 from "@taiga-ui/core";
6
6
  export class TuiLegendItemComponent {
7
7
  constructor() {
8
8
  this.active = false;
9
- this.color = ``;
10
- this.text = ``;
11
- this.size = `m`;
9
+ this.color = '';
10
+ this.text = '';
11
+ this.size = 'm';
12
12
  this.disabled = false;
13
13
  }
14
14
  get computedColor() {
15
- return this.color === `var(--tui-primary)` ? null : this.color;
15
+ return this.color === 'var(--tui-primary)' ? null : this.color;
16
16
  }
17
17
  }
18
18
  TuiLegendItemComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiLegendItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
@@ -32,9 +32,9 @@ __decorate([
32
32
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiLegendItemComponent, decorators: [{
33
33
  type: Component,
34
34
  args: [{
35
- selector: `tui-legend-item`,
36
- templateUrl: `./legend-item.template.html`,
37
- styleUrls: [`./legend-item.style.less`],
35
+ selector: 'tui-legend-item',
36
+ templateUrl: './legend-item.template.html',
37
+ styleUrls: ['./legend-item.style.less'],
38
38
  changeDetection: ChangeDetectionStrategy.OnPush,
39
39
  }]
40
40
  }], propDecorators: { active: [{
@@ -47,14 +47,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
47
47
  type: Input
48
48
  }, {
49
49
  type: HostBinding,
50
- args: [`attr.data-size`]
50
+ args: ['attr.data-size']
51
51
  }], disabled: [{
52
52
  type: Input
53
53
  }, {
54
54
  type: HostBinding,
55
- args: [`class._disabled`]
55
+ args: ['class._disabled']
56
56
  }], computedColor: [{
57
57
  type: HostBinding,
58
- args: [`style.--tui-primary`]
58
+ args: ['style.--tui-primary']
59
59
  }] } });
60
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVnZW5kLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvbGVnZW5kLWl0ZW0vbGVnZW5kLWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvbGVnZW5kLWl0ZW0vbGVnZW5kLWl0ZW0udGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3JGLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxlQUFlLENBQUM7OztBQVM3QyxNQUFNLE9BQU8sc0JBQXNCO0lBTm5DO1FBU0ksV0FBTSxHQUFHLEtBQUssQ0FBQztRQUlmLFVBQUssR0FBRyxFQUFFLENBQUM7UUFJWCxTQUFJLEdBQUcsRUFBRSxDQUFDO1FBS1YsU0FBSSxHQUFhLEdBQUcsQ0FBQztRQUlyQixhQUFRLEdBQUcsS0FBSyxDQUFDO0tBTXBCO0lBSkcsSUFDSSxhQUFhO1FBQ2IsT0FBTyxJQUFJLENBQUMsS0FBSyxLQUFLLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDbkUsQ0FBQzs7b0hBekJRLHNCQUFzQjt3R0FBdEIsc0JBQXNCLGlTQ1ZuQyxvZkFrQkE7QURMSTtJQURDLGNBQWMsRUFBRTtzREFDRjtBQUlmO0lBREMsY0FBYyxFQUFFO3FEQUNOO0FBSVg7SUFEQyxjQUFjLEVBQUU7b0RBQ1A7QUFLVjtJQURDLGNBQWMsRUFBRTtvREFDSTs0RkFoQlosc0JBQXNCO2tCQU5sQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLFdBQVcsRUFBRSw2QkFBNkI7b0JBQzFDLFNBQVMsRUFBRSxDQUFDLDBCQUEwQixDQUFDO29CQUN2QyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQ7OEJBSUcsTUFBTTtzQkFGTCxLQUFLO2dCQU1OLEtBQUs7c0JBRkosS0FBSztnQkFNTixJQUFJO3NCQUZILEtBQUs7Z0JBT04sSUFBSTtzQkFISCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLGdCQUFnQjtnQkFNN0IsUUFBUTtzQkFGUCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLGlCQUFpQjtnQkFJMUIsYUFBYTtzQkFEaEIsV0FBVzt1QkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge3R1aURlZmF1bHRQcm9wfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7VHVpU2l6ZVN9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IGB0dWktbGVnZW5kLWl0ZW1gLFxuICAgIHRlbXBsYXRlVXJsOiBgLi9sZWdlbmQtaXRlbS50ZW1wbGF0ZS5odG1sYCxcbiAgICBzdHlsZVVybHM6IFtgLi9sZWdlbmQtaXRlbS5zdHlsZS5sZXNzYF0sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aUxlZ2VuZEl0ZW1Db21wb25lbnQge1xuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBhY3RpdmUgPSBmYWxzZTtcblxuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBjb2xvciA9IGBgO1xuXG4gICAgQElucHV0KClcbiAgICBAdHVpRGVmYXVsdFByb3AoKVxuICAgIHRleHQgPSBgYDtcblxuICAgIEBJbnB1dCgpXG4gICAgQEhvc3RCaW5kaW5nKGBhdHRyLmRhdGEtc2l6ZWApXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBzaXplOiBUdWlTaXplUyA9IGBtYDtcblxuICAgIEBJbnB1dCgpXG4gICAgQEhvc3RCaW5kaW5nKGBjbGFzcy5fZGlzYWJsZWRgKVxuICAgIGRpc2FibGVkID0gZmFsc2U7XG5cbiAgICBASG9zdEJpbmRpbmcoYHN0eWxlLi0tdHVpLXByaW1hcnlgKVxuICAgIGdldCBjb21wdXRlZENvbG9yKCk6IHN0cmluZyB8IG51bGwge1xuICAgICAgICByZXR1cm4gdGhpcy5jb2xvciA9PT0gYHZhcigtLXR1aS1wcmltYXJ5KWAgPyBudWxsIDogdGhpcy5jb2xvcjtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgdHVpQnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgc2l6ZT1cInNcIlxuICAgIGFwcGVhcmFuY2U9XCJ3aGl0ZWJsb2NrXCJcbiAgICBjbGFzcz1cInQtYnV0dG9uXCJcbiAgICBbcHNldWRvSG92ZXJdPVwiYWN0aXZlIHx8IG51bGxcIlxuPlxuICAgIDxkaXYgY2xhc3M9XCJ0LXdyYXBwZXJcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpLXByaW1pdGl2ZS1jaGVja2JveFwiPjwvbmctY29udGVudD5cbiAgICAgICAgPHNwYW5cbiAgICAgICAgICAgIGNsYXNzPVwidC1kb3RcIlxuICAgICAgICAgICAgW3N0eWxlLmJhY2tncm91bmRDb2xvcl09XCJjb2xvciB8fCAndmFyKC0tdHVpLXByaW1hcnkpJ1wiXG4gICAgICAgID48L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwidC10ZXh0XCI+e3sgdGV4dCB9fTwvc3Bhbj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9idXR0b24+XG4iXX0=
60
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGVnZW5kLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvbGVnZW5kLWl0ZW0vbGVnZW5kLWl0ZW0uY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvbGVnZW5kLWl0ZW0vbGVnZW5kLWl0ZW0udGVtcGxhdGUuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxXQUFXLEVBQUUsS0FBSyxFQUFDLE1BQU0sZUFBZSxDQUFDO0FBQ3JGLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxlQUFlLENBQUM7OztBQVM3QyxNQUFNLE9BQU8sc0JBQXNCO0lBTm5DO1FBU0ksV0FBTSxHQUFHLEtBQUssQ0FBQztRQUlmLFVBQUssR0FBRyxFQUFFLENBQUM7UUFJWCxTQUFJLEdBQUcsRUFBRSxDQUFDO1FBS1YsU0FBSSxHQUFhLEdBQUcsQ0FBQztRQUlyQixhQUFRLEdBQUcsS0FBSyxDQUFDO0tBTXBCO0lBSkcsSUFDSSxhQUFhO1FBQ2IsT0FBTyxJQUFJLENBQUMsS0FBSyxLQUFLLG9CQUFvQixDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDbkUsQ0FBQzs7b0hBekJRLHNCQUFzQjt3R0FBdEIsc0JBQXNCLGlTQ1ZuQyxvZkFrQkE7QURMSTtJQURDLGNBQWMsRUFBRTtzREFDRjtBQUlmO0lBREMsY0FBYyxFQUFFO3FEQUNOO0FBSVg7SUFEQyxjQUFjLEVBQUU7b0RBQ1A7QUFLVjtJQURDLGNBQWMsRUFBRTtvREFDSTs0RkFoQlosc0JBQXNCO2tCQU5sQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxpQkFBaUI7b0JBQzNCLFdBQVcsRUFBRSw2QkFBNkI7b0JBQzFDLFNBQVMsRUFBRSxDQUFDLDBCQUEwQixDQUFDO29CQUN2QyxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtpQkFDbEQ7OEJBSUcsTUFBTTtzQkFGTCxLQUFLO2dCQU1OLEtBQUs7c0JBRkosS0FBSztnQkFNTixJQUFJO3NCQUZILEtBQUs7Z0JBT04sSUFBSTtzQkFISCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLGdCQUFnQjtnQkFNN0IsUUFBUTtzQkFGUCxLQUFLOztzQkFDTCxXQUFXO3VCQUFDLGlCQUFpQjtnQkFJMUIsYUFBYTtzQkFEaEIsV0FBVzt1QkFBQyxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEhvc3RCaW5kaW5nLCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge3R1aURlZmF1bHRQcm9wfSBmcm9tICdAdGFpZ2EtdWkvY2RrJztcbmltcG9ydCB7VHVpU2l6ZVN9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6ICd0dWktbGVnZW5kLWl0ZW0nLFxuICAgIHRlbXBsYXRlVXJsOiAnLi9sZWdlbmQtaXRlbS50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9sZWdlbmQtaXRlbS5zdHlsZS5sZXNzJ10sXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXG59KVxuZXhwb3J0IGNsYXNzIFR1aUxlZ2VuZEl0ZW1Db21wb25lbnQge1xuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBhY3RpdmUgPSBmYWxzZTtcblxuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBjb2xvciA9ICcnO1xuXG4gICAgQElucHV0KClcbiAgICBAdHVpRGVmYXVsdFByb3AoKVxuICAgIHRleHQgPSAnJztcblxuICAgIEBJbnB1dCgpXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRhdGEtc2l6ZScpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBzaXplOiBUdWlTaXplUyA9ICdtJztcblxuICAgIEBJbnB1dCgpXG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy5fZGlzYWJsZWQnKVxuICAgIGRpc2FibGVkID0gZmFsc2U7XG5cbiAgICBASG9zdEJpbmRpbmcoJ3N0eWxlLi0tdHVpLXByaW1hcnknKVxuICAgIGdldCBjb21wdXRlZENvbG9yKCk6IHN0cmluZyB8IG51bGwge1xuICAgICAgICByZXR1cm4gdGhpcy5jb2xvciA9PT0gJ3ZhcigtLXR1aS1wcmltYXJ5KScgPyBudWxsIDogdGhpcy5jb2xvcjtcbiAgICB9XG59XG4iLCI8YnV0dG9uXG4gICAgdHVpQnV0dG9uXG4gICAgdHlwZT1cImJ1dHRvblwiXG4gICAgc2l6ZT1cInNcIlxuICAgIGFwcGVhcmFuY2U9XCJ3aGl0ZWJsb2NrXCJcbiAgICBjbGFzcz1cInQtYnV0dG9uXCJcbiAgICBbcHNldWRvSG92ZXJdPVwiYWN0aXZlIHx8IG51bGxcIlxuPlxuICAgIDxkaXYgY2xhc3M9XCJ0LXdyYXBwZXJcIj5cbiAgICAgICAgPG5nLWNvbnRlbnQgc2VsZWN0PVwidHVpLXByaW1pdGl2ZS1jaGVja2JveFwiPjwvbmctY29udGVudD5cbiAgICAgICAgPHNwYW5cbiAgICAgICAgICAgIGNsYXNzPVwidC1kb3RcIlxuICAgICAgICAgICAgW3N0eWxlLmJhY2tncm91bmRDb2xvcl09XCJjb2xvciB8fCAndmFyKC0tdHVpLXByaW1hcnkpJ1wiXG4gICAgICAgID48L3NwYW4+XG4gICAgICAgIDxzcGFuIGNsYXNzPVwidC10ZXh0XCI+e3sgdGV4dCB9fTwvc3Bhbj5cbiAgICAgICAgPG5nLWNvbnRlbnQ+PC9uZy1jb250ZW50PlxuICAgIDwvZGl2PlxuPC9idXR0b24+XG4iXX0=
@@ -17,7 +17,7 @@ export class TuiLineChartHintDirective {
17
17
  this.hovered$ = hovered$;
18
18
  this.charts = EMPTY_QUERY;
19
19
  this.chartsRef = EMPTY_QUERY;
20
- this.hint = ``;
20
+ this.hint = '';
21
21
  }
22
22
  ngAfterContentInit() {
23
23
  combineLatest([tuiLineChartDrivers(this.charts), this.hovered$])
@@ -35,7 +35,7 @@ export class TuiLineChartHintDirective {
35
35
  const current = this.charts.map(chart => chart.value[index]);
36
36
  const sorted = [...current].sort((a, b) => a[1] - b[1]);
37
37
  this.charts.forEach(chart => chart.onHovered(index));
38
- this.chartsRef.forEach(({ nativeElement }, index) => this.renderer.setStyle(nativeElement, `z-index`, sorted.indexOf(current[index])));
38
+ this.chartsRef.forEach(({ nativeElement }, index) => this.renderer.setStyle(nativeElement, 'z-index', sorted.indexOf(current[index])));
39
39
  }
40
40
  computeContext(index, charts) {
41
41
  return {
@@ -55,7 +55,7 @@ __decorate([
55
55
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImport: i0, type: TuiLineChartHintDirective, decorators: [{
56
56
  type: Directive,
57
57
  args: [{
58
- selector: `[tuiLineChartHint]`,
58
+ selector: '[tuiLineChartHint]',
59
59
  providers: [TuiDestroyService, TuiHoveredService],
60
60
  }]
61
61
  }], ctorParameters: function () { return [{ type: i0.Renderer2, decorators: [{
@@ -80,11 +80,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.16", ngImpo
80
80
  args: [forwardRef(() => TuiLineChartComponent), { read: ElementRef }]
81
81
  }], hint: [{
82
82
  type: Input,
83
- args: [`tuiLineChartHint`]
83
+ args: ['tuiLineChartHint']
84
84
  }], computeContext: [] } });
85
85
  export function tuiLineChartDrivers(charts) {
86
86
  return combineLatest(charts
87
87
  .map(({ drivers }) => drivers.map(driver => driver.pipe(startWith(false))))
88
88
  .reduce((acc, drivers) => acc.concat(drivers), [])).pipe(map(values => values.some(Boolean)), distinctUntilChanged());
89
89
  }
90
- //# 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":"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","sourcesContent":["import {\n    AfterContentInit,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    forwardRef,\n    Inject,\n    Input,\n    NgZone,\n    QueryList,\n    Renderer2,\n    Self,\n} from '@angular/core';\nimport {TuiLineChartHintContext} from '@taiga-ui/addon-charts/interfaces';\nimport {\n    EMPTY_QUERY,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiHoveredService,\n    tuiPure,\n    tuiZonefree,\n} from '@taiga-ui/cdk';\nimport {TuiPoint} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {combineLatest, Observable} from 'rxjs';\nimport {distinctUntilChanged, filter, map, startWith, takeUntil} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiLineChartComponent} from './line-chart.component';\n\n@Directive({\n    selector: `[tuiLineChartHint]`,\n    providers: [TuiDestroyService, TuiHoveredService],\n})\nexport class TuiLineChartHintDirective implements AfterContentInit {\n    @ContentChildren(forwardRef(() => TuiLineChartComponent))\n    private readonly charts: QueryList<TuiLineChartComponent> = EMPTY_QUERY;\n\n    @ContentChildren(forwardRef(() => TuiLineChartComponent), {read: ElementRef})\n    private readonly chartsRef: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    @Input(`tuiLineChartHint`)\n    @tuiDefaultProp()\n    hint: PolymorpheusContent<TuiContextWithImplicit<readonly TuiPoint[]>> = ``;\n\n    constructor(\n        @Inject(Renderer2) private readonly renderer: Renderer2,\n        @Self() @Inject(TuiDestroyService) private readonly destroy$: TuiDestroyService,\n        @Inject(NgZone) private readonly ngZone: NgZone,\n        @Inject(TuiHoveredService) private readonly hovered$: Observable<boolean>,\n    ) {}\n\n    ngAfterContentInit(): void {\n        combineLatest([tuiLineChartDrivers(this.charts), this.hovered$])\n            .pipe(\n                map(([drivers, hovered]) => !drivers && !hovered),\n                filter(Boolean),\n                tuiZonefree(this.ngZone),\n                takeUntil(this.destroy$),\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    getContext(\n        index: number,\n        _chart: TuiLineChartComponent,\n    ): TuiLineChartHintContext<readonly TuiPoint[]> {\n        return this.computeContext(index, this.charts);\n    }\n\n    // _chart is required by TuiLineDaysChartComponent that impersonates this directive\n    raise(index: number, _chart: TuiLineChartComponent): void {\n        const current = this.charts.map(chart => chart.value[index]);\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]),\n            ),\n        );\n    }\n\n    @tuiPure\n    private computeContext(\n        index: number,\n        charts: QueryList<TuiLineChartComponent>,\n    ): TuiLineChartHintContext<readonly TuiPoint[]> {\n        return {\n            $implicit: charts.map(chart => chart.value[index]),\n            index,\n        };\n    }\n}\n\nexport function tuiLineChartDrivers(\n    charts: QueryList<{drivers: QueryList<Observable<boolean>>}>,\n): Observable<boolean> {\n    return combineLatest(\n        charts\n            .map(({drivers}) => drivers.map(driver => driver.pipe(startWith(false))))\n            .reduce((acc, drivers) => acc.concat(drivers), []),\n    ).pipe(\n        map(values => values.some(Boolean)),\n        distinctUntilChanged(),\n    );\n}\n"]}
90
+ //# 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":"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","sourcesContent":["import {\n    AfterContentInit,\n    ContentChildren,\n    Directive,\n    ElementRef,\n    forwardRef,\n    Inject,\n    Input,\n    NgZone,\n    QueryList,\n    Renderer2,\n    Self,\n} from '@angular/core';\nimport {TuiLineChartHintContext} from '@taiga-ui/addon-charts/interfaces';\nimport {\n    EMPTY_QUERY,\n    TuiContextWithImplicit,\n    tuiDefaultProp,\n    TuiDestroyService,\n    TuiHoveredService,\n    tuiPure,\n    tuiZonefree,\n} from '@taiga-ui/cdk';\nimport {TuiPoint} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\nimport {combineLatest, Observable} from 'rxjs';\nimport {distinctUntilChanged, filter, map, startWith, takeUntil} from 'rxjs/operators';\n\n// TODO: find the best way for prevent cycle\n// eslint-disable-next-line import/no-cycle\nimport {TuiLineChartComponent} from './line-chart.component';\n\n@Directive({\n    selector: '[tuiLineChartHint]',\n    providers: [TuiDestroyService, TuiHoveredService],\n})\nexport class TuiLineChartHintDirective implements AfterContentInit {\n    @ContentChildren(forwardRef(() => TuiLineChartComponent))\n    private readonly charts: QueryList<TuiLineChartComponent> = EMPTY_QUERY;\n\n    @ContentChildren(forwardRef(() => TuiLineChartComponent), {read: ElementRef})\n    private readonly chartsRef: QueryList<ElementRef<HTMLElement>> = EMPTY_QUERY;\n\n    @Input('tuiLineChartHint')\n    @tuiDefaultProp()\n    hint: PolymorpheusContent<TuiContextWithImplicit<readonly TuiPoint[]>> = '';\n\n    constructor(\n        @Inject(Renderer2) private readonly renderer: Renderer2,\n        @Self() @Inject(TuiDestroyService) private readonly destroy$: TuiDestroyService,\n        @Inject(NgZone) private readonly ngZone: NgZone,\n        @Inject(TuiHoveredService) private readonly hovered$: Observable<boolean>,\n    ) {}\n\n    ngAfterContentInit(): void {\n        combineLatest([tuiLineChartDrivers(this.charts), this.hovered$])\n            .pipe(\n                map(([drivers, hovered]) => !drivers && !hovered),\n                filter(Boolean),\n                tuiZonefree(this.ngZone),\n                takeUntil(this.destroy$),\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    getContext(\n        index: number,\n        _chart: TuiLineChartComponent,\n    ): TuiLineChartHintContext<readonly TuiPoint[]> {\n        return this.computeContext(index, this.charts);\n    }\n\n    // _chart is required by TuiLineDaysChartComponent that impersonates this directive\n    raise(index: number, _chart: TuiLineChartComponent): void {\n        const current = this.charts.map(chart => chart.value[index]);\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]),\n            ),\n        );\n    }\n\n    @tuiPure\n    private computeContext(\n        index: number,\n        charts: QueryList<TuiLineChartComponent>,\n    ): TuiLineChartHintContext<readonly TuiPoint[]> {\n        return {\n            $implicit: charts.map(chart => chart.value[index]),\n            index,\n        };\n    }\n}\n\nexport function tuiLineChartDrivers(\n    charts: QueryList<{drivers: QueryList<Observable<boolean>>}>,\n): Observable<boolean> {\n    return combineLatest(\n        charts\n            .map(({drivers}) => drivers.map(driver => driver.pipe(startWith(false))))\n            .reduce((acc, drivers) => acc.concat(drivers), []),\n    ).pipe(\n        map(values => values.some(Boolean)),\n        distinctUntilChanged(),\n    );\n}\n"]}