@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.
- package/bundles/taiga-ui-addon-charts-components-arc-chart.umd.js +12 -12
- package/bundles/taiga-ui-addon-charts-components-arc-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-axes.umd.js +10 -10
- package/bundles/taiga-ui-addon-charts-components-axes.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar-chart.umd.js +8 -8
- package/bundles/taiga-ui-addon-charts-components-bar-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar-set.umd.js +5 -5
- package/bundles/taiga-ui-addon-charts-components-bar-set.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar.umd.js +5 -5
- package/bundles/taiga-ui-addon-charts-components-bar.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-legend-item.umd.js +10 -10
- package/bundles/taiga-ui-addon-charts-components-legend-item.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-chart.umd.js +15 -15
- package/bundles/taiga-ui-addon-charts-components-line-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.js +10 -10
- package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-pie-chart.umd.js +16 -16
- package/bundles/taiga-ui-addon-charts-components-pie-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-ring-chart.umd.js +5 -5
- package/bundles/taiga-ui-addon-charts-components-ring-chart.umd.js.map +1 -1
- package/esm2015/components/arc-chart/arc-chart.component.js +13 -13
- package/esm2015/components/axes/axes.component.js +11 -11
- package/esm2015/components/bar/bar.component.js +6 -6
- package/esm2015/components/bar-chart/bar-chart.component.js +9 -9
- package/esm2015/components/bar-set/bar-set.component.js +6 -6
- package/esm2015/components/legend-item/legend-item.component.js +11 -11
- package/esm2015/components/line-chart/line-chart-hint.directive.js +5 -5
- package/esm2015/components/line-chart/line-chart.component.js +12 -12
- package/esm2015/components/line-days-chart/line-days-chart-hint.directive.js +4 -4
- package/esm2015/components/line-days-chart/line-days-chart.component.js +8 -8
- package/esm2015/components/pie-chart/pie-chart.component.js +15 -15
- package/esm2015/components/pie-chart/pie-chart.directive.js +3 -3
- package/esm2015/components/ring-chart/ring-chart.component.js +6 -6
- package/fesm2015/taiga-ui-addon-charts-components-arc-chart.js +12 -12
- package/fesm2015/taiga-ui-addon-charts-components-arc-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-axes.js +10 -10
- package/fesm2015/taiga-ui-addon-charts-components-axes.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-bar-chart.js +8 -8
- package/fesm2015/taiga-ui-addon-charts-components-bar-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-bar-set.js +5 -5
- package/fesm2015/taiga-ui-addon-charts-components-bar-set.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-bar.js +5 -5
- package/fesm2015/taiga-ui-addon-charts-components-bar.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-legend-item.js +10 -10
- package/fesm2015/taiga-ui-addon-charts-components-legend-item.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-line-chart.js +15 -15
- package/fesm2015/taiga-ui-addon-charts-components-line-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-line-days-chart.js +10 -10
- package/fesm2015/taiga-ui-addon-charts-components-line-days-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-pie-chart.js +16 -16
- package/fesm2015/taiga-ui-addon-charts-components-pie-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-ring-chart.js +5 -5
- package/fesm2015/taiga-ui-addon-charts-components-ring-chart.js.map +1 -1
- 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 =
|
|
13
|
+
this.axisX = 'solid';
|
|
14
14
|
this.axisXLabels = [];
|
|
15
|
-
this.axisY =
|
|
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 ===
|
|
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:
|
|
89
|
-
templateUrl:
|
|
90
|
-
styleUrls: [
|
|
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)':
|
|
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: [
|
|
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":";AAAA,OAAO,EACH,uBAAuB,EACvB,SAAS,EACT,WAAW,EACX,MAAM,EACN,KAAK,GACR,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,iBAAiB,EAAE,gBAAgB,EAAC,MAAM,kCAAkC,CAAC;AAErF,OAAO,EAAC,mBAAmB,EAAE,cAAc,EAAC,MAAM,eAAe,CAAC;AAClE,OAAO,EAAC,aAAa,EAAE,QAAQ,EAAgB,MAAM,gBAAgB,CAAC;;;;;AAatE,MAAM,OAAO,gBAAgB;IA0DzB,YAAuC,KAAuC;QAAvC,UAAK,GAAL,KAAK,CAAkC;QAvD9E,UAAK,GAAgB,OAAO,CAAC;QAI7B,gBAAW,GAAiC,EAAE,CAAC;QAI/C,UAAK,GAAgB,OAAO,CAAC;QAI7B,eAAU,GAAG,KAAK,CAAC;QAInB,gBAAW,GAAsB,EAAE,CAAC;QAIpC,cAAS,GAAG,EAAE,CAAC;QAIf,wBAAmB,GAAG,KAAK,CAAC;QAI5B,yBAAoB,GAAsB,EAAE,CAAC;QAI7C,uBAAkB,GAAG,EAAE,CAAC;QAIxB,oBAAe,GAAG,CAAC,CAAC;QAIpB,2BAAsB,GAAmB,gBAAgB,CAAC;QAI1D,kBAAa,GAAG,CAAC,CAAC;QAIlB,yBAAoB,GAAmB,iBAAiB,CAAC;IAOwB,CAAC;IALlF,IACI,eAAe;QACf,OAAO,IAAI,CAAC,KAAK,KAAK,MAAM,CAAC;IACjC,CAAC;IAID,IAAI,UAAU;QACV,OAAO,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;IACrC,CAAC;IAED,IAAI,UAAU;QACV,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;IAC/E,CAAC;IAED,IAAI,mBAAmB;QACnB,OAAO,CACH,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC;YACjE,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAC5B,CAAC;IACN,CAAC;IAED,QAAQ,CAAC,KAAoB;QACzB,OAAO,KAAK,IAAI,mBAAmB,CAAC;IACxC,CAAC;;8GA7EQ,gBAAgB,kBA0DL,QAAQ;kGA1DnB,gBAAgB,klBALd,CAAC,aAAa,CAAC,0BClB9B,8yGAkHA;ADxFI;IADC,cAAc,EAAE;+CACY;AAI7B;IADC,cAAc,EAAE;qDAC8B;AAI/C;IADC,cAAc,EAAE;+CACY;AAI7B;IADC,cAAc,EAAE;oDACE;AAInB;IADC,cAAc,EAAE;qDACmB;AAIpC;IADC,cAAc,EAAE;mDACF;AAIf;IADC,cAAc,EAAE;6DACW;AAI5B;IADC,cAAc,EAAE;8DAC4B;AAI7C;IADC,cAAc,EAAE;4DACO;AAIxB;IADC,cAAc,EAAE;yDACG;AAIpB;IADC,cAAc,EAAE;gEACyC;AAI1D;IADC,cAAc,EAAE;uDACC;AAIlB;IADC,cAAc,EAAE;8DACwC;4FAnDhD,gBAAgB;kBAV5B,SAAS;mBAAC;oBACP,QAAQ,EAAE,UAAU;oBACpB,WAAW,EAAE,sBAAsB;oBACnC,SAAS,EAAE,CAAC,mBAAmB,CAAC;oBAChC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,SAAS,EAAE,CAAC,aAAa,CAAC;oBAC1B,IAAI,EAAE;wBACF,oBAAoB,EAAE,OAAO;qBAChC;iBACJ;;0BA2DgB,MAAM;2BAAC,QAAQ;4CAvD5B,KAAK;sBAFJ,KAAK;gBAMN,WAAW;sBAFV,KAAK;gBAMN,KAAK;sBAFJ,KAAK;gBAMN,UAAU;sBAFT,KAAK;gBAMN,WAAW;sBAFV,KAAK;gBAMN,SAAS;sBAFR,KAAK;gBAMN,mBAAmB;sBAFlB,KAAK;gBAMN,oBAAoB;sBAFnB,KAAK;gBAMN,kBAAkB;sBAFjB,KAAK;gBAMN,eAAe;sBAFd,KAAK;gBAMN,sBAAsB;sBAFrB,KAAK;gBAMN,aAAa;sBAFZ,KAAK;gBAMN,oBAAoB;sBAFnB,KAAK;gBAKF,eAAe;sBADlB,WAAW;uBAAC,iBAAiB","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 =
|
|
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:
|
|
36
|
-
templateUrl:
|
|
37
|
-
styleUrls: [
|
|
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: [
|
|
46
|
+
args: ['attr.data-size']
|
|
47
47
|
}], getSum: [] } });
|
|
48
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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 =
|
|
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 =
|
|
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:
|
|
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:
|
|
72
|
-
templateUrl:
|
|
73
|
-
styleUrls: [
|
|
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:
|
|
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,
|
|
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 =
|
|
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 ||
|
|
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:
|
|
53
|
-
templateUrl:
|
|
54
|
-
styleUrls: [
|
|
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,
|
|
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 =
|
|
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 ===
|
|
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:
|
|
36
|
-
templateUrl:
|
|
37
|
-
styleUrls: [
|
|
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: [
|
|
50
|
+
args: ['attr.data-size']
|
|
51
51
|
}], disabled: [{
|
|
52
52
|
type: Input
|
|
53
53
|
}, {
|
|
54
54
|
type: HostBinding,
|
|
55
|
-
args: [
|
|
55
|
+
args: ['class._disabled']
|
|
56
56
|
}], computedColor: [{
|
|
57
57
|
type: HostBinding,
|
|
58
|
-
args: [
|
|
58
|
+
args: ['style.--tui-primary']
|
|
59
59
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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,
|
|
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:
|
|
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: [
|
|
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,
|
|
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"]}
|