UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

146 lines 20.7 kB
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, ViewChild, } from '@angular/core'; import { curveMonotoneX, line, } from 'd3'; import { Subject } from 'rxjs'; import { ContextChartService } from '../../chart.service'; import { defined } from '../../utils'; import * as i0 from "@angular/core"; import * as i1 from "../../chart.service"; import * as i2 from "@angular/common"; import * as i3 from "../../../effect-directive/e2e-attribute-binding.directive"; const _c0 = ["rect"]; const _c1 = ["aclRangeArea", ""]; function RangeAreaComponent__svg_path_4_Template(rf, ctx) { if (rf & 1) { const _r2 = i0.ɵɵgetCurrentView(); i0.ɵɵnamespaceSVG(); i0.ɵɵelementStart(0, "path", 4); i0.ɵɵlistener("mousedown", function RangeAreaComponent__svg_path_4_Template_path_mousedown_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(); const rect_r4 = i0.ɵɵreference(2); return i0.ɵɵresetView(ctx_r2.mouseDown($event, rect_r4)); })("mouseup", function RangeAreaComponent__svg_path_4_Template_path_mouseup_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(); const rect_r4 = i0.ɵɵreference(2); return i0.ɵɵresetView(ctx_r2.mouseUp($event, rect_r4)); })("mousemove", function RangeAreaComponent__svg_path_4_Template_path_mousemove_0_listener($event) { const item_r5 = i0.ɵɵrestoreView(_r2).$implicit; const ctx_r2 = i0.ɵɵnextContext(); const rect_r4 = i0.ɵɵreference(2); !ctx_r2.context.noData && ctx_r2.mouseMove($event, rect_r4); return i0.ɵɵresetView(ctx_r2.lineOnMouseMove(item_r5)); })("mouseleave", function RangeAreaComponent__svg_path_4_Template_path_mouseleave_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r2.lineOnMouseLeave($event)); })("click", function RangeAreaComponent__svg_path_4_Template_path_click_0_listener($event) { i0.ɵɵrestoreView(_r2); const ctx_r2 = i0.ɵɵnextContext(); const rect_r4 = i0.ɵɵreference(2); return i0.ɵɵresetView(ctx_r2.areaClickEvent($event, rect_r4)); }); i0.ɵɵelementEnd(); } if (rf & 2) { const item_r5 = ctx.$implicit; i0.ɵɵstyleProp("opacity", 0); i0.ɵɵattribute("d", item_r5.path)("stroke-width", 10)("visibility", item_r5.visibility); } } export class RangeAreaComponent { constructor(context, cdr) { this.context = context; this.cdr = cdr; this.mouseMoveEvent = new EventEmitter(); this.mouseLeaveEvent = new EventEmitter(); this.mouseDownEvent = new EventEmitter(); this.mouseUpEvent = new EventEmitter(); this.clickEvent = new EventEmitter(); this.destroy$$ = new Subject(); this.view = { width: 0, height: 0, }; } ngOnInit() { this.context.update$$.subscribe(() => { this.view = this.context.chartView; this.cdr.detectChanges(); }); } mouseDown(e, rectDom) { this.mouseDownEvent.next({ e, rectDom, }); } mouseUp(e, rectDom) { this.mouseUpEvent.next({ e, rectDom, }); } mouseMove(e, rectDom) { this.mouseMoveEvent.next({ e, rectDom, }); } mouseLeave(e) { if (this.allowLeave(e)) { this.mouseLeaveEvent.next(e); this.context.legendActivate$$.next(''); } } lineOnMouseMove(line) { this.context.legendActivate$$.next(line.name); } lineOnMouseLeave(e) { if (this.allowLeave(e)) { this.mouseLeaveEvent.next(e); } this.context.legendActivate$$.next(''); } areaClickEvent(e, rectDom) { this.clickEvent.next({ e, rectDom, }); } allowLeave(e) { const svgE = this.rectEl.nativeElement; const { left, top } = e.target.getBoundingClientRect(); const { width, height } = svgE.getBoundingClientRect(); const x = e.pageX - left; const y = e.y - top; // 判断触发 leave 是移入 line 触发还是 移出 area (只有移出 area 再触发 leave) return x < 0 || x > width || y > height || y < 0; } getLineGenerator() { const { x, y } = this.context; return line() .defined(defined) .curve(this.curveType || curveMonotoneX) .x(d => x(d.x)) .y(d => y(d.y) || 0); } ngOnDestroy() { this.destroy$$.next(); } static { this.ɵfac = function RangeAreaComponent_Factory(t) { return new (t || RangeAreaComponent)(i0.ɵɵdirectiveInject(i1.ContextChartService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; } static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: RangeAreaComponent, selectors: [["g", "aclRangeArea", ""]], viewQuery: function RangeAreaComponent_Query(rf, ctx) { if (rf & 1) { i0.ɵɵviewQuery(_c0, 5); } if (rf & 2) { let _t; i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.rectEl = _t.first); } }, inputs: { curveType: "curveType" }, outputs: { mouseMoveEvent: "mouseMoveEvent", mouseLeaveEvent: "mouseLeaveEvent", mouseDownEvent: "mouseDownEvent", mouseUpEvent: "mouseUpEvent", clickEvent: "clickEvent" }, attrs: _c1, decls: 6, vars: 6, consts: [["rect", ""], ["y", "0", 1, "zoom-area", 2, "opacity", "0", "cursor", "'auto'", 3, "mousedown", "mouseup", "mousemove", "mouseleave", "click"], [1, "acl-series"], ["class", "line", "stroke", "#999", "fill", "none", 3, "opacity", "mousedown", "mouseup", "mousemove", "mouseleave", "click", 4, "ngFor", "ngForOf"], ["stroke", "#999", "fill", "none", 1, "line", 3, "mousedown", "mouseup", "mousemove", "mouseleave", "click"]], template: function RangeAreaComponent_Template(rf, ctx) { if (rf & 1) { const _r1 = i0.ɵɵgetCurrentView(); i0.ɵɵnamespaceSVG(); i0.ɵɵelementStart(0, "g")(1, "rect", 1, 0); i0.ɵɵlistener("mousedown", function RangeAreaComponent_Template_rect_mousedown_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.mouseDown($event)); })("mouseup", function RangeAreaComponent_Template_rect_mouseup_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.mouseUp($event)); })("mousemove", function RangeAreaComponent_Template_rect_mousemove_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(!ctx.context.noData && ctx.mouseMove($event)); })("mouseleave", function RangeAreaComponent_Template_rect_mouseleave_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.mouseLeave($event)); })("click", function RangeAreaComponent_Template_rect_click_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.areaClickEvent($event)); }); i0.ɵɵelementEnd(); i0.ɵɵelementStart(3, "g", 2); i0.ɵɵtemplate(4, RangeAreaComponent__svg_path_4_Template, 1, 5, "path", 3); i0.ɵɵpipe(5, "async"); i0.ɵɵelementEnd()(); } if (rf & 2) { i0.ɵɵadvance(); i0.ɵɵattribute("x", 0)("width", ctx.view == null ? null : ctx.view.width)("height", ctx.view == null ? null : ctx.view.height); i0.ɵɵadvance(3); i0.ɵɵproperty("ngForOf", i0.ɵɵpipeBind1(5, 4, ctx.context.seriesData$)); } }, dependencies: [i2.NgForOf, i3.E2eAttributeBindingDirective, i2.AsyncPipe], encapsulation: 2, changeDetection: 0 }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(RangeAreaComponent, [{ type: Component, args: [{ selector: 'g[aclRangeArea]', changeDetection: ChangeDetectionStrategy.OnPush, template: "<svg:g>\n <svg:rect\n #rect\n class=\"zoom-area\"\n [attr.x]=\"0\"\n y=\"0\"\n [attr.width]=\"view?.width\"\n [attr.height]=\"view?.height\"\n style=\"opacity: 0; cursor: 'auto'\"\n (mousedown)=\"mouseDown($event)\"\n (mouseup)=\"mouseUp($event)\"\n (mousemove)=\"!context.noData && mouseMove($event)\"\n (mouseleave)=\"mouseLeave($event)\"\n (click)=\"areaClickEvent($event)\"\n />\n <svg:g class=\"acl-series\">\n <svg:path\n class=\"line\"\n *ngFor=\"let item of context.seriesData$ | async\"\n [attr.d]=\"item.path\"\n stroke=\"#999\"\n fill=\"none\"\n [style.opacity]=\"0\"\n [attr.stroke-width]=\"10\"\n [attr.visibility]=\"item.visibility\"\n (mousedown)=\"mouseDown($event, rect)\"\n (mouseup)=\"mouseUp($event, rect)\"\n (mousemove)=\"\n !context.noData && mouseMove($event, rect); lineOnMouseMove(item)\n \"\n (mouseleave)=\"lineOnMouseLeave($event)\"\n (click)=\"areaClickEvent($event, rect)\"\n ></svg:path>\n </svg:g>\n</svg:g>\n" }] }], () => [{ type: i1.ContextChartService }, { type: i0.ChangeDetectorRef }], { rectEl: [{ type: ViewChild, args: ['rect'] }], curveType: [{ type: Input }], mouseMoveEvent: [{ type: Output }], mouseLeaveEvent: [{ type: Output }], mouseDownEvent: [{ type: Output }], mouseUpEvent: [{ type: Output }], clickEvent: [{ type: Output }] }); })(); (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(RangeAreaComponent, { className: "RangeAreaComponent" }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range-area.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/range-area/range-area.component.ts","../../../../../../../libs/common/src/chart/common/range-area/range-area.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n} from '@angular/core';\nimport {\n  CurveFactory,\n  CurveFactoryLineOnly,\n  ScaleTime,\n  curveMonotoneX,\n  line,\n} from 'd3';\nimport { Subject } from 'rxjs';\n\nimport { ChartData, ChartDataItem } from '../../../view-chart/types';\nimport { ContextChartService } from '../../chart.service';\nimport { SeriesData } from '../../types';\nimport { defined } from '../../utils';\n\ninterface LineData extends ChartData {\n  width: 3;\n  path: string;\n  visibility: string;\n}\n\nexport interface AreaMouseEvent {\n  e: MouseEvent;\n  rectDom?: HTMLElement;\n}\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'g[aclRangeArea]',\n  templateUrl: './range-area.component.html',\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class RangeAreaComponent implements OnInit, OnDestroy {\n  @ViewChild('rect') rectEl: ElementRef;\n\n  @Input() curveType: CurveFactory | CurveFactoryLineOnly;\n\n  @Output() mouseMoveEvent = new EventEmitter<AreaMouseEvent>();\n\n  @Output() mouseLeaveEvent = new EventEmitter<MouseEvent>();\n\n  @Output() mouseDownEvent = new EventEmitter<AreaMouseEvent>();\n\n  @Output() mouseUpEvent = new EventEmitter<AreaMouseEvent>();\n\n  @Output() clickEvent = new EventEmitter<AreaMouseEvent>();\n\n  destroy$$ = new Subject<void>();\n\n  view = {\n    width: 0,\n    height: 0,\n  };\n\n  constructor(\n    public readonly context: ContextChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  lineData: LineData[];\n\n  ngOnInit() {\n    this.context.update$$.subscribe(() => {\n      this.view = this.context.chartView;\n      this.cdr.detectChanges();\n    });\n  }\n\n  mouseDown(e: MouseEvent, rectDom?: HTMLElement) {\n    this.mouseDownEvent.next({\n      e,\n      rectDom,\n    });\n  }\n\n  mouseUp(e: MouseEvent, rectDom?: HTMLElement) {\n    this.mouseUpEvent.next({\n      e,\n      rectDom,\n    });\n  }\n\n  mouseMove(e: MouseEvent, rectDom?: HTMLElement) {\n    this.mouseMoveEvent.next({\n      e,\n      rectDom,\n    });\n  }\n\n  mouseLeave(e: MouseEvent) {\n    if (this.allowLeave(e)) {\n      this.mouseLeaveEvent.next(e);\n      this.context.legendActivate$$.next('');\n    }\n  }\n\n  lineOnMouseMove(line: SeriesData) {\n    this.context.legendActivate$$.next(line.name);\n  }\n\n  lineOnMouseLeave(e: MouseEvent) {\n    if (this.allowLeave(e)) {\n      this.mouseLeaveEvent.next(e);\n    }\n    this.context.legendActivate$$.next('');\n  }\n\n  areaClickEvent(e: MouseEvent, rectDom?: HTMLElement) {\n    this.clickEvent.next({\n      e,\n      rectDom,\n    });\n  }\n\n  allowLeave(e: MouseEvent) {\n    const svgE = this.rectEl.nativeElement as SVGRectElement;\n    const { left, top } = (e.target as SVGRectElement).getBoundingClientRect();\n    const { width, height } = svgE.getBoundingClientRect();\n    const x = e.pageX - left;\n    const y = e.y - top;\n    // 判断触发 leave 是移入 line 触发还是 移出 area (只有移出 area 再触发 leave)\n    return x < 0 || x > width || y > height || y < 0;\n  }\n\n  getLineGenerator() {\n    const { x, y } = this.context;\n    return line<ChartDataItem>()\n      .defined(defined)\n      .curve(this.curveType || curveMonotoneX)\n      .x(d => (<ScaleTime<number, number>>x)(d.x as number))\n      .y(d => y(d.y) || 0);\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$$.next();\n  }\n}\n","<svg:g>\n  <svg:rect\n    #rect\n    class=\"zoom-area\"\n    [attr.x]=\"0\"\n    y=\"0\"\n    [attr.width]=\"view?.width\"\n    [attr.height]=\"view?.height\"\n    style=\"opacity: 0; cursor: 'auto'\"\n    (mousedown)=\"mouseDown($event)\"\n    (mouseup)=\"mouseUp($event)\"\n    (mousemove)=\"!context.noData && mouseMove($event)\"\n    (mouseleave)=\"mouseLeave($event)\"\n    (click)=\"areaClickEvent($event)\"\n  />\n  <svg:g class=\"acl-series\">\n    <svg:path\n      class=\"line\"\n      *ngFor=\"let item of context.seriesData$ | async\"\n      [attr.d]=\"item.path\"\n      stroke=\"#999\"\n      fill=\"none\"\n      [style.opacity]=\"0\"\n      [attr.stroke-width]=\"10\"\n      [attr.visibility]=\"item.visibility\"\n      (mousedown)=\"mouseDown($event, rect)\"\n      (mouseup)=\"mouseUp($event, rect)\"\n      (mousemove)=\"\n        !context.noData && mouseMove($event, rect); lineOnMouseMove(item)\n      \"\n      (mouseleave)=\"lineOnMouseLeave($event)\"\n      (click)=\"areaClickEvent($event, rect)\"\n    ></svg:path>\n  </svg:g>\n</svg:g>\n"]}