@alauda-fe/common
Version:
Alauda frontend team common codes.
235 lines (234 loc) • 19.4 kB
JavaScript
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
import { Subject, merge, map, takeUntil } from 'rxjs';
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 = ["aclYAxisTicks", ""];
function YAxisTicksComponent_ng_container_0__svg_g_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(0, "g")(1, "text", 4);
i0.ɵɵtext(2);
i0.ɵɵpipe(3, "pure");
i0.ɵɵelementEnd();
i0.ɵɵelement(4, "line", 5)(5, "line", 6);
i0.ɵɵelementEnd();
} if (rf & 2) {
const tick_r1 = ctx.$implicit;
const ctx_r1 = i0.ɵɵnextContext(2);
i0.ɵɵadvance();
i0.ɵɵattribute("y", tick_r1.y);
i0.ɵɵadvance();
i0.ɵɵtextInterpolate2(" ", i0.ɵɵpipeBind2(3, 8, tick_r1.value, ctx_r1.conversionMaximum), "", ctx_r1.suffix, " ");
i0.ɵɵadvance(2);
i0.ɵɵattribute("y1", tick_r1.y)("y2", tick_r1.y);
i0.ɵɵadvance();
i0.ɵɵattribute("x2", ctx_r1.context == null ? null : ctx_r1.context.chartView == null ? null : ctx_r1.context.chartView.width)("y1", tick_r1.y)("y2", tick_r1.y);
} }
function YAxisTicksComponent_ng_container_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelementContainerStart(0);
i0.ɵɵtemplate(1, YAxisTicksComponent_ng_container_0__svg_g_1_Template, 6, 11, "g", 2);
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(2, "g");
i0.ɵɵelement(3, "path", 3);
i0.ɵɵelementEnd();
i0.ɵɵelementContainerEnd();
} if (rf & 2) {
const ctx_r1 = i0.ɵɵnextContext();
i0.ɵɵadvance();
i0.ɵɵproperty("ngForOf", ctx_r1.ticks);
i0.ɵɵadvance(2);
i0.ɵɵattribute("d", ctx_r1.yAxisLine);
} }
function YAxisTicksComponent_ng_template_1__svg_g_0__svg_line_4_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelement(0, "line", 9);
} if (rf & 2) {
const tick_r3 = i0.ɵɵnextContext().$implicit;
const ctx_r1 = i0.ɵɵnextContext(2);
i0.ɵɵattribute("x1", tick_r3.x)("x2", tick_r3.x)("y1", 0)("y2", -(ctx_r1.context == null ? null : ctx_r1.context.chartView == null ? null : ctx_r1.context.chartView.height));
} }
function YAxisTicksComponent_ng_template_1__svg_g_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(0, "g")(1, "text", 7);
i0.ɵɵtext(2);
i0.ɵɵpipe(3, "pure");
i0.ɵɵelementEnd();
i0.ɵɵtemplate(4, YAxisTicksComponent_ng_template_1__svg_g_0__svg_line_4_Template, 1, 4, "line", 8);
i0.ɵɵelementEnd();
} if (rf & 2) {
const tick_r3 = ctx.$implicit;
const i_r4 = ctx.index;
const ctx_r1 = i0.ɵɵnextContext(2);
i0.ɵɵadvance();
i0.ɵɵattribute("x", i_r4 === 0 && ctx_r1.suffix ? tick_r3.x - 5 : tick_r3.x)("y", tick_r3.y + 16)("text-anchor", ctx_r1.textAnchor);
i0.ɵɵadvance();
i0.ɵɵtextInterpolate2(" ", i0.ɵɵpipeBind2(3, 6, tick_r3.value, ctx_r1.conversionMaximum), "", ctx_r1.suffix, " ");
i0.ɵɵadvance(2);
i0.ɵɵproperty("ngIf", i_r4 !== ctx_r1.ticks.length - 1);
} }
function YAxisTicksComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, YAxisTicksComponent_ng_template_1__svg_g_0_Template, 5, 9, "g", 2);
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(1, "g");
i0.ɵɵelement(2, "path", 3);
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r1 = i0.ɵɵnextContext();
i0.ɵɵproperty("ngForOf", ctx_r1.ticks);
i0.ɵɵadvance(2);
i0.ɵɵattribute("d", ctx_r1.xAxisLine);
} }
export class YAxisTicksComponent {
get yAxisLine() {
return `M${0} ${0}L${0} ${this.context.chartView.height}Z`;
}
get xAxisLine() {
const { width } = this.context.chartView;
return `M0 0L${width} 0Z`;
}
getTicks() {
const ticks = this.context.y.ticks(this.getMaxTicks(this.intervalWidth));
return ticks.map(value => {
const res = this.context.y(value);
return {
value,
y: this.context.horizontal ? 0 : res,
x: res,
};
});
}
getMaxTicks(tickHeight) {
const height = this.context.horizontal
? this.context.chartView.width
: this.context.chartView.height;
return Math.floor(height / tickHeight);
}
constructor(context, cd) {
this.context = context;
this.cd = cd;
this.intervalWidth = 40;
this.orientation = Orientation;
this.textAnchor = 'middle';
this.destroy$$ = new Subject();
}
ngOnInit() {
this.ticks = this.getTicks();
this.cd.detectChanges();
merge(this.context.seriesData$, this.context.legendChange$$)
.pipe(takeUntil(this.destroy$$), map(() => this.getTicks()))
.subscribe(res => {
this.ticks = res;
this.cd.detectChanges();
});
}
conversionMaximum(value) {
const unit = 'k';
if (value >= 1000) {
const num = +(value / 1000).toFixed(2);
return `${num}${unit}`;
}
return value;
}
ngOnDestroy() {
this.destroy$$.next();
}
static { this.ɵfac = function YAxisTicksComponent_Factory(t) { return new (t || YAxisTicksComponent)(i0.ɵɵdirectiveInject(i1.ContextChartService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: YAxisTicksComponent, selectors: [["g", "aclYAxisTicks", ""]], inputs: { intervalWidth: "intervalWidth", suffix: "suffix" }, attrs: _c0, decls: 3, vars: 2, consts: [["elseTemplate", ""], [4, "ngIf", "ngIfElse"], [4, "ngFor", "ngForOf"], ["stroke", "#ccd6eb", "fill", "none"], ["x", "-8", "fill", "#666", "text-anchor", "end", "font-size", "11", "alignment-baseline", "middle"], ["x1", "-4", "x2", "0", "stroke-width", "1", "stroke", "#ccd6eb"], ["x1", "0", "stroke-width", "1", "stroke-dasharray", "4 1", "stroke", "#e8e8e8"], ["fill", "#666", "font-size", "11"], ["stroke-width", "1", "stroke-dasharray", "4 1", "stroke", "#e8e8e8", 4, "ngIf"], ["stroke-width", "1", "stroke-dasharray", "4 1", "stroke", "#e8e8e8"]], template: function YAxisTicksComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, YAxisTicksComponent_ng_container_0_Template, 4, 2, "ng-container", 1)(1, YAxisTicksComponent_ng_template_1_Template, 3, 2, "ng-template", null, 0, i0.ɵɵtemplateRefExtractor);
} if (rf & 2) {
const elseTemplate_r5 = i0.ɵɵreference(2);
i0.ɵɵproperty("ngIf", ctx.context.barOptions.orientation === ctx.orientation.VERTICAL)("ngIfElse", elseTemplate_r5);
} }, dependencies: [i2.NgForOf, i2.NgIf, i3.PurePipe], encapsulation: 2, changeDetection: 0 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(YAxisTicksComponent, [{
type: Component,
args: [{
// eslint-disable-next-line @angular-eslint/component-selector
selector: 'g[aclYAxisTicks]',
template: `
<ng-container
*ngIf="
context.barOptions.orientation === orientation.VERTICAL;
else elseTemplate
"
>
<svg:g *ngFor="let tick of ticks">
<text
x="-8"
[attr.y]="tick.y"
fill="#666"
text-anchor="end"
font-size="11"
alignment-baseline="middle"
>
{{ tick.value | pure: conversionMaximum }}{{ suffix }}
</text>
<line
x1="-4"
x2="0"
[attr.y1]="tick.y"
[attr.y2]="tick.y"
stroke-width="1"
stroke="#ccd6eb"
></line>
<line
x1="0"
[attr.x2]="context?.chartView?.width"
[attr.y1]="tick.y"
[attr.y2]="tick.y"
stroke-width="1"
stroke-dasharray="4 1"
stroke="#e8e8e8"
></line>
</svg:g>
<svg:g>
<path
[attr.d]="yAxisLine"
stroke="#ccd6eb"
fill="none"
/>
</svg:g>
</ng-container>
<ng-template #elseTemplate>
<svg:g *ngFor="let tick of ticks; let i = index">
<text
[attr.x]="i === 0 && suffix ? tick.x - 5 : tick.x"
[attr.y]="tick.y + 16"
fill="#666"
[attr.text-anchor]="textAnchor"
font-size="11"
>
{{ tick.value | pure: conversionMaximum }}{{ suffix }}
</text>
<line
*ngIf="i !== ticks.length - 1"
[attr.x1]="tick.x"
[attr.x2]="tick.x"
[attr.y1]="0"
[attr.y2]="-context?.chartView?.height"
stroke-width="1"
stroke-dasharray="4 1"
stroke="#e8e8e8"
></line>
</svg:g>
<svg:g>
<path
[attr.d]="xAxisLine"
stroke="#ccd6eb"
fill="none"
/>
</svg:g>
</ng-template>
`,
changeDetection: ChangeDetectionStrategy.OnPush,
}]
}], () => [{ type: i1.ContextChartService }, { type: i0.ChangeDetectorRef }], { intervalWidth: [{
type: Input
}], suffix: [{
type: Input
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(YAxisTicksComponent, { className: "YAxisTicksComponent" }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"y-axis-ticks.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/axis/y-axis-ticks.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 { Subject, merge, map, takeUntil } from 'rxjs';\n\nimport { ContextChartService } from '../../chart.service';\nimport { Orientation } from '../../types';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'g[aclYAxisTicks]',\n  template: `\n    <ng-container\n      *ngIf=\"\n        context.barOptions.orientation === orientation.VERTICAL;\n        else elseTemplate\n      \"\n    >\n      <svg:g *ngFor=\"let tick of ticks\">\n        <text\n          x=\"-8\"\n          [attr.y]=\"tick.y\"\n          fill=\"#666\"\n          text-anchor=\"end\"\n          font-size=\"11\"\n          alignment-baseline=\"middle\"\n        >\n          {{ tick.value | pure: conversionMaximum }}{{ suffix }}\n        </text>\n        <line\n          x1=\"-4\"\n          x2=\"0\"\n          [attr.y1]=\"tick.y\"\n          [attr.y2]=\"tick.y\"\n          stroke-width=\"1\"\n          stroke=\"#ccd6eb\"\n        ></line>\n        <line\n          x1=\"0\"\n          [attr.x2]=\"context?.chartView?.width\"\n          [attr.y1]=\"tick.y\"\n          [attr.y2]=\"tick.y\"\n          stroke-width=\"1\"\n          stroke-dasharray=\"4 1\"\n          stroke=\"#e8e8e8\"\n        ></line>\n      </svg:g>\n      <svg:g>\n        <path\n          [attr.d]=\"yAxisLine\"\n          stroke=\"#ccd6eb\"\n          fill=\"none\"\n        />\n      </svg:g>\n    </ng-container>\n\n    <ng-template #elseTemplate>\n      <svg:g *ngFor=\"let tick of ticks; let i = index\">\n        <text\n          [attr.x]=\"i === 0 && suffix ? tick.x - 5 : tick.x\"\n          [attr.y]=\"tick.y + 16\"\n          fill=\"#666\"\n          [attr.text-anchor]=\"textAnchor\"\n          font-size=\"11\"\n        >\n          {{ tick.value | pure: conversionMaximum }}{{ suffix }}\n        </text>\n        <line\n          *ngIf=\"i !== ticks.length - 1\"\n          [attr.x1]=\"tick.x\"\n          [attr.x2]=\"tick.x\"\n          [attr.y1]=\"0\"\n          [attr.y2]=\"-context?.chartView?.height\"\n          stroke-width=\"1\"\n          stroke-dasharray=\"4 1\"\n          stroke=\"#e8e8e8\"\n        ></line>\n      </svg:g>\n      <svg:g>\n        <path\n          [attr.d]=\"xAxisLine\"\n          stroke=\"#ccd6eb\"\n          fill=\"none\"\n        />\n      </svg:g>\n    </ng-template>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class YAxisTicksComponent implements OnInit, OnDestroy {\n  @Input() intervalWidth = 40;\n\n  @Input() suffix: string;\n\n  ticks: Array<{ value: number; y: number; x: number }>;\n  orientation = Orientation;\n  textAnchor = 'middle';\n\n  destroy$$ = new Subject<void>();\n\n  get yAxisLine() {\n    return `M${0} ${0}L${0} ${this.context.chartView.height}Z`;\n  }\n\n  get xAxisLine() {\n    const { width } = this.context.chartView;\n    return `M0 0L${width} 0Z`;\n  }\n\n  getTicks() {\n    const ticks = this.context.y.ticks(this.getMaxTicks(this.intervalWidth));\n    return ticks.map(value => {\n      const res = this.context.y(value);\n      return {\n        value,\n        y: this.context.horizontal ? 0 : res,\n        x: res,\n      };\n    });\n  }\n\n  getMaxTicks(tickHeight: number): number {\n    const height = this.context.horizontal\n      ? this.context.chartView.width\n      : this.context.chartView.height;\n    return Math.floor(height / tickHeight);\n  }\n\n  constructor(\n    public readonly context: ContextChartService,\n    private readonly cd: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit() {\n    this.ticks = this.getTicks();\n    this.cd.detectChanges();\n    merge(this.context.seriesData$, this.context.legendChange$$)\n      .pipe(\n        takeUntil(this.destroy$$),\n        map(() => this.getTicks()),\n      )\n      .subscribe(res => {\n        this.ticks = res;\n        this.cd.detectChanges();\n      });\n  }\n\n  conversionMaximum(value: number) {\n    const unit = 'k';\n    if (value >= 1000) {\n      const num = +(value / 1000).toFixed(2);\n      return `${num}${unit}`;\n    }\n    return value;\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n"]}