UNPKG

igniteui-react-charts

Version:

Ignite UI React charting components for building rich data visualizations using TypeScript APIs.

1,214 lines (1,213 loc) 42.1 kB
/* 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 { TimeAxisBase } from "./TimeAxisBase"; import { ITimeRangeSelectorAxis_$type } from "./ITimeRangeSelectorAxis"; import { List$1 } from "igniteui-react-core"; import { TimeAxisBreak } from "./TimeAxisBreak"; import { TimeAxisBreakCollection } from "./TimeAxisBreakCollection"; import { TimeAxisLabellingMode_$type } from "./TimeAxisLabellingMode"; import { TimeAxisLabelFormatCollection } from "./TimeAxisLabelFormatCollection"; import { OrderedDictionary$2 } from "./OrderedDictionary$2"; import { TimeAxisInterval } from "./TimeAxisInterval"; import { TimeAxisIntervalCollection } from "./TimeAxisIntervalCollection"; import { EventArgs, runOn, delegateCombine, typeCast, Number_$type, fromEnum, enumGetBox, fromEn, Date_$type, markType } from "igniteui-react-core"; import { ScalerParams } from "./ScalerParams"; import { Rect } from "igniteui-react-core"; import { NumericScaler } from "./NumericScaler"; import { KeyValuePair$2 } from "igniteui-react-core"; import { LabelFormatOverrideEventArgs } from "./LabelFormatOverrideEventArgs"; import { NumericYAxis } from "./NumericYAxis"; import { LabelPosition } from "./LabelPosition"; import { Extensions } from "igniteui-react-core"; import { SortedListView$1 } from "./SortedListView$1"; import { Dictionary$2 } from "igniteui-react-core"; import { truncate, intDivide, isNaN_ } from "igniteui-react-core"; import { dateFromTicks, dateMaxValue, dateSubtract, dateMinValue, dateGetMonth, dateAddMonths, dateFromValues, dateGetTimeOfDay, dateAddDays, dateAddHours } from "igniteui-react-core"; import { timeSpanTicks, timeSpanInit3, timeSpanInit1, timeSpanFromMilliseconds, timeSpanFromSeconds, timeSpanFromMinutes, timeSpanFromHours, timeSpanFromDays, timeSpanFromTicks, timeSpanTotalMilliseconds } from "igniteui-react-core"; import { dateToStringFormat } from "igniteui-react-core"; /** * @hidden */ export let TimeXAxis = /*@__PURE__*/ (() => { class TimeXAxis extends TimeAxisBase { constructor() { super(); this.ti = 0; this.sr = null; this.s1 = 0; this.sz = null; this._omission = 0; this.sp = null; this.sw = null; this.tm = null; this.tz = 0; this.ta = dateMaxValue(); this.s8 = dateMaxValue(); this.s7 = dateMaxValue(); this.s9 = dateMinValue(); this.st = null; this.tx = 0; this.visibleRangeChanged = null; this.ab = TimeXAxis.$; this.omission = (0); this.ti = -2147483648; this.sr = new TimeAxisBreakCollection(); let a = this.breaks; a.collectionChanged = delegateCombine(a.collectionChanged, runOn(this, this.t2)); this.sw = new TimeAxisIntervalCollection(); let b = this.intervals; b.collectionChanged = delegateCombine(b.collectionChanged, runOn(this, this.t3)); this.sz = new TimeAxisLabelFormatCollection(); let c = this.labelFormats; c.collectionChanged = delegateCombine(c.collectionChanged, runOn(this, this.t4)); this.tz = (0); } al() { return new TimeXAxis(); } ko(a) { super.ko(a); this.kr(a, "LabellingMode"); } kr(a, b) { super.kr(a, b); let c = typeCast(TimeXAxis.$, a); if (c == null) { return; } if (b == "LabellingMode") { c.s2 = this.s2; } } get_ds() { return this.breaks != null && this.breaks.count > 0; } f7(a, b) { if (!b.c.isEmpty) { let c = this.tg(a, NumericScaler.ac, b.c, Rect.empty); c = (c - b.d.left) / b.d.width; c = b.d.left + b.d.width * (c - b.e.left) / b.e.width; return c; } return this.tg(a, b.e, b.d, b.c); } tg(a, b, c, d) { let e = new KeyValuePair$2(TimeAxisBreak.$, Number_$type, 1, null, 0); let f = this.ti != -2147483648 ? this.ti : 0; let g = this.sp != null ? this.sp.count : 0; while (f < g) { let h = this.sp.item1(f); if (h.d.getTime() <= a && h.c.getTime() >= a) { return NaN; } if (h.c.getTime() <= a) { e = new KeyValuePair$2(TimeAxisBreak.$, Number_$type, 1, h, this.sp.item(h)); f++; } else { break; } } if (f > 0) { f -= 1; } if (this.ti != -2147483648) { this.ti = f; } let i; let j; if (e.key != null) { i = e.value; j = e.key.c; } else { i = 0; j = this.actualMinimumValue; } let fromPrecedingBreak_ = +(dateFromTicks(truncate(a))) - +j; let k = (fromPrecedingBreak_ / ((this.actualMaximumValue.getTime() - this.actualMinimumValue.getTime()) - this.omission)); let l = i + k; l -= b.left; l /= b.width; let m = c.left; let n = c.right; let o = c.width; if (this.categoryMode != 0) { let p = this.getCategorySize(b, c, d); m += p / 2; n -= p / 2; o -= p; } if (this.dn) { return n - o * l; } return m + o * l; } k3(a, b, c, d) { this.ti = 0; for (let e = b; e < c; e++) { a.item(e, this.f7(a.item(e), d)); } this.ti = -2147483648; } startCursor() { this.ti = 0; } resetCursor() { this.ti = -2147483648; } ga(a, b) { if (!b.c.isEmpty) { let c = b.e.left + b.e.width * (a - b.d.left) / b.d.width; c = (c * b.d.width) + b.d.left; c = this.getUnscaledValue3(c, NumericScaler.ac, b.c, this.categoryMode); return c; } return this.th(a, b.e, b.d, b.c); } th(a, b, c, d) { let e = c.left; let f = c.width; if (this.categoryMode != 0) { let g = this.getCategorySize(b, c, d); e += g / 2; f -= g; } let h = b.left + b.width * (a - e) / f; if (this.dn) { h = 1 - h; } let i = new KeyValuePair$2(TimeAxisBreak.$, Number_$type, 1, null, 0); if (this.sp != null) { for (let j of fromEnum(this.sp)) { if (j.value >= h && j.value <= h) { return j.key.d.getTime(); } if (j.value < h && j.value > i.value) { i = j; } } } let precedingBreakEnd_; let k; if (i.key != null) { k = i.value; precedingBreakEnd_ = i.key.c; } else { k = 0; precedingBreakEnd_ = this.actualMinimumValue; } let portionFromPrecedingBreak_ = h - k; let actualRange_ = +(this.actualMaximumValue) - +(this.actualMinimumValue) - this.omission; return (precedingBreakEnd_.getTime() + portionFromPrecedingBreak_ * actualRange_); } get breaks() { return this.sr; } get s2() { return this.s1; } set s2(a) { let b = this.s2; if (a != b) { this.s1 = a; this.lu("LabellingMode", enumGetBox(TimeAxisLabellingMode_$type, b), enumGetBox(TimeAxisLabellingMode_$type, this.s2)); } } get labelFormats() { return this.sz; } lc(a, b, c, d) { super.lc(a, b, c, d); switch (b) { case "ActualMaximumValue": this.t1(); break; case "DateTimeColumn": this.tx = this.tv(); break; case "LabellingMode": this.l0(false); break; } } mg(a, b) { super.mg(a, b); this.t0(); this.sj(); } mf(a, b) { super.mf(a, b); this.t0(); this.sj(); } eg() { let a = super.eg(); this.t0(); return a; } get omission() { return this._omission; } set omission(a) { this._omission = a; } t1() { let a = this.s5(this.breaks); let b = (0); for (let c of fromEnum(a)) { b += (+(c.c) - +(c.d)); } this.omission = b; } s5(a) { let b = new List$1(TimeAxisBreak.$, 0); if (a == null || +(this.actualMaximumValue) == +(dateMaxValue())) { return b; } for (let c of fromEn(a)) { if (c.c >= this.actualMinimumValue && c.d <= this.actualMaximumValue) { b.add(c); } if (c.i != (0)) { let d = +(c.c) - +(c.d); let e = this.tb(c.d, c.i); while (e <= this.actualMaximumValue) { let f = this.tb(e, d); let g = ((() => { let $ret = new TimeAxisBreak(); $ret.d = e; $ret.c = f; return $ret; })()); if (g.c >= this.actualMinimumValue && g.d <= this.actualMaximumValue) { b.add(g); } if (dateSubtract(+(dateMaxValue()), +(c.i)) < g.d) { break; } e = this.tb(g.d, c.i); } } } return b; } tb(a, b) { let c = dateFromTicks(a.getTime()); c.setMilliseconds(c.getMilliseconds() + b); return c; } t0() { this.sp = new OrderedDictionary$2(TimeAxisBreak.$, Number_$type); if (+(this.actualMaximumValue) == +(dateMaxValue()) || this.breaks == null || this.breaks.count == 0 || this.b7 == null) { return; } let a = new List$1(TimeAxisBreak.$, 1, this.s5(this.breaks)); a.aa((b, c) => b.d < c.d ? -1 : b.d > c.d ? 1 : 0); let b = this.b7.yv; let c = new ScalerParams(0, this.b7.yv, this.b7.zd, this.dn, this.b7.yz); let d = +(this.actualMaximumValue) - +(this.actualMinimumValue) - this.omission; let e = 0; for (let f of fromEnum(a)) { let g = timeSpanTicks((+(f.d) - +(this.actualMinimumValue))) / timeSpanTicks(d); let h = timeSpanTicks((+(f.c) - +(this.actualMinimumValue))) / timeSpanTicks(d); if (h < 0 || g - e > 1) { continue; } this.sp.addItem(f, g - e); e += (h - g); } } ja(a) { if (isNaN_(a)) { return null; } let ticks_ = truncate(a); let b = (new Date(ticks_)); let c = this.hy(b); if (c == null) { return null; } return c.toString(); } hy(a) { if (!(typeCast(Date_$type, a) !== null)) { return super.hy(a); } let b = dateMinValue(); let c = false; if (this.tm != null) { if (typeCast(Date_$type, this.tm) !== null) { b = this.tm; c = true; } } let d = TimeXAxis.tl(a, c, b, this.s2, this.tz, this.labelFormats, this.hb); return d == null ? super.hy(a) : d; } static tl(a, b, c, d, e, f, g) { let h = TimeXAxis.sy(e, f, g); if (h != null) { let i = ((() => { let $ret = new LabelFormatOverrideEventArgs(); $ret.dateTime = a; $ret.format = h; return $ret; })()); let j = h.b(h, i); if (j != null) { return j; } } let k = TimeXAxis.tq(a, b, c, d, e, f, g); return dateToStringFormat(a, k, g); } static sy(a, b, c) { let d = null; let e = Number.MAX_VALUE; let f = null; for (let g of fromEnum(b)) { if (g.q < e) { e = g.q; f = g; } if (g.q > a) { continue; } if (d == null || g.q > d.q) { d = g; } } if (d == null) { d = f; } if (d == null) { return null; } return d; } static tq(a, b, c, d, e, f, g) { let h = 0; if (b) { h = TimeXAxis.s3(a, c); } let i; if (f == null || f.count == 0) { i = TimeXAxis.tp(e, h, d); } else { let j = TimeXAxis.sy(e, f, g); if (j == null) { return null; } switch (h) { case 3: if (j.j != null) { i = j.j; } else if (j.l != null) { i = j.l; } else if (j.n != null) { i = j.n; } else { i = j.g; } break; case 2: if (j.l != null) { i = j.l; } else if (j.n != null) { i = j.n; } else { i = j.g; } break; case 1: if (j.n != null) { i = j.n; } else { i = j.g; } break; default: i = j.g; break; } } return i; } static s3(a, b) { if (a.getFullYear() == b.getFullYear() && dateGetMonth(a) == dateGetMonth(b) && a.getDate() == b.getDate()) { return 3; } else if (a.getFullYear() == b.getFullYear() && dateGetMonth(a) == dateGetMonth(b)) { return 2; } else if (a.getFullYear() == b.getFullYear()) { return 1; } return 0; } get_rm() { return super.get_rm() || (this.intervals != null && this.intervals.count > 0); } set_rm(a) { super.set_rm(a); } get intervals() { return this.sw; } to(a, b) { return TimeXAxis.tp(this.tz, a, b); } static tp(a, b, c) { if (c != 2) { b = 0; } a = Math.abs(a); if (a > timeSpanInit3(1825, 0, 0, 0)) { return "yyyy"; } if (a > timeSpanInit3(365, 0, 0, 0)) { switch (b) { case 3: case 2: case 1: return "MMM"; } return "MMM yyyy"; } ; if (a > timeSpanInit3(4, 0, 0, 0)) { switch (b) { case 3: case 2: return "dd"; } return "MMM dd"; } ; if (a > timeSpanInit3(1, 0, 0, 0)) { switch (b) { case 3: return "hh:mmtt"; case 2: return "dd hh:mmtt"; } return "MMM dd hh:mmtt"; } ; if (a > timeSpanInit1(0, 10, 0)) { return "hh:mm"; } return "hh:mm:ss"; } static sq() { if (TimeXAxis.so == null) { TimeXAxis.so = ((() => { let $ret = new OrderedDictionary$2(Number_$type, TimeAxisInterval.$); $ret.addItem((0), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 0; $ret.f = 1; return $ret; })())); $ret.addItem(timeSpanFromMilliseconds(1), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 1; $ret.f = 1; return $ret; })())); $ret.addItem(timeSpanFromSeconds(1), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 2; $ret.f = 1; return $ret; })())); $ret.addItem(timeSpanFromSeconds(30), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 2; $ret.f = 30; return $ret; })())); $ret.addItem(timeSpanFromMinutes(2), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 3; $ret.f = 2; return $ret; })())); $ret.addItem(timeSpanFromMinutes(5), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 3; $ret.f = 5; return $ret; })())); $ret.addItem(timeSpanFromHours(1), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 4; $ret.f = 1; return $ret; })())); $ret.addItem(timeSpanFromDays(1), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 1; return $ret; })())); $ret.addItem(timeSpanFromDays(2), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 2; return $ret; })())); $ret.addItem(timeSpanFromDays(5), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 5; return $ret; })())); $ret.addItem(timeSpanFromDays(10), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 10; return $ret; })())); $ret.addItem(timeSpanFromDays(30), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 7; $ret.f = 1; return $ret; })())); $ret.addItem(timeSpanFromDays(60), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 7; $ret.f = 3; return $ret; })())); $ret.addItem(timeSpanFromDays(365), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 8; $ret.f = 1; return $ret; })())); $ret.addItem(timeSpanFromDays(365 * 10), ((() => { let $ret = new TimeAxisInterval(); $ret.b = 8; $ret.f = 10; return $ret; })())); return $ret; })()); } return TimeXAxis.so; } su() { if (this.eh && (this.a4 == null || this.a4.angle == 0)) { let a = this.gn(); let b = this.o8.width; let c = truncate(Math.floor(b / a)); let d = Number.MAX_VALUE; let e = c == 0 ? d : timeSpanFromTicks((intDivide(timeSpanTicks(this.tz), c))); let f = null; for (let g of fromEnum(TimeXAxis.sq())) { f = g.value; if (g.key > e) { break; } } let h = this.st; if (h != f) { this.l5(); } this.st = f; return f; } let i = this.tz; if (i == (0)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 8; $ret.f = 1; return $ret; })()); } if (i >= timeSpanFromDays(365 * 100)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 8; $ret.f = 10; return $ret; })()); } if (i >= timeSpanFromDays(365 * 5)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 8; $ret.f = 1; return $ret; })()); } if (i >= timeSpanFromDays(365 * 2)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 7; $ret.f = 3; return $ret; })()); } if (i >= timeSpanFromDays(150)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 7; $ret.f = 1; return $ret; })()); } if (i >= timeSpanFromDays(60)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 10; return $ret; })()); } if (i >= timeSpanFromDays(30)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 5; return $ret; })()); } if (i >= timeSpanFromDays(20)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 2; return $ret; })()); } if (i >= timeSpanFromDays(4)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 5; $ret.f = 1; return $ret; })()); } if (i >= timeSpanFromDays(1)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 4; $ret.f = 12; return $ret; })()); } if (i >= timeSpanFromHours(6)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 4; $ret.f = 1; return $ret; })()); } if (i >= timeSpanFromMinutes(30)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 3; $ret.f = 5; return $ret; })()); } if (i >= timeSpanFromMinutes(10)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 3; $ret.f = 2; return $ret; })()); } return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 2; $ret.f = 30; return $ret; })()); } sv() { if (this.intervals == null || this.intervals.count == 0) { return this.su(); } if (this.tz == (0)) { return ((() => { let $ret = new TimeAxisInterval(); $ret.b = 8; $ret.f = 1; return $ret; })()); } let a = null; for (let b of fromEnum(this.intervals)) { if (b.k > this.tz) { continue; } if (a == null || b.k > a.k) { a = b; } } return a == null ? this.su() : a; } l1(a) { super.l1(a); let b = this.b7 != null ? this.b7.yv : Rect.empty; let c = !b.isEmpty ? this.o8 : Rect.empty; let d = this.o3(); let e = this.o2(); let f = new ScalerParams(0, b, c, this.dn, d); if (this.ri == null && !this.ro() && !this.rp()) { return; } if (!b.isEmpty && !c.isEmpty) { let g = c.bottom; let h = g - c.top; if (this.an != null) { let i = typeCast(NumericYAxis.$, this.an); if (i != null) { let j = this.l6(g, h, b, c, d, c.top, c.bottom); g = j.p0; h = j.p1; } } if (isNaN_(g)) { g = 0; } this.k6(this.bp.bb(), g, c, this.bp.g(), true); this.a1.bn = h; let k = truncate(Math.ceil(e.right)); let l = truncate(Math.floor(e.left)); let m = this.bp.be(); let n = this.bp.h(); let o = this.bp.bc(); this.sj(); let p = new List$1(Date_$type, 1, this.s4()); let q = new List$1(Number_$type, 0); for (let r = 0; r < p.count; r++) { q.add(p._inner[r].getTime()); } this.k3(q, 0, q.count, f); this.tm = null; for (let s = 0; s < p.count; s++) { let t = p._inner[s]; let u = q._inner[s]; let v = truncate(Math.round(u)); if (v <= k) { if (s % 2 == 0) { let w = s < q.count - 1 ? q._inner[s + 1] : e.right; this.me(m, u, w, c); } this.md(o, u, c, n, false); this.pw.add(u); } if (v >= l && v <= k) { let x = this.hy(t); this.tm = t; if (x != null) { this.er.add1(x); this.es.add(new LabelPosition(0, u)); } } } this.tm = null; } if ((this.a4 == null || this.a4.visibility == 0) && this.an != null) { if (this.a4 != null && (this.a4.location == 4 || this.a4.location == 5)) { this.b7.pt(); } } this.a1.bg = this.er; this.a1.bh = this.es; this.a1.cr(); this.q4(); } s4() { let a = this.b7 != null ? this.b7.yv : Rect.empty; let b = !a.isEmpty ? this.o8 : Rect.empty; let c = this.o3(); let d = this.o2(); let e = new ScalerParams(0, a, b, this.dn, c); let f = this.sv(); let g = this.td; if (!this.rp() && f != null) { if (f.b == 7 && g.getDate() != 1) { g = dateAddMonths(g, 1); g = dateFromValues(g.getFullYear(), dateGetMonth(g), 1, 0, 0, 0, 0); } else if (f.b == 5 && dateGetTimeOfDay(g) != (0)) { g = dateAddDays(g, 1); g = dateFromValues(g.getFullYear(), dateGetMonth(g), g.getDate(), 0, 0, 0, 0); } else if (f.b == 4 && g.getMinutes() != 0) { g = dateAddHours(g, 1); g = dateFromValues(g.getFullYear(), dateGetMonth(g), g.getDate(), g.getHours(), 0, 0, 0); } } let h = new List$1(Date_$type, 0); let i = 0; let j = 10000; if (f.f == 0) { return h; } while (g <= this.visibleMaximum && i++ < j) { let k = this.s6(g); let l = g; if (k.key != null) { l = f.d(k.key.c); } h.add(l); while (g <= l) { g = f.c(g); if (+g == +(dateMaxValue())) { break; } } } return h; } s6(a) { if (this.sp == null) { return new KeyValuePair$2(TimeAxisBreak.$, Number_$type); } for (let b of fromEnum(this.sp)) { if (b.key.d <= a && b.key.c >= a) { return b; } } return new KeyValuePair$2(TimeAxisBreak.$, Number_$type); } get visibleMinimum() { return this.ta; } set visibleMinimum(a) { this.ta = a; } get td() { return this.s8; } set td(a) { this.s8 = a; } get tc() { return this.s7; } set tc(a) { this.s7 = a; } get visibleMaximum() { return this.s9; } set visibleMaximum(a) { this.s9 = a; } sj() { super.sj(); if (this.b7 == null || !Extensions.b(this.b7.zd)) { return; } let a = new ScalerParams(0, this.b7.yv, this.b7.zd, this.dn, this.b7.yz); let b = this.o2(); let c = b.left; let d = b.right; let e = b.left; let f = b.right; if (this.categoryMode != 0) { let g = this.getCategorySize(a.e, a.d, a.c); e += g / 2; f -= g / 2; } let h = truncate(this.ga(c, a)); let i = truncate(this.ga(d, a)); let j = truncate(this.ga(e, a)); let k = truncate(this.ga(f, a)); if (j < 0 || k < 0) { this.tz = (0); return; } h = Math.min(dateMaxValue().getTime(), h); i = Math.min(dateMaxValue().getTime(), i); h = Math.max(dateMinValue().getTime(), h); i = Math.max(dateMinValue().getTime(), i); j = Math.min(dateMaxValue().getTime(), j); k = Math.min(dateMaxValue().getTime(), k); let l = dateFromTicks(Math.min(h, i)); let m = dateFromTicks(Math.max(h, i)); let n = dateFromTicks(Math.min(j, k)); let o = dateFromTicks(Math.max(j, k)); let p = +(this.visibleMinimum) != +n || +(this.visibleMaximum) != +o; this.visibleMinimum = n; this.visibleMaximum = o; this.td = l; this.tc = m; if (p && this.visibleRangeChanged != null) { this.visibleRangeChanged(this, EventArgs.empty); } this.tz = +(this.visibleMaximum) - +(this.visibleMinimum); } p4(a, b, c, d, e) { return 0; } i$f(a) { let b = this; if (b.i$b == null || b.i$b.count == 0) { return -1; } let c = new SortedListView$1(Date_$type, this.ri, b.i$b); let ticks_ = a; let d = (new Date(ticks_)); let e = this.r2(d, c); e = Math.max(0, Math.min(b.i$b.count - 1, e)); let f = c.item(e); let g; let h; if (f < d) { g = e; h = g + 1; } else { h = e; g = e - 1; } g = this.tk(g, c); h = this.tj(h, c); if (g < 0) { return h; } if (h >= b.i$b.count) { return g; } let i = c.item(g); let j = c.item(h); let k = new ScalerParams(0, this.b7.ze, this.o8, this.dn, this.b7.yz); this.startCursor(); let l = this.f7(i.getTime(), k); let m = this.f7(a, k); let n = this.f7(j.getTime(), k); this.resetCursor(); if (i < this.td && j <= this.tc) { return this.rr._inner[h]; } if (j > this.tc && i >= this.td) { return this.rr._inner[g]; } if (Math.abs(l - m) < Math.abs(n - m)) { return this.rr._inner[g]; } else { return this.rr._inner[h]; } } tj(a, b) { if (a < 0 || a >= b.count - 1) { return a; } let c = b.item(a); let d = 0; while (d < this.sp.count) { let e = this.sp.item1(d); if (c >= e.d && c <= e.c) { break; } d++; } if (d >= this.sp.count) { return a; } let f = a; while (f < b.count) { if (f < 0 || f >= b.count - 1) { return a; } c = b.item(f); let g = this.sp.item1(d); if (c >= g.d && c <= g.c) { f++; continue; } d++; if (d > this.sp.count - 1) { break; } g = this.sp.item1(d); if (c >= g.d && c <= g.c) { f++; continue; } break; } if (f < 0 || f > b.count - 1) { return a; } return f; } tk(a, b) { if (a < 0 || a >= b.count - 1) { return a; } let c = b.item(a); let d = 0; while (d < this.sp.count) { let e = this.sp.item1(d); if (c >= e.d && c <= e.c) { break; } d++; } if (d >= this.sp.count) { return a; } let f = a; while (f >= 0) { if (f < 0 || f >= b.count - 1) { return a; } c = b.item(f); let g = this.sp.item1(d); if (c >= g.d && c <= g.c) { f--; continue; } d--; if (d < 0) { break; } g = this.sp.item1(d); if (c >= g.d && c <= g.c) { f--; continue; } break; } if (f < 0 || f > b.count - 1) { return a; } return f; } t2(a, b) { this.t1(); this.t0(); if (this.a1 != null) { this.a1.an = this.breaks.count > 0; } this.l0(false); for (let c of fromEnum(this.ep())) { c.sa(false); } } t4(a, b) { this.l0(false); } t3(a, b) { this.l0(false); } get_dg() { return false; } getWindowRectForSelection(a, b) { let c = +(this.actualMaximumValue) - +(this.actualMinimumValue); let d = timeSpanTotalMilliseconds((+a - +(this.actualMinimumValue))) / timeSpanTotalMilliseconds(c); let e = 1 - (timeSpanTotalMilliseconds((+(this.actualMaximumValue) - +b)) / timeSpanTotalMilliseconds(c)); e = Math.min(1, e); return new Rect(0, d, NaN, Math.max(0, e - d), NaN); } getCategorySize(a, b, c) { if (this.tz != (0)) { let d = timeSpanFromTicks(truncate((timeSpanTicks(this.tz) * (a.width / (this.b7 != null ? this.b7.yv.width : 1))))); let e = timeSpanTicks(d) / timeSpanTicks(this.tx); let f = b.width / 4; return Math.min(f, b.width / (e + 1)); } return super.getCategorySize(a, b, c); } static tw(a, b) { let c = Math.min(5, b); let d = a(0); let e = new Dictionary$2(Number_$type, Number_$type, 0); let f = 0; let g = (0); for (let h = 0; h < c; h++) { let i = a(h); let j = +i - +d; if (!e.containsKey(j)) { e.addItem(j, 0); } e.item(j, e.item(j) + 1); if (e.item(j) > f) { f = e.item(j); g = j; } d = i; } return g; } tv() { if (this.ri == null || this.ri.count < 2 || this.rr == null) { return (0); } return TimeXAxis.tw((a) => this.ri.item(this.rr._inner[a]), this.ri.count); } sf() { super.sf(); this.tx = this.tv(); } static ts(a) { if (a >= timeSpanFromDays(1)) { return "D"; } return "g"; } itemLabelFormat() { return TimeXAxis.ts(this.tx); } r1(a, b, c, d) { return this.r0(this.visibleMinimum); } r4(a, b, c, d) { return this.r3(this.visibleMaximum); } get isVertical() { return this.dz; } j$d(a, b) { return this.ga.apply(this, arguments); } j$c(a, b) { return this.f7.apply(this, arguments); } j$e(a, b, c, d, e) { this.k2.apply(this, arguments); } j$f(a, b, c, d) { this.k3.apply(this, arguments); } j$g(a, b, c, d) { this.k4.apply(this, arguments); } get j$b() { return this.dn; } j$a() { return this.ag.apply(this, arguments); } get i$a() { return this.dj; } } TimeXAxis.$t = /*@__PURE__*/ markType(TimeXAxis, 'TimeXAxis', TimeAxisBase.$, [ITimeRangeSelectorAxis_$type]); TimeXAxis.so = null; return TimeXAxis; })();