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
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.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;
})();