@alauda-fe/common
Version:
Alauda frontend team common codes.
214 lines (213 loc) • 18.3 kB
JavaScript
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from '@angular/core';
import dayjs from 'dayjs';
import { map } from 'rxjs';
import { ContextChartService } from '../../chart.service';
import { Orientation } from '../../types';
import { ScaleType, reduceTicks } from '../../utils';
import * as i0 from "@angular/core";
import * as i1 from "../../chart.service";
import * as i2 from "@angular/common";
import * as i3 from "../../../translate/translate.pipe";
const _c0 = ["aclXAxisTicks", ""];
function XAxisTicksComponent_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, "translate");
i0.ɵɵelementEnd();
i0.ɵɵelement(4, "line", 5);
i0.ɵɵelementEnd();
} if (rf & 2) {
const tick_r1 = ctx.$implicit;
const i_r2 = ctx.index;
const ctx_r2 = i0.ɵɵnextContext(2);
i0.ɵɵadvance();
i0.ɵɵattribute("x", i_r2 === ctx_r2.ticks.length - 1 && tick_r1.x >= (ctx_r2.context.chartView == null ? null : ctx_r2.context.chartView.height) ? tick_r1.x - 5 : tick_r1.x)("y", tick_r1.y + 16)("text-anchor", ctx_r2.textAnchor);
i0.ɵɵadvance();
i0.ɵɵtextInterpolate1(" ", ctx_r2.translation ? i0.ɵɵpipeBind1(3, 8, tick_r1.value) : tick_r1.value, " ");
i0.ɵɵadvance(2);
i0.ɵɵattribute("x1", tick_r1.x)("x2", tick_r1.x)("y1", tick_r1.y)("y2", tick_r1.y + 6);
} }
function XAxisTicksComponent_ng_container_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵelementContainerStart(0);
i0.ɵɵtemplate(1, XAxisTicksComponent_ng_container_0__svg_g_1_Template, 5, 10, "g", 2);
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(2, "g");
i0.ɵɵelement(3, "path", 3);
i0.ɵɵelementEnd();
i0.ɵɵelementContainerEnd();
} if (rf & 2) {
const ctx_r2 = i0.ɵɵnextContext();
i0.ɵɵadvance();
i0.ɵɵproperty("ngForOf", ctx_r2.ticks);
i0.ɵɵadvance(2);
i0.ɵɵattribute("d", ctx_r2.xAxisLine);
} }
function XAxisTicksComponent_ng_template_1__svg_g_0_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(0, "g")(1, "text", 6);
i0.ɵɵtext(2);
i0.ɵɵpipe(3, "translate");
i0.ɵɵpipe(4, "translate");
i0.ɵɵelementEnd()();
} if (rf & 2) {
const tick_r4 = ctx.$implicit;
const ctx_r2 = i0.ɵɵnextContext(2);
i0.ɵɵadvance();
i0.ɵɵattribute("y", tick_r4.x);
i0.ɵɵadvance();
i0.ɵɵtextInterpolate1(" ", ctx_r2.translation ? i0.ɵɵpipeBind1(4, 4, i0.ɵɵpipeBind1(3, 2, tick_r4.value)) : tick_r4.value, " ");
} }
function XAxisTicksComponent_ng_template_1_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, XAxisTicksComponent_ng_template_1__svg_g_0_Template, 5, 6, "g", 2);
i0.ɵɵnamespaceSVG();
i0.ɵɵelementStart(1, "g");
i0.ɵɵelement(2, "path", 3);
i0.ɵɵelementEnd();
} if (rf & 2) {
const ctx_r2 = i0.ɵɵnextContext();
i0.ɵɵproperty("ngForOf", ctx_r2.ticks);
i0.ɵɵadvance(2);
i0.ɵɵattribute("d", ctx_r2.yAxisLine);
} }
export class XAxisTicksComponent {
get context() {
return this.contextService;
}
get yAxisLine() {
return `M${0} ${0}L${0} ${this.context.chartView.height}Z`;
}
get xAxisLine() {
const { width } = this.contextService.chartView;
return `M0 0L${width} 0Z`;
}
getTicks() {
let ticks;
if (this.context.scaleType === ScaleType.ORDINAL) {
const maxTicks = this.getMaxTicks(20);
ticks = reduceTicks(this.context.x.domain(), maxTicks).map(this.handleTicksData);
}
else {
ticks = this.context.x
.ticks(this.getMaxTicks(100))
.map(this.handleTicksData);
}
return ticks;
}
getMaxTicks(tickWidth) {
const width = this.context.horizontal
? this.context.chartView.height
: this.context.chartView.width;
return Math.floor(width / tickWidth);
}
constructor(contextService, cdr) {
this.contextService = contextService;
this.cdr = cdr;
this.textAnchor = 'middle';
this.orientation = Orientation;
this.handleTicksData = (value) => {
const bandwidth = this.context.barOptions.isBand
? this.context.x.bandwidth() * 0.5
: 0;
return {
value: this.format(value),
x: this.context.x(value) + bandwidth,
y: 0,
};
};
}
ngOnInit() {
this.contextService.seriesData$
.pipe(map(() => this.getTicks()))
.subscribe(res => {
this.ticks = res;
this.cdr.detectChanges();
});
}
format(value) {
return this.contextService.scaleType === ScaleType.TIME
? dayjs(value).format(this.dateFormat)
: value;
}
static { this.ɵfac = function XAxisTicksComponent_Factory(t) { return new (t || XAxisTicksComponent)(i0.ɵɵdirectiveInject(i1.ContextChartService), i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: XAxisTicksComponent, selectors: [["g", "aclXAxisTicks", ""]], inputs: { dateFormat: "dateFormat", translation: "translation" }, attrs: _c0, decls: 3, vars: 2, consts: [["elseTemplate", ""], [4, "ngIf", "ngIfElse"], [4, "ngFor", "ngForOf"], ["stroke", "#ccd6eb", "fill", "none"], ["fill", "#666", "font-size", "11"], ["stroke-width", "1", "stroke", "#ccd6eb"], ["x", "-8", "fill", "#666", "text-anchor", "end", "font-size", "11", "alignment-baseline", "middle"]], template: function XAxisTicksComponent_Template(rf, ctx) { if (rf & 1) {
i0.ɵɵtemplate(0, XAxisTicksComponent_ng_container_0_Template, 4, 2, "ng-container", 1)(1, XAxisTicksComponent_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.TranslatePipe], encapsulation: 2, changeDetection: 0 }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(XAxisTicksComponent, [{
type: Component,
args: [{
// eslint-disable-next-line @angular-eslint/component-selector
selector: 'g[aclXAxisTicks]',
template: `
<ng-container
*ngIf="
context.barOptions.orientation === orientation.VERTICAL;
else elseTemplate
"
>
<svg:g *ngFor="let tick of ticks; let i = index">
<text
[attr.x]="
i === ticks.length - 1 && tick.x >= context.chartView?.height
? tick.x - 5
: tick.x
"
[attr.y]="tick.y + 16"
fill="#666"
[attr.text-anchor]="textAnchor"
font-size="11"
>
{{ translation ? (tick.value | translate) : tick.value }}
</text>
<line
[attr.x1]="tick.x"
[attr.x2]="tick.x"
[attr.y1]="tick.y"
[attr.y2]="tick.y + 6"
stroke-width="1"
stroke="#ccd6eb"
></line>
</svg:g>
<svg:g>
<path
[attr.d]="xAxisLine"
stroke="#ccd6eb"
fill="none"
/>
</svg:g>
</ng-container>
<ng-template #elseTemplate>
<svg:g *ngFor="let tick of ticks; let i = index">
<text
x="-8"
[attr.y]="tick.x"
fill="#666"
text-anchor="end"
font-size="11"
alignment-baseline="middle"
>
{{ translation ? (tick.value | translate | translate) : tick.value }}
</text>
</svg:g>
<svg:g>
<path
[attr.d]="yAxisLine"
stroke="#ccd6eb"
fill="none"
/>
</svg:g>
</ng-template>
`,
changeDetection: ChangeDetectionStrategy.OnPush,
}]
}], () => [{ type: i1.ContextChartService }, { type: i0.ChangeDetectorRef }], { dateFormat: [{
type: Input
}], translation: [{
type: Input
}] }); })();
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(XAxisTicksComponent, { className: "XAxisTicksComponent" }); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"x-axis-ticks.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/axis/x-axis-ticks.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  Input,\n  OnInit,\n} from '@angular/core';\nimport { ScalePoint, ScaleTime } from 'd3';\nimport dayjs from 'dayjs';\nimport { map } from 'rxjs';\n\nimport { ContextChartService } from '../../chart.service';\nimport { Orientation, Tick, TickValue } from '../../types';\nimport { ScaleType, reduceTicks } from '../../utils';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'g[aclXAxisTicks]',\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; let i = index\">\n        <text\n          [attr.x]=\"\n            i === ticks.length - 1 && tick.x >= context.chartView?.height\n              ? tick.x - 5\n              : tick.x\n          \"\n          [attr.y]=\"tick.y + 16\"\n          fill=\"#666\"\n          [attr.text-anchor]=\"textAnchor\"\n          font-size=\"11\"\n        >\n          {{ translation ? (tick.value | translate) : tick.value }}\n        </text>\n        <line\n          [attr.x1]=\"tick.x\"\n          [attr.x2]=\"tick.x\"\n          [attr.y1]=\"tick.y\"\n          [attr.y2]=\"tick.y + 6\"\n          stroke-width=\"1\"\n          stroke=\"#ccd6eb\"\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-container>\n\n    <ng-template #elseTemplate>\n      <svg:g *ngFor=\"let tick of ticks; let i = index\">\n        <text\n          x=\"-8\"\n          [attr.y]=\"tick.x\"\n          fill=\"#666\"\n          text-anchor=\"end\"\n          font-size=\"11\"\n          alignment-baseline=\"middle\"\n        >\n          {{ translation ? (tick.value | translate | translate) : tick.value }}\n        </text>\n      </svg:g>\n      <svg:g>\n        <path\n          [attr.d]=\"yAxisLine\"\n          stroke=\"#ccd6eb\"\n          fill=\"none\"\n        />\n      </svg:g>\n    </ng-template>\n  `,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class XAxisTicksComponent implements OnInit {\n  @Input() dateFormat: string;\n\n  @Input() translation: boolean;\n\n  textAnchor = 'middle';\n  orientation = Orientation;\n  get context() {\n    return this.contextService;\n  }\n\n  ticks: Tick[];\n  get yAxisLine() {\n    return `M${0} ${0}L${0} ${this.context.chartView.height}Z`;\n  }\n\n  get xAxisLine() {\n    const { width } = this.contextService.chartView;\n    return `M0 0L${width} 0Z`;\n  }\n\n  getTicks() {\n    let ticks: Tick[];\n    if (this.context.scaleType === ScaleType.ORDINAL) {\n      const maxTicks = this.getMaxTicks(20);\n      ticks = reduceTicks(this.context.x.domain(), maxTicks).map(\n        this.handleTicksData,\n      );\n    } else {\n      ticks = (this.context.x as ScaleTime<number, number>)\n        .ticks(this.getMaxTicks(100))\n        .map(this.handleTicksData);\n    }\n    return ticks;\n  }\n\n  handleTicksData = (value: TickValue): Tick => {\n    const bandwidth = this.context.barOptions.isBand\n      ? (this.context.x as ScalePoint<string>).bandwidth() * 0.5\n      : 0;\n    return {\n      value: this.format(value),\n      x: this.context.x(value) + bandwidth,\n      y: 0,\n    } as Tick;\n  };\n\n  getMaxTicks(tickWidth: number): number {\n    const width = this.context.horizontal\n      ? this.context.chartView.height\n      : this.context.chartView.width;\n    return Math.floor(width / tickWidth);\n  }\n\n  constructor(\n    private readonly contextService: ContextChartService,\n    private readonly cdr: ChangeDetectorRef,\n  ) {}\n\n  ngOnInit() {\n    this.contextService.seriesData$\n      .pipe(map(() => this.getTicks()))\n      .subscribe(res => {\n        this.ticks = res;\n        this.cdr.detectChanges();\n      });\n  }\n\n  format(value: string | number | Date) {\n    return this.contextService.scaleType === ScaleType.TIME\n      ? dayjs(value).format(this.dateFormat)\n      : value;\n  }\n}\n"]}