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
JavaScript
/*
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;
})();