UNPKG

@alauda-fe/common

Version:

Alauda frontend team common codes.

166 lines 22.4 kB
import { ChangeDetectorRef, Directive, Injector, Input, } from '@angular/core'; import { area, curveMonotoneX, line, } from 'd3'; import { cloneDeep } from 'lodash-es'; import { Subject, skip, takeUntil } from 'rxjs'; import { ContextChartService } from '../../chart.service'; import { defined, generateUID } from '../../utils'; import * as i0 from "@angular/core"; export class ChartSeriesComponent { get disabledLegend() { return this.context.disabledLegend; } get hasBar() { return this.seriesType === 'bar'; } constructor(injector) { this.injector = injector; this.x = (d) => d.x; this.y = (d) => d.y; this.type = 'standard'; this.lineWidth = 1.5; this.cdr = this.injector.get(ChangeDetectorRef); this.context = this.injector.get(ContextChartService); this.destroy$$ = new Subject(); this.handleOpacity = (name, activateLegend) => activateLegend ? (activateLegend === name ? 1 : 0.2) : 1; this.handleStrokeWidth = (name, activateLegend, width = 1.5) => activateLegend ? (activateLegend === name ? width + 0.5 : width) : width; } ngOnInit() { this.initSeries(); } initSeries() { this.context.chartData$ .pipe(takeUntil(this.destroy$$)) .subscribe(chartData => { this.context.chartData = chartData; }); this.context.triggerInitData$ .pipe(takeUntil(this.destroy$$)) .subscribe(chartData => { this.context.initContext(); this.handleChatData(chartData); setTimeout(() => { this.handleSeriesData(); }, 300); }); this.context.update$$ .pipe(takeUntil(this.destroy$$)) .pipe(skip(1)) .subscribe(() => { this.handleSeriesData(); }); this.legendActivate(); } legendActivate() { this.context.legendActivate$$ .pipe(takeUntil(this.destroy$$)) .subscribe(legend => { this.activateLegend = legend; this.cdr.detectChanges(); }); } handleChatData(data) { const chartData = data.map((d, index) => { if (this.hasBar) { this.context.xSeriesValue = [ ...new Set([...this.context.xSeriesValue, d.name]), ]; } this.type === 'stacked' && this.context.ySeriesValue.push(d.values.reduce((acc, curr) => { const y = this.y(curr); return y + acc; }, 0)); return { ...d, color: d.color || this.context.getChartDefaultColor(index), values: d.values.map(v => { const x = this.x(v); const y = this.y(v); if (!this.hasBar) { this.context.xSeriesValue = [ ...new Set([...this.context.xSeriesValue, x]), ]; } if (this.type !== 'stacked') { this.context.ySeriesValue.push(y); } return { ...v, x, y }; }), }; }); this.context.setChartData(chartData); } // eslint-disable-next-line sonarjs/cognitive-complexity handleSeriesData() { const seriesData = cloneDeep(this.context.chartData); const sliceValue = 30; const sliceTotal = Math.ceil(seriesData.length / sliceValue); const lineG = ['area', 'line'].includes(this.seriesType) && this.getLineGenerator(); const areaG = this.seriesType === 'area' && this.getAraGenerator(); for (let index = 0; index < sliceTotal; index++) { requestAnimationFrame(() => { [...seriesData].splice(0, sliceValue).forEach((_, i) => { const tIndex = index * sliceValue + i; const d = seriesData[tIndex]; if (d) { d.visibility = this.disabledLegend.has(d.name) ? 'hidden' : ''; if (this.seriesType === 'area') { d.areaPath = areaG(d.values); d.gradientFillId = generateUID(); } if (['area', 'line'].includes(this.seriesType)) { d.path = lineG(d.values); } if (tIndex === seriesData.length - 1) { this.seriesData = seriesData; this.context.seriesData$.next(seriesData); this.cdr.detectChanges(); } } }); }); } } 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); } getAraGenerator() { const { x, y } = this.context; return area() .defined(defined) .curve((this.curveType || curveMonotoneX)) .x(d => x(d.x)) .y0(y.range()[0]) .y1(d => y(d.y) || 0); } ngOnDestroy() { this.destroy$$.next(); } static { this.ɵfac = function ChartSeriesComponent_Factory(t) { return new (t || ChartSeriesComponent)(i0.ɵɵdirectiveInject(i0.Injector)); }; } static { this.ɵdir = /*@__PURE__*/ i0.ɵɵdefineDirective({ type: ChartSeriesComponent, inputs: { x: "x", y: "y", categories: "categories", unit: "unit", curveType: "curveType", type: "type", lineWidth: "lineWidth", seriesType: "seriesType" } }); } } (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(ChartSeriesComponent, [{ type: Directive }], () => [{ type: i0.Injector }], { x: [{ type: Input }], y: [{ type: Input }], categories: [{ type: Input }], unit: [{ type: Input }], curveType: [{ type: Input }], type: [{ type: Input }], lineWidth: [{ type: Input }], seriesType: [{ type: Input }] }); })(); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"series.component.js","sourceRoot":"","sources":["../../../../../../../libs/common/src/chart/common/series/series.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,QAAQ,EACR,KAAK,GAGN,MAAM,eAAe,CAAC;AACvB,OAAO,EAIL,IAAI,EACJ,cAAc,EACd,IAAI,GACL,MAAM,IAAI,CAAC;AACZ,OAAO,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AACtC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;AAGhD,OAAO,EAAE,mBAAmB,EAAE,MAAM,qBAAqB,CAAC;AAE1D,OAAO,EAAE,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;;AAGnD,MAAM,OAAgB,oBAAoB;IA8BxC,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC;IACrC,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,UAAU,KAAK,KAAK,CAAC;IACnC,CAAC;IAED,YAAsB,QAAkB;QAAlB,aAAQ,GAAR,QAAQ,CAAU;QArC/B,MAAC,GAA2C,CAAC,CAAgB,EAAE,EAAE,CACxE,CAAC,CAAC,CAAC,CAAC;QAEG,MAAC,GAA4B,CAAC,CAAgB,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAQvD,SAAI,GAA2B,UAAU,CAAC;QAE1C,cAAS,GAAG,GAAG,CAAC;QAIzB,QAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QAE3C,YAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;QAQjD,cAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;QAiDhC,kBAAa,GAAG,CAAC,IAAY,EAAE,cAAsB,EAAE,EAAE,CACvD,cAAc,CAAC,CAAC,CAAC,CAAC,cAAc,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE3D,sBAAiB,GAAG,CAAC,IAAY,EAAE,cAAsB,EAAE,KAAK,GAAG,GAAG,EAAE,EAAE,CACxE,cAAc,CAAC,CAAC,CAAC,CAAC,cAAc,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;IA3ChC,CAAC;IAE5C,QAAQ;QACN,IAAI,CAAC,UAAU,EAAE,CAAC;IACpB,CAAC;IAED,UAAU;QACR,IAAI,CAAC,OAAO,CAAC,UAAU;aACpB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,SAAS,CAAC,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,SAAS,CAAC;QACrC,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,OAAO,CAAC,gBAAgB;aAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,SAAS,CAAC,EAAE;YACrB,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;YAC3B,IAAI,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC;YAC/B,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,gBAAgB,EAAE,CAAC;YAC1B,CAAC,EAAE,GAAG,CAAC,CAAC;QACV,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,OAAO,CAAC,QAAQ;aAClB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;aACb,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,gBAAgB,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,OAAO,CAAC,gBAAgB;aAC1B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAC/B,SAAS,CAAC,MAAM,CAAC,EAAE;YAClB,IAAI,CAAC,cAAc,GAAG,MAAM,CAAC;YAC7B,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;QAC3B,CAAC,CAAC,CAAC;IACP,CAAC;IAQD,cAAc,CAAC,IAAiB;QAC9B,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,EAAE;YACtC,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC;gBAChB,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG;oBAC1B,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC;iBACnD,CAAC;YACJ,CAAC;YACD,IAAI,CAAC,IAAI,KAAK,SAAS;gBACrB,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAC5B,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAW,EAAE,IAAI,EAAE,EAAE;oBACpC,MAAM,CAAC,GAAW,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;oBAC/B,OAAO,CAAC,GAAG,GAAG,CAAC;gBACjB,CAAC,EAAE,CAAC,CAAC,CACN,CAAC;YACJ,OAAO;gBACL,GAAG,CAAC;gBACJ,KAAK,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,KAAK,CAAC;gBAC1D,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;oBACvB,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpB,MAAM,CAAC,GAAG,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpB,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC;wBACjB,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG;4BAC1B,GAAG,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC,CAAC;yBAC9C,CAAC;oBACJ,CAAC;oBACD,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;wBAC5B,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBACpC,CAAC;oBACD,OAAO,EAAE,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC;gBACxB,CAAC,CAAC;aACH,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,CAAC;IACvC,CAAC;IAED,wDAAwD;IACxD,gBAAgB;QACd,MAAM,UAAU,GAAiB,SAAS,CAAC,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACnE,MAAM,UAAU,GAAG,EAAE,CAAC;QACtB,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,GAAG,UAAU,CAAC,CAAC;QAC7D,MAAM,KAAK,GACT,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,gBAAgB,EAAE,CAAC;QACxE,MAAM,KAAK,GAAG,IAAI,CAAC,UAAU,KAAK,MAAM,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;QACnE,KAAK,IAAI,KAAK,GAAG,CAAC,EAAE,KAAK,GAAG,UAAU,EAAE,KAAK,EAAE,EAAE,CAAC;YAChD,qBAAqB,CAAC,GAAG,EAAE;gBACzB,CAAC,GAAG,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;oBACrD,MAAM,MAAM,GAAG,KAAK,GAAG,UAAU,GAAG,CAAC,CAAC;oBACtC,MAAM,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,CAAC;oBAC7B,IAAI,CAAC,EAAE,CAAC;wBACN,CAAC,CAAC,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;wBAC/D,IAAI,IAAI,CAAC,UAAU,KAAK,MAAM,EAAE,CAAC;4BAC/B,CAAC,CAAC,QAAQ,GAAG,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;4BAC7B,CAAC,CAAC,cAAc,GAAG,WAAW,EAAE,CAAC;wBACnC,CAAC;wBACD,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,EAAE,CAAC;4BAC/C,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;wBAC3B,CAAC;wBACD,IAAI,MAAM,KAAK,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;4BACrC,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;4BAC7B,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;4BAC1C,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;wBAC3B,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,gBAAgB;QACd,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAC9B,OAAO,IAAI,EAAiB;aACzB,OAAO,CAAC,OAAO,CAAC;aAChB,KAAK,CAAC,IAAI,CAAC,SAAS,IAAI,cAAc,CAAC;aACvC,CAAC,CAAC,CAAC,CAAC,EAAE,CAA6B,CAAE,CAAC,CAAC,CAAC,CAAW,CAAC,CAAC;aACrD,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IACzB,CAAC;IAED,eAAe;QACb,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,OAAO,CAAC;QAC9B,OAAO,IAAI,EAAiB;aACzB,OAAO,CAAC,OAAO,CAAC;aAChB,KAAK,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,cAAc,CAAiB,CAAC;aACzD,CAAC,CAAC,CAAC,CAAC,EAAE,CAA6B,CAAE,CAAC,CAAC,CAAC,CAAW,CAAC,CAAC;aACrD,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;aAChB,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;IAC1B,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;IACxB,CAAC;qFA5KmB,oBAAoB;oEAApB,oBAAoB;;iFAApB,oBAAoB;cADzC,SAAS;yCAEC,CAAC;kBAAT,KAAK;YAGG,CAAC;kBAAT,KAAK;YAEG,UAAU;kBAAlB,KAAK;YAEG,IAAI;kBAAZ,KAAK;YAEG,SAAS;kBAAjB,KAAK;YAEG,IAAI;kBAAZ,KAAK;YAEG,SAAS;kBAAjB,KAAK;YAEG,UAAU;kBAAlB,KAAK","sourcesContent":["import {\n  ChangeDetectorRef,\n  Directive,\n  Injector,\n  Input,\n  OnDestroy,\n  OnInit,\n} from '@angular/core';\nimport {\n  CurveFactory,\n  CurveFactoryLineOnly,\n  ScaleTime,\n  area,\n  curveMonotoneX,\n  line,\n} from 'd3';\nimport { cloneDeep } from 'lodash-es';\nimport { Subject, skip, takeUntil } from 'rxjs';\n\nimport { ChartData, ChartDataItem } from '../../../view-chart/types';\nimport { ContextChartService } from '../../chart.service';\nimport { SeriesData } from '../../types';\nimport { defined, generateUID } from '../../utils';\n\n@Directive()\nexport abstract class ChartSeriesComponent implements OnInit, OnDestroy {\n  @Input() x: (d: unknown) => number | Date | string = (d: ChartDataItem) =>\n    d.x;\n\n  @Input() y?: (d: unknown) => number = (d: ChartDataItem) => d.y;\n\n  @Input() categories: string;\n\n  @Input() unit: string;\n\n  @Input() curveType: CurveFactory | CurveFactoryLineOnly;\n\n  @Input() type: 'standard' | 'stacked' = 'standard';\n\n  @Input() lineWidth = 1.5;\n\n  @Input() seriesType: 'line' | 'area' | 'bar';\n\n  cdr = this.injector.get(ChangeDetectorRef);\n\n  context = this.injector.get(ContextChartService);\n\n  results: ChartData;\n\n  activateLegend: string;\n\n  seriesData: SeriesData[];\n\n  destroy$$ = new Subject<void>();\n\n  get disabledLegend() {\n    return this.context.disabledLegend;\n  }\n\n  get hasBar() {\n    return this.seriesType === 'bar';\n  }\n\n  constructor(protected injector: Injector) {}\n\n  ngOnInit(): void {\n    this.initSeries();\n  }\n\n  initSeries() {\n    this.context.chartData$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(chartData => {\n        this.context.chartData = chartData;\n      });\n    this.context.triggerInitData$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(chartData => {\n        this.context.initContext();\n        this.handleChatData(chartData);\n        setTimeout(() => {\n          this.handleSeriesData();\n        }, 300);\n      });\n    this.context.update$$\n      .pipe(takeUntil(this.destroy$$))\n      .pipe(skip(1))\n      .subscribe(() => {\n        this.handleSeriesData();\n      });\n    this.legendActivate();\n  }\n\n  legendActivate() {\n    this.context.legendActivate$$\n      .pipe(takeUntil(this.destroy$$))\n      .subscribe(legend => {\n        this.activateLegend = legend;\n        this.cdr.detectChanges();\n      });\n  }\n\n  handleOpacity = (name: string, activateLegend: string) =>\n    activateLegend ? (activateLegend === name ? 1 : 0.2) : 1;\n\n  handleStrokeWidth = (name: string, activateLegend: string, width = 1.5) =>\n    activateLegend ? (activateLegend === name ? width + 0.5 : width) : width;\n\n  handleChatData(data: ChartData[]) {\n    const chartData = data.map((d, index) => {\n      if (this.hasBar) {\n        this.context.xSeriesValue = [\n          ...new Set([...this.context.xSeriesValue, d.name]),\n        ];\n      }\n      this.type === 'stacked' &&\n        this.context.ySeriesValue.push(\n          d.values.reduce((acc: number, curr) => {\n            const y: number = this.y(curr);\n            return y + acc;\n          }, 0),\n        );\n      return {\n        ...d,\n        color: d.color || this.context.getChartDefaultColor(index),\n        values: d.values.map(v => {\n          const x = this.x(v);\n          const y = this.y(v);\n          if (!this.hasBar) {\n            this.context.xSeriesValue = [\n              ...new Set([...this.context.xSeriesValue, x]),\n            ];\n          }\n          if (this.type !== 'stacked') {\n            this.context.ySeriesValue.push(y);\n          }\n          return { ...v, x, y };\n        }),\n      };\n    });\n    this.context.setChartData(chartData);\n  }\n\n  // eslint-disable-next-line sonarjs/cognitive-complexity\n  handleSeriesData() {\n    const seriesData: SeriesData[] = cloneDeep(this.context.chartData);\n    const sliceValue = 30;\n    const sliceTotal = Math.ceil(seriesData.length / sliceValue);\n    const lineG =\n      ['area', 'line'].includes(this.seriesType) && this.getLineGenerator();\n    const areaG = this.seriesType === 'area' && this.getAraGenerator();\n    for (let index = 0; index < sliceTotal; index++) {\n      requestAnimationFrame(() => {\n        [...seriesData].splice(0, sliceValue).forEach((_, i) => {\n          const tIndex = index * sliceValue + i;\n          const d = seriesData[tIndex];\n          if (d) {\n            d.visibility = this.disabledLegend.has(d.name) ? 'hidden' : '';\n            if (this.seriesType === 'area') {\n              d.areaPath = areaG(d.values);\n              d.gradientFillId = generateUID();\n            }\n            if (['area', 'line'].includes(this.seriesType)) {\n              d.path = lineG(d.values);\n            }\n            if (tIndex === seriesData.length - 1) {\n              this.seriesData = seriesData;\n              this.context.seriesData$.next(seriesData);\n              this.cdr.detectChanges();\n            }\n          }\n        });\n      });\n    }\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  getAraGenerator() {\n    const { x, y } = this.context;\n    return area<ChartDataItem>()\n      .defined(defined)\n      .curve((this.curveType || curveMonotoneX) as CurveFactory)\n      .x(d => (<ScaleTime<number, number>>x)(d.x as number))\n      .y0(y.range()[0])\n      .y1(d => y(d.y) || 0);\n  }\n\n  ngOnDestroy() {\n    this.destroy$$.next();\n  }\n}\n"]}