igniteui-react-charts
Version:
Ignite UI React charting components for building rich data visualizations using TypeScript APIs.
458 lines (457 loc) • 15.9 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 } from "tslib";
import { HorizontalAnchoredCategorySeries } from "./HorizontalAnchoredCategorySeries";
import { CategoryLineRasterizer } from "./CategoryLineRasterizer";
import { typeCast, Point_$type, Array_$type, runOn, markType } from "igniteui-react-core";
import { ISortingAxis_$type } from "./ISortingAxis";
import { List$1 } from "igniteui-react-core";
import { Path } from "igniteui-react-core";
import { ScalerParams } from "./ScalerParams";
import { ChartSelection } from "./ChartSelection";
import { intDivide, isNaN_ } from "igniteui-react-core";
import { AnchoredCategorySeriesView } from "./AnchoredCategorySeriesView";
import { Defaults } from "./Defaults";
/**
* @hidden
*/
var StepAreaSeries = /** @class */ /*@__PURE__*/ (function (_super) {
__extends(StepAreaSeries, _super);
function StepAreaSeries() {
var _this = _super.call(this) || this;
_this.adk = null;
_this.adk = new CategoryLineRasterizer();
_this.ab = StepAreaSeries.$;
return _this;
}
StepAreaSeries.prototype.bk = function () {
return new StepAreaSeries();
};
StepAreaSeries.prototype.ct = function () {
return new StepAreaSeriesView(this);
};
StepAreaSeries.prototype.rh = function (a) {
_super.prototype.rh.call(this, a);
this.adl = a;
};
StepAreaSeries.prototype.get_ey = function () {
return true;
};
StepAreaSeries.prototype.get_ex = function () {
return true;
};
StepAreaSeries.prototype.get_f4 = function () {
return true;
};
StepAreaSeries.prototype.get_fo = function () {
return true;
};
StepAreaSeries.prototype.cz = function () {
if (this.c0 == 0) {
return 2;
}
return _super.prototype.cz.call(this);
};
StepAreaSeries.prototype.preferredCategoryMode = function (a) {
return typeCast(ISortingAxis_$type, a) !== null ? 0 : 1;
};
StepAreaSeries.prototype.pi = function (a, b) {
_super.prototype.pi.call(this, a, b);
var c = b;
c.du();
};
StepAreaSeries.prototype.adm = function (a, b, c, d, e, f) {
var 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);
};
StepAreaSeries.prototype.zp = function () {
return 1;
};
StepAreaSeries.prototype.i2 = function (a, b, c, d, e, f, g, h) {
var i = NaN;
if (c >= 0 && c < b.count) {
i = b.item(c);
}
var 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;
};
StepAreaSeries.prototype.g2 = function (a, b) {
var c = this.ww(this.w2(a), true, false);
if (this.ada(a, c, b)) {
return true;
}
if (this.g1(a, b)) {
return true;
}
if (this.x2(a, b)) {
return true;
}
return false;
};
StepAreaSeries.prototype.aj = function (a) {
var b = this.adj(a);
if (b == null) {
return null;
}
var c = new Array(1);
if (b.length == 4) {
var 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 {
var 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;
};
StepAreaSeries.prototype.adj = function (a) {
var b = this.am(this.xAxis, this.zf.k, this.aag(this.cw), this.aah(this.cw), this.w2(a), true);
if (b == null) {
return null;
}
var c = this.zg();
var d = b[0];
var 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;
}
var f = this.cw.ca;
var g = this.cw.b9;
var h = this.getEffectiveViewport1(this.cw);
var i = typeCast(ISortingAxis_$type, this.ac0) != null;
var j = this.ac0.dn;
var k = 0;
if (this.ac0 != null) {
k = 0.5 * this.ac0.getCategorySize(f, g, h);
}
var l = new Array(4);
var m = new Array(4);
var n = new Array(4);
var o = new Array(4);
if (!this.ac0.dn) {
var p = d * 2;
l[0] = this.adm(p, false, c, k, j, i);
l[1] = c.k._inner[(intDivide(p, 2))][1];
l[2] = this.adm(p, false, c, k, j, i);
l[3] = c.k._inner[(intDivide(p, 2))][2];
p++;
m[0] = this.adm(p, false, c, k, j, i);
m[1] = c.k._inner[(intDivide(p, 2))][1];
m[2] = this.adm(p, false, c, k, j, i);
m[3] = c.k._inner[(intDivide(p, 2))][2];
p = e * 2;
n[0] = this.adm(p, false, c, k, j, i);
n[1] = c.k._inner[(intDivide(p, 2))][1];
n[2] = this.adm(p, false, c, k, j, i);
n[3] = c.k._inner[(intDivide(p, 2))][2];
p++;
o[0] = this.adm(p, false, c, k, j, i);
o[1] = c.k._inner[(intDivide(p, 2))][1];
o[2] = this.adm(p, false, c, k, j, i);
o[3] = c.k._inner[(intDivide(p, 2))][2];
}
else {
var q = d * 2;
l[0] = this.adm(q, true, c, k, j, i);
l[1] = c.k._inner[(intDivide(q, 2))][1];
l[2] = this.adm(q, true, c, k, j, i);
l[3] = c.k._inner[(intDivide(q, 2))][2];
q++;
m[0] = this.adm(q, true, c, k, j, i);
m[1] = c.k._inner[(intDivide(q, 2))][1];
m[2] = this.adm(q, true, c, k, j, i);
m[3] = c.k._inner[(intDivide(q, 2))][2];
q = e * 2;
n[0] = this.adm(q, true, c, k, j, i);
n[1] = c.k._inner[(intDivide(q, 2))][1];
n[2] = this.adm(q, true, c, k, j, i);
n[3] = c.k._inner[(intDivide(q, 2))][2];
q++;
o[0] = this.adm(q, true, c, k, j, i);
o[1] = c.k._inner[(intDivide(q, 2))][1];
o[2] = this.adm(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];
};
StepAreaSeries.prototype.al = function (a) {
var b = this.adj(a);
if (b == null) {
return null;
}
var c = new Array(1);
if (b.length == 4) {
var 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 {
var 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;
};
StepAreaSeries.prototype.aa8 = function (a, b) {
var _this = this;
_super.prototype.aa8.call(this, a, b);
var c = b.ca;
var d = b.b9;
var e = this.getEffectiveViewport1(b);
var f = typeCast(ISortingAxis_$type, this.ac0) != null;
var g = this.ac0.dn;
var h = this.ac0 != null ? 0.5 * this.ac0.getCategorySize(c, d, e) : 0;
var i = a.k.count * 2;
var j = new List$1(Array_$type, 2, i);
this.zn.a2(this, this.z7(), runOn(this, this.y7), this.aag(b), this.aah(b));
var k = false;
var l = this.zn.b;
if (l != null) {
k = true;
}
if (!this.ac0.dn) {
for (var m = 0; m < i; m++) {
var n = new Array(4);
n[0] = this.adm(m, false, a, h, g, f);
n[1] = a.k._inner[(intDivide(m, 2))][1];
n[2] = this.adm(m, false, a, h, g, f);
n[3] = a.k._inner[(intDivide(m, 2))][2];
j.add(n);
}
}
else {
for (var o = 0; o < i; o++) {
var p = new Array(4);
p[0] = this.adm(o, true, a, h, g, f);
p[1] = a.k._inner[(intDivide(o, 2))][1];
p[2] = this.adm(o, true, a, h, g, f);
p[3] = a.k._inner[(intDivide(o, 2))][2];
j.add(p);
}
}
var q = this.zo.c9.d;
if (k) {
var r = new ScalerParams(0, b.ca, b.b9, this.ac0.dn, e);
this.aa4(j, -1, this.valueColumn.count, this.ac0, r, b.t, -1);
}
var s = typeCast(StepAreaSeriesView.$, b);
var t = s.d7;
var u = s.d8;
var v = s.d5;
var w = s.d6;
this.zn.ad(t, true, false, true, true);
this.zn.ad(u, true, false, true, true);
this.zn.ad(v, false, true, false, false);
this.zn.ad(w, false, true, false, false);
if (b.dd(a)) {
s.dw(i, j, false, q, this.ik, function (x, y, z, aa, ab) { return _this.acg(x, 2 * a.k.count, b); }, 1, this.abh(j, j.count - 1, b.b9, b.ca, true));
b.dg(a);
}
var x = this.fetchYAxis();
s.d5._opacity = this.zn.j * this.ig;
s.d6._opacity = 0.5 * this.zn.j * this.ig;
};
StepAreaSeries.prototype.qi = function (a, b, c) {
this.aa0(a, b, c, this.ze, 1);
};
StepAreaSeries.prototype.ak = function (a, b) {
var c = new List$1(ChartSelection.$, 0);
this.qi(a, c, b);
return c.toArray();
};
Object.defineProperty(StepAreaSeries.prototype, "useHighMarkerFidelity", {
get: function () {
return this.aab;
},
enumerable: false,
configurable: true
});
StepAreaSeries.$t = markType(StepAreaSeries, 'StepAreaSeries', HorizontalAnchoredCategorySeries.$);
return StepAreaSeries;
}(HorizontalAnchoredCategorySeries));
export { StepAreaSeries };
/**
* @hidden
*/
var StepAreaSeriesView = /** @class */ /*@__PURE__*/ (function (_super) {
__extends(StepAreaSeriesView, _super);
function StepAreaSeriesView(a) {
var _this = _super.call(this, a) || this;
_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;
return _this;
}
StepAreaSeriesView.prototype.a4 = function () {
_super.prototype.a4.call(this);
if (!this.t) {
this.dt.xv = Defaults.c;
}
};
Object.defineProperty(StepAreaSeriesView.prototype, "d5", {
get: function () {
return this.d1;
},
enumerable: false,
configurable: true
});
Object.defineProperty(StepAreaSeriesView.prototype, "d7", {
get: function () {
return this.d3;
},
enumerable: false,
configurable: true
});
Object.defineProperty(StepAreaSeriesView.prototype, "d6", {
get: function () {
return this.d2;
},
enumerable: false,
configurable: true
});
Object.defineProperty(StepAreaSeriesView.prototype, "d8", {
get: function () {
return this.d4;
},
enumerable: false,
configurable: true
});
StepAreaSeriesView.prototype.du = function () {
this.d1.an = null;
this.d2.an = null;
this.d3.an = null;
this.d4.an = null;
this.a2();
};
StepAreaSeriesView.prototype.dv = function (a, b, c, d, e, f, g) {
this.dv(a, b, c, d, e, f, g);
};
StepAreaSeriesView.prototype.dw = function (a, b, c, d, e, f, g, h) {
this.dt.adk.a = typeCast(ISortingAxis_$type, this.db.fetchXAxis()) !== null ? true : false;
this.dt.adk.j(this.d1, this.d3, this.d2, this.d4, a, b, c, d, e, f, g, h);
this.a2();
};
StepAreaSeriesView.prototype.bq = function () {
_super.prototype.bq.call(this);
this.dx.an = this.d1.an;
this.dz.an = this.d3.an;
this.dy.an = this.d2.an;
this.d0.an = this.d4.an;
var 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;
};
StepAreaSeriesView.prototype.bj = function (a, b) {
_super.prototype.bj.call(this, 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);
}
};
StepAreaSeriesView.prototype.ax = function (a) {
_super.prototype.ax.call(this, 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;
}(AnchoredCategorySeriesView));
export { StepAreaSeriesView };