UNPKG

igniteui-react-charts

Version:

Ignite UI React charting components for building rich data visualizations using TypeScript APIs.

748 lines (747 loc) 26.4 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 { CategoryBucketCalculator } from "./CategoryBucketCalculator"; import { markType, runOn, delegateCombine, typeCast, markDep, Point_$type } from "igniteui-react-core"; import { isNaN_, truncate, isInfinity } from "igniteui-react-core"; import { CategorySeries } from "./CategorySeries"; import { IIsCategoryBased_$type } from "./IIsCategoryBased"; import { IHasHighLowValueCategory_$type } from "./IHasHighLowValueCategory"; import { RangeCategoryFramePreparer } from "./RangeCategoryFramePreparer"; import { DependencyProperty } from "igniteui-react-core"; import { Series } from "./Series"; import { CategoryAxisBase } from "./CategoryAxisBase"; import { ICategoryScaler_$type } from "./ICategoryScaler"; import { IScaler_$type } from "./IScaler"; import { CategorySeriesView } from "./CategorySeriesView"; import { CategoryFrame } from "./CategoryFrame"; import { SeriesLayerPropertyOverlay } from "./SeriesLayerPropertyOverlay"; import { CategoryMarkerManager } from "./CategoryMarkerManager"; import { AxisRange } from "./AxisRange"; import { Rect } from "igniteui-react-core"; import { ScalerParams } from "./ScalerParams"; import { ISortingAxis_$type } from "./ISortingAxis"; import { IFastItemsSource_$type } from "igniteui-react-core"; import { CollisionAvoider } from "./CollisionAvoider"; import { ISupportsMarkers_$type } from "./ISupportsMarkers"; import { ChartSelection } from "./ChartSelection"; import { PropertyMetadata } from "igniteui-react-core"; import { FastFlattener } from "igniteui-react-core"; /** * @hidden */ export let RangeCategoryBucketCalculator = /*@__PURE__*/ (() => { class RangeCategoryBucketCalculator extends CategoryBucketCalculator { constructor(a) { super(a); this.j = null; this.l = 0; this.k = 0; this.i = null; this.h = null; this.j = a; } getBucketWithoutUnknowns(a) { let b = false; let c = this.i; let d = this.h; let e = this.l; let f = this.k; let g = Math.min(e, f); let h = a * this.d; let i = Math.min(h + this.d - 1, g - 1); let j = 1.7976931348623157E+308; let k = -1.7976931348623157E+308; let l = true; let m = 0; let n = 0; let o; let p; if (h <= i) { for (let q = h; q <= i; ++q) { m = c[q]; n = d[q]; if (m < n) { o = m; p = n; } else { p = m; o = n; } if (!l) { j = j < o ? j : o; k = k > o ? k : o; j = j < p ? j : p; k = k > p ? k : p; } else { j = Math.min(j, o); k = Math.max(k, o); k = Math.max(k, p); j = Math.min(j, p); l = false; } } } if (b && n < m) { let r = j; j = k; k = r; } if (!l) { let s = new Array(3); s[0] = 0.5 * (h + i); s[1] = j; s[2] = k; return s; } let t = new Array(3); t[0] = NaN; t[1] = NaN; t[2] = NaN; return t; } getBucket(a) { let b = false; let c = this.i; let d = this.h; let e = this.l; let f = this.k; let g = Math.min(e, f); let h = a * this.d; let i = Math.min(h + this.d - 1, g - 1); let j = NaN; let k = NaN; let l = true; let m = 0; let n = 0; let o; let p; if (h <= i) { for (let q = h; q <= i; ++q) { m = c[q]; n = d[q]; if (m < n) { o = m; p = n; } else { p = m; o = n; } if (!l) { if (!isNaN_(o)) { j = j < o ? j : o; k = k > o ? k : o; } if (!isNaN_(p)) { j = j < p ? j : p; k = k > p ? k : p; } } else { if (!isNaN_(o)) { if (isNaN_(j)) { j = o; } else { j = Math.min(j, o); } if (!isNaN_(k)) { k = Math.max(k, o); } } if (!isNaN_(p)) { if (isNaN_(k)) { k = p; } else { k = Math.max(k, p); } if (!isNaN_(j)) { j = Math.min(j, p); } } if (!isNaN_(j) && !isNaN_(k)) { l = false; } } } } if (n < m && b) { let r = j; j = k; k = r; } if (!l) { let s = new Array(3); s[0] = 0.5 * (h + i); s[1] = j; s[2] = k; return s; } let t = new Array(3); t[0] = NaN; t[1] = NaN; t[2] = NaN; return t; } cacheValues() { this.l = this.j.di.lowColumn.count; this.k = this.j.di.highColumn.count; this.i = this.j.di.lowColumn.asArray(); this.h = this.j.di.highColumn.asArray(); } unCacheValues() { this.i = null; this.h = null; } } RangeCategoryBucketCalculator.$t = /*@__PURE__*/ markType(RangeCategoryBucketCalculator, 'RangeCategoryBucketCalculator', CategoryBucketCalculator.$); return RangeCategoryBucketCalculator; })(); /** * @hidden */ export let RangeCategorySeries = /*@__PURE__*/ (() => { class RangeCategorySeries extends CategorySeries { ct() { return new RangeCategorySeriesView(this); } getHostReferenceValue() { return this.i0(); } q8(a) { super.q8(a); this.aa7 = a; } constructor() { super(); this._RangeFramePreparer = null; this.aa9 = null; this.aa8 = null; this.aa5 = null; this.RangeFramePreparer = new RangeCategoryFramePreparer(1, this, this.aa7, this, this, this.aa7.c9); } get RangeFramePreparer() { return this._RangeFramePreparer; } set RangeFramePreparer(a) { this._RangeFramePreparer = a; } gc() { return this.highlightedItemsSource != null || (this.abf != null && this.abd != null); } hu() { let a = super.hu(); { let b = ((() => { let $ret = new SeriesLayerPropertyOverlay(); $ret.ad = "HighMemberPath"; $ret.p = true; $ret.y = "HighlightedHighMemberPath"; $ret.q = true; return $ret; })()); b.valueResolving = delegateCombine(b.valueResolving, runOn(this, this.abm)); a.add(b); } { let c = ((() => { let $ret = new SeriesLayerPropertyOverlay(); $ret.ad = "LowMemberPath"; $ret.p = true; $ret.y = "HighlightedLowMemberPath"; $ret.q = true; return $ret; })()); c.valueResolving = delegateCombine(c.valueResolving, runOn(this, this.abn)); a.add(c); } return a; } abn(a, b) { if (this.abf != null) { b.value = this.abf; return; } b.value = this.abk; } abm(a, b) { if (this.abd != null) { b.value = this.abd; return; } b.value = this.abh; } ku(a, b) { let c = this.ni(b); if (c == RangeCategorySeries.$$p[0]) { return this.kv(a, b, this.abh); } if (c == RangeCategorySeries.$$p[3]) { return this.kv(a, b, this.abk); } if (c == RangeCategorySeries.$$p[2]) { return this.kv(a, b, this.abf); } if (c == RangeCategorySeries.$$p[1]) { return this.kv(a, b, this.abd); } return super.ku(a, b); } mi(a) { let b = this.ni(a); if (b == RangeCategorySeries.$$p[0]) { return this.abh; } if (b == RangeCategorySeries.$$p[3]) { return this.abk; } if (b == RangeCategorySeries.$$p[2]) { return this.abf; } if (b == RangeCategorySeries.$$p[1]) { return this.abd; } return super.mi(a); } get lowColumn() { return this.aa9; } set lowColumn(a) { if (this.aa9 != a) { let b = this.aa9; this.aa9 = a; this.raisePropertyChanged("LowColumn", b, this.aa9); } } get highColumn() { return this.aa8; } set highColumn(a) { if (this.aa8 != a) { let b = this.aa8; this.aa8 = a; this.raisePropertyChanged("HighColumn", b, this.aa8); } } zf() { return 11; } aay(a, b) { super.aay(a, b); b.ck = true; CategoryMarkerManager.e(this, a.p, b.dc, this.xt); this.aak(b, a); } abo(a, b, c, d, e, f) { this.aa7.dj(a, b, c, d, e, f); } az(a) { if (a.isEmpty && this.dc != null) { a = this.dc.xn; } let b = this.y3(); if (this.lowColumn == null || this.highColumn == null) { return null; } let c = this.wu(this.cw); let d = new ScalerParams(0, a, this.dc.x5, b.df, this.getEffectiveViewport()); let e = (b.fw(c.left, d)); let f = (b.fw(c.right, d)); if (b.df) { let g = e; e = f; f = g; } let h = null; if (b.dm) { h = b; e = h.i$f(e); f = h.i$f(f); } else { e = Math.floor(e); f = Math.ceil(f); } e = Math.max(0, Math.min(this.lowColumn.count - 1, e)); f = Math.max(0, Math.min(this.lowColumn.count - 1, f)); let i = 1.7976931348623157E+308; let j = -1.7976931348623157E+308; for (let k = truncate(e); k <= truncate(f); k++) { let l = k; if (h != null) { l = h.i$b._inner[k]; } let m = this.lowColumn.item(l); if (this.lowColumn.mayContainUnknowns) { if (isInfinity(m) || isNaN_(m)) { continue; } } let n = this.highColumn.item(l); if (this.highColumn.mayContainUnknowns) { if (isInfinity(n) || isNaN_(n)) { continue; } } i = Math.min(i, m); j = Math.max(j, n); } let o = new AxisRange(i, j); let p = this.zk(); o = this.ax(o, p, a); return o; } ge(a) { let b = new Rect(0, 0, 0, 1, 1); let c = this.cw != null ? this.cw.ca : Rect.empty; c = c.copy(); let d = this.cw != null ? this.cw.b9 : Rect.empty; let e = !c.isEmpty && !d.isEmpty && this.dp != null ? this.dp.indexOf(a) : -1; let f = this.fetchXAxis(); let g = this.fetchYAxis(); let h = this.ww(this.cw); let i; if (f != null) { let j = new ScalerParams(0, b, b, f.df, h); i = f.ft(e, j); } else { i = NaN; } let k = f != null ? this.RangeFramePreparer.r(typeCast(ICategoryScaler_$type, f), b, b, h) : 0; i += k; if (e >= 0 && Rect.l_op_Inequality(c, null) && Rect.l_op_Inequality(d, null)) { if (!isNaN_(i)) { if (i < c.left + 0.1 * c.width) { i = i + 0.4 * c.width; } if (i > c.right - 0.1 * c.width) { i = i - 0.4 * c.width; } c.x = i - 0.5 * c.width; } if (g != null && this.highColumn != null && e < this.highColumn.count) { let l = new ScalerParams(0, b, b, g.df, h); l.b = this.i0(); let m = g.ft(this.highColumn.item(e), l); let n = g.ft(this.lowColumn.item(e), l); if (!isNaN_(m) && !isNaN_(n)) { let o = Math.abs(n - m); if (c.height < o) { c.height = o; c.y = Math.min(n, m); } else { if (n < c.top + 0.1 * c.height) { n = n + 0.4 * c.height; } if (n > c.bottom - 0.1 * c.height) { n = n - 0.4 * c.height; } c.y = n - 0.5 * c.height; } } } if (this.c4 != null) { this.c4.au(this.dc, c, true); } } return e >= 0; } rh(a, b, c, d) { super.rh(a, b, c, d); switch (b) { case "FastItemsSource": if (typeCast(IFastItemsSource_$type, c) != null) { c.deregisterColumn(this.lowColumn); c.deregisterColumn(this.highColumn); this.lowColumn = null; this.highColumn = null; } if (typeCast(IFastItemsSource_$type, d) != null) { this.lowColumn = this.dl(this.abk); this.highColumn = this.dl(this.abh); } if (!this.z0()) { this.ze.c9.g(this.ie); this.rz(this.gh && c != null); } break; case RangeCategorySeries.$$p[3]: if (this.dp != null) { this.dp.deregisterColumn(this.lowColumn); this.lowColumn = this.dl(this.abk); } break; case "LowColumn": if (!this.z0()) { this.ze.c9.g(this.ie); this.rz(this.gh && this.d9); } break; case RangeCategorySeries.$$p[0]: if (this.dp != null) { this.dp.deregisterColumn(this.highColumn); this.highColumn = this.dl(this.abh); } break; case "HighColumn": if (!this.z0()) { this.ze.c9.g(this.ie); this.rz(this.gh && this.d9); } break; } } ay(a) { if (this.lowColumn == null || this.lowColumn.count == 0 || this.highColumn == null || this.highColumn.count == 0) { return null; } if (a == this.fetchXAxis()) { let b = Math.min(this.lowColumn.count, this.highColumn.count); return new AxisRange(0, b - 1); } if (a == this.fetchYAxis()) { let c = Math.min(this.lowColumn.minimum, this.highColumn.minimum); let d = Math.max(this.lowColumn.maximum, this.highColumn.maximum); return new AxisRange(Math.min(c, d), Math.max(c, d)); } return null; } ph(a, b, c, d) { if (this.fetchXAxis() != null && typeCast(ISortingAxis_$type, this.fetchXAxis()) !== null) { this.fetchXAxis().i$i(); } let e = this.fetchXAxis(); switch (a) { case 3: if (d == this.abk || d == this.abh) { if (e != null) { e.d2(); } if (!this.z0()) { this.rz(true); } } break; case 1: if (e != null) { e.d2(); } this.ze.c9.g(this.ie); if (!this.z0()) { this.rz(true); } break; case 0: if (e != null) { e.d2(); } this.ze.c9.g(this.ie); if (!this.z0()) { this.rz(true); } break; case 2: if (e != null) { e.d2(); } if (this.abk != null && this.abh != null && this.ze.c9.d > 0 && !this.z0()) { this.rz(true); } break; case 4: if (e != null) { e.d2(); } this.ze.c9.g(this.ie); if (!this.z0()) { this.rz(true); } break; } } hf(a, b, c) { let d = super.hf(a, b, c); if (this.lowColumn == null || this.lowColumn.count == 0 || this.highColumn == null || this.highColumn.count == 0) { d = false; } return d; } aav(a, b) { super.aav(a, b); this.RangeFramePreparer.d(a, b); } get currentCategoryMode() { return this.preferredCategoryMode(typeCast(CategoryAxisBase.$, this.fetchXAxis())); } get scaler() { return typeCast(ICategoryScaler_$type, this.fetchXAxis()); } get yScaler() { return typeCast(IScaler_$type, this.fetchYAxis()); } get bucketizer() { return this.ze.c9; } get currentMode2Index() { return this.z9(); } provideCollisionDetector() { return new CollisionAvoider(); } get mayContainUnknowns() { return this.lowColumn == null || this.lowColumn.mayContainUnknowns || this.highColumn == null || this.highColumn.mayContainUnknowns; } r1(a, b) { let c = this.g1; super.r1(a, b); if (!c) { this.cw.be(b); return; } this.cw.be(b); if (this.d7(this.cv)) { return; } let d = new RangeCategoryFramePreparer(1, this, typeCast(ISupportsMarkers_$type, this.cv), this.dc.dp.o, this, this.cv.c9); if (!this.gt) { this.y8 = new CategoryFrame(3); this.y8.x(); d.d(this.y8, this.cv); } this.gt = false; this.aay(this.y8, this.cv); this.g1 = false; } ry(a, b, c, d, e) { super.ry(a, b, c, d, e); let f = this.ba.a$j.item(d); let g = f; g.c9.g(this.ie); f.bd(c); if (this.d7(g)) { return; } let h = new RangeCategoryFramePreparer(1, this, typeCast(ISupportsMarkers_$type, f), f, this, f.c9); if (this.aa5 == null) { this.aa5 = new CategoryFrame(3); } this.aa5.x(); h.d(this.aa5, g); this.aay(this.aa5, g); } i0() { return Series.i1(this.lowColumn, typeCast(ISortingAxis_$type, this.fetchXAxis())); } aar(a, b, c, d, e, f, g) { if (c == -1 || d == -1) { return; } for (let h = c; h <= d; h++) { let i = this.lowColumn.item(h); let j = this.highColumn.item(h); let k = Math.min(i, j); let l = Math.max(i, j); if (k < f && e < l) { if (g == 7 || g == 6) { b.add(((() => { let $ret = new ChartSelection(); $ret.series = this; return $ret; })())); return; } this.aai(b, h, g); } } } aai(a, b, c) { if (c == 2 || c == 1) { a.add(((() => { let $ret = new ChartSelection(); $ret.item = this.dp.item(b); return $ret; })())); } else { a.add(((() => { let $ret = new ChartSelection(); $ret.item = this.dp.item(b); $ret.series = this; return $ret; })())); } } get useHighMarkerFidelity() { return this.z1; } } RangeCategorySeries.$t = /*@__PURE__*/ markType(RangeCategorySeries, 'RangeCategorySeries', CategorySeries.$, [IIsCategoryBased_$type, IHasHighLowValueCategory_$type]); RangeCategorySeries.$$p = /*@__PURE__*/ markDep(DependencyProperty, PropertyMetadata, RangeCategorySeries, 'raisePropertyChanged', ['HighMemberPath:abh:abr', [2, null], 'HighlightedHighMemberPath:abd:abp', [2, null], 'HighlightedLowMemberPath:abf:abq', [2, null], 'LowMemberPath:abk:abs', [2, null]]); return RangeCategorySeries; })(); /** * @hidden */ export let RangeCategorySeriesView = /*@__PURE__*/ (() => { class RangeCategorySeriesView extends CategorySeriesView { constructor(a) { super(a); this.di = null; this.di = a; } dj(a, b, c, d, e, f) { a.an.clear(); b.an.clear(); c.an.clear(); let g = FastFlattener.b(d, e, true, f, this.f.ie); let h = FastFlattener.b(d, e, false, f, this.f.ie); let i = g.count; let j = h.count; let k; let l; let m; let n; for (let o = 0; o < i; o++) { k = g.item(o); l = e._inner[k]; m = l[0]; n = l[1]; a.an.add({ $type: Point_$type, x: m, y: n }); b.an.add({ $type: Point_$type, x: m, y: n }); } let p; let q; for (let r = 0; r < j; r++) { k = h.item(r); l = e._inner[k]; if (f) { p = l[0]; q = l[2]; } else { p = l[2]; q = l[3]; } c.an.add({ $type: Point_$type, x: p, y: q }); b.an.add({ $type: Point_$type, x: p, y: q }); } a.ab = a.an.count > 0; b.ab = b.an.count > 0; c.ab = c.an.count > 0; } da() { return new RangeCategoryBucketCalculator(this); } } RangeCategorySeriesView.$t = /*@__PURE__*/ markType(RangeCategorySeriesView, 'RangeCategorySeriesView', CategorySeriesView.$); return RangeCategorySeriesView; })();