UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

127 lines 13.8 kB
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":"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","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"]}