igniteui-react-charts
Version:
Ignite UI React charting components for building rich data visualizations using TypeScript APIs.
623 lines (622 loc) • 23.2 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 { ScatterTriangulationSeries } from "./ScatterTriangulationSeries";
import { DependencyProperty } from "igniteui-react-core";
import { Point_$type, typeCast, Number_$type, fromEnum, runOn, delegateRemove, delegateCombine, markType, markDep } from "igniteui-react-core";
import { ValueBrushScale } from "./ValueBrushScale";
import { FastItemIntColumn } from "igniteui-react-core";
import { LinearContourValueResolver } from "./LinearContourValueResolver";
import { SeriesView } from "./SeriesView";
import { DataLegendSeriesValueInfo } from "igniteui-react-core";
import { DataLegendSeriesContext } from "igniteui-react-core";
import { List$1 } from "igniteui-react-core";
import { IFastItemsSource_$type } from "igniteui-react-core";
import { ScalerParams } from "./ScalerParams";
import { ContourBuilder } from "./ContourBuilder";
import { Clipper } from "igniteui-react-core";
import { RectUtil } from "igniteui-react-core";
import { Brush } from "igniteui-react-core";
import { BrushUtil } from "igniteui-react-core";
import { BrushCollection } from "igniteui-react-core";
import { DataContext } from "igniteui-react-core";
import { Path } from "igniteui-react-core";
import { PropertyMetadata } from "igniteui-react-core";
import { boxArray$1 } from "igniteui-react-core";
import { isNaN_ } from "igniteui-react-core";
import { Pool$1 } from "igniteui-react-core";
import { PathGeometry } from "igniteui-react-core";
import { PathFigure } from "igniteui-react-core";
import { PointCollectionUtil } from "igniteui-react-core";
import { PolyLineSegment } from "igniteui-react-core";
import { Tuple$2 } from "igniteui-react-core";
import { GeometryUtil } from "igniteui-react-core";
import { stringIsNullOrEmpty } from "igniteui-react-core";
/**
* @hidden
*/
var ScatterContourSeries = /** @class */ /*@__PURE__*/ (function (_super) {
__extends(ScatterContourSeries, _super);
function ScatterContourSeries() {
var _this = _super.call(this) || this;
_this.y7 = null;
_this.y2 = null;
FastItemIntColumn.m();
_this.ab = ScatterContourSeries.$;
_this.y3 = new LinearContourValueResolver();
return _this;
}
ScatterContourSeries.prototype.bk = function () {
return new ScatterContourSeries();
};
ScatterContourSeries.prototype.get_fk = function () {
return true;
};
ScatterContourSeries.prototype.ku = function (a, b) {
var c = this.ni(b);
if (c == ScatterContourSeries.$$p[4]) {
return this.kv(a, b, this.zg);
}
return _super.prototype.ku.call(this, a, b);
};
ScatterContourSeries.prototype.mi = function (a) {
var b = this.ni(a);
if (b == ScatterContourSeries.$$p[4]) {
return this.zg;
}
return _super.prototype.mi.call(this, a);
};
ScatterContourSeries.prototype.ct = function () {
this.y4 = new ScatterContourSeriesView(this);
return this.y4;
};
Object.defineProperty(ScatterContourSeries.prototype, "y8", {
get: function () {
return this.y7;
},
set: function (a) {
var b = this.y8 != a;
if (b) {
var c = this.y8;
this.y7 = a;
this.raisePropertyChanged("ValueColumn", c, this.y8);
}
},
enumerable: false,
configurable: true
});
ScatterContourSeries.prototype.getDataLegendSeriesContextAt = function (a, b) {
var c = { $type: Point_$type, x: a, y: b };
var d = this.kr(c);
var e = d == null ? NaN : this.iz(d, "XMemberPath");
var f = d == null ? NaN : this.iz(d, "YMemberPath");
var g = d == null ? NaN : this.iz(d, "ValueMemberPath");
var h = new DataLegendSeriesValueInfo();
h.a = 13;
h.l = e;
h.q = "X";
h.r = this.yb != null ? this.yb : "X";
h.s = this.x7 != null ? this.x7 : "X:";
h.t = this.x9 != null ? this.x9 : "";
var i = new DataLegendSeriesValueInfo();
i.a = 14;
i.l = f;
i.q = "Y";
i.r = this.yj != null ? this.yj : "Y";
i.s = this.yf != null ? this.yf : "Y:";
i.t = this.yh != null ? this.yh : "";
var j = new DataLegendSeriesValueInfo();
j.a = 0;
j.l = g;
j.q = "Value";
j.r = this.zg != null ? this.zg : "Value";
j.s = this.zc != null ? this.zc : "V:";
j.t = this.ze != null ? this.ze : "";
var k = new DataLegendSeriesContext();
k.e = ((function () {
var $ret = new List$1(DataLegendSeriesValueInfo.$, 0);
$ret.add(h);
$ret.add(i);
$ret.add(j);
return $ret;
})());
k.h = this.mh();
return k;
};
ScatterContourSeries.prototype.rh = function (a, b, c, d) {
_super.prototype.rh.call(this, a, b, c, d);
switch (b) {
case ScatterContourSeries.$$p[2]:
case ScatterContourSeries.$$p[3]:
this.qm();
break;
case "FastItemsSource":
var e = typeCast(IFastItemsSource_$type, c);
if (e != null) {
e.deregisterColumn(this.y8);
this.y8 = null;
}
var f = typeCast(IFastItemsSource_$type, d);
if (f != null) {
this.y8 = this.dl(this.zg);
}
this.rz(this.gh && c != null);
break;
case ScatterContourSeries.$$p[4]:
if (this.dp != null) {
this.dp.deregisterColumn(this.y8);
this.y8 = this.dl(this.zg);
}
this.rz(false);
this.qs();
break;
case "ValueResolver":
this.rz(false);
this.qs();
break;
case ScatterContourSeries.$$p[1]:
var g = c;
var h = d;
if (g != null) {
g.unregisterSeries(this);
}
if (h != null) {
h.registerSeries(this);
}
this.zk();
this.rz(false);
this.qs();
break;
case "ActualBrush":
this.zk();
this.rz(false);
this.qs();
break;
}
};
ScatterContourSeries.prototype.pb = function (a, b) {
_super.prototype.pb.call(this, a, b);
if (a) {
b.cj(a);
}
};
ScatterContourSeries.prototype.r0 = function (a) {
_super.prototype.r0.call(this, a);
this.zj(this.cw);
};
ScatterContourSeries.prototype.ry = function (a, b, c, d, e) {
_super.prototype.ry.call(this, a, b, c, d, e);
var f = this.ba.a$j.item(d);
f.bd(c);
if (this.d7(f)) {
return;
}
this.zj(f);
};
ScatterContourSeries.prototype.zj = function (a) {
var e_1, _a;
if (this.d7(a)) {
return;
}
var b;
var c;
var d = a;
var e = a.getViewInfo(c, b);
c = e.p0;
b = e.p1;
var f = new ScalerParams(1, b, c, this.w9.df);
f.c = this.getEffectiveViewport1(a);
var g = new ScalerParams(1, b, c, this.xa.df);
g.c = this.getEffectiveViewport1(a);
var h = this.w9;
var i = this.xa;
var j = this.xj.count;
var k;
var xArr_ = this.xm.asArray();
k = (xArr_.slice(0));
var l;
var yArr_ = this.xn.asArray();
l = (yArr_.slice(0));
var m = this.y8.asArray();
var n = this.xj.asArray();
var o = this.xk.asArray();
var p = this.xl.asArray();
var q = this.y3.j(this.y8);
var r = new List$1(Number_$type, 1, q).toArray();
h.j6(boxArray$1(k), 0, k.length, f);
i.j6(boxArray$1(l), 0, l.length, g);
var s = r.length;
var t = new Array(s);
for (var u = 0; u < s; ++u) {
t[u] = new ContourBuilder();
}
var v = c.top;
var w = c.left;
var x = c.right;
var y = c.bottom;
var z;
var aa;
var ab;
var ac;
var ad = k.length;
for (var ae = 0; ae < j; ae++) {
var af = n[ae];
var ag = o[ae];
var ah = p[ae];
if ((af >= ad) || (ag >= ad) || (ah >= ad) || (af < 0) || (ag < 0) || (ah < 0)) {
continue;
}
var ai = k[af];
var aj = l[af];
var ak = { $type: Point_$type, x: ai, y: aj };
var al = k[ag];
var am = l[ag];
var an = { $type: Point_$type, x: al, y: am };
var ao = k[ah];
var ap = l[ah];
var aq = { $type: Point_$type, x: ao, y: ap };
z = an.y < aq.y ? an.y : aq.y;
z = ak.y < z ? ak.y : z;
aa = an.y > aq.y ? an.y : aq.y;
aa = ak.y > aa ? ak.y : aa;
ab = an.x < aq.x ? an.x : aq.x;
ab = ak.x < ab ? ak.x : ab;
ac = an.x > aq.x ? an.x : aq.x;
ac = ak.x > ac ? ak.x : ac;
if (z < y && aa > v && ab < x && ac > w) {
var ar = m[af];
var as = m[ag];
var at = m[ah];
if (isNaN_(ar) || isNaN_(as) || isNaN_(at)) {
continue;
}
for (var au = 0; au < s; au++) {
var av = r[au];
var aw = t[au];
switch ((ar < av ? 1 : 0) | (as < av ? 2 : 0) | (at < av ? 4 : 0)) {
case 0: break;
case 1:
aw.d(aw.k(af, ak.x, ak.y, ar, ag, an.x, an.y, as, av), aw.k(ah, aq.x, aq.y, at, af, ak.x, ak.y, ar, av));
break;
case 2:
aw.d(aw.k(ag, an.x, an.y, as, ah, aq.x, aq.y, at, av), aw.k(af, ak.x, ak.y, ar, ag, an.x, an.y, as, av));
break;
case 3:
aw.d(aw.k(ag, an.x, an.y, as, ah, aq.x, aq.y, at, av), aw.k(ah, aq.x, aq.y, at, af, ak.x, ak.y, ar, av));
break;
case 4:
aw.d(aw.k(ah, aq.x, aq.y, at, af, ak.x, ak.y, ar, av), aw.k(ag, an.x, an.y, as, ah, aq.x, aq.y, at, av));
break;
case 5:
aw.d(aw.k(af, ak.x, ak.y, ar, ag, an.x, an.y, as, av), aw.k(ag, an.x, an.y, as, ah, aq.x, aq.y, at, av));
break;
case 6:
aw.d(aw.k(ah, aq.x, aq.y, at, af, ak.x, ak.y, ar, av), aw.k(af, ak.x, ak.y, ar, ag, an.x, an.y, as, av));
break;
case 7: break;
}
}
}
}
var ax = new Clipper(0, RectUtil.r(c, 2), false);
var ay = new List$1(List$1.$.specialize(List$1.$.specialize(Point_$type)), 0);
for (var az = 0; az < s; ++az) {
var a0 = t[az];
var a1 = new List$1(List$1.$.specialize(Point_$type), 0);
var a2 = a0.c();
for (var a3 = 0; a3 < a2.count; a3++) {
var a4 = a2._inner[a3];
var a5 = new List$1(Point_$type, 0);
ax.i = a5;
try {
for (var _b = (e_1 = void 0, __values(fromEnum(a4))), _c = _b.next(); !_c.done; _c = _b.next()) {
var a6 = _c.value;
ax.j({ $type: Point_$type, x: a0.g.item(a6), y: a0.h.item(a6) });
}
}
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;
}
}
ax.i = null;
a1.add(a5);
}
ay.add(a1);
}
d.ci(ay, r);
};
ScatterContourSeries.prototype.sq = function () {
_super.prototype.sq.call(this);
this.zk();
};
ScatterContourSeries.prototype.zk = function () {
var e_2, _a;
var a = this.vk;
if (a == null) {
a = this.vq;
}
if (a == null) {
a = BrushUtil.j(255, 255, 255, 255);
}
var b = new ValueBrushScale();
b.brushes = new BrushCollection();
if (this.y6 == null || this.y6.brushes == null || this.y6.brushes.count == 0) {
b.brushes.add(BrushUtil.o(a, -0.5));
b.brushes.add(a);
}
else {
try {
for (var _b = __values(fromEnum(this.y6.brushes)), _c = _b.next(); !_c.done; _c = _b.next()) {
var c = _c.value;
b.brushes.add(c);
}
}
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;
}
}
}
if (this.y6 != null) {
if (!isNaN_(this.y6.minimumValue)) {
b.minimumValue = this.y6.minimumValue;
}
if (!isNaN_(this.y6.maximumValue)) {
b.maximumValue = this.y6.maximumValue;
}
b.logarithmBase = this.y6.logarithmBase;
b.isLogarithmic = this.y6.isLogarithmic;
}
this.y5 = b;
};
Object.defineProperty(ScatterContourSeries.prototype, "y3", {
get: function () {
return this.y2;
},
set: function (a) {
var b = a != this.y3;
if (b) {
if (this.y2 != null) {
var c = this.y2;
c.updated = delegateRemove(c.updated, runOn(this, this.zl));
}
var d = this.y2;
this.y2 = a;
if (this.y2 != null) {
var e = this.y2;
e.updated = delegateCombine(e.updated, runOn(this, this.zl));
}
this.raisePropertyChanged("ValueResolver", d, a);
this.rz(false);
}
},
enumerable: false,
configurable: true
});
ScatterContourSeries.prototype.zl = function (a, b) {
this.rz(false);
};
ScatterContourSeries.prototype.hf = function (a, b, c) {
return _super.prototype.hf.call(this, a, b, c) && this.y3 != null && this.xm != null && this.xn != null && this.xj != null && this.xk != null && this.xl != null && this.xm.count > 0 && this.xn.count > 0 && this.xj.count > 0 && this.xk.count > 0 && this.xl.count > 0;
};
ScatterContourSeries.prototype.a2 = function (a, b) {
var c = this.y4.cn(a, b);
if (c != null) {
return c.dataContext;
}
return null;
};
ScatterContourSeries.$t = markType(ScatterContourSeries, 'ScatterContourSeries', ScatterTriangulationSeries.$);
ScatterContourSeries.$$p = markDep(DependencyProperty, PropertyMetadata, ScatterContourSeries, 'raisePropertyChanged', ['ActualFillScale:y5:zm', [ValueBrushScale.$, null], 'FillScale:y6:zn', [ValueBrushScale.$, null], 'ValueMemberAsLegendLabel:zc:zo', [2, null], 'ValueMemberAsLegendUnit:ze:zp', [2, null], 'ValueMemberPath:zg:zq', [2, null]]);
return ScatterContourSeries;
}(ScatterTriangulationSeries));
export { ScatterContourSeries };
/**
* @hidden
*/
var ScatterContourSeriesView = /** @class */ /*@__PURE__*/ (function (_super) {
__extends(ScatterContourSeriesView, _super);
function ScatterContourSeriesView(a) {
var _this = _super.call(this, a) || this;
_this.cf = null;
_this.ce = null;
_this.ch = null;
_this.cg = new List$1(Brush.$, 0);
_this.cd = null;
_this.ch = new List$1(Path.$, 0);
_this.ce = a;
_this.cf = ((function () {
var $ret = new Pool$1(Path.$);
$ret.create = runOn(_this, _this.co);
$ret.destroy = runOn(_this, _this.cm);
$ret.activate = runOn(_this, _this.ck);
$ret.disactivate = runOn(_this, _this.cl);
return $ret;
})());
return _this;
}
ScatterContourSeriesView.prototype.co = function () {
var _this = this;
var a = new Path();
a.dataContext = ((function () {
var $ret = new DataContext();
$ret.series = _this.f;
return $ret;
})());
this.ch.add(a);
return a;
};
ScatterContourSeriesView.prototype.ck = function (a) {
a._visibility = 0;
};
ScatterContourSeriesView.prototype.cl = function (a) {
a._visibility = 1;
};
ScatterContourSeriesView.prototype.cm = function (a) {
this.ch.remove(a);
};
ScatterContourSeriesView.prototype.ci = function (a, b) {
var c = 0;
this.cd = b;
this.cg.clear();
var d = this.ce.y5;
for (var e = 0; e < b.length; e++) {
var f = b[e];
var g = a._inner[c];
var h = new PathGeometry();
var _loop_1 = function (i) {
var j = g._inner[i];
if (j.count == 0) {
return "continue";
}
var k = PointCollectionUtil.f(j);
var l = ((function () {
var $ret = new PathFigure();
$ret.isClosed = false;
$ret.isFilled = false;
$ret.startPoint = k._inner[0];
return $ret;
})());
l._segments.add(((function () {
var $ret = new PolyLineSegment();
$ret.points = k;
return $ret;
})()));
h.c.add(l);
};
for (var i = 0; i < g.count; i++) {
_loop_1(i);
}
this.cf.item(c).an = h;
if (this.cf.item(c).dataContext != null) {
this.cf.item(c).dataContext.item = f;
}
if (d != null) {
var m = d.getBrushByValue(f, this.ce.y8);
if (m == null) {
m = this.f.vk;
}
this.cg.add(m);
}
else {
this.cg.add(this.f.vk);
}
c++;
}
this.cf.count = c;
this.a2();
};
ScatterContourSeriesView.prototype.bs = function (a, b) {
_super.prototype.bs.call(this, a, b);
var c = a;
c._stroke = this.cg._inner[b];
c.ad = this.f.ig;
if (c.y != null) {
this.m.j(c, c.y);
}
};
ScatterContourSeriesView.prototype.bt = function (a, b) {
_super.prototype.bt.call(this, a, b);
var c = a;
var d = this.b4(b);
c._stroke = d;
c.ad = this.f.ig + 3;
};
ScatterContourSeriesView.prototype.bj = function (a, b) {
_super.prototype.bj.call(this, a, b);
for (var c = 0; c < this.ch.count; c++) {
var d = this.ch._inner[c];
if (d._visibility != 1) {
this.br(d, c, b);
a.t(d);
}
}
};
ScatterContourSeriesView.prototype.cj = function (a) {
this.cf.count = 0;
this.a2();
};
ScatterContourSeriesView.prototype.ax = function (a) {
_super.prototype.ax.call(this, a);
var b = new List$1(Tuple$2.$.specialize(Number_$type, Path.$), 0);
if (this.cd != null) {
for (var c = 0; c < this.cf.count; c++) {
b.add(new Tuple$2(Number_$type, Path.$, this.cd[c], this.cf.item(c)));
}
}
b.aa(function (d, e) {
if (d.c < e.c) {
return -1;
}
else if (d.c > e.c) {
return 1;
}
return 0;
});
for (var d = 0; d < b.count; d++) {
var e = typeCast(Path.$, b._inner[d].d);
if (e._visibility != 1) {
this.f.bc.exportPathData(a, e, "contour" + d, ["Main "]);
}
}
};
ScatterContourSeriesView.prototype.getDefaultTooltipTemplate = function () {
var a = "<div class='ui-chart-default-tooltip-content'><span";
var b = this.f.ba.a$u(this.f);
if (!stringIsNullOrEmpty(b)) {
a += " style='color:" + b + "'";
}
a += ">" + this.ce.title + "</span><br/>";
if (!stringIsNullOrEmpty(this.ce.zg)) {
a += "<span>Value: ${item}</span>";
}
a += "</div>";
return a;
};
ScatterContourSeriesView.prototype.cn = function (a, b) {
for (var c = 0; c < this.ch.count; c++) {
var d = this.ch._inner[c];
var e = typeCast(PathGeometry.$, d.an);
if (e != null) {
for (var f = 0; f < e.c.count; f++) {
var g = e.c._inner[f];
var h = e.c._inner[f]._startPoint;
for (var i = 0; i < g._segments.count; i++) {
var j = typeCast(PolyLineSegment.$, g._segments._inner[i]);
if (j != null) {
var k = this.ce.ig / 2 + this.ce.iw(b);
if (j._points.count > 0 && GeometryUtil.e(a, h, j._points, k)) {
return d;
}
}
}
}
}
}
return null;
};
ScatterContourSeriesView.$t = markType(ScatterContourSeriesView, 'ScatterContourSeriesView', SeriesView.$);
return ScatterContourSeriesView;
}(SeriesView));
export { ScatterContourSeriesView };