@taiga-ui/addon-charts 2.75.0 → 2.76.0
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 +58 -13
- package/bundles/taiga-ui-addon-charts-components-arc-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-arc-chart.umd.min.js +1 -1
- package/bundles/taiga-ui-addon-charts-components-arc-chart.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-axes.umd.js +54 -9
- package/bundles/taiga-ui-addon-charts-components-axes.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-axes.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar-chart.umd.js +51 -6
- package/bundles/taiga-ui-addon-charts-components-bar-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar-chart.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar-set.umd.js +49 -4
- package/bundles/taiga-ui-addon-charts-components-bar-set.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar-set.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar.umd.js +49 -4
- package/bundles/taiga-ui-addon-charts-components-bar.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-bar.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-legend-item.umd.js +55 -10
- package/bundles/taiga-ui-addon-charts-components-legend-item.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-legend-item.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-chart.umd.js +58 -13
- package/bundles/taiga-ui-addon-charts-components-line-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-chart.umd.min.js +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-chart.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.js +58 -11
- package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.min.js +1 -1
- package/bundles/taiga-ui-addon-charts-components-line-days-chart.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-pie-chart.umd.js +59 -14
- package/bundles/taiga-ui-addon-charts-components-pie-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-pie-chart.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-ring-chart.umd.js +50 -5
- package/bundles/taiga-ui-addon-charts-components-ring-chart.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-components-ring-chart.umd.min.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-utils.umd.js +48 -2
- package/bundles/taiga-ui-addon-charts-utils.umd.js.map +1 -1
- package/bundles/taiga-ui-addon-charts-utils.umd.min.js +1 -1
- package/bundles/taiga-ui-addon-charts-utils.umd.min.js.map +1 -1
- package/components/arc-chart/taiga-ui-addon-charts-components-arc-chart.metadata.json +1 -1
- package/components/bar/bar.component.d.ts +1 -1
- package/components/bar-chart/bar-chart.component.d.ts +1 -1
- package/components/bar-set/bar-set.component.d.ts +2 -2
- package/components/pie-chart/pie-chart.component.d.ts +1 -1
- package/esm2015/components/arc-chart/arc-chart.component.js +13 -13
- package/esm2015/components/axes/axes.component.js +9 -9
- package/esm2015/components/bar/bar.component.js +4 -4
- package/esm2015/components/bar-chart/bar-chart.component.js +6 -6
- package/esm2015/components/bar-set/bar-set.component.js +4 -4
- package/esm2015/components/legend-item/legend-item.component.js +10 -10
- package/esm2015/components/line-chart/line-chart-hint.directive.js +5 -5
- package/esm2015/components/line-chart/line-chart.component.js +9 -9
- package/esm2015/components/line-days-chart/line-days-chart-hint.directive.js +5 -5
- package/esm2015/components/line-days-chart/line-days-chart.component.js +10 -7
- package/esm2015/components/pie-chart/pie-chart.component.js +12 -12
- package/esm2015/components/pie-chart/pie-chart.directive.js +3 -3
- package/esm2015/components/ring-chart/ring-chart.component.js +5 -5
- package/esm2015/types/line-type.js +1 -1
- package/esm2015/utils/describe-sector.js +2 -2
- package/esm2015/utils/line-length.js +2 -1
- package/esm5/components/arc-chart/arc-chart.component.js +13 -13
- package/esm5/components/axes/axes.component.js +9 -9
- package/esm5/components/bar/bar.component.js +4 -4
- package/esm5/components/bar-chart/bar-chart.component.js +6 -6
- package/esm5/components/bar-set/bar-set.component.js +4 -4
- package/esm5/components/legend-item/legend-item.component.js +10 -10
- package/esm5/components/line-chart/line-chart-hint.directive.js +5 -5
- package/esm5/components/line-chart/line-chart.component.js +9 -9
- package/esm5/components/line-days-chart/line-days-chart-hint.directive.js +5 -5
- package/esm5/components/line-days-chart/line-days-chart.component.js +9 -7
- package/esm5/components/pie-chart/pie-chart.component.js +12 -12
- package/esm5/components/pie-chart/pie-chart.directive.js +3 -3
- package/esm5/components/ring-chart/ring-chart.component.js +5 -5
- package/esm5/types/line-type.js +1 -1
- package/esm5/utils/describe-sector.js +2 -2
- package/esm5/utils/line-length.js +2 -1
- 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 +8 -8
- package/fesm2015/taiga-ui-addon-charts-components-axes.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-bar-chart.js +5 -5
- package/fesm2015/taiga-ui-addon-charts-components-bar-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-bar-set.js +3 -3
- package/fesm2015/taiga-ui-addon-charts-components-bar-set.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-bar.js +3 -3
- package/fesm2015/taiga-ui-addon-charts-components-bar.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-legend-item.js +9 -9
- package/fesm2015/taiga-ui-addon-charts-components-legend-item.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-line-chart.js +12 -12
- package/fesm2015/taiga-ui-addon-charts-components-line-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-line-days-chart.js +13 -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 +13 -13
- package/fesm2015/taiga-ui-addon-charts-components-pie-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-components-ring-chart.js +4 -4
- package/fesm2015/taiga-ui-addon-charts-components-ring-chart.js.map +1 -1
- package/fesm2015/taiga-ui-addon-charts-utils.js +2 -1
- package/fesm2015/taiga-ui-addon-charts-utils.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-arc-chart.js +12 -12
- package/fesm5/taiga-ui-addon-charts-components-arc-chart.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-axes.js +8 -8
- package/fesm5/taiga-ui-addon-charts-components-axes.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-bar-chart.js +5 -5
- package/fesm5/taiga-ui-addon-charts-components-bar-chart.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-bar-set.js +3 -3
- package/fesm5/taiga-ui-addon-charts-components-bar-set.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-bar.js +3 -3
- package/fesm5/taiga-ui-addon-charts-components-bar.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-legend-item.js +9 -9
- package/fesm5/taiga-ui-addon-charts-components-legend-item.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-line-chart.js +12 -12
- package/fesm5/taiga-ui-addon-charts-components-line-chart.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-line-days-chart.js +12 -10
- package/fesm5/taiga-ui-addon-charts-components-line-days-chart.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-pie-chart.js +13 -13
- package/fesm5/taiga-ui-addon-charts-components-pie-chart.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-components-ring-chart.js +4 -4
- package/fesm5/taiga-ui-addon-charts-components-ring-chart.js.map +1 -1
- package/fesm5/taiga-ui-addon-charts-utils.js +2 -1
- package/fesm5/taiga-ui-addon-charts-utils.js.map +1 -1
- package/package.json +3 -3
- package/types/line-type.d.ts +1 -1
|
@@ -6,11 +6,11 @@ import { tuiDefaultProp } from '@taiga-ui/cdk';
|
|
|
6
6
|
var TuiRingChartComponent = /** @class */ (function () {
|
|
7
7
|
function TuiRingChartComponent() {
|
|
8
8
|
this.value = [];
|
|
9
|
-
this.size =
|
|
9
|
+
this.size = 'm';
|
|
10
10
|
/** @deprecated */
|
|
11
11
|
this.colorHandler = TUI_DEFAULT_COLOR_HANDLER;
|
|
12
12
|
/** @deprecated */
|
|
13
|
-
this.content =
|
|
13
|
+
this.content = '';
|
|
14
14
|
this.masked = true;
|
|
15
15
|
this.activeItemIndex = NaN;
|
|
16
16
|
this.activeItemIndexChange = new EventEmitter();
|
|
@@ -31,7 +31,7 @@ var TuiRingChartComponent = /** @class */ (function () {
|
|
|
31
31
|
], TuiRingChartComponent.prototype, "value", void 0);
|
|
32
32
|
__decorate([
|
|
33
33
|
Input(),
|
|
34
|
-
HostBinding(
|
|
34
|
+
HostBinding('attr.data-size'),
|
|
35
35
|
tuiDefaultProp()
|
|
36
36
|
], TuiRingChartComponent.prototype, "size", void 0);
|
|
37
37
|
__decorate([
|
|
@@ -55,7 +55,7 @@ var TuiRingChartComponent = /** @class */ (function () {
|
|
|
55
55
|
], TuiRingChartComponent.prototype, "activeItemIndexChange", void 0);
|
|
56
56
|
TuiRingChartComponent = __decorate([
|
|
57
57
|
Component({
|
|
58
|
-
selector:
|
|
58
|
+
selector: 'tui-ring-chart',
|
|
59
59
|
template: "<div class=\"t-content\">\n <div\n *ngIf=\"content; else ngContent\"\n polymorpheus-outlet\n automation-id=\"tui-ring-chart__content\"\n class=\"t-wrapper\"\n [content]=\"content\"\n [context]=\"{$implicit: activeItemIndex, value: value}\"\n ></div>\n <ng-template #ngContent>\n <div class=\"t-wrapper\">\n <ng-content></ng-content>\n </div>\n </ng-template>\n</div>\n\n<tui-pie-chart\n [masked]=\"true\"\n [value]=\"value\"\n [colorHandler]=\"colorHandler\"\n [size]=\"size\"\n [activeItemIndex]=\"activeItemIndex\"\n (activeItemIndexChange)=\"onActiveItemIndexChange($event)\"\n></tui-pie-chart>\n\n<div class=\"t-shield\"></div>\n",
|
|
60
60
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
61
61
|
styles: [":host{position:relative;display:block}:host[data-size='s']{width:4rem;height:4rem}:host[data-size='m']{width:9rem;height:9rem}:host[data-size='l']{width:11rem;height:11rem}:host[data-size=xl]{width:16rem;height:16rem}.t-content{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;font:var(--tui-font-text-m);max-height:100%;flex-direction:column;justify-content:center;text-align:center;padding:1.5rem;border-radius:100%;box-sizing:border-box;overflow:hidden;word-break:break-word;white-space:pre-wrap;color:var(--tui-text-02)}:host[data-size='m'] .t-content{font:var(--tui-font-text-xs)}.t-wrapper:first-line{color:var(--tui-text-01)}:host[data-size='l'] .t-wrapper:first-line{font:var(--tui-font-text-l);font-weight:700}:host[data-size='m'] .t-wrapper:first-line{font:var(--tui-font-text-m);font-weight:700}.t-shield{position:absolute;top:25%;left:25%;right:25%;bottom:25%;border-radius:100%}"]
|
|
@@ -64,4 +64,4 @@ var TuiRingChartComponent = /** @class */ (function () {
|
|
|
64
64
|
return TuiRingChartComponent;
|
|
65
65
|
}());
|
|
66
66
|
export { TuiRingChartComponent };
|
|
67
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
67
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmluZy1jaGFydC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AdGFpZ2EtdWkvYWRkb24tY2hhcnRzL2NvbXBvbmVudHMvcmluZy1jaGFydC8iLCJzb3VyY2VzIjpbInJpbmctY2hhcnQuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQ0gsdUJBQXVCLEVBQ3ZCLFNBQVMsRUFDVCxZQUFZLEVBQ1osV0FBVyxFQUNYLEtBQUssRUFDTCxNQUFNLEdBQ1QsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sa0NBQWtDLENBQUM7QUFHM0UsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUk3Qyx1Q0FBdUM7QUFPdkM7SUFBQTtRQUdJLFVBQUssR0FBc0IsRUFBRSxDQUFDO1FBSzlCLFNBQUksR0FBeUIsR0FBRyxDQUFDO1FBRWpDLGtCQUFrQjtRQUdsQixpQkFBWSxHQUFvQix5QkFBeUIsQ0FBQztRQUUxRCxrQkFBa0I7UUFHbEIsWUFBTyxHQUE2QyxFQUFFLENBQUM7UUFJdkQsV0FBTSxHQUFHLElBQUksQ0FBQztRQUlkLG9CQUFlLEdBQUcsR0FBRyxDQUFDO1FBR2IsMEJBQXFCLEdBQUcsSUFBSSxZQUFZLEVBQVUsQ0FBQztJQWNoRSxDQUFDO0lBWkcsdURBQXVCLEdBQXZCLFVBQXdCLEtBQWE7UUFDakMsSUFBSSxDQUFDLHFCQUFxQixDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFTyxxREFBcUIsR0FBN0IsVUFBOEIsS0FBYTtRQUN2QyxJQUFJLEtBQUssS0FBSyxJQUFJLENBQUMsZUFBZSxFQUFFO1lBQ2hDLE9BQU87U0FDVjtRQUVELElBQUksQ0FBQyxlQUFlLEdBQUcsS0FBSyxDQUFDO1FBQzdCLElBQUksQ0FBQyxxQkFBcUIsQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQXZDRDtRQUZDLEtBQUssRUFBRTtRQUNQLGNBQWMsRUFBRTt3REFDYTtJQUs5QjtRQUhDLEtBQUssRUFBRTtRQUNQLFdBQVcsQ0FBQyxnQkFBZ0IsQ0FBQztRQUM3QixjQUFjLEVBQUU7dURBQ2dCO0lBS2pDO1FBRkMsS0FBSyxFQUFFO1FBQ1AsY0FBYyxFQUFFOytEQUN5QztJQUsxRDtRQUZDLEtBQUssRUFBRTtRQUNQLGNBQWMsRUFBRTswREFDc0M7SUFJdkQ7UUFGQyxLQUFLLEVBQUU7UUFDUCxjQUFjLEVBQUU7eURBQ0g7SUFJZDtRQUZDLEtBQUssRUFBRTtRQUNQLGNBQWMsRUFBRTtrRUFDSztJQUd0QjtRQURDLE1BQU0sRUFBRTt3RUFDbUQ7SUE3Qm5ELHFCQUFxQjtRQU5qQyxTQUFTLENBQUM7WUFDUCxRQUFRLEVBQUUsZ0JBQWdCO1lBQzFCLHN1QkFBeUM7WUFFekMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07O1NBQ2xELENBQUM7T0FDVyxxQkFBcUIsQ0EyQ2pDO0lBQUQsNEJBQUM7Q0FBQSxBQTNDRCxJQTJDQztTQTNDWSxxQkFBcUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICAgIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxuICAgIENvbXBvbmVudCxcbiAgICBFdmVudEVtaXR0ZXIsXG4gICAgSG9zdEJpbmRpbmcsXG4gICAgSW5wdXQsXG4gICAgT3V0cHV0LFxufSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7VFVJX0RFRkFVTFRfQ09MT1JfSEFORExFUn0gZnJvbSAnQHRhaWdhLXVpL2FkZG9uLWNoYXJ0cy9jb25zdGFudHMnO1xuaW1wb3J0IHtUdWlSaW5nQ2hhcnRDb250ZXh0fSBmcm9tICdAdGFpZ2EtdWkvYWRkb24tY2hhcnRzL2ludGVyZmFjZXMnO1xuaW1wb3J0IHtUdWlDb2xvckhhbmRsZXJ9IGZyb20gJ0B0YWlnYS11aS9hZGRvbi1jaGFydHMvdHlwZXMnO1xuaW1wb3J0IHt0dWlEZWZhdWx0UHJvcH0gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5pbXBvcnQge1R1aVNpemVTLCBUdWlTaXplWEx9IGZyb20gJ0B0YWlnYS11aS9jb3JlJztcbmltcG9ydCB7UG9seW1vcnBoZXVzQ29udGVudH0gZnJvbSAnQHRpbmtvZmYvbmctcG9seW1vcnBoZXVzJztcblxuLy8gVE9ETzogMy4wIFJlZmFjdG9yIHRvIHVzZSBuZy1jb250ZW50XG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogJ3R1aS1yaW5nLWNoYXJ0JyxcbiAgICB0ZW1wbGF0ZVVybDogJy4vcmluZy1jaGFydC50ZW1wbGF0ZS5odG1sJyxcbiAgICBzdHlsZVVybHM6IFsnLi9yaW5nLWNoYXJ0LnN0eWxlLmxlc3MnXSxcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgVHVpUmluZ0NoYXJ0Q29tcG9uZW50IHtcbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgdmFsdWU6IHJlYWRvbmx5IG51bWJlcltdID0gW107XG5cbiAgICBASW5wdXQoKVxuICAgIEBIb3N0QmluZGluZygnYXR0ci5kYXRhLXNpemUnKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgc2l6ZTogVHVpU2l6ZVMgfCBUdWlTaXplWEwgPSAnbSc7XG5cbiAgICAvKiogQGRlcHJlY2F0ZWQgKi9cbiAgICBASW5wdXQoKVxuICAgIEB0dWlEZWZhdWx0UHJvcCgpXG4gICAgY29sb3JIYW5kbGVyOiBUdWlDb2xvckhhbmRsZXIgPSBUVUlfREVGQVVMVF9DT0xPUl9IQU5ETEVSO1xuXG4gICAgLyoqIEBkZXByZWNhdGVkICovXG4gICAgQElucHV0KClcbiAgICBAdHVpRGVmYXVsdFByb3AoKVxuICAgIGNvbnRlbnQ6IFBvbHltb3JwaGV1c0NvbnRlbnQ8VHVpUmluZ0NoYXJ0Q29udGV4dD4gPSAnJztcblxuICAgIEBJbnB1dCgpXG4gICAgQHR1aURlZmF1bHRQcm9wKClcbiAgICBtYXNrZWQgPSB0cnVlO1xuXG4gICAgQElucHV0KClcbiAgICBAdHVpRGVmYXVsdFByb3AoKVxuICAgIGFjdGl2ZUl0ZW1JbmRleCA9IE5hTjtcblxuICAgIEBPdXRwdXQoKVxuICAgIHJlYWRvbmx5IGFjdGl2ZUl0ZW1JbmRleENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8bnVtYmVyPigpO1xuXG4gICAgb25BY3RpdmVJdGVtSW5kZXhDaGFuZ2UoaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICAgICB0aGlzLnVwZGF0ZUFjdGl2ZUl0ZW1JbmRleChpbmRleCk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSB1cGRhdGVBY3RpdmVJdGVtSW5kZXgoaW5kZXg6IG51bWJlcik6IHZvaWQge1xuICAgICAgICBpZiAoaW5kZXggPT09IHRoaXMuYWN0aXZlSXRlbUluZGV4KSB7XG4gICAgICAgICAgICByZXR1cm47XG4gICAgICAgIH1cblxuICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1JbmRleCA9IGluZGV4O1xuICAgICAgICB0aGlzLmFjdGl2ZUl0ZW1JbmRleENoYW5nZS5uZXh0KGluZGV4KTtcbiAgICB9XG59XG4iXX0=
|
package/esm5/types/line-type.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS10eXBlLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHRhaWdhLXVpL2FkZG9uLWNoYXJ0cy90eXBlcy8iLCJzb3VyY2VzIjpbImxpbmUtdHlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBOYXRpdmUgQ1NTIGJvcmRlci1zdHlsZSBvcHRpb25zXG4gKi9cbmV4cG9ydCB0eXBlIFR1aUxpbmVUeXBlVCA9ICdkYXNoZWQnIHwgJ2RvdHRlZCcgfCAnaGlkZGVuJyB8ICdub25lJyB8ICdzb2xpZCc7XG4iXX0=
|
|
@@ -30,7 +30,7 @@ export function describeSector(startAngle, endAngle) {
|
|
|
30
30
|
endY,
|
|
31
31
|
"L 0 0",
|
|
32
32
|
];
|
|
33
|
-
return isNaN(endX) ? EMPTY : result.join(" ");
|
|
33
|
+
return Number.isNaN(endX) ? EMPTY : result.join(" ");
|
|
34
34
|
}
|
|
35
35
|
export var tuiDescribeSector = describeSector;
|
|
36
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
36
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVzY3JpYmUtc2VjdG9yLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHRhaWdhLXVpL2FkZG9uLWNoYXJ0cy91dGlscy8iLCJzb3VyY2VzIjpbImRlc2NyaWJlLXNlY3Rvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsS0FBSyxFQUFFLFNBQVMsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUUvQyxJQUFNLEtBQUssR0FBRyxxQ0FBcUMsQ0FBQztBQUVwRDs7Ozs7Ozs7O0dBU0c7QUFDSCxnRUFBZ0U7QUFDaEUsTUFBTSxVQUFVLGNBQWMsQ0FBQyxVQUFrQixFQUFFLFFBQWdCO0lBQy9ELElBQU0sUUFBUSxHQUFHLFNBQVMsQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUN2QyxJQUFNLE1BQU0sR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDbkMsSUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsR0FBRyxHQUFHLENBQUM7SUFDeEMsSUFBTSxNQUFNLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxRQUFRLENBQUMsR0FBRyxHQUFHLENBQUM7SUFDeEMsSUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUM7SUFDcEMsSUFBTSxJQUFJLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENBQUMsR0FBRyxHQUFHLENBQUM7SUFDcEMsSUFBTSxZQUFZLEdBQUcsS0FBSyxDQUFDLFFBQVEsR0FBRyxVQUFVLEdBQUcsR0FBRyxDQUFDLENBQUM7SUFDeEQsSUFBTSxNQUFNLEdBQUc7UUFDWCxHQUFHO1FBQ0gsTUFBTTtRQUNOLE1BQU07UUFDTixhQUFhO1FBQ2IsWUFBWTtRQUNaLENBQUM7UUFDRCxJQUFJO1FBQ0osSUFBSTtRQUNKLE9BQU87S0FDVixDQUFDO0lBRUYsT0FBTyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7QUFDekQsQ0FBQztBQUVELE1BQU0sQ0FBQyxJQUFNLGlCQUFpQixHQUFHLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7dG9JbnQsIHRvUmFkaWFuc30gZnJvbSAnQHRhaWdhLXVpL2Nkayc7XG5cbmNvbnN0IEVNUFRZID0gYE0gMTAwIDAgQSAxMDAgMTAwIDAgMSAxIDEwMCAwIEwgMCAwYDtcblxuLyoqXG4gKiBAZGVwcmVjYXRlZDogdXNlIHtAbGluayB0dWlEZXNjcmliZVNlY3Rvcn0gaW5zdGVhZFxuICogRGVzY3JpYmVzIGEgbm9ybWFsaXplZCBzZWN0b3IgYnkgYW5nbGVzLiBOb3JtYWxpemVkIG1lYW5pbmcgaXQgc3VwcG9zZWQgdG8gd29yayB3aXRoXG4gKiBTVkcgd2l0aCB2aWV3Qm94PVwiLTEgLTEgMiAyXCIgc28gdGhhdCAwIGNvb3JkaW5hdGVzIGluIGNhcnRlc2lhbiBhbmQgcG9sYXIgbWF0Y2ggdGhlIHNhbWUgc3BvdC5cbiAqIEV2ZXJ5dGhpbmcgaXMgbXVsdGlwbGllZCBieSAxMDAgKGluY2x1ZGluZyB2aWV3Qm94IG9mIFNWRyB0byBob3N0IHRoaXMpIHNvIElFIHByb3Blcmx5XG4gKiBoYW5kbGVzIGhvdmVyIGV2ZW50cy5cbiAqXG4gKiBAcGFyYW0gc3RhcnRBbmdsZSBzdGFydGluZyBhbmdsZSBpbiBkZWdyZWVzXG4gKiBAcGFyYW0gZW5kQW5nbGUgZW5kaW5nIGFuZ2xlIGluIGRlZ3JlZXNcbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuZXhwb3J0IGZ1bmN0aW9uIGRlc2NyaWJlU2VjdG9yKHN0YXJ0QW5nbGU6IG51bWJlciwgZW5kQW5nbGU6IG51bWJlcik6IHN0cmluZyB7XG4gICAgY29uc3Qgc3RhcnRSYWQgPSB0b1JhZGlhbnMoc3RhcnRBbmdsZSk7XG4gICAgY29uc3QgZW5kUmFkID0gdG9SYWRpYW5zKGVuZEFuZ2xlKTtcbiAgICBjb25zdCBzdGFydFggPSBNYXRoLmNvcyhzdGFydFJhZCkgKiAxMDA7XG4gICAgY29uc3Qgc3RhcnRZID0gTWF0aC5zaW4oc3RhcnRSYWQpICogMTAwO1xuICAgIGNvbnN0IGVuZFggPSBNYXRoLmNvcyhlbmRSYWQpICogMTAwO1xuICAgIGNvbnN0IGVuZFkgPSBNYXRoLnNpbihlbmRSYWQpICogMTAwO1xuICAgIGNvbnN0IGxhcmdlQXJjRmxhZyA9IHRvSW50KGVuZEFuZ2xlIC0gc3RhcnRBbmdsZSA+IDE4MCk7XG4gICAgY29uc3QgcmVzdWx0ID0gW1xuICAgICAgICBgTWAsXG4gICAgICAgIHN0YXJ0WCxcbiAgICAgICAgc3RhcnRZLFxuICAgICAgICBgQSAxMDAgMTAwIDBgLFxuICAgICAgICBsYXJnZUFyY0ZsYWcsXG4gICAgICAgIDEsXG4gICAgICAgIGVuZFgsXG4gICAgICAgIGVuZFksXG4gICAgICAgIGBMIDAgMGAsXG4gICAgXTtcblxuICAgIHJldHVybiBOdW1iZXIuaXNOYU4oZW5kWCkgPyBFTVBUWSA6IHJlc3VsdC5qb2luKGAgYCk7XG59XG5cbmV4cG9ydCBjb25zdCB0dWlEZXNjcmliZVNlY3RvciA9IGRlc2NyaWJlU2VjdG9yO1xuIl19
|
|
@@ -5,7 +5,8 @@
|
|
|
5
5
|
export function lineLength(a, b) {
|
|
6
6
|
var x = b[0] - a[0];
|
|
7
7
|
var y = b[1] - a[1];
|
|
8
|
+
// eslint-disable-next-line no-restricted-properties
|
|
8
9
|
return Math.sqrt(Math.pow(x, 2) + Math.pow(y, 2));
|
|
9
10
|
}
|
|
10
11
|
export var tuiLineLength = lineLength;
|
|
11
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
12
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGluZS1sZW5ndGguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9AdGFpZ2EtdWkvYWRkb24tY2hhcnRzL3V0aWxzLyIsInNvdXJjZXMiOlsibGluZS1sZW5ndGgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUE7O0dBRUc7QUFDSCxnRUFBZ0U7QUFDaEUsTUFBTSxVQUFVLFVBQVUsQ0FBQyxDQUFXLEVBQUUsQ0FBVztJQUMvQyxJQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3RCLElBQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7SUFFdEIsb0RBQW9EO0lBQ3BELE9BQU8sSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDO0FBQ3RELENBQUM7QUFFRCxNQUFNLENBQUMsSUFBTSxhQUFhLEdBQUcsVUFBVSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtUdWlQb2ludH0gZnJvbSAnQHRhaWdhLXVpL2NvcmUnO1xuXG4vKipcbiAqIEBkZXByZWNhdGVkOiB1c2Uge0BsaW5rIHR1aUxpbmVMZW5ndGh9IGluc3RlYWRcbiAqL1xuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuZXhwb3J0IGZ1bmN0aW9uIGxpbmVMZW5ndGgoYTogVHVpUG9pbnQsIGI6IFR1aVBvaW50KTogbnVtYmVyIHtcbiAgICBjb25zdCB4ID0gYlswXSAtIGFbMF07XG4gICAgY29uc3QgeSA9IGJbMV0gLSBhWzFdO1xuXG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXJlc3RyaWN0ZWQtcHJvcGVydGllc1xuICAgIHJldHVybiBNYXRoLnNxcnQoTWF0aC5wb3coeCwgMikgKyBNYXRoLnBvdyh5LCAyKSk7XG59XG5cbmV4cG9ydCBjb25zdCB0dWlMaW5lTGVuZ3RoID0gbGluZUxlbmd0aDtcbiJdfQ==
|
|
@@ -27,10 +27,10 @@ let TuiArcChartComponent = class TuiArcChartComponent {
|
|
|
27
27
|
this.sanitizer = sanitizer;
|
|
28
28
|
this.arcs$ = new ReplaySubject(1);
|
|
29
29
|
this.value = [];
|
|
30
|
-
this.size =
|
|
30
|
+
this.size = 'm';
|
|
31
31
|
this.max = 100;
|
|
32
|
-
this.minLabel =
|
|
33
|
-
this.maxLabel =
|
|
32
|
+
this.minLabel = '0%';
|
|
33
|
+
this.maxLabel = '100%';
|
|
34
34
|
this.activeItemIndex = NaN;
|
|
35
35
|
this.activeItemIndexChange = this.arcs$.pipe(switchMap(arcs => arcs.changes.pipe(startWith(null), switchMap(() => merge(...arcsToIndex(arcs))))), tap(index => {
|
|
36
36
|
this.activeItemIndex = index;
|
|
@@ -52,7 +52,7 @@ let TuiArcChartComponent = class TuiArcChartComponent {
|
|
|
52
52
|
return WIDTH[this.size];
|
|
53
53
|
}
|
|
54
54
|
isInactive(index) {
|
|
55
|
-
return !isNaN(this.activeItemIndex) && index !== this.activeItemIndex;
|
|
55
|
+
return !Number.isNaN(this.activeItemIndex) && index !== this.activeItemIndex;
|
|
56
56
|
}
|
|
57
57
|
getInset(index) {
|
|
58
58
|
return this.strokeWidth / 2 + index * (this.strokeWidth + GAP[this.size]);
|
|
@@ -75,7 +75,7 @@ TuiArcChartComponent.ctorParameters = () => [
|
|
|
75
75
|
{ type: ChangeDetectorRef, decorators: [{ type: Inject, args: [ChangeDetectorRef,] }] }
|
|
76
76
|
];
|
|
77
77
|
__decorate([
|
|
78
|
-
ViewChildren(
|
|
78
|
+
ViewChildren('arc')
|
|
79
79
|
], TuiArcChartComponent.prototype, "arcs", null);
|
|
80
80
|
__decorate([
|
|
81
81
|
Input(),
|
|
@@ -83,7 +83,7 @@ __decorate([
|
|
|
83
83
|
], TuiArcChartComponent.prototype, "value", void 0);
|
|
84
84
|
__decorate([
|
|
85
85
|
Input(),
|
|
86
|
-
HostBinding(
|
|
86
|
+
HostBinding('attr.data-size'),
|
|
87
87
|
tuiDefaultProp()
|
|
88
88
|
], TuiArcChartComponent.prototype, "size", void 0);
|
|
89
89
|
__decorate([
|
|
@@ -106,16 +106,16 @@ __decorate([
|
|
|
106
106
|
Output()
|
|
107
107
|
], TuiArcChartComponent.prototype, "activeItemIndexChange", void 0);
|
|
108
108
|
__decorate([
|
|
109
|
-
HostBinding(
|
|
110
|
-
HostBinding(
|
|
109
|
+
HostBinding('style.width.rem'),
|
|
110
|
+
HostBinding('style.height.rem')
|
|
111
111
|
], TuiArcChartComponent.prototype, "width", null);
|
|
112
112
|
__decorate([
|
|
113
|
-
HostBinding(
|
|
113
|
+
HostBinding('style.strokeWidth.rem')
|
|
114
114
|
], TuiArcChartComponent.prototype, "strokeWidth", null);
|
|
115
115
|
TuiArcChartComponent = __decorate([
|
|
116
116
|
Component({
|
|
117
|
-
selector:
|
|
118
|
-
template: "<svg\n *tuiRepeatTimes=\"let index of value.length\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"-100 -100 200 200\"\n focusable=\"false\"\n class=\"t-svg\"\n [style.top.em]=\"getInset(index)\"\n [style.left.em]=\"getInset(index)\"\n [style.width.em]=\"getDiameter(index)\"\n [style.height.em]=\"getDiameter(index)\"\n>\n <path\n vector-effect=\"non-scaling-stroke\"\n d=\"M -70 70 A 100 100 0 1 1 70 70\"\n />\n <path\n #arc\n vector-effect=\"non-scaling-stroke\"\n d=\"M -70 70 A 100 100 0 1 1 70 70\"\n class=\"t-value\"\n [class.t-value_inactive]=\"isInactive(index)\"\n [style.stroke]=\"getColor(index)\"\n [style.strokeDasharray.em]=\"getLength(index)\"\n [style.strokeDashoffset.em]=\"initialized ? getOffset(index) : getLength(index)\"\n />\n</svg>\n<div class=\"t-content\">\n <div class=\"t-wrapper\"
|
|
117
|
+
selector: 'tui-arc-chart',
|
|
118
|
+
template: "<svg\n *tuiRepeatTimes=\"let index of value.length\"\n xmlns=\"http://www.w3.org/2000/svg\"\n viewBox=\"-100 -100 200 200\"\n focusable=\"false\"\n class=\"t-svg\"\n [style.top.em]=\"getInset(index)\"\n [style.left.em]=\"getInset(index)\"\n [style.width.em]=\"getDiameter(index)\"\n [style.height.em]=\"getDiameter(index)\"\n>\n <path\n vector-effect=\"non-scaling-stroke\"\n d=\"M -70 70 A 100 100 0 1 1 70 70\"\n />\n <path\n #arc\n vector-effect=\"non-scaling-stroke\"\n d=\"M -70 70 A 100 100 0 1 1 70 70\"\n class=\"t-value\"\n [class.t-value_inactive]=\"isInactive(index)\"\n [style.stroke]=\"getColor(index)\"\n [style.strokeDasharray.em]=\"getLength(index)\"\n [style.strokeDashoffset.em]=\"initialized ? getOffset(index) : getLength(index)\"\n />\n</svg>\n<div class=\"t-content\">\n <div class=\"t-wrapper\">\n <ng-content></ng-content>\n </div>\n</div>\n<div class=\"t-percent\">\n <span>{{ minLabel }}</span>\n <span>{{ maxLabel }}</span>\n</div>\n",
|
|
119
119
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
120
120
|
styles: [":host{position:relative;display:block;flex-shrink:0}.t-svg{position:absolute;top:0;left:0;bottom:0;right:0;overflow:visible;fill:none;stroke:currentColor;stroke-linecap:round;color:var(--tui-secondary);font-size:1rem;pointer-events:none}.t-value{pointer-events:auto;transition:stroke-dashoffset var(--tui-duration) ease-in-out,opacity var(--tui-duration) ease-in-out .1s}.t-value_inactive{transition-property:stroke-dashoffset,opacity;transition-duration:var(--tui-duration,300ms);transition-timing-function:ease-in-out;opacity:.16}.t-content{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;justify-content:center;align-items:center;text-align:center;color:var(--tui-text-02);font:var(--tui-font-text-xs);pointer-events:none}:host[data-size=xl] .t-content{font:var(--tui-font-text-m)}.t-wrapper{pointer-events:auto}.t-wrapper:first-line{color:var(--tui-text-01)}:host[data-size='m'] .t-wrapper:first-line{font:var(--tui-font-text-s);font-weight:700}:host[data-size='l'] .t-wrapper:first-line{font:var(--tui-font-text-m);font-weight:700}:host[data-size=xl] .t-wrapper:first-line{font:var(--tui-font-heading-5)}.t-percent{position:absolute;left:25%;bottom:11%;display:flex;width:50%;justify-content:space-between;font:var(--tui-font-text-xs);color:var(--tui-text-02)}:host[data-size=xl] .t-percent{font:var(--tui-font-text-m)}"]
|
|
121
121
|
}),
|
|
@@ -125,7 +125,7 @@ TuiArcChartComponent = __decorate([
|
|
|
125
125
|
function arcsToIndex(arcs) {
|
|
126
126
|
return arcs
|
|
127
127
|
.toArray()
|
|
128
|
-
.map(({ nativeElement }, index) => merge(typedFromEvent(nativeElement,
|
|
128
|
+
.map(({ nativeElement }, index) => merge(typedFromEvent(nativeElement, 'mouseenter').pipe(mapTo(index)), typedFromEvent(nativeElement, 'mouseleave').pipe(mapTo(NaN))));
|
|
129
129
|
}
|
|
130
130
|
|
|
131
131
|
let TuiArcChartModule = class TuiArcChartModule {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-charts-components-arc-chart.js","sources":["ng://@taiga-ui/addon-charts/components/arc-chart/arc-chart.component.ts","ng://@taiga-ui/addon-charts/components/arc-chart/arc-chart.module.ts","ng://@taiga-ui/addon-charts/components/arc-chart/taiga-ui-addon-charts-components-arc-chart.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n ChangeDetectorRef,\n Component,\n ElementRef,\n HostBinding,\n Inject,\n Input,\n Output,\n QueryList,\n ViewChildren,\n} from '@angular/core';\nimport {DomSanitizer, SafeValue} from '@angular/platform-browser';\nimport {tuiDefaultProp, typedFromEvent} from '@taiga-ui/cdk';\nimport {TuiSizeXL} from '@taiga-ui/core';\nimport {merge, Observable, ReplaySubject} from 'rxjs';\nimport {mapTo, startWith, switchMap, tap} from 'rxjs/operators';\n\n// 3/4 with 1% safety offset\nconst ARC = 0.76;\n\nconst SIZE: Record<TuiSizeXL, number> = {\n m: 9,\n l: 11,\n xl: 16,\n};\n\nconst WIDTH: Record<TuiSizeXL, number> = {\n m: 0.25,\n l: 0.375,\n xl: 0.5625,\n};\n\nconst GAP: Record<TuiSizeXL, number> = {\n m: 0.125,\n l: 0.1875,\n xl: 0.25,\n};\n\n@Component({\n selector:
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-charts-components-arc-chart.js","sources":["ng://@taiga-ui/addon-charts/components/arc-chart/arc-chart.component.ts","ng://@taiga-ui/addon-charts/components/arc-chart/arc-chart.module.ts","ng://@taiga-ui/addon-charts/components/arc-chart/taiga-ui-addon-charts-components-arc-chart.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n ChangeDetectorRef,\n Component,\n ElementRef,\n HostBinding,\n Inject,\n Input,\n Output,\n QueryList,\n ViewChildren,\n} from '@angular/core';\nimport {DomSanitizer, SafeValue} from '@angular/platform-browser';\nimport {tuiDefaultProp, typedFromEvent} from '@taiga-ui/cdk';\nimport {TuiSizeXL} from '@taiga-ui/core';\nimport {merge, Observable, ReplaySubject} from 'rxjs';\nimport {mapTo, startWith, switchMap, tap} from 'rxjs/operators';\n\n// 3/4 with 1% safety offset\nconst ARC = 0.76;\n\nconst SIZE: Record<TuiSizeXL, number> = {\n m: 9,\n l: 11,\n xl: 16,\n};\n\nconst WIDTH: Record<TuiSizeXL, number> = {\n m: 0.25,\n l: 0.375,\n xl: 0.5625,\n};\n\nconst GAP: Record<TuiSizeXL, number> = {\n m: 0.125,\n l: 0.1875,\n xl: 0.25,\n};\n\n@Component({\n selector: 'tui-arc-chart',\n templateUrl: './arc-chart.template.html',\n styleUrls: ['./arc-chart.style.less'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiArcChartComponent {\n private readonly arcs$ = new ReplaySubject<QueryList<ElementRef<SVGElement>>>(1);\n\n @ViewChildren('arc')\n set arcs(arcs: QueryList<ElementRef<SVGElement>>) {\n this.arcs$.next(arcs);\n }\n\n @Input()\n @tuiDefaultProp()\n value: readonly number[] = [];\n\n @Input()\n @HostBinding('attr.data-size')\n @tuiDefaultProp()\n size: TuiSizeXL = 'm';\n\n @Input()\n @tuiDefaultProp()\n max = 100;\n\n @Input()\n @tuiDefaultProp()\n minLabel = '0%';\n\n @Input()\n @tuiDefaultProp()\n maxLabel = '100%';\n\n @Input()\n @tuiDefaultProp()\n activeItemIndex = NaN;\n\n @Output()\n readonly activeItemIndexChange = this.arcs$.pipe(\n switchMap(arcs =>\n arcs.changes.pipe(\n startWith(null),\n switchMap(() => merge(...arcsToIndex(arcs))),\n ),\n ),\n tap(index => {\n this.activeItemIndex = index;\n }),\n );\n\n initialized = false;\n\n constructor(\n @Inject(DomSanitizer) private readonly sanitizer: DomSanitizer,\n @Inject(ChangeDetectorRef) changeDetectorRef: ChangeDetectorRef,\n ) {\n // So initial animation works\n setTimeout(() => {\n this.initialized = true;\n changeDetectorRef.markForCheck();\n });\n }\n\n @HostBinding('style.width.rem')\n @HostBinding('style.height.rem')\n get width(): number {\n return SIZE[this.size];\n }\n\n @HostBinding('style.strokeWidth.rem')\n get strokeWidth(): number {\n return WIDTH[this.size];\n }\n\n isInactive(index: number): boolean {\n return !Number.isNaN(this.activeItemIndex) && index !== this.activeItemIndex;\n }\n\n getInset(index: number): number {\n return this.strokeWidth / 2 + index * (this.strokeWidth + GAP[this.size]);\n }\n\n getDiameter(index: number): number {\n return SIZE[this.size] - 2 * this.getInset(index);\n }\n\n getLength(index: number): number {\n return Math.PI * this.getDiameter(index) * ARC;\n }\n\n getOffset(index: number): number {\n return this.getLength(index) * (1 - Math.min(this.value[index] / this.max, 1));\n }\n\n getColor(index: number): SafeValue {\n return this.sanitizer.bypassSecurityTrustStyle(\n `var(--tui-chart-${index}, var(--tui-support-0${index + 1}))`,\n );\n }\n}\n\nfunction arcsToIndex(arcs: QueryList<ElementRef<SVGElement>>): Array<Observable<number>> {\n return arcs\n .toArray()\n .map(({nativeElement}, index) =>\n merge(\n typedFromEvent(nativeElement, 'mouseenter').pipe(mapTo(index)),\n typedFromEvent(nativeElement, 'mouseleave').pipe(mapTo(NaN)),\n ),\n );\n}\n","import {NgModule} from '@angular/core';\nimport {TuiRepeatTimesModule} from '@taiga-ui/cdk';\n\nimport {TuiArcChartComponent} from './arc-chart.component';\n\n@NgModule({\n imports: [TuiRepeatTimesModule],\n declarations: [TuiArcChartComponent],\n exports: [TuiArcChartComponent],\n})\nexport class TuiArcChartModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -10,22 +10,22 @@ import { CommonModule } from '@angular/common';
|
|
|
10
10
|
let TuiAxesComponent = 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;
|
|
@@ -97,16 +97,16 @@ __decorate([
|
|
|
97
97
|
tuiDefaultProp()
|
|
98
98
|
], TuiAxesComponent.prototype, "verticalLinesHandler", void 0);
|
|
99
99
|
__decorate([
|
|
100
|
-
HostBinding(
|
|
100
|
+
HostBinding('class._centered')
|
|
101
101
|
], TuiAxesComponent.prototype, "centeredXLabels", null);
|
|
102
102
|
TuiAxesComponent = __decorate([
|
|
103
103
|
Component({
|
|
104
|
-
selector:
|
|
104
|
+
selector: 'tui-axes',
|
|
105
105
|
template: "<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",
|
|
106
106
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
107
107
|
providers: [MODE_PROVIDER],
|
|
108
108
|
host: {
|
|
109
|
-
'($.data-mode.attr)':
|
|
109
|
+
'($.data-mode.attr)': 'mode$',
|
|
110
110
|
},
|
|
111
111
|
styles: [":host{display:flex}.t-wrapper{display:flex;flex:1;height:100%;flex-direction:column}.t-grid{position:relative;z-index:0;display:flex;flex:1;justify-content:space-around;align-items:flex-end;border-width:1px;border-color:var(--tui-base-03)}:host[data-mode=onDark] .t-grid{border-color:rgba(255,255,255,.48)}:host[data-mode=onLight] .t-grid{border-color:rgba(0,0,0,.48)}.t-horizontal{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;flex-direction:column}.t-vertical{position:absolute;top:0;left:0;width:100%;height:100%;display:flex}:host._centered .t-vertical:after{content:'';display:block;flex:1 0 1px}.t-line{flex:2 0 1px;box-sizing:border-box;border-width:1px;border-color:var(--tui-base-03)}:host[data-mode=onDark] .t-line{border-color:rgba(255,255,255,.48)}:host[data-mode=onLight] .t-line{border-color:rgba(0,0,0,.48)}:host._centered .t-line_vertical:first-child{flex:1 0 1px;pointer-events:none}.t-side{display:flex;align-items:stretch}.t-side_padding{padding-bottom:2rem}.t-name{font:var(--tui-font-text-xs);-webkit-writing-mode:tb;writing-mode:tb;text-align:center;padding-left:.75rem;color:var(--tui-text-02)}.t-name_primary{transform:rotate(180deg)}:host[data-mode=onDark] .t-name{color:var(--tui-text-02-night)}.t-labels-y{display:flex;font:var(--tui-font-text-xs);flex-direction:column-reverse;justify-content:space-between;color:var(--tui-text-02)}:host[data-mode=onDark] .t-labels-y{color:var(--tui-text-02-night)}.t-labels-y_primary{text-align:right;padding-right:.75rem}.t-labels-y_secondary{padding-left:.75rem}.t-labels-y_transparent{border-color:transparent}.t-labels-y_inset{position:absolute;top:.5625rem;left:.25rem;bottom:-.75rem;pointer-events:none}.t-labels-y_inset_secondary{left:auto;right:.25rem;text-align:right}.t-labels-x{display:flex;font:var(--tui-font-text-xs);border-right:1px solid transparent;color:var(--tui-text-02)}.t-label-x{height:.4375rem;border-left:1px solid var(--tui-base-03);flex:1;margin-bottom:1.5625rem}:host[data-mode=onDark] .t-label-x{border-color:rgba(255,255,255,.48)}:host[data-mode=onLight] .t-label-x{border-color:rgba(0,0,0,.48)}.t-label-x:before{content:'';display:block;height:.5625rem}.t-label-x_transparent{border-color:transparent}:host._centered .t-label-x{height:2rem;text-align:center;border:none;margin:0}.t-label-y:first-child{margin-bottom:-.375rem}.t-label-y:last-child{margin-top:-.375rem}.t-content{position:absolute;top:0;left:-1px;right:0;bottom:-1px;display:flex;align-items:flex-end}"]
|
|
112
112
|
}),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-charts-components-axes.js","sources":["ng://@taiga-ui/addon-charts/components/axes/axes.component.ts","ng://@taiga-ui/addon-charts/components/axes/axes.module.ts","ng://@taiga-ui/addon-charts/components/axes/taiga-ui-addon-charts-components-axes.ts"],"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, TuiLineTypeT} from '@taiga-ui/addon-charts/types';\nimport {CHAR_NO_BREAK_SPACE, tuiDefaultProp} from '@taiga-ui/cdk';\nimport {MODE_PROVIDER} from '@taiga-ui/core/providers';\nimport {TUI_MODE} from '@taiga-ui/core/tokens';\nimport {TuiBrightness} from '@taiga-ui/core/types';\nimport {Observable} from 'rxjs';\n\n@Component({\n selector:
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-charts-components-axes.js","sources":["ng://@taiga-ui/addon-charts/components/axes/axes.component.ts","ng://@taiga-ui/addon-charts/components/axes/axes.module.ts","ng://@taiga-ui/addon-charts/components/axes/taiga-ui-addon-charts-components-axes.ts"],"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, TuiLineTypeT} from '@taiga-ui/addon-charts/types';\nimport {CHAR_NO_BREAK_SPACE, tuiDefaultProp} from '@taiga-ui/cdk';\nimport {MODE_PROVIDER} from '@taiga-ui/core/providers';\nimport {TUI_MODE} from '@taiga-ui/core/tokens';\nimport {TuiBrightness} from '@taiga-ui/core/types';\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: TuiLineTypeT = 'solid';\n\n @Input()\n @tuiDefaultProp()\n axisXLabels: ReadonlyArray<string | null> = [];\n\n @Input()\n @tuiDefaultProp()\n axisY: TuiLineTypeT = '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","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\nimport {TuiRepeatTimesModule} from '@taiga-ui/cdk';\n\nimport {TuiAxesComponent} from './axes.component';\n\n@NgModule({\n imports: [CommonModule, TuiRepeatTimesModule],\n declarations: [TuiAxesComponent],\n exports: [TuiAxesComponent],\n})\nexport class TuiAxesModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;IAyBa,gBAAgB,GAA7B,MAAa,gBAAgB;IA0DzB,YAAuC,KAAuC;QAAvC,UAAK,GAAL,KAAK,CAAkC;QAvD9E,UAAK,GAAiB,OAAO,CAAC;QAI9B,gBAAW,GAAiC,EAAE,CAAC;QAI/C,UAAK,GAAiB,OAAO,CAAC;QAI9B,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;KAOyB;IAJlF,IAAI,eAAe;QACf,OAAO,IAAI,CAAC,KAAK,KAAK,MAAM,CAAC;KAChC;IAID,IAAI,UAAU;QACV,OAAO,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC;KACpC;IAED,IAAI,UAAU;QACV,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,UAAU,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC;KAC9E;IAED,IAAI,mBAAmB;QACnB,QACI,CAAC,CAAC,CAAC,IAAI,CAAC,oBAAoB,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,mBAAmB;YAChE,CAAC,CAAC,IAAI,CAAC,kBAAkB,EAC3B;KACL;IAED,QAAQ,CAAC,KAAoB;QACzB,OAAO,KAAK,IAAI,mBAAmB,CAAC;KACvC;EACJ;;YApBiD,UAAU,uBAA3C,MAAM,SAAC,QAAQ;;AAvD5B;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;+CACa;AAI9B;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;qDAC8B;AAI/C;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;+CACa;AAI9B;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;oDACE;AAInB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;qDACmB;AAIpC;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;mDACF;AAIf;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;6DACW;AAI5B;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;8DAC4B;AAI7C;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;4DACO;AAIxB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;yDACG;AAIpB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;gEACyC;AAI1D;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;uDACC;AAIlB;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;8DACwC;AAGzD;IADC,WAAW,CAAC,iBAAiB,CAAC;uDAG9B;AAxDQ,gBAAgB;IAV5B,SAAS,CAAC;QACP,QAAQ,EAAE,UAAU;QACpB,wzGAAmC;QAEnC,eAAe,EAAE,uBAAuB,CAAC,MAAM;QAC/C,SAAS,EAAE,CAAC,aAAa,CAAC;QAC1B,IAAI,EAAE;YACF,oBAAoB,EAAE,OAAO;SAChC;;KACJ,CAAC;IA2De,WAAA,MAAM,CAAC,QAAQ,CAAC,CAAA;GA1DpB,gBAAgB,CA8E5B;;IC5FY,aAAa,GAA1B,MAAa,aAAa;EAAG;AAAhB,aAAa;IALzB,QAAQ,CAAC;QACN,OAAO,EAAE,CAAC,YAAY,EAAE,oBAAoB,CAAC;QAC7C,YAAY,EAAE,CAAC,gBAAgB,CAAC;QAChC,OAAO,EAAE,CAAC,gBAAgB,CAAC;KAC9B,CAAC;GACW,aAAa,CAAG;;ACX7B;;;;;;"}
|
|
@@ -12,15 +12,15 @@ function valueAssertion(value) {
|
|
|
12
12
|
const valid = value.every(array => array.length === value[0].length);
|
|
13
13
|
return valid;
|
|
14
14
|
}
|
|
15
|
-
const VALUE_ERROR =
|
|
15
|
+
const VALUE_ERROR = 'All arrays must be of the same length';
|
|
16
16
|
let TuiBarChartComponent = class TuiBarChartComponent {
|
|
17
17
|
constructor(idService) {
|
|
18
18
|
this.value = [];
|
|
19
19
|
this.max = NaN;
|
|
20
20
|
this.colorHandler = TUI_DEFAULT_COLOR_HANDLER;
|
|
21
|
-
this.size =
|
|
21
|
+
this.size = 'm';
|
|
22
22
|
this.collapsed = false;
|
|
23
|
-
this.hintContent =
|
|
23
|
+
this.hintContent = '';
|
|
24
24
|
this.hintMode = null;
|
|
25
25
|
this.percentMapper = (set, collapsed, max) => (100 * (collapsed ? sum(...set) : Math.max(...set))) / max;
|
|
26
26
|
this.autoIdString = idService.generate();
|
|
@@ -40,7 +40,7 @@ let TuiBarChartComponent = class TuiBarChartComponent {
|
|
|
40
40
|
};
|
|
41
41
|
}
|
|
42
42
|
getHint(hint) {
|
|
43
|
-
return this.hasHint ? hint :
|
|
43
|
+
return this.hasHint ? hint : '';
|
|
44
44
|
}
|
|
45
45
|
getHintId(index) {
|
|
46
46
|
return `${this.autoIdString}_${index}`;
|
|
@@ -96,7 +96,7 @@ __decorate([
|
|
|
96
96
|
], TuiBarChartComponent.prototype, "getMax", null);
|
|
97
97
|
TuiBarChartComponent = __decorate([
|
|
98
98
|
Component({
|
|
99
|
-
selector:
|
|
99
|
+
selector: 'tui-bar-chart',
|
|
100
100
|
template: "<div\n *ngFor=\"let set of transposed; let index = index\"\n tuiHintDirection=\"top-left\"\n class=\"t-wrapper\"\n [class.t-wrapper_hoverable]=\"hasHint\"\n [tuiHintHost]=\"hintHost\"\n [tuiHintId]=\"getHintId(index)\"\n [tuiHint]=\"getHint(hint)\"\n [tuiHintMode]=\"hintMode\"\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 [tuiDescribedBy]=\"getHintId(index)\"\n [tuiFocusable]=\"hasHint\"\n [value]=\"set\"\n [size]=\"size\"\n [collapsed]=\"collapsed\"\n [colorHandler]=\"colorHandler\"\n ></tui-bar-set>\n </div>\n <ng-template\n #hint=\"polymorpheus\"\n polymorpheus\n >\n <div\n polymorpheus-outlet\n class=\"t-text\"\n [content]=\"hintContent\"\n [context]=\"getContentContext(index)\"\n ></div>\n </ng-template>\n</div>\n",
|
|
101
101
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
102
102
|
styles: [":host{display:flex;flex:1;height:100%}.t-wrapper{transition-property:background-color;transition-duration:var(--tui-duration,300ms);transition-timing-function:ease-in-out;position:relative;display:flex;flex:1;align-items:flex-end;justify-content:center;height:100%}.t-wrapper_hoverable._hint_hovered{background-color:rgba(0,0,0,.05);cursor:pointer}.t-container{flex:1}.t-host{position:absolute;left:50%;right:50%}.t-set{border-radius:var(--tui-radius-m);pointer-events:none;outline:0}.t-set:focus{box-shadow:0 0 0 2px var(--tui-focus)}.t-text{white-space:pre-wrap}"]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-charts-components-bar-chart.js","sources":["ng://@taiga-ui/addon-charts/components/bar-chart/bar-chart.component.ts","ng://@taiga-ui/addon-charts/components/bar-chart/bar-chart.module.ts","ng://@taiga-ui/addon-charts/components/bar-chart/taiga-ui-addon-charts-components-bar-chart.ts"],"sourcesContent":["import {ChangeDetectionStrategy, Component, Inject, Input} from '@angular/core';\nimport {TUI_DEFAULT_COLOR_HANDLER} from '@taiga-ui/addon-charts/constants';\nimport {TuiColorHandler} from '@taiga-ui/addon-charts/types';\nimport {\n sum,\n TuiContextWithImplicit,\n tuiDefaultProp,\n TuiIdService,\n TuiMapper,\n tuiPure,\n} from '@taiga-ui/cdk';\nimport {TuiHintModeT, TuiSizeL, TuiSizeS} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function 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 =
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-charts-components-bar-chart.js","sources":["ng://@taiga-ui/addon-charts/components/bar-chart/bar-chart.component.ts","ng://@taiga-ui/addon-charts/components/bar-chart/bar-chart.module.ts","ng://@taiga-ui/addon-charts/components/bar-chart/taiga-ui-addon-charts-components-bar-chart.ts"],"sourcesContent":["import {ChangeDetectionStrategy, Component, Inject, Input} from '@angular/core';\nimport {TUI_DEFAULT_COLOR_HANDLER} from '@taiga-ui/addon-charts/constants';\nimport {TuiColorHandler} from '@taiga-ui/addon-charts/types';\nimport {\n sum,\n TuiContextWithImplicit,\n tuiDefaultProp,\n TuiIdService,\n TuiMapper,\n tuiPure,\n} from '@taiga-ui/cdk';\nimport {TuiHintModeT, TuiSizeL, TuiSizeS} from '@taiga-ui/core';\nimport {PolymorpheusContent} from '@tinkoff/ng-polymorpheus';\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport function 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})\nexport class TuiBarChartComponent {\n private readonly autoIdString: string;\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 colorHandler: TuiColorHandler = TUI_DEFAULT_COLOR_HANDLER;\n\n @Input()\n @tuiDefaultProp()\n size: TuiSizeL | TuiSizeS | null = 'm';\n\n @Input()\n @tuiDefaultProp()\n collapsed = false;\n\n @Input()\n @tuiDefaultProp()\n hintContent: PolymorpheusContent<TuiContextWithImplicit<number>> = '';\n\n @Input()\n @tuiDefaultProp()\n hintMode: TuiHintModeT | null = null;\n\n constructor(@Inject(TuiIdService) idService: TuiIdService) {\n this.autoIdString = idService.generate();\n }\n\n get hasHint(): boolean {\n return !!this.hintContent;\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 @tuiPure\n getContentContext(index: number): TuiContextWithImplicit<number> {\n return {\n $implicit: index,\n };\n }\n\n readonly percentMapper: TuiMapper<readonly number[], number> = (\n set,\n collapsed: boolean,\n max: number,\n ) => (100 * (collapsed ? sum(...set) : Math.max(...set))) / max;\n\n getHint(hint: PolymorpheusContent): PolymorpheusContent {\n return this.hasHint ? hint : '';\n }\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","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\nimport {TuiBarSetModule} from '@taiga-ui/addon-charts/components/bar-set';\nimport {TuiFocusableModule, TuiMapperPipeModule} from '@taiga-ui/cdk';\nimport {TuiDescribedByModule, TuiHintModule} from '@taiga-ui/core';\nimport {PolymorpheusModule} from '@tinkoff/ng-polymorpheus';\n\nimport {TuiBarChartComponent} from './bar-chart.component';\n\n@NgModule({\n imports: [\n CommonModule,\n PolymorpheusModule,\n TuiDescribedByModule,\n TuiBarSetModule,\n TuiFocusableModule,\n TuiHintModule,\n TuiMapperPipeModule,\n ],\n declarations: [TuiBarChartComponent],\n exports: [TuiBarChartComponent],\n})\nexport class TuiBarChartModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
|
@@ -16,7 +16,7 @@ let TuiBarSetComponent = class TuiBarSetComponent {
|
|
|
16
16
|
this.sanitizer = sanitizer;
|
|
17
17
|
this.value = [];
|
|
18
18
|
this.colorHandler = TUI_DEFAULT_COLOR_HANDLER;
|
|
19
|
-
this.size =
|
|
19
|
+
this.size = 'm';
|
|
20
20
|
this.collapsed = false;
|
|
21
21
|
}
|
|
22
22
|
get computedValue() {
|
|
@@ -26,7 +26,7 @@ let TuiBarSetComponent = class TuiBarSetComponent {
|
|
|
26
26
|
return this.collapsed ? this.value : EMPTY_ARRAY;
|
|
27
27
|
}
|
|
28
28
|
get computedSize() {
|
|
29
|
-
return this.size ||
|
|
29
|
+
return this.size || 'm';
|
|
30
30
|
}
|
|
31
31
|
getHeight(value) {
|
|
32
32
|
return Math.abs((PERCENT * value) / this.getLargest(this.computedValue));
|
|
@@ -62,7 +62,7 @@ __decorate([
|
|
|
62
62
|
], TuiBarSetComponent.prototype, "getLargest", null);
|
|
63
63
|
TuiBarSetComponent = __decorate([
|
|
64
64
|
Component({
|
|
65
|
-
selector:
|
|
65
|
+
selector: 'tui-bar-set',
|
|
66
66
|
template: "<ng-container *ngIf=\"size; else flexible\">\n <ng-container\n *ngFor=\"let item of computedValue; let index = index\"\n [ngTemplateOutlet]=\"bar\"\n [ngTemplateOutletContext]=\"{$implicit: item, index: index, flexible: false}\"\n ></ng-container>\n</ng-container>\n<ng-template #flexible>\n <div\n *ngFor=\"let item of computedValue; let index = index\"\n class=\"t-wrapper\"\n >\n <ng-container\n [ngTemplateOutlet]=\"bar\"\n [ngTemplateOutletContext]=\"{$implicit: item, index: index, flexible: true}\"\n ></ng-container>\n </div>\n</ng-template>\n<ng-template\n #bar\n let-item\n let-index=\"index\"\n let-flexible=\"flexible\"\n>\n <tui-bar\n automation-id=\"tui-bar-set__bar\"\n class=\"t-bar\"\n [class.t-bar_flexible]=\"flexible\"\n [class.t-bar_negative]=\"item < 0\"\n [style.height.%]=\"getHeight(item)\"\n [style.background]=\"getColor(index)\"\n [value]=\"computedSegments\"\n [size]=\"computedSize\"\n [colorHandler]=\"colorHandler\"\n ></tui-bar>\n</ng-template>\n",
|
|
67
67
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
68
68
|
styles: [":host{display:flex;height:100%;align-items:flex-end;justify-content:center}.t-wrapper{display:flex;flex:1;height:100%;align-items:flex-end}.t-wrapper:first-child{margin-left:25%}.t-wrapper:last-child{margin-right:25%}.t-bar{transform-origin:bottom center}.t-bar_negative{transform:rotate(180deg);opacity:var(--tui-disabled-opacity)}.t-bar.t-bar_flexible{max-width:none;width:75%;margin:0 auto}"]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-charts-components-bar-set.js","sources":["ng://@taiga-ui/addon-charts/components/bar-set/bar-set.component.ts","ng://@taiga-ui/addon-charts/components/bar-set/bar-set.module.ts","ng://@taiga-ui/addon-charts/components/bar-set/taiga-ui-addon-charts-components-bar-set.ts"],"sourcesContent":["import {ChangeDetectionStrategy, Component, Inject, Input} from '@angular/core';\nimport {DomSanitizer, SafeValue} from '@angular/platform-browser';\nimport {TUI_DEFAULT_COLOR_HANDLER} from '@taiga-ui/addon-charts/constants';\nimport {TuiColorHandler} from '@taiga-ui/addon-charts/types';\nimport {tuiDefaultProp, tuiPure} from '@taiga-ui/cdk';\nimport {colorFallback, TuiSizeL, TuiSizeS} from '@taiga-ui/core';\n\nconst PERCENT = 100;\nconst EMPTY_ARRAY: readonly number[] = [];\nconst FILLER_ARRAY: readonly number[] = [1];\n\n// TODO: 3.0 Remove sanitizer when Angular version is bumped\n@Component({\n selector:
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-charts-components-bar-set.js","sources":["ng://@taiga-ui/addon-charts/components/bar-set/bar-set.component.ts","ng://@taiga-ui/addon-charts/components/bar-set/bar-set.module.ts","ng://@taiga-ui/addon-charts/components/bar-set/taiga-ui-addon-charts-components-bar-set.ts"],"sourcesContent":["import {ChangeDetectionStrategy, Component, Inject, Input} from '@angular/core';\nimport {DomSanitizer, SafeValue} from '@angular/platform-browser';\nimport {TUI_DEFAULT_COLOR_HANDLER} from '@taiga-ui/addon-charts/constants';\nimport {TuiColorHandler} from '@taiga-ui/addon-charts/types';\nimport {tuiDefaultProp, tuiPure} from '@taiga-ui/cdk';\nimport {colorFallback, TuiSizeL, TuiSizeS} from '@taiga-ui/core';\n\nconst PERCENT = 100;\nconst EMPTY_ARRAY: readonly number[] = [];\nconst FILLER_ARRAY: readonly number[] = [1];\n\n// TODO: 3.0 Remove sanitizer when Angular version is bumped\n@Component({\n selector: 'tui-bar-set',\n templateUrl: './bar-set.template.html',\n styleUrls: ['./bar-set.style.less'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiBarSetComponent {\n @Input()\n @tuiDefaultProp()\n value: readonly number[] = [];\n\n @Input()\n @tuiDefaultProp()\n colorHandler: TuiColorHandler = TUI_DEFAULT_COLOR_HANDLER;\n\n @Input()\n @tuiDefaultProp()\n size: TuiSizeL | TuiSizeS | null = 'm';\n\n @Input()\n @tuiDefaultProp()\n collapsed = false;\n\n constructor(@Inject(DomSanitizer) private readonly sanitizer: DomSanitizer) {}\n\n get computedValue(): readonly number[] {\n return this.collapsed ? FILLER_ARRAY : this.value;\n }\n\n get computedSegments(): readonly number[] {\n return this.collapsed ? this.value : EMPTY_ARRAY;\n }\n\n get computedSize(): TuiSizeL | TuiSizeS {\n return this.size || 'm';\n }\n\n getHeight(value: number): number {\n return Math.abs((PERCENT * value) / this.getLargest(this.computedValue));\n }\n\n getColor(index: number): SafeValue {\n return this.sanitizer.bypassSecurityTrustStyle(\n `var(--tui-chart-${index}, ${colorFallback(this.colorHandler(index))})`,\n );\n }\n\n @tuiPure\n private getLargest(value: readonly number[]): number {\n return value.reduce((a, b) => (a > b ? a : b), 0);\n }\n}\n","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\nimport {TuiBarModule} from '@taiga-ui/addon-charts/components/bar';\n\nimport {TuiBarSetComponent} from './bar-set.component';\n\n@NgModule({\n imports: [CommonModule, TuiBarModule],\n declarations: [TuiBarSetComponent],\n exports: [TuiBarSetComponent],\n})\nexport class TuiBarSetModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;;AAOA,MAAM,OAAO,GAAG,GAAG,CAAC;AACpB,MAAM,WAAW,GAAsB,EAAE,CAAC;AAC1C,MAAM,YAAY,GAAsB,CAAC,CAAC,CAAC,CAAC;AAE5C;IAOa,kBAAkB,GAA/B,MAAa,kBAAkB;IAiB3B,YAAmD,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAd1E,UAAK,GAAsB,EAAE,CAAC;QAI9B,iBAAY,GAAoB,yBAAyB,CAAC;QAI1D,SAAI,GAA+B,GAAG,CAAC;QAIvC,cAAS,GAAG,KAAK,CAAC;KAE4D;IAE9E,IAAI,aAAa;QACb,OAAO,IAAI,CAAC,SAAS,GAAG,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC;KACrD;IAED,IAAI,gBAAgB;QAChB,OAAO,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC;KACpD;IAED,IAAI,YAAY;QACZ,OAAO,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC;KAC3B;IAED,SAAS,CAAC,KAAa;QACnB,OAAO,IAAI,CAAC,GAAG,CAAC,CAAC,OAAO,GAAG,KAAK,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;KAC5E;IAED,QAAQ,CAAC,KAAa;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAC1C,mBAAmB,KAAK,KAAK,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,GAAG,CAC1E,CAAC;KACL;IAGO,UAAU,CAAC,KAAwB;QACvC,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,MAAM,CAAC,GAAG,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;KACrD;EACJ;;YA5BiE,YAAY,uBAA7D,MAAM,SAAC,YAAY;;AAdhC;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;iDACa;AAI9B;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;wDACyC;AAI1D;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;gDACsB;AAIvC;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;qDACC;AA2BlB;IADC,OAAO;oDAGP;AA5CQ,kBAAkB;IAN9B,SAAS,CAAC;QACP,QAAQ,EAAE,aAAa;QACvB,soCAAsC;QAEtC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;KAClD,CAAC;IAkBe,WAAA,MAAM,CAAC,YAAY,CAAC,CAAA;GAjBxB,kBAAkB,CA6C9B;;ICpDY,eAAe,GAA5B,MAAa,eAAe;EAAG;AAAlB,eAAe;IAL3B,QAAQ,CAAC;QACN,OAAO,EAAE,CAAC,YAAY,EAAE,YAAY,CAAC;QACrC,YAAY,EAAE,CAAC,kBAAkB,CAAC;QAClC,OAAO,EAAE,CAAC,kBAAkB,CAAC;KAChC,CAAC;GACW,eAAe,CAAG;;ACX/B;;;;;;"}
|
|
@@ -12,7 +12,7 @@ let TuiBarComponent = class TuiBarComponent {
|
|
|
12
12
|
this.sanitizer = sanitizer;
|
|
13
13
|
this.value = [];
|
|
14
14
|
this.colorHandler = TUI_DEFAULT_COLOR_HANDLER;
|
|
15
|
-
this.size =
|
|
15
|
+
this.size = 'm';
|
|
16
16
|
}
|
|
17
17
|
getHeight(value) {
|
|
18
18
|
return (100 * value) / this.getSum(this.value);
|
|
@@ -37,7 +37,7 @@ __decorate([
|
|
|
37
37
|
], TuiBarComponent.prototype, "colorHandler", void 0);
|
|
38
38
|
__decorate([
|
|
39
39
|
Input(),
|
|
40
|
-
HostBinding(
|
|
40
|
+
HostBinding('attr.data-size'),
|
|
41
41
|
tuiDefaultProp()
|
|
42
42
|
], TuiBarComponent.prototype, "size", void 0);
|
|
43
43
|
__decorate([
|
|
@@ -45,7 +45,7 @@ __decorate([
|
|
|
45
45
|
], TuiBarComponent.prototype, "getSum", null);
|
|
46
46
|
TuiBarComponent = __decorate([
|
|
47
47
|
Component({
|
|
48
|
-
selector:
|
|
48
|
+
selector: 'tui-bar',
|
|
49
49
|
template: "<div\n *ngFor=\"let item of value; let index = index\"\n automation-id=\"tui-bar__bar\"\n [style.height.%]=\"getHeight(item)\"\n [style.background]=\"getColor(index)\"\n></div>\n",
|
|
50
50
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
51
51
|
styles: [":host{display:flex;min-width:.125rem;flex-direction:column-reverse;border-top-left-radius:var(--tui-radius-l);border-top-right-radius:var(--tui-radius-l);overflow:hidden}:host[data-size='l']{width:1rem;max-width:1rem;margin:0 .1875rem}:host[data-size='m']{width:.5rem;max-width:.5rem;margin:0 .1875rem}:host[data-size='s']{width:.25rem;max-width:.5rem;margin:0 .125rem}"]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-charts-components-bar.js","sources":["ng://@taiga-ui/addon-charts/components/bar/bar.component.ts","ng://@taiga-ui/addon-charts/components/bar/bar.module.ts","ng://@taiga-ui/addon-charts/components/bar/taiga-ui-addon-charts-components-bar.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n HostBinding,\n Inject,\n Input,\n} from '@angular/core';\nimport {DomSanitizer, SafeValue} from '@angular/platform-browser';\nimport {TUI_DEFAULT_COLOR_HANDLER} from '@taiga-ui/addon-charts/constants';\nimport {TuiColorHandler} from '@taiga-ui/addon-charts/types';\nimport {sum, tuiDefaultProp, tuiPure} from '@taiga-ui/cdk';\nimport {colorFallback, TuiSizeL, TuiSizeS} from '@taiga-ui/core';\n\n// TODO: 3.0 Remove sanitizer when Angular version is bumped\n@Component({\n selector:
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-charts-components-bar.js","sources":["ng://@taiga-ui/addon-charts/components/bar/bar.component.ts","ng://@taiga-ui/addon-charts/components/bar/bar.module.ts","ng://@taiga-ui/addon-charts/components/bar/taiga-ui-addon-charts-components-bar.ts"],"sourcesContent":["import {\n ChangeDetectionStrategy,\n Component,\n HostBinding,\n Inject,\n Input,\n} from '@angular/core';\nimport {DomSanitizer, SafeValue} from '@angular/platform-browser';\nimport {TUI_DEFAULT_COLOR_HANDLER} from '@taiga-ui/addon-charts/constants';\nimport {TuiColorHandler} from '@taiga-ui/addon-charts/types';\nimport {sum, tuiDefaultProp, tuiPure} from '@taiga-ui/cdk';\nimport {colorFallback, TuiSizeL, TuiSizeS} from '@taiga-ui/core';\n\n// TODO: 3.0 Remove sanitizer when Angular version is bumped\n@Component({\n selector: 'tui-bar',\n templateUrl: './bar.template.html',\n styleUrls: ['./bar.style.less'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiBarComponent {\n @Input()\n @tuiDefaultProp()\n value: readonly number[] = [];\n\n @Input()\n @tuiDefaultProp()\n colorHandler: TuiColorHandler = TUI_DEFAULT_COLOR_HANDLER;\n\n @Input()\n @HostBinding('attr.data-size')\n @tuiDefaultProp()\n size: TuiSizeL | TuiSizeS = 'm';\n\n constructor(@Inject(DomSanitizer) private readonly sanitizer: DomSanitizer) {}\n\n getHeight(value: number): number {\n return (100 * value) / this.getSum(this.value);\n }\n\n getColor(index: number): SafeValue {\n return this.sanitizer.bypassSecurityTrustStyle(\n `var(--tui-chart-${index}, ${colorFallback(this.colorHandler(index))})`,\n );\n }\n\n @tuiPure\n private getSum(value: readonly number[]): number {\n return sum(...value);\n }\n}\n","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\n\nimport {TuiBarComponent} from './bar.component';\n\n@NgModule({\n imports: [CommonModule],\n declarations: [TuiBarComponent],\n exports: [TuiBarComponent],\n})\nexport class TuiBarModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;;;AAaA;IAOa,eAAe,GAA5B,MAAa,eAAe;IAcxB,YAAmD,SAAuB;QAAvB,cAAS,GAAT,SAAS,CAAc;QAX1E,UAAK,GAAsB,EAAE,CAAC;QAI9B,iBAAY,GAAoB,yBAAyB,CAAC;QAK1D,SAAI,GAAwB,GAAG,CAAC;KAE8C;IAE9E,SAAS,CAAC,KAAa;QACnB,OAAO,CAAC,GAAG,GAAG,KAAK,IAAI,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KAClD;IAED,QAAQ,CAAC,KAAa;QAClB,OAAO,IAAI,CAAC,SAAS,CAAC,wBAAwB,CAC1C,mBAAmB,KAAK,KAAK,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,GAAG,CAC1E,CAAC;KACL;IAGO,MAAM,CAAC,KAAwB;QACnC,OAAO,GAAG,CAAC,GAAG,KAAK,CAAC,CAAC;KACxB;EACJ;;YAhBiE,YAAY,uBAA7D,MAAM,SAAC,YAAY;;AAXhC;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;8CACa;AAI9B;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;qDACyC;AAK1D;IAHC,KAAK,EAAE;IACP,WAAW,CAAC,gBAAgB,CAAC;IAC7B,cAAc,EAAE;6CACe;AAehC;IADC,OAAO;6CAGP;AA7BQ,eAAe;IAN3B,SAAS,CAAC;QACP,QAAQ,EAAE,SAAS;QACnB,0MAAkC;QAElC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;KAClD,CAAC;IAee,WAAA,MAAM,CAAC,YAAY,CAAC,CAAA;GAdxB,eAAe,CA8B3B;;ICxCY,YAAY,GAAzB,MAAa,YAAY;EAAG;AAAf,YAAY;IALxB,QAAQ,CAAC;QACN,OAAO,EAAE,CAAC,YAAY,CAAC;QACvB,YAAY,EAAE,CAAC,eAAe,CAAC;QAC/B,OAAO,EAAE,CAAC,eAAe,CAAC;KAC7B,CAAC;GACW,YAAY,CAAG;;ACV5B;;;;;;"}
|
|
@@ -8,16 +8,16 @@ import { CommonModule } from '@angular/common';
|
|
|
8
8
|
let TuiLegendItemComponent = class TuiLegendItemComponent {
|
|
9
9
|
constructor() {
|
|
10
10
|
this.active = false;
|
|
11
|
-
this.color =
|
|
12
|
-
this.text =
|
|
13
|
-
this.size =
|
|
11
|
+
this.color = '';
|
|
12
|
+
this.text = '';
|
|
13
|
+
this.size = 'm';
|
|
14
14
|
this.disabled = false;
|
|
15
15
|
}
|
|
16
16
|
get computedColor() {
|
|
17
|
-
if (this.color ===
|
|
17
|
+
if (this.color === 'var(--tui-primary)') {
|
|
18
18
|
return null;
|
|
19
19
|
}
|
|
20
|
-
return this.color.startsWith(
|
|
20
|
+
return this.color.startsWith('var(') ? this.color : colorFallback(this.color);
|
|
21
21
|
}
|
|
22
22
|
};
|
|
23
23
|
__decorate([
|
|
@@ -34,19 +34,19 @@ __decorate([
|
|
|
34
34
|
], TuiLegendItemComponent.prototype, "text", void 0);
|
|
35
35
|
__decorate([
|
|
36
36
|
Input(),
|
|
37
|
-
HostBinding(
|
|
37
|
+
HostBinding('attr.data-size'),
|
|
38
38
|
tuiDefaultProp()
|
|
39
39
|
], TuiLegendItemComponent.prototype, "size", void 0);
|
|
40
40
|
__decorate([
|
|
41
41
|
Input(),
|
|
42
|
-
HostBinding(
|
|
42
|
+
HostBinding('class._disabled')
|
|
43
43
|
], TuiLegendItemComponent.prototype, "disabled", void 0);
|
|
44
44
|
__decorate([
|
|
45
|
-
HostBinding(
|
|
45
|
+
HostBinding('style.--tui-primary')
|
|
46
46
|
], TuiLegendItemComponent.prototype, "computedColor", null);
|
|
47
47
|
TuiLegendItemComponent = __decorate([
|
|
48
48
|
Component({
|
|
49
|
-
selector:
|
|
49
|
+
selector: 'tui-legend-item',
|
|
50
50
|
template: "<button\n tuiButton\n type=\"button\"\n size=\"s\"\n appearance=\"whiteblock\"\n class=\"t-button\"\n [pseudoHovered]=\"active || null\"\n>\n <div class=\"t-wrapper\">\n <ng-content select=\"tui-primitive-checkbox\"></ng-content>\n <span class=\"t-dot\"></span>\n <span class=\"t-text\">{{ text }}</span>\n <ng-content></ng-content>\n </div>\n</button>\n",
|
|
51
51
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
52
52
|
styles: [":host{display:inline-block}.t-button{height:2rem;font-weight:700}:host[data-size='m'] .t-button{height:2.25rem;font:var(--tui-font-text-m);font-weight:700}.t-wrapper{display:flex;align-items:center;pointer-events:none}:host._disabled .t-wrapper{color:var(--tui-text-03)}.t-dot{width:.5rem;height:.5rem;border-radius:100%;background:var(--tui-primary)}:host._disabled .t-dot{background:var(--tui-base-04)}.t-dot:not(:first-child){display:none}.t-text{margin:0 .5rem;font-weight:400}"]
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"taiga-ui-addon-charts-components-legend-item.js","sources":["ng://@taiga-ui/addon-charts/components/legend-item/legend-item.component.ts","ng://@taiga-ui/addon-charts/components/legend-item/legend-item.module.ts","ng://@taiga-ui/addon-charts/components/legend-item/taiga-ui-addon-charts-components-legend-item.ts"],"sourcesContent":["import {ChangeDetectionStrategy, Component, HostBinding, Input} from '@angular/core';\nimport {tuiDefaultProp} from '@taiga-ui/cdk';\nimport {colorFallback, TuiSizeS} from '@taiga-ui/core';\n\n// TODO: 3.0 Remove fallback\n@Component({\n selector:
|
|
1
|
+
{"version":3,"file":"taiga-ui-addon-charts-components-legend-item.js","sources":["ng://@taiga-ui/addon-charts/components/legend-item/legend-item.component.ts","ng://@taiga-ui/addon-charts/components/legend-item/legend-item.module.ts","ng://@taiga-ui/addon-charts/components/legend-item/taiga-ui-addon-charts-components-legend-item.ts"],"sourcesContent":["import {ChangeDetectionStrategy, Component, HostBinding, Input} from '@angular/core';\nimport {tuiDefaultProp} from '@taiga-ui/cdk';\nimport {colorFallback, TuiSizeS} from '@taiga-ui/core';\n\n// TODO: 3.0 Remove fallback\n@Component({\n selector: 'tui-legend-item',\n templateUrl: './legend-item.template.html',\n styleUrls: ['./legend-item.style.less'],\n changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TuiLegendItemComponent {\n @Input()\n @tuiDefaultProp()\n active = false;\n\n @Input()\n @tuiDefaultProp()\n color = '';\n\n @Input()\n @tuiDefaultProp()\n text = '';\n\n @Input()\n @HostBinding('attr.data-size')\n @tuiDefaultProp()\n size: TuiSizeS = 'm';\n\n @Input()\n @HostBinding('class._disabled')\n disabled = false;\n\n @HostBinding('style.--tui-primary')\n get computedColor(): string | null {\n if (this.color === 'var(--tui-primary)') {\n return null;\n }\n\n return this.color.startsWith('var(') ? this.color : colorFallback(this.color);\n }\n}\n","import {CommonModule} from '@angular/common';\nimport {NgModule} from '@angular/core';\nimport {TuiButtonModule} from '@taiga-ui/core';\n\nimport {TuiLegendItemComponent} from './legend-item.component';\n\n@NgModule({\n imports: [CommonModule, TuiButtonModule],\n declarations: [TuiLegendItemComponent],\n exports: [TuiLegendItemComponent],\n})\nexport class TuiLegendItemModule {}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":";;;;;;AAIA;IAOa,sBAAsB,GAAnC,MAAa,sBAAsB;IAAnC;QAGI,WAAM,GAAG,KAAK,CAAC;QAIf,UAAK,GAAG,EAAE,CAAC;QAIX,SAAI,GAAG,EAAE,CAAC;QAKV,SAAI,GAAa,GAAG,CAAC;QAIrB,aAAQ,GAAG,KAAK,CAAC;KAUpB;IAPG,IAAI,aAAa;QACb,IAAI,IAAI,CAAC,KAAK,KAAK,oBAAoB,EAAE;YACrC,OAAO,IAAI,CAAC;SACf;QAED,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,GAAG,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;KACjF;EACJ;AA3BG;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;sDACF;AAIf;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;qDACN;AAIX;IAFC,KAAK,EAAE;IACP,cAAc,EAAE;oDACP;AAKV;IAHC,KAAK,EAAE;IACP,WAAW,CAAC,gBAAgB,CAAC;IAC7B,cAAc,EAAE;oDACI;AAIrB;IAFC,KAAK,EAAE;IACP,WAAW,CAAC,iBAAiB,CAAC;wDACd;AAGjB;IADC,WAAW,CAAC,qBAAqB,CAAC;2DAOlC;AA7BQ,sBAAsB;IANlC,SAAS,CAAC;QACP,QAAQ,EAAE,iBAAiB;QAC3B,kaAA0C;QAE1C,eAAe,EAAE,uBAAuB,CAAC,MAAM;;KAClD,CAAC;GACW,sBAAsB,CA8BlC;;IC9BY,mBAAmB,GAAhC,MAAa,mBAAmB;EAAG;AAAtB,mBAAmB;IAL/B,QAAQ,CAAC;QACN,OAAO,EAAE,CAAC,YAAY,EAAE,eAAe,CAAC;QACxC,YAAY,EAAE,CAAC,sBAAsB,CAAC;QACtC,OAAO,EAAE,CAAC,sBAAsB,CAAC;KACpC,CAAC;GACW,mBAAmB,CAAG;;ACXnC;;;;;;"}
|