@alauda-fe/common
Version:
Alauda frontend team common codes.
127 lines • 13.8 kB
JavaScript
import { __decorate, __metadata } from "tslib";
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
import { Observable, Subject, combineLatest, filter, takeUntil } from 'rxjs';
import { ObservableInput } from '../../../core/public-api';
import { ContextChartService } from '../../chart.service';
import * as i0 from "@angular/core";
import * as i1 from "../../chart.service";
import * as i2 from "@angular/common";
const _c0 = ["aclYPlotLines", ""];
function YPlotLinesComponent__svg_circle_2_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelement(0, "circle");
} if (rf & 2) {
const point_r1 = ctx.$implicit;
i0.ɵɵattribute("r", 2.5)("stroke", point_r1.color)("stroke-width", 1)("fill", point_r1.color)("cx", point_r1.cx)("cy", point_r1.cy < 0 ? 0 : point_r1.cy || 0)("visibility", point_r1.visibility);
} }
export class YPlotLinesComponent {
get dasharray() {
return this.dashType === 'dash' ? [3, 2] : [0, 0];
}
get view() {
return this.context.chartView;
}
constructor(context, cdr) {
this.context = context;
this.cdr = cdr;
this.dashType = 'dash';
this.hide = false;
this.path = '';
this.circleValue = [];
this.destroy$$ = new Subject();
}
ngOnInit() {
combineLatest([this.value$, this.context.seriesData$])
.pipe(filter(([value]) => !!value && !!value.length), takeUntil(this.destroy$$))
.subscribe(() => {
const x = this.context.x(this.value[0].x);
if (x && this.view.height) {
this.path = `M${x},0 L${x} ${this.view.height}`;
this.circleValue = this.value.map(item => ({
color: item.color,
cx: this.context.x(item.x),
cy: this.context.y(item.y),
visibility: this.context.disabledLegend.has(item.name)
? 'hidden'
: '',
name: item.name,
}));
}
this.cdr.detectChanges();
});
this.context.legendChange$$
.pipe(takeUntil(this.destroy$$))
.subscribe(() => {
this.circleValue = this.circleValue.map(item => ({
...item,
visibility: this.context.disabledLegend.has(item.name)
? 'hidden'
: '',
}));
this.cdr.detectChanges();
});
}
ngOnDestroy() {
this.destroy$$.next();
this.destroy$$.complete();
}
static { this.ɵfac = function YPlotLinesComponent_Factory(t) { return new (t || YPlotLinesComponent)(i0.ɵɵdirectiveInject(i1.ContextChartService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: YPlotLinesComponent, selectors: [["g", "aclYPlotLines", ""]], inputs: { value: "value", color: "color", dashType: "dashType", width: "width", hide: "hide" }, attrs: _c0, decls: 3, vars: 6, consts: [["fill", "none"], [4, "ngFor", "ngForOf"]], template: function YPlotLinesComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(0, "g");
i0.ɵɵelement(1, "path", 0);
i0.ɵɵtemplate(2, YPlotLinesComponent__svg_circle_2_Template, 1, 7, "circle", 1);
i0.ɵɵelementEnd();
} if (rf & 2) {
i0.ɵɵattribute("visibility", ctx.hide ? "hidden" : "");
i0.ɵɵadvance();
i0.ɵɵattribute("d", ctx.path)("stroke-width", ctx.width || 1)("stroke", ctx.color || "#ccc")("stroke-dasharray", ctx.dasharray);
i0.ɵɵadvance();
i0.ɵɵproperty("ngForOf", ctx.circleValue);
} }, dependencies: [i2.NgForOf], encapsulation: 2, changeDetection: 0 }); }
}
__decorate([
ObservableInput(),
__metadata("design:type", Observable)
], YPlotLinesComponent.prototype, "value$", void 0);
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(YPlotLinesComponent, [{
type: Component,
args: [{
// eslint-disable-next-line @angular-eslint/component-selector
selector: 'g[aclYPlotLines]',
template: `
<svg:g [attr.visibility]="hide ? 'hidden' : ''">
<path
[attr.d]="path"
fill="none"
[attr.stroke-width]="width || 1"
[attr.stroke]="color || '#ccc'"
[attr.stroke-dasharray]="dasharray"
/>
<circle
*ngFor="let point of circleValue"
[attr.r]="2.5"
[attr.stroke]="point.color"
[attr.stroke-width]="1"
[attr.fill]="point.color"
[attr.cx]="point.cx"
[attr.cy]="point.cy < 0 ? 0 : point.cy || 0"
[attr.visibility]="point.visibility"
></circle>
</svg:g>
`,
changeDetection: ChangeDetectionStrategy.OnPush,
}]
}], () => [{ type: i1.ContextChartService }, { type: i0.ChangeDetectorRef }], { value: [{
type: Input
}], value$: [], color: [{
type: Input
}], dashType: [{
type: Input
}], width: [{
type: Input
}], hide: [{
type: Input
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(YPlotLinesComponent, { className: "YPlotLinesComponent" }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"y-plot-lines.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/axis/y-plot-lines.component.ts"],"names":[],"mappings":";AAAA,OAAO,EACL,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,KAAK,GAGN,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,UAAU,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAE7E,OAAO,EAAE,eAAe,EAAE,MAAM,0BAA0B,CAAC;AAC3D,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;;;;;;;IAgBpD,yBASU;;;;;AAKhB,MAAM,OAAO,mBAAmB;IAuB9B,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,QAAQ,KAAK,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;IACpD,CAAC;IAED,IAAI,IAAI;QACN,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;IAChC,CAAC;IAID,YACkB,OAA4B,EAC3B,GAAsB;QADvB,YAAO,GAAP,OAAO,CAAqB;QAC3B,QAAG,GAAH,GAAG,CAAmB;QA5BhC,aAAQ,GAAqB,MAAM,CAAC;QAIpC,SAAI,GAAG,KAAK,CAAC;QAEtB,SAAI,GAAG,EAAE,CAAC;QAEV,gBAAW,GAMN,EAAE,CAAC;QAUS,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAK9C,CAAC;IAEJ,QAAQ;QACN,aAAa,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;aACnD,IAAI,CACH,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,EAC9C,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAC1B;aACA,SAAS,CAAC,GAAG,EAAE;YACd,MAAM,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAc,CAAC,CAAC;YACvD,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;gBAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;oBACzC,KAAK,EAAE,IAAI,CAAC,KAAK;oBACjB,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAc,CAAC;oBACvC,EAAE,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;oBAC1B,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;wBACpD,CAAC,CAAC,QAAQ;wBACV,CAAC,CAAC,EAAE;oBACN,IAAI,EAAE,IAAI,CAAC,IAAI;iBAChB,CAAC,CAAC,CAAC;YACN,CAAC;YACD,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;QAEL,IAAI,CAAC,OAAO,CAAC,cAAc;aACxB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;gBAC/C,GAAG,IAAI;gBACP,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC;oBACpD,CAAC,CAAC,QAAQ;oBACV,CAAC,CAAC,EAAE;aACP,CAAC,CAAC,CAAC;YACJ,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;oFA7EU,mBAAmB;oEAAnB,mBAAmB;;YAtB5B,yBAAgD;YAC9C,0BAME;YACF,+EASC;YACH,iBAAQ;;;YAhBJ,cAAe;;YAOG,cAAc;YAAd,yCAAc;;;AAgBtC;IADC,eAAe,EAAE;8BACT,UAAU;mDAAgB;iFAHxB,mBAAmB;cA1B/B,SAAS;eAAC;gBACT,8DAA8D;gBAC9D,QAAQ,EAAE,kBAAkB;gBAC5B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;GAoBT;gBACD,eAAe,EAAE,uBAAuB,CAAC,MAAM;aAChD;oFAEU,KAAK;kBAAb,KAAK;YAEN,MAAM,MAEG,KAAK;kBAAb,KAAK;YAEG,QAAQ;kBAAhB,KAAK;YAEG,KAAK;kBAAb,KAAK;YAEG,IAAI;kBAAZ,KAAK;;kFAXK,mBAAmB","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport { Observable, Subject, combineLatest, filter, takeUntil } from 'rxjs';\n\nimport { ObservableInput } from '../../../core/public-api';\nimport { ContextChartService } from '../../chart.service';\nimport { TickValue } from '../../types';\nimport { ContextItem } from '../tooltip/tooltip.component';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'g[aclYPlotLines]',\n  template: `\n    <svg:g [attr.visibility]=\"hide ? 'hidden' : ''\">\n      <path\n        [attr.d]=\"path\"\n        fill=\"none\"\n        [attr.stroke-width]=\"width || 1\"\n        [attr.stroke]=\"color || '#ccc'\"\n        [attr.stroke-dasharray]=\"dasharray\"\n      />\n      <circle\n        *ngFor=\"let point of circleValue\"\n        [attr.r]=\"2.5\"\n        [attr.stroke]=\"point.color\"\n        [attr.stroke-width]=\"1\"\n        [attr.fill]=\"point.color\"\n        [attr.cx]=\"point.cx\"\n        [attr.cy]=\"point.cy < 0 ? 0 : point.cy || 0\"\n        [attr.visibility]=\"point.visibility\"\n      ></circle>\n    </svg:g>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class YPlotLinesComponent implements OnInit, OnDestroy {\n  @Input() value: ContextItem[];\n  @ObservableInput()\n  value$!: Observable<ContextItem[]>;\n\n  @Input() color: string;\n\n  @Input() dashType: 'solid' | 'dash' = 'dash';\n\n  @Input() width: number;\n\n  @Input() hide = false;\n\n  path = '';\n\n  circleValue: Array<{\n    color: string;\n    cx: number;\n    cy: number;\n    visibility: string;\n    name: string;\n  }> = [];\n\n  get dasharray() {\n    return this.dashType === 'dash' ? [3, 2] : [0, 0];\n  }\n\n  get view() {\n    return this.context.chartView;\n  }\n\n  private readonly destroy$$ = new Subject<void>();\n\n  constructor(\n    public readonly context: ContextChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit() {\n    combineLatest([this.value$, this.context.seriesData$])\n      .pipe(\n        filter(([value]) => !!value && !!value.length),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe(() => {\n        const x = this.context.x(this.value[0].x as TickValue);\n        if (x && this.view.height) {\n          this.path = `M${x},0 L${x} ${this.view.height}`;\n          this.circleValue = this.value.map(item => ({\n            color: item.color,\n            cx: this.context.x(item.x as TickValue),\n            cy: this.context.y(item.y),\n            visibility: this.context.disabledLegend.has(item.name)\n              ? 'hidden'\n              : '',\n            name: item.name,\n          }));\n        }\n        this.cdr.detectChanges();\n      });\n\n    this.context.legendChange$$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(() => {\n        this.circleValue = this.circleValue.map(item => ({\n          ...item,\n          visibility: this.context.disabledLegend.has(item.name)\n            ? 'hidden'\n            : '',\n        }));\n        this.cdr.detectChanges();\n      });\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n}\n"]}