@alauda-fe/common
Version:
Alauda frontend team common codes.
157 lines • 24.1 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
import { Observable, merge, map, tap } from 'rxjs';
import { ObservableInput, publishRef } from '../../../core/public-api';
import { ContextChartService } from '../../chart.service';
import { Orientation } from '../../types';
import * as i0 from "@angular/core";
import * as i1 from "../../chart.service";
import * as i2 from "@angular/common";
import * as i3 from "../../../core/pipes/pure.pipe";
const _c0 = ["aclBarPath", ""];
function BarPathComponent__svg_ng_container_1__svg_rect_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelement(0, "rect", 3);
i0.ɵɵpipe(1, "pure");
i0.ɵɵpipe(2, "pure");
i0.ɵɵpipe(3, "pure");
i0.ɵɵpipe(4, "pure");
i0.ɵɵpipe(5, "pure");
} if (rf & 2) {
const item_r1 = ctx.$implicit;
const i_r2 = ctx.index;
const ctx_r2 = i0.ɵɵnextContext(2);
i0.ɵɵattribute("width", ctx_r2.innerBandWidth)("x", i0.ɵɵpipeBind2(1, 6, item_r1.x, ctx_r2.getRectX) || 0)("y", i0.ɵɵpipeBind3(2, 9, i_r2, ctx_r2.getRectY, item_r1.y) || 0)("height", item_r1.y ? i0.ɵɵpipeBind2(3, 13, 0, ctx_r2.context.y) - i0.ɵɵpipeBind2(4, 16, item_r1.y, ctx_r2.context.y) : 0)("fill", item_r1.color)("opacity", i0.ɵɵpipeBind3(5, 19, item_r1.x, ctx_r2.handleOpacity, ctx_r2.activateLegend));
} }
function BarPathComponent__svg_ng_container_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelementContainerStart(0);
i0.ɵɵtemplate(1, BarPathComponent__svg_ng_container_1__svg_rect_1_Template, 6, 23, "rect", 2);
i0.ɵɵpipe(2, "async");
i0.ɵɵelementContainerEnd();
} if (rf & 2) {
const ctx_r2 = i0.ɵɵnextContext();
i0.ɵɵadvance();
i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(2, 1, ctx_r2.barData$));
} }
function BarPathComponent__svg_ng_template_2__svg_rect_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelement(0, "rect", 3);
i0.ɵɵpipe(1, "pure");
i0.ɵɵpipe(2, "pure");
i0.ɵɵpipe(3, "pure");
i0.ɵɵpipe(4, "pure");
} if (rf & 2) {
const item_r4 = ctx.$implicit;
const i_r5 = ctx.index;
const ctx_r2 = i0.ɵɵnextContext(2);
i0.ɵɵattribute("height", ctx_r2.innerBandWidth)("y", i0.ɵɵpipeBind2(1, 6, item_r4.x, ctx_r2.getRectX) || 0)("x", i0.ɵɵpipeBind2(2, 9, i_r5, ctx_r2.getStackedRectY) || 0)("width", item_r4.y ? i0.ɵɵpipeBind2(3, 12, item_r4.y, ctx_r2.context.y) : 0)("fill", item_r4.color)("opacity", i0.ɵɵpipeBind3(4, 15, item_r4.x, ctx_r2.handleOpacity, ctx_r2.activateLegend));
} }
function BarPathComponent__svg_ng_template_2_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, BarPathComponent__svg_ng_template_2__svg_rect_0_Template, 5, 19, "rect", 2);
i0.ɵɵpipe(1, "async");
} if (rf & 2) {
const ctx_r2 = i0.ɵɵnextContext();
i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(1, 1, ctx_r2.barData$));
} }
export class BarPathComponent {
get isStacked() {
return this.type === 'stacked';
}
get innerBandWidth() {
return ((this.adaptiveBandWidth
? this.isStacked
? this.context.x.bandwidth()
: this.context.barInnerScale(this.barPadding).bandwidth()
: this.bandWidth) || 0);
}
constructor(context, cdr) {
this.context = context;
this.cdr = cdr;
this.barPadding = 8;
this.type = 'standard';
this.orientation = Orientation;
this.preValue = 0;
this.barData = [];
this.barData$ = merge(this.data$, this.context.legendChange$$, this.context.seriesData$).pipe(map(() => {
this.preValue = 0;
return this.data
.map((item, index) => ({
...item,
color: item.color || this.context.getChartDefaultColor(index),
}))
.filter(item => !this.context.disabledLegend.has(item.x));
}), tap(res => {
this.barData = res;
}), publishRef());
this.getRectX = (x) => this.isStacked
? 0
: this.context.barInnerScale(this.barPadding)(x);
this.getRectY = (index, y) => {
if (!this.isStacked) {
return this.context.y(y);
}
const previous = this.context.y(this.barData[index - 1 > 0 ? index - 1 : 0].y);
const diffH = Math.abs(this.context.y(0) - this.context.y(y));
const res = index === 0 ? previous : this.preValue - diffH;
this.preValue = res;
return res;
};
this.getStackedRectY = (index) => {
if (!this.isStacked) {
return 0;
}
const previous = this.context.y(this.barData[index - 1 > 0 ? index - 1 : 0].y);
const diffH = Math.abs(this.context.y(0) - previous);
const res = index === 0 ? 0 : index === 1 ? previous : this.preValue + diffH;
this.preValue = res;
return res;
};
this.handleVisibility = (name) => this.context.disabledLegend.has(name) ? 'hidden' : '';
this.handleOpacity = (name, activateLegend) => activateLegend ? (activateLegend === name ? 1 : 0.2) : 1;
}
ngOnInit() {
this.context.legendActivate$$.subscribe(legend => {
this.activateLegend = legend;
this.cdr.detectChanges();
});
this.context.update$$.subscribe(() => {
this.cdr.detectChanges();
});
}
static { this.ɵfac = function BarPathComponent_Factory(t) { return new (t || BarPathComponent)(i0.ɵɵdirectiveInject(i1.ContextChartService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: BarPathComponent, selectors: [["g", "aclBarPath", ""]], inputs: { stroke: "stroke", data: "data", barPadding: "barPadding", groupName: "groupName", type: "type", bandWidth: "bandWidth", adaptiveBandWidth: "adaptiveBandWidth" }, attrs: _c0, decls: 4, vars: 2, consts: [["elseTemplate", ""], [4, "ngIf", "ngIfElse"], ["class", "rect", 4, "ngFor", "ngForOf"], [1, "rect"]], template: function BarPathComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(0, "g");
i0.ɵɵtemplate(1, BarPathComponent__svg_ng_container_1_Template, 3, 3, "ng-container", 1)(2, BarPathComponent__svg_ng_template_2_Template, 2, 3, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
i0.ɵɵelementEnd();
} if (rf & 2) {
const elseTemplate_r6 = i0.ɵɵreference(3);
i0.ɵɵadvance();
i0.ɵɵproperty("ngIf", ctx.context.barOptions.orientation === ctx.orientation.VERTICAL)("ngIfElse", elseTemplate_r6);
} }, dependencies: [i2.NgForOf, i2.NgIf, i2.AsyncPipe, i3.PurePipe], styles: [".tooltipClass{pointer-events:none;max-width:800px!important}.tooltip-content[_ngcontent-%COMP%]{color:rgb(var(--aui-color-n-6))}.tooltip-content[_ngcontent-%COMP%] .title[_ngcontent-%COMP%]{margin-bottom:8px}.tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] ul[_ngcontent-%COMP%], .tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] li[_ngcontent-%COMP%]{padding:0;margin:0;list-style:none}.tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] ul[_ngcontent-%COMP%]:not(:last-child), .tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] li[_ngcontent-%COMP%]:not(:last-child){margin-bottom:6px}.tooltip-content[_ngcontent-%COMP%] .context-list[_ngcontent-%COMP%]{display:flex;flex-direction:column}.tooltip-content[_ngcontent-%COMP%] .context-list[_ngcontent-%COMP%] .active[_ngcontent-%COMP%]{color:rgb(var(--aui-color-n-10))}.tooltip-content[_ngcontent-%COMP%] .context-item[_ngcontent-%COMP%]{display:flex}.tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] .left[_ngcontent-%COMP%]{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] .right[_ngcontent-%COMP%]{text-align:right;white-space:nowrap}.tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] .column-layout[_ngcontent-%COMP%] .right[_ngcontent-%COMP%]{flex:1 1 auto;text-align:right}.tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] .column-layout[_ngcontent-%COMP%] .left[_ngcontent-%COMP%]{margin-right:8px}.tooltip-content[_ngcontent-%COMP%] .context[_ngcontent-%COMP%] .item-icon[_ngcontent-%COMP%]{margin-right:4px;width:6px;border-radius:50%;height:6px;background-color:rgb(var(--aui-color-n-10));display:inline-block;font-size:6px}"], changeDetection: 0 }); }
}
__decorate([
ObservableInput(true, []),
__metadata("design:type", Observable)
], BarPathComponent.prototype, "data$", void 0);
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(BarPathComponent, [{
type: Component,
args: [{ selector: 'g[aclBarPath]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<svg:g>\n <ng-container\n *ngIf=\"\n context.barOptions.orientation === orientation.VERTICAL;\n else elseTemplate\n \"\n >\n <rect\n *ngFor=\"let item of barData$ | async; let i = index\"\n class=\"rect\"\n [attr.width]=\"innerBandWidth\"\n [attr.x]=\"(item.x | pure: getRectX) || 0\"\n [attr.y]=\"(i | pure: getRectY:item.y) || 0\"\n [attr.height]=\"\n item.y ? (0 | pure: context.y) - (item.y | pure: context.y) : 0\n \"\n [attr.fill]=\"item.color\"\n [attr.opacity]=\"item.x | pure: handleOpacity:activateLegend\"\n ></rect>\n </ng-container>\n <ng-template #elseTemplate>\n <rect\n *ngFor=\"let item of barData$ | async; let i = index\"\n class=\"rect\"\n [attr.height]=\"innerBandWidth\"\n [attr.y]=\"(item.x | pure: getRectX) || 0\"\n [attr.x]=\"(i | pure: getStackedRectY) || 0\"\n [attr.width]=\"item.y ? (item.y | pure: context.y) : 0\"\n [attr.fill]=\"item.color\"\n [attr.opacity]=\"item.x | pure: handleOpacity:activateLegend\"\n ></rect>\n </ng-template>\n</svg:g>\n", styles: ["::ng-deep .tooltipClass{pointer-events:none;max-width:800px!important}.tooltip-content{color:rgb(var(--aui-color-n-6))}.tooltip-content .title{margin-bottom:8px}.tooltip-content .context ul,.tooltip-content .context li{padding:0;margin:0;list-style:none}.tooltip-content .context ul:not(:last-child),.tooltip-content .context li:not(:last-child){margin-bottom:6px}.tooltip-content .context-list{display:flex;flex-direction:column}.tooltip-content .context-list .active{color:rgb(var(--aui-color-n-10))}.tooltip-content .context-item{display:flex}.tooltip-content .context .left{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tooltip-content .context .right{text-align:right;white-space:nowrap}.tooltip-content .context .column-layout .right{flex:1 1 auto;text-align:right}.tooltip-content .context .column-layout .left{margin-right:8px}.tooltip-content .context .item-icon{margin-right:4px;width:6px;border-radius:50%;height:6px;background-color:rgb(var(--aui-color-n-10));display:inline-block;font-size:6px}\n"] }]
}], () => [{ type: i1.ContextChartService }, { type: i0.ChangeDetectorRef }], { stroke: [{
type: Input
}], data: [{
type: Input
}], data$: [], barPadding: [{
type: Input
}], groupName: [{
type: Input
}], type: [{
type: Input
}], bandWidth: [{
type: Input
}], adaptiveBandWidth: [{
type: Input
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(BarPathComponent, { className: "BarPathComponent" }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bar-path.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/series/bar-path.component.ts","../../../../../../../libs/common/src/chart/common/series/bar-path.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnInit,\n} from '@angular/core';\nimport { ScaleBand } from 'd3';\nimport { Observable, merge, map, tap } from 'rxjs';\n\nimport { ObservableInput, publishRef } from '../../../core/public-api';\nimport { ChartDataItem } from '../../../view-chart/types';\nimport { ContextChartService } from '../../chart.service';\nimport { Orientation } from '../../types';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'g[aclBarPath]',\n  templateUrl: './bar-path.component.html',\n  styleUrls: ['../tooltip/tooltip.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class BarPathComponent implements OnInit {\n  @Input() stroke: string;\n  @Input() data: Array<ChartDataItem<{ x: string; y: number; color?: string }>>;\n\n  @ObservableInput(true, [])\n  data$!: Observable<\n    Array<ChartDataItem<{ x: string; y: number; color?: string }>>\n  >;\n\n  @Input() barPadding = 8;\n\n  @Input() groupName: string;\n\n  @Input() type: 'standard' | 'stacked' = 'standard';\n\n  @Input() bandWidth: number;\n\n  @Input() adaptiveBandWidth: boolean;\n\n  path: string;\n  orientation = Orientation;\n  preValue = 0;\n  barData: ChartDataItem[] = [];\n  activateLegend: string;\n\n  get isStacked() {\n    return this.type === 'stacked';\n  }\n\n  barData$ = merge(\n    this.data$,\n    this.context.legendChange$$,\n    this.context.seriesData$,\n  ).pipe(\n    map(() => {\n      this.preValue = 0;\n      return this.data\n        .map((item, index) => ({\n          ...item,\n          color: item.color || this.context.getChartDefaultColor(index),\n        }))\n        .filter(item => !this.context.disabledLegend.has(item.x as string));\n    }),\n    tap(res => {\n      this.barData = res;\n    }),\n    publishRef(),\n  );\n\n  get innerBandWidth() {\n    return (\n      (this.adaptiveBandWidth\n        ? this.isStacked\n          ? (<ScaleBand<string>>this.context.x).bandwidth()\n          : this.context.barInnerScale(this.barPadding).bandwidth()\n        : this.bandWidth) || 0\n    );\n  }\n\n  constructor(\n    public readonly context: ContextChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  getRectX = (x: string | number | Date) =>\n    this.isStacked\n      ? 0\n      : this.context.barInnerScale(this.barPadding)(x as string);\n\n  ngOnInit() {\n    this.context.legendActivate$$.subscribe(legend => {\n      this.activateLegend = legend;\n      this.cdr.detectChanges();\n    });\n    this.context.update$$.subscribe(() => {\n      this.cdr.detectChanges();\n    });\n  }\n\n  getRectY = (index: number, y: number) => {\n    if (!this.isStacked) {\n      return this.context.y(y);\n    }\n    const previous = this.context.y(\n      this.barData[index - 1 > 0 ? index - 1 : 0].y,\n    );\n    const diffH = Math.abs(this.context.y(0) - this.context.y(y));\n    const res = index === 0 ? previous : this.preValue - diffH;\n    this.preValue = res;\n    return res;\n  };\n\n  getStackedRectY = (index: number) => {\n    if (!this.isStacked) {\n      return 0;\n    }\n    const previous = this.context.y(\n      this.barData[index - 1 > 0 ? index - 1 : 0].y,\n    );\n    const diffH = Math.abs(this.context.y(0) - previous);\n    const res =\n      index === 0 ? 0 : index === 1 ? previous : this.preValue + diffH;\n    this.preValue = res;\n    return res;\n  };\n\n  handleVisibility = (name: string) =>\n    this.context.disabledLegend.has(name) ? 'hidden' : '';\n\n  handleOpacity = (name: string | number | Date, activateLegend: string) =>\n    activateLegend ? (activateLegend === name ? 1 : 0.2) : 1;\n}\n","<svg:g>\n  <ng-container\n    *ngIf=\"\n      context.barOptions.orientation === orientation.VERTICAL;\n      else elseTemplate\n    \"\n  >\n    <rect\n      *ngFor=\"let item of barData$ | async; let i = index\"\n      class=\"rect\"\n      [attr.width]=\"innerBandWidth\"\n      [attr.x]=\"(item.x | pure: getRectX) || 0\"\n      [attr.y]=\"(i | pure: getRectY:item.y) || 0\"\n      [attr.height]=\"\n        item.y ? (0 | pure: context.y) - (item.y | pure: context.y) : 0\n      \"\n      [attr.fill]=\"item.color\"\n      [attr.opacity]=\"item.x | pure: handleOpacity:activateLegend\"\n    ></rect>\n  </ng-container>\n  <ng-template #elseTemplate>\n    <rect\n      *ngFor=\"let item of barData$ | async; let i = index\"\n      class=\"rect\"\n      [attr.height]=\"innerBandWidth\"\n      [attr.y]=\"(item.x | pure: getRectX) || 0\"\n      [attr.x]=\"(i | pure: getStackedRectY) || 0\"\n      [attr.width]=\"item.y ? (item.y | pure: context.y) : 0\"\n      [attr.fill]=\"item.color\"\n      [attr.opacity]=\"item.x | pure: handleOpacity:activateLegend\"\n    ></rect>\n  </ng-template>\n</svg:g>\n"]}