UNPKG

igniteui-angular-charts

Version:

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

434 lines (433 loc) 15.6 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 { HorizontalAnchoredCategorySeries } from "./HorizontalAnchoredCategorySeries"; import { CategoryLineRasterizer } from "./CategoryLineRasterizer"; import { typeCast, Point_$type, Array_$type, runOn, markType } from "igniteui-angular-core"; import { ISortingAxis_$type } from "./ISortingAxis"; import { List$1 } from "igniteui-angular-core"; import { Path } from "igniteui-angular-core"; import { ScalerParams } from "./ScalerParams"; import { ChartSelection } from "./ChartSelection"; import { intDivide, isNaN_ } from "igniteui-angular-core"; import { AnchoredCategorySeriesView } from "./AnchoredCategorySeriesView"; import { Defaults } from "./Defaults"; /** * @hidden */ export let StepAreaSeries = /*@__PURE__*/ (() => { class StepAreaSeries extends HorizontalAnchoredCategorySeries { constructor() { super(); this.adj = null; this.adj = new CategoryLineRasterizer(); this.ab = StepAreaSeries.$; } bk() { return new StepAreaSeries(); } ct() { return new StepAreaSeriesView(this); } rg(a) { super.rg(a); this.adk = a; } get_ey() { return true; } get_ex() { return true; } get_f4() { return true; } get_fo() { return true; } cz() { if (this.c0 == 0) { return 2; } return super.cz(); } preferredCategoryMode(a) { return typeCast(ISortingAxis_$type, a) !== null ? 0 : 1; } ph(a, b) { super.ph(a, b); let c = b; c.du(); } adl(a, b, c, d, e, f) { let g; if (b) { if (f) { g = (a & 1) == 0; if (g || (intDivide(a, 2)) + 1 < 0) { return c.k._inner[(intDivide(a, 2))][0]; } if (c.k.count == (intDivide(a, 2)) + 1) { return c.k._inner[(intDivide(a, 2))][0]; } return c.k._inner[(intDivide(a, 2)) + 1][0]; } g = (a & 1) == 0; return c.k._inner[(intDivide(a, 2))][0] + (g ? d : -d); } if (f) { g = (a & 1) == 0; if (g || ((intDivide(a, 2)) + 1) >= c.k.count) { return c.k._inner[(intDivide(a, 2))][0]; } if (c.k.count == (intDivide(a, 2)) + 1) { return c.k._inner[(intDivide(a, 2))][0]; } return c.k._inner[(intDivide(a, 2)) + 1][0]; } g = (a & 1) == 0; return c.k._inner[(intDivide(a, 2))][0] + (g ? -d : d); } zo() { return 1; } i2(a, b, c, d, e, f, g, h) { let i = NaN; if (c >= 0 && c < b.count) { i = b.item(c); } let j = NaN; if (d >= 0 && d < b.count) { j = b.item(d); } if (f == 0) { return j; } if (e == b.count - 1) { return i; } if (isNaN_(j) && g != 0 && a <= 0.5 && !h) { return i; } if (isNaN_(i) && g != 0 && a >= 0.5 && !h) { return j; } if (a > 0.5) { return j; } return i; } g2(a, b) { let c = this.wv(this.w1(a), true, false); if (this.ac9(a, c, b)) { return true; } if (this.g1(a, b)) { return true; } if (this.x1(a, b)) { return true; } return false; } aj(a) { let b = this.adi(a); if (b == null) { return null; } let c = new Array(1); if (b.length == 4) { let d = new Array(4); d[0] = { $type: Point_$type, x: b[0][0], y: b[0][1] }; d[1] = { $type: Point_$type, x: b[1][0], y: b[1][1] }; d[2] = { $type: Point_$type, x: b[2][0], y: b[2][1] }; d[3] = { $type: Point_$type, x: b[3][0], y: b[3][1] }; c[0] = d; } else { let e = new Array(2); e[0] = { $type: Point_$type, x: b[0][0], y: b[0][1] }; e[1] = { $type: Point_$type, x: b[1][0], y: b[1][1] }; c[0] = e; } return c; } adi(a) { let b = this.am(this.xAxis, this.ze.k, this.aaf(this.cw), this.aag(this.cw), this.w1(a), true); if (b == null) { return null; } let c = this.zf(); let d = b[0]; let e = b[1]; if (d < 0 && e < 0) { return null; } if (d > c.k.count - 1 && e > c.k.count - 1) { return null; } if (d < 0) { d = 0; } if (e < 0) { e = 0; } if (e > c.k.count - 1) { e = c.k.count - 1; } if (d > c.k.count - 1) { d = c.k.count - 1; } let f = this.cw.ca; let g = this.cw.b9; let h = this.getEffectiveViewport1(this.cw); let i = typeCast(ISortingAxis_$type, this.acz) != null; let j = this.acz.dn; let k = 0; if (this.acz != null) { k = 0.5 * this.acz.getCategorySize(f, g, h); } let l = new Array(4); let m = new Array(4); let n = new Array(4); let o = new Array(4); if (!this.acz.dn) { let p = d * 2; l[0] = this.adl(p, false, c, k, j, i); l[1] = c.k._inner[(intDivide(p, 2))][1]; l[2] = this.adl(p, false, c, k, j, i); l[3] = c.k._inner[(intDivide(p, 2))][2]; p++; m[0] = this.adl(p, false, c, k, j, i); m[1] = c.k._inner[(intDivide(p, 2))][1]; m[2] = this.adl(p, false, c, k, j, i); m[3] = c.k._inner[(intDivide(p, 2))][2]; p = e * 2; n[0] = this.adl(p, false, c, k, j, i); n[1] = c.k._inner[(intDivide(p, 2))][1]; n[2] = this.adl(p, false, c, k, j, i); n[3] = c.k._inner[(intDivide(p, 2))][2]; p++; o[0] = this.adl(p, false, c, k, j, i); o[1] = c.k._inner[(intDivide(p, 2))][1]; o[2] = this.adl(p, false, c, k, j, i); o[3] = c.k._inner[(intDivide(p, 2))][2]; } else { let q = d * 2; l[0] = this.adl(q, true, c, k, j, i); l[1] = c.k._inner[(intDivide(q, 2))][1]; l[2] = this.adl(q, true, c, k, j, i); l[3] = c.k._inner[(intDivide(q, 2))][2]; q++; m[0] = this.adl(q, true, c, k, j, i); m[1] = c.k._inner[(intDivide(q, 2))][1]; m[2] = this.adl(q, true, c, k, j, i); m[3] = c.k._inner[(intDivide(q, 2))][2]; q = e * 2; n[0] = this.adl(q, true, c, k, j, i); n[1] = c.k._inner[(intDivide(q, 2))][1]; n[2] = this.adl(q, true, c, k, j, i); n[3] = c.k._inner[(intDivide(q, 2))][2]; q++; o[0] = this.adl(q, true, c, k, j, i); o[1] = c.k._inner[(intDivide(q, 2))][1]; o[2] = this.adl(q, true, c, k, j, i); o[3] = c.k._inner[(intDivide(q, 2))][2]; } if (d == e) { return [l, m]; } return [l, m, n, o]; } al(a) { let b = this.adi(a); if (b == null) { return null; } let c = new Array(1); if (b.length == 4) { let d = new Array(4); d[0] = { $type: Point_$type, x: b[0][2], y: b[0][3] }; d[1] = { $type: Point_$type, x: b[1][2], y: b[1][3] }; d[2] = { $type: Point_$type, x: b[2][2], y: b[2][3] }; d[3] = { $type: Point_$type, x: b[3][2], y: b[3][3] }; c[0] = d; } else { let e = new Array(2); e[0] = { $type: Point_$type, x: b[0][2], y: b[0][3] }; e[1] = { $type: Point_$type, x: b[1][2], y: b[1][3] }; c[0] = e; } return c; } aa7(a, b) { super.aa7(a, b); let c = b.ca; let d = b.b9; let e = this.getEffectiveViewport1(b); let f = typeCast(ISortingAxis_$type, this.acz) != null; let g = this.acz.dn; let h = this.acz != null ? 0.5 * this.acz.getCategorySize(c, d, e) : 0; let i = a.k.count * 2; let j = new List$1(Array_$type, 2, i); this.zm.a2(this, this.z6(), runOn(this, this.y6), this.aaf(b), this.aag(b)); let k = false; let l = this.zm.b; if (l != null) { k = true; } if (!this.acz.dn) { for (let m = 0; m < i; m++) { let n = new Array(4); n[0] = this.adl(m, false, a, h, g, f); n[1] = a.k._inner[(intDivide(m, 2))][1]; n[2] = this.adl(m, false, a, h, g, f); n[3] = a.k._inner[(intDivide(m, 2))][2]; j.add(n); } } else { for (let o = 0; o < i; o++) { let p = new Array(4); p[0] = this.adl(o, true, a, h, g, f); p[1] = a.k._inner[(intDivide(o, 2))][1]; p[2] = this.adl(o, true, a, h, g, f); p[3] = a.k._inner[(intDivide(o, 2))][2]; j.add(p); } } let q = this.zn.c9.d; if (k) { let r = new ScalerParams(0, b.ca, b.b9, this.acz.dn, e); this.aa3(j, -1, this.valueColumn.count, this.acz, r, b.t, -1); } let s = typeCast(StepAreaSeriesView.$, b); let t = s.d7; let u = s.d8; let v = s.d5; let w = s.d6; this.zm.ad(t, true, false, true, true); this.zm.ad(u, true, false, true, true); this.zm.ad(v, false, true, false, false); this.zm.ad(w, false, true, false, false); if (b.dd(a)) { s.dw(i, j, false, q, this.ik, (x, y, z, aa, ab) => this.acf(x, 2 * a.k.count, b), 1, this.abg(j, j.count - 1, b.b9, b.ca, true)); b.dg(a); } let x = this.fetchYAxis(); s.d5._opacity = this.zm.j * this.ig; s.d6._opacity = 0.5 * this.zm.j * this.ig; } qh(a, b, c) { this.aaz(a, b, c, this.zd, 1); } ak(a, b) { let c = new List$1(ChartSelection.$, 0); this.qh(a, c, b); return c.toArray(); } get useHighMarkerFidelity() { return this.aaa; } } StepAreaSeries.$t = markType(StepAreaSeries, 'StepAreaSeries', HorizontalAnchoredCategorySeries.$); return StepAreaSeries; })(); /** * @hidden */ export let StepAreaSeriesView = /*@__PURE__*/ (() => { class StepAreaSeriesView extends AnchoredCategorySeriesView { constructor(a) { super(a); this.dt = null; this.d1 = new Path(); this.d3 = new Path(); this.d2 = new Path(); this.d4 = new Path(); this.dx = new Path(); this.dz = new Path(); this.dy = new Path(); this.d0 = new Path(); this.dt = a; } a4() { super.a4(); if (!this.t) { this.dt.xu = Defaults.c; } } get d5() { return this.d1; } get d7() { return this.d3; } get d6() { return this.d2; } get d8() { return this.d4; } du() { this.d1.an = null; this.d2.an = null; this.d3.an = null; this.d4.an = null; this.a2(); } dv(a, b, c, d, e, f, g) { this.dv(a, b, c, d, e, f, g); } dw(a, b, c, d, e, f, g, h) { this.dt.adj.a = typeCast(ISortingAxis_$type, this.db.fetchXAxis()) !== null ? true : false; this.dt.adj.j(this.d1, this.d3, this.d2, this.d4, a, b, c, d, e, f, g, h); this.a2(); } bq() { super.bq(); this.dx.an = this.d1.an; this.dz.an = this.d3.an; this.dy.an = this.d2.an; this.d0.an = this.d4.an; let a = this.b3(); this.dx._fill = a; this.dx._opacity = 1; this.dy._fill = a; this.dy._opacity = 1; this.dz._stroke = a; this.dz.ad = this.f.il + 3; this.d0._stroke = a; this.d0.ad = this.f.il + 3; } bj(a, b) { super.bj(a, b); if (b) { a.t(this.dx); a.t(this.dy); a.t(this.dz); a.t(this.d0); } else { a.t(this.d1); a.t(this.d2); a.t(this.d3); a.t(this.d4); } } ax(a) { super.ax(a); this.f.bc.exportPathData(a, this.d3, "lowerShape", ["Lower"]); this.f.bc.exportPathData(a, this.d4, "upperShape", ["Upper", "Main"]); this.f.bc.exportPathData(a, this.d2, "translucentShape", ["Translucent"]); this.f.bc.exportPathData(a, this.d1, "fillShape", ["Fill"]); } } StepAreaSeriesView.$t = markType(StepAreaSeriesView, 'StepAreaSeriesView', AnchoredCategorySeriesView.$); return StepAreaSeriesView; })();