/*!
* ApexCharts v5.3.6
* (c) 2018-2025 ApexCharts
*/
!function (t, e) {
"object" == typeof exports && "undefined" != typeof module ? module.exports = e() : "function" == typeof define && define.amd ? define(e) : (t = "undefined" != typeof globalThis ? globalThis : t || self).ApexCharts = e()
}(this, (function () {
"use strict";
function t(t, e) {
(null == e || e > t.length) && (e = t.length);
for (var i = 0, a = Array(e); i < e; i++) a[i] = t[i];
return a
}
function e(t) {
if (void 0 === t) throw new ReferenceError("this hasn't been initialised - super() hasn't been called");
return t
}
function i(t, e) {
if (!(t instanceof e)) throw new TypeError("Cannot call a class as a function")
}
function a(t, e) {
for (var i = 0; i < e.length; i++) {
var a = e[i];
a.enumerable = a.enumerable || !1, a.configurable = !0, "value" in a && (a.writable = !0), Object.defineProperty(t, x(a.key), a)
}
}
function s(t, e, i) {
return e && a(t.prototype, e), i && a(t, i), Object.defineProperty(t, "prototype", {writable: !1}), t
}
function r(t, e) {
var i = "undefined" != typeof Symbol && t[Symbol.iterator] || t["@@iterator"];
if (!i) {
if (Array.isArray(t) || (i = m(t)) || e && t && "number" == typeof t.length) {
i && (t = i);
var a = 0, s = function () {
};
return {
s: s, n: function () {
return a >= t.length ? {done: !0} : {done: !1, value: t[a++]}
}, e: function (t) {
throw t
}, f: s
}
}
throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")
}
var r, n = !0, o = !1;
return {
s: function () {
i = i.call(t)
}, n: function () {
var t = i.next();
return n = t.done, t
}, e: function (t) {
o = !0, r = t
}, f: function () {
try {
n || null == i.return || i.return()
} finally {
if (o) throw r
}
}
}
}
function n(t) {
var i = c();
return function () {
var a, s = l(t);
if (i) {
var r = l(this).constructor;
a = Reflect.construct(s, arguments, r)
} else a = s.apply(this, arguments);
return function (t, i) {
if (i && ("object" == typeof i || "function" == typeof i)) return i;
if (void 0 !== i) throw new TypeError("Derived constructors may only return object or undefined");
return e(t)
}(this, a)
}
}
function o(t, e, i) {
return (e = x(e)) in t ? Object.defineProperty(t, e, {
value: i,
enumerable: !0,
configurable: !0,
writable: !0
}) : t[e] = i, t
}
function l(t) {
return l = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) {
return t.__proto__ || Object.getPrototypeOf(t)
}, l(t)
}
function h(t, e) {
if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function");
t.prototype = Object.create(e && e.prototype, {
constructor: {
value: t,
writable: !0,
configurable: !0
}
}), Object.defineProperty(t, "prototype", {writable: !1}), e && g(t, e)
}
function c() {
try {
var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], (function () {
})))
} catch (t) {
}
return (c = function () {
return !!t
})()
}
function d(t, e) {
var i = Object.keys(t);
if (Object.getOwnPropertySymbols) {
var a = Object.getOwnPropertySymbols(t);
e && (a = a.filter((function (e) {
return Object.getOwnPropertyDescriptor(t, e).enumerable
}))), i.push.apply(i, a)
}
return i
}
function u(t) {
for (var e = 1; e < arguments.length; e++) {
var i = null != arguments[e] ? arguments[e] : {};
e % 2 ? d(Object(i), !0).forEach((function (e) {
o(t, e, i[e])
})) : Object.getOwnPropertyDescriptors ? Object.defineProperties(t, Object.getOwnPropertyDescriptors(i)) : d(Object(i)).forEach((function (e) {
Object.defineProperty(t, e, Object.getOwnPropertyDescriptor(i, e))
}))
}
return t
}
function g(t, e) {
return g = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) {
return t.__proto__ = e, t
}, g(t, e)
}
function p(t, e) {
return function (t) {
if (Array.isArray(t)) return t
}(t) || function (t, e) {
var i = null == t ? null : "undefined" != typeof Symbol && t[Symbol.iterator] || t["@@iterator"];
if (null != i) {
var a, s, r, n, o = [], l = !0, h = !1;
try {
if (r = (i = i.call(t)).next, 0 === e) {
if (Object(i) !== i) return;
l = !1
} else for (; !(l = (a = r.call(i)).done) && (o.push(a.value), o.length !== e); l = !0) ;
} catch (t) {
h = !0, s = t
} finally {
try {
if (!l && null != i.return && (n = i.return(), Object(n) !== n)) return
} finally {
if (h) throw s
}
}
return o
}
}(t, e) || m(t, e) || function () {
throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")
}()
}
function f(e) {
return function (e) {
if (Array.isArray(e)) return t(e)
}(e) || function (t) {
if ("undefined" != typeof Symbol && null != t[Symbol.iterator] || null != t["@@iterator"]) return Array.from(t)
}(e) || m(e) || function () {
throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")
}()
}
function x(t) {
var e = function (t, e) {
if ("object" != typeof t || !t) return t;
var i = t[Symbol.toPrimitive];
if (void 0 !== i) {
var a = i.call(t, e || "default");
if ("object" != typeof a) return a;
throw new TypeError("@@toPrimitive must return a primitive value.")
}
return ("string" === e ? String : Number)(t)
}(t, "string");
return "symbol" == typeof e ? e : e + ""
}
function b(t) {
return b = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (t) {
return typeof t
} : function (t) {
return t && "function" == typeof Symbol && t.constructor === Symbol && t !== Symbol.prototype ? "symbol" : typeof t
}, b(t)
}
function m(e, i) {
if (e) {
if ("string" == typeof e) return t(e, i);
var a = {}.toString.call(e).slice(8, -1);
return "Object" === a && e.constructor && (a = e.constructor.name), "Map" === a || "Set" === a ? Array.from(e) : "Arguments" === a || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(a) ? t(e, i) : void 0
}
}
var v = function () {
function t() {
i(this, t)
}
return s(t, [{
key: "shadeRGBColor", value: function (t, e) {
var i = e.split(","), a = t < 0 ? 0 : 255, s = t < 0 ? -1 * t : t, r = parseInt(i[0].slice(4), 10),
n = parseInt(i[1], 10), o = parseInt(i[2], 10);
return "rgb(" + (Math.round((a - r) * s) + r) + "," + (Math.round((a - n) * s) + n) + "," + (Math.round((a - o) * s) + o) + ")"
}
}, {
key: "shadeHexColor", value: function (t, e) {
var i = parseInt(e.slice(1), 16), a = t < 0 ? 0 : 255, s = t < 0 ? -1 * t : t, r = i >> 16,
n = i >> 8 & 255, o = 255 & i;
return "#" + (16777216 + 65536 * (Math.round((a - r) * s) + r) + 256 * (Math.round((a - n) * s) + n) + (Math.round((a - o) * s) + o)).toString(16).slice(1)
}
}, {
key: "shadeColor", value: function (e, i) {
return t.isColorHex(i) ? this.shadeHexColor(e, i) : this.shadeRGBColor(e, i)
}
}], [{
key: "bind", value: function (t, e) {
return function () {
return t.apply(e, arguments)
}
}
}, {
key: "isObject", value: function (t) {
return t && "object" === b(t) && !Array.isArray(t) && null != t
}
}, {
key: "is", value: function (t, e) {
return Object.prototype.toString.call(e) === "[object " + t + "]"
}
}, {
key: "isSafari", value: function () {
return /^((?!chrome|android).)*safari/i.test(navigator.userAgent)
}
}, {
key: "listToArray", value: function (t) {
var e, i = [];
for (e = 0; e < t.length; e++) i[e] = t[e];
return i
}
}, {
key: "extend", value: function (t, e) {
var i = this;
"function" != typeof Object.assign && (Object.assign = function (t) {
if (null == t) throw new TypeError("Cannot convert undefined or null to object");
for (var e = Object(t), i = 1; i < arguments.length; i++) {
var a = arguments[i];
if (null != a) for (var s in a) a.hasOwnProperty(s) && (e[s] = a[s])
}
return e
});
var a = Object.assign({}, t);
return this.isObject(t) && this.isObject(e) && Object.keys(e).forEach((function (s) {
i.isObject(e[s]) && s in t ? a[s] = i.extend(t[s], e[s]) : Object.assign(a, o({}, s, e[s]))
})), a
}
}, {
key: "extendArray", value: function (e, i) {
var a = [];
return e.map((function (e) {
a.push(t.extend(i, e))
})), e = a
}
}, {
key: "monthMod", value: function (t) {
return t % 12
}
}, {
key: "clone", value: function (t) {
var e, i = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : new WeakMap;
if (null === t || "object" !== b(t)) return t;
if (i.has(t)) return i.get(t);
if (Array.isArray(t)) {
e = [], i.set(t, e);
for (var a = 0; a < t.length; a++) e[a] = this.clone(t[a], i)
} else if (t instanceof Date) e = new Date(t.getTime()); else for (var s in e = {}, i.set(t, e), t) t.hasOwnProperty(s) && (e[s] = this.clone(t[s], i));
return e
}
}, {
key: "log10", value: function (t) {
return Math.log(t) / Math.LN10
}
}, {
key: "roundToBase10", value: function (t) {
return Math.pow(10, Math.floor(Math.log10(t)))
}
}, {
key: "roundToBase", value: function (t, e) {
return Math.pow(e, Math.floor(Math.log(t) / Math.log(e)))
}
}, {
key: "parseNumber", value: function (t) {
return "number" == typeof t || null === t ? t : parseFloat(t)
}
}, {
key: "stripNumber", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 2;
return Number.isInteger(t) ? t : parseFloat(t.toPrecision(e))
}
}, {
key: "randomId", value: function () {
return (Math.random() + 1).toString(36).substring(4)
}
}, {
key: "noExponents", value: function (t) {
return t.toString().includes("e") ? Math.round(t) : t
}
}, {
key: "elementExists", value: function (t) {
return !(!t || !t.isConnected)
}
}, {
key: "isInShadowDOM", value: function (e) {
if (!e || !e.getRootNode) return !1;
var i = e.getRootNode();
return i && i !== document && t.is("ShadowRoot", i)
}
}, {
key: "getShadowRootHost", value: function (e) {
return t.isInShadowDOM(e) && e.getRootNode().host || null
}
}, {
key: "getDimensions", value: function (t) {
if (!t) return [0, 0];
var e, i = t.getRootNode && t.getRootNode();
if (i && i !== document && i.host) {
var a = i.host.getBoundingClientRect();
return [a.width, a.height]
}
try {
e = getComputedStyle(t, null)
} catch (e) {
return [t.clientWidth || 0, t.clientHeight || 0]
}
var s = t.clientHeight, r = t.clientWidth;
return s -= parseFloat(e.paddingTop) + parseFloat(e.paddingBottom), [r -= parseFloat(e.paddingLeft) + parseFloat(e.paddingRight), s]
}
}, {
key: "getBoundingClientRect", value: function (t) {
if (!t) return {top: 0, right: 0, bottom: 0, left: 0, width: 0, height: 0, x: 0, y: 0};
var e = t.getBoundingClientRect();
return {
top: e.top,
right: e.right,
bottom: e.bottom,
left: e.left,
width: t.clientWidth,
height: t.clientHeight,
x: e.left,
y: e.top
}
}
}, {
key: "getLargestStringFromArr", value: function (t) {
return t.reduce((function (t, e) {
return Array.isArray(e) && (e = e.reduce((function (t, e) {
return t.length > e.length ? t : e
}))), t.length > e.length ? t : e
}), 0)
}
}, {
key: "hexToRgba", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : "#999999",
e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : .6;
"#" !== t.substring(0, 1) && (t = "#999999");
var i = t.replace("#", "");
i = i.match(new RegExp("(.{" + i.length / 3 + "})", "g"));
for (var a = 0; a < i.length; a++) i[a] = parseInt(1 === i[a].length ? i[a] + i[a] : i[a], 16);
return void 0 !== e && i.push(e), "rgba(" + i.join(",") + ")"
}
}, {
key: "getOpacityFromRGBA", value: function (t) {
return parseFloat(t.replace(/^.*,(.+)\)/, "$1"))
}
}, {
key: "rgb2hex", value: function (t) {
return (t = t.match(/^rgba?[\s+]?\([\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?,[\s+]?(\d+)[\s+]?/i)) && 4 === t.length ? "#" + ("0" + parseInt(t[1], 10).toString(16)).slice(-2) + ("0" + parseInt(t[2], 10).toString(16)).slice(-2) + ("0" + parseInt(t[3], 10).toString(16)).slice(-2) : ""
}
}, {
key: "isColorHex", value: function (t) {
return /(^#[0-9A-F]{6}$)|(^#[0-9A-F]{3}$)|(^#[0-9A-F]{8}$)/i.test(t)
}
}, {
key: "getPolygonPos", value: function (t, e) {
for (var i = [], a = 2 * Math.PI / e, s = 0; s < e; s++) {
var r = {};
r.x = t * Math.sin(s * a), r.y = -t * Math.cos(s * a), i.push(r)
}
return i
}
}, {
key: "polarToCartesian", value: function (t, e, i, a) {
var s = (a - 90) * Math.PI / 180;
return {x: t + i * Math.cos(s), y: e + i * Math.sin(s)}
}
}, {
key: "escapeString", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : "x", i = t.toString().slice();
return i = i.replace(/[` ~!@#$%^&*()|+\=?;:'",.<>{}[\]\\/]/gi, e)
}
}, {
key: "negToZero", value: function (t) {
return t < 0 ? 0 : t
}
}, {
key: "moveIndexInArray", value: function (t, e, i) {
if (i >= t.length) for (var a = i - t.length + 1; a--;) t.push(void 0);
return t.splice(i, 0, t.splice(e, 1)[0]), t
}
}, {
key: "extractNumber", value: function (t) {
return parseFloat(t.replace(/[^\d.]*/g, ""))
}
}, {
key: "findAncestor", value: function (t, e) {
for (; (t = t.parentElement) && !t.classList.contains(e);) ;
return t
}
}, {
key: "setELstyles", value: function (t, e) {
for (var i in e) e.hasOwnProperty(i) && (t.style.key = e[i])
}
}, {
key: "preciseAddition", value: function (t, e) {
var i = (String(t).split(".")[1] || "").length, a = (String(e).split(".")[1] || "").length,
s = Math.pow(10, Math.max(i, a));
return (Math.round(t * s) + Math.round(e * s)) / s
}
}, {
key: "isNumber", value: function (t) {
return !isNaN(t) && parseFloat(Number(t)) === t && !isNaN(parseInt(t, 10))
}
}, {
key: "isFloat", value: function (t) {
return Number(t) === t && t % 1 != 0
}
}, {
key: "isMsEdge", value: function () {
var t = window.navigator.userAgent, e = t.indexOf("Edge/");
return e > 0 && parseInt(t.substring(e + 5, t.indexOf(".", e)), 10)
}
}, {
key: "getGCD", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : 7,
a = Math.pow(10, i - Math.floor(Math.log10(Math.max(t, e))));
for (a > 1 ? (t = Math.round(Math.abs(t) * a), e = Math.round(Math.abs(e) * a)) : a = 1; e;) {
var s = e;
e = t % e, t = s
}
return t / a
}
}, {
key: "getPrimeFactors", value: function (t) {
for (var e = [], i = 2; t >= 2;) t % i == 0 ? (e.push(i), t /= i) : i++;
return e
}
}, {
key: "mod", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : 7,
a = Math.pow(10, i - Math.floor(Math.log10(Math.max(t, e))));
return (t = Math.round(Math.abs(t) * a)) % (e = Math.round(Math.abs(e) * a)) / a
}
}]), t
}(), y = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "animateLine", value: function (t, e, i, a) {
t.attr(e).animate(a).attr(i)
}
}, {
key: "animateMarker", value: function (t, e, i, a) {
t.attr({opacity: 0}).animate(e).attr({opacity: 1}).after((function () {
a()
}))
}
}, {
key: "animateRect", value: function (t, e, i, a, s) {
t.attr(e).animate(a).attr(i).after((function () {
return s()
}))
}
}, {
key: "animatePathsGradually", value: function (t) {
var e = t.el, i = t.realIndex, a = t.j, s = t.fill, r = t.pathFrom, n = t.pathTo, o = t.speed,
l = t.delay, h = this.w, c = 0;
h.config.chart.animations.animateGradually.enabled && (c = h.config.chart.animations.animateGradually.delay), h.config.chart.animations.dynamicAnimation.enabled && h.globals.dataChanged && "bar" !== h.config.chart.type && (c = 0), this.morphSVG(e, i, a, "line" !== h.config.chart.type || h.globals.comboCharts ? s : "stroke", r, n, o, l * c)
}
}, {
key: "showDelayedElements", value: function () {
this.w.globals.delayedElements.forEach((function (t) {
var e = t.el;
e.classList.remove("apexcharts-element-hidden"), e.classList.add("apexcharts-hidden-element-shown")
}))
}
}, {
key: "animationCompleted", value: function (t) {
var e = this.w;
e.globals.animationEnded || (e.globals.animationEnded = !0, this.showDelayedElements(), "function" == typeof e.config.chart.events.animationEnd && e.config.chart.events.animationEnd(this.ctx, {
el: t,
w: e
}))
}
}, {
key: "morphSVG", value: function (t, e, i, a, s, r, n, o) {
var l = this, h = this.w;
s || (s = t.attr("pathFrom")), r || (r = t.attr("pathTo"));
var c = function (t) {
return "radar" === h.config.chart.type && (n = 1), "M 0 ".concat(h.globals.gridHeight)
};
(!s || s.indexOf("undefined") > -1 || s.indexOf("NaN") > -1) && (s = c()), (!r.trim() || r.indexOf("undefined") > -1 || r.indexOf("NaN") > -1) && (r = c()), h.globals.shouldAnimate || (n = 1), t.plot(s).animate(1, o).plot(s).animate(n, o).plot(r).after((function () {
v.isNumber(i) ? i === h.globals.series[h.globals.maxValsInArrayIndex].length - 2 && h.globals.shouldAnimate && l.animationCompleted(t) : "none" !== a && h.globals.shouldAnimate && (!h.globals.comboCharts && e === h.globals.series.length - 1 || h.globals.comboCharts) && l.animationCompleted(t), l.showDelayedElements()
}))
}
}]), t
}();
const w = {}, k = [];
function A(t, e) {
if (Array.isArray(t)) for (const i of t) A(i, e); else if ("object" != typeof t) S(Object.getOwnPropertyNames(e)), w[t] = Object.assign(w[t] || {}, e); else for (const e in t) A(e, t[e])
}
function C(t) {
return w[t] || {}
}
function S(t) {
k.push(...t)
}
function L(t, e) {
let i;
const a = t.length, s = [];
for (i = 0; i < a; i++) s.push(e(t[i]));
return s
}
function M(t) {
return t % 360 * Math.PI / 180
}
function P(t) {
return t.charAt(0).toUpperCase() + t.slice(1)
}
function I(t, e, i, a) {
return null != e && null != i || (a = a || t.bbox(), null == e ? e = a.width / a.height * i : null == i && (i = a.height / a.width * e)), {
width: e,
height: i
}
}
function T(t, e) {
const i = t.origin;
let a = null != t.ox ? t.ox : null != t.originX ? t.originX : "center",
s = null != t.oy ? t.oy : null != t.originY ? t.originY : "center";
null != i && ([a, s] = Array.isArray(i) ? i : "object" == typeof i ? [i.x, i.y] : [i, i]);
const r = "string" == typeof a, n = "string" == typeof s;
if (r || n) {
const {height: t, width: i, x: o, y: l} = e.bbox();
r && (a = a.includes("left") ? o : a.includes("right") ? o + i : o + i / 2), n && (s = s.includes("top") ? l : s.includes("bottom") ? l + t : l + t / 2)
}
return [a, s]
}
const z = new Set(["desc", "metadata", "title"]), X = t => z.has(t.nodeName), R = (t, e, i = {}) => {
const a = {...e};
for (const t in a) a[t].valueOf() === i[t] && delete a[t];
Object.keys(a).length ? t.node.setAttribute("data-svgjs", JSON.stringify(a)) : (t.node.removeAttribute("data-svgjs"), t.node.removeAttribute("svgjs:data"))
}, E = "http://www.w3.org/2000/svg", Y = "http://www.w3.org/2000/xmlns/", H = "http://www.w3.org/1999/xlink", O = {
window: "undefined" == typeof window ? null : window,
document: "undefined" == typeof document ? null : document
};
function F() {
return O.window
}
let D = class {
};
const _ = {}, N = "___SYMBOL___ROOT___";
function W(t, e = E) {
return O.document.createElementNS(e, t)
}
function B(t, e = !1) {
if (t instanceof D) return t;
if ("object" == typeof t) return U(t);
if (null == t) return new _[N];
if ("string" == typeof t && "<" !== t.charAt(0)) return U(O.document.querySelector(t));
const i = e ? O.document.createElement("div") : W("svg");
return i.innerHTML = t, t = U(i.firstChild), i.removeChild(i.firstChild), t
}
function G(t, e) {
return e && (e instanceof O.window.Node || e.ownerDocument && e instanceof e.ownerDocument.defaultView.Node) ? e : W(t)
}
function V(t) {
if (!t) return null;
if (t.instance instanceof D) return t.instance;
if ("#document-fragment" === t.nodeName) return new _.Fragment(t);
let e = P(t.nodeName || "Dom");
return "LinearGradient" === e || "RadialGradient" === e ? e = "Gradient" : _[e] || (e = "Dom"), new _[e](t)
}
let U = V;
function q(t, e = t.name, i = !1) {
return _[e] = t, i && (_[N] = t), S(Object.getOwnPropertyNames(t.prototype)), t
}
let Z = 1e3;
function $(t) {
return "Svgjs" + P(t) + Z++
}
function J(t) {
for (let e = t.children.length - 1; e >= 0; e--) J(t.children[e]);
return t.id ? (t.id = $(t.nodeName), t) : t
}
function Q(t, e) {
let i, a;
for (a = (t = Array.isArray(t) ? t : [t]).length - 1; a >= 0; a--) for (i in e) t[a].prototype[i] = e[i]
}
function K(t) {
return function (...e) {
const i = e[e.length - 1];
return !i || i.constructor !== Object || i instanceof Array ? t.apply(this, e) : t.apply(this, e.slice(0, -1)).attr(i)
}
}
A("Dom", {
siblings: function () {
return this.parent().children()
}, position: function () {
return this.parent().index(this)
}, next: function () {
return this.siblings()[this.position() + 1]
}, prev: function () {
return this.siblings()[this.position() - 1]
}, forward: function () {
const t = this.position();
return this.parent().add(this.remove(), t + 1), this
}, backward: function () {
const t = this.position();
return this.parent().add(this.remove(), t ? t - 1 : 0), this
}, front: function () {
return this.parent().add(this.remove()), this
}, back: function () {
return this.parent().add(this.remove(), 0), this
}, before: function (t) {
(t = B(t)).remove();
const e = this.position();
return this.parent().add(t, e), this
}, after: function (t) {
(t = B(t)).remove();
const e = this.position();
return this.parent().add(t, e + 1), this
}, insertBefore: function (t) {
return (t = B(t)).before(this), this
}, insertAfter: function (t) {
return (t = B(t)).after(this), this
}
});
const tt = /^([+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?)([a-z%]*)$/i, et = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i,
it = /rgb\((\d+),(\d+),(\d+)\)/, at = /(#[a-z_][a-z0-9\-_]*)/i, st = /\)\s*,?\s*/, rt = /\s/g,
nt = /^#[a-f0-9]{3}$|^#[a-f0-9]{6}$/i, ot = /^rgb\(/, lt = /^(\s+)?$/,
ht = /^[+-]?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i, ct = /\.(jpg|jpeg|png|gif|svg)(\?[^=]+.*)?/i, dt = /[\s,]+/,
ut = /[MLHVCSQTAZ]/i;
function gt(t) {
const e = Math.round(t), i = Math.max(0, Math.min(255, e)).toString(16);
return 1 === i.length ? "0" + i : i
}
function pt(t, e) {
for (let i = e.length; i--;) if (null == t[e[i]]) return !1;
return !0
}
function ft(t, e, i) {
return i < 0 && (i += 1), i > 1 && (i -= 1), i < 1 / 6 ? t + 6 * (e - t) * i : i < .5 ? e : i < 2 / 3 ? t + (e - t) * (2 / 3 - i) * 6 : t
}
A("Dom", {
classes: function () {
const t = this.attr("class");
return null == t ? [] : t.trim().split(dt)
}, hasClass: function (t) {
return -1 !== this.classes().indexOf(t)
}, addClass: function (t) {
if (!this.hasClass(t)) {
const e = this.classes();
e.push(t), this.attr("class", e.join(" "))
}
return this
}, removeClass: function (t) {
return this.hasClass(t) && this.attr("class", this.classes().filter((function (e) {
return e !== t
})).join(" ")), this
}, toggleClass: function (t) {
return this.hasClass(t) ? this.removeClass(t) : this.addClass(t)
}
}), A("Dom", {
css: function (t, e) {
const i = {};
if (0 === arguments.length) return this.node.style.cssText.split(/\s*;\s*/).filter((function (t) {
return !!t.length
})).forEach((function (t) {
const e = t.split(/\s*:\s*/);
i[e[0]] = e[1]
})), i;
if (arguments.length < 2) {
if (Array.isArray(t)) {
for (const e of t) {
const t = e;
i[e] = this.node.style.getPropertyValue(t)
}
return i
}
if ("string" == typeof t) return this.node.style.getPropertyValue(t);
if ("object" == typeof t) for (const e in t) this.node.style.setProperty(e, null == t[e] || lt.test(t[e]) ? "" : t[e])
}
return 2 === arguments.length && this.node.style.setProperty(t, null == e || lt.test(e) ? "" : e), this
}, show: function () {
return this.css("display", "")
}, hide: function () {
return this.css("display", "none")
}, visible: function () {
return "none" !== this.css("display")
}
}), A("Dom", {
data: function (t, e, i) {
if (null == t) return this.data(L(function (t, e) {
let i;
const a = t.length, s = [];
for (i = 0; i < a; i++) e(t[i]) && s.push(t[i]);
return s
}(this.node.attributes, (t => 0 === t.nodeName.indexOf("data-"))), (t => t.nodeName.slice(5))));
if (t instanceof Array) {
const e = {};
for (const i of t) e[i] = this.data(i);
return e
}
if ("object" == typeof t) for (e in t) this.data(e, t[e]); else if (arguments.length < 2) try {
return JSON.parse(this.attr("data-" + t))
} catch (e) {
return this.attr("data-" + t)
} else this.attr("data-" + t, null === e ? null : !0 === i || "string" == typeof e || "number" == typeof e ? e : JSON.stringify(e));
return this
}
}), A("Dom", {
remember: function (t, e) {
if ("object" == typeof arguments[0]) for (const e in t) this.remember(e, t[e]); else {
if (1 === arguments.length) return this.memory()[t];
this.memory()[t] = e
}
return this
}, forget: function () {
if (0 === arguments.length) this._memory = {}; else for (let t = arguments.length - 1; t >= 0; t--) delete this.memory()[arguments[t]];
return this
}, memory: function () {
return this._memory = this._memory || {}
}
});
class xt {
constructor(...t) {
this.init(...t)
}
static isColor(t) {
return t && (t instanceof xt || this.isRgb(t) || this.test(t))
}
static isRgb(t) {
return t && "number" == typeof t.r && "number" == typeof t.g && "number" == typeof t.b
}
static random(t = "vibrant", e) {
const {random: i, round: a, sin: s, PI: r} = Math;
if ("vibrant" === t) {
const t = 24 * i() + 57, e = 38 * i() + 45, a = 360 * i();
return new xt(t, e, a, "lch")
}
if ("sine" === t) {
const t = a(80 * s(2 * r * (e = null == e ? i() : e) / .5 + .01) + 150),
n = a(50 * s(2 * r * e / .5 + 4.6) + 200), o = a(100 * s(2 * r * e / .5 + 2.3) + 150);
return new xt(t, n, o)
}
if ("pastel" === t) {
const t = 8 * i() + 86, e = 17 * i() + 9, a = 360 * i();
return new xt(t, e, a, "lch")
}
if ("dark" === t) {
const t = 10 + 10 * i(), e = 50 * i() + 86, a = 360 * i();
return new xt(t, e, a, "lch")
}
if ("rgb" === t) {
const t = 255 * i(), e = 255 * i(), a = 255 * i();
return new xt(t, e, a)
}
if ("lab" === t) {
const t = 100 * i(), e = 256 * i() - 128, a = 256 * i() - 128;
return new xt(t, e, a, "lab")
}
if ("grey" === t) {
const t = 255 * i();
return new xt(t, t, t)
}
throw new Error("Unsupported random color mode")
}
static test(t) {
return "string" == typeof t && (nt.test(t) || ot.test(t))
}
cmyk() {
const {_a: t, _b: e, _c: i} = this.rgb(), [a, s, r] = [t, e, i].map((t => t / 255)),
n = Math.min(1 - a, 1 - s, 1 - r);
if (1 === n) return new xt(0, 0, 0, 1, "cmyk");
return new xt((1 - a - n) / (1 - n), (1 - s - n) / (1 - n), (1 - r - n) / (1 - n), n, "cmyk")
}
hsl() {
const {_a: t, _b: e, _c: i} = this.rgb(), [a, s, r] = [t, e, i].map((t => t / 255)), n = Math.max(a, s, r),
o = Math.min(a, s, r), l = (n + o) / 2, h = n === o, c = n - o;
return new xt(360 * (h ? 0 : n === a ? ((s - r) / c + (s < r ? 6 : 0)) / 6 : n === s ? ((r - a) / c + 2) / 6 : n === r ? ((a - s) / c + 4) / 6 : 0), 100 * (h ? 0 : l > .5 ? c / (2 - n - o) : c / (n + o)), 100 * l, "hsl")
}
init(t = 0, e = 0, i = 0, a = 0, s = "rgb") {
if (t = t || 0, this.space) for (const t in this.space) delete this[this.space[t]];
if ("number" == typeof t) s = "string" == typeof a ? a : s, a = "string" == typeof a ? 0 : a, Object.assign(this, {
_a: t,
_b: e,
_c: i,
_d: a,
space: s
}); else if (t instanceof Array) this.space = e || ("string" == typeof t[3] ? t[3] : t[4]) || "rgb", Object.assign(this, {
_a: t[0],
_b: t[1],
_c: t[2],
_d: t[3] || 0
}); else if (t instanceof Object) {
const i = function (t, e) {
const i = pt(t, "rgb") ? {_a: t.r, _b: t.g, _c: t.b, _d: 0, space: "rgb"} : pt(t, "xyz") ? {
_a: t.x,
_b: t.y,
_c: t.z,
_d: 0,
space: "xyz"
} : pt(t, "hsl") ? {_a: t.h, _b: t.s, _c: t.l, _d: 0, space: "hsl"} : pt(t, "lab") ? {
_a: t.l,
_b: t.a,
_c: t.b,
_d: 0,
space: "lab"
} : pt(t, "lch") ? {_a: t.l, _b: t.c, _c: t.h, _d: 0, space: "lch"} : pt(t, "cmyk") ? {
_a: t.c,
_b: t.m,
_c: t.y,
_d: t.k,
space: "cmyk"
} : {_a: 0, _b: 0, _c: 0, space: "rgb"};
return i.space = e || i.space, i
}(t, e);
Object.assign(this, i)
} else if ("string" == typeof t) if (ot.test(t)) {
const e = t.replace(rt, ""), [i, a, s] = it.exec(e).slice(1, 4).map((t => parseInt(t)));
Object.assign(this, {_a: i, _b: a, _c: s, _d: 0, space: "rgb"})
} else {
if (!nt.test(t)) throw Error("Unsupported string format, can't construct Color");
{
const e = t => parseInt(t, 16), [, i, a, s] = et.exec(function (t) {
return 4 === t.length ? ["#", t.substring(1, 2), t.substring(1, 2), t.substring(2, 3), t.substring(2, 3), t.substring(3, 4), t.substring(3, 4)].join("") : t
}(t)).map(e);
Object.assign(this, {_a: i, _b: a, _c: s, _d: 0, space: "rgb"})
}
}
const {_a: r, _b: n, _c: o, _d: l} = this,
h = "rgb" === this.space ? {r: r, g: n, b: o} : "xyz" === this.space ? {
x: r,
y: n,
z: o
} : "hsl" === this.space ? {h: r, s: n, l: o} : "lab" === this.space ? {
l: r,
a: n,
b: o
} : "lch" === this.space ? {l: r, c: n, h: o} : "cmyk" === this.space ? {c: r, m: n, y: o, k: l} : {};
Object.assign(this, h)
}
lab() {
const {x: t, y: e, z: i} = this.xyz();
return new xt(116 * e - 16, 500 * (t - e), 200 * (e - i), "lab")
}
lch() {
const {l: t, a: e, b: i} = this.lab(), a = Math.sqrt(e ** 2 + i ** 2);
let s = 180 * Math.atan2(i, e) / Math.PI;
s < 0 && (s *= -1, s = 360 - s);
return new xt(t, a, s, "lch")
}
rgb() {
if ("rgb" === this.space) return this;
if ("lab" === (t = this.space) || "xyz" === t || "lch" === t) {
let {x: t, y: e, z: i} = this;
if ("lab" === this.space || "lch" === this.space) {
let {l: a, a: s, b: r} = this;
if ("lch" === this.space) {
const {c: t, h: e} = this, i = Math.PI / 180;
s = t * Math.cos(i * e), r = t * Math.sin(i * e)
}
const n = (a + 16) / 116, o = s / 500 + n, l = n - r / 200, h = 16 / 116, c = .008856, d = 7.787;
t = .95047 * (o ** 3 > c ? o ** 3 : (o - h) / d), e = 1 * (n ** 3 > c ? n ** 3 : (n - h) / d), i = 1.08883 * (l ** 3 > c ? l ** 3 : (l - h) / d)
}
const a = 3.2406 * t + -1.5372 * e + -.4986 * i, s = -.9689 * t + 1.8758 * e + .0415 * i,
r = .0557 * t + -.204 * e + 1.057 * i, n = Math.pow, o = .0031308,
l = a > o ? 1.055 * n(a, 1 / 2.4) - .055 : 12.92 * a,
h = s > o ? 1.055 * n(s, 1 / 2.4) - .055 : 12.92 * s,
c = r > o ? 1.055 * n(r, 1 / 2.4) - .055 : 12.92 * r;
return new xt(255 * l, 255 * h, 255 * c)
}
if ("hsl" === this.space) {
let {h: t, s: e, l: i} = this;
if (t /= 360, e /= 100, i /= 100, 0 === e) {
i *= 255;
return new xt(i, i, i)
}
const a = i < .5 ? i * (1 + e) : i + e - i * e, s = 2 * i - a, r = 255 * ft(s, a, t + 1 / 3),
n = 255 * ft(s, a, t), o = 255 * ft(s, a, t - 1 / 3);
return new xt(r, n, o)
}
if ("cmyk" === this.space) {
const {c: t, m: e, y: i, k: a} = this, s = 255 * (1 - Math.min(1, t * (1 - a) + a)),
r = 255 * (1 - Math.min(1, e * (1 - a) + a)), n = 255 * (1 - Math.min(1, i * (1 - a) + a));
return new xt(s, r, n)
}
return this;
var t
}
toArray() {
const {_a: t, _b: e, _c: i, _d: a, space: s} = this;
return [t, e, i, a, s]
}
toHex() {
const [t, e, i] = this._clamped().map(gt);
return `#${t}${e}${i}`
}
toRgb() {
const [t, e, i] = this._clamped();
return `rgb(${t},${e},${i})`
}
toString() {
return this.toHex()
}
xyz() {
const {_a: t, _b: e, _c: i} = this.rgb(), [a, s, r] = [t, e, i].map((t => t / 255)),
n = a > .04045 ? Math.pow((a + .055) / 1.055, 2.4) : a / 12.92,
o = s > .04045 ? Math.pow((s + .055) / 1.055, 2.4) : s / 12.92,
l = r > .04045 ? Math.pow((r + .055) / 1.055, 2.4) : r / 12.92,
h = (.4124 * n + .3576 * o + .1805 * l) / .95047, c = (.2126 * n + .7152 * o + .0722 * l) / 1,
d = (.0193 * n + .1192 * o + .9505 * l) / 1.08883,
u = h > .008856 ? Math.pow(h, 1 / 3) : 7.787 * h + 16 / 116,
g = c > .008856 ? Math.pow(c, 1 / 3) : 7.787 * c + 16 / 116,
p = d > .008856 ? Math.pow(d, 1 / 3) : 7.787 * d + 16 / 116;
return new xt(u, g, p, "xyz")
}
_clamped() {
const {_a: t, _b: e, _c: i} = this.rgb(), {max: a, min: s, round: r} = Math;
return [t, e, i].map((t => a(0, s(r(t), 255))))
}
}
class bt {
constructor(...t) {
this.init(...t)
}
clone() {
return new bt(this)
}
init(t, e) {
const i = 0, a = 0,
s = Array.isArray(t) ? {x: t[0], y: t[1]} : "object" == typeof t ? {x: t.x, y: t.y} : {x: t, y: e};
return this.x = null == s.x ? i : s.x, this.y = null == s.y ? a : s.y, this
}
toArray() {
return [this.x, this.y]
}
transform(t) {
return this.clone().transformO(t)
}
transformO(t) {
vt.isMatrixLike(t) || (t = new vt(t));
const {x: e, y: i} = this;
return this.x = t.a * e + t.c * i + t.e, this.y = t.b * e + t.d * i + t.f, this
}
}
function mt(t, e, i) {
return Math.abs(e - t) < (i || 1e-6)
}
class vt {
constructor(...t) {
this.init(...t)
}
static formatTransforms(t) {
const e = "both" === t.flip || !0 === t.flip, i = t.flip && (e || "x" === t.flip) ? -1 : 1,
a = t.flip && (e || "y" === t.flip) ? -1 : 1,
s = t.skew && t.skew.length ? t.skew[0] : isFinite(t.skew) ? t.skew : isFinite(t.skewX) ? t.skewX : 0,
r = t.skew && t.skew.length ? t.skew[1] : isFinite(t.skew) ? t.skew : isFinite(t.skewY) ? t.skewY : 0,
n = t.scale && t.scale.length ? t.scale[0] * i : isFinite(t.scale) ? t.scale * i : isFinite(t.scaleX) ? t.scaleX * i : i,
o = t.scale && t.scale.length ? t.scale[1] * a : isFinite(t.scale) ? t.scale * a : isFinite(t.scaleY) ? t.scaleY * a : a,
l = t.shear || 0, h = t.rotate || t.theta || 0,
c = new bt(t.origin || t.around || t.ox || t.originX, t.oy || t.originY), d = c.x, u = c.y,
g = new bt(t.position || t.px || t.positionX || NaN, t.py || t.positionY || NaN), p = g.x, f = g.y,
x = new bt(t.translate || t.tx || t.translateX, t.ty || t.translateY), b = x.x, m = x.y,
v = new bt(t.relative || t.rx || t.relativeX, t.ry || t.relativeY);
return {
scaleX: n,
scaleY: o,
skewX: s,
skewY: r,
shear: l,
theta: h,
rx: v.x,
ry: v.y,
tx: b,
ty: m,
ox: d,
oy: u,
px: p,
py: f
}
}
static fromArray(t) {
return {a: t[0], b: t[1], c: t[2], d: t[3], e: t[4], f: t[5]}
}
static isMatrixLike(t) {
return null != t.a || null != t.b || null != t.c || null != t.d || null != t.e || null != t.f
}
static matrixMultiply(t, e, i) {
const a = t.a * e.a + t.c * e.b, s = t.b * e.a + t.d * e.b, r = t.a * e.c + t.c * e.d,
n = t.b * e.c + t.d * e.d, o = t.e + t.a * e.e + t.c * e.f, l = t.f + t.b * e.e + t.d * e.f;
return i.a = a, i.b = s, i.c = r, i.d = n, i.e = o, i.f = l, i
}
around(t, e, i) {
return this.clone().aroundO(t, e, i)
}
aroundO(t, e, i) {
const a = t || 0, s = e || 0;
return this.translateO(-a, -s).lmultiplyO(i).translateO(a, s)
}
clone() {
return new vt(this)
}
decompose(t = 0, e = 0) {
const i = this.a, a = this.b, s = this.c, r = this.d, n = this.e, o = this.f, l = i * r - a * s,
h = l > 0 ? 1 : -1, c = h * Math.sqrt(i * i + a * a), d = Math.atan2(h * a, h * i),
u = 180 / Math.PI * d, g = Math.cos(d), p = Math.sin(d), f = (i * s + a * r) / l,
x = s * c / (f * i - a) || r * c / (f * a + i);
return {
scaleX: c,
scaleY: x,
shear: f,
rotate: u,
translateX: n - t + t * g * c + e * (f * g * c - p * x),
translateY: o - e + t * p * c + e * (f * p * c + g * x),
originX: t,
originY: e,
a: this.a,
b: this.b,
c: this.c,
d: this.d,
e: this.e,
f: this.f
}
}
equals(t) {
if (t === this) return !0;
const e = new vt(t);
return mt(this.a, e.a) && mt(this.b, e.b) && mt(this.c, e.c) && mt(this.d, e.d) && mt(this.e, e.e) && mt(this.f, e.f)
}
flip(t, e) {
return this.clone().flipO(t, e)
}
flipO(t, e) {
return "x" === t ? this.scaleO(-1, 1, e, 0) : "y" === t ? this.scaleO(1, -1, 0, e) : this.scaleO(-1, -1, t, e || t)
}
init(t) {
const e = vt.fromArray([1, 0, 0, 1, 0, 0]);
return t = t instanceof Gt ? t.matrixify() : "string" == typeof t ? vt.fromArray(t.split(dt).map(parseFloat)) : Array.isArray(t) ? vt.fromArray(t) : "object" == typeof t && vt.isMatrixLike(t) ? t : "object" == typeof t ? (new vt).transform(t) : 6 === arguments.length ? vt.fromArray([].slice.call(arguments)) : e, this.a = null != t.a ? t.a : e.a, this.b = null != t.b ? t.b : e.b, this.c = null != t.c ? t.c : e.c, this.d = null != t.d ? t.d : e.d, this.e = null != t.e ? t.e : e.e, this.f = null != t.f ? t.f : e.f, this
}
inverse() {
return this.clone().inverseO()
}
inverseO() {
const t = this.a, e = this.b, i = this.c, a = this.d, s = this.e, r = this.f, n = t * a - e * i;
if (!n) throw new Error("Cannot invert " + this);
const o = a / n, l = -e / n, h = -i / n, c = t / n, d = -(o * s + h * r), u = -(l * s + c * r);
return this.a = o, this.b = l, this.c = h, this.d = c, this.e = d, this.f = u, this
}
lmultiply(t) {
return this.clone().lmultiplyO(t)
}
lmultiplyO(t) {
const e = t instanceof vt ? t : new vt(t);
return vt.matrixMultiply(e, this, this)
}
multiply(t) {
return this.clone().multiplyO(t)
}
multiplyO(t) {
const e = t instanceof vt ? t : new vt(t);
return vt.matrixMultiply(this, e, this)
}
rotate(t, e, i) {
return this.clone().rotateO(t, e, i)
}
rotateO(t, e = 0, i = 0) {
t = M(t);
const a = Math.cos(t), s = Math.sin(t), {a: r, b: n, c: o, d: l, e: h, f: c} = this;
return this.a = r * a - n * s, this.b = n * a + r * s, this.c = o * a - l * s, this.d = l * a + o * s, this.e = h * a - c * s + i * s - e * a + e, this.f = c * a + h * s - e * s - i * a + i, this
}
scale() {
return this.clone().scaleO(...arguments)
}
scaleO(t, e = t, i = 0, a = 0) {
3 === arguments.length && (a = i, i = e, e = t);
const {a: s, b: r, c: n, d: o, e: l, f: h} = this;
return this.a = s * t, this.b = r * e, this.c = n * t, this.d = o * e, this.e = l * t - i * t + i, this.f = h * e - a * e + a, this
}
shear(t, e, i) {
return this.clone().shearO(t, e, i)
}
shearO(t, e = 0, i = 0) {
const {a: a, b: s, c: r, d: n, e: o, f: l} = this;
return this.a = a + s * t, this.c = r + n * t, this.e = o + l * t - i * t, this
}
skew() {
return this.clone().skewO(...arguments)
}
skewO(t, e = t, i = 0, a = 0) {
3 === arguments.length && (a = i, i = e, e = t), t = M(t), e = M(e);
const s = Math.tan(t), r = Math.tan(e), {a: n, b: o, c: l, d: h, e: c, f: d} = this;
return this.a = n + o * s, this.b = o + n * r, this.c = l + h * s, this.d = h + l * r, this.e = c + d * s - a * s, this.f = d + c * r - i * r, this
}
skewX(t, e, i) {
return this.skew(t, 0, e, i)
}
skewY(t, e, i) {
return this.skew(0, t, e, i)
}
toArray() {
return [this.a, this.b, this.c, this.d, this.e, this.f]
}
toString() {
return "matrix(" + this.a + "," + this.b + "," + this.c + "," + this.d + "," + this.e + "," + this.f + ")"
}
transform(t) {
if (vt.isMatrixLike(t)) {
return new vt(t).multiplyO(this)
}
const e = vt.formatTransforms(t), {x: i, y: a} = new bt(e.ox, e.oy).transform(this),
s = (new vt).translateO(e.rx, e.ry).lmultiplyO(this).translateO(-i, -a).scaleO(e.scaleX, e.scaleY).skewO(e.skewX, e.skewY).shearO(e.shear).rotateO(e.theta).translateO(i, a);
if (isFinite(e.px) || isFinite(e.py)) {
const t = new bt(i, a).transform(s), r = isFinite(e.px) ? e.px - t.x : 0,
n = isFinite(e.py) ? e.py - t.y : 0;
s.translateO(r, n)
}
return s.translateO(e.tx, e.ty), s
}
translate(t, e) {
return this.clone().translateO(t, e)
}
translateO(t, e) {
return this.e += t || 0, this.f += e || 0, this
}
valueOf() {
return {a: this.a, b: this.b, c: this.c, d: this.d, e: this.e, f: this.f}
}
}
function yt() {
if (!yt.nodes) {
const t = B().size(2, 0);
t.node.style.cssText = ["opacity: 0", "position: absolute", "left: -100%", "top: -100%", "overflow: hidden"].join(";"), t.attr("focusable", "false"), t.attr("aria-hidden", "true");
const e = t.path().node;
yt.nodes = {svg: t, path: e}
}
if (!yt.nodes.svg.node.parentNode) {
const t = O.document.body || O.document.documentElement;
yt.nodes.svg.addTo(t)
}
return yt.nodes
}
function wt(t) {
return !(t.width || t.height || t.x || t.y)
}
q(vt, "Matrix");
class kt {
constructor(...t) {
this.init(...t)
}
addOffset() {
return this.x += O.window.pageXOffset, this.y += O.window.pageYOffset, new kt(this)
}
init(t) {
return t = "string" == typeof t ? t.split(dt).map(parseFloat) : Array.isArray(t) ? t : "object" == typeof t ? [null != t.left ? t.left : t.x, null != t.top ? t.top : t.y, t.width, t.height] : 4 === arguments.length ? [].slice.call(arguments) : [0, 0, 0, 0], this.x = t[0] || 0, this.y = t[1] || 0, this.width = this.w = t[2] || 0, this.height = this.h = t[3] || 0, this.x2 = this.x + this.w, this.y2 = this.y + this.h, this.cx = this.x + this.w / 2, this.cy = this.y + this.h / 2, this
}
isNulled() {
return wt(this)
}
merge(t) {
const e = Math.min(this.x, t.x), i = Math.min(this.y, t.y),
a = Math.max(this.x + this.width, t.x + t.width) - e,
s = Math.max(this.y + this.height, t.y + t.height) - i;
return new kt(e, i, a, s)
}
toArray() {
return [this.x, this.y, this.width, this.height]
}
toString() {
return this.x + " " + this.y + " " + this.width + " " + this.height
}
transform(t) {
t instanceof vt || (t = new vt(t));
let e = 1 / 0, i = -1 / 0, a = 1 / 0, s = -1 / 0;
return [new bt(this.x, this.y), new bt(this.x2, this.y), new bt(this.x, this.y2), new bt(this.x2, this.y2)].forEach((function (r) {
r = r.transform(t), e = Math.min(e, r.x), i = Math.max(i, r.x), a = Math.min(a, r.y), s = Math.max(s, r.y)
})), new kt(e, a, i - e, s - a)
}
}
function At(t, e, i) {
let a;
try {
if (a = e(t.node), wt(a) && ((s = t.node) !== O.document && !(O.document.documentElement.contains || function (t) {
for (; t.parentNode;) t = t.parentNode;
return t === O.document
}).call(O.document.documentElement, s))) throw new Error("Element not in the dom")
} catch (e) {
a = i(t)
}
var s;
return a
}
A({
viewbox: {
viewbox(t, e, i, a) {
return null == t ? new kt(this.attr("viewBox")) : this.attr("viewBox", new kt(t, e, i, a))
}, zoom(t, e) {
let {width: i, height: a} = this.attr(["width", "height"]);
if ((i || a) && "string" != typeof i && "string" != typeof a || (i = this.node.clientWidth, a = this.node.clientHeight), !i || !a) throw new Error("Impossible to get absolute width and height. Please provide an absolute width and height attribute on the zooming element");
const s = this.viewbox(), r = i / s.width, n = a / s.height, o = Math.min(r, n);
if (null == t) return o;
let l = o / t;
l === 1 / 0 && (l = Number.MAX_SAFE_INTEGER / 100), e = e || new bt(i / 2 / r + s.x, a / 2 / n + s.y);
const h = new kt(s).transform(new vt({scale: l, origin: e}));
return this.viewbox(h)
}
}
}), q(kt, "Box");
class Ct extends Array {
constructor(t = [], ...e) {
if (super(t, ...e), "number" == typeof t) return this;
this.length = 0, this.push(...t)
}
}
Q([Ct], {
each(t, ...e) {
return "function" == typeof t ? this.map(((e, i, a) => t.call(e, e, i, a))) : this.map((i => i[t](...e)))
}, toArray() {
return Array.prototype.concat.apply([], this)
}
});
const St = ["toArray", "constructor", "each"];
function Lt(t, e) {
return new Ct(L((e || O.document).querySelectorAll(t), (function (t) {
return V(t)
})))
}
Ct.extend = function (t) {
t = t.reduce(((t, e) => (St.includes(e) || "_" === e[0] || (e in Array.prototype && (t["$" + e] = Array.prototype[e]), t[e] = function (...t) {
return this.each(e, ...t)
}), t)), {}), Q([Ct], t)
};
let Mt = 0;
const Pt = {};
function It(t) {
let e = t.getEventHolder();
return e === O.window && (e = Pt), e.events || (e.events = {}), e.events
}
function Tt(t) {
return t.getEventTarget()
}
function zt(t, e, i, a, s) {
const r = i.bind(a || t), n = B(t), o = It(n), l = Tt(n);
e = Array.isArray(e) ? e : e.split(dt), i._svgjsListenerId || (i._svgjsListenerId = ++Mt), e.forEach((function (t) {
const e = t.split(".")[0], a = t.split(".")[1] || "*";
o[e] = o[e] || {}, o[e][a] = o[e][a] || {}, o[e][a][i._svgjsListenerId] = r, l.addEventListener(e, r, s || !1)
}))
}
function Xt(t, e, i, a) {
const s = B(t), r = It(s), n = Tt(s);
("function" != typeof i || (i = i._svgjsListenerId)) && (e = Array.isArray(e) ? e : (e || "").split(dt)).forEach((function (t) {
const e = t && t.split(".")[0], o = t && t.split(".")[1];
let l, h;
if (i) r[e] && r[e][o || "*"] && (n.removeEventListener(e, r[e][o || "*"][i], a || !1), delete r[e][o || "*"][i]); else if (e && o) {
if (r[e] && r[e][o]) {
for (h in r[e][o]) Xt(n, [e, o].join("."), h);
delete r[e][o]
}
} else if (o) for (t in r) for (l in r[t]) o === l && Xt(n, [t, o].join(".")); else if (e) {
if (r[e]) {
for (l in r[e]) Xt(n, [e, l].join("."));
delete r[e]
}
} else {
for (t in r) Xt(n, t);
!function (t) {
let e = t.getEventHolder();
e === O.window && (e = Pt), e.events && (e.events = {})
}(s)
}
}))
}
class Rt extends D {
addEventListener() {
}
dispatch(t, e, i) {
return function (t, e, i, a) {
const s = Tt(t);
return e instanceof O.window.Event || (e = new O.window.CustomEvent(e, {
detail: i,
cancelable: !0, ...a
})), s.dispatchEvent(e), e
}(this, t, e, i)
}
dispatchEvent(t) {
const e = this.getEventHolder().events;
if (!e) return !0;
const i = e[t.type];
for (const e in i) for (const a in i[e]) i[e][a](t);
return !t.defaultPrevented
}
fire(t, e, i) {
return this.dispatch(t, e, i), this
}
getEventHolder() {
return this
}
getEventTarget() {
return this
}
off(t, e, i) {
return Xt(this, t, e, i), this
}
on(t, e, i, a) {
return zt(this, t, e, i, a), this
}
removeEventListener() {
}
}
function Et() {
}
q(Rt, "EventTarget");
const Yt = 400, Ht = ">", Ot = 0, Ft = {
"fill-opacity": 1,
"stroke-opacity": 1,
"stroke-width": 0,
"stroke-linejoin": "miter",
"stroke-linecap": "butt",
fill: "#000000",
stroke: "#000000",
opacity: 1,
x: 0,
y: 0,
cx: 0,
cy: 0,
width: 0,
height: 0,
r: 0,
rx: 0,
ry: 0,
offset: 0,
"stop-opacity": 1,
"stop-color": "#000000",
"text-anchor": "start"
};
class Dt extends Array {
constructor(...t) {
super(...t), this.init(...t)
}
clone() {
return new this.constructor(this)
}
init(t) {
return "number" == typeof t || (this.length = 0, this.push(...this.parse(t))), this
}
parse(t = []) {
return t instanceof Array ? t : t.trim().split(dt).map(parseFloat)
}
toArray() {
return Array.prototype.concat.apply([], this)
}
toSet() {
return new Set(this)
}
toString() {
return this.join(" ")
}
valueOf() {
const t = [];
return t.push(...this), t
}
}
class _t {
constructor(...t) {
this.init(...t)
}
convert(t) {
return new _t(this.value, t)
}
divide(t) {
return t = new _t(t), new _t(this / t, this.unit || t.unit)
}
init(t, e) {
return e = Array.isArray(t) ? t[1] : e, t = Array.isArray(t) ? t[0] : t, this.value = 0, this.unit = e || "", "number" == typeof t ? this.value = isNaN(t) ? 0 : isFinite(t) ? t : t < 0 ? -34e37 : 34e37 : "string" == typeof t ? (e = t.match(tt)) && (this.value = parseFloat(e[1]), "%" === e[5] ? this.value /= 100 : "s" === e[5] && (this.value *= 1e3), this.unit = e[5]) : t instanceof _t && (this.value = t.valueOf(), this.unit = t.unit), this
}
minus(t) {
return t = new _t(t), new _t(this - t, this.unit || t.unit)
}
plus(t) {
return t = new _t(t), new _t(this + t, this.unit || t.unit)
}
times(t) {
return t = new _t(t), new _t(this * t, this.unit || t.unit)
}
toArray() {
return [this.value, this.unit]
}
toJSON() {
return this.toString()
}
toString() {
return ("%" === this.unit ? ~~(1e8 * this.value) / 1e6 : "s" === this.unit ? this.value / 1e3 : this.value) + this.unit
}
valueOf() {
return this.value
}
}
const Nt = new Set(["fill", "stroke", "color", "bgcolor", "stop-color", "flood-color", "lighting-color"]), Wt = [];
class Bt extends Rt {
constructor(t, e) {
super(), this.node = t, this.type = t.nodeName, e && t !== e && this.attr(e)
}
add(t, e) {
return (t = B(t)).removeNamespace && this.node instanceof O.window.SVGElement && t.removeNamespace(), null == e ? this.node.appendChild(t.node) : t.node !== this.node.childNodes[e] && this.node.insertBefore(t.node, this.node.childNodes[e]), this
}
addTo(t, e) {
return B(t).put(this, e)
}
children() {
return new Ct(L(this.node.children, (function (t) {
return V(t)
})))
}
clear() {
for (; this.node.hasChildNodes();) this.node.removeChild(this.node.lastChild);
return this
}
clone(t = !0, e = !0) {
this.writeDataToDom();
let i = this.node.cloneNode(t);
return e && (i = J(i)), new this.constructor(i)
}
each(t, e) {
const i = this.children();
let a, s;
for (a = 0, s = i.length; a < s; a++) t.apply(i[a], [a, i]), e && i[a].each(t, e);
return this
}
element(t, e) {
return this.put(new Bt(W(t), e))
}
first() {
return V(this.node.firstChild)
}
get(t) {
return V(this.node.childNodes[t])
}
getEventHolder() {
return this.node
}
getEventTarget() {
return this.node
}
has(t) {
return this.index(t) >= 0
}
html(t, e) {
return this.xml(t, e, "http://www.w3.org/1999/xhtml")
}
id(t) {
return void 0 !== t || this.node.id || (this.node.id = $(this.type)), this.attr("id", t)
}
index(t) {
return [].slice.call(this.node.childNodes).indexOf(t.node)
}
last() {
return V(this.node.lastChild)
}
matches(t) {
const e = this.node,
i = e.matches || e.matchesSelector || e.msMatchesSelector || e.mozMatchesSelector || e.webkitMatchesSelector || e.oMatchesSelector || null;
return i && i.call(e, t)
}
parent(t) {
let e = this;
if (!e.node.parentNode) return null;
if (e = V(e.node.parentNode), !t) return e;
do {
if ("string" == typeof t ? e.matches(t) : e instanceof t) return e
} while (e = V(e.node.parentNode));
return e
}
put(t, e) {
return t = B(t), this.add(t, e), t
}
putIn(t, e) {
return B(t).add(this, e)
}
remove() {
return this.parent() && this.parent().removeElement(this), this
}
removeElement(t) {
return this.node.removeChild(t.node), this
}
replace(t) {
return t = B(t), this.node.parentNode && this.node.parentNode.replaceChild(t.node, this.node), t
}
round(t = 2, e = null) {
const i = 10 ** t, a = this.attr(e);
for (const t in a) "number" == typeof a[t] && (a[t] = Math.round(a[t] * i) / i);
return this.attr(a), this
}
svg(t, e) {
return this.xml(t, e, E)
}
toString() {
return this.id()
}
words(t) {
return this.node.textContent = t, this
}
wrap(t) {
const e = this.parent();
if (!e) return this.addTo(t);
const i = e.index(this);
return e.put(t, i).put(this)
}
writeDataToDom() {
return this.each((function () {
this.writeDataToDom()
})), this
}
xml(t, e, i) {
if ("boolean" == typeof t && (i = e, e = t, t = null), null == t || "function" == typeof t) {
e = null == e || e, this.writeDataToDom();
let i = this;
if (null != t) {
if (i = V(i.node.cloneNode(!0)), e) {
const e = t(i);
if (i = e || i, !1 === e) return ""
}
i.each((function () {
const e = t(this), i = e || this;
!1 === e ? this.remove() : e && this !== i && this.replace(i)
}), !0)
}
return e ? i.node.outerHTML : i.node.innerHTML
}
e = null != e && e;
const a = W("wrapper", i), s = O.document.createDocumentFragment();
a.innerHTML = t;
for (let t = a.children.length; t--;) s.appendChild(a.firstElementChild);
const r = this.parent();
return e ? this.replace(s) && r : this.add(s)
}
}
Q(Bt, {
attr: function (t, e, i) {
if (null == t) {
t = {}, e = this.node.attributes;
for (const i of e) t[i.nodeName] = ht.test(i.nodeValue) ? parseFloat(i.nodeValue) : i.nodeValue;
return t
}
if (t instanceof Array) return t.reduce(((t, e) => (t[e] = this.attr(e), t)), {});
if ("object" == typeof t && t.constructor === Object) for (e in t) this.attr(e, t[e]); else if (null === e) this.node.removeAttribute(t); else {
if (null == e) return null == (e = this.node.getAttribute(t)) ? Ft[t] : ht.test(e) ? parseFloat(e) : e;
"number" == typeof (e = Wt.reduce(((e, i) => i(t, e, this)), e)) ? e = new _t(e) : Nt.has(t) && xt.isColor(e) ? e = new xt(e) : e.constructor === Array && (e = new Dt(e)), "leading" === t ? this.leading && this.leading(e) : "string" == typeof i ? this.node.setAttributeNS(i, t, e.toString()) : this.node.setAttribute(t, e.toString()), !this.rebuild || "font-size" !== t && "x" !== t || this.rebuild()
}
return this
}, find: function (t) {
return Lt(t, this.node)
}, findOne: function (t) {
return V(this.node.querySelector(t))
}
}), q(Bt, "Dom");
let Gt = class extends Bt {
constructor(t, e) {
super(t, e), this.dom = {}, this.node.instance = this, (t.hasAttribute("data-svgjs") || t.hasAttribute("svgjs:data")) && this.setData(JSON.parse(t.getAttribute("data-svgjs")) ?? JSON.parse(t.getAttribute("svgjs:data")) ?? {})
}
center(t, e) {
return this.cx(t).cy(e)
}
cx(t) {
return null == t ? this.x() + this.width() / 2 : this.x(t - this.width() / 2)
}
cy(t) {
return null == t ? this.y() + this.height() / 2 : this.y(t - this.height() / 2)
}
defs() {
const t = this.root();
return t && t.defs()
}
dmove(t, e) {
return this.dx(t).dy(e)
}
dx(t = 0) {
return this.x(new _t(t).plus(this.x()))
}
dy(t = 0) {
return this.y(new _t(t).plus(this.y()))
}
getEventHolder() {
return this
}
height(t) {
return this.attr("height", t)
}
move(t, e) {
return this.x(t).y(e)
}
parents(t = this.root()) {
const e = "string" == typeof t;
e || (t = B(t));
const i = new Ct;
let a = this;
for (; (a = a.parent()) && a.node !== O.document && "#document-fragment" !== a.nodeName && (i.push(a), e || a.node !== t.node) && (!e || !a.matches(t));) if (a.node === this.root().node) return null;
return i
}
reference(t) {
if (!(t = this.attr(t))) return null;
const e = (t + "").match(at);
return e ? B(e[1]) : null
}
root() {
const t = this.parent(function (t) {
return _[t]
}(N));
return t && t.root()
}
setData(t) {
return this.dom = t, this
}
size(t, e) {
const i = I(this, t, e);
return this.width(new _t(i.width)).height(new _t(i.height))
}
width(t) {
return this.attr("width", t)
}
writeDataToDom() {
return R(this, this.dom), super.writeDataToDom()
}
x(t) {
return this.attr("x", t)
}
y(t) {
return this.attr("y", t)
}
};
Q(Gt, {
bbox: function () {
const t = At(this, (t => t.getBBox()), (t => {
try {
const e = t.clone().addTo(yt().svg).show(), i = e.node.getBBox();
return e.remove(), i
} catch (e) {
throw new Error(`Getting bbox of element "${t.node.nodeName}" is not possible: ${e.toString()}`)
}
}));
return new kt(t)
}, rbox: function (t) {
const e = At(this, (t => t.getBoundingClientRect()), (t => {
throw new Error(`Getting rbox of element "${t.node.nodeName}" is not possible`)
})), i = new kt(e);
return t ? i.transform(t.screenCTM().inverseO()) : i.addOffset()
}, inside: function (t, e) {
const i = this.bbox();
return t > i.x && e > i.y && t < i.x + i.width && e < i.y + i.height
}, point: function (t, e) {
return new bt(t, e).transformO(this.screenCTM().inverseO())
}, ctm: function () {
return new vt(this.node.getCTM())
}, screenCTM: function () {
try {
if ("function" == typeof this.isRoot && !this.isRoot()) {
const t = this.rect(1, 1), e = t.node.getScreenCTM();
return t.remove(), new vt(e)
}
return new vt(this.node.getScreenCTM())
} catch (t) {
return console.warn(`Cannot get CTM from SVG node ${this.node.nodeName}. Is the element rendered?`), new vt
}
}
}), q(Gt, "Element");
const jt = {
stroke: ["color", "width", "opacity", "linecap", "linejoin", "miterlimit", "dasharray", "dashoffset"],
fill: ["color", "opacity", "rule"],
prefix: function (t, e) {
return "color" === e ? t : t + "-" + e
}
};
["fill", "stroke"].forEach((function (t) {
const e = {};
let i;
e[t] = function (e) {
if (void 0 === e) return this.attr(t);
if ("string" == typeof e || e instanceof xt || xt.isRgb(e) || e instanceof Gt) this.attr(t, e); else for (i = jt[t].length - 1; i >= 0; i--) null != e[jt[t][i]] && this.attr(jt.prefix(t, jt[t][i]), e[jt[t][i]]);
return this
}, A(["Element", "Runner"], e)
})), A(["Element", "Runner"], {
matrix: function (t, e, i, a, s, r) {
return null == t ? new vt(this) : this.attr("transform", new vt(t, e, i, a, s, r))
}, rotate: function (t, e, i) {
return this.transform({rotate: t, ox: e, oy: i}, !0)
}, skew: function (t, e, i, a) {
return 1 === arguments.length || 3 === arguments.length ? this.transform({
skew: t,
ox: e,
oy: i
}, !0) : this.transform({skew: [t, e], ox: i, oy: a}, !0)
}, shear: function (t, e, i) {
return this.transform({shear: t, ox: e, oy: i}, !0)
}, scale: function (t, e, i, a) {
return 1 === arguments.length || 3 === arguments.length ? this.transform({
scale: t,
ox: e,
oy: i
}, !0) : this.transform({scale: [t, e], ox: i, oy: a}, !0)
}, translate: function (t, e) {
return this.transform({translate: [t, e]}, !0)
}, relative: function (t, e) {
return this.transform({relative: [t, e]}, !0)
}, flip: function (t = "both", e = "center") {
return -1 === "xybothtrue".indexOf(t) && (e = t, t = "both"), this.transform({flip: t, origin: e}, !0)
}, opacity: function (t) {
return this.attr("opacity", t)
}
}), A("radius", {
radius: function (t, e = t) {
return "radialGradient" === (this._element || this).type ? this.attr("r", new _t(t)) : this.rx(t).ry(e)
}
}), A("Path", {
length: function () {
return this.node.getTotalLength()
}, pointAt: function (t) {
return new bt(this.node.getPointAtLength(t))
}
}), A(["Element", "Runner"], {
font: function (t, e) {
if ("object" == typeof t) {
for (e in t) this.font(e, t[e]);
return this
}
return "leading" === t ? this.leading(e) : "anchor" === t ? this.attr("text-anchor", e) : "size" === t || "family" === t || "weight" === t || "stretch" === t || "variant" === t || "style" === t ? this.attr("font-" + t, e) : this.attr(t, e)
}
});
A("Element", ["click", "dblclick", "mousedown", "mouseup", "mouseover", "mouseout", "mousemove", "mouseenter", "mouseleave", "touchstart", "touchmove", "touchleave", "touchend", "touchcancel", "contextmenu", "wheel", "pointerdown", "pointermove", "pointerup", "pointerleave", "pointercancel"].reduce((function (t, e) {
return t[e] = function (t) {
return null === t ? this.off(e) : this.on(e, t), this
}, t
}), {})), A("Element", {
untransform: function () {
return this.attr("transform", null)
}, matrixify: function () {
const t = (this.attr("transform") || "").split(st).slice(0, -1).map((function (t) {
const e = t.trim().split("(");
return [e[0], e[1].split(dt).map((function (t) {
return parseFloat(t)
}))]
})).reverse().reduce((function (t, e) {
return "matrix" === e[0] ? t.lmultiply(vt.fromArray(e[1])) : t[e[0]].apply(t, e[1])
}), new vt);
return t
}, toParent: function (t, e) {
if (this === t) return this;
if (X(this.node)) return this.addTo(t, e);
const i = this.screenCTM(), a = t.screenCTM().inverse();
return this.addTo(t, e).untransform().transform(a.multiply(i)), this
}, toRoot: function (t) {
return this.toParent(this.root(), t)
}, transform: function (t, e) {
if (null == t || "string" == typeof t) {
const e = new vt(this).decompose();
return null == t ? e : e[t]
}
vt.isMatrixLike(t) || (t = {...t, origin: T(t, this)});
const i = new vt(!0 === e ? this : e || !1).transform(t);
return this.attr("transform", i)
}
});
class Vt extends Gt {
flatten() {
return this.each((function () {
if (this instanceof Vt) return this.flatten().ungroup()
})), this
}
ungroup(t = this.parent(), e = t.index(this)) {
return e = -1 === e ? t.children().length : e, this.each((function (i, a) {
return a[a.length - i - 1].toParent(t, e)
})), this.remove()
}
}
q(Vt, "Container");
class Ut extends Vt {
constructor(t, e = t) {
super(G("defs", t), e)
}
flatten() {
return this
}
ungroup() {
return this
}
}
q(Ut, "Defs");
class qt extends Gt {
}
function Zt(t) {
return this.attr("rx", t)
}
function $t(t) {
return this.attr("ry", t)
}
function Jt(t) {
return null == t ? this.cx() - this.rx() : this.cx(t + this.rx())
}
function Qt(t) {
return null == t ? this.cy() - this.ry() : this.cy(t + this.ry())
}
function Kt(t) {
return this.attr("cx", t)
}
function te(t) {
return this.attr("cy", t)
}
function ee(t) {
return null == t ? 2 * this.rx() : this.rx(new _t(t).divide(2))
}
function ie(t) {
return null == t ? 2 * this.ry() : this.ry(new _t(t).divide(2))
}
q(qt, "Shape");
var ae = Object.freeze({__proto__: null, cx: Kt, cy: te, height: ie, rx: Zt, ry: $t, width: ee, x: Jt, y: Qt});
class se extends qt {
constructor(t, e = t) {
super(G("ellipse", t), e)
}
size(t, e) {
const i = I(this, t, e);
return this.rx(new _t(i.width).divide(2)).ry(new _t(i.height).divide(2))
}
}
Q(se, ae), A("Container", {
ellipse: K((function (t = 0, e = t) {
return this.put(new se).size(t, e).move(0, 0)
}))
}), q(se, "Ellipse");
class re extends Bt {
constructor(t = O.document.createDocumentFragment()) {
super(t)
}
xml(t, e, i) {
if ("boolean" == typeof t && (i = e, e = t, t = null), null == t || "function" == typeof t) {
const t = new Bt(W("wrapper", i));
return t.add(this.node.cloneNode(!0)), t.xml(!1, i)
}
return super.xml(t, !1, i)
}
}
function ne(t, e) {
return "radialGradient" === (this._element || this).type ? this.attr({
fx: new _t(t),
fy: new _t(e)
}) : this.attr({x1: new _t(t), y1: new _t(e)})
}
function oe(t, e) {
return "radialGradient" === (this._element || this).type ? this.attr({
cx: new _t(t),
cy: new _t(e)
}) : this.attr({x2: new _t(t), y2: new _t(e)})
}
q(re, "Fragment");
var le = Object.freeze({__proto__: null, from: ne, to: oe});
class he extends Vt {
constructor(t, e) {
super(G(t + "Gradient", "string" == typeof t ? null : t), e)
}
attr(t, e, i) {
return "transform" === t && (t = "gradientTransform"), super.attr(t, e, i)
}
bbox() {
return new kt
}
targets() {
return Lt("svg [fill*=" + this.id() + "]")
}
toString() {
return this.url()
}
update(t) {
return this.clear(), "function" == typeof t && t.call(this, this), this
}
url() {
return "url(#" + this.id() + ")"
}
}
Q(he, le), A({
Container: {
gradient(...t) {
return this.defs().gradient(...t)
}
}, Defs: {
gradient: K((function (t, e) {
return this.put(new he(t)).update(e)
}))
}
}), q(he, "Gradient");
class ce extends Vt {
constructor(t, e = t) {
super(G("pattern", t), e)
}
attr(t, e, i) {
return "transform" === t && (t = "patternTransform"), super.attr(t, e, i)
}
bbox() {
return new kt
}
targets() {
return Lt("svg [fill*=" + this.id() + "]")
}
toString() {
return this.url()
}
update(t) {
return this.clear(), "function" == typeof t && t.call(this, this), this
}
url() {
return "url(#" + this.id() + ")"
}
}
A({
Container: {
pattern(...t) {
return this.defs().pattern(...t)
}
}, Defs: {
pattern: K((function (t, e, i) {
return this.put(new ce).update(i).attr({
x: 0,
y: 0,
width: t,
height: e,
patternUnits: "userSpaceOnUse"
})
}))
}
}), q(ce, "Pattern");
let de = class extends qt {
constructor(t, e = t) {
super(G("image", t), e)
}
load(t, e) {
if (!t) return this;
const i = new O.window.Image;
return zt(i, "load", (function (t) {
const a = this.parent(ce);
0 === this.width() && 0 === this.height() && this.size(i.width, i.height), a instanceof ce && 0 === a.width() && 0 === a.height() && a.size(this.width(), this.height()), "function" == typeof e && e.call(this, t)
}), this), zt(i, "load error", (function () {
Xt(i)
})), this.attr("href", i.src = t, H)
}
};
var ue;
ue = function (t, e, i) {
return "fill" !== t && "stroke" !== t || ct.test(e) && (e = i.root().defs().image(e)), e instanceof de && (e = i.root().defs().pattern(0, 0, (t => {
t.add(e)
}))), e
}, Wt.push(ue), A({
Container: {
image: K((function (t, e) {
return this.put(new de).size(0, 0).load(t, e)
}))
}
}), q(de, "Image");
class ge extends Dt {
bbox() {
let t = -1 / 0, e = -1 / 0, i = 1 / 0, a = 1 / 0;
return this.forEach((function (s) {
t = Math.max(s[0], t), e = Math.max(s[1], e), i = Math.min(s[0], i), a = Math.min(s[1], a)
})), new kt(i, a, t - i, e - a)
}
move(t, e) {
const i = this.bbox();
if (t -= i.x, e -= i.y, !isNaN(t) && !isNaN(e)) for (let i = this.length - 1; i >= 0; i--) this[i] = [this[i][0] + t, this[i][1] + e];
return this
}
parse(t = [0, 0]) {
const e = [];
(t = t instanceof Array ? Array.prototype.concat.apply([], t) : t.trim().split(dt).map(parseFloat)).length % 2 != 0 && t.pop();
for (let i = 0, a = t.length; i < a; i += 2) e.push([t[i], t[i + 1]]);
return e
}
size(t, e) {
let i;
const a = this.bbox();
for (i = this.length - 1; i >= 0; i--) a.width && (this[i][0] = (this[i][0] - a.x) * t / a.width + a.x), a.height && (this[i][1] = (this[i][1] - a.y) * e / a.height + a.y);
return this
}
toLine() {
return {x1: this[0][0], y1: this[0][1], x2: this[1][0], y2: this[1][1]}
}
toString() {
const t = [];
for (let e = 0, i = this.length; e < i; e++) t.push(this[e].join(","));
return t.join(" ")
}
transform(t) {
return this.clone().transformO(t)
}
transformO(t) {
vt.isMatrixLike(t) || (t = new vt(t));
for (let e = this.length; e--;) {
const [i, a] = this[e];
this[e][0] = t.a * i + t.c * a + t.e, this[e][1] = t.b * i + t.d * a + t.f
}
return this
}
}
const pe = ge;
var fe = Object.freeze({
__proto__: null, MorphArray: pe, height: function (t) {
const e = this.bbox();
return null == t ? e.height : this.size(e.width, t)
}, width: function (t) {
const e = this.bbox();
return null == t ? e.width : this.size(t, e.height)
}, x: function (t) {
return null == t ? this.bbox().x : this.move(t, this.bbox().y)
}, y: function (t) {
return null == t ? this.bbox().y : this.move(this.bbox().x, t)
}
});
let xe = class extends qt {
constructor(t, e = t) {
super(G("line", t), e)
}
array() {
return new ge([[this.attr("x1"), this.attr("y1")], [this.attr("x2"), this.attr("y2")]])
}
move(t, e) {
return this.attr(this.array().move(t, e).toLine())
}
plot(t, e, i, a) {
return null == t ? this.array() : (t = void 0 !== e ? {
x1: t,
y1: e,
x2: i,
y2: a
} : new ge(t).toLine(), this.attr(t))
}
size(t, e) {
const i = I(this, t, e);
return this.attr(this.array().size(i.width, i.height).toLine())
}
};
Q(xe, fe), A({
Container: {
line: K((function (...t) {
return xe.prototype.plot.apply(this.put(new xe), null != t[0] ? t : [0, 0, 0, 0])
}))
}
}), q(xe, "Line");
let be = class extends Vt {
constructor(t, e = t) {
super(G("marker", t), e)
}
height(t) {
return this.attr("markerHeight", t)
}
orient(t) {
return this.attr("orient", t)
}
ref(t, e) {
return this.attr("refX", t).attr("refY", e)
}
toString() {
return "url(#" + this.id() + ")"
}
update(t) {
return this.clear(), "function" == typeof t && t.call(this, this), this
}
width(t) {
return this.attr("markerWidth", t)
}
};
function me(t, e) {
return function (i) {
return null == i ? this[t] : (this[t] = i, e && e.call(this), this)
}
}
A({
Container: {
marker(...t) {
return this.defs().marker(...t)
}
}, Defs: {
marker: K((function (t, e, i) {
return this.put(new be).size(t, e).ref(t / 2, e / 2).viewbox(0, 0, t, e).attr("orient", "auto").update(i)
}))
}, marker: {
marker(t, e, i, a) {
let s = ["marker"];
return "all" !== t && s.push(t), s = s.join("-"), t = arguments[1] instanceof be ? arguments[1] : this.defs().marker(e, i, a), this.attr(s, t)
}
}
}), q(be, "Marker");
const ve = {
"-": function (t) {
return t
}, "<>": function (t) {
return -Math.cos(t * Math.PI) / 2 + .5
}, ">": function (t) {
return Math.sin(t * Math.PI / 2)
}, "<": function (t) {
return 1 - Math.cos(t * Math.PI / 2)
}, bezier: function (t, e, i, a) {
return function (s) {
return s < 0 ? t > 0 ? e / t * s : i > 0 ? a / i * s : 0 : s > 1 ? i < 1 ? (1 - a) / (1 - i) * s + (a - i) / (1 - i) : t < 1 ? (1 - e) / (1 - t) * s + (e - t) / (1 - t) : 1 : 3 * s * (1 - s) ** 2 * e + 3 * s ** 2 * (1 - s) * a + s ** 3
}
}, steps: function (t, e = "end") {
e = e.split("-").reverse()[0];
let i = t;
return "none" === e ? --i : "both" === e && ++i, (a, s = !1) => {
let r = Math.floor(a * t);
const n = a * r % 1 == 0;
return "start" !== e && "both" !== e || ++r, s && n && --r, a >= 0 && r < 0 && (r = 0), a <= 1 && r > i && (r = i), r / i
}
}
};
class ye {
done() {
return !1
}
}
class we extends ye {
constructor(t = Ht) {
super(), this.ease = ve[t] || t
}
step(t, e, i) {
return "number" != typeof t ? i < 1 ? t : e : t + (e - t) * this.ease(i)
}
}
class ke extends ye {
constructor(t) {
super(), this.stepper = t
}
done(t) {
return t.done
}
step(t, e, i, a) {
return this.stepper(t, e, i, a)
}
}
function Ae() {
const t = (this._duration || 500) / 1e3, e = this._overshoot || 0, i = Math.PI, a = Math.log(e / 100 + 1e-10),
s = -a / Math.sqrt(i * i + a * a), r = 3.9 / (s * t);
this.d = 2 * s * r, this.k = r * r
}
Q(class extends ke {
constructor(t = 500, e = 0) {
super(), this.duration(t).overshoot(e)
}
step(t, e, i, a) {
if ("string" == typeof t) return t;
if (a.done = i === 1 / 0, i === 1 / 0) return e;
if (0 === i) return t;
i > 100 && (i = 16), i /= 1e3;
const s = a.velocity || 0, r = -this.d * s - this.k * (t - e), n = t + s * i + r * i * i / 2;
return a.velocity = s + r * i, a.done = Math.abs(e - n) + Math.abs(s) < .002, a.done ? e : n
}
}, {duration: me("_duration", Ae), overshoot: me("_overshoot", Ae)});
Q(class extends ke {
constructor(t = .1, e = .01, i = 0, a = 1e3) {
super(), this.p(t).i(e).d(i).windup(a)
}
step(t, e, i, a) {
if ("string" == typeof t) return t;
if (a.done = i === 1 / 0, i === 1 / 0) return e;
if (0 === i) return t;
const s = e - t;
let r = (a.integral || 0) + s * i;
const n = (s - (a.error || 0)) / i, o = this._windup;
return !1 !== o && (r = Math.max(-o, Math.min(r, o))), a.error = s, a.integral = r, a.done = Math.abs(s) < .001, a.done ? e : t + (this.P * s + this.I * r + this.D * n)
}
}, {windup: me("_windup"), p: me("P"), i: me("I"), d: me("D")});
const Ce = {M: 2, L: 2, H: 1, V: 1, C: 6, S: 4, Q: 4, T: 2, A: 7, Z: 0}, Se = {
M: function (t, e, i) {
return e.x = i.x = t[0], e.y = i.y = t[1], ["M", e.x, e.y]
}, L: function (t, e) {
return e.x = t[0], e.y = t[1], ["L", t[0], t[1]]
}, H: function (t, e) {
return e.x = t[0], ["H", t[0]]
}, V: function (t, e) {
return e.y = t[0], ["V", t[0]]
}, C: function (t, e) {
return e.x = t[4], e.y = t[5], ["C", t[0], t[1], t[2], t[3], t[4], t[5]]
}, S: function (t, e) {
return e.x = t[2], e.y = t[3], ["S", t[0], t[1], t[2], t[3]]
}, Q: function (t, e) {
return e.x = t[2], e.y = t[3], ["Q", t[0], t[1], t[2], t[3]]
}, T: function (t, e) {
return e.x = t[0], e.y = t[1], ["T", t[0], t[1]]
}, Z: function (t, e, i) {
return e.x = i.x, e.y = i.y, ["Z"]
}, A: function (t, e) {
return e.x = t[5], e.y = t[6], ["A", t[0], t[1], t[2], t[3], t[4], t[5], t[6]]
}
}, Le = "mlhvqtcsaz".split("");
for (let t = 0, e = Le.length; t < e; ++t) Se[Le[t]] = function (t) {
return function (e, i, a) {
if ("H" === t) e[0] = e[0] + i.x; else if ("V" === t) e[0] = e[0] + i.y; else if ("A" === t) e[5] = e[5] + i.x, e[6] = e[6] + i.y; else for (let t = 0, a = e.length; t < a; ++t) e[t] = e[t] + (t % 2 ? i.y : i.x);
return Se[t](e, i, a)
}
}(Le[t].toUpperCase());
function Me(t) {
return t.segment.length && t.segment.length - 1 === Ce[t.segment[0].toUpperCase()]
}
function Pe(t, e) {
t.inNumber && Ie(t, !1);
const i = ut.test(e);
if (i) t.segment = [e]; else {
const e = t.lastCommand, i = e.toLowerCase(), a = e === i;
t.segment = ["m" === i ? a ? "l" : "L" : e]
}
return t.inSegment = !0, t.lastCommand = t.segment[0], i
}
function Ie(t, e) {
if (!t.inNumber) throw new Error("Parser Error");
t.number && t.segment.push(parseFloat(t.number)), t.inNumber = e, t.number = "", t.pointSeen = !1, t.hasExponent = !1, Me(t) && Te(t)
}
function Te(t) {
t.inSegment = !1, t.absolute && (t.segment = function (t) {
const e = t.segment[0];
return Se[e](t.segment.slice(1), t.p, t.p0)
}(t)), t.segments.push(t.segment)
}
function ze(t) {
if (!t.segment.length) return !1;
const e = "A" === t.segment[0].toUpperCase(), i = t.segment.length;
return e && (4 === i || 5 === i)
}
function Xe(t) {
return "E" === t.lastToken.toUpperCase()
}
const Re = new Set([" ", ",", "\t", "\n", "\r", "\f"]);
class Ee extends Dt {
bbox() {
return yt().path.setAttribute("d", this.toString()), new kt(yt.nodes.path.getBBox())
}
move(t, e) {
const i = this.bbox();
if (t -= i.x, e -= i.y, !isNaN(t) && !isNaN(e)) for (let i, a = this.length - 1; a >= 0; a--) i = this[a][0], "M" === i || "L" === i || "T" === i ? (this[a][1] += t, this[a][2] += e) : "H" === i ? this[a][1] += t : "V" === i ? this[a][1] += e : "C" === i || "S" === i || "Q" === i ? (this[a][1] += t, this[a][2] += e, this[a][3] += t, this[a][4] += e, "C" === i && (this[a][5] += t, this[a][6] += e)) : "A" === i && (this[a][6] += t, this[a][7] += e);
return this
}
parse(t = "M0 0") {
return Array.isArray(t) && (t = Array.prototype.concat.apply([], t).toString()), function (t, e = !0) {
let i = 0, a = "";
const s = {
segment: [],
inNumber: !1,
number: "",
lastToken: "",
inSegment: !1,
segments: [],
pointSeen: !1,
hasExponent: !1,
absolute: e,
p0: new bt,
p: new bt
};
for (; s.lastToken = a, a = t.charAt(i++);) if (s.inSegment || !Pe(s, a)) if ("." !== a) if (isNaN(parseInt(a))) if (Re.has(a)) s.inNumber && Ie(s, !1); else if ("-" !== a && "+" !== a) if ("E" !== a.toUpperCase()) {
if (ut.test(a)) {
if (s.inNumber) Ie(s, !1); else {
if (!Me(s)) throw new Error("parser Error");
Te(s)
}
--i
}
} else s.number += a, s.hasExponent = !0; else {
if (s.inNumber && !Xe(s)) {
Ie(s, !1), --i;
continue
}
s.number += a, s.inNumber = !0
} else {
if ("0" === s.number || ze(s)) {
s.inNumber = !0, s.number = a, Ie(s, !0);
continue
}
s.inNumber = !0, s.number += a
} else {
if (s.pointSeen || s.hasExponent) {
Ie(s, !1), --i;
continue
}
s.inNumber = !0, s.pointSeen = !0, s.number += a
}
return s.inNumber && Ie(s, !1), s.inSegment && Me(s) && Te(s), s.segments
}(t)
}
size(t, e) {
const i = this.bbox();
let a, s;
for (i.width = 0 === i.width ? 1 : i.width, i.height = 0 === i.height ? 1 : i.height, a = this.length - 1; a >= 0; a--) s = this[a][0], "M" === s || "L" === s || "T" === s ? (this[a][1] = (this[a][1] - i.x) * t / i.width + i.x, this[a][2] = (this[a][2] - i.y) * e / i.height + i.y) : "H" === s ? this[a][1] = (this[a][1] - i.x) * t / i.width + i.x : "V" === s ? this[a][1] = (this[a][1] - i.y) * e / i.height + i.y : "C" === s || "S" === s || "Q" === s ? (this[a][1] = (this[a][1] - i.x) * t / i.width + i.x, this[a][2] = (this[a][2] - i.y) * e / i.height + i.y, this[a][3] = (this[a][3] - i.x) * t / i.width + i.x, this[a][4] = (this[a][4] - i.y) * e / i.height + i.y, "C" === s && (this[a][5] = (this[a][5] - i.x) * t / i.width + i.x, this[a][6] = (this[a][6] - i.y) * e / i.height + i.y)) : "A" === s && (this[a][1] = this[a][1] * t / i.width, this[a][2] = this[a][2] * e / i.height, this[a][6] = (this[a][6] - i.x) * t / i.width + i.x, this[a][7] = (this[a][7] - i.y) * e / i.height + i.y);
return this
}
toString() {
return function (t) {
let e = "";
for (let i = 0, a = t.length; i < a; i++) e += t[i][0], null != t[i][1] && (e += t[i][1], null != t[i][2] && (e += " ", e += t[i][2], null != t[i][3] && (e += " ", e += t[i][3], e += " ", e += t[i][4], null != t[i][5] && (e += " ", e += t[i][5], e += " ", e += t[i][6], null != t[i][7] && (e += " ", e += t[i][7])))));
return e + " "
}(this)
}
}
const Ye = t => {
const e = typeof t;
return "number" === e ? _t : "string" === e ? xt.isColor(t) ? xt : dt.test(t) ? ut.test(t) ? Ee : Dt : tt.test(t) ? _t : Oe : Ne.indexOf(t.constructor) > -1 ? t.constructor : Array.isArray(t) ? Dt : "object" === e ? _e : Oe
};
class He {
constructor(t) {
this._stepper = t || new we("-"), this._from = null, this._to = null, this._type = null, this._context = null, this._morphObj = null
}
at(t) {
return this._morphObj.morph(this._from, this._to, t, this._stepper, this._context)
}
done() {
return this._context.map(this._stepper.done).reduce((function (t, e) {
return t && e
}), !0)
}
from(t) {
return null == t ? this._from : (this._from = this._set(t), this)
}
stepper(t) {
return null == t ? this._stepper : (this._stepper = t, this)
}
to(t) {
return null == t ? this._to : (this._to = this._set(t), this)
}
type(t) {
return null == t ? this._type : (this._type = t, this)
}
_set(t) {
this._type || this.type(Ye(t));
let e = new this._type(t);
return this._type === xt && (e = this._to ? e[this._to[4]]() : this._from ? e[this._from[4]]() : e), this._type === _e && (e = this._to ? e.align(this._to) : this._from ? e.align(this._from) : e), e = e.toConsumable(), this._morphObj = this._morphObj || new this._type, this._context = this._context || Array.apply(null, Array(e.length)).map(Object).map((function (t) {
return t.done = !0, t
})), e
}
}
class Oe {
constructor(...t) {
this.init(...t)
}
init(t) {
return t = Array.isArray(t) ? t[0] : t, this.value = t, this
}
toArray() {
return [this.value]
}
valueOf() {
return this.value
}
}
class Fe {
constructor(...t) {
this.init(...t)
}
init(t) {
return Array.isArray(t) && (t = {
scaleX: t[0],
scaleY: t[1],
shear: t[2],
rotate: t[3],
translateX: t[4],
translateY: t[5],
originX: t[6],
originY: t[7]
}), Object.assign(this, Fe.defaults, t), this
}
toArray() {
const t = this;
return [t.scaleX, t.scaleY, t.shear, t.rotate, t.translateX, t.translateY, t.originX, t.originY]
}
}
Fe.defaults = {scaleX: 1, scaleY: 1, shear: 0, rotate: 0, translateX: 0, translateY: 0, originX: 0, originY: 0};
const De = (t, e) => t[0] < e[0] ? -1 : t[0] > e[0] ? 1 : 0;
class _e {
constructor(...t) {
this.init(...t)
}
align(t) {
const e = this.values;
for (let i = 0, a = e.length; i < a; ++i) {
if (e[i + 1] === t[i + 1]) {
if (e[i + 1] === xt && t[i + 7] !== e[i + 7]) {
const e = t[i + 7], a = new xt(this.values.splice(i + 3, 5))[e]().toArray();
this.values.splice(i + 3, 0, ...a)
}
i += e[i + 2] + 2;
continue
}
if (!t[i + 1]) return this;
const a = (new t[i + 1]).toArray(), s = e[i + 2] + 3;
e.splice(i, s, t[i], t[i + 1], t[i + 2], ...a), i += e[i + 2] + 2
}
return this
}
init(t) {
if (this.values = [], Array.isArray(t)) return void (this.values = t.slice());
t = t || {};
const e = [];
for (const i in t) {
const a = Ye(t[i]), s = new a(t[i]).toArray();
e.push([i, a, s.length, ...s])
}
return e.sort(De), this.values = e.reduce(((t, e) => t.concat(e)), []), this
}
toArray() {
return this.values
}
valueOf() {
const t = {}, e = this.values;
for (; e.length;) {
const i = e.shift(), a = e.shift(), s = e.shift(), r = e.splice(0, s);
t[i] = new a(r)
}
return t
}
}
const Ne = [Oe, Fe, _e];
class We extends qt {
constructor(t, e = t) {
super(G("path", t), e)
}
array() {
return this._array || (this._array = new Ee(this.attr("d")))
}
clear() {
return delete this._array, this
}
height(t) {
return null == t ? this.bbox().height : this.size(this.bbox().width, t)
}
move(t, e) {
return this.attr("d", this.array().move(t, e))
}
plot(t) {
return null == t ? this.array() : this.clear().attr("d", "string" == typeof t ? t : this._array = new Ee(t))
}
size(t, e) {
const i = I(this, t, e);
return this.attr("d", this.array().size(i.width, i.height))
}
width(t) {
return null == t ? this.bbox().width : this.size(t, this.bbox().height)
}
x(t) {
return null == t ? this.bbox().x : this.move(t, this.bbox().y)
}
y(t) {
return null == t ? this.bbox().y : this.move(this.bbox().x, t)
}
}
We.prototype.MorphArray = Ee, A({
Container: {
path: K((function (t) {
return this.put(new We).plot(t || new Ee)
}))
}
}), q(We, "Path");
var Be = Object.freeze({
__proto__: null, array: function () {
return this._array || (this._array = new ge(this.attr("points")))
}, clear: function () {
return delete this._array, this
}, move: function (t, e) {
return this.attr("points", this.array().move(t, e))
}, plot: function (t) {
return null == t ? this.array() : this.clear().attr("points", "string" == typeof t ? t : this._array = new ge(t))
}, size: function (t, e) {
const i = I(this, t, e);
return this.attr("points", this.array().size(i.width, i.height))
}
});
class Ge extends qt {
constructor(t, e = t) {
super(G("polygon", t), e)
}
}
A({
Container: {
polygon: K((function (t) {
return this.put(new Ge).plot(t || new ge)
}))
}
}), Q(Ge, fe), Q(Ge, Be), q(Ge, "Polygon");
class je extends qt {
constructor(t, e = t) {
super(G("polyline", t), e)
}
}
A({
Container: {
polyline: K((function (t) {
return this.put(new je).plot(t || new ge)
}))
}
}), Q(je, fe), Q(je, Be), q(je, "Polyline");
class Ve extends qt {
constructor(t, e = t) {
super(G("rect", t), e)
}
}
Q(Ve, {rx: Zt, ry: $t}), A({
Container: {
rect: K((function (t, e) {
return this.put(new Ve).size(t, e)
}))
}
}), q(Ve, "Rect");
class Ue {
constructor() {
this._first = null, this._last = null
}
first() {
return this._first && this._first.value
}
last() {
return this._last && this._last.value
}
push(t) {
const e = void 0 !== t.next ? t : {value: t, next: null, prev: null};
return this._last ? (e.prev = this._last, this._last.next = e, this._last = e) : (this._last = e, this._first = e), e
}
remove(t) {
t.prev && (t.prev.next = t.next), t.next && (t.next.prev = t.prev), t === this._last && (this._last = t.prev), t === this._first && (this._first = t.next), t.prev = null, t.next = null
}
shift() {
const t = this._first;
return t ? (this._first = t.next, this._first && (this._first.prev = null), this._last = this._first ? this._last : null, t.value) : null
}
}
const qe = {
nextDraw: null,
frames: new Ue,
timeouts: new Ue,
immediates: new Ue,
timer: () => O.window.performance || O.window.Date,
transforms: [],
frame(t) {
const e = qe.frames.push({run: t});
return null === qe.nextDraw && (qe.nextDraw = O.window.requestAnimationFrame(qe._draw)), e
},
timeout(t, e) {
e = e || 0;
const i = qe.timer().now() + e, a = qe.timeouts.push({run: t, time: i});
return null === qe.nextDraw && (qe.nextDraw = O.window.requestAnimationFrame(qe._draw)), a
},
immediate(t) {
const e = qe.immediates.push(t);
return null === qe.nextDraw && (qe.nextDraw = O.window.requestAnimationFrame(qe._draw)), e
},
cancelFrame(t) {
null != t && qe.frames.remove(t)
},
clearTimeout(t) {
null != t && qe.timeouts.remove(t)
},
cancelImmediate(t) {
null != t && qe.immediates.remove(t)
},
_draw(t) {
let e = null;
const i = qe.timeouts.last();
for (; (e = qe.timeouts.shift()) && (t >= e.time ? e.run() : qe.timeouts.push(e), e !== i);) ;
let a = null;
const s = qe.frames.last();
for (; a !== s && (a = qe.frames.shift());) a.run(t);
let r = null;
for (; r = qe.immediates.shift();) r();
qe.nextDraw = qe.timeouts.first() || qe.frames.first() ? O.window.requestAnimationFrame(qe._draw) : null
}
}, Ze = function (t) {
const e = t.start, i = t.runner.duration();
return {start: e, duration: i, end: e + i, runner: t.runner}
}, $e = function () {
const t = O.window;
return (t.performance || t.Date).now()
};
class Je extends Rt {
constructor(t = $e) {
super(), this._timeSource = t, this.terminate()
}
active() {
return !!this._nextFrame
}
finish() {
return this.time(this.getEndTimeOfTimeline() + 1), this.pause()
}
getEndTime() {
const t = this.getLastRunnerInfo(), e = t ? t.runner.duration() : 0;
return (t ? t.start : this._time) + e
}
getEndTimeOfTimeline() {
const t = this._runners.map((t => t.start + t.runner.duration()));
return Math.max(0, ...t)
}
getLastRunnerInfo() {
return this.getRunnerInfoById(this._lastRunnerId)
}
getRunnerInfoById(t) {
return this._runners[this._runnerIds.indexOf(t)] || null
}
pause() {
return this._paused = !0, this._continue()
}
persist(t) {
return null == t ? this._persist : (this._persist = t, this)
}
play() {
return this._paused = !1, this.updateTime()._continue()
}
reverse(t) {
const e = this.speed();
if (null == t) return this.speed(-e);
const i = Math.abs(e);
return this.speed(t ? -i : i)
}
schedule(t, e, i) {
if (null == t) return this._runners.map(Ze);
let a = 0;
const s = this.getEndTime();
if (e = e || 0, null == i || "last" === i || "after" === i) a = s; else if ("absolute" === i || "start" === i) a = e, e = 0; else if ("now" === i) a = this._time; else if ("relative" === i) {
const i = this.getRunnerInfoById(t.id);
i && (a = i.start + e, e = 0)
} else {
if ("with-last" !== i) throw new Error('Invalid value for the "when" parameter');
{
const t = this.getLastRunnerInfo();
a = t ? t.start : this._time
}
}
t.unschedule(), t.timeline(this);
const r = t.persist(), n = {persist: null === r ? this._persist : r, start: a + e, runner: t};
return this._lastRunnerId = t.id, this._runners.push(n), this._runners.sort(((t, e) => t.start - e.start)), this._runnerIds = this._runners.map((t => t.runner.id)), this.updateTime()._continue(), this
}
seek(t) {
return this.time(this._time + t)
}
source(t) {
return null == t ? this._timeSource : (this._timeSource = t, this)
}
speed(t) {
return null == t ? this._speed : (this._speed = t, this)
}
stop() {
return this.time(0), this.pause()
}
time(t) {
return null == t ? this._time : (this._time = t, this._continue(!0))
}
unschedule(t) {
const e = this._runnerIds.indexOf(t.id);
return e < 0 || (this._runners.splice(e, 1), this._runnerIds.splice(e, 1), t.timeline(null)), this
}
updateTime() {
return this.active() || (this._lastSourceTime = this._timeSource()), this
}
_continue(t = !1) {
return qe.cancelFrame(this._nextFrame), this._nextFrame = null, t ? this._stepImmediate() : (this._paused || (this._nextFrame = qe.frame(this._step)), this)
}
_stepFn(t = !1) {
const e = this._timeSource();
let i = e - this._lastSourceTime;
t && (i = 0);
const a = this._speed * i + (this._time - this._lastStepTime);
this._lastSourceTime = e, t || (this._time += a, this._time = this._time < 0 ? 0 : this._time), this._lastStepTime = this._time, this.fire("time", this._time);
for (let t = this._runners.length; t--;) {
const e = this._runners[t], i = e.runner;
this._time - e.start <= 0 && i.reset()
}
let s = !1;
for (let t = 0, e = this._runners.length; t < e; t++) {
const i = this._runners[t], r = i.runner;
let n = a;
const o = this._time - i.start;
if (o <= 0) {
s = !0;
continue
}
if (o < n && (n = o), !r.active()) continue;
if (r.step(n).done) {
if (!0 !== i.persist) {
r.duration() - r.time() + this._time + i.persist < this._time && (r.unschedule(), --t, --e)
}
} else s = !0
}
return s && !(this._speed < 0 && 0 === this._time) || this._runnerIds.length && this._speed < 0 && this._time > 0 ? this._continue() : (this.pause(), this.fire("finished")), this
}
terminate() {
this._startTime = 0, this._speed = 1, this._persist = 0, this._nextFrame = null, this._paused = !0, this._runners = [], this._runnerIds = [], this._lastRunnerId = -1, this._time = 0, this._lastSourceTime = 0, this._lastStepTime = 0, this._step = this._stepFn.bind(this, !1), this._stepImmediate = this._stepFn.bind(this, !0)
}
}
A({
Element: {
timeline: function (t) {
return null == t ? (this._timeline = this._timeline || new Je, this._timeline) : (this._timeline = t, this)
}
}
});
class Qe extends Rt {
constructor(t) {
super(), this.id = Qe.id++, t = "function" == typeof (t = null == t ? Yt : t) ? new ke(t) : t, this._element = null, this._timeline = null, this.done = !1, this._queue = [], this._duration = "number" == typeof t && t, this._isDeclarative = t instanceof ke, this._stepper = this._isDeclarative ? t : new we, this._history = {}, this.enabled = !0, this._time = 0, this._lastTime = 0, this._reseted = !0, this.transforms = new vt, this.transformId = 1, this._haveReversed = !1, this._reverse = !1, this._loopsDone = 0, this._swing = !1, this._wait = 0, this._times = 1, this._frameId = null, this._persist = !!this._isDeclarative || null
}
static sanitise(t, e, i) {
let a = 1, s = !1, r = 0;
return e = e ?? Ot, i = i || "last", "object" != typeof (t = t ?? Yt) || t instanceof ye || (e = t.delay ?? e, i = t.when ?? i, s = t.swing || s, a = t.times ?? a, r = t.wait ?? r, t = t.duration ?? Yt), {
duration: t,
delay: e,
swing: s,
times: a,
wait: r,
when: i
}
}
active(t) {
return null == t ? this.enabled : (this.enabled = t, this)
}
addTransform(t) {
return this.transforms.lmultiplyO(t), this
}
after(t) {
return this.on("finished", t)
}
animate(t, e, i) {
const a = Qe.sanitise(t, e, i), s = new Qe(a.duration);
return this._timeline && s.timeline(this._timeline), this._element && s.element(this._element), s.loop(a).schedule(a.delay, a.when)
}
clearTransform() {
return this.transforms = new vt, this
}
clearTransformsFromQueue() {
this.done && this._timeline && this._timeline._runnerIds.includes(this.id) || (this._queue = this._queue.filter((t => !t.isTransform)))
}
delay(t) {
return this.animate(0, t)
}
duration() {
return this._times * (this._wait + this._duration) - this._wait
}
during(t) {
return this.queue(null, t)
}
ease(t) {
return this._stepper = new we(t), this
}
element(t) {
return null == t ? this._element : (this._element = t, t._prepareRunner(), this)
}
finish() {
return this.step(1 / 0)
}
loop(t, e, i) {
return "object" == typeof t && (e = t.swing, i = t.wait, t = t.times), this._times = t || 1 / 0, this._swing = e || !1, this._wait = i || 0, !0 === this._times && (this._times = 1 / 0), this
}
loops(t) {
const e = this._duration + this._wait;
if (null == t) {
const t = Math.floor(this._time / e), i = (this._time - t * e) / this._duration;
return Math.min(t + i, this._times)
}
const i = t % 1, a = e * Math.floor(t) + this._duration * i;
return this.time(a)
}
persist(t) {
return null == t ? this._persist : (this._persist = t, this)
}
position(t) {
const e = this._time, i = this._duration, a = this._wait, s = this._times, r = this._swing,
n = this._reverse;
let o;
if (null == t) {
const t = function (t) {
const e = r * Math.floor(t % (2 * (a + i)) / (a + i)), s = e && !n || !e && n,
o = Math.pow(-1, s) * (t % (a + i)) / i + s;
return Math.max(Math.min(o, 1), 0)
}, l = s * (a + i) - a;
return o = e <= 0 ? Math.round(t(1e-5)) : e < l ? t(e) : Math.round(t(l - 1e-5)), o
}
const l = Math.floor(this.loops()), h = r && l % 2 == 0;
return o = l + (h && !n || n && h ? t : 1 - t), this.loops(o)
}
progress(t) {
return null == t ? Math.min(1, this._time / this.duration()) : this.time(t * this.duration())
}
queue(t, e, i, a) {
this._queue.push({
initialiser: t || Et,
runner: e || Et,
retarget: i,
isTransform: a,
initialised: !1,
finished: !1
});
return this.timeline() && this.timeline()._continue(), this
}
reset() {
return this._reseted || (this.time(0), this._reseted = !0), this
}
reverse(t) {
return this._reverse = null == t ? !this._reverse : t, this
}
schedule(t, e, i) {
if (t instanceof Je || (i = e, e = t, t = this.timeline()), !t) throw Error("Runner cannot be scheduled without timeline");
return t.schedule(this, e, i), this
}
step(t) {
if (!this.enabled) return this;
t = null == t ? 16 : t, this._time += t;
const e = this.position(), i = this._lastPosition !== e && this._time >= 0;
this._lastPosition = e;
const a = this.duration(), s = this._lastTime <= 0 && this._time > 0,
r = this._lastTime < a && this._time >= a;
this._lastTime = this._time, s && this.fire("start", this);
const n = this._isDeclarative;
this.done = !n && !r && this._time >= a, this._reseted = !1;
let o = !1;
return (i || n) && (this._initialise(i), this.transforms = new vt, o = this._run(n ? t : e), this.fire("step", this)), this.done = this.done || o && n, r && this.fire("finished", this), this
}
time(t) {
if (null == t) return this._time;
const e = t - this._time;
return this.step(e), this
}
timeline(t) {
return void 0 === t ? this._timeline : (this._timeline = t, this)
}
unschedule() {
const t = this.timeline();
return t && t.unschedule(this), this
}
_initialise(t) {
if (t || this._isDeclarative) for (let e = 0, i = this._queue.length; e < i; ++e) {
const i = this._queue[e], a = this._isDeclarative || !i.initialised && t;
t = !i.finished, a && t && (i.initialiser.call(this), i.initialised = !0)
}
}
_rememberMorpher(t, e) {
if (this._history[t] = {morpher: e, caller: this._queue[this._queue.length - 1]}, this._isDeclarative) {
const t = this.timeline();
t && t.play()
}
}
_run(t) {
let e = !0;
for (let i = 0, a = this._queue.length; i < a; ++i) {
const a = this._queue[i], s = a.runner.call(this, t);
a.finished = a.finished || !0 === s, e = e && a.finished
}
return e
}
_tryRetarget(t, e, i) {
if (this._history[t]) {
if (!this._history[t].caller.initialised) {
const e = this._queue.indexOf(this._history[t].caller);
return this._queue.splice(e, 1), !1
}
this._history[t].caller.retarget ? this._history[t].caller.retarget.call(this, e, i) : this._history[t].morpher.to(e), this._history[t].caller.finished = !1;
const a = this.timeline();
return a && a.play(), !0
}
return !1
}
}
Qe.id = 0;
class Ke {
constructor(t = new vt, e = -1, i = !0) {
this.transforms = t, this.id = e, this.done = i
}
clearTransformsFromQueue() {
}
}
Q([Qe, Ke], {
mergeWith(t) {
return new Ke(t.transforms.lmultiply(this.transforms), t.id)
}
});
const ti = (t, e) => t.lmultiplyO(e), ei = t => t.transforms;
function ii() {
const t = this._transformationRunners.runners.map(ei).reduce(ti, new vt);
this.transform(t), this._transformationRunners.merge(), 1 === this._transformationRunners.length() && (this._frameId = null)
}
class ai {
constructor() {
this.runners = [], this.ids = []
}
add(t) {
if (this.runners.includes(t)) return;
const e = t.id + 1;
return this.runners.push(t), this.ids.push(e), this
}
clearBefore(t) {
const e = this.ids.indexOf(t + 1) || 1;
return this.ids.splice(0, e, 0), this.runners.splice(0, e, new Ke).forEach((t => t.clearTransformsFromQueue())), this
}
edit(t, e) {
const i = this.ids.indexOf(t + 1);
return this.ids.splice(i, 1, t + 1), this.runners.splice(i, 1, e), this
}
getByID(t) {
return this.runners[this.ids.indexOf(t + 1)]
}
length() {
return this.ids.length
}
merge() {
let t = null;
for (let e = 0; e < this.runners.length; ++e) {
const i = this.runners[e];
if (t && i.done && t.done && (!i._timeline || !i._timeline._runnerIds.includes(i.id)) && (!t._timeline || !t._timeline._runnerIds.includes(t.id))) {
this.remove(i.id);
const a = i.mergeWith(t);
this.edit(t.id, a), t = a, --e
} else t = i
}
return this
}
remove(t) {
const e = this.ids.indexOf(t + 1);
return this.ids.splice(e, 1), this.runners.splice(e, 1), this
}
}
A({
Element: {
animate(t, e, i) {
const a = Qe.sanitise(t, e, i), s = this.timeline();
return new Qe(a.duration).loop(a).element(this).timeline(s.play()).schedule(a.delay, a.when)
}, delay(t, e) {
return this.animate(0, t, e)
}, _clearTransformRunnersBefore(t) {
this._transformationRunners.clearBefore(t.id)
}, _currentTransform(t) {
return this._transformationRunners.runners.filter((e => e.id <= t.id)).map(ei).reduce(ti, new vt)
}, _addRunner(t) {
this._transformationRunners.add(t), qe.cancelImmediate(this._frameId), this._frameId = qe.immediate(ii.bind(this))
}, _prepareRunner() {
null == this._frameId && (this._transformationRunners = (new ai).add(new Ke(new vt(this))))
}
}
});
Q(Qe, {
attr(t, e) {
return this.styleAttr("attr", t, e)
}, css(t, e) {
return this.styleAttr("css", t, e)
}, styleAttr(t, e, i) {
if ("string" == typeof e) return this.styleAttr(t, {[e]: i});
let a = e;
if (this._tryRetarget(t, a)) return this;
let s = new He(this._stepper).to(a), r = Object.keys(a);
return this.queue((function () {
s = s.from(this.element()[t](r))
}), (function (e) {
return this.element()[t](s.at(e).valueOf()), s.done()
}), (function (e) {
const i = Object.keys(e), n = (o = r, i.filter((t => !o.includes(t))));
var o;
if (n.length) {
const e = this.element()[t](n), i = new _e(s.from()).valueOf();
Object.assign(i, e), s.from(i)
}
const l = new _e(s.to()).valueOf();
Object.assign(l, e), s.to(l), r = i, a = e
})), this._rememberMorpher(t, s), this
}, zoom(t, e) {
if (this._tryRetarget("zoom", t, e)) return this;
let i = new He(this._stepper).to(new _t(t));
return this.queue((function () {
i = i.from(this.element().zoom())
}), (function (t) {
return this.element().zoom(i.at(t), e), i.done()
}), (function (t, a) {
e = a, i.to(t)
})), this._rememberMorpher("zoom", i), this
}, transform(t, e, i) {
if (e = t.relative || e, this._isDeclarative && !e && this._tryRetarget("transform", t)) return this;
const a = vt.isMatrixLike(t);
i = null != t.affine ? t.affine : null != i ? i : !a;
const s = new He(this._stepper).type(i ? Fe : vt);
let r, n, o, l, h;
return this.queue((function () {
n = n || this.element(), r = r || T(t, n), h = new vt(e ? void 0 : n), n._addRunner(this), e || n._clearTransformRunnersBefore(this)
}), (function (c) {
e || this.clearTransform();
const {x: d, y: u} = new bt(r).transform(n._currentTransform(this));
let g = new vt({...t, origin: [d, u]}), p = this._isDeclarative && o ? o : h;
if (i) {
g = g.decompose(d, u), p = p.decompose(d, u);
const t = g.rotate, e = p.rotate, i = [t - 360, t, t + 360], a = i.map((t => Math.abs(t - e))),
s = Math.min(...a), r = a.indexOf(s);
g.rotate = i[r]
}
e && (a || (g.rotate = t.rotate || 0), this._isDeclarative && l && (p.rotate = l)), s.from(p), s.to(g);
const f = s.at(c);
return l = f.rotate, o = new vt(f), this.addTransform(o), n._addRunner(this), s.done()
}), (function (e) {
(e.origin || "center").toString() !== (t.origin || "center").toString() && (r = T(e, n)), t = {
...e,
origin: r
}
}), !0), this._isDeclarative && this._rememberMorpher("transform", s), this
}, x(t) {
return this._queueNumber("x", t)
}, y(t) {
return this._queueNumber("y", t)
}, ax(t) {
return this._queueNumber("ax", t)
}, ay(t) {
return this._queueNumber("ay", t)
}, dx(t = 0) {
return this._queueNumberDelta("x", t)
}, dy(t = 0) {
return this._queueNumberDelta("y", t)
}, dmove(t, e) {
return this.dx(t).dy(e)
}, _queueNumberDelta(t, e) {
if (e = new _t(e), this._tryRetarget(t, e)) return this;
const i = new He(this._stepper).to(e);
let a = null;
return this.queue((function () {
a = this.element()[t](), i.from(a), i.to(a + e)
}), (function (e) {
return this.element()[t](i.at(e)), i.done()
}), (function (t) {
i.to(a + new _t(t))
})), this._rememberMorpher(t, i), this
}, _queueObject(t, e) {
if (this._tryRetarget(t, e)) return this;
const i = new He(this._stepper).to(e);
return this.queue((function () {
i.from(this.element()[t]())
}), (function (e) {
return this.element()[t](i.at(e)), i.done()
})), this._rememberMorpher(t, i), this
}, _queueNumber(t, e) {
return this._queueObject(t, new _t(e))
}, cx(t) {
return this._queueNumber("cx", t)
}, cy(t) {
return this._queueNumber("cy", t)
}, move(t, e) {
return this.x(t).y(e)
}, amove(t, e) {
return this.ax(t).ay(e)
}, center(t, e) {
return this.cx(t).cy(e)
}, size(t, e) {
let i;
return t && e || (i = this._element.bbox()), t || (t = i.width / i.height * e), e || (e = i.height / i.width * t), this.width(t).height(e)
}, width(t) {
return this._queueNumber("width", t)
}, height(t) {
return this._queueNumber("height", t)
}, plot(t, e, i, a) {
if (4 === arguments.length) return this.plot([t, e, i, a]);
if (this._tryRetarget("plot", t)) return this;
const s = new He(this._stepper).type(this._element.MorphArray).to(t);
return this.queue((function () {
s.from(this._element.array())
}), (function (t) {
return this._element.plot(s.at(t)), s.done()
})), this._rememberMorpher("plot", s), this
}, leading(t) {
return this._queueNumber("leading", t)
}, viewbox(t, e, i, a) {
return this._queueObject("viewbox", new kt(t, e, i, a))
}, update(t) {
return "object" != typeof t ? this.update({
offset: arguments[0],
color: arguments[1],
opacity: arguments[2]
}) : (null != t.opacity && this.attr("stop-opacity", t.opacity), null != t.color && this.attr("stop-color", t.color), null != t.offset && this.attr("offset", t.offset), this)
}
}), Q(Qe, {rx: Zt, ry: $t, from: ne, to: oe}), q(Qe, "Runner");
class si extends Vt {
constructor(t, e = t) {
super(G("svg", t), e), this.namespace()
}
defs() {
return this.isRoot() ? V(this.node.querySelector("defs")) || this.put(new Ut) : this.root().defs()
}
isRoot() {
return !this.node.parentNode || !(this.node.parentNode instanceof O.window.SVGElement) && "#document-fragment" !== this.node.parentNode.nodeName
}
namespace() {
return this.isRoot() ? this.attr({
xmlns: E,
version: "1.1"
}).attr("xmlns:xlink", H, Y) : this.root().namespace()
}
removeNamespace() {
return this.attr({xmlns: null, version: null}).attr("xmlns:xlink", null, Y).attr("xmlns:svgjs", null, Y)
}
root() {
return this.isRoot() ? this : super.root()
}
}
A({
Container: {
nested: K((function () {
return this.put(new si)
}))
}
}), q(si, "Svg", !0);
let ri = class extends Vt {
constructor(t, e = t) {
super(G("symbol", t), e)
}
};
A({
Container: {
symbol: K((function () {
return this.put(new ri)
}))
}
}), q(ri, "Symbol");
var ni = Object.freeze({
__proto__: null, amove: function (t, e) {
return this.ax(t).ay(e)
}, ax: function (t) {
return this.attr("x", t)
}, ay: function (t) {
return this.attr("y", t)
}, build: function (t) {
return this._build = !!t, this
}, center: function (t, e, i = this.bbox()) {
return this.cx(t, i).cy(e, i)
}, cx: function (t, e = this.bbox()) {
return null == t ? e.cx : this.attr("x", this.attr("x") + t - e.cx)
}, cy: function (t, e = this.bbox()) {
return null == t ? e.cy : this.attr("y", this.attr("y") + t - e.cy)
}, length: function () {
return this.node.getComputedTextLength()
}, move: function (t, e, i = this.bbox()) {
return this.x(t, i).y(e, i)
}, plain: function (t) {
return !1 === this._build && this.clear(), this.node.appendChild(O.document.createTextNode(t)), this
}, x: function (t, e = this.bbox()) {
return null == t ? e.x : this.attr("x", this.attr("x") + t - e.x)
}, y: function (t, e = this.bbox()) {
return null == t ? e.y : this.attr("y", this.attr("y") + t - e.y)
}
});
class oi extends qt {
constructor(t, e = t) {
super(G("text", t), e), this.dom.leading = this.dom.leading ?? new _t(1.3), this._rebuild = !0, this._build = !1
}
leading(t) {
return null == t ? this.dom.leading : (this.dom.leading = new _t(t), this.rebuild())
}
rebuild(t) {
if ("boolean" == typeof t && (this._rebuild = t), this._rebuild) {
const t = this;
let e = 0;
const i = this.dom.leading;
this.each((function (a) {
if (X(this.node)) return;
const s = O.window.getComputedStyle(this.node).getPropertyValue("font-size"), r = i * new _t(s);
this.dom.newLined && (this.attr("x", t.attr("x")), "\n" === this.text() ? e += r : (this.attr("dy", a ? r + e : 0), e = 0))
})), this.fire("rebuild")
}
return this
}
setData(t) {
return this.dom = t, this.dom.leading = new _t(t.leading || 1.3), this
}
writeDataToDom() {
return R(this, this.dom, {leading: 1.3}), this
}
text(t) {
if (void 0 === t) {
const e = this.node.childNodes;
let i = 0;
t = "";
for (let a = 0, s = e.length; a < s; ++a) "textPath" === e[a].nodeName || X(e[a]) ? 0 === a && (i = a + 1) : (a !== i && 3 !== e[a].nodeType && !0 === V(e[a]).dom.newLined && (t += "\n"), t += e[a].textContent);
return t
}
if (this.clear().build(!0), "function" == typeof t) t.call(this, this); else for (let e = 0, i = (t = (t + "").split("\n")).length; e < i; e++) this.newLine(t[e]);
return this.build(!1).rebuild()
}
}
Q(oi, ni), A({
Container: {
text: K((function (t = "") {
return this.put(new oi).text(t)
})), plain: K((function (t = "") {
return this.put(new oi).plain(t)
}))
}
}), q(oi, "Text");
class li extends qt {
constructor(t, e = t) {
super(G("tspan", t), e), this._build = !1
}
dx(t) {
return this.attr("dx", t)
}
dy(t) {
return this.attr("dy", t)
}
newLine() {
this.dom.newLined = !0;
const t = this.parent();
if (!(t instanceof oi)) return this;
const e = t.index(this), i = O.window.getComputedStyle(this.node).getPropertyValue("font-size"),
a = t.dom.leading * new _t(i);
return this.dy(e ? a : 0).attr("x", t.x())
}
text(t) {
return null == t ? this.node.textContent + (this.dom.newLined ? "\n" : "") : ("function" == typeof t ? (this.clear().build(!0), t.call(this, this), this.build(!1)) : this.plain(t), this)
}
}
Q(li, ni), A({
Tspan: {
tspan: K((function (t = "") {
const e = new li;
return this._build || this.clear(), this.put(e).text(t)
}))
}, Text: {
newLine: function (t = "") {
return this.tspan(t).newLine()
}
}
}), q(li, "Tspan");
class hi extends qt {
constructor(t, e = t) {
super(G("circle", t), e)
}
radius(t) {
return this.attr("r", t)
}
rx(t) {
return this.attr("r", t)
}
ry(t) {
return this.rx(t)
}
size(t) {
return this.radius(new _t(t).divide(2))
}
}
Q(hi, {x: Jt, y: Qt, cx: Kt, cy: te, width: ee, height: ie}), A({
Container: {
circle: K((function (t = 0) {
return this.put(new hi).size(t).move(0, 0)
}))
}
}), q(hi, "Circle");
class ci extends Vt {
constructor(t, e = t) {
super(G("clipPath", t), e)
}
remove() {
return this.targets().forEach((function (t) {
t.unclip()
})), super.remove()
}
targets() {
return Lt("svg [clip-path*=" + this.id() + "]")
}
}
A({
Container: {
clip: K((function () {
return this.defs().put(new ci)
}))
}, Element: {
clipper() {
return this.reference("clip-path")
}, clipWith(t) {
const e = t instanceof ci ? t : this.parent().clip().add(t);
return this.attr("clip-path", "url(#" + e.id() + ")")
}, unclip() {
return this.attr("clip-path", null)
}
}
}), q(ci, "ClipPath");
class di extends Gt {
constructor(t, e = t) {
super(G("foreignObject", t), e)
}
}
A({
Container: {
foreignObject: K((function (t, e) {
return this.put(new di).size(t, e)
}))
}
}), q(di, "ForeignObject");
var ui = Object.freeze({
__proto__: null, dmove: function (t, e) {
return this.children().forEach((i => {
let a;
try {
a = i.node instanceof F().SVGSVGElement ? new kt(i.attr(["x", "y", "width", "height"])) : i.bbox()
} catch (t) {
return
}
const s = new vt(i), r = s.translate(t, e).transform(s.inverse()), n = new bt(a.x, a.y).transform(r);
i.move(n.x, n.y)
})), this
}, dx: function (t) {
return this.dmove(t, 0)
}, dy: function (t) {
return this.dmove(0, t)
}, height: function (t, e = this.bbox()) {
return null == t ? e.height : this.size(e.width, t, e)
}, move: function (t = 0, e = 0, i = this.bbox()) {
const a = t - i.x, s = e - i.y;
return this.dmove(a, s)
}, size: function (t, e, i = this.bbox()) {
const a = I(this, t, e, i), s = a.width / i.width, r = a.height / i.height;
return this.children().forEach((t => {
const e = new bt(i).transform(new vt(t).inverse());
t.scale(s, r, e.x, e.y)
})), this
}, width: function (t, e = this.bbox()) {
return null == t ? e.width : this.size(t, e.height, e)
}, x: function (t, e = this.bbox()) {
return null == t ? e.x : this.move(t, e.y, e)
}, y: function (t, e = this.bbox()) {
return null == t ? e.y : this.move(e.x, t, e)
}
});
class gi extends Vt {
constructor(t, e = t) {
super(G("g", t), e)
}
}
Q(gi, ui), A({
Container: {
group: K((function () {
return this.put(new gi)
}))
}
}), q(gi, "G");
class pi extends Vt {
constructor(t, e = t) {
super(G("a", t), e)
}
target(t) {
return this.attr("target", t)
}
to(t) {
return this.attr("href", t, H)
}
}
Q(pi, ui), A({
Container: {
link: K((function (t) {
return this.put(new pi).to(t)
}))
}, Element: {
unlink() {
const t = this.linker();
if (!t) return this;
const e = t.parent();
if (!e) return this.remove();
const i = e.index(t);
return e.add(this, i), t.remove(), this
}, linkTo(t) {
let e = this.linker();
return e || (e = new pi, this.wrap(e)), "function" == typeof t ? t.call(e, e) : e.to(t), this
}, linker() {
const t = this.parent();
return t && "a" === t.node.nodeName.toLowerCase() ? t : null
}
}
}), q(pi, "A");
class fi extends Vt {
constructor(t, e = t) {
super(G("mask", t), e)
}
remove() {
return this.targets().forEach((function (t) {
t.unmask()
})), super.remove()
}
targets() {
return Lt("svg [mask*=" + this.id() + "]")
}
}
A({
Container: {
mask: K((function () {
return this.defs().put(new fi)
}))
}, Element: {
masker() {
return this.reference("mask")
}, maskWith(t) {
const e = t instanceof fi ? t : this.parent().mask().add(t);
return this.attr("mask", "url(#" + e.id() + ")")
}, unmask() {
return this.attr("mask", null)
}
}
}), q(fi, "Mask");
class xi extends Gt {
constructor(t, e = t) {
super(G("stop", t), e)
}
update(t) {
return ("number" == typeof t || t instanceof _t) && (t = {
offset: arguments[0],
color: arguments[1],
opacity: arguments[2]
}), null != t.opacity && this.attr("stop-opacity", t.opacity), null != t.color && this.attr("stop-color", t.color), null != t.offset && this.attr("offset", new _t(t.offset)), this
}
}
A({
Gradient: {
stop: function (t, e, i) {
return this.put(new xi).update(t, e, i)
}
}
}), q(xi, "Stop");
class bi extends Gt {
constructor(t, e = t) {
super(G("style", t), e)
}
addText(t = "") {
return this.node.textContent += t, this
}
font(t, e, i = {}) {
return this.rule("@font-face", {fontFamily: t, src: e, ...i})
}
rule(t, e) {
return this.addText(function (t, e) {
if (!t) return "";
if (!e) return t;
let i = t + "{";
for (const t in e) i += t.replace(/([A-Z])/g, (function (t, e) {
return "-" + e.toLowerCase()
})) + ":" + e[t] + ";";
return i += "}", i
}(t, e))
}
}
A("Dom", {
style(t, e) {
return this.put(new bi).rule(t, e)
}, fontface(t, e, i) {
return this.put(new bi).font(t, e, i)
}
}), q(bi, "Style");
class mi extends oi {
constructor(t, e = t) {
super(G("textPath", t), e)
}
array() {
const t = this.track();
return t ? t.array() : null
}
plot(t) {
const e = this.track();
let i = null;
return e && (i = e.plot(t)), null == t ? i : this
}
track() {
return this.reference("href")
}
}
A({
Container: {
textPath: K((function (t, e) {
return t instanceof oi || (t = this.text(t)), t.path(e)
}))
}, Text: {
path: K((function (t, e = !0) {
const i = new mi;
let a;
if (t instanceof We || (t = this.defs().path(t)), i.attr("href", "#" + t, H), e) for (; a = this.node.firstChild;) i.node.appendChild(a);
return this.put(i)
})), textPath() {
return this.findOne("textPath")
}
}, Path: {
text: K((function (t) {
return t instanceof oi || (t = (new oi).addTo(this.parent()).text(t)), t.path(this)
})), targets() {
return Lt("svg textPath").filter((t => (t.attr("href") || "").includes(this.id())))
}
}
}), mi.prototype.MorphArray = Ee, q(mi, "TextPath");
class vi extends qt {
constructor(t, e = t) {
super(G("use", t), e)
}
use(t, e) {
return this.attr("href", (e || "") + "#" + t, H)
}
}
A({
Container: {
use: K((function (t, e) {
return this.put(new vi).use(t, e)
}))
}
}), q(vi, "Use");
const yi = B;
Q([si, ri, de, ce, be], C("viewbox")), Q([xe, je, Ge, We], C("marker")), Q(oi, C("Text")), Q(We, C("Path")), Q(Ut, C("Defs")), Q([oi, li], C("Tspan")), Q([Ve, se, he, Qe], C("radius")), Q(Rt, C("EventTarget")), Q(Bt, C("Dom")), Q(Gt, C("Element")), Q(qt, C("Shape")), Q([Vt, re], C("Container")), Q(he, C("Gradient")), Q(Qe, C("Runner")), Ct.extend([...new Set(k)]), function (t = []) {
Ne.push(...[].concat(t))
}([_t, xt, kt, vt, Dt, ge, Ee, bt]), Q(Ne, {
to(t) {
return (new He).type(this.constructor).from(this.toArray()).to(t)
}, fromArray(t) {
return this.init(t), this
}, toConsumable() {
return this.toArray()
}, morph(t, e, i, a, s) {
return this.fromArray(t.map((function (t, r) {
return a.step(t, e[r], i, s[r], s)
})))
}
});
class wi extends Gt {
constructor(t) {
super(G("filter", t), t), this.$source = "SourceGraphic", this.$sourceAlpha = "SourceAlpha", this.$background = "BackgroundImage", this.$backgroundAlpha = "BackgroundAlpha", this.$fill = "FillPaint", this.$stroke = "StrokePaint", this.$autoSetIn = !0
}
put(t, e) {
return !(t = super.put(t, e)).attr("in") && this.$autoSetIn && t.attr("in", this.$source), t.attr("result") || t.attr("result", t.id()), t
}
remove() {
return this.targets().each("unfilter"), super.remove()
}
targets() {
return Lt('svg [filter*="' + this.id() + '"]')
}
toString() {
return "url(#" + this.id() + ")"
}
}
class ki extends Gt {
constructor(t, e) {
super(t, e), this.result(this.id())
}
in(t) {
if (null == t) {
const t = this.attr("in");
return this.parent() && this.parent().find(`[result="${t}"]`)[0] || t
}
return this.attr("in", t)
}
result(t) {
return this.attr("result", t)
}
toString() {
return this.result()
}
}
const Ai = t => function (...e) {
for (let i = t.length; i--;) null != e[i] && this.attr(t[i], e[i])
}, Ci = {
blend: Ai(["in", "in2", "mode"]),
colorMatrix: Ai(["type", "values"]),
composite: Ai(["in", "in2", "operator"]),
convolveMatrix: function (t) {
t = new Dt(t).toString(), this.attr({order: Math.sqrt(t.split(" ").length), kernelMatrix: t})
},
diffuseLighting: Ai(["surfaceScale", "lightingColor", "diffuseConstant", "kernelUnitLength"]),
displacementMap: Ai(["in", "in2", "scale", "xChannelSelector", "yChannelSelector"]),
dropShadow: Ai(["in", "dx", "dy", "stdDeviation"]),
flood: Ai(["flood-color", "flood-opacity"]),
gaussianBlur: function (t = 0, e = t) {
this.attr("stdDeviation", t + " " + e)
},
image: function (t) {
this.attr("href", t, H)
},
morphology: Ai(["operator", "radius"]),
offset: Ai(["dx", "dy"]),
specularLighting: Ai(["surfaceScale", "lightingColor", "diffuseConstant", "specularExponent", "kernelUnitLength"]),
tile: Ai([]),
turbulence: Ai(["baseFrequency", "numOctaves", "seed", "stitchTiles", "type"])
};
["blend", "colorMatrix", "componentTransfer", "composite", "convolveMatrix", "diffuseLighting", "displacementMap", "dropShadow", "flood", "gaussianBlur", "image", "merge", "morphology", "offset", "specularLighting", "tile", "turbulence"].forEach((t => {
const e = P(t), i = Ci[t];
wi[e + "Effect"] = class extends ki {
constructor(t) {
super(G("fe" + e, t), t)
}
update(t) {
return i.apply(this, t), this
}
}, wi.prototype[t] = K((function (t, ...i) {
const a = new wi[e + "Effect"];
return null == t ? this.put(a) : ("function" == typeof t ? t.call(a, a) : i.unshift(t), this.put(a).update(i))
}))
})), Q(wi, {
merge(t) {
const e = this.put(new wi.MergeEffect);
if ("function" == typeof t) return t.call(e, e), e;
return (t instanceof Array ? t : [...arguments]).forEach((t => {
t instanceof wi.MergeNode ? e.put(t) : e.mergeNode(t)
})), e
}, componentTransfer(t = {}) {
const e = this.put(new wi.ComponentTransferEffect);
if ("function" == typeof t) return t.call(e, e), e;
if (!(t.r || t.g || t.b || t.a)) {
t = {r: t, g: t, b: t, a: t}
}
for (const i in t) e.add(new (wi["Func" + i.toUpperCase()])(t[i]));
return e
}
});
["distantLight", "pointLight", "spotLight", "mergeNode", "FuncR", "FuncG", "FuncB", "FuncA"].forEach((t => {
const e = P(t);
wi[e] = class extends ki {
constructor(t) {
super(G("fe" + e, t), t)
}
}
}));
["funcR", "funcG", "funcB", "funcA"].forEach((function (t) {
const e = wi[P(t)], i = K((function () {
return this.put(new e)
}));
wi.ComponentTransferEffect.prototype[t] = i
}));
["distantLight", "pointLight", "spotLight"].forEach((t => {
const e = wi[P(t)], i = K((function () {
return this.put(new e)
}));
wi.DiffuseLightingEffect.prototype[t] = i, wi.SpecularLightingEffect.prototype[t] = i
})), Q(wi.MergeEffect, {
mergeNode(t) {
return this.put(new wi.MergeNode).attr("in", t)
}
}), Q(Ut, {
filter: function (t) {
const e = this.put(new wi);
return "function" == typeof t && t.call(e, e), e
}
}), Q(Vt, {
filter: function (t) {
return this.defs().filter(t)
}
}), Q(Gt, {
filterWith: function (t) {
const e = t instanceof wi ? t : this.defs().filter(t);
return this.attr("filter", e)
}, unfilter: function (t) {
return this.attr("filter", null)
}, filterer() {
return this.reference("filter")
}
});
const Si = {
blend: function (t, e) {
return this.parent() && this.parent().blend(this, t, e)
}, colorMatrix: function (t, e) {
return this.parent() && this.parent().colorMatrix(t, e).in(this)
}, componentTransfer: function (t) {
return this.parent() && this.parent().componentTransfer(t).in(this)
}, composite: function (t, e) {
return this.parent() && this.parent().composite(this, t, e)
}, convolveMatrix: function (t) {
return this.parent() && this.parent().convolveMatrix(t).in(this)
}, diffuseLighting: function (t, e, i, a) {
return this.parent() && this.parent().diffuseLighting(t, i, a).in(this)
}, displacementMap: function (t, e, i, a) {
return this.parent() && this.parent().displacementMap(this, t, e, i, a)
}, dropShadow: function (t, e, i) {
return this.parent() && this.parent().dropShadow(this, t, e, i).in(this)
}, flood: function (t, e) {
return this.parent() && this.parent().flood(t, e)
}, gaussianBlur: function (t, e) {
return this.parent() && this.parent().gaussianBlur(t, e).in(this)
}, image: function (t) {
return this.parent() && this.parent().image(t)
}, merge: function (t) {
return t = t instanceof Array ? t : [...t], this.parent() && this.parent().merge(this, ...t)
}, morphology: function (t, e) {
return this.parent() && this.parent().morphology(t, e).in(this)
}, offset: function (t, e) {
return this.parent() && this.parent().offset(t, e).in(this)
}, specularLighting: function (t, e, i, a, s) {
return this.parent() && this.parent().specularLighting(t, i, a, s).in(this)
}, tile: function () {
return this.parent() && this.parent().tile().in(this)
}, turbulence: function (t, e, i, a, s) {
return this.parent() && this.parent().turbulence(t, e, i, a, s).in(this)
}
};
Q(ki, Si), Q(wi.MergeEffect, {
in: function (t) {
return t instanceof wi.MergeNode ? this.add(t, 0) : this.add((new wi.MergeNode).in(t), 0), this
}
}), Q([wi.CompositeEffect, wi.BlendEffect, wi.DisplacementMapEffect], {
in2: function (t) {
if (null == t) {
const t = this.attr("in2");
return this.parent() && this.parent().find(`[result="${t}"]`)[0] || t
}
return this.attr("in2", t)
}
}), wi.filter = {sepiatone: [.343, .669, .119, 0, 0, .249, .626, .13, 0, 0, .172, .334, .111, 0, 0, 0, 0, 0, 1, 0]};
var Li = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "getDefaultFilter", value: function (t, e) {
var i = this.w;
t.unfilter(!0), (new wi).size("120%", "180%", "-5%", "-40%"), i.config.chart.dropShadow.enabled && this.dropShadow(t, i.config.chart.dropShadow, e)
}
}, {
key: "applyFilter", value: function (t, e, i) {
var a, s = this, r = this.w;
if (t.unfilter(!0), "none" !== i) {
var n, o, l = r.config.chart.dropShadow, h = "lighten" === i ? 2 : .3;
if (t.filterWith((function (t) {
t.colorMatrix({
type: "matrix",
values: "\n ".concat(h, " 0 0 0 0\n 0 ").concat(h, " 0 0 0\n 0 0 ").concat(h, " 0 0\n 0 0 0 1 0\n "),
in: "SourceGraphic",
result: "brightness"
}), l.enabled && s.addShadow(t, e, l, "brightness")
})), !l.noUserSpaceOnUse) null === (n = t.filterer()) || void 0 === n || null === (o = n.node) || void 0 === o || o.setAttribute("filterUnits", "userSpaceOnUse");
this._scaleFilterSize(null === (a = t.filterer()) || void 0 === a ? void 0 : a.node)
} else this.getDefaultFilter(t, e)
}
}, {
key: "addShadow", value: function (t, e, i, a) {
var s, r = this.w, n = i.blur, o = i.top, l = i.left, h = i.color, c = i.opacity;
if (h = Array.isArray(h) ? h[e] : h, (null === (s = r.config.chart.dropShadow.enabledOnSeries) || void 0 === s ? void 0 : s.length) > 0 && -1 === r.config.chart.dropShadow.enabledOnSeries.indexOf(e)) return t;
t.offset({in: a, dx: l, dy: o, result: "offset"}), t.gaussianBlur({
in: "offset",
stdDeviation: n,
result: "blur"
}), t.flood({"flood-color": h, "flood-opacity": c, result: "flood"}), t.composite({
in: "flood",
in2: "blur",
operator: "in",
result: "shadow"
}), t.merge(["shadow", a])
}
}, {
key: "dropShadow", value: function (t, e) {
var i, a, s, r, n, o = this, l = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : 0,
h = this.w;
if (t.unfilter(!0), v.isMsEdge() && "radialBar" === h.config.chart.type) return t;
if ((null === (i = h.config.chart.dropShadow.enabledOnSeries) || void 0 === i ? void 0 : i.length) > 0 && -1 === (null === (s = h.config.chart.dropShadow.enabledOnSeries) || void 0 === s ? void 0 : s.indexOf(l))) return t;
(t.filterWith((function (t) {
o.addShadow(t, l, e, "SourceGraphic")
})), e.noUserSpaceOnUse) || (null === (r = t.filterer()) || void 0 === r || null === (n = r.node) || void 0 === n || n.setAttribute("filterUnits", "userSpaceOnUse"));
return this._scaleFilterSize(null === (a = t.filterer()) || void 0 === a ? void 0 : a.node), t
}
}, {
key: "setSelectionFilter", value: function (t, e, i) {
var a = this.w;
if (void 0 !== a.globals.selectedDataPoints[e] && a.globals.selectedDataPoints[e].indexOf(i) > -1) {
t.node.setAttribute("selected", !0);
var s = a.config.states.active.filter;
"none" !== s && this.applyFilter(t, e, s.type)
}
}
}, {
key: "_scaleFilterSize", value: function (t) {
if (t) {
!function (e) {
for (var i in e) e.hasOwnProperty(i) && t.setAttribute(i, e[i])
}({width: "200%", height: "200%", x: "-50%", y: "-50%"})
}
}
}]), t
}(), Mi = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "roundPathCorners", value: function (t, e) {
function i(t, e, i) {
var s = e.x - t.x, r = e.y - t.y, n = Math.sqrt(s * s + r * r);
return a(t, e, Math.min(1, i / n))
}
function a(t, e, i) {
return {x: t.x + (e.x - t.x) * i, y: t.y + (e.y - t.y) * i}
}
function s(t, e) {
t.length > 2 && (t[t.length - 2] = e.x, t[t.length - 1] = e.y)
}
function r(t) {
return {x: parseFloat(t[t.length - 2]), y: parseFloat(t[t.length - 1])}
}
t.indexOf("NaN") > -1 && (t = "");
var n = t.split(/[,\s]/).reduce((function (t, e) {
var i = e.match(/^([a-zA-Z])(.+)/);
return i ? (t.push(i[1]), t.push(i[2])) : t.push(e), t
}), []).reduce((function (t, e) {
return parseFloat(e) == e && t.length ? t[t.length - 1].push(e) : t.push([e]), t
}), []), o = [];
if (n.length > 1) {
var l = r(n[0]), h = null;
"Z" == n[n.length - 1][0] && n[0].length > 2 && (h = ["L", l.x, l.y], n[n.length - 1] = h), o.push(n[0]);
for (var c = 1; c < n.length; c++) {
var d = o[o.length - 1], u = n[c], g = u == h ? n[1] : n[c + 1];
if (g && d && d.length > 2 && "L" == u[0] && g.length > 2 && "L" == g[0]) {
var p, f, x = r(d), b = r(u), m = r(g);
p = i(b, x, e), f = i(b, m, e), s(u, p), u.origPoint = b, o.push(u);
var v = a(p, b, .5), y = a(b, f, .5), w = ["C", v.x, v.y, y.x, y.y, f.x, f.y];
w.origPoint = b, o.push(w)
} else o.push(u)
}
if (h) {
var k = r(o[o.length - 1]);
o.push(["Z"]), s(o[0], k)
}
} else o = n;
return o.reduce((function (t, e) {
return t + e.join(" ") + " "
}), "")
}
}, {
key: "drawLine", value: function (t, e, i, a) {
var s = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : "#a8a8a8",
r = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : 0,
n = arguments.length > 6 && void 0 !== arguments[6] ? arguments[6] : null,
o = arguments.length > 7 && void 0 !== arguments[7] ? arguments[7] : "butt";
return this.w.globals.dom.Paper.line().attr({
x1: t,
y1: e,
x2: i,
y2: a,
stroke: s,
"stroke-dasharray": r,
"stroke-width": n,
"stroke-linecap": o
})
}
}, {
key: "drawRect", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : 0,
e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : 0,
i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : 0,
a = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : 0,
s = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : 0,
r = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : "#fefefe",
n = arguments.length > 6 && void 0 !== arguments[6] ? arguments[6] : 1,
o = arguments.length > 7 && void 0 !== arguments[7] ? arguments[7] : null,
l = arguments.length > 8 && void 0 !== arguments[8] ? arguments[8] : null,
h = arguments.length > 9 && void 0 !== arguments[9] ? arguments[9] : 0,
c = this.w.globals.dom.Paper.rect();
return c.attr({
x: t,
y: e,
width: i > 0 ? i : 0,
height: a > 0 ? a : 0,
rx: s,
ry: s,
opacity: n,
"stroke-width": null !== o ? o : 0,
stroke: null !== l ? l : "none",
"stroke-dasharray": h
}), c.node.setAttribute("fill", r), c
}
}, {
key: "drawPolygon", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : "#e1e1e1",
i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : 1,
a = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : "none";
return this.w.globals.dom.Paper.polygon(t).attr({fill: a, stroke: e, "stroke-width": i})
}
}, {
key: "drawCircle", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : null;
t < 0 && (t = 0);
var i = this.w.globals.dom.Paper.circle(2 * t);
return null !== e && i.attr(e), i
}
}, {
key: "drawPath", value: function (t) {
var e = t.d, i = void 0 === e ? "" : e, a = t.stroke, s = void 0 === a ? "#a8a8a8" : a,
r = t.strokeWidth, n = void 0 === r ? 1 : r, o = t.fill, l = t.fillOpacity,
h = void 0 === l ? 1 : l, c = t.strokeOpacity, d = void 0 === c ? 1 : c, u = t.classes,
g = t.strokeLinecap, p = void 0 === g ? null : g, f = t.strokeDashArray, x = void 0 === f ? 0 : f,
b = this.w;
return null === p && (p = b.config.stroke.lineCap), (i.indexOf("undefined") > -1 || i.indexOf("NaN") > -1) && (i = "M 0 ".concat(b.globals.gridHeight)), b.globals.dom.Paper.path(i).attr({
fill: o,
"fill-opacity": h,
stroke: s,
"stroke-opacity": d,
"stroke-linecap": p,
"stroke-width": n,
"stroke-dasharray": x,
class: u
})
}
}, {
key: "group", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null,
e = this.w.globals.dom.Paper.group();
return null !== t && e.attr(t), e
}
}, {
key: "move", value: function (t, e) {
var i = ["M", t, e].join(" ");
return i
}
}, {
key: "line", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : null, a = null;
return null === i ? a = [" L", t, e].join(" ") : "H" === i ? a = [" H", t].join(" ") : "V" === i && (a = [" V", e].join(" ")), a
}
}, {
key: "curve", value: function (t, e, i, a, s, r) {
var n = ["C", t, e, i, a, s, r].join(" ");
return n
}
}, {
key: "quadraticCurve", value: function (t, e, i, a) {
return ["Q", t, e, i, a].join(" ")
}
}, {
key: "arc", value: function (t, e, i, a, s, r, n) {
var o = "A";
arguments.length > 7 && void 0 !== arguments[7] && arguments[7] && (o = "a");
var l = [o, t, e, i, a, s, r, n].join(" ");
return l
}
}, {
key: "renderPaths", value: function (t) {
var e, i = t.j, a = t.realIndex, s = t.pathFrom, r = t.pathTo, n = t.stroke, o = t.strokeWidth,
l = t.strokeLinecap, h = t.fill, c = t.animationDelay, d = t.initialSpeed, g = t.dataChangeSpeed,
p = t.className, f = t.chartType, x = t.shouldClipToGrid, b = void 0 === x || x,
m = t.bindEventsOnPaths, v = void 0 === m || m, w = t.drawShadow, k = void 0 === w || w, A = this.w,
C = new Li(this.ctx), S = new y(this.ctx), L = this.w.config.chart.animations.enabled,
M = L && this.w.config.chart.animations.dynamicAnimation.enabled;
if (s && s.startsWith("M 0 0") && r) {
var P = r.match(/^M\s+[\d.-]+\s+[\d.-]+/);
P && (s = s.replace(/^M\s+0\s+0/, P[0]))
}
var I = !!(L && !A.globals.resized || M && A.globals.dataChanged && A.globals.shouldAnimate);
I ? e = s : (e = r, A.globals.animationEnded = !0);
var T = A.config.stroke.dashArray, z = 0;
z = Array.isArray(T) ? T[a] : A.config.stroke.dashArray;
var X = this.drawPath({
d: e,
stroke: n,
strokeWidth: o,
fill: h,
fillOpacity: 1,
classes: p,
strokeLinecap: l,
strokeDashArray: z
});
X.attr("index", a), b && ("bar" === f && !A.globals.isHorizontal || A.globals.comboCharts ? X.attr({"clip-path": "url(#gridRectBarMask".concat(A.globals.cuid, ")")}) : X.attr({"clip-path": "url(#gridRectMask".concat(A.globals.cuid, ")")})), A.config.chart.dropShadow.enabled && k && C.dropShadow(X, A.config.chart.dropShadow, a), v && (X.node.addEventListener("mouseenter", this.pathMouseEnter.bind(this, X)), X.node.addEventListener("mouseleave", this.pathMouseLeave.bind(this, X)), X.node.addEventListener("mousedown", this.pathMouseDown.bind(this, X))), X.attr({
pathTo: r,
pathFrom: s
});
var R = {el: X, j: i, realIndex: a, pathFrom: s, pathTo: r, fill: h, strokeWidth: o, delay: c};
return !L || A.globals.resized || A.globals.dataChanged ? !A.globals.resized && A.globals.dataChanged || S.showDelayedElements() : S.animatePathsGradually(u(u({}, R), {}, {speed: d})), A.globals.dataChanged && M && I && S.animatePathsGradually(u(u({}, R), {}, {speed: g})), X
}
}, {
key: "drawPattern", value: function (t, e, i) {
var a = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : "#a8a8a8",
s = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : 0;
return this.w.globals.dom.Paper.pattern(e, i, (function (r) {
"horizontalLines" === t ? r.line(0, 0, i, 0).stroke({
color: a,
width: s + 1
}) : "verticalLines" === t ? r.line(0, 0, 0, e).stroke({
color: a,
width: s + 1
}) : "slantedLines" === t ? r.line(0, 0, e, i).stroke({
color: a,
width: s
}) : "squares" === t ? r.rect(e, i).fill("none").stroke({
color: a,
width: s
}) : "circles" === t && r.circle(e).fill("none").stroke({color: a, width: s})
}))
}
}, {
key: "drawGradient", value: function (t, e, i, a, s) {
var r, n = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : null,
o = arguments.length > 6 && void 0 !== arguments[6] ? arguments[6] : null,
l = arguments.length > 7 && void 0 !== arguments[7] ? arguments[7] : [],
h = arguments.length > 8 && void 0 !== arguments[8] ? arguments[8] : 0, c = this.w;
e.length < 9 && 0 === e.indexOf("#") && (e = v.hexToRgba(e, a)), i.length < 9 && 0 === i.indexOf("#") && (i = v.hexToRgba(i, s));
var d = 0, u = 1, g = 1, p = null;
null !== o && (d = void 0 !== o[0] ? o[0] / 100 : 0, u = void 0 !== o[1] ? o[1] / 100 : 1, g = void 0 !== o[2] ? o[2] / 100 : 1, p = void 0 !== o[3] ? o[3] / 100 : null);
var f = !("donut" !== c.config.chart.type && "pie" !== c.config.chart.type && "polarArea" !== c.config.chart.type && "bubble" !== c.config.chart.type);
if (r = l && 0 !== l.length ? c.globals.dom.Paper.gradient(f ? "radial" : "linear", (function (t) {
(Array.isArray(l[h]) ? l[h] : l).forEach((function (e) {
t.stop(e.offset / 100, e.color, e.opacity)
}))
})) : c.globals.dom.Paper.gradient(f ? "radial" : "linear", (function (t) {
t.stop(d, e, a), t.stop(u, i, s), t.stop(g, i, s), null !== p && t.stop(p, e, a)
})), f) {
var x = c.globals.gridWidth / 2, b = c.globals.gridHeight / 2;
"bubble" !== c.config.chart.type ? r.attr({
gradientUnits: "userSpaceOnUse",
cx: x,
cy: b,
r: n
}) : r.attr({cx: .5, cy: .5, r: .8, fx: .2, fy: .2})
} else "vertical" === t ? r.from(0, 0).to(0, 1) : "diagonal" === t ? r.from(0, 0).to(1, 1) : "horizontal" === t ? r.from(0, 1).to(1, 1) : "diagonal2" === t && r.from(1, 0).to(0, 1);
return r
}
}, {
key: "getTextBasedOnMaxWidth", value: function (t) {
var e = t.text, i = t.maxWidth, a = t.fontSize, s = t.fontFamily, r = this.getTextRects(e, a, s),
n = r.width / e.length, o = Math.floor(i / n);
return i < r.width ? e.slice(0, o - 3) + "..." : e
}
}, {
key: "drawText", value: function (t) {
var e = this, i = t.x, a = t.y, s = t.text, r = t.textAnchor, n = t.fontSize, o = t.fontFamily,
l = t.fontWeight, h = t.foreColor, c = t.opacity, d = t.maxWidth, g = t.cssClass,
p = void 0 === g ? "" : g, f = t.isPlainText, x = void 0 === f || f, b = t.dominantBaseline,
m = void 0 === b ? "auto" : b, v = this.w;
void 0 === s && (s = "");
var y = s;
r || (r = "start"), h && h.length || (h = v.config.chart.foreColor), o = o || v.config.chart.fontFamily, l = l || "regular";
var w, k = {maxWidth: d, fontSize: n = n || "11px", fontFamily: o};
return Array.isArray(s) ? w = v.globals.dom.Paper.text((function (t) {
for (var i = 0; i < s.length; i++) y = s[i], d && (y = e.getTextBasedOnMaxWidth(u({text: s[i]}, k))), 0 === i ? t.tspan(y) : t.tspan(y).newLine()
})) : (d && (y = this.getTextBasedOnMaxWidth(u({text: s}, k))), w = x ? v.globals.dom.Paper.plain(s) : v.globals.dom.Paper.text((function (t) {
return t.tspan(y)
}))), w.attr({
x: i,
y: a,
"text-anchor": r,
"dominant-baseline": m,
"font-size": n,
"font-family": o,
"font-weight": l,
fill: h,
class: "apexcharts-text " + p
}), w.node.style.fontFamily = o, w.node.style.opacity = c, w
}
}, {
key: "getMarkerPath", value: function (t, e, i, a) {
var s = "";
switch (i) {
case"cross":
s = "M ".concat(t - (a /= 1.4), " ").concat(e - a, " L ").concat(t + a, " ").concat(e + a, " M ").concat(t - a, " ").concat(e + a, " L ").concat(t + a, " ").concat(e - a);
break;
case"plus":
s = "M ".concat(t - (a /= 1.12), " ").concat(e, " L ").concat(t + a, " ").concat(e, " M ").concat(t, " ").concat(e - a, " L ").concat(t, " ").concat(e + a);
break;
case"star":
case"sparkle":
var r = 5;
a *= 1.15, "sparkle" === i && (a /= 1.1, r = 4);
for (var n = Math.PI / r, o = 0; o <= 2 * r; o++) {
var l = o * n, h = o % 2 == 0 ? a : a / 2;
s += (0 === o ? "M" : "L") + (t + h * Math.sin(l)) + "," + (e - h * Math.cos(l))
}
s += "Z";
break;
case"triangle":
s = "M ".concat(t, " ").concat(e - a, " \n L ").concat(t + a, " ").concat(e + a, " \n L ").concat(t - a, " ").concat(e + a, " \n Z");
break;
case"square":
case"rect":
s = "M ".concat(t - (a /= 1.125), " ").concat(e - a, " \n L ").concat(t + a, " ").concat(e - a, " \n L ").concat(t + a, " ").concat(e + a, " \n L ").concat(t - a, " ").concat(e + a, " \n Z");
break;
case"diamond":
a *= 1.05, s = "M ".concat(t, " ").concat(e - a, " \n L ").concat(t + a, " ").concat(e, " \n L ").concat(t, " ").concat(e + a, " \n L ").concat(t - a, " ").concat(e, " \n Z");
break;
case"line":
s = "M ".concat(t - (a /= 1.1), " ").concat(e, " \n L ").concat(t + a, " ").concat(e);
break;
default:
a *= 2, s = "M ".concat(t, ", ").concat(e, " \n m -").concat(a / 2, ", 0 \n a ").concat(a / 2, ",").concat(a / 2, " 0 1,0 ").concat(a, ",0 \n a ").concat(a / 2, ",").concat(a / 2, " 0 1,0 -").concat(a, ",0")
}
return s
}
}, {
key: "drawMarkerShape", value: function (t, e, i, a, s) {
var r = this.drawPath({
d: this.getMarkerPath(t, e, i, a, s),
stroke: s.pointStrokeColor,
strokeDashArray: s.pointStrokeDashArray,
strokeWidth: s.pointStrokeWidth,
fill: s.pointFillColor,
fillOpacity: s.pointFillOpacity,
strokeOpacity: s.pointStrokeOpacity
});
return r.attr({cx: t, cy: e, shape: s.shape, class: s.class ? s.class : ""}), r
}
}, {
key: "drawMarker", value: function (t, e, i) {
t = t || 0;
var a = i.pSize || 0;
return v.isNumber(e) || (a = 0, e = 0), this.drawMarkerShape(t, e, null == i ? void 0 : i.shape, a, u(u({}, i), "line" === i.shape || "plus" === i.shape || "cross" === i.shape ? {
pointStrokeColor: i.pointFillColor,
pointStrokeOpacity: i.pointFillOpacity
} : {}))
}
}, {
key: "pathMouseEnter", value: function (t, e) {
var i = this.w, a = new Li(this.ctx), s = parseInt(t.node.getAttribute("index"), 10),
r = parseInt(t.node.getAttribute("j"), 10);
if ("function" == typeof i.config.chart.events.dataPointMouseEnter && i.config.chart.events.dataPointMouseEnter(e, this.ctx, {
seriesIndex: s,
dataPointIndex: r,
w: i
}), this.ctx.events.fireEvent("dataPointMouseEnter", [e, this.ctx, {
seriesIndex: s,
dataPointIndex: r,
w: i
}]), ("none" === i.config.states.active.filter.type || "true" !== t.node.getAttribute("selected")) && "none" !== i.config.states.hover.filter.type && !i.globals.isTouchDevice) {
var n = i.config.states.hover.filter;
a.applyFilter(t, s, n.type)
}
}
}, {
key: "pathMouseLeave", value: function (t, e) {
var i = this.w, a = new Li(this.ctx), s = parseInt(t.node.getAttribute("index"), 10),
r = parseInt(t.node.getAttribute("j"), 10);
"function" == typeof i.config.chart.events.dataPointMouseLeave && i.config.chart.events.dataPointMouseLeave(e, this.ctx, {
seriesIndex: s,
dataPointIndex: r,
w: i
}), this.ctx.events.fireEvent("dataPointMouseLeave", [e, this.ctx, {
seriesIndex: s,
dataPointIndex: r,
w: i
}]), "none" !== i.config.states.active.filter.type && "true" === t.node.getAttribute("selected") || "none" !== i.config.states.hover.filter.type && a.getDefaultFilter(t, s)
}
}, {
key: "pathMouseDown", value: function (t, e) {
var i = this.w, a = new Li(this.ctx), s = parseInt(t.node.getAttribute("index"), 10),
r = parseInt(t.node.getAttribute("j"), 10), n = "false";
if ("true" === t.node.getAttribute("selected")) {
if (t.node.setAttribute("selected", "false"), i.globals.selectedDataPoints[s].indexOf(r) > -1) {
var o = i.globals.selectedDataPoints[s].indexOf(r);
i.globals.selectedDataPoints[s].splice(o, 1)
}
} else {
if (!i.config.states.active.allowMultipleDataPointsSelection && i.globals.selectedDataPoints.length > 0) {
i.globals.selectedDataPoints = [];
var l = i.globals.dom.Paper.find(".apexcharts-series path:not(.apexcharts-decoration-element)"),
h = i.globals.dom.Paper.find(".apexcharts-series circle:not(.apexcharts-decoration-element), .apexcharts-series rect:not(.apexcharts-decoration-element)"),
c = function (t) {
Array.prototype.forEach.call(t, (function (t) {
t.node.setAttribute("selected", "false"), a.getDefaultFilter(t, s)
}))
};
c(l), c(h)
}
t.node.setAttribute("selected", "true"), n = "true", void 0 === i.globals.selectedDataPoints[s] && (i.globals.selectedDataPoints[s] = []), i.globals.selectedDataPoints[s].push(r)
}
if ("true" === n) {
var d = i.config.states.active.filter;
if ("none" !== d) a.applyFilter(t, s, d.type); else if ("none" !== i.config.states.hover.filter && !i.globals.isTouchDevice) {
var u = i.config.states.hover.filter;
a.applyFilter(t, s, u.type)
}
} else if ("none" !== i.config.states.active.filter.type) if ("none" === i.config.states.hover.filter.type || i.globals.isTouchDevice) a.getDefaultFilter(t, s); else {
u = i.config.states.hover.filter;
a.applyFilter(t, s, u.type)
}
"function" == typeof i.config.chart.events.dataPointSelection && i.config.chart.events.dataPointSelection(e, this.ctx, {
selectedDataPoints: i.globals.selectedDataPoints,
seriesIndex: s,
dataPointIndex: r,
w: i
}), e && this.ctx.events.fireEvent("dataPointSelection", [e, this.ctx, {
selectedDataPoints: i.globals.selectedDataPoints,
seriesIndex: s,
dataPointIndex: r,
w: i
}])
}
}, {
key: "rotateAroundCenter", value: function (t) {
var e = {};
return t && "function" == typeof t.getBBox && (e = t.getBBox()), {
x: e.x + e.width / 2,
y: e.y + e.height / 2
}
}
}, {
key: "getTextRects", value: function (t, e, i, a) {
var s = !(arguments.length > 4 && void 0 !== arguments[4]) || arguments[4], r = this.w,
n = this.drawText({
x: -200,
y: -200,
text: t,
textAnchor: "start",
fontSize: e,
fontFamily: i,
foreColor: "#fff",
opacity: 0
});
a && n.attr("transform", a), r.globals.dom.Paper.add(n);
var o = n.bbox();
return s || (o = n.node.getBoundingClientRect()), n.remove(), {width: o.width, height: o.height}
}
}, {
key: "placeTextWithEllipsis", value: function (t, e, i) {
if ("function" == typeof t.getComputedTextLength && (t.textContent = e, e.length > 0 && t.getComputedTextLength() >= i / 1.1)) {
for (var a = e.length - 3; a > 0; a -= 3) if (t.getSubStringLength(0, a) <= i / 1.1) return void (t.textContent = e.substring(0, a) + "...");
t.textContent = "."
}
}
}], [{
key: "setAttrs", value: function (t, e) {
for (var i in e) e.hasOwnProperty(i) && t.setAttribute(i, e[i])
}
}]), t
}(), Pi = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "getStackedSeriesTotals", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : [], e = this.w, i = [];
if (0 === e.globals.series.length) return i;
for (var a = 0; a < e.globals.series[e.globals.maxValsInArrayIndex].length; a++) {
for (var s = 0, r = 0; r < e.globals.series.length; r++) void 0 !== e.globals.series[r][a] && -1 === t.indexOf(r) && (s += e.globals.series[r][a]);
i.push(s)
}
return i
}
}, {
key: "getSeriesTotalByIndex", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null;
return null === t ? this.w.config.series.reduce((function (t, e) {
return t + e
}), 0) : this.w.globals.series[t].reduce((function (t, e) {
return t + e
}), 0)
}
}, {
key: "getStackedSeriesTotalsByGroups", value: function () {
var t = this, e = this.w, i = [];
return e.globals.seriesGroups.forEach((function (a) {
var s = [];
e.config.series.forEach((function (t, i) {
a.indexOf(e.globals.seriesNames[i]) > -1 && s.push(i)
}));
var r = e.globals.series.map((function (t, e) {
return -1 === s.indexOf(e) ? e : -1
})).filter((function (t) {
return -1 !== t
}));
i.push(t.getStackedSeriesTotals(r))
})), i
}
}, {
key: "setSeriesYAxisMappings", value: function () {
var t = this.w.globals, e = this.w.config, i = [], a = [], s = [],
r = t.series.length > e.yaxis.length || e.yaxis.some((function (t) {
return Array.isArray(t.seriesName)
}));
e.series.forEach((function (t, e) {
s.push(e), a.push(null)
})), e.yaxis.forEach((function (t, e) {
i[e] = []
}));
var n = [];
e.yaxis.forEach((function (t, a) {
var o = !1;
if (t.seriesName) {
var l = [];
Array.isArray(t.seriesName) ? l = t.seriesName : l.push(t.seriesName), l.forEach((function (t) {
e.series.forEach((function (e, n) {
if (e.name === t) {
var l = n;
a === n || r ? !r || s.indexOf(n) > -1 ? i[a].push([a, n]) : console.warn("Series '" + e.name + "' referenced more than once in what looks like the new style. That is, when using either seriesName: [], or when there are more series than yaxes.") : (i[n].push([n, a]), l = a), o = !0, -1 !== (l = s.indexOf(l)) && s.splice(l, 1)
}
}))
}))
}
o || n.push(a)
})), i = i.map((function (t, e) {
var i = [];
return t.forEach((function (t) {
a[t[1]] = t[0], i.push(t[1])
})), i
}));
for (var o = e.yaxis.length - 1, l = 0; l < n.length && (o = n[l], i[o] = [], s); l++) {
var h = s[0];
s.shift(), i[o].push(h), a[h] = o
}
s.forEach((function (t) {
i[o].push(t), a[t] = o
})), t.seriesYAxisMap = i.map((function (t) {
return t
})), t.seriesYAxisReverseMap = a.map((function (t) {
return t
})), t.seriesYAxisMap.forEach((function (t, i) {
t.forEach((function (t) {
e.series[t] && void 0 === e.series[t].group && (e.series[t].group = "apexcharts-axis-".concat(i.toString()))
}))
}))
}
}, {
key: "isSeriesNull", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null;
return 0 === (null === t ? this.w.config.series.filter((function (t) {
return null !== t
})) : this.w.config.series[t].data.filter((function (t) {
return null !== t
}))).length
}
}, {
key: "seriesHaveSameValues", value: function (t) {
return this.w.globals.series[t].every((function (t, e, i) {
return t === i[0]
}))
}
}, {
key: "getCategoryLabels", value: function (t) {
var e = this.w, i = t.slice();
return e.config.xaxis.convertedCatToNumeric && (i = t.map((function (t, i) {
return e.config.xaxis.labels.formatter(t - e.globals.minX + 1)
}))), i
}
}, {
key: "getLargestSeries", value: function () {
var t = this.w;
t.globals.maxValsInArrayIndex = t.globals.series.map((function (t) {
return t.length
})).indexOf(Math.max.apply(Math, t.globals.series.map((function (t) {
return t.length
}))))
}
}, {
key: "getLargestMarkerSize", value: function () {
var t = this.w, e = 0;
return t.globals.markers.size.forEach((function (t) {
e = Math.max(e, t)
})), t.config.markers.discrete && t.config.markers.discrete.length && t.config.markers.discrete.forEach((function (t) {
e = Math.max(e, t.size)
})), e > 0 && (t.config.markers.hover.size > 0 ? e = t.config.markers.hover.size : e += t.config.markers.hover.sizeOffset), t.globals.markers.largestSize = e, e
}
}, {
key: "getSeriesTotals", value: function () {
var t = this.w;
t.globals.seriesTotals = t.globals.series.map((function (t, e) {
var i = 0;
if (Array.isArray(t)) for (var a = 0; a < t.length; a++) i += t[a]; else i += t;
return i
}))
}
}, {
key: "getSeriesTotalsXRange", value: function (t, e) {
var i = this.w;
return i.globals.series.map((function (a, s) {
for (var r = 0, n = 0; n < a.length; n++) i.globals.seriesX[s][n] > t && i.globals.seriesX[s][n] < e && (r += a[n]);
return r
}))
}
}, {
key: "getPercentSeries", value: function () {
var t = this.w;
t.globals.seriesPercent = t.globals.series.map((function (e, i) {
var a = [];
if (Array.isArray(e)) for (var s = 0; s < e.length; s++) {
var r = t.globals.stackedSeriesTotals[s], n = 0;
r && (n = 100 * e[s] / r), a.push(n)
} else {
var o = 100 * e / t.globals.seriesTotals.reduce((function (t, e) {
return t + e
}), 0);
a.push(o)
}
return a
}))
}
}, {
key: "getCalculatedRatios", value: function () {
var t, e, i, a = this, s = this.w, r = s.globals, n = [], o = 0, l = [], h = .1, c = 0;
if (r.yRange = [], r.isMultipleYAxis) for (var d = 0; d < r.minYArr.length; d++) r.yRange.push(Math.abs(r.minYArr[d] - r.maxYArr[d])), l.push(0); else r.yRange.push(Math.abs(r.minY - r.maxY));
r.xRange = Math.abs(r.maxX - r.minX), r.zRange = Math.abs(r.maxZ - r.minZ);
for (var u = 0; u < r.yRange.length; u++) n.push(r.yRange[u] / r.gridHeight);
if (e = r.xRange / r.gridWidth, t = r.yRange / r.gridWidth, i = r.xRange / r.gridHeight, (o = r.zRange / r.gridHeight * 16) || (o = 1), r.minY !== Number.MIN_VALUE && 0 !== Math.abs(r.minY) && (r.hasNegs = !0), s.globals.seriesYAxisReverseMap.length > 0) {
var g = function (t, e) {
var i = s.config.yaxis[s.globals.seriesYAxisReverseMap[e]], r = t < 0 ? -1 : 1;
return t = Math.abs(t), i.logarithmic && (t = a.getBaseLog(i.logBase, t)), -r * t / n[e]
};
if (r.isMultipleYAxis) {
l = [];
for (var p = 0; p < n.length; p++) l.push(g(r.minYArr[p], p))
} else (l = []).push(g(r.minY, 0)), r.minY !== Number.MIN_VALUE && 0 !== Math.abs(r.minY) && (h = -r.minY / t, c = r.minX / e)
} else (l = []).push(0), h = 0, c = 0;
return {
yRatio: n,
invertedYRatio: t,
zRatio: o,
xRatio: e,
invertedXRatio: i,
baseLineInvertedY: h,
baseLineY: l,
baseLineX: c
}
}
}, {
key: "getLogSeries", value: function (t) {
var e = this, i = this.w;
return i.globals.seriesLog = t.map((function (t, a) {
var s = i.globals.seriesYAxisReverseMap[a];
return i.config.yaxis[s] && i.config.yaxis[s].logarithmic ? t.map((function (t) {
return null === t ? null : e.getLogVal(i.config.yaxis[s].logBase, t, a)
})) : t
})), i.globals.invalidLogScale ? t : i.globals.seriesLog
}
}, {
key: "getLogValAtSeriesIndex", value: function (t, e) {
if (null === t) return null;
var i = this.w, a = i.globals.seriesYAxisReverseMap[e];
return i.config.yaxis[a] && i.config.yaxis[a].logarithmic ? this.getLogVal(i.config.yaxis[a].logBase, t, e) : t
}
}, {
key: "getBaseLog", value: function (t, e) {
return Math.log(e) / Math.log(t)
}
}, {
key: "getLogVal", value: function (t, e, i) {
if (e <= 0) return 0;
var a = this.w, s = 0 === a.globals.minYArr[i] ? -1 : this.getBaseLog(t, a.globals.minYArr[i]),
r = (0 === a.globals.maxYArr[i] ? 0 : this.getBaseLog(t, a.globals.maxYArr[i])) - s;
return e < 1 ? e / r : (this.getBaseLog(t, e) - s) / r
}
}, {
key: "getLogYRatios", value: function (t) {
var e = this, i = this.w, a = this.w.globals;
return a.yLogRatio = t.slice(), a.logYRange = a.yRange.map((function (t, s) {
var r = i.globals.seriesYAxisReverseMap[s];
if (i.config.yaxis[r] && e.w.config.yaxis[r].logarithmic) {
var n, o = -Number.MAX_VALUE, l = Number.MIN_VALUE;
return a.seriesLog.forEach((function (t, e) {
t.forEach((function (t) {
i.config.yaxis[e] && i.config.yaxis[e].logarithmic && (o = Math.max(t, o), l = Math.min(t, l))
}))
})), n = Math.pow(a.yRange[s], Math.abs(l - o) / a.yRange[s]), a.yLogRatio[s] = n / a.gridHeight, n
}
})), a.invalidLogScale ? t.slice() : a.yLogRatio
}
}, {
key: "drawSeriesByGroup", value: function (t, e, i, a) {
var s = this.w, r = [];
return t.series.length > 0 && e.forEach((function (e) {
var n = [], o = [];
t.i.forEach((function (i, a) {
s.config.series[i].group === e && (n.push(t.series[a]), o.push(i))
})), n.length > 0 && r.push(a.draw(n, i, o))
})), r
}
}], [{
key: "checkComboSeries", value: function (t, e) {
var i = !1, a = 0, s = 0;
return void 0 === e && (e = "line"), t.length && void 0 !== t[0].type && t.forEach((function (t) {
"bar" !== t.type && "column" !== t.type && "candlestick" !== t.type && "boxPlot" !== t.type || a++, void 0 !== t.type && t.type !== e && s++
})), s > 0 && (i = !0), {comboBarCount: a, comboCharts: i}
}
}, {
key: "extendArrayProps", value: function (t, e, i) {
var a, s, r, n, o, l;
(null !== (a = e) && void 0 !== a && a.yaxis && (e = t.extendYAxis(e, i)), null !== (s = e) && void 0 !== s && s.annotations) && (e.annotations.yaxis && (e = t.extendYAxisAnnotations(e)), null !== (r = e) && void 0 !== r && null !== (n = r.annotations) && void 0 !== n && n.xaxis && (e = t.extendXAxisAnnotations(e)), null !== (o = e) && void 0 !== o && null !== (l = o.annotations) && void 0 !== l && l.points && (e = t.extendPointAnnotations(e)));
return e
}
}]), t
}(), Ii = function () {
function t(e) {
i(this, t), this.w = e.w, this.annoCtx = e
}
return s(t, [{
key: "setOrientations", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : null, i = this.w;
if ("vertical" === t.label.orientation) {
var a = null !== e ? e : 0,
s = i.globals.dom.baseEl.querySelector(".apexcharts-xaxis-annotations .apexcharts-xaxis-annotation-label[rel='".concat(a, "']"));
if (null !== s) {
var r = s.getBoundingClientRect();
s.setAttribute("x", parseFloat(s.getAttribute("x")) - r.height + 4);
var n = "top" === t.label.position ? r.width : -r.width;
s.setAttribute("y", parseFloat(s.getAttribute("y")) + n);
var o = this.annoCtx.graphics.rotateAroundCenter(s), l = o.x, h = o.y;
s.setAttribute("transform", "rotate(-90 ".concat(l, " ").concat(h, ")"))
}
}
}
}, {
key: "addBackgroundToAnno", value: function (t, e) {
var i = this.w;
if (!t || !e.label.text || !String(e.label.text).trim()) return null;
var a = i.globals.dom.baseEl.querySelector(".apexcharts-grid").getBoundingClientRect(),
s = t.getBoundingClientRect(), r = e.label.style.padding, n = r.left, o = r.right, l = r.top,
h = r.bottom;
if ("vertical" === e.label.orientation) {
var c = [n, o, l, h];
l = c[0], h = c[1], n = c[2], o = c[3]
}
var d = s.left - a.left - n, u = s.top - a.top - l,
g = this.annoCtx.graphics.drawRect(d - i.globals.barPadForNumericAxis, u, s.width + n + o, s.height + l + h, e.label.borderRadius, e.label.style.background, 1, e.label.borderWidth, e.label.borderColor, 0);
return e.id && g.node.classList.add(e.id), g
}
}, {
key: "annotationsBackground", value: function () {
var t = this, e = this.w, i = function (i, a, s) {
var r = e.globals.dom.baseEl.querySelector(".apexcharts-".concat(s, "-annotations .apexcharts-").concat(s, "-annotation-label[rel='").concat(a, "']"));
if (r) {
var n = r.parentNode, o = t.addBackgroundToAnno(r, i);
o && (n.insertBefore(o.node, r), i.label.mouseEnter && o.node.addEventListener("mouseenter", i.label.mouseEnter.bind(t, i)), i.label.mouseLeave && o.node.addEventListener("mouseleave", i.label.mouseLeave.bind(t, i)), i.label.click && o.node.addEventListener("click", i.label.click.bind(t, i)))
}
};
e.config.annotations.xaxis.forEach((function (t, e) {
return i(t, e, "xaxis")
})), e.config.annotations.yaxis.forEach((function (t, e) {
return i(t, e, "yaxis")
})), e.config.annotations.points.forEach((function (t, e) {
return i(t, e, "point")
}))
}
}, {
key: "getY1Y2", value: function (t, e) {
var i, a = this.w, s = "y1" === t ? e.y : e.y2, r = !1;
if (this.annoCtx.invertAxis) {
var n = a.config.xaxis.convertedCatToNumeric ? a.globals.categoryLabels : a.globals.labels,
o = n.indexOf(s),
l = a.globals.dom.baseEl.querySelector(".apexcharts-yaxis-texts-g text:nth-child(".concat(o + 1, ")"));
i = l ? parseFloat(l.getAttribute("y")) : (a.globals.gridHeight / n.length - 1) * (o + 1) - a.globals.barHeight, void 0 !== e.seriesIndex && a.globals.barHeight && (i -= a.globals.barHeight / 2 * (a.globals.series.length - 1) - a.globals.barHeight * e.seriesIndex)
} else {
var h, c = a.globals.seriesYAxisMap[e.yAxisIndex][0],
d = a.config.yaxis[e.yAxisIndex].logarithmic ? new Pi(this.annoCtx.ctx).getLogVal(a.config.yaxis[e.yAxisIndex].logBase, s, c) / a.globals.yLogRatio[c] : (s - a.globals.minYArr[c]) / (a.globals.yRange[c] / a.globals.gridHeight);
i = a.globals.gridHeight - Math.min(Math.max(d, 0), a.globals.gridHeight), r = d > a.globals.gridHeight || d < 0, !e.marker || void 0 !== e.y && null !== e.y || (i = 0), null !== (h = a.config.yaxis[e.yAxisIndex]) && void 0 !== h && h.reversed && (i = d)
}
return "string" == typeof s && s.includes("px") && (i = parseFloat(s)), {yP: i, clipped: r}
}
}, {
key: "getX1X2", value: function (t, e) {
var i = this.w, a = "x1" === t ? e.x : e.x2,
s = this.annoCtx.invertAxis ? i.globals.minY : i.globals.minX,
r = this.annoCtx.invertAxis ? i.globals.maxY : i.globals.maxX,
n = this.annoCtx.invertAxis ? i.globals.yRange[0] : i.globals.xRange, o = !1,
l = this.annoCtx.inversedReversedAxis ? (r - a) / (n / i.globals.gridWidth) : (a - s) / (n / i.globals.gridWidth);
return "category" !== i.config.xaxis.type && !i.config.xaxis.convertedCatToNumeric || this.annoCtx.invertAxis || i.globals.dataFormatXNumeric || i.config.chart.sparkline.enabled || (l = this.getStringX(a)), "string" == typeof a && a.includes("px") && (l = parseFloat(a)), null == a && e.marker && (l = i.globals.gridWidth), void 0 !== e.seriesIndex && i.globals.barWidth && !this.annoCtx.invertAxis && (l -= i.globals.barWidth / 2 * (i.globals.series.length - 1) - i.globals.barWidth * e.seriesIndex), "number" != typeof l && (l = 0, o = !0), parseFloat(l.toFixed(10)) > parseFloat(i.globals.gridWidth.toFixed(10)) ? (l = i.globals.gridWidth, o = !0) : l < 0 && (l = 0, o = !0), {
x: l,
clipped: o
}
}
}, {
key: "getStringX", value: function (t) {
var e = this.w, i = t;
e.config.xaxis.convertedCatToNumeric && e.globals.categoryLabels.length && (t = e.globals.categoryLabels.indexOf(t) + 1);
var a = e.globals.labels.map((function (t) {
return Array.isArray(t) ? t.join(" ") : t
})).indexOf(t),
s = e.globals.dom.baseEl.querySelector(".apexcharts-xaxis-texts-g text:nth-child(".concat(a + 1, ")"));
return s && (i = parseFloat(s.getAttribute("x"))), i
}
}]), t
}(), Ti = function () {
function t(e) {
i(this, t), this.w = e.w, this.annoCtx = e, this.invertAxis = this.annoCtx.invertAxis, this.helpers = new Ii(this.annoCtx)
}
return s(t, [{
key: "addXaxisAnnotation", value: function (t, e, i) {
var a, s = this.w, r = this.helpers.getX1X2("x1", t), n = r.x, o = r.clipped, l = !0, h = t.label.text,
c = t.strokeDashArray;
if (v.isNumber(n)) {
if (null === t.x2 || void 0 === t.x2) {
if (!o) {
var d = this.annoCtx.graphics.drawLine(n + t.offsetX, 0 + t.offsetY, n + t.offsetX, s.globals.gridHeight + t.offsetY, t.borderColor, c, t.borderWidth);
e.appendChild(d.node), t.id && d.node.classList.add(t.id)
}
} else {
var u = this.helpers.getX1X2("x2", t);
if (a = u.x, l = u.clipped, a < n) {
var g = n;
n = a, a = g
}
var p = this.annoCtx.graphics.drawRect(n + t.offsetX, 0 + t.offsetY, a - n, s.globals.gridHeight + t.offsetY, 0, t.fillColor, t.opacity, 1, t.borderColor, c);
p.node.classList.add("apexcharts-annotation-rect"), p.attr("clip-path", "url(#gridRectMask".concat(s.globals.cuid, ")")), e.appendChild(p.node), t.id && p.node.classList.add(t.id)
}
if (!o || !l) {
var f = this.annoCtx.graphics.getTextRects(h, parseFloat(t.label.style.fontSize)),
x = "top" === t.label.position ? 4 : "center" === t.label.position ? s.globals.gridHeight / 2 + ("vertical" === t.label.orientation ? f.width / 2 : 0) : s.globals.gridHeight,
b = this.annoCtx.graphics.drawText({
x: n + t.label.offsetX,
y: x + t.label.offsetY - ("vertical" === t.label.orientation ? "top" === t.label.position ? f.width / 2 - 12 : -f.width / 2 : 0),
text: h,
textAnchor: t.label.textAnchor,
fontSize: t.label.style.fontSize,
fontFamily: t.label.style.fontFamily,
fontWeight: t.label.style.fontWeight,
foreColor: t.label.style.color,
cssClass: "apexcharts-xaxis-annotation-label ".concat(t.label.style.cssClass, " ").concat(t.id ? t.id : "")
});
b.attr({rel: i}), e.appendChild(b.node), this.annoCtx.helpers.setOrientations(t, i)
}
}
}
}, {
key: "drawXAxisAnnotations", value: function () {
var t = this, e = this.w, i = this.annoCtx.graphics.group({class: "apexcharts-xaxis-annotations"});
return e.config.annotations.xaxis.map((function (e, a) {
t.addXaxisAnnotation(e, i.node, a)
})), i
}
}]), t
}(), zi = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.months31 = [1, 3, 5, 7, 8, 10, 12], this.months30 = [2, 4, 6, 9, 11], this.daysCntOfYear = [0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334]
}
return s(t, [{
key: "isValidDate", value: function (t) {
return "number" != typeof t && !isNaN(this.parseDate(t))
}
}, {
key: "getTimeStamp", value: function (t) {
return Date.parse(t) ? this.w.config.xaxis.labels.datetimeUTC ? new Date(new Date(t).toISOString().substr(0, 25)).getTime() : new Date(t).getTime() : t
}
}, {
key: "getDate", value: function (t) {
return this.w.config.xaxis.labels.datetimeUTC ? new Date(new Date(t).toUTCString()) : new Date(t)
}
}, {
key: "parseDate", value: function (t) {
var e = Date.parse(t);
if (!isNaN(e)) return this.getTimeStamp(t);
var i = Date.parse(t.replace(/-/g, "/").replace(/[a-z]+/gi, " "));
return i = this.getTimeStamp(i)
}
}, {
key: "parseDateWithTimezone", value: function (t) {
return Date.parse(t.replace(/-/g, "/").replace(/[a-z]+/gi, " "))
}
}, {
key: "formatDate", value: function (t, e) {
var i = this.w.globals.locale, a = this.w.config.xaxis.labels.datetimeUTC,
s = ["\0"].concat(f(i.months)), r = ["\x01"].concat(f(i.shortMonths)),
n = ["\x02"].concat(f(i.days)), o = ["\x03"].concat(f(i.shortDays));
function l(t, e) {
var i = t + "";
for (e = e || 2; i.length < e;) i = "0" + i;
return i
}
var h = a ? t.getUTCFullYear() : t.getFullYear();
e = (e = (e = e.replace(/(^|[^\\])yyyy+/g, "$1" + h)).replace(/(^|[^\\])yy/g, "$1" + h.toString().substr(2, 2))).replace(/(^|[^\\])y/g, "$1" + h);
var c = (a ? t.getUTCMonth() : t.getMonth()) + 1;
e = (e = (e = (e = e.replace(/(^|[^\\])MMMM+/g, "$1" + s[0])).replace(/(^|[^\\])MMM/g, "$1" + r[0])).replace(/(^|[^\\])MM/g, "$1" + l(c))).replace(/(^|[^\\])M/g, "$1" + c);
var d = a ? t.getUTCDate() : t.getDate();
e = (e = (e = (e = e.replace(/(^|[^\\])dddd+/g, "$1" + n[0])).replace(/(^|[^\\])ddd/g, "$1" + o[0])).replace(/(^|[^\\])dd/g, "$1" + l(d))).replace(/(^|[^\\])d/g, "$1" + d);
var u = a ? t.getUTCHours() : t.getHours(), g = u > 12 ? u - 12 : 0 === u ? 12 : u;
e = (e = (e = (e = e.replace(/(^|[^\\])HH+/g, "$1" + l(u))).replace(/(^|[^\\])H/g, "$1" + u)).replace(/(^|[^\\])hh+/g, "$1" + l(g))).replace(/(^|[^\\])h/g, "$1" + g);
var p = a ? t.getUTCMinutes() : t.getMinutes();
e = (e = e.replace(/(^|[^\\])mm+/g, "$1" + l(p))).replace(/(^|[^\\])m/g, "$1" + p);
var x = a ? t.getUTCSeconds() : t.getSeconds();
e = (e = e.replace(/(^|[^\\])ss+/g, "$1" + l(x))).replace(/(^|[^\\])s/g, "$1" + x);
var b = a ? t.getUTCMilliseconds() : t.getMilliseconds();
e = e.replace(/(^|[^\\])fff+/g, "$1" + l(b, 3)), b = Math.round(b / 10), e = e.replace(/(^|[^\\])ff/g, "$1" + l(b)), b = Math.round(b / 10);
var m = u < 12 ? "AM" : "PM";
e = (e = (e = e.replace(/(^|[^\\])f/g, "$1" + b)).replace(/(^|[^\\])TT+/g, "$1" + m)).replace(/(^|[^\\])T/g, "$1" + m.charAt(0));
var v = m.toLowerCase();
e = (e = e.replace(/(^|[^\\])tt+/g, "$1" + v)).replace(/(^|[^\\])t/g, "$1" + v.charAt(0));
var y = -t.getTimezoneOffset(), w = a || !y ? "Z" : y > 0 ? "+" : "-";
if (!a) {
var k = (y = Math.abs(y)) % 60;
w += l(Math.floor(y / 60)) + ":" + l(k)
}
e = e.replace(/(^|[^\\])K/g, "$1" + w);
var A = (a ? t.getUTCDay() : t.getDay()) + 1;
return e = (e = (e = (e = (e = e.replace(new RegExp(n[0], "g"), n[A])).replace(new RegExp(o[0], "g"), o[A])).replace(new RegExp(s[0], "g"), s[c])).replace(new RegExp(r[0], "g"), r[c])).replace(/\\(.)/g, "$1")
}
}, {
key: "getTimeUnitsfromTimestamp", value: function (t, e, i) {
var a = this.w;
void 0 !== a.config.xaxis.min && (t = a.config.xaxis.min), void 0 !== a.config.xaxis.max && (e = a.config.xaxis.max);
var s = this.getDate(t), r = this.getDate(e),
n = this.formatDate(s, "yyyy MM dd HH mm ss fff").split(" "),
o = this.formatDate(r, "yyyy MM dd HH mm ss fff").split(" ");
return {
minMillisecond: parseInt(n[6], 10),
maxMillisecond: parseInt(o[6], 10),
minSecond: parseInt(n[5], 10),
maxSecond: parseInt(o[5], 10),
minMinute: parseInt(n[4], 10),
maxMinute: parseInt(o[4], 10),
minHour: parseInt(n[3], 10),
maxHour: parseInt(o[3], 10),
minDate: parseInt(n[2], 10),
maxDate: parseInt(o[2], 10),
minMonth: parseInt(n[1], 10) - 1,
maxMonth: parseInt(o[1], 10) - 1,
minYear: parseInt(n[0], 10),
maxYear: parseInt(o[0], 10)
}
}
}, {
key: "isLeapYear", value: function (t) {
return t % 4 == 0 && t % 100 != 0 || t % 400 == 0
}
}, {
key: "calculcateLastDaysOfMonth", value: function (t, e, i) {
return this.determineDaysOfMonths(t, e) - i
}
}, {
key: "determineDaysOfYear", value: function (t) {
var e = 365;
return this.isLeapYear(t) && (e = 366), e
}
}, {
key: "determineRemainingDaysOfYear", value: function (t, e, i) {
var a = this.daysCntOfYear[e] + i;
return e > 1 && this.isLeapYear() && a++, a
}
}, {
key: "determineDaysOfMonths", value: function (t, e) {
var i = 30;
switch (t = v.monthMod(t), !0) {
case this.months30.indexOf(t) > -1:
2 === t && (i = this.isLeapYear(e) ? 29 : 28);
break;
case this.months31.indexOf(t) > -1:
default:
i = 31
}
return i
}
}]), t
}(), Xi = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.tooltipKeyFormat = "dd MMM"
}
return s(t, [{
key: "xLabelFormat", value: function (t, e, i, a) {
var s = this.w;
if ("datetime" === s.config.xaxis.type && void 0 === s.config.xaxis.labels.formatter && void 0 === s.config.tooltip.x.formatter) {
var r = new zi(this.ctx);
return r.formatDate(r.getDate(e), s.config.tooltip.x.format)
}
return t(e, i, a)
}
}, {
key: "defaultGeneralFormatter", value: function (t) {
return Array.isArray(t) ? t.map((function (t) {
return t
})) : t
}
}, {
key: "defaultYFormatter", value: function (t, e, i) {
var a = this.w;
if (v.isNumber(t)) if (0 !== a.globals.yValueDecimal) t = t.toFixed(void 0 !== e.decimalsInFloat ? e.decimalsInFloat : a.globals.yValueDecimal); else {
var s = t.toFixed(0);
t = t == s ? s : t.toFixed(1)
}
return t
}
}, {
key: "setLabelFormatters", value: function () {
var t = this, e = this.w;
return e.globals.xaxisTooltipFormatter = function (e) {
return t.defaultGeneralFormatter(e)
}, e.globals.ttKeyFormatter = function (e) {
return t.defaultGeneralFormatter(e)
}, e.globals.ttZFormatter = function (t) {
return t
}, e.globals.legendFormatter = function (e) {
return t.defaultGeneralFormatter(e)
}, void 0 !== e.config.xaxis.labels.formatter ? e.globals.xLabelFormatter = e.config.xaxis.labels.formatter : e.globals.xLabelFormatter = function (t) {
if (v.isNumber(t)) {
if (!e.config.xaxis.convertedCatToNumeric && "numeric" === e.config.xaxis.type) {
if (v.isNumber(e.config.xaxis.decimalsInFloat)) return t.toFixed(e.config.xaxis.decimalsInFloat);
var i = e.globals.maxX - e.globals.minX;
return i > 0 && i < 100 ? t.toFixed(1) : t.toFixed(0)
}
if (e.globals.isBarHorizontal) if (e.globals.maxY - e.globals.minYArr < 4) return t.toFixed(1);
return t.toFixed(0)
}
return t
}, "function" == typeof e.config.tooltip.x.formatter ? e.globals.ttKeyFormatter = e.config.tooltip.x.formatter : e.globals.ttKeyFormatter = e.globals.xLabelFormatter, "function" == typeof e.config.xaxis.tooltip.formatter && (e.globals.xaxisTooltipFormatter = e.config.xaxis.tooltip.formatter), (Array.isArray(e.config.tooltip.y) || void 0 !== e.config.tooltip.y.formatter) && (e.globals.ttVal = e.config.tooltip.y), void 0 !== e.config.tooltip.z.formatter && (e.globals.ttZFormatter = e.config.tooltip.z.formatter), void 0 !== e.config.legend.formatter && (e.globals.legendFormatter = e.config.legend.formatter), e.config.yaxis.forEach((function (i, a) {
void 0 !== i.labels.formatter ? e.globals.yLabelFormatters[a] = i.labels.formatter : e.globals.yLabelFormatters[a] = function (s) {
return e.globals.xyCharts ? Array.isArray(s) ? s.map((function (e) {
return t.defaultYFormatter(e, i, a)
})) : t.defaultYFormatter(s, i, a) : s
}
})), e.globals
}
}, {
key: "heatmapLabelFormatters", value: function () {
var t = this.w;
if ("heatmap" === t.config.chart.type) {
t.globals.yAxisScale[0].result = t.globals.seriesNames.slice();
var e = t.globals.seriesNames.reduce((function (t, e) {
return t.length > e.length ? t : e
}), 0);
t.globals.yAxisScale[0].niceMax = e, t.globals.yAxisScale[0].niceMin = e
}
}
}]), t
}(), Ri = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "getLabel", value: function (t, e, i, a) {
var s = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : [],
r = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : "12px",
n = !(arguments.length > 6 && void 0 !== arguments[6]) || arguments[6], o = this.w,
l = void 0 === t[a] ? "" : t[a], h = l, c = o.globals.xLabelFormatter,
d = o.config.xaxis.labels.formatter, u = !1, g = new Xi(this.ctx), p = l;
n && (h = g.xLabelFormat(c, l, p, {
i: a,
dateFormatter: new zi(this.ctx).formatDate,
w: o
}), void 0 !== d && (h = d(l, t[a], {i: a, dateFormatter: new zi(this.ctx).formatDate, w: o})));
var f, x;
e.length > 0 ? (f = e[a].unit, x = null, e.forEach((function (t) {
"month" === t.unit ? x = "year" : "day" === t.unit ? x = "month" : "hour" === t.unit ? x = "day" : "minute" === t.unit && (x = "hour")
})), u = x === f, i = e[a].position, h = e[a].value) : "datetime" === o.config.xaxis.type && void 0 === d && (h = ""), void 0 === h && (h = ""), h = Array.isArray(h) ? h : h.toString();
var b = new Mi(this.ctx), m = {};
m = o.globals.rotateXLabels && n ? b.getTextRects(h, parseInt(r, 10), null, "rotate(".concat(o.config.xaxis.labels.rotate, " 0 0)"), !1) : b.getTextRects(h, parseInt(r, 10));
var v = !o.config.xaxis.labels.showDuplicates && this.ctx.timeScale;
return !Array.isArray(h) && ("NaN" === String(h) || s.indexOf(h) >= 0 && v) && (h = ""), {
x: i,
text: h,
textRect: m,
isBold: u
}
}
}, {
key: "checkLabelBasedOnTickamount", value: function (t, e, i) {
var a = this.w, s = a.config.xaxis.tickAmount;
return "dataPoints" === s && (s = Math.round(a.globals.gridWidth / 120)), s > i || t % Math.round(i / (s + 1)) == 0 || (e.text = ""), e
}
}, {
key: "checkForOverflowingLabels", value: function (t, e, i, a, s) {
var r = this.w;
if (0 === t && r.globals.skipFirstTimelinelabel && (e.text = ""), t === i - 1 && r.globals.skipLastTimelinelabel && (e.text = ""), r.config.xaxis.labels.hideOverlappingLabels && a.length > 0) {
var n = s[s.length - 1];
if (r.config.xaxis.labels.trim && "datetime" !== r.config.xaxis.type) return e;
e.x < n.textRect.width / (r.globals.rotateXLabels ? Math.abs(r.config.xaxis.labels.rotate) / 12 : 1.01) + n.x && (e.text = "")
}
return e
}
}, {
key: "checkForReversedLabels", value: function (t, e) {
var i = this.w;
return i.config.yaxis[t] && i.config.yaxis[t].reversed && e.reverse(), e
}
}, {
key: "yAxisAllSeriesCollapsed", value: function (t) {
var e = this.w.globals;
return !e.seriesYAxisMap[t].some((function (t) {
return -1 === e.collapsedSeriesIndices.indexOf(t)
}))
}
}, {
key: "translateYAxisIndex", value: function (t) {
var e = this.w, i = e.globals, a = e.config.yaxis;
return i.series.length > a.length || a.some((function (t) {
return Array.isArray(t.seriesName)
})) ? t : i.seriesYAxisReverseMap[t]
}
}, {
key: "isYAxisHidden", value: function (t) {
var e = this.w, i = e.config.yaxis[t];
if (!i.show || this.yAxisAllSeriesCollapsed(t)) return !0;
if (!i.showForNullSeries) {
var a = e.globals.seriesYAxisMap[t], s = new Pi(this.ctx);
return a.every((function (t) {
return s.isSeriesNull(t)
}))
}
return !1
}
}, {
key: "getYAxisForeColor", value: function (t, e) {
var i = this.w;
return Array.isArray(t) && i.globals.yAxisScale[e] && this.ctx.theme.pushExtraColors(t, i.globals.yAxisScale[e].result.length, !1), t
}
}, {
key: "drawYAxisTicks", value: function (t, e, i, a, s, r, n) {
var o = this.w, l = new Mi(this.ctx), h = o.globals.translateY + o.config.yaxis[s].labels.offsetY;
if (o.globals.isBarHorizontal ? h = 0 : "heatmap" === o.config.chart.type && (h += r / 2), a.show && e > 0) {
!0 === o.config.yaxis[s].opposite && (t += a.width);
for (var c = e; c >= 0; c--) {
var d = l.drawLine(t + i.offsetX - a.width + a.offsetX, h + a.offsetY, t + i.offsetX + a.offsetX, h + a.offsetY, a.color);
n.add(d), h += r
}
}
}
}]), t
}(), Ei = function () {
function t(e) {
i(this, t), this.w = e.w, this.annoCtx = e, this.helpers = new Ii(this.annoCtx), this.axesUtils = new Ri(this.annoCtx)
}
return s(t, [{
key: "addYaxisAnnotation", value: function (t, e, i) {
var a, s = this.w, r = t.strokeDashArray, n = this.helpers.getY1Y2("y1", t), o = n.yP, l = n.clipped,
h = !0, c = !1, d = t.label.text;
if (null === t.y2 || void 0 === t.y2) {
if (!l) {
c = !0;
var u = this.annoCtx.graphics.drawLine(0 + t.offsetX, o + t.offsetY, this._getYAxisAnnotationWidth(t), o + t.offsetY, t.borderColor, r, t.borderWidth);
e.appendChild(u.node), t.id && u.node.classList.add(t.id)
}
} else {
if (a = (n = this.helpers.getY1Y2("y2", t)).yP, h = n.clipped, a > o) {
var g = o;
o = a, a = g
}
if (!l || !h) {
c = !0;
var p = this.annoCtx.graphics.drawRect(0 + t.offsetX, a + t.offsetY, this._getYAxisAnnotationWidth(t), o - a, 0, t.fillColor, t.opacity, 1, t.borderColor, r);
p.node.classList.add("apexcharts-annotation-rect"), p.attr("clip-path", "url(#gridRectMask".concat(s.globals.cuid, ")")), e.appendChild(p.node), t.id && p.node.classList.add(t.id)
}
}
if (c) {
var f = "right" === t.label.position ? s.globals.gridWidth : "center" === t.label.position ? s.globals.gridWidth / 2 : 0,
x = this.annoCtx.graphics.drawText({
x: f + t.label.offsetX,
y: (null != a ? a : o) + t.label.offsetY - 3,
text: d,
textAnchor: t.label.textAnchor,
fontSize: t.label.style.fontSize,
fontFamily: t.label.style.fontFamily,
fontWeight: t.label.style.fontWeight,
foreColor: t.label.style.color,
cssClass: "apexcharts-yaxis-annotation-label ".concat(t.label.style.cssClass, " ").concat(t.id ? t.id : "")
});
x.attr({rel: i}), e.appendChild(x.node)
}
}
}, {
key: "_getYAxisAnnotationWidth", value: function (t) {
var e = this.w;
e.globals.gridWidth;
return (t.width.indexOf("%") > -1 ? e.globals.gridWidth * parseInt(t.width, 10) / 100 : parseInt(t.width, 10)) + t.offsetX
}
}, {
key: "drawYAxisAnnotations", value: function () {
var t = this, e = this.w, i = this.annoCtx.graphics.group({class: "apexcharts-yaxis-annotations"});
return e.config.annotations.yaxis.forEach((function (e, a) {
e.yAxisIndex = t.axesUtils.translateYAxisIndex(e.yAxisIndex), t.axesUtils.isYAxisHidden(e.yAxisIndex) && t.axesUtils.yAxisAllSeriesCollapsed(e.yAxisIndex) || t.addYaxisAnnotation(e, i.node, a)
})), i
}
}]), t
}(), Yi = function () {
function t(e) {
i(this, t), this.w = e.w, this.annoCtx = e, this.helpers = new Ii(this.annoCtx)
}
return s(t, [{
key: "addPointAnnotation", value: function (t, e, i) {
if (!(this.w.globals.collapsedSeriesIndices.indexOf(t.seriesIndex) > -1)) {
var a = this.helpers.getX1X2("x1", t), s = a.x, r = a.clipped,
n = (a = this.helpers.getY1Y2("y1", t)).yP, o = a.clipped;
if (v.isNumber(s) && !o && !r) {
var l = {
pSize: t.marker.size,
pointStrokeWidth: t.marker.strokeWidth,
pointFillColor: t.marker.fillColor,
pointStrokeColor: t.marker.strokeColor,
shape: t.marker.shape,
pRadius: t.marker.radius,
class: "apexcharts-point-annotation-marker ".concat(t.marker.cssClass, " ").concat(t.id ? t.id : "")
}, h = this.annoCtx.graphics.drawMarker(s + t.marker.offsetX, n + t.marker.offsetY, l);
e.appendChild(h.node);
var c = t.label.text ? t.label.text : "", d = this.annoCtx.graphics.drawText({
x: s + t.label.offsetX,
y: n + t.label.offsetY - t.marker.size - parseFloat(t.label.style.fontSize) / 1.6,
text: c,
textAnchor: t.label.textAnchor,
fontSize: t.label.style.fontSize,
fontFamily: t.label.style.fontFamily,
fontWeight: t.label.style.fontWeight,
foreColor: t.label.style.color,
cssClass: "apexcharts-point-annotation-label ".concat(t.label.style.cssClass, " ").concat(t.id ? t.id : "")
});
if (d.attr({rel: i}), e.appendChild(d.node), t.customSVG.SVG) {
var u = this.annoCtx.graphics.group({class: "apexcharts-point-annotations-custom-svg " + t.customSVG.cssClass});
u.attr({transform: "translate(".concat(s + t.customSVG.offsetX, ", ").concat(n + t.customSVG.offsetY, ")")}), u.node.innerHTML = t.customSVG.SVG, e.appendChild(u.node)
}
if (t.image.path) {
var g = t.image.width ? t.image.width : 20, p = t.image.height ? t.image.height : 20;
h = this.annoCtx.addImage({
x: s + t.image.offsetX - g / 2,
y: n + t.image.offsetY - p / 2,
width: g,
height: p,
path: t.image.path,
appendTo: ".apexcharts-point-annotations"
})
}
t.mouseEnter && h.node.addEventListener("mouseenter", t.mouseEnter.bind(this, t)), t.mouseLeave && h.node.addEventListener("mouseleave", t.mouseLeave.bind(this, t)), t.click && h.node.addEventListener("click", t.click.bind(this, t))
}
}
}
}, {
key: "drawPointAnnotations", value: function () {
var t = this, e = this.w, i = this.annoCtx.graphics.group({class: "apexcharts-point-annotations"});
return e.config.annotations.points.map((function (e, a) {
t.addPointAnnotation(e, i.node, a)
})), i
}
}]), t
}();
var Hi = {
name: "en",
options: {
months: ["January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"],
shortMonths: ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
days: ["Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"],
shortDays: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
toolbar: {
exportToSVG: "Download SVG",
exportToPNG: "Download PNG",
exportToCSV: "Download CSV",
menu: "Menu",
selection: "Selection",
selectionZoom: "Selection Zoom",
zoomIn: "Zoom In",
zoomOut: "Zoom Out",
pan: "Panning",
reset: "Reset Zoom"
}
}
}, Oi = function () {
function t() {
i(this, t), this.yAxis = {
show: !0,
showAlways: !1,
showForNullSeries: !0,
seriesName: void 0,
opposite: !1,
reversed: !1,
logarithmic: !1,
logBase: 10,
tickAmount: void 0,
stepSize: void 0,
forceNiceScale: !1,
max: void 0,
min: void 0,
floating: !1,
decimalsInFloat: void 0,
labels: {
show: !0,
showDuplicates: !1,
minWidth: 0,
maxWidth: 160,
offsetX: 0,
offsetY: 0,
align: void 0,
rotate: 0,
padding: 20,
style: {colors: [], fontSize: "11px", fontWeight: 400, fontFamily: void 0, cssClass: ""},
formatter: void 0
},
axisBorder: {show: !1, color: "#e0e0e0", width: 1, offsetX: 0, offsetY: 0},
axisTicks: {show: !1, color: "#e0e0e0", width: 6, offsetX: 0, offsetY: 0},
title: {
text: void 0,
rotate: -90,
offsetY: 0,
offsetX: 0,
style: {color: void 0, fontSize: "11px", fontWeight: 900, fontFamily: void 0, cssClass: ""}
},
tooltip: {enabled: !1, offsetX: 0},
crosshairs: {show: !0, position: "front", stroke: {color: "#b6b6b6", width: 1, dashArray: 0}}
}, this.pointAnnotation = {
id: void 0,
x: 0,
y: null,
yAxisIndex: 0,
seriesIndex: void 0,
mouseEnter: void 0,
mouseLeave: void 0,
click: void 0,
marker: {
size: 4,
fillColor: "#fff",
strokeWidth: 2,
strokeColor: "#333",
shape: "circle",
offsetX: 0,
offsetY: 0,
cssClass: ""
},
label: {
borderColor: "#c2c2c2",
borderWidth: 1,
borderRadius: 2,
text: void 0,
textAnchor: "middle",
offsetX: 0,
offsetY: 0,
mouseEnter: void 0,
mouseLeave: void 0,
click: void 0,
style: {
background: "#fff",
color: void 0,
fontSize: "11px",
fontFamily: void 0,
fontWeight: 400,
cssClass: "",
padding: {left: 5, right: 5, top: 2, bottom: 2}
}
},
customSVG: {SVG: void 0, cssClass: void 0, offsetX: 0, offsetY: 0},
image: {path: void 0, width: 20, height: 20, offsetX: 0, offsetY: 0}
}, this.yAxisAnnotation = {
id: void 0,
y: 0,
y2: null,
strokeDashArray: 1,
fillColor: "#c2c2c2",
borderColor: "#c2c2c2",
borderWidth: 1,
opacity: .3,
offsetX: 0,
offsetY: 0,
width: "100%",
yAxisIndex: 0,
label: {
borderColor: "#c2c2c2",
borderWidth: 1,
borderRadius: 2,
text: void 0,
textAnchor: "end",
position: "right",
offsetX: 0,
offsetY: -3,
mouseEnter: void 0,
mouseLeave: void 0,
click: void 0,
style: {
background: "#fff",
color: void 0,
fontSize: "11px",
fontFamily: void 0,
fontWeight: 400,
cssClass: "",
padding: {left: 5, right: 5, top: 2, bottom: 2}
}
}
}, this.xAxisAnnotation = {
id: void 0,
x: 0,
x2: null,
strokeDashArray: 1,
fillColor: "#c2c2c2",
borderColor: "#c2c2c2",
borderWidth: 1,
opacity: .3,
offsetX: 0,
offsetY: 0,
label: {
borderColor: "#c2c2c2",
borderWidth: 1,
borderRadius: 2,
text: void 0,
textAnchor: "middle",
orientation: "vertical",
position: "top",
offsetX: 0,
offsetY: 0,
mouseEnter: void 0,
mouseLeave: void 0,
click: void 0,
style: {
background: "#fff",
color: void 0,
fontSize: "11px",
fontFamily: void 0,
fontWeight: 400,
cssClass: "",
padding: {left: 5, right: 5, top: 2, bottom: 2}
}
}
}, this.text = {
x: 0,
y: 0,
text: "",
textAnchor: "start",
foreColor: void 0,
fontSize: "13px",
fontFamily: void 0,
fontWeight: 400,
appendTo: ".apexcharts-annotations",
backgroundColor: "transparent",
borderColor: "#c2c2c2",
borderRadius: 0,
borderWidth: 0,
paddingLeft: 4,
paddingRight: 4,
paddingTop: 2,
paddingBottom: 2
}
}
return s(t, [{
key: "init", value: function () {
return {
annotations: {
yaxis: [this.yAxisAnnotation],
xaxis: [this.xAxisAnnotation],
points: [this.pointAnnotation],
texts: [],
images: [],
shapes: []
},
chart: {
animations: {
enabled: !0,
speed: 800,
animateGradually: {delay: 150, enabled: !0},
dynamicAnimation: {enabled: !0, speed: 350}
},
background: "",
locales: [Hi],
defaultLocale: "en",
dropShadow: {
enabled: !1,
enabledOnSeries: void 0,
top: 2,
left: 2,
blur: 4,
color: "#000",
opacity: .7
},
events: {
animationEnd: void 0,
beforeMount: void 0,
mounted: void 0,
updated: void 0,
click: void 0,
mouseMove: void 0,
mouseLeave: void 0,
xAxisLabelClick: void 0,
legendClick: void 0,
markerClick: void 0,
selection: void 0,
dataPointSelection: void 0,
dataPointMouseEnter: void 0,
dataPointMouseLeave: void 0,
beforeZoom: void 0,
beforeResetZoom: void 0,
zoomed: void 0,
scrolled: void 0,
brushScrolled: void 0
},
foreColor: "#373d3f",
fontFamily: "Helvetica, Arial, sans-serif",
height: "auto",
parentHeightOffset: 15,
redrawOnParentResize: !0,
redrawOnWindowResize: !0,
id: void 0,
group: void 0,
nonce: void 0,
offsetX: 0,
offsetY: 0,
injectStyleSheet: !0,
selection: {
enabled: !1,
type: "x",
fill: {color: "#24292e", opacity: .1},
stroke: {width: 1, color: "#24292e", opacity: .4, dashArray: 3},
xaxis: {min: void 0, max: void 0},
yaxis: {min: void 0, max: void 0}
},
sparkline: {enabled: !1},
brush: {enabled: !1, autoScaleYaxis: !0, target: void 0, targets: void 0},
stacked: !1,
stackOnlyBar: !0,
stackType: "normal",
toolbar: {
show: !0,
offsetX: 0,
offsetY: 0,
tools: {
download: !0,
selection: !0,
zoom: !0,
zoomin: !0,
zoomout: !0,
pan: !0,
reset: !0,
customIcons: []
},
export: {
csv: {
filename: void 0,
columnDelimiter: ",",
headerCategory: "category",
headerValue: "value",
categoryFormatter: void 0,
valueFormatter: void 0
}, png: {filename: void 0}, svg: {filename: void 0}, scale: void 0, width: void 0
},
autoSelected: "zoom"
},
type: "line",
width: "100%",
zoom: {
enabled: !0,
type: "x",
autoScaleYaxis: !1,
allowMouseWheelZoom: !0,
zoomedArea: {
fill: {color: "#90CAF9", opacity: .4},
stroke: {color: "#0D47A1", opacity: .4, width: 1}
}
}
},
parsing: {x: void 0, y: void 0},
plotOptions: {
line: {
isSlopeChart: !1,
colors: {threshold: 0, colorAboveThreshold: void 0, colorBelowThreshold: void 0}
},
area: {fillTo: "origin"},
bar: {
horizontal: !1,
columnWidth: "70%",
barHeight: "70%",
distributed: !1,
borderRadius: 0,
borderRadiusApplication: "around",
borderRadiusWhenStacked: "last",
rangeBarOverlap: !0,
rangeBarGroupRows: !1,
hideZeroBarsWhenGrouped: !1,
isDumbbell: !1,
dumbbellColors: void 0,
isFunnel: !1,
isFunnel3d: !0,
colors: {
ranges: [],
backgroundBarColors: [],
backgroundBarOpacity: 1,
backgroundBarRadius: 0
},
dataLabels: {
position: "top",
maxItems: 100,
hideOverflowingLabels: !0,
orientation: "horizontal",
total: {
enabled: !1,
formatter: void 0,
offsetX: 0,
offsetY: 0,
style: {color: "#373d3f", fontSize: "12px", fontFamily: void 0, fontWeight: 600}
}
}
},
bubble: {zScaling: !0, minBubbleRadius: void 0, maxBubbleRadius: void 0},
candlestick: {colors: {upward: "#00B746", downward: "#EF403C"}, wick: {useFillColor: !0}},
boxPlot: {colors: {upper: "#00E396", lower: "#008FFB"}},
heatmap: {
radius: 2,
enableShades: !0,
shadeIntensity: .5,
reverseNegativeShade: !1,
distributed: !1,
useFillColorAsStroke: !1,
colorScale: {inverse: !1, ranges: [], min: void 0, max: void 0}
},
treemap: {
enableShades: !0,
shadeIntensity: .5,
distributed: !1,
reverseNegativeShade: !1,
useFillColorAsStroke: !1,
borderRadius: 4,
dataLabels: {format: "scale"},
colorScale: {inverse: !1, ranges: [], min: void 0, max: void 0},
seriesTitle: {
show: !0,
offsetY: 1,
offsetX: 1,
borderColor: "#000",
borderWidth: 1,
borderRadius: 2,
style: {
background: "rgba(0, 0, 0, 0.6)",
color: "#fff",
fontSize: "12px",
fontFamily: void 0,
fontWeight: 400,
cssClass: "",
padding: {left: 6, right: 6, top: 2, bottom: 2}
}
}
},
radialBar: {
inverseOrder: !1,
startAngle: 0,
endAngle: 360,
offsetX: 0,
offsetY: 0,
hollow: {
margin: 5,
size: "50%",
background: "transparent",
image: void 0,
imageWidth: 150,
imageHeight: 150,
imageOffsetX: 0,
imageOffsetY: 0,
imageClipped: !0,
position: "front",
dropShadow: {enabled: !1, top: 0, left: 0, blur: 3, color: "#000", opacity: .5}
},
track: {
show: !0,
startAngle: void 0,
endAngle: void 0,
background: "#f2f2f2",
strokeWidth: "97%",
opacity: 1,
margin: 5,
dropShadow: {enabled: !1, top: 0, left: 0, blur: 3, color: "#000", opacity: .5}
},
dataLabels: {
show: !0,
name: {
show: !0,
fontSize: "16px",
fontFamily: void 0,
fontWeight: 600,
color: void 0,
offsetY: 0,
formatter: function (t) {
return t
}
},
value: {
show: !0,
fontSize: "14px",
fontFamily: void 0,
fontWeight: 400,
color: void 0,
offsetY: 16,
formatter: function (t) {
return t + "%"
}
},
total: {
show: !1,
label: "Total",
fontSize: "16px",
fontWeight: 600,
fontFamily: void 0,
color: void 0,
formatter: function (t) {
return t.globals.seriesTotals.reduce((function (t, e) {
return t + e
}), 0) / t.globals.series.length + "%"
}
}
},
barLabels: {
enabled: !1,
offsetX: 0,
offsetY: 0,
useSeriesColors: !0,
fontFamily: void 0,
fontWeight: 600,
fontSize: "16px",
formatter: function (t) {
return t
},
onClick: void 0
}
},
pie: {
customScale: 1,
offsetX: 0,
offsetY: 0,
startAngle: 0,
endAngle: 360,
expandOnClick: !0,
dataLabels: {offset: 0, minAngleToShowLabel: 10},
donut: {
size: "65%",
background: "transparent",
labels: {
show: !1,
name: {
show: !0,
fontSize: "16px",
fontFamily: void 0,
fontWeight: 600,
color: void 0,
offsetY: -10,
formatter: function (t) {
return t
}
},
value: {
show: !0,
fontSize: "20px",
fontFamily: void 0,
fontWeight: 400,
color: void 0,
offsetY: 10,
formatter: function (t) {
return t
}
},
total: {
show: !1,
showAlways: !1,
label: "Total",
fontSize: "16px",
fontWeight: 400,
fontFamily: void 0,
color: void 0,
formatter: function (t) {
return t.globals.seriesTotals.reduce((function (t, e) {
return t + e
}), 0)
}
}
}
}
},
polarArea: {
rings: {strokeWidth: 1, strokeColor: "#e8e8e8"},
spokes: {strokeWidth: 1, connectorColors: "#e8e8e8"}
},
radar: {
size: void 0,
offsetX: 0,
offsetY: 0,
polygons: {
strokeWidth: 1,
strokeColors: "#e8e8e8",
connectorColors: "#e8e8e8",
fill: {colors: void 0}
}
}
},
colors: void 0,
dataLabels: {
enabled: !0,
enabledOnSeries: void 0,
formatter: function (t) {
return null !== t ? t : ""
},
textAnchor: "middle",
distributed: !1,
offsetX: 0,
offsetY: 0,
style: {fontSize: "12px", fontFamily: void 0, fontWeight: 600, colors: void 0},
background: {
enabled: !0,
foreColor: "#fff",
backgroundColor: void 0,
borderRadius: 2,
padding: 4,
opacity: .9,
borderWidth: 1,
borderColor: "#fff",
dropShadow: {enabled: !1, top: 1, left: 1, blur: 1, color: "#000", opacity: .8}
},
dropShadow: {enabled: !1, top: 1, left: 1, blur: 1, color: "#000", opacity: .8}
},
fill: {
type: "solid",
colors: void 0,
opacity: .85,
gradient: {
shade: "dark",
type: "horizontal",
shadeIntensity: .5,
gradientToColors: void 0,
inverseColors: !0,
opacityFrom: 1,
opacityTo: 1,
stops: [0, 50, 100],
colorStops: []
},
image: {src: [], width: void 0, height: void 0},
pattern: {style: "squares", width: 6, height: 6, strokeWidth: 2}
},
forecastDataPoints: {count: 0, fillOpacity: .5, strokeWidth: void 0, dashArray: 4},
grid: {
show: !0,
borderColor: "#e0e0e0",
strokeDashArray: 0,
position: "back",
xaxis: {lines: {show: !1}},
yaxis: {lines: {show: !0}},
row: {colors: void 0, opacity: .5},
column: {colors: void 0, opacity: .5},
padding: {top: 0, right: 10, bottom: 0, left: 12}
},
labels: [],
legend: {
show: !0,
showForSingleSeries: !1,
showForNullSeries: !0,
showForZeroSeries: !0,
floating: !1,
position: "bottom",
horizontalAlign: "center",
inverseOrder: !1,
fontSize: "12px",
fontFamily: void 0,
fontWeight: 400,
width: void 0,
height: void 0,
formatter: void 0,
tooltipHoverFormatter: void 0,
offsetX: -20,
offsetY: 4,
customLegendItems: [],
clusterGroupedSeries: !0,
clusterGroupedSeriesOrientation: "vertical",
labels: {colors: void 0, useSeriesColors: !1},
markers: {
size: 7,
fillColors: void 0,
strokeWidth: 1,
shape: void 0,
offsetX: 0,
offsetY: 0,
customHTML: void 0,
onClick: void 0
},
itemMargin: {horizontal: 5, vertical: 4},
onItemClick: {toggleDataSeries: !0},
onItemHover: {highlightDataSeries: !0}
},
markers: {
discrete: [],
size: 0,
colors: void 0,
strokeColors: "#fff",
strokeWidth: 2,
strokeOpacity: .9,
strokeDashArray: 0,
fillOpacity: 1,
shape: "circle",
offsetX: 0,
offsetY: 0,
showNullDataPoints: !0,
onClick: void 0,
onDblClick: void 0,
hover: {size: void 0, sizeOffset: 3}
},
noData: {
text: void 0,
align: "center",
verticalAlign: "middle",
offsetX: 0,
offsetY: 0,
style: {color: void 0, fontSize: "14px", fontFamily: void 0}
},
responsive: [],
series: void 0,
states: {
hover: {filter: {type: "lighten"}},
active: {allowMultipleDataPointsSelection: !1, filter: {type: "darken"}}
},
title: {
text: void 0,
align: "left",
margin: 5,
offsetX: 0,
offsetY: 0,
floating: !1,
style: {fontSize: "14px", fontWeight: 900, fontFamily: void 0, color: void 0}
},
subtitle: {
text: void 0,
align: "left",
margin: 5,
offsetX: 0,
offsetY: 30,
floating: !1,
style: {fontSize: "12px", fontWeight: 400, fontFamily: void 0, color: void 0}
},
stroke: {
show: !0,
curve: "smooth",
lineCap: "butt",
width: 2,
colors: void 0,
dashArray: 0,
fill: {
type: "solid",
colors: void 0,
opacity: .85,
gradient: {
shade: "dark",
type: "horizontal",
shadeIntensity: .5,
gradientToColors: void 0,
inverseColors: !0,
opacityFrom: 1,
opacityTo: 1,
stops: [0, 50, 100],
colorStops: []
}
}
},
tooltip: {
enabled: !0,
enabledOnSeries: void 0,
shared: !0,
hideEmptySeries: !1,
followCursor: !1,
intersect: !1,
inverseOrder: !1,
custom: void 0,
fillSeriesColor: !1,
theme: "light",
cssClass: "",
style: {fontSize: "12px", fontFamily: void 0},
onDatasetHover: {highlightDataSeries: !1},
x: {show: !0, format: "dd MMM", formatter: void 0},
y: {
formatter: void 0, title: {
formatter: function (t) {
return t ? t + ": " : ""
}
}
},
z: {formatter: void 0, title: "Size: "},
marker: {show: !0, fillColors: void 0},
items: {display: "flex"},
fixed: {enabled: !1, position: "topRight", offsetX: 0, offsetY: 0}
},
xaxis: {
type: "category",
categories: [],
convertedCatToNumeric: !1,
offsetX: 0,
offsetY: 0,
overwriteCategories: void 0,
labels: {
show: !0,
rotate: -45,
rotateAlways: !1,
hideOverlappingLabels: !0,
trim: !1,
minHeight: void 0,
maxHeight: 120,
showDuplicates: !0,
style: {colors: [], fontSize: "12px", fontWeight: 400, fontFamily: void 0, cssClass: ""},
offsetX: 0,
offsetY: 0,
format: void 0,
formatter: void 0,
datetimeUTC: !0,
datetimeFormatter: {
year: "yyyy",
month: "MMM 'yy",
day: "dd MMM",
hour: "HH:mm",
minute: "HH:mm:ss",
second: "HH:mm:ss"
}
},
group: {
groups: [],
style: {colors: [], fontSize: "12px", fontWeight: 400, fontFamily: void 0, cssClass: ""}
},
axisBorder: {show: !0, color: "#e0e0e0", width: "100%", height: 1, offsetX: 0, offsetY: 0},
axisTicks: {show: !0, color: "#e0e0e0", height: 6, offsetX: 0, offsetY: 0},
stepSize: void 0,
tickAmount: void 0,
tickPlacement: "on",
min: void 0,
max: void 0,
range: void 0,
floating: !1,
decimalsInFloat: void 0,
position: "bottom",
title: {
text: void 0,
offsetX: 0,
offsetY: 0,
style: {color: void 0, fontSize: "12px", fontWeight: 900, fontFamily: void 0, cssClass: ""}
},
crosshairs: {
show: !0,
width: 1,
position: "back",
opacity: .9,
stroke: {color: "#b6b6b6", width: 1, dashArray: 3},
fill: {
type: "solid",
color: "#B1B9C4",
gradient: {
colorFrom: "#D8E3F0",
colorTo: "#BED1E6",
stops: [0, 100],
opacityFrom: .4,
opacityTo: .5
}
},
dropShadow: {enabled: !1, left: 0, top: 0, blur: 1, opacity: .8}
},
tooltip: {
enabled: !0,
offsetY: 0,
formatter: void 0,
style: {fontSize: "12px", fontFamily: void 0}
}
},
yaxis: this.yAxis,
theme: {
mode: "",
palette: "palette1",
monochrome: {enabled: !1, color: "#008FFB", shadeTo: "light", shadeIntensity: .65}
}
}
}
}]), t
}(), Fi = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.graphics = new Mi(this.ctx), this.w.globals.isBarHorizontal && (this.invertAxis = !0), this.helpers = new Ii(this), this.xAxisAnnotations = new Ti(this), this.yAxisAnnotations = new Ei(this), this.pointsAnnotations = new Yi(this), this.w.globals.isBarHorizontal && this.w.config.yaxis[0].reversed && (this.inversedReversedAxis = !0), this.xDivision = this.w.globals.gridWidth / this.w.globals.dataPoints
}
return s(t, [{
key: "drawAxesAnnotations", value: function () {
var t = this.w;
if (t.globals.axisCharts && t.globals.dataPoints) {
for (var e = this.yAxisAnnotations.drawYAxisAnnotations(), i = this.xAxisAnnotations.drawXAxisAnnotations(), a = this.pointsAnnotations.drawPointAnnotations(), s = t.config.chart.animations.enabled, r = [e, i, a], n = [i.node, e.node, a.node], o = 0; o < 3; o++) t.globals.dom.elGraphical.add(r[o]), !s || t.globals.resized || t.globals.dataChanged || "scatter" !== t.config.chart.type && "bubble" !== t.config.chart.type && t.globals.dataPoints > 1 && n[o].classList.add("apexcharts-element-hidden"), t.globals.delayedElements.push({
el: n[o],
index: 0
});
this.helpers.annotationsBackground()
}
}
}, {
key: "drawImageAnnos", value: function () {
var t = this;
this.w.config.annotations.images.map((function (e, i) {
t.addImage(e, i)
}))
}
}, {
key: "drawTextAnnos", value: function () {
var t = this;
this.w.config.annotations.texts.map((function (e, i) {
t.addText(e, i)
}))
}
}, {
key: "addXaxisAnnotation", value: function (t, e, i) {
this.xAxisAnnotations.addXaxisAnnotation(t, e, i)
}
}, {
key: "addYaxisAnnotation", value: function (t, e, i) {
this.yAxisAnnotations.addYaxisAnnotation(t, e, i)
}
}, {
key: "addPointAnnotation", value: function (t, e, i) {
this.pointsAnnotations.addPointAnnotation(t, e, i)
}
}, {
key: "addText", value: function (t, e) {
var i = t.x, a = t.y, s = t.text, r = t.textAnchor, n = t.foreColor, o = t.fontSize, l = t.fontFamily,
h = t.fontWeight, c = t.cssClass, d = t.backgroundColor, u = t.borderWidth, g = t.strokeDashArray,
p = t.borderRadius, f = t.borderColor, x = t.appendTo, b = void 0 === x ? ".apexcharts-svg" : x,
m = t.paddingLeft, v = void 0 === m ? 4 : m, y = t.paddingRight, w = void 0 === y ? 4 : y,
k = t.paddingBottom, A = void 0 === k ? 2 : k, C = t.paddingTop, S = void 0 === C ? 2 : C,
L = this.w, M = this.graphics.drawText({
x: i,
y: a,
text: s,
textAnchor: r || "start",
fontSize: o || "12px",
fontWeight: h || "regular",
fontFamily: l || L.config.chart.fontFamily,
foreColor: n || L.config.chart.foreColor,
cssClass: c
}), P = L.globals.dom.baseEl.querySelector(b);
P && P.appendChild(M.node);
var I = M.bbox();
if (s) {
var T = this.graphics.drawRect(I.x - v, I.y - S, I.width + v + w, I.height + A + S, p, d || "transparent", 1, u, f, g);
P.insertBefore(T.node, M.node)
}
}
}, {
key: "addImage", value: function (t, e) {
var i = this.w, a = t.path, s = t.x, r = void 0 === s ? 0 : s, n = t.y, o = void 0 === n ? 0 : n,
l = t.width, h = void 0 === l ? 20 : l, c = t.height, d = void 0 === c ? 20 : c, u = t.appendTo,
g = void 0 === u ? ".apexcharts-svg" : u, p = i.globals.dom.Paper.image(a);
p.size(h, d).move(r, o);
var f = i.globals.dom.baseEl.querySelector(g);
return f && f.appendChild(p.node), p
}
}, {
key: "addXaxisAnnotationExternal", value: function (t, e, i) {
return this.addAnnotationExternal({
params: t,
pushToMemory: e,
context: i,
type: "xaxis",
contextMethod: i.addXaxisAnnotation
}), i
}
}, {
key: "addYaxisAnnotationExternal", value: function (t, e, i) {
return this.addAnnotationExternal({
params: t,
pushToMemory: e,
context: i,
type: "yaxis",
contextMethod: i.addYaxisAnnotation
}), i
}
}, {
key: "addPointAnnotationExternal", value: function (t, e, i) {
return void 0 === this.invertAxis && (this.invertAxis = i.w.globals.isBarHorizontal), this.addAnnotationExternal({
params: t,
pushToMemory: e,
context: i,
type: "point",
contextMethod: i.addPointAnnotation
}), i
}
}, {
key: "addAnnotationExternal", value: function (t) {
var e = t.params, i = t.pushToMemory, a = t.context, s = t.type, r = t.contextMethod, n = a, o = n.w,
l = o.globals.dom.baseEl.querySelector(".apexcharts-".concat(s, "-annotations")),
h = l.childNodes.length + 1, c = new Oi,
d = Object.assign({}, "xaxis" === s ? c.xAxisAnnotation : "yaxis" === s ? c.yAxisAnnotation : c.pointAnnotation),
u = v.extend(d, e);
switch (s) {
case"xaxis":
this.addXaxisAnnotation(u, l, h);
break;
case"yaxis":
this.addYaxisAnnotation(u, l, h);
break;
case"point":
this.addPointAnnotation(u, l, h)
}
var g = o.globals.dom.baseEl.querySelector(".apexcharts-".concat(s, "-annotations .apexcharts-").concat(s, "-annotation-label[rel='").concat(h, "']")),
p = this.helpers.addBackgroundToAnno(g, u);
return p && l.insertBefore(p.node, g), i && o.globals.memory.methodsToExec.push({
context: n,
id: u.id ? u.id : v.randomId(),
method: r,
label: "addAnnotation",
params: e
}), a
}
}, {
key: "clearAnnotations", value: function (t) {
for (var e = t.w, i = e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis-annotations, .apexcharts-xaxis-annotations, .apexcharts-point-annotations"), a = e.globals.memory.methodsToExec.length - 1; a >= 0; a--) "addText" !== e.globals.memory.methodsToExec[a].label && "addAnnotation" !== e.globals.memory.methodsToExec[a].label || e.globals.memory.methodsToExec.splice(a, 1);
i = v.listToArray(i), Array.prototype.forEach.call(i, (function (t) {
for (; t.firstChild;) t.removeChild(t.firstChild)
}))
}
}, {
key: "removeAnnotation", value: function (t, e) {
var i = t.w, a = i.globals.dom.baseEl.querySelectorAll(".".concat(e));
a && (i.globals.memory.methodsToExec.map((function (t, a) {
t.id === e && i.globals.memory.methodsToExec.splice(a, 1)
})), Object.keys(i.config.annotations).forEach((function (t) {
var a = i.config.annotations[t];
Array.isArray(a) && (i.config.annotations[t] = a.filter((function (t) {
return t.id !== e
})))
})), Array.prototype.forEach.call(a, (function (t) {
t.parentElement.removeChild(t)
})))
}
}]), t
}(), Di = function (t) {
var e, i = t.isTimeline, a = t.ctx, s = t.seriesIndex, r = t.dataPointIndex, n = t.y1, o = t.y2, l = t.w,
h = l.globals.seriesRangeStart[s][r], c = l.globals.seriesRangeEnd[s][r], d = l.globals.labels[r],
u = l.config.series[s].name ? l.config.series[s].name : "", g = l.globals.ttKeyFormatter,
p = l.config.tooltip.y.title.formatter, f = {w: l, seriesIndex: s, dataPointIndex: r, start: h, end: c};
("function" == typeof p && (u = p(u, f)), null !== (e = l.config.series[s].data[r]) && void 0 !== e && e.x && (d = l.config.series[s].data[r].x), i) || "datetime" === l.config.xaxis.type && (d = new Xi(a).xLabelFormat(l.globals.ttKeyFormatter, d, d, {
i: void 0,
dateFormatter: new zi(a).formatDate,
w: l
}));
"function" == typeof g && (d = g(d, f)), Number.isFinite(n) && Number.isFinite(o) && (h = n, c = o);
var x = "", b = "", m = l.globals.colors[s];
if (void 0 === l.config.tooltip.x.formatter) if ("datetime" === l.config.xaxis.type) {
var v = new zi(a);
x = v.formatDate(v.getDate(h), l.config.tooltip.x.format), b = v.formatDate(v.getDate(c), l.config.tooltip.x.format)
} else x = h, b = c; else x = l.config.tooltip.x.formatter(h), b = l.config.tooltip.x.formatter(c);
return {start: h, end: c, startVal: x, endVal: b, ylabel: d, color: m, seriesName: u}
}, _i = function (t) {
var e = t.color, i = t.seriesName, a = t.ylabel, s = t.start, r = t.end, n = t.seriesIndex,
o = t.dataPointIndex, l = t.ctx.tooltip.tooltipLabels.getFormatters(n);
s = l.yLbFormatter(s), r = l.yLbFormatter(r);
var h = l.yLbFormatter(t.w.globals.series[n][o]),
c = '\n '.concat(s, '\n - \n ').concat(r, "\n ");
return '
"
}, Ni = function () {
function t(e) {
i(this, t), this.opts = e
}
return s(t, [{
key: "hideYAxis", value: function () {
this.opts.yaxis[0].show = !1, this.opts.yaxis[0].title.text = "", this.opts.yaxis[0].axisBorder.show = !1, this.opts.yaxis[0].axisTicks.show = !1, this.opts.yaxis[0].floating = !0
}
}, {
key: "line", value: function () {
return {
dataLabels: {enabled: !1},
stroke: {width: 5, curve: "straight"},
markers: {size: 0, hover: {sizeOffset: 6}},
xaxis: {crosshairs: {width: 1}}
}
}
}, {
key: "sparkline", value: function (t) {
this.hideYAxis();
return v.extend(t, {
grid: {show: !1, padding: {left: 0, right: 0, top: 0, bottom: 0}},
legend: {show: !1},
xaxis: {labels: {show: !1}, tooltip: {enabled: !1}, axisBorder: {show: !1}, axisTicks: {show: !1}},
chart: {toolbar: {show: !1}, zoom: {enabled: !1}},
dataLabels: {enabled: !1}
})
}
}, {
key: "slope", value: function () {
return this.hideYAxis(), {
chart: {toolbar: {show: !1}, zoom: {enabled: !1}},
dataLabels: {
enabled: !0, formatter: function (t, e) {
var i = e.w.config.series[e.seriesIndex].name;
return null !== t ? i + ": " + t : ""
}, background: {enabled: !1}, offsetX: -5
},
grid: {xaxis: {lines: {show: !0}}, yaxis: {lines: {show: !1}}},
xaxis: {
position: "top",
labels: {style: {fontSize: 14, fontWeight: 900}},
tooltip: {enabled: !1},
crosshairs: {show: !1}
},
markers: {size: 8, hover: {sizeOffset: 1}},
legend: {show: !1},
tooltip: {shared: !1, intersect: !0, followCursor: !0},
stroke: {width: 5, curve: "straight"}
}
}
}, {
key: "bar", value: function () {
return {
chart: {stacked: !1},
plotOptions: {bar: {dataLabels: {position: "center"}}},
dataLabels: {style: {colors: ["#fff"]}, background: {enabled: !1}},
stroke: {width: 0, lineCap: "square"},
fill: {opacity: .85},
legend: {markers: {shape: "square"}},
tooltip: {shared: !1, intersect: !0},
xaxis: {
tooltip: {enabled: !1},
tickPlacement: "between",
crosshairs: {
width: "barWidth",
position: "back",
fill: {type: "gradient"},
dropShadow: {enabled: !1},
stroke: {width: 0}
}
}
}
}
}, {
key: "funnel", value: function () {
return this.hideYAxis(), u(u({}, this.bar()), {}, {
chart: {
animations: {
speed: 800,
animateGradually: {enabled: !1}
}
},
plotOptions: {
bar: {
horizontal: !0,
borderRadiusApplication: "around",
borderRadius: 0,
dataLabels: {position: "center"}
}
},
grid: {show: !1, padding: {left: 0, right: 0}},
xaxis: {labels: {show: !1}, tooltip: {enabled: !1}, axisBorder: {show: !1}, axisTicks: {show: !1}}
})
}
}, {
key: "candlestick", value: function () {
var t = this;
return {
stroke: {width: 1},
fill: {opacity: 1},
dataLabels: {enabled: !1},
tooltip: {
shared: !0, custom: function (e) {
var i = e.seriesIndex, a = e.dataPointIndex, s = e.w;
return t._getBoxTooltip(s, i, a, ["Open", "High", "", "Low", "Close"], "candlestick")
}
},
states: {active: {filter: {type: "none"}}},
xaxis: {crosshairs: {width: 1}}
}
}
}, {
key: "boxPlot", value: function () {
var t = this;
return {
chart: {animations: {dynamicAnimation: {enabled: !1}}},
stroke: {width: 1, colors: ["#24292e"]},
dataLabels: {enabled: !1},
tooltip: {
shared: !0, custom: function (e) {
var i = e.seriesIndex, a = e.dataPointIndex, s = e.w;
return t._getBoxTooltip(s, i, a, ["Minimum", "Q1", "Median", "Q3", "Maximum"], "boxPlot")
}
},
markers: {size: 7, strokeWidth: 1, strokeColors: "#111"},
xaxis: {crosshairs: {width: 1}}
}
}
}, {
key: "rangeBar", value: function () {
return {
chart: {animations: {animateGradually: !1}},
stroke: {width: 0, lineCap: "square"},
plotOptions: {bar: {borderRadius: 0, dataLabels: {position: "center"}}},
dataLabels: {
enabled: !1, formatter: function (t, e) {
e.ctx;
var i = e.seriesIndex, a = e.dataPointIndex, s = e.w, r = function () {
var t = s.globals.seriesRangeStart[i][a];
return s.globals.seriesRangeEnd[i][a] - t
};
return s.globals.comboCharts ? "rangeBar" === s.config.series[i].type || "rangeArea" === s.config.series[i].type ? r() : t : r()
}, background: {enabled: !1}, style: {colors: ["#fff"]}
},
markers: {size: 10},
tooltip: {
shared: !1, followCursor: !0, custom: function (t) {
return t.w.config.plotOptions && t.w.config.plotOptions.bar && t.w.config.plotOptions.bar.horizontal ? function (t) {
var e = Di(u(u({}, t), {}, {isTimeline: !0})), i = e.color, a = e.seriesName,
s = e.ylabel, r = e.startVal, n = e.endVal;
return _i(u(u({}, t), {}, {color: i, seriesName: a, ylabel: s, start: r, end: n}))
}(t) : function (t) {
var e = Di(t), i = e.color, a = e.seriesName, s = e.ylabel, r = e.start, n = e.end;
return _i(u(u({}, t), {}, {color: i, seriesName: a, ylabel: s, start: r, end: n}))
}(t)
}
},
xaxis: {tickPlacement: "between", tooltip: {enabled: !1}, crosshairs: {stroke: {width: 0}}}
}
}
}, {
key: "dumbbell", value: function (t) {
var e, i;
return null !== (e = t.plotOptions.bar) && void 0 !== e && e.barHeight || (t.plotOptions.bar.barHeight = 2), null !== (i = t.plotOptions.bar) && void 0 !== i && i.columnWidth || (t.plotOptions.bar.columnWidth = 2), t
}
}, {
key: "area", value: function () {
return {
stroke: {
width: 4,
fill: {
type: "solid",
gradient: {
inverseColors: !1,
shade: "light",
type: "vertical",
opacityFrom: .65,
opacityTo: .5,
stops: [0, 100, 100]
}
}
},
fill: {
type: "gradient",
gradient: {
inverseColors: !1,
shade: "light",
type: "vertical",
opacityFrom: .65,
opacityTo: .5,
stops: [0, 100, 100]
}
},
markers: {size: 0, hover: {sizeOffset: 6}},
tooltip: {followCursor: !1}
}
}
}, {
key: "rangeArea", value: function () {
return {
stroke: {curve: "straight", width: 0},
fill: {type: "solid", opacity: .6},
markers: {size: 0},
states: {hover: {filter: {type: "none"}}, active: {filter: {type: "none"}}},
tooltip: {
intersect: !1, shared: !0, followCursor: !0, custom: function (t) {
return function (t) {
var e = Di(t), i = e.color, a = e.seriesName, s = e.ylabel, r = e.start, n = e.end;
return _i(u(u({}, t), {}, {color: i, seriesName: a, ylabel: s, start: r, end: n}))
}(t)
}
}
}
}
}, {
key: "brush", value: function (t) {
return v.extend(t, {
chart: {toolbar: {autoSelected: "selection", show: !1}, zoom: {enabled: !1}},
dataLabels: {enabled: !1},
stroke: {width: 1},
tooltip: {enabled: !1},
xaxis: {tooltip: {enabled: !1}}
})
}
}, {
key: "stacked100", value: function (t) {
t.dataLabels = t.dataLabels || {}, t.dataLabels.formatter = t.dataLabels.formatter || void 0;
var e = t.dataLabels.formatter;
return t.yaxis.forEach((function (e, i) {
t.yaxis[i].min = 0, t.yaxis[i].max = 100
})), "bar" === t.chart.type && (t.dataLabels.formatter = e || function (t) {
return "number" == typeof t && t ? t.toFixed(0) + "%" : t
}), t
}
}, {
key: "stackedBars", value: function () {
var t = this.bar();
return u(u({}, t), {}, {
plotOptions: u(u({}, t.plotOptions), {}, {
bar: u(u({}, t.plotOptions.bar), {}, {
borderRadiusApplication: "end",
borderRadiusWhenStacked: "last"
})
})
})
}
}, {
key: "convertCatToNumeric", value: function (t) {
return t.xaxis.convertedCatToNumeric = !0, t
}
}, {
key: "convertCatToNumericXaxis", value: function (t, e, i) {
t.xaxis.type = "numeric", t.xaxis.labels = t.xaxis.labels || {}, t.xaxis.labels.formatter = t.xaxis.labels.formatter || function (t) {
return v.isNumber(t) ? Math.floor(t) : t
};
var a = t.xaxis.labels.formatter,
s = t.xaxis.categories && t.xaxis.categories.length ? t.xaxis.categories : t.labels;
return i && i.length && (s = i.map((function (t) {
return Array.isArray(t) ? t : String(t)
}))), s && s.length && (t.xaxis.labels.formatter = function (t) {
return v.isNumber(t) ? a(s[Math.floor(t) - 1]) : a(t)
}), t.xaxis.categories = [], t.labels = [], t.xaxis.tickAmount = t.xaxis.tickAmount || "dataPoints", t
}
}, {
key: "bubble", value: function () {
return {
dataLabels: {style: {colors: ["#fff"]}},
tooltip: {shared: !1, intersect: !0},
xaxis: {crosshairs: {width: 0}},
fill: {
type: "solid",
gradient: {shade: "light", inverse: !0, shadeIntensity: .55, opacityFrom: .4, opacityTo: .8}
}
}
}
}, {
key: "scatter", value: function () {
return {
dataLabels: {enabled: !1},
tooltip: {shared: !1, intersect: !0},
markers: {size: 6, strokeWidth: 1, hover: {sizeOffset: 2}}
}
}
}, {
key: "heatmap", value: function () {
return {
chart: {stacked: !1},
fill: {opacity: 1},
dataLabels: {style: {colors: ["#fff"]}},
stroke: {colors: ["#fff"]},
tooltip: {followCursor: !0, marker: {show: !1}, x: {show: !1}},
legend: {position: "top", markers: {shape: "square"}},
grid: {padding: {right: 20}}
}
}
}, {
key: "treemap", value: function () {
return {
chart: {zoom: {enabled: !1}},
dataLabels: {style: {fontSize: 14, fontWeight: 600, colors: ["#fff"]}},
stroke: {show: !0, width: 2, colors: ["#fff"]},
legend: {show: !1},
fill: {opacity: 1, gradient: {stops: [0, 100]}},
tooltip: {followCursor: !0, x: {show: !1}},
grid: {padding: {left: 0, right: 0}},
xaxis: {crosshairs: {show: !1}, tooltip: {enabled: !1}}
}
}
}, {
key: "pie", value: function () {
return {
chart: {toolbar: {show: !1}},
plotOptions: {pie: {donut: {labels: {show: !1}}}},
dataLabels: {
formatter: function (t) {
return t.toFixed(1) + "%"
}, style: {colors: ["#fff"]}, background: {enabled: !1}, dropShadow: {enabled: !0}
},
stroke: {colors: ["#fff"]},
fill: {opacity: 1, gradient: {shade: "light", stops: [0, 100]}},
tooltip: {theme: "dark", fillSeriesColor: !0},
legend: {position: "right"},
grid: {padding: {left: 0, right: 0, top: 0, bottom: 0}}
}
}
}, {
key: "donut", value: function () {
return {
chart: {toolbar: {show: !1}},
dataLabels: {
formatter: function (t) {
return t.toFixed(1) + "%"
}, style: {colors: ["#fff"]}, background: {enabled: !1}, dropShadow: {enabled: !0}
},
stroke: {colors: ["#fff"]},
fill: {
opacity: 1,
gradient: {shade: "light", shadeIntensity: .35, stops: [80, 100], opacityFrom: 1, opacityTo: 1}
},
tooltip: {theme: "dark", fillSeriesColor: !0},
legend: {position: "right"},
grid: {padding: {left: 0, right: 0, top: 0, bottom: 0}}
}
}
}, {
key: "polarArea", value: function () {
return {
chart: {toolbar: {show: !1}},
dataLabels: {
formatter: function (t) {
return t.toFixed(1) + "%"
}, enabled: !1
},
stroke: {show: !0, width: 2},
fill: {opacity: .7},
tooltip: {theme: "dark", fillSeriesColor: !0},
legend: {position: "right"},
grid: {padding: {left: 0, right: 0, top: 0, bottom: 0}}
}
}
}, {
key: "radar", value: function () {
return this.opts.yaxis[0].labels.offsetY = this.opts.yaxis[0].labels.offsetY ? this.opts.yaxis[0].labels.offsetY : 6, {
dataLabels: {
enabled: !1,
style: {fontSize: "11px"}
},
stroke: {width: 2},
markers: {size: 5, strokeWidth: 1, strokeOpacity: 1},
fill: {opacity: .2},
tooltip: {shared: !1, intersect: !0, followCursor: !0},
grid: {show: !1, padding: {left: 0, right: 0, top: 0, bottom: 0}},
xaxis: {
labels: {
formatter: function (t) {
return t
}, style: {colors: ["#a8a8a8"], fontSize: "11px"}
}, tooltip: {enabled: !1}, crosshairs: {show: !1}
}
}
}
}, {
key: "radialBar", value: function () {
return {
chart: {animations: {dynamicAnimation: {enabled: !0, speed: 800}}, toolbar: {show: !1}},
fill: {
gradient: {
shade: "dark",
shadeIntensity: .4,
inverseColors: !1,
type: "diagonal2",
opacityFrom: 1,
opacityTo: 1,
stops: [70, 98, 100]
}
},
legend: {show: !1, position: "right"},
tooltip: {enabled: !1, fillSeriesColor: !0},
grid: {padding: {left: 0, right: 0, top: 0, bottom: 0}}
}
}
}, {
key: "_getBoxTooltip", value: function (t, e, i, a, s) {
var r = t.globals.seriesCandleO[e][i], n = t.globals.seriesCandleH[e][i],
o = t.globals.seriesCandleM[e][i], l = t.globals.seriesCandleL[e][i],
h = t.globals.seriesCandleC[e][i];
return t.config.series[e].type && t.config.series[e].type !== s ? '\n '.concat(t.config.series[e].name ? t.config.series[e].name : "series-" + (e + 1), ": ").concat(t.globals.series[e][i], "\n
") : '"
}
}]), t
}(), Wi = function () {
function t(e) {
i(this, t), this.opts = e
}
return s(t, [{
key: "init", value: function (t) {
var e = t.responsiveOverride, i = this.opts, a = new Oi, s = new Ni(i);
this.chartType = i.chart.type, i = this.extendYAxis(i), i = this.extendAnnotations(i);
var r = a.init(), n = {};
if (i && "object" === b(i)) {
var o, l, h, c, d, u, g, p, f, x, m = {};
m = -1 !== ["line", "area", "bar", "candlestick", "boxPlot", "rangeBar", "rangeArea", "bubble", "scatter", "heatmap", "treemap", "pie", "polarArea", "donut", "radar", "radialBar"].indexOf(i.chart.type) ? s[i.chart.type]() : s.line(), null !== (o = i.plotOptions) && void 0 !== o && null !== (l = o.bar) && void 0 !== l && l.isFunnel && (m = s.funnel()), i.chart.stacked && "bar" === i.chart.type && (m = s.stackedBars()), null !== (h = i.chart.brush) && void 0 !== h && h.enabled && (m = s.brush(m)), null !== (c = i.plotOptions) && void 0 !== c && null !== (d = c.line) && void 0 !== d && d.isSlopeChart && (m = s.slope()), i.chart.stacked && "100%" === i.chart.stackType && (i = s.stacked100(i)), null !== (u = i.plotOptions) && void 0 !== u && null !== (g = u.bar) && void 0 !== g && g.isDumbbell && (i = s.dumbbell(i)), this.checkForDarkTheme(window.Apex), this.checkForDarkTheme(i), i.xaxis = i.xaxis || window.Apex.xaxis || {}, e || (i.xaxis.convertedCatToNumeric = !1), (null !== (p = (i = this.checkForCatToNumericXAxis(this.chartType, m, i)).chart.sparkline) && void 0 !== p && p.enabled || null !== (f = window.Apex.chart) && void 0 !== f && null !== (x = f.sparkline) && void 0 !== x && x.enabled) && (m = s.sparkline(m)), n = v.extend(r, m)
}
var y = v.extend(n, window.Apex);
return r = v.extend(y, i), r = this.handleUserInputErrors(r)
}
}, {
key: "checkForCatToNumericXAxis", value: function (t, e, i) {
var a, s, r = new Ni(i),
n = ("bar" === t || "boxPlot" === t) && (null === (a = i.plotOptions) || void 0 === a || null === (s = a.bar) || void 0 === s ? void 0 : s.horizontal),
o = "pie" === t || "polarArea" === t || "donut" === t || "radar" === t || "radialBar" === t || "heatmap" === t,
l = "datetime" !== i.xaxis.type && "numeric" !== i.xaxis.type,
h = i.xaxis.tickPlacement ? i.xaxis.tickPlacement : e.xaxis && e.xaxis.tickPlacement;
return n || o || !l || "between" === h || (i = r.convertCatToNumeric(i)), i
}
}, {
key: "extendYAxis", value: function (t, e) {
var i = new Oi;
(void 0 === t.yaxis || !t.yaxis || Array.isArray(t.yaxis) && 0 === t.yaxis.length) && (t.yaxis = {}), t.yaxis.constructor !== Array && window.Apex.yaxis && window.Apex.yaxis.constructor !== Array && (t.yaxis = v.extend(t.yaxis, window.Apex.yaxis)), t.yaxis.constructor !== Array ? t.yaxis = [v.extend(i.yAxis, t.yaxis)] : t.yaxis = v.extendArray(t.yaxis, i.yAxis);
var a = !1;
t.yaxis.forEach((function (t) {
t.logarithmic && (a = !0)
}));
var s = t.series;
return e && !s && (s = e.config.series), a && s.length !== t.yaxis.length && s.length && (t.yaxis = s.map((function (e, a) {
if (e.name || (s[a].name = "series-".concat(a + 1)), t.yaxis[a]) return t.yaxis[a].seriesName = s[a].name, t.yaxis[a];
var r = v.extend(i.yAxis, t.yaxis[0]);
return r.show = !1, r
}))), a && s.length > 1 && s.length !== t.yaxis.length && console.warn("A multi-series logarithmic chart should have equal number of series and y-axes"), t
}
}, {
key: "extendAnnotations", value: function (t) {
return void 0 === t.annotations && (t.annotations = {}, t.annotations.yaxis = [], t.annotations.xaxis = [], t.annotations.points = []), t = this.extendYAxisAnnotations(t), t = this.extendXAxisAnnotations(t), t = this.extendPointAnnotations(t)
}
}, {
key: "extendYAxisAnnotations", value: function (t) {
var e = new Oi;
return t.annotations.yaxis = v.extendArray(void 0 !== t.annotations.yaxis ? t.annotations.yaxis : [], e.yAxisAnnotation), t
}
}, {
key: "extendXAxisAnnotations", value: function (t) {
var e = new Oi;
return t.annotations.xaxis = v.extendArray(void 0 !== t.annotations.xaxis ? t.annotations.xaxis : [], e.xAxisAnnotation), t
}
}, {
key: "extendPointAnnotations", value: function (t) {
var e = new Oi;
return t.annotations.points = v.extendArray(void 0 !== t.annotations.points ? t.annotations.points : [], e.pointAnnotation), t
}
}, {
key: "checkForDarkTheme", value: function (t) {
t.theme && "dark" === t.theme.mode && (t.tooltip || (t.tooltip = {}), "light" !== t.tooltip.theme && (t.tooltip.theme = "dark"), t.chart.foreColor || (t.chart.foreColor = "#f6f7f8"), t.theme.palette || (t.theme.palette = "palette4"))
}
}, {
key: "handleUserInputErrors", value: function (t) {
var e = t;
if (e.tooltip.shared && e.tooltip.intersect) throw new Error("tooltip.shared cannot be enabled when tooltip.intersect is true. Turn off any other option by setting it to false.");
if ("bar" === e.chart.type && e.plotOptions.bar.horizontal) {
if (e.yaxis.length > 1) throw new Error("Multiple Y Axis for bars are not supported. Switch to column chart by setting plotOptions.bar.horizontal=false");
e.yaxis[0].reversed && (e.yaxis[0].opposite = !0), e.xaxis.tooltip.enabled = !1, e.yaxis[0].tooltip.enabled = !1, e.chart.zoom.enabled = !1
}
return "bar" !== e.chart.type && "rangeBar" !== e.chart.type || e.tooltip.shared && "barWidth" === e.xaxis.crosshairs.width && e.series.length > 1 && (e.xaxis.crosshairs.width = "tickWidth"), "candlestick" !== e.chart.type && "boxPlot" !== e.chart.type || e.yaxis[0].reversed && (console.warn("Reversed y-axis in ".concat(e.chart.type, " chart is not supported.")), e.yaxis[0].reversed = !1), e
}
}]), t
}(), Bi = function () {
function t() {
i(this, t)
}
return s(t, [{
key: "initGlobalVars", value: function (t) {
t.series = [], t.seriesCandleO = [], t.seriesCandleH = [], t.seriesCandleM = [], t.seriesCandleL = [], t.seriesCandleC = [], t.seriesRangeStart = [], t.seriesRangeEnd = [], t.seriesRange = [], t.seriesPercent = [], t.seriesGoals = [], t.seriesX = [], t.seriesZ = [], t.seriesNames = [], t.seriesTotals = [], t.seriesLog = [], t.seriesColors = [], t.stackedSeriesTotals = [], t.seriesXvalues = [], t.seriesYvalues = [], t.dataWasParsed = !1, t.originalSeries = null, t.labels = [], t.hasXaxisGroups = !1, t.groups = [], t.barGroups = [], t.lineGroups = [], t.areaGroups = [], t.hasSeriesGroups = !1, t.seriesGroups = [], t.categoryLabels = [], t.timescaleLabels = [], t.noLabelsProvided = !1, t.resizeTimer = null, t.selectionResizeTimer = null, t.lastWheelExecution = 0, t.delayedElements = [], t.pointsArray = [], t.dataLabelsRects = [], t.isXNumeric = !1, t.skipLastTimelinelabel = !1, t.skipFirstTimelinelabel = !1, t.isDataXYZ = !1, t.isMultiLineX = !1, t.isMultipleYAxis = !1, t.maxY = -Number.MAX_VALUE, t.minY = Number.MIN_VALUE, t.minYArr = [], t.maxYArr = [], t.maxX = -Number.MAX_VALUE, t.minX = Number.MAX_VALUE, t.initialMaxX = -Number.MAX_VALUE, t.initialMinX = Number.MAX_VALUE, t.maxDate = 0, t.minDate = Number.MAX_VALUE, t.minZ = Number.MAX_VALUE, t.maxZ = -Number.MAX_VALUE, t.minXDiff = Number.MAX_VALUE, t.yAxisScale = [], t.xAxisScale = null, t.xAxisTicksPositions = [], t.yLabelsCoords = [], t.yTitleCoords = [], t.barPadForNumericAxis = 0, t.padHorizontal = 0, t.xRange = 0, t.yRange = [], t.zRange = 0, t.dataPoints = 0, t.xTickAmount = 0, t.multiAxisTickAmount = 0
}
}, {
key: "globalVars", value: function (t) {
return {
chartID: null,
cuid: null,
events: {
beforeMount: [],
mounted: [],
updated: [],
clicked: [],
selection: [],
dataPointSelection: [],
zoomed: [],
scrolled: []
},
colors: [],
clientX: null,
clientY: null,
fill: {colors: []},
stroke: {colors: []},
dataLabels: {style: {colors: []}},
radarPolygons: {fill: {colors: []}},
markers: {colors: [], size: t.markers.size, largestSize: 0},
animationEnded: !1,
isTouchDevice: "ontouchstart" in window || navigator.msMaxTouchPoints,
isDirty: !1,
isExecCalled: !1,
initialConfig: null,
initialSeries: [],
lastXAxis: [],
lastYAxis: [],
columnSeries: null,
labels: [],
timescaleLabels: [],
noLabelsProvided: !1,
allSeriesCollapsed: !1,
collapsedSeries: [],
collapsedSeriesIndices: [],
ancillaryCollapsedSeries: [],
ancillaryCollapsedSeriesIndices: [],
risingSeries: [],
dataFormatXNumeric: !1,
capturedSeriesIndex: -1,
capturedDataPointIndex: -1,
selectedDataPoints: [],
invalidLogScale: !1,
ignoreYAxisIndexes: [],
maxValsInArrayIndex: 0,
radialSize: 0,
selection: void 0,
zoomEnabled: "zoom" === t.chart.toolbar.autoSelected && t.chart.toolbar.tools.zoom && t.chart.zoom.enabled,
panEnabled: "pan" === t.chart.toolbar.autoSelected && t.chart.toolbar.tools.pan,
selectionEnabled: "selection" === t.chart.toolbar.autoSelected && t.chart.toolbar.tools.selection,
yaxis: null,
mousedown: !1,
lastClientPosition: {},
visibleXRange: void 0,
yValueDecimal: 0,
total: 0,
SVGNS: "http://www.w3.org/2000/svg",
svgWidth: 0,
svgHeight: 0,
noData: !1,
locale: {},
dom: {},
memory: {methodsToExec: []},
shouldAnimate: !0,
skipLastTimelinelabel: !1,
skipFirstTimelinelabel: !1,
delayedElements: [],
axisCharts: !0,
isDataXYZ: !1,
isSlopeChart: t.plotOptions.line.isSlopeChart,
resized: !1,
resizeTimer: null,
comboCharts: !1,
dataChanged: !1,
previousPaths: [],
allSeriesHasEqualX: !0,
pointsArray: [],
dataLabelsRects: [],
lastDrawnDataLabelsIndexes: [],
hasNullValues: !1,
zoomed: !1,
gridWidth: 0,
gridHeight: 0,
rotateXLabels: !1,
defaultLabels: !1,
xLabelFormatter: void 0,
yLabelFormatters: [],
xaxisTooltipFormatter: void 0,
ttKeyFormatter: void 0,
ttVal: void 0,
ttZFormatter: void 0,
LINE_HEIGHT_RATIO: 1.618,
xAxisLabelsHeight: 0,
xAxisGroupLabelsHeight: 0,
xAxisLabelsWidth: 0,
yAxisLabelsWidth: 0,
scaleX: 1,
scaleY: 1,
translateX: 0,
translateY: 0,
translateYAxisX: [],
yAxisWidths: [],
translateXAxisY: 0,
translateXAxisX: 0,
tooltip: null,
niceScaleAllowedMagMsd: [[1, 1, 2, 5, 5, 5, 10, 10, 10, 10, 10], [1, 1, 2, 5, 5, 5, 10, 10, 10, 10, 10]],
niceScaleDefaultTicks: [1, 2, 4, 4, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 12, 12, 12, 12, 12, 12, 12, 12, 12, 24],
seriesYAxisMap: [],
seriesYAxisReverseMap: []
}
}
}, {
key: "init", value: function (t) {
var e = this.globalVars(t);
return this.initGlobalVars(e), e.initialConfig = v.extend({}, t), e.initialSeries = v.clone(t.series), e.lastXAxis = v.clone(e.initialConfig.xaxis), e.lastYAxis = v.clone(e.initialConfig.yaxis), e
}
}]), t
}(), Gi = function () {
function t(e) {
i(this, t), this.opts = e
}
return s(t, [{
key: "init", value: function () {
var t = new Wi(this.opts).init({responsiveOverride: !1});
return {config: t, globals: (new Bi).init(t)}
}
}]), t
}(), ji = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.opts = null, this.seriesIndex = 0, this.patternIDs = []
}
return s(t, [{
key: "clippedImgArea", value: function (t) {
var e = this.w, i = e.config, a = parseInt(e.globals.gridWidth, 10),
s = parseInt(e.globals.gridHeight, 10), r = a > s ? a : s, n = t.image, o = 0, l = 0;
void 0 === t.width && void 0 === t.height ? void 0 !== i.fill.image.width && void 0 !== i.fill.image.height ? (o = i.fill.image.width + 1, l = i.fill.image.height) : (o = r + 1, l = r) : (o = t.width, l = t.height);
var h = document.createElementNS(e.globals.SVGNS, "pattern");
Mi.setAttrs(h, {
id: t.patternID,
patternUnits: t.patternUnits ? t.patternUnits : "userSpaceOnUse",
width: o + "px",
height: l + "px"
});
var c = document.createElementNS(e.globals.SVGNS, "image");
h.appendChild(c), c.setAttributeNS(window.SVG.xlink, "href", n), Mi.setAttrs(c, {
x: 0,
y: 0,
preserveAspectRatio: "none",
width: o + "px",
height: l + "px"
}), c.style.opacity = t.opacity, e.globals.dom.elDefs.node.appendChild(h)
}
}, {
key: "getSeriesIndex", value: function (t) {
var e = this.w, i = e.config.chart.type;
return ("bar" === i || "rangeBar" === i) && e.config.plotOptions.bar.distributed || "heatmap" === i || "treemap" === i ? this.seriesIndex = t.seriesNumber : this.seriesIndex = t.seriesNumber % e.globals.series.length, this.seriesIndex
}
}, {
key: "computeColorStops", value: function (t, e) {
var i, a = this.w, s = null, n = null, o = r(t);
try {
for (o.s(); !(i = o.n()).done;) {
var l = i.value;
l >= e.threshold ? (null === s || l > s) && (s = l) : (null === n || l < n) && (n = l)
}
} catch (t) {
o.e(t)
} finally {
o.f()
}
null === s && (s = e.threshold), null === n && (n = e.threshold);
var h = s - e.threshold + (e.threshold - n);
0 === h && (h = 1);
var c = 100 - (e.threshold - n) / h * 100;
return [{
offset: c = Math.max(0, Math.min(c, 100)),
color: e.colorAboveThreshold,
opacity: a.config.fill.opacity
}, {offset: 0, color: e.colorBelowThreshold, opacity: a.config.fill.opacity}]
}
}, {
key: "fillPath", value: function (t) {
var e, i, a, s = this.w;
this.opts = t;
var r, n, o, l = this.w.config;
this.seriesIndex = this.getSeriesIndex(t);
var h = l.plotOptions.line.colors.colorAboveThreshold && l.plotOptions.line.colors.colorBelowThreshold,
c = this.getFillColors()[this.seriesIndex];
void 0 !== s.globals.seriesColors[this.seriesIndex] && (c = s.globals.seriesColors[this.seriesIndex]), "function" == typeof c && (c = c({
seriesIndex: this.seriesIndex,
dataPointIndex: t.dataPointIndex,
value: t.value,
w: s
}));
var d, u, g, p = t.fillType ? t.fillType : this.getFillType(this.seriesIndex),
x = Array.isArray(l.fill.opacity) ? l.fill.opacity[this.seriesIndex] : l.fill.opacity,
b = "gradient" === p || h;
(t.color && (c = t.color), null !== (e = s.config.series[this.seriesIndex]) && void 0 !== e && null !== (i = e.data) && void 0 !== i && null !== (a = i[t.dataPointIndex]) && void 0 !== a && a.fillColor) && (c = null === (d = s.config.series[this.seriesIndex]) || void 0 === d || null === (u = d.data) || void 0 === u || null === (g = u[t.dataPointIndex]) || void 0 === g ? void 0 : g.fillColor);
c || (c = "#fff", console.warn("undefined color - ApexCharts"));
var m = c;
if (-1 === c.indexOf("rgb") ? -1 === c.indexOf("#") ? m = c : c.length < 9 && (m = v.hexToRgba(c, x)) : c.indexOf("rgba") > -1 ? x = v.getOpacityFromRGBA(c) : m = v.hexToRgba(v.rgb2hex(c), x), t.opacity && (x = t.opacity), "pattern" === p && (n = this.handlePatternFill({
fillConfig: t.fillConfig,
patternFill: n,
fillColor: c,
fillOpacity: x,
defaultColor: m
})), b) {
var y = f(l.fill.gradient.colorStops) || [], w = l.fill.gradient.type;
h && (y[this.seriesIndex] = this.computeColorStops(s.globals.series[this.seriesIndex], l.plotOptions.line.colors), w = "vertical"), o = this.handleGradientFill({
type: w,
fillConfig: t.fillConfig,
fillColor: c,
fillOpacity: x,
colorStops: y,
i: this.seriesIndex
})
}
if ("image" === p) {
var k = l.fill.image.src, A = t.patternID ? t.patternID : "",
C = "pattern".concat(s.globals.cuid).concat(t.seriesNumber + 1).concat(A);
-1 === this.patternIDs.indexOf(C) && (this.clippedImgArea({
opacity: x,
image: Array.isArray(k) ? t.seriesNumber < k.length ? k[t.seriesNumber] : k[0] : k,
width: t.width ? t.width : void 0,
height: t.height ? t.height : void 0,
patternUnits: t.patternUnits,
patternID: C
}), this.patternIDs.push(C)), r = "url(#".concat(C, ")")
} else r = b ? o : "pattern" === p ? n : m;
return t.solid && (r = m), r
}
}, {
key: "getFillType", value: function (t) {
var e = this.w;
return Array.isArray(e.config.fill.type) ? e.config.fill.type[t] : e.config.fill.type
}
}, {
key: "getFillColors", value: function () {
var t = this.w, e = t.config, i = this.opts, a = [];
return t.globals.comboCharts ? "line" === t.config.series[this.seriesIndex].type ? Array.isArray(t.globals.stroke.colors) ? a = t.globals.stroke.colors : a.push(t.globals.stroke.colors) : Array.isArray(t.globals.fill.colors) ? a = t.globals.fill.colors : a.push(t.globals.fill.colors) : "line" === e.chart.type ? Array.isArray(t.globals.stroke.colors) ? a = t.globals.stroke.colors : a.push(t.globals.stroke.colors) : Array.isArray(t.globals.fill.colors) ? a = t.globals.fill.colors : a.push(t.globals.fill.colors), void 0 !== i.fillColors && (a = [], Array.isArray(i.fillColors) ? a = i.fillColors.slice() : a.push(i.fillColors)), a
}
}, {
key: "handlePatternFill", value: function (t) {
var e = t.fillConfig, i = t.patternFill, a = t.fillColor, s = t.fillOpacity, r = t.defaultColor,
n = this.w.config.fill;
e && (n = e);
var o = this.opts, l = new Mi(this.ctx),
h = Array.isArray(n.pattern.strokeWidth) ? n.pattern.strokeWidth[this.seriesIndex] : n.pattern.strokeWidth,
c = a;
Array.isArray(n.pattern.style) ? i = void 0 !== n.pattern.style[o.seriesNumber] ? l.drawPattern(n.pattern.style[o.seriesNumber], n.pattern.width, n.pattern.height, c, h, s) : r : i = l.drawPattern(n.pattern.style, n.pattern.width, n.pattern.height, c, h, s);
return i
}
}, {
key: "handleGradientFill", value: function (t) {
var e = t.type, i = t.fillColor, a = t.fillOpacity, s = t.fillConfig, r = t.colorStops, n = t.i,
o = this.w.config.fill;
s && (o = u(u({}, o), s));
var l = this.opts, h = new Mi(this.ctx), c = new v;
e = e || o.gradient.type;
var d, g = i,
p = void 0 === o.gradient.opacityFrom ? a : Array.isArray(o.gradient.opacityFrom) ? o.gradient.opacityFrom[n] : o.gradient.opacityFrom;
g.indexOf("rgba") > -1 && (p = v.getOpacityFromRGBA(g));
var f = void 0 === o.gradient.opacityTo ? a : Array.isArray(o.gradient.opacityTo) ? o.gradient.opacityTo[n] : o.gradient.opacityTo;
if (void 0 === o.gradient.gradientToColors || 0 === o.gradient.gradientToColors.length) d = "dark" === o.gradient.shade ? c.shadeColor(-1 * parseFloat(o.gradient.shadeIntensity), i.indexOf("rgb") > -1 ? v.rgb2hex(i) : i) : c.shadeColor(parseFloat(o.gradient.shadeIntensity), i.indexOf("rgb") > -1 ? v.rgb2hex(i) : i); else if (o.gradient.gradientToColors[l.seriesNumber]) {
var x = o.gradient.gradientToColors[l.seriesNumber];
d = x, x.indexOf("rgba") > -1 && (f = v.getOpacityFromRGBA(x))
} else d = i;
if (o.gradient.gradientFrom && (g = o.gradient.gradientFrom), o.gradient.gradientTo && (d = o.gradient.gradientTo), o.gradient.inverseColors) {
var b = g;
g = d, d = b
}
return g.indexOf("rgb") > -1 && (g = v.rgb2hex(g)), d.indexOf("rgb") > -1 && (d = v.rgb2hex(d)), h.drawGradient(e, g, d, p, f, l.size, o.gradient.stops, r, n)
}
}]), t
}(), Vi = function () {
function t(e, a) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "setGlobalMarkerSize", value: function () {
var t = this.w;
if (t.globals.markers.size = Array.isArray(t.config.markers.size) ? t.config.markers.size : [t.config.markers.size], t.globals.markers.size.length > 0) {
if (t.globals.markers.size.length < t.globals.series.length + 1) for (var e = 0; e <= t.globals.series.length; e++) void 0 === t.globals.markers.size[e] && t.globals.markers.size.push(t.globals.markers.size[0])
} else t.globals.markers.size = t.config.series.map((function (e) {
return t.config.markers.size
}))
}
}, {
key: "plotChartMarkers", value: function (t) {
var e = t.pointsPos, i = t.seriesIndex, a = t.j, s = t.pSize, r = t.alwaysDrawMarker,
n = void 0 !== r && r, o = t.isVirtualPoint, l = void 0 !== o && o, h = this.w, c = i, d = e,
u = null, g = new Mi(this.ctx), p = h.config.markers.discrete && h.config.markers.discrete.length;
if (Array.isArray(d.x)) for (var f = 0; f < d.x.length; f++) {
var x = void 0, b = a, m = !v.isNumber(d.y[f]);
0 === h.globals.markers.largestSize && h.globals.hasNullValues && null !== h.globals.series[c][a + 1] && !l && (m = !0), 1 === a && 0 === f && (b = 0), 1 === a && 1 === f && (b = 1);
var y = "apexcharts-marker";
if ("line" !== h.config.chart.type && "area" !== h.config.chart.type || h.globals.comboCharts || h.config.tooltip.intersect || (y += " no-pointer-events"), (Array.isArray(h.config.markers.size) ? h.globals.markers.size[i] > 0 : h.config.markers.size > 0) || n || p) {
m || (y += " w".concat(v.randomId()));
var w = this.getMarkerConfig({cssClass: y, seriesIndex: i, dataPointIndex: b});
if (h.config.series[c].data[b] && (h.config.series[c].data[b].fillColor && (w.pointFillColor = h.config.series[c].data[b].fillColor), h.config.series[c].data[b].strokeColor && (w.pointStrokeColor = h.config.series[c].data[b].strokeColor)), void 0 !== s && (w.pSize = s), (d.x[f] < -h.globals.markers.largestSize || d.x[f] > h.globals.gridWidth + h.globals.markers.largestSize || d.y[f] < -h.globals.markers.largestSize || d.y[f] > h.globals.gridHeight + h.globals.markers.largestSize) && (w.pSize = 0), !m) (h.globals.markers.size[i] > 0 || n || p) && !u && (u = g.group({class: n || p ? "" : "apexcharts-series-markers"})).attr("clip-path", "url(#gridRectMarkerMask".concat(h.globals.cuid, ")")), (x = g.drawMarker(d.x[f], d.y[f], w)).attr("rel", b), x.attr("j", b), x.attr("index", i), x.node.setAttribute("default-marker-size", w.pSize), new Li(this.ctx).setSelectionFilter(x, i, b), this.addEvents(x), u && u.add(x)
} else void 0 === h.globals.pointsArray[i] && (h.globals.pointsArray[i] = []), h.globals.pointsArray[i].push([d.x[f], d.y[f]])
}
return u
}
}, {
key: "getMarkerConfig", value: function (t) {
var e = t.cssClass, i = t.seriesIndex, a = t.dataPointIndex, s = void 0 === a ? null : a, r = t.radius,
n = void 0 === r ? null : r, o = t.size, l = void 0 === o ? null : o, h = t.strokeWidth,
c = void 0 === h ? null : h, d = this.w, u = this.getMarkerStyle(i),
g = null === l ? d.globals.markers.size[i] : l, p = d.config.markers;
return null !== s && p.discrete.length && p.discrete.map((function (t) {
t.seriesIndex === i && t.dataPointIndex === s && (u.pointStrokeColor = t.strokeColor, u.pointFillColor = t.fillColor, g = t.size, u.pointShape = t.shape)
})), {
pSize: null === n ? g : n,
pRadius: null !== n ? n : p.radius,
pointStrokeWidth: null !== c ? c : Array.isArray(p.strokeWidth) ? p.strokeWidth[i] : p.strokeWidth,
pointStrokeColor: u.pointStrokeColor,
pointFillColor: u.pointFillColor,
shape: u.pointShape || (Array.isArray(p.shape) ? p.shape[i] : p.shape),
class: e,
pointStrokeOpacity: Array.isArray(p.strokeOpacity) ? p.strokeOpacity[i] : p.strokeOpacity,
pointStrokeDashArray: Array.isArray(p.strokeDashArray) ? p.strokeDashArray[i] : p.strokeDashArray,
pointFillOpacity: Array.isArray(p.fillOpacity) ? p.fillOpacity[i] : p.fillOpacity,
seriesIndex: i
}
}
}, {
key: "addEvents", value: function (t) {
var e = this.w, i = new Mi(this.ctx);
t.node.addEventListener("mouseenter", i.pathMouseEnter.bind(this.ctx, t)), t.node.addEventListener("mouseleave", i.pathMouseLeave.bind(this.ctx, t)), t.node.addEventListener("mousedown", i.pathMouseDown.bind(this.ctx, t)), t.node.addEventListener("click", e.config.markers.onClick), t.node.addEventListener("dblclick", e.config.markers.onDblClick), t.node.addEventListener("touchstart", i.pathMouseDown.bind(this.ctx, t), {passive: !0})
}
}, {
key: "getMarkerStyle", value: function (t) {
var e = this.w, i = e.globals.markers.colors,
a = e.config.markers.strokeColor || e.config.markers.strokeColors;
return {pointStrokeColor: Array.isArray(a) ? a[t] : a, pointFillColor: Array.isArray(i) ? i[t] : i}
}
}]), t
}(), Ui = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.initialAnim = this.w.config.chart.animations.enabled
}
return s(t, [{
key: "draw", value: function (t, e, i) {
var a = this.w, s = new Mi(this.ctx), r = i.realIndex, n = i.pointsPos, o = i.zRatio, l = i.elParent,
h = s.group({class: "apexcharts-series-markers apexcharts-series-".concat(a.config.chart.type)});
if (h.attr("clip-path", "url(#gridRectMarkerMask".concat(a.globals.cuid, ")")), Array.isArray(n.x)) for (var c = 0; c < n.x.length; c++) {
var d = e + 1, u = !0;
0 === e && 0 === c && (d = 0), 0 === e && 1 === c && (d = 1);
var g = a.globals.markers.size[r];
if (o !== 1 / 0) {
var p = a.config.plotOptions.bubble;
g = a.globals.seriesZ[r][d], p.zScaling && (g /= o), p.minBubbleRadius && g < p.minBubbleRadius && (g = p.minBubbleRadius), p.maxBubbleRadius && g > p.maxBubbleRadius && (g = p.maxBubbleRadius)
}
var f = n.x[c], x = n.y[c];
if (g = g || 0, null !== x && void 0 !== a.globals.series[r][d] || (u = !1), u) {
var b = this.drawPoint(f, x, g, r, d, e);
h.add(b)
}
l.add(h)
}
}
}, {
key: "drawPoint", value: function (t, e, i, a, s, r) {
var n = this.w, o = a, l = new y(this.ctx), h = new Li(this.ctx), c = new ji(this.ctx),
d = new Vi(this.ctx), u = new Mi(this.ctx), g = d.getMarkerConfig({
cssClass: "apexcharts-marker",
seriesIndex: o,
dataPointIndex: s,
radius: "bubble" === n.config.chart.type || n.globals.comboCharts && n.config.series[a] && "bubble" === n.config.series[a].type ? i : null
}), p = c.fillPath({
seriesNumber: a,
dataPointIndex: s,
color: g.pointFillColor,
patternUnits: "objectBoundingBox",
value: n.globals.series[a][r]
}), f = u.drawMarker(t, e, g);
if (n.config.series[o].data[s] && n.config.series[o].data[s].fillColor && (p = n.config.series[o].data[s].fillColor), f.attr({fill: p}), n.config.chart.dropShadow.enabled) {
var x = n.config.chart.dropShadow;
h.dropShadow(f, x, a)
}
if (!this.initialAnim || n.globals.dataChanged || n.globals.resized) n.globals.animationEnded = !0; else {
var b = n.config.chart.animations.speed;
l.animateMarker(f, b, n.globals.easing, (function () {
window.setTimeout((function () {
l.animationCompleted(f)
}), 100)
}))
}
return f.attr({
rel: s,
j: s,
index: a,
"default-marker-size": g.pSize
}), h.setSelectionFilter(f, a, s), d.addEvents(f), f.node.classList.add("apexcharts-marker"), f
}
}, {
key: "centerTextInBubble", value: function (t) {
var e = this.w;
return {y: t += parseInt(e.config.dataLabels.style.fontSize, 10) / 4}
}
}]), t
}(), qi = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "dataLabelsCorrection", value: function (t, e, i, a, s, r, n) {
var o = this.w, l = !1, h = new Mi(this.ctx).getTextRects(i, n), c = h.width, d = h.height;
e < 0 && (e = 0), e > o.globals.gridHeight + d && (e = o.globals.gridHeight + d / 2), void 0 === o.globals.dataLabelsRects[a] && (o.globals.dataLabelsRects[a] = []), o.globals.dataLabelsRects[a].push({
x: t,
y: e,
width: c,
height: d
});
var u = o.globals.dataLabelsRects[a].length - 2,
g = void 0 !== o.globals.lastDrawnDataLabelsIndexes[a] ? o.globals.lastDrawnDataLabelsIndexes[a][o.globals.lastDrawnDataLabelsIndexes[a].length - 1] : 0;
if (void 0 !== o.globals.dataLabelsRects[a][u]) {
var p = o.globals.dataLabelsRects[a][g];
(t > p.x + p.width || e > p.y + p.height || e + d < p.y || t + c < p.x) && (l = !0)
}
return (0 === s || r) && (l = !0), {x: t, y: e, textRects: h, drawnextLabel: l}
}
}, {
key: "drawDataLabel", value: function (t) {
var e = this, i = t.type, a = t.pos, s = t.i, r = t.j, n = t.isRangeStart, o = t.strokeWidth,
l = void 0 === o ? 2 : o, h = this.w, c = new Mi(this.ctx), d = h.config.dataLabels, u = 0, g = 0,
p = r, f = null;
if (-1 !== h.globals.collapsedSeriesIndices.indexOf(s) || !d.enabled || !Array.isArray(a.x)) return f;
f = c.group({class: "apexcharts-data-labels"});
for (var x = 0; x < a.x.length; x++) if (u = a.x[x] + d.offsetX, g = a.y[x] + d.offsetY + l, !isNaN(u)) {
1 === r && 0 === x && (p = 0), 1 === r && 1 === x && (p = 1);
var b = h.globals.series[s][p];
"rangeArea" === i && (b = n ? h.globals.seriesRangeStart[s][p] : h.globals.seriesRangeEnd[s][p]);
var m = "", v = function (t) {
return h.config.dataLabels.formatter(t, {ctx: e.ctx, seriesIndex: s, dataPointIndex: p, w: h})
};
if ("bubble" === h.config.chart.type) m = v(b = h.globals.seriesZ[s][p]), g = a.y[x], g = new Ui(this.ctx).centerTextInBubble(g, s, p).y; else void 0 !== b && (m = v(b));
var y = h.config.dataLabels.textAnchor;
h.globals.isSlopeChart && (y = 0 === p ? "end" : p === h.config.series[s].data.length - 1 ? "start" : "middle"), this.plotDataLabelsText({
x: u,
y: g,
text: m,
i: s,
j: p,
parent: f,
offsetCorrection: !0,
dataLabelsConfig: h.config.dataLabels,
textAnchor: y
})
}
return f
}
}, {
key: "plotDataLabelsText", value: function (t) {
var e = this.w, i = new Mi(this.ctx), a = t.x, s = t.y, r = t.i, n = t.j, o = t.text, l = t.textAnchor,
h = t.fontSize, c = t.parent, d = t.dataLabelsConfig, u = t.color, g = t.alwaysDrawDataLabel,
p = t.offsetCorrection, f = t.className, x = null;
if (Array.isArray(e.config.dataLabels.enabledOnSeries) && e.config.dataLabels.enabledOnSeries.indexOf(r) < 0) return x;
var b = {x: a, y: s, drawnextLabel: !0, textRects: null};
p && (b = this.dataLabelsCorrection(a, s, o, r, n, g, parseInt(d.style.fontSize, 10))), e.globals.zoomed || (a = b.x, s = b.y), b.textRects && (a < -20 - b.textRects.width || a > e.globals.gridWidth + b.textRects.width + 30) && (o = "");
var m = e.globals.dataLabels.style.colors[r];
(("bar" === e.config.chart.type || "rangeBar" === e.config.chart.type) && e.config.plotOptions.bar.distributed || e.config.dataLabels.distributed) && (m = e.globals.dataLabels.style.colors[n]), "function" == typeof m && (m = m({
series: e.globals.series,
seriesIndex: r,
dataPointIndex: n,
w: e
})), u && (m = u);
var v = d.offsetX, y = d.offsetY;
if ("bar" !== e.config.chart.type && "rangeBar" !== e.config.chart.type || (v = 0, y = 0), e.globals.isSlopeChart && (0 !== n && (v = -2 * d.offsetX + 5), 0 !== n && n !== e.config.series[r].data.length - 1 && (v = 0)), b.drawnextLabel) {
if ("middle" === l && a === e.globals.gridWidth && (l = "end"), (x = i.drawText({
width: 100,
height: parseInt(d.style.fontSize, 10),
x: a + v,
y: s + y,
foreColor: m,
textAnchor: l || d.textAnchor,
text: o,
fontSize: h || d.style.fontSize,
fontFamily: d.style.fontFamily,
fontWeight: d.style.fontWeight || "normal"
})).attr({class: f || "apexcharts-datalabel", cx: a, cy: s}), d.dropShadow.enabled) {
var w = d.dropShadow;
new Li(this.ctx).dropShadow(x, w)
}
c.add(x), void 0 === e.globals.lastDrawnDataLabelsIndexes[r] && (e.globals.lastDrawnDataLabelsIndexes[r] = []), e.globals.lastDrawnDataLabelsIndexes[r].push(n)
}
return x
}
}, {
key: "addBackgroundToDataLabel", value: function (t, e) {
var i = this.w, a = i.config.dataLabels.background, s = a.padding, r = a.padding / 2, n = e.width,
o = e.height,
l = new Mi(this.ctx).drawRect(e.x - s, e.y - r / 2, n + 2 * s, o + r, a.borderRadius, "transparent" !== i.config.chart.background && i.config.chart.background ? i.config.chart.background : "#fff", a.opacity, a.borderWidth, a.borderColor);
a.dropShadow.enabled && new Li(this.ctx).dropShadow(l, a.dropShadow);
return l
}
}, {
key: "dataLabelsBackground", value: function () {
var t = this.w;
if ("bubble" !== t.config.chart.type) for (var e = t.globals.dom.baseEl.querySelectorAll(".apexcharts-datalabels text"), i = 0; i < e.length; i++) {
var a = e[i], s = a.getBBox(), r = null;
if (s.width && s.height && (r = this.addBackgroundToDataLabel(a, s)), r) {
a.parentNode.insertBefore(r.node, a);
var n = t.config.dataLabels.background.backgroundColor || a.getAttribute("fill");
t.config.chart.animations.enabled && !t.globals.resized && !t.globals.dataChanged ? r.animate().attr({fill: n}) : r.attr({fill: n}), a.setAttribute("fill", t.config.dataLabels.background.foreColor)
}
}
}
}, {
key: "bringForward", value: function () {
for (var t = this.w, e = t.globals.dom.baseEl.querySelectorAll(".apexcharts-datalabels"), i = t.globals.dom.baseEl.querySelector(".apexcharts-plot-series:last-child"), a = 0; a < e.length; a++) i && i.insertBefore(e[a], i.nextSibling)
}
}]), t
}(),
Zi = ".apexcharts-flip-y {\n transform: scaleY(-1) translateY(-100%);\n transform-origin: top;\n transform-box: fill-box;\n}\n.apexcharts-flip-x {\n transform: scaleX(-1);\n transform-origin: center;\n transform-box: fill-box;\n}\n.apexcharts-legend {\n display: flex;\n overflow: auto;\n padding: 0 10px;\n}\n.apexcharts-legend.apexcharts-legend-group-horizontal {\n flex-direction: column;\n}\n.apexcharts-legend-group {\n display: flex;\n}\n.apexcharts-legend-group-vertical {\n flex-direction: column-reverse;\n}\n.apexcharts-legend.apx-legend-position-bottom, .apexcharts-legend.apx-legend-position-top {\n flex-wrap: wrap\n}\n.apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\n flex-direction: column;\n bottom: 0;\n}\n.apexcharts-legend.apx-legend-position-bottom.apexcharts-align-left, .apexcharts-legend.apx-legend-position-top.apexcharts-align-left, .apexcharts-legend.apx-legend-position-right, .apexcharts-legend.apx-legend-position-left {\n justify-content: flex-start;\n align-items: flex-start;\n}\n.apexcharts-legend.apx-legend-position-bottom.apexcharts-align-center, .apexcharts-legend.apx-legend-position-top.apexcharts-align-center {\n justify-content: center;\n align-items: center;\n}\n.apexcharts-legend.apx-legend-position-bottom.apexcharts-align-right, .apexcharts-legend.apx-legend-position-top.apexcharts-align-right {\n justify-content: flex-end;\n align-items: flex-end;\n}\n.apexcharts-legend-series {\n cursor: pointer;\n line-height: normal;\n display: flex;\n align-items: center;\n}\n.apexcharts-legend-text {\n position: relative;\n font-size: 14px;\n}\n.apexcharts-legend-text *, .apexcharts-legend-marker * {\n pointer-events: none;\n}\n.apexcharts-legend-marker {\n position: relative;\n display: flex;\n align-items: center;\n justify-content: center;\n cursor: pointer;\n margin-right: 1px;\n}\n\n.apexcharts-legend-series.apexcharts-no-click {\n cursor: auto;\n}\n.apexcharts-legend .apexcharts-hidden-zero-series, .apexcharts-legend .apexcharts-hidden-null-series {\n display: none !important;\n}\n.apexcharts-inactive-legend {\n opacity: 0.45;\n} ",
$i = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.legendInactiveClass = "legend-mouseover-inactive"
}
return s(t, [{
key: "getAllSeriesEls", value: function () {
return this.w.globals.dom.baseEl.getElementsByClassName("apexcharts-series")
}
}, {
key: "getSeriesByName", value: function (t) {
return this.w.globals.dom.baseEl.querySelector(".apexcharts-inner .apexcharts-series[seriesName='".concat(v.escapeString(t), "']"))
}
}, {
key: "isSeriesHidden", value: function (t) {
var e = this.getSeriesByName(t), i = parseInt(e.getAttribute("data:realIndex"), 10);
return {isHidden: e.classList.contains("apexcharts-series-collapsed"), realIndex: i}
}
}, {
key: "addCollapsedClassToSeries", value: function (t, e) {
var i = this.w;
function a(i) {
for (var a = 0; a < i.length; a++) i[a].index === e && t.node.classList.add("apexcharts-series-collapsed")
}
a(i.globals.collapsedSeries), a(i.globals.ancillaryCollapsedSeries)
}
}, {
key: "toggleSeries", value: function (t) {
var e = this.isSeriesHidden(t);
return this.ctx.legend.legendHelpers.toggleDataSeries(e.realIndex, e.isHidden), e.isHidden
}
}, {
key: "showSeries", value: function (t) {
var e = this.isSeriesHidden(t);
e.isHidden && this.ctx.legend.legendHelpers.toggleDataSeries(e.realIndex, !0)
}
}, {
key: "hideSeries", value: function (t) {
var e = this.isSeriesHidden(t);
e.isHidden || this.ctx.legend.legendHelpers.toggleDataSeries(e.realIndex, !1)
}
}, {
key: "resetSeries", value: function () {
var t = !(arguments.length > 0 && void 0 !== arguments[0]) || arguments[0],
e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1],
i = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2], a = this.w,
s = v.clone(a.globals.initialSeries);
a.globals.previousPaths = [], i ? (a.globals.collapsedSeries = [], a.globals.ancillaryCollapsedSeries = [], a.globals.collapsedSeriesIndices = [], a.globals.ancillaryCollapsedSeriesIndices = []) : s = this.emptyCollapsedSeries(s), a.config.series = s, t && (e && (a.globals.zoomed = !1, this.ctx.updateHelpers.revertDefaultAxisMinMax()), this.ctx.updateHelpers._updateSeries(s, a.config.chart.animations.dynamicAnimation.enabled))
}
}, {
key: "emptyCollapsedSeries", value: function (t) {
for (var e = this.w, i = 0; i < t.length; i++) e.globals.collapsedSeriesIndices.indexOf(i) > -1 && (t[i].data = []);
return t
}
}, {
key: "highlightSeries", value: function (t) {
var e = this.w, i = this.getSeriesByName(t),
a = parseInt(null == i ? void 0 : i.getAttribute("data:realIndex"), 10),
s = e.globals.dom.baseEl.querySelectorAll(".apexcharts-series, .apexcharts-datalabels, .apexcharts-yaxis"),
r = null, n = null, o = null;
if (e.globals.axisCharts || "radialBar" === e.config.chart.type) if (e.globals.axisCharts) {
r = e.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(a, "']")), n = e.globals.dom.baseEl.querySelector(".apexcharts-datalabels[data\\:realIndex='".concat(a, "']"));
var l = e.globals.seriesYAxisReverseMap[a];
o = e.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(l, "']"))
} else r = e.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(a + 1, "']")); else r = e.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(a + 1, "'] path"));
for (var h = 0; h < s.length; h++) s[h].classList.add(this.legendInactiveClass);
if (r) e.globals.axisCharts || r.parentNode.classList.remove(this.legendInactiveClass), r.classList.remove(this.legendInactiveClass), null !== n && n.classList.remove(this.legendInactiveClass), null !== o && o.classList.remove(this.legendInactiveClass); else for (var c = 0; c < s.length; c++) s[c].classList.remove(this.legendInactiveClass)
}
}, {
key: "toggleSeriesOnHover", value: function (t, e) {
var i = this.w;
e || (e = t.target);
var a = i.globals.dom.baseEl.querySelectorAll(".apexcharts-series, .apexcharts-datalabels, .apexcharts-yaxis");
if ("mousemove" === t.type) {
var s = parseInt(e.getAttribute("rel"), 10) - 1;
this.highlightSeries(i.globals.seriesNames[s])
} else if ("mouseout" === t.type) for (var r = 0; r < a.length; r++) a[r].classList.remove(this.legendInactiveClass)
}
}, {
key: "highlightRangeInSeries", value: function (t, e) {
var i = this, a = this.w,
s = a.globals.dom.baseEl.getElementsByClassName("apexcharts-heatmap-rect"), r = function (t) {
for (var e = 0; e < s.length; e++) s[e].classList[t](i.legendInactiveClass)
};
if ("mousemove" === t.type) {
var n = parseInt(e.getAttribute("rel"), 10) - 1;
r("add");
var o = a.config.plotOptions.heatmap.colorScale.ranges;
!function (t, e) {
for (var a = 0; a < s.length; a++) {
var r = Number(s[a].getAttribute("val"));
r >= t.from && (r < t.to || t.to === e && r === e) && s[a].classList.remove(i.legendInactiveClass)
}
}(o[n], o.reduce((function (t, e) {
return Math.max(t, e.to)
}), 0))
} else "mouseout" === t.type && r("remove")
}
}, {
key: "getActiveConfigSeriesIndex", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : "asc",
e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : [], i = this.w, a = 0;
if (i.config.series.length > 1) for (var s = i.config.series.map((function (t, a) {
return t.data && t.data.length > 0 && -1 === i.globals.collapsedSeriesIndices.indexOf(a) && (!i.globals.comboCharts || 0 === e.length || e.length && e.indexOf(i.config.series[a].type) > -1) ? a : -1
})), r = "asc" === t ? 0 : s.length - 1; "asc" === t ? r < s.length : r >= 0; "asc" === t ? r++ : r--) if (-1 !== s[r]) {
a = s[r];
break
}
return a
}
}, {
key: "getBarSeriesIndices", value: function () {
return this.w.globals.comboCharts ? this.w.config.series.map((function (t, e) {
return "bar" === t.type || "column" === t.type ? e : -1
})).filter((function (t) {
return -1 !== t
})) : this.w.config.series.map((function (t, e) {
return e
}))
}
}, {
key: "getPreviousPaths", value: function () {
var t = this.w;
function e(e, i, a) {
for (var s = e[i].childNodes, r = {
type: a,
paths: [],
realIndex: e[i].getAttribute("data:realIndex")
}, n = 0; n < s.length; n++) if (s[n].hasAttribute("pathTo")) {
var o = s[n].getAttribute("pathTo");
r.paths.push({d: o})
}
t.globals.previousPaths.push(r)
}
t.globals.previousPaths = [];
["line", "area", "bar", "rangebar", "rangeArea", "candlestick", "radar"].forEach((function (i) {
for (var a, s = (a = i, t.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(a, "-series .apexcharts-series"))), r = 0; r < s.length; r++) e(s, r, i)
}));
var i = t.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(t.config.chart.type, " .apexcharts-series"));
if (i.length > 0) for (var a = function (e) {
for (var i = t.globals.dom.baseEl.querySelectorAll(".apexcharts-".concat(t.config.chart.type, " .apexcharts-series[data\\:realIndex='").concat(e, "'] rect")), a = [], s = function (t) {
var e = function (e) {
return i[t].getAttribute(e)
}, s = {
x: parseFloat(e("x")),
y: parseFloat(e("y")),
width: parseFloat(e("width")),
height: parseFloat(e("height"))
};
a.push({rect: s, color: i[t].getAttribute("color")})
}, r = 0; r < i.length; r++) s(r);
t.globals.previousPaths.push(a)
}, s = 0; s < i.length; s++) a(s);
t.globals.axisCharts || (t.globals.previousPaths = t.globals.series)
}
}, {
key: "clearPreviousPaths", value: function () {
var t = this.w;
t.globals.previousPaths = [], t.globals.allSeriesCollapsed = !1
}
}, {
key: "handleNoData", value: function () {
var t = this.w, e = t.config.noData, i = new Mi(this.ctx), a = t.globals.svgWidth / 2,
s = t.globals.svgHeight / 2, r = "middle";
if (t.globals.noData = !0, t.globals.animationEnded = !0, "left" === e.align ? (a = 10, r = "start") : "right" === e.align && (a = t.globals.svgWidth - 10, r = "end"), "top" === e.verticalAlign ? s = 50 : "bottom" === e.verticalAlign && (s = t.globals.svgHeight - 50), a += e.offsetX, s = s + parseInt(e.style.fontSize, 10) + 2 + e.offsetY, void 0 !== e.text && "" !== e.text) {
var n = i.drawText({
x: a,
y: s,
text: e.text,
textAnchor: r,
fontSize: e.style.fontSize,
fontFamily: e.style.fontFamily,
foreColor: e.style.color,
opacity: 1,
class: "apexcharts-text-nodata"
});
t.globals.dom.Paper.add(n)
}
}
}, {
key: "setNullSeriesToZeroValues", value: function (t) {
for (var e = this.w, i = 0; i < t.length; i++) if (0 === t[i].length) for (var a = 0; a < t[e.globals.maxValsInArrayIndex].length; a++) t[i].push(0);
return t
}
}, {
key: "hasAllSeriesEqualX", value: function () {
for (var t = !0, e = this.w, i = this.filteredSeriesX(), a = 0; a < i.length - 1; a++) if (i[a][0] !== i[a + 1][0]) {
t = !1;
break
}
return e.globals.allSeriesHasEqualX = t, t
}
}, {
key: "filteredSeriesX", value: function () {
var t = this.w.globals.seriesX.map((function (t) {
return t.length > 0 ? t : []
}));
return t
}
}]), t
}(), Ji = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.twoDSeries = [], this.threeDSeries = [], this.twoDSeriesX = [], this.seriesGoals = [], this.coreUtils = new Pi(this.ctx)
}
return s(t, [{
key: "isMultiFormat", value: function () {
return this.isFormatXY() || this.isFormat2DArray()
}
}, {
key: "isFormatXY", value: function () {
var t = this.w.config.series.slice(), e = new $i(this.ctx);
if (this.activeSeriesIndex = e.getActiveConfigSeriesIndex(), void 0 !== t[this.activeSeriesIndex].data && t[this.activeSeriesIndex].data.length > 0 && null !== t[this.activeSeriesIndex].data[0] && void 0 !== t[this.activeSeriesIndex].data[0].x && null !== t[this.activeSeriesIndex].data[0]) return !0
}
}, {
key: "isFormat2DArray", value: function () {
var t = this.w.config.series.slice(), e = new $i(this.ctx);
if (this.activeSeriesIndex = e.getActiveConfigSeriesIndex(), void 0 !== t[this.activeSeriesIndex].data && t[this.activeSeriesIndex].data.length > 0 && void 0 !== t[this.activeSeriesIndex].data[0] && null !== t[this.activeSeriesIndex].data[0] && t[this.activeSeriesIndex].data[0].constructor === Array) return !0
}
}, {
key: "handleFormat2DArray", value: function (t, e) {
for (var i = this.w.config, a = this.w.globals, s = "boxPlot" === i.chart.type || "boxPlot" === i.series[e].type, r = 0; r < t[e].data.length; r++) if (void 0 !== t[e].data[r][1] && (Array.isArray(t[e].data[r][1]) && 4 === t[e].data[r][1].length && !s ? this.twoDSeries.push(v.parseNumber(t[e].data[r][1][3])) : t[e].data[r].length >= 5 ? this.twoDSeries.push(v.parseNumber(t[e].data[r][4])) : this.twoDSeries.push(v.parseNumber(t[e].data[r][1])), a.dataFormatXNumeric = !0), "datetime" === i.xaxis.type) {
var n = new Date(t[e].data[r][0]);
n = new Date(n).getTime(), this.twoDSeriesX.push(n)
} else this.twoDSeriesX.push(t[e].data[r][0]);
for (var o = 0; o < t[e].data.length; o++) void 0 !== t[e].data[o][2] && (this.threeDSeries.push(t[e].data[o][2]), a.isDataXYZ = !0)
}
}, {
key: "handleFormatXY", value: function (t, e) {
var i = this.w.config, a = this.w.globals, s = new zi(this.ctx), r = e;
a.collapsedSeriesIndices.indexOf(e) > -1 && (r = this.activeSeriesIndex);
for (var n = 0; n < t[e].data.length; n++) void 0 !== t[e].data[n].y && (Array.isArray(t[e].data[n].y) ? this.twoDSeries.push(v.parseNumber(t[e].data[n].y[t[e].data[n].y.length - 1])) : this.twoDSeries.push(v.parseNumber(t[e].data[n].y))), void 0 !== t[e].data[n].goals && Array.isArray(t[e].data[n].goals) ? (void 0 === this.seriesGoals[e] && (this.seriesGoals[e] = []), this.seriesGoals[e].push(t[e].data[n].goals)) : (void 0 === this.seriesGoals[e] && (this.seriesGoals[e] = []), this.seriesGoals[e].push(null));
for (var o = 0; o < t[r].data.length; o++) {
var l = "string" == typeof t[r].data[o].x, h = Array.isArray(t[r].data[o].x),
c = !h && !!s.isValidDate(t[r].data[o].x);
if (l || c) if (l || i.xaxis.convertedCatToNumeric) {
var d = a.isBarHorizontal && a.isRangeData;
"datetime" !== i.xaxis.type || d ? (this.fallbackToCategory = !0, this.twoDSeriesX.push(t[r].data[o].x), isNaN(t[r].data[o].x) || "category" === this.w.config.xaxis.type || "string" == typeof t[r].data[o].x || (a.isXNumeric = !0)) : this.twoDSeriesX.push(s.parseDate(t[r].data[o].x))
} else "datetime" === i.xaxis.type ? this.twoDSeriesX.push(s.parseDate(t[r].data[o].x.toString())) : (a.dataFormatXNumeric = !0, a.isXNumeric = !0, this.twoDSeriesX.push(parseFloat(t[r].data[o].x))); else h ? (this.fallbackToCategory = !0, this.twoDSeriesX.push(t[r].data[o].x)) : (a.isXNumeric = !0, a.dataFormatXNumeric = !0, this.twoDSeriesX.push(t[r].data[o].x))
}
if (t[e].data[0] && void 0 !== t[e].data[0].z) {
for (var u = 0; u < t[e].data.length; u++) this.threeDSeries.push(t[e].data[u].z);
a.isDataXYZ = !0
}
}
}, {
key: "handleRangeData", value: function (t, e) {
var i = this.w.globals, a = {};
return this.isFormat2DArray() ? a = this.handleRangeDataFormat("array", t, e) : this.isFormatXY() && (a = this.handleRangeDataFormat("xy", t, e)), i.seriesRangeStart[e] = void 0 === a.start ? [] : a.start, i.seriesRangeEnd[e] = void 0 === a.end ? [] : a.end, i.seriesRange[e] = a.rangeUniques, i.seriesRange.forEach((function (t, e) {
t && t.forEach((function (t, e) {
t.y.forEach((function (e, i) {
for (var a = 0; a < t.y.length; a++) if (i !== a) {
var s = e.y1, r = e.y2, n = t.y[a].y1;
s <= t.y[a].y2 && n <= r && (t.overlaps.indexOf(e.rangeName) < 0 && t.overlaps.push(e.rangeName), t.overlaps.indexOf(t.y[a].rangeName) < 0 && t.overlaps.push(t.y[a].rangeName))
}
}))
}))
})), a
}
}, {
key: "handleCandleStickBoxData", value: function (t, e) {
var i = this.w.globals, a = {};
return this.isFormat2DArray() ? a = this.handleCandleStickBoxDataFormat("array", t, e) : this.isFormatXY() && (a = this.handleCandleStickBoxDataFormat("xy", t, e)), i.seriesCandleO[e] = a.o, i.seriesCandleH[e] = a.h, i.seriesCandleM[e] = a.m, i.seriesCandleL[e] = a.l, i.seriesCandleC[e] = a.c, a
}
}, {
key: "handleRangeDataFormat", value: function (t, e, i) {
var a = [], s = [], r = e[i].data.filter((function (t, e, i) {
return e === i.findIndex((function (e) {
return e.x === t.x
}))
})).map((function (t, e) {
return {x: t.x, overlaps: [], y: []}
}));
if ("array" === t) for (var n = 0; n < e[i].data.length; n++) Array.isArray(e[i].data[n]) ? (a.push(e[i].data[n][1][0]), s.push(e[i].data[n][1][1])) : (a.push(e[i].data[n]), s.push(e[i].data[n])); else if ("xy" === t) for (var o = function (t) {
var n = Array.isArray(e[i].data[t].y), o = v.randomId(), l = e[i].data[t].x, h = {
y1: n ? e[i].data[t].y[0] : e[i].data[t].y,
y2: n ? e[i].data[t].y[1] : e[i].data[t].y,
rangeName: o
};
e[i].data[t].rangeName = o;
var c = r.findIndex((function (t) {
return t.x === l
}));
r[c].y.push(h), a.push(h.y1), s.push(h.y2)
}, l = 0; l < e[i].data.length; l++) o(l);
return {start: a, end: s, rangeUniques: r}
}
}, {
key: "handleCandleStickBoxDataFormat", value: function (t, e, i) {
var a = this.w, s = "boxPlot" === a.config.chart.type || "boxPlot" === a.config.series[i].type, r = [],
n = [], o = [], l = [], h = [];
if ("array" === t) if (s && 6 === e[i].data[0].length || !s && 5 === e[i].data[0].length) for (var c = 0; c < e[i].data.length; c++) r.push(e[i].data[c][1]), n.push(e[i].data[c][2]), s ? (o.push(e[i].data[c][3]), l.push(e[i].data[c][4]), h.push(e[i].data[c][5])) : (l.push(e[i].data[c][3]), h.push(e[i].data[c][4])); else for (var d = 0; d < e[i].data.length; d++) Array.isArray(e[i].data[d][1]) && (r.push(e[i].data[d][1][0]), n.push(e[i].data[d][1][1]), s ? (o.push(e[i].data[d][1][2]), l.push(e[i].data[d][1][3]), h.push(e[i].data[d][1][4])) : (l.push(e[i].data[d][1][2]), h.push(e[i].data[d][1][3]))); else if ("xy" === t) for (var u = 0; u < e[i].data.length; u++) Array.isArray(e[i].data[u].y) && (r.push(e[i].data[u].y[0]), n.push(e[i].data[u].y[1]), s ? (o.push(e[i].data[u].y[2]), l.push(e[i].data[u].y[3]), h.push(e[i].data[u].y[4])) : (l.push(e[i].data[u].y[2]), h.push(e[i].data[u].y[3])));
return {o: r, h: n, m: o, l: l, c: h}
}
}, {
key: "parseDataAxisCharts", value: function (t) {
var e = this, i = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : this.ctx,
a = this.w.config, s = this.w.globals, r = new zi(i),
n = a.labels.length > 0 ? a.labels.slice() : a.xaxis.categories.slice();
s.isRangeBar = "rangeBar" === a.chart.type && s.isBarHorizontal, s.hasXaxisGroups = "category" === a.xaxis.type && a.xaxis.group.groups.length > 0, s.hasXaxisGroups && (s.groups = a.xaxis.group.groups), t.forEach((function (t, e) {
void 0 !== t.name ? s.seriesNames.push(t.name) : s.seriesNames.push("series-" + parseInt(e + 1, 10))
})), this.coreUtils.setSeriesYAxisMappings();
var o = [], l = f(new Set(a.series.map((function (t) {
return t.group
}))));
a.series.forEach((function (t, e) {
var i = l.indexOf(t.group);
o[i] || (o[i] = []), o[i].push(s.seriesNames[e])
})), s.seriesGroups = o;
for (var h = function () {
for (var t = 0; t < n.length; t++) if ("string" == typeof n[t]) {
if (!r.isValidDate(n[t])) throw new Error("You have provided invalid Date format. Please provide a valid JavaScript Date");
e.twoDSeriesX.push(r.parseDate(n[t]))
} else e.twoDSeriesX.push(n[t])
}, c = 0; c < t.length; c++) {
if (this.twoDSeries = [], this.twoDSeriesX = [], this.threeDSeries = [], void 0 === t[c].data) return void console.error("It is a possibility that you may have not included 'data' property in series.");
if ("rangeBar" !== a.chart.type && "rangeArea" !== a.chart.type && "rangeBar" !== t[c].type && "rangeArea" !== t[c].type || (s.isRangeData = !0, this.handleRangeData(t, c)), this.isMultiFormat()) this.isFormat2DArray() ? this.handleFormat2DArray(t, c) : this.isFormatXY() && this.handleFormatXY(t, c), "candlestick" !== a.chart.type && "candlestick" !== t[c].type && "boxPlot" !== a.chart.type && "boxPlot" !== t[c].type || this.handleCandleStickBoxData(t, c), s.series.push(this.twoDSeries), s.labels.push(this.twoDSeriesX), s.seriesX.push(this.twoDSeriesX), s.seriesGoals = this.seriesGoals, c !== this.activeSeriesIndex || this.fallbackToCategory || (s.isXNumeric = !0); else {
"datetime" === a.xaxis.type ? (s.isXNumeric = !0, h(), s.seriesX.push(this.twoDSeriesX)) : "numeric" === a.xaxis.type && (s.isXNumeric = !0, n.length > 0 && (this.twoDSeriesX = n, s.seriesX.push(this.twoDSeriesX))), s.labels.push(this.twoDSeriesX);
var d = t[c].data.map((function (t) {
return v.parseNumber(t)
}));
s.series.push(d)
}
s.seriesZ.push(this.threeDSeries), void 0 !== t[c].color ? s.seriesColors.push(t[c].color) : s.seriesColors.push(void 0)
}
return this.w
}
}, {
key: "parseDataNonAxisCharts", value: function (t) {
var e = this.w.globals, i = this.w.config, a = Array.isArray(t) && t.every((function (t) {
return "number" == typeof t
})) && i.labels.length > 0, s = Array.isArray(t) && t.some((function (t) {
return t && "object" === b(t) && t.data || t && "object" === b(t) && t.parsing
}));
if (a && s && console.warn("ApexCharts: Both old format (numeric series + labels) and new format (series objects with data/parsing) detected. Using old format for backward compatibility."), a) {
e.series = t.slice(), e.seriesNames = i.labels.slice();
for (var r = 0; r < e.series.length; r++) void 0 === e.seriesNames[r] && e.seriesNames.push("series-" + (r + 1));
return this.w
}
if (Array.isArray(t) && t.every((function (t) {
return "number" == typeof t
}))) {
e.series = t.slice(), e.seriesNames = [];
for (var n = 0; n < e.series.length; n++) e.seriesNames.push(i.labels[n] || "series-".concat(n + 1));
return this.w
}
var o = this.extractPieDataFromSeries(t);
e.series = o.values, e.seriesNames = o.labels, "radialBar" === i.chart.type && (e.series = e.series.map((function (t) {
var e = v.parseNumber(t);
return e > 100 && console.warn("ApexCharts: RadialBar value ".concat(e, " > 100, consider using percentage values (0-100)")), e
})));
for (var l = 0; l < e.series.length; l++) void 0 === e.seriesNames[l] && e.seriesNames.push("series-" + (l + 1));
return this.w
}
}, {
key: "resetParsingFlags", value: function () {
var t = this.w;
t.globals.dataWasParsed = !1, t.globals.originalSeries = null, t.config.series && t.config.series.forEach((function (t) {
t.__apexParsed && delete t.__apexParsed
}))
}
}, {
key: "extractPieDataFromSeries", value: function (t) {
var e = [], i = [];
if (!Array.isArray(t)) return console.warn("ApexCharts: Expected array for series data"), {
values: [],
labels: []
};
if (0 === t.length) return console.warn("ApexCharts: Empty series array"), {values: [], labels: []};
var a = t[0];
return "object" === b(a) && null !== a && a.data ? (this.extractPieDataFromSeriesObjects(t, e, i), {
values: e,
labels: i
}) : (console.warn("ApexCharts: Unsupported series format for pie/donut/radialBar. Expected series objects with data property."), {
values: [],
labels: []
})
}
}, {
key: "extractPieDataFromSeriesObjects", value: function (t, e, i) {
t.forEach((function (t, a) {
t.data && Array.isArray(t.data) ? t.data.forEach((function (t) {
"object" === b(t) && null !== t ? void 0 !== t.x && void 0 !== t.y ? (i.push(String(t.x)), e.push(v.parseNumber(t.y))) : console.warn("ApexCharts: Invalid data point format for pie chart. Expected {x, y} format:", t) : console.warn("ApexCharts: Expected object data point, got:", b(t))
})) : console.warn("ApexCharts: Series ".concat(a, " has no valid data array"))
}))
}
}, {
key: "handleExternalLabelsData", value: function (t) {
var e = this.w.config, i = this.w.globals;
if (e.xaxis.categories.length > 0) i.labels = e.xaxis.categories; else if (e.labels.length > 0) i.labels = e.labels.slice(); else if (this.fallbackToCategory) {
if (i.labels = i.labels[0], i.seriesRange.length && (i.seriesRange.map((function (t) {
t.forEach((function (t) {
i.labels.indexOf(t.x) < 0 && t.x && i.labels.push(t.x)
}))
})), i.labels = Array.from(new Set(i.labels.map(JSON.stringify)), JSON.parse)), e.xaxis.convertedCatToNumeric) new Ni(e).convertCatToNumericXaxis(e, this.ctx, i.seriesX[0]), this._generateExternalLabels(t)
} else this._generateExternalLabels(t)
}
}, {
key: "_generateExternalLabels", value: function (t) {
var e = this.w.globals, i = this.w.config, a = [];
if (e.axisCharts) {
if (e.series.length > 0) if (this.isFormatXY()) for (var s = i.series.map((function (t, e) {
return t.data.filter((function (t, e, i) {
return i.findIndex((function (e) {
return e.x === t.x
})) === e
}))
})), r = s.reduce((function (t, e, i, a) {
return a[t].length > e.length ? t : i
}), 0), n = 0; n < s[r].length; n++) a.push(n + 1); else for (var o = 0; o < e.series[e.maxValsInArrayIndex].length; o++) a.push(o + 1);
e.seriesX = [];
for (var l = 0; l < t.length; l++) e.seriesX.push(a);
this.w.globals.isBarHorizontal || (e.isXNumeric = !0)
}
if (0 === a.length) {
a = e.axisCharts ? [] : e.series.map((function (t, e) {
return e + 1
}));
for (var h = 0; h < t.length; h++) e.seriesX.push(a)
}
e.labels = a, i.xaxis.convertedCatToNumeric && (e.categoryLabels = a.map((function (t) {
return i.xaxis.labels.formatter(t)
}))), e.noLabelsProvided = !0
}
}, {
key: "parseRawDataIfNeeded", value: function (t) {
var e = this, i = this.w.config, a = this.w.globals, s = i.parsing;
if (a.dataWasParsed) return t;
if (!s && !t.some((function (t) {
return t.parsing
}))) return t;
var r = t.map((function (t, i) {
var a, r, n;
if (!t.data || !Array.isArray(t.data) || 0 === t.data.length) return t;
var o = {
x: (null === (a = t.parsing) || void 0 === a ? void 0 : a.x) || (null == s ? void 0 : s.x),
y: (null === (r = t.parsing) || void 0 === r ? void 0 : r.y) || (null == s ? void 0 : s.y),
z: (null === (n = t.parsing) || void 0 === n ? void 0 : n.z) || (null == s ? void 0 : s.z)
};
if (!o.x && !o.y) return t;
var l = t.data[0];
if ("object" === b(l) && null !== l && (l.hasOwnProperty("x") || l.hasOwnProperty("y")) || Array.isArray(l)) return t;
if (!o.x || !o.y || Array.isArray(o.y) && 0 === o.y.length) return console.warn("ApexCharts: Series ".concat(i, " has parsing config but missing x or y field specification")), t;
var h = t.data.map((function (t, a) {
if ("object" !== b(t) || null === t) return console.warn("ApexCharts: Series ".concat(i, ", data point ").concat(a, " is not an object, skipping parsing")), t;
var s, r = e.getNestedValue(t, o.x), n = void 0;
if (Array.isArray(o.y)) {
var l = o.y.map((function (i) {
return e.getNestedValue(t, i)
}));
s = "bubble" === e.w.config.chart.type && 2 === l.length ? l[0] : l
} else s = e.getNestedValue(t, o.y);
o.z && (n = e.getNestedValue(t, o.z)), void 0 === r && console.warn("ApexCharts: Series ".concat(i, ", data point ").concat(a, " missing field '").concat(o.x, "'")), void 0 === s && console.warn("ApexCharts: Series ".concat(i, ", data point ").concat(a, " missing field '").concat(o.y, "'"));
var h = {x: r, y: s};
if ("bubble" === e.w.config.chart.type && Array.isArray(o.y) && 2 === o.y.length) {
var c = e.getNestedValue(t, o.y[1]);
void 0 !== c && (h.z = c)
}
return void 0 !== n && (h.z = n), h
}));
return u(u({}, t), {}, {data: h, __apexParsed: !0})
}));
return a.dataWasParsed = !0, a.originalSeries || (a.originalSeries = v.clone(t)), r
}
}, {
key: "getNestedValue", value: function (t, e) {
if (t && "object" === b(t) && e) {
if (-1 === e.indexOf(".")) return t[e];
for (var i = e.split("."), a = t, s = 0; s < i.length; s++) {
if (null == a || "object" !== b(a)) return;
a = a[i[s]]
}
return a
}
}
}, {
key: "parseData", value: function (t) {
var e = this.w, i = e.config, a = e.globals;
if (t = this.parseRawDataIfNeeded(t), i.series = t, a.initialSeries = v.clone(t), this.excludeCollapsedSeriesInYAxis(), this.fallbackToCategory = !1, this.ctx.core.resetGlobals(), this.ctx.core.isMultipleY(), a.axisCharts ? (this.parseDataAxisCharts(t), this.coreUtils.getLargestSeries()) : this.parseDataNonAxisCharts(t), i.chart.stacked) {
var s = new $i(this.ctx);
a.series = s.setNullSeriesToZeroValues(a.series)
}
this.coreUtils.getSeriesTotals(), a.axisCharts && (a.stackedSeriesTotals = this.coreUtils.getStackedSeriesTotals(), a.stackedSeriesTotalsByGroups = this.coreUtils.getStackedSeriesTotalsByGroups()), this.coreUtils.getPercentSeries(), a.dataFormatXNumeric || a.isXNumeric && ("numeric" !== i.xaxis.type || 0 !== i.labels.length || 0 !== i.xaxis.categories.length) || this.handleExternalLabelsData(t);
for (var r = this.coreUtils.getCategoryLabels(a.labels), n = 0; n < r.length; n++) if (Array.isArray(r[n])) {
a.isMultiLineX = !0;
break
}
}
}, {
key: "excludeCollapsedSeriesInYAxis", value: function () {
var t = this.w, e = [];
t.globals.seriesYAxisMap.forEach((function (i, a) {
var s = 0;
i.forEach((function (e) {
-1 !== t.globals.collapsedSeriesIndices.indexOf(e) && s++
})), s > 0 && s == i.length && e.push(a)
})), t.globals.ignoreYAxisIndexes = e.map((function (t) {
return t
}))
}
}]), t
}(), Qi = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "svgStringToNode", value: function (t) {
return (new DOMParser).parseFromString(t, "image/svg+xml").documentElement
}
}, {
key: "scaleSvgNode", value: function (t, e) {
var i = parseFloat(t.getAttributeNS(null, "width")), a = parseFloat(t.getAttributeNS(null, "height"));
t.setAttributeNS(null, "width", i * e), t.setAttributeNS(null, "height", a * e), t.setAttributeNS(null, "viewBox", "0 0 " + i + " " + a)
}
}, {
key: "getSvgString", value: function (t) {
var e = this;
return new Promise((function (i) {
var a = e.w,
s = t || a.config.chart.toolbar.export.scale || a.config.chart.toolbar.export.width / a.globals.svgWidth;
s || (s = 1);
var r = a.globals.svgWidth * s, n = a.globals.svgHeight * s, o = a.globals.dom.elWrap.cloneNode(!0);
o.style.width = r + "px", o.style.height = n + "px";
var l = (new XMLSerializer).serializeToString(o),
h = "\n .apexcharts-tooltip, .apexcharts-toolbar, .apexcharts-xaxistooltip, .apexcharts-yaxistooltip, .apexcharts-xcrosshairs, .apexcharts-ycrosshairs, .apexcharts-zoom-rect, .apexcharts-selection-rect {\n display: none;\n }\n ";
a.config.legend.show && a.globals.dom.elLegendWrap && a.globals.dom.elLegendWrap.children.length > 0 && (h += Zi);
var c = '\n \n "),
d = e.svgStringToNode(c);
1 !== s && e.scaleSvgNode(d, s), e.convertImagesToBase64(d).then((function () {
c = (new XMLSerializer).serializeToString(d), i(c.replace(/ /g, " "))
}))
}))
}
}, {
key: "convertImagesToBase64", value: function (t) {
var e = this, i = t.getElementsByTagName("image"), a = Array.from(i).map((function (t) {
var i = t.getAttributeNS("http://www.w3.org/1999/xlink", "href");
return i && !i.startsWith("data:") ? e.getBase64FromUrl(i).then((function (e) {
t.setAttributeNS("http://www.w3.org/1999/xlink", "href", e)
})).catch((function (t) {
console.error("Error converting image to base64:", t)
})) : Promise.resolve()
}));
return Promise.all(a)
}
}, {
key: "getBase64FromUrl", value: function (t) {
return new Promise((function (e, i) {
var a = new Image;
a.crossOrigin = "Anonymous", a.onload = function () {
var t = document.createElement("canvas");
t.width = a.width, t.height = a.height, t.getContext("2d").drawImage(a, 0, 0), e(t.toDataURL())
}, a.onerror = i, a.src = t
}))
}
}, {
key: "svgUrl", value: function () {
var t = this;
return new Promise((function (e) {
t.getSvgString().then((function (t) {
var i = new Blob([t], {type: "image/svg+xml;charset=utf-8"});
e(URL.createObjectURL(i))
}))
}))
}
}, {
key: "dataURI", value: function (t) {
var e = this;
return new Promise((function (i) {
var a = e.w, s = t ? t.scale || t.width / a.globals.svgWidth : 1,
r = document.createElement("canvas");
r.width = a.globals.svgWidth * s, r.height = parseInt(a.globals.dom.elWrap.style.height, 10) * s;
var n = "transparent" !== a.config.chart.background && a.config.chart.background ? a.config.chart.background : "#fff",
o = r.getContext("2d");
o.fillStyle = n, o.fillRect(0, 0, r.width * s, r.height * s), e.getSvgString(s).then((function (t) {
var e = "data:image/svg+xml," + encodeURIComponent(t), a = new Image;
a.crossOrigin = "anonymous", a.onload = function () {
if (o.drawImage(a, 0, 0), r.msToBlob) {
var t = r.msToBlob();
i({blob: t})
} else {
var e = r.toDataURL("image/png");
i({imgURI: e})
}
}, a.src = e
}))
}))
}
}, {
key: "exportToSVG", value: function () {
var t = this;
this.svgUrl().then((function (e) {
t.triggerDownload(e, t.w.config.chart.toolbar.export.svg.filename, ".svg")
}))
}
}, {
key: "exportToPng", value: function () {
var t = this, e = this.w.config.chart.toolbar.export.scale,
i = this.w.config.chart.toolbar.export.width, a = e ? {scale: e} : i ? {width: i} : void 0;
this.dataURI(a).then((function (e) {
var i = e.imgURI, a = e.blob;
a ? navigator.msSaveOrOpenBlob(a, t.w.globals.chartID + ".png") : t.triggerDownload(i, t.w.config.chart.toolbar.export.png.filename, ".png")
}))
}
}, {
key: "exportToCSV", value: function (t) {
var e = this, i = t.series, a = t.fileName, s = t.columnDelimiter, r = void 0 === s ? "," : s,
n = t.lineDelimiter, o = void 0 === n ? "\n" : n, l = this.w;
i || (i = l.config.series);
var h = [], c = [], d = "", u = l.globals.series.map((function (t, e) {
return -1 === l.globals.collapsedSeriesIndices.indexOf(e) ? t : []
})), g = function (t) {
return "function" == typeof l.config.chart.toolbar.export.csv.categoryFormatter ? l.config.chart.toolbar.export.csv.categoryFormatter(t) : "datetime" === l.config.xaxis.type && String(t).length >= 10 ? new Date(t).toDateString() : v.isNumber(t) ? t : t.split(r).join("")
}, p = function (t) {
return "function" == typeof l.config.chart.toolbar.export.csv.valueFormatter ? l.config.chart.toolbar.export.csv.valueFormatter(t) : t
}, x = Math.max.apply(Math, f(i.map((function (t) {
return t.data ? t.data.length : 0
})))), b = new Ji(this.ctx), m = new Ri(this.ctx), y = function (t) {
var i = "";
if (l.globals.axisCharts) {
if ("category" === l.config.xaxis.type || l.config.xaxis.convertedCatToNumeric) if (l.globals.isBarHorizontal) {
var a = l.globals.yLabelFormatters[0], s = new $i(e.ctx).getActiveConfigSeriesIndex();
i = a(l.globals.labels[t], {seriesIndex: s, dataPointIndex: t, w: l})
} else i = m.getLabel(l.globals.labels, l.globals.timescaleLabels, 0, t).text;
"datetime" === l.config.xaxis.type && (l.config.xaxis.categories.length ? i = l.config.xaxis.categories[t] : l.config.labels.length && (i = l.config.labels[t]))
} else i = l.config.labels[t];
return null === i ? "nullvalue" : (Array.isArray(i) && (i = i.join(" ")), v.isNumber(i) ? i : i.split(r).join(""))
}, w = function (t, e) {
if (h.length && 0 === e && c.push(h.join(r)), t.data) {
t.data = t.data.length && t.data || f(Array(x)).map((function () {
return ""
}));
for (var a = 0; a < t.data.length; a++) {
h = [];
var s = y(a);
if ("nullvalue" !== s) {
if (s || (b.isFormatXY() ? s = i[e].data[a].x : b.isFormat2DArray() && (s = i[e].data[a] ? i[e].data[a][0] : "")), 0 === e) {
h.push(g(s));
for (var n = 0; n < l.globals.series.length; n++) {
var o,
d = b.isFormatXY() ? null === (o = i[n].data[a]) || void 0 === o ? void 0 : o.y : u[n][a];
h.push(p(d))
}
}
("candlestick" === l.config.chart.type || t.type && "candlestick" === t.type) && (h.pop(), h.push(l.globals.seriesCandleO[e][a]), h.push(l.globals.seriesCandleH[e][a]), h.push(l.globals.seriesCandleL[e][a]), h.push(l.globals.seriesCandleC[e][a])), ("boxPlot" === l.config.chart.type || t.type && "boxPlot" === t.type) && (h.pop(), h.push(l.globals.seriesCandleO[e][a]), h.push(l.globals.seriesCandleH[e][a]), h.push(l.globals.seriesCandleM[e][a]), h.push(l.globals.seriesCandleL[e][a]), h.push(l.globals.seriesCandleC[e][a])), "rangeBar" === l.config.chart.type && (h.pop(), h.push(l.globals.seriesRangeStart[e][a]), h.push(l.globals.seriesRangeEnd[e][a])), h.length && c.push(h.join(r))
}
}
}
};
h.push(l.config.chart.toolbar.export.csv.headerCategory), "boxPlot" === l.config.chart.type ? (h.push("minimum"), h.push("q1"), h.push("median"), h.push("q3"), h.push("maximum")) : "candlestick" === l.config.chart.type ? (h.push("open"), h.push("high"), h.push("low"), h.push("close")) : "rangeBar" === l.config.chart.type ? (h.push("minimum"), h.push("maximum")) : i.map((function (t, e) {
var i = (t.name ? t.name : "series-".concat(e)) + "";
l.globals.axisCharts && h.push(i.split(r).join("") ? i.split(r).join("") : "series-".concat(e))
})), l.globals.axisCharts || (h.push(l.config.chart.toolbar.export.csv.headerValue), c.push(h.join(r))), l.globals.allSeriesHasEqualX || !l.globals.axisCharts || l.config.xaxis.categories.length || l.config.labels.length ? i.map((function (t, e) {
l.globals.axisCharts ? w(t, e) : ((h = []).push(g(l.globals.labels[e])), h.push(p(u[e])), c.push(h.join(r)))
})) : function () {
var t = new Set, e = {};
i.forEach((function (a, s) {
null == a || a.data.forEach((function (a) {
var r, n;
if (b.isFormatXY()) r = a.x, n = a.y; else {
if (!b.isFormat2DArray()) return;
r = a[0], n = a[1]
}
e[r] || (e[r] = Array(i.length).fill("")), e[r][s] = p(n), t.add(r)
}))
})), h.length && c.push(h.join(r)), Array.from(t).sort().forEach((function (t) {
c.push([g(t), e[t].join(r)])
}))
}(), d += c.join(o), this.triggerDownload("data:text/csv; charset=utf-8," + encodeURIComponent("\ufeff" + d), a || l.config.chart.toolbar.export.csv.filename, ".csv")
}
}, {
key: "triggerDownload", value: function (t, e, i) {
var a = document.createElement("a");
a.href = t, a.download = (e || this.w.globals.chartID) + i, document.body.appendChild(a), a.click(), document.body.removeChild(a)
}
}]), t
}(), Ki = function () {
function t(e, a) {
i(this, t), this.ctx = e, this.elgrid = a, this.w = e.w;
var s = this.w;
this.axesUtils = new Ri(e), this.xaxisLabels = s.globals.labels.slice(), s.globals.timescaleLabels.length > 0 && !s.globals.isBarHorizontal && (this.xaxisLabels = s.globals.timescaleLabels.slice()), s.config.xaxis.overwriteCategories && (this.xaxisLabels = s.config.xaxis.overwriteCategories), this.drawnLabels = [], this.drawnLabelsRects = [], "top" === s.config.xaxis.position ? this.offY = 0 : this.offY = s.globals.gridHeight, this.offY = this.offY + s.config.xaxis.axisBorder.offsetY, this.isCategoryBarHorizontal = "bar" === s.config.chart.type && s.config.plotOptions.bar.horizontal, this.xaxisFontSize = s.config.xaxis.labels.style.fontSize, this.xaxisFontFamily = s.config.xaxis.labels.style.fontFamily, this.xaxisForeColors = s.config.xaxis.labels.style.colors, this.xaxisBorderWidth = s.config.xaxis.axisBorder.width, this.isCategoryBarHorizontal && (this.xaxisBorderWidth = s.config.yaxis[0].axisBorder.width.toString()), String(this.xaxisBorderWidth).indexOf("%") > -1 ? this.xaxisBorderWidth = s.globals.gridWidth * parseInt(this.xaxisBorderWidth, 10) / 100 : this.xaxisBorderWidth = parseInt(this.xaxisBorderWidth, 10), this.xaxisBorderHeight = s.config.xaxis.axisBorder.height, this.yaxis = s.config.yaxis[0]
}
return s(t, [{
key: "drawXaxis", value: function () {
var t = this.w, e = new Mi(this.ctx), i = e.group({
class: "apexcharts-xaxis",
transform: "translate(".concat(t.config.xaxis.offsetX, ", ").concat(t.config.xaxis.offsetY, ")")
}), a = e.group({
class: "apexcharts-xaxis-texts-g",
transform: "translate(".concat(t.globals.translateXAxisX, ", ").concat(t.globals.translateXAxisY, ")")
});
i.add(a);
for (var s = [], r = 0; r < this.xaxisLabels.length; r++) s.push(this.xaxisLabels[r]);
if (this.drawXAxisLabelAndGroup(!0, e, a, s, t.globals.isXNumeric, (function (t, e) {
return e
})), t.globals.hasXaxisGroups) {
var n = t.globals.groups;
s = [];
for (var o = 0; o < n.length; o++) s.push(n[o].title);
var l = {};
t.config.xaxis.group.style && (l.xaxisFontSize = t.config.xaxis.group.style.fontSize, l.xaxisFontFamily = t.config.xaxis.group.style.fontFamily, l.xaxisForeColors = t.config.xaxis.group.style.colors, l.fontWeight = t.config.xaxis.group.style.fontWeight, l.cssClass = t.config.xaxis.group.style.cssClass), this.drawXAxisLabelAndGroup(!1, e, a, s, !1, (function (t, e) {
return n[t].cols * e
}), l)
}
if (void 0 !== t.config.xaxis.title.text) {
var h = e.group({class: "apexcharts-xaxis-title"}), c = e.drawText({
x: t.globals.gridWidth / 2 + t.config.xaxis.title.offsetX,
y: this.offY + parseFloat(this.xaxisFontSize) + ("bottom" === t.config.xaxis.position ? t.globals.xAxisLabelsHeight : -t.globals.xAxisLabelsHeight - 10) + t.config.xaxis.title.offsetY,
text: t.config.xaxis.title.text,
textAnchor: "middle",
fontSize: t.config.xaxis.title.style.fontSize,
fontFamily: t.config.xaxis.title.style.fontFamily,
fontWeight: t.config.xaxis.title.style.fontWeight,
foreColor: t.config.xaxis.title.style.color,
cssClass: "apexcharts-xaxis-title-text " + t.config.xaxis.title.style.cssClass
});
h.add(c), i.add(h)
}
if (t.config.xaxis.axisBorder.show) {
var d = t.globals.barPadForNumericAxis,
u = e.drawLine(t.globals.padHorizontal + t.config.xaxis.axisBorder.offsetX - d, this.offY, this.xaxisBorderWidth + d, this.offY, t.config.xaxis.axisBorder.color, 0, this.xaxisBorderHeight);
this.elgrid && this.elgrid.elGridBorders && t.config.grid.show ? this.elgrid.elGridBorders.add(u) : i.add(u)
}
return i
}
}, {
key: "drawXAxisLabelAndGroup", value: function (t, e, i, a, s, r) {
var n, o = this, l = arguments.length > 6 && void 0 !== arguments[6] ? arguments[6] : {}, h = [],
c = [], d = this.w, u = l.xaxisFontSize || this.xaxisFontSize,
g = l.xaxisFontFamily || this.xaxisFontFamily, p = l.xaxisForeColors || this.xaxisForeColors,
f = l.fontWeight || d.config.xaxis.labels.style.fontWeight,
x = l.cssClass || d.config.xaxis.labels.style.cssClass, b = d.globals.padHorizontal, m = a.length,
v = "category" === d.config.xaxis.type ? d.globals.dataPoints : m;
if (0 === v && m > v && (v = m), s) {
var y = Math.max(Number(d.config.xaxis.tickAmount) || 1, v > 1 ? v - 1 : v);
n = d.globals.gridWidth / Math.min(y, m - 1), b = b + r(0, n) / 2 + d.config.xaxis.labels.offsetX
} else n = d.globals.gridWidth / v, b = b + r(0, n) + d.config.xaxis.labels.offsetX;
for (var w = function (s) {
var l = b - r(s, n) / 2 + d.config.xaxis.labels.offsetX;
0 === s && 1 === m && n / 2 === b && 1 === v && (l = d.globals.gridWidth / 2);
var y = o.axesUtils.getLabel(a, d.globals.timescaleLabels, l, s, h, u, t), w = 28;
d.globals.rotateXLabels && t && (w = 22), d.config.xaxis.title.text && "top" === d.config.xaxis.position && (w += parseFloat(d.config.xaxis.title.style.fontSize) + 2), t || (w = w + parseFloat(u) + (d.globals.xAxisLabelsHeight - d.globals.xAxisGroupLabelsHeight) + (d.globals.rotateXLabels ? 10 : 0)), y = void 0 !== d.config.xaxis.tickAmount && "dataPoints" !== d.config.xaxis.tickAmount && "datetime" !== d.config.xaxis.type ? o.axesUtils.checkLabelBasedOnTickamount(s, y, m) : o.axesUtils.checkForOverflowingLabels(s, y, m, h, c);
if (d.config.xaxis.labels.show) {
var k = e.drawText({
x: y.x,
y: o.offY + d.config.xaxis.labels.offsetY + w - ("top" === d.config.xaxis.position ? d.globals.xAxisHeight + d.config.xaxis.axisTicks.height - 2 : 0),
text: y.text,
textAnchor: "middle",
fontWeight: y.isBold ? 600 : f,
fontSize: u,
fontFamily: g,
foreColor: Array.isArray(p) ? t && d.config.xaxis.convertedCatToNumeric ? p[d.globals.minX + s - 1] : p[s] : p,
isPlainText: !1,
cssClass: (t ? "apexcharts-xaxis-label " : "apexcharts-xaxis-group-label ") + x
});
if (i.add(k), k.on("click", (function (t) {
if ("function" == typeof d.config.chart.events.xAxisLabelClick) {
var e = Object.assign({}, d, {labelIndex: s});
d.config.chart.events.xAxisLabelClick(t, o.ctx, e)
}
})), t) {
var A = document.createElementNS(d.globals.SVGNS, "title");
A.textContent = Array.isArray(y.text) ? y.text.join(" ") : y.text, k.node.appendChild(A), "" !== y.text && (h.push(y.text), c.push(y))
}
}
s < m - 1 && (b += r(s + 1, n))
}, k = 0; k <= m - 1; k++) w(k)
}
}, {
key: "drawXaxisInversed", value: function (t) {
var e, i, a = this, s = this.w, r = new Mi(this.ctx),
n = s.config.yaxis[0].opposite ? s.globals.translateYAxisX[t] : 0,
o = r.group({class: "apexcharts-yaxis apexcharts-xaxis-inversed", rel: t}), l = r.group({
class: "apexcharts-yaxis-texts-g apexcharts-xaxis-inversed-texts-g",
transform: "translate(" + n + ", 0)"
});
o.add(l);
var h = [];
if (s.config.yaxis[t].show) for (var c = 0; c < this.xaxisLabels.length; c++) h.push(this.xaxisLabels[c]);
e = s.globals.gridHeight / h.length, i = -e / 2.2;
var d = s.globals.yLabelFormatters[0], u = s.config.yaxis[0].labels;
if (u.show) for (var g = function (n) {
var o = void 0 === h[n] ? "" : h[n];
o = d(o, {seriesIndex: t, dataPointIndex: n, w: s});
var c = a.axesUtils.getYAxisForeColor(u.style.colors, t), g = 0;
Array.isArray(o) && (g = o.length / 2 * parseInt(u.style.fontSize, 10));
var p = u.offsetX - 15, f = "end";
a.yaxis.opposite && (f = "start"), "left" === s.config.yaxis[0].labels.align ? (p = u.offsetX, f = "start") : "center" === s.config.yaxis[0].labels.align ? (p = u.offsetX, f = "middle") : "right" === s.config.yaxis[0].labels.align && (f = "end");
var x = r.drawText({
x: p,
y: i + e + u.offsetY - g,
text: o,
textAnchor: f,
foreColor: Array.isArray(c) ? c[n] : c,
fontSize: u.style.fontSize,
fontFamily: u.style.fontFamily,
fontWeight: u.style.fontWeight,
isPlainText: !1,
cssClass: "apexcharts-yaxis-label " + u.style.cssClass,
maxWidth: u.maxWidth
});
l.add(x), x.on("click", (function (t) {
if ("function" == typeof s.config.chart.events.xAxisLabelClick) {
var e = Object.assign({}, s, {labelIndex: n});
s.config.chart.events.xAxisLabelClick(t, a.ctx, e)
}
}));
var b = document.createElementNS(s.globals.SVGNS, "title");
if (b.textContent = Array.isArray(o) ? o.join(" ") : o, x.node.appendChild(b), 0 !== s.config.yaxis[t].labels.rotate) {
var m = r.rotateAroundCenter(x.node);
x.node.setAttribute("transform", "rotate(".concat(s.config.yaxis[t].labels.rotate, " 0 ").concat(m.y, ")"))
}
i += e
}, p = 0; p <= h.length - 1; p++) g(p);
if (void 0 !== s.config.yaxis[0].title.text) {
var f = r.group({
class: "apexcharts-yaxis-title apexcharts-xaxis-title-inversed",
transform: "translate(" + n + ", 0)"
}), x = r.drawText({
x: s.config.yaxis[0].title.offsetX,
y: s.globals.gridHeight / 2 + s.config.yaxis[0].title.offsetY,
text: s.config.yaxis[0].title.text,
textAnchor: "middle",
foreColor: s.config.yaxis[0].title.style.color,
fontSize: s.config.yaxis[0].title.style.fontSize,
fontWeight: s.config.yaxis[0].title.style.fontWeight,
fontFamily: s.config.yaxis[0].title.style.fontFamily,
cssClass: "apexcharts-yaxis-title-text " + s.config.yaxis[0].title.style.cssClass
});
f.add(x), o.add(f)
}
var b = 0;
this.isCategoryBarHorizontal && s.config.yaxis[0].opposite && (b = s.globals.gridWidth);
var m = s.config.xaxis.axisBorder;
if (m.show) {
var v = r.drawLine(s.globals.padHorizontal + m.offsetX + b, 1 + m.offsetY, s.globals.padHorizontal + m.offsetX + b, s.globals.gridHeight + m.offsetY, m.color, 0);
this.elgrid && this.elgrid.elGridBorders && s.config.grid.show ? this.elgrid.elGridBorders.add(v) : o.add(v)
}
return s.config.yaxis[0].axisTicks.show && this.axesUtils.drawYAxisTicks(b, h.length, s.config.yaxis[0].axisBorder, s.config.yaxis[0].axisTicks, 0, e, o), o
}
}, {
key: "drawXaxisTicks", value: function (t, e, i) {
var a = this.w, s = t;
if (!(t < 0 || t - 2 > a.globals.gridWidth)) {
var r = this.offY + a.config.xaxis.axisTicks.offsetY;
if (e = e + r + a.config.xaxis.axisTicks.height, "top" === a.config.xaxis.position && (e = r - a.config.xaxis.axisTicks.height), a.config.xaxis.axisTicks.show) {
var n = new Mi(this.ctx).drawLine(t + a.config.xaxis.axisTicks.offsetX, r + a.config.xaxis.offsetY, s + a.config.xaxis.axisTicks.offsetX, e + a.config.xaxis.offsetY, a.config.xaxis.axisTicks.color);
i.add(n), n.node.classList.add("apexcharts-xaxis-tick")
}
}
}
}, {
key: "getXAxisTicksPositions", value: function () {
var t = this.w, e = [], i = this.xaxisLabels.length, a = t.globals.padHorizontal;
if (t.globals.timescaleLabels.length > 0) for (var s = 0; s < i; s++) a = this.xaxisLabels[s].position, e.push(a); else for (var r = i, n = 0; n < r; n++) {
var o = r;
t.globals.isXNumeric && "bar" !== t.config.chart.type && (o -= 1), a += t.globals.gridWidth / o, e.push(a)
}
return e
}
}, {
key: "xAxisLabelCorrections", value: function () {
var t = this.w, e = new Mi(this.ctx),
i = t.globals.dom.baseEl.querySelector(".apexcharts-xaxis-texts-g"),
a = t.globals.dom.baseEl.querySelectorAll(".apexcharts-xaxis-texts-g text:not(.apexcharts-xaxis-group-label)"),
s = t.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis-inversed text"),
r = t.globals.dom.baseEl.querySelectorAll(".apexcharts-xaxis-inversed-texts-g text tspan");
if (t.globals.rotateXLabels || t.config.xaxis.labels.rotateAlways) for (var n = 0; n < a.length; n++) {
var o = e.rotateAroundCenter(a[n]);
o.y = o.y - 1, o.x = o.x + 1, a[n].setAttribute("transform", "rotate(".concat(t.config.xaxis.labels.rotate, " ").concat(o.x, " ").concat(o.y, ")")), a[n].setAttribute("text-anchor", "end");
i.setAttribute("transform", "translate(0, ".concat(-10, ")"));
var l = a[n].childNodes;
t.config.xaxis.labels.trim && Array.prototype.forEach.call(l, (function (i) {
e.placeTextWithEllipsis(i, i.textContent, t.globals.xAxisLabelsHeight - ("bottom" === t.config.legend.position ? 20 : 10))
}))
} else !function () {
for (var i = t.globals.gridWidth / (t.globals.labels.length + 1), s = 0; s < a.length; s++) {
var r = a[s].childNodes;
t.config.xaxis.labels.trim && "datetime" !== t.config.xaxis.type && Array.prototype.forEach.call(r, (function (t) {
e.placeTextWithEllipsis(t, t.textContent, i)
}))
}
}();
if (s.length > 0) {
var h = s[s.length - 1].getBBox(), c = s[0].getBBox();
h.x < -20 && s[s.length - 1].parentNode.removeChild(s[s.length - 1]), c.x + c.width > t.globals.gridWidth && !t.globals.isBarHorizontal && s[0].parentNode.removeChild(s[0]);
for (var d = 0; d < r.length; d++) e.placeTextWithEllipsis(r[d], r[d].textContent, t.config.yaxis[0].labels.maxWidth - (t.config.yaxis[0].title.text ? 2 * parseFloat(t.config.yaxis[0].title.style.fontSize) : 0) - 15)
}
}
}]), t
}(), ta = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w;
var a = this.w;
this.xaxisLabels = a.globals.labels.slice(), this.axesUtils = new Ri(e), this.isRangeBar = a.globals.seriesRange.length && a.globals.isBarHorizontal, a.globals.timescaleLabels.length > 0 && (this.xaxisLabels = a.globals.timescaleLabels.slice())
}
return s(t, [{
key: "drawGridArea", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null, e = this.w,
i = new Mi(this.ctx);
t || (t = i.group({class: "apexcharts-grid"}));
var a = i.drawLine(e.globals.padHorizontal, 1, e.globals.padHorizontal, e.globals.gridHeight, "transparent"),
s = i.drawLine(e.globals.padHorizontal, e.globals.gridHeight, e.globals.gridWidth, e.globals.gridHeight, "transparent");
return t.add(s), t.add(a), t
}
}, {
key: "drawGrid", value: function () {
if (this.w.globals.axisCharts) {
var t = this.renderGrid();
return this.drawGridArea(t.el), t
}
return null
}
}, {
key: "createGridMask", value: function () {
var t = this.w, e = t.globals, i = new Mi(this.ctx),
a = Array.isArray(t.config.stroke.width) ? Math.max.apply(Math, f(t.config.stroke.width)) : t.config.stroke.width,
s = function (t) {
var i = document.createElementNS(e.SVGNS, "clipPath");
return i.setAttribute("id", t), i
};
e.dom.elGridRectMask = s("gridRectMask".concat(e.cuid)), e.dom.elGridRectBarMask = s("gridRectBarMask".concat(e.cuid)), e.dom.elGridRectMarkerMask = s("gridRectMarkerMask".concat(e.cuid)), e.dom.elForecastMask = s("forecastMask".concat(e.cuid)), e.dom.elNonForecastMask = s("nonForecastMask".concat(e.cuid));
var r = 0, n = 0;
(["bar", "rangeBar", "candlestick", "boxPlot"].includes(t.config.chart.type) || t.globals.comboBarCount > 0) && t.globals.isXNumeric && !t.globals.isBarHorizontal && (r = Math.max(t.config.grid.padding.left, e.barPadForNumericAxis), n = Math.max(t.config.grid.padding.right, e.barPadForNumericAxis)), e.dom.elGridRect = i.drawRect(-a / 2 - 2, -a / 2 - 2, e.gridWidth + a + 4, e.gridHeight + a + 4, 0, "#fff"), e.dom.elGridRectBar = i.drawRect(-a / 2 - r - 2, -a / 2 - 2, e.gridWidth + a + n + r + 4, e.gridHeight + a + 4, 0, "#fff");
var o = t.globals.markers.largestSize;
e.dom.elGridRectMarker = i.drawRect(Math.min(-a / 2 - r - 2, -o), -o, e.gridWidth + Math.max(a + n + r + 4, 2 * o), e.gridHeight + 2 * o, 0, "#fff"), e.dom.elGridRectMask.appendChild(e.dom.elGridRect.node), e.dom.elGridRectBarMask.appendChild(e.dom.elGridRectBar.node), e.dom.elGridRectMarkerMask.appendChild(e.dom.elGridRectMarker.node);
var l = e.dom.baseEl.querySelector("defs");
l.appendChild(e.dom.elGridRectMask), l.appendChild(e.dom.elGridRectBarMask), l.appendChild(e.dom.elGridRectMarkerMask), l.appendChild(e.dom.elForecastMask), l.appendChild(e.dom.elNonForecastMask)
}
}, {
key: "_drawGridLines", value: function (t) {
var e = t.i, i = t.x1, a = t.y1, s = t.x2, r = t.y2, n = t.xCount, o = t.parent, l = this.w;
if (!(0 === e && l.globals.skipFirstTimelinelabel || e === n - 1 && l.globals.skipLastTimelinelabel && !l.config.xaxis.labels.formatter || "radar" === l.config.chart.type)) {
l.config.grid.xaxis.lines.show && this._drawGridLine({
i: e,
x1: i,
y1: a,
x2: s,
y2: r,
xCount: n,
parent: o
});
var h = 0;
if (l.globals.hasXaxisGroups && "between" === l.config.xaxis.tickPlacement) {
var c = l.globals.groups;
if (c) {
for (var d = 0, u = 0; d < e && u < c.length; u++) d += c[u].cols;
d === e && (h = .6 * l.globals.xAxisLabelsHeight)
}
}
new Ki(this.ctx).drawXaxisTicks(i, h, l.globals.dom.elGraphical)
}
}
}, {
key: "_drawGridLine", value: function (t) {
var e = t.i, i = t.x1, a = t.y1, s = t.x2, r = t.y2, n = t.xCount, o = t.parent, l = this.w,
h = o.node.classList.contains("apexcharts-gridlines-horizontal"),
c = l.globals.barPadForNumericAxis,
d = 0 === a && 0 === r || 0 === i && 0 === s || a === l.globals.gridHeight && r === l.globals.gridHeight || l.globals.isBarHorizontal && (0 === e || e === n - 1),
u = new Mi(this).drawLine(i - (h ? c : 0), a, s + (h ? c : 0), r, l.config.grid.borderColor, l.config.grid.strokeDashArray);
u.node.classList.add("apexcharts-gridline"), d && l.config.grid.show ? this.elGridBorders.add(u) : o.add(u)
}
}, {
key: "_drawGridBandRect", value: function (t) {
var e = t.c, i = t.x1, a = t.y1, s = t.x2, r = t.y2, n = t.type, o = this.w, l = new Mi(this.ctx),
h = o.globals.barPadForNumericAxis, c = o.config.grid[n].colors[e],
d = l.drawRect(i - ("row" === n ? h : 0), a, s + ("row" === n ? 2 * h : 0), r, 0, c, o.config.grid[n].opacity);
this.elg.add(d), d.attr("clip-path", "url(#gridRectMask".concat(o.globals.cuid, ")")), d.node.classList.add("apexcharts-grid-".concat(n))
}
}, {
key: "_drawXYLines", value: function (t) {
var e = this, i = t.xCount, a = t.tickAmount, s = this.w;
if (s.config.grid.xaxis.lines.show || s.config.xaxis.axisTicks.show) {
var r, n = s.globals.padHorizontal, o = s.globals.gridHeight;
s.globals.timescaleLabels.length ? function (t) {
for (var a = t.xC, s = t.x1, r = t.y1, n = t.x2, o = t.y2, l = 0; l < a; l++) s = e.xaxisLabels[l].position, n = e.xaxisLabels[l].position, e._drawGridLines({
i: l,
x1: s,
y1: r,
x2: n,
y2: o,
xCount: i,
parent: e.elgridLinesV
})
}({
xC: i,
x1: n,
y1: 0,
x2: r,
y2: o
}) : (s.globals.isXNumeric && (i = s.globals.xAxisScale.result.length), function (t) {
for (var a = t.xC, r = t.x1, n = t.y1, o = t.x2, l = t.y2, h = 0; h < a + (s.globals.isXNumeric ? 0 : 1); h++) 0 === h && 1 === a && 1 === s.globals.dataPoints && (o = r = s.globals.gridWidth / 2), e._drawGridLines({
i: h,
x1: r,
y1: n,
x2: o,
y2: l,
xCount: i,
parent: e.elgridLinesV
}), o = r += s.globals.gridWidth / (s.globals.isXNumeric ? a - 1 : a)
}({xC: i, x1: n, y1: 0, x2: r, y2: o}))
}
if (s.config.grid.yaxis.lines.show) {
var l = 0, h = 0, c = s.globals.gridWidth, d = a + 1;
this.isRangeBar && (d = s.globals.labels.length);
for (var u = 0; u < d + (this.isRangeBar ? 1 : 0); u++) this._drawGridLine({
i: u,
xCount: d + (this.isRangeBar ? 1 : 0),
x1: 0,
y1: l,
x2: c,
y2: h,
parent: this.elgridLinesH
}), h = l += s.globals.gridHeight / (this.isRangeBar ? d : a)
}
}
}, {
key: "_drawInvertedXYLines", value: function (t) {
var e = t.xCount, i = this.w;
if (i.config.grid.xaxis.lines.show || i.config.xaxis.axisTicks.show) for (var a, s = i.globals.padHorizontal, r = i.globals.gridHeight, n = 0; n < e + 1; n++) {
i.config.grid.xaxis.lines.show && this._drawGridLine({
i: n,
xCount: e + 1,
x1: s,
y1: 0,
x2: a,
y2: r,
parent: this.elgridLinesV
}), new Ki(this.ctx).drawXaxisTicks(s, 0, i.globals.dom.elGraphical), a = s += i.globals.gridWidth / e
}
if (i.config.grid.yaxis.lines.show) for (var o = 0, l = 0, h = i.globals.gridWidth, c = 0; c < i.globals.dataPoints + 1; c++) this._drawGridLine({
i: c,
xCount: i.globals.dataPoints + 1,
x1: 0,
y1: o,
x2: h,
y2: l,
parent: this.elgridLinesH
}), l = o += i.globals.gridHeight / i.globals.dataPoints
}
}, {
key: "renderGrid", value: function () {
var t = this.w, e = t.globals, i = new Mi(this.ctx);
this.elg = i.group({class: "apexcharts-grid"}), this.elgridLinesH = i.group({class: "apexcharts-gridlines-horizontal"}), this.elgridLinesV = i.group({class: "apexcharts-gridlines-vertical"}), this.elGridBorders = i.group({class: "apexcharts-grid-borders"}), this.elg.add(this.elgridLinesH), this.elg.add(this.elgridLinesV), t.config.grid.show || (this.elgridLinesV.hide(), this.elgridLinesH.hide(), this.elGridBorders.hide());
for (var a = 0; a < e.seriesYAxisMap.length && e.ignoreYAxisIndexes.includes(a);) a++;
a === e.seriesYAxisMap.length && (a = 0);
var s, r = e.yAxisScale[a].result.length - 1;
if (!e.isBarHorizontal || this.isRangeBar) {
var n, o, l;
if (s = this.xaxisLabels.length, this.isRangeBar) r = e.labels.length, t.config.xaxis.tickAmount && t.config.xaxis.labels.formatter && (s = t.config.xaxis.tickAmount), (null === (n = e.yAxisScale) || void 0 === n || null === (o = n[a]) || void 0 === o || null === (l = o.result) || void 0 === l ? void 0 : l.length) > 0 && "datetime" !== t.config.xaxis.type && (s = e.yAxisScale[a].result.length - 1);
this._drawXYLines({xCount: s, tickAmount: r})
} else s = r, r = e.xTickAmount, this._drawInvertedXYLines({xCount: s, tickAmount: r});
return this.drawGridBands(s, r), {
el: this.elg,
elGridBorders: this.elGridBorders,
xAxisTickWidth: e.gridWidth / s
}
}
}, {
key: "drawGridBands", value: function (t, e) {
var i, a, s = this, r = this.w;
if ((null === (i = r.config.grid.row.colors) || void 0 === i ? void 0 : i.length) > 0 && function (t, i, a, n, o, l) {
for (var h = 0, c = 0; h < i; h++, c++) c >= r.config.grid[t].colors.length && (c = 0), s._drawGridBandRect({
c: c,
x1: a,
y1: n,
x2: o,
y2: l,
type: t
}), n += r.globals.gridHeight / e
}("row", e, 0, 0, r.globals.gridWidth, r.globals.gridHeight / e), (null === (a = r.config.grid.column.colors) || void 0 === a ? void 0 : a.length) > 0) {
var n = r.globals.isBarHorizontal || "on" !== r.config.xaxis.tickPlacement || "category" !== r.config.xaxis.type && !r.config.xaxis.convertedCatToNumeric ? t : t - 1;
r.globals.isXNumeric && (n = r.globals.xAxisScale.result.length - 1);
for (var o = r.globals.padHorizontal, l = r.globals.padHorizontal + r.globals.gridWidth / n, h = r.globals.gridHeight, c = 0, d = 0; c < t; c++, d++) {
var u;
if (d >= r.config.grid.column.colors.length && (d = 0), "datetime" === r.config.xaxis.type) o = this.xaxisLabels[c].position, l = ((null === (u = this.xaxisLabels[c + 1]) || void 0 === u ? void 0 : u.position) || r.globals.gridWidth) - this.xaxisLabels[c].position;
this._drawGridBandRect({
c: d,
x1: o,
y1: 0,
x2: l,
y2: h,
type: "column"
}), o += r.globals.gridWidth / n
}
}
}
}]), t
}(), ea = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.coreUtils = new Pi(this.ctx)
}
return s(t, [{
key: "niceScale", value: function (t, e) {
var i, a, s, r, n = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : 0, o = 1e-11,
l = this.w, h = l.globals;
h.isBarHorizontal ? (i = l.config.xaxis, a = Math.max((h.svgWidth - 100) / 25, 2)) : (i = l.config.yaxis[n], a = Math.max((h.svgHeight - 100) / 15, 2)), v.isNumber(a) || (a = 10), s = void 0 !== i.min && null !== i.min, r = void 0 !== i.max && null !== i.min;
var c = void 0 !== i.stepSize && null !== i.stepSize,
d = void 0 !== i.tickAmount && null !== i.tickAmount,
u = d ? i.tickAmount : h.niceScaleDefaultTicks[Math.min(Math.round(a / 2), h.niceScaleDefaultTicks.length - 1)];
if (h.isMultipleYAxis && !d && h.multiAxisTickAmount > 0 && (u = h.multiAxisTickAmount, d = !0), u = "dataPoints" === u ? h.dataPoints - 1 : Math.abs(Math.round(u)), (t === Number.MIN_VALUE && 0 === e || !v.isNumber(t) && !v.isNumber(e) || t === Number.MIN_VALUE && e === -Number.MAX_VALUE) && (t = v.isNumber(i.min) ? i.min : 0, e = v.isNumber(i.max) ? i.max : t + u, h.allSeriesCollapsed = !1), t > e) {
console.warn("axis.min cannot be greater than axis.max: swapping min and max");
var g = e;
e = t, t = g
} else t === e && (t = 0 === t ? 0 : t - 1, e = 0 === e ? 2 : e + 1);
var p = [];
u < 1 && (u = 1);
var f = u, x = Math.abs(e - t);
!s && t > 0 && t / x < .15 && (t = 0, s = !0), !r && e < 0 && -e / x < .15 && (e = 0, r = !0);
var b = (x = Math.abs(e - t)) / f, m = b, y = Math.floor(Math.log10(m)), w = Math.pow(10, y),
k = Math.ceil(m / w);
if (b = m = (k = h.niceScaleAllowedMagMsd[0 === h.yValueDecimal ? 0 : 1][k]) * w, h.isBarHorizontal && i.stepSize && "datetime" !== i.type ? (b = i.stepSize, c = !0) : c && (b = i.stepSize), c && i.forceNiceScale) {
var A = Math.floor(Math.log10(b));
b *= Math.pow(10, y - A)
}
if (s && r) {
var C = x / f;
if (d) if (c) if (0 != v.mod(x, b)) {
var S = v.getGCD(b, C);
b = C / S < 10 ? S : C
} else 0 == v.mod(b, C) ? b = C : (C = b, d = !1); else b = C; else if (c) 0 == v.mod(x, b) ? C = b : b = C; else if (0 == v.mod(x, b)) C = b; else {
C = x / (f = Math.ceil(x / b));
var L = v.getGCD(x, b);
x / L < a && (C = L), b = C
}
f = Math.round(x / b)
} else {
if (s || r) {
if (r) if (d) t = e - b * f; else {
var M = t;
t = b * Math.floor(t / b), Math.abs(e - t) / v.getGCD(x, b) > a && (t = e - b * u, t += b * Math.floor((M - t) / b))
} else if (s) if (d) e = t + b * f; else {
var P = e;
e = b * Math.ceil(e / b), Math.abs(e - t) / v.getGCD(x, b) > a && (e = t + b * u, e += b * Math.ceil((P - e) / b))
}
} else if (h.isMultipleYAxis && d) {
var I = b * Math.floor(t / b), T = I + b * f;
T < e && (b *= 2), T = e, e = (t = I) + b * f, x = Math.abs(e - t), t > 0 && t < Math.abs(T - e) && (t = 0, e = b * f), e < 0 && -e < Math.abs(I - t) && (e = 0, t = -b * f)
} else t = b * Math.floor(t / b), e = b * Math.ceil(e / b);
x = Math.abs(e - t), b = v.getGCD(x, b), f = Math.round(x / b)
}
if (d || s || r || (f = Math.ceil((x - o) / (b + o))) > 16 && v.getPrimeFactors(f).length < 2 && f++, !d && i.forceNiceScale && 0 === h.yValueDecimal && f > x && (f = x, b = Math.round(x / f)), f > a && (!d && !c || i.forceNiceScale)) {
var z = v.getPrimeFactors(f), X = z.length - 1, R = f;
t:for (var E = 0; E < X; E++) for (var Y = 0; Y <= X - E; Y++) {
for (var H = Math.min(Y + E, X), O = R, F = 1, D = Y; D <= H; D++) F *= z[D];
if ((O /= F) < a) {
R = O;
break t
}
}
b = R === f ? x : x / R, f = Math.round(x / b)
}
h.isMultipleYAxis && 0 == h.multiAxisTickAmount && h.ignoreYAxisIndexes.indexOf(n) < 0 && (h.multiAxisTickAmount = f);
var _ = t - b, N = b * o;
do {
_ += b, p.push(v.stripNumber(_, 7))
} while (e - _ > N);
return {result: p, niceMin: p[0], niceMax: p[p.length - 1]}
}
}, {
key: "linearScale", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : 10,
a = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : 0,
s = arguments.length > 4 && void 0 !== arguments[4] ? arguments[4] : void 0, r = Math.abs(e - t),
n = [];
if (t === e) return {result: n = [t], niceMin: n[0], niceMax: n[n.length - 1]};
"dataPoints" === (i = this._adjustTicksForSmallRange(i, a, r)) && (i = this.w.globals.dataPoints - 1), s || (s = r / i), s = Math.round(100 * (s + Number.EPSILON)) / 100, i === Number.MAX_VALUE && (i = 5, s = 1);
for (var o = t; i >= 0;) n.push(o), o = v.preciseAddition(o, s), i -= 1;
return {result: n, niceMin: n[0], niceMax: n[n.length - 1]}
}
}, {
key: "logarithmicScaleNice", value: function (t, e, i) {
e <= 0 && (e = Math.max(t, i)), t <= 0 && (t = Math.min(e, i));
for (var a = [], s = Math.ceil(Math.log(e) / Math.log(i) + 1), r = Math.floor(Math.log(t) / Math.log(i)); r < s; r++) a.push(Math.pow(i, r));
return {result: a, niceMin: a[0], niceMax: a[a.length - 1]}
}
}, {
key: "logarithmicScale", value: function (t, e, i) {
e <= 0 && (e = Math.max(t, i)), t <= 0 && (t = Math.min(e, i));
for (var a = [], s = Math.log(e) / Math.log(i), r = Math.log(t) / Math.log(i), n = s - r, o = Math.round(n), l = n / o, h = 0, c = r; h < o; h++, c += l) a.push(Math.pow(i, c));
return a.push(Math.pow(i, s)), {result: a, niceMin: t, niceMax: e}
}
}, {
key: "_adjustTicksForSmallRange", value: function (t, e, i) {
var a = t;
if (void 0 !== e && this.w.config.yaxis[e].labels.formatter && void 0 === this.w.config.yaxis[e].tickAmount) {
var s = Number(this.w.config.yaxis[e].labels.formatter(1));
v.isNumber(s) && 0 === this.w.globals.yValueDecimal && (a = Math.ceil(i))
}
return a < t ? a : t
}
}, {
key: "setYScaleForIndex", value: function (t, e, i) {
var a = this.w.globals, s = this.w.config, r = a.isBarHorizontal ? s.xaxis : s.yaxis[t];
void 0 === a.yAxisScale[t] && (a.yAxisScale[t] = []);
var n = Math.abs(i - e);
r.logarithmic && n <= 5 && (a.invalidLogScale = !0), r.logarithmic && n > 5 ? (a.allSeriesCollapsed = !1, a.yAxisScale[t] = r.forceNiceScale ? this.logarithmicScaleNice(e, i, r.logBase) : this.logarithmicScale(e, i, r.logBase)) : i !== -Number.MAX_VALUE && v.isNumber(i) && e !== Number.MAX_VALUE && v.isNumber(e) ? (a.allSeriesCollapsed = !1, a.yAxisScale[t] = this.niceScale(e, i, t)) : a.yAxisScale[t] = this.niceScale(Number.MIN_VALUE, 0, t)
}
}, {
key: "setXScale", value: function (t, e) {
var i = this.w, a = i.globals;
if (e !== -Number.MAX_VALUE && v.isNumber(e)) {
var s = a.xTickAmount;
a.xAxisScale = this.linearScale(t, e, s, 0, void 0 === i.config.xaxis.max ? i.config.xaxis.stepSize : void 0)
} else a.xAxisScale = this.linearScale(0, 10, 10);
return a.xAxisScale
}
}, {
key: "scaleMultipleYAxes", value: function () {
var t = this, e = this.w.config, i = this.w.globals;
this.coreUtils.setSeriesYAxisMappings();
var a = i.seriesYAxisMap, s = i.minYArr, r = i.maxYArr;
i.allSeriesCollapsed = !0, i.barGroups = [], a.forEach((function (a, n) {
var o = [];
a.forEach((function (t) {
var i, a = null === (i = e.series[t]) || void 0 === i ? void 0 : i.group;
o.indexOf(a) < 0 && o.push(a)
})), a.length > 0 ? function () {
var l, h, c = Number.MAX_VALUE, d = -Number.MAX_VALUE, u = c, g = d;
if (e.chart.stacked) !function () {
var t = new Array(i.dataPoints).fill(0), s = [], r = [], p = [];
o.forEach((function () {
s.push(t.map((function () {
return Number.MIN_VALUE
}))), r.push(t.map((function () {
return Number.MIN_VALUE
}))), p.push(t.map((function () {
return Number.MIN_VALUE
})))
}));
for (var f = function (t) {
!l && e.series[a[t]].type && (l = e.series[a[t]].type);
var c = a[t];
h = e.series[c].group ? e.series[c].group : "axis-".concat(n), !(i.collapsedSeriesIndices.indexOf(c) < 0 && i.ancillaryCollapsedSeriesIndices.indexOf(c) < 0) || (i.allSeriesCollapsed = !1, o.forEach((function (t, a) {
if (e.series[c].group === t) for (var n = 0; n < i.series[c].length; n++) {
var o = i.series[c][n];
o >= 0 ? r[a][n] += o : p[a][n] += o, s[a][n] += o, u = Math.min(u, o), g = Math.max(g, o)
}
}))), "bar" !== l && "column" !== l || i.barGroups.push(h)
}, x = 0; x < a.length; x++) f(x);
l || (l = e.chart.type), "bar" === l || "column" === l ? o.forEach((function (t, e) {
c = Math.min(c, Math.min.apply(null, p[e])), d = Math.max(d, Math.max.apply(null, r[e]))
})) : (o.forEach((function (t, e) {
u = Math.min(u, Math.min.apply(null, s[e])), g = Math.max(g, Math.max.apply(null, s[e]))
})), c = u, d = g), c === Number.MIN_VALUE && d === Number.MIN_VALUE && (d = -Number.MAX_VALUE)
}(); else for (var p = 0; p < a.length; p++) {
var f = a[p];
c = Math.min(c, s[f]), d = Math.max(d, r[f]), !(i.collapsedSeriesIndices.indexOf(f) < 0 && i.ancillaryCollapsedSeriesIndices.indexOf(f) < 0) || (i.allSeriesCollapsed = !1)
}
void 0 !== e.yaxis[n].min && (c = "function" == typeof e.yaxis[n].min ? e.yaxis[n].min(c) : e.yaxis[n].min), void 0 !== e.yaxis[n].max && (d = "function" == typeof e.yaxis[n].max ? e.yaxis[n].max(d) : e.yaxis[n].max), i.barGroups = i.barGroups.filter((function (t, e, i) {
return i.indexOf(t) === e
})), t.setYScaleForIndex(n, c, d), a.forEach((function (t) {
s[t] = i.yAxisScale[n].niceMin, r[t] = i.yAxisScale[n].niceMax
}))
}() : t.setYScaleForIndex(n, 0, -Number.MAX_VALUE)
}))
}
}]), t
}(), ia = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.scales = new ea(e)
}
return s(t, [{
key: "init", value: function () {
this.setYRange(), this.setXRange(), this.setZRange()
}
}, {
key: "getMinYMaxY", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : Number.MAX_VALUE,
i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : -Number.MAX_VALUE,
a = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : null, s = this.w.config,
r = this.w.globals, n = -Number.MAX_VALUE, o = Number.MIN_VALUE;
null === a && (a = t + 1);
var l = r.series, h = l, c = l;
"candlestick" === s.chart.type ? (h = r.seriesCandleL, c = r.seriesCandleH) : "boxPlot" === s.chart.type ? (h = r.seriesCandleO, c = r.seriesCandleC) : r.isRangeData && (h = r.seriesRangeStart, c = r.seriesRangeEnd);
var d = !1;
if (r.seriesX.length >= a) {
var u, g = null === (u = r.brushSource) || void 0 === u ? void 0 : u.w.config.chart.brush;
(s.chart.zoom.enabled && s.chart.zoom.autoScaleYaxis || null != g && g.enabled && null != g && g.autoScaleYaxis) && (d = !0)
}
for (var p = t; p < a; p++) {
r.dataPoints = Math.max(r.dataPoints, l[p].length);
var f = s.series[p].type;
r.categoryLabels.length && (r.dataPoints = r.categoryLabels.filter((function (t) {
return void 0 !== t
})).length), r.labels.length && "datetime" !== s.xaxis.type && 0 !== r.series.reduce((function (t, e) {
return t + e.length
}), 0) && (r.dataPoints = Math.max(r.dataPoints, r.labels.length));
var x = 0, b = l[p].length - 1;
if (d) {
if (s.xaxis.min) for (; x < b && r.seriesX[p][x] < s.xaxis.min; x++) ;
if (s.xaxis.max) for (; b > x && r.seriesX[p][b] > s.xaxis.max; b--) ;
}
for (var m = x; m <= b && m < r.series[p].length; m++) {
var y = l[p][m];
if (null !== y && v.isNumber(y)) {
var w, k, A, C;
switch (void 0 !== (null === (w = c[p]) || void 0 === w ? void 0 : w[m]) && (n = Math.max(n, c[p][m]), e = Math.min(e, c[p][m])), void 0 !== (null === (k = h[p]) || void 0 === k ? void 0 : k[m]) && (e = Math.min(e, h[p][m]), i = Math.max(i, h[p][m])), f) {
case"candlestick":
void 0 !== r.seriesCandleC[p][m] && (n = Math.max(n, r.seriesCandleH[p][m]), e = Math.min(e, r.seriesCandleL[p][m]));
break;
case"boxPlot":
void 0 !== r.seriesCandleC[p][m] && (n = Math.max(n, r.seriesCandleC[p][m]), e = Math.min(e, r.seriesCandleO[p][m]))
}
f && "candlestick" !== f && "boxPlot" !== f && "rangeArea" !== f && "rangeBar" !== f && (n = Math.max(n, r.series[p][m]), e = Math.min(e, r.series[p][m])), r.seriesGoals[p] && r.seriesGoals[p][m] && Array.isArray(r.seriesGoals[p][m]) && r.seriesGoals[p][m].forEach((function (t) {
n = Math.max(n, t.value), e = Math.min(e, t.value)
})), i = n, y = v.noExponents(y), v.isFloat(y) && (r.yValueDecimal = Math.max(r.yValueDecimal, y.toString().split(".")[1].length)), o > (null === (A = h[p]) || void 0 === A ? void 0 : A[m]) && (null === (C = h[p]) || void 0 === C ? void 0 : C[m]) < 0 && (o = h[p][m])
} else r.hasNullValues = !0
}
"bar" !== f && "column" !== f || (o < 0 && n < 0 && (n = 0, i = Math.max(i, 0)), o === Number.MIN_VALUE && (o = 0, e = Math.min(e, 0)))
}
return "rangeBar" === s.chart.type && r.seriesRangeStart.length && r.isBarHorizontal && (o = e), "bar" === s.chart.type && (o < 0 && n < 0 && (n = 0), o === Number.MIN_VALUE && (o = 0)), {
minY: o,
maxY: n,
lowestY: e,
highestY: i
}
}
}, {
key: "setYRange", value: function () {
var t = this.w.globals, e = this.w.config;
t.maxY = -Number.MAX_VALUE, t.minY = Number.MIN_VALUE;
var i, a = Number.MAX_VALUE;
if (t.isMultipleYAxis) {
a = Number.MAX_VALUE;
for (var s = 0; s < t.series.length; s++) i = this.getMinYMaxY(s), t.minYArr[s] = i.lowestY, t.maxYArr[s] = i.highestY, a = Math.min(a, i.lowestY)
}
if (i = this.getMinYMaxY(0, a, null, t.series.length), "bar" === e.chart.type ? (t.minY = i.minY, t.maxY = i.maxY) : (t.minY = i.lowestY, t.maxY = i.highestY), a = i.lowestY, e.chart.stacked && this._setStackedMinMax(), "line" === e.chart.type || "area" === e.chart.type || "scatter" === e.chart.type || "candlestick" === e.chart.type || "boxPlot" === e.chart.type || "rangeBar" === e.chart.type && !t.isBarHorizontal ? t.minY === Number.MIN_VALUE && a !== -Number.MAX_VALUE && a !== t.maxY && (t.minY = a) : t.minY = t.minY !== Number.MIN_VALUE ? Math.min(i.minY, t.minY) : i.minY, e.yaxis.forEach((function (e, i) {
void 0 !== e.max && ("number" == typeof e.max ? t.maxYArr[i] = e.max : "function" == typeof e.max && (t.maxYArr[i] = e.max(t.isMultipleYAxis ? t.maxYArr[i] : t.maxY)), t.maxY = t.maxYArr[i]), void 0 !== e.min && ("number" == typeof e.min ? t.minYArr[i] = e.min : "function" == typeof e.min && (t.minYArr[i] = e.min(t.isMultipleYAxis ? t.minYArr[i] === Number.MIN_VALUE ? 0 : t.minYArr[i] : t.minY)), t.minY = t.minYArr[i])
})), t.isBarHorizontal) {
["min", "max"].forEach((function (i) {
void 0 !== e.xaxis[i] && "number" == typeof e.xaxis[i] && ("min" === i ? t.minY = e.xaxis[i] : t.maxY = e.xaxis[i])
}))
}
return t.isMultipleYAxis ? (this.scales.scaleMultipleYAxes(), t.minY = a) : (this.scales.setYScaleForIndex(0, t.minY, t.maxY), t.minY = t.yAxisScale[0].niceMin, t.maxY = t.yAxisScale[0].niceMax, t.minYArr[0] = t.minY, t.maxYArr[0] = t.maxY), t.barGroups = [], t.lineGroups = [], t.areaGroups = [], e.series.forEach((function (i) {
switch (i.type || e.chart.type) {
case"bar":
case"column":
t.barGroups.push(i.group);
break;
case"line":
t.lineGroups.push(i.group);
break;
case"area":
t.areaGroups.push(i.group)
}
})), t.barGroups = t.barGroups.filter((function (t, e, i) {
return i.indexOf(t) === e
})), t.lineGroups = t.lineGroups.filter((function (t, e, i) {
return i.indexOf(t) === e
})), t.areaGroups = t.areaGroups.filter((function (t, e, i) {
return i.indexOf(t) === e
})), {minY: t.minY, maxY: t.maxY, minYArr: t.minYArr, maxYArr: t.maxYArr, yAxisScale: t.yAxisScale}
}
}, {
key: "setXRange", value: function () {
var t = this.w.globals, e = this.w.config,
i = "numeric" === e.xaxis.type || "datetime" === e.xaxis.type || "category" === e.xaxis.type && !t.noLabelsProvided || t.noLabelsProvided || t.isXNumeric;
if (t.isXNumeric && function () {
for (var e = 0; e < t.series.length; e++) if (t.labels[e]) for (var i = 0; i < t.labels[e].length; i++) null !== t.labels[e][i] && v.isNumber(t.labels[e][i]) && (t.maxX = Math.max(t.maxX, t.labels[e][i]), t.initialMaxX = Math.max(t.maxX, t.labels[e][i]), t.minX = Math.min(t.minX, t.labels[e][i]), t.initialMinX = Math.min(t.minX, t.labels[e][i]))
}(), t.noLabelsProvided && 0 === e.xaxis.categories.length && (t.maxX = t.labels[t.labels.length - 1], t.initialMaxX = t.labels[t.labels.length - 1], t.minX = 1, t.initialMinX = 1), t.isXNumeric || t.noLabelsProvided || t.dataFormatXNumeric) {
var a = 10;
if (void 0 === e.xaxis.tickAmount) a = Math.round(t.svgWidth / 150), "numeric" === e.xaxis.type && t.dataPoints < 30 && (a = t.dataPoints - 1), a > t.dataPoints && 0 !== t.dataPoints && (a = t.dataPoints - 1); else if ("dataPoints" === e.xaxis.tickAmount) {
if (t.series.length > 1 && (a = t.series[t.maxValsInArrayIndex].length - 1), t.isXNumeric) {
var s = Math.round(t.maxX - t.minX);
s < 30 && (a = s)
}
} else a = e.xaxis.tickAmount;
if (t.xTickAmount = a, void 0 !== e.xaxis.max && "number" == typeof e.xaxis.max && (t.maxX = e.xaxis.max), void 0 !== e.xaxis.min && "number" == typeof e.xaxis.min && (t.minX = e.xaxis.min), void 0 !== e.xaxis.range && (t.minX = t.maxX - e.xaxis.range), t.minX !== Number.MAX_VALUE && t.maxX !== -Number.MAX_VALUE) if (e.xaxis.convertedCatToNumeric && !t.dataFormatXNumeric) {
for (var r = [], n = t.minX - 1; n < t.maxX; n++) r.push(n + 1);
t.xAxisScale = {result: r, niceMin: r[0], niceMax: r[r.length - 1]}
} else t.xAxisScale = this.scales.setXScale(t.minX, t.maxX); else t.xAxisScale = this.scales.linearScale(0, a, a, 0, e.xaxis.stepSize), t.noLabelsProvided && t.labels.length > 0 && (t.xAxisScale = this.scales.linearScale(1, t.labels.length, a - 1, 0, e.xaxis.stepSize), t.seriesX = t.labels.slice());
i && (t.labels = t.xAxisScale.result.slice())
}
return t.isBarHorizontal && t.labels.length && (t.xTickAmount = t.labels.length), this._handleSingleDataPoint(), this._getMinXDiff(), {
minX: t.minX,
maxX: t.maxX
}
}
}, {
key: "setZRange", value: function () {
var t = this.w.globals;
if (t.isDataXYZ) for (var e = 0; e < t.series.length; e++) if (void 0 !== t.seriesZ[e]) for (var i = 0; i < t.seriesZ[e].length; i++) null !== t.seriesZ[e][i] && v.isNumber(t.seriesZ[e][i]) && (t.maxZ = Math.max(t.maxZ, t.seriesZ[e][i]), t.minZ = Math.min(t.minZ, t.seriesZ[e][i]))
}
}, {
key: "_handleSingleDataPoint", value: function () {
var t = this.w.globals, e = this.w.config;
if (t.minX === t.maxX) {
var i = new zi(this.ctx);
if ("datetime" === e.xaxis.type) {
var a = i.getDate(t.minX);
e.xaxis.labels.datetimeUTC ? a.setUTCDate(a.getUTCDate() - 2) : a.setDate(a.getDate() - 2), t.minX = new Date(a).getTime();
var s = i.getDate(t.maxX);
e.xaxis.labels.datetimeUTC ? s.setUTCDate(s.getUTCDate() + 2) : s.setDate(s.getDate() + 2), t.maxX = new Date(s).getTime()
} else ("numeric" === e.xaxis.type || "category" === e.xaxis.type && !t.noLabelsProvided) && (t.minX = t.minX - 2, t.initialMinX = t.minX, t.maxX = t.maxX + 2, t.initialMaxX = t.maxX)
}
}
}, {
key: "_getMinXDiff", value: function () {
var t = this.w.globals;
t.isXNumeric && t.seriesX.forEach((function (e, i) {
if (e.length) {
1 === e.length && e.push(t.seriesX[t.maxValsInArrayIndex][t.seriesX[t.maxValsInArrayIndex].length - 1]);
var a = e.slice();
a.sort((function (t, e) {
return t - e
})), a.forEach((function (e, i) {
if (i > 0) {
var s = e - a[i - 1];
s > 0 && (t.minXDiff = Math.min(s, t.minXDiff))
}
})), 1 !== t.dataPoints && t.minXDiff !== Number.MAX_VALUE || (t.minXDiff = .5)
}
}))
}
}, {
key: "_setStackedMinMax", value: function () {
var t = this, e = this.w.globals;
if (e.series.length) {
var i = e.seriesGroups;
i.length || (i = [this.w.globals.seriesNames.map((function (t) {
return t
}))]);
var a = {}, s = {};
i.forEach((function (i) {
a[i] = [], s[i] = [], t.w.config.series.map((function (t, a) {
return i.indexOf(e.seriesNames[a]) > -1 ? a : null
})).filter((function (t) {
return null !== t
})).forEach((function (r) {
for (var n = 0; n < e.series[e.maxValsInArrayIndex].length; n++) {
var o, l, h, c;
void 0 === a[i][n] && (a[i][n] = 0, s[i][n] = 0), (t.w.config.chart.stacked && !e.comboCharts || t.w.config.chart.stacked && e.comboCharts && (!t.w.config.chart.stackOnlyBar || "bar" === (null === (o = t.w.config.series) || void 0 === o || null === (l = o[r]) || void 0 === l ? void 0 : l.type) || "column" === (null === (h = t.w.config.series) || void 0 === h || null === (c = h[r]) || void 0 === c ? void 0 : c.type))) && null !== e.series[r][n] && v.isNumber(e.series[r][n]) && (e.series[r][n] > 0 ? a[i][n] += parseFloat(e.series[r][n]) + 1e-4 : s[i][n] += parseFloat(e.series[r][n]))
}
}))
})), Object.entries(a).forEach((function (t) {
var i = p(t, 1)[0];
a[i].forEach((function (t, r) {
e.maxY = Math.max(e.maxY, a[i][r]), e.minY = Math.min(e.minY, s[i][r])
}))
}))
}
}
}]), t
}(), aa = function () {
function t(e, a) {
i(this, t), this.ctx = e, this.elgrid = a, this.w = e.w;
var s = this.w;
this.xaxisFontSize = s.config.xaxis.labels.style.fontSize, this.axisFontFamily = s.config.xaxis.labels.style.fontFamily, this.xaxisForeColors = s.config.xaxis.labels.style.colors, this.isCategoryBarHorizontal = "bar" === s.config.chart.type && s.config.plotOptions.bar.horizontal, this.xAxisoffX = "bottom" === s.config.xaxis.position ? s.globals.gridHeight : 0, this.drawnLabels = [], this.axesUtils = new Ri(e)
}
return s(t, [{
key: "drawYaxis", value: function (t) {
var e = this.w, i = new Mi(this.ctx), a = e.config.yaxis[t].labels.style, s = a.fontSize,
r = a.fontFamily, n = a.fontWeight, o = i.group({
class: "apexcharts-yaxis",
rel: t,
transform: "translate(".concat(e.globals.translateYAxisX[t], ", 0)")
});
if (this.axesUtils.isYAxisHidden(t)) return o;
var l = i.group({class: "apexcharts-yaxis-texts-g"});
o.add(l);
var h = e.globals.yAxisScale[t].result.length - 1, c = e.globals.gridHeight / h,
d = e.globals.yLabelFormatters[t],
u = this.axesUtils.checkForReversedLabels(t, e.globals.yAxisScale[t].result.slice());
if (e.config.yaxis[t].labels.show) {
var g = e.globals.translateY + e.config.yaxis[t].labels.offsetY;
e.globals.isBarHorizontal ? g = 0 : "heatmap" === e.config.chart.type && (g -= c / 2), g += parseInt(s, 10) / 3;
for (var p = h; p >= 0; p--) {
var f = d(u[p], p, e), x = e.config.yaxis[t].labels.padding;
e.config.yaxis[t].opposite && 0 !== e.config.yaxis.length && (x *= -1);
var b = this.getTextAnchor(e.config.yaxis[t].labels.align, e.config.yaxis[t].opposite),
m = this.axesUtils.getYAxisForeColor(a.colors, t), y = Array.isArray(m) ? m[p] : m,
w = v.listToArray(e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis[rel='".concat(t, "'] .apexcharts-yaxis-label tspan"))).map((function (t) {
return t.textContent
})), k = i.drawText({
x: x,
y: g,
text: w.includes(f) && !e.config.yaxis[t].labels.showDuplicates ? "" : f,
textAnchor: b,
fontSize: s,
fontFamily: r,
fontWeight: n,
maxWidth: e.config.yaxis[t].labels.maxWidth,
foreColor: y,
isPlainText: !1,
cssClass: "apexcharts-yaxis-label ".concat(a.cssClass)
});
l.add(k), this.addTooltip(k, f), 0 !== e.config.yaxis[t].labels.rotate && this.rotateLabel(i, k, firstLabel, e.config.yaxis[t].labels.rotate), g += c
}
}
return this.addYAxisTitle(i, o, t), this.addAxisBorder(i, o, t, h, c), o
}
}, {
key: "getTextAnchor", value: function (t, e) {
return "left" === t ? "start" : "center" === t ? "middle" : "right" === t ? "end" : e ? "start" : "end"
}
}, {
key: "addTooltip", value: function (t, e) {
var i = document.createElementNS(this.w.globals.SVGNS, "title");
i.textContent = Array.isArray(e) ? e.join(" ") : e, t.node.appendChild(i)
}
}, {
key: "rotateLabel", value: function (t, e, i, a) {
var s = t.rotateAroundCenter(i.node), r = t.rotateAroundCenter(e.node);
e.node.setAttribute("transform", "rotate(".concat(a, " ").concat(s.x, " ").concat(r.y, ")"))
}
}, {
key: "addYAxisTitle", value: function (t, e, i) {
var a = this.w;
if (void 0 !== a.config.yaxis[i].title.text) {
var s = t.group({class: "apexcharts-yaxis-title"}),
r = a.config.yaxis[i].opposite ? a.globals.translateYAxisX[i] : 0, n = t.drawText({
x: r,
y: a.globals.gridHeight / 2 + a.globals.translateY + a.config.yaxis[i].title.offsetY,
text: a.config.yaxis[i].title.text,
textAnchor: "end",
foreColor: a.config.yaxis[i].title.style.color,
fontSize: a.config.yaxis[i].title.style.fontSize,
fontWeight: a.config.yaxis[i].title.style.fontWeight,
fontFamily: a.config.yaxis[i].title.style.fontFamily,
cssClass: "apexcharts-yaxis-title-text ".concat(a.config.yaxis[i].title.style.cssClass)
});
s.add(n), e.add(s)
}
}
}, {
key: "addAxisBorder", value: function (t, e, i, a, s) {
var r = this.w, n = r.config.yaxis[i].axisBorder, o = 31 + n.offsetX;
if (r.config.yaxis[i].opposite && (o = -31 - n.offsetX), n.show) {
var l = t.drawLine(o, r.globals.translateY + n.offsetY - 2, o, r.globals.gridHeight + r.globals.translateY + n.offsetY + 2, n.color, 0, n.width);
e.add(l)
}
r.config.yaxis[i].axisTicks.show && this.axesUtils.drawYAxisTicks(o, a, n, r.config.yaxis[i].axisTicks, i, s, e)
}
}, {
key: "drawYaxisInversed", value: function (t) {
var e = this.w, i = new Mi(this.ctx),
a = i.group({class: "apexcharts-xaxis apexcharts-yaxis-inversed"}), s = i.group({
class: "apexcharts-xaxis-texts-g",
transform: "translate(".concat(e.globals.translateXAxisX, ", ").concat(e.globals.translateXAxisY, ")")
});
a.add(s);
var r = e.globals.yAxisScale[t].result.length - 1, n = e.globals.gridWidth / r + .1,
o = n + e.config.xaxis.labels.offsetX, l = e.globals.xLabelFormatter,
h = this.axesUtils.checkForReversedLabels(t, e.globals.yAxisScale[t].result.slice()),
c = e.globals.timescaleLabels;
if (c.length > 0 && (this.xaxisLabels = c.slice(), r = (h = c.slice()).length), e.config.xaxis.labels.show) for (var d = c.length ? 0 : r; c.length ? d < c.length : d >= 0; c.length ? d++ : d--) {
var u = l(h[d], d, e),
g = e.globals.gridWidth + e.globals.padHorizontal - (o - n + e.config.xaxis.labels.offsetX);
if (c.length) {
var p = this.axesUtils.getLabel(h, c, g, d, this.drawnLabels, this.xaxisFontSize);
g = p.x, u = p.text, this.drawnLabels.push(p.text), 0 === d && e.globals.skipFirstTimelinelabel && (u = ""), d === h.length - 1 && e.globals.skipLastTimelinelabel && (u = "")
}
var f = i.drawText({
x: g,
y: this.xAxisoffX + e.config.xaxis.labels.offsetY + 30 - ("top" === e.config.xaxis.position ? e.globals.xAxisHeight + e.config.xaxis.axisTicks.height - 2 : 0),
text: u,
textAnchor: "middle",
foreColor: Array.isArray(this.xaxisForeColors) ? this.xaxisForeColors[t] : this.xaxisForeColors,
fontSize: this.xaxisFontSize,
fontFamily: this.xaxisFontFamily,
fontWeight: e.config.xaxis.labels.style.fontWeight,
isPlainText: !1,
cssClass: "apexcharts-xaxis-label ".concat(e.config.xaxis.labels.style.cssClass)
});
s.add(f), f.tspan(u), this.addTooltip(f, u), o += n
}
return this.inversedYAxisTitleText(a), this.inversedYAxisBorder(a), a
}
}, {
key: "inversedYAxisBorder", value: function (t) {
var e = this.w, i = new Mi(this.ctx), a = e.config.xaxis.axisBorder;
if (a.show) {
var s = 0;
"bar" === e.config.chart.type && e.globals.isXNumeric && (s -= 15);
var r = i.drawLine(e.globals.padHorizontal + s + a.offsetX, this.xAxisoffX, e.globals.gridWidth, this.xAxisoffX, a.color, 0, a.height);
this.elgrid && this.elgrid.elGridBorders && e.config.grid.show ? this.elgrid.elGridBorders.add(r) : t.add(r)
}
}
}, {
key: "inversedYAxisTitleText", value: function (t) {
var e = this.w, i = new Mi(this.ctx);
if (void 0 !== e.config.xaxis.title.text) {
var a = i.group({class: "apexcharts-xaxis-title apexcharts-yaxis-title-inversed"}), s = i.drawText({
x: e.globals.gridWidth / 2 + e.config.xaxis.title.offsetX,
y: this.xAxisoffX + parseFloat(this.xaxisFontSize) + parseFloat(e.config.xaxis.title.style.fontSize) + e.config.xaxis.title.offsetY + 20,
text: e.config.xaxis.title.text,
textAnchor: "middle",
fontSize: e.config.xaxis.title.style.fontSize,
fontFamily: e.config.xaxis.title.style.fontFamily,
fontWeight: e.config.xaxis.title.style.fontWeight,
foreColor: e.config.xaxis.title.style.color,
cssClass: "apexcharts-xaxis-title-text ".concat(e.config.xaxis.title.style.cssClass)
});
a.add(s), t.add(a)
}
}
}, {
key: "yAxisTitleRotate", value: function (t, e) {
var i = this.w, a = new Mi(this.ctx),
s = i.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(t, "'] .apexcharts-yaxis-texts-g")),
r = s ? s.getBoundingClientRect() : {width: 0, height: 0},
n = i.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(t, "'] .apexcharts-yaxis-title text")),
o = n ? n.getBoundingClientRect() : {width: 0, height: 0};
if (n) {
var l = this.xPaddingForYAxisTitle(t, r, o, e);
n.setAttribute("x", l.xPos - (e ? 10 : 0));
var h = a.rotateAroundCenter(n);
n.setAttribute("transform", "rotate(".concat(e ? -1 * i.config.yaxis[t].title.rotate : i.config.yaxis[t].title.rotate, " ").concat(h.x, " ").concat(h.y, ")"))
}
}
}, {
key: "xPaddingForYAxisTitle", value: function (t, e, i, a) {
var s = this.w, r = 0, n = 10;
return void 0 === s.config.yaxis[t].title.text || t < 0 ? {
xPos: r,
padd: 0
} : (a ? r = e.width + s.config.yaxis[t].title.offsetX + i.width / 2 + n / 2 : (r = -1 * e.width + s.config.yaxis[t].title.offsetX + n / 2 + i.width / 2, s.globals.isBarHorizontal && (n = 25, r = -1 * e.width - s.config.yaxis[t].title.offsetX - n)), {
xPos: r,
padd: n
})
}
}, {
key: "setYAxisXPosition", value: function (t, e) {
var i = this.w, a = 0, s = 0, r = 18, n = 1;
i.config.yaxis.length > 1 && (this.multipleYs = !0), i.config.yaxis.forEach((function (o, l) {
var h = i.globals.ignoreYAxisIndexes.includes(l) || !o.show || o.floating || 0 === t[l].width,
c = t[l].width + e[l].width;
o.opposite ? i.globals.isBarHorizontal ? (s = i.globals.gridWidth + i.globals.translateX - 1, i.globals.translateYAxisX[l] = s - o.labels.offsetX) : (s = i.globals.gridWidth + i.globals.translateX + n, h || (n += c + 20), i.globals.translateYAxisX[l] = s - o.labels.offsetX + 20) : (a = i.globals.translateX - r, h || (r += c + 20), i.globals.translateYAxisX[l] = a + o.labels.offsetX)
}))
}
}, {
key: "setYAxisTextAlignments", value: function () {
var t = this.w;
v.listToArray(t.globals.dom.baseEl.getElementsByClassName("apexcharts-yaxis")).forEach((function (e, i) {
var a = t.config.yaxis[i];
if (a && !a.floating && void 0 !== a.labels.align) {
var s = t.globals.dom.baseEl.querySelector(".apexcharts-yaxis[rel='".concat(i, "'] .apexcharts-yaxis-texts-g")),
r = v.listToArray(t.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxis[rel='".concat(i, "'] .apexcharts-yaxis-label"))),
n = s.getBoundingClientRect();
r.forEach((function (t) {
t.setAttribute("text-anchor", a.labels.align)
})), "left" !== a.labels.align || a.opposite ? "center" === a.labels.align ? s.setAttribute("transform", "translate(".concat(n.width / 2 * (a.opposite ? 1 : -1), ", 0)")) : "right" === a.labels.align && a.opposite && s.setAttribute("transform", "translate(".concat(n.width, ", 0)")) : s.setAttribute("transform", "translate(-".concat(n.width, ", 0)"))
}
}))
}
}]), t
}(), sa = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.documentEvent = v.bind(this.documentEvent, this)
}
return s(t, [{
key: "addEventListener", value: function (t, e) {
var i = this.w;
i.globals.events.hasOwnProperty(t) ? i.globals.events[t].push(e) : i.globals.events[t] = [e]
}
}, {
key: "removeEventListener", value: function (t, e) {
var i = this.w;
if (i.globals.events.hasOwnProperty(t)) {
var a = i.globals.events[t].indexOf(e);
-1 !== a && i.globals.events[t].splice(a, 1)
}
}
}, {
key: "fireEvent", value: function (t, e) {
var i = this.w;
if (i.globals.events.hasOwnProperty(t)) {
e && e.length || (e = []);
for (var a = i.globals.events[t], s = a.length, r = 0; r < s; r++) a[r].apply(null, e)
}
}
}, {
key: "setupEventHandlers", value: function () {
var t = this, e = this.w, i = this.ctx, a = e.globals.dom.baseEl.querySelector(e.globals.chartClass);
this.ctx.eventList.forEach((function (t) {
a.addEventListener(t, (function (t) {
var a = null === t.target.getAttribute("i") && -1 !== e.globals.capturedSeriesIndex ? e.globals.capturedSeriesIndex : t.target.getAttribute("i"),
s = null === t.target.getAttribute("j") && -1 !== e.globals.capturedDataPointIndex ? e.globals.capturedDataPointIndex : t.target.getAttribute("j"),
r = Object.assign({}, e, {seriesIndex: e.globals.axisCharts ? a : 0, dataPointIndex: s});
"mousemove" === t.type || "touchmove" === t.type ? "function" == typeof e.config.chart.events.mouseMove && e.config.chart.events.mouseMove(t, i, r) : "mouseleave" === t.type || "touchleave" === t.type ? "function" == typeof e.config.chart.events.mouseLeave && e.config.chart.events.mouseLeave(t, i, r) : ("mouseup" === t.type && 1 === t.which || "touchend" === t.type) && ("function" == typeof e.config.chart.events.click && e.config.chart.events.click(t, i, r), i.ctx.events.fireEvent("click", [t, i, r]))
}), {capture: !1, passive: !0})
})), this.ctx.eventList.forEach((function (i) {
e.globals.dom.baseEl.addEventListener(i, t.documentEvent, {passive: !0})
})), this.ctx.core.setupBrushHandler()
}
}, {
key: "documentEvent", value: function (t) {
var e = this.w, i = t.target.className;
if ("click" === t.type) {
var a = e.globals.dom.baseEl.querySelector(".apexcharts-menu");
a && a.classList.contains("apexcharts-menu-open") && "apexcharts-menu-icon" !== i && a.classList.remove("apexcharts-menu-open")
}
e.globals.clientX = "touchmove" === t.type ? t.touches[0].clientX : t.clientX, e.globals.clientY = "touchmove" === t.type ? t.touches[0].clientY : t.clientY
}
}]), t
}(), ra = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "setCurrentLocaleValues", value: function (t) {
var e = this.w.config.chart.locales;
window.Apex.chart && window.Apex.chart.locales && window.Apex.chart.locales.length > 0 && (e = this.w.config.chart.locales.concat(window.Apex.chart.locales));
var i = e.filter((function (e) {
return e.name === t
}))[0];
if (!i) throw new Error("Wrong locale name provided. Please make sure you set the correct locale name in options");
var a = v.extend(Hi, i);
this.w.globals.locale = a.options
}
}]), t
}(), na = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "drawAxis", value: function (t, e) {
var i, a, s = this, r = this.w.globals, n = this.w.config, o = new Ki(this.ctx, e),
l = new aa(this.ctx, e);
r.axisCharts && "radar" !== t && (r.isBarHorizontal ? (a = l.drawYaxisInversed(0), i = o.drawXaxisInversed(0), r.dom.elGraphical.add(i), r.dom.elGraphical.add(a)) : (i = o.drawXaxis(), r.dom.elGraphical.add(i), n.yaxis.map((function (t, e) {
if (-1 === r.ignoreYAxisIndexes.indexOf(e) && (a = l.drawYaxis(e), r.dom.Paper.add(a), "back" === s.w.config.grid.position)) {
var i = r.dom.Paper.children()[1];
i.remove(), r.dom.Paper.add(i)
}
}))))
}
}]), t
}(), oa = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "drawXCrosshairs", value: function () {
var t = this.w, e = new Mi(this.ctx), i = new Li(this.ctx), a = t.config.xaxis.crosshairs.fill.gradient,
s = t.config.xaxis.crosshairs.dropShadow, r = t.config.xaxis.crosshairs.fill.type, n = a.colorFrom,
o = a.colorTo, l = a.opacityFrom, h = a.opacityTo, c = a.stops, d = s.enabled, u = s.left,
g = s.top, p = s.blur, f = s.color, x = s.opacity, b = t.config.xaxis.crosshairs.fill.color;
if (t.config.xaxis.crosshairs.show) {
"gradient" === r && (b = e.drawGradient("vertical", n, o, l, h, null, c, null));
var m = e.drawRect();
1 === t.config.xaxis.crosshairs.width && (m = e.drawLine());
var y = t.globals.gridHeight;
(!v.isNumber(y) || y < 0) && (y = 0);
var w = t.config.xaxis.crosshairs.width;
(!v.isNumber(w) || w < 0) && (w = 0), m.attr({
class: "apexcharts-xcrosshairs",
x: 0,
y: 0,
y2: y,
width: w,
height: y,
fill: b,
filter: "none",
"fill-opacity": t.config.xaxis.crosshairs.opacity,
stroke: t.config.xaxis.crosshairs.stroke.color,
"stroke-width": t.config.xaxis.crosshairs.stroke.width,
"stroke-dasharray": t.config.xaxis.crosshairs.stroke.dashArray
}), d && (m = i.dropShadow(m, {
left: u,
top: g,
blur: p,
color: f,
opacity: x
})), t.globals.dom.elGraphical.add(m)
}
}
}, {
key: "drawYCrosshairs", value: function () {
var t = this.w, e = new Mi(this.ctx), i = t.config.yaxis[0].crosshairs,
a = t.globals.barPadForNumericAxis;
if (t.config.yaxis[0].crosshairs.show) {
var s = e.drawLine(-a, 0, t.globals.gridWidth + a, 0, i.stroke.color, i.stroke.dashArray, i.stroke.width);
s.attr({class: "apexcharts-ycrosshairs"}), t.globals.dom.elGraphical.add(s)
}
var r = e.drawLine(-a, 0, t.globals.gridWidth + a, 0, i.stroke.color, 0, 0);
r.attr({class: "apexcharts-ycrosshairs-hidden"}), t.globals.dom.elGraphical.add(r)
}
}]), t
}(), la = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "checkResponsiveConfig", value: function (t) {
var e = this, i = this.w, a = i.config;
if (0 !== a.responsive.length) {
var s = a.responsive.slice();
s.sort((function (t, e) {
return t.breakpoint > e.breakpoint ? 1 : e.breakpoint > t.breakpoint ? -1 : 0
})).reverse();
var r = new Wi({}), n = function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {},
a = s[0].breakpoint, n = window.innerWidth > 0 ? window.innerWidth : screen.width;
if (n > a) {
var o = v.clone(i.globals.initialConfig);
o.series = v.clone(i.config.series);
var l = Pi.extendArrayProps(r, o, i);
t = v.extend(l, t), t = v.extend(i.config, t), e.overrideResponsiveOptions(t)
} else for (var h = 0; h < s.length; h++) n < s[h].breakpoint && (t = Pi.extendArrayProps(r, s[h].options, i), t = v.extend(i.config, t), e.overrideResponsiveOptions(t))
};
if (t) {
var o = Pi.extendArrayProps(r, t, i);
o = v.extend(i.config, o), n(o = v.extend(o, t))
} else n({})
}
}
}, {
key: "overrideResponsiveOptions", value: function (t) {
var e = new Wi(t).init({responsiveOverride: !0});
this.w.config = e
}
}]), t
}(), ha = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.colors = [], this.isColorFn = !1, this.isHeatmapDistributed = this.checkHeatmapDistributed(), this.isBarDistributed = this.checkBarDistributed()
}
return s(t, [{
key: "checkHeatmapDistributed", value: function () {
var t = this.w.config, e = t.chart, i = t.plotOptions;
return "treemap" === e.type && i.treemap && i.treemap.distributed || "heatmap" === e.type && i.heatmap && i.heatmap.distributed
}
}, {
key: "checkBarDistributed", value: function () {
var t = this.w.config, e = t.chart, i = t.plotOptions;
return i.bar && i.bar.distributed && ("bar" === e.type || "rangeBar" === e.type)
}
}, {
key: "init", value: function () {
this.setDefaultColors()
}
}, {
key: "setDefaultColors", value: function () {
var t = this.w, e = new v;
t.globals.dom.elWrap.classList.add("apexcharts-theme-".concat(t.config.theme.mode || "light"));
var i = f(t.config.colors || t.config.fill.colors || []);
t.globals.colors = this.getColors(i), this.applySeriesColors(t.globals.seriesColors, t.globals.colors), t.config.theme.monochrome.enabled && (t.globals.colors = this.getMonochromeColors(t.config.theme.monochrome, t.globals.series, e));
var a = t.globals.colors.slice();
this.pushExtraColors(t.globals.colors), this.applyColorTypes(["fill", "stroke"], a), this.applyDataLabelsColors(a), this.applyRadarPolygonsColors(), this.applyMarkersColors(a)
}
}, {
key: "getColors", value: function (t) {
var e = this, i = this.w;
return t && 0 !== t.length ? Array.isArray(t) && t.length > 0 && "function" == typeof t[0] ? (this.isColorFn = !0, i.config.series.map((function (a, s) {
var r = t[s] || t[0];
return "function" == typeof r ? r({
value: i.globals.axisCharts ? i.globals.series[s][0] || 0 : i.globals.series[s],
seriesIndex: s,
dataPointIndex: s,
w: e.w
}) : r
}))) : t : this.predefined()
}
}, {
key: "applySeriesColors", value: function (t, e) {
t.forEach((function (t, i) {
t && (e[i] = t)
}))
}
}, {
key: "getMonochromeColors", value: function (t, e, i) {
var a = t.color, s = t.shadeIntensity, r = t.shadeTo,
n = this.isBarDistributed || this.isHeatmapDistributed ? e[0].length * e.length : e.length,
o = 1 / (n / s), l = 0;
return Array.from({length: n}, (function () {
var t = "dark" === r ? i.shadeColor(-1 * l, a) : i.shadeColor(l, a);
return l += o, t
}))
}
}, {
key: "applyColorTypes", value: function (t, e) {
var i = this, a = this.w;
t.forEach((function (t) {
a.globals[t].colors = void 0 === a.config[t].colors ? i.isColorFn ? a.config.colors : e : a.config[t].colors.slice(), i.pushExtraColors(a.globals[t].colors)
}))
}
}, {
key: "applyDataLabelsColors", value: function (t) {
var e = this.w;
e.globals.dataLabels.style.colors = void 0 === e.config.dataLabels.style.colors ? t : e.config.dataLabels.style.colors.slice(), this.pushExtraColors(e.globals.dataLabels.style.colors, 50)
}
}, {
key: "applyRadarPolygonsColors", value: function () {
var t = this.w;
t.globals.radarPolygons.fill.colors = void 0 === t.config.plotOptions.radar.polygons.fill.colors ? ["dark" === t.config.theme.mode ? "#343A3F" : "none"] : t.config.plotOptions.radar.polygons.fill.colors.slice(), this.pushExtraColors(t.globals.radarPolygons.fill.colors, 20)
}
}, {
key: "applyMarkersColors", value: function (t) {
var e = this.w;
e.globals.markers.colors = void 0 === e.config.markers.colors ? t : e.config.markers.colors.slice(), this.pushExtraColors(e.globals.markers.colors)
}
}, {
key: "pushExtraColors", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : null, a = this.w,
s = e || a.globals.series.length;
if (null === i && (i = this.isBarDistributed || this.isHeatmapDistributed || "heatmap" === a.config.chart.type && a.config.plotOptions.heatmap && a.config.plotOptions.heatmap.colorScale.inverse), i && a.globals.series.length && (s = a.globals.series[a.globals.maxValsInArrayIndex].length * a.globals.series.length), t.length < s) for (var r = s - t.length, n = 0; n < r; n++) t.push(t[n])
}
}, {
key: "updateThemeOptions", value: function (t) {
t.chart = t.chart || {}, t.tooltip = t.tooltip || {};
var e = t.theme.mode,
i = "dark" === e ? "palette4" : "light" === e ? "palette1" : t.theme.palette || "palette1",
a = "dark" === e ? "#f6f7f8" : "light" === e ? "#373d3f" : t.chart.foreColor || "#373d3f";
return t.tooltip.theme = e || "light", t.chart.foreColor = a, t.theme.palette = i, t
}
}, {
key: "predefined", value: function () {
var t = this.w.config.theme.palette, e = this.ctx.constructor.getThemePalettes();
return e[t] || e.palette1
}
}]), t
}(), ca = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "draw", value: function () {
this.drawTitleSubtitle("title"), this.drawTitleSubtitle("subtitle")
}
}, {
key: "drawTitleSubtitle", value: function (t) {
var e = this.w, i = "title" === t ? e.config.title : e.config.subtitle, a = e.globals.svgWidth / 2,
s = i.offsetY, r = "middle";
if ("left" === i.align ? (a = 10, r = "start") : "right" === i.align && (a = e.globals.svgWidth - 10, r = "end"), a += i.offsetX, s = s + parseInt(i.style.fontSize, 10) + i.margin / 2, void 0 !== i.text) {
var n = new Mi(this.ctx).drawText({
x: a,
y: s,
text: i.text,
textAnchor: r,
fontSize: i.style.fontSize,
fontFamily: i.style.fontFamily,
fontWeight: i.style.fontWeight,
foreColor: i.style.color,
opacity: 1
});
n.node.setAttribute("class", "apexcharts-".concat(t, "-text")), e.globals.dom.Paper.add(n)
}
}
}]), t
}(), da = function () {
function t(e) {
i(this, t), this.w = e.w, this.dCtx = e
}
return s(t, [{
key: "getTitleSubtitleCoords", value: function (t) {
var e = this.w, i = 0, a = 0, s = "title" === t ? e.config.title.floating : e.config.subtitle.floating,
r = e.globals.dom.baseEl.querySelector(".apexcharts-".concat(t, "-text"));
if (null !== r && !s) {
var n = r.getBoundingClientRect();
i = n.width, a = e.globals.axisCharts ? n.height + 5 : n.height
}
return {width: i, height: a}
}
}, {
key: "getLegendsRect", value: function () {
var t = this.w, e = t.globals.dom.elLegendWrap;
t.config.legend.height || "top" !== t.config.legend.position && "bottom" !== t.config.legend.position || (e.style.maxHeight = t.globals.svgHeight / 2 + "px");
var i = Object.assign({}, v.getBoundingClientRect(e));
return null !== e && !t.config.legend.floating && t.config.legend.show ? this.dCtx.lgRect = {
x: i.x,
y: i.y,
height: i.height,
width: 0 === i.height ? 0 : i.width
} : this.dCtx.lgRect = {
x: 0,
y: 0,
height: 0,
width: 0
}, "left" !== t.config.legend.position && "right" !== t.config.legend.position || 1.5 * this.dCtx.lgRect.width > t.globals.svgWidth && (this.dCtx.lgRect.width = t.globals.svgWidth / 1.5), this.dCtx.lgRect
}
}, {
key: "getDatalabelsRect", value: function () {
var t = this, e = this.w, i = [];
e.config.series.forEach((function (s, r) {
s.data.forEach((function (s, n) {
var o;
o = e.globals.series[r][n], a = e.config.dataLabels.formatter(o, {
ctx: t.dCtx.ctx,
seriesIndex: r,
dataPointIndex: n,
w: e
}), i.push(a)
}))
}));
var a = v.getLargestStringFromArr(i), s = new Mi(this.dCtx.ctx), r = e.config.dataLabels.style,
n = s.getTextRects(a, parseInt(r.fontSize), r.fontFamily);
return {width: 1.05 * n.width, height: n.height}
}
}, {
key: "getLargestStringFromMultiArr", value: function (t, e) {
var i = t;
if (this.w.globals.isMultiLineX) {
var a = e.map((function (t, e) {
return Array.isArray(t) ? t.length : 1
})), s = Math.max.apply(Math, f(a));
i = e[a.indexOf(s)]
}
return i
}
}]), t
}(), ua = function () {
function t(e) {
i(this, t), this.w = e.w, this.dCtx = e
}
return s(t, [{
key: "getxAxisLabelsCoords", value: function () {
var t, e = this.w, i = e.globals.labels.slice();
if (e.config.xaxis.convertedCatToNumeric && 0 === i.length && (i = e.globals.categoryLabels), e.globals.timescaleLabels.length > 0) {
var a = this.getxAxisTimeScaleLabelsCoords();
t = {width: a.width, height: a.height}, e.globals.rotateXLabels = !1
} else {
this.dCtx.lgWidthForSideLegends = "left" !== e.config.legend.position && "right" !== e.config.legend.position || e.config.legend.floating ? 0 : this.dCtx.lgRect.width;
var s = e.globals.xLabelFormatter, r = v.getLargestStringFromArr(i),
n = this.dCtx.dimHelpers.getLargestStringFromMultiArr(r, i);
e.globals.isBarHorizontal && (n = r = e.globals.yAxisScale[0].result.reduce((function (t, e) {
return t.length > e.length ? t : e
}), 0));
var o = new Xi(this.dCtx.ctx), l = r;
r = o.xLabelFormat(s, r, l, {
i: void 0,
dateFormatter: new zi(this.dCtx.ctx).formatDate,
w: e
}), n = o.xLabelFormat(s, n, l, {
i: void 0,
dateFormatter: new zi(this.dCtx.ctx).formatDate,
w: e
}), (e.config.xaxis.convertedCatToNumeric && void 0 === r || "" === String(r).trim()) && (n = r = "1");
var h = new Mi(this.dCtx.ctx), c = h.getTextRects(r, e.config.xaxis.labels.style.fontSize), d = c;
if (r !== n && (d = h.getTextRects(n, e.config.xaxis.labels.style.fontSize)), (t = {
width: c.width >= d.width ? c.width : d.width,
height: c.height >= d.height ? c.height : d.height
}).width * i.length > e.globals.svgWidth - this.dCtx.lgWidthForSideLegends - this.dCtx.yAxisWidth - this.dCtx.gridPad.left - this.dCtx.gridPad.right && 0 !== e.config.xaxis.labels.rotate || e.config.xaxis.labels.rotateAlways) {
if (!e.globals.isBarHorizontal) {
e.globals.rotateXLabels = !0;
var u = function (t) {
return h.getTextRects(t, e.config.xaxis.labels.style.fontSize, e.config.xaxis.labels.style.fontFamily, "rotate(".concat(e.config.xaxis.labels.rotate, " 0 0)"), !1)
};
c = u(r), r !== n && (d = u(n)), t.height = (c.height > d.height ? c.height : d.height) / 1.5, t.width = c.width > d.width ? c.width : d.width
}
} else e.globals.rotateXLabels = !1
}
return e.config.xaxis.labels.show || (t = {width: 0, height: 0}), {width: t.width, height: t.height}
}
}, {
key: "getxAxisGroupLabelsCoords", value: function () {
var t, e = this.w;
if (!e.globals.hasXaxisGroups) return {width: 0, height: 0};
var i,
a = (null === (t = e.config.xaxis.group.style) || void 0 === t ? void 0 : t.fontSize) || e.config.xaxis.labels.style.fontSize,
s = e.globals.groups.map((function (t) {
return t.title
})), r = v.getLargestStringFromArr(s), n = this.dCtx.dimHelpers.getLargestStringFromMultiArr(r, s),
o = new Mi(this.dCtx.ctx), l = o.getTextRects(r, a), h = l;
return r !== n && (h = o.getTextRects(n, a)), i = {
width: l.width >= h.width ? l.width : h.width,
height: l.height >= h.height ? l.height : h.height
}, e.config.xaxis.labels.show || (i = {width: 0, height: 0}), {width: i.width, height: i.height}
}
}, {
key: "getxAxisTitleCoords", value: function () {
var t = this.w, e = 0, i = 0;
if (void 0 !== t.config.xaxis.title.text) {
var a = new Mi(this.dCtx.ctx).getTextRects(t.config.xaxis.title.text, t.config.xaxis.title.style.fontSize);
e = a.width, i = a.height
}
return {width: e, height: i}
}
}, {
key: "getxAxisTimeScaleLabelsCoords", value: function () {
var t, e = this.w;
this.dCtx.timescaleLabels = e.globals.timescaleLabels.slice();
var i = this.dCtx.timescaleLabels.map((function (t) {
return t.value
})), a = i.reduce((function (t, e) {
return void 0 === t ? (console.error("You have possibly supplied invalid Date format. Please supply a valid JavaScript Date"), 0) : t.length > e.length ? t : e
}), 0);
return 1.05 * (t = new Mi(this.dCtx.ctx).getTextRects(a, e.config.xaxis.labels.style.fontSize)).width * i.length > e.globals.gridWidth && 0 !== e.config.xaxis.labels.rotate && (e.globals.overlappingXLabels = !0), t
}
}, {
key: "additionalPaddingXLabels", value: function (t) {
var e = this, i = this.w, a = i.globals, s = i.config, r = s.xaxis.type, n = t.width;
a.skipLastTimelinelabel = !1, a.skipFirstTimelinelabel = !1;
var o = i.config.yaxis[0].opposite && i.globals.isBarHorizontal, l = function (t, o) {
s.yaxis.length > 1 && function (t) {
return -1 !== a.collapsedSeriesIndices.indexOf(t)
}(o) || function (t) {
if (e.dCtx.timescaleLabels && e.dCtx.timescaleLabels.length) {
var o = e.dCtx.timescaleLabels[0],
l = e.dCtx.timescaleLabels[e.dCtx.timescaleLabels.length - 1].position + n / 1.75 - e.dCtx.yAxisWidthRight,
h = o.position - n / 1.75 + e.dCtx.yAxisWidthLeft,
c = "right" === i.config.legend.position && e.dCtx.lgRect.width > 0 ? e.dCtx.lgRect.width : 0;
l > a.svgWidth - a.translateX - c && (a.skipLastTimelinelabel = !0), h < -(t.show && !t.floating || "bar" !== s.chart.type && "candlestick" !== s.chart.type && "rangeBar" !== s.chart.type && "boxPlot" !== s.chart.type ? 10 : n / 1.75) && (a.skipFirstTimelinelabel = !0)
} else "datetime" === r ? e.dCtx.gridPad.right < n && !a.rotateXLabels && (a.skipLastTimelinelabel = !0) : "datetime" !== r && e.dCtx.gridPad.right < n / 2 - e.dCtx.yAxisWidthRight && !a.rotateXLabels && !i.config.xaxis.labels.trim && (e.dCtx.xPadRight = n / 2 + 1)
}(t)
};
s.yaxis.forEach((function (t, i) {
o ? (e.dCtx.gridPad.left < n && (e.dCtx.xPadLeft = n / 2 + 1), e.dCtx.xPadRight = n / 2 + 1) : l(t, i)
}))
}
}]), t
}(), ga = function () {
function t(e) {
i(this, t), this.w = e.w, this.dCtx = e
}
return s(t, [{
key: "getyAxisLabelsCoords", value: function () {
var t = this, e = this.w, i = [], a = 10, s = new Ri(this.dCtx.ctx);
return e.config.yaxis.map((function (r, n) {
var o = {seriesIndex: n, dataPointIndex: -1, w: e}, l = e.globals.yAxisScale[n], h = 0;
if (!s.isYAxisHidden(n) && r.labels.show && void 0 !== r.labels.minWidth && (h = r.labels.minWidth), !s.isYAxisHidden(n) && r.labels.show && l.result.length) {
var c = e.globals.yLabelFormatters[n], d = l.niceMin === Number.MIN_VALUE ? 0 : l.niceMin,
u = l.result.reduce((function (t, e) {
var i, a;
return (null === (i = String(c(t, o))) || void 0 === i ? void 0 : i.length) > (null === (a = String(c(e, o))) || void 0 === a ? void 0 : a.length) ? t : e
}), d), g = u = c(u, o);
if (void 0 !== u && 0 !== u.length || (u = l.niceMax), e.globals.isBarHorizontal) {
a = 0;
var p = e.globals.labels.slice();
u = v.getLargestStringFromArr(p), u = c(u, {
seriesIndex: n,
dataPointIndex: -1,
w: e
}), g = t.dCtx.dimHelpers.getLargestStringFromMultiArr(u, p)
}
var f = new Mi(t.dCtx.ctx), x = "rotate(".concat(r.labels.rotate, " 0 0)"),
b = f.getTextRects(u, r.labels.style.fontSize, r.labels.style.fontFamily, x, !1), m = b;
u !== g && (m = f.getTextRects(g, r.labels.style.fontSize, r.labels.style.fontFamily, x, !1)), i.push({
width: (h > m.width || h > b.width ? h : m.width > b.width ? m.width : b.width) + a,
height: m.height > b.height ? m.height : b.height
})
} else i.push({width: 0, height: 0})
})), i
}
}, {
key: "getyAxisTitleCoords", value: function () {
var t = this, e = this.w, i = [];
return e.config.yaxis.map((function (e, a) {
if (e.show && void 0 !== e.title.text) {
var s = new Mi(t.dCtx.ctx), r = "rotate(".concat(e.title.rotate, " 0 0)"),
n = s.getTextRects(e.title.text, e.title.style.fontSize, e.title.style.fontFamily, r, !1);
i.push({width: n.width, height: n.height})
} else i.push({width: 0, height: 0})
})), i
}
}, {
key: "getTotalYAxisWidth", value: function () {
var t = this.w, e = 0, i = 0, a = 0, s = t.globals.yAxisScale.length > 1 ? 10 : 0,
r = new Ri(this.dCtx.ctx), n = function (n, o) {
var l = t.config.yaxis[o].floating, h = 0;
n.width > 0 && !l ? (h = n.width + s, function (e) {
return t.globals.ignoreYAxisIndexes.indexOf(e) > -1
}(o) && (h = h - n.width - s)) : h = l || r.isYAxisHidden(o) ? 0 : 5, t.config.yaxis[o].opposite ? a += h : i += h, e += h
};
return t.globals.yLabelsCoords.map((function (t, e) {
n(t, e)
})), t.globals.yTitleCoords.map((function (t, e) {
n(t, e)
})), t.globals.isBarHorizontal && !t.config.yaxis[0].floating && (e = t.globals.yLabelsCoords[0].width + t.globals.yTitleCoords[0].width + 15), this.dCtx.yAxisWidthLeft = i, this.dCtx.yAxisWidthRight = a, e
}
}]), t
}(), pa = function () {
function t(e) {
i(this, t), this.w = e.w, this.dCtx = e
}
return s(t, [{
key: "gridPadForColumnsInNumericAxis", value: function (t) {
var e = this.w, i = e.config, a = e.globals;
if (a.noData || a.collapsedSeries.length + a.ancillaryCollapsedSeries.length === i.series.length) return 0;
var s = function (t) {
return ["bar", "rangeBar", "candlestick", "boxPlot"].includes(t)
}, r = i.chart.type, n = 0, o = s(r) ? i.series.length : 1;
a.comboBarCount > 0 && (o = a.comboBarCount), a.collapsedSeries.forEach((function (t) {
s(t.type) && (o -= 1)
})), i.chart.stacked && (o = 1);
var l = s(r) || a.comboBarCount > 0, h = Math.abs(a.initialMaxX - a.initialMinX);
if (l && a.isXNumeric && !a.isBarHorizontal && o > 0 && 0 !== h) {
h <= 3 && (h = a.dataPoints);
var c = h / t, d = a.minXDiff && a.minXDiff / c > 0 ? a.minXDiff / c : 0;
d > t / 2 && (d /= 2), (n = d * parseInt(i.plotOptions.bar.columnWidth, 10) / 100) < 1 && (n = 1), a.barPadForNumericAxis = n
}
return n
}
}, {
key: "gridPadFortitleSubtitle", value: function () {
var t = this, e = this.w, i = e.globals, a = this.dCtx.isSparkline || !i.axisCharts ? 0 : 10;
["title", "subtitle"].forEach((function (s) {
void 0 !== e.config[s].text ? a += e.config[s].margin : a += t.dCtx.isSparkline || !i.axisCharts ? 0 : 5
})), !e.config.legend.show || "bottom" !== e.config.legend.position || e.config.legend.floating || i.axisCharts || (a += 10);
var s = this.dCtx.dimHelpers.getTitleSubtitleCoords("title"),
r = this.dCtx.dimHelpers.getTitleSubtitleCoords("subtitle");
i.gridHeight -= s.height + r.height + a, i.translateY += s.height + r.height + a
}
}, {
key: "setGridXPosForDualYAxis", value: function (t, e) {
var i = this.w, a = new Ri(this.dCtx.ctx);
i.config.yaxis.forEach((function (s, r) {
-1 !== i.globals.ignoreYAxisIndexes.indexOf(r) || s.floating || a.isYAxisHidden(r) || (s.opposite && (i.globals.translateX -= e[r].width + t[r].width + parseInt(s.labels.style.fontSize, 10) / 1.2 + 12), i.globals.translateX < 2 && (i.globals.translateX = 2))
}))
}
}]), t
}(), fa = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.lgRect = {}, this.yAxisWidth = 0, this.yAxisWidthLeft = 0, this.yAxisWidthRight = 0, this.xAxisHeight = 0, this.isSparkline = this.w.config.chart.sparkline.enabled, this.dimHelpers = new da(this), this.dimYAxis = new ga(this), this.dimXAxis = new ua(this), this.dimGrid = new pa(this), this.lgWidthForSideLegends = 0, this.gridPad = this.w.config.grid.padding, this.xPadRight = 0, this.xPadLeft = 0
}
return s(t, [{
key: "plotCoords", value: function () {
var t = this, e = this.w, i = e.globals;
this.lgRect = this.dimHelpers.getLegendsRect(), this.datalabelsCoords = {width: 0, height: 0};
var a = Array.isArray(e.config.stroke.width) ? Math.max.apply(Math, f(e.config.stroke.width)) : e.config.stroke.width;
this.isSparkline && ((e.config.markers.discrete.length > 0 || e.config.markers.size > 0) && Object.entries(this.gridPad).forEach((function (e) {
var i = p(e, 2), a = i[0], s = i[1];
t.gridPad[a] = Math.max(s, t.w.globals.markers.largestSize / 1.5)
})), this.gridPad.top = Math.max(a / 2, this.gridPad.top), this.gridPad.bottom = Math.max(a / 2, this.gridPad.bottom)), i.axisCharts ? this.setDimensionsForAxisCharts() : this.setDimensionsForNonAxisCharts(), this.dimGrid.gridPadFortitleSubtitle(), i.gridHeight = i.gridHeight - this.gridPad.top - this.gridPad.bottom, i.gridWidth = i.gridWidth - this.gridPad.left - this.gridPad.right - this.xPadRight - this.xPadLeft;
var s = this.dimGrid.gridPadForColumnsInNumericAxis(i.gridWidth);
i.gridWidth = i.gridWidth - 2 * s, i.translateX = i.translateX + this.gridPad.left + this.xPadLeft + (s > 0 ? s : 0), i.translateY = i.translateY + this.gridPad.top
}
}, {
key: "setDimensionsForAxisCharts", value: function () {
var t = this, e = this.w, i = e.globals, a = this.dimYAxis.getyAxisLabelsCoords(),
s = this.dimYAxis.getyAxisTitleCoords();
i.isSlopeChart && (this.datalabelsCoords = this.dimHelpers.getDatalabelsRect()), e.globals.yLabelsCoords = [], e.globals.yTitleCoords = [], e.config.yaxis.map((function (t, i) {
e.globals.yLabelsCoords.push({
width: a[i].width,
index: i
}), e.globals.yTitleCoords.push({width: s[i].width, index: i})
})), this.yAxisWidth = this.dimYAxis.getTotalYAxisWidth();
var r = this.dimXAxis.getxAxisLabelsCoords(), n = this.dimXAxis.getxAxisGroupLabelsCoords(),
o = this.dimXAxis.getxAxisTitleCoords();
this.conditionalChecksForAxisCoords(r, o, n), i.translateXAxisY = e.globals.rotateXLabels ? this.xAxisHeight / 8 : -4, i.translateXAxisX = e.globals.rotateXLabels && e.globals.isXNumeric && e.config.xaxis.labels.rotate <= -45 ? -this.xAxisWidth / 4 : 0, e.globals.isBarHorizontal && (i.rotateXLabels = !1, i.translateXAxisY = parseInt(e.config.xaxis.labels.style.fontSize, 10) / 1.5 * -1), i.translateXAxisY = i.translateXAxisY + e.config.xaxis.labels.offsetY, i.translateXAxisX = i.translateXAxisX + e.config.xaxis.labels.offsetX;
var l = this.yAxisWidth, h = this.xAxisHeight;
i.xAxisLabelsHeight = this.xAxisHeight - o.height, i.xAxisGroupLabelsHeight = i.xAxisLabelsHeight - r.height, i.xAxisLabelsWidth = this.xAxisWidth, i.xAxisHeight = this.xAxisHeight;
var c = 10;
("radar" === e.config.chart.type || this.isSparkline) && (l = 0, h = 0), this.isSparkline && (this.lgRect = {
height: 0,
width: 0
}), (this.isSparkline || "treemap" === e.config.chart.type) && (l = 0, h = 0, c = 0), this.isSparkline || "treemap" === e.config.chart.type || this.dimXAxis.additionalPaddingXLabels(r);
var d = function () {
i.translateX = l + t.datalabelsCoords.width, i.gridHeight = i.svgHeight - t.lgRect.height - h - (t.isSparkline || "treemap" === e.config.chart.type ? 0 : e.globals.rotateXLabels ? 10 : 15), i.gridWidth = i.svgWidth - l - 2 * t.datalabelsCoords.width
};
switch ("top" === e.config.xaxis.position && (c = i.xAxisHeight - e.config.xaxis.axisTicks.height - 5), e.config.legend.position) {
case"bottom":
i.translateY = c, d();
break;
case"top":
i.translateY = this.lgRect.height + c, d();
break;
case"left":
i.translateY = c, i.translateX = this.lgRect.width + l + this.datalabelsCoords.width, i.gridHeight = i.svgHeight - h - 12, i.gridWidth = i.svgWidth - this.lgRect.width - l - 2 * this.datalabelsCoords.width;
break;
case"right":
i.translateY = c, i.translateX = l + this.datalabelsCoords.width, i.gridHeight = i.svgHeight - h - 12, i.gridWidth = i.svgWidth - this.lgRect.width - l - 2 * this.datalabelsCoords.width - 5;
break;
default:
throw new Error("Legend position not supported")
}
this.dimGrid.setGridXPosForDualYAxis(s, a), new aa(this.ctx).setYAxisXPosition(a, s)
}
}, {
key: "setDimensionsForNonAxisCharts", value: function () {
var t = this.w, e = t.globals, i = t.config, a = 0;
t.config.legend.show && !t.config.legend.floating && (a = 20);
var s = "pie" === i.chart.type || "polarArea" === i.chart.type || "donut" === i.chart.type ? "pie" : "radialBar",
r = i.plotOptions[s].offsetY, n = i.plotOptions[s].offsetX;
if (!i.legend.show || i.legend.floating) {
e.gridHeight = e.svgHeight;
var o = e.dom.elWrap.getBoundingClientRect().width;
return e.gridWidth = Math.min(o, e.gridHeight), e.translateY = r, void (e.translateX = n + (e.svgWidth - e.gridWidth) / 2)
}
switch (i.legend.position) {
case"bottom":
e.gridHeight = e.svgHeight - this.lgRect.height, e.gridWidth = e.svgWidth, e.translateY = r - 10, e.translateX = n + (e.svgWidth - e.gridWidth) / 2;
break;
case"top":
e.gridHeight = e.svgHeight - this.lgRect.height, e.gridWidth = e.svgWidth, e.translateY = this.lgRect.height + r + 10, e.translateX = n + (e.svgWidth - e.gridWidth) / 2;
break;
case"left":
e.gridWidth = e.svgWidth - this.lgRect.width - a, e.gridHeight = "auto" !== i.chart.height ? e.svgHeight : e.gridWidth, e.translateY = r, e.translateX = n + this.lgRect.width + a;
break;
case"right":
e.gridWidth = e.svgWidth - this.lgRect.width - a - 5, e.gridHeight = "auto" !== i.chart.height ? e.svgHeight : e.gridWidth, e.translateY = r, e.translateX = n + 10;
break;
default:
throw new Error("Legend position not supported")
}
}
}, {
key: "conditionalChecksForAxisCoords", value: function (t, e, i) {
var a = this.w, s = a.globals.hasXaxisGroups ? 2 : 1, r = i.height + t.height + e.height,
n = a.globals.isMultiLineX ? 1.2 : a.globals.LINE_HEIGHT_RATIO,
o = a.globals.rotateXLabels ? 22 : 10,
l = a.globals.rotateXLabels && "bottom" === a.config.legend.position ? 10 : 0;
this.xAxisHeight = r * n + s * o + l, this.xAxisWidth = t.width, this.xAxisHeight - e.height > a.config.xaxis.labels.maxHeight && (this.xAxisHeight = a.config.xaxis.labels.maxHeight), a.config.xaxis.labels.minHeight && this.xAxisHeight < a.config.xaxis.labels.minHeight && (this.xAxisHeight = a.config.xaxis.labels.minHeight), a.config.xaxis.floating && (this.xAxisHeight = 0);
var h = 0, c = 0;
a.config.yaxis.forEach((function (t) {
h += t.labels.minWidth, c += t.labels.maxWidth
})), this.yAxisWidth < h && (this.yAxisWidth = h), this.yAxisWidth > c && (this.yAxisWidth = c)
}
}]), t
}(), xa = function () {
function t(e) {
i(this, t), this.w = e.w, this.lgCtx = e
}
return s(t, [{
key: "getLegendStyles", value: function () {
var t, e, i, a = document.createElement("style");
a.setAttribute("type", "text/css");
var s = (null === (t = this.lgCtx.ctx) || void 0 === t || null === (e = t.opts) || void 0 === e || null === (i = e.chart) || void 0 === i ? void 0 : i.nonce) || this.w.config.chart.nonce;
s && a.setAttribute("nonce", s);
var r = document.createTextNode(Zi);
return a.appendChild(r), a
}
}, {
key: "getLegendDimensions", value: function () {
var t = this.w.globals.dom.baseEl.querySelector(".apexcharts-legend").getBoundingClientRect(),
e = t.width;
return {clwh: t.height, clww: e}
}
}, {
key: "appendToForeignObject", value: function () {
var t = this.w.globals;
!1 !== this.w.config.chart.injectStyleSheet && t.dom.elLegendForeign.appendChild(this.getLegendStyles())
}
}, {
key: "toggleDataSeries", value: function (t, e) {
var i = this, a = this.w;
if (a.globals.axisCharts || "radialBar" === a.config.chart.type) {
a.globals.resized = !0;
var s = null, r = null;
if (a.globals.risingSeries = [], a.globals.axisCharts ? (s = a.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(t, "']")), r = parseInt(s.getAttribute("data:realIndex"), 10)) : (s = a.globals.dom.baseEl.querySelector(".apexcharts-series[rel='".concat(t + 1, "']")), r = parseInt(s.getAttribute("rel"), 10) - 1), e) [{
cs: a.globals.collapsedSeries,
csi: a.globals.collapsedSeriesIndices
}, {
cs: a.globals.ancillaryCollapsedSeries,
csi: a.globals.ancillaryCollapsedSeriesIndices
}].forEach((function (t) {
i.riseCollapsedSeries(t.cs, t.csi, r)
})); else this.hideSeries({seriesEl: s, realIndex: r})
} else {
var n = a.globals.dom.Paper.findOne(" .apexcharts-series[rel='".concat(t + 1, "'] path")),
o = a.config.chart.type;
if ("pie" === o || "polarArea" === o || "donut" === o) {
var l = a.config.plotOptions.pie.donut.labels;
new Mi(this.lgCtx.ctx).pathMouseDown(n, null), this.lgCtx.ctx.pie.printDataLabelsInner(n.node, l)
}
n.fire("click")
}
}
}, {
key: "getSeriesAfterCollapsing", value: function (t) {
var e = t.realIndex, i = this.w, a = i.globals, s = v.clone(i.config.series);
if (a.axisCharts) {
var r = i.config.yaxis[a.seriesYAxisReverseMap[e]],
n = {index: e, data: s[e].data.slice(), type: s[e].type || i.config.chart.type};
if (r && r.show && r.showAlways) a.ancillaryCollapsedSeriesIndices.indexOf(e) < 0 && (a.ancillaryCollapsedSeries.push(n), a.ancillaryCollapsedSeriesIndices.push(e)); else if (a.collapsedSeriesIndices.indexOf(e) < 0) {
a.collapsedSeries.push(n), a.collapsedSeriesIndices.push(e);
var o = a.risingSeries.indexOf(e);
a.risingSeries.splice(o, 1)
}
} else a.collapsedSeries.push({index: e, data: s[e]}), a.collapsedSeriesIndices.push(e);
return a.allSeriesCollapsed = a.collapsedSeries.length + a.ancillaryCollapsedSeries.length === i.config.series.length, this._getSeriesBasedOnCollapsedState(s)
}
}, {
key: "hideSeries", value: function (t) {
for (var e = t.seriesEl, i = t.realIndex, a = this.w, s = this.getSeriesAfterCollapsing({realIndex: i}), r = e.childNodes, n = 0; n < r.length; n++) r[n].classList.contains("apexcharts-series-markers-wrap") && (r[n].classList.contains("apexcharts-hide") ? r[n].classList.remove("apexcharts-hide") : r[n].classList.add("apexcharts-hide"));
this.lgCtx.ctx.updateHelpers._updateSeries(s, a.config.chart.animations.dynamicAnimation.enabled)
}
}, {
key: "riseCollapsedSeries", value: function (t, e, i) {
var a = this.w, s = v.clone(a.config.series);
if (t.length > 0) {
for (var r = 0; r < t.length; r++) t[r].index === i && (a.globals.axisCharts ? s[i].data = t[r].data.slice() : s[i] = t[r].data, "number" != typeof s[i] && (s[i].hidden = !1), t.splice(r, 1), e.splice(r, 1), a.globals.risingSeries.push(i));
s = this._getSeriesBasedOnCollapsedState(s), this.lgCtx.ctx.updateHelpers._updateSeries(s, a.config.chart.animations.dynamicAnimation.enabled)
}
}
}, {
key: "_getSeriesBasedOnCollapsedState", value: function (t) {
var e = this.w, i = 0;
return e.globals.axisCharts ? t.forEach((function (a, s) {
e.globals.collapsedSeriesIndices.indexOf(s) < 0 && e.globals.ancillaryCollapsedSeriesIndices.indexOf(s) < 0 || (t[s].data = [], i++)
})) : t.forEach((function (a, s) {
!e.globals.collapsedSeriesIndices.indexOf(s) < 0 && (t[s] = 0, i++)
})), e.globals.allSeriesCollapsed = i === t.length, t
}
}]), t
}(), ba = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.onLegendClick = this.onLegendClick.bind(this), this.onLegendHovered = this.onLegendHovered.bind(this), this.isBarsDistributed = "bar" === this.w.config.chart.type && this.w.config.plotOptions.bar.distributed && 1 === this.w.config.series.length, this.legendHelpers = new xa(this)
}
return s(t, [{
key: "init", value: function () {
var t = this.w, e = t.globals, i = t.config,
a = i.legend.showForSingleSeries && 1 === e.series.length || this.isBarsDistributed || e.series.length > 1;
if (this.legendHelpers.appendToForeignObject(), (a || !e.axisCharts) && i.legend.show) {
for (; e.dom.elLegendWrap.firstChild;) e.dom.elLegendWrap.removeChild(e.dom.elLegendWrap.firstChild);
this.drawLegends(), "bottom" === i.legend.position || "top" === i.legend.position ? this.legendAlignHorizontal() : "right" !== i.legend.position && "left" !== i.legend.position || this.legendAlignVertical()
}
}
}, {
key: "createLegendMarker", value: function (t) {
var e = t.i, i = t.fillcolor, a = this.w, s = document.createElement("span");
s.classList.add("apexcharts-legend-marker");
var r = a.config.legend.markers.shape || a.config.markers.shape, n = r;
Array.isArray(r) && (n = r[e]);
var o = Array.isArray(a.config.legend.markers.size) ? parseFloat(a.config.legend.markers.size[e]) : parseFloat(a.config.legend.markers.size),
l = Array.isArray(a.config.legend.markers.offsetX) ? parseFloat(a.config.legend.markers.offsetX[e]) : parseFloat(a.config.legend.markers.offsetX),
h = Array.isArray(a.config.legend.markers.offsetY) ? parseFloat(a.config.legend.markers.offsetY[e]) : parseFloat(a.config.legend.markers.offsetY),
c = Array.isArray(a.config.legend.markers.strokeWidth) ? parseFloat(a.config.legend.markers.strokeWidth[e]) : parseFloat(a.config.legend.markers.strokeWidth),
d = s.style;
if (d.height = 2 * (o + c) + "px", d.width = 2 * (o + c) + "px", d.left = l + "px", d.top = h + "px", a.config.legend.markers.customHTML) d.background = "transparent", d.color = i[e], Array.isArray(a.config.legend.markers.customHTML) ? a.config.legend.markers.customHTML[e] && (s.innerHTML = a.config.legend.markers.customHTML[e]()) : s.innerHTML = a.config.legend.markers.customHTML(); else {
var g = new Vi(this.ctx).getMarkerConfig({
cssClass: "apexcharts-legend-marker apexcharts-marker apexcharts-marker-".concat(n),
seriesIndex: e,
strokeWidth: c,
size: o
}), p = window.SVG().addTo(s).size("100%", "100%"),
f = new Mi(this.ctx).drawMarker(0, 0, u(u({}, g), {}, {
pointFillColor: Array.isArray(i) ? i[e] : g.pointFillColor,
shape: n
}));
a.globals.dom.Paper.find(".apexcharts-legend-marker.apexcharts-marker").forEach((function (t) {
t.node.classList.contains("apexcharts-marker-triangle") ? t.node.style.transform = "translate(50%, 45%)" : t.node.style.transform = "translate(50%, 50%)"
})), p.add(f)
}
return s
}
}, {
key: "drawLegends", value: function () {
var t = this, e = this, i = this.w, a = i.config.legend.fontFamily, s = i.globals.seriesNames,
r = i.config.legend.markers.fillColors ? i.config.legend.markers.fillColors.slice() : i.globals.colors.slice();
if ("heatmap" === i.config.chart.type) {
var n = i.config.plotOptions.heatmap.colorScale.ranges;
s = n.map((function (t) {
return t.name ? t.name : t.from + " - " + t.to
})), r = n.map((function (t) {
return t.color
}))
} else this.isBarsDistributed && (s = i.globals.labels.slice());
i.config.legend.customLegendItems.length && (s = i.config.legend.customLegendItems);
var o = i.globals.legendFormatter, l = i.config.legend.inverseOrder, h = [];
i.globals.seriesGroups.length > 1 && i.config.legend.clusterGroupedSeries && i.globals.seriesGroups.forEach((function (t, e) {
h[e] = document.createElement("div"), h[e].classList.add("apexcharts-legend-group", "apexcharts-legend-group-".concat(e)), "horizontal" === i.config.legend.clusterGroupedSeriesOrientation ? i.globals.dom.elLegendWrap.classList.add("apexcharts-legend-group-horizontal") : h[e].classList.add("apexcharts-legend-group-vertical")
}));
for (var c = function (e) {
var n, l = o(s[e], {seriesIndex: e, w: i}), c = !1, d = !1;
if (i.globals.collapsedSeries.length > 0) for (var u = 0; u < i.globals.collapsedSeries.length; u++) i.globals.collapsedSeries[u].index === e && (c = !0);
if (i.globals.ancillaryCollapsedSeriesIndices.length > 0) for (var g = 0; g < i.globals.ancillaryCollapsedSeriesIndices.length; g++) i.globals.ancillaryCollapsedSeriesIndices[g] === e && (d = !0);
var p = t.createLegendMarker({i: e, fillcolor: r});
Mi.setAttrs(p, {
rel: e + 1,
"data:collapsed": c || d
}), (c || d) && p.classList.add("apexcharts-inactive-legend");
var f = document.createElement("div"), x = document.createElement("span");
x.classList.add("apexcharts-legend-text"), x.innerHTML = Array.isArray(l) ? l.join(" ") : l;
var b = i.config.legend.labels.useSeriesColors ? i.globals.colors[e] : Array.isArray(i.config.legend.labels.colors) ? null === (n = i.config.legend.labels.colors) || void 0 === n ? void 0 : n[e] : i.config.legend.labels.colors;
b || (b = i.config.chart.foreColor), x.style.color = b, x.style.fontSize = parseFloat(i.config.legend.fontSize) + "px", x.style.fontWeight = i.config.legend.fontWeight, x.style.fontFamily = a || i.config.chart.fontFamily, Mi.setAttrs(x, {
rel: e + 1,
i: e,
"data:default-text": encodeURIComponent(l),
"data:collapsed": c || d
}), f.appendChild(p), f.appendChild(x);
var m = new Pi(t.ctx);
i.config.legend.showForZeroSeries || 0 === m.getSeriesTotalByIndex(e) && m.seriesHaveSameValues(e) && !m.isSeriesNull(e) && -1 === i.globals.collapsedSeriesIndices.indexOf(e) && -1 === i.globals.ancillaryCollapsedSeriesIndices.indexOf(e) && f.classList.add("apexcharts-hidden-zero-series");
i.config.legend.showForNullSeries || m.isSeriesNull(e) && -1 === i.globals.collapsedSeriesIndices.indexOf(e) && -1 === i.globals.ancillaryCollapsedSeriesIndices.indexOf(e) && f.classList.add("apexcharts-hidden-null-series"), h.length ? i.globals.seriesGroups.forEach((function (t, a) {
var s;
t.includes(null === (s = i.config.series[e]) || void 0 === s ? void 0 : s.name) && (i.globals.dom.elLegendWrap.appendChild(h[a]), h[a].appendChild(f))
})) : i.globals.dom.elLegendWrap.appendChild(f), i.globals.dom.elLegendWrap.classList.add("apexcharts-align-".concat(i.config.legend.horizontalAlign)), i.globals.dom.elLegendWrap.classList.add("apx-legend-position-" + i.config.legend.position), f.classList.add("apexcharts-legend-series"), f.style.margin = "".concat(i.config.legend.itemMargin.vertical, "px ").concat(i.config.legend.itemMargin.horizontal, "px"), i.globals.dom.elLegendWrap.style.width = i.config.legend.width ? i.config.legend.width + "px" : "", i.globals.dom.elLegendWrap.style.height = i.config.legend.height ? i.config.legend.height + "px" : "", Mi.setAttrs(f, {
rel: e + 1,
seriesName: v.escapeString(s[e]),
"data:collapsed": c || d
}), (c || d) && f.classList.add("apexcharts-inactive-legend"), i.config.legend.onItemClick.toggleDataSeries || f.classList.add("apexcharts-no-click")
}, d = l ? s.length - 1 : 0; l ? d >= 0 : d <= s.length - 1; l ? d-- : d++) c(d);
i.globals.dom.elWrap.addEventListener("click", e.onLegendClick, !0), i.config.legend.onItemHover.highlightDataSeries && 0 === i.config.legend.customLegendItems.length && (i.globals.dom.elWrap.addEventListener("mousemove", e.onLegendHovered, !0), i.globals.dom.elWrap.addEventListener("mouseout", e.onLegendHovered, !0))
}
}, {
key: "setLegendWrapXY", value: function (t, e) {
var i = this.w, a = i.globals.dom.elLegendWrap, s = a.clientHeight, r = 0, n = 0;
if ("bottom" === i.config.legend.position) n = i.globals.svgHeight - Math.min(s, i.globals.svgHeight / 2) - 5; else if ("top" === i.config.legend.position) {
var o = new fa(this.ctx), l = o.dimHelpers.getTitleSubtitleCoords("title").height,
h = o.dimHelpers.getTitleSubtitleCoords("subtitle").height;
n = (l > 0 ? l - 10 : 0) + (h > 0 ? h - 10 : 0)
}
a.style.position = "absolute", r = r + t + i.config.legend.offsetX, n = n + e + i.config.legend.offsetY, a.style.left = r + "px", a.style.top = n + "px", "right" === i.config.legend.position && (a.style.left = "auto", a.style.right = 25 + i.config.legend.offsetX + "px");
["width", "height"].forEach((function (t) {
a.style[t] && (a.style[t] = parseInt(i.config.legend[t], 10) + "px")
}))
}
}, {
key: "legendAlignHorizontal", value: function () {
var t = this.w;
t.globals.dom.elLegendWrap.style.right = 0;
var e = new fa(this.ctx), i = e.dimHelpers.getTitleSubtitleCoords("title"),
a = e.dimHelpers.getTitleSubtitleCoords("subtitle"), s = 0;
"top" === t.config.legend.position && (s = i.height + a.height + t.config.title.margin + t.config.subtitle.margin - 10), this.setLegendWrapXY(20, s)
}
}, {
key: "legendAlignVertical", value: function () {
var t = this.w, e = this.legendHelpers.getLegendDimensions(), i = 0;
"left" === t.config.legend.position && (i = 20), "right" === t.config.legend.position && (i = t.globals.svgWidth - e.clww - 10), this.setLegendWrapXY(i, 20)
}
}, {
key: "onLegendHovered", value: function (t) {
var e = this.w,
i = t.target.classList.contains("apexcharts-legend-series") || t.target.classList.contains("apexcharts-legend-text") || t.target.classList.contains("apexcharts-legend-marker");
if ("heatmap" === e.config.chart.type || this.isBarsDistributed) {
if (i) {
var a = parseInt(t.target.getAttribute("rel"), 10) - 1;
this.ctx.events.fireEvent("legendHover", [this.ctx, a, this.w]), new $i(this.ctx).highlightRangeInSeries(t, t.target)
}
} else !t.target.classList.contains("apexcharts-inactive-legend") && i && new $i(this.ctx).toggleSeriesOnHover(t, t.target)
}
}, {
key: "onLegendClick", value: function (t) {
var e = this.w;
if (!e.config.legend.customLegendItems.length && (t.target.classList.contains("apexcharts-legend-series") || t.target.classList.contains("apexcharts-legend-text") || t.target.classList.contains("apexcharts-legend-marker"))) {
var i = parseInt(t.target.getAttribute("rel"), 10) - 1,
a = "true" === t.target.getAttribute("data:collapsed"),
s = this.w.config.chart.events.legendClick;
"function" == typeof s && s(this.ctx, i, this.w), this.ctx.events.fireEvent("legendClick", [this.ctx, i, this.w]);
var r = this.w.config.legend.markers.onClick;
"function" == typeof r && t.target.classList.contains("apexcharts-legend-marker") && (r(this.ctx, i, this.w), this.ctx.events.fireEvent("legendMarkerClick", [this.ctx, i, this.w])), "treemap" !== e.config.chart.type && "heatmap" !== e.config.chart.type && !this.isBarsDistributed && e.config.legend.onItemClick.toggleDataSeries && this.legendHelpers.toggleDataSeries(i, a)
}
}
}]), t
}(), ma = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w;
var a = this.w;
this.ev = this.w.config.chart.events, this.selectedClass = "apexcharts-selected", this.localeValues = this.w.globals.locale.toolbar, this.minX = a.globals.minX, this.maxX = a.globals.maxX
}
return s(t, [{
key: "createToolbar", value: function () {
var t = this, e = this.w, i = function () {
return document.createElement("div")
}, a = i();
if (a.setAttribute("class", "apexcharts-toolbar"), a.style.top = e.config.chart.toolbar.offsetY + "px", a.style.right = 3 - e.config.chart.toolbar.offsetX + "px", e.globals.dom.elWrap.appendChild(a), this.elZoom = i(), this.elZoomIn = i(), this.elZoomOut = i(), this.elPan = i(), this.elSelection = i(), this.elZoomReset = i(), this.elMenuIcon = i(), this.elMenu = i(), this.elCustomIcons = [], this.t = e.config.chart.toolbar.tools, Array.isArray(this.t.customIcons)) for (var s = 0; s < this.t.customIcons.length; s++) this.elCustomIcons.push(i());
var r = [], n = function (i, a, s) {
var n = i.toLowerCase();
t.t[n] && e.config.chart.zoom.enabled && r.push({
el: a,
icon: "string" == typeof t.t[n] ? t.t[n] : s,
title: t.localeValues[i],
class: "apexcharts-".concat(n, "-icon")
})
};
n("zoomIn", this.elZoomIn, '\n'), n("zoomOut", this.elZoomOut, '\n');
var o = function (i) {
t.t[i] && e.config.chart[i].enabled && r.push({
el: "zoom" === i ? t.elZoom : t.elSelection,
icon: "string" == typeof t.t[i] ? t.t[i] : "zoom" === i ? '' : '',
title: t.localeValues["zoom" === i ? "selectionZoom" : "selection"],
class: "apexcharts-".concat(i, "-icon")
})
};
o("zoom"), o("selection"), this.t.pan && e.config.chart.zoom.enabled && r.push({
el: this.elPan,
icon: "string" == typeof this.t.pan ? this.t.pan : '',
title: this.localeValues.pan,
class: "apexcharts-pan-icon"
}), n("reset", this.elZoomReset, ''), this.t.download && r.push({
el: this.elMenuIcon,
icon: "string" == typeof this.t.download ? this.t.download : '',
title: this.localeValues.menu,
class: "apexcharts-menu-icon"
});
for (var l = 0; l < this.elCustomIcons.length; l++) r.push({
el: this.elCustomIcons[l],
icon: this.t.customIcons[l].icon,
title: this.t.customIcons[l].title,
index: this.t.customIcons[l].index,
class: "apexcharts-toolbar-custom-icon " + this.t.customIcons[l].class
});
r.forEach((function (t, e) {
t.index && v.moveIndexInArray(r, e, t.index)
}));
for (var h = 0; h < r.length; h++) Mi.setAttrs(r[h].el, {
class: r[h].class,
title: r[h].title
}), r[h].el.innerHTML = r[h].icon, a.appendChild(r[h].el);
this._createHamburgerMenu(a), e.globals.zoomEnabled ? this.elZoom.classList.add(this.selectedClass) : e.globals.panEnabled ? this.elPan.classList.add(this.selectedClass) : e.globals.selectionEnabled && this.elSelection.classList.add(this.selectedClass), this.addToolbarEventListeners()
}
}, {
key: "_createHamburgerMenu", value: function (t) {
this.elMenuItems = [], t.appendChild(this.elMenu), Mi.setAttrs(this.elMenu, {class: "apexcharts-menu"});
for (var e = [{name: "exportSVG", title: this.localeValues.exportToSVG}, {
name: "exportPNG",
title: this.localeValues.exportToPNG
}, {
name: "exportCSV",
title: this.localeValues.exportToCSV
}], i = 0; i < e.length; i++) this.elMenuItems.push(document.createElement("div")), this.elMenuItems[i].innerHTML = e[i].title, Mi.setAttrs(this.elMenuItems[i], {
class: "apexcharts-menu-item ".concat(e[i].name),
title: e[i].title
}), this.elMenu.appendChild(this.elMenuItems[i])
}
}, {
key: "addToolbarEventListeners", value: function () {
var t = this;
this.elZoomReset.addEventListener("click", this.handleZoomReset.bind(this)), this.elSelection.addEventListener("click", this.toggleZoomSelection.bind(this, "selection")), this.elZoom.addEventListener("click", this.toggleZoomSelection.bind(this, "zoom")), this.elZoomIn.addEventListener("click", this.handleZoomIn.bind(this)), this.elZoomOut.addEventListener("click", this.handleZoomOut.bind(this)), this.elPan.addEventListener("click", this.togglePanning.bind(this)), this.elMenuIcon.addEventListener("click", this.toggleMenu.bind(this)), this.elMenuItems.forEach((function (e) {
e.classList.contains("exportSVG") ? e.addEventListener("click", t.handleDownload.bind(t, "svg")) : e.classList.contains("exportPNG") ? e.addEventListener("click", t.handleDownload.bind(t, "png")) : e.classList.contains("exportCSV") && e.addEventListener("click", t.handleDownload.bind(t, "csv"))
}));
for (var e = 0; e < this.t.customIcons.length; e++) this.elCustomIcons[e].addEventListener("click", this.t.customIcons[e].click.bind(this, this.ctx, this.ctx.w))
}
}, {
key: "toggleZoomSelection", value: function (t) {
this.ctx.getSyncedCharts().forEach((function (e) {
e.ctx.toolbar.toggleOtherControls();
var i = "selection" === t ? e.ctx.toolbar.elSelection : e.ctx.toolbar.elZoom,
a = "selection" === t ? "selectionEnabled" : "zoomEnabled";
e.w.globals[a] = !e.w.globals[a], i.classList.contains(e.ctx.toolbar.selectedClass) ? i.classList.remove(e.ctx.toolbar.selectedClass) : i.classList.add(e.ctx.toolbar.selectedClass)
}))
}
}, {
key: "getToolbarIconsReference", value: function () {
var t = this.w;
this.elZoom || (this.elZoom = t.globals.dom.baseEl.querySelector(".apexcharts-zoom-icon")), this.elPan || (this.elPan = t.globals.dom.baseEl.querySelector(".apexcharts-pan-icon")), this.elSelection || (this.elSelection = t.globals.dom.baseEl.querySelector(".apexcharts-selection-icon"))
}
}, {
key: "enableZoomPanFromToolbar", value: function (t) {
this.toggleOtherControls(), "pan" === t ? this.w.globals.panEnabled = !0 : this.w.globals.zoomEnabled = !0;
var e = "pan" === t ? this.elPan : this.elZoom, i = "pan" === t ? this.elZoom : this.elPan;
e && e.classList.add(this.selectedClass), i && i.classList.remove(this.selectedClass)
}
}, {
key: "togglePanning", value: function () {
this.ctx.getSyncedCharts().forEach((function (t) {
t.ctx.toolbar.toggleOtherControls(), t.w.globals.panEnabled = !t.w.globals.panEnabled, t.ctx.toolbar.elPan.classList.contains(t.ctx.toolbar.selectedClass) ? t.ctx.toolbar.elPan.classList.remove(t.ctx.toolbar.selectedClass) : t.ctx.toolbar.elPan.classList.add(t.ctx.toolbar.selectedClass)
}))
}
}, {
key: "toggleOtherControls", value: function () {
var t = this, e = this.w;
e.globals.panEnabled = !1, e.globals.zoomEnabled = !1, e.globals.selectionEnabled = !1, this.getToolbarIconsReference(), [this.elPan, this.elSelection, this.elZoom].forEach((function (e) {
e && e.classList.remove(t.selectedClass)
}))
}
}, {
key: "handleZoomIn", value: function () {
var t = this.w;
t.globals.isRangeBar && (this.minX = t.globals.minY, this.maxX = t.globals.maxY);
var e = (this.minX + this.maxX) / 2, i = (this.minX + e) / 2, a = (this.maxX + e) / 2,
s = this._getNewMinXMaxX(i, a);
t.globals.disableZoomIn || this.zoomUpdateOptions(s.minX, s.maxX)
}
}, {
key: "handleZoomOut", value: function () {
var t = this.w;
if (t.globals.isRangeBar && (this.minX = t.globals.minY, this.maxX = t.globals.maxY), !("datetime" === t.config.xaxis.type && new Date(this.minX).getUTCFullYear() < 1e3)) {
var e = (this.minX + this.maxX) / 2, i = this.minX - (e - this.minX),
a = this.maxX - (e - this.maxX), s = this._getNewMinXMaxX(i, a);
t.globals.disableZoomOut || this.zoomUpdateOptions(s.minX, s.maxX)
}
}
}, {
key: "_getNewMinXMaxX", value: function (t, e) {
var i = this.w.config.xaxis.convertedCatToNumeric;
return {minX: i ? Math.floor(t) : t, maxX: i ? Math.floor(e) : e}
}
}, {
key: "zoomUpdateOptions", value: function (t, e) {
var i = this.w;
if (void 0 !== t || void 0 !== e) {
if (!(i.config.xaxis.convertedCatToNumeric && (t < 1 && (t = 1, e = i.globals.dataPoints), e - t < 2))) {
var a = {min: t, max: e}, s = this.getBeforeZoomRange(a);
s && (a = s.xaxis);
var r = {xaxis: a}, n = v.clone(i.globals.initialConfig.yaxis);
i.config.chart.group || (r.yaxis = n), this.w.globals.zoomed = !0, this.ctx.updateHelpers._updateOptions(r, !1, this.w.config.chart.animations.dynamicAnimation.enabled), this.zoomCallback(a, n)
}
} else this.handleZoomReset()
}
}, {
key: "zoomCallback", value: function (t, e) {
"function" == typeof this.ev.zoomed && (this.ev.zoomed(this.ctx, {
xaxis: t,
yaxis: e
}), this.ctx.events.fireEvent("zoomed", {xaxis: t, yaxis: e}))
}
}, {
key: "getBeforeZoomRange", value: function (t, e) {
var i = null;
return "function" == typeof this.ev.beforeZoom && (i = this.ev.beforeZoom(this, {
xaxis: t,
yaxis: e
})), i
}
}, {
key: "toggleMenu", value: function () {
var t = this;
window.setTimeout((function () {
t.elMenu.classList.contains("apexcharts-menu-open") ? t.elMenu.classList.remove("apexcharts-menu-open") : t.elMenu.classList.add("apexcharts-menu-open")
}), 0)
}
}, {
key: "handleDownload", value: function (t) {
var e = this.w, i = new Qi(this.ctx);
switch (t) {
case"svg":
i.exportToSVG(this.ctx);
break;
case"png":
i.exportToPng(this.ctx);
break;
case"csv":
i.exportToCSV({
series: e.config.series,
columnDelimiter: e.config.chart.toolbar.export.csv.columnDelimiter
})
}
}
}, {
key: "handleZoomReset", value: function (t) {
this.ctx.getSyncedCharts().forEach((function (t) {
var e = t.w;
if (e.globals.lastXAxis.min = e.globals.initialConfig.xaxis.min, e.globals.lastXAxis.max = e.globals.initialConfig.xaxis.max, t.updateHelpers.revertDefaultAxisMinMax(), "function" == typeof e.config.chart.events.beforeResetZoom) {
var i = e.config.chart.events.beforeResetZoom(t, e);
i && t.updateHelpers.revertDefaultAxisMinMax(i)
}
"function" == typeof e.config.chart.events.zoomed && t.ctx.toolbar.zoomCallback({
min: e.config.xaxis.min,
max: e.config.xaxis.max
}), e.globals.zoomed = !1;
var a = t.ctx.series.emptyCollapsedSeries(v.clone(e.globals.initialSeries));
t.updateHelpers._updateSeries(a, e.config.chart.animations.dynamicAnimation.enabled)
}))
}
}, {
key: "destroy", value: function () {
this.elZoom = null, this.elZoomIn = null, this.elZoomOut = null, this.elPan = null, this.elSelection = null, this.elZoomReset = null, this.elMenuIcon = null
}
}]), t
}(), va = function (t) {
h(a, t);
var e = n(a);
function a(t) {
var s;
return i(this, a), (s = e.call(this, t)).ctx = t, s.w = t.w, s.dragged = !1, s.graphics = new Mi(s.ctx), s.eventList = ["mousedown", "mouseleave", "mousemove", "touchstart", "touchmove", "mouseup", "touchend", "wheel"], s.clientX = 0, s.clientY = 0, s.startX = 0, s.endX = 0, s.dragX = 0, s.startY = 0, s.endY = 0, s.dragY = 0, s.moveDirection = "none", s.debounceTimer = null, s.debounceDelay = 100, s.wheelDelay = 400, s
}
return s(a, [{
key: "init", value: function (t) {
var e = this, i = t.xyRatios, a = this.w, s = this;
this.xyRatios = i, this.zoomRect = this.graphics.drawRect(0, 0, 0, 0), this.selectionRect = this.graphics.drawRect(0, 0, 0, 0), this.gridRect = a.globals.dom.baseEl.querySelector(".apexcharts-grid"), this.constraints = new kt(0, 0, a.globals.gridWidth, a.globals.gridHeight), this.zoomRect.node.classList.add("apexcharts-zoom-rect"), this.selectionRect.node.classList.add("apexcharts-selection-rect"), a.globals.dom.Paper.add(this.zoomRect), a.globals.dom.Paper.add(this.selectionRect), "x" === a.config.chart.selection.type ? this.slDraggableRect = this.selectionRect.draggable({
minX: 0,
minY: 0,
maxX: a.globals.gridWidth,
maxY: a.globals.gridHeight
}).on("dragmove.namespace", this.selectionDragging.bind(this, "dragging")) : "y" === a.config.chart.selection.type ? this.slDraggableRect = this.selectionRect.draggable({
minX: 0,
maxX: a.globals.gridWidth
}).on("dragmove.namespace", this.selectionDragging.bind(this, "dragging")) : this.slDraggableRect = this.selectionRect.draggable().on("dragmove.namespace", this.selectionDragging.bind(this, "dragging")), this.preselectedSelection(), this.hoverArea = a.globals.dom.baseEl.querySelector("".concat(a.globals.chartClass, " .apexcharts-svg")), this.hoverArea.classList.add("apexcharts-zoomable"), this.eventList.forEach((function (t) {
e.hoverArea.addEventListener(t, s.svgMouseEvents.bind(s, i), {capture: !1, passive: !0})
})), a.config.chart.zoom.enabled && a.config.chart.zoom.allowMouseWheelZoom && this.hoverArea.addEventListener("wheel", s.mouseWheelEvent.bind(s), {
capture: !1,
passive: !1
})
}
}, {
key: "destroy", value: function () {
this.slDraggableRect && (this.slDraggableRect.draggable(!1), this.slDraggableRect.off(), this.selectionRect.off()), this.selectionRect = null, this.zoomRect = null, this.gridRect = null
}
}, {
key: "svgMouseEvents", value: function (t, e) {
var i = this.w, a = this.ctx.toolbar,
s = i.globals.zoomEnabled ? i.config.chart.zoom.type : i.config.chart.selection.type,
r = i.config.chart.toolbar.autoSelected;
if (e.shiftKey ? (this.shiftWasPressed = !0, a.enableZoomPanFromToolbar("pan" === r ? "zoom" : "pan")) : this.shiftWasPressed && (a.enableZoomPanFromToolbar(r), this.shiftWasPressed = !1), e.target) {
var n, o = e.target.classList;
if (e.target.parentNode && null !== e.target.parentNode && (n = e.target.parentNode.classList), !(o.contains("apexcharts-legend-marker") || o.contains("apexcharts-legend-text") || n && n.contains("apexcharts-toolbar"))) {
if (this.clientX = "touchmove" === e.type || "touchstart" === e.type ? e.touches[0].clientX : "touchend" === e.type ? e.changedTouches[0].clientX : e.clientX, this.clientY = "touchmove" === e.type || "touchstart" === e.type ? e.touches[0].clientY : "touchend" === e.type ? e.changedTouches[0].clientY : e.clientY, "mousedown" === e.type && 1 === e.which || "touchstart" === e.type) {
var l = this.gridRect.getBoundingClientRect();
this.startX = this.clientX - l.left - i.globals.barPadForNumericAxis, this.startY = this.clientY - l.top, this.dragged = !1, this.w.globals.mousedown = !0
}
("mousemove" === e.type && 1 === e.which || "touchmove" === e.type) && (this.dragged = !0, i.globals.panEnabled ? (i.globals.selection = null, this.w.globals.mousedown && this.panDragging({
context: this,
zoomtype: s,
xyRatios: t
})) : (this.w.globals.mousedown && i.globals.zoomEnabled || this.w.globals.mousedown && i.globals.selectionEnabled) && (this.selection = this.selectionDrawing({
context: this,
zoomtype: s
}))), "mouseup" !== e.type && "touchend" !== e.type && "mouseleave" !== e.type || this.handleMouseUp({zoomtype: s}), this.makeSelectionRectDraggable()
}
}
}
}, {
key: "handleMouseUp", value: function (t) {
var e, i = t.zoomtype, a = t.isResized, s = this.w,
r = null === (e = this.gridRect) || void 0 === e ? void 0 : e.getBoundingClientRect();
r && (this.w.globals.mousedown || a) && (this.endX = this.clientX - r.left - s.globals.barPadForNumericAxis, this.endY = this.clientY - r.top, this.dragX = Math.abs(this.endX - this.startX), this.dragY = Math.abs(this.endY - this.startY), (s.globals.zoomEnabled || s.globals.selectionEnabled) && this.selectionDrawn({
context: this,
zoomtype: i
})), s.globals.zoomEnabled && this.hideSelectionRect(this.selectionRect), this.dragged = !1, this.w.globals.mousedown = !1
}
}, {
key: "mouseWheelEvent", value: function (t) {
var e = this, i = this.w;
t.preventDefault();
var a = Date.now();
a - i.globals.lastWheelExecution > this.wheelDelay && (this.executeMouseWheelZoom(t), i.globals.lastWheelExecution = a), this.debounceTimer && clearTimeout(this.debounceTimer), this.debounceTimer = setTimeout((function () {
a - i.globals.lastWheelExecution > e.wheelDelay && (e.executeMouseWheelZoom(t), i.globals.lastWheelExecution = a)
}), this.debounceDelay)
}
}, {
key: "executeMouseWheelZoom", value: function (t) {
var e, i = this.w;
this.minX = i.globals.isRangeBar ? i.globals.minY : i.globals.minX, this.maxX = i.globals.isRangeBar ? i.globals.maxY : i.globals.maxX;
var a = null === (e = this.gridRect) || void 0 === e ? void 0 : e.getBoundingClientRect();
if (a) {
var s, r, n, o = (t.clientX - a.left) / a.width, l = this.minX, h = this.maxX, c = h - l;
if (t.deltaY < 0) {
var d = l + o * c;
r = d - (s = .5 * c) / 2, n = d + s / 2
} else r = l - (s = 1.5 * c) / 2, n = h + s / 2;
if (!i.globals.isRangeBar) {
r = Math.max(r, i.globals.initialMinX), n = Math.min(n, i.globals.initialMaxX);
var u = .01 * (i.globals.initialMaxX - i.globals.initialMinX);
if (n - r < u) {
var g = (r + n) / 2;
r = g - u / 2, n = g + u / 2
}
}
var p = this._getNewMinXMaxX(r, n);
isNaN(p.minX) || isNaN(p.maxX) || this.zoomUpdateOptions(p.minX, p.maxX)
}
}
}, {
key: "makeSelectionRectDraggable", value: function () {
var t = this, e = this.w;
if (this.selectionRect) {
var i = this.selectionRect.node.getBoundingClientRect();
i.width > 0 && i.height > 0 && (this.selectionRect.select(!1).resize(!1), this.selectionRect.select({
createRot: function () {
}, updateRot: function () {
}, createHandle: function (t, e, i, a, s) {
return "l" === s || "r" === s ? t.circle(8).css({
"stroke-width": 1,
stroke: "#333",
fill: "#fff"
}) : t.circle(0)
}, updateHandle: function (t, e) {
return t.center(e[0], e[1])
}
}).resize().on("resize", (function () {
var i = e.globals.zoomEnabled ? e.config.chart.zoom.type : e.config.chart.selection.type;
t.handleMouseUp({zoomtype: i, isResized: !0})
})))
}
}
}, {
key: "preselectedSelection", value: function () {
var t = this.w, e = this.xyRatios;
if (!t.globals.zoomEnabled) if (void 0 !== t.globals.selection && null !== t.globals.selection) this.drawSelectionRect(u(u({}, t.globals.selection), {}, {
translateX: t.globals.translateX,
translateY: t.globals.translateY
})); else if (void 0 !== t.config.chart.selection.xaxis.min && void 0 !== t.config.chart.selection.xaxis.max) {
var i = (t.config.chart.selection.xaxis.min - t.globals.minX) / e.xRatio,
a = t.globals.gridWidth - (t.globals.maxX - t.config.chart.selection.xaxis.max) / e.xRatio - i;
t.globals.isRangeBar && (i = (t.config.chart.selection.xaxis.min - t.globals.yAxisScale[0].niceMin) / e.invertedYRatio, a = (t.config.chart.selection.xaxis.max - t.config.chart.selection.xaxis.min) / e.invertedYRatio);
var s = {
x: i,
y: 0,
width: a,
height: t.globals.gridHeight,
translateX: t.globals.translateX,
translateY: t.globals.translateY,
selectionEnabled: !0
};
this.drawSelectionRect(s), this.makeSelectionRectDraggable(), "function" == typeof t.config.chart.events.selection && t.config.chart.events.selection(this.ctx, {
xaxis: {
min: t.config.chart.selection.xaxis.min,
max: t.config.chart.selection.xaxis.max
}, yaxis: {}
})
}
}
}, {
key: "drawSelectionRect", value: function (t) {
var e = t.x, i = t.y, a = t.width, s = t.height, r = t.translateX, n = void 0 === r ? 0 : r,
o = t.translateY, l = void 0 === o ? 0 : o, h = this.w, c = this.zoomRect, d = this.selectionRect;
if (this.dragged || null !== h.globals.selection) {
var u = {transform: "translate(" + n + ", " + l + ")"};
h.globals.zoomEnabled && this.dragged && (a < 0 && (a = 1), c.attr({
x: e,
y: i,
width: a,
height: s,
fill: h.config.chart.zoom.zoomedArea.fill.color,
"fill-opacity": h.config.chart.zoom.zoomedArea.fill.opacity,
stroke: h.config.chart.zoom.zoomedArea.stroke.color,
"stroke-width": h.config.chart.zoom.zoomedArea.stroke.width,
"stroke-opacity": h.config.chart.zoom.zoomedArea.stroke.opacity
}), Mi.setAttrs(c.node, u)), h.globals.selectionEnabled && (d.attr({
x: e,
y: i,
width: a > 0 ? a : 0,
height: s > 0 ? s : 0,
fill: h.config.chart.selection.fill.color,
"fill-opacity": h.config.chart.selection.fill.opacity,
stroke: h.config.chart.selection.stroke.color,
"stroke-width": h.config.chart.selection.stroke.width,
"stroke-dasharray": h.config.chart.selection.stroke.dashArray,
"stroke-opacity": h.config.chart.selection.stroke.opacity
}), Mi.setAttrs(d.node, u))
}
}
}, {
key: "hideSelectionRect", value: function (t) {
t && t.attr({x: 0, y: 0, width: 0, height: 0})
}
}, {
key: "selectionDrawing", value: function (t) {
var e = t.context, i = t.zoomtype, a = this.w, s = e, r = this.gridRect.getBoundingClientRect(),
n = s.startX - 1, o = s.startY, l = !1, h = !1,
c = s.clientX - r.left - a.globals.barPadForNumericAxis, d = s.clientY - r.top, g = c - n,
p = d - o, f = {translateX: a.globals.translateX, translateY: a.globals.translateY};
return Math.abs(g + n) > a.globals.gridWidth ? g = a.globals.gridWidth - n : c < 0 && (g = n), n > c && (l = !0, g = Math.abs(g)), o > d && (h = !0, p = Math.abs(p)), f = u(u({}, f = "x" === i ? {
x: l ? n - g : n,
y: 0,
width: g,
height: a.globals.gridHeight
} : "y" === i ? {x: 0, y: h ? o - p : o, width: a.globals.gridWidth, height: p} : {
x: l ? n - g : n,
y: h ? o - p : o,
width: g,
height: p
}), {}, {
translateX: a.globals.translateX,
translateY: a.globals.translateY
}), s.drawSelectionRect(f), s.selectionDragging("resizing"), f
}
}, {
key: "selectionDragging", value: function (t, e) {
var i = this, a = this.w;
if (e) {
e.preventDefault();
var s = e.detail, r = s.handler, n = s.box, o = n.x, l = n.y;
o < this.constraints.x && (o = this.constraints.x), l < this.constraints.y && (l = this.constraints.y), n.x2 > this.constraints.x2 && (o = this.constraints.x2 - n.w), n.y2 > this.constraints.y2 && (l = this.constraints.y2 - n.h), r.move(o, l);
var h = this.xyRatios, c = this.selectionRect, d = 0;
"resizing" === t && (d = 30);
var u = function (t) {
return parseFloat(c.node.getAttribute(t))
}, g = {x: u("x"), y: u("y"), width: u("width"), height: u("height")};
a.globals.selection = g, "function" == typeof a.config.chart.events.selection && a.globals.selectionEnabled && (clearTimeout(this.w.globals.selectionResizeTimer), this.w.globals.selectionResizeTimer = window.setTimeout((function () {
var t, e, s, r, n = i.gridRect.getBoundingClientRect(), o = c.node.getBoundingClientRect();
a.globals.isRangeBar ? (t = a.globals.yAxisScale[0].niceMin + (o.left - n.left) * h.invertedYRatio, e = a.globals.yAxisScale[0].niceMin + (o.right - n.left) * h.invertedYRatio, s = 0, r = 1) : (t = a.globals.xAxisScale.niceMin + (o.left - n.left) * h.xRatio, e = a.globals.xAxisScale.niceMin + (o.right - n.left) * h.xRatio, s = a.globals.yAxisScale[0].niceMin + (n.bottom - o.bottom) * h.yRatio[0], r = a.globals.yAxisScale[0].niceMax - (o.top - n.top) * h.yRatio[0]);
var l = {xaxis: {min: t, max: e}, yaxis: {min: s, max: r}};
a.config.chart.events.selection(i.ctx, l), a.config.chart.brush.enabled && void 0 !== a.config.chart.events.brushScrolled && a.config.chart.events.brushScrolled(i.ctx, l)
}), d))
}
}
}, {
key: "selectionDrawn", value: function (t) {
var e, i, a = t.context, s = t.zoomtype, r = this.w, n = a, o = this.xyRatios, l = this.ctx.toolbar,
h = r.globals.zoomEnabled ? n.zoomRect.node.getBoundingClientRect() : n.selectionRect.node.getBoundingClientRect(),
c = n.gridRect.getBoundingClientRect(), d = h.left - c.left - r.globals.barPadForNumericAxis,
u = h.right - c.left - r.globals.barPadForNumericAxis, g = h.top - c.top, p = h.bottom - c.top;
r.globals.isRangeBar ? (e = r.globals.yAxisScale[0].niceMin + d * o.invertedYRatio, i = r.globals.yAxisScale[0].niceMin + u * o.invertedYRatio) : (e = r.globals.xAxisScale.niceMin + d * o.xRatio, i = r.globals.xAxisScale.niceMin + u * o.xRatio);
var f = [], x = [];
if (r.config.yaxis.forEach((function (t, e) {
var i = r.globals.seriesYAxisMap[e][0], a = r.globals.yAxisScale[e].niceMax - o.yRatio[i] * g,
s = r.globals.yAxisScale[e].niceMax - o.yRatio[i] * p;
f.push(a), x.push(s)
})), n.dragged && (n.dragX > 10 || n.dragY > 10) && e !== i) if (r.globals.zoomEnabled) {
var b = v.clone(r.globals.initialConfig.yaxis), m = v.clone(r.globals.initialConfig.xaxis);
if (r.globals.zoomed = !0, r.config.xaxis.convertedCatToNumeric && (e = Math.floor(e), i = Math.floor(i), e < 1 && (e = 1, i = r.globals.dataPoints), i - e < 2 && (i = e + 1)), "xy" !== s && "x" !== s || (m = {
min: e,
max: i
}), "xy" !== s && "y" !== s || b.forEach((function (t, e) {
b[e].min = x[e], b[e].max = f[e]
})), l) {
var y = l.getBeforeZoomRange(m, b);
y && (m = y.xaxis ? y.xaxis : m, b = y.yaxis ? y.yaxis : b)
}
var w = {xaxis: m};
r.config.chart.group || (w.yaxis = b), n.ctx.updateHelpers._updateOptions(w, !1, n.w.config.chart.animations.dynamicAnimation.enabled), "function" == typeof r.config.chart.events.zoomed && l.zoomCallback(m, b)
} else if (r.globals.selectionEnabled) {
var k, A = null;
k = {
min: e,
max: i
}, "xy" !== s && "y" !== s || (A = v.clone(r.config.yaxis)).forEach((function (t, e) {
A[e].min = x[e], A[e].max = f[e]
})), r.globals.selection = n.selection, "function" == typeof r.config.chart.events.selection && r.config.chart.events.selection(n.ctx, {
xaxis: k,
yaxis: A
})
}
}
}, {
key: "panDragging", value: function (t) {
var e = t.context, i = this.w, a = e;
if (void 0 !== i.globals.lastClientPosition.x) {
var s = i.globals.lastClientPosition.x - a.clientX, r = i.globals.lastClientPosition.y - a.clientY;
Math.abs(s) > Math.abs(r) && s > 0 ? this.moveDirection = "left" : Math.abs(s) > Math.abs(r) && s < 0 ? this.moveDirection = "right" : Math.abs(r) > Math.abs(s) && r > 0 ? this.moveDirection = "up" : Math.abs(r) > Math.abs(s) && r < 0 && (this.moveDirection = "down")
}
i.globals.lastClientPosition = {x: a.clientX, y: a.clientY};
var n = i.globals.isRangeBar ? i.globals.minY : i.globals.minX,
o = i.globals.isRangeBar ? i.globals.maxY : i.globals.maxX;
a.panScrolled(n, o)
}
}, {
key: "panScrolled", value: function (t, e) {
var i = this.w, a = this.xyRatios, s = v.clone(i.globals.initialConfig.yaxis), r = a.xRatio,
n = i.globals.minX, o = i.globals.maxX;
i.globals.isRangeBar && (r = a.invertedYRatio, n = i.globals.minY, o = i.globals.maxY), "left" === this.moveDirection ? (t = n + i.globals.gridWidth / 15 * r, e = o + i.globals.gridWidth / 15 * r) : "right" === this.moveDirection && (t = n - i.globals.gridWidth / 15 * r, e = o - i.globals.gridWidth / 15 * r), i.globals.isRangeBar || (t < i.globals.initialMinX || e > i.globals.initialMaxX) && (t = n, e = o);
var l = {xaxis: {min: t, max: e}};
i.config.chart.group || (l.yaxis = s), this.updateScrolledChart(l, t, e)
}
}, {
key: "updateScrolledChart", value: function (t, e, i) {
var a = this.w;
if (this.ctx.updateHelpers._updateOptions(t, !1, !1), "function" == typeof a.config.chart.events.scrolled) {
var s = {xaxis: {min: e, max: i}};
a.config.chart.events.scrolled(this.ctx, s), this.ctx.events.fireEvent("scrolled", s)
}
}
}]), a
}(ma), ya = function () {
function t(e) {
i(this, t), this.w = e.w, this.ttCtx = e, this.ctx = e.ctx
}
return s(t, [{
key: "getNearestValues", value: function (t) {
var e = t.hoverArea, i = t.elGrid, a = t.clientX, s = t.clientY, r = this.w,
n = i.getBoundingClientRect(), o = n.width, l = n.height, h = o / (r.globals.dataPoints - 1),
c = l / r.globals.dataPoints, d = this.hasBars();
!r.globals.comboCharts && !d || r.config.xaxis.convertedCatToNumeric || (h = o / r.globals.dataPoints);
var u = a - n.left - r.globals.barPadForNumericAxis, g = s - n.top;
u < 0 || g < 0 || u > o || g > l ? (e.classList.remove("hovering-zoom"), e.classList.remove("hovering-pan")) : r.globals.zoomEnabled ? (e.classList.remove("hovering-pan"), e.classList.add("hovering-zoom")) : r.globals.panEnabled && (e.classList.remove("hovering-zoom"), e.classList.add("hovering-pan"));
var p = Math.round(u / h), f = Math.floor(g / c);
d && !r.config.xaxis.convertedCatToNumeric && (p = Math.ceil(u / h), p -= 1);
var x = null, b = null, m = r.globals.seriesXvalues.map((function (t) {
return t.filter((function (t) {
return v.isNumber(t)
}))
})), y = r.globals.seriesYvalues.map((function (t) {
return t.filter((function (t) {
return v.isNumber(t)
}))
}));
if (r.globals.isXNumeric) {
var w = this.ttCtx.getElGrid().getBoundingClientRect(), k = u * (w.width / o),
A = g * (w.height / l);
x = (b = this.closestInMultiArray(k, A, m, y)).index, p = b.j, null !== x && r.globals.hasNullValues && (m = r.globals.seriesXvalues[x], p = (b = this.closestInArray(k, m)).j)
}
return r.globals.capturedSeriesIndex = null === x ? -1 : x, (!p || p < 1) && (p = 0), r.globals.isBarHorizontal ? r.globals.capturedDataPointIndex = f : r.globals.capturedDataPointIndex = p, {
capturedSeries: x,
j: r.globals.isBarHorizontal ? f : p,
hoverX: u,
hoverY: g
}
}
}, {
key: "getFirstActiveXArray", value: function (t) {
for (var e = this.w, i = 0, a = t.map((function (t, e) {
return t.length > 0 ? e : -1
})), s = 0; s < a.length; s++) if (-1 !== a[s] && -1 === e.globals.collapsedSeriesIndices.indexOf(s) && -1 === e.globals.ancillaryCollapsedSeriesIndices.indexOf(s)) {
i = a[s];
break
}
return i
}
}, {
key: "closestInMultiArray", value: function (t, e, i, a) {
for (var s, r = this.w, n = 1 / 0, o = null, l = null, h = 0; h < i.length; h++) if (s = h, -1 === r.globals.collapsedSeriesIndices.indexOf(s) && -1 === r.globals.ancillaryCollapsedSeriesIndices.indexOf(s)) for (var c = i[h], d = a[h], u = Math.min(c.length, d.length), g = 0; g < u; g++) {
var p = t - c[g], f = Math.sqrt(p * p);
if (!r.globals.allSeriesHasEqualX) {
var x = e - d[g];
f = Math.sqrt(p * p + x * x)
}
f < n && (n = f, o = h, l = g)
}
return {index: o, j: l}
}
}, {
key: "closestInArray", value: function (t, e) {
for (var i = e[0], a = null, s = Math.abs(t - i), r = 0; r < e.length; r++) {
var n = Math.abs(t - e[r]);
n < s && (s = n, a = r)
}
return {j: a}
}
}, {
key: "isXoverlap", value: function (t) {
var e = [], i = this.w.globals.seriesX.filter((function (t) {
return void 0 !== t[0]
}));
if (i.length > 0) for (var a = 0; a < i.length - 1; a++) void 0 !== i[a][t] && void 0 !== i[a + 1][t] && i[a][t] !== i[a + 1][t] && e.push("unEqual");
return 0 === e.length
}
}, {
key: "isInitialSeriesSameLen", value: function () {
for (var t = !0, e = this.w.globals.initialSeries, i = 0; i < e.length - 1; i++) if (e[i].data.length !== e[i + 1].data.length) {
t = !1;
break
}
return t
}
}, {
key: "getBarsHeight", value: function (t) {
return f(t).reduce((function (t, e) {
return t + e.getBBox().height
}), 0)
}
}, {
key: "getElMarkers", value: function (t) {
return "number" == typeof t ? this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series[data\\:realIndex='".concat(t, "'] .apexcharts-series-markers-wrap > *")) : this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap > *")
}
}, {
key: "getAllMarkers", value: function () {
var t = this, e = arguments.length > 0 && void 0 !== arguments[0] && arguments[0],
i = this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers-wrap");
i = f(i), e && (i = i.filter((function (e) {
var i = Number(e.getAttribute("data:realIndex"));
return -1 === t.w.globals.collapsedSeriesIndices.indexOf(i)
}))), i.sort((function (t, e) {
var i = Number(t.getAttribute("data:realIndex")), a = Number(e.getAttribute("data:realIndex"));
return a < i ? 1 : a > i ? -1 : 0
}));
var a = [];
return i.forEach((function (t) {
a.push(t.querySelector(".apexcharts-marker"))
})), a
}
}, {
key: "hasMarkers", value: function (t) {
return this.getElMarkers(t).length > 0
}
}, {
key: "getPathFromPoint", value: function (t, e) {
var i = Number(t.getAttribute("cx")), a = Number(t.getAttribute("cy")), s = t.getAttribute("shape");
return new Mi(this.ctx).getMarkerPath(i, a, s, e)
}
}, {
key: "getElBars", value: function () {
return this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-bar-series, .apexcharts-candlestick-series, .apexcharts-boxPlot-series, .apexcharts-rangebar-series")
}
}, {
key: "hasBars", value: function () {
return this.getElBars().length > 0
}
}, {
key: "getHoverMarkerSize", value: function (t) {
var e = this.w, i = e.config.markers.hover.size;
return void 0 === i && (i = e.globals.markers.size[t] + e.config.markers.hover.sizeOffset), i
}
}, {
key: "toggleAllTooltipSeriesGroups", value: function (t) {
var e = this.w, i = this.ttCtx;
0 === i.allTooltipSeriesGroups.length && (i.allTooltipSeriesGroups = e.globals.dom.baseEl.querySelectorAll(".apexcharts-tooltip-series-group"));
for (var a = i.allTooltipSeriesGroups, s = 0; s < a.length; s++) "enable" === t ? (a[s].classList.add("apexcharts-active"), a[s].style.display = e.config.tooltip.items.display) : (a[s].classList.remove("apexcharts-active"), a[s].style.display = "none")
}
}]), t
}(), wa = function () {
function t(e) {
i(this, t), this.w = e.w, this.ctx = e.ctx, this.ttCtx = e, this.tooltipUtil = new ya(e)
}
return s(t, [{
key: "drawSeriesTexts", value: function (t) {
var e = t.shared, i = void 0 === e || e, a = t.ttItems, s = t.i, r = void 0 === s ? 0 : s, n = t.j,
o = void 0 === n ? null : n, l = t.y1, h = t.y2, c = t.e, d = this.w;
void 0 !== d.config.tooltip.custom ? this.handleCustomTooltip({
i: r,
j: o,
y1: l,
y2: h,
w: d
}) : this.toggleActiveInactiveSeries(i, r);
var u = this.getValuesToPrint({i: r, j: o});
this.printLabels({i: r, j: o, values: u, ttItems: a, shared: i, e: c});
var g = this.ttCtx.getElTooltip();
this.ttCtx.tooltipRect.ttWidth = g.getBoundingClientRect().width, this.ttCtx.tooltipRect.ttHeight = g.getBoundingClientRect().height
}
}, {
key: "printLabels", value: function (t) {
var e, i = this, a = t.i, s = t.j, r = t.values, n = t.ttItems, o = t.shared, l = t.e, h = this.w,
c = [], d = function (t) {
return h.globals.seriesGoals[t] && h.globals.seriesGoals[t][s] && Array.isArray(h.globals.seriesGoals[t][s])
}, g = r.xVal, p = r.zVal, f = r.xAxisTTVal, x = "", b = h.globals.colors[a];
null !== s && h.config.plotOptions.bar.distributed && (b = h.globals.colors[s]);
for (var m = function (t, r) {
var m = i.getFormatters(a);
x = i.getSeriesName({
fn: m.yLbTitleFormatter,
index: a,
seriesIndex: a,
j: s
}), "treemap" === h.config.chart.type && (x = m.yLbTitleFormatter(String(h.config.series[a].data[s].x), {
series: h.globals.series,
seriesIndex: a,
dataPointIndex: s,
w: h
}));
var v = h.config.tooltip.inverseOrder ? r : t;
if (h.globals.axisCharts) {
var y = function (t) {
var e, i, a, r;
return h.globals.isRangeData ? m.yLbFormatter(null === (e = h.globals.seriesRangeStart) || void 0 === e || null === (i = e[t]) || void 0 === i ? void 0 : i[s], {
series: h.globals.seriesRangeStart,
seriesIndex: t,
dataPointIndex: s,
w: h
}) + " - " + m.yLbFormatter(null === (a = h.globals.seriesRangeEnd) || void 0 === a || null === (r = a[t]) || void 0 === r ? void 0 : r[s], {
series: h.globals.seriesRangeEnd,
seriesIndex: t,
dataPointIndex: s,
w: h
}) : m.yLbFormatter(h.globals.series[t][s], {
series: h.globals.series,
seriesIndex: t,
dataPointIndex: s,
w: h
})
};
if (o) m = i.getFormatters(v), x = i.getSeriesName({
fn: m.yLbTitleFormatter,
index: v,
seriesIndex: a,
j: s
}), b = h.globals.colors[v], e = y(v), d(v) && (c = h.globals.seriesGoals[v][s].map((function (t) {
return {attrs: t, val: m.yLbFormatter(t.value, {seriesIndex: v, dataPointIndex: s, w: h})}
}))); else {
var w,
k = null == l || null === (w = l.target) || void 0 === w ? void 0 : w.getAttribute("fill");
k && (-1 !== k.indexOf("url") ? -1 !== k.indexOf("Pattern") && (b = h.globals.dom.baseEl.querySelector(k.substr(4).slice(0, -1)).childNodes[0].getAttribute("stroke")) : b = k), e = y(a), d(a) && Array.isArray(h.globals.seriesGoals[a][s]) && (c = h.globals.seriesGoals[a][s].map((function (t) {
return {
attrs: t,
val: m.yLbFormatter(t.value, {seriesIndex: a, dataPointIndex: s, w: h})
}
})))
}
}
null === s && (e = m.yLbFormatter(h.globals.series[a], u(u({}, h), {}, {
seriesIndex: a,
dataPointIndex: a
}))), i.DOMHandling({
i: a,
t: v,
j: s,
ttItems: n,
values: {val: e, goalVals: c, xVal: g, xAxisTTVal: f, zVal: p},
seriesName: x,
shared: o,
pColor: b
})
}, v = 0, y = h.globals.series.length - 1; v < h.globals.series.length; v++, y--) m(v, y)
}
}, {
key: "getFormatters", value: function (t) {
var e, i = this.w, a = i.globals.yLabelFormatters[t];
return void 0 !== i.globals.ttVal ? Array.isArray(i.globals.ttVal) ? (a = i.globals.ttVal[t] && i.globals.ttVal[t].formatter, e = i.globals.ttVal[t] && i.globals.ttVal[t].title && i.globals.ttVal[t].title.formatter) : (a = i.globals.ttVal.formatter, "function" == typeof i.globals.ttVal.title.formatter && (e = i.globals.ttVal.title.formatter)) : e = i.config.tooltip.y.title.formatter, "function" != typeof a && (a = i.globals.yLabelFormatters[0] ? i.globals.yLabelFormatters[0] : function (t) {
return t
}), "function" != typeof e && (e = function (t) {
return t ? t + ": " : ""
}), {yLbFormatter: a, yLbTitleFormatter: e}
}
}, {
key: "getSeriesName", value: function (t) {
var e = t.fn, i = t.index, a = t.seriesIndex, s = t.j, r = this.w;
return e(String(r.globals.seriesNames[i]), {
series: r.globals.series,
seriesIndex: a,
dataPointIndex: s,
w: r
})
}
}, {
key: "DOMHandling", value: function (t) {
t.i;
var e = t.t, i = t.j, a = t.ttItems, s = t.values, r = t.seriesName, n = t.shared, o = t.pColor,
l = this.w, h = this.ttCtx, c = s.val, d = s.goalVals, u = s.xVal, g = s.xAxisTTVal, p = s.zVal,
f = null;
f = a[e].children, l.config.tooltip.fillSeriesColor && (a[e].style.backgroundColor = o, f[0].style.display = "none"), h.showTooltipTitle && (null === h.tooltipTitle && (h.tooltipTitle = l.globals.dom.baseEl.querySelector(".apexcharts-tooltip-title")), h.tooltipTitle.innerHTML = u), h.isXAxisTooltipEnabled && (h.xaxisTooltipText.innerHTML = "" !== g ? g : u);
var x = a[e].querySelector(".apexcharts-tooltip-text-y-label");
x && (x.innerHTML = r || "");
var b = a[e].querySelector(".apexcharts-tooltip-text-y-value");
b && (b.innerHTML = void 0 !== c ? c : ""), f[0] && f[0].classList.contains("apexcharts-tooltip-marker") && (l.config.tooltip.marker.fillColors && Array.isArray(l.config.tooltip.marker.fillColors) && (o = l.config.tooltip.marker.fillColors[e]), l.config.tooltip.fillSeriesColor ? f[0].style.backgroundColor = o : f[0].style.color = o), l.config.tooltip.marker.show || (f[0].style.display = "none");
var m = a[e].querySelector(".apexcharts-tooltip-text-goals-label"),
v = a[e].querySelector(".apexcharts-tooltip-text-goals-value");
if (d.length && l.globals.seriesGoals[e]) {
var y = function () {
var t = "", e = "
";
d.forEach((function (i, a) {
t += '
').concat(i.attrs.name, "
"), e += "
".concat(i.val, "
")
})), m.innerHTML = t + "
", v.innerHTML = e + "
"
};
n ? l.globals.seriesGoals[e][i] && Array.isArray(l.globals.seriesGoals[e][i]) ? y() : (m.innerHTML = "", v.innerHTML = "") : y()
} else m.innerHTML = "", v.innerHTML = "";
null !== p && (a[e].querySelector(".apexcharts-tooltip-text-z-label").innerHTML = l.config.tooltip.z.title, a[e].querySelector(".apexcharts-tooltip-text-z-value").innerHTML = void 0 !== p ? p : "");
if (n && f[0]) {
if (l.config.tooltip.hideEmptySeries) {
var w = a[e].querySelector(".apexcharts-tooltip-marker"),
k = a[e].querySelector(".apexcharts-tooltip-text");
0 == parseFloat(c) ? (w.style.display = "none", k.style.display = "none") : (w.style.display = "block", k.style.display = "block")
}
null == c || l.globals.ancillaryCollapsedSeriesIndices.indexOf(e) > -1 || l.globals.collapsedSeriesIndices.indexOf(e) > -1 || Array.isArray(h.tConfig.enabledOnSeries) && -1 === h.tConfig.enabledOnSeries.indexOf(e) ? f[0].parentNode.style.display = "none" : f[0].parentNode.style.display = l.config.tooltip.items.display
} else Array.isArray(h.tConfig.enabledOnSeries) && -1 === h.tConfig.enabledOnSeries.indexOf(e) && (f[0].parentNode.style.display = "none")
}
}, {
key: "toggleActiveInactiveSeries", value: function (t, e) {
var i = this.w;
if (t) this.tooltipUtil.toggleAllTooltipSeriesGroups("enable"); else {
this.tooltipUtil.toggleAllTooltipSeriesGroups("disable");
var a = i.globals.dom.baseEl.querySelector(".apexcharts-tooltip-series-group-".concat(e));
a && (a.classList.add("apexcharts-active"), a.style.display = i.config.tooltip.items.display)
}
}
}, {
key: "getValuesToPrint", value: function (t) {
var e = t.i, i = t.j, a = this.w, s = this.ctx.series.filteredSeriesX(), r = "", n = "", o = null,
l = null, h = {series: a.globals.series, seriesIndex: e, dataPointIndex: i, w: a},
c = a.globals.ttZFormatter;
null === i ? l = a.globals.series[e] : a.globals.isXNumeric && "treemap" !== a.config.chart.type ? (r = s[e][i], 0 === s[e].length && (r = s[this.tooltipUtil.getFirstActiveXArray(s)][i])) : r = new Ji(this.ctx).isFormatXY() ? void 0 !== a.config.series[e].data[i] ? a.config.series[e].data[i].x : "" : void 0 !== a.globals.labels[i] ? a.globals.labels[i] : "";
var d = r;
a.globals.isXNumeric && "datetime" === a.config.xaxis.type ? r = new Xi(this.ctx).xLabelFormat(a.globals.ttKeyFormatter, d, d, {
i: void 0,
dateFormatter: new zi(this.ctx).formatDate,
w: this.w
}) : r = a.globals.isBarHorizontal ? a.globals.yLabelFormatters[0](d, h) : a.globals.xLabelFormatter(d, h);
return void 0 !== a.config.tooltip.x.formatter && (r = a.globals.ttKeyFormatter(d, h)), a.globals.seriesZ.length > 0 && a.globals.seriesZ[e].length > 0 && (o = c(a.globals.seriesZ[e][i], a)), n = "function" == typeof a.config.xaxis.tooltip.formatter ? a.globals.xaxisTooltipFormatter(d, h) : r, {
val: Array.isArray(l) ? l.join(" ") : l,
xVal: Array.isArray(r) ? r.join(" ") : r,
xAxisTTVal: Array.isArray(n) ? n.join(" ") : n,
zVal: o
}
}
}, {
key: "handleCustomTooltip", value: function (t) {
var e = t.i, i = t.j, a = t.y1, s = t.y2, r = t.w, n = this.ttCtx.getElTooltip(),
o = r.config.tooltip.custom;
Array.isArray(o) && o[e] && (o = o[e]);
var l = o({
ctx: this.ctx,
series: r.globals.series,
seriesIndex: e,
dataPointIndex: i,
y1: a,
y2: s,
w: r
});
"string" == typeof l || "number" == typeof l ? n.innerHTML = l : (l instanceof Element || "string" == typeof l.nodeName) && (n.innerHTML = "", n.appendChild(l.cloneNode(!0)))
}
}]), t
}(), ka = function () {
function t(e) {
i(this, t), this.ttCtx = e, this.ctx = e.ctx, this.w = e.w
}
return s(t, [{
key: "moveXCrosshairs", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : null, i = this.ttCtx,
a = this.w, s = i.getElXCrosshairs(), r = t - i.xcrosshairsWidth / 2,
n = a.globals.labels.slice().length;
if (null !== e && (r = a.globals.gridWidth / n * e), null === s || a.globals.isBarHorizontal || (s.setAttribute("x", r), s.setAttribute("x1", r), s.setAttribute("x2", r), s.setAttribute("y2", a.globals.gridHeight), s.classList.add("apexcharts-active")), r < 0 && (r = 0), r > a.globals.gridWidth && (r = a.globals.gridWidth), i.isXAxisTooltipEnabled) {
var o = r;
"tickWidth" !== a.config.xaxis.crosshairs.width && "barWidth" !== a.config.xaxis.crosshairs.width || (o = r + i.xcrosshairsWidth / 2), this.moveXAxisTooltip(o)
}
}
}, {
key: "moveYCrosshairs", value: function (t) {
var e = this.ttCtx;
null !== e.ycrosshairs && Mi.setAttrs(e.ycrosshairs, {
y1: t,
y2: t
}), null !== e.ycrosshairsHidden && Mi.setAttrs(e.ycrosshairsHidden, {y1: t, y2: t})
}
}, {
key: "moveXAxisTooltip", value: function (t) {
var e = this.w, i = this.ttCtx;
if (null !== i.xaxisTooltip && 0 !== i.xcrosshairsWidth) {
i.xaxisTooltip.classList.add("apexcharts-active");
var a = i.xaxisOffY + e.config.xaxis.tooltip.offsetY + e.globals.translateY + 1 + e.config.xaxis.offsetY;
if (t -= i.xaxisTooltip.getBoundingClientRect().width / 2, !isNaN(t)) {
t += e.globals.translateX;
var s;
s = new Mi(this.ctx).getTextRects(i.xaxisTooltipText.innerHTML), i.xaxisTooltipText.style.minWidth = s.width + "px", i.xaxisTooltip.style.left = t + "px", i.xaxisTooltip.style.top = a + "px"
}
}
}
}, {
key: "moveYAxisTooltip", value: function (t) {
var e = this.w, i = this.ttCtx;
null === i.yaxisTTEls && (i.yaxisTTEls = e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxistooltip"));
var a = parseInt(i.ycrosshairsHidden.getAttribute("y1"), 10), s = e.globals.translateY + a,
r = i.yaxisTTEls[t].getBoundingClientRect(), n = r.height, o = e.globals.translateYAxisX[t] - 2;
e.config.yaxis[t].opposite && (o -= r.width), s -= n / 2, -1 === e.globals.ignoreYAxisIndexes.indexOf(t) && s > 0 && s < e.globals.gridHeight ? (i.yaxisTTEls[t].classList.add("apexcharts-active"), i.yaxisTTEls[t].style.top = s + "px", i.yaxisTTEls[t].style.left = o + e.config.yaxis[t].tooltip.offsetX + "px") : i.yaxisTTEls[t].classList.remove("apexcharts-active")
}
}, {
key: "moveTooltip", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : null, a = this.w,
s = this.ttCtx, r = s.getElTooltip(), n = s.tooltipRect, o = null !== i ? parseFloat(i) : 1,
l = parseFloat(t) + o + 5, h = parseFloat(e) + o / 2;
if (l > a.globals.gridWidth / 2 && (l = l - n.ttWidth - o - 10), l > a.globals.gridWidth - n.ttWidth - 10 && (l = a.globals.gridWidth - n.ttWidth), l < -20 && (l = -20), a.config.tooltip.followCursor) {
var c = s.getElGrid().getBoundingClientRect();
(l = s.e.clientX - c.left) > a.globals.gridWidth / 2 && (l -= s.tooltipRect.ttWidth), (h = s.e.clientY + a.globals.translateY - c.top) > a.globals.gridHeight / 2 && (h -= s.tooltipRect.ttHeight)
} else a.globals.isBarHorizontal || n.ttHeight / 2 + h > a.globals.gridHeight && (h = a.globals.gridHeight - n.ttHeight + a.globals.translateY);
isNaN(l) || (l += a.globals.translateX, r.style.left = l + "px", r.style.top = h + "px")
}
}, {
key: "moveMarkers", value: function (t, e) {
var i = this.w, a = this.ttCtx;
if (i.globals.markers.size[t] > 0) for (var s = i.globals.dom.baseEl.querySelectorAll(" .apexcharts-series[data\\:realIndex='".concat(t, "'] .apexcharts-marker")), r = 0; r < s.length; r++) parseInt(s[r].getAttribute("rel"), 10) === e && (a.marker.resetPointsSize(), a.marker.enlargeCurrentPoint(e, s[r])); else a.marker.resetPointsSize(), this.moveDynamicPointOnHover(e, t)
}
}, {
key: "moveDynamicPointOnHover", value: function (t, e) {
var i, a, s, r, n = this.w, o = this.ttCtx, l = new Mi(this.ctx), h = n.globals.pointsArray,
c = o.tooltipUtil.getHoverMarkerSize(e), d = n.config.series[e].type;
if (!d || "column" !== d && "candlestick" !== d && "boxPlot" !== d) {
s = null === (i = h[e][t]) || void 0 === i ? void 0 : i[0], r = (null === (a = h[e][t]) || void 0 === a ? void 0 : a[1]) || 0;
var u = n.globals.dom.baseEl.querySelector(".apexcharts-series[data\\:realIndex='".concat(e, "'] .apexcharts-series-markers path"));
if (u && r < n.globals.gridHeight && r > 0) {
var g = u.getAttribute("shape"), p = l.getMarkerPath(s, r, g, 1.5 * c);
u.setAttribute("d", p)
}
this.moveXCrosshairs(s), o.fixedTooltip || this.moveTooltip(s, r, c)
}
}
}, {
key: "moveDynamicPointsOnHover", value: function (t) {
var e, i = this.ttCtx, a = i.w, s = 0, r = 0, n = a.globals.pointsArray, o = new $i(this.ctx),
l = new Mi(this.ctx);
e = o.getActiveConfigSeriesIndex("asc", ["line", "area", "scatter", "bubble"]);
var h = i.tooltipUtil.getHoverMarkerSize(e);
if (n[e] && (s = n[e][t][0], r = n[e][t][1]), !isNaN(s)) {
var c = i.tooltipUtil.getAllMarkers();
if (c.length) for (var d = 0; d < a.globals.series.length; d++) {
var u = n[d];
if (a.globals.comboCharts && void 0 === u && c.splice(d, 0, null), u && u.length) {
var g = n[d][t][1], p = void 0;
c[d].setAttribute("cx", s);
var f = c[d].getAttribute("shape");
if ("rangeArea" === a.config.chart.type && !a.globals.comboCharts) {
var x = t + a.globals.series[d].length;
p = n[d][x][1], g -= Math.abs(g - p) / 2
}
if (null !== g && !isNaN(g) && g < a.globals.gridHeight + h && g + h > 0) {
var b = l.getMarkerPath(s, g, f, h);
c[d].setAttribute("d", b)
} else c[d].setAttribute("d", "")
}
}
this.moveXCrosshairs(s), i.fixedTooltip || this.moveTooltip(s, r || a.globals.gridHeight, h)
}
}
}, {
key: "moveStickyTooltipOverBars", value: function (t, e) {
var i = this.w, a = this.ttCtx,
s = i.globals.columnSeries ? i.globals.columnSeries.length : i.globals.series.length;
i.config.chart.stacked && (s = i.globals.barGroups.length);
var r = s >= 2 && s % 2 == 0 ? Math.floor(s / 2) : Math.floor(s / 2) + 1;
i.globals.isBarHorizontal && (r = new $i(this.ctx).getActiveConfigSeriesIndex("desc") + 1);
var n = i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[rel='".concat(r, "'] path[j='").concat(t, "'], .apexcharts-candlestick-series .apexcharts-series[rel='").concat(r, "'] path[j='").concat(t, "'], .apexcharts-boxPlot-series .apexcharts-series[rel='").concat(r, "'] path[j='").concat(t, "'], .apexcharts-rangebar-series .apexcharts-series[rel='").concat(r, "'] path[j='").concat(t, "']"));
n || "number" != typeof e || (n = i.globals.dom.baseEl.querySelector(".apexcharts-bar-series .apexcharts-series[data\\:realIndex='".concat(e, "'] path[j='").concat(t, "'],\n .apexcharts-candlestick-series .apexcharts-series[data\\:realIndex='").concat(e, "'] path[j='").concat(t, "'],\n .apexcharts-boxPlot-series .apexcharts-series[data\\:realIndex='").concat(e, "'] path[j='").concat(t, "'],\n .apexcharts-rangebar-series .apexcharts-series[data\\:realIndex='").concat(e, "'] path[j='").concat(t, "']")));
var o = n ? parseFloat(n.getAttribute("cx")) : 0, l = n ? parseFloat(n.getAttribute("cy")) : 0,
h = n ? parseFloat(n.getAttribute("barWidth")) : 0, c = a.getElGrid().getBoundingClientRect(),
d = n && (n.classList.contains("apexcharts-candlestick-area") || n.classList.contains("apexcharts-boxPlot-area"));
i.globals.isXNumeric ? (n && !d && (o -= s % 2 != 0 ? h / 2 : 0), n && d && (o -= h / 2)) : i.globals.isBarHorizontal || (o = a.xAxisTicksPositions[t - 1] + a.dataPointsDividedWidth / 2, isNaN(o) && (o = a.xAxisTicksPositions[t] - a.dataPointsDividedWidth / 2)), i.globals.isBarHorizontal ? l -= a.tooltipRect.ttHeight : i.config.tooltip.followCursor ? l = a.e.clientY - c.top - a.tooltipRect.ttHeight / 2 : l + a.tooltipRect.ttHeight + 15 > i.globals.gridHeight && (l = i.globals.gridHeight), i.globals.isBarHorizontal || this.moveXCrosshairs(o), a.fixedTooltip || this.moveTooltip(o, l || i.globals.gridHeight)
}
}]), t
}(), Aa = function () {
function t(e) {
i(this, t), this.w = e.w, this.ttCtx = e, this.ctx = e.ctx, this.tooltipPosition = new ka(e)
}
return s(t, [{
key: "drawDynamicPoints", value: function () {
var t = this.w, e = new Mi(this.ctx), i = new Vi(this.ctx),
a = t.globals.dom.baseEl.querySelectorAll(".apexcharts-series");
a = f(a), t.config.chart.stacked && a.sort((function (t, e) {
return parseFloat(t.getAttribute("data:realIndex")) - parseFloat(e.getAttribute("data:realIndex"))
}));
for (var s = 0; s < a.length; s++) {
var r = a[s].querySelector(".apexcharts-series-markers-wrap");
if (null !== r) {
var n = void 0, o = "apexcharts-marker w".concat((Math.random() + 1).toString(36).substring(4));
"line" !== t.config.chart.type && "area" !== t.config.chart.type || t.globals.comboCharts || t.config.tooltip.intersect || (o += " no-pointer-events");
var l = i.getMarkerConfig({cssClass: o, seriesIndex: Number(r.getAttribute("data:realIndex"))});
(n = e.drawMarker(0, 0, l)).node.setAttribute("default-marker-size", 0);
var h = document.createElementNS(t.globals.SVGNS, "g");
h.classList.add("apexcharts-series-markers"), h.appendChild(n.node), r.appendChild(h)
}
}
}
}, {
key: "enlargeCurrentPoint", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : null,
a = arguments.length > 3 && void 0 !== arguments[3] ? arguments[3] : null, s = this.w;
"bubble" !== s.config.chart.type && this.newPointSize(t, e);
var r = e.getAttribute("cx"), n = e.getAttribute("cy");
if (null !== i && null !== a && (r = i, n = a), this.tooltipPosition.moveXCrosshairs(r), !this.fixedTooltip) {
if ("radar" === s.config.chart.type) {
var o = this.ttCtx.getElGrid().getBoundingClientRect();
r = this.ttCtx.e.clientX - o.left
}
this.tooltipPosition.moveTooltip(r, n, s.config.markers.hover.size)
}
}
}, {
key: "enlargePoints", value: function (t) {
for (var e = this.w, i = this, a = this.ttCtx, s = t, r = e.globals.dom.baseEl.querySelectorAll(".apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker"), n = e.config.markers.hover.size, o = 0; o < r.length; o++) {
var l = r[o].getAttribute("rel"), h = r[o].getAttribute("index");
if (void 0 === n && (n = e.globals.markers.size[h] + e.config.markers.hover.sizeOffset), s === parseInt(l, 10)) {
i.newPointSize(s, r[o]);
var c = r[o].getAttribute("cx"), d = r[o].getAttribute("cy");
i.tooltipPosition.moveXCrosshairs(c), a.fixedTooltip || i.tooltipPosition.moveTooltip(c, d, n)
} else i.oldPointSize(r[o])
}
}
}, {
key: "newPointSize", value: function (t, e) {
var i = this.w, a = i.config.markers.hover.size,
s = 0 === t ? e.parentNode.firstChild : e.parentNode.lastChild;
if ("0" !== s.getAttribute("default-marker-size")) {
var r = parseInt(s.getAttribute("index"), 10);
void 0 === a && (a = i.globals.markers.size[r] + i.config.markers.hover.sizeOffset), a < 0 && (a = 0);
var n = this.ttCtx.tooltipUtil.getPathFromPoint(e, a);
e.setAttribute("d", n)
}
}
}, {
key: "oldPointSize", value: function (t) {
var e = parseFloat(t.getAttribute("default-marker-size")),
i = this.ttCtx.tooltipUtil.getPathFromPoint(t, e);
t.setAttribute("d", i)
}
}, {
key: "resetPointsSize", value: function () {
for (var t = this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series:not(.apexcharts-series-collapsed) .apexcharts-marker"), e = 0; e < t.length; e++) {
var i = parseFloat(t[e].getAttribute("default-marker-size"));
if (v.isNumber(i) && i > 0) {
var a = this.ttCtx.tooltipUtil.getPathFromPoint(t[e], i);
t[e].setAttribute("d", a)
} else t[e].setAttribute("d", "M0,0")
}
}
}]), t
}(), Ca = function () {
function t(e) {
i(this, t), this.w = e.w;
var a = this.w;
this.ttCtx = e, this.isVerticalGroupedRangeBar = !a.globals.isBarHorizontal && "rangeBar" === a.config.chart.type && a.config.plotOptions.bar.rangeBarGroupRows
}
return s(t, [{
key: "getAttr", value: function (t, e) {
return parseFloat(t.target.getAttribute(e))
}
}, {
key: "handleHeatTreeTooltip", value: function (t) {
var e = t.e, i = t.opt, a = t.x, s = t.y, r = t.type, n = this.ttCtx, o = this.w;
if (e.target.classList.contains("apexcharts-".concat(r, "-rect"))) {
var l = this.getAttr(e, "i"), h = this.getAttr(e, "j"), c = this.getAttr(e, "cx"),
d = this.getAttr(e, "cy"), u = this.getAttr(e, "width"), g = this.getAttr(e, "height");
if (n.tooltipLabels.drawSeriesTexts({
ttItems: i.ttItems,
i: l,
j: h,
shared: !1,
e: e
}), o.globals.capturedSeriesIndex = l, o.globals.capturedDataPointIndex = h, a = c + n.tooltipRect.ttWidth / 2 + u, s = d + n.tooltipRect.ttHeight / 2 - g / 2, n.tooltipPosition.moveXCrosshairs(c + u / 2), a > o.globals.gridWidth / 2 && (a = c - n.tooltipRect.ttWidth / 2 + u), n.w.config.tooltip.followCursor) {
var p = o.globals.dom.elWrap.getBoundingClientRect();
a = o.globals.clientX - p.left - (a > o.globals.gridWidth / 2 ? n.tooltipRect.ttWidth : 0), s = o.globals.clientY - p.top - (s > o.globals.gridHeight / 2 ? n.tooltipRect.ttHeight : 0)
}
}
return {x: a, y: s}
}
}, {
key: "handleMarkerTooltip", value: function (t) {
var e, i, a = t.e, s = t.opt, r = t.x, n = t.y, o = this.w, l = this.ttCtx;
if (a.target.classList.contains("apexcharts-marker")) {
var h = parseInt(s.paths.getAttribute("cx"), 10), c = parseInt(s.paths.getAttribute("cy"), 10),
d = parseFloat(s.paths.getAttribute("val"));
if (i = parseInt(s.paths.getAttribute("rel"), 10), e = parseInt(s.paths.parentNode.parentNode.parentNode.getAttribute("rel"), 10) - 1, l.intersect) {
var u = v.findAncestor(s.paths, "apexcharts-series");
u && (e = parseInt(u.getAttribute("data:realIndex"), 10))
}
if (l.tooltipLabels.drawSeriesTexts({
ttItems: s.ttItems,
i: e,
j: i,
shared: !l.showOnIntersect && o.config.tooltip.shared,
e: a
}), "mouseup" === a.type && l.markerClick(a, e, i), o.globals.capturedSeriesIndex = e, o.globals.capturedDataPointIndex = i, r = h, n = c + o.globals.translateY - 1.4 * l.tooltipRect.ttHeight, l.w.config.tooltip.followCursor) {
var g = l.getElGrid().getBoundingClientRect();
n = l.e.clientY + o.globals.translateY - g.top
}
d < 0 && (n = c), l.marker.enlargeCurrentPoint(i, s.paths, r, n)
}
return {x: r, y: n}
}
}, {
key: "handleBarTooltip", value: function (t) {
var e, i, a = t.e, s = t.opt, r = this.w, n = this.ttCtx, o = n.getElTooltip(), l = 0, h = 0, c = 0,
d = this.getBarTooltipXY({e: a, opt: s});
if (null !== d.j || 0 !== d.barHeight || 0 !== d.barWidth) {
e = d.i;
var u = d.j;
if (r.globals.capturedSeriesIndex = e, r.globals.capturedDataPointIndex = u, r.globals.isBarHorizontal && n.tooltipUtil.hasBars() || !r.config.tooltip.shared ? (h = d.x, c = d.y, i = Array.isArray(r.config.stroke.width) ? r.config.stroke.width[e] : r.config.stroke.width, l = h) : r.globals.comboCharts || r.config.tooltip.shared || (l /= 2), isNaN(c) && (c = r.globals.svgHeight - n.tooltipRect.ttHeight), parseInt(s.paths.parentNode.getAttribute("data:realIndex"), 10), h + n.tooltipRect.ttWidth > r.globals.gridWidth ? h -= n.tooltipRect.ttWidth : h < 0 && (h = 0), n.w.config.tooltip.followCursor) {
var g = n.getElGrid().getBoundingClientRect();
c = n.e.clientY - g.top
}
null === n.tooltip && (n.tooltip = r.globals.dom.baseEl.querySelector(".apexcharts-tooltip")), r.config.tooltip.shared || (r.globals.comboBarCount > 0 ? n.tooltipPosition.moveXCrosshairs(l + i / 2) : n.tooltipPosition.moveXCrosshairs(l)), !n.fixedTooltip && (!r.config.tooltip.shared || r.globals.isBarHorizontal && n.tooltipUtil.hasBars()) && (c = c + r.globals.translateY - n.tooltipRect.ttHeight / 2, o.style.left = h + r.globals.translateX + "px", o.style.top = c + "px")
}
}
}, {
key: "getBarTooltipXY", value: function (t) {
var e = this, i = t.e, a = t.opt, s = this.w, r = null, n = this.ttCtx, o = 0, l = 0, h = 0, c = 0,
d = 0, u = i.target.classList;
if (u.contains("apexcharts-bar-area") || u.contains("apexcharts-candlestick-area") || u.contains("apexcharts-boxPlot-area") || u.contains("apexcharts-rangebar-area")) {
var g = i.target, p = g.getBoundingClientRect(), f = a.elGrid.getBoundingClientRect(), x = p.height;
d = p.height;
var b = p.width, m = parseInt(g.getAttribute("cx"), 10), v = parseInt(g.getAttribute("cy"), 10);
c = parseFloat(g.getAttribute("barWidth"));
var y = "touchmove" === i.type ? i.touches[0].clientX : i.clientX;
r = parseInt(g.getAttribute("j"), 10), o = parseInt(g.parentNode.getAttribute("rel"), 10) - 1;
var w = g.getAttribute("data-range-y1"), k = g.getAttribute("data-range-y2");
s.globals.comboCharts && (o = parseInt(g.parentNode.getAttribute("data:realIndex"), 10));
var A = function (t) {
return s.globals.isXNumeric ? m - b / 2 : e.isVerticalGroupedRangeBar ? m + b / 2 : m - n.dataPointsDividedWidth + b / 2
}, C = function () {
return v - n.dataPointsDividedHeight + x / 2 - n.tooltipRect.ttHeight / 2
};
n.tooltipLabels.drawSeriesTexts({
ttItems: a.ttItems,
i: o,
j: r,
y1: w ? parseInt(w, 10) : null,
y2: k ? parseInt(k, 10) : null,
shared: !n.showOnIntersect && s.config.tooltip.shared,
e: i
}), s.config.tooltip.followCursor ? s.globals.isBarHorizontal ? (l = y - f.left + 15, h = C()) : (l = A(), h = i.clientY - f.top - n.tooltipRect.ttHeight / 2 - 15) : s.globals.isBarHorizontal ? ((l = m) < n.xyRatios.baseLineInvertedY && (l = m - n.tooltipRect.ttWidth), h = C()) : (l = A(), h = v)
}
return {x: l, y: h, barHeight: d, barWidth: c, i: o, j: r}
}
}]), t
}(), Sa = function () {
function t(e) {
i(this, t), this.w = e.w, this.ttCtx = e
}
return s(t, [{
key: "drawXaxisTooltip", value: function () {
var t = this.w, e = this.ttCtx, i = "bottom" === t.config.xaxis.position;
e.xaxisOffY = i ? t.globals.gridHeight + 1 : -t.globals.xAxisHeight - t.config.xaxis.axisTicks.height + 3;
var a = i ? "apexcharts-xaxistooltip apexcharts-xaxistooltip-bottom" : "apexcharts-xaxistooltip apexcharts-xaxistooltip-top",
s = t.globals.dom.elWrap;
e.isXAxisTooltipEnabled && (null === t.globals.dom.baseEl.querySelector(".apexcharts-xaxistooltip") && (e.xaxisTooltip = document.createElement("div"), e.xaxisTooltip.setAttribute("class", a + " apexcharts-theme-" + t.config.tooltip.theme), s.appendChild(e.xaxisTooltip), e.xaxisTooltipText = document.createElement("div"), e.xaxisTooltipText.classList.add("apexcharts-xaxistooltip-text"), e.xaxisTooltipText.style.fontFamily = t.config.xaxis.tooltip.style.fontFamily || t.config.chart.fontFamily, e.xaxisTooltipText.style.fontSize = t.config.xaxis.tooltip.style.fontSize, e.xaxisTooltip.appendChild(e.xaxisTooltipText)))
}
}, {
key: "drawYaxisTooltip", value: function () {
for (var t = this.w, e = this.ttCtx, i = 0; i < t.config.yaxis.length; i++) {
var a = t.config.yaxis[i].opposite || t.config.yaxis[i].crosshairs.opposite;
e.yaxisOffX = a ? t.globals.gridWidth + 1 : 1;
var s = "apexcharts-yaxistooltip apexcharts-yaxistooltip-".concat(i, a ? " apexcharts-yaxistooltip-right" : " apexcharts-yaxistooltip-left"),
r = t.globals.dom.elWrap;
null === t.globals.dom.baseEl.querySelector(".apexcharts-yaxistooltip apexcharts-yaxistooltip-".concat(i)) && (e.yaxisTooltip = document.createElement("div"), e.yaxisTooltip.setAttribute("class", s + " apexcharts-theme-" + t.config.tooltip.theme), r.appendChild(e.yaxisTooltip), 0 === i && (e.yaxisTooltipText = []), e.yaxisTooltipText[i] = document.createElement("div"), e.yaxisTooltipText[i].classList.add("apexcharts-yaxistooltip-text"), e.yaxisTooltip.appendChild(e.yaxisTooltipText[i]))
}
}
}, {
key: "setXCrosshairWidth", value: function () {
var t = this.w, e = this.ttCtx, i = e.getElXCrosshairs();
if (e.xcrosshairsWidth = parseInt(t.config.xaxis.crosshairs.width, 10), t.globals.comboCharts) {
var a = t.globals.dom.baseEl.querySelector(".apexcharts-bar-area");
if (null !== a && "barWidth" === t.config.xaxis.crosshairs.width) {
var s = parseFloat(a.getAttribute("barWidth"));
e.xcrosshairsWidth = s
} else if ("tickWidth" === t.config.xaxis.crosshairs.width) {
var r = t.globals.labels.length;
e.xcrosshairsWidth = t.globals.gridWidth / r
}
} else if ("tickWidth" === t.config.xaxis.crosshairs.width) {
var n = t.globals.labels.length;
e.xcrosshairsWidth = t.globals.gridWidth / n
} else if ("barWidth" === t.config.xaxis.crosshairs.width) {
var o = t.globals.dom.baseEl.querySelector(".apexcharts-bar-area");
if (null !== o) {
var l = parseFloat(o.getAttribute("barWidth"));
e.xcrosshairsWidth = l
} else e.xcrosshairsWidth = 1
}
t.globals.isBarHorizontal && (e.xcrosshairsWidth = 0), null !== i && e.xcrosshairsWidth > 0 && i.setAttribute("width", e.xcrosshairsWidth)
}
}, {
key: "handleYCrosshair", value: function () {
var t = this.w, e = this.ttCtx;
e.ycrosshairs = t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs"), e.ycrosshairsHidden = t.globals.dom.baseEl.querySelector(".apexcharts-ycrosshairs-hidden")
}
}, {
key: "drawYaxisTooltipText", value: function (t, e, i) {
var a = this.ttCtx, s = this.w, r = s.globals, n = r.seriesYAxisMap[t];
if (a.yaxisTooltips[t] && n.length > 0) {
var o = r.yLabelFormatters[t], l = a.getElGrid().getBoundingClientRect(), h = n[0], c = 0;
i.yRatio.length > 1 && (c = h);
var d = (e - l.top) * i.yRatio[c], u = r.maxYArr[h] - r.minYArr[h], g = r.minYArr[h] + (u - d);
s.config.yaxis[t].reversed && (g = r.maxYArr[h] - (u - d)), a.tooltipPosition.moveYCrosshairs(e - l.top), a.yaxisTooltipText[t].innerHTML = o(g), a.tooltipPosition.moveYAxisTooltip(t)
}
}
}]), t
}(), La = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w;
var a = this.w;
this.tConfig = a.config.tooltip, this.tooltipUtil = new ya(this), this.tooltipLabels = new wa(this), this.tooltipPosition = new ka(this), this.marker = new Aa(this), this.intersect = new Ca(this), this.axesTooltip = new Sa(this), this.showOnIntersect = this.tConfig.intersect, this.showTooltipTitle = this.tConfig.x.show, this.fixedTooltip = this.tConfig.fixed.enabled, this.xaxisTooltip = null, this.yaxisTTEls = null, this.isBarShared = !a.globals.isBarHorizontal && this.tConfig.shared, this.lastHoverTime = Date.now()
}
return s(t, [{
key: "getElTooltip", value: function (t) {
return t || (t = this), t.w.globals.dom.baseEl ? t.w.globals.dom.baseEl.querySelector(".apexcharts-tooltip") : null
}
}, {
key: "getElXCrosshairs", value: function () {
return this.w.globals.dom.baseEl.querySelector(".apexcharts-xcrosshairs")
}
}, {
key: "getElGrid", value: function () {
return this.w.globals.dom.baseEl.querySelector(".apexcharts-grid")
}
}, {
key: "drawTooltip", value: function (t) {
var e = this.w;
this.xyRatios = t, this.isXAxisTooltipEnabled = e.config.xaxis.tooltip.enabled && e.globals.axisCharts, this.yaxisTooltips = e.config.yaxis.map((function (t, i) {
return !!(t.show && t.tooltip.enabled && e.globals.axisCharts)
})), this.allTooltipSeriesGroups = [], e.globals.axisCharts || (this.showTooltipTitle = !1);
var i = document.createElement("div");
if (i.classList.add("apexcharts-tooltip"), e.config.tooltip.cssClass && i.classList.add(e.config.tooltip.cssClass), i.classList.add("apexcharts-theme-".concat(this.tConfig.theme || "light")), e.globals.dom.elWrap.appendChild(i), e.globals.axisCharts) {
this.axesTooltip.drawXaxisTooltip(), this.axesTooltip.drawYaxisTooltip(), this.axesTooltip.setXCrosshairWidth(), this.axesTooltip.handleYCrosshair();
var a = new Ki(this.ctx);
this.xAxisTicksPositions = a.getXAxisTicksPositions()
}
if (!e.globals.comboCharts && !this.tConfig.intersect && "rangeBar" !== e.config.chart.type || this.tConfig.shared || (this.showOnIntersect = !0), 0 !== e.config.markers.size && 0 !== e.globals.markers.largestSize || this.marker.drawDynamicPoints(this), e.globals.collapsedSeries.length !== e.globals.series.length) {
this.dataPointsDividedHeight = e.globals.gridHeight / e.globals.dataPoints, this.dataPointsDividedWidth = e.globals.gridWidth / e.globals.dataPoints, this.showTooltipTitle && (this.tooltipTitle = document.createElement("div"), this.tooltipTitle.classList.add("apexcharts-tooltip-title"), this.tooltipTitle.style.fontFamily = this.tConfig.style.fontFamily || e.config.chart.fontFamily, this.tooltipTitle.style.fontSize = this.tConfig.style.fontSize, i.appendChild(this.tooltipTitle));
var s = e.globals.series.length;
(e.globals.xyCharts || e.globals.comboCharts) && this.tConfig.shared && (s = this.showOnIntersect ? 1 : e.globals.series.length), this.legendLabels = e.globals.dom.baseEl.querySelectorAll(".apexcharts-legend-text"), this.ttItems = this.createTTElements(s), this.addSVGEvents()
}
}
}, {
key: "createTTElements", value: function (t) {
for (var e = this, i = this.w, a = [], s = this.getElTooltip(), r = function (r) {
var n = document.createElement("div");
n.classList.add("apexcharts-tooltip-series-group", "apexcharts-tooltip-series-group-".concat(r)), n.style.order = i.config.tooltip.inverseOrder ? t - r : r + 1;
var o = document.createElement("span");
o.classList.add("apexcharts-tooltip-marker"), i.config.tooltip.fillSeriesColor ? o.style.backgroundColor = i.globals.colors[r] : o.style.color = i.globals.colors[r];
var l = i.config.markers.shape, h = l;
Array.isArray(l) && (h = l[r]), o.setAttribute("shape", h), n.appendChild(o);
var c = document.createElement("div");
c.classList.add("apexcharts-tooltip-text"), c.style.fontFamily = e.tConfig.style.fontFamily || i.config.chart.fontFamily, c.style.fontSize = e.tConfig.style.fontSize, ["y", "goals", "z"].forEach((function (t) {
var e = document.createElement("div");
e.classList.add("apexcharts-tooltip-".concat(t, "-group"));
var i = document.createElement("span");
i.classList.add("apexcharts-tooltip-text-".concat(t, "-label")), e.appendChild(i);
var a = document.createElement("span");
a.classList.add("apexcharts-tooltip-text-".concat(t, "-value")), e.appendChild(a), c.appendChild(e)
})), n.appendChild(c), s.appendChild(n), a.push(n)
}, n = 0; n < t; n++) r(n);
return a
}
}, {
key: "addSVGEvents", value: function () {
var t = this.w, e = t.config.chart.type, i = this.getElTooltip(),
a = !("bar" !== e && "candlestick" !== e && "boxPlot" !== e && "rangeBar" !== e),
s = "area" === e || "line" === e || "scatter" === e || "bubble" === e || "radar" === e,
r = t.globals.dom.Paper.node, n = this.getElGrid();
n && (this.seriesBound = n.getBoundingClientRect());
var o, l = [], h = [],
c = {hoverArea: r, elGrid: n, tooltipEl: i, tooltipY: l, tooltipX: h, ttItems: this.ttItems};
if (t.globals.axisCharts && (s ? o = t.globals.dom.baseEl.querySelectorAll(".apexcharts-series[data\\:longestSeries='true'] .apexcharts-marker") : a ? o = t.globals.dom.baseEl.querySelectorAll(".apexcharts-series .apexcharts-bar-area, .apexcharts-series .apexcharts-candlestick-area, .apexcharts-series .apexcharts-boxPlot-area, .apexcharts-series .apexcharts-rangebar-area") : "heatmap" !== e && "treemap" !== e || (o = t.globals.dom.baseEl.querySelectorAll(".apexcharts-series .apexcharts-heatmap, .apexcharts-series .apexcharts-treemap")), o && o.length)) for (var d = 0; d < o.length; d++) l.push(o[d].getAttribute("cy")), h.push(o[d].getAttribute("cx"));
if (t.globals.xyCharts && !this.showOnIntersect || t.globals.comboCharts && !this.showOnIntersect || a && this.tooltipUtil.hasBars() && this.tConfig.shared) this.addPathsEventListeners([r], c); else if (a && !t.globals.comboCharts || s && this.showOnIntersect) this.addDatapointEventsListeners(c); else if (!t.globals.axisCharts || "heatmap" === e || "treemap" === e) {
var u = t.globals.dom.baseEl.querySelectorAll(".apexcharts-series");
this.addPathsEventListeners(u, c)
}
if (this.showOnIntersect) {
var g = t.globals.dom.baseEl.querySelectorAll(".apexcharts-line-series .apexcharts-marker, .apexcharts-area-series .apexcharts-marker");
g.length > 0 && this.addPathsEventListeners(g, c), this.tooltipUtil.hasBars() && !this.tConfig.shared && this.addDatapointEventsListeners(c)
}
}
}, {
key: "drawFixedTooltipRect", value: function () {
var t = this.w, e = this.getElTooltip(), i = e.getBoundingClientRect(), a = i.width + 10,
s = i.height + 10, r = this.tConfig.fixed.offsetX, n = this.tConfig.fixed.offsetY,
o = this.tConfig.fixed.position.toLowerCase();
return o.indexOf("right") > -1 && (r = r + t.globals.svgWidth - a + 10), o.indexOf("bottom") > -1 && (n = n + t.globals.svgHeight - s - 10), e.style.left = r + "px", e.style.top = n + "px", {
x: r,
y: n,
ttWidth: a,
ttHeight: s
}
}
}, {
key: "addDatapointEventsListeners", value: function (t) {
var e = this.w.globals.dom.baseEl.querySelectorAll(".apexcharts-series-markers .apexcharts-marker, .apexcharts-bar-area, .apexcharts-candlestick-area, .apexcharts-boxPlot-area, .apexcharts-rangebar-area");
this.addPathsEventListeners(e, t)
}
}, {
key: "addPathsEventListeners", value: function (t, e) {
for (var i = this, a = function (a) {
var s = {
paths: t[a],
tooltipEl: e.tooltipEl,
tooltipY: e.tooltipY,
tooltipX: e.tooltipX,
elGrid: e.elGrid,
hoverArea: e.hoverArea,
ttItems: e.ttItems
};
["mousemove", "mouseup", "touchmove", "mouseout", "touchend"].map((function (e) {
return t[a].addEventListener(e, i.onSeriesHover.bind(i, s), {capture: !1, passive: !0})
}))
}, s = 0; s < t.length; s++) a(s)
}
}, {
key: "onSeriesHover", value: function (t, e) {
var i = this, a = Date.now() - this.lastHoverTime;
a >= 20 ? this.seriesHover(t, e) : (clearTimeout(this.seriesHoverTimeout), this.seriesHoverTimeout = setTimeout((function () {
i.seriesHover(t, e)
}), 20 - a))
}
}, {
key: "seriesHover", value: function (t, e) {
var i = this;
this.lastHoverTime = Date.now();
var a = [], s = this.w;
s.config.chart.group && (a = this.ctx.getGroupedCharts()), s.globals.axisCharts && (s.globals.minX === -1 / 0 && s.globals.maxX === 1 / 0 || 0 === s.globals.dataPoints) || (a.length ? a.forEach((function (a) {
var s = i.getElTooltip(a), r = {
paths: t.paths,
tooltipEl: s,
tooltipY: t.tooltipY,
tooltipX: t.tooltipX,
elGrid: t.elGrid,
hoverArea: t.hoverArea,
ttItems: a.w.globals.tooltip.ttItems
};
a.w.globals.minX === i.w.globals.minX && a.w.globals.maxX === i.w.globals.maxX && a.w.globals.tooltip.seriesHoverByContext({
chartCtx: a,
ttCtx: a.w.globals.tooltip,
opt: r,
e: e
})
})) : this.seriesHoverByContext({chartCtx: this.ctx, ttCtx: this.w.globals.tooltip, opt: t, e: e}))
}
}, {
key: "seriesHoverByContext", value: function (t) {
var e = t.chartCtx, i = t.ttCtx, a = t.opt, s = t.e, r = e.w, n = this.getElTooltip(e);
if (n) {
if (i.tooltipRect = {
x: 0,
y: 0,
ttWidth: n.getBoundingClientRect().width,
ttHeight: n.getBoundingClientRect().height
}, i.e = s, i.tooltipUtil.hasBars() && !r.globals.comboCharts && !i.isBarShared) if (this.tConfig.onDatasetHover.highlightDataSeries) new $i(e).toggleSeriesOnHover(s, s.target.parentNode);
r.globals.axisCharts ? i.axisChartsTooltips({
e: s,
opt: a,
tooltipRect: i.tooltipRect
}) : i.nonAxisChartsTooltips({
e: s,
opt: a,
tooltipRect: i.tooltipRect
}), i.fixedTooltip && i.drawFixedTooltipRect()
}
}
}, {
key: "axisChartsTooltips", value: function (t) {
var e, i, a = t.e, s = t.opt, r = this.w, n = s.elGrid.getBoundingClientRect(),
o = "touchmove" === a.type ? a.touches[0].clientX : a.clientX,
l = "touchmove" === a.type ? a.touches[0].clientY : a.clientY;
if (this.clientY = l, this.clientX = o, r.globals.capturedSeriesIndex = -1, r.globals.capturedDataPointIndex = -1, l < n.top || l > n.top + n.height) this.handleMouseOut(s); else {
if (Array.isArray(this.tConfig.enabledOnSeries) && !r.config.tooltip.shared) {
var h = parseInt(s.paths.getAttribute("index"), 10);
if (this.tConfig.enabledOnSeries.indexOf(h) < 0) return void this.handleMouseOut(s)
}
var c = this.getElTooltip(), d = this.getElXCrosshairs(), u = [];
r.config.chart.group && (u = this.ctx.getSyncedCharts());
var g = r.globals.xyCharts || "bar" === r.config.chart.type && !r.globals.isBarHorizontal && this.tooltipUtil.hasBars() && this.tConfig.shared || r.globals.comboCharts && this.tooltipUtil.hasBars();
if ("mousemove" === a.type || "touchmove" === a.type || "mouseup" === a.type) {
if (r.globals.collapsedSeries.length + r.globals.ancillaryCollapsedSeries.length === r.globals.series.length) return;
null !== d && d.classList.add("apexcharts-active");
var p = this.yaxisTooltips.filter((function (t) {
return !0 === t
}));
if (null !== this.ycrosshairs && p.length && this.ycrosshairs.classList.add("apexcharts-active"), g && !this.showOnIntersect || u.length > 1) this.handleStickyTooltip(a, o, l, s); else if ("heatmap" === r.config.chart.type || "treemap" === r.config.chart.type) {
var f = this.intersect.handleHeatTreeTooltip({
e: a,
opt: s,
x: e,
y: i,
type: r.config.chart.type
});
e = f.x, i = f.y, c.style.left = e + "px", c.style.top = i + "px"
} else this.tooltipUtil.hasBars() && this.intersect.handleBarTooltip({
e: a,
opt: s
}), this.tooltipUtil.hasMarkers() && this.intersect.handleMarkerTooltip({
e: a,
opt: s,
x: e,
y: i
});
if (this.yaxisTooltips.length) for (var x = 0; x < r.config.yaxis.length; x++) this.axesTooltip.drawYaxisTooltipText(x, l, this.xyRatios);
r.globals.dom.baseEl.classList.add("apexcharts-tooltip-active"), s.tooltipEl.classList.add("apexcharts-active")
} else "mouseout" !== a.type && "touchend" !== a.type || this.handleMouseOut(s)
}
}
}, {
key: "nonAxisChartsTooltips", value: function (t) {
var e = t.e, i = t.opt, a = t.tooltipRect, s = this.w, r = i.paths.getAttribute("rel"),
n = this.getElTooltip(), o = s.globals.dom.elWrap.getBoundingClientRect();
if ("mousemove" === e.type || "touchmove" === e.type) {
s.globals.dom.baseEl.classList.add("apexcharts-tooltip-active"), n.classList.add("apexcharts-active"), this.tooltipLabels.drawSeriesTexts({
ttItems: i.ttItems,
i: parseInt(r, 10) - 1,
shared: !1
});
var l = s.globals.clientX - o.left - a.ttWidth / 2, h = s.globals.clientY - o.top - a.ttHeight - 10;
if (n.style.left = l + "px", n.style.top = h + "px", s.config.legend.tooltipHoverFormatter) {
var c = r - 1,
d = (0, s.config.legend.tooltipHoverFormatter)(this.legendLabels[c].getAttribute("data:default-text"), {
seriesIndex: c,
dataPointIndex: c,
w: s
});
this.legendLabels[c].innerHTML = d
}
} else "mouseout" !== e.type && "touchend" !== e.type || (n.classList.remove("apexcharts-active"), s.globals.dom.baseEl.classList.remove("apexcharts-tooltip-active"), s.config.legend.tooltipHoverFormatter && this.legendLabels.forEach((function (t) {
var e = t.getAttribute("data:default-text");
t.innerHTML = decodeURIComponent(e)
})))
}
}, {
key: "handleStickyTooltip", value: function (t, e, i, a) {
var s = this.w, r = this.tooltipUtil.getNearestValues({
context: this,
hoverArea: a.hoverArea,
elGrid: a.elGrid,
clientX: e,
clientY: i
}), n = r.j, o = r.capturedSeries;
s.globals.collapsedSeriesIndices.includes(o) && (o = null);
var l = a.elGrid.getBoundingClientRect();
if (r.hoverX < 0 || r.hoverX > l.width) this.handleMouseOut(a); else if (null !== o) this.handleStickyCapturedSeries(t, o, a, n); else if (this.tooltipUtil.isXoverlap(n) || s.globals.isBarHorizontal) {
var h = s.globals.series.findIndex((function (t, e) {
return !s.globals.collapsedSeriesIndices.includes(e)
}));
this.create(t, this, h, n, a.ttItems)
}
}
}, {
key: "handleStickyCapturedSeries", value: function (t, e, i, a) {
var s = this.w;
if (!this.tConfig.shared && null === s.globals.series[e][a]) return void this.handleMouseOut(i);
if (void 0 !== s.globals.series[e][a]) this.tConfig.shared && this.tooltipUtil.isXoverlap(a) && this.tooltipUtil.isInitialSeriesSameLen() ? this.create(t, this, e, a, i.ttItems) : this.create(t, this, e, a, i.ttItems, !1); else if (this.tooltipUtil.isXoverlap(a)) {
var r = s.globals.series.findIndex((function (t, e) {
return !s.globals.collapsedSeriesIndices.includes(e)
}));
this.create(t, this, r, a, i.ttItems)
}
}
}, {
key: "deactivateHoverFilter", value: function () {
for (var t = this.w, e = new Mi(this.ctx), i = t.globals.dom.Paper.find(".apexcharts-bar-area"), a = 0; a < i.length; a++) e.pathMouseLeave(i[a])
}
}, {
key: "handleMouseOut", value: function (t) {
var e = this.w, i = this.getElXCrosshairs();
if (e.globals.dom.baseEl.classList.remove("apexcharts-tooltip-active"), t.tooltipEl.classList.remove("apexcharts-active"), this.deactivateHoverFilter(), "bubble" !== e.config.chart.type && this.marker.resetPointsSize(), null !== i && i.classList.remove("apexcharts-active"), null !== this.ycrosshairs && this.ycrosshairs.classList.remove("apexcharts-active"), this.isXAxisTooltipEnabled && this.xaxisTooltip.classList.remove("apexcharts-active"), this.yaxisTooltips.length) {
null === this.yaxisTTEls && (this.yaxisTTEls = e.globals.dom.baseEl.querySelectorAll(".apexcharts-yaxistooltip"));
for (var a = 0; a < this.yaxisTTEls.length; a++) this.yaxisTTEls[a].classList.remove("apexcharts-active")
}
e.config.legend.tooltipHoverFormatter && this.legendLabels.forEach((function (t) {
var e = t.getAttribute("data:default-text");
t.innerHTML = decodeURIComponent(e)
}))
}
}, {
key: "markerClick", value: function (t, e, i) {
var a = this.w;
"function" == typeof a.config.chart.events.markerClick && a.config.chart.events.markerClick(t, this.ctx, {
seriesIndex: e,
dataPointIndex: i,
w: a
}), this.ctx.events.fireEvent("markerClick", [t, this.ctx, {seriesIndex: e, dataPointIndex: i, w: a}])
}
}, {
key: "create", value: function (t, e, i, a, s) {
var r, n, o, l, h, c, d, g, p, f, x, b, m, v, y, w,
k = arguments.length > 5 && void 0 !== arguments[5] ? arguments[5] : null, A = this.w, C = e;
"mouseup" === t.type && this.markerClick(t, i, a), null === k && (k = this.tConfig.shared);
var S = this.tooltipUtil.hasMarkers(i), L = this.tooltipUtil.getElBars(), M = function () {
A.globals.markers.largestSize > 0 ? C.marker.enlargePoints(a) : C.tooltipPosition.moveDynamicPointsOnHover(a)
};
if (A.config.legend.tooltipHoverFormatter) {
var P = A.config.legend.tooltipHoverFormatter, I = Array.from(this.legendLabels);
I.forEach((function (t) {
var e = t.getAttribute("data:default-text");
t.innerHTML = decodeURIComponent(e)
}));
for (var T = 0; T < I.length; T++) {
var z = I[T], X = parseInt(z.getAttribute("i"), 10),
R = decodeURIComponent(z.getAttribute("data:default-text")),
E = P(R, {seriesIndex: k ? X : i, dataPointIndex: a, w: A});
if (k) z.innerHTML = A.globals.collapsedSeriesIndices.indexOf(X) < 0 ? E : R; else if (z.innerHTML = X === i ? E : R, i === X) break
}
}
var Y = u(u({
ttItems: s,
i: i,
j: a
}, void 0 !== (null === (r = A.globals.seriesRange) || void 0 === r || null === (n = r[i]) || void 0 === n || null === (o = n[a]) || void 0 === o || null === (l = o.y[0]) || void 0 === l ? void 0 : l.y1) && {y1: null === (h = A.globals.seriesRange) || void 0 === h || null === (c = h[i]) || void 0 === c || null === (d = c[a]) || void 0 === d || null === (g = d.y[0]) || void 0 === g ? void 0 : g.y1}), void 0 !== (null === (p = A.globals.seriesRange) || void 0 === p || null === (f = p[i]) || void 0 === f || null === (x = f[a]) || void 0 === x || null === (b = x.y[0]) || void 0 === b ? void 0 : b.y2) && {y2: null === (m = A.globals.seriesRange) || void 0 === m || null === (v = m[i]) || void 0 === v || null === (y = v[a]) || void 0 === y || null === (w = y.y[0]) || void 0 === w ? void 0 : w.y2});
if (k) {
if (C.tooltipLabels.drawSeriesTexts(u(u({}, Y), {}, {shared: !this.showOnIntersect && this.tConfig.shared})), S) M(); else if (this.tooltipUtil.hasBars() && (this.barSeriesHeight = this.tooltipUtil.getBarsHeight(L), this.barSeriesHeight > 0)) {
var H = new Mi(this.ctx),
O = A.globals.dom.Paper.find(".apexcharts-bar-area[j='".concat(a, "']"));
this.deactivateHoverFilter(), C.tooltipUtil.getAllMarkers(!0).length && !this.barSeriesHeight && M(), C.tooltipPosition.moveStickyTooltipOverBars(a, i);
for (var F = 0; F < O.length; F++) H.pathMouseEnter(O[F])
}
} else C.tooltipLabels.drawSeriesTexts(u({shared: !1}, Y)), this.tooltipUtil.hasBars() && C.tooltipPosition.moveStickyTooltipOverBars(a, i), S && C.tooltipPosition.moveMarkers(i, a)
}
}]), t
}(), Ma = function () {
function t(e) {
i(this, t), this.w = e.w, this.barCtx = e, this.totalFormatter = this.w.config.plotOptions.bar.dataLabels.total.formatter, this.totalFormatter || (this.totalFormatter = this.w.config.dataLabels.formatter)
}
return s(t, [{
key: "handleBarDataLabels", value: function (t) {
var e, i, a = t.x, s = t.y, r = t.y1, n = t.y2, o = t.i, l = t.j, h = t.realIndex,
c = t.columnGroupIndex, d = t.series, g = t.barHeight, p = t.barWidth, f = t.barXPosition,
x = t.barYPosition, b = t.visibleSeries, m = this.w, v = new Mi(this.barCtx.ctx),
y = Array.isArray(this.barCtx.strokeWidth) ? this.barCtx.strokeWidth[h] : this.barCtx.strokeWidth;
m.globals.isXNumeric && !m.globals.isBarHorizontal ? (e = a + parseFloat(p * (b + 1)), i = s + parseFloat(g * (b + 1)) - y) : (e = a + parseFloat(p * b), i = s + parseFloat(g * b));
var w, k = null, A = a, C = s, S = {}, L = m.config.dataLabels, M = this.barCtx.barOptions.dataLabels,
P = this.barCtx.barOptions.dataLabels.total;
void 0 !== x && this.barCtx.isRangeBar && (i = x, C = x), void 0 !== f && this.barCtx.isVerticalGroupedRangeBar && (e = f, A = f);
var I = L.offsetX, T = L.offsetY, z = {width: 0, height: 0};
if (m.config.dataLabels.enabled) {
var X = m.globals.series[o][l];
z = v.getTextRects(m.config.dataLabels.formatter ? m.config.dataLabels.formatter(X, u(u({}, m), {}, {
seriesIndex: o,
dataPointIndex: l,
w: m
})) : m.globals.yLabelFormatters[0](X), parseFloat(L.style.fontSize))
}
var R = {
x: a,
y: s,
i: o,
j: l,
realIndex: h,
columnGroupIndex: c,
bcx: e,
bcy: i,
barHeight: g,
barWidth: p,
textRects: z,
strokeWidth: y,
dataLabelsX: A,
dataLabelsY: C,
dataLabelsConfig: L,
barDataLabelsConfig: M,
barTotalDataLabelsConfig: P,
offX: I,
offY: T
};
return S = this.barCtx.isHorizontal ? this.calculateBarsDataLabelsPosition(R) : this.calculateColumnsDataLabelsPosition(R), w = this.drawCalculatedDataLabels({
x: S.dataLabelsX,
y: S.dataLabelsY,
val: this.barCtx.isRangeBar ? [r, n] : "100%" === m.config.chart.stackType ? d[h][l] : m.globals.series[h][l],
i: h,
j: l,
barWidth: p,
barHeight: g,
textRects: z,
dataLabelsConfig: L
}), m.config.chart.stacked && P.enabled && (k = this.drawTotalDataLabels({
x: S.totalDataLabelsX,
y: S.totalDataLabelsY,
barWidth: p,
barHeight: g,
realIndex: h,
textAnchor: S.totalDataLabelsAnchor,
val: this.getStackedTotalDataLabel({realIndex: h, j: l}),
dataLabelsConfig: L,
barTotalDataLabelsConfig: P
})), {dataLabelsPos: S, dataLabels: w, totalDataLabels: k}
}
}, {
key: "getStackedTotalDataLabel", value: function (t) {
var e = t.realIndex, i = t.j, a = this.w, s = this.barCtx.stackedSeriesTotals[i];
return this.totalFormatter && (s = this.totalFormatter(s, u(u({}, a), {}, {
seriesIndex: e,
dataPointIndex: i,
w: a
}))), s
}
}, {
key: "calculateColumnsDataLabelsPosition", value: function (t) {
var e = this, i = this.w, a = t.i, s = t.j, r = t.realIndex;
t.columnGroupIndex;
var n, o, l = t.y, h = t.bcx, c = t.barWidth, d = t.barHeight, u = t.textRects, g = t.dataLabelsX,
p = t.dataLabelsY, f = t.dataLabelsConfig, x = t.barDataLabelsConfig,
b = t.barTotalDataLabelsConfig, m = t.strokeWidth, v = t.offX, y = t.offY, w = h;
d = Math.abs(d);
var k = "vertical" === i.config.plotOptions.bar.dataLabels.orientation,
A = this.barCtx.barHelpers.getZeroValueEncounters({i: a, j: s}).zeroEncounters;
h -= m / 2;
var C = i.globals.gridWidth / i.globals.dataPoints;
if (this.barCtx.isVerticalGroupedRangeBar ? g += c / 2 : (g = i.globals.isXNumeric ? h - c / 2 + v : h - C + c / 2 + v, !i.config.chart.stacked && A > 0 && i.config.plotOptions.bar.hideZeroBarsWhenGrouped && (g -= c * A)), k) {
g = g + u.height / 2 - m / 2 - 2
}
var S = i.globals.series[a][s] < 0, L = l;
switch (this.barCtx.isReversed && (L = l + (S ? d : -d)), x.position) {
case"center":
p = k ? S ? L - d / 2 + y : L + d / 2 - y : S ? L - d / 2 + u.height / 2 + y : L + d / 2 + u.height / 2 - y;
break;
case"bottom":
p = k ? S ? L - d + y : L + d - y : S ? L - d + u.height + m + y : L + d - u.height / 2 + m - y;
break;
case"top":
p = k ? S ? L + y : L - y : S ? L - u.height / 2 - y : L + u.height + y
}
var M = L;
if (i.globals.seriesGroups.forEach((function (t) {
var i;
null === (i = e.barCtx[t.join(",")]) || void 0 === i || i.prevY.forEach((function (t) {
M = S ? Math.max(t[s], M) : Math.min(t[s], M)
}))
})), this.barCtx.lastActiveBarSerieIndex === r && b.enabled) {
var P = new Mi(this.barCtx.ctx).getTextRects(this.getStackedTotalDataLabel({
realIndex: r,
j: s
}), f.fontSize);
n = S ? M - P.height / 2 - y - b.offsetY + 18 : M + P.height + y + b.offsetY - 18;
var I = C;
o = w + (i.globals.isXNumeric ? -c * i.globals.barGroups.length / 2 : i.globals.barGroups.length * c / 2 - (i.globals.barGroups.length - 1) * c - I) + b.offsetX
}
return i.config.chart.stacked || (p < 0 ? p = 0 + m : p + u.height / 3 > i.globals.gridHeight && (p = i.globals.gridHeight - m)), {
bcx: h,
bcy: l,
dataLabelsX: g,
dataLabelsY: p,
totalDataLabelsX: o,
totalDataLabelsY: n,
totalDataLabelsAnchor: "middle"
}
}
}, {
key: "calculateBarsDataLabelsPosition", value: function (t) {
var e = this, i = this.w, a = t.x, s = t.i, r = t.j, n = t.realIndex, o = t.bcy, l = t.barHeight,
h = t.barWidth, c = t.textRects, d = t.dataLabelsX, u = t.strokeWidth, g = t.dataLabelsConfig,
p = t.barDataLabelsConfig, f = t.barTotalDataLabelsConfig, x = t.offX, b = t.offY,
m = i.globals.gridHeight / i.globals.dataPoints,
v = this.barCtx.barHelpers.getZeroValueEncounters({i: s, j: r}).zeroEncounters;
h = Math.abs(h);
var y, w, k = o - (this.barCtx.isRangeBar ? 0 : m) + l / 2 + c.height / 2 + b - 3;
!i.config.chart.stacked && v > 0 && i.config.plotOptions.bar.hideZeroBarsWhenGrouped && (k -= l * v);
var A = "start", C = i.globals.series[s][r] < 0, S = a;
switch (this.barCtx.isReversed && (S = a + (C ? -h : h), A = C ? "start" : "end"), p.position) {
case"center":
d = C ? S + h / 2 - x : Math.max(c.width / 2, S - h / 2) + x;
break;
case"bottom":
d = C ? S + h - u - x : S - h + u + x;
break;
case"top":
d = C ? S - u - x : S - u + x
}
var L = S;
if (i.globals.seriesGroups.forEach((function (t) {
var i;
null === (i = e.barCtx[t.join(",")]) || void 0 === i || i.prevX.forEach((function (t) {
L = C ? Math.min(t[r], L) : Math.max(t[r], L)
}))
})), this.barCtx.lastActiveBarSerieIndex === n && f.enabled) {
var M = new Mi(this.barCtx.ctx).getTextRects(this.getStackedTotalDataLabel({
realIndex: n,
j: r
}), g.fontSize);
C ? (y = L - u - x - f.offsetX, A = "end") : y = L + x + f.offsetX + (this.barCtx.isReversed ? -(h + u) : u), w = k - c.height / 2 + M.height / 2 + f.offsetY + u, i.globals.barGroups.length > 1 && (w -= i.globals.barGroups.length / 2 * (l / 2))
}
return i.config.chart.stacked || ("start" === g.textAnchor ? d - c.width < 0 ? d = C ? c.width + u : u : d + c.width > i.globals.gridWidth && (d = C ? i.globals.gridWidth - u : i.globals.gridWidth - c.width - u) : "middle" === g.textAnchor ? d - c.width / 2 < 0 ? d = c.width / 2 + u : d + c.width / 2 > i.globals.gridWidth && (d = i.globals.gridWidth - c.width / 2 - u) : "end" === g.textAnchor && (d < 1 ? d = c.width + u : d + 1 > i.globals.gridWidth && (d = i.globals.gridWidth - c.width - u))), {
bcx: a,
bcy: o,
dataLabelsX: d,
dataLabelsY: k,
totalDataLabelsX: y,
totalDataLabelsY: w,
totalDataLabelsAnchor: A
}
}
}, {
key: "drawCalculatedDataLabels", value: function (t) {
var e = t.x, i = t.y, a = t.val, s = t.i, r = t.j, n = t.textRects, o = t.barHeight, l = t.barWidth,
h = t.dataLabelsConfig, c = this.w, d = "rotate(0)";
"vertical" === c.config.plotOptions.bar.dataLabels.orientation && (d = "rotate(-90, ".concat(e, ", ").concat(i, ")"));
var g = new qi(this.barCtx.ctx), p = new Mi(this.barCtx.ctx), f = h.formatter, x = null,
b = c.globals.collapsedSeriesIndices.indexOf(s) > -1;
if (h.enabled && !b) {
x = p.group({class: "apexcharts-data-labels", transform: d});
var m = "";
void 0 !== a && (m = f(a, u(u({}, c), {}, {
seriesIndex: s,
dataPointIndex: r,
w: c
}))), !a && c.config.plotOptions.bar.hideZeroBarsWhenGrouped && (m = "");
var v = c.globals.series[s][r] < 0, y = c.config.plotOptions.bar.dataLabels.position;
if ("vertical" === c.config.plotOptions.bar.dataLabels.orientation && ("top" === y && (h.textAnchor = v ? "end" : "start"), "center" === y && (h.textAnchor = "middle"), "bottom" === y && (h.textAnchor = v ? "end" : "start")), this.barCtx.isRangeBar && this.barCtx.barOptions.dataLabels.hideOverflowingLabels) l < p.getTextRects(m, parseFloat(h.style.fontSize)).width && (m = "");
c.config.chart.stacked && this.barCtx.barOptions.dataLabels.hideOverflowingLabels && (this.barCtx.isHorizontal ? n.width / 1.6 > Math.abs(l) && (m = "") : n.height / 1.6 > Math.abs(o) && (m = ""));
var w = u({}, h);
this.barCtx.isHorizontal && a < 0 && ("start" === h.textAnchor ? w.textAnchor = "end" : "end" === h.textAnchor && (w.textAnchor = "start")), g.plotDataLabelsText({
x: e,
y: i,
text: m,
i: s,
j: r,
parent: x,
dataLabelsConfig: w,
alwaysDrawDataLabel: !0,
offsetCorrection: !0
})
}
return x
}
}, {
key: "drawTotalDataLabels", value: function (t) {
var e = t.x, i = t.y, a = t.val, s = t.realIndex, r = t.textAnchor, n = t.barTotalDataLabelsConfig;
this.w;
var o, l = new Mi(this.barCtx.ctx);
return n.enabled && void 0 !== e && void 0 !== i && this.barCtx.lastActiveBarSerieIndex === s && (o = l.drawText({
x: e,
y: i,
foreColor: n.style.color,
text: a,
textAnchor: r,
fontFamily: n.style.fontFamily,
fontSize: n.style.fontSize,
fontWeight: n.style.fontWeight
})), o
}
}]), t
}(), Pa = function () {
function t(e) {
i(this, t), this.w = e.w, this.barCtx = e
}
return s(t, [{
key: "initVariables", value: function (t) {
var e = this.w;
this.barCtx.series = t, this.barCtx.totalItems = 0, this.barCtx.seriesLen = 0, this.barCtx.visibleI = -1, this.barCtx.visibleItems = 1;
for (var i = 0; i < t.length; i++) if (t[i].length > 0 && (this.barCtx.seriesLen = this.barCtx.seriesLen + 1, this.barCtx.totalItems += t[i].length), e.globals.isXNumeric) for (var a = 0; a < t[i].length; a++) e.globals.seriesX[i][a] > e.globals.minX && e.globals.seriesX[i][a] < e.globals.maxX && this.barCtx.visibleItems++; else this.barCtx.visibleItems = e.globals.dataPoints;
this.arrBorderRadius = this.createBorderRadiusArr(e.globals.series), v.isSafari() && (this.arrBorderRadius = this.arrBorderRadius.map((function (t) {
return t.map((function (t) {
return "none"
}))
}))), 0 === this.barCtx.seriesLen && (this.barCtx.seriesLen = 1), this.barCtx.zeroSerieses = [], e.globals.comboCharts || this.checkZeroSeries({series: t})
}
}, {
key: "initialPositions", value: function (t) {
var e, i, a, s, r, n, o, l, h = this.w, c = h.globals.dataPoints;
this.barCtx.isRangeBar && (c = h.globals.labels.length);
var d = this.barCtx.seriesLen;
if (h.config.plotOptions.bar.rangeBarGroupRows && (d = 1), this.barCtx.isHorizontal) r = (a = h.globals.gridHeight / c) / d, h.globals.isXNumeric && (r = (a = h.globals.gridHeight / this.barCtx.totalItems) / this.barCtx.seriesLen), r = r * parseInt(this.barCtx.barOptions.barHeight, 10) / 100, -1 === String(this.barCtx.barOptions.barHeight).indexOf("%") && (r = parseInt(this.barCtx.barOptions.barHeight, 10)), l = this.barCtx.baseLineInvertedY + h.globals.padHorizontal + (this.barCtx.isReversed ? h.globals.gridWidth : 0) - (this.barCtx.isReversed ? 2 * this.barCtx.baseLineInvertedY : 0), this.barCtx.isFunnel && (l = h.globals.gridWidth / 2), i = (a - r * this.barCtx.seriesLen) / 2; else {
if (s = h.globals.gridWidth / this.barCtx.visibleItems, h.config.xaxis.convertedCatToNumeric && (s = h.globals.gridWidth / h.globals.dataPoints), n = s / d * parseInt(this.barCtx.barOptions.columnWidth, 10) / 100, h.globals.isXNumeric) {
var u = this.barCtx.xRatio;
h.globals.minXDiff && .5 !== h.globals.minXDiff && h.globals.minXDiff / u > 0 && (s = h.globals.minXDiff / u), (n = s / d * parseInt(this.barCtx.barOptions.columnWidth, 10) / 100) < 1 && (n = 1)
}
if (-1 === String(this.barCtx.barOptions.columnWidth).indexOf("%") && (n = parseInt(this.barCtx.barOptions.columnWidth, 10)), o = h.globals.gridHeight - this.barCtx.baseLineY[this.barCtx.translationsIndex] - (this.barCtx.isReversed ? h.globals.gridHeight : 0) + (this.barCtx.isReversed ? 2 * this.barCtx.baseLineY[this.barCtx.translationsIndex] : 0), h.globals.isXNumeric) e = this.barCtx.getBarXForNumericXAxis({
x: e,
j: 0,
realIndex: t,
barWidth: n
}).x; else e = h.globals.padHorizontal + v.noExponents(s - n * this.barCtx.seriesLen) / 2
}
return h.globals.barHeight = r, h.globals.barWidth = n, {
x: e,
y: i,
yDivision: a,
xDivision: s,
barHeight: r,
barWidth: n,
zeroH: o,
zeroW: l
}
}
}, {
key: "initializeStackedPrevVars", value: function (t) {
t.w.globals.seriesGroups.forEach((function (e) {
t[e] || (t[e] = {}), t[e].prevY = [], t[e].prevX = [], t[e].prevYF = [], t[e].prevXF = [], t[e].prevYVal = [], t[e].prevXVal = []
}))
}
}, {
key: "initializeStackedXYVars", value: function (t) {
t.w.globals.seriesGroups.forEach((function (e) {
t[e] || (t[e] = {}), t[e].xArrj = [], t[e].xArrjF = [], t[e].xArrjVal = [], t[e].yArrj = [], t[e].yArrjF = [], t[e].yArrjVal = []
}))
}
}, {
key: "getPathFillColor", value: function (t, e, i, a) {
var s, r, n, o, l = this.w, h = this.barCtx.ctx.fill, c = null,
d = this.barCtx.barOptions.distributed ? i : e, u = !1;
this.barCtx.barOptions.colors.ranges.length > 0 && this.barCtx.barOptions.colors.ranges.map((function (a) {
t[e][i] >= a.from && t[e][i] <= a.to && (c = a.color, u = !0)
}));
return {
color: h.fillPath({
seriesNumber: this.barCtx.barOptions.distributed ? d : a,
dataPointIndex: i,
color: c,
value: t[e][i],
fillConfig: null === (s = l.config.series[e].data[i]) || void 0 === s ? void 0 : s.fill,
fillType: null !== (r = l.config.series[e].data[i]) && void 0 !== r && null !== (n = r.fill) && void 0 !== n && n.type ? null === (o = l.config.series[e].data[i]) || void 0 === o ? void 0 : o.fill.type : Array.isArray(l.config.fill.type) ? l.config.fill.type[a] : l.config.fill.type
}), useRangeColor: u
}
}
}, {
key: "getStrokeWidth", value: function (t, e, i) {
var a = 0, s = this.w;
return void 0 === this.barCtx.series[t][e] || null === this.barCtx.series[t][e] || "bar" === s.config.chart.type && !this.barCtx.series[t][e] ? this.barCtx.isNullValue = !0 : this.barCtx.isNullValue = !1, s.config.stroke.show && (this.barCtx.isNullValue || (a = Array.isArray(this.barCtx.strokeWidth) ? this.barCtx.strokeWidth[i] : this.barCtx.strokeWidth)), a
}
}, {
key: "createBorderRadiusArr", value: function (t) {
var e, i = this.w, a = !this.w.config.chart.stacked || i.config.plotOptions.bar.borderRadius <= 0,
s = t.length, n = 0 | (null === (e = t[0]) || void 0 === e ? void 0 : e.length),
o = Array.from({length: s}, (function () {
return Array(n).fill(a ? "top" : "none")
}));
if (a) return o;
for (var l = 0; l < n; l++) {
for (var h = [], c = [], d = 0, u = 0; u < s; u++) {
var g = t[u][l];
g > 0 ? (h.push(u), d++) : g < 0 && (c.push(u), d++)
}
if (h.length > 0 && 0 === c.length) if (1 === h.length) o[h[0]][l] = "both"; else {
var p, f = h[0], x = h[h.length - 1], b = r(h);
try {
for (b.s(); !(p = b.n()).done;) {
var m = p.value;
o[m][l] = m === f ? "bottom" : m === x ? "top" : "none"
}
} catch (t) {
b.e(t)
} finally {
b.f()
}
} else if (c.length > 0 && 0 === h.length) if (1 === c.length) o[c[0]][l] = "both"; else {
var v, y = Math.max.apply(Math, c), w = Math.min.apply(Math, c), k = r(c);
try {
for (k.s(); !(v = k.n()).done;) {
var A = v.value;
o[A][l] = A === y ? "bottom" : A === w ? "top" : "none"
}
} catch (t) {
k.e(t)
} finally {
k.f()
}
} else if (h.length > 0 && c.length > 0) {
var C, S = h[h.length - 1], L = r(h);
try {
for (L.s(); !(C = L.n()).done;) {
var M = C.value;
o[M][l] = M === S ? "top" : "none"
}
} catch (t) {
L.e(t)
} finally {
L.f()
}
var P, I = Math.max.apply(Math, c), T = r(c);
try {
for (T.s(); !(P = T.n()).done;) {
var z = P.value;
o[z][l] = z === I ? "bottom" : "none"
}
} catch (t) {
T.e(t)
} finally {
T.f()
}
} else if (1 === d) {
o[h[0] || c[0]][l] = "both"
}
}
return o
}
}, {
key: "barBackground", value: function (t) {
var e = t.j, i = t.i, a = t.x1, s = t.x2, r = t.y1, n = t.y2, o = t.elSeries, l = this.w,
h = new Mi(this.barCtx.ctx), c = new $i(this.barCtx.ctx).getActiveConfigSeriesIndex();
if (this.barCtx.barOptions.colors.backgroundBarColors.length > 0 && c === i) {
e >= this.barCtx.barOptions.colors.backgroundBarColors.length && (e %= this.barCtx.barOptions.colors.backgroundBarColors.length);
var d = this.barCtx.barOptions.colors.backgroundBarColors[e],
u = h.drawRect(void 0 !== a ? a : 0, void 0 !== r ? r : 0, void 0 !== s ? s : l.globals.gridWidth, void 0 !== n ? n : l.globals.gridHeight, this.barCtx.barOptions.colors.backgroundBarRadius, d, this.barCtx.barOptions.colors.backgroundBarOpacity);
o.add(u), u.node.classList.add("apexcharts-backgroundBar")
}
}
}, {
key: "getColumnPaths", value: function (t) {
var e, i = t.barWidth, a = t.barXPosition, s = t.y1, r = t.y2, n = t.strokeWidth, o = t.isReversed,
l = t.series, h = t.seriesGroup, c = t.realIndex, d = t.i, u = t.j, g = t.w,
p = new Mi(this.barCtx.ctx);
(n = Array.isArray(n) ? n[c] : n) || (n = 0);
var f = i, x = a;
null !== (e = g.config.series[c].data[u]) && void 0 !== e && e.columnWidthOffset && (x = a - g.config.series[c].data[u].columnWidthOffset / 2, f = i + g.config.series[c].data[u].columnWidthOffset);
var b = n / 2, m = x + b, v = x + f - b, y = (l[d][u] >= 0 ? 1 : -1) * (o ? -1 : 1);
s += .001 - b * y, r += .001 + b * y;
var w = p.move(m, s), k = p.move(m, s), A = p.line(v, s);
if (g.globals.previousPaths.length > 0 && (k = this.barCtx.getPreviousPath(c, u, !1)), w = w + p.line(m, r) + p.line(v, r) + A + ("around" === g.config.plotOptions.bar.borderRadiusApplication || "both" === this.arrBorderRadius[c][u] ? " Z" : " z"), k = k + p.line(m, s) + A + A + A + A + A + p.line(m, s) + ("around" === g.config.plotOptions.bar.borderRadiusApplication || "both" === this.arrBorderRadius[c][u] ? " Z" : " z"), "none" !== this.arrBorderRadius[c][u] && (w = p.roundPathCorners(w, g.config.plotOptions.bar.borderRadius)), g.config.chart.stacked) {
var C = this.barCtx;
(C = this.barCtx[h]).yArrj.push(r - b * y), C.yArrjF.push(Math.abs(s - r + n * y)), C.yArrjVal.push(this.barCtx.series[d][u])
}
return {pathTo: w, pathFrom: k}
}
}, {
key: "getBarpaths", value: function (t) {
var e, i = t.barYPosition, a = t.barHeight, s = t.x1, r = t.x2, n = t.strokeWidth, o = t.isReversed,
l = t.series, h = t.seriesGroup, c = t.realIndex, d = t.i, u = t.j, g = t.w,
p = new Mi(this.barCtx.ctx);
(n = Array.isArray(n) ? n[c] : n) || (n = 0);
var f = i, x = a;
null !== (e = g.config.series[c].data[u]) && void 0 !== e && e.barHeightOffset && (f = i - g.config.series[c].data[u].barHeightOffset / 2, x = a + g.config.series[c].data[u].barHeightOffset);
var b = n / 2, m = f + b, v = f + x - b, y = (l[d][u] >= 0 ? 1 : -1) * (o ? -1 : 1);
s += .001 + b * y, r += .001 - b * y;
var w = p.move(s, m), k = p.move(s, m);
g.globals.previousPaths.length > 0 && (k = this.barCtx.getPreviousPath(c, u, !1));
var A = p.line(s, v);
if (w = w + p.line(r, m) + p.line(r, v) + A + ("around" === g.config.plotOptions.bar.borderRadiusApplication || "both" === this.arrBorderRadius[c][u] ? " Z" : " z"), k = k + p.line(s, m) + A + A + A + A + A + p.line(s, m) + ("around" === g.config.plotOptions.bar.borderRadiusApplication || "both" === this.arrBorderRadius[c][u] ? " Z" : " z"), "none" !== this.arrBorderRadius[c][u] && (w = p.roundPathCorners(w, g.config.plotOptions.bar.borderRadius)), g.config.chart.stacked) {
var C = this.barCtx;
(C = this.barCtx[h]).xArrj.push(r + b * y), C.xArrjF.push(Math.abs(s - r - n * y)), C.xArrjVal.push(this.barCtx.series[d][u])
}
return {pathTo: w, pathFrom: k}
}
}, {
key: "checkZeroSeries", value: function (t) {
for (var e = t.series, i = this.w, a = 0; a < e.length; a++) {
for (var s = 0, r = 0; r < e[i.globals.maxValsInArrayIndex].length; r++) s += e[a][r];
0 === s && this.barCtx.zeroSerieses.push(a)
}
}
}, {
key: "getXForValue", value: function (t, e) {
var i = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2] ? e : null;
return null != t && (i = e + t / this.barCtx.invertedYRatio - 2 * (this.barCtx.isReversed ? t / this.barCtx.invertedYRatio : 0)), i
}
}, {
key: "getYForValue", value: function (t, e, i) {
var a = !(arguments.length > 3 && void 0 !== arguments[3]) || arguments[3] ? e : null;
return null != t && (a = e - t / this.barCtx.yRatio[i] + 2 * (this.barCtx.isReversed ? t / this.barCtx.yRatio[i] : 0)), a
}
}, {
key: "getGoalValues", value: function (t, e, i, a, s, r) {
var n = this, l = this.w, h = [], c = function (a, s) {
var l;
h.push((o(l = {}, t, "x" === t ? n.getXForValue(a, e, !1) : n.getYForValue(a, i, r, !1)), o(l, "attrs", s), l))
};
if (l.globals.seriesGoals[a] && l.globals.seriesGoals[a][s] && Array.isArray(l.globals.seriesGoals[a][s]) && l.globals.seriesGoals[a][s].forEach((function (t) {
c(t.value, t)
})), this.barCtx.barOptions.isDumbbell && l.globals.seriesRange.length) {
var d = this.barCtx.barOptions.dumbbellColors ? this.barCtx.barOptions.dumbbellColors : l.globals.colors,
g = {
strokeHeight: "x" === t ? 0 : l.globals.markers.size[a],
strokeWidth: "x" === t ? l.globals.markers.size[a] : 0,
strokeDashArray: 0,
strokeLineCap: "round",
strokeColor: Array.isArray(d[a]) ? d[a][0] : d[a]
};
c(l.globals.seriesRangeStart[a][s], g), c(l.globals.seriesRangeEnd[a][s], u(u({}, g), {}, {strokeColor: Array.isArray(d[a]) ? d[a][1] : d[a]}))
}
return h
}
}, {
key: "drawGoalLine", value: function (t) {
var e = t.barXPosition, i = t.barYPosition, a = t.goalX, s = t.goalY, r = t.barWidth, n = t.barHeight,
o = new Mi(this.barCtx.ctx), l = o.group({className: "apexcharts-bar-goals-groups"});
l.node.classList.add("apexcharts-element-hidden"), this.barCtx.w.globals.delayedElements.push({el: l.node}), l.attr("clip-path", "url(#gridRectMarkerMask".concat(this.barCtx.w.globals.cuid, ")"));
var h = null;
return this.barCtx.isHorizontal ? Array.isArray(a) && a.forEach((function (t) {
if (t.x >= -1 && t.x <= o.w.globals.gridWidth + 1) {
var e = void 0 !== t.attrs.strokeHeight ? t.attrs.strokeHeight : n / 2, a = i + e + n / 2;
h = o.drawLine(t.x, a - 2 * e, t.x, a, t.attrs.strokeColor ? t.attrs.strokeColor : void 0, t.attrs.strokeDashArray, t.attrs.strokeWidth ? t.attrs.strokeWidth : 2, t.attrs.strokeLineCap), l.add(h)
}
})) : Array.isArray(s) && s.forEach((function (t) {
if (t.y >= -1 && t.y <= o.w.globals.gridHeight + 1) {
var i = void 0 !== t.attrs.strokeWidth ? t.attrs.strokeWidth : r / 2, a = e + i + r / 2;
h = o.drawLine(a - 2 * i, t.y, a, t.y, t.attrs.strokeColor ? t.attrs.strokeColor : void 0, t.attrs.strokeDashArray, t.attrs.strokeHeight ? t.attrs.strokeHeight : 2, t.attrs.strokeLineCap), l.add(h)
}
})), l
}
}, {
key: "drawBarShadow", value: function (t) {
var e = t.prevPaths, i = t.currPaths, a = t.color, s = this.w, r = e.x, n = e.x1, o = e.barYPosition,
l = i.x, h = i.x1, c = i.barYPosition, d = o + i.barHeight, u = new Mi(this.barCtx.ctx), g = new v,
p = u.move(n, d) + u.line(r, d) + u.line(l, c) + u.line(h, c) + u.line(n, d) + ("around" === s.config.plotOptions.bar.borderRadiusApplication || "both" === this.arrBorderRadius[realIndex][j] ? " Z" : " z");
return u.drawPath({
d: p,
fill: g.shadeColor(.5, v.rgb2hex(a)),
stroke: "none",
strokeWidth: 0,
fillOpacity: 1,
classes: "apexcharts-bar-shadow apexcharts-decoration-element"
})
}
}, {
key: "getZeroValueEncounters", value: function (t) {
var e, i = t.i, a = t.j, s = this.w, r = 0, n = 0;
return (s.config.plotOptions.bar.horizontal ? s.globals.series.map((function (t, e) {
return e
})) : (null === (e = s.globals.columnSeries) || void 0 === e ? void 0 : e.i.map((function (t) {
return t
}))) || []).forEach((function (t) {
var e = s.globals.seriesPercent[t][a];
e && r++, t < i && 0 === e && n++
})), {nonZeroColumns: r, zeroEncounters: n}
}
}, {
key: "getGroupIndex", value: function (t) {
var e = this.w, i = e.globals.seriesGroups.findIndex((function (i) {
return i.indexOf(e.globals.seriesNames[t]) > -1
})), a = this.barCtx.columnGroupIndices, s = a.indexOf(i);
return s < 0 && (a.push(i), s = a.length - 1), {groupIndex: i, columnGroupIndex: s}
}
}]), t
}(), Ia = function () {
function t(e, a) {
i(this, t), this.ctx = e, this.w = e.w;
var s = this.w;
this.barOptions = s.config.plotOptions.bar, this.isHorizontal = this.barOptions.horizontal, this.strokeWidth = s.config.stroke.width, this.isNullValue = !1, this.isRangeBar = s.globals.seriesRange.length && this.isHorizontal, this.isVerticalGroupedRangeBar = !s.globals.isBarHorizontal && s.globals.seriesRange.length && s.config.plotOptions.bar.rangeBarGroupRows, this.isFunnel = this.barOptions.isFunnel, this.xyRatios = a, null !== this.xyRatios && (this.xRatio = a.xRatio, this.yRatio = a.yRatio, this.invertedXRatio = a.invertedXRatio, this.invertedYRatio = a.invertedYRatio, this.baseLineY = a.baseLineY, this.baseLineInvertedY = a.baseLineInvertedY), this.yaxisIndex = 0, this.translationsIndex = 0, this.seriesLen = 0, this.pathArr = [];
var r = new $i(this.ctx);
this.lastActiveBarSerieIndex = r.getActiveConfigSeriesIndex("desc", ["bar", "column"]), this.columnGroupIndices = [];
var n = r.getBarSeriesIndices(), o = new Pi(this.ctx);
this.stackedSeriesTotals = o.getStackedSeriesTotals(this.w.config.series.map((function (t, e) {
return -1 === n.indexOf(e) ? e : -1
})).filter((function (t) {
return -1 !== t
}))), this.barHelpers = new Pa(this)
}
return s(t, [{
key: "draw", value: function (t, e) {
var i = this.w, a = new Mi(this.ctx), s = new Pi(this.ctx, i);
t = s.getLogSeries(t), this.series = t, this.yRatio = s.getLogYRatios(this.yRatio), this.barHelpers.initVariables(t);
var r = a.group({class: "apexcharts-bar-series apexcharts-plot-series"});
i.config.dataLabels.enabled && this.totalItems > this.barOptions.dataLabels.maxItems && console.warn("WARNING: DataLabels are enabled but there are too many to display. This may cause performance issue when rendering - ApexCharts");
for (var n = 0, o = 0; n < t.length; n++, o++) {
var l, h, c, d, g = void 0, p = void 0, f = [], x = [], b = i.globals.comboCharts ? e[n] : n,
m = this.barHelpers.getGroupIndex(b).columnGroupIndex, y = a.group({
class: "apexcharts-series",
rel: n + 1,
seriesName: v.escapeString(i.globals.seriesNames[b]),
"data:realIndex": b
});
this.ctx.series.addCollapsedClassToSeries(y, b), t[n].length > 0 && (this.visibleI = this.visibleI + 1);
var w = 0, k = 0;
this.yRatio.length > 1 && (this.yaxisIndex = i.globals.seriesYAxisReverseMap[b], this.translationsIndex = b);
var A = this.translationsIndex;
this.isReversed = i.config.yaxis[this.yaxisIndex] && i.config.yaxis[this.yaxisIndex].reversed;
var C = this.barHelpers.initialPositions(b);
p = C.y, w = C.barHeight, h = C.yDivision, d = C.zeroW, g = C.x, k = C.barWidth, l = C.xDivision, c = C.zeroH, this.isHorizontal || x.push(g + k / 2);
var S = a.group({class: "apexcharts-datalabels", "data:realIndex": b});
i.globals.delayedElements.push({el: S.node}), S.node.classList.add("apexcharts-element-hidden");
var L = a.group({class: "apexcharts-bar-goals-markers"}),
M = a.group({class: "apexcharts-bar-shadows"});
i.globals.delayedElements.push({el: M.node}), M.node.classList.add("apexcharts-element-hidden");
for (var P = 0; P < t[n].length; P++) {
var I = this.barHelpers.getStrokeWidth(n, P, b), T = null, z = {
indexes: {i: n, j: P, realIndex: b, translationsIndex: A, bc: o},
x: g,
y: p,
strokeWidth: I,
elSeries: y
};
this.isHorizontal ? (T = this.drawBarPaths(u(u({}, z), {}, {
barHeight: w,
zeroW: d,
yDivision: h
})), k = this.series[n][P] / this.invertedYRatio) : (T = this.drawColumnPaths(u(u({}, z), {}, {
xDivision: l,
barWidth: k,
zeroH: c
})), w = this.series[n][P] / this.yRatio[A]);
var X = this.barHelpers.getPathFillColor(t, n, P, b);
if (this.isFunnel && this.barOptions.isFunnel3d && this.pathArr.length && P > 0) {
var R, E = this.barHelpers.drawBarShadow({
color: "string" == typeof X.color && -1 === (null === (R = X.color) || void 0 === R ? void 0 : R.indexOf("url")) ? X.color : v.hexToRgba(i.globals.colors[n]),
prevPaths: this.pathArr[this.pathArr.length - 1],
currPaths: T
});
if (M.add(E), i.config.chart.dropShadow.enabled) new Li(this.ctx).dropShadow(E, i.config.chart.dropShadow, b)
}
this.pathArr.push(T);
var Y = this.barHelpers.drawGoalLine({
barXPosition: T.barXPosition,
barYPosition: T.barYPosition,
goalX: T.goalX,
goalY: T.goalY,
barHeight: w,
barWidth: k
});
Y && L.add(Y), p = T.y, g = T.x, P > 0 && x.push(g + k / 2), f.push(p), this.renderSeries(u(u({
realIndex: b,
pathFill: X.color
}, X.useRangeColor ? {lineFill: X.color} : {}), {}, {
j: P,
i: n,
columnGroupIndex: m,
pathFrom: T.pathFrom,
pathTo: T.pathTo,
strokeWidth: I,
elSeries: y,
x: g,
y: p,
series: t,
barHeight: Math.abs(T.barHeight ? T.barHeight : w),
barWidth: Math.abs(T.barWidth ? T.barWidth : k),
elDataLabelsWrap: S,
elGoalsMarkers: L,
elBarShadows: M,
visibleSeries: this.visibleI,
type: "bar"
}))
}
i.globals.seriesXvalues[b] = x, i.globals.seriesYvalues[b] = f, r.add(y)
}
return r
}
}, {
key: "renderSeries", value: function (t) {
var e = t.realIndex, i = t.pathFill, a = t.lineFill, s = t.j, r = t.i, n = t.columnGroupIndex,
o = t.pathFrom, l = t.pathTo, h = t.strokeWidth, c = t.elSeries, d = t.x, u = t.y, g = t.y1,
p = t.y2, f = t.series, x = t.barHeight, b = t.barWidth, m = t.barXPosition, v = t.barYPosition,
y = t.elDataLabelsWrap, w = t.elGoalsMarkers, k = t.elBarShadows, A = t.visibleSeries, C = t.type,
S = t.classes, L = this.w, M = new Mi(this.ctx), P = !1;
if (!a) {
var I = "function" == typeof L.globals.stroke.colors[e] ? function (t) {
var e, i = L.config.stroke.colors;
return Array.isArray(i) && i.length > 0 && ((e = i[t]) || (e = ""), "function" == typeof e) ? e({
value: L.globals.series[t][s],
dataPointIndex: s,
w: L
}) : e
}(e) : L.globals.stroke.colors[e];
a = this.barOptions.distributed ? L.globals.stroke.colors[s] : I
}
var T = new Ma(this).handleBarDataLabels({
x: d,
y: u,
y1: g,
y2: p,
i: r,
j: s,
series: f,
realIndex: e,
columnGroupIndex: n,
barHeight: x,
barWidth: b,
barXPosition: m,
barYPosition: v,
visibleSeries: A
});
L.globals.isBarHorizontal || (T.dataLabelsPos.dataLabelsX + Math.max(b, L.globals.barPadForNumericAxis) < 0 || T.dataLabelsPos.dataLabelsX - Math.max(b, L.globals.barPadForNumericAxis) > L.globals.gridWidth) && (P = !0), L.config.series[r].data[s] && L.config.series[r].data[s].strokeColor && (a = L.config.series[r].data[s].strokeColor), this.isNullValue && (i = "none");
var z = s / L.config.chart.animations.animateGradually.delay * (L.config.chart.animations.speed / L.globals.dataPoints) / 2.4;
if (!P) {
var X = M.renderPaths({
i: r,
j: s,
realIndex: e,
pathFrom: o,
pathTo: l,
stroke: a,
strokeWidth: h,
strokeLineCap: L.config.stroke.lineCap,
fill: i,
animationDelay: z,
initialSpeed: L.config.chart.animations.speed,
dataChangeSpeed: L.config.chart.animations.dynamicAnimation.speed,
className: "apexcharts-".concat(C, "-area ").concat(S),
chartType: C
});
X.attr("clip-path", "url(#gridRectBarMask".concat(L.globals.cuid, ")"));
var R = L.config.forecastDataPoints;
R.count > 0 && s >= L.globals.dataPoints - R.count && (X.node.setAttribute("stroke-dasharray", R.dashArray), X.node.setAttribute("stroke-width", R.strokeWidth), X.node.setAttribute("fill-opacity", R.fillOpacity)), void 0 !== g && void 0 !== p && (X.attr("data-range-y1", g), X.attr("data-range-y2", p)), new Li(this.ctx).setSelectionFilter(X, e, s), c.add(X), X.attr({
cy: T.dataLabelsPos.bcy,
cx: T.dataLabelsPos.bcx,
j: s,
val: L.globals.series[r][s],
barHeight: x,
barWidth: b
}), null !== T.dataLabels && y.add(T.dataLabels), T.totalDataLabels && y.add(T.totalDataLabels), c.add(y), w && c.add(w), k && c.add(k)
}
return c
}
}, {
key: "drawBarPaths", value: function (t) {
var e, i = t.indexes, a = t.barHeight, s = t.strokeWidth, r = t.zeroW, n = t.x, o = t.y,
l = t.yDivision, h = t.elSeries, c = this.w, d = i.i, u = i.j;
if (c.globals.isXNumeric) e = (o = (c.globals.seriesX[d][u] - c.globals.minX) / this.invertedXRatio - a) + a * this.visibleI; else if (c.config.plotOptions.bar.hideZeroBarsWhenGrouped) {
var g = this.barHelpers.getZeroValueEncounters({i: d, j: u}), p = g.nonZeroColumns,
f = g.zeroEncounters;
p > 0 && (a = this.seriesLen * a / p), e = o + a * this.visibleI, e -= a * f
} else e = o + a * this.visibleI;
this.isFunnel && (r -= (this.barHelpers.getXForValue(this.series[d][u], r) - r) / 2), n = this.barHelpers.getXForValue(this.series[d][u], r);
var x = this.barHelpers.getBarpaths({
barYPosition: e,
barHeight: a,
x1: r,
x2: n,
strokeWidth: s,
isReversed: this.isReversed,
series: this.series,
realIndex: i.realIndex,
i: d,
j: u,
w: c
});
return c.globals.isXNumeric || (o += l), this.barHelpers.barBackground({
j: u,
i: d,
y1: e - a * this.visibleI,
y2: a * this.seriesLen,
elSeries: h
}), {
pathTo: x.pathTo,
pathFrom: x.pathFrom,
x1: r,
x: n,
y: o,
goalX: this.barHelpers.getGoalValues("x", r, null, d, u),
barYPosition: e,
barHeight: a
}
}
}, {
key: "drawColumnPaths", value: function (t) {
var e, i = t.indexes, a = t.x, s = t.y, r = t.xDivision, n = t.barWidth, o = t.zeroH, l = t.strokeWidth,
h = t.elSeries, c = this.w, d = i.realIndex, u = i.translationsIndex, g = i.i, p = i.j, f = i.bc;
if (c.globals.isXNumeric) {
var x = this.getBarXForNumericXAxis({x: a, j: p, realIndex: d, barWidth: n});
a = x.x, e = x.barXPosition
} else if (c.config.plotOptions.bar.hideZeroBarsWhenGrouped) {
var b = this.barHelpers.getZeroValueEncounters({i: g, j: p}), m = b.nonZeroColumns,
v = b.zeroEncounters;
m > 0 && (n = this.seriesLen * n / m), e = a + n * this.visibleI, e -= n * v
} else e = a + n * this.visibleI;
s = this.barHelpers.getYForValue(this.series[g][p], o, u);
var y = this.barHelpers.getColumnPaths({
barXPosition: e,
barWidth: n,
y1: o,
y2: s,
strokeWidth: l,
isReversed: this.isReversed,
series: this.series,
realIndex: d,
i: g,
j: p,
w: c
});
return c.globals.isXNumeric || (a += r), this.barHelpers.barBackground({
bc: f,
j: p,
i: g,
x1: e - l / 2 - n * this.visibleI,
x2: n * this.seriesLen + l / 2,
elSeries: h
}), {
pathTo: y.pathTo,
pathFrom: y.pathFrom,
x: a,
y: s,
goalY: this.barHelpers.getGoalValues("y", null, o, g, p, u),
barXPosition: e,
barWidth: n
}
}
}, {
key: "getBarXForNumericXAxis", value: function (t) {
var e = t.x, i = t.barWidth, a = t.realIndex, s = t.j, r = this.w, n = a;
return r.globals.seriesX[a].length || (n = r.globals.maxValsInArrayIndex), v.isNumber(r.globals.seriesX[n][s]) && (e = (r.globals.seriesX[n][s] - r.globals.minX) / this.xRatio - i * this.seriesLen / 2), {
barXPosition: e + i * this.visibleI,
x: e
}
}
}, {
key: "getPreviousPath", value: function (t, e) {
for (var i = this.w, a = "M 0 0", s = 0; s < i.globals.previousPaths.length; s++) {
var r = i.globals.previousPaths[s];
r.paths && r.paths.length > 0 && parseInt(r.realIndex, 10) === parseInt(t, 10) && void 0 !== i.globals.previousPaths[s].paths[e] && (a = i.globals.previousPaths[s].paths[e].d)
}
return a
}
}]), t
}(), Ta = function (t) {
h(a, t);
var e = n(a);
function a() {
return i(this, a), e.apply(this, arguments)
}
return s(a, [{
key: "draw", value: function (t, e) {
var i = this, a = this.w;
this.graphics = new Mi(this.ctx), this.bar = new Ia(this.ctx, this.xyRatios);
var s = new Pi(this.ctx, a);
t = s.getLogSeries(t), this.yRatio = s.getLogYRatios(this.yRatio), this.barHelpers.initVariables(t), "100%" === a.config.chart.stackType && (t = a.globals.comboCharts ? e.map((function (t) {
return a.globals.seriesPercent[t]
})) : a.globals.seriesPercent.slice()), this.series = t, this.barHelpers.initializeStackedPrevVars(this);
for (var r = this.graphics.group({class: "apexcharts-bar-series apexcharts-plot-series"}), n = 0, o = 0, l = function (s, l) {
var h = void 0, c = void 0, d = void 0, g = void 0, p = a.globals.comboCharts ? e[s] : s,
f = i.barHelpers.getGroupIndex(p), x = f.groupIndex, b = f.columnGroupIndex;
i.groupCtx = i[a.globals.seriesGroups[x]];
var m = [], y = [], w = 0;
i.yRatio.length > 1 && (i.yaxisIndex = a.globals.seriesYAxisReverseMap[p][0], w = p), i.isReversed = a.config.yaxis[i.yaxisIndex] && a.config.yaxis[i.yaxisIndex].reversed;
var k = i.graphics.group({
class: "apexcharts-series",
seriesName: v.escapeString(a.globals.seriesNames[p]),
rel: s + 1,
"data:realIndex": p
});
i.ctx.series.addCollapsedClassToSeries(k, p);
var A = i.graphics.group({class: "apexcharts-datalabels", "data:realIndex": p}),
C = i.graphics.group({class: "apexcharts-bar-goals-markers"}), S = 0, L = 0,
M = i.initialPositions(n, o, h, c, d, g, w);
o = M.y, S = M.barHeight, c = M.yDivision, g = M.zeroW, n = M.x, L = M.barWidth, h = M.xDivision, d = M.zeroH, a.globals.barHeight = S, a.globals.barWidth = L, i.barHelpers.initializeStackedXYVars(i), 1 === i.groupCtx.prevY.length && i.groupCtx.prevY[0].every((function (t) {
return isNaN(t)
})) && (i.groupCtx.prevY[0] = i.groupCtx.prevY[0].map((function () {
return d
})), i.groupCtx.prevYF[0] = i.groupCtx.prevYF[0].map((function () {
return 0
})));
for (var P = 0; P < a.globals.dataPoints; P++) {
var I = i.barHelpers.getStrokeWidth(s, P, p), T = {
indexes: {i: s, j: P, realIndex: p, translationsIndex: w, bc: l},
strokeWidth: I,
x: n,
y: o,
elSeries: k,
columnGroupIndex: b,
seriesGroup: a.globals.seriesGroups[x]
}, z = null;
i.isHorizontal ? (z = i.drawStackedBarPaths(u(u({}, T), {}, {
zeroW: g,
barHeight: S,
yDivision: c
})), L = i.series[s][P] / i.invertedYRatio) : (z = i.drawStackedColumnPaths(u(u({}, T), {}, {
xDivision: h,
barWidth: L,
zeroH: d
})), S = i.series[s][P] / i.yRatio[w]);
var X = i.barHelpers.drawGoalLine({
barXPosition: z.barXPosition,
barYPosition: z.barYPosition,
goalX: z.goalX,
goalY: z.goalY,
barHeight: S,
barWidth: L
});
X && C.add(X), o = z.y, n = z.x, m.push(n), y.push(o);
var R = i.barHelpers.getPathFillColor(t, s, P, p), E = "",
Y = a.globals.isBarHorizontal ? "apexcharts-flip-x" : "apexcharts-flip-y";
("bottom" === i.barHelpers.arrBorderRadius[p][P] && a.globals.series[p][P] > 0 || "top" === i.barHelpers.arrBorderRadius[p][P] && a.globals.series[p][P] < 0) && (E = Y), k = i.renderSeries(u(u({
realIndex: p,
pathFill: R.color
}, R.useRangeColor ? {lineFill: R.color} : {}), {}, {
j: P,
i: s,
columnGroupIndex: b,
pathFrom: z.pathFrom,
pathTo: z.pathTo,
strokeWidth: I,
elSeries: k,
x: n,
y: o,
series: t,
barHeight: S,
barWidth: L,
elDataLabelsWrap: A,
elGoalsMarkers: C,
type: "bar",
visibleSeries: b,
classes: E
}))
}
a.globals.seriesXvalues[p] = m, a.globals.seriesYvalues[p] = y, i.groupCtx.prevY.push(i.groupCtx.yArrj), i.groupCtx.prevYF.push(i.groupCtx.yArrjF), i.groupCtx.prevYVal.push(i.groupCtx.yArrjVal), i.groupCtx.prevX.push(i.groupCtx.xArrj), i.groupCtx.prevXF.push(i.groupCtx.xArrjF), i.groupCtx.prevXVal.push(i.groupCtx.xArrjVal), r.add(k)
}, h = 0, c = 0; h < t.length; h++, c++) l(h, c);
return r
}
}, {
key: "initialPositions", value: function (t, e, i, a, s, r, n) {
var o, l, h = this.w;
if (this.isHorizontal) {
a = h.globals.gridHeight / h.globals.dataPoints;
var c = h.config.plotOptions.bar.barHeight;
o = -1 === String(c).indexOf("%") ? parseInt(c, 10) : a * parseInt(c, 10) / 100, r = h.globals.padHorizontal + (this.isReversed ? h.globals.gridWidth - this.baseLineInvertedY : this.baseLineInvertedY), e = (a - o) / 2
} else {
l = i = h.globals.gridWidth / h.globals.dataPoints;
var d = h.config.plotOptions.bar.columnWidth;
h.globals.isXNumeric && h.globals.dataPoints > 1 ? l = (i = h.globals.minXDiff / this.xRatio) * parseInt(this.barOptions.columnWidth, 10) / 100 : -1 === String(d).indexOf("%") ? l = parseInt(d, 10) : l *= parseInt(d, 10) / 100, s = this.isReversed ? this.baseLineY[n] : h.globals.gridHeight - this.baseLineY[n], t = h.globals.padHorizontal + (i - l) / 2
}
var u = h.globals.barGroups.length || 1;
return {x: t, y: e, yDivision: a, xDivision: i, barHeight: o / u, barWidth: l / u, zeroH: s, zeroW: r}
}
}, {
key: "drawStackedBarPaths", value: function (t) {
for (var e, i = t.indexes, a = t.barHeight, s = t.strokeWidth, r = t.zeroW, n = t.x, o = t.y, l = t.columnGroupIndex, h = t.seriesGroup, c = t.yDivision, d = t.elSeries, u = this.w, g = o + l * a, p = i.i, f = i.j, x = i.realIndex, b = i.translationsIndex, m = 0, v = 0; v < this.groupCtx.prevXF.length; v++) m += this.groupCtx.prevXF[v][f];
var y = p;
if (u.config.series[x].name && (y = h.indexOf(u.config.series[x].name)), y > 0) {
var w = r;
this.groupCtx.prevXVal[y - 1][f] < 0 ? w = this.series[p][f] >= 0 ? this.groupCtx.prevX[y - 1][f] + m - 2 * (this.isReversed ? m : 0) : this.groupCtx.prevX[y - 1][f] : this.groupCtx.prevXVal[y - 1][f] >= 0 && (w = this.series[p][f] >= 0 ? this.groupCtx.prevX[y - 1][f] : this.groupCtx.prevX[y - 1][f] - m + 2 * (this.isReversed ? m : 0)), e = w
} else e = r;
n = null === this.series[p][f] ? e : e + this.series[p][f] / this.invertedYRatio - 2 * (this.isReversed ? this.series[p][f] / this.invertedYRatio : 0);
var k = this.barHelpers.getBarpaths({
barYPosition: g,
barHeight: a,
x1: e,
x2: n,
strokeWidth: s,
isReversed: this.isReversed,
series: this.series,
realIndex: i.realIndex,
seriesGroup: h,
i: p,
j: f,
w: u
});
return this.barHelpers.barBackground({
j: f,
i: p,
y1: g,
y2: a,
elSeries: d
}), o += c, {
pathTo: k.pathTo,
pathFrom: k.pathFrom,
goalX: this.barHelpers.getGoalValues("x", r, null, p, f, b),
barXPosition: e,
barYPosition: g,
x: n,
y: o
}
}
}, {
key: "drawStackedColumnPaths", value: function (t) {
var e = t.indexes, i = t.x, a = t.y, s = t.xDivision, r = t.barWidth, n = t.zeroH,
o = t.columnGroupIndex, l = t.seriesGroup, h = t.elSeries, c = this.w, d = e.i, u = e.j, g = e.bc,
p = e.realIndex, f = e.translationsIndex;
if (c.globals.isXNumeric) {
var x = c.globals.seriesX[p][u];
x || (x = 0), i = (x - c.globals.minX) / this.xRatio - r / 2 * c.globals.barGroups.length
}
for (var b, m = i + o * r, v = 0, y = 0; y < this.groupCtx.prevYF.length; y++) v += isNaN(this.groupCtx.prevYF[y][u]) ? 0 : this.groupCtx.prevYF[y][u];
var w = d;
if (l && (w = l.indexOf(c.globals.seriesNames[p])), w > 0 && !c.globals.isXNumeric || w > 0 && c.globals.isXNumeric && c.globals.seriesX[p - 1][u] === c.globals.seriesX[p][u]) {
var k, A, C, S = Math.min(this.yRatio.length + 1, p + 1);
if (void 0 !== this.groupCtx.prevY[w - 1] && this.groupCtx.prevY[w - 1].length) for (var L = 1; L < S; L++) {
var M;
if (!isNaN(null === (M = this.groupCtx.prevY[w - L]) || void 0 === M ? void 0 : M[u])) {
C = this.groupCtx.prevY[w - L][u];
break
}
}
for (var P = 1; P < S; P++) {
var I, T;
if ((null === (I = this.groupCtx.prevYVal[w - P]) || void 0 === I ? void 0 : I[u]) < 0) {
A = this.series[d][u] >= 0 ? C - v + 2 * (this.isReversed ? v : 0) : C;
break
}
if ((null === (T = this.groupCtx.prevYVal[w - P]) || void 0 === T ? void 0 : T[u]) >= 0) {
A = this.series[d][u] >= 0 ? C : C + v - 2 * (this.isReversed ? v : 0);
break
}
}
void 0 === A && (A = c.globals.gridHeight), b = null !== (k = this.groupCtx.prevYF[0]) && void 0 !== k && k.every((function (t) {
return 0 === t
})) && this.groupCtx.prevYF.slice(1, w).every((function (t) {
return t.every((function (t) {
return isNaN(t)
}))
})) ? n : A
} else b = n;
a = this.series[d][u] ? b - this.series[d][u] / this.yRatio[f] + 2 * (this.isReversed ? this.series[d][u] / this.yRatio[f] : 0) : b;
var z = this.barHelpers.getColumnPaths({
barXPosition: m,
barWidth: r,
y1: b,
y2: a,
yRatio: this.yRatio[f],
strokeWidth: this.strokeWidth,
isReversed: this.isReversed,
series: this.series,
seriesGroup: l,
realIndex: e.realIndex,
i: d,
j: u,
w: c
});
return this.barHelpers.barBackground({bc: g, j: u, i: d, x1: m, x2: r, elSeries: h}), {
pathTo: z.pathTo,
pathFrom: z.pathFrom,
goalY: this.barHelpers.getGoalValues("y", null, n, d, u),
barXPosition: m,
x: c.globals.isXNumeric ? i : i + s,
y: a
}
}
}]), a
}(Ia), za = function (t) {
h(a, t);
var e = n(a);
function a() {
return i(this, a), e.apply(this, arguments)
}
return s(a, [{
key: "draw", value: function (t, e, i) {
var a = this, s = this.w, r = new Mi(this.ctx), n = s.globals.comboCharts ? e : s.config.chart.type,
o = new ji(this.ctx);
this.candlestickOptions = this.w.config.plotOptions.candlestick, this.boxOptions = this.w.config.plotOptions.boxPlot, this.isHorizontal = s.config.plotOptions.bar.horizontal, this.isOHLC = this.candlestickOptions && "ohlc" === this.candlestickOptions.type;
var l = new Pi(this.ctx, s);
t = l.getLogSeries(t), this.series = t, this.yRatio = l.getLogYRatios(this.yRatio), this.barHelpers.initVariables(t);
for (var h = r.group({class: "apexcharts-".concat(n, "-series apexcharts-plot-series")}), c = function (e) {
a.isBoxPlot = "boxPlot" === s.config.chart.type || "boxPlot" === s.config.series[e].type;
var n, l, c, d, g = void 0, p = void 0, f = [], x = [], b = s.globals.comboCharts ? i[e] : e,
m = a.barHelpers.getGroupIndex(b).columnGroupIndex, y = r.group({
class: "apexcharts-series",
seriesName: v.escapeString(s.globals.seriesNames[b]),
rel: e + 1,
"data:realIndex": b
});
a.ctx.series.addCollapsedClassToSeries(y, b), t[e].length > 0 && (a.visibleI = a.visibleI + 1);
var w, k, A = 0;
a.yRatio.length > 1 && (a.yaxisIndex = s.globals.seriesYAxisReverseMap[b][0], A = b);
var C = a.barHelpers.initialPositions(b);
p = C.y, w = C.barHeight, l = C.yDivision, d = C.zeroW, g = C.x, k = C.barWidth, n = C.xDivision, c = C.zeroH, x.push(g + k / 2);
for (var S = r.group({
class: "apexcharts-datalabels",
"data:realIndex": b
}), L = r.group({class: "apexcharts-bar-goals-markers"}), M = function (i) {
var r = a.barHelpers.getStrokeWidth(e, i, b), h = null, v = {
indexes: {i: e, j: i, realIndex: b, translationsIndex: A},
x: g,
y: p,
strokeWidth: r,
elSeries: y
};
h = a.isHorizontal ? a.drawHorizontalBoxPaths(u(u({}, v), {}, {
yDivision: l,
barHeight: w,
zeroW: d
})) : a.drawVerticalBoxPaths(u(u({}, v), {}, {
xDivision: n,
barWidth: k,
zeroH: c
})), p = h.y, g = h.x;
var C = a.barHelpers.drawGoalLine({
barXPosition: h.barXPosition,
barYPosition: h.barYPosition,
goalX: h.goalX,
goalY: h.goalY,
barHeight: w,
barWidth: k
});
C && L.add(C), i > 0 && x.push(g + k / 2), f.push(p), h.pathTo.forEach((function (n, l) {
var c = !a.isBoxPlot && a.candlestickOptions.wick.useFillColor ? h.color[l] : s.globals.stroke.colors[e],
d = o.fillPath({seriesNumber: b, dataPointIndex: i, color: h.color[l], value: t[e][i]});
a.renderSeries({
realIndex: b,
pathFill: d,
lineFill: c,
j: i,
i: e,
pathFrom: h.pathFrom,
pathTo: n,
strokeWidth: r,
elSeries: y,
x: g,
y: p,
series: t,
columnGroupIndex: m,
barHeight: w,
barWidth: k,
elDataLabelsWrap: S,
elGoalsMarkers: L,
visibleSeries: a.visibleI,
type: s.config.chart.type
})
}))
}, P = 0; P < s.globals.dataPoints; P++) M(P);
s.globals.seriesXvalues[b] = x, s.globals.seriesYvalues[b] = f, h.add(y)
}, d = 0; d < t.length; d++) c(d);
return h
}
}, {
key: "drawVerticalBoxPaths", value: function (t) {
var e = t.indexes, i = t.x;
t.y;
var a = t.xDivision, s = t.barWidth, r = t.zeroH, n = t.strokeWidth, o = this.w, l = new Mi(this.ctx),
h = e.i, c = e.j, d = o.config.plotOptions.candlestick.colors, u = this.boxOptions.colors,
g = e.realIndex, p = function (t) {
return Array.isArray(t) ? t[g] : t
}, f = p(d.upward), x = p(d.downward), b = this.yRatio[e.translationsIndex],
m = this.getOHLCValue(g, c), v = r, y = r, w = m.o < m.c ? [f] : [x];
this.isBoxPlot && (w = [p(u.lower), p(u.upper)]);
var k = Math.min(m.o, m.c), A = Math.max(m.o, m.c), C = m.m;
o.globals.isXNumeric && (i = (o.globals.seriesX[g][c] - o.globals.minX) / this.xRatio - s / 2);
var S = i + s * this.visibleI;
void 0 === this.series[h][c] || null === this.series[h][c] ? (k = r, A = r) : (k = r - k / b, A = r - A / b, v = r - m.h / b, y = r - m.l / b, C = r - m.m / b);
var L = l.move(S, r), M = l.move(S + s / 2, k);
if (o.globals.previousPaths.length > 0 && (M = this.getPreviousPath(g, c, !0)), this.isOHLC) {
var P = S + s / 2, I = r - m.o / b, T = r - m.c / b;
L = [l.move(P, v) + l.line(P, y) + l.move(P, I) + l.line(S, I) + l.move(P, T) + l.line(S + s, T)]
} else L = this.isBoxPlot ? [l.move(S, k) + l.line(S + s / 2, k) + l.line(S + s / 2, v) + l.line(S + s / 4, v) + l.line(S + s - s / 4, v) + l.line(S + s / 2, v) + l.line(S + s / 2, k) + l.line(S + s, k) + l.line(S + s, C) + l.line(S, C) + l.line(S, k + n / 2), l.move(S, C) + l.line(S + s, C) + l.line(S + s, A) + l.line(S + s / 2, A) + l.line(S + s / 2, y) + l.line(S + s - s / 4, y) + l.line(S + s / 4, y) + l.line(S + s / 2, y) + l.line(S + s / 2, A) + l.line(S, A) + l.line(S, C) + "z"] : [l.move(S, A) + l.line(S + s / 2, A) + l.line(S + s / 2, v) + l.line(S + s / 2, A) + l.line(S + s, A) + l.line(S + s, k) + l.line(S + s / 2, k) + l.line(S + s / 2, y) + l.line(S + s / 2, k) + l.line(S, k) + l.line(S, A - n / 2)];
return M += l.move(S, k), o.globals.isXNumeric || (i += a), {
pathTo: L,
pathFrom: M,
x: i,
y: A,
goalY: this.barHelpers.getGoalValues("y", null, r, h, c, e.translationsIndex),
barXPosition: S,
color: w
}
}
}, {
key: "drawHorizontalBoxPaths", value: function (t) {
var e = t.indexes;
t.x;
var i = t.y, a = t.yDivision, s = t.barHeight, r = t.zeroW, n = t.strokeWidth, o = this.w,
l = new Mi(this.ctx), h = e.i, c = e.j, d = this.boxOptions.colors.lower;
this.isBoxPlot && (d = [this.boxOptions.colors.lower, this.boxOptions.colors.upper]);
var u = this.invertedYRatio, g = e.realIndex, p = this.getOHLCValue(g, c), f = r, x = r,
b = Math.min(p.o, p.c), m = Math.max(p.o, p.c), v = p.m;
o.globals.isXNumeric && (i = (o.globals.seriesX[g][c] - o.globals.minX) / this.invertedXRatio - s / 2);
var y = i + s * this.visibleI;
void 0 === this.series[h][c] || null === this.series[h][c] ? (b = r, m = r) : (b = r + b / u, m = r + m / u, f = r + p.h / u, x = r + p.l / u, v = r + p.m / u);
var w = l.move(r, y), k = l.move(b, y + s / 2);
return o.globals.previousPaths.length > 0 && (k = this.getPreviousPath(g, c, !0)), w = [l.move(b, y) + l.line(b, y + s / 2) + l.line(f, y + s / 2) + l.line(f, y + s / 2 - s / 4) + l.line(f, y + s / 2 + s / 4) + l.line(f, y + s / 2) + l.line(b, y + s / 2) + l.line(b, y + s) + l.line(v, y + s) + l.line(v, y) + l.line(b + n / 2, y), l.move(v, y) + l.line(v, y + s) + l.line(m, y + s) + l.line(m, y + s / 2) + l.line(x, y + s / 2) + l.line(x, y + s - s / 4) + l.line(x, y + s / 4) + l.line(x, y + s / 2) + l.line(m, y + s / 2) + l.line(m, y) + l.line(v, y) + "z"], k += l.move(b, y), o.globals.isXNumeric || (i += a), {
pathTo: w,
pathFrom: k,
x: m,
y: i,
goalX: this.barHelpers.getGoalValues("x", r, null, h, c),
barYPosition: y,
color: d
}
}
}, {
key: "getOHLCValue", value: function (t, e) {
var i = this.w, a = new Pi(this.ctx, i), s = a.getLogValAtSeriesIndex(i.globals.seriesCandleH[t][e], t),
r = a.getLogValAtSeriesIndex(i.globals.seriesCandleO[t][e], t),
n = a.getLogValAtSeriesIndex(i.globals.seriesCandleM[t][e], t),
o = a.getLogValAtSeriesIndex(i.globals.seriesCandleC[t][e], t),
l = a.getLogValAtSeriesIndex(i.globals.seriesCandleL[t][e], t);
return {
o: this.isBoxPlot ? s : r,
h: this.isBoxPlot ? r : s,
m: n,
l: this.isBoxPlot ? o : l,
c: this.isBoxPlot ? l : o
}
}
}]), a
}(Ia), Xa = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "checkColorRange", value: function () {
var t = this.w, e = !1, i = t.config.plotOptions[t.config.chart.type];
return i.colorScale.ranges.length > 0 && i.colorScale.ranges.map((function (t, i) {
t.from <= 0 && (e = !0)
})), e
}
}, {
key: "getShadeColor", value: function (t, e, i, a) {
var s = this.w, r = 1, n = s.config.plotOptions[t].shadeIntensity, o = this.determineColor(t, e, i);
s.globals.hasNegs || a ? r = s.config.plotOptions[t].reverseNegativeShade ? o.percent < 0 ? o.percent / 100 * (1.25 * n) : (1 - o.percent / 100) * (1.25 * n) : o.percent <= 0 ? 1 - (1 + o.percent / 100) * n : (1 - o.percent / 100) * n : (r = 1 - o.percent / 100, "treemap" === t && (r = (1 - o.percent / 100) * (1.25 * n)));
var l = o.color, h = new v;
if (s.config.plotOptions[t].enableShades) if ("dark" === this.w.config.theme.mode) {
var c = h.shadeColor(-1 * r, o.color);
l = v.hexToRgba(v.isColorHex(c) ? c : v.rgb2hex(c), s.config.fill.opacity)
} else {
var d = h.shadeColor(r, o.color);
l = v.hexToRgba(v.isColorHex(d) ? d : v.rgb2hex(d), s.config.fill.opacity)
}
return {color: l, colorProps: o}
}
}, {
key: "determineColor", value: function (t, e, i) {
var a = this.w, s = a.globals.series[e][i], r = a.config.plotOptions[t],
n = r.colorScale.inverse ? i : e;
r.distributed && "treemap" === a.config.chart.type && (n = i);
var o = a.globals.colors[n], l = null, h = Math.min.apply(Math, f(a.globals.series[e])),
c = Math.max.apply(Math, f(a.globals.series[e]));
r.distributed || "heatmap" !== t || (h = a.globals.minY, c = a.globals.maxY), void 0 !== r.colorScale.min && (h = r.colorScale.min < a.globals.minY ? r.colorScale.min : a.globals.minY, c = r.colorScale.max > a.globals.maxY ? r.colorScale.max : a.globals.maxY);
var d = Math.abs(c) + Math.abs(h), u = 100 * s / (0 === d ? d - 1e-6 : d);
r.colorScale.ranges.length > 0 && r.colorScale.ranges.map((function (t, e) {
if (s >= t.from && s <= t.to) {
o = t.color, l = t.foreColor ? t.foreColor : null, h = t.from, c = t.to;
var i = Math.abs(c) + Math.abs(h);
u = 100 * s / (0 === i ? i - 1e-6 : i)
}
}));
return {color: o, foreColor: l, percent: u}
}
}, {
key: "calculateDataLabels", value: function (t) {
var e = t.text, i = t.x, a = t.y, s = t.i, r = t.j, n = t.colorProps, o = t.fontSize,
l = this.w.config.dataLabels, h = new Mi(this.ctx), c = new qi(this.ctx), d = null;
if (l.enabled) {
d = h.group({class: "apexcharts-data-labels"});
var u = l.offsetX, g = l.offsetY, p = i + u, f = a + parseFloat(l.style.fontSize) / 3 + g;
c.plotDataLabelsText({
x: p,
y: f,
text: e,
i: s,
j: r,
color: n.foreColor,
parent: d,
fontSize: o,
dataLabelsConfig: l
})
}
return d
}
}, {
key: "addListeners", value: function (t) {
var e = new Mi(this.ctx);
t.node.addEventListener("mouseenter", e.pathMouseEnter.bind(this, t)), t.node.addEventListener("mouseleave", e.pathMouseLeave.bind(this, t)), t.node.addEventListener("mousedown", e.pathMouseDown.bind(this, t))
}
}]), t
}(), Ra = function () {
function t(e, a) {
i(this, t), this.ctx = e, this.w = e.w, this.xRatio = a.xRatio, this.yRatio = a.yRatio, this.dynamicAnim = this.w.config.chart.animations.dynamicAnimation, this.helpers = new Xa(e), this.rectRadius = this.w.config.plotOptions.heatmap.radius, this.strokeWidth = this.w.config.stroke.show ? this.w.config.stroke.width : 0
}
return s(t, [{
key: "draw", value: function (t) {
var e = this.w, i = new Mi(this.ctx), a = i.group({class: "apexcharts-heatmap"});
a.attr("clip-path", "url(#gridRectMask".concat(e.globals.cuid, ")"));
var s = e.globals.gridWidth / e.globals.dataPoints, r = e.globals.gridHeight / e.globals.series.length,
n = 0, o = !1;
this.negRange = this.helpers.checkColorRange();
var l = t.slice();
e.config.yaxis[0].reversed && (o = !0, l.reverse());
for (var h = o ? 0 : l.length - 1; o ? h < l.length : h >= 0; o ? h++ : h--) {
var c = i.group({
class: "apexcharts-series apexcharts-heatmap-series",
seriesName: v.escapeString(e.globals.seriesNames[h]),
rel: h + 1,
"data:realIndex": h
});
if (this.ctx.series.addCollapsedClassToSeries(c, h), e.config.chart.dropShadow.enabled) {
var d = e.config.chart.dropShadow;
new Li(this.ctx).dropShadow(c, d, h)
}
for (var u = 0, g = e.config.plotOptions.heatmap.shadeIntensity, p = 0, f = 0; f < e.globals.dataPoints; f++) if (e.globals.seriesX.length && !e.globals.allSeriesHasEqualX && e.globals.minX + e.globals.minXDiff * f < e.globals.seriesX[h][p]) u += s; else {
if (p >= l[h].length) break;
var x = this.helpers.getShadeColor(e.config.chart.type, h, p, this.negRange), b = x.color,
m = x.colorProps;
if ("image" === e.config.fill.type) b = new ji(this.ctx).fillPath({
seriesNumber: h,
dataPointIndex: p,
opacity: e.globals.hasNegs ? m.percent < 0 ? 1 - (1 + m.percent / 100) : g + m.percent / 100 : m.percent / 100,
patternID: v.randomId(),
width: e.config.fill.image.width ? e.config.fill.image.width : s,
height: e.config.fill.image.height ? e.config.fill.image.height : r
});
var y = this.rectRadius, w = i.drawRect(u, n, s, r, y);
if (w.attr({
cx: u,
cy: n
}), w.node.classList.add("apexcharts-heatmap-rect"), c.add(w), w.attr({
fill: b,
i: h,
index: h,
j: p,
val: t[h][p],
"stroke-width": this.strokeWidth,
stroke: e.config.plotOptions.heatmap.useFillColorAsStroke ? b : e.globals.stroke.colors[0],
color: b
}), this.helpers.addListeners(w), e.config.chart.animations.enabled && !e.globals.dataChanged) {
var k = 1;
e.globals.resized || (k = e.config.chart.animations.speed), this.animateHeatMap(w, u, n, s, r, k)
}
if (e.globals.dataChanged) {
var A = 1;
if (this.dynamicAnim.enabled && e.globals.shouldAnimate) {
A = this.dynamicAnim.speed;
var C = e.globals.previousPaths[h] && e.globals.previousPaths[h][p] && e.globals.previousPaths[h][p].color;
C || (C = "rgba(255, 255, 255, 0)"), this.animateHeatColor(w, v.isColorHex(C) ? C : v.rgb2hex(C), v.isColorHex(b) ? b : v.rgb2hex(b), A)
}
}
var S = (0, e.config.dataLabels.formatter)(e.globals.series[h][p], {
value: e.globals.series[h][p],
seriesIndex: h,
dataPointIndex: p,
w: e
}), L = this.helpers.calculateDataLabels({
text: S,
x: u + s / 2,
y: n + r / 2,
i: h,
j: p,
colorProps: m,
series: l
});
null !== L && c.add(L), u += s, p++
}
n += r, a.add(c)
}
var M = e.globals.yAxisScale[0].result.slice();
return e.config.yaxis[0].reversed ? M.unshift("") : M.push(""), e.globals.yAxisScale[0].result = M, a
}
}, {
key: "animateHeatMap", value: function (t, e, i, a, s, r) {
var n = new y(this.ctx);
n.animateRect(t, {x: e + a / 2, y: i + s / 2, width: 0, height: 0}, {
x: e,
y: i,
width: a,
height: s
}, r, (function () {
n.animationCompleted(t)
}))
}
}, {
key: "animateHeatColor", value: function (t, e, i, a) {
t.attr({fill: e}).animate(a).attr({fill: i})
}
}]), t
}(), Ea = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "drawYAxisTexts", value: function (t, e, i, a) {
var s = this.w, r = s.config.yaxis[0], n = s.globals.yLabelFormatters[0];
return new Mi(this.ctx).drawText({
x: t + r.labels.offsetX,
y: e + r.labels.offsetY,
text: n(a, i),
textAnchor: "middle",
fontSize: r.labels.style.fontSize,
fontFamily: r.labels.style.fontFamily,
foreColor: Array.isArray(r.labels.style.colors) ? r.labels.style.colors[i] : r.labels.style.colors
})
}
}]), t
}(), Ya = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w;
var a = this.w;
this.chartType = this.w.config.chart.type, this.initialAnim = this.w.config.chart.animations.enabled, this.dynamicAnim = this.initialAnim && this.w.config.chart.animations.dynamicAnimation.enabled, this.animBeginArr = [0], this.animDur = 0, this.donutDataLabels = this.w.config.plotOptions.pie.donut.labels, this.lineColorArr = void 0 !== a.globals.stroke.colors ? a.globals.stroke.colors : a.globals.colors, this.defaultSize = Math.min(a.globals.gridWidth, a.globals.gridHeight), this.centerY = this.defaultSize / 2, this.centerX = a.globals.gridWidth / 2, "radialBar" === a.config.chart.type ? this.fullAngle = 360 : this.fullAngle = Math.abs(a.config.plotOptions.pie.endAngle - a.config.plotOptions.pie.startAngle), this.initialAngle = a.config.plotOptions.pie.startAngle % this.fullAngle, a.globals.radialSize = this.defaultSize / 2.05 - a.config.stroke.width - (a.config.chart.sparkline.enabled ? 0 : a.config.chart.dropShadow.blur), this.donutSize = a.globals.radialSize * parseInt(a.config.plotOptions.pie.donut.size, 10) / 100;
var s = a.config.plotOptions.pie.customScale, r = a.globals.gridWidth / 2, n = a.globals.gridHeight / 2;
this.translateX = r - r * s, this.translateY = n - n * s, this.dataLabelsGroup = new Mi(this.ctx).group({
class: "apexcharts-datalabels-group",
transform: "translate(".concat(this.translateX, ", ").concat(this.translateY, ") scale(").concat(s, ")")
}), this.maxY = 0, this.sliceLabels = [], this.sliceSizes = [], this.prevSectorAngleArr = []
}
return s(t, [{
key: "draw", value: function (t) {
var e = this, i = this.w, a = new Mi(this.ctx), s = a.group({class: "apexcharts-pie"});
if (i.globals.noData) return s;
for (var r = 0, n = 0; n < t.length; n++) r += v.negToZero(t[n]);
var o = [], l = a.group();
0 === r && (r = 1e-5), t.forEach((function (t) {
e.maxY = Math.max(e.maxY, t)
})), i.config.yaxis[0].max && (this.maxY = i.config.yaxis[0].max), "back" === i.config.grid.position && "polarArea" === this.chartType && this.drawPolarElements(s);
for (var h = 0; h < t.length; h++) {
var c = this.fullAngle * v.negToZero(t[h]) / r;
o.push(c), "polarArea" === this.chartType ? (o[h] = this.fullAngle / t.length, this.sliceSizes.push(i.globals.radialSize * t[h] / this.maxY)) : this.sliceSizes.push(i.globals.radialSize)
}
if (i.globals.dataChanged) {
for (var d, u = 0, g = 0; g < i.globals.previousPaths.length; g++) u += v.negToZero(i.globals.previousPaths[g]);
for (var p = 0; p < i.globals.previousPaths.length; p++) d = this.fullAngle * v.negToZero(i.globals.previousPaths[p]) / u, this.prevSectorAngleArr.push(d)
}
if (this.donutSize < 0 && (this.donutSize = 0), "donut" === this.chartType) {
var f = a.drawCircle(this.donutSize);
f.attr({
cx: this.centerX,
cy: this.centerY,
fill: i.config.plotOptions.pie.donut.background ? i.config.plotOptions.pie.donut.background : "transparent"
}), l.add(f)
}
var x = this.drawArcs(o, t);
if (this.sliceLabels.forEach((function (t) {
x.add(t)
})), l.attr({transform: "translate(".concat(this.translateX, ", ").concat(this.translateY, ") scale(").concat(i.config.plotOptions.pie.customScale, ")")}), l.add(x), s.add(l), this.donutDataLabels.show) {
var b = this.renderInnerDataLabels(this.dataLabelsGroup, this.donutDataLabels, {
hollowSize: this.donutSize,
centerX: this.centerX,
centerY: this.centerY,
opacity: this.donutDataLabels.show
});
s.add(b)
}
return "front" === i.config.grid.position && "polarArea" === this.chartType && this.drawPolarElements(s), s
}
}, {
key: "drawArcs", value: function (t, e) {
var i = this.w, a = new Li(this.ctx), s = new Mi(this.ctx), r = new ji(this.ctx),
n = s.group({class: "apexcharts-slices"}), o = this.initialAngle, l = this.initialAngle,
h = this.initialAngle, c = this.initialAngle;
this.strokeWidth = i.config.stroke.show ? i.config.stroke.width : 0;
for (var d = 0; d < t.length; d++) {
var u = s.group({
class: "apexcharts-series apexcharts-pie-series",
seriesName: v.escapeString(i.globals.seriesNames[d]),
rel: d + 1,
"data:realIndex": d
});
n.add(u), l = c, h = (o = h) + t[d], c = l + this.prevSectorAngleArr[d];
var g = h < o ? this.fullAngle + h - o : h - o,
p = r.fillPath({seriesNumber: d, size: this.sliceSizes[d], value: e[d]}),
f = this.getChangedPath(l, c), x = s.drawPath({
d: f,
stroke: Array.isArray(this.lineColorArr) ? this.lineColorArr[d] : this.lineColorArr,
strokeWidth: 0,
fill: p,
fillOpacity: i.config.fill.opacity,
classes: "apexcharts-pie-area apexcharts-".concat(this.chartType.toLowerCase(), "-slice-").concat(d)
});
if (x.attr({index: 0, j: d}), a.setSelectionFilter(x, 0, d), i.config.chart.dropShadow.enabled) {
var b = i.config.chart.dropShadow;
a.dropShadow(x, b, d)
}
this.addListeners(x, this.donutDataLabels), Mi.setAttrs(x.node, {
"data:angle": g,
"data:startAngle": o,
"data:strokeWidth": this.strokeWidth,
"data:value": e[d]
});
var m = {x: 0, y: 0};
"pie" === this.chartType || "polarArea" === this.chartType ? m = v.polarToCartesian(this.centerX, this.centerY, i.globals.radialSize / 1.25 + i.config.plotOptions.pie.dataLabels.offset, (o + g / 2) % this.fullAngle) : "donut" === this.chartType && (m = v.polarToCartesian(this.centerX, this.centerY, (i.globals.radialSize + this.donutSize) / 2 + i.config.plotOptions.pie.dataLabels.offset, (o + g / 2) % this.fullAngle)), u.add(x);
var y = 0;
if (!this.initialAnim || i.globals.resized || i.globals.dataChanged ? this.animBeginArr.push(0) : (0 === (y = g / this.fullAngle * i.config.chart.animations.speed) && (y = 1), this.animDur = y + this.animDur, this.animBeginArr.push(this.animDur)), this.dynamicAnim && i.globals.dataChanged ? this.animatePaths(x, {
size: this.sliceSizes[d],
endAngle: h,
startAngle: o,
prevStartAngle: l,
prevEndAngle: c,
animateStartingPos: !0,
i: d,
animBeginArr: this.animBeginArr,
shouldSetPrevPaths: !0,
dur: i.config.chart.animations.dynamicAnimation.speed
}) : this.animatePaths(x, {
size: this.sliceSizes[d],
endAngle: h,
startAngle: o,
i: d,
totalItems: t.length - 1,
animBeginArr: this.animBeginArr,
dur: y
}), i.config.plotOptions.pie.expandOnClick && "polarArea" !== this.chartType && x.node.addEventListener("mouseup", this.pieClicked.bind(this, d)), void 0 !== i.globals.selectedDataPoints[0] && i.globals.selectedDataPoints[0].indexOf(d) > -1 && this.pieClicked(d), i.config.dataLabels.enabled) {
var w = m.x, k = m.y, A = 100 * g / this.fullAngle + "%";
if (0 !== g && i.config.plotOptions.pie.dataLabels.minAngleToShowLabel < t[d]) {
var C = i.config.dataLabels.formatter;
void 0 !== C && (A = C(i.globals.seriesPercent[d][0], {seriesIndex: d, w: i}));
var S = i.globals.dataLabels.style.colors[d], L = s.group({class: "apexcharts-datalabels"}),
M = s.drawText({
x: w,
y: k,
text: A,
textAnchor: "middle",
fontSize: i.config.dataLabels.style.fontSize,
fontFamily: i.config.dataLabels.style.fontFamily,
fontWeight: i.config.dataLabels.style.fontWeight,
foreColor: S
});
if (L.add(M), i.config.dataLabels.dropShadow.enabled) {
var P = i.config.dataLabels.dropShadow;
a.dropShadow(M, P)
}
M.node.classList.add("apexcharts-pie-label"), i.config.chart.animations.animate && !1 === i.globals.resized && (M.node.classList.add("apexcharts-pie-label-delay"), M.node.style.animationDelay = i.config.chart.animations.speed / 940 + "s"), this.sliceLabels.push(L)
}
}
}
return n
}
}, {
key: "addListeners", value: function (t, e) {
var i = new Mi(this.ctx);
t.node.addEventListener("mouseenter", i.pathMouseEnter.bind(this, t)), t.node.addEventListener("mouseleave", i.pathMouseLeave.bind(this, t)), t.node.addEventListener("mouseleave", this.revertDataLabelsInner.bind(this, t.node, e)), t.node.addEventListener("mousedown", i.pathMouseDown.bind(this, t)), this.donutDataLabels.total.showAlways || (t.node.addEventListener("mouseenter", this.printDataLabelsInner.bind(this, t.node, e)), t.node.addEventListener("mousedown", this.printDataLabelsInner.bind(this, t.node, e)))
}
}, {
key: "animatePaths", value: function (t, e) {
var i = this.w,
a = e.endAngle < e.startAngle ? this.fullAngle + e.endAngle - e.startAngle : e.endAngle - e.startAngle,
s = a, r = e.startAngle, n = e.startAngle;
void 0 !== e.prevStartAngle && void 0 !== e.prevEndAngle && (r = e.prevEndAngle, s = e.prevEndAngle < e.prevStartAngle ? this.fullAngle + e.prevEndAngle - e.prevStartAngle : e.prevEndAngle - e.prevStartAngle), e.i === i.config.series.length - 1 && (a + n > this.fullAngle ? e.endAngle = e.endAngle - (a + n) : a + n < this.fullAngle && (e.endAngle = e.endAngle + (this.fullAngle - (a + n)))), a === this.fullAngle && (a = this.fullAngle - .01), this.animateArc(t, r, n, a, s, e)
}
}, {
key: "animateArc", value: function (t, e, i, a, s, r) {
var n, o = this, l = this.w, h = new y(this.ctx), c = r.size;
(isNaN(e) || isNaN(s)) && (e = i, s = a, r.dur = 0);
var d = a, u = i, g = e < i ? this.fullAngle + e - i : e - i;
l.globals.dataChanged && r.shouldSetPrevPaths && r.prevEndAngle && (n = o.getPiePath({
me: o,
startAngle: r.prevStartAngle,
angle: r.prevEndAngle < r.prevStartAngle ? this.fullAngle + r.prevEndAngle - r.prevStartAngle : r.prevEndAngle - r.prevStartAngle,
size: c
}), t.attr({d: n})), 0 !== r.dur ? t.animate(r.dur, r.animBeginArr[r.i]).after((function () {
"pie" !== o.chartType && "donut" !== o.chartType && "polarArea" !== o.chartType || this.animate(l.config.chart.animations.dynamicAnimation.speed).attr({"stroke-width": o.strokeWidth}), r.i === l.config.series.length - 1 && h.animationCompleted(t)
})).during((function (l) {
d = g + (a - g) * l, r.animateStartingPos && (d = s + (a - s) * l, u = e - s + (i - (e - s)) * l), n = o.getPiePath({
me: o,
startAngle: u,
angle: d,
size: c
}), t.node.setAttribute("data:pathOrig", n), t.attr({d: n})
})) : (n = o.getPiePath({
me: o,
startAngle: u,
angle: a,
size: c
}), r.isTrack || (l.globals.animationEnded = !0), t.node.setAttribute("data:pathOrig", n), t.attr({
d: n,
"stroke-width": o.strokeWidth
}))
}
}, {
key: "pieClicked", value: function (t) {
var e, i = this.w, a = this, s = a.sliceSizes[t] + (i.config.plotOptions.pie.expandOnClick ? 4 : 0),
r = i.globals.dom.Paper.findOne(".apexcharts-".concat(a.chartType.toLowerCase(), "-slice-").concat(t));
if ("true" !== r.attr("data:pieClicked")) {
var n = i.globals.dom.baseEl.getElementsByClassName("apexcharts-pie-area");
Array.prototype.forEach.call(n, (function (t) {
t.setAttribute("data:pieClicked", "false");
var e = t.getAttribute("data:pathOrig");
e && t.setAttribute("d", e)
})), i.globals.capturedDataPointIndex = t, r.attr("data:pieClicked", "true");
var o = parseInt(r.attr("data:startAngle"), 10), l = parseInt(r.attr("data:angle"), 10);
e = a.getPiePath({me: a, startAngle: o, angle: l, size: s}), 360 !== l && r.plot(e)
} else {
r.attr({"data:pieClicked": "false"}), this.revertDataLabelsInner(r.node, this.donutDataLabels);
var h = r.attr("data:pathOrig");
r.attr({d: h})
}
}
}, {
key: "getChangedPath", value: function (t, e) {
var i = "";
return this.dynamicAnim && this.w.globals.dataChanged && (i = this.getPiePath({
me: this,
startAngle: t,
angle: e - t,
size: this.size
})), i
}
}, {
key: "getPiePath", value: function (t) {
var e, i = t.me, a = t.startAngle, s = t.angle, r = t.size, n = new Mi(this.ctx), o = a,
l = Math.PI * (o - 90) / 180, h = s + a;
Math.ceil(h) >= this.fullAngle + this.w.config.plotOptions.pie.startAngle % this.fullAngle && (h = this.fullAngle + this.w.config.plotOptions.pie.startAngle % this.fullAngle - .01), Math.ceil(h) > this.fullAngle && (h -= this.fullAngle);
var c = Math.PI * (h - 90) / 180, d = i.centerX + r * Math.cos(l), u = i.centerY + r * Math.sin(l),
g = i.centerX + r * Math.cos(c), p = i.centerY + r * Math.sin(c),
f = v.polarToCartesian(i.centerX, i.centerY, i.donutSize, h),
x = v.polarToCartesian(i.centerX, i.centerY, i.donutSize, o), b = s > 180 ? 1 : 0,
m = ["M", d, u, "A", r, r, 0, b, 1, g, p];
return e = "donut" === i.chartType ? [].concat(m, ["L", f.x, f.y, "A", i.donutSize, i.donutSize, 0, b, 0, x.x, x.y, "L", d, u, "z"]).join(" ") : "pie" === i.chartType || "polarArea" === i.chartType ? [].concat(m, ["L", i.centerX, i.centerY, "L", d, u]).join(" ") : [].concat(m).join(" "), n.roundPathCorners(e, 2 * this.strokeWidth)
}
}, {
key: "drawPolarElements", value: function (t) {
var e = this.w, i = new ea(this.ctx), a = new Mi(this.ctx), s = new Ea(this.ctx), r = a.group(),
n = a.group(), o = i.niceScale(0, Math.ceil(this.maxY), 0), l = o.result.reverse(),
h = o.result.length;
this.maxY = o.niceMax;
for (var c = e.globals.radialSize, d = c / (h - 1), u = 0; u < h - 1; u++) {
var g = a.drawCircle(c);
if (g.attr({
cx: this.centerX,
cy: this.centerY,
fill: "none",
"stroke-width": e.config.plotOptions.polarArea.rings.strokeWidth,
stroke: e.config.plotOptions.polarArea.rings.strokeColor
}), e.config.yaxis[0].show) {
var p = s.drawYAxisTexts(this.centerX, this.centerY - c + parseInt(e.config.yaxis[0].labels.style.fontSize, 10) / 2, u, l[u]);
n.add(p)
}
r.add(g), c -= d
}
this.drawSpokes(t), t.add(r), t.add(n)
}
}, {
key: "renderInnerDataLabels", value: function (t, e, i) {
var a = this.w, s = new Mi(this.ctx), r = e.total.show;
t.node.innerHTML = "", t.node.style.opacity = i.opacity;
var n, o, l = i.centerX, h = this.donutDataLabels.total.label ? i.centerY : i.centerY - i.centerY / 6;
n = void 0 === e.name.color ? a.globals.colors[0] : e.name.color;
var c = e.name.fontSize, d = e.name.fontFamily, u = e.name.fontWeight;
o = void 0 === e.value.color ? a.config.chart.foreColor : e.value.color;
var g = e.value.formatter, p = "", f = "";
if (r ? (n = e.total.color, c = e.total.fontSize, d = e.total.fontFamily, u = e.total.fontWeight, f = this.donutDataLabels.total.label ? e.total.label : "", p = e.total.formatter(a)) : 1 === a.globals.series.length && (p = g(a.globals.series[0], a), f = a.globals.seriesNames[0]), f && (f = e.name.formatter(f, e.total.show, a)), e.name.show) {
var x = s.drawText({
x: l,
y: h + parseFloat(e.name.offsetY),
text: f,
textAnchor: "middle",
foreColor: n,
fontSize: c,
fontWeight: u,
fontFamily: d
});
x.node.classList.add("apexcharts-datalabel-label"), t.add(x)
}
if (e.value.show) {
var b = e.name.show ? parseFloat(e.value.offsetY) + 16 : e.value.offsetY, m = s.drawText({
x: l,
y: h + b,
text: p,
textAnchor: "middle",
foreColor: o,
fontWeight: e.value.fontWeight,
fontSize: e.value.fontSize,
fontFamily: e.value.fontFamily
});
m.node.classList.add("apexcharts-datalabel-value"), t.add(m)
}
return t
}
}, {
key: "printInnerLabels", value: function (t, e, i, a) {
var s, r = this.w;
a ? s = void 0 === t.name.color ? r.globals.colors[parseInt(a.parentNode.getAttribute("rel"), 10) - 1] : t.name.color : r.globals.series.length > 1 && t.total.show && (s = t.total.color);
var n = r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-label"),
o = r.globals.dom.baseEl.querySelector(".apexcharts-datalabel-value");
i = (0, t.value.formatter)(i, r), a || "function" != typeof t.total.formatter || (i = t.total.formatter(r));
var l = e === t.total.label;
e = this.donutDataLabels.total.label ? t.name.formatter(e, l, r) : "", null !== n && (n.textContent = e), null !== o && (o.textContent = i), null !== n && (n.style.fill = s)
}
}, {
key: "printDataLabelsInner", value: function (t, e) {
var i = this.w, a = t.getAttribute("data:value"),
s = i.globals.seriesNames[parseInt(t.parentNode.getAttribute("rel"), 10) - 1];
i.globals.series.length > 1 && this.printInnerLabels(e, s, a, t);
var r = i.globals.dom.baseEl.querySelector(".apexcharts-datalabels-group");
null !== r && (r.style.opacity = 1)
}
}, {
key: "drawSpokes", value: function (t) {
var e = this, i = this.w, a = new Mi(this.ctx), s = i.config.plotOptions.polarArea.spokes;
if (0 !== s.strokeWidth) {
for (var r = [], n = 360 / i.globals.series.length, o = 0; o < i.globals.series.length; o++) r.push(v.polarToCartesian(this.centerX, this.centerY, i.globals.radialSize, i.config.plotOptions.pie.startAngle + n * o));
r.forEach((function (i, r) {
var n = a.drawLine(i.x, i.y, e.centerX, e.centerY, Array.isArray(s.connectorColors) ? s.connectorColors[r] : s.connectorColors);
t.add(n)
}))
}
}
}, {
key: "revertDataLabelsInner", value: function () {
var t = this.w;
if (this.donutDataLabels.show) {
var e = t.globals.dom.Paper.findOne(".apexcharts-datalabels-group"),
i = this.renderInnerDataLabels(e, this.donutDataLabels, {
hollowSize: this.donutSize,
centerX: this.centerX,
centerY: this.centerY,
opacity: this.donutDataLabels.show
});
t.globals.dom.Paper.findOne(".apexcharts-radialbar, .apexcharts-pie").add(i)
}
}
}]), t
}(), Ha = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.chartType = this.w.config.chart.type, this.initialAnim = this.w.config.chart.animations.enabled, this.dynamicAnim = this.initialAnim && this.w.config.chart.animations.dynamicAnimation.enabled, this.animDur = 0;
var a = this.w;
this.graphics = new Mi(this.ctx), this.lineColorArr = void 0 !== a.globals.stroke.colors ? a.globals.stroke.colors : a.globals.colors, this.defaultSize = a.globals.svgHeight < a.globals.svgWidth ? a.globals.gridHeight : a.globals.gridWidth, this.isLog = a.config.yaxis[0].logarithmic, this.logBase = a.config.yaxis[0].logBase, this.coreUtils = new Pi(this.ctx), this.maxValue = this.isLog ? this.coreUtils.getLogVal(this.logBase, a.globals.maxY, 0) : a.globals.maxY, this.minValue = this.isLog ? this.coreUtils.getLogVal(this.logBase, this.w.globals.minY, 0) : a.globals.minY, this.polygons = a.config.plotOptions.radar.polygons, this.strokeWidth = a.config.stroke.show ? a.config.stroke.width : 0, this.size = this.defaultSize / 2.1 - this.strokeWidth - a.config.chart.dropShadow.blur, a.config.xaxis.labels.show && (this.size = this.size - a.globals.xAxisLabelsWidth / 1.75), void 0 !== a.config.plotOptions.radar.size && (this.size = a.config.plotOptions.radar.size), this.dataRadiusOfPercent = [], this.dataRadius = [], this.angleArr = [], this.yaxisLabelsTextsPos = []
}
return s(t, [{
key: "draw", value: function (t) {
var e = this, i = this.w, a = new ji(this.ctx), s = [], r = new qi(this.ctx);
t.length && (this.dataPointsLen = t[i.globals.maxValsInArrayIndex].length), this.disAngle = 2 * Math.PI / this.dataPointsLen;
var n = i.globals.gridWidth / 2, o = i.globals.gridHeight / 2,
l = n + i.config.plotOptions.radar.offsetX, h = o + i.config.plotOptions.radar.offsetY,
c = this.graphics.group({
class: "apexcharts-radar-series apexcharts-plot-series",
transform: "translate(".concat(l || 0, ", ").concat(h || 0, ")")
}), d = [], g = null, p = null;
if (this.yaxisLabels = this.graphics.group({class: "apexcharts-yaxis"}), t.forEach((function (t, n) {
var o = t.length === i.globals.dataPoints, l = e.graphics.group().attr({
class: "apexcharts-series",
"data:longestSeries": o,
seriesName: v.escapeString(i.globals.seriesNames[n]),
rel: n + 1,
"data:realIndex": n
});
e.dataRadiusOfPercent[n] = [], e.dataRadius[n] = [], e.angleArr[n] = [], t.forEach((function (t, i) {
var a = Math.abs(e.maxValue - e.minValue);
t -= e.minValue, e.isLog && (t = e.coreUtils.getLogVal(e.logBase, t, 0)), e.dataRadiusOfPercent[n][i] = t / a, e.dataRadius[n][i] = e.dataRadiusOfPercent[n][i] * e.size, e.angleArr[n][i] = i * e.disAngle
})), d = e.getDataPointsPos(e.dataRadius[n], e.angleArr[n]);
var h = e.createPaths(d, {x: 0, y: 0});
g = e.graphics.group({class: "apexcharts-series-markers-wrap apexcharts-element-hidden"}), p = e.graphics.group({
class: "apexcharts-datalabels",
"data:realIndex": n
}), i.globals.delayedElements.push({el: g.node, index: n});
var c = {
i: n,
realIndex: n,
animationDelay: n,
initialSpeed: i.config.chart.animations.speed,
dataChangeSpeed: i.config.chart.animations.dynamicAnimation.speed,
className: "apexcharts-radar",
shouldClipToGrid: !1,
bindEventsOnPaths: !1,
stroke: i.globals.stroke.colors[n],
strokeLineCap: i.config.stroke.lineCap
}, f = null;
i.globals.previousPaths.length > 0 && (f = e.getPreviousPath(n));
for (var x = 0; x < h.linePathsTo.length; x++) {
var b = e.graphics.renderPaths(u(u({}, c), {}, {
pathFrom: null === f ? h.linePathsFrom[x] : f,
pathTo: h.linePathsTo[x],
strokeWidth: Array.isArray(e.strokeWidth) ? e.strokeWidth[n] : e.strokeWidth,
fill: "none",
drawShadow: !1
}));
l.add(b);
var m = a.fillPath({seriesNumber: n}), y = e.graphics.renderPaths(u(u({}, c), {}, {
pathFrom: null === f ? h.areaPathsFrom[x] : f,
pathTo: h.areaPathsTo[x],
strokeWidth: 0,
fill: m,
drawShadow: !1
}));
if (i.config.chart.dropShadow.enabled) {
var w = new Li(e.ctx), k = i.config.chart.dropShadow;
w.dropShadow(y, Object.assign({}, k, {noUserSpaceOnUse: !0}), n)
}
l.add(y)
}
t.forEach((function (t, a) {
var s = new Vi(e.ctx).getMarkerConfig({
cssClass: "apexcharts-marker",
seriesIndex: n,
dataPointIndex: a
}), o = e.graphics.drawMarker(d[a].x, d[a].y, s);
o.attr("rel", a), o.attr("j", a), o.attr("index", n), o.node.setAttribute("default-marker-size", s.pSize);
var h = e.graphics.group({class: "apexcharts-series-markers"});
h && h.add(o), g.add(h), l.add(g);
var c = i.config.dataLabels;
if (c.enabled) {
var f = c.formatter(i.globals.series[n][a], {seriesIndex: n, dataPointIndex: a, w: i});
r.plotDataLabelsText({
x: d[a].x,
y: d[a].y,
text: f,
textAnchor: "middle",
i: n,
j: n,
parent: p,
offsetCorrection: !1,
dataLabelsConfig: u({}, c)
})
}
l.add(p)
})), s.push(l)
})), this.drawPolygons({parent: c}), i.config.xaxis.labels.show) {
var f = this.drawXAxisTexts();
c.add(f)
}
return s.forEach((function (t) {
c.add(t)
})), c.add(this.yaxisLabels), c
}
}, {
key: "drawPolygons", value: function (t) {
for (var e = this, i = this.w, a = t.parent, s = new Ea(this.ctx), r = i.globals.yAxisScale[0].result.reverse(), n = r.length, o = [], l = this.size / (n - 1), h = 0; h < n; h++) o[h] = l * h;
o.reverse();
var c = [], d = [];
o.forEach((function (t, i) {
var a = v.getPolygonPos(t, e.dataPointsLen), s = "";
a.forEach((function (t, a) {
if (0 === i) {
var r = e.graphics.drawLine(t.x, t.y, 0, 0, Array.isArray(e.polygons.connectorColors) ? e.polygons.connectorColors[a] : e.polygons.connectorColors);
d.push(r)
}
0 === a && e.yaxisLabelsTextsPos.push({x: t.x, y: t.y}), s += t.x + "," + t.y + " "
})), c.push(s)
})), c.forEach((function (t, s) {
var r = e.polygons.strokeColors, n = e.polygons.strokeWidth,
o = e.graphics.drawPolygon(t, Array.isArray(r) ? r[s] : r, Array.isArray(n) ? n[s] : n, i.globals.radarPolygons.fill.colors[s]);
a.add(o)
})), d.forEach((function (t) {
a.add(t)
})), i.config.yaxis[0].show && this.yaxisLabelsTextsPos.forEach((function (t, i) {
var a = s.drawYAxisTexts(t.x, t.y, i, r[i]);
e.yaxisLabels.add(a)
}))
}
}, {
key: "drawXAxisTexts", value: function () {
var t = this, e = this.w, i = e.config.xaxis.labels,
a = this.graphics.group({class: "apexcharts-xaxis"}),
s = v.getPolygonPos(this.size, this.dataPointsLen);
return e.globals.labels.forEach((function (r, n) {
var o = e.config.xaxis.labels.formatter, l = new qi(t.ctx);
if (s[n]) {
var h = t.getTextPos(s[n], t.size), c = o(r, {seriesIndex: -1, dataPointIndex: n, w: e});
l.plotDataLabelsText({
x: h.newX,
y: h.newY,
text: c,
textAnchor: h.textAnchor,
i: n,
j: n,
parent: a,
className: "apexcharts-xaxis-label",
color: Array.isArray(i.style.colors) && i.style.colors[n] ? i.style.colors[n] : "#a8a8a8",
dataLabelsConfig: u({textAnchor: h.textAnchor, dropShadow: {enabled: !1}}, i),
offsetCorrection: !1
}).on("click", (function (i) {
if ("function" == typeof e.config.chart.events.xAxisLabelClick) {
var a = Object.assign({}, e, {labelIndex: n});
e.config.chart.events.xAxisLabelClick(i, t.ctx, a)
}
}))
}
})), a
}
}, {
key: "createPaths", value: function (t, e) {
var i = this, a = [], s = [], r = [], n = [];
if (t.length) {
s = [this.graphics.move(e.x, e.y)], n = [this.graphics.move(e.x, e.y)];
var o = this.graphics.move(t[0].x, t[0].y), l = this.graphics.move(t[0].x, t[0].y);
t.forEach((function (e, a) {
o += i.graphics.line(e.x, e.y), l += i.graphics.line(e.x, e.y), a === t.length - 1 && (o += "Z", l += "Z")
})), a.push(o), r.push(l)
}
return {linePathsFrom: s, linePathsTo: a, areaPathsFrom: n, areaPathsTo: r}
}
}, {
key: "getTextPos", value: function (t, e) {
var i = "middle", a = t.x, s = t.y;
return Math.abs(t.x) >= 10 ? t.x > 0 ? (i = "start", a += 10) : t.x < 0 && (i = "end", a -= 10) : i = "middle", Math.abs(t.y) >= e - 10 && (t.y < 0 ? s -= 10 : t.y > 0 && (s += 10)), {
textAnchor: i,
newX: a,
newY: s
}
}
}, {
key: "getPreviousPath", value: function (t) {
for (var e = this.w, i = null, a = 0; a < e.globals.previousPaths.length; a++) {
var s = e.globals.previousPaths[a];
s.paths.length > 0 && parseInt(s.realIndex, 10) === parseInt(t, 10) && void 0 !== e.globals.previousPaths[a].paths[0] && (i = e.globals.previousPaths[a].paths[0].d)
}
return i
}
}, {
key: "getDataPointsPos", value: function (t, e) {
var i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : this.dataPointsLen;
t = t || [], e = e || [];
for (var a = [], s = 0; s < i; s++) {
var r = {};
r.x = t[s] * Math.sin(e[s]), r.y = -t[s] * Math.cos(e[s]), a.push(r)
}
return a
}
}]), t
}(), Oa = function (t) {
h(r, t);
var a = n(r);
function r(t) {
var s;
i(this, r), (s = a.call(this, t)).ctx = t, s.w = t.w, s.animBeginArr = [0], s.animDur = 0;
var n = s.w;
return s.startAngle = n.config.plotOptions.radialBar.startAngle, s.endAngle = n.config.plotOptions.radialBar.endAngle, s.totalAngle = Math.abs(n.config.plotOptions.radialBar.endAngle - n.config.plotOptions.radialBar.startAngle), s.trackStartAngle = n.config.plotOptions.radialBar.track.startAngle, s.trackEndAngle = n.config.plotOptions.radialBar.track.endAngle, s.barLabels = s.w.config.plotOptions.radialBar.barLabels, s.donutDataLabels = s.w.config.plotOptions.radialBar.dataLabels, s.radialDataLabels = s.donutDataLabels, s.trackStartAngle || (s.trackStartAngle = s.startAngle), s.trackEndAngle || (s.trackEndAngle = s.endAngle), 360 === s.endAngle && (s.endAngle = 359.99), s.margin = parseInt(n.config.plotOptions.radialBar.track.margin, 10), s.onBarLabelClick = s.onBarLabelClick.bind(e(s)), s
}
return s(r, [{
key: "draw", value: function (t) {
var e = this.w, i = new Mi(this.ctx), a = i.group({class: "apexcharts-radialbar"});
if (e.globals.noData) return a;
var s = i.group(), r = this.defaultSize / 2, n = e.globals.gridWidth / 2, o = this.defaultSize / 2.05;
e.config.chart.sparkline.enabled || (o = o - e.config.stroke.width - e.config.chart.dropShadow.blur);
var l = e.globals.fill.colors;
if (e.config.plotOptions.radialBar.track.show) {
var h = this.drawTracks({size: o, centerX: n, centerY: r, colorArr: l, series: t});
s.add(h)
}
var c = this.drawArcs({size: o, centerX: n, centerY: r, colorArr: l, series: t}), d = 360;
e.config.plotOptions.radialBar.startAngle < 0 && (d = this.totalAngle);
var u = (360 - d) / 360;
if (e.globals.radialSize = o - o * u, this.radialDataLabels.value.show) {
var g = Math.max(this.radialDataLabels.value.offsetY, this.radialDataLabels.name.offsetY);
e.globals.radialSize += g * u
}
return s.add(c.g), "front" === e.config.plotOptions.radialBar.hollow.position && (c.g.add(c.elHollow), c.dataLabels && c.g.add(c.dataLabels)), a.add(s), a
}
}, {
key: "drawTracks", value: function (t) {
var e = this.w, i = new Mi(this.ctx), a = i.group({class: "apexcharts-tracks"}), s = new Li(this.ctx),
r = new ji(this.ctx), n = this.getStrokeWidth(t);
t.size = t.size - n / 2;
for (var o = 0; o < t.series.length; o++) {
var l = i.group({class: "apexcharts-radialbar-track apexcharts-track"});
a.add(l), l.attr({rel: o + 1}), t.size = t.size - n - this.margin;
var h = e.config.plotOptions.radialBar.track, c = r.fillPath({
seriesNumber: 0,
size: t.size,
fillColors: Array.isArray(h.background) ? h.background[o] : h.background,
solid: !0
}), d = this.trackStartAngle, u = this.trackEndAngle;
Math.abs(u) + Math.abs(d) >= 360 && (u = 360 - Math.abs(this.startAngle) - .1);
var g = i.drawPath({
d: "",
stroke: c,
strokeWidth: n * parseInt(h.strokeWidth, 10) / 100,
fill: "none",
strokeOpacity: h.opacity,
classes: "apexcharts-radialbar-area"
});
if (h.dropShadow.enabled) {
var p = h.dropShadow;
s.dropShadow(g, p)
}
l.add(g), g.attr("id", "apexcharts-radialbarTrack-" + o), this.animatePaths(g, {
centerX: t.centerX,
centerY: t.centerY,
endAngle: u,
startAngle: d,
size: t.size,
i: o,
totalItems: 2,
animBeginArr: 0,
dur: 0,
isTrack: !0
})
}
return a
}
}, {
key: "drawArcs", value: function (t) {
var e = this.w, i = new Mi(this.ctx), a = new ji(this.ctx), s = new Li(this.ctx), r = i.group(),
n = this.getStrokeWidth(t);
t.size = t.size - n / 2;
var o = e.config.plotOptions.radialBar.hollow.background,
l = t.size - n * t.series.length - this.margin * t.series.length - n * parseInt(e.config.plotOptions.radialBar.track.strokeWidth, 10) / 100 / 2,
h = l - e.config.plotOptions.radialBar.hollow.margin;
void 0 !== e.config.plotOptions.radialBar.hollow.image && (o = this.drawHollowImage(t, r, l, o));
var c = this.drawHollow({size: h, centerX: t.centerX, centerY: t.centerY, fill: o || "transparent"});
if (e.config.plotOptions.radialBar.hollow.dropShadow.enabled) {
var d = e.config.plotOptions.radialBar.hollow.dropShadow;
s.dropShadow(c, d)
}
var u = 1;
!this.radialDataLabels.total.show && e.globals.series.length > 1 && (u = 0);
var g = null;
if (this.radialDataLabels.show) {
var p = e.globals.dom.Paper.findOne(".apexcharts-datalabels-group");
g = this.renderInnerDataLabels(p, this.radialDataLabels, {
hollowSize: l,
centerX: t.centerX,
centerY: t.centerY,
opacity: u
})
}
"back" === e.config.plotOptions.radialBar.hollow.position && (r.add(c), g && r.add(g));
var f = !1;
e.config.plotOptions.radialBar.inverseOrder && (f = !0);
for (var x = f ? t.series.length - 1 : 0; f ? x >= 0 : x < t.series.length; f ? x-- : x++) {
var b = i.group({
class: "apexcharts-series apexcharts-radial-series",
seriesName: v.escapeString(e.globals.seriesNames[x])
});
r.add(b), b.attr({
rel: x + 1,
"data:realIndex": x
}), this.ctx.series.addCollapsedClassToSeries(b, x), t.size = t.size - n - this.margin;
var m = a.fillPath({seriesNumber: x, size: t.size, value: t.series[x]}), y = this.startAngle,
w = void 0, k = v.negToZero(t.series[x] > 100 ? 100 : t.series[x]) / 100,
A = Math.round(this.totalAngle * k) + this.startAngle, C = void 0;
e.globals.dataChanged && (w = this.startAngle, C = Math.round(this.totalAngle * v.negToZero(e.globals.previousPaths[x]) / 100) + w), Math.abs(A) + Math.abs(y) > 360 && (A -= .01), Math.abs(C) + Math.abs(w) > 360 && (C -= .01);
var S = A - y,
L = Array.isArray(e.config.stroke.dashArray) ? e.config.stroke.dashArray[x] : e.config.stroke.dashArray,
M = i.drawPath({
d: "",
stroke: m,
strokeWidth: n,
fill: "none",
fillOpacity: e.config.fill.opacity,
classes: "apexcharts-radialbar-area apexcharts-radialbar-slice-" + x,
strokeDashArray: L
});
if (Mi.setAttrs(M.node, {
"data:angle": S,
"data:value": t.series[x]
}), e.config.chart.dropShadow.enabled) {
var P = e.config.chart.dropShadow;
s.dropShadow(M, P, x)
}
if (s.setSelectionFilter(M, 0, x), this.addListeners(M, this.radialDataLabels), b.add(M), M.attr({
index: 0,
j: x
}), this.barLabels.enabled) {
var I = v.polarToCartesian(t.centerX, t.centerY, t.size, y),
T = this.barLabels.formatter(e.globals.seriesNames[x], {seriesIndex: x, w: e}),
z = ["apexcharts-radialbar-label"];
this.barLabels.onClick || z.push("apexcharts-no-click");
var X = this.barLabels.useSeriesColors ? e.globals.colors[x] : e.config.chart.foreColor;
X || (X = e.config.chart.foreColor);
var R = I.x + this.barLabels.offsetX, E = I.y + this.barLabels.offsetY, Y = i.drawText({
x: R,
y: E,
text: T,
textAnchor: "end",
dominantBaseline: "middle",
fontFamily: this.barLabels.fontFamily,
fontWeight: this.barLabels.fontWeight,
fontSize: this.barLabels.fontSize,
foreColor: X,
cssClass: z.join(" ")
});
Y.on("click", this.onBarLabelClick), Y.attr({rel: x + 1}), 0 !== y && Y.attr({
"transform-origin": "".concat(R, " ").concat(E),
transform: "rotate(".concat(y, " 0 0)")
}), b.add(Y)
}
var H = 0;
!this.initialAnim || e.globals.resized || e.globals.dataChanged || (H = e.config.chart.animations.speed), e.globals.dataChanged && (H = e.config.chart.animations.dynamicAnimation.speed), this.animDur = H / (1.2 * t.series.length) + this.animDur, this.animBeginArr.push(this.animDur), this.animatePaths(M, {
centerX: t.centerX,
centerY: t.centerY,
endAngle: A,
startAngle: y,
prevEndAngle: C,
prevStartAngle: w,
size: t.size,
i: x,
totalItems: 2,
animBeginArr: this.animBeginArr,
dur: H,
shouldSetPrevPaths: !0
})
}
return {g: r, elHollow: c, dataLabels: g}
}
}, {
key: "drawHollow", value: function (t) {
var e = new Mi(this.ctx).drawCircle(2 * t.size);
return e.attr({
class: "apexcharts-radialbar-hollow",
cx: t.centerX,
cy: t.centerY,
r: t.size,
fill: t.fill
}), e
}
}, {
key: "drawHollowImage", value: function (t, e, i, a) {
var s = this.w, r = new ji(this.ctx), n = v.randomId(), o = s.config.plotOptions.radialBar.hollow.image;
if (s.config.plotOptions.radialBar.hollow.imageClipped) r.clippedImgArea({
width: i,
height: i,
image: o,
patternID: "pattern".concat(s.globals.cuid).concat(n)
}), a = "url(#pattern".concat(s.globals.cuid).concat(n, ")"); else {
var l = s.config.plotOptions.radialBar.hollow.imageWidth,
h = s.config.plotOptions.radialBar.hollow.imageHeight;
if (void 0 === l && void 0 === h) {
var c = s.globals.dom.Paper.image(o, (function (e) {
this.move(t.centerX - e.width / 2 + s.config.plotOptions.radialBar.hollow.imageOffsetX, t.centerY - e.height / 2 + s.config.plotOptions.radialBar.hollow.imageOffsetY)
}));
e.add(c)
} else {
var d = s.globals.dom.Paper.image(o, (function (e) {
this.move(t.centerX - l / 2 + s.config.plotOptions.radialBar.hollow.imageOffsetX, t.centerY - h / 2 + s.config.plotOptions.radialBar.hollow.imageOffsetY), this.size(l, h)
}));
e.add(d)
}
}
return a
}
}, {
key: "getStrokeWidth", value: function (t) {
var e = this.w;
return t.size * (100 - parseInt(e.config.plotOptions.radialBar.hollow.size, 10)) / 100 / (t.series.length + 1) - this.margin
}
}, {
key: "onBarLabelClick", value: function (t) {
var e = parseInt(t.target.getAttribute("rel"), 10) - 1, i = this.barLabels.onClick, a = this.w;
i && i(a.globals.seriesNames[e], {w: a, seriesIndex: e})
}
}]), r
}(Ya), Fa = function (t) {
h(a, t);
var e = n(a);
function a() {
return i(this, a), e.apply(this, arguments)
}
return s(a, [{
key: "draw", value: function (t, e) {
var i = this.w, a = new Mi(this.ctx);
this.rangeBarOptions = this.w.config.plotOptions.rangeBar, this.series = t, this.seriesRangeStart = i.globals.seriesRangeStart, this.seriesRangeEnd = i.globals.seriesRangeEnd, this.barHelpers.initVariables(t);
for (var s = a.group({class: "apexcharts-rangebar-series apexcharts-plot-series"}), r = 0; r < t.length; r++) {
var n, o, l, h, c = void 0, d = void 0, g = i.globals.comboCharts ? e[r] : r,
p = this.barHelpers.getGroupIndex(g).columnGroupIndex, f = a.group({
class: "apexcharts-series",
seriesName: v.escapeString(i.globals.seriesNames[g]),
rel: r + 1,
"data:realIndex": g
});
this.ctx.series.addCollapsedClassToSeries(f, g), t[r].length > 0 && (this.visibleI = this.visibleI + 1);
var x = 0, b = 0, m = 0;
this.yRatio.length > 1 && (this.yaxisIndex = i.globals.seriesYAxisReverseMap[g][0], m = g);
var y = this.barHelpers.initialPositions(g);
d = y.y, h = y.zeroW, c = y.x, b = y.barWidth, x = y.barHeight, n = y.xDivision, o = y.yDivision, l = y.zeroH;
for (var w = a.group({
class: "apexcharts-datalabels",
"data:realIndex": g
}), k = a.group({class: "apexcharts-rangebar-goals-markers"}), A = 0; A < i.globals.dataPoints; A++) {
var C = this.barHelpers.getStrokeWidth(r, A, g), S = this.seriesRangeStart[r][A],
L = this.seriesRangeEnd[r][A], M = null, P = null, I = null,
T = {x: c, y: d, strokeWidth: C, elSeries: f}, z = this.seriesLen;
if (i.config.plotOptions.bar.rangeBarGroupRows && (z = 1), void 0 === i.config.series[r].data[A]) break;
if (this.isHorizontal) {
I = d + x * this.visibleI;
var X = (o - x * z) / 2;
if (i.config.series[r].data[A].x) {
var R = this.detectOverlappingBars({
i: r,
j: A,
barYPosition: I,
srty: X,
barHeight: x,
yDivision: o,
initPositions: y
});
x = R.barHeight, I = R.barYPosition
}
b = (M = this.drawRangeBarPaths(u({
indexes: {i: r, j: A, realIndex: g},
barHeight: x,
barYPosition: I,
zeroW: h,
yDivision: o,
y1: S,
y2: L
}, T))).barWidth
} else {
i.globals.isXNumeric && (c = (i.globals.seriesX[r][A] - i.globals.minX) / this.xRatio - b / 2), P = c + b * this.visibleI;
var E = (n - b * z) / 2;
if (i.config.series[r].data[A].x) {
var Y = this.detectOverlappingBars({
i: r,
j: A,
barXPosition: P,
srtx: E,
barWidth: b,
xDivision: n,
initPositions: y
});
b = Y.barWidth, P = Y.barXPosition
}
x = (M = this.drawRangeColumnPaths(u({
indexes: {
i: r,
j: A,
realIndex: g,
translationsIndex: m
}, barWidth: b, barXPosition: P, zeroH: l, xDivision: n
}, T))).barHeight
}
var H = this.barHelpers.drawGoalLine({
barXPosition: M.barXPosition,
barYPosition: I,
goalX: M.goalX,
goalY: M.goalY,
barHeight: x,
barWidth: b
});
H && k.add(H), d = M.y, c = M.x;
var O = this.barHelpers.getPathFillColor(t, r, A, g);
this.renderSeries({
realIndex: g,
pathFill: O.color,
lineFill: O.useRangeColor ? O.color : i.globals.stroke.colors[g],
j: A,
i: r,
x: c,
y: d,
y1: S,
y2: L,
pathFrom: M.pathFrom,
pathTo: M.pathTo,
strokeWidth: C,
elSeries: f,
series: t,
barHeight: x,
barWidth: b,
barXPosition: P,
barYPosition: I,
columnGroupIndex: p,
elDataLabelsWrap: w,
elGoalsMarkers: k,
visibleSeries: this.visibleI,
type: "rangebar"
})
}
s.add(f)
}
return s
}
}, {
key: "detectOverlappingBars", value: function (t) {
var e = t.i, i = t.j, a = t.barYPosition, s = t.barXPosition, r = t.srty, n = t.srtx, o = t.barHeight,
l = t.barWidth, h = t.yDivision, c = t.xDivision, d = t.initPositions, u = this.w, g = [],
p = u.config.series[e].data[i].rangeName, f = u.config.series[e].data[i].x,
x = Array.isArray(f) ? f.join(" ") : f, b = u.globals.labels.map((function (t) {
return Array.isArray(t) ? t.join(" ") : t
})).indexOf(x), m = u.globals.seriesRange[e].findIndex((function (t) {
return t.x === x && t.overlaps.length > 0
}));
return this.isHorizontal ? (a = u.config.plotOptions.bar.rangeBarGroupRows ? r + h * b : r + o * this.visibleI + h * b, m > -1 && !u.config.plotOptions.bar.rangeBarOverlap && (g = u.globals.seriesRange[e][m].overlaps).indexOf(p) > -1 && (a = (o = d.barHeight / g.length) * this.visibleI + h * (100 - parseInt(this.barOptions.barHeight, 10)) / 100 / 2 + o * (this.visibleI + g.indexOf(p)) + h * b)) : (b > -1 && !u.globals.timescaleLabels.length && (s = u.config.plotOptions.bar.rangeBarGroupRows ? n + c * b : n + l * this.visibleI + c * b), m > -1 && !u.config.plotOptions.bar.rangeBarOverlap && (g = u.globals.seriesRange[e][m].overlaps).indexOf(p) > -1 && (s = (l = d.barWidth / g.length) * this.visibleI + c * (100 - parseInt(this.barOptions.barWidth, 10)) / 100 / 2 + l * (this.visibleI + g.indexOf(p)) + c * b)), {
barYPosition: a,
barXPosition: s,
barHeight: o,
barWidth: l
}
}
}, {
key: "drawRangeColumnPaths", value: function (t) {
var e = t.indexes, i = t.x, a = t.xDivision, s = t.barWidth, r = t.barXPosition, n = t.zeroH,
o = this.w, l = e.i, h = e.j, c = e.realIndex, d = e.translationsIndex, u = this.yRatio[d],
g = this.getRangeValue(c, h), p = Math.min(g.start, g.end), f = Math.max(g.start, g.end);
void 0 === this.series[l][h] || null === this.series[l][h] ? p = n : (p = n - p / u, f = n - f / u);
var x = Math.abs(f - p), b = this.barHelpers.getColumnPaths({
barXPosition: r,
barWidth: s,
y1: p,
y2: f,
strokeWidth: this.strokeWidth,
series: this.seriesRangeEnd,
realIndex: c,
i: c,
j: h,
w: o
});
if (o.globals.isXNumeric) {
var m = this.getBarXForNumericXAxis({x: i, j: h, realIndex: c, barWidth: s});
i = m.x, r = m.barXPosition
} else i += a;
return {
pathTo: b.pathTo,
pathFrom: b.pathFrom,
barHeight: x,
x: i,
y: g.start < 0 && g.end < 0 ? p : f,
goalY: this.barHelpers.getGoalValues("y", null, n, l, h, d),
barXPosition: r
}
}
}, {
key: "preventBarOverflow", value: function (t) {
var e = this.w;
return t < 0 && (t = 0), t > e.globals.gridWidth && (t = e.globals.gridWidth), t
}
}, {
key: "drawRangeBarPaths", value: function (t) {
var e = t.indexes, i = t.y, a = t.y1, s = t.y2, r = t.yDivision, n = t.barHeight, o = t.barYPosition,
l = t.zeroW, h = this.w, c = e.realIndex, d = e.j,
u = this.preventBarOverflow(l + a / this.invertedYRatio),
g = this.preventBarOverflow(l + s / this.invertedYRatio), p = this.getRangeValue(c, d),
f = Math.abs(g - u), x = this.barHelpers.getBarpaths({
barYPosition: o,
barHeight: n,
x1: u,
x2: g,
strokeWidth: this.strokeWidth,
series: this.seriesRangeEnd,
i: c,
realIndex: c,
j: d,
w: h
});
return h.globals.isXNumeric || (i += r), {
pathTo: x.pathTo,
pathFrom: x.pathFrom,
barWidth: f,
x: p.start < 0 && p.end < 0 ? u : g,
goalX: this.barHelpers.getGoalValues("x", l, null, c, d),
y: i
}
}
}, {
key: "getRangeValue", value: function (t, e) {
var i = this.w;
return {start: i.globals.seriesRangeStart[t][e], end: i.globals.seriesRangeEnd[t][e]}
}
}]), a
}(Ia), Da = function () {
function t(e) {
i(this, t), this.w = e.w, this.lineCtx = e
}
return s(t, [{
key: "sameValueSeriesFix", value: function (t, e) {
var i = this.w;
if (("gradient" === i.config.fill.type || "gradient" === i.config.fill.type[t]) && new Pi(this.lineCtx.ctx, i).seriesHaveSameValues(t)) {
var a = e[t].slice();
a[a.length - 1] = a[a.length - 1] + 1e-6, e[t] = a
}
return e
}
}, {
key: "calculatePoints", value: function (t) {
var e = t.series, i = t.realIndex, a = t.x, s = t.y, r = t.i, n = t.j, o = t.prevY, l = this.w, h = [],
c = [], d = this.lineCtx.categoryAxisCorrection + l.config.markers.offsetX;
return l.globals.isXNumeric && (d = (l.globals.seriesX[i][0] - l.globals.minX) / this.lineCtx.xRatio + l.config.markers.offsetX), 0 === n && (h.push(d), c.push(v.isNumber(e[r][0]) ? o + l.config.markers.offsetY : null)), h.push(a + l.config.markers.offsetX), c.push(v.isNumber(e[r][n + 1]) ? s + l.config.markers.offsetY : null), {
x: h,
y: c
}
}
}, {
key: "checkPreviousPaths", value: function (t) {
for (var e = t.pathFromLine, i = t.pathFromArea, a = t.realIndex, s = this.w, r = 0; r < s.globals.previousPaths.length; r++) {
var n = s.globals.previousPaths[r];
("line" === n.type || "area" === n.type) && n.paths.length > 0 && parseInt(n.realIndex, 10) === parseInt(a, 10) && ("line" === n.type ? (this.lineCtx.appendPathFrom = !1, e = s.globals.previousPaths[r].paths[0].d) : "area" === n.type && (this.lineCtx.appendPathFrom = !1, i = s.globals.previousPaths[r].paths[0].d, s.config.stroke.show && s.globals.previousPaths[r].paths[1] && (e = s.globals.previousPaths[r].paths[1].d)))
}
return {pathFromLine: e, pathFromArea: i}
}
}, {
key: "determineFirstPrevY", value: function (t) {
var e, i, a, s = t.i, r = t.realIndex, n = t.series, o = t.prevY, l = t.lineYPosition,
h = t.translationsIndex, c = this.w,
d = c.config.chart.stacked && !c.globals.comboCharts || c.config.chart.stacked && c.globals.comboCharts && (!this.w.config.chart.stackOnlyBar || "bar" === (null === (e = this.w.config.series[r]) || void 0 === e ? void 0 : e.type) || "column" === (null === (i = this.w.config.series[r]) || void 0 === i ? void 0 : i.type));
if (void 0 !== (null === (a = n[s]) || void 0 === a ? void 0 : a[0])) o = (l = d && s > 0 ? this.lineCtx.prevSeriesY[s - 1][0] : this.lineCtx.zeroY) - n[s][0] / this.lineCtx.yRatio[h] + 2 * (this.lineCtx.isReversed ? n[s][0] / this.lineCtx.yRatio[h] : 0); else if (d && s > 0 && void 0 === n[s][0]) for (var u = s - 1; u >= 0; u--) if (null !== n[u][0] && void 0 !== n[u][0]) {
o = l = this.lineCtx.prevSeriesY[u][0];
break
}
return {prevY: o, lineYPosition: l}
}
}]), t
}(), _a = function (t) {
for (var e, i, a, s, r = function (t) {
for (var e = [], i = t[0], a = t[1], s = e[0] = Ba(i, a), r = 1, n = t.length - 1; r < n; r++) i = a, a = t[r + 1], e[r] = .5 * (s + (s = Ba(i, a)));
return e[r] = s, e
}(t), n = t.length - 1, o = [], l = 0; l < n; l++) a = Ba(t[l], t[l + 1]), Math.abs(a) < 1e-6 ? r[l] = r[l + 1] = 0 : (s = (e = r[l] / a) * e + (i = r[l + 1] / a) * i) > 9 && (s = 3 * a / Math.sqrt(s), r[l] = s * e, r[l + 1] = s * i);
for (var h = 0; h <= n; h++) s = (t[Math.min(n, h + 1)][0] - t[Math.max(0, h - 1)][0]) / (6 * (1 + r[h] * r[h])), o.push([s || 0, r[h] * s || 0]);
return o
}, Na = function (t) {
var e = _a(t), i = t[1], a = t[0], s = [], r = e[1], n = e[0];
s.push(a, [a[0] + n[0], a[1] + n[1], i[0] - r[0], i[1] - r[1], i[0], i[1]]);
for (var o = 2, l = e.length; o < l; o++) {
var h = t[o], c = e[o];
s.push([h[0] - c[0], h[1] - c[1], h[0], h[1]])
}
return s
}, Wa = function (t, e, i) {
var a = t.slice(e, i);
if (e) {
if (i - e > 1 && a[1].length < 6) {
var s = a[0].length;
a[1] = [2 * a[0][s - 2] - a[0][s - 4], 2 * a[0][s - 1] - a[0][s - 3]].concat(a[1])
}
a[0] = a[0].slice(-2)
}
return a
};
function Ba(t, e) {
return (e[1] - t[1]) / (e[0] - t[0])
}
var Ga = function () {
function t(e, a, s) {
i(this, t), this.ctx = e, this.w = e.w, this.xyRatios = a, this.pointsChart = !("bubble" !== this.w.config.chart.type && "scatter" !== this.w.config.chart.type) || s, this.scatter = new Ui(this.ctx), this.noNegatives = this.w.globals.minX === Number.MAX_VALUE, this.lineHelpers = new Da(this), this.markers = new Vi(this.ctx), this.prevSeriesY = [], this.categoryAxisCorrection = 0, this.yaxisIndex = 0
}
return s(t, [{
key: "draw", value: function (t, e, i, a) {
var s, r = this.w, n = new Mi(this.ctx), o = r.globals.comboCharts ? e : r.config.chart.type,
l = n.group({class: "apexcharts-".concat(o, "-series apexcharts-plot-series")}),
h = new Pi(this.ctx, r);
this.yRatio = this.xyRatios.yRatio, this.zRatio = this.xyRatios.zRatio, this.xRatio = this.xyRatios.xRatio, this.baseLineY = this.xyRatios.baseLineY, t = h.getLogSeries(t), this.yRatio = h.getLogYRatios(this.yRatio), this.prevSeriesY = [];
for (var c = [], d = 0; d < t.length; d++) {
t = this.lineHelpers.sameValueSeriesFix(d, t);
var g = r.globals.comboCharts ? i[d] : d, p = this.yRatio.length > 1 ? g : 0;
this._initSerieVariables(t, d, g);
var f = [], x = [], b = [], m = r.globals.padHorizontal + this.categoryAxisCorrection;
this.ctx.series.addCollapsedClassToSeries(this.elSeries, g), r.globals.isXNumeric && r.globals.seriesX.length > 0 && (m = (r.globals.seriesX[g][0] - r.globals.minX) / this.xRatio), b.push(m);
var v, y = m, w = void 0, k = y, A = this.zeroY, C = this.zeroY;
A = this.lineHelpers.determineFirstPrevY({
i: d,
realIndex: g,
series: t,
prevY: A,
lineYPosition: 0,
translationsIndex: p
}).prevY, "monotoneCubic" === r.config.stroke.curve && null === t[d][0] ? f.push(null) : f.push(A), v = A;
"rangeArea" === o && (w = C = this.lineHelpers.determineFirstPrevY({
i: d,
realIndex: g,
series: a,
prevY: C,
lineYPosition: 0,
translationsIndex: p
}).prevY, x.push(null !== f[0] ? C : null));
var S = this._calculatePathsFrom({
type: o,
series: t,
i: d,
realIndex: g,
translationsIndex: p,
prevX: k,
prevY: A,
prevY2: C
}), L = [f[0]], M = [x[0]], P = {
type: o,
series: t,
realIndex: g,
translationsIndex: p,
i: d,
x: m,
y: 1,
pX: y,
pY: v,
pathsFrom: S,
linePaths: [],
areaPaths: [],
seriesIndex: i,
lineYPosition: 0,
xArrj: b,
yArrj: f,
y2Arrj: x,
seriesRangeEnd: a
}, I = this._iterateOverDataPoints(u(u({}, P), {}, {
iterations: "rangeArea" === o ? t[d].length - 1 : void 0,
isRangeStart: !0
}));
if ("rangeArea" === o) {
for (var T = this._calculatePathsFrom({
series: a,
i: d,
realIndex: g,
prevX: k,
prevY: C
}), z = this._iterateOverDataPoints(u(u({}, P), {}, {
series: a,
xArrj: [m],
yArrj: L,
y2Arrj: M,
pY: w,
areaPaths: I.areaPaths,
pathsFrom: T,
iterations: a[d].length - 1,
isRangeStart: !1
})), X = I.linePaths.length / 2, R = 0; R < X; R++) I.linePaths[R] = z.linePaths[R + X] + I.linePaths[R];
I.linePaths.splice(X), I.pathFromLine = z.pathFromLine + I.pathFromLine
} else I.pathFromArea += "z";
this._handlePaths({
type: o,
realIndex: g,
i: d,
paths: I
}), this.elSeries.add(this.elPointsMain), this.elSeries.add(this.elDataLabelsWrap), c.push(this.elSeries)
}
if (void 0 !== (null === (s = r.config.series[0]) || void 0 === s ? void 0 : s.zIndex) && c.sort((function (t, e) {
return Number(t.node.getAttribute("zIndex")) - Number(e.node.getAttribute("zIndex"))
})), r.config.chart.stacked) for (var E = c.length - 1; E >= 0; E--) l.add(c[E]); else for (var Y = 0; Y < c.length; Y++) l.add(c[Y]);
return l
}
}, {
key: "_initSerieVariables", value: function (t, e, i) {
var a = this.w, s = new Mi(this.ctx);
this.xDivision = a.globals.gridWidth / (a.globals.dataPoints - ("on" === a.config.xaxis.tickPlacement ? 1 : 0)), this.strokeWidth = Array.isArray(a.config.stroke.width) ? a.config.stroke.width[i] : a.config.stroke.width;
var r = 0;
if (this.yRatio.length > 1 && (this.yaxisIndex = a.globals.seriesYAxisReverseMap[i], r = i), this.isReversed = a.config.yaxis[this.yaxisIndex] && a.config.yaxis[this.yaxisIndex].reversed, this.zeroY = a.globals.gridHeight - this.baseLineY[r] - (this.isReversed ? a.globals.gridHeight : 0) + (this.isReversed ? 2 * this.baseLineY[r] : 0), this.areaBottomY = this.zeroY, (this.zeroY > a.globals.gridHeight || "end" === a.config.plotOptions.area.fillTo) && (this.areaBottomY = a.globals.gridHeight), this.categoryAxisCorrection = this.xDivision / 2, this.elSeries = s.group({
class: "apexcharts-series",
zIndex: void 0 !== a.config.series[i].zIndex ? a.config.series[i].zIndex : i,
seriesName: v.escapeString(a.globals.seriesNames[i])
}), this.elPointsMain = s.group({
class: "apexcharts-series-markers-wrap",
"data:realIndex": i
}), a.globals.hasNullValues) {
var n = this.markers.plotChartMarkers({
pointsPos: {
x: [0],
y: [a.globals.gridHeight + a.globals.markers.largestSize]
}, seriesIndex: e, j: 0, pSize: .1, alwaysDrawMarker: !0, isVirtualPoint: !0
});
null !== n && this.elPointsMain.add(n)
}
this.elDataLabelsWrap = s.group({class: "apexcharts-datalabels", "data:realIndex": i});
var o = t[e].length === a.globals.dataPoints;
this.elSeries.attr({"data:longestSeries": o, rel: e + 1, "data:realIndex": i}), this.appendPathFrom = !0
}
}, {
key: "_calculatePathsFrom", value: function (t) {
var e, i, a, s, r = t.type, n = t.series, o = t.i, l = t.realIndex, h = t.translationsIndex,
c = t.prevX, d = t.prevY, u = t.prevY2, g = this.w, p = new Mi(this.ctx);
if (null === n[o][0]) {
for (var f = 0; f < n[o].length; f++) if (null !== n[o][f]) {
c = this.xDivision * f, d = this.zeroY - n[o][f] / this.yRatio[h], e = p.move(c, d), i = p.move(c, this.areaBottomY);
break
}
} else e = p.move(c, d), "rangeArea" === r && (e = p.move(c, u) + p.line(c, d)), i = p.move(c, this.areaBottomY) + p.line(c, d);
if (a = p.move(0, this.areaBottomY) + p.line(0, this.areaBottomY), s = p.move(0, this.areaBottomY) + p.line(0, this.areaBottomY), g.globals.previousPaths.length > 0) {
var x = this.lineHelpers.checkPreviousPaths({pathFromLine: a, pathFromArea: s, realIndex: l});
a = x.pathFromLine, s = x.pathFromArea
}
return {prevX: c, prevY: d, linePath: e, areaPath: i, pathFromLine: a, pathFromArea: s}
}
}, {
key: "_handlePaths", value: function (t) {
var e = t.type, i = t.realIndex, a = t.i, s = t.paths, r = this.w, n = new Mi(this.ctx),
o = new ji(this.ctx);
this.prevSeriesY.push(s.yArrj), r.globals.seriesXvalues[i] = s.xArrj, r.globals.seriesYvalues[i] = s.yArrj;
var l = r.config.forecastDataPoints;
if (l.count > 0 && "rangeArea" !== e) {
var h = r.globals.seriesXvalues[i][r.globals.seriesXvalues[i].length - l.count - 1],
c = n.drawRect(h, 0, r.globals.gridWidth, r.globals.gridHeight, 0);
r.globals.dom.elForecastMask.appendChild(c.node);
var d = n.drawRect(0, 0, h, r.globals.gridHeight, 0);
r.globals.dom.elNonForecastMask.appendChild(d.node)
}
this.pointsChart || r.globals.delayedElements.push({el: this.elPointsMain.node, index: i});
var g = {
i: a,
realIndex: i,
animationDelay: a,
initialSpeed: r.config.chart.animations.speed,
dataChangeSpeed: r.config.chart.animations.dynamicAnimation.speed,
className: "apexcharts-".concat(e)
};
if ("area" === e) for (var p = o.fillPath({seriesNumber: i}), f = 0; f < s.areaPaths.length; f++) {
var x = n.renderPaths(u(u({}, g), {}, {
pathFrom: s.pathFromArea,
pathTo: s.areaPaths[f],
stroke: "none",
strokeWidth: 0,
strokeLineCap: null,
fill: p
}));
this.elSeries.add(x)
}
if (r.config.stroke.show && !this.pointsChart) {
var b = null;
if ("line" === e) b = o.fillPath({
seriesNumber: i,
i: a
}); else if ("solid" === r.config.stroke.fill.type) b = r.globals.stroke.colors[i]; else {
var m = r.config.fill;
r.config.fill = r.config.stroke.fill, b = o.fillPath({seriesNumber: i, i: a}), r.config.fill = m
}
for (var v = 0; v < s.linePaths.length; v++) {
var y = b;
"rangeArea" === e && (y = o.fillPath({seriesNumber: i}));
var w = u(u({}, g), {}, {
pathFrom: s.pathFromLine,
pathTo: s.linePaths[v],
stroke: b,
strokeWidth: this.strokeWidth,
strokeLineCap: r.config.stroke.lineCap,
fill: "rangeArea" === e ? y : "none"
}), k = n.renderPaths(w);
if (this.elSeries.add(k), k.attr("fill-rule", "evenodd"), l.count > 0 && "rangeArea" !== e) {
var A = n.renderPaths(w);
A.node.setAttribute("stroke-dasharray", l.dashArray), l.strokeWidth && A.node.setAttribute("stroke-width", l.strokeWidth), this.elSeries.add(A), A.attr("clip-path", "url(#forecastMask".concat(r.globals.cuid, ")")), k.attr("clip-path", "url(#nonForecastMask".concat(r.globals.cuid, ")"))
}
}
}
}
}, {
key: "_iterateOverDataPoints", value: function (t) {
var e, i, a = this, s = t.type, r = t.series, n = t.iterations, o = t.realIndex,
l = t.translationsIndex, h = t.i, c = t.x, d = t.y, u = t.pX, g = t.pY, p = t.pathsFrom,
f = t.linePaths, x = t.areaPaths, b = t.seriesIndex, m = t.lineYPosition, y = t.xArrj, w = t.yArrj,
k = t.y2Arrj, A = t.isRangeStart, C = t.seriesRangeEnd, S = this.w, L = new Mi(this.ctx),
M = this.yRatio, P = p.prevY, I = p.linePath, T = p.areaPath, z = p.pathFromLine,
X = p.pathFromArea, R = v.isNumber(S.globals.minYArr[o]) ? S.globals.minYArr[o] : S.globals.minY;
n || (n = S.globals.dataPoints > 1 ? S.globals.dataPoints - 1 : S.globals.dataPoints);
var E = function (t, e) {
return e - t / M[l] + 2 * (a.isReversed ? t / M[l] : 0)
}, Y = d,
H = S.config.chart.stacked && !S.globals.comboCharts || S.config.chart.stacked && S.globals.comboCharts && (!this.w.config.chart.stackOnlyBar || "bar" === (null === (e = this.w.config.series[o]) || void 0 === e ? void 0 : e.type) || "column" === (null === (i = this.w.config.series[o]) || void 0 === i ? void 0 : i.type)),
O = S.config.stroke.curve;
Array.isArray(O) && (O = Array.isArray(b) ? O[b[h]] : O[h]);
for (var F, D = 0, _ = 0; _ < n && 0 !== r[h].length; _++) {
var N = void 0 === r[h][_ + 1] || null === r[h][_ + 1];
if (S.globals.isXNumeric) {
var W = S.globals.seriesX[o][_ + 1];
void 0 === S.globals.seriesX[o][_ + 1] && (W = S.globals.seriesX[o][n - 1]), c = (W - S.globals.minX) / this.xRatio
} else c += this.xDivision;
if (H) if (h > 0 && S.globals.collapsedSeries.length < S.config.series.length - 1) {
m = this.prevSeriesY[function (t) {
for (var e = t; e > 0; e--) {
if (!(S.globals.collapsedSeriesIndices.indexOf((null == b ? void 0 : b[e]) || e) > -1)) return e;
e--
}
return 0
}(h - 1)][_ + 1]
} else m = this.zeroY; else m = this.zeroY;
N ? d = E(R, m) : (d = E(r[h][_ + 1], m), "rangeArea" === s && (Y = E(C[h][_ + 1], m))), y.push(null === r[h][_ + 1] ? null : c), !N || "smooth" !== S.config.stroke.curve && "monotoneCubic" !== S.config.stroke.curve ? (w.push(d), k.push(Y)) : (w.push(null), k.push(null));
var B = this.lineHelpers.calculatePoints({
series: r,
x: c,
y: d,
realIndex: o,
i: h,
j: _,
prevY: P
}), G = this._createPaths({
type: s,
series: r,
i: h,
realIndex: o,
j: _,
x: c,
y: d,
y2: Y,
xArrj: y,
yArrj: w,
y2Arrj: k,
pX: u,
pY: g,
pathState: D,
segmentStartX: F,
linePath: I,
areaPath: T,
linePaths: f,
areaPaths: x,
curve: O,
isRangeStart: A
});
x = G.areaPaths, f = G.linePaths, u = G.pX, g = G.pY, D = G.pathState, F = G.segmentStartX, T = G.areaPath, I = G.linePath, !this.appendPathFrom || S.globals.hasNullValues || "monotoneCubic" === O && "rangeArea" === s || (z += L.line(c, this.areaBottomY), X += L.line(c, this.areaBottomY)), this.handleNullDataPoints(r, B, h, _, o), this._handleMarkersAndLabels({
type: s,
pointsPos: B,
i: h,
j: _,
realIndex: o,
isRangeStart: A
})
}
return {
yArrj: w,
xArrj: y,
pathFromArea: X,
areaPaths: x,
pathFromLine: z,
linePaths: f,
linePath: I,
areaPath: T
}
}
}, {
key: "_handleMarkersAndLabels", value: function (t) {
var e = t.type, i = t.pointsPos, a = t.isRangeStart, s = t.i, r = t.j, n = t.realIndex, o = this.w,
l = new qi(this.ctx);
if (this.pointsChart) this.scatter.draw(this.elSeries, r, {
realIndex: n,
pointsPos: i,
zRatio: this.zRatio,
elParent: this.elPointsMain
}); else {
o.globals.series[s].length > 1 && this.elPointsMain.node.classList.add("apexcharts-element-hidden");
var h = this.markers.plotChartMarkers({pointsPos: i, seriesIndex: n, j: r + 1});
null !== h && this.elPointsMain.add(h)
}
var c = l.drawDataLabel({type: e, isRangeStart: a, pos: i, i: n, j: r + 1});
null !== c && this.elDataLabelsWrap.add(c)
}
}, {
key: "_createPaths", value: function (t) {
var e = t.type, i = t.series, a = t.i;
t.realIndex;
var s, r = t.j, n = t.x, o = t.y, l = t.xArrj, h = t.yArrj, c = t.y2, d = t.y2Arrj, u = t.pX, g = t.pY,
p = t.pathState, f = t.segmentStartX, x = t.linePath, b = t.areaPath, m = t.linePaths,
v = t.areaPaths, y = t.curve, w = t.isRangeStart, k = new Mi(this.ctx), A = this.areaBottomY,
C = "rangeArea" === e, S = "rangeArea" === e && w;
switch (y) {
case"monotoneCubic":
var L = w ? h : d;
switch (p) {
case 0:
if (null === L[r + 1]) break;
p = 1;
case 1:
if (!(C ? l.length === i[a].length : r === i[a].length - 2)) break;
case 2:
var M = w ? l : l.slice().reverse(), P = w ? L : L.slice().reverse(),
I = (s = P, M.map((function (t, e) {
return [t, s[e]]
})).filter((function (t) {
return null !== t[1]
}))), T = I.length > 1 ? Na(I) : I, z = [];
C && (S ? v = I : z = v.reverse());
var X = 0, R = 0;
if (function (t, e) {
for (var i = function (t) {
var e = [], i = 0;
return t.forEach((function (t) {
null !== t ? i++ : i > 0 && (e.push(i), i = 0)
})), i > 0 && e.push(i), e
}(t), a = [], s = 0, r = 0; s < i.length; r += i[s++]) a[s] = Wa(e, r, r + i[s]);
return a
}(P, T).forEach((function (t) {
X++;
var e = function (t) {
for (var e = "", i = 0; i < t.length; i++) {
var a = t[i], s = a.length;
s > 4 ? (e += "C".concat(a[0], ", ").concat(a[1]), e += ", ".concat(a[2], ", ").concat(a[3]), e += ", ".concat(a[4], ", ").concat(a[5])) : s > 2 && (e += "S".concat(a[0], ", ").concat(a[1]), e += ", ".concat(a[2], ", ").concat(a[3]))
}
return e
}(t), i = R, a = (R += t.length) - 1;
S ? x = k.move(I[i][0], I[i][1]) + e : C ? x = k.move(z[i][0], z[i][1]) + k.line(I[i][0], I[i][1]) + e + k.line(z[a][0], z[a][1]) : (x = k.move(I[i][0], I[i][1]) + e, b = x + k.line(I[a][0], A) + k.line(I[i][0], A) + "z", v.push(b)), m.push(x)
})), C && X > 1 && !S) {
var E = m.slice(X).reverse();
m.splice(X), E.forEach((function (t) {
return m.push(t)
}))
}
p = 0
}
break;
case"smooth":
var Y = .35 * (n - u);
if (null === i[a][r]) p = 0; else switch (p) {
case 0:
if (f = u, x = S ? k.move(u, d[r]) + k.line(u, g) : k.move(u, g), b = k.move(u, g), null === i[a][r + 1] || void 0 === i[a][r + 1]) {
m.push(x), v.push(b);
break
}
if (p = 1, r < i[a].length - 2) {
var H = k.curve(u + Y, g, n - Y, o, n, o);
x += H, b += H;
break
}
case 1:
if (null === i[a][r + 1]) x += S ? k.line(u, c) : k.move(u, g), b += k.line(u, A) + k.line(f, A) + "z", m.push(x), v.push(b), p = -1; else {
var O = k.curve(u + Y, g, n - Y, o, n, o);
x += O, b += O, r >= i[a].length - 2 && (S && (x += k.curve(n, o, n, o, n, c) + k.move(n, c)), b += k.curve(n, o, n, o, n, A) + k.line(f, A) + "z", m.push(x), v.push(b), p = -1)
}
}
u = n, g = o;
break;
default:
var F = function (t, e, i) {
var a = [];
switch (t) {
case"stepline":
a = k.line(e, null, "H") + k.line(null, i, "V");
break;
case"linestep":
a = k.line(null, i, "V") + k.line(e, null, "H");
break;
case"straight":
a = k.line(e, i)
}
return a
};
if (null === i[a][r]) p = 0; else switch (p) {
case 0:
if (f = u, x = S ? k.move(u, d[r]) + k.line(u, g) : k.move(u, g), b = k.move(u, g), null === i[a][r + 1] || void 0 === i[a][r + 1]) {
m.push(x), v.push(b);
break
}
if (p = 1, r < i[a].length - 2) {
var D = F(y, n, o);
x += D, b += D;
break
}
case 1:
if (null === i[a][r + 1]) x += S ? k.line(u, c) : k.move(u, g), b += k.line(u, A) + k.line(f, A) + "z", m.push(x), v.push(b), p = -1; else {
var _ = F(y, n, o);
x += _, b += _, r >= i[a].length - 2 && (S && (x += k.line(n, c)), b += k.line(n, A) + k.line(f, A) + "z", m.push(x), v.push(b), p = -1)
}
}
u = n, g = o
}
return {
linePaths: m,
areaPaths: v,
pX: u,
pY: g,
pathState: p,
segmentStartX: f,
linePath: x,
areaPath: b
}
}
}, {
key: "handleNullDataPoints", value: function (t, e, i, a, s) {
var r = this.w;
if (null === t[i][a] && r.config.markers.showNullDataPoints || 1 === t[i].length) {
var n = this.strokeWidth - r.config.markers.strokeWidth / 2;
n > 0 || (n = 0);
var o = this.markers.plotChartMarkers({
pointsPos: e,
seriesIndex: s,
j: a + 1,
pSize: n,
alwaysDrawMarker: !0
});
null !== o && this.elPointsMain.add(o)
}
}
}]), t
}();
window.TreemapSquared = {}, window.TreemapSquared.generate = function () {
function t(e, i, a, s) {
this.xoffset = e, this.yoffset = i, this.height = s, this.width = a, this.shortestEdge = function () {
return Math.min(this.height, this.width)
}, this.getCoordinates = function (t) {
var e, i = [], a = this.xoffset, s = this.yoffset, n = r(t) / this.height, o = r(t) / this.width;
if (this.width >= this.height) for (e = 0; e < t.length; e++) i.push([a, s, a + n, s + t[e] / n]), s += t[e] / n; else for (e = 0; e < t.length; e++) i.push([a, s, a + t[e] / o, s + o]), a += t[e] / o;
return i
}, this.cutArea = function (e) {
var i;
if (this.width >= this.height) {
var a = e / this.height, s = this.width - a;
i = new t(this.xoffset + a, this.yoffset, s, this.height)
} else {
var r = e / this.width, n = this.height - r;
i = new t(this.xoffset, this.yoffset + r, this.width, n)
}
return i
}
}
function e(e, a, s, n, o) {
n = void 0 === n ? 0 : n, o = void 0 === o ? 0 : o;
var l = i(function (t, e) {
var i, a = [], s = e / r(t);
for (i = 0; i < t.length; i++) a[i] = t[i] * s;
return a
}(e, a * s), [], new t(n, o, a, s), []);
return function (t) {
var e, i, a = [];
for (e = 0; e < t.length; e++) for (i = 0; i < t[e].length; i++) a.push(t[e][i]);
return a
}(l)
}
function i(t, e, s, n) {
var o, l, h;
if (0 !== t.length) return o = s.shortestEdge(), function (t, e, i) {
var s;
if (0 === t.length) return !0;
(s = t.slice()).push(e);
var r = a(t, i), n = a(s, i);
return r >= n
}(e, l = t[0], o) ? (e.push(l), i(t.slice(1), e, s, n)) : (h = s.cutArea(r(e), n), n.push(s.getCoordinates(e)), i(t, [], h, n)), n;
n.push(s.getCoordinates(e))
}
function a(t, e) {
var i = Math.min.apply(Math, t), a = Math.max.apply(Math, t), s = r(t);
return Math.max(Math.pow(e, 2) * a / Math.pow(s, 2), Math.pow(s, 2) / (Math.pow(e, 2) * i))
}
function s(t) {
return t && t.constructor === Array
}
function r(t) {
var e, i = 0;
for (e = 0; e < t.length; e++) i += t[e];
return i
}
function n(t) {
var e, i = 0;
if (s(t[0])) for (e = 0; e < t.length; e++) i += n(t[e]); else i = r(t);
return i
}
return function t(i, a, r, o, l) {
o = void 0 === o ? 0 : o, l = void 0 === l ? 0 : l;
var h, c, d = [], u = [];
if (s(i[0])) {
for (c = 0; c < i.length; c++) d[c] = n(i[c]);
for (h = e(d, a, r, o, l), c = 0; c < i.length; c++) u.push(t(i[c], h[c][2] - h[c][0], h[c][3] - h[c][1], h[c][0], h[c][1]))
} else u = e(i, a, r, o, l);
return u
}
}();
var ja = function () {
function t(e, a) {
i(this, t), this.ctx = e, this.w = e.w, this.strokeWidth = this.w.config.stroke.width, this.helpers = new Xa(e), this.dynamicAnim = this.w.config.chart.animations.dynamicAnimation, this.labels = []
}
return s(t, [{
key: "draw", value: function (t) {
var e = this, i = this.w, a = new Mi(this.ctx), s = new ji(this.ctx),
r = a.group({class: "apexcharts-treemap"});
if (i.globals.noData) return r;
var n = [];
return t.forEach((function (t) {
var e = t.map((function (t) {
return Math.abs(t)
}));
n.push(e)
})), this.negRange = this.helpers.checkColorRange(), i.config.series.forEach((function (t, i) {
t.data.forEach((function (t) {
Array.isArray(e.labels[i]) || (e.labels[i] = []), e.labels[i].push(t.x)
}))
})), window.TreemapSquared.generate(n, i.globals.gridWidth, i.globals.gridHeight).forEach((function (n, o) {
var l = a.group({
class: "apexcharts-series apexcharts-treemap-series",
seriesName: v.escapeString(i.globals.seriesNames[o]),
rel: o + 1,
"data:realIndex": o
});
if (i.config.chart.dropShadow.enabled) {
var h = i.config.chart.dropShadow;
new Li(e.ctx).dropShadow(r, h, o)
}
var c = a.group({class: "apexcharts-data-labels"}),
d = {xMin: 1 / 0, yMin: 1 / 0, xMax: -1 / 0, yMax: -1 / 0};
n.forEach((function (r, n) {
var h = r[0], c = r[1], u = r[2], g = r[3];
d.xMin = Math.min(d.xMin, h), d.yMin = Math.min(d.yMin, c), d.xMax = Math.max(d.xMax, u), d.yMax = Math.max(d.yMax, g);
var p = e.helpers.getShadeColor(i.config.chart.type, o, n, e.negRange), f = p.color,
x = s.fillPath({color: f, seriesNumber: o, dataPointIndex: n}),
b = a.drawRect(h, c, u - h, g - c, i.config.plotOptions.treemap.borderRadius, "#fff", 1, e.strokeWidth, i.config.plotOptions.treemap.useFillColorAsStroke ? f : i.globals.stroke.colors[o]);
b.attr({
cx: h,
cy: c,
index: o,
i: o,
j: n,
width: u - h,
height: g - c,
fill: x
}), b.node.classList.add("apexcharts-treemap-rect"), e.helpers.addListeners(b);
var m = {x: h + (u - h) / 2, y: c + (g - c) / 2, width: 0, height: 0},
v = {x: h, y: c, width: u - h, height: g - c};
if (i.config.chart.animations.enabled && !i.globals.dataChanged) {
var y = 1;
i.globals.resized || (y = i.config.chart.animations.speed), e.animateTreemap(b, m, v, y)
}
if (i.globals.dataChanged) {
var w = 1;
e.dynamicAnim.enabled && i.globals.shouldAnimate && (w = e.dynamicAnim.speed, i.globals.previousPaths[o] && i.globals.previousPaths[o][n] && i.globals.previousPaths[o][n].rect && (m = i.globals.previousPaths[o][n].rect), e.animateTreemap(b, m, v, w))
}
var k = e.getFontSize(r), A = i.config.dataLabels.formatter(e.labels[o][n], {
value: i.globals.series[o][n],
seriesIndex: o,
dataPointIndex: n,
w: i
});
"truncate" === i.config.plotOptions.treemap.dataLabels.format && (k = parseInt(i.config.dataLabels.style.fontSize, 10), A = e.truncateLabels(A, k, h, c, u, g));
var C = null;
i.globals.series[o][n] && (C = e.helpers.calculateDataLabels({
text: A,
x: (h + u) / 2,
y: (c + g) / 2 + e.strokeWidth / 2 + k / 3,
i: o,
j: n,
colorProps: p,
fontSize: k,
series: t
})), i.config.dataLabels.enabled && C && e.rotateToFitLabel(C, k, A, h, c, u, g), l.add(b), null !== C && l.add(C)
}));
var u = i.config.plotOptions.treemap.seriesTitle;
if (i.config.series.length > 1 && u && u.show) {
var g = i.config.series[o].name || "";
if (g && d.xMin < 1 / 0 && d.yMin < 1 / 0) {
var p = u.offsetX, f = u.offsetY, x = u.borderColor, b = u.borderWidth, m = u.borderRadius,
y = u.style, w = y.color || i.config.chart.foreColor, k = {
left: y.padding.left,
right: y.padding.right,
top: y.padding.top,
bottom: y.padding.bottom
}, A = a.getTextRects(g, y.fontSize, y.fontFamily), C = A.width + k.left + k.right,
S = A.height + k.top + k.bottom, L = d.xMin + (p || 0), M = d.yMin + (f || 0),
P = a.drawRect(L, M, C, S, m, y.background, 1, b, x), I = a.drawText({
x: L + k.left,
y: M + k.top + .75 * A.height,
text: g,
fontSize: y.fontSize,
fontFamily: y.fontFamily,
fontWeight: y.fontWeight,
foreColor: w,
cssClass: y.cssClass || ""
});
l.add(P), l.add(I)
}
}
l.add(c), r.add(l)
})), r
}
}, {
key: "getFontSize", value: function (t) {
var e = this.w;
var i = function t(e) {
var i, a = 0;
if (Array.isArray(e[0])) for (i = 0; i < e.length; i++) a += t(e[i]); else for (i = 0; i < e.length; i++) a += e[i].length;
return a
}(this.labels) / function t(e) {
var i, a = 0;
if (Array.isArray(e[0])) for (i = 0; i < e.length; i++) a += t(e[i]); else for (i = 0; i < e.length; i++) a += 1;
return a
}(this.labels);
return function (t, a) {
var s = t * a, r = Math.pow(s, .5);
return Math.min(r / i, parseInt(e.config.dataLabels.style.fontSize, 10))
}(t[2] - t[0], t[3] - t[1])
}
}, {
key: "rotateToFitLabel", value: function (t, e, i, a, s, r, n) {
var o = new Mi(this.ctx), l = o.getTextRects(i, e);
if (l.width + this.w.config.stroke.width + 5 > r - a && l.width <= n - s) {
var h = o.rotateAroundCenter(t.node);
t.node.setAttribute("transform", "rotate(-90 ".concat(h.x, " ").concat(h.y, ") translate(").concat(l.height / 3, ")"))
}
}
}, {
key: "truncateLabels", value: function (t, e, i, a, s, r) {
var n = new Mi(this.ctx),
o = n.getTextRects(t, e).width + this.w.config.stroke.width + 5 > s - i && r - a > s - i ? r - a : s - i,
l = n.getTextBasedOnMaxWidth({text: t, maxWidth: o, fontSize: e});
return t.length !== l.length && o / e < 5 ? "" : l
}
}, {
key: "animateTreemap", value: function (t, e, i, a) {
var s = new y(this.ctx);
s.animateRect(t, e, i, a, (function () {
s.animationCompleted(t)
}))
}
}]), t
}(), Va = 86400, Ua = 10 / Va, qa = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w, this.timeScaleArray = [], this.utc = this.w.config.xaxis.labels.datetimeUTC
}
return s(t, [{
key: "calculateTimeScaleTicks", value: function (t, e) {
var i = this, a = this.w;
if (a.globals.allSeriesCollapsed) return a.globals.labels = [], a.globals.timescaleLabels = [], [];
var s = new zi(this.ctx), r = (e - t) / 864e5;
this.determineInterval(r), a.globals.disableZoomIn = !1, a.globals.disableZoomOut = !1, r < Ua ? a.globals.disableZoomIn = !0 : r > 5e4 && (a.globals.disableZoomOut = !0);
var n = s.getTimeUnitsfromTimestamp(t, e, this.utc), o = a.globals.gridWidth / r, l = o / 24,
h = l / 60, c = h / 60, d = Math.floor(24 * r), g = Math.floor(1440 * r), p = Math.floor(r * Va),
f = Math.floor(r), x = Math.floor(r / 30), b = Math.floor(r / 365), m = {
minMillisecond: n.minMillisecond,
minSecond: n.minSecond,
minMinute: n.minMinute,
minHour: n.minHour,
minDate: n.minDate,
minMonth: n.minMonth,
minYear: n.minYear
}, v = {
firstVal: m,
currentMillisecond: m.minMillisecond,
currentSecond: m.minSecond,
currentMinute: m.minMinute,
currentHour: m.minHour,
currentMonthDate: m.minDate,
currentDate: m.minDate,
currentMonth: m.minMonth,
currentYear: m.minYear,
daysWidthOnXAxis: o,
hoursWidthOnXAxis: l,
minutesWidthOnXAxis: h,
secondsWidthOnXAxis: c,
numberOfSeconds: p,
numberOfMinutes: g,
numberOfHours: d,
numberOfDays: f,
numberOfMonths: x,
numberOfYears: b
};
switch (this.tickInterval) {
case"years":
this.generateYearScale(v);
break;
case"months":
case"half_year":
this.generateMonthScale(v);
break;
case"months_days":
case"months_fortnight":
case"days":
case"week_days":
this.generateDayScale(v);
break;
case"hours":
this.generateHourScale(v);
break;
case"minutes_fives":
case"minutes":
this.generateMinuteScale(v);
break;
case"seconds_tens":
case"seconds_fives":
case"seconds":
this.generateSecondScale(v)
}
var y = this.timeScaleArray.map((function (t) {
var e = {
position: t.position,
unit: t.unit,
year: t.year,
day: t.day ? t.day : 1,
hour: t.hour ? t.hour : 0,
month: t.month + 1
};
return "month" === t.unit ? u(u({}, e), {}, {
day: 1,
value: t.value + 1
}) : "day" === t.unit || "hour" === t.unit ? u(u({}, e), {}, {value: t.value}) : "minute" === t.unit ? u(u({}, e), {}, {
value: t.value,
minute: t.value
}) : "second" === t.unit ? u(u({}, e), {}, {value: t.value, minute: t.minute, second: t.second}) : t
}));
return y.filter((function (t) {
var e = 1, s = Math.ceil(a.globals.gridWidth / 120), r = t.value;
void 0 !== a.config.xaxis.tickAmount && (s = a.config.xaxis.tickAmount), y.length > s && (e = Math.floor(y.length / s));
var n = !1, o = !1;
switch (i.tickInterval) {
case"years":
"year" === t.unit && (n = !0);
break;
case"half_year":
e = 7, "year" === t.unit && (n = !0);
break;
case"months":
e = 1, "year" === t.unit && (n = !0);
break;
case"months_fortnight":
e = 15, "year" !== t.unit && "month" !== t.unit || (n = !0), 30 === r && (o = !0);
break;
case"months_days":
e = 10, "month" === t.unit && (n = !0), 30 === r && (o = !0);
break;
case"week_days":
e = 8, "month" === t.unit && (n = !0);
break;
case"days":
e = 1, "month" === t.unit && (n = !0);
break;
case"hours":
"day" === t.unit && (n = !0);
break;
case"minutes_fives":
case"seconds_fives":
r % 5 != 0 && (o = !0);
break;
case"seconds_tens":
r % 10 != 0 && (o = !0)
}
if ("hours" === i.tickInterval || "minutes_fives" === i.tickInterval || "seconds_tens" === i.tickInterval || "seconds_fives" === i.tickInterval) {
if (!o) return !0
} else if ((r % e == 0 || n) && !o) return !0
}))
}
}, {
key: "recalcDimensionsBasedOnFormat", value: function (t, e) {
var i = this.w, a = this.formatDates(t), s = this.removeOverlappingTS(a);
i.globals.timescaleLabels = s.slice(), new fa(this.ctx).plotCoords()
}
}, {
key: "determineInterval", value: function (t) {
var e = 24 * t, i = 60 * e;
switch (!0) {
case t / 365 > 5:
this.tickInterval = "years";
break;
case t > 800:
this.tickInterval = "half_year";
break;
case t > 180:
this.tickInterval = "months";
break;
case t > 90:
this.tickInterval = "months_fortnight";
break;
case t > 60:
this.tickInterval = "months_days";
break;
case t > 30:
this.tickInterval = "week_days";
break;
case t > 2:
this.tickInterval = "days";
break;
case e > 2.4:
this.tickInterval = "hours";
break;
case i > 15:
this.tickInterval = "minutes_fives";
break;
case i > 5:
this.tickInterval = "minutes";
break;
case i > 1:
this.tickInterval = "seconds_tens";
break;
case 60 * i > 20:
this.tickInterval = "seconds_fives";
break;
default:
this.tickInterval = "seconds"
}
}
}, {
key: "generateYearScale", value: function (t) {
var e = t.firstVal, i = t.currentMonth, a = t.currentYear, s = t.daysWidthOnXAxis, r = t.numberOfYears,
n = e.minYear, o = 0, l = new zi(this.ctx), h = "year";
if (e.minDate > 1 || e.minMonth > 0) {
var c = l.determineRemainingDaysOfYear(e.minYear, e.minMonth, e.minDate);
o = (l.determineDaysOfYear(e.minYear) - c + 1) * s, n = e.minYear + 1, this.timeScaleArray.push({
position: o,
value: n,
unit: h,
year: n,
month: v.monthMod(i + 1)
})
} else 1 === e.minDate && 0 === e.minMonth && this.timeScaleArray.push({
position: o,
value: n,
unit: h,
year: a,
month: v.monthMod(i + 1)
});
for (var d = n, u = o, g = 0; g < r; g++) d++, u = l.determineDaysOfYear(d - 1) * s + u, this.timeScaleArray.push({
position: u,
value: d,
unit: h,
year: d,
month: 1
})
}
}, {
key: "generateMonthScale", value: function (t) {
var e = t.firstVal, i = t.currentMonthDate, a = t.currentMonth, s = t.currentYear,
r = t.daysWidthOnXAxis, n = t.numberOfMonths, o = a, l = 0, h = new zi(this.ctx), c = "month",
d = 0;
if (e.minDate > 1) {
l = (h.determineDaysOfMonths(a + 1, e.minYear) - i + 1) * r, o = v.monthMod(a + 1);
var u = s + d, g = v.monthMod(o), p = o;
0 === o && (c = "year", p = u, g = 1, u += d += 1), this.timeScaleArray.push({
position: l,
value: p,
unit: c,
year: u,
month: g
})
} else this.timeScaleArray.push({position: l, value: o, unit: c, year: s, month: v.monthMod(a)});
for (var f = o + 1, x = l, b = 0, m = 1; b < n; b++, m++) {
0 === (f = v.monthMod(f)) ? (c = "year", d += 1) : c = "month";
var y = this._getYear(s, f, d);
x = h.determineDaysOfMonths(f, y) * r + x;
var w = 0 === f ? y : f;
this.timeScaleArray.push({position: x, value: w, unit: c, year: y, month: 0 === f ? 1 : f}), f++
}
}
}, {
key: "generateDayScale", value: function (t) {
var e = t.firstVal, i = t.currentMonth, a = t.currentYear, s = t.hoursWidthOnXAxis, r = t.numberOfDays,
n = new zi(this.ctx), o = "day", l = e.minDate + 1, h = l, c = function (t, e, i) {
return t > n.determineDaysOfMonths(e + 1, i) ? (h = 1, o = "month", u = e += 1, e) : e
}, d = (24 - e.minHour) * s, u = l, g = c(h, i, a);
0 === e.minHour && 1 === e.minDate ? (d = 0, u = v.monthMod(e.minMonth), o = "month", h = e.minDate) : 1 !== e.minDate && 0 === e.minHour && 0 === e.minMinute && (d = 0, l = e.minDate, u = l, g = c(h = l, i, a), 1 !== u && (o = "day")), this.timeScaleArray.push({
position: d,
value: u,
unit: o,
year: this._getYear(a, g, 0),
month: v.monthMod(g),
day: h
});
for (var p = d, f = 0; f < r; f++) {
o = "day", g = c(h += 1, g, this._getYear(a, g, 0));
var x = this._getYear(a, g, 0);
p = 24 * s + p;
var b = 1 === h ? v.monthMod(g) : h;
this.timeScaleArray.push({position: p, value: b, unit: o, year: x, month: v.monthMod(g), day: b})
}
}
}, {
key: "generateHourScale", value: function (t) {
var e = t.firstVal, i = t.currentDate, a = t.currentMonth, s = t.currentYear, r = t.minutesWidthOnXAxis,
n = t.numberOfHours, o = new zi(this.ctx), l = "hour", h = function (t, e) {
return t > o.determineDaysOfMonths(e + 1, s) && (f = 1, e += 1), {month: e, date: f}
}, c = function (t, e) {
return t > o.determineDaysOfMonths(e + 1, s) ? e += 1 : e
}, d = 60 - (e.minMinute + e.minSecond / 60), u = d * r, g = e.minHour + 1, p = g;
60 === d && (u = 0, p = g = e.minHour);
var f = i;
p >= 24 && (p = 0, l = "day", g = f += 1);
var x = h(f, a).month;
x = c(f, x), g > 31 && (g = f = 1), this.timeScaleArray.push({
position: u,
value: g,
unit: l,
day: f,
hour: p,
year: s,
month: v.monthMod(x)
}), p++;
for (var b = u, m = 0; m < n; m++) {
if (l = "hour", p >= 24) p = 0, l = "day", x = h(f += 1, x).month, x = c(f, x);
var y = this._getYear(s, x, 0);
b = 60 * r + b;
var w = 0 === p ? f : p;
this.timeScaleArray.push({
position: b,
value: w,
unit: l,
hour: p,
day: f,
year: y,
month: v.monthMod(x)
}), p++
}
}
}, {
key: "generateMinuteScale", value: function (t) {
for (var e = t.currentMillisecond, i = t.currentSecond, a = t.currentMinute, s = t.currentHour, r = t.currentDate, n = t.currentMonth, o = t.currentYear, l = t.minutesWidthOnXAxis, h = t.secondsWidthOnXAxis, c = t.numberOfMinutes, d = a + 1, u = r, g = n, p = o, f = s, x = (60 - i - e / 1e3) * h, b = 0; b < c; b++) d >= 60 && (d = 0, 24 === (f += 1) && (f = 0)), this.timeScaleArray.push({
position: x,
value: d,
unit: "minute",
hour: f,
minute: d,
day: u,
year: this._getYear(p, g, 0),
month: v.monthMod(g)
}), x += l, d++
}
}, {
key: "generateSecondScale", value: function (t) {
for (var e = t.currentMillisecond, i = t.currentSecond, a = t.currentMinute, s = t.currentHour, r = t.currentDate, n = t.currentMonth, o = t.currentYear, l = t.secondsWidthOnXAxis, h = t.numberOfSeconds, c = i + 1, d = a, u = r, g = n, p = o, f = s, x = (1e3 - e) / 1e3 * l, b = 0; b < h; b++) c >= 60 && (c = 0, ++d >= 60 && (d = 0, 24 === ++f && (f = 0))), this.timeScaleArray.push({
position: x,
value: c,
unit: "second",
hour: f,
minute: d,
second: c,
day: u,
year: this._getYear(p, g, 0),
month: v.monthMod(g)
}), x += l, c++
}
}, {
key: "createRawDateString", value: function (t, e) {
var i = t.year;
return 0 === t.month && (t.month = 1), i += "-" + ("0" + t.month.toString()).slice(-2), "day" === t.unit ? i += "day" === t.unit ? "-" + ("0" + e).slice(-2) : "-01" : i += "-" + ("0" + (t.day ? t.day : "1")).slice(-2), "hour" === t.unit ? i += "hour" === t.unit ? "T" + ("0" + e).slice(-2) : "T00" : i += "T" + ("0" + (t.hour ? t.hour : "0")).slice(-2), "minute" === t.unit ? i += ":" + ("0" + e).slice(-2) : i += ":" + (t.minute ? ("0" + t.minute).slice(-2) : "00"), "second" === t.unit ? i += ":" + ("0" + e).slice(-2) : i += ":00", this.utc && (i += ".000Z"), i
}
}, {
key: "formatDates", value: function (t) {
var e = this, i = this.w;
return t.map((function (t) {
var a = t.value.toString(), s = new zi(e.ctx), r = e.createRawDateString(t, a),
n = s.getDate(s.parseDate(r));
if (e.utc || (n = s.getDate(s.parseDateWithTimezone(r))), void 0 === i.config.xaxis.labels.format) {
var o = "dd MMM", l = i.config.xaxis.labels.datetimeFormatter;
"year" === t.unit && (o = l.year), "month" === t.unit && (o = l.month), "day" === t.unit && (o = l.day), "hour" === t.unit && (o = l.hour), "minute" === t.unit && (o = l.minute), "second" === t.unit && (o = l.second), a = s.formatDate(n, o)
} else a = s.formatDate(n, i.config.xaxis.labels.format);
return {dateString: r, position: t.position, value: a, unit: t.unit, year: t.year, month: t.month}
}))
}
}, {
key: "removeOverlappingTS", value: function (t) {
var e, i = this, a = new Mi(this.ctx), s = !1;
t.length > 0 && t[0].value && t.every((function (e) {
return e.value.length === t[0].value.length
})) && (s = !0, e = a.getTextRects(t[0].value).width);
var r = 0, n = t.map((function (n, o) {
if (o > 0 && i.w.config.xaxis.labels.hideOverlappingLabels) {
var l = s ? e : a.getTextRects(t[r].value).width, h = t[r].position;
return n.position > h + l + 10 ? (r = o, n) : null
}
return n
}));
return n = n.filter((function (t) {
return null !== t
}))
}
}, {
key: "_getYear", value: function (t, e, i) {
return t + Math.floor(e / 12) + i
}
}]), t
}(), Za = function () {
function t(e, a) {
i(this, t), this.ctx = a, this.w = a.w, this.el = e
}
return s(t, [{
key: "setupElements", value: function () {
var t = this.w, e = t.globals, i = t.config, a = i.chart.type;
e.axisCharts = ["line", "area", "bar", "rangeBar", "rangeArea", "candlestick", "boxPlot", "scatter", "bubble", "radar", "heatmap", "treemap"].includes(a), e.xyCharts = ["line", "area", "bar", "rangeBar", "rangeArea", "candlestick", "boxPlot", "scatter", "bubble"].includes(a), e.isBarHorizontal = ["bar", "rangeBar", "boxPlot"].includes(a) && i.plotOptions.bar.horizontal, e.chartClass = ".apexcharts".concat(e.chartID), e.dom.baseEl = this.el, e.dom.elWrap = document.createElement("div"), Mi.setAttrs(e.dom.elWrap, {
id: e.chartClass.substring(1),
class: "apexcharts-canvas ".concat(e.chartClass.substring(1))
}), this.el.appendChild(e.dom.elWrap), e.dom.Paper = window.SVG().addTo(e.dom.elWrap), e.dom.Paper.attr({
class: "apexcharts-svg",
"xmlns:data": "ApexChartsNS",
transform: "translate(".concat(i.chart.offsetX, ", ").concat(i.chart.offsetY, ")")
}), e.dom.Paper.node.style.background = "dark" !== i.theme.mode || i.chart.background ? "light" !== i.theme.mode || i.chart.background ? i.chart.background : "#fff" : "#343A3F", this.setSVGDimensions(), e.dom.elLegendForeign = document.createElementNS(e.SVGNS, "foreignObject"), Mi.setAttrs(e.dom.elLegendForeign, {
x: 0,
y: 0,
width: e.svgWidth,
height: e.svgHeight
}), e.dom.elLegendWrap = document.createElement("div"), e.dom.elLegendWrap.classList.add("apexcharts-legend"), e.dom.elWrap.appendChild(e.dom.elLegendWrap), e.dom.Paper.node.appendChild(e.dom.elLegendForeign), e.dom.elGraphical = e.dom.Paper.group().attr({class: "apexcharts-inner apexcharts-graphical"}), e.dom.elDefs = e.dom.Paper.defs(), e.dom.Paper.add(e.dom.elGraphical), e.dom.elGraphical.add(e.dom.elDefs)
}
}, {
key: "plotChartType", value: function (t, e) {
var i = this.w, a = this.ctx, s = i.config, r = i.globals, n = {
line: {series: [], i: []},
area: {series: [], i: []},
scatter: {series: [], i: []},
bubble: {series: [], i: []},
bar: {series: [], i: []},
candlestick: {series: [], i: []},
boxPlot: {series: [], i: []},
rangeBar: {series: [], i: []},
rangeArea: {series: [], seriesRangeEnd: [], i: []}
}, o = s.chart.type || "line", l = null, h = 0;
r.series.forEach((function (e, a) {
var s, c,
d = "column" === (null === (s = t[a]) || void 0 === s ? void 0 : s.type) ? "bar" : (null === (c = t[a]) || void 0 === c ? void 0 : c.type) || ("column" === o ? "bar" : o);
n[d] ? ("rangeArea" === d ? (n[d].series.push(r.seriesRangeStart[a]), n[d].seriesRangeEnd.push(r.seriesRangeEnd[a])) : n[d].series.push(e), n[d].i.push(a), "bar" === d && (i.globals.columnSeries = n.bar)) : ["heatmap", "treemap", "pie", "donut", "polarArea", "radialBar", "radar"].includes(d) ? l = d : console.warn("You have specified an unrecognized series type (".concat(d, ").")), o !== d && "scatter" !== d && h++
})), h > 0 && (l && console.warn("Chart or series type ".concat(l, " cannot appear with other chart or series types.")), n.bar.series.length > 0 && s.plotOptions.bar.horizontal && (h -= n.bar.series.length, n.bar = {
series: [],
i: []
}, i.globals.columnSeries = {
series: [],
i: []
}, console.warn("Horizontal bars are not supported in a mixed/combo chart. Please turn off `plotOptions.bar.horizontal`"))), r.comboCharts || (r.comboCharts = h > 0);
var c = new Ga(a, e), d = new za(a, e);
a.pie = new Ya(a);
var u = new Oa(a);
a.rangeBar = new Fa(a, e);
var g = new Ha(a), p = [];
if (r.comboCharts) {
var x, b, m = new Pi(a);
if (n.area.series.length > 0) (x = p).push.apply(x, f(m.drawSeriesByGroup(n.area, r.areaGroups, "area", c)));
if (n.bar.series.length > 0) if (s.chart.stacked) {
var v = new Ta(a, e);
p.push(v.draw(n.bar.series, n.bar.i))
} else a.bar = new Ia(a, e), p.push(a.bar.draw(n.bar.series, n.bar.i));
if (n.rangeArea.series.length > 0 && p.push(c.draw(n.rangeArea.series, "rangeArea", n.rangeArea.i, n.rangeArea.seriesRangeEnd)), n.line.series.length > 0) (b = p).push.apply(b, f(m.drawSeriesByGroup(n.line, r.lineGroups, "line", c)));
if (n.candlestick.series.length > 0 && p.push(d.draw(n.candlestick.series, "candlestick", n.candlestick.i)), n.boxPlot.series.length > 0 && p.push(d.draw(n.boxPlot.series, "boxPlot", n.boxPlot.i)), n.rangeBar.series.length > 0 && p.push(a.rangeBar.draw(n.rangeBar.series, n.rangeBar.i)), n.scatter.series.length > 0) {
var y = new Ga(a, e, !0);
p.push(y.draw(n.scatter.series, "scatter", n.scatter.i))
}
if (n.bubble.series.length > 0) {
var w = new Ga(a, e, !0);
p.push(w.draw(n.bubble.series, "bubble", n.bubble.i))
}
} else switch (s.chart.type) {
case"line":
p = c.draw(r.series, "line");
break;
case"area":
p = c.draw(r.series, "area");
break;
case"bar":
if (s.chart.stacked) p = new Ta(a, e).draw(r.series); else a.bar = new Ia(a, e), p = a.bar.draw(r.series);
break;
case"candlestick":
p = new za(a, e).draw(r.series, "candlestick");
break;
case"boxPlot":
p = new za(a, e).draw(r.series, s.chart.type);
break;
case"rangeBar":
p = a.rangeBar.draw(r.series);
break;
case"rangeArea":
p = c.draw(r.seriesRangeStart, "rangeArea", void 0, r.seriesRangeEnd);
break;
case"heatmap":
p = new Ra(a, e).draw(r.series);
break;
case"treemap":
p = new ja(a, e).draw(r.series);
break;
case"pie":
case"donut":
case"polarArea":
p = a.pie.draw(r.series);
break;
case"radialBar":
p = u.draw(r.series);
break;
case"radar":
p = g.draw(r.series);
break;
default:
p = c.draw(r.series)
}
return p
}
}, {
key: "setSVGDimensions", value: function () {
var t = this.w, e = t.globals, i = t.config;
i.chart.width = i.chart.width || "100%", i.chart.height = i.chart.height || "auto", e.svgWidth = i.chart.width, e.svgHeight = i.chart.height;
var a = v.getDimensions(this.el), s = i.chart.width.toString().split(/[0-9]+/g).pop();
"%" === s ? v.isNumber(a[0]) && (0 === a[0].width && (a = v.getDimensions(this.el.parentNode)), e.svgWidth = a[0] * parseInt(i.chart.width, 10) / 100) : "px" !== s && "" !== s || (e.svgWidth = parseInt(i.chart.width, 10));
var r = String(i.chart.height).toString().split(/[0-9]+/g).pop();
if ("auto" !== e.svgHeight && "" !== e.svgHeight) if ("%" === r) {
var n = v.getDimensions(this.el.parentNode);
e.svgHeight = n[1] * parseInt(i.chart.height, 10) / 100
} else e.svgHeight = parseInt(i.chart.height, 10); else e.svgHeight = e.axisCharts ? e.svgWidth / 1.61 : e.svgWidth / 1.2;
if (e.svgWidth = Math.max(e.svgWidth, 0), e.svgHeight = Math.max(e.svgHeight, 0), Mi.setAttrs(e.dom.Paper.node, {
width: e.svgWidth,
height: e.svgHeight
}), "%" !== r) {
var o = i.chart.sparkline.enabled ? 0 : e.axisCharts ? i.chart.parentHeightOffset : 0;
e.dom.Paper.node.parentNode.parentNode.style.minHeight = "".concat(e.svgHeight + o, "px")
}
e.dom.elWrap.style.width = "".concat(e.svgWidth, "px"), e.dom.elWrap.style.height = "".concat(e.svgHeight, "px")
}
}, {
key: "shiftGraphPosition", value: function () {
var t = this.w.globals, e = t.translateY, i = t.translateX;
Mi.setAttrs(t.dom.elGraphical.node, {transform: "translate(".concat(i, ", ").concat(e, ")")})
}
}, {
key: "resizeNonAxisCharts", value: function () {
var t = this.w, e = t.globals, i = 0, a = t.config.chart.sparkline.enabled ? 1 : 15;
a += t.config.grid.padding.bottom, ["top", "bottom"].includes(t.config.legend.position) && t.config.legend.show && !t.config.legend.floating && (i = new ba(this.ctx).legendHelpers.getLegendDimensions().clwh + 7);
var s = t.globals.dom.baseEl.querySelector(".apexcharts-radialbar, .apexcharts-pie"),
r = 2.05 * t.globals.radialSize;
if (s && !t.config.chart.sparkline.enabled && 0 !== t.config.plotOptions.radialBar.startAngle) {
var n = v.getBoundingClientRect(s);
r = n.bottom;
var o = n.bottom - n.top;
r = Math.max(2.05 * t.globals.radialSize, o)
}
var l = Math.ceil(r + e.translateY + i + a);
e.dom.elLegendForeign && e.dom.elLegendForeign.setAttribute("height", l), t.config.chart.height && String(t.config.chart.height).includes("%") || (e.dom.elWrap.style.height = "".concat(l, "px"), Mi.setAttrs(e.dom.Paper.node, {height: l}), e.dom.Paper.node.parentNode.parentNode.style.minHeight = "".concat(l, "px"))
}
}, {
key: "coreCalculations", value: function () {
new ia(this.ctx).init()
}
}, {
key: "resetGlobals", value: function () {
var t = this, e = function () {
return t.w.config.series.map((function () {
return []
}))
}, i = new Bi, a = this.w.globals,
s = {dataWasParsed: a.dataWasParsed, originalSeries: a.originalSeries};
i.initGlobalVars(a), a.seriesXvalues = e(), a.seriesYvalues = e(), s.dataWasParsed && (a.dataWasParsed = s.dataWasParsed, a.originalSeries = s.originalSeries)
}
}, {
key: "isMultipleY", value: function () {
return !!(Array.isArray(this.w.config.yaxis) && this.w.config.yaxis.length > 1) && (this.w.globals.isMultipleYAxis = !0, !0)
}
}, {
key: "xySettings", value: function () {
var t = this.w, e = null;
if (t.globals.axisCharts) {
if ("back" === t.config.xaxis.crosshairs.position && new oa(this.ctx).drawXCrosshairs(), "back" === t.config.yaxis[0].crosshairs.position && new oa(this.ctx).drawYCrosshairs(), "datetime" === t.config.xaxis.type && void 0 === t.config.xaxis.labels.formatter) {
this.ctx.timeScale = new qa(this.ctx);
var i = [];
isFinite(t.globals.minX) && isFinite(t.globals.maxX) && !t.globals.isBarHorizontal ? i = this.ctx.timeScale.calculateTimeScaleTicks(t.globals.minX, t.globals.maxX) : t.globals.isBarHorizontal && (i = this.ctx.timeScale.calculateTimeScaleTicks(t.globals.minY, t.globals.maxY)), this.ctx.timeScale.recalcDimensionsBasedOnFormat(i)
}
e = new Pi(this.ctx).getCalculatedRatios()
}
return e
}
}, {
key: "updateSourceChart", value: function (t) {
this.ctx.w.globals.selection = void 0, this.ctx.updateHelpers._updateOptions({
chart: {
selection: {
xaxis: {
min: t.w.globals.minX,
max: t.w.globals.maxX
}
}
}
}, !1, !1)
}
}, {
key: "setupBrushHandler", value: function () {
var t = this, e = this.ctx, i = this.w;
if (i.config.chart.brush.enabled && "function" != typeof i.config.chart.events.selection) {
var a = Array.isArray(i.config.chart.brush.targets) ? i.config.chart.brush.targets : [i.config.chart.brush.target];
a.forEach((function (i) {
var a = e.constructor.getChartByID(i);
a.w.globals.brushSource = t.ctx, "function" != typeof a.w.config.chart.events.zoomed && (a.w.config.chart.events.zoomed = function () {
return t.updateSourceChart(a)
}), "function" != typeof a.w.config.chart.events.scrolled && (a.w.config.chart.events.scrolled = function () {
return t.updateSourceChart(a)
})
})), i.config.chart.events.selection = function (t, i) {
a.forEach((function (t) {
e.constructor.getChartByID(t).ctx.updateHelpers._updateOptions({
xaxis: {
min: i.xaxis.min,
max: i.xaxis.max
}
}, !1, !1, !1, !1)
}))
}
}
}
}]), t
}(), $a = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "_updateOptions", value: function (t) {
var e = this, i = arguments.length > 1 && void 0 !== arguments[1] && arguments[1],
a = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2],
s = !(arguments.length > 3 && void 0 !== arguments[3]) || arguments[3],
r = arguments.length > 4 && void 0 !== arguments[4] && arguments[4];
return new Promise((function (n) {
var o = [e.ctx];
s && (o = e.ctx.getSyncedCharts()), e.ctx.w.globals.isExecCalled && (o = [e.ctx], e.ctx.w.globals.isExecCalled = !1), o.forEach((function (s, l) {
var h = s.w;
if (h.globals.shouldAnimate = a, i || (h.globals.resized = !0, h.globals.dataChanged = !0, a && s.series.getPreviousPaths()), t && "object" === b(t) && (s.config = new Wi(t), t = Pi.extendArrayProps(s.config, t, h), s.w.globals.chartID !== e.ctx.w.globals.chartID && delete t.series, h.config = v.extend(h.config, t), r && (h.globals.lastXAxis = t.xaxis ? v.clone(t.xaxis) : [], h.globals.lastYAxis = t.yaxis ? v.clone(t.yaxis) : [], h.globals.initialConfig = v.extend({}, h.config), h.globals.initialSeries = v.clone(h.config.series), t.series))) {
for (var c = 0; c < h.globals.collapsedSeriesIndices.length; c++) {
var d = h.config.series[h.globals.collapsedSeriesIndices[c]];
h.globals.collapsedSeries[c].data = h.globals.axisCharts ? d.data.slice() : d
}
for (var u = 0; u < h.globals.ancillaryCollapsedSeriesIndices.length; u++) {
var g = h.config.series[h.globals.ancillaryCollapsedSeriesIndices[u]];
h.globals.ancillaryCollapsedSeries[u].data = h.globals.axisCharts ? g.data.slice() : g
}
s.series.emptyCollapsedSeries(h.config.series)
}
return s.update(t).then((function () {
l === o.length - 1 && n(s)
}))
}))
}))
}
}, {
key: "_updateSeries", value: function (t, e) {
var i = this, a = arguments.length > 2 && void 0 !== arguments[2] && arguments[2];
return new Promise((function (s) {
var r = i.w;
return r.globals.shouldAnimate = e, r.globals.dataChanged = !0, e && i.ctx.series.getPreviousPaths(), i.ctx.data.resetParsingFlags(), i.ctx.data.parseData(t), a && (r.globals.initialConfig.series = v.clone(r.config.series), r.globals.initialSeries = v.clone(r.config.series)), i.ctx.update().then((function () {
s(i.ctx)
}))
}))
}
}, {
key: "_extendSeries", value: function (t, e) {
var i = this.w, a = i.config.series[e];
return u(u({}, i.config.series[e]), {}, {
name: t.name ? t.name : null == a ? void 0 : a.name,
color: t.color ? t.color : null == a ? void 0 : a.color,
type: t.type ? t.type : null == a ? void 0 : a.type,
group: t.group ? t.group : null == a ? void 0 : a.group,
hidden: void 0 !== t.hidden ? t.hidden : null == a ? void 0 : a.hidden,
data: t.data ? t.data : null == a ? void 0 : a.data,
zIndex: void 0 !== t.zIndex ? t.zIndex : e
})
}
}, {
key: "toggleDataPointSelection", value: function (t, e) {
var i = this.w, a = null, s = ".apexcharts-series[data\\:realIndex='".concat(t, "']");
return i.globals.axisCharts ? a = i.globals.dom.Paper.findOne("".concat(s, " path[j='").concat(e, "'], ").concat(s, " circle[j='").concat(e, "'], ").concat(s, " rect[j='").concat(e, "']")) : void 0 === e && (a = i.globals.dom.Paper.findOne("".concat(s, " path[j='").concat(t, "']")), "pie" !== i.config.chart.type && "polarArea" !== i.config.chart.type && "donut" !== i.config.chart.type || this.ctx.pie.pieClicked(t)), a ? (new Mi(this.ctx).pathMouseDown(a, null), a.node ? a.node : null) : (console.warn("toggleDataPointSelection: Element not found"), null)
}
}, {
key: "forceXAxisUpdate", value: function (t) {
var e = this.w;
if (["min", "max"].forEach((function (i) {
void 0 !== t.xaxis[i] && (e.config.xaxis[i] = t.xaxis[i], e.globals.lastXAxis[i] = t.xaxis[i])
})), t.xaxis.categories && t.xaxis.categories.length && (e.config.xaxis.categories = t.xaxis.categories), e.config.xaxis.convertedCatToNumeric) {
var i = new Ni(t);
t = i.convertCatToNumericXaxis(t, this.ctx)
}
return t
}
}, {
key: "forceYAxisUpdate", value: function (t) {
return t.chart && t.chart.stacked && "100%" === t.chart.stackType && (Array.isArray(t.yaxis) ? t.yaxis.forEach((function (e, i) {
t.yaxis[i].min = 0, t.yaxis[i].max = 100
})) : (t.yaxis.min = 0, t.yaxis.max = 100)), t
}
}, {
key: "revertDefaultAxisMinMax", value: function (t) {
var e = this, i = this.w, a = i.globals.lastXAxis, s = i.globals.lastYAxis;
t && t.xaxis && (a = t.xaxis), t && t.yaxis && (s = t.yaxis), i.config.xaxis.min = a.min, i.config.xaxis.max = a.max;
var r = function (t) {
void 0 !== s[t] && (i.config.yaxis[t].min = s[t].min, i.config.yaxis[t].max = s[t].max)
};
i.config.yaxis.map((function (t, a) {
i.globals.zoomed || void 0 !== s[a] ? r(a) : void 0 !== e.ctx.opts.yaxis[a] && (t.min = e.ctx.opts.yaxis[a].min, t.max = e.ctx.opts.yaxis[a].max)
}))
}
}]), t
}();
!function () {
function t() {
for (var t = arguments.length > 0 && arguments[0] !== h ? arguments[0] : [], s = arguments.length > 1 ? arguments[1] : h, r = arguments.length > 2 ? arguments[2] : h, n = arguments.length > 3 ? arguments[3] : h, o = arguments.length > 4 ? arguments[4] : h, l = arguments.length > 5 ? arguments[5] : h, h = arguments.length > 6 ? arguments[6] : h, c = t.slice(s, r || h), d = n.slice(o, l || h), u = 0, g = {
pos: [0, 0],
start: [0, 0]
}, p = {pos: [0, 0], start: [0, 0]}; ;) {
if (c[u] = e.call(g, c[u]), d[u] = e.call(p, d[u]), c[u][0] != d[u][0] || "M" == c[u][0] || "A" == c[u][0] && (c[u][4] != d[u][4] || c[u][5] != d[u][5]) ? (Array.prototype.splice.apply(c, [u, 1].concat(a.call(g, c[u]))), Array.prototype.splice.apply(d, [u, 1].concat(a.call(p, d[u])))) : (c[u] = i.call(g, c[u]), d[u] = i.call(p, d[u])), ++u == c.length && u == d.length) break;
u == c.length && c.push(["C", g.pos[0], g.pos[1], g.pos[0], g.pos[1], g.pos[0], g.pos[1]]), u == d.length && d.push(["C", p.pos[0], p.pos[1], p.pos[0], p.pos[1], p.pos[0], p.pos[1]])
}
return {start: c, dest: d}
}
function e(t) {
switch (t[0]) {
case"z":
case"Z":
t[0] = "L", t[1] = this.start[0], t[2] = this.start[1];
break;
case"H":
t[0] = "L", t[2] = this.pos[1];
break;
case"V":
t[0] = "L", t[2] = t[1], t[1] = this.pos[0];
break;
case"T":
t[0] = "Q", t[3] = t[1], t[4] = t[2], t[1] = this.reflection[1], t[2] = this.reflection[0];
break;
case"S":
t[0] = "C", t[6] = t[4], t[5] = t[3], t[4] = t[2], t[3] = t[1], t[2] = this.reflection[1], t[1] = this.reflection[0]
}
return t
}
function i(t) {
var e = t.length;
return this.pos = [t[e - 2], t[e - 1]], -1 != "SCQT".indexOf(t[0]) && (this.reflection = [2 * this.pos[0] - t[e - 4], 2 * this.pos[1] - t[e - 3]]), t
}
function a(t) {
var e = [t];
switch (t[0]) {
case"M":
return this.pos = this.start = [t[1], t[2]], e;
case"L":
t[5] = t[3] = t[1], t[6] = t[4] = t[2], t[1] = this.pos[0], t[2] = this.pos[1];
break;
case"Q":
t[6] = t[4], t[5] = t[3], t[4] = 1 * t[4] / 3 + 2 * t[2] / 3, t[3] = 1 * t[3] / 3 + 2 * t[1] / 3, t[2] = 1 * this.pos[1] / 3 + 2 * t[2] / 3, t[1] = 1 * this.pos[0] / 3 + 2 * t[1] / 3;
break;
case"A":
e = function (t, e) {
var i, a, s, r, n, o, l, h, c, d, u, g, p, f, x, b, m, v, y, w, k, A, C, S, L, M,
P = Math.abs(e[1]), I = Math.abs(e[2]), T = e[3] % 360, z = e[4], X = e[5], R = e[6],
E = e[7], Y = new bt(t), H = new bt(R, E), O = [];
if (0 === P || 0 === I || Y.x === H.x && Y.y === H.y) return [["C", Y.x, Y.y, H.x, H.y, H.x, H.y]];
i = new bt((Y.x - H.x) / 2, (Y.y - H.y) / 2).transform((new vt).rotate(T)), a = i.x * i.x / (P * P) + i.y * i.y / (I * I), a > 1 && (P *= a = Math.sqrt(a), I *= a);
s = (new vt).rotate(T).scale(1 / P, 1 / I).rotate(-T), Y = Y.transform(s), H = H.transform(s), r = [H.x - Y.x, H.y - Y.y], o = r[0] * r[0] + r[1] * r[1], n = Math.sqrt(o), r[0] /= n, r[1] /= n, l = o < 4 ? Math.sqrt(1 - o / 4) : 0, z === X && (l *= -1);
h = new bt((H.x + Y.x) / 2 + l * -r[1], (H.y + Y.y) / 2 + l * r[0]), c = new bt(Y.x - h.x, Y.y - h.y), d = new bt(H.x - h.x, H.y - h.y), u = Math.acos(c.x / Math.sqrt(c.x * c.x + c.y * c.y)), c.y < 0 && (u *= -1);
g = Math.acos(d.x / Math.sqrt(d.x * d.x + d.y * d.y)), d.y < 0 && (g *= -1);
X && u > g && (g += 2 * Math.PI);
!X && u < g && (g -= 2 * Math.PI);
for (f = Math.ceil(2 * Math.abs(u - g) / Math.PI), b = [], m = u, p = (g - u) / f, x = 4 * Math.tan(p / 4) / 3, k = 0; k <= f; k++) y = Math.cos(m), v = Math.sin(m), w = new bt(h.x + y, h.y + v), b[k] = [new bt(w.x + x * v, w.y - x * y), w, new bt(w.x - x * v, w.y + x * y)], m += p;
for (b[0][0] = b[0][1].clone(), b[b.length - 1][2] = b[b.length - 1][1].clone(), s = (new vt).rotate(T).scale(P, I).rotate(-T), k = 0, A = b.length; k < A; k++) b[k][0] = b[k][0].transform(s), b[k][1] = b[k][1].transform(s), b[k][2] = b[k][2].transform(s);
for (k = 1, A = b.length; k < A; k++) C = (w = b[k - 1][2]).x, S = w.y, L = (w = b[k][0]).x, M = w.y, R = (w = b[k][1]).x, E = w.y, O.push(["C", C, S, L, M, R, E]);
return O
}(this.pos, t), t = e[0]
}
return t[0] = "C", this.pos = [t[5], t[6]], this.reflection = [2 * t[5] - t[3], 2 * t[6] - t[4]], e
}
function s() {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : [],
e = arguments.length > 1 ? arguments[1] : void 0;
if (!1 === e) return !1;
for (var i = e, a = t.length; i < a; ++i) if ("M" == t[i][0]) return i;
return !1
}
Q(Ee, {
morph: function (e, i, a, r, n) {
for (var o = this.parse(e), l = this.parse(i), h = 0, c = 0, d = !1, u = !1; !1 !== h || !1 !== c;) {
var g;
d = s(o, !1 !== h && h + 1), u = s(l, !1 !== c && c + 1), !1 === h && (h = 0 == (g = new Ee(p.start).bbox()).height || 0 == g.width ? o.push(o[0]) - 1 : o.push(["M", g.x + g.width / 2, g.y + g.height / 2]) - 1), !1 === c && (c = 0 == (g = new Ee(p.dest).bbox()).height || 0 == g.width ? l.push(l[0]) - 1 : l.push(["M", g.x + g.width / 2, g.y + g.height / 2]) - 1);
var p = t(o, h, d, l, c, u);
o = o.slice(0, h).concat(p.start, !1 === d ? [] : o.slice(d)), l = l.slice(0, c).concat(p.dest, !1 === u ? [] : l.slice(u)), h = !1 !== d && h + p.start.length, c = !1 !== u && c + p.dest.length
}
this._array = o, this.destination = new Ee, this.destination._array = l;
var f = this.fromArray(o.map((function (t, e) {
var i = l[e].map((function (i, s) {
return 0 === s ? i : r.step(t[s], l[e][s], a, n[e], n)
}));
return i
})));
return f
}
})
}();
const Ja = t => (t.changedTouches && (t = t.changedTouches[0]), {x: t.clientX, y: t.clientY});
class Qa {
constructor(t) {
t.remember("_draggable", this), this.el = t, this.drag = this.drag.bind(this), this.startDrag = this.startDrag.bind(this), this.endDrag = this.endDrag.bind(this)
}
init(t) {
t ? (this.el.on("mousedown.drag", this.startDrag), this.el.on("touchstart.drag", this.startDrag, {passive: !1})) : (this.el.off("mousedown.drag"), this.el.off("touchstart.drag"))
}
startDrag(t) {
const e = !t.type.indexOf("mouse");
if (e && 1 !== t.which && 0 !== t.buttons) return;
if (this.el.dispatch("beforedrag", {event: t, handler: this}).defaultPrevented) return;
t.preventDefault(), t.stopPropagation(), this.init(!1), this.box = this.el.bbox(), this.lastClick = this.el.point(Ja(t));
const i = (e ? "mouseup" : "touchend") + ".drag";
zt(window, (e ? "mousemove" : "touchmove") + ".drag", this.drag, this, {passive: !1}), zt(window, i, this.endDrag, this, {passive: !1}), this.el.fire("dragstart", {
event: t,
handler: this,
box: this.box
})
}
drag(t) {
const {box: e, lastClick: i} = this, a = this.el.point(Ja(t)), s = a.x - i.x, r = a.y - i.y;
if (!s && !r) return e;
const n = e.x + s, o = e.y + r;
this.box = new kt(n, o, e.w, e.h), this.lastClick = a, this.el.dispatch("dragmove", {
event: t,
handler: this,
box: this.box
}).defaultPrevented || this.move(n, o)
}
move(t, e) {
"svg" === this.el.type ? gi.prototype.move.call(this.el, t, e) : this.el.move(t, e)
}
endDrag(t) {
this.drag(t), this.el.fire("dragend", {
event: t,
handler: this,
box: this.box
}), Xt(window, "mousemove.drag"), Xt(window, "touchmove.drag"), Xt(window, "mouseup.drag"), Xt(window, "touchend.drag"), this.init(!0)
}
}
/*!
* @svgdotjs/svg.select.js - An extension of svg.js which allows to select elements with mouse
* @version 4.0.1
* https://github.com/svgdotjs/svg.select.js
*
* @copyright Ulrich-Matthias Schäfer
* @license MIT
*
* BUILT: Mon Jul 01 2024 15:04:42 GMT+0200 (Central European Summer Time)
*/
function Ka(t, e, i, a = null) {
return function (s) {
s.preventDefault(), s.stopPropagation();
var r = s.pageX || s.touches[0].pageX, n = s.pageY || s.touches[0].pageY;
e.fire(t, {x: r, y: n, event: s, index: a, points: i})
}
}
function ts([t, e], {a: i, b: a, c: s, d: r, e: n, f: o}) {
return [t * i + e * s + n, t * a + e * r + o]
}
Q(Gt, {
draggable(t = !0) {
return (this.remember("_draggable") || new Qa(this)).init(t), this
}
});
let es = class {
constructor(t) {
this.el = t, t.remember("_selectHandler", this), this.selection = new gi, this.order = ["lt", "t", "rt", "r", "rb", "b", "lb", "l", "rot"], this.mutationHandler = this.mutationHandler.bind(this);
const e = F();
this.observer = new e.MutationObserver(this.mutationHandler)
}
init(t) {
this.createHandle = t.createHandle || this.createHandleFn, this.createRot = t.createRot || this.createRotFn, this.updateHandle = t.updateHandle || this.updateHandleFn, this.updateRot = t.updateRot || this.updateRotFn, this.el.root().put(this.selection), this.updatePoints(), this.createSelection(), this.createResizeHandles(), this.updateResizeHandles(), this.createRotationHandle(), this.updateRotationHandle(), this.observer.observe(this.el.node, {attributes: !0})
}
active(t, e) {
if (!t) return this.selection.clear().remove(), void this.observer.disconnect();
this.init(e)
}
createSelection() {
this.selection.polygon(this.handlePoints).addClass("svg_select_shape")
}
updateSelection() {
this.selection.get(0).plot(this.handlePoints)
}
createResizeHandles() {
this.handlePoints.forEach(((t, e, i) => {
const a = this.order[e];
this.createHandle.call(this, this.selection, t, e, i, a), this.selection.get(e + 1).addClass("svg_select_handle svg_select_handle_" + a).on("mousedown.selection touchstart.selection", Ka(a, this.el, this.handlePoints, e))
}))
}
createHandleFn(t) {
t.polyline()
}
updateHandleFn(t, e, i, a) {
const s = a.at(i - 1), r = a[(i + 1) % a.length], n = e, o = [n[0] - s[0], n[1] - s[1]],
l = [n[0] - r[0], n[1] - r[1]], h = Math.sqrt(o[0] * o[0] + o[1] * o[1]),
c = Math.sqrt(l[0] * l[0] + l[1] * l[1]), d = [o[0] / h, o[1] / h], u = [l[0] / c, l[1] / c],
g = [n[0] - 10 * d[0], n[1] - 10 * d[1]], p = [n[0] - 10 * u[0], n[1] - 10 * u[1]];
t.plot([g, n, p])
}
updateResizeHandles() {
this.handlePoints.forEach(((t, e, i) => {
const a = this.order[e];
this.updateHandle.call(this, this.selection.get(e + 1), t, e, i, a)
}))
}
createRotFn(t) {
t.line(), t.circle(5)
}
getPoint(t) {
return this.handlePoints[this.order.indexOf(t)]
}
getPointHandle(t) {
return this.selection.get(this.order.indexOf(t) + 1)
}
updateRotFn(t, e) {
const i = this.getPoint("t");
t.get(0).plot(i[0], i[1], e[0], e[1]), t.get(1).center(e[0], e[1])
}
createRotationHandle() {
const t = this.selection.group().addClass("svg_select_handle_rot").on("mousedown.selection touchstart.selection", Ka("rot", this.el, this.handlePoints));
this.createRot.call(this, t)
}
updateRotationHandle() {
const t = this.selection.findOne("g.svg_select_handle_rot");
this.updateRot(t, this.rotationPoint, this.handlePoints)
}
updatePoints() {
const t = this.el.bbox(), e = this.el.parent().screenCTM().inverseO().multiplyO(this.el.screenCTM());
this.handlePoints = this.getHandlePoints(t).map((t => ts(t, e))), this.rotationPoint = ts(this.getRotationPoint(t), e)
}
getHandlePoints({x: t, x2: e, y: i, y2: a, cx: s, cy: r} = this.el.bbox()) {
return [[t, i], [s, i], [e, i], [e, r], [e, a], [s, a], [t, a], [t, r]]
}
getRotationPoint({y: t, cx: e} = this.el.bbox()) {
return [e, t - 20]
}
mutationHandler() {
this.updatePoints(), this.updateSelection(), this.updateResizeHandles(), this.updateRotationHandle()
}
};
const is = t => function (e = !0, i = {}) {
"object" == typeof e && (i = e, e = !0);
let a = this.remember("_" + t.name);
return a || (e.prototype instanceof es ? (a = new e(this), e = !0) : a = new t(this), this.remember("_" + t.name, a)), a.active(e, i), this
};
/*!
* @svgdotjs/svg.resize.js - An extension for svg.js which allows to resize elements which are selected
* @version 2.0.4
* https://github.com/svgdotjs/svg.resize.js
*
* @copyright [object Object]
* @license MIT
*
* BUILT: Fri Sep 13 2024 12:43:14 GMT+0200 (Central European Summer Time)
*/
/*!
* @svgdotjs/svg.select.js - An extension of svg.js which allows to select elements with mouse
* @version 4.0.1
* https://github.com/svgdotjs/svg.select.js
*
* @copyright Ulrich-Matthias Schäfer
* @license MIT
*
* BUILT: Mon Jul 01 2024 15:04:42 GMT+0200 (Central European Summer Time)
*/
function as(t, e, i, a = null) {
return function (s) {
s.preventDefault(), s.stopPropagation();
var r = s.pageX || s.touches[0].pageX, n = s.pageY || s.touches[0].pageY;
e.fire(t, {x: r, y: n, event: s, index: a, points: i})
}
}
function ss([t, e], {a: i, b: a, c: s, d: r, e: n, f: o}) {
return [t * i + e * s + n, t * a + e * r + o]
}
Q(Gt, {select: is(es)}), Q([Ge, je, xe], {
pointSelect: is(class {
constructor(t) {
this.el = t, t.remember("_pointSelectHandler", this), this.selection = new gi, this.order = ["lt", "t", "rt", "r", "rb", "b", "lb", "l", "rot"], this.mutationHandler = this.mutationHandler.bind(this);
const e = F();
this.observer = new e.MutationObserver(this.mutationHandler)
}
init(t) {
this.createHandle = t.createHandle || this.createHandleFn, this.updateHandle = t.updateHandle || this.updateHandleFn, this.el.root().put(this.selection), this.updatePoints(), this.createSelection(), this.createPointHandles(), this.updatePointHandles(), this.observer.observe(this.el.node, {attributes: !0})
}
active(t, e) {
if (!t) return this.selection.clear().remove(), void this.observer.disconnect();
this.init(e)
}
createSelection() {
this.selection.polygon(this.points).addClass("svg_select_shape_pointSelect")
}
updateSelection() {
this.selection.get(0).plot(this.points)
}
createPointHandles() {
this.points.forEach(((t, e, i) => {
this.createHandle.call(this, this.selection, t, e, i), this.selection.get(e + 1).addClass("svg_select_handle_point").on("mousedown.selection touchstart.selection", Ka("point", this.el, this.points, e))
}))
}
createHandleFn(t) {
t.circle(5)
}
updateHandleFn(t, e) {
t.center(e[0], e[1])
}
updatePointHandles() {
this.points.forEach(((t, e, i) => {
this.updateHandle.call(this, this.selection.get(e + 1), t, e, i)
}))
}
updatePoints() {
const t = this.el.parent().screenCTM().inverseO().multiplyO(this.el.screenCTM());
this.points = this.el.array().map((e => ts(e, t)))
}
mutationHandler() {
this.updatePoints(), this.updateSelection(), this.updatePointHandles()
}
})
});
class rs {
constructor(t) {
this.el = t, t.remember("_selectHandler", this), this.selection = new gi, this.order = ["lt", "t", "rt", "r", "rb", "b", "lb", "l", "rot"], this.mutationHandler = this.mutationHandler.bind(this);
const e = F();
this.observer = new e.MutationObserver(this.mutationHandler)
}
init(t) {
this.createHandle = t.createHandle || this.createHandleFn, this.createRot = t.createRot || this.createRotFn, this.updateHandle = t.updateHandle || this.updateHandleFn, this.updateRot = t.updateRot || this.updateRotFn, this.el.root().put(this.selection), this.updatePoints(), this.createSelection(), this.createResizeHandles(), this.updateResizeHandles(), this.createRotationHandle(), this.updateRotationHandle(), this.observer.observe(this.el.node, {attributes: !0})
}
active(t, e) {
if (!t) return this.selection.clear().remove(), void this.observer.disconnect();
this.init(e)
}
createSelection() {
this.selection.polygon(this.handlePoints).addClass("svg_select_shape")
}
updateSelection() {
this.selection.get(0).plot(this.handlePoints)
}
createResizeHandles() {
this.handlePoints.forEach(((t, e, i) => {
const a = this.order[e];
this.createHandle.call(this, this.selection, t, e, i, a), this.selection.get(e + 1).addClass("svg_select_handle svg_select_handle_" + a).on("mousedown.selection touchstart.selection", as(a, this.el, this.handlePoints, e))
}))
}
createHandleFn(t) {
t.polyline()
}
updateHandleFn(t, e, i, a) {
const s = a.at(i - 1), r = a[(i + 1) % a.length], n = e, o = [n[0] - s[0], n[1] - s[1]],
l = [n[0] - r[0], n[1] - r[1]], h = Math.sqrt(o[0] * o[0] + o[1] * o[1]),
c = Math.sqrt(l[0] * l[0] + l[1] * l[1]), d = [o[0] / h, o[1] / h], u = [l[0] / c, l[1] / c],
g = [n[0] - 10 * d[0], n[1] - 10 * d[1]], p = [n[0] - 10 * u[0], n[1] - 10 * u[1]];
t.plot([g, n, p])
}
updateResizeHandles() {
this.handlePoints.forEach(((t, e, i) => {
const a = this.order[e];
this.updateHandle.call(this, this.selection.get(e + 1), t, e, i, a)
}))
}
createRotFn(t) {
t.line(), t.circle(5)
}
getPoint(t) {
return this.handlePoints[this.order.indexOf(t)]
}
getPointHandle(t) {
return this.selection.get(this.order.indexOf(t) + 1)
}
updateRotFn(t, e) {
const i = this.getPoint("t");
t.get(0).plot(i[0], i[1], e[0], e[1]), t.get(1).center(e[0], e[1])
}
createRotationHandle() {
const t = this.selection.group().addClass("svg_select_handle_rot").on("mousedown.selection touchstart.selection", as("rot", this.el, this.handlePoints));
this.createRot.call(this, t)
}
updateRotationHandle() {
const t = this.selection.findOne("g.svg_select_handle_rot");
this.updateRot(t, this.rotationPoint, this.handlePoints)
}
updatePoints() {
const t = this.el.bbox(), e = this.el.parent().screenCTM().inverseO().multiplyO(this.el.screenCTM());
this.handlePoints = this.getHandlePoints(t).map((t => ss(t, e))), this.rotationPoint = ss(this.getRotationPoint(t), e)
}
getHandlePoints({x: t, x2: e, y: i, y2: a, cx: s, cy: r} = this.el.bbox()) {
return [[t, i], [s, i], [e, i], [e, r], [e, a], [s, a], [t, a], [t, r]]
}
getRotationPoint({y: t, cx: e} = this.el.bbox()) {
return [e, t - 20]
}
mutationHandler() {
this.updatePoints(), this.updateSelection(), this.updateResizeHandles(), this.updateRotationHandle()
}
}
const ns = t => function (e = !0, i = {}) {
"object" == typeof e && (i = e, e = !0);
let a = this.remember("_" + t.name);
return a || (e.prototype instanceof rs ? (a = new e(this), e = !0) : a = new t(this), this.remember("_" + t.name, a)), a.active(e, i), this
};
Q(Gt, {select: ns(rs)}), Q([Ge, je, xe], {
pointSelect: ns(class {
constructor(t) {
this.el = t, t.remember("_pointSelectHandler", this), this.selection = new gi, this.order = ["lt", "t", "rt", "r", "rb", "b", "lb", "l", "rot"], this.mutationHandler = this.mutationHandler.bind(this);
const e = F();
this.observer = new e.MutationObserver(this.mutationHandler)
}
init(t) {
this.createHandle = t.createHandle || this.createHandleFn, this.updateHandle = t.updateHandle || this.updateHandleFn, this.el.root().put(this.selection), this.updatePoints(), this.createSelection(), this.createPointHandles(), this.updatePointHandles(), this.observer.observe(this.el.node, {attributes: !0})
}
active(t, e) {
if (!t) return this.selection.clear().remove(), void this.observer.disconnect();
this.init(e)
}
createSelection() {
this.selection.polygon(this.points).addClass("svg_select_shape_pointSelect")
}
updateSelection() {
this.selection.get(0).plot(this.points)
}
createPointHandles() {
this.points.forEach(((t, e, i) => {
this.createHandle.call(this, this.selection, t, e, i), this.selection.get(e + 1).addClass("svg_select_handle_point").on("mousedown.selection touchstart.selection", as("point", this.el, this.points, e))
}))
}
createHandleFn(t) {
t.circle(5)
}
updateHandleFn(t, e) {
t.center(e[0], e[1])
}
updatePointHandles() {
this.points.forEach(((t, e, i) => {
this.updateHandle.call(this, this.selection.get(e + 1), t, e, i)
}))
}
updatePoints() {
const t = this.el.parent().screenCTM().inverseO().multiplyO(this.el.screenCTM());
this.points = this.el.array().map((e => ss(e, t)))
}
mutationHandler() {
this.updatePoints(), this.updateSelection(), this.updatePointHandles()
}
})
});
const os = t => (t.changedTouches && (t = t.changedTouches[0]), {x: t.clientX, y: t.clientY}), ls = t => {
let e = 1 / 0, i = 1 / 0, a = -1 / 0, s = -1 / 0;
for (let r = 0; r < t.length; r++) {
const n = t[r];
e = Math.min(e, n[0]), i = Math.min(i, n[1]), a = Math.max(a, n[0]), s = Math.max(s, n[1])
}
return new kt(e, i, a - e, s - i)
};
class hs {
constructor(t) {
this.el = t, t.remember("_ResizeHandler", this), this.lastCoordinates = null, this.eventType = "", this.lastEvent = null, this.handleResize = this.handleResize.bind(this), this.resize = this.resize.bind(this), this.endResize = this.endResize.bind(this), this.rotate = this.rotate.bind(this), this.movePoint = this.movePoint.bind(this)
}
active(t, e) {
this.preserveAspectRatio = e.preserveAspectRatio ?? !1, this.aroundCenter = e.aroundCenter ?? !1, this.grid = e.grid ?? 0, this.degree = e.degree ?? 0, this.el.off(".resize"), t && (this.el.on(["lt.resize", "rt.resize", "rb.resize", "lb.resize", "t.resize", "r.resize", "b.resize", "l.resize", "rot.resize", "point.resize"], this.handleResize), this.lastEvent && ("rot" === this.eventType ? this.rotate(this.lastEvent) : "point" === this.eventType ? this.movePoint(this.lastEvent) : this.resize(this.lastEvent)))
}
handleResize(t) {
this.eventType = t.type;
const {event: e, index: i, points: a} = t.detail, s = !e.type.indexOf("mouse");
if (s && 1 !== (e.which || e.buttons)) return;
if (this.el.dispatch("beforeresize", {event: t, handler: this}).defaultPrevented) return;
this.box = this.el.bbox(), this.startPoint = this.el.point(os(e)), this.index = i, this.points = a.slice();
const r = (s ? "mousemove" : "touchmove") + ".resize",
n = (s ? "mouseup" : "touchcancel.resize touchend") + ".resize";
"point" === t.type ? zt(window, r, this.movePoint) : "rot" === t.type ? zt(window, r, this.rotate) : zt(window, r, this.resize), zt(window, n, this.endResize)
}
resize(t) {
this.lastEvent = t;
const e = this.snapToGrid(this.el.point(os(t)));
let i = e.x - this.startPoint.x, a = e.y - this.startPoint.y;
this.preserveAspectRatio && this.aroundCenter && (i *= 2, a *= 2);
const s = this.box.x + i, r = this.box.y + a, n = this.box.x2 + i, o = this.box.y2 + a;
let l = new kt(this.box);
if (this.eventType.includes("l") && (l.x = Math.min(s, this.box.x2), l.x2 = Math.max(s, this.box.x2)), this.eventType.includes("r") && (l.x = Math.min(n, this.box.x), l.x2 = Math.max(n, this.box.x)), this.eventType.includes("t") && (l.y = Math.min(r, this.box.y2), l.y2 = Math.max(r, this.box.y2)), this.eventType.includes("b") && (l.y = Math.min(o, this.box.y), l.y2 = Math.max(o, this.box.y)), l.width = l.x2 - l.x, l.height = l.y2 - l.y, this.preserveAspectRatio) {
const t = l.width / this.box.width, e = l.height / this.box.height,
i = ["lt", "t", "rt", "r", "rb", "b", "lb", "l"], a = (i.indexOf(this.eventType) + 4) % i.length,
s = this.aroundCenter ? [this.box.cx, this.box.cy] : this.points[a];
let r = this.eventType.includes("t") || this.eventType.includes("b") ? e : t;
r = 2 === this.eventType.length ? Math.max(t, e) : r, l = function (t, e, i) {
const a = [[t.x, t.y], [t.x + t.width, t.y], [t.x + t.width, t.y + t.height], [t.x, t.y + t.height]].map((([t, a]) => {
const s = t - e[0], r = (a - e[1]) * i;
return [s * i + e[0], r + e[1]]
}));
return ls(a)
}(this.box, s, r)
}
this.el.dispatch("resize", {
box: new kt(l),
angle: 0,
eventType: this.eventType,
event: t,
handler: this
}).defaultPrevented || this.el.size(l.width, l.height).move(l.x, l.y)
}
movePoint(t) {
this.lastEvent = t;
const {x: e, y: i} = this.snapToGrid(this.el.point(os(t))), a = this.el.array().slice();
a[this.index] = [e, i], this.el.dispatch("resize", {
box: ls(a),
angle: 0,
eventType: this.eventType,
event: t,
handler: this
}).defaultPrevented || this.el.plot(a)
}
rotate(t) {
this.lastEvent = t;
const e = this.startPoint, i = this.el.point(os(t)), {cx: a, cy: s} = this.box, r = e.x - a, n = e.y - s,
o = i.x - a, l = i.y - s, h = Math.sqrt(r * r + n * n) * Math.sqrt(o * o + l * l);
if (0 === h) return;
let c = Math.acos((r * o + n * l) / h) / Math.PI * 180;
if (!c) return;
i.x < e.x && (c = -c);
const d = new vt(this.el), {x: u, y: g} = new bt(a, s).transformO(d), {rotate: p} = d.decompose(),
f = this.snapToAngle(p + c) - p;
this.el.dispatch("resize", {
box: this.box,
angle: f,
eventType: this.eventType,
event: t,
handler: this
}).defaultPrevented || this.el.transform(d.rotateO(f, u, g))
}
endResize(t) {
"rot" !== this.eventType && "point" !== this.eventType && this.resize(t), this.lastEvent = null, this.eventType = "", Xt(window, "mousemove.resize touchmove.resize"), Xt(window, "mouseup.resize touchend.resize")
}
snapToGrid(t) {
return this.grid && (t.x = Math.round(t.x / this.grid) * this.grid, t.y = Math.round(t.y / this.grid) * this.grid), t
}
snapToAngle(t) {
return this.degree && (t = Math.round(t / this.degree) * this.degree), t
}
}
Q(Gt, {
resize: function (t = !0, e = {}) {
"object" == typeof t && (e = t, t = !0);
let i = this.remember("_ResizeHandler");
return i || (t.prototype instanceof hs ? (i = new t(this), t = !0) : i = new hs(this), this.remember("_resizeHandler", i)), i.active(t, e), this
}
}), void 0 === window.SVG && (window.SVG = yi), void 0 === window.Apex && (window.Apex = {});
var cs = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "initModules", value: function () {
this.ctx.publicMethods = ["updateOptions", "updateSeries", "appendData", "appendSeries", "isSeriesHidden", "highlightSeries", "toggleSeries", "showSeries", "hideSeries", "setLocale", "resetSeries", "zoomX", "toggleDataPointSelection", "dataURI", "exportToCSV", "addXaxisAnnotation", "addYaxisAnnotation", "addPointAnnotation", "clearAnnotations", "removeAnnotation", "paper", "destroy"], this.ctx.eventList = ["click", "mousedown", "mousemove", "mouseleave", "touchstart", "touchmove", "touchleave", "mouseup", "touchend"], this.ctx.animations = new y(this.ctx), this.ctx.axes = new na(this.ctx), this.ctx.core = new Za(this.ctx.el, this.ctx), this.ctx.config = new Wi({}), this.ctx.data = new Ji(this.ctx), this.ctx.grid = new ta(this.ctx), this.ctx.graphics = new Mi(this.ctx), this.ctx.coreUtils = new Pi(this.ctx), this.ctx.crosshairs = new oa(this.ctx), this.ctx.events = new sa(this.ctx), this.ctx.exports = new Qi(this.ctx), this.ctx.fill = new ji(this.ctx), this.ctx.localization = new ra(this.ctx), this.ctx.options = new Oi, this.ctx.responsive = new la(this.ctx), this.ctx.series = new $i(this.ctx), this.ctx.theme = new ha(this.ctx), this.ctx.formatters = new Xi(this.ctx), this.ctx.titleSubtitle = new ca(this.ctx), this.ctx.legend = new ba(this.ctx), this.ctx.toolbar = new ma(this.ctx), this.ctx.tooltip = new La(this.ctx), this.ctx.dimensions = new fa(this.ctx), this.ctx.updateHelpers = new $a(this.ctx), this.ctx.zoomPanSelection = new va(this.ctx), this.ctx.w.globals.tooltip = new La(this.ctx)
}
}]), t
}(), ds = function () {
function t(e) {
i(this, t), this.ctx = e, this.w = e.w
}
return s(t, [{
key: "clear", value: function (t) {
var e = t.isUpdating;
this.ctx.zoomPanSelection && this.ctx.zoomPanSelection.destroy(), this.ctx.toolbar && this.ctx.toolbar.destroy(), this.ctx.animations = null, this.ctx.axes = null, this.ctx.annotations = null, this.ctx.core = null, this.ctx.data = null, this.ctx.grid = null, this.ctx.series = null, this.ctx.responsive = null, this.ctx.theme = null, this.ctx.formatters = null, this.ctx.titleSubtitle = null, this.ctx.legend = null, this.ctx.dimensions = null, this.ctx.options = null, this.ctx.crosshairs = null, this.ctx.zoomPanSelection = null, this.ctx.updateHelpers = null, this.ctx.toolbar = null, this.ctx.localization = null, this.ctx.w.globals.tooltip = null, this.clearDomElements({isUpdating: e})
}
}, {
key: "killSVG", value: function (t) {
t.each((function () {
this.removeClass("*"), this.off()
}), !0), t.clear()
}
}, {
key: "clearDomElements", value: function (t) {
var e = this, i = t.isUpdating, a = this.w.globals.dom.Paper.node;
a.parentNode && a.parentNode.parentNode && !i && (a.parentNode.parentNode.style.minHeight = "unset");
var s = this.w.globals.dom.baseEl;
s && this.ctx.eventList.forEach((function (t) {
s.removeEventListener(t, e.ctx.events.documentEvent)
}));
var r = this.w.globals.dom;
if (null !== this.ctx.el) for (; this.ctx.el.firstChild;) this.ctx.el.removeChild(this.ctx.el.firstChild);
this.killSVG(r.Paper), r.Paper.remove(), r.elWrap = null, r.elGraphical = null, r.elLegendWrap = null, r.elLegendForeign = null, r.baseEl = null, r.elGridRect = null, r.elGridRectMask = null, r.elGridRectBarMask = null, r.elGridRectMarkerMask = null, r.elForecastMask = null, r.elNonForecastMask = null, r.elDefs = null
}
}]), t
}(), us = new WeakMap;
var gs = function () {
function t(e, a) {
i(this, t), this.opts = a, this.ctx = this, this.w = new Gi(a).init(), this.el = e, this.w.globals.cuid = v.randomId(), this.w.globals.chartID = this.w.config.chart.id ? v.escapeString(this.w.config.chart.id) : this.w.globals.cuid, new cs(this).initModules(), this.lastUpdateOptions = null, this.create = v.bind(this.create, this), this.windowResizeHandler = this._windowResizeHandler.bind(this), this.parentResizeHandler = this._parentResizeCallback.bind(this)
}
return s(t, [{
key: "render", value: function () {
var t = this;
return new Promise((function (e, i) {
if (v.elementExists(t.el)) {
void 0 === Apex._chartInstances && (Apex._chartInstances = []), t.w.config.chart.id && Apex._chartInstances.push({
id: t.w.globals.chartID,
group: t.w.config.chart.group,
chart: t
}), t.setLocale(t.w.config.chart.defaultLocale);
var a = t.w.config.chart.events.beforeMount;
"function" == typeof a && a(t, t.w), t.events.fireEvent("beforeMount", [t, t.w]), window.addEventListener("resize", t.windowResizeHandler), function (t, e) {
var i = !1;
if (t.nodeType !== Node.DOCUMENT_FRAGMENT_NODE) {
var a = t.getBoundingClientRect();
"none" !== t.style.display && 0 !== a.width || (i = !0)
}
var s = new ResizeObserver((function (a) {
i && e.call(t, a), i = !0
}));
t.nodeType === Node.DOCUMENT_FRAGMENT_NODE ? Array.from(t.children).forEach((function (t) {
return s.observe(t)
})) : s.observe(t), us.set(e, s)
}(t.el.parentNode, t.parentResizeHandler);
var s = t.el.getRootNode && t.el.getRootNode(), r = v.is("ShadowRoot", s),
n = t.el.ownerDocument,
o = r ? s.getElementById("apexcharts-css") : n.getElementById("apexcharts-css");
if (!o) {
var l;
(o = document.createElement("style")).id = "apexcharts-css", o.textContent = '@keyframes opaque {\n 0% {\n opacity: 0\n }\n\n to {\n opacity: 1\n }\n}\n\n@keyframes resizeanim {\n\n 0%,\n to {\n opacity: 0\n }\n}\n\n.apexcharts-canvas {\n position: relative;\n direction: ltr !important;\n user-select: none\n}\n\n.apexcharts-canvas ::-webkit-scrollbar {\n -webkit-appearance: none;\n width: 6px\n}\n\n.apexcharts-canvas ::-webkit-scrollbar-thumb {\n border-radius: 4px;\n background-color: rgba(0, 0, 0, .5);\n box-shadow: 0 0 1px rgba(255, 255, 255, .5);\n -webkit-box-shadow: 0 0 1px rgba(255, 255, 255, .5)\n}\n\n.apexcharts-inner {\n position: relative\n}\n\n.apexcharts-text tspan {\n font-family: inherit\n}\n\nrect.legend-mouseover-inactive,\n.legend-mouseover-inactive rect,\n.legend-mouseover-inactive path,\n.legend-mouseover-inactive circle,\n.legend-mouseover-inactive line,\n.legend-mouseover-inactive text.apexcharts-yaxis-title-text,\n.legend-mouseover-inactive text.apexcharts-yaxis-label {\n transition: .15s ease all;\n opacity: .2\n}\n\n.apexcharts-legend-text {\n padding-left: 15px;\n margin-left: -15px;\n}\n\n.apexcharts-series-collapsed {\n opacity: 0\n}\n\n.apexcharts-tooltip {\n border-radius: 5px;\n box-shadow: 2px 2px 6px -4px #999;\n cursor: default;\n font-size: 14px;\n left: 62px;\n opacity: 0;\n pointer-events: none;\n position: absolute;\n top: 20px;\n display: flex;\n flex-direction: column;\n overflow: hidden;\n white-space: nowrap;\n z-index: 12;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-tooltip.apexcharts-theme-light {\n border: 1px solid #e3e3e3;\n background: rgba(255, 255, 255, .96)\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark {\n color: #fff;\n background: rgba(30, 30, 30, .8)\n}\n\n.apexcharts-tooltip * {\n font-family: inherit\n}\n\n.apexcharts-tooltip-title {\n padding: 6px;\n font-size: 15px;\n margin-bottom: 4px\n}\n\n.apexcharts-tooltip.apexcharts-theme-light .apexcharts-tooltip-title {\n background: #eceff1;\n border-bottom: 1px solid #ddd\n}\n\n.apexcharts-tooltip.apexcharts-theme-dark .apexcharts-tooltip-title {\n background: rgba(0, 0, 0, .7);\n border-bottom: 1px solid #333\n}\n\n.apexcharts-tooltip-text-goals-value,\n.apexcharts-tooltip-text-y-value,\n.apexcharts-tooltip-text-z-value {\n display: inline-block;\n margin-left: 5px;\n font-weight: 600\n}\n\n.apexcharts-tooltip-text-goals-label:empty,\n.apexcharts-tooltip-text-goals-value:empty,\n.apexcharts-tooltip-text-y-label:empty,\n.apexcharts-tooltip-text-y-value:empty,\n.apexcharts-tooltip-text-z-value:empty,\n.apexcharts-tooltip-title:empty {\n display: none\n}\n\n.apexcharts-tooltip-text-goals-label,\n.apexcharts-tooltip-text-goals-value {\n padding: 6px 0 5px\n}\n\n.apexcharts-tooltip-goals-group,\n.apexcharts-tooltip-text-goals-label,\n.apexcharts-tooltip-text-goals-value {\n display: flex\n}\n\n.apexcharts-tooltip-text-goals-label:not(:empty),\n.apexcharts-tooltip-text-goals-value:not(:empty) {\n margin-top: -6px\n}\n\n.apexcharts-tooltip-marker {\n display: inline-block;\n position: relative;\n width: 16px;\n height: 16px;\n font-size: 16px;\n line-height: 16px;\n margin-right: 4px;\n text-align: center;\n vertical-align: middle;\n color: inherit;\n}\n\n.apexcharts-tooltip-marker::before {\n content: "";\n display: inline-block;\n width: 100%;\n text-align: center;\n color: currentcolor;\n text-rendering: optimizeLegibility;\n -webkit-font-smoothing: antialiased;\n font-size: 26px;\n font-family: Arial, Helvetica, sans-serif;\n line-height: 14px;\n font-weight: 900;\n}\n\n.apexcharts-tooltip-marker[shape="circle"]::before {\n content: "\\25CF";\n}\n\n.apexcharts-tooltip-marker[shape="square"]::before,\n.apexcharts-tooltip-marker[shape="rect"]::before {\n content: "\\25A0";\n transform: translate(-1px, -2px);\n}\n\n.apexcharts-tooltip-marker[shape="line"]::before {\n content: "\\2500";\n}\n\n.apexcharts-tooltip-marker[shape="diamond"]::before {\n content: "\\25C6";\n font-size: 28px;\n}\n\n.apexcharts-tooltip-marker[shape="triangle"]::before {\n content: "\\25B2";\n font-size: 22px;\n}\n\n.apexcharts-tooltip-marker[shape="cross"]::before {\n content: "\\2715";\n font-size: 18px;\n}\n\n.apexcharts-tooltip-marker[shape="plus"]::before {\n content: "\\2715";\n transform: rotate(45deg) translate(-1px, -1px);\n font-size: 18px;\n}\n\n.apexcharts-tooltip-marker[shape="star"]::before {\n content: "\\2605";\n font-size: 18px;\n}\n\n.apexcharts-tooltip-marker[shape="sparkle"]::before {\n content: "\\2726";\n font-size: 20px;\n}\n\n.apexcharts-tooltip-series-group {\n padding: 0 10px;\n display: none;\n text-align: left;\n justify-content: left;\n align-items: center\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active .apexcharts-tooltip-marker {\n opacity: 1\n}\n\n.apexcharts-tooltip-series-group.apexcharts-active,\n.apexcharts-tooltip-series-group:last-child {\n padding-bottom: 4px\n}\n\n.apexcharts-tooltip-y-group {\n padding: 6px 0 5px\n}\n\n.apexcharts-custom-tooltip,\n.apexcharts-tooltip-box {\n padding: 4px 8px\n}\n\n.apexcharts-tooltip-boxPlot {\n display: flex;\n flex-direction: column-reverse\n}\n\n.apexcharts-tooltip-box>div {\n margin: 4px 0\n}\n\n.apexcharts-tooltip-box span.value {\n font-weight: 700\n}\n\n.apexcharts-tooltip-rangebar {\n padding: 5px 8px\n}\n\n.apexcharts-tooltip-rangebar .category {\n font-weight: 600;\n color: #777\n}\n\n.apexcharts-tooltip-rangebar .series-name {\n font-weight: 700;\n display: block;\n margin-bottom: 5px\n}\n\n.apexcharts-xaxistooltip,\n.apexcharts-yaxistooltip {\n opacity: 0;\n pointer-events: none;\n color: #373d3f;\n font-size: 13px;\n text-align: center;\n border-radius: 2px;\n position: absolute;\n z-index: 10;\n background: #eceff1;\n border: 1px solid #90a4ae\n}\n\n.apexcharts-xaxistooltip {\n padding: 9px 10px;\n transition: .15s ease all\n}\n\n.apexcharts-xaxistooltip.apexcharts-theme-dark {\n background: rgba(0, 0, 0, .7);\n border: 1px solid rgba(0, 0, 0, .5);\n color: #fff\n}\n\n.apexcharts-xaxistooltip:after,\n.apexcharts-xaxistooltip:before {\n left: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-xaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-left: -6px\n}\n\n.apexcharts-xaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-left: -7px\n}\n\n.apexcharts-xaxistooltip-bottom:after,\n.apexcharts-xaxistooltip-bottom:before {\n bottom: 100%\n}\n\n.apexcharts-xaxistooltip-top:after,\n.apexcharts-xaxistooltip-top:before {\n top: 100%\n}\n\n.apexcharts-xaxistooltip-bottom:after {\n border-bottom-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-bottom:before {\n border-bottom-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:after,\n.apexcharts-xaxistooltip-bottom.apexcharts-theme-dark:before {\n border-bottom-color: rgba(0, 0, 0, .5)\n}\n\n.apexcharts-xaxistooltip-top:after {\n border-top-color: #eceff1\n}\n\n.apexcharts-xaxistooltip-top:before {\n border-top-color: #90a4ae\n}\n\n.apexcharts-xaxistooltip-top.apexcharts-theme-dark:after,\n.apexcharts-xaxistooltip-top.apexcharts-theme-dark:before {\n border-top-color: rgba(0, 0, 0, .5)\n}\n\n.apexcharts-xaxistooltip.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-yaxistooltip {\n padding: 4px 10px\n}\n\n.apexcharts-yaxistooltip.apexcharts-theme-dark {\n background: rgba(0, 0, 0, .7);\n border: 1px solid rgba(0, 0, 0, .5);\n color: #fff\n}\n\n.apexcharts-yaxistooltip:after,\n.apexcharts-yaxistooltip:before {\n top: 50%;\n border: solid transparent;\n content: " ";\n height: 0;\n width: 0;\n position: absolute;\n pointer-events: none\n}\n\n.apexcharts-yaxistooltip:after {\n border-color: transparent;\n border-width: 6px;\n margin-top: -6px\n}\n\n.apexcharts-yaxistooltip:before {\n border-color: transparent;\n border-width: 7px;\n margin-top: -7px\n}\n\n.apexcharts-yaxistooltip-left:after,\n.apexcharts-yaxistooltip-left:before {\n left: 100%\n}\n\n.apexcharts-yaxistooltip-right:after,\n.apexcharts-yaxistooltip-right:before {\n right: 100%\n}\n\n.apexcharts-yaxistooltip-left:after {\n border-left-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-left:before {\n border-left-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-left.apexcharts-theme-dark:after,\n.apexcharts-yaxistooltip-left.apexcharts-theme-dark:before {\n border-left-color: rgba(0, 0, 0, .5)\n}\n\n.apexcharts-yaxistooltip-right:after {\n border-right-color: #eceff1\n}\n\n.apexcharts-yaxistooltip-right:before {\n border-right-color: #90a4ae\n}\n\n.apexcharts-yaxistooltip-right.apexcharts-theme-dark:after,\n.apexcharts-yaxistooltip-right.apexcharts-theme-dark:before {\n border-right-color: rgba(0, 0, 0, .5)\n}\n\n.apexcharts-yaxistooltip.apexcharts-active {\n opacity: 1\n}\n\n.apexcharts-yaxistooltip-hidden {\n display: none\n}\n\n.apexcharts-xcrosshairs,\n.apexcharts-ycrosshairs {\n pointer-events: none;\n opacity: 0;\n transition: .15s ease all\n}\n\n.apexcharts-xcrosshairs.apexcharts-active,\n.apexcharts-ycrosshairs.apexcharts-active {\n opacity: 1;\n transition: .15s ease all\n}\n\n.apexcharts-ycrosshairs-hidden {\n opacity: 0\n}\n\n.apexcharts-selection-rect {\n cursor: move\n}\n\n.svg_select_shape {\n stroke-width: 1;\n stroke-dasharray: 10 10;\n stroke: black;\n stroke-opacity: 0.1;\n pointer-events: none;\n fill: none;\n}\n\n.svg_select_handle {\n stroke-width: 3;\n stroke: black;\n fill: none;\n}\n\n.svg_select_handle_r {\n cursor: e-resize;\n}\n\n.svg_select_handle_l {\n cursor: w-resize;\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-zoom {\n cursor: crosshair\n}\n\n.apexcharts-svg.apexcharts-zoomable.hovering-pan {\n cursor: move\n}\n\n.apexcharts-menu-icon,\n.apexcharts-pan-icon,\n.apexcharts-reset-icon,\n.apexcharts-selection-icon,\n.apexcharts-toolbar-custom-icon,\n.apexcharts-zoom-icon,\n.apexcharts-zoomin-icon,\n.apexcharts-zoomout-icon {\n cursor: pointer;\n width: 20px;\n height: 20px;\n line-height: 24px;\n color: #6e8192;\n text-align: center\n}\n\n.apexcharts-menu-icon svg,\n.apexcharts-reset-icon svg,\n.apexcharts-zoom-icon svg,\n.apexcharts-zoomin-icon svg,\n.apexcharts-zoomout-icon svg {\n fill: #6e8192\n}\n\n.apexcharts-selection-icon svg {\n fill: #444;\n transform: scale(.76)\n}\n\n.apexcharts-theme-dark .apexcharts-menu-icon svg,\n.apexcharts-theme-dark .apexcharts-pan-icon svg,\n.apexcharts-theme-dark .apexcharts-reset-icon svg,\n.apexcharts-theme-dark .apexcharts-selection-icon svg,\n.apexcharts-theme-dark .apexcharts-toolbar-custom-icon svg,\n.apexcharts-theme-dark .apexcharts-zoom-icon svg,\n.apexcharts-theme-dark .apexcharts-zoomin-icon svg,\n.apexcharts-theme-dark .apexcharts-zoomout-icon svg {\n fill: #f3f4f5\n}\n\n.apexcharts-canvas .apexcharts-reset-zoom-icon.apexcharts-selected svg,\n.apexcharts-canvas .apexcharts-selection-icon.apexcharts-selected svg,\n.apexcharts-canvas .apexcharts-zoom-icon.apexcharts-selected svg {\n fill: #008ffb\n}\n\n.apexcharts-theme-light .apexcharts-menu-icon:hover svg,\n.apexcharts-theme-light .apexcharts-reset-icon:hover svg,\n.apexcharts-theme-light .apexcharts-selection-icon:not(.apexcharts-selected):hover svg,\n.apexcharts-theme-light .apexcharts-zoom-icon:not(.apexcharts-selected):hover svg,\n.apexcharts-theme-light .apexcharts-zoomin-icon:hover svg,\n.apexcharts-theme-light .apexcharts-zoomout-icon:hover svg {\n fill: #333\n}\n\n.apexcharts-menu-icon,\n.apexcharts-selection-icon {\n position: relative\n}\n\n.apexcharts-reset-icon {\n margin-left: 5px\n}\n\n.apexcharts-menu-icon,\n.apexcharts-reset-icon,\n.apexcharts-zoom-icon {\n transform: scale(.85)\n}\n\n.apexcharts-zoomin-icon,\n.apexcharts-zoomout-icon {\n transform: scale(.7)\n}\n\n.apexcharts-zoomout-icon {\n margin-right: 3px\n}\n\n.apexcharts-pan-icon {\n transform: scale(.62);\n position: relative;\n left: 1px;\n top: 0\n}\n\n.apexcharts-pan-icon svg {\n fill: #fff;\n stroke: #6e8192;\n stroke-width: 2\n}\n\n.apexcharts-pan-icon.apexcharts-selected svg {\n stroke: #008ffb\n}\n\n.apexcharts-pan-icon:not(.apexcharts-selected):hover svg {\n stroke: #333\n}\n\n.apexcharts-toolbar {\n position: absolute;\n z-index: 11;\n max-width: 176px;\n text-align: right;\n border-radius: 3px;\n padding: 0 6px 2px;\n display: flex;\n justify-content: space-between;\n align-items: center\n}\n\n.apexcharts-menu {\n background: #fff;\n position: absolute;\n top: 100%;\n border: 1px solid #ddd;\n border-radius: 3px;\n padding: 3px;\n right: 10px;\n opacity: 0;\n min-width: 110px;\n transition: .15s ease all;\n pointer-events: none\n}\n\n.apexcharts-menu.apexcharts-menu-open {\n opacity: 1;\n pointer-events: all;\n transition: .15s ease all\n}\n\n.apexcharts-menu-item {\n padding: 6px 7px;\n font-size: 12px;\n cursor: pointer\n}\n\n.apexcharts-theme-light .apexcharts-menu-item:hover {\n background: #eee\n}\n\n.apexcharts-theme-dark .apexcharts-menu {\n background: rgba(0, 0, 0, .7);\n color: #fff\n}\n\n@media screen and (min-width:768px) {\n .apexcharts-canvas:hover .apexcharts-toolbar {\n opacity: 1\n }\n}\n\n.apexcharts-canvas .apexcharts-element-hidden,\n.apexcharts-datalabel.apexcharts-element-hidden,\n.apexcharts-hide .apexcharts-series-points {\n opacity: 0;\n}\n\n.apexcharts-hidden-element-shown {\n opacity: 1;\n transition: 0.25s ease all;\n}\n\n.apexcharts-datalabel,\n.apexcharts-datalabel-label,\n.apexcharts-datalabel-value,\n.apexcharts-datalabels,\n.apexcharts-pie-label {\n cursor: default;\n pointer-events: none\n}\n\n.apexcharts-pie-label-delay {\n opacity: 0;\n animation-name: opaque;\n animation-duration: .3s;\n animation-fill-mode: forwards;\n animation-timing-function: ease\n}\n\n.apexcharts-radialbar-label {\n cursor: pointer;\n}\n\n.apexcharts-annotation-rect,\n.apexcharts-area-series .apexcharts-area,\n.apexcharts-gridline,\n.apexcharts-line,\n.apexcharts-point-annotation-label,\n.apexcharts-radar-series path:not(.apexcharts-marker),\n.apexcharts-radar-series polygon,\n.apexcharts-toolbar svg,\n.apexcharts-tooltip .apexcharts-marker,\n.apexcharts-xaxis-annotation-label,\n.apexcharts-yaxis-annotation-label,\n.apexcharts-zoom-rect,\n.no-pointer-events {\n pointer-events: none\n}\n\n.apexcharts-tooltip-active .apexcharts-marker {\n transition: .15s ease all\n}\n\n.apexcharts-radar-series .apexcharts-yaxis {\n pointer-events: none;\n}\n\n.resize-triggers {\n animation: 1ms resizeanim;\n visibility: hidden;\n opacity: 0;\n height: 100%;\n width: 100%;\n overflow: hidden\n}\n\n.contract-trigger:before,\n.resize-triggers,\n.resize-triggers>div {\n content: " ";\n display: block;\n position: absolute;\n top: 0;\n left: 0\n}\n\n.resize-triggers>div {\n height: 100%;\n width: 100%;\n background: #eee;\n overflow: auto\n}\n\n.contract-trigger:before {\n overflow: hidden;\n width: 200%;\n height: 200%\n}\n\n.apexcharts-bar-goals-markers {\n pointer-events: none\n}\n\n.apexcharts-bar-shadows {\n pointer-events: none\n}\n\n.apexcharts-rangebar-goals-markers {\n pointer-events: none\n}\n\n.apexcharts-disable-transitions * {\n transition: none !important;\n}';
var h = (null === (l = t.opts.chart) || void 0 === l ? void 0 : l.nonce) || t.w.config.chart.nonce;
h && o.setAttribute("nonce", h), r ? s.prepend(o) : !1 !== t.w.config.chart.injectStyleSheet && n.head.appendChild(o)
}
var c = t.create(t.w.config.series, {});
if (!c) return e(t);
t.mount(c).then((function () {
"function" == typeof t.w.config.chart.events.mounted && t.w.config.chart.events.mounted(t, t.w), t.events.fireEvent("mounted", [t, t.w]), e(c)
})).catch((function (t) {
i(t)
}))
} else i(new Error("Element not found"))
}))
}
}, {
key: "create", value: function (t, e) {
var i = this, a = this.w;
new cs(this).initModules();
var s = this.w.globals;
if (s.noData = !1, s.animationEnded = !1, !v.elementExists(this.el)) return s.animationEnded = !0, null;
(this.responsive.checkResponsiveConfig(e), a.config.xaxis.convertedCatToNumeric) && new Ni(a.config).convertCatToNumericXaxis(a.config, this.ctx);
if (this.core.setupElements(), "treemap" === a.config.chart.type && (a.config.grid.show = !1, a.config.yaxis[0].show = !1), 0 === s.svgWidth) return s.animationEnded = !0, null;
var r = t;
t.forEach((function (t, e) {
t.hidden && (r = i.legend.legendHelpers.getSeriesAfterCollapsing({realIndex: e}))
}));
var n = Pi.checkComboSeries(r, a.config.chart.type);
s.comboCharts = n.comboCharts, s.comboBarCount = n.comboBarCount;
var o = r.every((function (t) {
return t.data && 0 === t.data.length
}));
(0 === r.length || o && s.collapsedSeries.length < 1) && this.series.handleNoData(), this.events.setupEventHandlers(), this.data.parseData(r), this.theme.init(), new Vi(this).setGlobalMarkerSize(), this.formatters.setLabelFormatters(), this.titleSubtitle.draw(), s.noData && s.collapsedSeries.length !== s.series.length && !a.config.legend.showForSingleSeries || this.legend.init(), this.series.hasAllSeriesEqualX(), s.axisCharts && (this.core.coreCalculations(), "category" !== a.config.xaxis.type && this.formatters.setLabelFormatters(), this.ctx.toolbar.minX = a.globals.minX, this.ctx.toolbar.maxX = a.globals.maxX), this.formatters.heatmapLabelFormatters(), new Pi(this).getLargestMarkerSize(), this.dimensions.plotCoords();
var l = this.core.xySettings();
this.grid.createGridMask();
var h = this.core.plotChartType(r, l), c = new qi(this);
return c.bringForward(), a.config.dataLabels.background.enabled && c.dataLabelsBackground(), this.core.shiftGraphPosition(), a.globals.dataPoints > 50 && a.globals.dom.elWrap.classList.add("apexcharts-disable-transitions"), {
elGraph: h,
xyRatios: l,
dimensions: {
plot: {
left: a.globals.translateX,
top: a.globals.translateY,
width: a.globals.gridWidth,
height: a.globals.gridHeight
}
}
}
}
}, {
key: "mount", value: function () {
var t = this, e = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : null, i = this,
a = i.w;
return new Promise((function (s, r) {
if (null === i.el) return r(new Error("Not enough data to display or target element not found"));
(null === e || a.globals.allSeriesCollapsed) && i.series.handleNoData(), i.grid = new ta(i);
var n, o, l = i.grid.drawGrid();
(i.annotations = new Fi(i), i.annotations.drawImageAnnos(), i.annotations.drawTextAnnos(), "back" === a.config.grid.position) && (l && a.globals.dom.elGraphical.add(l.el), null != l && null !== (n = l.elGridBorders) && void 0 !== n && n.node && a.globals.dom.elGraphical.add(l.elGridBorders));
if (Array.isArray(e.elGraph)) for (var h = 0; h < e.elGraph.length; h++) a.globals.dom.elGraphical.add(e.elGraph[h]); else a.globals.dom.elGraphical.add(e.elGraph);
"front" === a.config.grid.position && (l && a.globals.dom.elGraphical.add(l.el), null != l && null !== (o = l.elGridBorders) && void 0 !== o && o.node && a.globals.dom.elGraphical.add(l.elGridBorders));
"front" === a.config.xaxis.crosshairs.position && i.crosshairs.drawXCrosshairs(), "front" === a.config.yaxis[0].crosshairs.position && i.crosshairs.drawYCrosshairs(), "treemap" !== a.config.chart.type && i.axes.drawAxis(a.config.chart.type, l);
var c = new Ki(t.ctx, l), d = new aa(t.ctx, l);
if (null !== l && (c.xAxisLabelCorrections(l.xAxisTickWidth), d.setYAxisTextAlignments(), a.config.yaxis.map((function (t, e) {
-1 === a.globals.ignoreYAxisIndexes.indexOf(e) && d.yAxisTitleRotate(e, t.opposite)
}))), i.annotations.drawAxesAnnotations(), !a.globals.noData) {
if (a.config.tooltip.enabled && !a.globals.noData && i.w.globals.tooltip.drawTooltip(e.xyRatios), a.globals.axisCharts && (a.globals.isXNumeric || a.config.xaxis.convertedCatToNumeric || a.globals.isRangeBar)) (a.config.chart.zoom.enabled || a.config.chart.selection && a.config.chart.selection.enabled || a.config.chart.pan && a.config.chart.pan.enabled) && i.zoomPanSelection.init({xyRatios: e.xyRatios}); else {
var u = a.config.chart.toolbar.tools;
["zoom", "zoomin", "zoomout", "selection", "pan", "reset"].forEach((function (t) {
u[t] = !1
}))
}
a.config.chart.toolbar.show && !a.globals.allSeriesCollapsed && i.toolbar.createToolbar()
}
a.globals.memory.methodsToExec.length > 0 && a.globals.memory.methodsToExec.forEach((function (t) {
t.method(t.params, !1, t.context)
})), a.globals.axisCharts || a.globals.noData || i.core.resizeNonAxisCharts(), s(i)
}))
}
}, {
key: "destroy", value: function () {
window.removeEventListener("resize", this.windowResizeHandler), function (t, e) {
var i = us.get(e);
i && (i.disconnect(), us.delete(e))
}(this.el.parentNode, this.parentResizeHandler);
var t = this.w.config.chart.id;
t && Apex._chartInstances.forEach((function (e, i) {
e.id === v.escapeString(t) && Apex._chartInstances.splice(i, 1)
})), new ds(this.ctx).clear({isUpdating: !1})
}
}, {
key: "updateOptions", value: function (t) {
var e = this, i = arguments.length > 1 && void 0 !== arguments[1] && arguments[1],
a = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2],
s = !(arguments.length > 3 && void 0 !== arguments[3]) || arguments[3],
r = !(arguments.length > 4 && void 0 !== arguments[4]) || arguments[4], n = this.w;
return n.globals.selection = void 0, this.lastUpdateOptions && JSON.stringify(this.lastUpdateOptions) === JSON.stringify(t) ? this : (t.series && (this.data.resetParsingFlags(), this.series.resetSeries(!1, !0, !1), t.series.length && t.series[0].data && (t.series = t.series.map((function (t, i) {
return e.updateHelpers._extendSeries(t, i)
}))), this.updateHelpers.revertDefaultAxisMinMax()), t.xaxis && (t = this.updateHelpers.forceXAxisUpdate(t)), t.yaxis && (t = this.updateHelpers.forceYAxisUpdate(t)), n.globals.collapsedSeriesIndices.length > 0 && this.series.clearPreviousPaths(), t.theme && (t = this.theme.updateThemeOptions(t)), this.updateHelpers._updateOptions(t, i, a, s, r))
}
}, {
key: "updateSeries", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : [],
e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1],
i = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2];
return this.data.resetParsingFlags(), this.series.resetSeries(!1), this.updateHelpers.revertDefaultAxisMinMax(), this.updateHelpers._updateSeries(t, e, i)
}
}, {
key: "appendSeries", value: function (t) {
var e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1],
i = !(arguments.length > 2 && void 0 !== arguments[2]) || arguments[2];
this.data.resetParsingFlags();
var a = this.w.config.series.slice();
return a.push(t), this.series.resetSeries(!1), this.updateHelpers.revertDefaultAxisMinMax(), this.updateHelpers._updateSeries(a, e, i)
}
}, {
key: "appendData", value: function (t) {
var e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1], i = this;
i.data.resetParsingFlags(), i.w.globals.dataChanged = !0, i.series.getPreviousPaths();
for (var a = i.w.config.series.slice(), s = 0; s < a.length; s++) if (null !== t[s] && void 0 !== t[s]) for (var r = 0; r < t[s].data.length; r++) a[s].data.push(t[s].data[r]);
return i.w.config.series = a, e && (i.w.globals.initialSeries = v.clone(i.w.config.series)), this.update()
}
}, {
key: "update", value: function (t) {
var e = this;
return new Promise((function (i, a) {
if (e.lastUpdateOptions && JSON.stringify(e.lastUpdateOptions) === JSON.stringify(t)) return i(e);
e.lastUpdateOptions = v.clone(t), new ds(e.ctx).clear({isUpdating: !0});
var s = e.create(e.w.config.series, t);
if (!s) return i(e);
e.mount(s).then((function () {
"function" == typeof e.w.config.chart.events.updated && e.w.config.chart.events.updated(e, e.w), e.events.fireEvent("updated", [e, e.w]), e.w.globals.isDirty = !0, i(e)
})).catch((function (t) {
a(t)
}))
}))
}
}, {
key: "getSyncedCharts", value: function () {
var t = this.getGroupedCharts(), e = [this];
return t.length && (e = [], t.forEach((function (t) {
e.push(t)
}))), e
}
}, {
key: "getGroupedCharts", value: function () {
var t = this;
return Apex._chartInstances.filter((function (t) {
if (t.group) return !0
})).map((function (e) {
return t.w.config.chart.group === e.group ? e.chart : t
}))
}
}, {
key: "toggleSeries", value: function (t) {
return this.series.toggleSeries(t)
}
}, {
key: "highlightSeriesOnLegendHover", value: function (t, e) {
return this.series.toggleSeriesOnHover(t, e)
}
}, {
key: "showSeries", value: function (t) {
this.series.showSeries(t)
}
}, {
key: "hideSeries", value: function (t) {
this.series.hideSeries(t)
}
}, {
key: "highlightSeries", value: function (t) {
this.series.highlightSeries(t)
}
}, {
key: "isSeriesHidden", value: function (t) {
this.series.isSeriesHidden(t)
}
}, {
key: "resetSeries", value: function () {
var t = !(arguments.length > 0 && void 0 !== arguments[0]) || arguments[0],
e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1];
this.series.resetSeries(t, e)
}
}, {
key: "addEventListener", value: function (t, e) {
this.events.addEventListener(t, e)
}
}, {
key: "removeEventListener", value: function (t, e) {
this.events.removeEventListener(t, e)
}
}, {
key: "addXaxisAnnotation", value: function (t) {
var e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1],
i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : void 0, a = this;
i && (a = i), a.annotations.addXaxisAnnotationExternal(t, e, a)
}
}, {
key: "addYaxisAnnotation", value: function (t) {
var e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1],
i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : void 0, a = this;
i && (a = i), a.annotations.addYaxisAnnotationExternal(t, e, a)
}
}, {
key: "addPointAnnotation", value: function (t) {
var e = !(arguments.length > 1 && void 0 !== arguments[1]) || arguments[1],
i = arguments.length > 2 && void 0 !== arguments[2] ? arguments[2] : void 0, a = this;
i && (a = i), a.annotations.addPointAnnotationExternal(t, e, a)
}
}, {
key: "clearAnnotations", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : void 0, e = this;
t && (e = t), e.annotations.clearAnnotations(e)
}
}, {
key: "removeAnnotation", value: function (t) {
var e = arguments.length > 1 && void 0 !== arguments[1] ? arguments[1] : void 0, i = this;
e && (i = e), i.annotations.removeAnnotation(i, t)
}
}, {
key: "getChartArea", value: function () {
return this.w.globals.dom.baseEl.querySelector(".apexcharts-inner")
}
}, {
key: "getSeriesTotalXRange", value: function (t, e) {
return this.coreUtils.getSeriesTotalsXRange(t, e)
}
}, {
key: "getHighestValueInSeries", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : 0;
return new ia(this.ctx).getMinYMaxY(t).highestY
}
}, {
key: "getLowestValueInSeries", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : 0;
return new ia(this.ctx).getMinYMaxY(t).lowestY
}
}, {
key: "getSeriesTotal", value: function () {
return this.w.globals.seriesTotals
}
}, {
key: "toggleDataPointSelection", value: function (t, e) {
return this.updateHelpers.toggleDataPointSelection(t, e)
}
}, {
key: "zoomX", value: function (t, e) {
this.ctx.toolbar.zoomUpdateOptions(t, e)
}
}, {
key: "setLocale", value: function (t) {
this.localization.setCurrentLocaleValues(t)
}
}, {
key: "dataURI", value: function (t) {
return new Qi(this.ctx).dataURI(t)
}
}, {
key: "getSvgString", value: function (t) {
return new Qi(this.ctx).getSvgString(t)
}
}, {
key: "exportToCSV", value: function () {
var t = arguments.length > 0 && void 0 !== arguments[0] ? arguments[0] : {};
return new Qi(this.ctx).exportToCSV(t)
}
}, {
key: "paper", value: function () {
return this.w.globals.dom.Paper
}
}, {
key: "_parentResizeCallback", value: function () {
this.w.globals.animationEnded && this.w.config.chart.redrawOnParentResize && this._windowResize()
}
}, {
key: "_windowResize", value: function () {
var t = this;
clearTimeout(this.w.globals.resizeTimer), this.w.globals.resizeTimer = window.setTimeout((function () {
t.w.globals.resized = !0, t.w.globals.dataChanged = !1, t.ctx.update()
}), 150)
}
}, {
key: "_windowResizeHandler", value: function () {
var t = this.w.config.chart.redrawOnWindowResize;
"function" == typeof t && (t = t()), t && this._windowResize()
}
}], [{
key: "getChartByID", value: function (t) {
var e = v.escapeString(t);
if (Apex._chartInstances) {
var i = Apex._chartInstances.filter((function (t) {
return t.id === e
}))[0];
return i && i.chart
}
}
}, {
key: "initOnLoad", value: function () {
for (var e = document.querySelectorAll("[data-apexcharts]"), i = 0; i < e.length; i++) {
new t(e[i], JSON.parse(e[i].getAttribute("data-options"))).render()
}
}
}, {
key: "exec", value: function (t, e) {
var i = this.getChartByID(t);
if (i) {
i.w.globals.isExecCalled = !0;
var a = null;
if (-1 !== i.publicMethods.indexOf(e)) {
for (var s = arguments.length, r = new Array(s > 2 ? s - 2 : 0), n = 2; n < s; n++) r[n - 2] = arguments[n];
a = i[e].apply(i, r)
}
return a
}
}
}, {
key: "merge", value: function (t, e) {
return v.extend(t, e)
}
}, {
key: "getThemePalettes", value: function () {
return {
palette1: ["#008FFB", "#00E396", "#FEB019", "#FF4560", "#775DD0"],
palette2: ["#3F51B5", "#03A9F4", "#4CAF50", "#F9CE1D", "#FF9800"],
palette3: ["#33B2DF", "#546E7A", "#D4526E", "#13D8AA", "#A5978B"],
palette4: ["#4ECDC4", "#C7F464", "#81D4FA", "#FD6A6A", "#546E7A"],
palette5: ["#2B908F", "#F9A3A4", "#90EE7E", "#FA4443", "#69D2E7"],
palette6: ["#449DD1", "#F86624", "#EA3546", "#662E9B", "#C5D86D"],
palette7: ["#D7263D", "#1B998B", "#2E294E", "#F46036", "#E2C044"],
palette8: ["#662E9B", "#F86624", "#F9C80E", "#EA3546", "#43BCCD"],
palette9: ["#5C4742", "#A5978B", "#8D5B4C", "#5A2A27", "#C4BBAF"],
palette10: ["#A300D6", "#7D02EB", "#5653FE", "#2983FF", "#00B1F2"]
}
}
}]), t
}();
return gs
}));