igniteui-angular-charts
Version:
Ignite UI Angular charting components for building rich data visualizations for modern web apps.
1,412 lines • 68.5 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-angular-core";
import { DataToolTipLayerGroupingMode_$type } from "igniteui-angular-core";
import { Series } from "./Series";
import { Rect } from "igniteui-angular-core";
import { Base, enumGetBox, EnumUtil, fromEnum, typeCast, String_$type, typeGetValue, Point_$type, Array_$type, markType, markDep, runOn, TypeRegistrar } from "igniteui-angular-core";
import { Size } from "igniteui-angular-core";
import { RectUtil } from "igniteui-angular-core";
import { DataTooltipGroupedPositionX_$type } from "igniteui-angular-core";
import { DataTooltipGroupedPositionY_$type } from "igniteui-angular-core";
import { DataAbbreviationMode_$type } from "igniteui-angular-core";
import { DataLegendValueMode_$type } from "igniteui-angular-core";
import { Thickness } from "igniteui-angular-core";
import { Brush } from "igniteui-angular-core";
import { DataLegendHeaderDateMode_$type } from "igniteui-angular-core";
import { DataLegendHeaderTimeMode_$type } from "igniteui-angular-core";
import { DataLegendSummaryType_$type } from "igniteui-angular-core";
import { LegendItemBadgeShape_$type } from "igniteui-angular-core";
import { DataLegendLayoutMode_$type } from "igniteui-angular-core";
import { DataLegendUnitsMode_$type } from "igniteui-angular-core";
import { DataLegendLabelMode_$type } from "igniteui-angular-core";
import { DataToolTipLayerFrame } from "./DataToolTipLayerFrame";
import { Dictionary$2 } from "igniteui-angular-core";
import { List$1 } from "igniteui-angular-core";
import { Pool$1 } from "igniteui-angular-core";
import { DataToolTipSeriesInfo } from "./DataToolTipSeriesInfo";
import { DataContext } from "igniteui-angular-core";
import { DataTooltipCollisionInfo } from "./DataTooltipCollisionInfo";
import { DeviceUtils } from "igniteui-angular-core";
import { HashSet$1 } from "igniteui-angular-core";
import { PropertyMetadata } from "igniteui-angular-core";
import { isNaN_ } from "igniteui-angular-core";
import { stringEmpty } from "igniteui-angular-core";
import { AnnotationLayerView } from "./AnnotationLayerView";
import { PointerTooltip } from "./PointerTooltip";
import { IOnDemandRender_$type } from "igniteui-angular-core";
/**
* @hidden
*/
export let DataToolTipLayer = /*@__PURE__*/ (() => {
class DataToolTipLayer extends AnnotationLayer {
constructor() {
super();
this.aam = 1;
this.abr = new Dictionary$2(String_$type, Base.$, 0);
this.abs = new List$1(String_$type, 0);
this.aae = 8;
this.aai = 11;
this.aa2 = null;
this.aau = null;
this.aat = null;
this.aax = null;
this.aaz = null;
this.aaw = null;
this.aay = null;
this.aa1 = null;
this.aa0 = null;
this.aav = null;
let a = new DataToolTipLayerFrame();
let b = new DataToolTipLayerFrame();
let c = new DataToolTipLayerFrame();
this.xb = a;
this.xa = b;
this.xc = c;
this.ab = DataToolTipLayer.$;
}
bj() {
return new DataToolTipLayer();
}
get_er() {
return true;
}
cs() {
return new DataToolTipLayerView(this);
}
q0(a) {
super.q0(a);
this.aaq = a;
}
get_e2() {
return true;
}
get aan() {
return this.aam;
}
set aan(a) {
let b = this.aam;
this.aam = a;
if (b != this.aam) {
this.raisePropertyChanged("ActualGroupingMode", enumGetBox(DataToolTipLayerGroupingMode_$type, b), enumGetBox(DataToolTipLayerGroupingMode_$type, this.aam));
}
}
aap() {
let a = true;
let b = true;
let c = true;
let d = true;
if (this.aao != 0) {
return this.aao;
}
let e = this.z4();
if (e != null) {
for (let f of fromEnum(e.db())) {
if (!f.es && !f.fv) {
a = false;
}
if (!f.es && !f.fo) {
b = false;
}
if (!f.es && !f.fw) {
c = false;
}
if (!f.es && !f.fs) {
d = false;
}
}
}
if (a || b || c || d) {
return 2;
}
return 1;
}
q8(a, b, c, d) {
super.q8(a, b, c, d);
switch (b) {
case DataToolTipLayer.$$p[42]:
this.rq(true);
break;
case DataToolTipLayer.$$p[49]:
this.rq(true);
break;
case DataToolTipLayer.$$p[12]:
this.aan = this.aap();
break;
case "ActualGroupingMode":
this.rq(true);
break;
case DataToolTipLayer.$$p[10]:
this.aaf = this.aah();
break;
case DataToolTipLayer.$$p[11]:
this.aaj = this.aal();
break;
case "SeriesViewer":
this.aaq.cl();
break;
case DataToolTipLayer.$$p[31]:
case DataToolTipLayer.$$p[24]:
case DataToolTipLayer.$$p[5]:
case DataToolTipLayer.$$p[23]:
case DataToolTipLayer.$$p[4]:
case DataToolTipLayer.$$p[28]:
case DataToolTipLayer.$$p[50]:
case DataToolTipLayer.$$p[52]:
case DataToolTipLayer.$$p[53]:
case DataToolTipLayer.$$p[54]:
case DataToolTipLayer.$$p[51]:
case DataToolTipLayer.$$p[57]:
case DataToolTipLayer.$$p[56]:
case DataToolTipLayer.$$p[55]:
case DataToolTipLayer.$$p[58]:
case DataToolTipLayer.$$p[59]:
case DataToolTipLayer.$$p[63]:
case DataToolTipLayer.$$p[62]:
case DataToolTipLayer.$$p[61]:
case DataToolTipLayer.$$p[60]:
case "ValueTextStyle":
case DataToolTipLayer.$$p[16]:
case DataToolTipLayer.$$p[15]:
case DataToolTipLayer.$$p[13]:
case DataToolTipLayer.$$p[14]:
case DataToolTipLayer.$$p[17]:
case DataToolTipLayer.$$p[22]:
case DataToolTipLayer.$$p[20]:
case DataToolTipLayer.$$p[21]:
case DataToolTipLayer.$$p[18]:
case DataToolTipLayer.$$p[19]:
case "HeaderTextStyle":
case DataToolTipLayer.$$p[8]:
case DataToolTipLayer.$$p[9]:
case DataToolTipLayer.$$p[6]:
case DataToolTipLayer.$$p[7]:
case "GroupTextStyle":
case DataToolTipLayer.$$p[35]:
case "SummaryTitleTextStyle":
case DataToolTipLayer.$$p[38]:
case DataToolTipLayer.$$p[37]:
case DataToolTipLayer.$$p[36]:
case DataToolTipLayer.$$p[34]:
case DataToolTipLayer.$$p[41]:
case "SummaryValueTextStyle":
case DataToolTipLayer.$$p[33]:
case DataToolTipLayer.$$p[32]:
case "SummaryLabelTextStyle":
case DataToolTipLayer.$$p[40]:
case DataToolTipLayer.$$p[39]:
case "SummaryUnitsTextStyle":
case DataToolTipLayer.$$p[0]:
case DataToolTipLayer.$$p[1]:
case DataToolTipLayer.$$p[45]:
case DataToolTipLayer.$$p[48]:
case DataToolTipLayer.$$p[46]:
case DataToolTipLayer.$$p[47]:
case "UnitsTextStyle":
case DataToolTipLayer.$$p[44]:
case DataToolTipLayer.$$p[43]:
case "TitleTextStyle":
case DataToolTipLayer.$$p[25]:
case DataToolTipLayer.$$p[26]:
case DataToolTipLayer.$$p[27]:
case "LabelTextStyle":
this.aff(b, c, d);
break;
}
}
aff(a, b, c) {
if (!this.abr.containsKey(a)) {
this.abs.add(a);
this.abr.addItem(a, c);
}
else {
this.abr.item(a, c);
}
this.rq(true);
}
afj(a, b) {
switch (a) {
case DataToolTipLayer.$$p[12]:
this.aao = EnumUtil.getEnumValue(DataToolTipLayerGroupingMode_$type, b);
break;
case DataToolTipLayer.$$p[29]:
this.abw = b;
break;
case DataToolTipLayer.$$p[30]:
this.abx = b;
break;
case DataToolTipLayer.$$p[2]:
this.abu = b;
break;
case DataToolTipLayer.$$p[3]:
this.abv = b;
break;
case DataToolTipLayer.$$p[10]:
this.aag = EnumUtil.getEnumValue(DataTooltipGroupedPositionX_$type, b);
break;
case DataToolTipLayer.$$p[11]:
this.aak = EnumUtil.getEnumValue(DataTooltipGroupedPositionY_$type, b);
break;
case DataToolTipLayer.$$p[31]:
this.abm = b;
break;
case DataToolTipLayer.$$p[24]:
this.z2 = b;
break;
case DataToolTipLayer.$$p[5]:
this.zx = b;
break;
case DataToolTipLayer.$$p[23]:
this.z1 = b;
break;
case DataToolTipLayer.$$p[4]:
this.zw = b;
break;
case DataToolTipLayer.$$p[50]:
this.z6 = EnumUtil.getEnumValue(DataAbbreviationMode_$type, b);
break;
case DataToolTipLayer.$$p[52]:
this.acw = typeGetValue(b);
break;
case DataToolTipLayer.$$p[53]:
this.acx = typeGetValue(b);
break;
case DataToolTipLayer.$$p[54]:
this.aad = EnumUtil.getEnumValue(DataLegendValueMode_$type, b);
break;
case DataToolTipLayer.$$p[51]:
this.aex = b;
break;
case DataToolTipLayer.$$p[57]:
this.abo = b;
break;
case DataToolTipLayer.$$p[56]:
this.ae3 = b;
break;
case DataToolTipLayer.$$p[55]:
this.z3 = b;
break;
case DataToolTipLayer.$$p[58]:
this.ah2 = b;
break;
case DataToolTipLayer.$$p[59]:
this.abp = b;
break;
case DataToolTipLayer.$$p[63]:
this.afc = b;
break;
case DataToolTipLayer.$$p[62]:
this.abq = b;
break;
case DataToolTipLayer.$$p[61]:
this.ah3 = b;
break;
case DataToolTipLayer.$$p[60]:
this.ahl = b;
break;
case "ValueTextStyle":
this.abc = b;
break;
case DataToolTipLayer.$$p[16]:
this.adk = b;
break;
case DataToolTipLayer.$$p[15]:
this.z0 = b;
break;
case DataToolTipLayer.$$p[13]:
this.adg = b;
break;
case DataToolTipLayer.$$p[14]:
this.z7 = EnumUtil.getEnumValue(DataLegendHeaderDateMode_$type, b);
break;
case DataToolTipLayer.$$p[17]:
this.z8 = EnumUtil.getEnumValue(DataLegendHeaderTimeMode_$type, b);
break;
case DataToolTipLayer.$$p[22]:
this.adp = b;
break;
case DataToolTipLayer.$$p[20]:
this.ahd = b;
break;
case DataToolTipLayer.$$p[21]:
this.ahw = b;
break;
case DataToolTipLayer.$$p[18]:
this.ahv = b;
break;
case DataToolTipLayer.$$p[19]:
this.abf = b;
break;
case "HeaderTextStyle":
this.aa4 = b;
break;
case DataToolTipLayer.$$p[28]:
this.aaa = EnumUtil.getEnumValue(DataLegendLayoutMode_$type, b);
break;
case DataToolTipLayer.$$p[8]:
this.ahc = b;
break;
case DataToolTipLayer.$$p[9]:
this.ahu = b;
break;
case DataToolTipLayer.$$p[6]:
this.aht = b;
break;
case DataToolTipLayer.$$p[7]:
this.abe = b;
break;
case "GroupTextStyle":
this.aa3 = b;
break;
case DataToolTipLayer.$$p[35]:
this.ahg = b;
break;
case "SummaryTitleTextStyle":
this.aa7 = b;
break;
case DataToolTipLayer.$$p[38]:
this.aab = EnumUtil.getEnumValue(DataLegendSummaryType_$type, b);
break;
case DataToolTipLayer.$$p[37]:
this.ad9 = b;
break;
case DataToolTipLayer.$$p[36]:
this.ahz = b;
break;
case DataToolTipLayer.$$p[34]:
this.ahy = b;
break;
case DataToolTipLayer.$$p[41]:
this.ahi = b;
break;
case "SummaryValueTextStyle":
this.aa9 = b;
break;
case DataToolTipLayer.$$p[33]:
this.ad4 = b;
break;
case DataToolTipLayer.$$p[32]:
this.ahf = b;
break;
case "SummaryLabelTextStyle":
this.aa6 = b;
break;
case DataToolTipLayer.$$p[40]:
this.aef = b;
break;
case DataToolTipLayer.$$p[39]:
this.ahh = b;
break;
case "SummaryUnitsTextStyle":
this.aa8 = b;
break;
case DataToolTipLayer.$$p[0]:
this.ahs = b;
break;
case DataToolTipLayer.$$p[1]:
this.aas = EnumUtil.getEnumValue(LegendItemBadgeShape_$type, b);
break;
case DataToolTipLayer.$$p[45]:
this.aac = EnumUtil.getEnumValue(DataLegendUnitsMode_$type, b);
break;
case DataToolTipLayer.$$p[48]:
this.aeq = b;
break;
case DataToolTipLayer.$$p[46]:
this.ahk = b;
break;
case DataToolTipLayer.$$p[47]:
this.ah1 = b;
break;
case "UnitsTextStyle":
this.abb = b;
break;
case DataToolTipLayer.$$p[44]:
this.ah0 = b;
break;
case DataToolTipLayer.$$p[43]:
this.ahj = b;
break;
case "TitleTextStyle":
this.aba = b;
break;
case DataToolTipLayer.$$p[25]:
this.z9 = EnumUtil.getEnumValue(DataLegendLabelMode_$type, b);
break;
case DataToolTipLayer.$$p[26]:
this.ahe = b;
break;
case DataToolTipLayer.$$p[27]:
this.ahx = b;
break;
case "LabelTextStyle":
this.aa5 = b;
break;
}
}
afg(a) {
for (let b = 0; b < this.abs.count; b++) {
let c = this.abs._inner[b];
a.updatePropertyByName(c, this.abr.item(c));
}
}
yn(a, b) {
{
if (!this.a1.c) {
this.rq(b);
}
}
}
yo(a, b) {
if (!this.a1.c) {
this.rq(b);
}
}
yq(a, b) {
super.yq(a, b);
this.aam = this.aap();
let c = a;
let d = this.aaq.b9;
let e = this.abn;
let f = false;
c.m.clear();
c.i.clear();
c.l.clear();
c.g.clear();
c.f.clear();
c.k.clear();
c.j.clear();
c.h.clear();
if (isNaN_(this.zt.x) && isNaN_(this.zt.y)) {
d.count = 0;
return;
}
{
if (this.aan == 2) {
let g = 0;
{
for (let h of fromEnum(this.db.series)) {
if (this.xh(h)) {
this.afi(h, c, e, f, g);
g++;
}
if (h.isStacked) {
h.p2((i) => {
if (this.xh(i)) {
this.afi(i, c, e, f, g);
g++;
}
if (i.eg) {
i.p0((j) => {
if (this.xh(j)) {
this.afi(j, c, e, f, g);
g++;
}
return true;
});
}
return true;
});
}
if (h.eg) {
h.p0((i) => {
if (this.xh(i)) {
this.afi(i, c, e, f, g);
g++;
}
return true;
});
}
}
this.afe(c);
}
d.count = g;
}
else {
let i = this.z4();
let j = this.abt(i);
let k = this.aar(i, j, e);
this.afh(k, c, e);
}
}
}
abt(a) {
let b = new List$1(Series.$, 0);
if (a == null) {
return b;
}
for (let c of fromEnum(a.df)) {
b.add(c);
}
return b;
}
z4() {
if (this.z5 != null) {
return this.z5;
}
if (this.db == null) {
return null;
}
for (let a of fromEnum(this.db.series)) {
if (a.ey) {
let b = a.a0();
if (b != null && b.co()) {
return b;
}
}
}
for (let c of fromEnum(this.db.series)) {
if (!c.ey) {
let d = c.ai();
let e = d != null && d.length > 0 ? d[0] : null;
if (e != null && e.co()) {
return e;
}
}
}
return null;
}
aar(a, b, c) {
let d = 1.7976931348623157E+308;
let e = -1.7976931348623157E+308;
let f = new List$1(DataContext.$, 0);
let g = new List$1(Base.$, 0);
let h = false;
let i = true;
let j = { $type: Point_$type, x: NaN, y: NaN };
let k = 0;
let l = 0;
for (let m = 0; m < b.count; m++) {
let n = b.item(m);
k = n.db.l;
l = n.db.m;
if (n.ey) {
let o = n;
let p = new List$1(Series.$, 0);
if (o.isStacked) {
o.p2((q) => {
p.add(q);
if (q.eg) {
q.p0((r) => {
p.add(r);
return true;
});
}
return true;
});
}
else if (o.eg) {
p.add(o);
o.p0((q) => {
p.add(q);
return true;
});
}
else {
p.add(o);
}
for (let q = 0; q < p.count; q++) {
let r = p._inner[q];
let s = p._inner[q];
if (s.db == null) {
continue;
}
if (!r.categoryAxis.co()) {
continue;
}
if (i) {
h = s.isVertical;
}
else {
if (h != s.isVertical) {
continue;
}
}
let t = this.yj(s);
if (!t.c) {
continue;
}
j = s.v6(t.d);
let u = s.wb(t.d, c, false);
if (h) {
if (!isNaN_(u.y)) {
d = Math.min(d, u.y);
e = Math.max(e, u.y);
}
}
else {
if (!isNaN_(u.x)) {
d = Math.min(d, u.x);
e = Math.max(e, u.x);
}
}
}
}
else {
let v = n.ai();
for (let w = 0; w < v.length; w++) {
if (!v[w].co()) {
continue;
}
}
let x = n.wb(this.zt, c, false);
j = n.v6(this.zt);
if (h) {
if (!isNaN_(x.y)) {
d = Math.min(d, x.y);
e = Math.max(e, x.y);
}
}
else {
if (!isNaN_(x.x)) {
d = Math.min(d, x.x);
e = Math.max(e, x.x);
}
}
}
let y = null;
let z = n.km(this.zt);
if (n.e3 && z != null) {
y = n.a3(z);
}
else {
y = new DataContext();
y.item = z;
y.series = n;
}
f.add(y);
}
let aa = 0;
let ab = 0;
if (h) {
ab = (d + e) / 2;
aa = this.wr.right;
if (!isNaN_(j.x)) {
aa = j.x;
}
if (ab < 0 || ab > this.wr.bottom) {
ab = NaN;
}
}
else {
aa = (d + e) / 2;
if (!isNaN_(j.y)) {
ab = j.y;
}
if (aa < 0 || aa > this.wr.right) {
aa = NaN;
}
}
let ac = new DataToolTipSeriesInfo();
ac.f = { $type: Point_$type, x: aa, y: ab };
ac.e = { $type: Point_$type, x: j.x, y: j.y };
ac.b = f;
ac.a = h;
return ac;
}
p6() {
this.zt = { $type: Point_$type, x: NaN, y: NaN };
this.rq(false);
this.aaq.cj(false);
}
p7() {
this.zt = { $type: Point_$type, x: NaN, y: NaN };
this.rq(false);
this.aaq.cj(true);
}
get ahp() {
let a = RectUtil.n(this.cv.bx);
let b = new Size(1, this.cv.bx.width, this.cv.bx.height);
return new Rect(3, a, b);
}
get aho() {
let a = RectUtil.n(this.cv.bx);
let b = new Size(1, this.cv.bx.width, this.cv.bx.height);
return new Rect(3, this.aaq.cm(a), b);
}
get ahn() {
let a = new Rect(0, 0, 0, this.db.m, this.db.l);
let b = RectUtil.n(a);
let c = new Size(1, a.width, a.height);
return new Rect(3, this.aaq.cm(b), c);
}
get ahr() {
let a = { $type: Point_$type, x: 0, y: 0 };
return new Rect(3, a, this.aaq.cr());
}
ahq() {
return this.ahp;
}
abj(a, b, c) {
if (Rect.l_op_Equality(a, Rect.empty)) {
return false;
}
let d = a.top;
return c < d;
}
abg(a, b, c, d) {
if (Rect.l_op_Equality(a, Rect.empty)) {
return false;
}
let e = a.bottom;
return c + d.height >= e;
}
abh(a, b, c) {
if (Rect.l_op_Equality(a, Rect.empty)) {
return false;
}
let d = a.left;
return c < d;
}
abi(a, b, c, d) {
if (Rect.l_op_Equality(a, Rect.empty)) {
return false;
}
let e = a.right;
return c + d.width > e;
}
acm(a, b) {
return a.top + b;
}
ack(a, b, c) {
return a.bottom - c.height - b;
}
acl(a, b) {
return ((a.bottom + a.top) / 2) - (b.height / 2);
}
acv(a, b, c, d, e) {
let f = c.y - d.height - b;
return f;
}
act(a, b, c, d, e) {
let f = c.y + b;
return f;
}
acu(a, b, c, d, e) {
let f = c.y - (d.height / 2);
return f;
}
acp(a, b, c, d, e) {
let f = c.y - d.height;
f = f - b;
return f;
}
acn(a, b, c, d, e) {
let f = c.y;
f = f + b;
return f;
}
aco(a, b, c, d, e) {
let f = c.y - (d.height / 2);
return f;
}
ab5(a, b) {
return a.left + b;
}
ab7(a, b, c) {
return (a.right - (c.width)) - b;
}
ab6(a, b, c) {
return ((a.right + a.left) / 2) - (c.width / 2) + b;
}
ace(a, b, c, d, e) {
let f = (c.x - d.width) - b;
return f;
}
acg(a, b, c, d, e) {
let f = c.x + b;
return f;
}
acf(a, b, c, d, e) {
let f = (c.x - (d.width / 2));
f = f + b;
return f;
}
acb(a, b, c, d, e) {
let f = c.x - d.width;
f = f - b;
return f;
}
acd(a, b, c, d, e) {
let f = c.x;
f = f + b;
return f;
}
acc(a, b, c, d, e) {
let f = c.x - (d.width / 2);
f = f + b;
return f;
}
ab1(a, b, c, d, e, f, g, h) {
switch (a) {
case 1:
{
return this.acp(e, b, h, f, true);
}
case 2:
{
return this.acn(e, b, h, f, true);
}
case 3:
{
return this.aco(e, b, h, f, true);
}
case 5: return this.acq(e, c, b, h, f);
case 6: return this.acr(e, c, b, h, f);
case 4: return this.acs(e, c, b, h, f);
case 8: return this.ach(e, c, b, h, f);
case 9: return this.aci(e, c, b, h, f);
case 7: return this.acj(e, c, b, h, f);
case 13: return this.acm(d, b);
case 14: return this.ack(d, b, f);
case 15: return this.acl(d, f);
case 10: return this.acv(e, b, g, f, true);
case 12: return this.acu(e, b, g, f, true);
case 11:
default: return this.act(e, b, g, f, true);
}
}
ab8(a, b, c, d, e) {
let f = d.x;
f = f + b / 2;
f = f - e.width;
f = f - c;
return f;
}
ab9(a, b, c, d, e) {
let f = d.x;
f = f + b / 2;
f = f - e.width / 2;
f = f + c;
return f;
}
aca(a, b, c, d, e) {
let f = d.x;
f = f + b / 2;
f = f + c;
return f;
}
ab2(a, b, c, d, e) {
let f = d.x;
f = f - b / 2;
f = f - e.width;
f = f - c;
return f;
}
ab3(a, b, c, d, e) {
let f = d.x;
f = f - b / 2;
f = f - e.width / 2;
f = f + c;
return f;
}
ab4(a, b, c, d, e) {
let f = d.x;
f = f - b / 2;
f = f + c;
return f;
}
acj(a, b, c, d, e) {
let f = d.y;
f = f + b / 2;
f = f - e.height;
f = f - c;
return f;
}
aci(a, b, c, d, e) {
let f = d.y;
f = f + b / 2;
f = f - e.height / 2;
f = f + c;
return f;
}
ach(a, b, c, d, e) {
let f = d.y;
f = f + b / 2;
f = f + c;
return f;
}
acs(a, b, c, d, e) {
let f = d.y;
f = f - b / 2;
f = f - e.height;
f = f - c;
return f;
}
acr(a, b, c, d, e) {
let f = d.y;
f = f - b / 2;
f = f - e.height / 2;
f = f + c;
return f;
}
acq(a, b, c, d, e) {
let f = d.y;
f = f - b / 2;
f = f + c;
return f;
}
ab0(a, b, c, d, e, f, g, h) {
switch (a) {
case 10: return this.ace(e, b, g, f, true);
case 11: return this.acg(e, b, g, f, true);
case 12: return this.acf(e, b, g, f, true);
case 13: return this.ab5(d, b);
case 14: return this.ab7(e, b, f);
case 15: return this.ab6(e, b, f);
case 5: return this.ab4(e, c, b, h, f);
case 6: return this.ab3(e, c, b, h, f);
case 4: return this.ab2(e, c, b, h, f);
case 8: return this.aca(e, c, b, h, f);
case 9: return this.ab9(e, c, b, h, f);
case 7: return this.ab8(e, c, b, h, f);
case 1:
{
return this.acb(e, b, h, f, true);
}
case 3:
{
return this.acc(e, b, h, f, true);
}
case 2:
default:
{
return this.acd(e, b, h, f, true);
}
}
}
ahm(a, b, c, d) {
let e = this.aaf;
let f = this.aaj;
let g = this.z4();
let h = 0;
if (g != null && g.cb && this.db != null) {
h = g.getCategorySize(this.db.v4, this.wr, this.getEffectiveViewport());
if (g.categoryMode == 0) {
h = 0;
}
}
let i = this.aby(e);
let j = this.abz(f);
let k = this.ab0(e, i, h, this.ahp, a, b, c, d);
let l = this.ab1(f, j, h, this.ahp, a, b, c, d);
let m = this.abk(a, i, k, b);
let n = this.abl(a, j, l, b);
if (!m) {
let o = this.zy(e);
let p = 0;
while (!m && p < o.length) {
e = o[p];
i = this.aby(e);
k = this.ab0(e, i, h, this.ahp, a, b, c, d);
m = this.abk(a, i, k, b);
p++;
}
}
if (!n) {
let q = this.zz(f);
let r = 0;
while (!n && r < q.length) {
f = q[r];
j = this.abz(f);
l = this.ab1(f, j, h, this.ahp, a, b, c, d);
n = this.abl(a, j, l, b);
r++;
}
}
return { $type: Point_$type, x: k, y: l };
}
abz(a) {
if (!isNaN_(this.abx)) {
return this.abx;
}
switch (a) {
case 1: return this.abv;
case 2: return this.abv;
case 3: return 0;
case 4: return this.abv;
case 5: return this.abv;
case 6: return this.abv;
case 7: return this.abv;
case 8: return this.abv;
case 9: return 0;
case 10: return this.abv;
case 11: return this.abv;
case 12: return 0;
case 13: return this.abv;
case 14: return this.abv;
case 15: return 0;
}
return this.abv;
}
aby(a) {
if (!isNaN_(this.abw)) {
return this.abw;
}
switch (a) {
case 4: return this.abu;
case 6: return 0;
case 5: return this.abu;
case 13: return this.abu;
case 15: return 0;
case 14: return this.abu;
case 7: return this.abu;
case 9: return 0;
case 8: return this.abu;
case 1: return this.abu;
case 3: return 0;
case 2: return this.abu;
case 10: return this.abu;
case 12: return 0;
case 11: return this.abu;
}
return this.abu;
}
zz(a) {
let b = [a];
switch (a) {
case 1:
b = [2, 3, 13, 14];
break;
case 2:
b = [1, 3, 14, 13];
break;
case 3:
b = [1, 2];
break;
case 4:
b = [8, 7, 3, 13, 14];
break;
case 5:
b = [7, 8, 3, 13, 14];
break;
case 6:
b = [9, 8, 4, 3];
break;
case 7:
b = [5, 4, 2, 14, 13];
break;
case 8:
b = [4, 5, 3, 14, 13];
break;
case 9:
b = [6, 4, 8, 3];
break;
case 10:
b = [11, 12, 2, 1, 3, 13, 14];
break;
case 11:
b = [10, 12, 1, 2, 3, 14, 13];
break;
case 12:
b = [10, 11];
break;
case 13: break;
case 14: break;
case 15: break;
}
return b;
}
zy(a) {
let b = [a];
switch (a) {
case 1:
b = [2, 3, 13, 14];
break;
case 2:
b = [1, 3, 14, 13];
break;
case 3:
b = [1, 2];
break;
case 4:
b = [8, 7, 3, 13, 14];
break;
case 5:
b = [7, 8, 1, 14, 13];
break;
case 6:
b = [9, 8, 4, 3];
break;
case 7:
b = [5, 4, 2, 14, 13];
break;
case 8:
b = [4, 5, 3, 13, 14];
break;
case 9:
b = [6, 4, 8, 3];
break;
case 10:
b = [11, 12, 2, 1, 3, 13, 14];
break;
case 11:
b = [10, 12, 1, 2, 3, 14, 13];
break;
case 12:
b = [10, 11];
break;
case 13: break;
case 14: break;
case 15: break;
}
return b;
}
abk(a, b, c, d) {
return !(this.abh(a, b, c) || this.abi(a, b, c, d));
}
abl(a, b, c, d) {
return !(this.abj(a, b, c) || this.abg(a, b, c, d));
}
afe(a) {
let b = new List$1(DataTooltipCollisionInfo.$, 0);
for (let c = 0; c < a.f.count; c++) {
let d = new DataTooltipCollisionInfo();
d.d = c;
d.e = { $type: Point_$type, x: a.f._inner[c], y: a.g._inner[c] };
d.c = a.k._inner[c];
d.a = a.j._inner[c];
d.b = a.m._inner[c];
if (isNaN_(d.e.x) || isNaN_(d.e.y)) {
continue;
}
b.add(d);
}
b.aa((e, f) => {
if (e.e.y < f.e.y) {
return -1;
}
if (e.e.y > f.e.y) {
return 1;
}
if (e.b < f.b) {
return -1;
}
if (e.b > f.b) {
return 1;
}
return 0;
});
let e = this.abd(b);
if (!e) {
return;
}
for (let f = 0; f < b.count - 1; f++) {
let g = b._inner[f];
let h = b._inner[f + 1];
let i = new Rect(0, g.e.x, g.e.y, g.c, g.a);
let j = new Rect(0, h.e.x, h.e.y, h.c, h.a);
if (i.intersectsWith(j) || i.top > j.bottom) {
h.e = { $type: Point_$type, x: h.e.x, y: i.bottom + 1 };
}
}
if (b._inner[b.count - 1].e.y + b._inner[b.count - 1].a > this.cv.bx.height) {
b._inner[b.count - 1].e = { $type: Point_$type, x: b._inner[b.count - 1].e.x, y: b._inner[b.count - 1].e.y - ((b._inner[b.count - 1].e.y + b._inner[b.count - 1].a) - this.cv.bx.height) };
}
for (let k = b.count - 1; k >= 1; k--) {
let l = b._inner[k];
let m = b._inner[k - 1];
let n = new Rect(0, l.e.x, l.e.y, l.c, l.a);
let o = new Rect(0, m.e.x, m.e.y, m.c, m.a);
if (n.intersectsWith(o) || n.top < o.bottom) {
m.e = { $type: Point_$type, x: m.e.x, y: n.top - (o.height + 1) };
}
}
for (let p = 0; p < b.count; p++) {
let q = b._inner[p].d;
let r = b._inner[p];
a.f._inner[q] = r.e.x;
a.g._inner[q] = r.e.y;
}
}
abd(a) {
if (a.count <= 1) {
return false;
}
let b = this.cv.bx;
for (let c = 0; c < a.count - 1; c++) {
let d = a._inner[c];
let e = a._inner[c + 1];
let f = new Rect(0, d.e.x, d.e.y, d.c, d.a);
let g = new Rect(0, e.e.x, e.e.y, e.c, e.a);
if (f.intersectsWith(g)) {
return true;
}
}
return false;
}
afi(a, b, c, d, e) {
let f = this.yj(a);
if (!f.c) {
return;
}
let g = a.wb(f.d, c, d);
let h = this.aaq.b9;
let i = this.zt;
if (!c) {
i = this.wg(g);
}
let j = a.km(i);
let k = h.item(e);
let l = this.cv.bx;
let m = this.aaq.b8(k);
if (!Base.equalsStatic(m.target, this.db)) {
m.target = this.db;
}
let n = new List$1(String_$type, 0);
if (a.eg && this.aan == 2) {
a.p0((o) => {
if (this.xh(o)) {
n.add(o.dataLegendKey);
}
return true;
});
}
m.includedSeries = [a.dataLegendKey];
m.excludedSeries = n.toArray();
this.afg(m);
m.targetCursorPositionX = this.zt.x;
m.targetCursorPositionY = this.zt.y;
if (!this.aaq.cb(k, a)) {
return;
}
let o = this.aaq.cq(k);
b.i.add1(k);
let p = g.x;
let q = g.x;
q = Math.max(q, l.left);
q = Math.min(q, l.right);
b.l.add(q);
let r = g.y;
r = Math.max(r, l.top);
r = Math.min(r, l.bottom);
b.m.add(r);
let s = DeviceUtils.g(10);
let t = g.x + s;
if (t + o.width > l.right) {
t = (l.right - o.width) - s;
}
if (t < l.left) {
t = l.left;
}
b.f.add(t);
let u = (g.y - o.height) - s;
if (u + o.height > l.bottom) {
u = (l.bottom - o.height) - s;
}
if (u < l.top) {
u = l.top;
}
b.g.add(u);
b.k.add(o.width);
b.j.add(o.height);
let v = this.u8;
if (v == null) {
v = this.ve;
}
if (v == null) {
v = a.u8;
}
b.h.add(v);
}
afh(a, b, c) {
this.aae = this.aah();
this.aai = this.aal();
let d = a.f;
let e = a.e;
let f = 0;
let g = this.aaq.b9.item(0);
this.aaq.cb(g, null);
let h = this.aaq.b8(g);
if (!Base.equalsStatic(h.target, this.db)) {
h.target = this.db;
}
let i = new List$1(String_$type, 0);
let j = this.z4();
if (j != null) {
for (let k of fromEnum(j.db())) {
if (k.isStacked) {
k.p2((l) => {
i.add(l.dataLegendKey);
if (l.eg) {
l.p0((m) => {
i.add(m.dataLegendKey);
return true;
});
}
return true;
});
}
else if (k.eg) {
i.add(k.dataLegendKey);
k.p0((l) => {
i.add(l.dataLegendKey);
return true;
});
}
else {
i.add(k.dataLegendKey);
}
}
h.includedSeries = i.toArray();
h.excludedSeries = null;
}
else {
h.includedSeries = null;
h.excludedSeries = null;
}
this.afg(h);
h.targetCursorPositionX = this.zt.x;
h.targetCursorPositionY = this.zt.y;
let l = this.aaq.cq(g);
let m = 0;
let n = 0;
let o = 0;
let p = 0;
let q = false;
let r = false;
o = d.x;
p = d.y;
let s = this.cv.bx;
let t = this.aaq.cr();
let u = this.ahq();
let v = this.ahm(u, l, e, d);
let w = v.x;
let x = v.y;
{
}
b.l.add(w);
b.m.add(x);
b.f.add(w);
b.g.add(x);
b.k.add(l.width);
b.j.add(l.height);
b.i.add1(g);
let y = null;
b.h.add(y);
this.aaq.b9.count = 1;
}
acy(a) {
return a.toolTip;
}
yt(a, b) {
super.yt(a, b);
let c = a;
let d = c.m.count;
let e = b.bx.left;
let f = b.bx.right;
let g = b.bx.top;
let h = b.bx.bottom;
for (let i = 0; i < d; i++) {
if (isNaN_(c.l._inner[i]) || isNaN_(c.m._inner[i]) || isNaN_(c.f._inner[i]) || isNaN_(c.g._inner[i])) {
this.aaq.ci(c.i._inner[i]);
continue;
}
let j = c.f._inner[i];
let k = c.g._inner[i];