igniteui-react-charts
Version:
Ignite UI React charting components for building rich data visualizations using TypeScript APIs.
728 lines (727 loc) • 24 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 { __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 };