UNPKG

igniteui-react-charts

Version:

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

728 lines (727 loc) 24 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 { __extends, __values } from "tslib"; import { VerticalAnchoredCategorySeries } from "./VerticalAnchoredCategorySeries"; import { IBarSeries_$type } from "./IBarSeries"; import { DependencyProperty } from "igniteui-react-core"; import { Defaults } from "./Defaults"; import { Rect } from "igniteui-react-core"; import { typeCast, fromEnum, runOn, markType, markDep } from "igniteui-react-core"; import { ScalerParams } from "./ScalerParams"; import { List$1 } from "igniteui-react-core"; import { ChartSelection } from "./ChartSelection"; import { CategorySeriesView } from "./CategorySeriesView"; import { BarFramePreparer } from "./BarFramePreparer"; import { Pool$1 } from "igniteui-react-core"; import { Rectangle } from "igniteui-react-core"; import { AxisRange } from "./AxisRange"; import { CategoryBucketCalculator } from "./CategoryBucketCalculator"; import { AnchoredCategorySeriesView } from "./AnchoredCategorySeriesView"; import { CategoryTrendLineManagerFactory } from "./CategoryTrendLineManagerFactory"; import { BarTrendLineManager } from "./BarTrendLineManager"; import { PropertyMetadata } from "igniteui-react-core"; import { truncate, isNaN_, isInfinity } from "igniteui-react-core"; import { ISupportsMarkers_$type } from "./ISupportsMarkers"; import { Color } from "igniteui-react-core"; /** * @hidden */ var BarSeries = /** @class */ /*@__PURE__*/ (function (_super) { __extends(BarSeries, _super); function BarSeries() { var _this = _super.call(this) || this; _this.ab = BarSeries.$; _this.y4 = new BarFramePreparer(1, _this, _this.acv, _this, _this, _this.acv.c9); return _this; } BarSeries.prototype.bk = function () { return new BarSeries(); }; BarSeries.prototype.get_ez = function () { return true; }; BarSeries.prototype.jl = function () { if (!isNaN_(this.jk)) { return _super.prototype.jl.call(this); } return Defaults.h; }; BarSeries.prototype.get_fm = function () { return true; }; BarSeries.prototype.ct = function () { return new BarSeriesView(this); }; BarSeries.prototype.y9 = function () { return 1; }; BarSeries.prototype.cz = function () { if (this.c0 == 0) { return 2; } return _super.prototype.cz.call(this); }; BarSeries.prototype.q3 = function (a) { _super.prototype.q3.call(this, a); this.acv = a; }; BarSeries.prototype.get_ef = function () { return true; }; BarSeries.prototype.ws = function (a) { if (this.xAxis == null || this.yAxis == null || this.yz.h.count == 0) { return Rect.empty; } var b = this.cw.ca; var c = this.cw.b9; var d = this.getEffectiveViewport1(this.cw); var e = new ScalerParams(0, b, c, this.xAxis.ch, d); var f = this.wc(a); var g = this.kb(a, true); var h = this.j9(a, true); var i = truncate(Math.floor(g / this.z0(this.cw))); var j = truncate(Math.floor(h / this.z0(this.cw))); var k = i - this.z1(this.cw); var l = j - this.z1(this.cw); if (k < 0) { k = 0; } if (k > this.yz.h.count - 1) { k = this.yz.h.count - 1; } if (l < 0) { l = 0; } if (l > this.yz.h.count - 1) { l = this.yz.h.count - 1; } var m = this.yz.h._inner[k]; var n = this.yz.h._inner[l]; var o = Math.abs(f.y - m[0]); var p = Math.abs(f.y - n[0]); var q = this.abg(this.y8); var r = this.yAxis.k8(b, c, d); if (o < p) { var s = m[0] - 0.5 * r; var t = m[1]; var u = q; return new Rect(0, Math.min(u, t), s, Math.max(u, t) - Math.min(u, t), r); } else { var v = n[0] - 0.5 * r; var w = n[1]; var x = q; return new Rect(0, Math.min(x, w), v, Math.max(x, w) - Math.min(x, w), r); } }; BarSeries.prototype.gx = function (a, b) { if (this.g0(a, b)) { return true; } if (this.xm(a, b)) { return true; } return false; }; BarSeries.prototype.ak = function (a, b) { var c = new List$1(ChartSelection.$, 0); this.p6(a, c, b); return c.toArray(); }; BarSeries.prototype.p6 = function (a, b, c) { this.aak(a, b, c, this.yy, 1); }; BarSeries.prototype.y5 = function (a) { var b = typeCast(CategorySeriesView.$, a); if (b != null && b.t) { if (b.s) { return new BarFramePreparer(1, this, typeCast(ISupportsMarkers_$type, b), b, this, b.c9); } else { return new BarFramePreparer(1, this, typeCast(ISupportsMarkers_$type, b), this.dc.dc.o, this, b.c9); } } else { return this.y4; } }; BarSeries.prototype.ac = function () { _super.prototype.ac.call(this); }; BarSeries.prototype.preferredCategoryMode = function (a) { return 2; }; BarSeries.prototype.o7 = function (a, b) { _super.prototype.o7.call(this, a, b); var c = typeCast(BarSeriesView.$, b); if (a && c != null && c.du != null) { c.du.count = 0; } }; BarSeries.prototype.z3 = function () { var e_1, _a; if (this.bo != null) { var a = this.bo; return a.z3(); } var b = 0; try { for (var _b = __values(fromEnum(this.dc.series)), _c = _b.next(); !_c.done; _c = _b.next()) { var c = _c.value; if (c == this) { return b; } var d = typeCast(IBarSeries_$type, c); if (d != null && d.yAxis == this.yAxis && d.getPreferredCategoryMode() == 2) { b++; } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_1) throw e_1.error; } } return -1; }; BarSeries.prototype.abg = function (a) { var b = 0; var c = a.ca; var d = a.b9; var e = this.getEffectiveViewport1(a); if (!c.isEmpty && !d.isEmpty && this.xAxis != null) { var f = new ScalerParams(0, c, d, this.xAxis.ch, e); b = this.xAxis.el(this.xAxis.me, f); } return b; }; BarSeries.prototype.ay = function (a) { if (this.valueColumn == null || this.valueColumn.count == 0) { return null; } if (a == this.yAxis) { return new AxisRange(0, this.valueColumn.count - 1); } if (a == this.xAxis) { return new AxisRange(this.valueColumn.minimum, this.valueColumn.maximum); } return null; }; BarSeries.prototype.ge = function (a) { var b = this.cw.ca; b = b.copy(); var c = this.cw.b9; var d = new Rect(0, 0, 0, 1, 1); var e = !b.isEmpty && !c.isEmpty && this.dp != null ? this.dp.indexOf(a) : -1; var f = this.wq(this.cw); var g = new ScalerParams(0, d, d, this.xAxis.ch, f); var h = new ScalerParams(0, d, d, this.yAxis.ch, f); var i = this.yAxis != null ? this.yAxis.el(e, h) : NaN; var j = this.yAxis != null ? this.y4.r(this.yAxis, d, d, f) : 0; i += j; var k = this.xAxis != null && this.valueColumn != null && e < this.valueColumn.count ? this.xAxis.el(this.valueColumn.item(e), g) : NaN; if (!isNaN_(k)) { if (k < b.left + 0.1 * b.width) { k = k + 0.4 * b.width; b.x = k - 0.5 * b.width; } if (k > b.right - 0.1 * b.width) { k = k - 0.4 * b.width; b.x = k - 0.5 * b.width; } } if (!isNaN_(i)) { if (i < b.top + 0.1 * b.height) { i = i + 0.4 * b.height; b.y = i - 0.5 * b.height; } if (i > b.bottom - 0.1 * b.height) { i = i - 0.4 * b.height; b.y = i - 0.5 * b.height; } } if (this.c4 != null) { this.c4.au(this.dc, b, true); } return e >= 0; }; BarSeries.prototype.ix = function () { return this.yAxis.k8(this.cw.ca, this.cw.b9, this.getEffectiveViewport1(this.cw)); }; BarSeries.prototype.aas = function (a, b) { _super.prototype.aas.call(this, a, b); var c = a.h; if (!b.r()) { return; } var d = b.ca; var e = b.b9; var f = this.getEffectiveViewport1(b); var g = new ScalerParams(0, d, e, this.xAxis.ch, f); var h = this.yAxis; var i = new ScalerParams(0, d, e, this.yAxis.ch, f); var j = this.xAxis; var k = j.el(j.me, g); var l = this.yAxis.k8(d, e, f); var m = typeCast(BarSeriesView.$, b); if (isNaN_(l) || isInfinity(l) || isNaN_(k)) { m.du.count = 0; return; } this.y7.a2(this, this.zr(), runOn(this, this.yr), this.z0(b), this.z1(b)); this.y7.r = this.acw; this.y7.s = this.acx; this.y7.k = this.acw; this.y7.l = this.acx; var n = false; var o = this.y7.b; if (o != null) { n = true; } var p = this.xAxis.cn; var q = p ? this.xAxis : null; var r = this.valueColumn.count; var s = this.z0(b); var t = 0; for (var u = 0; u < c.count; ++u) { var v = c._inner[u][0] - 0.5 * l; var w = c._inner[u][1]; var x = k; x = Math.max(x, -100); w = Math.min(w, e.right + 100); var y = Math.abs(w - x); if (isInfinity(y) || isNaN_(y)) { continue; } var z = m.du.item(t); t++; z.height = l; z.width = y; var aa = this.y7.aw(r, u)[0]; if (n) { this.aao(c, u, r, h, i, b.t, aa); } if (z.dataContext != null) { var ab = z.dataContext; if (s == 1) { if (aa >= 0 && aa < this.dp.count) { if (q != null && q.i$b != null && q.i$b.count > aa) { aa = q.i$b._inner[aa]; } ab.item = this.dp.item(aa); } } else { ab.item = null; } } this.y7.ad(z, false, false, false, false); z.ap = this.y7.k; z.aq = this.y7.l; m.dz(z, Math.min(w, x), v); } m.du.count = t; b.dg(a); }; BarSeries.prototype.pd = function (a, b, c, d) { var e_2, _a; switch (a) { case 4: case 1: case 0: this.aa2.c9.g(this.ie); break; } if (this.aa2.dl) { this.aa2.dk.g$i(a, b, c, d); } if (this.aa2.aa.count > 0) { try { for (var _b = __values(fromEnum(this.aa2.aa)), _c = _b.next(); !_c.done; _c = _b.next()) { var e = _c.value; e.g$i(a, b, c, d); } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_2) throw e_2.error; } } } switch (a) { case 4: if (this.xAxis != null && !this.xAxis.c1()) { this.ru(true); } break; case 1: if (this.xAxis != null && !this.xAxis.c1()) { this.ru(true); } break; case 0: if (this.xAxis != null && !this.xAxis.c1()) { this.ru(true); } break; case 2: if (this.abu != null && this.aa2.c9.d > 0) { this.ru(true); } break; case 3: if (d == this.abu) { if (this.xAxis != null && !this.xAxis.c1()) { this.ru(true); } } break; } }; BarSeries.prototype.rc = function (a, b, c, d) { _super.prototype.rc.call(this, a, b, c, d); switch (b) { case VerticalAnchoredCategorySeries.$$p[0]: if (c != null) { c.b0(this); } if (d != null) { d.ct(this); } this.aa2.c9.g(this.ie); if (this.xAxis != null && this.xAxis.c1()) { this.ru(false); } break; case VerticalAnchoredCategorySeries.$$p[1]: if (c != null) { c.b0(this); } if (d != null) { d.ct(this); } if (this.aa2.dl) { this.aa2.dk = CategoryTrendLineManagerFactory.a(this.aa2.dk, this.yAxis, this.sz, this, this.ds); } this.aa2.c9.g(this.ie); this.ru(false); break; case "FastItemsSource": if (this.xAxis != null && !this.xAxis.c1()) { this.aa2.c9.g(this.ie); this.ru(this.gh && c != null); } break; case "ValueColumn": if (this.xAxis != null && !this.xAxis.c1()) { this.aa2.c9.g(this.ie); this.ru(this.gh && this.d9); } break; case "SeriesViewer": if (c != null && d == null) { this.pe(this.xAxis); this.pe(this.yAxis); } if (c == null && d != null) { this.rk(this.xAxis); this.rk(this.yAxis); } this.aa2.c9.g(this.ie); this.ru(false); break; } }; BarSeries.prototype.getPreferredCategoryMode = function () { return this.preferredCategoryMode(this.yAxis); }; BarSeries.prototype.bd = function () { return new BarTrendLineManager(); }; Object.defineProperty(BarSeries.prototype, "useHighMarkerFidelity", { get: function () { return this.zv; }, enumerable: false, configurable: true }); BarSeries.$t = markType(BarSeries, 'BarSeries', VerticalAnchoredCategorySeries.$, [IBarSeries_$type]); BarSeries.$$p = markDep(DependencyProperty, PropertyMetadata, BarSeries, 'raisePropertyChanged', ['RadiusX:acw:ac0', [1, 0], 'RadiusY:acx:ac1', [1, 0]]); return BarSeries; }(VerticalAnchoredCategorySeries)); export { BarSeries }; /** * @hidden */ var BarBucketCalculator = /** @class */ /*@__PURE__*/ (function (_super) { __extends(BarBucketCalculator, _super); function BarBucketCalculator(a) { var _this = _super.call(this, a) || this; _this.i = null; _this.h = null; _this.j = 0; _this.i = a; return _this; } BarBucketCalculator.prototype.g = function (a) { var b = this.c.ca; var c = this.c.b9; var d = this.c.db.dp; if (b.isEmpty || c.isEmpty || this.i.dt.yAxis == null || d == null || d.count == 0) { this.d = 0; return; } var e = typeCast(BarSeries.$, this.c.db); var f = e.wo(this.c); var g = e.getEffectiveViewport1(this.c); var h = new ScalerParams(0, b, c, e.yAxis.ch, g); var i = Math.floor(e.yAxis.ep(f.top, h, 0)); var j = Math.ceil(e.yAxis.ep(f.bottom, h, 0)); if (!e.yAxis.ch) { j = Math.ceil(e.yAxis.ep(f.top, h, 0)); i = Math.floor(e.yAxis.ep(f.bottom, h, 0)); } var k = Math.floor((j - i + 1) * a / f.height); this.d = truncate(Math.max(1, k)); this.e = truncate(Math.max(0, Math.floor(i / this.d) - 1)); this.f = truncate(Math.ceil(j / this.d)); }; BarBucketCalculator.prototype.getBucketWithoutUnknowns = function (a) { var b = this.h; var c = this.j; var d = a * this.d; var e = d + this.d - 1; var f = c - 1; d = d < f ? d : f; e = e < f ? e : f; var g = 1.7976931348623157E+308; var h = -1.7976931348623157E+308; var i = true; for (var j = d; j <= e; ++j) { var k = b[j]; g = g < k ? g : k; h = h > k ? h : k; Math.max(h, k); i = false; } if (!i) { return [0.5 * (d + e), g, h]; } return [0.5 * (d + e), NaN, NaN]; }; BarBucketCalculator.prototype.getBucket = function (a) { var b = this.h; var c = this.j; var d = a * this.d; var e = d + this.d - 1; var f = c - 1; d = d < f ? d : f; e = e < f ? e : f; var g = NaN; var h = NaN; for (var i = d; i <= e; ++i) { var j = b[i]; if (!isNaN_(g)) { if (!isNaN_(j)) { g = Math.min(g, j); h = Math.max(h, j); } } else { g = j; h = j; } } if (!isNaN_(g)) { return [0.5 * (d + e), g, h]; } return [0.5 * (d + e), NaN, NaN]; }; BarBucketCalculator.prototype.cacheValues = function () { this.j = this.i.dt.valueColumn.count; this.h = this.i.dt.valueColumn.asArray(); }; BarBucketCalculator.prototype.unCacheValues = function () { this.h = null; }; BarBucketCalculator.$t = markType(BarBucketCalculator, 'BarBucketCalculator', CategoryBucketCalculator.$); return BarBucketCalculator; }(CategoryBucketCalculator)); export { BarBucketCalculator }; /** * @hidden */ var BarSeriesView = /** @class */ /*@__PURE__*/ (function (_super) { __extends(BarSeriesView, _super); function BarSeriesView(a) { var _this = _super.call(this, a) || this; _this.dt = null; _this.du = null; _this.dv = null; _this.d0 = new Rectangle(); _this.dt = a; _this.du = ((function () { var $ret = new Pool$1(Rectangle.$); $ret.create = runOn(_this, _this.d1); $ret.activate = runOn(_this, _this.dw); $ret.disactivate = runOn(_this, _this.dy); $ret.destroy = runOn(_this, _this.dx); return $ret; })()); _this.dk = new BarTrendLineManager(); return _this; } BarSeriesView.prototype.a4 = function () { _super.prototype.a4.call(this); this.dv = new List$1(Rectangle.$, 0); if (!this.t) { this.dt.xf = Defaults.c; this.dt.jq = Defaults.i; } }; BarSeriesView.prototype.d1 = function () { var a = new Rectangle(); this.dv.add(a); a._visibility = 1; return a; }; BarSeriesView.prototype.dw = function (a) { a._visibility = 0; }; BarSeriesView.prototype.dy = function (a) { a._visibility = 1; }; BarSeriesView.prototype.dx = function (a) { this.dv.remove(a); }; BarSeriesView.prototype.dz = function (a, b, c) { if (!this.isDirty) { this.a2(); } a.o = c; a.n = b; }; BarSeriesView.prototype.da = function () { return new BarBucketCalculator(this); }; BarSeriesView.prototype.bt = function (a, b) { _super.prototype.bt.call(this, a, b); var c = a; var d = this.b4(b); c._fill = d; c._stroke = d; c.ad = this.f.ig; }; BarSeriesView.prototype.ak = function (a) { return this.dv._inner[a]; }; BarSeriesView.prototype.aj = function (a) { var b = this.dv._inner[a]; this.d0.n = b.n; this.d0.o = b.o; this.d0.width = b.width; this.d0.height = b.height; var c = this.b4(a); this.d0._fill = c; this.d0._stroke = c; this.d0.ad = this.f.ig + 3; return this.d0; }; BarSeriesView.prototype.bj = function (a, b) { _super.prototype.bj.call(this, a, b); if (a.d) { for (var c = 0; c < this.dv.count; c++) { var d = this.ai(c, b); this.br(d, c, b); a.w(d); } } }; BarSeriesView.prototype.ax = function (a) { var e_3, _a, e_4, _b; _super.prototype.ax.call(this, a); var b = 0; var c = new List$1(Rectangle.$, 0); try { for (var _c = __values(fromEnum(this.du.a)), _d = _c.next(); !_d.done; _d = _c.next()) { var d = _d.value; c.add(d); } } catch (e_3_1) { e_3 = { error: e_3_1 }; } finally { try { if (_d && !_d.done && (_a = _c.return)) _a.call(_c); } finally { if (e_3) throw e_3.error; } } c.aa(function (e, f) { if (e.o > f.o) { return -1; } else if (e.o < f.o) { return 1; } else { return 0; } }); try { for (var _e = __values(fromEnum(c)), _f = _e.next(); !_f.done; _f = _e.next()) { var e = _f.value; this.f.bc.exportRectangleData(a, e, "column" + b, ["Main", "Fill"]); } } catch (e_4_1) { e_4 = { error: e_4_1 }; } finally { try { if (_f && !_f.done && (_b = _e.return)) _b.call(_e); } finally { if (e_4) throw e_4.error; } } b++; }; BarSeriesView.prototype.an = function () { var a = new Color(); a.colorString = "rgba(95,95,95,0.5)"; this.f.v6 = a; this.f.jn = 5; this.f.jo = 5; this.f.jp = -5; }; BarSeriesView.$t = markType(BarSeriesView, 'BarSeriesView', AnchoredCategorySeriesView.$); return BarSeriesView; }(AnchoredCategorySeriesView)); export { BarSeriesView };