@alauda-fe/common
Version:
Alauda frontend team common codes.
146 lines • 20.7 kB
JavaScript
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"]}