UNPKG

igniteui-angular-charts

Version:

Ignite UI Angular charting components for building rich data visualizations for modern web apps.

266 lines (265 loc) 9.88 kB
/* THIS INFRAGISTICS ULTIMATE SOFTWARE LICENSE AGREEMENT ("AGREEMENT") LOCATED HERE: https://www.infragistics.com/legal/license/igultimate-la https://www.infragistics.com/legal/license/igultimate-eula GOVERNS THE LICENSING, INSTALLATION AND USE OF INFRAGISTICS SOFTWARE. BY DOWNLOADING AND/OR INSTALLING AND USING INFRAGISTICS SOFTWARE: you are indicating that you have read and understand this Agreement, and agree to be legally bound by it on behalf of the yourself and your company. */ import { ScatterBase } from "./ScatterBase"; import { UnknownValuePlotting_$type } from "igniteui-angular-core"; import { DependencyProperty } from "igniteui-angular-core"; import { Point_$type, typeCast, runOn, Number_$type, enumGetBox, markType, markDep } from "igniteui-angular-core"; import { OwnedPoint } from "./OwnedPoint"; import { ScatterFrame } from "./ScatterFrame"; import { ScatterLineSeriesView } from "./ScatterLineSeriesView"; import { Defaults } from "./Defaults"; import { PathGeometry } from "igniteui-angular-core"; import { Rect } from "igniteui-angular-core"; import { ScalerParams } from "./ScalerParams"; import { Clipper } from "igniteui-angular-core"; import { List$1 } from "igniteui-angular-core"; import { RectUtil } from "igniteui-angular-core"; import { PolyLineSegment } from "igniteui-angular-core"; import { PathFigure } from "igniteui-angular-core"; import { PathFigureCollection } from "igniteui-angular-core"; import { Flattener } from "igniteui-angular-core"; import { PropertyMetadata } from "igniteui-angular-core"; import { boxArray$1, arrayShallowClone } from "igniteui-angular-core"; import { isNaN_ } from "igniteui-angular-core"; /** * @hidden */ export let ScatterLineSeries = /*@__PURE__*/ (() => { class ScatterLineSeries extends ScatterBase { constructor() { super(); this.ab = ScatterLineSeries.$; this.y1 = new ScatterFrame(); this.y3 = new ScatterFrame(); this.yz = new ScatterFrame(); let a = (b, c, d) => { let e = this.dn.indexOf(b.a); if (e == -1 || e == 0) { return b; } let f = this.dn.item(e - 1); let g; if (!((() => { let h = c.g.tryGetValue(f, g); g = h.p1; return h.ret; })())) { return b; } return g; }; this.y1.o = a; this.y3.o = a; this.yz.o = a; } bj() { return new ScatterLineSeries(); } get_fj() { return true; } cs() { return new ScatterLineSeriesView(this); } zv() { return true; } jj() { if (!isNaN_(this.ji)) { return super.jj(); } return Defaults.x; } gv(a, b) { if (this.xg(a, b)) { return true; } if (this.acn(a, b)) { return true; } return false; } acn(a, b) { let c = this.cv; let d = c.dl; return this.gw(a, b, d.an); } abe(a, b) { super.abe(a, b); a.m.clear(); a.u.clear(); let c = b.by; let d = b.bx; let e = this.getEffectiveViewport1(b); let f = this.ic * this.ic; let g = 0; if (this.zg != null) { g = this.zg.count; } if (this.zh != null) { g = Math.min(this.zh.count, g); } let h = new ScalerParams(0, c, d, this.yv.d, e); let i = ((() => { let $ret = new ScalerParams(0, c, d, this.yv.e, e); $ret.b = this.ix(); return $ret; })()); let j = arrayShallowClone(this.zg.asArray()); let k = arrayShallowClone(this.zh.asArray()); this.xAxis.hq(boxArray$1(j), 0, j.length, h); this.yAxis.hq(boxArray$1(k), 0, k.length, i); let l = d.top - 10; let m = d.bottom + 10; let n = d.left - 10; let o = d.right + 10; let p = ((() => { let $ret = new Clipper(1, n, m, o, l, false); $ret.i = a.m; return $ret; })()); for (let q = 0; q < g;) { let r = q; ++q; if (g > this.z8) { while (q < g) { let s = j[q] - j[r]; let t = k[q] - k[r]; let u = s * s + t * t; if (isNaN_(u) || u >= f) { break; } ++q; } p.j(this.acu(j, k, r, q - 1)); } else { let v = new OwnedPoint(); v.c = { $type: Point_$type, x: j[r], y: k[r] }; v.a = this.dn.item(r); if (!a.u.containsKey(v.a)) { a.u.addItem(v.a, v); } } } if (g > this.z8) { p.i = null; } } acu(a, b, c, d) { if (c == d) { return { $type: Point_$type, x: a[c], y: b[c] }; } let e = 0; let f = 0; let g = (d - c + 1); for (let h = c; h <= d; ++h) { e += a[h]; f += b[h]; } return { $type: Point_$type, x: e / g, y: f / g }; } get_zp() { return true; } abp(a, b) { b.c9(false); super.abp(a, b); let c = this.getEffectiveViewport1(b); let d = new Rect(0, b.bx.left, b.bx.top, b.bx.width, b.bx.height); d = RectUtil.t(d, this.id, this.id); this.abi(a, new Clipper(0, d, false)); let e = typeCast(ScatterLineSeriesView.$, b); this.y8.az(this, this.zu(), runOn(this, this.yo)); let f = false; let g = this.y8.b; if (g != null) { f = true; } if (f) { this.aba(-1, this.zg.count, b.q); } this.y8.ad(e.dl, true, false, true, false); this.acs(e.dl, a.m.count, (h) => a.m._inner[h].x, (h) => a.m._inner[h].y, this.acm, this.ic); } acs(a, b, c, d, e, f) { let g = new PathGeometry(); a.an = g; g.c = new PathFigureCollection(); let h = new List$1(PolyLineSegment.$, 0); let i = 0; for (let j = 0; j < b; j++) { if (isNaN_(c(j)) || isNaN_(d(j))) { let k = j - i; if (k > 0) { if (e == 1 || h.count == 0) { let l = new PolyLineSegment(); h.add(l); } this.acr(h._inner[h.count - 1]._points, i, j - 1, c, d, f); } i = j + 1; } } if (e == 1 || h.count == 0) { let m = new PolyLineSegment(); h.add(m); } this.acr(h._inner[h.count - 1]._points, i, b - 1, c, d, f); for (let n = 0; n < h.count; n++) { let o = h._inner[n]; if (o._points.count > 0) { let p = ((() => { let $ret = new PathFigure(); $ret.startPoint = o._points._inner[0]; return $ret; })()); p._segments.add(o); g.c.add(p); } } } aco(a, b, c, d, e, f) { let g = new List$1(Number_$type, 0); let h = d; let i = e; let j = i - h + 1; while (j > 0) { if (j <= 512) { Flattener.c(g, b, c, h, i, f); h = i + 1; } else { let k = h + 512 - 1; Flattener.c(g, b, c, h, k, f); h = k + 1; } j = i - h + 1; } return g; } acr(a, b, c, d, e, f) { if (c > -1) { let g = !isNaN_(this.ji) ? f : 1; let h = this.aco(new List$1(Number_$type, 0), d, e, b, c, g); let i; for (let j = 0; j < h.count; j++) { i = h.item(j); a.add({ $type: Point_$type, x: d(i), y: e(i) }); } } } q8(a, b, c, d) { super.q8(a, b, c, d); switch (b) { case ScatterLineSeries.$$p[0]: this.rq(false); this.qk(); break; } } } ScatterLineSeries.$t = markType(ScatterLineSeries, 'ScatterLineSeries', ScatterBase.$); ScatterLineSeries.$$p = markDep(DependencyProperty, PropertyMetadata, ScatterLineSeries, 'raisePropertyChanged', ['UnknownValuePlotting:acm:act', [UnknownValuePlotting_$type, enumGetBox(UnknownValuePlotting_$type, 1)]]); return ScatterLineSeries; })();