igniteui-react-charts
Version:
Ignite UI React charting components for building rich data visualizations using TypeScript APIs.
558 lines (557 loc) • 17.7 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 { AnnotationLayer } from "./AnnotationLayer";
import { Axis } from "./Axis";
import { DependencyProperty } from "igniteui-react-core";
import { CategoryTooltipLayerPosition_$type } from "./CategoryTooltipLayerPosition";
import { Series } from "./Series";
import { CategoryToolTipLayerFrame } from "./CategoryToolTipLayerFrame";
import { Base, enumGetBox, typeCast, fromEnum, Point_$type, markType, markDep, String_$type } from "igniteui-react-core";
import { CategoryTooltipSeriesInfo } from "./CategoryTooltipSeriesInfo";
import { XamDataChart } from "./XamDataChart";
import { List$1 } from "igniteui-react-core";
import { DataContext } from "igniteui-react-core";
import { Size } from "igniteui-react-core";
import { DeviceUtils } from "igniteui-react-core";
import { PropertyMetadata } from "igniteui-react-core";
import { isNaN_ } from "igniteui-react-core";
import { AnnotationLayerView } from "./AnnotationLayerView";
import { PointerTooltip } from "./PointerTooltip";
/**
* @hidden
*/
export let CategoryToolTipLayer = /*@__PURE__*/ (() => {
class CategoryToolTipLayer extends AnnotationLayer {
bk() {
return new CategoryToolTipLayer();
}
get_es() {
return true;
}
constructor() {
super();
let a = new CategoryToolTipLayerFrame();
let b = new CategoryToolTipLayerFrame();
let c = new CategoryToolTipLayerFrame();
this.xe = a;
this.xd = b;
this.xf = c;
this.ab = CategoryToolTipLayer.$;
}
ct() {
return new CategoryToolTipLayerView(this);
}
q1(a) {
super.q1(a);
this.z9 = a;
}
get_e3() {
return true;
}
ra(a, b, c, d) {
super.ra(a, b, c, d);
switch (b) {
case CategoryToolTipLayer.$$p[0]:
this.rs(true);
break;
case CategoryToolTipLayer.$$p[2]:
this.rs(true);
break;
case CategoryToolTipLayer.$$p[1]:
this.rs(true);
break;
case "SeriesViewer":
this.z9.cp();
break;
}
}
ys(a, b) {
if (this.z7 == a) {
if (!this.a1.c) {
this.rs(b);
}
}
}
yt(a, b) {
if (!this.a1.c) {
this.rs(b);
}
}
yv(a, b) {
super.yv(a, b);
let c = a;
let d = this.aab;
c.l = NaN;
c.k = NaN;
c.g = NaN;
c.h = NaN;
c.k = NaN;
c.l = NaN;
if (isNaN_(this.z4.x) && isNaN_(this.z4.y)) {
this.z9.cn(this.z9.ck());
return;
}
if (this.z7 != null) {
let e = this.z7;
if (e == null || !e.cb || e.b9) {
return;
}
if (!e.co()) {
return;
}
let f = e;
let g = this.aaa(f.df, d);
this.aag(g, c, d);
}
else {
if (typeCast(XamDataChart.$, this.dc) !== null) {
let h = this.dc;
let i = true;
let j = false;
let k = new List$1(Series.$, 0);
for (let l of fromEnum(h.axes)) {
if (l.cb && !l.b9) {
if (!l.co()) {
continue;
}
if (i) {
i = false;
j = l.cp;
}
else {
if (l.cp != j) {
continue;
}
}
for (let m of fromEnum(l.df)) {
k.add(m);
}
}
}
let n = this.aaa(k, d);
this.aag(n, c, d);
}
}
}
aaa(a, b) {
let c = 1.7976931348623157E+308;
let d = -1.7976931348623157E+308;
let e = new List$1(DataContext.$, 0);
let f = new List$1(Base.$, 0);
let g = false;
let h = true;
for (let i = 0; i < a.count; i++) {
let j = a.item(i);
if (!j.e7 && !j.ez) {
continue;
}
if (j.isStacked) {
continue;
}
let k = j;
if (!k.categoryAxis.co()) {
continue;
}
if (h) {
g = j.isVertical;
}
else {
if (g != j.isVertical) {
continue;
}
}
let l = this.yo(j);
if (!l.c) {
continue;
}
let m = j.we(l.d, b, false);
if (g) {
if (!isNaN_(m.y)) {
c = Math.min(c, m.y);
d = Math.max(d, m.y);
}
}
else {
if (!isNaN_(m.x)) {
c = Math.min(c, m.x);
d = Math.max(d, m.x);
}
}
let n = this.aac(j);
if (n == null) {
continue;
}
let o = null;
let p = j.kn(this.z4);
if (j.e4 && p != null) {
o = j.a3(p);
}
else {
o = new DataContext();
o.item = p;
o.series = j;
}
e.add(o);
f.add1(n);
}
let q = 0;
let r = 0;
if (g) {
r = (c + d) / 2;
q = this.wu.right;
if (this.z8 == 2 || this.z8 == 1) {
q = this.wu.left;
}
if (r < 0 || r > this.wu.bottom) {
r = NaN;
}
}
else {
q = (c + d) / 2;
r = this.wu.top;
if (this.z8 == 2 || this.z8 == 1) {
r = this.wu.bottom;
}
if (q < 0 || q > this.wu.right) {
q = NaN;
}
}
let s = new CategoryTooltipSeriesInfo();
s.c = { $type: Point_$type, x: q, y: r };
s.a = e;
s.b = f;
return s;
}
p7() {
this.z4 = { $type: Point_$type, x: NaN, y: NaN };
this.cw.au();
}
aag(a, b, c) {
let d = a.c;
let e = a.a;
let f = a.b;
d = this.z9.cq(d);
let g = 0;
let h = this.cw.b1;
let i = this.z9.ck();
this.z9.cm();
let j = false;
if (e.count == 0) {
this.cw.au();
return;
}
let k = false;
for (let l = 0; l < e.count; l++) {
let m = e._inner[l].series;
j = m.isVertical;
let n = e._inner[l];
let o = f._inner[l];
if (this.z9.ch(m, o, n)) {
k = true;
}
g++;
}
if (!k) {
this.z9.cn(i);
return;
}
let p = this.z9.cr(i);
let q = 0;
let r = 0;
let s = 0;
let t = 0;
let u = false;
let v = false;
let w = this.z8;
if (w == 2 || w == 3) {
v = true;
}
if (w == 2 || w == 1) {
u = true;
}
let x = this.z9.cs();
if (j) {
if (!u && !v && d.x + (p.width + DeviceUtils.g(10)) > x.width) {
v = true;
}
if (u && !v && d.x - (p.width + DeviceUtils.g(10)) < 0) {
v = true;
}
}
else {
if (!u && !v && d.y - (p.height + 10) < 0) {
v = true;
}
if (u && !v && d.y + (p.height + 10) > x.height) {
v = true;
}
}
let y = DeviceUtils.g(10);
let z = DeviceUtils.g(5);
if (!u) {
if (!j) {
z = p.height + y;
}
if (v) {
if (j) {
z = z + p.width + y;
}
else {
z = 0;
}
}
}
else {
if (j) {
z = p.width + y;
if (v) {
z = 0;
}
}
else {
z = DeviceUtils.g(5);
if (v) {
z = z + p.height + y;
}
}
}
if (j) {
r = 0 - (y + DeviceUtils.g(5));
if (u) {
r = (r * -1) + p.width;
}
q = p.height / 2;
t = d.y - p.height / 2;
s = d.x - z;
}
else {
q = p.height + DeviceUtils.g(10) + DeviceUtils.g(5);
if (u) {
q = 0 - (y + DeviceUtils.g(5));
}
r = p.width / 2;
s = d.x - p.width / 2;
t = d.y - z;
}
if (j) {
if (t < 0) {
q -= 0 - t;
t = 0;
}
if (t + p.height > x.height) {
q += (t + p.height) - x.height;
t = x.height - p.height;
}
}
else {
if (s < 0) {
r -= 0 - s;
s = 0;
}
if (s + p.width > x.width) {
r += (s + p.width) - x.width;
s = x.width - p.width;
}
}
b.k = s;
b.l = t;
b.g = r;
b.h = q;
b.j = p.width;
b.i = p.height;
}
aac(a) {
return a.toolTip;
}
yy(a, b) {
super.yy(a, b);
let c = a;
let d = b.b1.left;
let e = b.b1.right;
let f = b.b1.top;
let g = b.b1.bottom;
let h = this.z9.ck();
if (isNaN_(c.k) || isNaN_(c.l) || isNaN_(c.g) || isNaN_(c.h)) {
this.z9.cn(h);
return;
}
let i = c.k;
let j = c.l;
let k = c.g;
let l = c.h;
if (h != null) {
this.z9.co(h, i, j, k, l);
}
}
ga() {
return true;
}
}
CategoryToolTipLayer.$t = /*@__PURE__*/ markType(CategoryToolTipLayer, 'CategoryToolTipLayer', AnnotationLayer.$);
CategoryToolTipLayer.$$p = /*@__PURE__*/ markDep(DependencyProperty, PropertyMetadata, CategoryToolTipLayer, 'raisePropertyChanged', ['TargetAxis:z7:aah', [Axis.$, null], 'ToolTipPosition:z8:aai', [CategoryTooltipLayerPosition_$type, /*@__PURE__*/ enumGetBox(CategoryTooltipLayerPosition_$type, 0)], 'UseInterpolation:aab:aaj', [0, false]]);
return CategoryToolTipLayer;
})();
/**
* @hidden
*/
export let CategoryToolTipLayerView = /*@__PURE__*/ (() => {
class CategoryToolTipLayerView extends AnnotationLayerView {
constructor(a) {
super(a);
this.ce = null;
this.cf = null;
this._tooltips = null;
this.ci = null;
this.cg = false;
this._htmlTest = null;
this.ce = a;
this.htmlTest = /^[^<]*(<[\w\W]+>)[^>]*$/;
}
ck() {
if (this.cf == null) {
this.cf = new PointerTooltip();
this.cf.bw(this.f.jz);
this.cf.ap = this.f.dc.c9.k;
this._tooltips = this.f.jz.createElement("div");
this.ci = this.f.jz.createElement("div");
this.cf._visibility = 0;
}
return this.cf;
}
ax() {
super.ax();
if (this.cf != null) {
this.cf._visibility = 1;
}
}
an() {
super.an();
if (this.cf != null) {
this.cf.br();
this.cf = null;
}
}
get htmlTest() {
return this._htmlTest;
}
set htmlTest(a) {
this._htmlTest = a;
}
ch(a, b, c) {
if (a.k2 == "default") {
a.k2 = a.cw.getDefaultTooltipTemplate();
}
let template_ = a.k2;
let context_ = c;
if (a.toolTip == null) {
return false;
}
let tooltip_ = a.toolTip;
if ((tooltip_.updateToolTip)) {
tooltip_._inPointer = true;
tooltip_.updateToolTip(context_, true);
tooltip_.setStyleProperty('position', 'relative');
tooltip_.setStyleProperty('left', '');
tooltip_.setStyleProperty('top', '');
tooltip_.remove();
}
this._tooltips.append(a.toolTip);
return true;
}
cr(a) {
let b = a;
b.content = this._tooltips;
let c = new Size(1, Number.POSITIVE_INFINITY, Number.POSITIVE_INFINITY);
b.cy = 1;
let d = b.cx(new Size(1, Number.POSITIVE_INFINITY, Number.POSITIVE_INFINITY));
b.cy = 0;
return d;
}
cq(a) {
let b = 0;
let c = 0;
if (this.f.dc != null) {
let d = this.f.dc.vy();
b += d.x;
c += d.y;
}
return { $type: Point_$type, x: b + a.x, y: c + a.y };
}
co(a, b, c, d, e) {
let f = a;
let g = f.content;
f.cs = { $type: Point_$type, x: d, y: e };
f._visibility = 0;
f.n = b;
f.o = c;
}
cs() {
let a = (window.innerWidth);
let b = (window.innerHeight);
return new Size(1, a, b);
}
cn(a) {
this._tooltips.removeChildren();
this.ci.removeChildren();
this.cf._visibility = 1;
}
cm() {
if (this._tooltips != null) {
this._tooltips.removeChildren();
}
}
cp() {
}
bc(a, b) {
super.bc(a, b);
if (b) {
return;
}
let c = null;
if (this.f.dc != null) {
c = this.f.dc.c9.j.i();
}
let d = 0;
let e = 0;
let f = this.f.dc;
if (f != null) {
let g = f.c9.j.b8();
d += g.x;
e += g.y;
}
if (this.cf != null) {
this.cf.aq = c;
this.cf.by(this.cf.n, this.cf.o);
}
}
aq(a) {
super.aq(a);
let b = this.cf;
let c = 0;
let d = 0;
if (this.f.dc != null) {
let e = this.f.dc.vy();
c += e.x;
d += e.y;
}
let f = b.a5();
let g = b.n - c;
let h = b.o - d;
let i = new List$1(String_$type, 0);
let j = this._tooltips.getChildCount();
for (let k = 0; k < j; k++) {
let indexliteral_ = k.toString();
let l = this._tooltips.getChildAt(k).getText();
let m = l.toString();
i.add(m);
}
this.f.bc.addPointerTooltipData(a, f, g, h, i);
}
}
CategoryToolTipLayerView.$t = /*@__PURE__*/ markType(CategoryToolTipLayerView, 'CategoryToolTipLayerView', AnnotationLayerView.$);
return CategoryToolTipLayerView;
})();