UNPKG

igniteui-angular-charts

Version:

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

268 lines (267 loc) 9.96 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.zm = new ScatterFrame(); this.zo = new ScatterFrame(); this.zk = new ScatterFrame(); let a = (b, c, d) => { let e = this.dp.indexOf(b.a); if (e == -1 || e == 0) { return b; } let f = this.dp.item(e - 1); let g; if (!((() => { let h = c.j.tryGetValue(f, g); g = h.p1; return h.ret; })())) { return b; } return g; }; this.zm.s = a; this.zo.s = a; this.zk.s = a; } bk() { return new ScatterLineSeries(); } get_fn() { return true; } ct() { return new ScatterLineSeriesView(this); } aag() { return true; } js() { if (!isNaN_(this.jr)) { return super.js(); } return Defaults.ak; } g2(a, b) { if (this.x1(a, b)) { return true; } if (this.dp.count <= this.aas) { if (this.ac8(a, b)) { return true; } } return false; } ac8(a, b) { let c = this.cw; let d = c.dz; return this.g3(a, b, d.an); } abz(a, b) { super.abz(a, b); a.q.clear(); a.y.clear(); let c = b.ca; let d = b.b9; let e = this.getEffectiveViewport1(b); let f = this.ik * this.ik; let g = 0; if (this.z1 != null) { g = this.z1.count; } if (this.z2 != null) { g = Math.min(this.z2.count, g); } let h = new ScalerParams(0, c, d, this.zg.d, e); let i = ((() => { let $ret = new ScalerParams(0, c, d, this.zg.e, e); $ret.b = this.i5(); return $ret; })()); let j = arrayShallowClone(this.z1.asArray()); let k = arrayShallowClone(this.z2.asArray()); this.xAxis.ky(boxArray$1(j), 0, j.length, h); this.yAxis.ky(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.q; return $ret; })()); for (let q = 0; q < g;) { let r = q; ++q; if (g > this.aat) { 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.adf(j, k, r, q - 1)); } else { let v = new OwnedPoint(); v.c = { $type: Point_$type, x: j[r], y: k[r] }; v.a = this.dp.item(r); if (!a.y.containsKey(v.a)) { a.y.addItem(v.a, v); } } } if (g > this.aat) { p.i = null; } } adf(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_aaa() { return true; } aca(a, b) { b.dm(false); super.aca(a, b); let c = this.getEffectiveViewport1(b); let d = new Rect(0, b.b9.left, b.b9.top, b.b9.width, b.b9.height); d = RectUtil.t(d, this.il, this.il); this.ab3(a, new Clipper(0, d, false)); let e = typeCast(ScatterLineSeriesView.$, b); this.zt.az(this, this.aaf(), runOn(this, this.y9)); let f = false; let g = this.zt.b; if (g != null) { f = true; } if (f) { this.abv(-1, this.z1.count, b.t); } this.zt.ad(e.dz, true, false, true, false); this.add(e.dz, a.q.count, (h) => a.q._inner[h].x, (h) => a.q._inner[h].y, this.ac7, this.ik); } add(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.adc(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.adc(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); } } } ac9(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; } adc(a, b, c, d, e, f) { if (c > -1) { let g = !isNaN_(this.jr) ? f : 1; let h = this.ac9(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) }); } } } rp(a, b, c, d) { super.rp(a, b, c, d); switch (b) { case ScatterLineSeries.$$p[0]: this.r7(false); this.qz(); break; } } } ScatterLineSeries.$t = markType(ScatterLineSeries, 'ScatterLineSeries', ScatterBase.$); ScatterLineSeries.$$p = markDep(DependencyProperty, PropertyMetadata, ScatterLineSeries, 'raisePropertyChanged', ['UnknownValuePlotting:ac7:ade', [UnknownValuePlotting_$type, enumGetBox(UnknownValuePlotting_$type, 1)]]); return ScatterLineSeries; })();