/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ !(function (t, e) { "object" == typeof exports && "undefined" != typeof module ? e(exports) : "function" == typeof define && define.amd ? define(["exports"], e) : e( ((t = "undefined" != typeof globalThis ? globalThis : t || self).echarts = {}) ); })(this, function (t) { "use strict"; /*! ***************************************************************************** Copyright (c) Microsoft Corporation. Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted. THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. ***************************************************************************** */ var e = function (t, n) { return ( (e = Object.setPrototypeOf || ({ __proto__: [] } instanceof Array && function (t, e) { t.__proto__ = e; }) || function (t, e) { for (var n in e) Object.prototype.hasOwnProperty.call(e, n) && (t[n] = e[n]); }), e(t, n) ); }; function n(t, n) { if ("function" != typeof n && null !== n) throw new TypeError( "Class extends value " + String(n) + " is not a constructor or null" ); function i() { this.constructor = t; } e(t, n), (t.prototype = null === n ? Object.create(n) : ((i.prototype = n.prototype), new i())); } var i = function () { (this.firefox = !1), (this.ie = !1), (this.edge = !1), (this.newEdge = !1), (this.weChat = !1); }, r = new (function () { (this.browser = new i()), (this.node = !1), (this.wxa = !1), (this.worker = !1), (this.svgSupported = !1), (this.touchEventsSupported = !1), (this.pointerEventsSupported = !1), (this.domSupported = !1), (this.transformSupported = !1), (this.transform3dSupported = !1), (this.hasGlobalWindow = "undefined" != typeof window); })(); "object" == typeof wx && "function" == typeof wx.getSystemInfoSync ? ((r.wxa = !0), (r.touchEventsSupported = !0)) : "undefined" == typeof document && "undefined" != typeof self ? (r.worker = !0) : !r.hasGlobalWindow || "Deno" in window ? ((r.node = !0), (r.svgSupported = !0)) : (function (t, e) { var n = e.browser, i = t.match(/Firefox\/([\d.]+)/), r = t.match(/MSIE\s([\d.]+)/) || t.match(/Trident\/.+?rv:(([\d.]+))/), o = t.match(/Edge?\/([\d.]+)/), a = /micromessenger/i.test(t); i && ((n.firefox = !0), (n.version = i[1])); r && ((n.ie = !0), (n.version = r[1])); o && ((n.edge = !0), (n.version = o[1]), (n.newEdge = +o[1].split(".")[0] > 18)); a && (n.weChat = !0); (e.svgSupported = "undefined" != typeof SVGRect), (e.touchEventsSupported = "ontouchstart" in window && !n.ie && !n.edge), (e.pointerEventsSupported = "onpointerdown" in window && (n.edge || (n.ie && +n.version >= 11))), (e.domSupported = "undefined" != typeof document); var s = document.documentElement.style; (e.transform3dSupported = ((n.ie && "transition" in s) || n.edge || ("WebKitCSSMatrix" in window && "m11" in new WebKitCSSMatrix()) || "MozPerspective" in s) && !("OTransition" in s)), (e.transformSupported = e.transform3dSupported || (n.ie && +n.version >= 9)); })(navigator.userAgent, r); var o = "sans-serif", a = "12px " + o; var s, l, u = (function (t) { var e = {}; if ("undefined" == typeof JSON) return e; for (var n = 0; n < t.length; n++) { var i = String.fromCharCode(n + 32), r = (t.charCodeAt(n) - 20) / 100; e[i] = r; } return e; })( "007LLmW'55;N0500LLLLLLLLLL00NNNLzWW\\\\WQb\\0FWLg\\bWb\\WQ\\WrWWQ000CL5LLFLL0LL**F*gLLLL5F0LF\\FFF5.5N" ), h = { createCanvas: function () { return ( "undefined" != typeof document && document.createElement("canvas") ); }, measureText: function (t, e) { if (!s) { var n = h.createCanvas(); s = n && n.getContext("2d"); } if (s) return l !== e && (l = s.font = e || a), s.measureText(t); t = t || ""; var i = /((?:\d+)?\.?\d*)px/.exec((e = e || a)), r = (i && +i[1]) || 12, o = 0; if (e.indexOf("mono") >= 0) o = r * t.length; else for (var c = 0; c < t.length; c++) { var p = u[t[c]]; o += null == p ? r : p * r; } return { width: o }; }, loadImage: function (t, e, n) { var i = new Image(); return (i.onload = e), (i.onerror = n), (i.src = t), i; }, }; function c(t) { for (var e in h) t[e] && (h[e] = t[e]); } var p = V( [ "Function", "RegExp", "Date", "Error", "CanvasGradient", "CanvasPattern", "Image", "Canvas", ], function (t, e) { return (t["[object " + e + "]"] = !0), t; }, {} ), d = V( [ "Int8", "Uint8", "Uint8Clamped", "Int16", "Uint16", "Int32", "Uint32", "Float32", "Float64", ], function (t, e) { return (t["[object " + e + "Array]"] = !0), t; }, {} ), f = Object.prototype.toString, g = Array.prototype, y = g.forEach, v = g.filter, m = g.slice, x = g.map, _ = function () {}.constructor, b = _ ? _.prototype : null, w = "__proto__", S = 2311; function M() { return S++; } function I() { for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e]; "undefined" != typeof console && console.error.apply(console, t); } function T(t) { if (null == t || "object" != typeof t) return t; var e = t, n = f.call(t); if ("[object Array]" === n) { if (!pt(t)) { e = []; for (var i = 0, r = t.length; i < r; i++) e[i] = T(t[i]); } } else if (d[n]) { if (!pt(t)) { var o = t.constructor; if (o.from) e = o.from(t); else { e = new o(t.length); for (i = 0, r = t.length; i < r; i++) e[i] = t[i]; } } } else if (!p[n] && !pt(t) && !J(t)) for (var a in ((e = {}), t)) t.hasOwnProperty(a) && a !== w && (e[a] = T(t[a])); return e; } function C(t, e, n) { if (!q(e) || !q(t)) return n ? T(e) : t; for (var i in e) if (e.hasOwnProperty(i) && i !== w) { var r = t[i], o = e[i]; !q(o) || !q(r) || Y(o) || Y(r) || J(o) || J(r) || K(o) || K(r) || pt(o) || pt(r) ? (!n && i in t) || (t[i] = T(e[i])) : C(r, o, n); } return t; } function D(t, e) { for (var n = t[0], i = 1, r = t.length; i < r; i++) n = C(n, t[i], e); return n; } function A(t, e) { if (Object.assign) Object.assign(t, e); else for (var n in e) e.hasOwnProperty(n) && n !== w && (t[n] = e[n]); return t; } function k(t, e, n) { for (var i = G(e), r = 0, o = i.length; r < o; r++) { var a = i[r]; (n ? null != e[a] : null == t[a]) && (t[a] = e[a]); } return t; } var L = h.createCanvas; function P(t, e) { if (t) { if (t.indexOf) return t.indexOf(e); for (var n = 0, i = t.length; n < i; n++) if (t[n] === e) return n; } return -1; } function O(t, e) { var n = t.prototype; function i() {} for (var r in ((i.prototype = e.prototype), (t.prototype = new i()), n)) n.hasOwnProperty(r) && (t.prototype[r] = n[r]); (t.prototype.constructor = t), (t.superClass = e); } function R(t, e, n) { if ( ((t = "prototype" in t ? t.prototype : t), (e = "prototype" in e ? e.prototype : e), Object.getOwnPropertyNames) ) for ( var i = Object.getOwnPropertyNames(e), r = 0; r < i.length; r++ ) { var o = i[r]; "constructor" !== o && (n ? null != e[o] : null == t[o]) && (t[o] = e[o]); } else k(t, e, n); } function N(t) { return !!t && "string" != typeof t && "number" == typeof t.length; } function E(t, e, n) { if (t && e) if (t.forEach && t.forEach === y) t.forEach(e, n); else if (t.length === +t.length) for (var i = 0, r = t.length; i < r; i++) e.call(n, t[i], i, t); else for (var o in t) t.hasOwnProperty(o) && e.call(n, t[o], o, t); } function z(t, e, n) { if (!t) return []; if (!e) return at(t); if (t.map && t.map === x) return t.map(e, n); for (var i = [], r = 0, o = t.length; r < o; r++) i.push(e.call(n, t[r], r, t)); return i; } function V(t, e, n, i) { if (t && e) { for (var r = 0, o = t.length; r < o; r++) n = e.call(i, n, t[r], r, t); return n; } } function B(t, e, n) { if (!t) return []; if (!e) return at(t); if (t.filter && t.filter === v) return t.filter(e, n); for (var i = [], r = 0, o = t.length; r < o; r++) e.call(n, t[r], r, t) && i.push(t[r]); return i; } function F(t, e, n) { if (t && e) for (var i = 0, r = t.length; i < r; i++) if (e.call(n, t[i], i, t)) return t[i]; } function G(t) { if (!t) return []; if (Object.keys) return Object.keys(t); var e = []; for (var n in t) t.hasOwnProperty(n) && e.push(n); return e; } var W = b && X(b.bind) ? b.call.bind(b.bind) : function (t, e) { for (var n = [], i = 2; i < arguments.length; i++) n[i - 2] = arguments[i]; return function () { return t.apply(e, n.concat(m.call(arguments))); }; }; function H(t) { for (var e = [], n = 1; n < arguments.length; n++) e[n - 1] = arguments[n]; return function () { return t.apply(this, e.concat(m.call(arguments))); }; } function Y(t) { return Array.isArray ? Array.isArray(t) : "[object Array]" === f.call(t); } function X(t) { return "function" == typeof t; } function U(t) { return "string" == typeof t; } function Z(t) { return "[object String]" === f.call(t); } function j(t) { return "number" == typeof t; } function q(t) { var e = typeof t; return "function" === e || (!!t && "object" === e); } function K(t) { return !!p[f.call(t)]; } function $(t) { return !!d[f.call(t)]; } function J(t) { return ( "object" == typeof t && "number" == typeof t.nodeType && "object" == typeof t.ownerDocument ); } function Q(t) { return null != t.colorStops; } function tt(t) { return null != t.image; } function et(t) { return "[object RegExp]" === f.call(t); } function nt(t) { return t != t; } function it() { for (var t = [], e = 0; e < arguments.length; e++) t[e] = arguments[e]; for (var n = 0, i = t.length; n < i; n++) if (null != t[n]) return t[n]; } function rt(t, e) { return null != t ? t : e; } function ot(t, e, n) { return null != t ? t : null != e ? e : n; } function at(t) { for (var e = [], n = 1; n < arguments.length; n++) e[n - 1] = arguments[n]; return m.apply(t, e); } function st(t) { if ("number" == typeof t) return [t, t, t, t]; var e = t.length; return 2 === e ? [t[0], t[1], t[0], t[1]] : 3 === e ? [t[0], t[1], t[2], t[1]] : t; } function lt(t, e) { if (!t) throw new Error(e); } function ut(t) { return null == t ? null : "function" == typeof t.trim ? t.trim() : t.replace(/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g, ""); } var ht = "__ec_primitive__"; function ct(t) { t[ht] = !0; } function pt(t) { return t[ht]; } var dt = (function () { function t() { this.data = {}; } return ( (t.prototype.delete = function (t) { var e = this.has(t); return e && delete this.data[t], e; }), (t.prototype.has = function (t) { return this.data.hasOwnProperty(t); }), (t.prototype.get = function (t) { return this.data[t]; }), (t.prototype.set = function (t, e) { return (this.data[t] = e), this; }), (t.prototype.keys = function () { return G(this.data); }), (t.prototype.forEach = function (t) { var e = this.data; for (var n in e) e.hasOwnProperty(n) && t(e[n], n); }), t ); })(), ft = "function" == typeof Map; var gt = (function () { function t(e) { var n = Y(e); this.data = ft ? new Map() : new dt(); var i = this; function r(t, e) { n ? i.set(t, e) : i.set(e, t); } e instanceof t ? e.each(r) : e && E(e, r); } return ( (t.prototype.hasKey = function (t) { return this.data.has(t); }), (t.prototype.get = function (t) { return this.data.get(t); }), (t.prototype.set = function (t, e) { return this.data.set(t, e), e; }), (t.prototype.each = function (t, e) { this.data.forEach(function (n, i) { t.call(e, n, i); }); }), (t.prototype.keys = function () { var t = this.data.keys(); return ft ? Array.from(t) : t; }), (t.prototype.removeKey = function (t) { this.data.delete(t); }), t ); })(); function yt(t) { return new gt(t); } function vt(t, e) { for ( var n = new t.constructor(t.length + e.length), i = 0; i < t.length; i++ ) n[i] = t[i]; var r = t.length; for (i = 0; i < e.length; i++) n[i + r] = e[i]; return n; } function mt(t, e) { var n; if (Object.create) n = Object.create(t); else { var i = function () {}; (i.prototype = t), (n = new i()); } return e && A(n, e), n; } function xt(t) { var e = t.style; (e.webkitUserSelect = "none"), (e.userSelect = "none"), (e.webkitTapHighlightColor = "rgba(0,0,0,0)"), (e["-webkit-touch-callout"] = "none"); } function _t(t, e) { return t.hasOwnProperty(e); } function bt() {} var wt = 180 / Math.PI, St = Object.freeze({ __proto__: null, guid: M, logError: I, clone: T, merge: C, mergeAll: D, extend: A, defaults: k, createCanvas: L, indexOf: P, inherits: O, mixin: R, isArrayLike: N, each: E, map: z, reduce: V, filter: B, find: F, keys: G, bind: W, curry: H, isArray: Y, isFunction: X, isString: U, isStringSafe: Z, isNumber: j, isObject: q, isBuiltInObject: K, isTypedArray: $, isDom: J, isGradientObject: Q, isImagePatternObject: tt, isRegExp: et, eqNaN: nt, retrieve: it, retrieve2: rt, retrieve3: ot, slice: at, normalizeCssArray: st, assert: lt, trim: ut, setAsPrimitive: ct, isPrimitive: pt, HashMap: gt, createHashMap: yt, concatArray: vt, createObject: mt, disableUserSelect: xt, hasOwn: _t, noop: bt, RADIAN_TO_DEGREE: wt, }); function Mt(t, e) { return null == t && (t = 0), null == e && (e = 0), [t, e]; } function It(t, e) { return (t[0] = e[0]), (t[1] = e[1]), t; } function Tt(t) { return [t[0], t[1]]; } function Ct(t, e, n) { return (t[0] = e), (t[1] = n), t; } function Dt(t, e, n) { return (t[0] = e[0] + n[0]), (t[1] = e[1] + n[1]), t; } function At(t, e, n, i) { return (t[0] = e[0] + n[0] * i), (t[1] = e[1] + n[1] * i), t; } function kt(t, e, n) { return (t[0] = e[0] - n[0]), (t[1] = e[1] - n[1]), t; } function Lt(t) { return Math.sqrt(Ot(t)); } var Pt = Lt; function Ot(t) { return t[0] * t[0] + t[1] * t[1]; } var Rt = Ot; function Nt(t, e, n) { return (t[0] = e[0] * n), (t[1] = e[1] * n), t; } function Et(t, e) { var n = Lt(e); return ( 0 === n ? ((t[0] = 0), (t[1] = 0)) : ((t[0] = e[0] / n), (t[1] = e[1] / n)), t ); } function zt(t, e) { return Math.sqrt( (t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1]) ); } var Vt = zt; function Bt(t, e) { return (t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1]); } var Ft = Bt; function Gt(t, e, n, i) { return ( (t[0] = e[0] + i * (n[0] - e[0])), (t[1] = e[1] + i * (n[1] - e[1])), t ); } function Wt(t, e, n) { var i = e[0], r = e[1]; return ( (t[0] = n[0] * i + n[2] * r + n[4]), (t[1] = n[1] * i + n[3] * r + n[5]), t ); } function Ht(t, e, n) { return (t[0] = Math.min(e[0], n[0])), (t[1] = Math.min(e[1], n[1])), t; } function Yt(t, e, n) { return (t[0] = Math.max(e[0], n[0])), (t[1] = Math.max(e[1], n[1])), t; } var Xt = Object.freeze({ __proto__: null, create: Mt, copy: It, clone: Tt, set: Ct, add: Dt, scaleAndAdd: At, sub: kt, len: Lt, length: Pt, lenSquare: Ot, lengthSquare: Rt, mul: function (t, e, n) { return (t[0] = e[0] * n[0]), (t[1] = e[1] * n[1]), t; }, div: function (t, e, n) { return (t[0] = e[0] / n[0]), (t[1] = e[1] / n[1]), t; }, dot: function (t, e) { return t[0] * e[0] + t[1] * e[1]; }, scale: Nt, normalize: Et, distance: zt, dist: Vt, distanceSquare: Bt, distSquare: Ft, negate: function (t, e) { return (t[0] = -e[0]), (t[1] = -e[1]), t; }, lerp: Gt, applyTransform: Wt, min: Ht, max: Yt, }), Ut = function (t, e) { (this.target = t), (this.topTarget = e && e.topTarget); }, Zt = (function () { function t(t) { (this.handler = t), t.on("mousedown", this._dragStart, this), t.on("mousemove", this._drag, this), t.on("mouseup", this._dragEnd, this); } return ( (t.prototype._dragStart = function (t) { for (var e = t.target; e && !e.draggable; ) e = e.parent || e.__hostTarget; e && ((this._draggingTarget = e), (e.dragging = !0), (this._x = t.offsetX), (this._y = t.offsetY), this.handler.dispatchToElement( new Ut(e, t), "dragstart", t.event )); }), (t.prototype._drag = function (t) { var e = this._draggingTarget; if (e) { var n = t.offsetX, i = t.offsetY, r = n - this._x, o = i - this._y; (this._x = n), (this._y = i), e.drift(r, o, t), this.handler.dispatchToElement( new Ut(e, t), "drag", t.event ); var a = this.handler.findHover(n, i, e).target, s = this._dropTarget; (this._dropTarget = a), e !== a && (s && a !== s && this.handler.dispatchToElement( new Ut(s, t), "dragleave", t.event ), a && a !== s && this.handler.dispatchToElement( new Ut(a, t), "dragenter", t.event )); } }), (t.prototype._dragEnd = function (t) { var e = this._draggingTarget; e && (e.dragging = !1), this.handler.dispatchToElement( new Ut(e, t), "dragend", t.event ), this._dropTarget && this.handler.dispatchToElement( new Ut(this._dropTarget, t), "drop", t.event ), (this._draggingTarget = null), (this._dropTarget = null); }), t ); })(), jt = (function () { function t(t) { t && (this._$eventProcessor = t); } return ( (t.prototype.on = function (t, e, n, i) { this._$handlers || (this._$handlers = {}); var r = this._$handlers; if ( ("function" == typeof e && ((i = n), (n = e), (e = null)), !n || !t) ) return this; var o = this._$eventProcessor; null != e && o && o.normalizeQuery && (e = o.normalizeQuery(e)), r[t] || (r[t] = []); for (var a = 0; a < r[t].length; a++) if (r[t][a].h === n) return this; var s = { h: n, query: e, ctx: i || this, callAtLast: n.zrEventfulCallAtLast, }, l = r[t].length - 1, u = r[t][l]; return ( u && u.callAtLast ? r[t].splice(l, 0, s) : r[t].push(s), this ); }), (t.prototype.isSilent = function (t) { var e = this._$handlers; return !e || !e[t] || !e[t].length; }), (t.prototype.off = function (t, e) { var n = this._$handlers; if (!n) return this; if (!t) return (this._$handlers = {}), this; if (e) { if (n[t]) { for (var i = [], r = 0, o = n[t].length; r < o; r++) n[t][r].h !== e && i.push(n[t][r]); n[t] = i; } n[t] && 0 === n[t].length && delete n[t]; } else delete n[t]; return this; }), (t.prototype.trigger = function (t) { for (var e = [], n = 1; n < arguments.length; n++) e[n - 1] = arguments[n]; if (!this._$handlers) return this; var i = this._$handlers[t], r = this._$eventProcessor; if (i) for ( var o = e.length, a = i.length, s = 0; s < a; s++ ) { var l = i[s]; if ( !r || !r.filter || null == l.query || r.filter(t, l.query) ) switch (o) { case 0: l.h.call(l.ctx); break; case 1: l.h.call(l.ctx, e[0]); break; case 2: l.h.call(l.ctx, e[0], e[1]); break; default: l.h.apply(l.ctx, e); } } return r && r.afterTrigger && r.afterTrigger(t), this; }), (t.prototype.triggerWithContext = function (t) { for (var e = [], n = 1; n < arguments.length; n++) e[n - 1] = arguments[n]; if (!this._$handlers) return this; var i = this._$handlers[t], r = this._$eventProcessor; if (i) for ( var o = e.length, a = e[o - 1], s = i.length, l = 0; l < s; l++ ) { var u = i[l]; if ( !r || !r.filter || null == u.query || r.filter(t, u.query) ) switch (o) { case 0: u.h.call(a); break; case 1: u.h.call(a, e[0]); break; case 2: u.h.call(a, e[0], e[1]); break; default: u.h.apply(a, e.slice(1, o - 1)); } } return r && r.afterTrigger && r.afterTrigger(t), this; }), t ); })(), qt = Math.log(2); function Kt(t, e, n, i, r, o) { var a = i + "-" + r, s = t.length; if (o.hasOwnProperty(a)) return o[a]; if (1 === e) { var l = Math.round(Math.log(((1 << s) - 1) & ~r) / qt); return t[n][l]; } for (var u = i | (1 << n), h = n + 1; i & (1 << h); ) h++; for (var c = 0, p = 0, d = 0; p < s; p++) { var f = 1 << p; f & r || ((c += (d % 2 ? -1 : 1) * t[n][p] * Kt(t, e - 1, h, u, r | f, o)), d++); } return (o[a] = c), c; } function $t(t, e) { var n = [ [t[0], t[1], 1, 0, 0, 0, -e[0] * t[0], -e[0] * t[1]], [0, 0, 0, t[0], t[1], 1, -e[1] * t[0], -e[1] * t[1]], [t[2], t[3], 1, 0, 0, 0, -e[2] * t[2], -e[2] * t[3]], [0, 0, 0, t[2], t[3], 1, -e[3] * t[2], -e[3] * t[3]], [t[4], t[5], 1, 0, 0, 0, -e[4] * t[4], -e[4] * t[5]], [0, 0, 0, t[4], t[5], 1, -e[5] * t[4], -e[5] * t[5]], [t[6], t[7], 1, 0, 0, 0, -e[6] * t[6], -e[6] * t[7]], [0, 0, 0, t[6], t[7], 1, -e[7] * t[6], -e[7] * t[7]], ], i = {}, r = Kt(n, 8, 0, 0, 0, i); if (0 !== r) { for (var o = [], a = 0; a < 8; a++) for (var s = 0; s < 8; s++) null == o[s] && (o[s] = 0), (o[s] += ((((a + s) % 2 ? -1 : 1) * Kt(n, 7, 0 === a ? 1 : 0, 1 << a, 1 << s, i)) / r) * e[a]); return function (t, e, n) { var i = e * o[6] + n * o[7] + 1; (t[0] = (e * o[0] + n * o[1] + o[2]) / i), (t[1] = (e * o[3] + n * o[4] + o[5]) / i); }; } } var Jt = "___zrEVENTSAVED", Qt = []; function te(t, e, n, i, o) { if (e.getBoundingClientRect && r.domSupported && !ee(e)) { var a = e[Jt] || (e[Jt] = {}), s = (function (t, e) { var n = e.markers; if (n) return n; n = e.markers = []; for ( var i = ["left", "right"], r = ["top", "bottom"], o = 0; o < 4; o++ ) { var a = document.createElement("div"), s = o % 2, l = (o >> 1) % 2; (a.style.cssText = [ "position: absolute", "visibility: hidden", "padding: 0", "margin: 0", "border-width: 0", "user-select: none", "width:0", "height:0", i[s] + ":0", r[l] + ":0", i[1 - s] + ":auto", r[1 - l] + ":auto", "", ].join("!important;")), t.appendChild(a), n.push(a); } return n; })(e, a), l = (function (t, e, n) { for ( var i = n ? "invTrans" : "trans", r = e[i], o = e.srcCoords, a = [], s = [], l = !0, u = 0; u < 4; u++ ) { var h = t[u].getBoundingClientRect(), c = 2 * u, p = h.left, d = h.top; a.push(p, d), (l = l && o && p === o[c] && d === o[c + 1]), s.push(t[u].offsetLeft, t[u].offsetTop); } return l && r ? r : ((e.srcCoords = a), (e[i] = n ? $t(s, a) : $t(a, s))); })(s, a, o); if (l) return l(t, n, i), !0; } return !1; } function ee(t) { return "CANVAS" === t.nodeName.toUpperCase(); } var ne = /([&<>"'])/g, ie = { "&": "&", "<": "<", ">": ">", '"': """, "'": "'", }; function re(t) { return null == t ? "" : (t + "").replace(ne, function (t, e) { return ie[e]; }); } var oe = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, ae = [], se = r.browser.firefox && +r.browser.version.split(".")[0] < 39; function le(t, e, n, i) { return ( (n = n || {}), i ? ue(t, e, n) : se && null != e.layerX && e.layerX !== e.offsetX ? ((n.zrX = e.layerX), (n.zrY = e.layerY)) : null != e.offsetX ? ((n.zrX = e.offsetX), (n.zrY = e.offsetY)) : ue(t, e, n), n ); } function ue(t, e, n) { if (r.domSupported && t.getBoundingClientRect) { var i = e.clientX, o = e.clientY; if (ee(t)) { var a = t.getBoundingClientRect(); return (n.zrX = i - a.left), void (n.zrY = o - a.top); } if (te(ae, t, i, o)) return (n.zrX = ae[0]), void (n.zrY = ae[1]); } n.zrX = n.zrY = 0; } function he(t) { return t || window.event; } function ce(t, e, n) { if (null != (e = he(e)).zrX) return e; var i = e.type; if (i && i.indexOf("touch") >= 0) { var r = "touchend" !== i ? e.targetTouches[0] : e.changedTouches[0]; r && le(t, r, e, n); } else { le(t, e, e, n); var o = (function (t) { var e = t.wheelDelta; if (e) return e; var n = t.deltaX, i = t.deltaY; if (null == n || null == i) return e; return ( 3 * (0 !== i ? Math.abs(i) : Math.abs(n)) * (i > 0 ? -1 : i < 0 ? 1 : n > 0 ? -1 : 1) ); })(e); e.zrDelta = o ? o / 120 : -(e.detail || 0) / 3; } var a = e.button; return ( null == e.which && void 0 !== a && oe.test(e.type) && (e.which = 1 & a ? 1 : 2 & a ? 3 : 4 & a ? 2 : 0), e ); } function pe(t, e, n, i) { t.addEventListener(e, n, i); } var de = function (t) { t.preventDefault(), t.stopPropagation(), (t.cancelBubble = !0); }; function fe(t) { return 2 === t.which || 3 === t.which; } var ge = (function () { function t() { this._track = []; } return ( (t.prototype.recognize = function (t, e, n) { return this._doTrack(t, e, n), this._recognize(t); }), (t.prototype.clear = function () { return (this._track.length = 0), this; }), (t.prototype._doTrack = function (t, e, n) { var i = t.touches; if (i) { for ( var r = { points: [], touches: [], target: e, event: t, }, o = 0, a = i.length; o < a; o++ ) { var s = i[o], l = le(n, s, {}); r.points.push([l.zrX, l.zrY]), r.touches.push(s); } this._track.push(r); } }), (t.prototype._recognize = function (t) { for (var e in ve) if (ve.hasOwnProperty(e)) { var n = ve[e](this._track, t); if (n) return n; } }), t ); })(); function ye(t) { var e = t[1][0] - t[0][0], n = t[1][1] - t[0][1]; return Math.sqrt(e * e + n * n); } var ve = { pinch: function (t, e) { var n = t.length; if (n) { var i, r = (t[n - 1] || {}).points, o = (t[n - 2] || {}).points || r; if (o && o.length > 1 && r && r.length > 1) { var a = ye(r) / ye(o); !isFinite(a) && (a = 1), (e.pinchScale = a); var s = [ ((i = r)[0][0] + i[1][0]) / 2, (i[0][1] + i[1][1]) / 2, ]; return ( (e.pinchX = s[0]), (e.pinchY = s[1]), { type: "pinch", target: t[0].target, event: e } ); } } }, }; function me() { return [1, 0, 0, 1, 0, 0]; } function xe(t) { return ( (t[0] = 1), (t[1] = 0), (t[2] = 0), (t[3] = 1), (t[4] = 0), (t[5] = 0), t ); } function _e(t, e) { return ( (t[0] = e[0]), (t[1] = e[1]), (t[2] = e[2]), (t[3] = e[3]), (t[4] = e[4]), (t[5] = e[5]), t ); } function be(t, e, n) { var i = e[0] * n[0] + e[2] * n[1], r = e[1] * n[0] + e[3] * n[1], o = e[0] * n[2] + e[2] * n[3], a = e[1] * n[2] + e[3] * n[3], s = e[0] * n[4] + e[2] * n[5] + e[4], l = e[1] * n[4] + e[3] * n[5] + e[5]; return ( (t[0] = i), (t[1] = r), (t[2] = o), (t[3] = a), (t[4] = s), (t[5] = l), t ); } function we(t, e, n) { return ( (t[0] = e[0]), (t[1] = e[1]), (t[2] = e[2]), (t[3] = e[3]), (t[4] = e[4] + n[0]), (t[5] = e[5] + n[1]), t ); } function Se(t, e, n, i) { void 0 === i && (i = [0, 0]); var r = e[0], o = e[2], a = e[4], s = e[1], l = e[3], u = e[5], h = Math.sin(n), c = Math.cos(n); return ( (t[0] = r * c + s * h), (t[1] = -r * h + s * c), (t[2] = o * c + l * h), (t[3] = -o * h + c * l), (t[4] = c * (a - i[0]) + h * (u - i[1]) + i[0]), (t[5] = c * (u - i[1]) - h * (a - i[0]) + i[1]), t ); } function Me(t, e, n) { var i = n[0], r = n[1]; return ( (t[0] = e[0] * i), (t[1] = e[1] * r), (t[2] = e[2] * i), (t[3] = e[3] * r), (t[4] = e[4] * i), (t[5] = e[5] * r), t ); } function Ie(t, e) { var n = e[0], i = e[2], r = e[4], o = e[1], a = e[3], s = e[5], l = n * a - o * i; return l ? ((l = 1 / l), (t[0] = a * l), (t[1] = -o * l), (t[2] = -i * l), (t[3] = n * l), (t[4] = (i * s - a * r) * l), (t[5] = (o * r - n * s) * l), t) : null; } function Te(t) { var e = [1, 0, 0, 1, 0, 0]; return _e(e, t), e; } var Ce = Object.freeze({ __proto__: null, create: me, identity: xe, copy: _e, mul: be, translate: we, rotate: Se, scale: Me, invert: Ie, clone: Te, }), De = (function () { function t(t, e) { (this.x = t || 0), (this.y = e || 0); } return ( (t.prototype.copy = function (t) { return (this.x = t.x), (this.y = t.y), this; }), (t.prototype.clone = function () { return new t(this.x, this.y); }), (t.prototype.set = function (t, e) { return (this.x = t), (this.y = e), this; }), (t.prototype.equal = function (t) { return t.x === this.x && t.y === this.y; }), (t.prototype.add = function (t) { return (this.x += t.x), (this.y += t.y), this; }), (t.prototype.scale = function (t) { (this.x *= t), (this.y *= t); }), (t.prototype.scaleAndAdd = function (t, e) { (this.x += t.x * e), (this.y += t.y * e); }), (t.prototype.sub = function (t) { return (this.x -= t.x), (this.y -= t.y), this; }), (t.prototype.dot = function (t) { return this.x * t.x + this.y * t.y; }), (t.prototype.len = function () { return Math.sqrt(this.x * this.x + this.y * this.y); }), (t.prototype.lenSquare = function () { return this.x * this.x + this.y * this.y; }), (t.prototype.normalize = function () { var t = this.len(); return (this.x /= t), (this.y /= t), this; }), (t.prototype.distance = function (t) { var e = this.x - t.x, n = this.y - t.y; return Math.sqrt(e * e + n * n); }), (t.prototype.distanceSquare = function (t) { var e = this.x - t.x, n = this.y - t.y; return e * e + n * n; }), (t.prototype.negate = function () { return (this.x = -this.x), (this.y = -this.y), this; }), (t.prototype.transform = function (t) { if (t) { var e = this.x, n = this.y; return ( (this.x = t[0] * e + t[2] * n + t[4]), (this.y = t[1] * e + t[3] * n + t[5]), this ); } }), (t.prototype.toArray = function (t) { return (t[0] = this.x), (t[1] = this.y), t; }), (t.prototype.fromArray = function (t) { (this.x = t[0]), (this.y = t[1]); }), (t.set = function (t, e, n) { (t.x = e), (t.y = n); }), (t.copy = function (t, e) { (t.x = e.x), (t.y = e.y); }), (t.len = function (t) { return Math.sqrt(t.x * t.x + t.y * t.y); }), (t.lenSquare = function (t) { return t.x * t.x + t.y * t.y; }), (t.dot = function (t, e) { return t.x * e.x + t.y * e.y; }), (t.add = function (t, e, n) { (t.x = e.x + n.x), (t.y = e.y + n.y); }), (t.sub = function (t, e, n) { (t.x = e.x - n.x), (t.y = e.y - n.y); }), (t.scale = function (t, e, n) { (t.x = e.x * n), (t.y = e.y * n); }), (t.scaleAndAdd = function (t, e, n, i) { (t.x = e.x + n.x * i), (t.y = e.y + n.y * i); }), (t.lerp = function (t, e, n, i) { var r = 1 - i; (t.x = r * e.x + i * n.x), (t.y = r * e.y + i * n.y); }), t ); })(), Ae = Math.min, ke = Math.max, Le = new De(), Pe = new De(), Oe = new De(), Re = new De(), Ne = new De(), Ee = new De(), ze = (function () { function t(t, e, n, i) { n < 0 && ((t += n), (n = -n)), i < 0 && ((e += i), (i = -i)), (this.x = t), (this.y = e), (this.width = n), (this.height = i); } return ( (t.prototype.union = function (t) { var e = Ae(t.x, this.x), n = Ae(t.y, this.y); isFinite(this.x) && isFinite(this.width) ? (this.width = ke(t.x + t.width, this.x + this.width) - e) : (this.width = t.width), isFinite(this.y) && isFinite(this.height) ? (this.height = ke(t.y + t.height, this.y + this.height) - n) : (this.height = t.height), (this.x = e), (this.y = n); }), (t.prototype.applyTransform = function (e) { t.applyTransform(this, this, e); }), (t.prototype.calculateTransform = function (t) { var e = this, n = t.width / e.width, i = t.height / e.height, r = [1, 0, 0, 1, 0, 0]; return ( we(r, r, [-e.x, -e.y]), Me(r, r, [n, i]), we(r, r, [t.x, t.y]), r ); }), (t.prototype.intersect = function (e, n) { if (!e) return !1; e instanceof t || (e = t.create(e)); var i = this, r = i.x, o = i.x + i.width, a = i.y, s = i.y + i.height, l = e.x, u = e.x + e.width, h = e.y, c = e.y + e.height, p = !(o < l || u < r || s < h || c < a); if (n) { var d = 1 / 0, f = 0, g = Math.abs(o - l), y = Math.abs(u - r), v = Math.abs(s - h), m = Math.abs(c - a), x = Math.min(g, y), _ = Math.min(v, m); o < l || u < r ? x > f && ((f = x), g < y ? De.set(Ee, -g, 0) : De.set(Ee, y, 0)) : x < d && ((d = x), g < y ? De.set(Ne, g, 0) : De.set(Ne, -y, 0)), s < h || c < a ? _ > f && ((f = _), v < m ? De.set(Ee, 0, -v) : De.set(Ee, 0, m)) : x < d && ((d = x), v < m ? De.set(Ne, 0, v) : De.set(Ne, 0, -m)); } return n && De.copy(n, p ? Ne : Ee), p; }), (t.prototype.contain = function (t, e) { var n = this; return ( t >= n.x && t <= n.x + n.width && e >= n.y && e <= n.y + n.height ); }), (t.prototype.clone = function () { return new t(this.x, this.y, this.width, this.height); }), (t.prototype.copy = function (e) { t.copy(this, e); }), (t.prototype.plain = function () { return { x: this.x, y: this.y, width: this.width, height: this.height, }; }), (t.prototype.isFinite = function () { return ( isFinite(this.x) && isFinite(this.y) && isFinite(this.width) && isFinite(this.height) ); }), (t.prototype.isZero = function () { return 0 === this.width || 0 === this.height; }), (t.create = function (e) { return new t(e.x, e.y, e.width, e.height); }), (t.copy = function (t, e) { (t.x = e.x), (t.y = e.y), (t.width = e.width), (t.height = e.height); }), (t.applyTransform = function (e, n, i) { if (i) { if ( i[1] < 1e-5 && i[1] > -1e-5 && i[2] < 1e-5 && i[2] > -1e-5 ) { var r = i[0], o = i[3], a = i[4], s = i[5]; return ( (e.x = n.x * r + a), (e.y = n.y * o + s), (e.width = n.width * r), (e.height = n.height * o), e.width < 0 && ((e.x += e.width), (e.width = -e.width)), void ( e.height < 0 && ((e.y += e.height), (e.height = -e.height)) ) ); } (Le.x = Oe.x = n.x), (Le.y = Re.y = n.y), (Pe.x = Re.x = n.x + n.width), (Pe.y = Oe.y = n.y + n.height), Le.transform(i), Re.transform(i), Pe.transform(i), Oe.transform(i), (e.x = Ae(Le.x, Pe.x, Oe.x, Re.x)), (e.y = Ae(Le.y, Pe.y, Oe.y, Re.y)); var l = ke(Le.x, Pe.x, Oe.x, Re.x), u = ke(Le.y, Pe.y, Oe.y, Re.y); (e.width = l - e.x), (e.height = u - e.y); } else e !== n && t.copy(e, n); }), t ); })(), Ve = "silent"; function Be() { de(this.event); } var Fe = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.handler = null), e; } return ( n(e, t), (e.prototype.dispose = function () {}), (e.prototype.setCursor = function () {}), e ); })(jt), Ge = function (t, e) { (this.x = t), (this.y = e); }, We = [ "click", "dblclick", "mousewheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu", ], He = new ze(0, 0, 0, 0), Ye = (function (t) { function e(e, n, i, r, o) { var a = t.call(this) || this; return ( (a._hovered = new Ge(0, 0)), (a.storage = e), (a.painter = n), (a.painterRoot = r), (a._pointerSize = o), (i = i || new Fe()), (a.proxy = null), a.setHandlerProxy(i), (a._draggingMgr = new Zt(a)), a ); } return ( n(e, t), (e.prototype.setHandlerProxy = function (t) { this.proxy && this.proxy.dispose(), t && (E( We, function (e) { t.on && t.on(e, this[e], this); }, this ), (t.handler = this)), (this.proxy = t); }), (e.prototype.mousemove = function (t) { var e = t.zrX, n = t.zrY, i = Ze(this, e, n), r = this._hovered, o = r.target; o && !o.__zr && (o = (r = this.findHover(r.x, r.y)).target); var a = (this._hovered = i ? new Ge(e, n) : this.findHover(e, n)), s = a.target, l = this.proxy; l.setCursor && l.setCursor(s ? s.cursor : "default"), o && s !== o && this.dispatchToElement(r, "mouseout", t), this.dispatchToElement(a, "mousemove", t), s && s !== o && this.dispatchToElement(a, "mouseover", t); }), (e.prototype.mouseout = function (t) { var e = t.zrEventControl; "only_globalout" !== e && this.dispatchToElement(this._hovered, "mouseout", t), "no_globalout" !== e && this.trigger("globalout", { type: "globalout", event: t, }); }), (e.prototype.resize = function () { this._hovered = new Ge(0, 0); }), (e.prototype.dispatch = function (t, e) { var n = this[t]; n && n.call(this, e); }), (e.prototype.dispose = function () { this.proxy.dispose(), (this.storage = null), (this.proxy = null), (this.painter = null); }), (e.prototype.setCursorStyle = function (t) { var e = this.proxy; e.setCursor && e.setCursor(t); }), (e.prototype.dispatchToElement = function (t, e, n) { var i = (t = t || {}).target; if (!i || !i.silent) { for ( var r = "on" + e, o = (function (t, e, n) { return { type: t, event: n, target: e.target, topTarget: e.topTarget, cancelBubble: !1, offsetX: n.zrX, offsetY: n.zrY, gestureEvent: n.gestureEvent, pinchX: n.pinchX, pinchY: n.pinchY, pinchScale: n.pinchScale, wheelDelta: n.zrDelta, zrByTouch: n.zrByTouch, which: n.which, stop: Be, }; })(e, t, n); i && (i[r] && (o.cancelBubble = !!i[r].call(i, o)), i.trigger(e, o), (i = i.__hostTarget ? i.__hostTarget : i.parent), !o.cancelBubble); ); o.cancelBubble || (this.trigger(e, o), this.painter && this.painter.eachOtherLayer && this.painter.eachOtherLayer(function (t) { "function" == typeof t[r] && t[r].call(t, o), t.trigger && t.trigger(e, o); })); } }), (e.prototype.findHover = function (t, e, n) { var i = this.storage.getDisplayList(), r = new Ge(t, e); if ((Ue(i, r, t, e, n), this._pointerSize && !r.target)) { for ( var o = [], a = this._pointerSize, s = a / 2, l = new ze(t - s, e - s, a, a), u = i.length - 1; u >= 0; u-- ) { var h = i[u]; h === n || h.ignore || h.ignoreCoarsePointer || (h.parent && h.parent.ignoreCoarsePointer) || (He.copy(h.getBoundingRect()), h.transform && He.applyTransform(h.transform), He.intersect(l) && o.push(h)); } if (o.length) for ( var c = Math.PI / 12, p = 2 * Math.PI, d = 0; d < s; d += 4 ) for (var f = 0; f < p; f += c) { if ( (Ue( o, r, t + d * Math.cos(f), e + d * Math.sin(f), n ), r.target) ) return r; } } return r; }), (e.prototype.processGesture = function (t, e) { this._gestureMgr || (this._gestureMgr = new ge()); var n = this._gestureMgr; "start" === e && n.clear(); var i = n.recognize( t, this.findHover(t.zrX, t.zrY, null).target, this.proxy.dom ); if (("end" === e && n.clear(), i)) { var r = i.type; t.gestureEvent = r; var o = new Ge(); (o.target = i.target), this.dispatchToElement(o, r, i.event); } }), e ); })(jt); function Xe(t, e, n) { if (t[t.rectHover ? "rectContain" : "contain"](e, n)) { for (var i = t, r = void 0, o = !1; i; ) { if ((i.ignoreClip && (o = !0), !o)) { var a = i.getClipPath(); if (a && !a.contain(e, n)) return !1; } i.silent && (r = !0); var s = i.__hostTarget; i = s || i.parent; } return !r || Ve; } return !1; } function Ue(t, e, n, i, r) { for (var o = t.length - 1; o >= 0; o--) { var a = t[o], s = void 0; if ( a !== r && !a.ignore && (s = Xe(a, n, i)) && (!e.topTarget && (e.topTarget = a), s !== Ve) ) { e.target = a; break; } } } function Ze(t, e, n) { var i = t.painter; return e < 0 || e > i.getWidth() || n < 0 || n > i.getHeight(); } E( [ "click", "mousedown", "mouseup", "mousewheel", "dblclick", "contextmenu", ], function (t) { Ye.prototype[t] = function (e) { var n, i, r = e.zrX, o = e.zrY, a = Ze(this, r, o); if ( (("mouseup" === t && a) || (i = (n = this.findHover(r, o)).target), "mousedown" === t) ) (this._downEl = i), (this._downPoint = [e.zrX, e.zrY]), (this._upEl = i); else if ("mouseup" === t) this._upEl = i; else if ("click" === t) { if ( this._downEl !== this._upEl || !this._downPoint || Vt(this._downPoint, [e.zrX, e.zrY]) > 4 ) return; this._downPoint = null; } this.dispatchToElement(n, t, e); }; } ); function je(t, e, n, i) { var r = e + 1; if (r === n) return 1; if (i(t[r++], t[e]) < 0) { for (; r < n && i(t[r], t[r - 1]) < 0; ) r++; !(function (t, e, n) { n--; for (; e < n; ) { var i = t[e]; (t[e++] = t[n]), (t[n--] = i); } })(t, e, r); } else for (; r < n && i(t[r], t[r - 1]) >= 0; ) r++; return r - e; } function qe(t, e, n, i, r) { for (i === e && i++; i < n; i++) { for (var o, a = t[i], s = e, l = i; s < l; ) r(a, t[(o = (s + l) >>> 1)]) < 0 ? (l = o) : (s = o + 1); var u = i - s; switch (u) { case 3: t[s + 3] = t[s + 2]; case 2: t[s + 2] = t[s + 1]; case 1: t[s + 1] = t[s]; break; default: for (; u > 0; ) (t[s + u] = t[s + u - 1]), u--; } t[s] = a; } } function Ke(t, e, n, i, r, o) { var a = 0, s = 0, l = 1; if (o(t, e[n + r]) > 0) { for (s = i - r; l < s && o(t, e[n + r + l]) > 0; ) (a = l), (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s), (a += r), (l += r); } else { for (s = r + 1; l < s && o(t, e[n + r - l]) <= 0; ) (a = l), (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s); var u = a; (a = r - l), (l = r - u); } for (a++; a < l; ) { var h = a + ((l - a) >>> 1); o(t, e[n + h]) > 0 ? (a = h + 1) : (l = h); } return l; } function $e(t, e, n, i, r, o) { var a = 0, s = 0, l = 1; if (o(t, e[n + r]) < 0) { for (s = r + 1; l < s && o(t, e[n + r - l]) < 0; ) (a = l), (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s); var u = a; (a = r - l), (l = r - u); } else { for (s = i - r; l < s && o(t, e[n + r + l]) >= 0; ) (a = l), (l = 1 + (l << 1)) <= 0 && (l = s); l > s && (l = s), (a += r), (l += r); } for (a++; a < l; ) { var h = a + ((l - a) >>> 1); o(t, e[n + h]) < 0 ? (l = h) : (a = h + 1); } return l; } function Je(t, e) { var n, i, r = 7, o = 0, a = []; function s(s) { var l = n[s], u = i[s], h = n[s + 1], c = i[s + 1]; (i[s] = u + c), s === o - 3 && ((n[s + 1] = n[s + 2]), (i[s + 1] = i[s + 2])), o--; var p = $e(t[h], t, l, u, 0, e); (l += p), 0 !== (u -= p) && 0 !== (c = Ke(t[l + u - 1], t, h, c, c - 1, e)) && (u <= c ? (function (n, i, o, s) { var l = 0; for (l = 0; l < i; l++) a[l] = t[n + l]; var u = 0, h = o, c = n; if (((t[c++] = t[h++]), 0 == --s)) { for (l = 0; l < i; l++) t[c + l] = a[u + l]; return; } if (1 === i) { for (l = 0; l < s; l++) t[c + l] = t[h + l]; return void (t[c + s] = a[u]); } var p, d, f, g = r; for (;;) { (p = 0), (d = 0), (f = !1); do { if (e(t[h], a[u]) < 0) { if ( ((t[c++] = t[h++]), d++, (p = 0), 0 == --s) ) { f = !0; break; } } else if ( ((t[c++] = a[u++]), p++, (d = 0), 1 == --i) ) { f = !0; break; } } while ((p | d) < g); if (f) break; do { if (0 !== (p = $e(t[h], a, u, i, 0, e))) { for (l = 0; l < p; l++) t[c + l] = a[u + l]; if ( ((c += p), (u += p), (i -= p) <= 1) ) { f = !0; break; } } if (((t[c++] = t[h++]), 0 == --s)) { f = !0; break; } if (0 !== (d = Ke(a[u], t, h, s, 0, e))) { for (l = 0; l < d; l++) t[c + l] = t[h + l]; if ( ((c += d), (h += d), 0 === (s -= d)) ) { f = !0; break; } } if (((t[c++] = a[u++]), 1 == --i)) { f = !0; break; } g--; } while (p >= 7 || d >= 7); if (f) break; g < 0 && (g = 0), (g += 2); } if (((r = g) < 1 && (r = 1), 1 === i)) { for (l = 0; l < s; l++) t[c + l] = t[h + l]; t[c + s] = a[u]; } else { if (0 === i) throw new Error(); for (l = 0; l < i; l++) t[c + l] = a[u + l]; } })(l, u, h, c) : (function (n, i, o, s) { var l = 0; for (l = 0; l < s; l++) a[l] = t[o + l]; var u = n + i - 1, h = s - 1, c = o + s - 1, p = 0, d = 0; if (((t[c--] = t[u--]), 0 == --i)) { for (p = c - (s - 1), l = 0; l < s; l++) t[p + l] = a[l]; return; } if (1 === s) { for ( d = (c -= i) + 1, p = (u -= i) + 1, l = i - 1; l >= 0; l-- ) t[d + l] = t[p + l]; return void (t[c] = a[h]); } var f = r; for (;;) { var g = 0, y = 0, v = !1; do { if (e(a[h], t[u]) < 0) { if ( ((t[c--] = t[u--]), g++, (y = 0), 0 == --i) ) { v = !0; break; } } else if ( ((t[c--] = a[h--]), y++, (g = 0), 1 == --s) ) { v = !0; break; } } while ((g | y) < f); if (v) break; do { if ( 0 !== (g = i - $e(a[h], t, n, i, i - 1, e)) ) { for ( i -= g, d = (c -= g) + 1, p = (u -= g) + 1, l = g - 1; l >= 0; l-- ) t[d + l] = t[p + l]; if (0 === i) { v = !0; break; } } if (((t[c--] = a[h--]), 1 == --s)) { v = !0; break; } if ( 0 !== (y = s - Ke(t[u], a, 0, s, s - 1, e)) ) { for ( s -= y, d = (c -= y) + 1, p = (h -= y) + 1, l = 0; l < y; l++ ) t[d + l] = a[p + l]; if (s <= 1) { v = !0; break; } } if (((t[c--] = t[u--]), 0 == --i)) { v = !0; break; } f--; } while (g >= 7 || y >= 7); if (v) break; f < 0 && (f = 0), (f += 2); } (r = f) < 1 && (r = 1); if (1 === s) { for ( d = (c -= i) + 1, p = (u -= i) + 1, l = i - 1; l >= 0; l-- ) t[d + l] = t[p + l]; t[c] = a[h]; } else { if (0 === s) throw new Error(); for (p = c - (s - 1), l = 0; l < s; l++) t[p + l] = a[l]; } })(l, u, h, c)); } return ( (n = []), (i = []), { mergeRuns: function () { for (; o > 1; ) { var t = o - 2; if ( (t >= 1 && i[t - 1] <= i[t] + i[t + 1]) || (t >= 2 && i[t - 2] <= i[t] + i[t - 1]) ) i[t - 1] < i[t + 1] && t--; else if (i[t] > i[t + 1]) break; s(t); } }, forceMergeRuns: function () { for (; o > 1; ) { var t = o - 2; t > 0 && i[t - 1] < i[t + 1] && t--, s(t); } }, pushRun: function (t, e) { (n[o] = t), (i[o] = e), (o += 1); }, } ); } function Qe(t, e, n, i) { n || (n = 0), i || (i = t.length); var r = i - n; if (!(r < 2)) { var o = 0; if (r < 32) qe(t, n, i, n + (o = je(t, n, i, e)), e); else { var a = Je(t, e), s = (function (t) { for (var e = 0; t >= 32; ) (e |= 1 & t), (t >>= 1); return t + e; })(r); do { if ((o = je(t, n, i, e)) < s) { var l = r; l > s && (l = s), qe(t, n, n + l, n + o, e), (o = l); } a.pushRun(n, o), a.mergeRuns(), (r -= o), (n += o); } while (0 !== r); a.forceMergeRuns(); } } } var tn = !1; function en() { tn || ((tn = !0), console.warn( "z / z2 / zlevel of displayable is invalid, which may cause unexpected errors" )); } function nn(t, e) { return t.zlevel === e.zlevel ? t.z === e.z ? t.z2 - e.z2 : t.z - e.z : t.zlevel - e.zlevel; } var rn = (function () { function t() { (this._roots = []), (this._displayList = []), (this._displayListLen = 0), (this.displayableSortFunc = nn); } return ( (t.prototype.traverse = function (t, e) { for (var n = 0; n < this._roots.length; n++) this._roots[n].traverse(t, e); }), (t.prototype.getDisplayList = function (t, e) { e = e || !1; var n = this._displayList; return (!t && n.length) || this.updateDisplayList(e), n; }), (t.prototype.updateDisplayList = function (t) { this._displayListLen = 0; for ( var e = this._roots, n = this._displayList, i = 0, r = e.length; i < r; i++ ) this._updateAndAddDisplayable(e[i], null, t); (n.length = this._displayListLen), Qe(n, nn); }), (t.prototype._updateAndAddDisplayable = function (t, e, n) { if (!t.ignore || n) { t.beforeUpdate(), t.update(), t.afterUpdate(); var i = t.getClipPath(); if (t.ignoreClip) e = null; else if (i) { e = e ? e.slice() : []; for (var r = i, o = t; r; ) (r.parent = o), r.updateTransform(), e.push(r), (o = r), (r = r.getClipPath()); } if (t.childrenRef) { for ( var a = t.childrenRef(), s = 0; s < a.length; s++ ) { var l = a[s]; t.__dirty && (l.__dirty |= 1), this._updateAndAddDisplayable(l, e, n); } t.__dirty = 0; } else { var u = t; e && e.length ? (u.__clipPaths = e) : u.__clipPaths && u.__clipPaths.length > 0 && (u.__clipPaths = []), isNaN(u.z) && (en(), (u.z = 0)), isNaN(u.z2) && (en(), (u.z2 = 0)), isNaN(u.zlevel) && (en(), (u.zlevel = 0)), (this._displayList[this._displayListLen++] = u); } var h = t.getDecalElement && t.getDecalElement(); h && this._updateAndAddDisplayable(h, e, n); var c = t.getTextGuideLine(); c && this._updateAndAddDisplayable(c, e, n); var p = t.getTextContent(); p && this._updateAndAddDisplayable(p, e, n); } }), (t.prototype.addRoot = function (t) { (t.__zr && t.__zr.storage === this) || this._roots.push(t); }), (t.prototype.delRoot = function (t) { if (t instanceof Array) for (var e = 0, n = t.length; e < n; e++) this.delRoot(t[e]); else { var i = P(this._roots, t); i >= 0 && this._roots.splice(i, 1); } }), (t.prototype.delAllRoots = function () { (this._roots = []), (this._displayList = []), (this._displayListLen = 0); }), (t.prototype.getRoots = function () { return this._roots; }), (t.prototype.dispose = function () { (this._displayList = null), (this._roots = null); }), t ); })(), on = (r.hasGlobalWindow && ((window.requestAnimationFrame && window.requestAnimationFrame.bind(window)) || (window.msRequestAnimationFrame && window.msRequestAnimationFrame.bind(window)) || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame)) || function (t) { return setTimeout(t, 16); }, an = { linear: function (t) { return t; }, quadraticIn: function (t) { return t * t; }, quadraticOut: function (t) { return t * (2 - t); }, quadraticInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t : -0.5 * (--t * (t - 2) - 1); }, cubicIn: function (t) { return t * t * t; }, cubicOut: function (t) { return --t * t * t + 1; }, cubicInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t * t : 0.5 * ((t -= 2) * t * t + 2); }, quarticIn: function (t) { return t * t * t * t; }, quarticOut: function (t) { return 1 - --t * t * t * t; }, quarticInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t * t * t : -0.5 * ((t -= 2) * t * t * t - 2); }, quinticIn: function (t) { return t * t * t * t * t; }, quinticOut: function (t) { return --t * t * t * t * t + 1; }, quinticInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t * t * t * t : 0.5 * ((t -= 2) * t * t * t * t + 2); }, sinusoidalIn: function (t) { return 1 - Math.cos((t * Math.PI) / 2); }, sinusoidalOut: function (t) { return Math.sin((t * Math.PI) / 2); }, sinusoidalInOut: function (t) { return 0.5 * (1 - Math.cos(Math.PI * t)); }, exponentialIn: function (t) { return 0 === t ? 0 : Math.pow(1024, t - 1); }, exponentialOut: function (t) { return 1 === t ? 1 : 1 - Math.pow(2, -10 * t); }, exponentialInOut: function (t) { return 0 === t ? 0 : 1 === t ? 1 : (t *= 2) < 1 ? 0.5 * Math.pow(1024, t - 1) : 0.5 * (2 - Math.pow(2, -10 * (t - 1))); }, circularIn: function (t) { return 1 - Math.sqrt(1 - t * t); }, circularOut: function (t) { return Math.sqrt(1 - --t * t); }, circularInOut: function (t) { return (t *= 2) < 1 ? -0.5 * (Math.sqrt(1 - t * t) - 1) : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1); }, elasticIn: function (t) { var e, n = 0.1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? ((n = 1), (e = 0.1)) : (e = (0.4 * Math.asin(1 / n)) / (2 * Math.PI)), -n * Math.pow(2, 10 * (t -= 1)) * Math.sin(((t - e) * (2 * Math.PI)) / 0.4)); }, elasticOut: function (t) { var e, n = 0.1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? ((n = 1), (e = 0.1)) : (e = (0.4 * Math.asin(1 / n)) / (2 * Math.PI)), n * Math.pow(2, -10 * t) * Math.sin(((t - e) * (2 * Math.PI)) / 0.4) + 1); }, elasticInOut: function (t) { var e, n = 0.1, i = 0.4; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? ((n = 1), (e = 0.1)) : (e = (i * Math.asin(1 / n)) / (2 * Math.PI)), (t *= 2) < 1 ? n * Math.pow(2, 10 * (t -= 1)) * Math.sin(((t - e) * (2 * Math.PI)) / i) * -0.5 : n * Math.pow(2, -10 * (t -= 1)) * Math.sin(((t - e) * (2 * Math.PI)) / i) * 0.5 + 1); }, backIn: function (t) { var e = 1.70158; return t * t * ((e + 1) * t - e); }, backOut: function (t) { var e = 1.70158; return --t * t * ((e + 1) * t + e) + 1; }, backInOut: function (t) { var e = 2.5949095; return (t *= 2) < 1 ? t * t * ((e + 1) * t - e) * 0.5 : 0.5 * ((t -= 2) * t * ((e + 1) * t + e) + 2); }, bounceIn: function (t) { return 1 - an.bounceOut(1 - t); }, bounceOut: function (t) { return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + 0.75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + 0.9375 : 7.5625 * (t -= 2.625 / 2.75) * t + 0.984375; }, bounceInOut: function (t) { return t < 0.5 ? 0.5 * an.bounceIn(2 * t) : 0.5 * an.bounceOut(2 * t - 1) + 0.5; }, }, sn = Math.pow, ln = Math.sqrt, un = 1e-8, hn = 1e-4, cn = ln(3), pn = 1 / 3, dn = Mt(), fn = Mt(), gn = Mt(); function yn(t) { return t > -1e-8 && t < un; } function vn(t) { return t > un || t < -1e-8; } function mn(t, e, n, i, r) { var o = 1 - r; return o * o * (o * t + 3 * r * e) + r * r * (r * i + 3 * o * n); } function xn(t, e, n, i, r) { var o = 1 - r; return 3 * (((e - t) * o + 2 * (n - e) * r) * o + (i - n) * r * r); } function _n(t, e, n, i, r, o) { var a = i + 3 * (e - n) - t, s = 3 * (n - 2 * e + t), l = 3 * (e - t), u = t - r, h = s * s - 3 * a * l, c = s * l - 9 * a * u, p = l * l - 3 * s * u, d = 0; if (yn(h) && yn(c)) { if (yn(s)) o[0] = 0; else (M = -l / s) >= 0 && M <= 1 && (o[d++] = M); } else { var f = c * c - 4 * h * p; if (yn(f)) { var g = c / h, y = -g / 2; (M = -s / a + g) >= 0 && M <= 1 && (o[d++] = M), y >= 0 && y <= 1 && (o[d++] = y); } else if (f > 0) { var v = ln(f), m = h * s + 1.5 * a * (-c + v), x = h * s + 1.5 * a * (-c - v); (M = (-s - ((m = m < 0 ? -sn(-m, pn) : sn(m, pn)) + (x = x < 0 ? -sn(-x, pn) : sn(x, pn)))) / (3 * a)) >= 0 && M <= 1 && (o[d++] = M); } else { var _ = (2 * h * s - 3 * a * c) / (2 * ln(h * h * h)), b = Math.acos(_) / 3, w = ln(h), S = Math.cos(b), M = (-s - 2 * w * S) / (3 * a), I = ((y = (-s + w * (S + cn * Math.sin(b))) / (3 * a)), (-s + w * (S - cn * Math.sin(b))) / (3 * a)); M >= 0 && M <= 1 && (o[d++] = M), y >= 0 && y <= 1 && (o[d++] = y), I >= 0 && I <= 1 && (o[d++] = I); } } return d; } function bn(t, e, n, i, r) { var o = 6 * n - 12 * e + 6 * t, a = 9 * e + 3 * i - 3 * t - 9 * n, s = 3 * e - 3 * t, l = 0; if (yn(a)) { if (vn(o)) (h = -s / o) >= 0 && h <= 1 && (r[l++] = h); } else { var u = o * o - 4 * a * s; if (yn(u)) r[0] = -o / (2 * a); else if (u > 0) { var h, c = ln(u), p = (-o - c) / (2 * a); (h = (-o + c) / (2 * a)) >= 0 && h <= 1 && (r[l++] = h), p >= 0 && p <= 1 && (r[l++] = p); } } return l; } function wn(t, e, n, i, r, o) { var a = (e - t) * r + t, s = (n - e) * r + e, l = (i - n) * r + n, u = (s - a) * r + a, h = (l - s) * r + s, c = (h - u) * r + u; (o[0] = t), (o[1] = a), (o[2] = u), (o[3] = c), (o[4] = c), (o[5] = h), (o[6] = l), (o[7] = i); } function Sn(t, e, n, i, r, o, a, s, l, u, h) { var c, p, d, f, g, y = 0.005, v = 1 / 0; (dn[0] = l), (dn[1] = u); for (var m = 0; m < 1; m += 0.05) (fn[0] = mn(t, n, r, a, m)), (fn[1] = mn(e, i, o, s, m)), (f = Ft(dn, fn)) < v && ((c = m), (v = f)); v = 1 / 0; for (var x = 0; x < 32 && !(y < hn); x++) (p = c - y), (d = c + y), (fn[0] = mn(t, n, r, a, p)), (fn[1] = mn(e, i, o, s, p)), (f = Ft(fn, dn)), p >= 0 && f < v ? ((c = p), (v = f)) : ((gn[0] = mn(t, n, r, a, d)), (gn[1] = mn(e, i, o, s, d)), (g = Ft(gn, dn)), d <= 1 && g < v ? ((c = d), (v = g)) : (y *= 0.5)); return ( h && ((h[0] = mn(t, n, r, a, c)), (h[1] = mn(e, i, o, s, c))), ln(v) ); } function Mn(t, e, n, i, r, o, a, s, l) { for (var u = t, h = e, c = 0, p = 1 / l, d = 1; d <= l; d++) { var f = d * p, g = mn(t, n, r, a, f), y = mn(e, i, o, s, f), v = g - u, m = y - h; (c += Math.sqrt(v * v + m * m)), (u = g), (h = y); } return c; } function In(t, e, n, i) { var r = 1 - i; return r * (r * t + 2 * i * e) + i * i * n; } function Tn(t, e, n, i) { return 2 * ((1 - i) * (e - t) + i * (n - e)); } function Cn(t, e, n) { var i = t + n - 2 * e; return 0 === i ? 0.5 : (t - e) / i; } function Dn(t, e, n, i, r) { var o = (e - t) * i + t, a = (n - e) * i + e, s = (a - o) * i + o; (r[0] = t), (r[1] = o), (r[2] = s), (r[3] = s), (r[4] = a), (r[5] = n); } function An(t, e, n, i, r, o, a, s, l) { var u, h = 0.005, c = 1 / 0; (dn[0] = a), (dn[1] = s); for (var p = 0; p < 1; p += 0.05) { (fn[0] = In(t, n, r, p)), (fn[1] = In(e, i, o, p)), (y = Ft(dn, fn)) < c && ((u = p), (c = y)); } c = 1 / 0; for (var d = 0; d < 32 && !(h < hn); d++) { var f = u - h, g = u + h; (fn[0] = In(t, n, r, f)), (fn[1] = In(e, i, o, f)); var y = Ft(fn, dn); if (f >= 0 && y < c) (u = f), (c = y); else { (gn[0] = In(t, n, r, g)), (gn[1] = In(e, i, o, g)); var v = Ft(gn, dn); g <= 1 && v < c ? ((u = g), (c = v)) : (h *= 0.5); } } return l && ((l[0] = In(t, n, r, u)), (l[1] = In(e, i, o, u))), ln(c); } function kn(t, e, n, i, r, o, a) { for (var s = t, l = e, u = 0, h = 1 / a, c = 1; c <= a; c++) { var p = c * h, d = In(t, n, r, p), f = In(e, i, o, p), g = d - s, y = f - l; (u += Math.sqrt(g * g + y * y)), (s = d), (l = f); } return u; } var Ln = /cubic-bezier\(([0-9,\.e ]+)\)/; function Pn(t) { var e = t && Ln.exec(t); if (e) { var n = e[1].split(","), i = +ut(n[0]), r = +ut(n[1]), o = +ut(n[2]), a = +ut(n[3]); if (isNaN(i + r + o + a)) return; var s = []; return function (t) { return t <= 0 ? 0 : t >= 1 ? 1 : _n(0, i, o, 1, t, s) && mn(0, r, a, 1, s[0]); }; } } var On = (function () { function t(t) { (this._inited = !1), (this._startTime = 0), (this._pausedTime = 0), (this._paused = !1), (this._life = t.life || 1e3), (this._delay = t.delay || 0), (this.loop = t.loop || !1), (this.onframe = t.onframe || bt), (this.ondestroy = t.ondestroy || bt), (this.onrestart = t.onrestart || bt), t.easing && this.setEasing(t.easing); } return ( (t.prototype.step = function (t, e) { if ( (this._inited || ((this._startTime = t + this._delay), (this._inited = !0)), !this._paused) ) { var n = this._life, i = t - this._startTime - this._pausedTime, r = i / n; r < 0 && (r = 0), (r = Math.min(r, 1)); var o = this.easingFunc, a = o ? o(r) : r; if ((this.onframe(a), 1 === r)) { if (!this.loop) return !0; var s = i % n; (this._startTime = t - s), (this._pausedTime = 0), this.onrestart(); } return !1; } this._pausedTime += e; }), (t.prototype.pause = function () { this._paused = !0; }), (t.prototype.resume = function () { this._paused = !1; }), (t.prototype.setEasing = function (t) { (this.easing = t), (this.easingFunc = X(t) ? t : an[t] || Pn(t)); }), t ); })(), Rn = function (t) { this.value = t; }, Nn = (function () { function t() { this._len = 0; } return ( (t.prototype.insert = function (t) { var e = new Rn(t); return this.insertEntry(e), e; }), (t.prototype.insertEntry = function (t) { this.head ? ((this.tail.next = t), (t.prev = this.tail), (t.next = null), (this.tail = t)) : (this.head = this.tail = t), this._len++; }), (t.prototype.remove = function (t) { var e = t.prev, n = t.next; e ? (e.next = n) : (this.head = n), n ? (n.prev = e) : (this.tail = e), (t.next = t.prev = null), this._len--; }), (t.prototype.len = function () { return this._len; }), (t.prototype.clear = function () { (this.head = this.tail = null), (this._len = 0); }), t ); })(), En = (function () { function t(t) { (this._list = new Nn()), (this._maxSize = 10), (this._map = {}), (this._maxSize = t); } return ( (t.prototype.put = function (t, e) { var n = this._list, i = this._map, r = null; if (null == i[t]) { var o = n.len(), a = this._lastRemovedEntry; if (o >= this._maxSize && o > 0) { var s = n.head; n.remove(s), delete i[s.key], (r = s.value), (this._lastRemovedEntry = s); } a ? (a.value = e) : (a = new Rn(e)), (a.key = t), n.insertEntry(a), (i[t] = a); } return r; }), (t.prototype.get = function (t) { var e = this._map[t], n = this._list; if (null != e) return ( e !== n.tail && (n.remove(e), n.insertEntry(e)), e.value ); }), (t.prototype.clear = function () { this._list.clear(), (this._map = {}); }), (t.prototype.len = function () { return this._list.len(); }), t ); })(), zn = { transparent: [0, 0, 0, 0], aliceblue: [240, 248, 255, 1], antiquewhite: [250, 235, 215, 1], aqua: [0, 255, 255, 1], aquamarine: [127, 255, 212, 1], azure: [240, 255, 255, 1], beige: [245, 245, 220, 1], bisque: [255, 228, 196, 1], black: [0, 0, 0, 1], blanchedalmond: [255, 235, 205, 1], blue: [0, 0, 255, 1], blueviolet: [138, 43, 226, 1], brown: [165, 42, 42, 1], burlywood: [222, 184, 135, 1], cadetblue: [95, 158, 160, 1], chartreuse: [127, 255, 0, 1], chocolate: [210, 105, 30, 1], coral: [255, 127, 80, 1], cornflowerblue: [100, 149, 237, 1], cornsilk: [255, 248, 220, 1], crimson: [220, 20, 60, 1], cyan: [0, 255, 255, 1], darkblue: [0, 0, 139, 1], darkcyan: [0, 139, 139, 1], darkgoldenrod: [184, 134, 11, 1], darkgray: [169, 169, 169, 1], darkgreen: [0, 100, 0, 1], darkgrey: [169, 169, 169, 1], darkkhaki: [189, 183, 107, 1], darkmagenta: [139, 0, 139, 1], darkolivegreen: [85, 107, 47, 1], darkorange: [255, 140, 0, 1], darkorchid: [153, 50, 204, 1], darkred: [139, 0, 0, 1], darksalmon: [233, 150, 122, 1], darkseagreen: [143, 188, 143, 1], darkslateblue: [72, 61, 139, 1], darkslategray: [47, 79, 79, 1], darkslategrey: [47, 79, 79, 1], darkturquoise: [0, 206, 209, 1], darkviolet: [148, 0, 211, 1], deeppink: [255, 20, 147, 1], deepskyblue: [0, 191, 255, 1], dimgray: [105, 105, 105, 1], dimgrey: [105, 105, 105, 1], dodgerblue: [30, 144, 255, 1], firebrick: [178, 34, 34, 1], floralwhite: [255, 250, 240, 1], forestgreen: [34, 139, 34, 1], fuchsia: [255, 0, 255, 1], gainsboro: [220, 220, 220, 1], ghostwhite: [248, 248, 255, 1], gold: [255, 215, 0, 1], goldenrod: [218, 165, 32, 1], gray: [128, 128, 128, 1], green: [0, 128, 0, 1], greenyellow: [173, 255, 47, 1], grey: [128, 128, 128, 1], honeydew: [240, 255, 240, 1], hotpink: [255, 105, 180, 1], indianred: [205, 92, 92, 1], indigo: [75, 0, 130, 1], ivory: [255, 255, 240, 1], khaki: [240, 230, 140, 1], lavender: [230, 230, 250, 1], lavenderblush: [255, 240, 245, 1], lawngreen: [124, 252, 0, 1], lemonchiffon: [255, 250, 205, 1], lightblue: [173, 216, 230, 1], lightcoral: [240, 128, 128, 1], lightcyan: [224, 255, 255, 1], lightgoldenrodyellow: [250, 250, 210, 1], lightgray: [211, 211, 211, 1], lightgreen: [144, 238, 144, 1], lightgrey: [211, 211, 211, 1], lightpink: [255, 182, 193, 1], lightsalmon: [255, 160, 122, 1], lightseagreen: [32, 178, 170, 1], lightskyblue: [135, 206, 250, 1], lightslategray: [119, 136, 153, 1], lightslategrey: [119, 136, 153, 1], lightsteelblue: [176, 196, 222, 1], lightyellow: [255, 255, 224, 1], lime: [0, 255, 0, 1], limegreen: [50, 205, 50, 1], linen: [250, 240, 230, 1], magenta: [255, 0, 255, 1], maroon: [128, 0, 0, 1], mediumaquamarine: [102, 205, 170, 1], mediumblue: [0, 0, 205, 1], mediumorchid: [186, 85, 211, 1], mediumpurple: [147, 112, 219, 1], mediumseagreen: [60, 179, 113, 1], mediumslateblue: [123, 104, 238, 1], mediumspringgreen: [0, 250, 154, 1], mediumturquoise: [72, 209, 204, 1], mediumvioletred: [199, 21, 133, 1], midnightblue: [25, 25, 112, 1], mintcream: [245, 255, 250, 1], mistyrose: [255, 228, 225, 1], moccasin: [255, 228, 181, 1], navajowhite: [255, 222, 173, 1], navy: [0, 0, 128, 1], oldlace: [253, 245, 230, 1], olive: [128, 128, 0, 1], olivedrab: [107, 142, 35, 1], orange: [255, 165, 0, 1], orangered: [255, 69, 0, 1], orchid: [218, 112, 214, 1], palegoldenrod: [238, 232, 170, 1], palegreen: [152, 251, 152, 1], paleturquoise: [175, 238, 238, 1], palevioletred: [219, 112, 147, 1], papayawhip: [255, 239, 213, 1], peachpuff: [255, 218, 185, 1], peru: [205, 133, 63, 1], pink: [255, 192, 203, 1], plum: [221, 160, 221, 1], powderblue: [176, 224, 230, 1], purple: [128, 0, 128, 1], red: [255, 0, 0, 1], rosybrown: [188, 143, 143, 1], royalblue: [65, 105, 225, 1], saddlebrown: [139, 69, 19, 1], salmon: [250, 128, 114, 1], sandybrown: [244, 164, 96, 1], seagreen: [46, 139, 87, 1], seashell: [255, 245, 238, 1], sienna: [160, 82, 45, 1], silver: [192, 192, 192, 1], skyblue: [135, 206, 235, 1], slateblue: [106, 90, 205, 1], slategray: [112, 128, 144, 1], slategrey: [112, 128, 144, 1], snow: [255, 250, 250, 1], springgreen: [0, 255, 127, 1], steelblue: [70, 130, 180, 1], tan: [210, 180, 140, 1], teal: [0, 128, 128, 1], thistle: [216, 191, 216, 1], tomato: [255, 99, 71, 1], turquoise: [64, 224, 208, 1], violet: [238, 130, 238, 1], wheat: [245, 222, 179, 1], white: [255, 255, 255, 1], whitesmoke: [245, 245, 245, 1], yellow: [255, 255, 0, 1], yellowgreen: [154, 205, 50, 1], }; function Vn(t) { return (t = Math.round(t)) < 0 ? 0 : t > 255 ? 255 : t; } function Bn(t) { return t < 0 ? 0 : t > 1 ? 1 : t; } function Fn(t) { var e = t; return e.length && "%" === e.charAt(e.length - 1) ? Vn((parseFloat(e) / 100) * 255) : Vn(parseInt(e, 10)); } function Gn(t) { var e = t; return e.length && "%" === e.charAt(e.length - 1) ? Bn(parseFloat(e) / 100) : Bn(parseFloat(e)); } function Wn(t, e, n) { return ( n < 0 ? (n += 1) : n > 1 && (n -= 1), 6 * n < 1 ? t + (e - t) * n * 6 : 2 * n < 1 ? e : 3 * n < 2 ? t + (e - t) * (2 / 3 - n) * 6 : t ); } function Hn(t, e, n) { return t + (e - t) * n; } function Yn(t, e, n, i, r) { return (t[0] = e), (t[1] = n), (t[2] = i), (t[3] = r), t; } function Xn(t, e) { return (t[0] = e[0]), (t[1] = e[1]), (t[2] = e[2]), (t[3] = e[3]), t; } var Un = new En(20), Zn = null; function jn(t, e) { Zn && Xn(Zn, e), (Zn = Un.put(t, Zn || e.slice())); } function qn(t, e) { if (t) { e = e || []; var n = Un.get(t); if (n) return Xn(e, n); var i = (t += "").replace(/ /g, "").toLowerCase(); if (i in zn) return Xn(e, zn[i]), jn(t, e), e; var r, o = i.length; if ("#" === i.charAt(0)) return 4 === o || 5 === o ? (r = parseInt(i.slice(1, 4), 16)) >= 0 && r <= 4095 ? (Yn( e, ((3840 & r) >> 4) | ((3840 & r) >> 8), (240 & r) | ((240 & r) >> 4), (15 & r) | ((15 & r) << 4), 5 === o ? parseInt(i.slice(4), 16) / 15 : 1 ), jn(t, e), e) : void Yn(e, 0, 0, 0, 1) : 7 === o || 9 === o ? (r = parseInt(i.slice(1, 7), 16)) >= 0 && r <= 16777215 ? (Yn( e, (16711680 & r) >> 16, (65280 & r) >> 8, 255 & r, 9 === o ? parseInt(i.slice(7), 16) / 255 : 1 ), jn(t, e), e) : void Yn(e, 0, 0, 0, 1) : void 0; var a = i.indexOf("("), s = i.indexOf(")"); if (-1 !== a && s + 1 === o) { var l = i.substr(0, a), u = i.substr(a + 1, s - (a + 1)).split(","), h = 1; switch (l) { case "rgba": if (4 !== u.length) return 3 === u.length ? Yn(e, +u[0], +u[1], +u[2], 1) : Yn(e, 0, 0, 0, 1); h = Gn(u.pop()); case "rgb": return u.length >= 3 ? (Yn( e, Fn(u[0]), Fn(u[1]), Fn(u[2]), 3 === u.length ? h : Gn(u[3]) ), jn(t, e), e) : void Yn(e, 0, 0, 0, 1); case "hsla": return 4 !== u.length ? void Yn(e, 0, 0, 0, 1) : ((u[3] = Gn(u[3])), Kn(u, e), jn(t, e), e); case "hsl": return 3 !== u.length ? void Yn(e, 0, 0, 0, 1) : (Kn(u, e), jn(t, e), e); default: return; } } Yn(e, 0, 0, 0, 1); } } function Kn(t, e) { var n = (((parseFloat(t[0]) % 360) + 360) % 360) / 360, i = Gn(t[1]), r = Gn(t[2]), o = r <= 0.5 ? r * (i + 1) : r + i - r * i, a = 2 * r - o; return ( Yn( (e = e || []), Vn(255 * Wn(a, o, n + 1 / 3)), Vn(255 * Wn(a, o, n)), Vn(255 * Wn(a, o, n - 1 / 3)), 1 ), 4 === t.length && (e[3] = t[3]), e ); } function $n(t, e) { var n = qn(t); if (n) { for (var i = 0; i < 3; i++) (n[i] = e < 0 ? (n[i] * (1 - e)) | 0 : ((255 - n[i]) * e + n[i]) | 0), n[i] > 255 ? (n[i] = 255) : n[i] < 0 && (n[i] = 0); return ri(n, 4 === n.length ? "rgba" : "rgb"); } } function Jn(t, e, n) { if (e && e.length && t >= 0 && t <= 1) { n = n || []; var i = t * (e.length - 1), r = Math.floor(i), o = Math.ceil(i), a = e[r], s = e[o], l = i - r; return ( (n[0] = Vn(Hn(a[0], s[0], l))), (n[1] = Vn(Hn(a[1], s[1], l))), (n[2] = Vn(Hn(a[2], s[2], l))), (n[3] = Bn(Hn(a[3], s[3], l))), n ); } } var Qn = Jn; function ti(t, e, n) { if (e && e.length && t >= 0 && t <= 1) { var i = t * (e.length - 1), r = Math.floor(i), o = Math.ceil(i), a = qn(e[r]), s = qn(e[o]), l = i - r, u = ri( [ Vn(Hn(a[0], s[0], l)), Vn(Hn(a[1], s[1], l)), Vn(Hn(a[2], s[2], l)), Bn(Hn(a[3], s[3], l)), ], "rgba" ); return n ? { color: u, leftIndex: r, rightIndex: o, value: i } : u; } } var ei = ti; function ni(t, e, n, i) { var r = qn(t); if (t) return ( (r = (function (t) { if (t) { var e, n, i = t[0] / 255, r = t[1] / 255, o = t[2] / 255, a = Math.min(i, r, o), s = Math.max(i, r, o), l = s - a, u = (s + a) / 2; if (0 === l) (e = 0), (n = 0); else { n = u < 0.5 ? l / (s + a) : l / (2 - s - a); var h = ((s - i) / 6 + l / 2) / l, c = ((s - r) / 6 + l / 2) / l, p = ((s - o) / 6 + l / 2) / l; i === s ? (e = p - c) : r === s ? (e = 1 / 3 + h - p) : o === s && (e = 2 / 3 + c - h), e < 0 && (e += 1), e > 1 && (e -= 1); } var d = [360 * e, n, u]; return null != t[3] && d.push(t[3]), d; } })(r)), null != e && (r[0] = (function (t) { return (t = Math.round(t)) < 0 ? 0 : t > 360 ? 360 : t; })(e)), null != n && (r[1] = Gn(n)), null != i && (r[2] = Gn(i)), ri(Kn(r), "rgba") ); } function ii(t, e) { var n = qn(t); if (n && null != e) return (n[3] = Bn(e)), ri(n, "rgba"); } function ri(t, e) { if (t && t.length) { var n = t[0] + "," + t[1] + "," + t[2]; return ( ("rgba" !== e && "hsva" !== e && "hsla" !== e) || (n += "," + t[3]), e + "(" + n + ")" ); } } function oi(t, e) { var n = qn(t); return n ? ((0.299 * n[0] + 0.587 * n[1] + 0.114 * n[2]) * n[3]) / 255 + (1 - n[3]) * e : 0; } var ai = new En(100); function si(t) { if (U(t)) { var e = ai.get(t); return e || ((e = $n(t, -0.1)), ai.put(t, e)), e; } if (Q(t)) { var n = A({}, t); return ( (n.colorStops = z(t.colorStops, function (t) { return { offset: t.offset, color: $n(t.color, -0.1) }; })), n ); } return t; } var li = Object.freeze({ __proto__: null, parse: qn, lift: $n, toHex: function (t) { var e = qn(t); if (e) return ((1 << 24) + (e[0] << 16) + (e[1] << 8) + +e[2]) .toString(16) .slice(1); }, fastLerp: Jn, fastMapToColor: Qn, lerp: ti, mapToColor: ei, modifyHSL: ni, modifyAlpha: ii, stringify: ri, lum: oi, random: function () { return ri( [ Math.round(255 * Math.random()), Math.round(255 * Math.random()), Math.round(255 * Math.random()), ], "rgb" ); }, liftColor: si, }), ui = Math.round; function hi(t) { var e; if (t && "transparent" !== t) { if ("string" == typeof t && t.indexOf("rgba") > -1) { var n = qn(t); n && ((t = "rgb(" + n[0] + "," + n[1] + "," + n[2] + ")"), (e = n[3])); } } else t = "none"; return { color: t, opacity: null == e ? 1 : e }; } var ci = 1e-4; function pi(t) { return t < ci && t > -1e-4; } function di(t) { return ui(1e3 * t) / 1e3; } function fi(t) { return ui(1e4 * t) / 1e4; } var gi = { left: "start", right: "end", center: "middle", middle: "middle", }; function yi(t) { return t && !!t.image; } function vi(t) { return ( yi(t) || (function (t) { return t && !!t.svgElement; })(t) ); } function mi(t) { return "linear" === t.type; } function xi(t) { return "radial" === t.type; } function _i(t) { return t && ("linear" === t.type || "radial" === t.type); } function bi(t) { return "url(#" + t + ")"; } function wi(t) { var e = t.getGlobalScale(), n = Math.max(e[0], e[1]); return Math.max(Math.ceil(Math.log(n) / Math.log(10)), 1); } function Si(t) { var e = t.x || 0, n = t.y || 0, i = (t.rotation || 0) * wt, r = rt(t.scaleX, 1), o = rt(t.scaleY, 1), a = t.skewX || 0, s = t.skewY || 0, l = []; return ( (e || n) && l.push("translate(" + e + "px," + n + "px)"), i && l.push("rotate(" + i + ")"), (1 === r && 1 === o) || l.push("scale(" + r + "," + o + ")"), (a || s) && l.push("skew(" + ui(a * wt) + "deg, " + ui(s * wt) + "deg)"), l.join(" ") ); } var Mi = r.hasGlobalWindow && X(window.btoa) ? function (t) { return window.btoa(unescape(encodeURIComponent(t))); } : "undefined" != typeof Buffer ? function (t) { return Buffer.from(t).toString("base64"); } : function (t) { return null; }, Ii = Array.prototype.slice; function Ti(t, e, n) { return (e - t) * n + t; } function Ci(t, e, n, i) { for (var r = e.length, o = 0; o < r; o++) t[o] = Ti(e[o], n[o], i); return t; } function Di(t, e, n, i) { for (var r = e.length, o = 0; o < r; o++) t[o] = e[o] + n[o] * i; return t; } function Ai(t, e, n, i) { for (var r = e.length, o = r && e[0].length, a = 0; a < r; a++) { t[a] || (t[a] = []); for (var s = 0; s < o; s++) t[a][s] = e[a][s] + n[a][s] * i; } return t; } function ki(t, e) { for ( var n = t.length, i = e.length, r = n > i ? e : t, o = Math.min(n, i), a = r[o - 1] || { color: [0, 0, 0, 0], offset: 0 }, s = o; s < Math.max(n, i); s++ ) r.push({ offset: a.offset, color: a.color.slice() }); } function Li(t, e, n) { var i = t, r = e; if (i.push && r.push) { var o = i.length, a = r.length; if (o !== a) if (o > a) i.length = a; else for (var s = o; s < a; s++) i.push(1 === n ? r[s] : Ii.call(r[s])); var l = i[0] && i[0].length; for (s = 0; s < i.length; s++) if (1 === n) isNaN(i[s]) && (i[s] = r[s]); else for (var u = 0; u < l; u++) isNaN(i[s][u]) && (i[s][u] = r[s][u]); } } function Pi(t) { if (N(t)) { var e = t.length; if (N(t[0])) { for (var n = [], i = 0; i < e; i++) n.push(Ii.call(t[i])); return n; } return Ii.call(t); } return t; } function Oi(t) { return ( (t[0] = Math.floor(t[0]) || 0), (t[1] = Math.floor(t[1]) || 0), (t[2] = Math.floor(t[2]) || 0), (t[3] = null == t[3] ? 1 : t[3]), "rgba(" + t.join(",") + ")" ); } function Ri(t) { return 4 === t || 5 === t; } function Ni(t) { return 1 === t || 2 === t; } var Ei = [0, 0, 0, 0], zi = (function () { function t(t) { (this.keyframes = []), (this.discrete = !1), (this._invalid = !1), (this._needsSort = !1), (this._lastFr = 0), (this._lastFrP = 0), (this.propName = t); } return ( (t.prototype.isFinished = function () { return this._finished; }), (t.prototype.setFinished = function () { (this._finished = !0), this._additiveTrack && this._additiveTrack.setFinished(); }), (t.prototype.needsAnimate = function () { return this.keyframes.length >= 1; }), (t.prototype.getAdditiveTrack = function () { return this._additiveTrack; }), (t.prototype.addKeyframe = function (t, e, n) { this._needsSort = !0; var i = this.keyframes, r = i.length, o = !1, a = 6, s = e; if (N(e)) { var l = (function (t) { return N(t && t[0]) ? 2 : 1; })(e); (a = l), ((1 === l && !j(e[0])) || (2 === l && !j(e[0][0]))) && (o = !0); } else if (j(e) && !nt(e)) a = 0; else if (U(e)) if (isNaN(+e)) { var u = qn(e); u && ((s = u), (a = 3)); } else a = 0; else if (Q(e)) { var h = A({}, s); (h.colorStops = z(e.colorStops, function (t) { return { offset: t.offset, color: qn(t.color) }; })), mi(e) ? (a = 4) : xi(e) && (a = 5), (s = h); } 0 === r ? (this.valType = a) : (a === this.valType && 6 !== a) || (o = !0), (this.discrete = this.discrete || o); var c = { time: t, value: s, rawValue: e, percent: 0 }; return ( n && ((c.easing = n), (c.easingFunc = X(n) ? n : an[n] || Pn(n))), i.push(c), c ); }), (t.prototype.prepare = function (t, e) { var n = this.keyframes; this._needsSort && n.sort(function (t, e) { return t.time - e.time; }); for ( var i = this.valType, r = n.length, o = n[r - 1], a = this.discrete, s = Ni(i), l = Ri(i), u = 0; u < r; u++ ) { var h = n[u], c = h.value, p = o.value; (h.percent = h.time / t), a || (s && u !== r - 1 ? Li(c, p, i) : l && ki(c.colorStops, p.colorStops)); } if ( !a && 5 !== i && e && this.needsAnimate() && e.needsAnimate() && i === e.valType && !e._finished ) { this._additiveTrack = e; var d = n[0].value; for (u = 0; u < r; u++) 0 === i ? (n[u].additiveValue = n[u].value - d) : 3 === i ? (n[u].additiveValue = Di( [], n[u].value, d, -1 )) : Ni(i) && (n[u].additiveValue = 1 === i ? Di([], n[u].value, d, -1) : Ai([], n[u].value, d, -1)); } }), (t.prototype.step = function (t, e) { if (!this._finished) { this._additiveTrack && this._additiveTrack._finished && (this._additiveTrack = null); var n, i, r, o = null != this._additiveTrack, a = o ? "additiveValue" : "value", s = this.valType, l = this.keyframes, u = l.length, h = this.propName, c = 3 === s, p = this._lastFr, d = Math.min; if (1 === u) i = r = l[0]; else { if (e < 0) n = 0; else if (e < this._lastFrP) { for ( n = d(p + 1, u - 1); n >= 0 && !(l[n].percent <= e); n-- ); n = d(n, u - 2); } else { for (n = p; n < u && !(l[n].percent > e); n++); n = d(n - 1, u - 2); } (r = l[n + 1]), (i = l[n]); } if (i && r) { (this._lastFr = n), (this._lastFrP = e); var f = r.percent - i.percent, g = 0 === f ? 1 : d((e - i.percent) / f, 1); r.easingFunc && (g = r.easingFunc(g)); var y = o ? this._additiveValue : c ? Ei : t[h]; if ( ((!Ni(s) && !c) || y || (y = this._additiveValue = []), this.discrete) ) t[h] = g < 1 ? i.rawValue : r.rawValue; else if (Ni(s)) 1 === s ? Ci(y, i[a], r[a], g) : (function (t, e, n, i) { for ( var r = e.length, o = r && e[0].length, a = 0; a < r; a++ ) { t[a] || (t[a] = []); for (var s = 0; s < o; s++) t[a][s] = Ti( e[a][s], n[a][s], i ); } })(y, i[a], r[a], g); else if (Ri(s)) { var v = i[a], m = r[a], x = 4 === s; (t[h] = { type: x ? "linear" : "radial", x: Ti(v.x, m.x, g), y: Ti(v.y, m.y, g), colorStops: z( v.colorStops, function (t, e) { var n = m.colorStops[e]; return { offset: Ti( t.offset, n.offset, g ), color: Oi( Ci([], t.color, n.color, g) ), }; } ), global: m.global, }), x ? ((t[h].x2 = Ti(v.x2, m.x2, g)), (t[h].y2 = Ti(v.y2, m.y2, g))) : (t[h].r = Ti(v.r, m.r, g)); } else if (c) Ci(y, i[a], r[a], g), o || (t[h] = Oi(y)); else { var _ = Ti(i[a], r[a], g); o ? (this._additiveValue = _) : (t[h] = _); } o && this._addToTarget(t); } } }), (t.prototype._addToTarget = function (t) { var e = this.valType, n = this.propName, i = this._additiveValue; 0 === e ? (t[n] = t[n] + i) : 3 === e ? (qn(t[n], Ei), Di(Ei, Ei, i, 1), (t[n] = Oi(Ei))) : 1 === e ? Di(t[n], t[n], i, 1) : 2 === e && Ai(t[n], t[n], i, 1); }), t ); })(), Vi = (function () { function t(t, e, n, i) { (this._tracks = {}), (this._trackKeys = []), (this._maxTime = 0), (this._started = 0), (this._clip = null), (this._target = t), (this._loop = e), e && i ? I("Can' use additive animation on looped animation.") : ((this._additiveAnimators = i), (this._allowDiscrete = n)); } return ( (t.prototype.getMaxTime = function () { return this._maxTime; }), (t.prototype.getDelay = function () { return this._delay; }), (t.prototype.getLoop = function () { return this._loop; }), (t.prototype.getTarget = function () { return this._target; }), (t.prototype.changeTarget = function (t) { this._target = t; }), (t.prototype.when = function (t, e, n) { return this.whenWithKeys(t, e, G(e), n); }), (t.prototype.whenWithKeys = function (t, e, n, i) { for (var r = this._tracks, o = 0; o < n.length; o++) { var a = n[o], s = r[a]; if (!s) { s = r[a] = new zi(a); var l = void 0, u = this._getAdditiveTrack(a); if (u) { var h = u.keyframes, c = h[h.length - 1]; (l = c && c.value), 3 === u.valType && l && (l = Oi(l)); } else l = this._target[a]; if (null == l) continue; t > 0 && s.addKeyframe(0, Pi(l), i), this._trackKeys.push(a); } s.addKeyframe(t, Pi(e[a]), i); } return (this._maxTime = Math.max(this._maxTime, t)), this; }), (t.prototype.pause = function () { this._clip.pause(), (this._paused = !0); }), (t.prototype.resume = function () { this._clip.resume(), (this._paused = !1); }), (t.prototype.isPaused = function () { return !!this._paused; }), (t.prototype.duration = function (t) { return (this._maxTime = t), (this._force = !0), this; }), (t.prototype._doneCallback = function () { this._setTracksFinished(), (this._clip = null); var t = this._doneCbs; if (t) for (var e = t.length, n = 0; n < e; n++) t[n].call(this); }), (t.prototype._abortedCallback = function () { this._setTracksFinished(); var t = this.animation, e = this._abortedCbs; if ((t && t.removeClip(this._clip), (this._clip = null), e)) for (var n = 0; n < e.length; n++) e[n].call(this); }), (t.prototype._setTracksFinished = function () { for ( var t = this._tracks, e = this._trackKeys, n = 0; n < e.length; n++ ) t[e[n]].setFinished(); }), (t.prototype._getAdditiveTrack = function (t) { var e, n = this._additiveAnimators; if (n) for (var i = 0; i < n.length; i++) { var r = n[i].getTrack(t); r && (e = r); } return e; }), (t.prototype.start = function (t) { if (!(this._started > 0)) { this._started = 1; for ( var e = this, n = [], i = this._maxTime || 0, r = 0; r < this._trackKeys.length; r++ ) { var o = this._trackKeys[r], a = this._tracks[o], s = this._getAdditiveTrack(o), l = a.keyframes, u = l.length; if ((a.prepare(i, s), a.needsAnimate())) if (!this._allowDiscrete && a.discrete) { var h = l[u - 1]; h && (e._target[a.propName] = h.rawValue), a.setFinished(); } else n.push(a); } if (n.length || this._force) { var c = new On({ life: i, loop: this._loop, delay: this._delay || 0, onframe: function (t) { e._started = 2; var i = e._additiveAnimators; if (i) { for ( var r = !1, o = 0; o < i.length; o++ ) if (i[o]._clip) { r = !0; break; } r || (e._additiveAnimators = null); } for (o = 0; o < n.length; o++) n[o].step(e._target, t); var a = e._onframeCbs; if (a) for (o = 0; o < a.length; o++) a[o](e._target, t); }, ondestroy: function () { e._doneCallback(); }, }); (this._clip = c), this.animation && this.animation.addClip(c), t && c.setEasing(t); } else this._doneCallback(); return this; } }), (t.prototype.stop = function (t) { if (this._clip) { var e = this._clip; t && e.onframe(1), this._abortedCallback(); } }), (t.prototype.delay = function (t) { return (this._delay = t), this; }), (t.prototype.during = function (t) { return ( t && (this._onframeCbs || (this._onframeCbs = []), this._onframeCbs.push(t)), this ); }), (t.prototype.done = function (t) { return ( t && (this._doneCbs || (this._doneCbs = []), this._doneCbs.push(t)), this ); }), (t.prototype.aborted = function (t) { return ( t && (this._abortedCbs || (this._abortedCbs = []), this._abortedCbs.push(t)), this ); }), (t.prototype.getClip = function () { return this._clip; }), (t.prototype.getTrack = function (t) { return this._tracks[t]; }), (t.prototype.getTracks = function () { var t = this; return z(this._trackKeys, function (e) { return t._tracks[e]; }); }), (t.prototype.stopTracks = function (t, e) { if (!t.length || !this._clip) return !0; for ( var n = this._tracks, i = this._trackKeys, r = 0; r < t.length; r++ ) { var o = n[t[r]]; o && !o.isFinished() && (e ? o.step(this._target, 1) : 1 === this._started && o.step(this._target, 0), o.setFinished()); } var a = !0; for (r = 0; r < i.length; r++) if (!n[i[r]].isFinished()) { a = !1; break; } return a && this._abortedCallback(), a; }), (t.prototype.saveTo = function (t, e, n) { if (t) { e = e || this._trackKeys; for (var i = 0; i < e.length; i++) { var r = e[i], o = this._tracks[r]; if (o && !o.isFinished()) { var a = o.keyframes, s = a[n ? 0 : a.length - 1]; s && (t[r] = Pi(s.rawValue)); } } } }), (t.prototype.__changeFinalValue = function (t, e) { e = e || G(t); for (var n = 0; n < e.length; n++) { var i = e[n], r = this._tracks[i]; if (r) { var o = r.keyframes; if (o.length > 1) { var a = o.pop(); r.addKeyframe(a.time, t[i]), r.prepare( this._maxTime, r.getAdditiveTrack() ); } } } }), t ); })(); function Bi() { return new Date().getTime(); } var Fi, Gi, Wi = (function (t) { function e(e) { var n = t.call(this) || this; return ( (n._running = !1), (n._time = 0), (n._pausedTime = 0), (n._pauseStart = 0), (n._paused = !1), (e = e || {}), (n.stage = e.stage || {}), n ); } return ( n(e, t), (e.prototype.addClip = function (t) { t.animation && this.removeClip(t), this._head ? ((this._tail.next = t), (t.prev = this._tail), (t.next = null), (this._tail = t)) : (this._head = this._tail = t), (t.animation = this); }), (e.prototype.addAnimator = function (t) { t.animation = this; var e = t.getClip(); e && this.addClip(e); }), (e.prototype.removeClip = function (t) { if (t.animation) { var e = t.prev, n = t.next; e ? (e.next = n) : (this._head = n), n ? (n.prev = e) : (this._tail = e), (t.next = t.prev = t.animation = null); } }), (e.prototype.removeAnimator = function (t) { var e = t.getClip(); e && this.removeClip(e), (t.animation = null); }), (e.prototype.update = function (t) { for ( var e = Bi() - this._pausedTime, n = e - this._time, i = this._head; i; ) { var r = i.next; i.step(e, n) ? (i.ondestroy(), this.removeClip(i), (i = r)) : (i = r); } (this._time = e), t || (this.trigger("frame", n), this.stage.update && this.stage.update()); }), (e.prototype._startLoop = function () { var t = this; (this._running = !0), on(function e() { t._running && (on(e), !t._paused && t.update()); }); }), (e.prototype.start = function () { this._running || ((this._time = Bi()), (this._pausedTime = 0), this._startLoop()); }), (e.prototype.stop = function () { this._running = !1; }), (e.prototype.pause = function () { this._paused || ((this._pauseStart = Bi()), (this._paused = !0)); }), (e.prototype.resume = function () { this._paused && ((this._pausedTime += Bi() - this._pauseStart), (this._paused = !1)); }), (e.prototype.clear = function () { for (var t = this._head; t; ) { var e = t.next; (t.prev = t.next = t.animation = null), (t = e); } this._head = this._tail = null; }), (e.prototype.isFinished = function () { return null == this._head; }), (e.prototype.animate = function (t, e) { (e = e || {}), this.start(); var n = new Vi(t, e.loop); return this.addAnimator(n), n; }), e ); })(jt), Hi = r.domSupported, Yi = ((Gi = { pointerdown: 1, pointerup: 1, pointermove: 1, pointerout: 1, }), { mouse: (Fi = [ "click", "dblclick", "mousewheel", "wheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu", ]), touch: ["touchstart", "touchend", "touchmove"], pointer: z(Fi, function (t) { var e = t.replace("mouse", "pointer"); return Gi.hasOwnProperty(e) ? e : t; }), }), Xi = ["mousemove", "mouseup"], Ui = ["pointermove", "pointerup"], Zi = !1; function ji(t) { var e = t.pointerType; return "pen" === e || "touch" === e; } function qi(t) { t && (t.zrByTouch = !0); } function Ki(t, e) { for ( var n = e, i = !1; n && 9 !== n.nodeType && !(i = n.domBelongToZr || (n !== e && n === t.painterRoot)); ) n = n.parentNode; return i; } var $i = function (t, e) { (this.stopPropagation = bt), (this.stopImmediatePropagation = bt), (this.preventDefault = bt), (this.type = e.type), (this.target = this.currentTarget = t.dom), (this.pointerType = e.pointerType), (this.clientX = e.clientX), (this.clientY = e.clientY); }, Ji = { mousedown: function (t) { (t = ce(this.dom, t)), (this.__mayPointerCapture = [t.zrX, t.zrY]), this.trigger("mousedown", t); }, mousemove: function (t) { t = ce(this.dom, t); var e = this.__mayPointerCapture; !e || (t.zrX === e[0] && t.zrY === e[1]) || this.__togglePointerCapture(!0), this.trigger("mousemove", t); }, mouseup: function (t) { (t = ce(this.dom, t)), this.__togglePointerCapture(!1), this.trigger("mouseup", t); }, mouseout: function (t) { Ki(this, (t = ce(this.dom, t)).toElement || t.relatedTarget) || (this.__pointerCapturing && (t.zrEventControl = "no_globalout"), this.trigger("mouseout", t)); }, wheel: function (t) { (Zi = !0), (t = ce(this.dom, t)), this.trigger("mousewheel", t); }, mousewheel: function (t) { Zi || ((t = ce(this.dom, t)), this.trigger("mousewheel", t)); }, touchstart: function (t) { qi((t = ce(this.dom, t))), (this.__lastTouchMoment = new Date()), this.handler.processGesture(t, "start"), Ji.mousemove.call(this, t), Ji.mousedown.call(this, t); }, touchmove: function (t) { qi((t = ce(this.dom, t))), this.handler.processGesture(t, "change"), Ji.mousemove.call(this, t); }, touchend: function (t) { qi((t = ce(this.dom, t))), this.handler.processGesture(t, "end"), Ji.mouseup.call(this, t), +new Date() - +this.__lastTouchMoment < 300 && Ji.click.call(this, t); }, pointerdown: function (t) { Ji.mousedown.call(this, t); }, pointermove: function (t) { ji(t) || Ji.mousemove.call(this, t); }, pointerup: function (t) { Ji.mouseup.call(this, t); }, pointerout: function (t) { ji(t) || Ji.mouseout.call(this, t); }, }; E(["click", "dblclick", "contextmenu"], function (t) { Ji[t] = function (e) { (e = ce(this.dom, e)), this.trigger(t, e); }; }); var Qi = { pointermove: function (t) { ji(t) || Qi.mousemove.call(this, t); }, pointerup: function (t) { Qi.mouseup.call(this, t); }, mousemove: function (t) { this.trigger("mousemove", t); }, mouseup: function (t) { var e = this.__pointerCapturing; this.__togglePointerCapture(!1), this.trigger("mouseup", t), e && ((t.zrEventControl = "only_globalout"), this.trigger("mouseout", t)); }, }; function tr(t, e) { var n = e.domHandlers; r.pointerEventsSupported ? E(Yi.pointer, function (i) { nr(e, i, function (e) { n[i].call(t, e); }); }) : (r.touchEventsSupported && E(Yi.touch, function (i) { nr(e, i, function (r) { n[i].call(t, r), (function (t) { (t.touching = !0), null != t.touchTimer && (clearTimeout(t.touchTimer), (t.touchTimer = null)), (t.touchTimer = setTimeout(function () { (t.touching = !1), (t.touchTimer = null); }, 700)); })(e); }); }), E(Yi.mouse, function (i) { nr(e, i, function (r) { (r = he(r)), e.touching || n[i].call(t, r); }); })); } function er(t, e) { function n(n) { nr( e, n, function (i) { (i = he(i)), Ki(t, i.target) || ((i = (function (t, e) { return ce(t.dom, new $i(t, e), !0); })(t, i)), e.domHandlers[n].call(t, i)); }, { capture: !0 } ); } r.pointerEventsSupported ? E(Ui, n) : r.touchEventsSupported || E(Xi, n); } function nr(t, e, n, i) { (t.mounted[e] = n), (t.listenerOpts[e] = i), pe(t.domTarget, e, n, i); } function ir(t) { var e, n, i, r, o = t.mounted; for (var a in o) o.hasOwnProperty(a) && ((e = t.domTarget), (n = a), (i = o[a]), (r = t.listenerOpts[a]), e.removeEventListener(n, i, r)); t.mounted = {}; } var rr = function (t, e) { (this.mounted = {}), (this.listenerOpts = {}), (this.touching = !1), (this.domTarget = t), (this.domHandlers = e); }, or = (function (t) { function e(e, n) { var i = t.call(this) || this; return ( (i.__pointerCapturing = !1), (i.dom = e), (i.painterRoot = n), (i._localHandlerScope = new rr(e, Ji)), Hi && (i._globalHandlerScope = new rr(document, Qi)), tr(i, i._localHandlerScope), i ); } return ( n(e, t), (e.prototype.dispose = function () { ir(this._localHandlerScope), Hi && ir(this._globalHandlerScope); }), (e.prototype.setCursor = function (t) { this.dom.style && (this.dom.style.cursor = t || "default"); }), (e.prototype.__togglePointerCapture = function (t) { if ( ((this.__mayPointerCapture = null), Hi && +this.__pointerCapturing ^ +t) ) { this.__pointerCapturing = t; var e = this._globalHandlerScope; t ? er(this, e) : ir(e); } }), e ); })(jt), ar = 1; r.hasGlobalWindow && (ar = Math.max( window.devicePixelRatio || (window.screen && window.screen.deviceXDPI / window.screen.logicalXDPI) || 1, 1 )); var sr = ar, lr = "#333", ur = "#ccc", hr = xe, cr = 5e-5; function pr(t) { return t > cr || t < -5e-5; } var dr = [], fr = [], gr = [1, 0, 0, 1, 0, 0], yr = Math.abs, vr = (function () { function t() {} return ( (t.prototype.getLocalTransform = function (e) { return t.getLocalTransform(this, e); }), (t.prototype.setPosition = function (t) { (this.x = t[0]), (this.y = t[1]); }), (t.prototype.setScale = function (t) { (this.scaleX = t[0]), (this.scaleY = t[1]); }), (t.prototype.setSkew = function (t) { (this.skewX = t[0]), (this.skewY = t[1]); }), (t.prototype.setOrigin = function (t) { (this.originX = t[0]), (this.originY = t[1]); }), (t.prototype.needLocalTransform = function () { return ( pr(this.rotation) || pr(this.x) || pr(this.y) || pr(this.scaleX - 1) || pr(this.scaleY - 1) || pr(this.skewX) || pr(this.skewY) ); }), (t.prototype.updateTransform = function () { var t = this.parent && this.parent.transform, e = this.needLocalTransform(), n = this.transform; e || t ? ((n = n || [1, 0, 0, 1, 0, 0]), e ? this.getLocalTransform(n) : hr(n), t && (e ? be(n, t, n) : _e(n, t)), (this.transform = n), this._resolveGlobalScaleRatio(n)) : n && (hr(n), (this.invTransform = null)); }), (t.prototype._resolveGlobalScaleRatio = function (t) { var e = this.globalScaleRatio; if (null != e && 1 !== e) { this.getGlobalScale(dr); var n = dr[0] < 0 ? -1 : 1, i = dr[1] < 0 ? -1 : 1, r = ((dr[0] - n) * e + n) / dr[0] || 0, o = ((dr[1] - i) * e + i) / dr[1] || 0; (t[0] *= r), (t[1] *= r), (t[2] *= o), (t[3] *= o); } (this.invTransform = this.invTransform || [ 1, 0, 0, 1, 0, 0, ]), Ie(this.invTransform, t); }), (t.prototype.getComputedTransform = function () { for (var t = this, e = []; t; ) e.push(t), (t = t.parent); for (; (t = e.pop()); ) t.updateTransform(); return this.transform; }), (t.prototype.setLocalTransform = function (t) { if (t) { var e = t[0] * t[0] + t[1] * t[1], n = t[2] * t[2] + t[3] * t[3], i = Math.atan2(t[1], t[0]), r = Math.PI / 2 + i - Math.atan2(t[3], t[2]); (n = Math.sqrt(n) * Math.cos(r)), (e = Math.sqrt(e)), (this.skewX = r), (this.skewY = 0), (this.rotation = -i), (this.x = +t[4]), (this.y = +t[5]), (this.scaleX = e), (this.scaleY = n), (this.originX = 0), (this.originY = 0); } }), (t.prototype.decomposeTransform = function () { if (this.transform) { var t = this.parent, e = this.transform; t && t.transform && ((t.invTransform = t.invTransform || [ 1, 0, 0, 1, 0, 0, ]), be(fr, t.invTransform, e), (e = fr)); var n = this.originX, i = this.originY; (n || i) && ((gr[4] = n), (gr[5] = i), be(fr, e, gr), (fr[4] -= n), (fr[5] -= i), (e = fr)), this.setLocalTransform(e); } }), (t.prototype.getGlobalScale = function (t) { var e = this.transform; return ( (t = t || []), e ? ((t[0] = Math.sqrt(e[0] * e[0] + e[1] * e[1])), (t[1] = Math.sqrt(e[2] * e[2] + e[3] * e[3])), e[0] < 0 && (t[0] = -t[0]), e[3] < 0 && (t[1] = -t[1]), t) : ((t[0] = 1), (t[1] = 1), t) ); }), (t.prototype.transformCoordToLocal = function (t, e) { var n = [t, e], i = this.invTransform; return i && Wt(n, n, i), n; }), (t.prototype.transformCoordToGlobal = function (t, e) { var n = [t, e], i = this.transform; return i && Wt(n, n, i), n; }), (t.prototype.getLineScale = function () { var t = this.transform; return t && yr(t[0] - 1) > 1e-10 && yr(t[3] - 1) > 1e-10 ? Math.sqrt(yr(t[0] * t[3] - t[2] * t[1])) : 1; }), (t.prototype.copyTransform = function (t) { xr(this, t); }), (t.getLocalTransform = function (t, e) { e = e || []; var n = t.originX || 0, i = t.originY || 0, r = t.scaleX, o = t.scaleY, a = t.anchorX, s = t.anchorY, l = t.rotation || 0, u = t.x, h = t.y, c = t.skewX ? Math.tan(t.skewX) : 0, p = t.skewY ? Math.tan(-t.skewY) : 0; if (n || i || a || s) { var d = n + a, f = i + s; (e[4] = -d * r - c * f * o), (e[5] = -f * o - p * d * r); } else e[4] = e[5] = 0; return ( (e[0] = r), (e[3] = o), (e[1] = p * r), (e[2] = c * o), l && Se(e, e, l), (e[4] += n + u), (e[5] += i + h), e ); }), (t.initDefaultProps = (function () { var e = t.prototype; (e.scaleX = e.scaleY = e.globalScaleRatio = 1), (e.x = e.y = e.originX = e.originY = e.skewX = e.skewY = e.rotation = e.anchorX = e.anchorY = 0); })()), t ); })(), mr = [ "x", "y", "originX", "originY", "anchorX", "anchorY", "rotation", "scaleX", "scaleY", "skewX", "skewY", ]; function xr(t, e) { for (var n = 0; n < mr.length; n++) { var i = mr[n]; t[i] = e[i]; } } var _r = {}; function br(t, e) { var n = _r[(e = e || a)]; n || (n = _r[e] = new En(500)); var i = n.get(t); return null == i && ((i = h.measureText(t, e).width), n.put(t, i)), i; } function wr(t, e, n, i) { var r = br(t, e), o = Tr(e), a = Mr(0, r, n), s = Ir(0, o, i); return new ze(a, s, r, o); } function Sr(t, e, n, i) { var r = ((t || "") + "").split("\n"); if (1 === r.length) return wr(r[0], e, n, i); for (var o = new ze(0, 0, 0, 0), a = 0; a < r.length; a++) { var s = wr(r[a], e, n, i); 0 === a ? o.copy(s) : o.union(s); } return o; } function Mr(t, e, n) { return "right" === n ? (t -= e) : "center" === n && (t -= e / 2), t; } function Ir(t, e, n) { return "middle" === n ? (t -= e / 2) : "bottom" === n && (t -= e), t; } function Tr(t) { return br("国", t); } function Cr(t, e) { return "string" == typeof t ? t.lastIndexOf("%") >= 0 ? (parseFloat(t) / 100) * e : parseFloat(t) : t; } function Dr(t, e, n) { var i = e.position || "inside", r = null != e.distance ? e.distance : 5, o = n.height, a = n.width, s = o / 2, l = n.x, u = n.y, h = "left", c = "top"; if (i instanceof Array) (l += Cr(i[0], n.width)), (u += Cr(i[1], n.height)), (h = null), (c = null); else switch (i) { case "left": (l -= r), (u += s), (h = "right"), (c = "middle"); break; case "right": (l += r + a), (u += s), (c = "middle"); break; case "top": (l += a / 2), (u -= r), (h = "center"), (c = "bottom"); break; case "bottom": (l += a / 2), (u += o + r), (h = "center"); break; case "inside": (l += a / 2), (u += s), (h = "center"), (c = "middle"); break; case "insideLeft": (l += r), (u += s), (c = "middle"); break; case "insideRight": (l += a - r), (u += s), (h = "right"), (c = "middle"); break; case "insideTop": (l += a / 2), (u += r), (h = "center"); break; case "insideBottom": (l += a / 2), (u += o - r), (h = "center"), (c = "bottom"); break; case "insideTopLeft": (l += r), (u += r); break; case "insideTopRight": (l += a - r), (u += r), (h = "right"); break; case "insideBottomLeft": (l += r), (u += o - r), (c = "bottom"); break; case "insideBottomRight": (l += a - r), (u += o - r), (h = "right"), (c = "bottom"); } return ( ((t = t || {}).x = l), (t.y = u), (t.align = h), (t.verticalAlign = c), t ); } var Ar = "__zr_normal__", kr = mr.concat(["ignore"]), Lr = V( mr, function (t, e) { return (t[e] = !0), t; }, { ignore: !1 } ), Pr = {}, Or = new ze(0, 0, 0, 0), Rr = (function () { function t(t) { (this.id = M()), (this.animators = []), (this.currentStates = []), (this.states = {}), this._init(t); } return ( (t.prototype._init = function (t) { this.attr(t); }), (t.prototype.drift = function (t, e, n) { switch (this.draggable) { case "horizontal": e = 0; break; case "vertical": t = 0; } var i = this.transform; i || (i = this.transform = [1, 0, 0, 1, 0, 0]), (i[4] += t), (i[5] += e), this.decomposeTransform(), this.markRedraw(); }), (t.prototype.beforeUpdate = function () {}), (t.prototype.afterUpdate = function () {}), (t.prototype.update = function () { this.updateTransform(), this.__dirty && this.updateInnerText(); }), (t.prototype.updateInnerText = function (t) { var e = this._textContent; if (e && (!e.ignore || t)) { this.textConfig || (this.textConfig = {}); var n = this.textConfig, i = n.local, r = e.innerTransformable, o = void 0, a = void 0, s = !1; r.parent = i ? this : null; var l = !1; if ((r.copyTransform(e), null != n.position)) { var u = Or; n.layoutRect ? u.copy(n.layoutRect) : u.copy(this.getBoundingRect()), i || u.applyTransform(this.transform), this.calculateTextPosition ? this.calculateTextPosition(Pr, n, u) : Dr(Pr, n, u), (r.x = Pr.x), (r.y = Pr.y), (o = Pr.align), (a = Pr.verticalAlign); var h = n.origin; if (h && null != n.rotation) { var c = void 0, p = void 0; "center" === h ? ((c = 0.5 * u.width), (p = 0.5 * u.height)) : ((c = Cr(h[0], u.width)), (p = Cr(h[1], u.height))), (l = !0), (r.originX = -r.x + c + (i ? 0 : u.x)), (r.originY = -r.y + p + (i ? 0 : u.y)); } } null != n.rotation && (r.rotation = n.rotation); var d = n.offset; d && ((r.x += d[0]), (r.y += d[1]), l || ((r.originX = -d[0]), (r.originY = -d[1]))); var f = null == n.inside ? "string" == typeof n.position && n.position.indexOf("inside") >= 0 : n.inside, g = this._innerTextDefaultStyle || (this._innerTextDefaultStyle = {}), y = void 0, v = void 0, m = void 0; f && this.canBeInsideText() ? ((y = n.insideFill), (v = n.insideStroke), (null != y && "auto" !== y) || (y = this.getInsideTextFill()), (null != v && "auto" !== v) || ((v = this.getInsideTextStroke(y)), (m = !0))) : ((y = n.outsideFill), (v = n.outsideStroke), (null != y && "auto" !== y) || (y = this.getOutsideFill()), (null != v && "auto" !== v) || ((v = this.getOutsideStroke(y)), (m = !0))), ((y = y || "#000") === g.fill && v === g.stroke && m === g.autoStroke && o === g.align && a === g.verticalAlign) || ((s = !0), (g.fill = y), (g.stroke = v), (g.autoStroke = m), (g.align = o), (g.verticalAlign = a), e.setDefaultTextStyle(g)), (e.__dirty |= 1), s && e.dirtyStyle(!0); } }), (t.prototype.canBeInsideText = function () { return !0; }), (t.prototype.getInsideTextFill = function () { return "#fff"; }), (t.prototype.getInsideTextStroke = function (t) { return "#000"; }), (t.prototype.getOutsideFill = function () { return this.__zr && this.__zr.isDarkMode() ? ur : lr; }), (t.prototype.getOutsideStroke = function (t) { var e = this.__zr && this.__zr.getBackgroundColor(), n = "string" == typeof e && qn(e); n || (n = [255, 255, 255, 1]); for ( var i = n[3], r = this.__zr.isDarkMode(), o = 0; o < 3; o++ ) n[o] = n[o] * i + (r ? 0 : 255) * (1 - i); return (n[3] = 1), ri(n, "rgba"); }), (t.prototype.traverse = function (t, e) {}), (t.prototype.attrKV = function (t, e) { "textConfig" === t ? this.setTextConfig(e) : "textContent" === t ? this.setTextContent(e) : "clipPath" === t ? this.setClipPath(e) : "extra" === t ? ((this.extra = this.extra || {}), A(this.extra, e)) : (this[t] = e); }), (t.prototype.hide = function () { (this.ignore = !0), this.markRedraw(); }), (t.prototype.show = function () { (this.ignore = !1), this.markRedraw(); }), (t.prototype.attr = function (t, e) { if ("string" == typeof t) this.attrKV(t, e); else if (q(t)) for (var n = G(t), i = 0; i < n.length; i++) { var r = n[i]; this.attrKV(r, t[r]); } return this.markRedraw(), this; }), (t.prototype.saveCurrentToNormalState = function (t) { this._innerSaveToNormal(t); for ( var e = this._normalState, n = 0; n < this.animators.length; n++ ) { var i = this.animators[n], r = i.__fromStateTransition; if (!(i.getLoop() || (r && r !== Ar))) { var o = i.targetName, a = o ? e[o] : e; i.saveTo(a); } } }), (t.prototype._innerSaveToNormal = function (t) { var e = this._normalState; e || (e = this._normalState = {}), t.textConfig && !e.textConfig && (e.textConfig = this.textConfig), this._savePrimaryToNormal(t, e, kr); }), (t.prototype._savePrimaryToNormal = function (t, e, n) { for (var i = 0; i < n.length; i++) { var r = n[i]; null == t[r] || r in e || (e[r] = this[r]); } }), (t.prototype.hasState = function () { return this.currentStates.length > 0; }), (t.prototype.getState = function (t) { return this.states[t]; }), (t.prototype.ensureState = function (t) { var e = this.states; return e[t] || (e[t] = {}), e[t]; }), (t.prototype.clearStates = function (t) { this.useState(Ar, !1, t); }), (t.prototype.useState = function (t, e, n, i) { var r = t === Ar; if (this.hasState() || !r) { var o = this.currentStates, a = this.stateTransition; if (!(P(o, t) >= 0) || (!e && 1 !== o.length)) { var s; if ( (this.stateProxy && !r && (s = this.stateProxy(t)), s || (s = this.states && this.states[t]), s || r) ) { r || this.saveCurrentToNormalState(s); var l = !!((s && s.hoverLayer) || i); l && this._toggleHoverLayerFlag(!0), this._applyStateObj( t, s, this._normalState, e, !n && !this.__inHover && a && a.duration > 0, a ); var u = this._textContent, h = this._textGuide; return ( u && u.useState(t, e, n, l), h && h.useState(t, e, n, l), r ? ((this.currentStates = []), (this._normalState = {})) : e ? this.currentStates.push(t) : (this.currentStates = [t]), this._updateAnimationTargets(), this.markRedraw(), !l && this.__inHover && (this._toggleHoverLayerFlag(!1), (this.__dirty &= -2)), s ); } I("State " + t + " not exists."); } } }), (t.prototype.useStates = function (t, e, n) { if (t.length) { var i = [], r = this.currentStates, o = t.length, a = o === r.length; if (a) for (var s = 0; s < o; s++) if (t[s] !== r[s]) { a = !1; break; } if (a) return; for (s = 0; s < o; s++) { var l = t[s], u = void 0; this.stateProxy && (u = this.stateProxy(l, t)), u || (u = this.states[l]), u && i.push(u); } var h = i[o - 1], c = !!((h && h.hoverLayer) || n); c && this._toggleHoverLayerFlag(!0); var p = this._mergeStates(i), d = this.stateTransition; this.saveCurrentToNormalState(p), this._applyStateObj( t.join(","), p, this._normalState, !1, !e && !this.__inHover && d && d.duration > 0, d ); var f = this._textContent, g = this._textGuide; f && f.useStates(t, e, c), g && g.useStates(t, e, c), this._updateAnimationTargets(), (this.currentStates = t.slice()), this.markRedraw(), !c && this.__inHover && (this._toggleHoverLayerFlag(!1), (this.__dirty &= -2)); } else this.clearStates(); }), (t.prototype.isSilent = function () { for (var t = this.silent, e = this.parent; !t && e; ) { if (e.silent) { t = !0; break; } e = e.parent; } return t; }), (t.prototype._updateAnimationTargets = function () { for (var t = 0; t < this.animators.length; t++) { var e = this.animators[t]; e.targetName && e.changeTarget(this[e.targetName]); } }), (t.prototype.removeState = function (t) { var e = P(this.currentStates, t); if (e >= 0) { var n = this.currentStates.slice(); n.splice(e, 1), this.useStates(n); } }), (t.prototype.replaceState = function (t, e, n) { var i = this.currentStates.slice(), r = P(i, t), o = P(i, e) >= 0; r >= 0 ? o ? i.splice(r, 1) : (i[r] = e) : n && !o && i.push(e), this.useStates(i); }), (t.prototype.toggleState = function (t, e) { e ? this.useState(t, !0) : this.removeState(t); }), (t.prototype._mergeStates = function (t) { for (var e, n = {}, i = 0; i < t.length; i++) { var r = t[i]; A(n, r), r.textConfig && A((e = e || {}), r.textConfig); } return e && (n.textConfig = e), n; }), (t.prototype._applyStateObj = function (t, e, n, i, r, o) { var a = !(e && i); e && e.textConfig ? ((this.textConfig = A( {}, i ? this.textConfig : n.textConfig )), A(this.textConfig, e.textConfig)) : a && n.textConfig && (this.textConfig = n.textConfig); for (var s = {}, l = !1, u = 0; u < kr.length; u++) { var h = kr[u], c = r && Lr[h]; e && null != e[h] ? c ? ((l = !0), (s[h] = e[h])) : (this[h] = e[h]) : a && null != n[h] && (c ? ((l = !0), (s[h] = n[h])) : (this[h] = n[h])); } if (!r) for (u = 0; u < this.animators.length; u++) { var p = this.animators[u], d = p.targetName; p.getLoop() || p.__changeFinalValue(d ? (e || n)[d] : e || n); } l && this._transitionState(t, s, o); }), (t.prototype._attachComponent = function (t) { if ((!t.__zr || t.__hostTarget) && t !== this) { var e = this.__zr; e && t.addSelfToZr(e), (t.__zr = e), (t.__hostTarget = this); } }), (t.prototype._detachComponent = function (t) { t.__zr && t.removeSelfFromZr(t.__zr), (t.__zr = null), (t.__hostTarget = null); }), (t.prototype.getClipPath = function () { return this._clipPath; }), (t.prototype.setClipPath = function (t) { this._clipPath && this._clipPath !== t && this.removeClipPath(), this._attachComponent(t), (this._clipPath = t), this.markRedraw(); }), (t.prototype.removeClipPath = function () { var t = this._clipPath; t && (this._detachComponent(t), (this._clipPath = null), this.markRedraw()); }), (t.prototype.getTextContent = function () { return this._textContent; }), (t.prototype.setTextContent = function (t) { var e = this._textContent; e !== t && (e && e !== t && this.removeTextContent(), (t.innerTransformable = new vr()), this._attachComponent(t), (this._textContent = t), this.markRedraw()); }), (t.prototype.setTextConfig = function (t) { this.textConfig || (this.textConfig = {}), A(this.textConfig, t), this.markRedraw(); }), (t.prototype.removeTextConfig = function () { (this.textConfig = null), this.markRedraw(); }), (t.prototype.removeTextContent = function () { var t = this._textContent; t && ((t.innerTransformable = null), this._detachComponent(t), (this._textContent = null), (this._innerTextDefaultStyle = null), this.markRedraw()); }), (t.prototype.getTextGuideLine = function () { return this._textGuide; }), (t.prototype.setTextGuideLine = function (t) { this._textGuide && this._textGuide !== t && this.removeTextGuideLine(), this._attachComponent(t), (this._textGuide = t), this.markRedraw(); }), (t.prototype.removeTextGuideLine = function () { var t = this._textGuide; t && (this._detachComponent(t), (this._textGuide = null), this.markRedraw()); }), (t.prototype.markRedraw = function () { this.__dirty |= 1; var t = this.__zr; t && (this.__inHover ? t.refreshHover() : t.refresh()), this.__hostTarget && this.__hostTarget.markRedraw(); }), (t.prototype.dirty = function () { this.markRedraw(); }), (t.prototype._toggleHoverLayerFlag = function (t) { this.__inHover = t; var e = this._textContent, n = this._textGuide; e && (e.__inHover = t), n && (n.__inHover = t); }), (t.prototype.addSelfToZr = function (t) { if (this.__zr !== t) { this.__zr = t; var e = this.animators; if (e) for (var n = 0; n < e.length; n++) t.animation.addAnimator(e[n]); this._clipPath && this._clipPath.addSelfToZr(t), this._textContent && this._textContent.addSelfToZr(t), this._textGuide && this._textGuide.addSelfToZr(t); } }), (t.prototype.removeSelfFromZr = function (t) { if (this.__zr) { this.__zr = null; var e = this.animators; if (e) for (var n = 0; n < e.length; n++) t.animation.removeAnimator(e[n]); this._clipPath && this._clipPath.removeSelfFromZr(t), this._textContent && this._textContent.removeSelfFromZr(t), this._textGuide && this._textGuide.removeSelfFromZr(t); } }), (t.prototype.animate = function (t, e, n) { var i = t ? this[t] : this; var r = new Vi(i, e, n); return t && (r.targetName = t), this.addAnimator(r, t), r; }), (t.prototype.addAnimator = function (t, e) { var n = this.__zr, i = this; t .during(function () { i.updateDuringAnimation(e); }) .done(function () { var e = i.animators, n = P(e, t); n >= 0 && e.splice(n, 1); }), this.animators.push(t), n && n.animation.addAnimator(t), n && n.wakeUp(); }), (t.prototype.updateDuringAnimation = function (t) { this.markRedraw(); }), (t.prototype.stopAnimation = function (t, e) { for ( var n = this.animators, i = n.length, r = [], o = 0; o < i; o++ ) { var a = n[o]; t && t !== a.scope ? r.push(a) : a.stop(e); } return (this.animators = r), this; }), (t.prototype.animateTo = function (t, e, n) { Nr(this, t, e, n); }), (t.prototype.animateFrom = function (t, e, n) { Nr(this, t, e, n, !0); }), (t.prototype._transitionState = function (t, e, n, i) { for (var r = Nr(this, e, n, i), o = 0; o < r.length; o++) r[o].__fromStateTransition = t; }), (t.prototype.getBoundingRect = function () { return null; }), (t.prototype.getPaintRect = function () { return null; }), (t.initDefaultProps = (function () { var e = t.prototype; (e.type = "element"), (e.name = ""), (e.ignore = e.silent = e.isGroup = e.draggable = e.dragging = e.ignoreClip = e.__inHover = !1), (e.__dirty = 1); function n(t, n, i, r) { function o(t, e) { Object.defineProperty(e, 0, { get: function () { return t[i]; }, set: function (e) { t[i] = e; }, }), Object.defineProperty(e, 1, { get: function () { return t[r]; }, set: function (e) { t[r] = e; }, }); } Object.defineProperty(e, t, { get: function () { this[n] || o(this, (this[n] = [])); return this[n]; }, set: function (t) { (this[i] = t[0]), (this[r] = t[1]), (this[n] = t), o(this, t); }, }); } Object.defineProperty && (n("position", "_legacyPos", "x", "y"), n("scale", "_legacyScale", "scaleX", "scaleY"), n("origin", "_legacyOrigin", "originX", "originY")); })()), t ); })(); function Nr(t, e, n, i, r) { var o = []; Vr(t, "", t, e, (n = n || {}), i, o, r); var a = o.length, s = !1, l = n.done, u = n.aborted, h = function () { (s = !0), --a <= 0 && (s ? l && l() : u && u()); }, c = function () { --a <= 0 && (s ? l && l() : u && u()); }; a || (l && l()), o.length > 0 && n.during && o[0].during(function (t, e) { n.during(e); }); for (var p = 0; p < o.length; p++) { var d = o[p]; h && d.done(h), c && d.aborted(c), n.force && d.duration(n.duration), d.start(n.easing); } return o; } function Er(t, e, n) { for (var i = 0; i < n; i++) t[i] = e[i]; } function zr(t, e, n) { if (N(e[n])) if ((N(t[n]) || (t[n] = []), $(e[n]))) { var i = e[n].length; t[n].length !== i && ((t[n] = new e[n].constructor(i)), Er(t[n], e[n], i)); } else { var r = e[n], o = t[n], a = r.length; if (N(r[0])) for (var s = r[0].length, l = 0; l < a; l++) o[l] ? Er(o[l], r[l], s) : (o[l] = Array.prototype.slice.call(r[l])); else Er(o, r, a); o.length = r.length; } else t[n] = e[n]; } function Vr(t, e, n, i, r, o, a, s) { for ( var l = G(i), u = r.duration, h = r.delay, c = r.additive, p = r.setToFinal, d = !q(o), f = t.animators, g = [], y = 0; y < l.length; y++ ) { var v = l[y], m = i[v]; if (null != m && null != n[v] && (d || o[v])) if (!q(m) || N(m) || Q(m)) g.push(v); else { if (e) { s || ((n[v] = m), t.updateDuringAnimation(e)); continue; } Vr(t, v, n[v], m, r, o && o[v], a, s); } else s || ((n[v] = m), t.updateDuringAnimation(e), g.push(v)); } var x = g.length; if (!c && x) for (var _ = 0; _ < f.length; _++) { if ((w = f[_]).targetName === e) if (w.stopTracks(g)) { var b = P(f, w); f.splice(b, 1); } } if ( (r.force || ((g = B(g, function (t) { return ( (e = i[t]), (r = n[t]), !( e === r || (N(e) && N(r) && (function (t, e) { var n = t.length; if (n !== e.length) return !1; for (var i = 0; i < n; i++) if (t[i] !== e[i]) return !1; return !0; })(e, r)) ) ); var e, r; })), (x = g.length)), x > 0 || (r.force && !a.length)) ) { var w, S = void 0, M = void 0, I = void 0; if (s) { (M = {}), p && (S = {}); for (_ = 0; _ < x; _++) { (M[(v = g[_])] = n[v]), p ? (S[v] = i[v]) : (n[v] = i[v]); } } else if (p) { I = {}; for (_ = 0; _ < x; _++) { (I[(v = g[_])] = Pi(n[v])), zr(n, i, v); } } ((w = new Vi( n, !1, !1, c ? B(f, function (t) { return t.targetName === e; }) : null )).targetName = e), r.scope && (w.scope = r.scope), p && S && w.whenWithKeys(0, S, g), I && w.whenWithKeys(0, I, g), w.whenWithKeys(null == u ? 500 : u, s ? M : i, g).delay(h || 0), t.addAnimator(w, e), a.push(w); } } R(Rr, jt), R(Rr, vr); var Br = (function (t) { function e(e) { var n = t.call(this) || this; return (n.isGroup = !0), (n._children = []), n.attr(e), n; } return ( n(e, t), (e.prototype.childrenRef = function () { return this._children; }), (e.prototype.children = function () { return this._children.slice(); }), (e.prototype.childAt = function (t) { return this._children[t]; }), (e.prototype.childOfName = function (t) { for (var e = this._children, n = 0; n < e.length; n++) if (e[n].name === t) return e[n]; }), (e.prototype.childCount = function () { return this._children.length; }), (e.prototype.add = function (t) { return ( t && t !== this && t.parent !== this && (this._children.push(t), this._doAdd(t)), this ); }), (e.prototype.addBefore = function (t, e) { if ( t && t !== this && t.parent !== this && e && e.parent === this ) { var n = this._children, i = n.indexOf(e); i >= 0 && (n.splice(i, 0, t), this._doAdd(t)); } return this; }), (e.prototype.replace = function (t, e) { var n = P(this._children, t); return n >= 0 && this.replaceAt(e, n), this; }), (e.prototype.replaceAt = function (t, e) { var n = this._children, i = n[e]; if (t && t !== this && t.parent !== this && t !== i) { (n[e] = t), (i.parent = null); var r = this.__zr; r && i.removeSelfFromZr(r), this._doAdd(t); } return this; }), (e.prototype._doAdd = function (t) { t.parent && t.parent.remove(t), (t.parent = this); var e = this.__zr; e && e !== t.__zr && t.addSelfToZr(e), e && e.refresh(); }), (e.prototype.remove = function (t) { var e = this.__zr, n = this._children, i = P(n, t); return ( i < 0 || (n.splice(i, 1), (t.parent = null), e && t.removeSelfFromZr(e), e && e.refresh()), this ); }), (e.prototype.removeAll = function () { for ( var t = this._children, e = this.__zr, n = 0; n < t.length; n++ ) { var i = t[n]; e && i.removeSelfFromZr(e), (i.parent = null); } return (t.length = 0), this; }), (e.prototype.eachChild = function (t, e) { for (var n = this._children, i = 0; i < n.length; i++) { var r = n[i]; t.call(e, r, i); } return this; }), (e.prototype.traverse = function (t, e) { for (var n = 0; n < this._children.length; n++) { var i = this._children[n], r = t.call(e, i); i.isGroup && !r && i.traverse(t, e); } return this; }), (e.prototype.addSelfToZr = function (e) { t.prototype.addSelfToZr.call(this, e); for (var n = 0; n < this._children.length; n++) { this._children[n].addSelfToZr(e); } }), (e.prototype.removeSelfFromZr = function (e) { t.prototype.removeSelfFromZr.call(this, e); for (var n = 0; n < this._children.length; n++) { this._children[n].removeSelfFromZr(e); } }), (e.prototype.getBoundingRect = function (t) { for ( var e = new ze(0, 0, 0, 0), n = t || this._children, i = [], r = null, o = 0; o < n.length; o++ ) { var a = n[o]; if (!a.ignore && !a.invisible) { var s = a.getBoundingRect(), l = a.getLocalTransform(i); l ? (ze.applyTransform(e, s, l), (r = r || e.clone()).union(e)) : (r = r || s.clone()).union(s); } } return r || e; }), e ); })(Rr); Br.prototype.type = "group"; /*! * ZRender, a high performance 2d drawing library. * * Copyright (c) 2013, Baidu Inc. * All rights reserved. * * LICENSE * https://github.com/ecomfe/zrender/blob/master/LICENSE.txt */ var Fr = {}, Gr = {}; var Wr, Hr = (function () { function t(t, e, n) { var i = this; (this._sleepAfterStill = 10), (this._stillFrameAccum = 0), (this._needsRefresh = !0), (this._needsRefreshHover = !0), (this._darkMode = !1), (n = n || {}), (this.dom = e), (this.id = t); var o = new rn(), a = n.renderer || "canvas"; Fr[a] || (a = G(Fr)[0]), (n.useDirtyRect = null != n.useDirtyRect && n.useDirtyRect); var s = new Fr[a](e, o, n, t), l = n.ssr || s.ssrOnly; (this.storage = o), (this.painter = s); var u, h = r.node || r.worker || l ? null : new or(s.getViewportRoot(), s.root), c = n.useCoarsePointer; (null == c || "auto" === c ? r.touchEventsSupported : !!c) && (u = rt(n.pointerSize, 44)), (this.handler = new Ye(o, s, h, s.root, u)), (this.animation = new Wi({ stage: { update: l ? null : function () { return i._flush(!0); }, }, })), l || this.animation.start(); } return ( (t.prototype.add = function (t) { !this._disposed && t && (this.storage.addRoot(t), t.addSelfToZr(this), this.refresh()); }), (t.prototype.remove = function (t) { !this._disposed && t && (this.storage.delRoot(t), t.removeSelfFromZr(this), this.refresh()); }), (t.prototype.configLayer = function (t, e) { this._disposed || (this.painter.configLayer && this.painter.configLayer(t, e), this.refresh()); }), (t.prototype.setBackgroundColor = function (t) { this._disposed || (this.painter.setBackgroundColor && this.painter.setBackgroundColor(t), this.refresh(), (this._backgroundColor = t), (this._darkMode = (function (t) { if (!t) return !1; if ("string" == typeof t) return oi(t, 1) < 0.4; if (t.colorStops) { for ( var e = t.colorStops, n = 0, i = e.length, r = 0; r < i; r++ ) n += oi(e[r].color, 1); return (n /= i) < 0.4; } return !1; })(t))); }), (t.prototype.getBackgroundColor = function () { return this._backgroundColor; }), (t.prototype.setDarkMode = function (t) { this._darkMode = t; }), (t.prototype.isDarkMode = function () { return this._darkMode; }), (t.prototype.refreshImmediately = function (t) { this._disposed || (t || this.animation.update(!0), (this._needsRefresh = !1), this.painter.refresh(), (this._needsRefresh = !1)); }), (t.prototype.refresh = function () { this._disposed || ((this._needsRefresh = !0), this.animation.start()); }), (t.prototype.flush = function () { this._disposed || this._flush(!1); }), (t.prototype._flush = function (t) { var e, n = Bi(); this._needsRefresh && ((e = !0), this.refreshImmediately(t)), this._needsRefreshHover && ((e = !0), this.refreshHoverImmediately()); var i = Bi(); e ? ((this._stillFrameAccum = 0), this.trigger("rendered", { elapsedTime: i - n })) : this._sleepAfterStill > 0 && (this._stillFrameAccum++, this._stillFrameAccum > this._sleepAfterStill && this.animation.stop()); }), (t.prototype.setSleepAfterStill = function (t) { this._sleepAfterStill = t; }), (t.prototype.wakeUp = function () { this._disposed || (this.animation.start(), (this._stillFrameAccum = 0)); }), (t.prototype.refreshHover = function () { this._needsRefreshHover = !0; }), (t.prototype.refreshHoverImmediately = function () { this._disposed || ((this._needsRefreshHover = !1), this.painter.refreshHover && "canvas" === this.painter.getType() && this.painter.refreshHover()); }), (t.prototype.resize = function (t) { this._disposed || ((t = t || {}), this.painter.resize(t.width, t.height), this.handler.resize()); }), (t.prototype.clearAnimation = function () { this._disposed || this.animation.clear(); }), (t.prototype.getWidth = function () { if (!this._disposed) return this.painter.getWidth(); }), (t.prototype.getHeight = function () { if (!this._disposed) return this.painter.getHeight(); }), (t.prototype.setCursorStyle = function (t) { this._disposed || this.handler.setCursorStyle(t); }), (t.prototype.findHover = function (t, e) { if (!this._disposed) return this.handler.findHover(t, e); }), (t.prototype.on = function (t, e, n) { return this._disposed || this.handler.on(t, e, n), this; }), (t.prototype.off = function (t, e) { this._disposed || this.handler.off(t, e); }), (t.prototype.trigger = function (t, e) { this._disposed || this.handler.trigger(t, e); }), (t.prototype.clear = function () { if (!this._disposed) { for ( var t = this.storage.getRoots(), e = 0; e < t.length; e++ ) t[e] instanceof Br && t[e].removeSelfFromZr(this); this.storage.delAllRoots(), this.painter.clear(); } }), (t.prototype.dispose = function () { var t; this._disposed || (this.animation.stop(), this.clear(), this.storage.dispose(), this.painter.dispose(), this.handler.dispose(), (this.animation = this.storage = this.painter = this.handler = null), (this._disposed = !0), (t = this.id), delete Gr[t]); }), t ); })(); function Yr(t, e) { var n = new Hr(M(), t, e); return (Gr[n.id] = n), n; } function Xr(t, e) { Fr[t] = e; } function Ur(t) { if ("function" == typeof Wr) return Wr(t); } function Zr(t) { Wr = t; } var jr = Object.freeze({ __proto__: null, init: Yr, dispose: function (t) { t.dispose(); }, disposeAll: function () { for (var t in Gr) Gr.hasOwnProperty(t) && Gr[t].dispose(); Gr = {}; }, getInstance: function (t) { return Gr[t]; }, registerPainter: Xr, getElementSSRData: Ur, registerSSRDataGetter: Zr, version: "5.6.1", }), qr = 1e-4; function Kr(t, e, n, i) { var r = e[0], o = e[1], a = n[0], s = n[1], l = o - r, u = s - a; if (0 === l) return 0 === u ? a : (a + s) / 2; if (i) if (l > 0) { if (t <= r) return a; if (t >= o) return s; } else { if (t >= r) return a; if (t <= o) return s; } else { if (t === r) return a; if (t === o) return s; } return ((t - r) / l) * u + a; } function $r(t, e) { switch (t) { case "center": case "middle": t = "50%"; break; case "left": case "top": t = "0%"; break; case "right": case "bottom": t = "100%"; } return U(t) ? ((n = t), n.replace(/^\s+|\s+$/g, "")).match(/%$/) ? (parseFloat(t) / 100) * e : parseFloat(t) : null == t ? NaN : +t; var n; } function Jr(t, e, n) { return ( null == e && (e = 10), (e = Math.min(Math.max(0, e), 20)), (t = (+t).toFixed(e)), n ? t : +t ); } function Qr(t) { return ( t.sort(function (t, e) { return t - e; }), t ); } function to(t) { if (((t = +t), isNaN(t))) return 0; if (t > 1e-14) for (var e = 1, n = 0; n < 15; n++, e *= 10) if (Math.round(t * e) / e === t) return n; return eo(t); } function eo(t) { var e = t.toString().toLowerCase(), n = e.indexOf("e"), i = n > 0 ? +e.slice(n + 1) : 0, r = n > 0 ? n : e.length, o = e.indexOf("."), a = o < 0 ? 0 : r - 1 - o; return Math.max(0, a - i); } function no(t, e) { var n = Math.log, i = Math.LN10, r = Math.floor(n(t[1] - t[0]) / i), o = Math.round(n(Math.abs(e[1] - e[0])) / i), a = Math.min(Math.max(-r + o, 0), 20); return isFinite(a) ? a : 20; } function io(t, e) { var n = V( t, function (t, e) { return t + (isNaN(e) ? 0 : e); }, 0 ); if (0 === n) return []; for ( var i = Math.pow(10, e), r = z(t, function (t) { return ((isNaN(t) ? 0 : t) / n) * i * 100; }), o = 100 * i, a = z(r, function (t) { return Math.floor(t); }), s = V( a, function (t, e) { return t + e; }, 0 ), l = z(r, function (t, e) { return t - a[e]; }); s < o; ) { for ( var u = Number.NEGATIVE_INFINITY, h = null, c = 0, p = l.length; c < p; ++c ) l[c] > u && ((u = l[c]), (h = c)); ++a[h], (l[h] = 0), ++s; } return z(a, function (t) { return t / i; }); } function ro(t, e) { var n = Math.max(to(t), to(e)), i = t + e; return n > 20 ? i : Jr(i, n); } var oo = 9007199254740991; function ao(t) { var e = 2 * Math.PI; return ((t % e) + e) % e; } function so(t) { return t > -1e-4 && t < qr; } var lo = /^(?:(\d{4})(?:[-\/](\d{1,2})(?:[-\/](\d{1,2})(?:[T ](\d{1,2})(?::(\d{1,2})(?::(\d{1,2})(?:[.,](\d+))?)?)?(Z|[\+\-]\d\d:?\d\d)?)?)?)?)?$/; function uo(t) { if (t instanceof Date) return t; if (U(t)) { var e = lo.exec(t); if (!e) return new Date(NaN); if (e[8]) { var n = +e[4] || 0; return ( "Z" !== e[8].toUpperCase() && (n -= +e[8].slice(0, 3)), new Date( Date.UTC( +e[1], +(e[2] || 1) - 1, +e[3] || 1, n, +(e[5] || 0), +e[6] || 0, e[7] ? +e[7].substring(0, 3) : 0 ) ) ); } return new Date( +e[1], +(e[2] || 1) - 1, +e[3] || 1, +e[4] || 0, +(e[5] || 0), +e[6] || 0, e[7] ? +e[7].substring(0, 3) : 0 ); } return null == t ? new Date(NaN) : new Date(Math.round(t)); } function ho(t) { return Math.pow(10, co(t)); } function co(t) { if (0 === t) return 0; var e = Math.floor(Math.log(t) / Math.LN10); return t / Math.pow(10, e) >= 10 && e++, e; } function po(t, e) { var n = co(t), i = Math.pow(10, n), r = t / i; return ( (t = (e ? r < 1.5 ? 1 : r < 2.5 ? 2 : r < 4 ? 3 : r < 7 ? 5 : 10 : r < 1 ? 1 : r < 2 ? 2 : r < 3 ? 3 : r < 5 ? 5 : 10) * i), n >= -20 ? +t.toFixed(n < 0 ? -n : 0) : t ); } function fo(t, e) { var n = (t.length - 1) * e + 1, i = Math.floor(n), r = +t[i - 1], o = n - i; return o ? r + o * (t[i] - r) : r; } function go(t) { t.sort(function (t, e) { return s(t, e, 0) ? -1 : 1; }); for (var e = -1 / 0, n = 1, i = 0; i < t.length; ) { for (var r = t[i].interval, o = t[i].close, a = 0; a < 2; a++) r[a] <= e && ((r[a] = e), (o[a] = a ? 1 : 1 - n)), (e = r[a]), (n = o[a]); r[0] === r[1] && o[0] * o[1] != 1 ? t.splice(i, 1) : i++; } return t; function s(t, e, n) { return ( t.interval[n] < e.interval[n] || (t.interval[n] === e.interval[n] && (t.close[n] - e.close[n] == (n ? -1 : 1) || (!n && s(t, e, 1)))) ); } } function yo(t) { var e = parseFloat(t); return e == t && (0 !== e || !U(t) || t.indexOf("x") <= 0) ? e : NaN; } function vo(t) { return !isNaN(yo(t)); } function mo() { return Math.round(9 * Math.random()); } function xo(t, e) { return 0 === e ? t : xo(e, t % e); } function _o(t, e) { return null == t ? e : null == e ? t : (t * e) / xo(t, e); } "undefined" != typeof console && console.warn && console.log; function bo(t) { 0; } function wo(t) { throw new Error(t); } function So(t, e, n) { return (e - t) * n + t; } var Mo = "series\0", Io = "\0_ec_\0"; function To(t) { return t instanceof Array ? t : null == t ? [] : [t]; } function Co(t, e, n) { if (t) { (t[e] = t[e] || {}), (t.emphasis = t.emphasis || {}), (t.emphasis[e] = t.emphasis[e] || {}); for (var i = 0, r = n.length; i < r; i++) { var o = n[i]; !t.emphasis[e].hasOwnProperty(o) && t[e].hasOwnProperty(o) && (t.emphasis[e][o] = t[e][o]); } } } var Do = [ "fontStyle", "fontWeight", "fontSize", "fontFamily", "rich", "tag", "color", "textBorderColor", "textBorderWidth", "width", "height", "lineHeight", "align", "verticalAlign", "baseline", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY", "textShadowColor", "textShadowBlur", "textShadowOffsetX", "textShadowOffsetY", "backgroundColor", "borderColor", "borderWidth", "borderRadius", "padding", ]; function Ao(t) { return !q(t) || Y(t) || t instanceof Date ? t : t.value; } function ko(t) { return q(t) && !(t instanceof Array); } function Lo(t, e, n) { var i = "normalMerge" === n, r = "replaceMerge" === n, o = "replaceAll" === n; (t = t || []), (e = (e || []).slice()); var a = yt(); E(e, function (t, n) { q(t) || (e[n] = null); }); var s, l, u = (function (t, e, n) { var i = []; if ("replaceAll" === n) return i; for (var r = 0; r < t.length; r++) { var o = t[r]; o && null != o.id && e.set(o.id, r), i.push({ existing: "replaceMerge" === n || Eo(o) ? null : o, newOption: null, keyInfo: null, brandNew: null, }); } return i; })(t, a, n); return ( (i || r) && (function (t, e, n, i) { E(i, function (r, o) { if (r && null != r.id) { var a = Oo(r.id), s = n.get(a); if (null != s) { var l = t[s]; lt( !l.newOption, 'Duplicated option on id "' + a + '".' ), (l.newOption = r), (l.existing = e[s]), (i[o] = null); } } }); })(u, t, a, e), i && (function (t, e) { E(e, function (n, i) { if (n && null != n.name) for (var r = 0; r < t.length; r++) { var o = t[r].existing; if ( !t[r].newOption && o && (null == o.id || null == n.id) && !Eo(n) && !Eo(o) && Po("name", o, n) ) return ( (t[r].newOption = n), void (e[i] = null) ); } }); })(u, e), i || r ? (function (t, e, n) { E(e, function (e) { if (e) { for ( var i, r = 0; (i = t[r]) && (i.newOption || Eo(i.existing) || (i.existing && null != e.id && !Po("id", e, i.existing))); ) r++; i ? ((i.newOption = e), (i.brandNew = n)) : t.push({ newOption: e, brandNew: n, existing: null, keyInfo: null, }), r++; } }); })(u, e, r) : o && (function (t, e) { E(e, function (e) { t.push({ newOption: e, brandNew: !0, existing: null, keyInfo: null, }); }); })(u, e), (s = u), (l = yt()), E(s, function (t) { var e = t.existing; e && l.set(e.id, t); }), E(s, function (t) { var e = t.newOption; lt( !e || null == e.id || !l.get(e.id) || l.get(e.id) === t, "id duplicates: " + (e && e.id) ), e && null != e.id && l.set(e.id, t), !t.keyInfo && (t.keyInfo = {}); }), E(s, function (t, e) { var n = t.existing, i = t.newOption, r = t.keyInfo; if (q(i)) { if ( ((r.name = null != i.name ? Oo(i.name) : n ? n.name : Mo + e), n) ) r.id = Oo(n.id); else if (null != i.id) r.id = Oo(i.id); else { var o = 0; do { r.id = "\0" + r.name + "\0" + o++; } while (l.get(r.id)); } l.set(r.id, t); } }), u ); } function Po(t, e, n) { var i = Ro(e[t], null), r = Ro(n[t], null); return null != i && null != r && i === r; } function Oo(t) { return Ro(t, ""); } function Ro(t, e) { return null == t ? e : U(t) ? t : j(t) || Z(t) ? t + "" : e; } function No(t) { var e = t.name; return !(!e || !e.indexOf(Mo)); } function Eo(t) { return t && null != t.id && 0 === Oo(t.id).indexOf(Io); } function zo(t, e) { return null != e.dataIndexInside ? e.dataIndexInside : null != e.dataIndex ? Y(e.dataIndex) ? z(e.dataIndex, function (e) { return t.indexOfRawIndex(e); }) : t.indexOfRawIndex(e.dataIndex) : null != e.name ? Y(e.name) ? z(e.name, function (e) { return t.indexOfName(e); }) : t.indexOfName(e.name) : void 0; } function Vo() { var t = "__ec_inner_" + Bo++; return function (e) { return e[t] || (e[t] = {}); }; } var Bo = mo(); function Fo(t, e, n) { var i = Go(e, n), r = i.mainTypeSpecified, o = i.queryOptionMap, a = i.others, s = n ? n.defaultMainType : null; return ( !r && s && o.set(s, {}), o.each(function (e, i) { var r = Yo(t, i, e, { useDefault: s === i, enableAll: !n || null == n.enableAll || n.enableAll, enableNone: !n || null == n.enableNone || n.enableNone, }); (a[i + "Models"] = r.models), (a[i + "Model"] = r.models[0]); }), a ); } function Go(t, e) { var n; if (U(t)) { var i = {}; (i[t + "Index"] = 0), (n = i); } else n = t; var r = yt(), o = {}, a = !1; return ( E(n, function (t, n) { if ("dataIndex" !== n && "dataIndexInside" !== n) { var i = n.match(/^(\w+)(Index|Id|Name)$/) || [], s = i[1], l = (i[2] || "").toLowerCase(); if ( s && l && !( e && e.includeMainTypes && P(e.includeMainTypes, s) < 0 ) ) (a = a || !!s), ((r.get(s) || r.set(s, {}))[l] = t); } else o[n] = t; }), { mainTypeSpecified: a, queryOptionMap: r, others: o } ); } var Wo = { useDefault: !0, enableAll: !1, enableNone: !1 }, Ho = { useDefault: !1, enableAll: !0, enableNone: !0 }; function Yo(t, e, n, i) { i = i || Wo; var r = n.index, o = n.id, a = n.name, s = { models: null, specified: null != r || null != o || null != a, }; if (!s.specified) { var l = void 0; return ( (s.models = i.useDefault && (l = t.getComponent(e)) ? [l] : []), s ); } return "none" === r || !1 === r ? (lt( i.enableNone, '`"none"` or `false` is not a valid value on index option.' ), (s.models = []), s) : ("all" === r && (lt( i.enableAll, '`"all"` is not a valid value on index option.' ), (r = o = a = null)), (s.models = t.queryComponents({ mainType: e, index: r, id: o, name: a, })), s); } function Xo(t, e, n) { t.setAttribute ? t.setAttribute(e, n) : (t[e] = n); } function Uo(t, e) { var n = yt(), i = []; return ( E(t, function (t) { var r = e(t); (n.get(r) || (i.push(r), n.set(r, []))).push(t); }), { keys: i, buckets: n } ); } function Zo(t, e, n, i, r) { var o = null == e || "auto" === e; if (null == i) return i; if (j(i)) return Jr( (f = So(n || 0, i, r)), o ? Math.max(to(n || 0), to(i)) : e ); if (U(i)) return r < 1 ? n : i; for ( var a = [], s = n, l = i, u = Math.max(s ? s.length : 0, l.length), h = 0; h < u; ++h ) { var c = t.getDimensionInfo(h); if (c && "ordinal" === c.type) a[h] = (r < 1 && s ? s : l)[h]; else { var p = s && s[h] ? s[h] : 0, d = l[h], f = So(p, d, r); a[h] = Jr(f, o ? Math.max(to(p), to(d)) : e); } } return a; } var jo = "___EC__COMPONENT__CONTAINER___", qo = "___EC__EXTENDED_CLASS___"; function Ko(t) { var e = { main: "", sub: "" }; if (t) { var n = t.split("."); (e.main = n[0] || ""), (e.sub = n[1] || ""); } return e; } function $o(t, e) { (t.$constructor = t), (t.extend = function (t) { var e, i, r = this; return ( X((i = r)) && /^class\s/.test(Function.prototype.toString.call(i)) ? (e = (function (t) { function e() { return t.apply(this, arguments) || this; } return n(e, t), e; })(r)) : ((e = function () { (t.$constructor || r).apply(this, arguments); }), O(e, this)), A(e.prototype, t), (e[qo] = !0), (e.extend = this.extend), (e.superCall = ta), (e.superApply = ea), (e.superClass = r), e ); }); } function Jo(t, e) { t.extend = e.extend; } var Qo = Math.round(10 * Math.random()); function ta(t, e) { for (var n = [], i = 2; i < arguments.length; i++) n[i - 2] = arguments[i]; return this.superClass.prototype[e].apply(t, n); } function ea(t, e, n) { return this.superClass.prototype[e].apply(t, n); } function na(t) { var e = {}; (t.registerClass = function (t) { var n, i = t.type || t.prototype.type; if (i) { lt( /^[a-zA-Z0-9_]+([.][a-zA-Z0-9_]+)?$/.test((n = i)), 'componentType "' + n + '" illegal' ), (t.prototype.type = i); var r = Ko(i); if (r.sub) { if (r.sub !== jo) { var o = (function (t) { var n = e[t.main]; (n && n[jo]) || ((n = e[t.main] = {})[jo] = !0); return n; })(r); o[r.sub] = t; } } else e[r.main] = t; } return t; }), (t.getClass = function (t, n, i) { var r = e[t]; if ((r && r[jo] && (r = n ? r[n] : null), i && !r)) throw new Error( n ? "Component " + t + "." + (n || "") + " is used but not imported." : t + ".type should be specified." ); return r; }), (t.getClassesByMainType = function (t) { var n = Ko(t), i = [], r = e[n.main]; return ( r && r[jo] ? E(r, function (t, e) { e !== jo && i.push(t); }) : i.push(r), i ); }), (t.hasClass = function (t) { var n = Ko(t); return !!e[n.main]; }), (t.getAllClassMainTypes = function () { var t = []; return ( E(e, function (e, n) { t.push(n); }), t ); }), (t.hasSubTypes = function (t) { var n = Ko(t), i = e[n.main]; return i && i[jo]; }); } function ia(t, e) { for (var n = 0; n < t.length; n++) t[n][1] || (t[n][1] = t[n][0]); return ( (e = e || !1), function (n, i, r) { for (var o = {}, a = 0; a < t.length; a++) { var s = t[a][1]; if (!((i && P(i, s) >= 0) || (r && P(r, s) < 0))) { var l = n.getShallow(s, e); null != l && (o[t[a][0]] = l); } } return o; } ); } var ra = ia([ ["fill", "color"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["opacity"], ["shadowColor"], ]), oa = (function () { function t() {} return ( (t.prototype.getAreaStyle = function (t, e) { return ra(this, t, e); }), t ); })(), aa = new En(50); function sa(t) { if ("string" == typeof t) { var e = aa.get(t); return e && e.image; } return t; } function la(t, e, n, i, r) { if (t) { if ("string" == typeof t) { if ((e && e.__zrImageSrc === t) || !n) return e; var o = aa.get(t), a = { hostEl: n, cb: i, cbPayload: r }; return ( o ? !ha((e = o.image)) && o.pending.push(a) : (((e = h.loadImage(t, ua, ua)).__zrImageSrc = t), aa.put( t, (e.__cachedImgObj = { image: e, pending: [a] }) )), e ); } return t; } return e; } function ua() { var t = this.__cachedImgObj; this.onload = this.onerror = this.__cachedImgObj = null; for (var e = 0; e < t.pending.length; e++) { var n = t.pending[e], i = n.cb; i && i(this, n.cbPayload), n.hostEl.dirty(); } t.pending.length = 0; } function ha(t) { return t && t.width && t.height; } var ca = /\{([a-zA-Z0-9_]+)\|([^}]*)\}/g; function pa(t, e, n, i, r, o) { if (!n) return (t.text = ""), void (t.isTruncated = !1); var a = (e + "").split("\n"); o = da(n, i, r, o); for (var s = !1, l = {}, u = 0, h = a.length; u < h; u++) fa(l, a[u], o), (a[u] = l.textLine), (s = s || l.isTruncated); (t.text = a.join("\n")), (t.isTruncated = s); } function da(t, e, n, i) { var r = A({}, (i = i || {})); (r.font = e), (n = rt(n, "...")), (r.maxIterations = rt(i.maxIterations, 2)); var o = (r.minChar = rt(i.minChar, 0)); r.cnCharWidth = br("国", e); var a = (r.ascCharWidth = br("a", e)); r.placeholder = rt(i.placeholder, ""); for (var s = (t = Math.max(0, t - 1)), l = 0; l < o && s >= a; l++) s -= a; var u = br(n, e); return ( u > s && ((n = ""), (u = 0)), (s = t - u), (r.ellipsis = n), (r.ellipsisWidth = u), (r.contentWidth = s), (r.containerWidth = t), r ); } function fa(t, e, n) { var i = n.containerWidth, r = n.font, o = n.contentWidth; if (!i) return (t.textLine = ""), void (t.isTruncated = !1); var a = br(e, r); if (a <= i) return (t.textLine = e), void (t.isTruncated = !1); for (var s = 0; ; s++) { if (a <= o || s >= n.maxIterations) { e += n.ellipsis; break; } var l = 0 === s ? ga(e, o, n.ascCharWidth, n.cnCharWidth) : a > 0 ? Math.floor((e.length * o) / a) : 0; a = br((e = e.substr(0, l)), r); } "" === e && (e = n.placeholder), (t.textLine = e), (t.isTruncated = !0); } function ga(t, e, n, i) { for (var r = 0, o = 0, a = t.length; o < a && r < e; o++) { var s = t.charCodeAt(o); r += 0 <= s && s <= 127 ? n : i; } return o; } var ya = function () {}, va = function (t) { (this.tokens = []), t && (this.tokens = t); }, ma = function () { (this.width = 0), (this.height = 0), (this.contentWidth = 0), (this.contentHeight = 0), (this.outerWidth = 0), (this.outerHeight = 0), (this.lines = []), (this.isTruncated = !1); }; function xa(t, e, n, i, r) { var o, a, s = "" === e, l = (r && n.rich[r]) || {}, u = t.lines, h = l.font || n.font, c = !1; if (i) { var p = l.padding, d = p ? p[1] + p[3] : 0; if (null != l.width && "auto" !== l.width) { var f = Cr(l.width, i.width) + d; u.length > 0 && f + i.accumWidth > i.width && ((o = e.split("\n")), (c = !0)), (i.accumWidth = f); } else { var g = wa(e, h, i.width, i.breakAll, i.accumWidth); (i.accumWidth = g.accumWidth + d), (a = g.linesWidths), (o = g.lines); } } else o = e.split("\n"); for (var y = 0; y < o.length; y++) { var v = o[y], m = new ya(); if ( ((m.styleName = r), (m.text = v), (m.isLineHolder = !v && !s), "number" == typeof l.width ? (m.width = l.width) : (m.width = a ? a[y] : br(v, h)), y || c) ) u.push(new va([m])); else { var x = (u[u.length - 1] || (u[0] = new va())).tokens, _ = x.length; 1 === _ && x[0].isLineHolder ? (x[0] = m) : (v || !_ || s) && x.push(m); } } } var _a = V( ",&?/;] ".split(""), function (t, e) { return (t[e] = !0), t; }, {} ); function ba(t) { return ( !(function (t) { var e = t.charCodeAt(0); return ( (e >= 32 && e <= 591) || (e >= 880 && e <= 4351) || (e >= 4608 && e <= 5119) || (e >= 7680 && e <= 8303) ); })(t) || !!_a[t] ); } function wa(t, e, n, i, r) { for ( var o = [], a = [], s = "", l = "", u = 0, h = 0, c = 0; c < t.length; c++ ) { var p = t.charAt(c); if ("\n" !== p) { var d = br(p, e), f = !i && !ba(p); (o.length ? h + d > n : r + h + d > n) ? h ? (s || l) && (f ? (s || ((s = l), (l = ""), (h = u = 0)), o.push(s), a.push(h - u), (l += p), (s = ""), (h = u += d)) : (l && ((s += l), (l = ""), (u = 0)), o.push(s), a.push(h), (s = p), (h = d))) : f ? (o.push(l), a.push(u), (l = p), (u = d)) : (o.push(p), a.push(d)) : ((h += d), f ? ((l += p), (u += d)) : (l && ((s += l), (l = ""), (u = 0)), (s += p))); } else l && ((s += l), (h += u)), o.push(s), a.push(h), (s = ""), (l = ""), (u = 0), (h = 0); } return ( o.length || s || ((s = t), (l = ""), (u = 0)), l && (s += l), s && (o.push(s), a.push(h)), 1 === o.length && (h += r), { accumWidth: h, lines: o, linesWidths: a } ); } var Sa = "__zr_style_" + Math.round(10 * Math.random()), Ma = { shadowBlur: 0, shadowOffsetX: 0, shadowOffsetY: 0, shadowColor: "#000", opacity: 1, blend: "source-over", }, Ia = { style: { shadowBlur: !0, shadowOffsetX: !0, shadowOffsetY: !0, shadowColor: !0, opacity: !0, }, }; Ma[Sa] = !0; var Ta = ["z", "z2", "invisible"], Ca = ["invisible"], Da = (function (t) { function e(e) { return t.call(this, e) || this; } var i; return ( n(e, t), (e.prototype._init = function (e) { for (var n = G(e), i = 0; i < n.length; i++) { var r = n[i]; "style" === r ? this.useStyle(e[r]) : t.prototype.attrKV.call(this, r, e[r]); } this.style || this.useStyle({}); }), (e.prototype.beforeBrush = function () {}), (e.prototype.afterBrush = function () {}), (e.prototype.innerBeforeBrush = function () {}), (e.prototype.innerAfterBrush = function () {}), (e.prototype.shouldBePainted = function (t, e, n, i) { var r = this.transform; if ( this.ignore || this.invisible || 0 === this.style.opacity || (this.culling && (function (t, e, n) { Aa.copy(t.getBoundingRect()), t.transform && Aa.applyTransform(t.transform); return ( (ka.width = e), (ka.height = n), !Aa.intersect(ka) ); })(this, t, e)) || (r && !r[0] && !r[3]) ) return !1; if (n && this.__clipPaths) for (var o = 0; o < this.__clipPaths.length; ++o) if (this.__clipPaths[o].isZeroArea()) return !1; if (i && this.parent) for (var a = this.parent; a; ) { if (a.ignore) return !1; a = a.parent; } return !0; }), (e.prototype.contain = function (t, e) { return this.rectContain(t, e); }), (e.prototype.traverse = function (t, e) { t.call(e, this); }), (e.prototype.rectContain = function (t, e) { var n = this.transformCoordToLocal(t, e); return this.getBoundingRect().contain(n[0], n[1]); }), (e.prototype.getPaintRect = function () { var t = this._paintRect; if (!this._paintRect || this.__dirty) { var e = this.transform, n = this.getBoundingRect(), i = this.style, r = i.shadowBlur || 0, o = i.shadowOffsetX || 0, a = i.shadowOffsetY || 0; (t = this._paintRect || (this._paintRect = new ze(0, 0, 0, 0))), e ? ze.applyTransform(t, n, e) : t.copy(n), (r || o || a) && ((t.width += 2 * r + Math.abs(o)), (t.height += 2 * r + Math.abs(a)), (t.x = Math.min(t.x, t.x + o - r)), (t.y = Math.min(t.y, t.y + a - r))); var s = this.dirtyRectTolerance; t.isZero() || ((t.x = Math.floor(t.x - s)), (t.y = Math.floor(t.y - s)), (t.width = Math.ceil(t.width + 1 + 2 * s)), (t.height = Math.ceil(t.height + 1 + 2 * s))); } return t; }), (e.prototype.setPrevPaintRect = function (t) { t ? ((this._prevPaintRect = this._prevPaintRect || new ze(0, 0, 0, 0)), this._prevPaintRect.copy(t)) : (this._prevPaintRect = null); }), (e.prototype.getPrevPaintRect = function () { return this._prevPaintRect; }), (e.prototype.animateStyle = function (t) { return this.animate("style", t); }), (e.prototype.updateDuringAnimation = function (t) { "style" === t ? this.dirtyStyle() : this.markRedraw(); }), (e.prototype.attrKV = function (e, n) { "style" !== e ? t.prototype.attrKV.call(this, e, n) : this.style ? this.setStyle(n) : this.useStyle(n); }), (e.prototype.setStyle = function (t, e) { return ( "string" == typeof t ? (this.style[t] = e) : A(this.style, t), this.dirtyStyle(), this ); }), (e.prototype.dirtyStyle = function (t) { t || this.markRedraw(), (this.__dirty |= 2), this._rect && (this._rect = null); }), (e.prototype.dirty = function () { this.dirtyStyle(); }), (e.prototype.styleChanged = function () { return !!(2 & this.__dirty); }), (e.prototype.styleUpdated = function () { this.__dirty &= -3; }), (e.prototype.createStyle = function (t) { return mt(Ma, t); }), (e.prototype.useStyle = function (t) { t[Sa] || (t = this.createStyle(t)), this.__inHover ? (this.__hoverStyle = t) : (this.style = t), this.dirtyStyle(); }), (e.prototype.isStyleObject = function (t) { return t[Sa]; }), (e.prototype._innerSaveToNormal = function (e) { t.prototype._innerSaveToNormal.call(this, e); var n = this._normalState; e.style && !n.style && (n.style = this._mergeStyle( this.createStyle(), this.style )), this._savePrimaryToNormal(e, n, Ta); }), (e.prototype._applyStateObj = function (e, n, i, r, o, a) { t.prototype._applyStateObj.call(this, e, n, i, r, o, a); var s, l = !(n && r); if ( (n && n.style ? o ? r ? (s = n.style) : ((s = this._mergeStyle( this.createStyle(), i.style )), this._mergeStyle(s, n.style)) : ((s = this._mergeStyle( this.createStyle(), r ? this.style : i.style )), this._mergeStyle(s, n.style)) : l && (s = i.style), s) ) if (o) { var u = this.style; if ( ((this.style = this.createStyle(l ? {} : u)), l) ) for (var h = G(u), c = 0; c < h.length; c++) { (d = h[c]) in s && ((s[d] = s[d]), (this.style[d] = u[d])); } var p = G(s); for (c = 0; c < p.length; c++) { var d = p[c]; this.style[d] = this.style[d]; } this._transitionState( e, { style: s }, a, this.getAnimationStyleProps() ); } else this.useStyle(s); var f = this.__inHover ? Ca : Ta; for (c = 0; c < f.length; c++) { d = f[c]; n && null != n[d] ? (this[d] = n[d]) : l && null != i[d] && (this[d] = i[d]); } }), (e.prototype._mergeStates = function (e) { for ( var n, i = t.prototype._mergeStates.call(this, e), r = 0; r < e.length; r++ ) { var o = e[r]; o.style && ((n = n || {}), this._mergeStyle(n, o.style)); } return n && (i.style = n), i; }), (e.prototype._mergeStyle = function (t, e) { return A(t, e), t; }), (e.prototype.getAnimationStyleProps = function () { return Ia; }), (e.initDefaultProps = (((i = e.prototype).type = "displayable"), (i.invisible = !1), (i.z = 0), (i.z2 = 0), (i.zlevel = 0), (i.culling = !1), (i.cursor = "pointer"), (i.rectHover = !1), (i.incremental = !1), (i._rect = null), (i.dirtyRectTolerance = 0), void (i.__dirty = 3))), e ); })(Rr), Aa = new ze(0, 0, 0, 0), ka = new ze(0, 0, 0, 0); var La = Math.min, Pa = Math.max, Oa = Math.sin, Ra = Math.cos, Na = 2 * Math.PI, Ea = Mt(), za = Mt(), Va = Mt(); function Ba(t, e, n) { if (0 !== t.length) { for ( var i = t[0], r = i[0], o = i[0], a = i[1], s = i[1], l = 1; l < t.length; l++ ) (i = t[l]), (r = La(r, i[0])), (o = Pa(o, i[0])), (a = La(a, i[1])), (s = Pa(s, i[1])); (e[0] = r), (e[1] = a), (n[0] = o), (n[1] = s); } } function Fa(t, e, n, i, r, o) { (r[0] = La(t, n)), (r[1] = La(e, i)), (o[0] = Pa(t, n)), (o[1] = Pa(e, i)); } var Ga = [], Wa = []; function Ha(t, e, n, i, r, o, a, s, l, u) { var h = bn, c = mn, p = h(t, n, r, a, Ga); (l[0] = 1 / 0), (l[1] = 1 / 0), (u[0] = -1 / 0), (u[1] = -1 / 0); for (var d = 0; d < p; d++) { var f = c(t, n, r, a, Ga[d]); (l[0] = La(f, l[0])), (u[0] = Pa(f, u[0])); } p = h(e, i, o, s, Wa); for (d = 0; d < p; d++) { var g = c(e, i, o, s, Wa[d]); (l[1] = La(g, l[1])), (u[1] = Pa(g, u[1])); } (l[0] = La(t, l[0])), (u[0] = Pa(t, u[0])), (l[0] = La(a, l[0])), (u[0] = Pa(a, u[0])), (l[1] = La(e, l[1])), (u[1] = Pa(e, u[1])), (l[1] = La(s, l[1])), (u[1] = Pa(s, u[1])); } function Ya(t, e, n, i, r, o, a, s) { var l = Cn, u = In, h = Pa(La(l(t, n, r), 1), 0), c = Pa(La(l(e, i, o), 1), 0), p = u(t, n, r, h), d = u(e, i, o, c); (a[0] = La(t, r, p)), (a[1] = La(e, o, d)), (s[0] = Pa(t, r, p)), (s[1] = Pa(e, o, d)); } function Xa(t, e, n, i, r, o, a, s, l) { var u = Ht, h = Yt, c = Math.abs(r - o); if (c % Na < 1e-4 && c > 1e-4) return ( (s[0] = t - n), (s[1] = e - i), (l[0] = t + n), void (l[1] = e + i) ); if ( ((Ea[0] = Ra(r) * n + t), (Ea[1] = Oa(r) * i + e), (za[0] = Ra(o) * n + t), (za[1] = Oa(o) * i + e), u(s, Ea, za), h(l, Ea, za), (r %= Na) < 0 && (r += Na), (o %= Na) < 0 && (o += Na), r > o && !a ? (o += Na) : r < o && a && (r += Na), a) ) { var p = o; (o = r), (r = p); } for (var d = 0; d < o; d += Math.PI / 2) d > r && ((Va[0] = Ra(d) * n + t), (Va[1] = Oa(d) * i + e), u(s, Va, s), h(l, Va, l)); } var Ua = { M: 1, L: 2, C: 3, Q: 4, A: 5, Z: 6, R: 7 }, Za = [], ja = [], qa = [], Ka = [], $a = [], Ja = [], Qa = Math.min, ts = Math.max, es = Math.cos, ns = Math.sin, is = Math.abs, rs = Math.PI, os = 2 * rs, as = "undefined" != typeof Float32Array, ss = []; function ls(t) { return ((Math.round((t / rs) * 1e8) / 1e8) % 2) * rs; } function us(t, e) { var n = ls(t[0]); n < 0 && (n += os); var i = n - t[0], r = t[1]; (r += i), !e && r - n >= os ? (r = n + os) : e && n - r >= os ? (r = n - os) : !e && n > r ? (r = n + (os - ls(n - r))) : e && n < r && (r = n - (os - ls(r - n))), (t[0] = n), (t[1] = r); } var hs = (function () { function t(t) { (this.dpr = 1), (this._xi = 0), (this._yi = 0), (this._x0 = 0), (this._y0 = 0), (this._len = 0), t && (this._saveData = !1), this._saveData && (this.data = []); } return ( (t.prototype.increaseVersion = function () { this._version++; }), (t.prototype.getVersion = function () { return this._version; }), (t.prototype.setScale = function (t, e, n) { (n = n || 0) > 0 && ((this._ux = is(n / sr / t) || 0), (this._uy = is(n / sr / e) || 0)); }), (t.prototype.setDPR = function (t) { this.dpr = t; }), (t.prototype.setContext = function (t) { this._ctx = t; }), (t.prototype.getContext = function () { return this._ctx; }), (t.prototype.beginPath = function () { return this._ctx && this._ctx.beginPath(), this.reset(), this; }), (t.prototype.reset = function () { this._saveData && (this._len = 0), this._pathSegLen && ((this._pathSegLen = null), (this._pathLen = 0)), this._version++; }), (t.prototype.moveTo = function (t, e) { return ( this._drawPendingPt(), this.addData(Ua.M, t, e), this._ctx && this._ctx.moveTo(t, e), (this._x0 = t), (this._y0 = e), (this._xi = t), (this._yi = e), this ); }), (t.prototype.lineTo = function (t, e) { var n = is(t - this._xi), i = is(e - this._yi), r = n > this._ux || i > this._uy; if ( (this.addData(Ua.L, t, e), this._ctx && r && this._ctx.lineTo(t, e), r) ) (this._xi = t), (this._yi = e), (this._pendingPtDist = 0); else { var o = n * n + i * i; o > this._pendingPtDist && ((this._pendingPtX = t), (this._pendingPtY = e), (this._pendingPtDist = o)); } return this; }), (t.prototype.bezierCurveTo = function (t, e, n, i, r, o) { return ( this._drawPendingPt(), this.addData(Ua.C, t, e, n, i, r, o), this._ctx && this._ctx.bezierCurveTo(t, e, n, i, r, o), (this._xi = r), (this._yi = o), this ); }), (t.prototype.quadraticCurveTo = function (t, e, n, i) { return ( this._drawPendingPt(), this.addData(Ua.Q, t, e, n, i), this._ctx && this._ctx.quadraticCurveTo(t, e, n, i), (this._xi = n), (this._yi = i), this ); }), (t.prototype.arc = function (t, e, n, i, r, o) { this._drawPendingPt(), (ss[0] = i), (ss[1] = r), us(ss, o), (i = ss[0]); var a = (r = ss[1]) - i; return ( this.addData(Ua.A, t, e, n, n, i, a, 0, o ? 0 : 1), this._ctx && this._ctx.arc(t, e, n, i, r, o), (this._xi = es(r) * n + t), (this._yi = ns(r) * n + e), this ); }), (t.prototype.arcTo = function (t, e, n, i, r) { return ( this._drawPendingPt(), this._ctx && this._ctx.arcTo(t, e, n, i, r), this ); }), (t.prototype.rect = function (t, e, n, i) { return ( this._drawPendingPt(), this._ctx && this._ctx.rect(t, e, n, i), this.addData(Ua.R, t, e, n, i), this ); }), (t.prototype.closePath = function () { this._drawPendingPt(), this.addData(Ua.Z); var t = this._ctx, e = this._x0, n = this._y0; return t && t.closePath(), (this._xi = e), (this._yi = n), this; }), (t.prototype.fill = function (t) { t && t.fill(), this.toStatic(); }), (t.prototype.stroke = function (t) { t && t.stroke(), this.toStatic(); }), (t.prototype.len = function () { return this._len; }), (t.prototype.setData = function (t) { var e = t.length; (this.data && this.data.length === e) || !as || (this.data = new Float32Array(e)); for (var n = 0; n < e; n++) this.data[n] = t[n]; this._len = e; }), (t.prototype.appendPath = function (t) { t instanceof Array || (t = [t]); for (var e = t.length, n = 0, i = this._len, r = 0; r < e; r++) n += t[r].len(); as && this.data instanceof Float32Array && (this.data = new Float32Array(i + n)); for (r = 0; r < e; r++) for (var o = t[r].data, a = 0; a < o.length; a++) this.data[i++] = o[a]; this._len = i; }), (t.prototype.addData = function (t, e, n, i, r, o, a, s, l) { if (this._saveData) { var u = this.data; this._len + arguments.length > u.length && (this._expandData(), (u = this.data)); for (var h = 0; h < arguments.length; h++) u[this._len++] = arguments[h]; } }), (t.prototype._drawPendingPt = function () { this._pendingPtDist > 0 && (this._ctx && this._ctx.lineTo(this._pendingPtX, this._pendingPtY), (this._pendingPtDist = 0)); }), (t.prototype._expandData = function () { if (!(this.data instanceof Array)) { for (var t = [], e = 0; e < this._len; e++) t[e] = this.data[e]; this.data = t; } }), (t.prototype.toStatic = function () { if (this._saveData) { this._drawPendingPt(); var t = this.data; t instanceof Array && ((t.length = this._len), as && this._len > 11 && (this.data = new Float32Array(t))); } }), (t.prototype.getBoundingRect = function () { (qa[0] = qa[1] = $a[0] = $a[1] = Number.MAX_VALUE), (Ka[0] = Ka[1] = Ja[0] = Ja[1] = -Number.MAX_VALUE); var t, e = this.data, n = 0, i = 0, r = 0, o = 0; for (t = 0; t < this._len; ) { var a = e[t++], s = 1 === t; switch ((s && ((r = n = e[t]), (o = i = e[t + 1])), a)) { case Ua.M: (n = r = e[t++]), (i = o = e[t++]), ($a[0] = r), ($a[1] = o), (Ja[0] = r), (Ja[1] = o); break; case Ua.L: Fa(n, i, e[t], e[t + 1], $a, Ja), (n = e[t++]), (i = e[t++]); break; case Ua.C: Ha( n, i, e[t++], e[t++], e[t++], e[t++], e[t], e[t + 1], $a, Ja ), (n = e[t++]), (i = e[t++]); break; case Ua.Q: Ya(n, i, e[t++], e[t++], e[t], e[t + 1], $a, Ja), (n = e[t++]), (i = e[t++]); break; case Ua.A: var l = e[t++], u = e[t++], h = e[t++], c = e[t++], p = e[t++], d = e[t++] + p; t += 1; var f = !e[t++]; s && ((r = es(p) * h + l), (o = ns(p) * c + u)), Xa(l, u, h, c, p, d, f, $a, Ja), (n = es(d) * h + l), (i = ns(d) * c + u); break; case Ua.R: Fa( (r = n = e[t++]), (o = i = e[t++]), r + e[t++], o + e[t++], $a, Ja ); break; case Ua.Z: (n = r), (i = o); } Ht(qa, qa, $a), Yt(Ka, Ka, Ja); } return ( 0 === t && (qa[0] = qa[1] = Ka[0] = Ka[1] = 0), new ze(qa[0], qa[1], Ka[0] - qa[0], Ka[1] - qa[1]) ); }), (t.prototype._calculateLength = function () { var t = this.data, e = this._len, n = this._ux, i = this._uy, r = 0, o = 0, a = 0, s = 0; this._pathSegLen || (this._pathSegLen = []); for (var l = this._pathSegLen, u = 0, h = 0, c = 0; c < e; ) { var p = t[c++], d = 1 === c; d && ((a = r = t[c]), (s = o = t[c + 1])); var f = -1; switch (p) { case Ua.M: (r = a = t[c++]), (o = s = t[c++]); break; case Ua.L: var g = t[c++], y = (x = t[c++]) - o; (is((A = g - r)) > n || is(y) > i || c === e - 1) && ((f = Math.sqrt(A * A + y * y)), (r = g), (o = x)); break; case Ua.C: var v = t[c++], m = t[c++], x = ((g = t[c++]), t[c++]), _ = t[c++], b = t[c++]; (f = Mn(r, o, v, m, g, x, _, b, 10)), (r = _), (o = b); break; case Ua.Q: (f = kn( r, o, (v = t[c++]), (m = t[c++]), (g = t[c++]), (x = t[c++]), 10 )), (r = g), (o = x); break; case Ua.A: var w = t[c++], S = t[c++], M = t[c++], I = t[c++], T = t[c++], C = t[c++], D = C + T; (c += 1), d && ((a = es(T) * M + w), (s = ns(T) * I + S)), (f = ts(M, I) * Qa(os, Math.abs(C))), (r = es(D) * M + w), (o = ns(D) * I + S); break; case Ua.R: (a = r = t[c++]), (s = o = t[c++]), (f = 2 * t[c++] + 2 * t[c++]); break; case Ua.Z: var A = a - r; y = s - o; (f = Math.sqrt(A * A + y * y)), (r = a), (o = s); } f >= 0 && ((l[h++] = f), (u += f)); } return (this._pathLen = u), u; }), (t.prototype.rebuildPath = function (t, e) { var n, i, r, o, a, s, l, u, h, c, p = this.data, d = this._ux, f = this._uy, g = this._len, y = e < 1, v = 0, m = 0, x = 0; if ( !y || (this._pathSegLen || this._calculateLength(), (l = this._pathSegLen), (u = e * this._pathLen)) ) t: for (var _ = 0; _ < g; ) { var b = p[_++], w = 1 === _; switch ( (w && ((n = r = p[_]), (i = o = p[_ + 1])), b !== Ua.L && x > 0 && (t.lineTo(h, c), (x = 0)), b) ) { case Ua.M: (n = r = p[_++]), (i = o = p[_++]), t.moveTo(r, o); break; case Ua.L: (a = p[_++]), (s = p[_++]); var S = is(a - r), M = is(s - o); if (S > d || M > f) { if (y) { if (v + (j = l[m++]) > u) { var I = (u - v) / j; t.lineTo( r * (1 - I) + a * I, o * (1 - I) + s * I ); break t; } v += j; } t.lineTo(a, s), (r = a), (o = s), (x = 0); } else { var T = S * S + M * M; T > x && ((h = a), (c = s), (x = T)); } break; case Ua.C: var C = p[_++], D = p[_++], A = p[_++], k = p[_++], L = p[_++], P = p[_++]; if (y) { if (v + (j = l[m++]) > u) { wn(r, C, A, L, (I = (u - v) / j), Za), wn(o, D, k, P, I, ja), t.bezierCurveTo( Za[1], ja[1], Za[2], ja[2], Za[3], ja[3] ); break t; } v += j; } t.bezierCurveTo(C, D, A, k, L, P), (r = L), (o = P); break; case Ua.Q: (C = p[_++]), (D = p[_++]), (A = p[_++]), (k = p[_++]); if (y) { if (v + (j = l[m++]) > u) { Dn(r, C, A, (I = (u - v) / j), Za), Dn(o, D, k, I, ja), t.quadraticCurveTo( Za[1], ja[1], Za[2], ja[2] ); break t; } v += j; } t.quadraticCurveTo(C, D, A, k), (r = A), (o = k); break; case Ua.A: var O = p[_++], R = p[_++], N = p[_++], E = p[_++], z = p[_++], V = p[_++], B = p[_++], F = !p[_++], G = N > E ? N : E, W = is(N - E) > 0.001, H = z + V, Y = !1; if (y) v + (j = l[m++]) > u && ((H = z + (V * (u - v)) / j), (Y = !0)), (v += j); if ( (W && t.ellipse ? t.ellipse(O, R, N, E, B, z, H, F) : t.arc(O, R, G, z, H, F), Y) ) break t; w && ((n = es(z) * N + O), (i = ns(z) * E + R)), (r = es(H) * N + O), (o = ns(H) * E + R); break; case Ua.R: (n = r = p[_]), (i = o = p[_ + 1]), (a = p[_++]), (s = p[_++]); var X = p[_++], U = p[_++]; if (y) { if (v + (j = l[m++]) > u) { var Z = u - v; t.moveTo(a, s), t.lineTo(a + Qa(Z, X), s), (Z -= X) > 0 && t.lineTo(a + X, s + Qa(Z, U)), (Z -= U) > 0 && t.lineTo( a + ts(X - Z, 0), s + U ), (Z -= X) > 0 && t.lineTo(a, s + ts(U - Z, 0)); break t; } v += j; } t.rect(a, s, X, U); break; case Ua.Z: if (y) { var j; if (v + (j = l[m++]) > u) { I = (u - v) / j; t.lineTo( r * (1 - I) + n * I, o * (1 - I) + i * I ); break t; } v += j; } t.closePath(), (r = n), (o = i); } } }), (t.prototype.clone = function () { var e = new t(), n = this.data; return ( (e.data = n.slice ? n.slice() : Array.prototype.slice.call(n)), (e._len = this._len), e ); }), (t.CMD = Ua), (t.initDefaultProps = (function () { var e = t.prototype; (e._saveData = !0), (e._ux = 0), (e._uy = 0), (e._pendingPtDist = 0), (e._version = 0); })()), t ); })(); function cs(t, e, n, i, r, o, a) { if (0 === r) return !1; var s = r, l = 0; if ( (a > e + s && a > i + s) || (a < e - s && a < i - s) || (o > t + s && o > n + s) || (o < t - s && o < n - s) ) return !1; if (t === n) return Math.abs(o - t) <= s / 2; var u = (l = (e - i) / (t - n)) * o - a + (t * i - n * e) / (t - n); return (u * u) / (l * l + 1) <= ((s / 2) * s) / 2; } function ps(t, e, n, i, r, o, a, s, l, u, h) { if (0 === l) return !1; var c = l; return ( !( (h > e + c && h > i + c && h > o + c && h > s + c) || (h < e - c && h < i - c && h < o - c && h < s - c) || (u > t + c && u > n + c && u > r + c && u > a + c) || (u < t - c && u < n - c && u < r - c && u < a - c) ) && Sn(t, e, n, i, r, o, a, s, u, h, null) <= c / 2 ); } function ds(t, e, n, i, r, o, a, s, l) { if (0 === a) return !1; var u = a; return ( !( (l > e + u && l > i + u && l > o + u) || (l < e - u && l < i - u && l < o - u) || (s > t + u && s > n + u && s > r + u) || (s < t - u && s < n - u && s < r - u) ) && An(t, e, n, i, r, o, s, l, null) <= u / 2 ); } var fs = 2 * Math.PI; function gs(t) { return (t %= fs) < 0 && (t += fs), t; } var ys = 2 * Math.PI; function vs(t, e, n, i, r, o, a, s, l) { if (0 === a) return !1; var u = a; (s -= t), (l -= e); var h = Math.sqrt(s * s + l * l); if (h - u > n || h + u < n) return !1; if (Math.abs(i - r) % ys < 1e-4) return !0; if (o) { var c = i; (i = gs(r)), (r = gs(c)); } else (i = gs(i)), (r = gs(r)); i > r && (r += ys); var p = Math.atan2(l, s); return ( p < 0 && (p += ys), (p >= i && p <= r) || (p + ys >= i && p + ys <= r) ); } function ms(t, e, n, i, r, o) { if ((o > e && o > i) || (o < e && o < i)) return 0; if (i === e) return 0; var a = (o - e) / (i - e), s = i < e ? 1 : -1; (1 !== a && 0 !== a) || (s = i < e ? 0.5 : -0.5); var l = a * (n - t) + t; return l === r ? 1 / 0 : l > r ? s : 0; } var xs = hs.CMD, _s = 2 * Math.PI; var bs = [-1, -1, -1], ws = [-1, -1]; function Ss(t, e, n, i, r, o, a, s, l, u) { if ( (u > e && u > i && u > o && u > s) || (u < e && u < i && u < o && u < s) ) return 0; var h, c = _n(e, i, o, s, u, bs); if (0 === c) return 0; for (var p = 0, d = -1, f = void 0, g = void 0, y = 0; y < c; y++) { var v = bs[y], m = 0 === v || 1 === v ? 0.5 : 1; mn(t, n, r, a, v) < l || (d < 0 && ((d = bn(e, i, o, s, ws)), ws[1] < ws[0] && d > 1 && ((h = void 0), (h = ws[0]), (ws[0] = ws[1]), (ws[1] = h)), (f = mn(e, i, o, s, ws[0])), d > 1 && (g = mn(e, i, o, s, ws[1]))), 2 === d ? v < ws[0] ? (p += f < e ? m : -m) : v < ws[1] ? (p += g < f ? m : -m) : (p += s < g ? m : -m) : v < ws[0] ? (p += f < e ? m : -m) : (p += s < f ? m : -m)); } return p; } function Ms(t, e, n, i, r, o, a, s) { if ((s > e && s > i && s > o) || (s < e && s < i && s < o)) return 0; var l = (function (t, e, n, i, r) { var o = t - 2 * e + n, a = 2 * (e - t), s = t - i, l = 0; if (yn(o)) vn(a) && (h = -s / a) >= 0 && h <= 1 && (r[l++] = h); else { var u = a * a - 4 * o * s; if (yn(u)) (h = -a / (2 * o)) >= 0 && h <= 1 && (r[l++] = h); else if (u > 0) { var h, c = ln(u), p = (-a - c) / (2 * o); (h = (-a + c) / (2 * o)) >= 0 && h <= 1 && (r[l++] = h), p >= 0 && p <= 1 && (r[l++] = p); } } return l; })(e, i, o, s, bs); if (0 === l) return 0; var u = Cn(e, i, o); if (u >= 0 && u <= 1) { for (var h = 0, c = In(e, i, o, u), p = 0; p < l; p++) { var d = 0 === bs[p] || 1 === bs[p] ? 0.5 : 1; In(t, n, r, bs[p]) < a || (bs[p] < u ? (h += c < e ? d : -d) : (h += o < c ? d : -d)); } return h; } d = 0 === bs[0] || 1 === bs[0] ? 0.5 : 1; return In(t, n, r, bs[0]) < a ? 0 : o < e ? d : -d; } function Is(t, e, n, i, r, o, a, s) { if ((s -= e) > n || s < -n) return 0; var l = Math.sqrt(n * n - s * s); (bs[0] = -l), (bs[1] = l); var u = Math.abs(i - r); if (u < 1e-4) return 0; if (u >= _s - 1e-4) { (i = 0), (r = _s); var h = o ? 1 : -1; return a >= bs[0] + t && a <= bs[1] + t ? h : 0; } if (i > r) { var c = i; (i = r), (r = c); } i < 0 && ((i += _s), (r += _s)); for (var p = 0, d = 0; d < 2; d++) { var f = bs[d]; if (f + t > a) { var g = Math.atan2(s, f); h = o ? 1 : -1; g < 0 && (g = _s + g), ((g >= i && g <= r) || (g + _s >= i && g + _s <= r)) && (g > Math.PI / 2 && g < 1.5 * Math.PI && (h = -h), (p += h)); } } return p; } function Ts(t, e, n, i, r) { for ( var o, a, s, l, u = t.data, h = t.len(), c = 0, p = 0, d = 0, f = 0, g = 0, y = 0; y < h; ) { var v = u[y++], m = 1 === y; switch ( (v === xs.M && y > 1 && (n || (c += ms(p, d, f, g, i, r))), m && ((f = p = u[y]), (g = d = u[y + 1])), v) ) { case xs.M: (p = f = u[y++]), (d = g = u[y++]); break; case xs.L: if (n) { if (cs(p, d, u[y], u[y + 1], e, i, r)) return !0; } else c += ms(p, d, u[y], u[y + 1], i, r) || 0; (p = u[y++]), (d = u[y++]); break; case xs.C: if (n) { if ( ps( p, d, u[y++], u[y++], u[y++], u[y++], u[y], u[y + 1], e, i, r ) ) return !0; } else c += Ss( p, d, u[y++], u[y++], u[y++], u[y++], u[y], u[y + 1], i, r ) || 0; (p = u[y++]), (d = u[y++]); break; case xs.Q: if (n) { if (ds(p, d, u[y++], u[y++], u[y], u[y + 1], e, i, r)) return !0; } else c += Ms(p, d, u[y++], u[y++], u[y], u[y + 1], i, r) || 0; (p = u[y++]), (d = u[y++]); break; case xs.A: var x = u[y++], _ = u[y++], b = u[y++], w = u[y++], S = u[y++], M = u[y++]; y += 1; var I = !!(1 - u[y++]); (o = Math.cos(S) * b + x), (a = Math.sin(S) * w + _), m ? ((f = o), (g = a)) : (c += ms(p, d, o, a, i, r)); var T = ((i - x) * w) / b + x; if (n) { if (vs(x, _, w, S, S + M, I, e, T, r)) return !0; } else c += Is(x, _, w, S, S + M, I, T, r); (p = Math.cos(S + M) * b + x), (d = Math.sin(S + M) * w + _); break; case xs.R: if ( ((f = p = u[y++]), (g = d = u[y++]), (o = f + u[y++]), (a = g + u[y++]), n) ) { if ( cs(f, g, o, g, e, i, r) || cs(o, g, o, a, e, i, r) || cs(o, a, f, a, e, i, r) || cs(f, a, f, g, e, i, r) ) return !0; } else (c += ms(o, g, o, a, i, r)), (c += ms(f, a, f, g, i, r)); break; case xs.Z: if (n) { if (cs(p, d, f, g, e, i, r)) return !0; } else c += ms(p, d, f, g, i, r); (p = f), (d = g); } } return ( n || ((s = d), (l = g), Math.abs(s - l) < 1e-4) || (c += ms(p, d, f, g, i, r) || 0), 0 !== c ); } var Cs = k( { fill: "#000", stroke: null, strokePercent: 1, fillOpacity: 1, strokeOpacity: 1, lineDashOffset: 0, lineWidth: 1, lineCap: "butt", miterLimit: 10, strokeNoScale: !1, strokeFirst: !1, }, Ma ), Ds = { style: k( { fill: !0, stroke: !0, strokePercent: !0, fillOpacity: !0, strokeOpacity: !0, lineDashOffset: !0, lineWidth: !0, miterLimit: !0, }, Ia.style ), }, As = mr.concat(["invisible", "culling", "z", "z2", "zlevel", "parent"]), ks = (function (t) { function e(e) { return t.call(this, e) || this; } var i; return ( n(e, t), (e.prototype.update = function () { var n = this; t.prototype.update.call(this); var i = this.style; if (i.decal) { var r = (this._decalEl = this._decalEl || new e()); r.buildPath === e.prototype.buildPath && (r.buildPath = function (t) { n.buildPath(t, n.shape); }), (r.silent = !0); var o = r.style; for (var a in i) o[a] !== i[a] && (o[a] = i[a]); (o.fill = i.fill ? i.decal : null), (o.decal = null), (o.shadowColor = null), i.strokeFirst && (o.stroke = null); for (var s = 0; s < As.length; ++s) r[As[s]] = this[As[s]]; r.__dirty |= 1; } else this._decalEl && (this._decalEl = null); }), (e.prototype.getDecalElement = function () { return this._decalEl; }), (e.prototype._init = function (e) { var n = G(e); this.shape = this.getDefaultShape(); var i = this.getDefaultStyle(); i && this.useStyle(i); for (var r = 0; r < n.length; r++) { var o = n[r], a = e[o]; "style" === o ? this.style ? A(this.style, a) : this.useStyle(a) : "shape" === o ? A(this.shape, a) : t.prototype.attrKV.call(this, o, a); } this.style || this.useStyle({}); }), (e.prototype.getDefaultStyle = function () { return null; }), (e.prototype.getDefaultShape = function () { return {}; }), (e.prototype.canBeInsideText = function () { return this.hasFill(); }), (e.prototype.getInsideTextFill = function () { var t = this.style.fill; if ("none" !== t) { if (U(t)) { var e = oi(t, 0); return e > 0.5 ? lr : e > 0.2 ? "#eee" : ur; } if (t) return ur; } return lr; }), (e.prototype.getInsideTextStroke = function (t) { var e = this.style.fill; if (U(e)) { var n = this.__zr; if (!(!n || !n.isDarkMode()) === oi(t, 0) < 0.4) return e; } }), (e.prototype.buildPath = function (t, e, n) {}), (e.prototype.pathUpdated = function () { this.__dirty &= -5; }), (e.prototype.getUpdatedPathProxy = function (t) { return ( !this.path && this.createPathProxy(), this.path.beginPath(), this.buildPath(this.path, this.shape, t), this.path ); }), (e.prototype.createPathProxy = function () { this.path = new hs(!1); }), (e.prototype.hasStroke = function () { var t = this.style, e = t.stroke; return !(null == e || "none" === e || !(t.lineWidth > 0)); }), (e.prototype.hasFill = function () { var t = this.style.fill; return null != t && "none" !== t; }), (e.prototype.getBoundingRect = function () { var t = this._rect, e = this.style, n = !t; if (n) { var i = !1; this.path || ((i = !0), this.createPathProxy()); var r = this.path; (i || 4 & this.__dirty) && (r.beginPath(), this.buildPath(r, this.shape, !1), this.pathUpdated()), (t = r.getBoundingRect()); } if ( ((this._rect = t), this.hasStroke() && this.path && this.path.len() > 0) ) { var o = this._rectStroke || (this._rectStroke = t.clone()); if (this.__dirty || n) { o.copy(t); var a = e.strokeNoScale ? this.getLineScale() : 1, s = e.lineWidth; if (!this.hasFill()) { var l = this.strokeContainThreshold; s = Math.max(s, null == l ? 4 : l); } a > 1e-10 && ((o.width += s / a), (o.height += s / a), (o.x -= s / a / 2), (o.y -= s / a / 2)); } return o; } return t; }), (e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e), i = this.getBoundingRect(), r = this.style; if (((t = n[0]), (e = n[1]), i.contain(t, e))) { var o = this.path; if (this.hasStroke()) { var a = r.lineWidth, s = r.strokeNoScale ? this.getLineScale() : 1; if ( s > 1e-10 && (this.hasFill() || (a = Math.max( a, this.strokeContainThreshold )), (function (t, e, n, i) { return Ts(t, e, !0, n, i); })(o, a / s, t, e)) ) return !0; } if (this.hasFill()) return (function (t, e, n) { return Ts(t, 0, !1, e, n); })(o, t, e); } return !1; }), (e.prototype.dirtyShape = function () { (this.__dirty |= 4), this._rect && (this._rect = null), this._decalEl && this._decalEl.dirtyShape(), this.markRedraw(); }), (e.prototype.dirty = function () { this.dirtyStyle(), this.dirtyShape(); }), (e.prototype.animateShape = function (t) { return this.animate("shape", t); }), (e.prototype.updateDuringAnimation = function (t) { "style" === t ? this.dirtyStyle() : "shape" === t ? this.dirtyShape() : this.markRedraw(); }), (e.prototype.attrKV = function (e, n) { "shape" === e ? this.setShape(n) : t.prototype.attrKV.call(this, e, n); }), (e.prototype.setShape = function (t, e) { var n = this.shape; return ( n || (n = this.shape = {}), "string" == typeof t ? (n[t] = e) : A(n, t), this.dirtyShape(), this ); }), (e.prototype.shapeChanged = function () { return !!(4 & this.__dirty); }), (e.prototype.createStyle = function (t) { return mt(Cs, t); }), (e.prototype._innerSaveToNormal = function (e) { t.prototype._innerSaveToNormal.call(this, e); var n = this._normalState; e.shape && !n.shape && (n.shape = A({}, this.shape)); }), (e.prototype._applyStateObj = function (e, n, i, r, o, a) { t.prototype._applyStateObj.call(this, e, n, i, r, o, a); var s, l = !(n && r); if ( (n && n.shape ? o ? r ? (s = n.shape) : ((s = A({}, i.shape)), A(s, n.shape)) : ((s = A({}, r ? this.shape : i.shape)), A(s, n.shape)) : l && (s = i.shape), s) ) if (o) { this.shape = A({}, this.shape); for ( var u = {}, h = G(s), c = 0; c < h.length; c++ ) { var p = h[c]; "object" == typeof s[p] ? (this.shape[p] = s[p]) : (u[p] = s[p]); } this._transitionState(e, { shape: u }, a); } else (this.shape = s), this.dirtyShape(); }), (e.prototype._mergeStates = function (e) { for ( var n, i = t.prototype._mergeStates.call(this, e), r = 0; r < e.length; r++ ) { var o = e[r]; o.shape && ((n = n || {}), this._mergeStyle(n, o.shape)); } return n && (i.shape = n), i; }), (e.prototype.getAnimationStyleProps = function () { return Ds; }), (e.prototype.isZeroArea = function () { return !1; }), (e.extend = function (t) { var i = (function (e) { function i(n) { var i = e.call(this, n) || this; return t.init && t.init.call(i, n), i; } return ( n(i, e), (i.prototype.getDefaultStyle = function () { return T(t.style); }), (i.prototype.getDefaultShape = function () { return T(t.shape); }), i ); })(e); for (var r in t) "function" == typeof t[r] && (i.prototype[r] = t[r]); return i; }), (e.initDefaultProps = (((i = e.prototype).type = "path"), (i.strokeContainThreshold = 5), (i.segmentIgnoreThreshold = 0), (i.subPixelOptimize = !1), (i.autoBatch = !1), void (i.__dirty = 7))), e ); })(Da), Ls = k( { strokeFirst: !0, font: a, x: 0, y: 0, textAlign: "left", textBaseline: "top", miterLimit: 2, }, Cs ), Ps = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.hasStroke = function () { var t = this.style, e = t.stroke; return null != e && "none" !== e && t.lineWidth > 0; }), (e.prototype.hasFill = function () { var t = this.style.fill; return null != t && "none" !== t; }), (e.prototype.createStyle = function (t) { return mt(Ls, t); }), (e.prototype.setBoundingRect = function (t) { this._rect = t; }), (e.prototype.getBoundingRect = function () { var t = this.style; if (!this._rect) { var e = t.text; null != e ? (e += "") : (e = ""); var n = Sr(e, t.font, t.textAlign, t.textBaseline); if ( ((n.x += t.x || 0), (n.y += t.y || 0), this.hasStroke()) ) { var i = t.lineWidth; (n.x -= i / 2), (n.y -= i / 2), (n.width += i), (n.height += i); } this._rect = n; } return this._rect; }), (e.initDefaultProps = void (e.prototype.dirtyRectTolerance = 10)), e ); })(Da); Ps.prototype.type = "tspan"; var Os = k({ x: 0, y: 0 }, Ma), Rs = { style: k( { x: !0, y: !0, width: !0, height: !0, sx: !0, sy: !0, sWidth: !0, sHeight: !0, }, Ia.style ), }; var Ns = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.createStyle = function (t) { return mt(Os, t); }), (e.prototype._getSize = function (t) { var e = this.style, n = e[t]; if (null != n) return n; var i, r = (i = e.image) && "string" != typeof i && i.width && i.height ? e.image : this.__image; if (!r) return 0; var o = "width" === t ? "height" : "width", a = e[o]; return null == a ? r[t] : (r[t] / r[o]) * a; }), (e.prototype.getWidth = function () { return this._getSize("width"); }), (e.prototype.getHeight = function () { return this._getSize("height"); }), (e.prototype.getAnimationStyleProps = function () { return Rs; }), (e.prototype.getBoundingRect = function () { var t = this.style; return ( this._rect || (this._rect = new ze( t.x || 0, t.y || 0, this.getWidth(), this.getHeight() )), this._rect ); }), e ); })(Da); Ns.prototype.type = "image"; var Es = Math.round; function zs(t, e, n) { if (e) { var i = e.x1, r = e.x2, o = e.y1, a = e.y2; (t.x1 = i), (t.x2 = r), (t.y1 = o), (t.y2 = a); var s = n && n.lineWidth; return s ? (Es(2 * i) === Es(2 * r) && (t.x1 = t.x2 = Bs(i, s, !0)), Es(2 * o) === Es(2 * a) && (t.y1 = t.y2 = Bs(o, s, !0)), t) : t; } } function Vs(t, e, n) { if (e) { var i = e.x, r = e.y, o = e.width, a = e.height; (t.x = i), (t.y = r), (t.width = o), (t.height = a); var s = n && n.lineWidth; return s ? ((t.x = Bs(i, s, !0)), (t.y = Bs(r, s, !0)), (t.width = Math.max(Bs(i + o, s, !1) - t.x, 0 === o ? 0 : 1)), (t.height = Math.max( Bs(r + a, s, !1) - t.y, 0 === a ? 0 : 1 )), t) : t; } } function Bs(t, e, n) { if (!e) return t; var i = Es(2 * t); return (i + Es(e)) % 2 == 0 ? i / 2 : (i + (n ? 1 : -1)) / 2; } var Fs = function () { (this.x = 0), (this.y = 0), (this.width = 0), (this.height = 0); }, Gs = {}, Ws = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new Fs(); }), (e.prototype.buildPath = function (t, e) { var n, i, r, o; if (this.subPixelOptimize) { var a = Vs(Gs, e, this.style); (n = a.x), (i = a.y), (r = a.width), (o = a.height), (a.r = e.r), (e = a); } else (n = e.x), (i = e.y), (r = e.width), (o = e.height); e.r ? (function (t, e) { var n, i, r, o, a, s = e.x, l = e.y, u = e.width, h = e.height, c = e.r; u < 0 && ((s += u), (u = -u)), h < 0 && ((l += h), (h = -h)), "number" == typeof c ? (n = i = r = o = c) : c instanceof Array ? 1 === c.length ? (n = i = r = o = c[0]) : 2 === c.length ? ((n = r = c[0]), (i = o = c[1])) : 3 === c.length ? ((n = c[0]), (i = o = c[1]), (r = c[2])) : ((n = c[0]), (i = c[1]), (r = c[2]), (o = c[3])) : (n = i = r = o = 0), n + i > u && ((n *= u / (a = n + i)), (i *= u / a)), r + o > u && ((r *= u / (a = r + o)), (o *= u / a)), i + r > h && ((i *= h / (a = i + r)), (r *= h / a)), n + o > h && ((n *= h / (a = n + o)), (o *= h / a)), t.moveTo(s + n, l), t.lineTo(s + u - i, l), 0 !== i && t.arc( s + u - i, l + i, i, -Math.PI / 2, 0 ), t.lineTo(s + u, l + h - r), 0 !== r && t.arc( s + u - r, l + h - r, r, 0, Math.PI / 2 ), t.lineTo(s + o, l + h), 0 !== o && t.arc( s + o, l + h - o, o, Math.PI / 2, Math.PI ), t.lineTo(s, l + n), 0 !== n && t.arc( s + n, l + n, n, Math.PI, 1.5 * Math.PI ); })(t, e) : t.rect(n, i, r, o); }), (e.prototype.isZeroArea = function () { return !this.shape.width || !this.shape.height; }), e ); })(ks); Ws.prototype.type = "rect"; var Hs = { fill: "#000" }, Ys = { style: k( { fill: !0, stroke: !0, fillOpacity: !0, strokeOpacity: !0, lineWidth: !0, fontSize: !0, lineHeight: !0, width: !0, height: !0, textShadowColor: !0, textShadowBlur: !0, textShadowOffsetX: !0, textShadowOffsetY: !0, backgroundColor: !0, padding: !0, borderColor: !0, borderWidth: !0, borderRadius: !0, }, Ia.style ), }, Xs = (function (t) { function e(e) { var n = t.call(this) || this; return ( (n.type = "text"), (n._children = []), (n._defaultStyle = Hs), n.attr(e), n ); } return ( n(e, t), (e.prototype.childrenRef = function () { return this._children; }), (e.prototype.update = function () { t.prototype.update.call(this), this.styleChanged() && this._updateSubTexts(); for (var e = 0; e < this._children.length; e++) { var n = this._children[e]; (n.zlevel = this.zlevel), (n.z = this.z), (n.z2 = this.z2), (n.culling = this.culling), (n.cursor = this.cursor), (n.invisible = this.invisible); } }), (e.prototype.updateTransform = function () { var e = this.innerTransformable; e ? (e.updateTransform(), e.transform && (this.transform = e.transform)) : t.prototype.updateTransform.call(this); }), (e.prototype.getLocalTransform = function (e) { var n = this.innerTransformable; return n ? n.getLocalTransform(e) : t.prototype.getLocalTransform.call(this, e); }), (e.prototype.getComputedTransform = function () { return ( this.__hostTarget && (this.__hostTarget.getComputedTransform(), this.__hostTarget.updateInnerText(!0)), t.prototype.getComputedTransform.call(this) ); }), (e.prototype._updateSubTexts = function () { var t; (this._childCursor = 0), Js((t = this.style)), E(t.rich, Js), this.style.rich ? this._updateRichTexts() : this._updatePlainTexts(), (this._children.length = this._childCursor), this.styleUpdated(); }), (e.prototype.addSelfToZr = function (e) { t.prototype.addSelfToZr.call(this, e); for (var n = 0; n < this._children.length; n++) this._children[n].__zr = e; }), (e.prototype.removeSelfFromZr = function (e) { t.prototype.removeSelfFromZr.call(this, e); for (var n = 0; n < this._children.length; n++) this._children[n].__zr = null; }), (e.prototype.getBoundingRect = function () { if ( (this.styleChanged() && this._updateSubTexts(), !this._rect) ) { for ( var t = new ze(0, 0, 0, 0), e = this._children, n = [], i = null, r = 0; r < e.length; r++ ) { var o = e[r], a = o.getBoundingRect(), s = o.getLocalTransform(n); s ? (t.copy(a), t.applyTransform(s), (i = i || t.clone()).union(t)) : (i = i || a.clone()).union(a); } this._rect = i || t; } return this._rect; }), (e.prototype.setDefaultTextStyle = function (t) { this._defaultStyle = t || Hs; }), (e.prototype.setTextContent = function (t) { 0; }), (e.prototype._mergeStyle = function (t, e) { if (!e) return t; var n = e.rich, i = t.rich || (n && {}); return ( A(t, e), n && i ? (this._mergeRich(i, n), (t.rich = i)) : i && (t.rich = i), t ); }), (e.prototype._mergeRich = function (t, e) { for (var n = G(e), i = 0; i < n.length; i++) { var r = n[i]; (t[r] = t[r] || {}), A(t[r], e[r]); } }), (e.prototype.getAnimationStyleProps = function () { return Ys; }), (e.prototype._getOrCreateChild = function (t) { var e = this._children[this._childCursor]; return ( (e && e instanceof t) || (e = new t()), (this._children[this._childCursor++] = e), (e.__zr = this.__zr), (e.parent = this), e ); }), (e.prototype._updatePlainTexts = function () { var t = this.style, e = t.font || a, n = t.padding, i = (function (t, e) { null != t && (t += ""); var n, i = e.overflow, r = e.padding, o = e.font, a = "truncate" === i, s = Tr(o), l = rt(e.lineHeight, s), u = !!e.backgroundColor, h = "truncate" === e.lineOverflow, c = !1, p = e.width, d = (n = null == p || ("break" !== i && "breakAll" !== i) ? t ? t.split("\n") : [] : t ? wa( t, e.font, p, "breakAll" === i, 0 ).lines : []).length * l, f = rt(e.height, d); if (d > f && h) { var g = Math.floor(f / l); (c = c || n.length > g), (n = n.slice(0, g)); } if (t && a && null != p) for ( var y = da(p, o, e.ellipsis, { minChar: e.truncateMinChar, placeholder: e.placeholder, }), v = {}, m = 0; m < n.length; m++ ) fa(v, n[m], y), (n[m] = v.textLine), (c = c || v.isTruncated); var x = f, _ = 0; for (m = 0; m < n.length; m++) _ = Math.max(br(n[m], o), _); null == p && (p = _); var b = _; return ( r && ((x += r[0] + r[2]), (b += r[1] + r[3]), (p += r[1] + r[3])), u && (b = p), { lines: n, height: f, outerWidth: b, outerHeight: x, lineHeight: l, calculatedLineHeight: s, contentWidth: _, contentHeight: d, width: p, isTruncated: c, } ); })(nl(t), t), r = il(t), o = !!t.backgroundColor, s = i.outerHeight, l = i.outerWidth, u = i.contentWidth, h = i.lines, c = i.lineHeight, p = this._defaultStyle; this.isTruncated = !!i.isTruncated; var d = t.x || 0, f = t.y || 0, g = t.align || p.align || "left", y = t.verticalAlign || p.verticalAlign || "top", v = d, m = Ir(f, i.contentHeight, y); if (r || n) { var x = Mr(d, l, g), _ = Ir(f, s, y); r && this._renderBackground(t, t, x, _, l, s); } (m += c / 2), n && ((v = el(d, g, n)), "top" === y ? (m += n[0]) : "bottom" === y && (m -= n[2])); for ( var b = 0, w = !1, S = tl(("fill" in t) ? t.fill : ((w = !0), p.fill)), M = Qs( ("stroke" in t) ? t.stroke : o || (p.autoStroke && !w) ? null : ((b = 2), p.stroke) ), I = t.textShadowBlur > 0, T = null != t.width && ("truncate" === t.overflow || "break" === t.overflow || "breakAll" === t.overflow), C = i.calculatedLineHeight, D = 0; D < h.length; D++ ) { var A = this._getOrCreateChild(Ps), k = A.createStyle(); A.useStyle(k), (k.text = h[D]), (k.x = v), (k.y = m), g && (k.textAlign = g), (k.textBaseline = "middle"), (k.opacity = t.opacity), (k.strokeFirst = !0), I && ((k.shadowBlur = t.textShadowBlur || 0), (k.shadowColor = t.textShadowColor || "transparent"), (k.shadowOffsetX = t.textShadowOffsetX || 0), (k.shadowOffsetY = t.textShadowOffsetY || 0)), (k.stroke = M), (k.fill = S), M && ((k.lineWidth = t.lineWidth || b), (k.lineDash = t.lineDash), (k.lineDashOffset = t.lineDashOffset || 0)), (k.font = e), Ks(k, t), (m += c), T && A.setBoundingRect( new ze( Mr(k.x, u, k.textAlign), Ir(k.y, C, k.textBaseline), u, C ) ); } }), (e.prototype._updateRichTexts = function () { var t = this.style, e = (function (t, e) { var n = new ma(); if ((null != t && (t += ""), !t)) return n; for ( var i, r = e.width, o = e.height, a = e.overflow, s = ("break" !== a && "breakAll" !== a) || null == r ? null : { width: r, accumWidth: 0, breakAll: "breakAll" === a, }, l = (ca.lastIndex = 0); null != (i = ca.exec(t)); ) { var u = i.index; u > l && xa(n, t.substring(l, u), e, s), xa(n, i[2], e, s, i[1]), (l = ca.lastIndex); } l < t.length && xa(n, t.substring(l, t.length), e, s); var h = [], c = 0, p = 0, d = e.padding, f = "truncate" === a, g = "truncate" === e.lineOverflow, y = {}; function v(t, e, n) { (t.width = e), (t.lineHeight = n), (c += n), (p = Math.max(p, e)); } t: for (var m = 0; m < n.lines.length; m++) { for ( var x = n.lines[m], _ = 0, b = 0, w = 0; w < x.tokens.length; w++ ) { var S = ((R = x.tokens[w]).styleName && e.rich[R.styleName]) || {}, M = (R.textPadding = S.padding), I = M ? M[1] + M[3] : 0, T = (R.font = S.font || e.font); R.contentHeight = Tr(T); var C = rt(S.height, R.contentHeight); if ( ((R.innerHeight = C), M && (C += M[0] + M[2]), (R.height = C), (R.lineHeight = ot( S.lineHeight, e.lineHeight, C )), (R.align = (S && S.align) || e.align), (R.verticalAlign = (S && S.verticalAlign) || "middle"), g && null != o && c + R.lineHeight > o) ) { var D = n.lines.length; w > 0 ? ((x.tokens = x.tokens.slice( 0, w )), v(x, b, _), (n.lines = n.lines.slice( 0, m + 1 ))) : (n.lines = n.lines.slice(0, m)), (n.isTruncated = n.isTruncated || n.lines.length < D); break t; } var A = S.width, k = null == A || "auto" === A; if ( "string" == typeof A && "%" === A.charAt(A.length - 1) ) (R.percentWidth = A), h.push(R), (R.contentWidth = br(R.text, T)); else { if (k) { var L = S.backgroundColor, P = L && L.image; P && ha((P = sa(P))) && (R.width = Math.max( R.width, (P.width * C) / P.height )); } var O = f && null != r ? r - b : null; null != O && O < R.width ? !k || O < I ? ((R.text = ""), (R.width = R.contentWidth = 0)) : (pa( y, R.text, O - I, T, e.ellipsis, { minChar: e.truncateMinChar, } ), (R.text = y.text), (n.isTruncated = n.isTruncated || y.isTruncated), (R.width = R.contentWidth = br(R.text, T))) : (R.contentWidth = br(R.text, T)); } (R.width += I), (b += R.width), S && (_ = Math.max(_, R.lineHeight)); } v(x, b, _); } for ( n.outerWidth = n.width = rt(r, p), n.outerHeight = n.height = rt(o, c), n.contentHeight = c, n.contentWidth = p, d && ((n.outerWidth += d[1] + d[3]), (n.outerHeight += d[0] + d[2])), m = 0; m < h.length; m++ ) { var R, N = (R = h[m]).percentWidth; R.width = (parseInt(N, 10) / 100) * n.width; } return n; })(nl(t), t), n = e.width, i = e.outerWidth, r = e.outerHeight, o = t.padding, a = t.x || 0, s = t.y || 0, l = this._defaultStyle, u = t.align || l.align, h = t.verticalAlign || l.verticalAlign; this.isTruncated = !!e.isTruncated; var c = Mr(a, i, u), p = Ir(s, r, h), d = c, f = p; o && ((d += o[3]), (f += o[0])); var g = d + n; il(t) && this._renderBackground(t, t, c, p, i, r); for ( var y = !!t.backgroundColor, v = 0; v < e.lines.length; v++ ) { for ( var m = e.lines[v], x = m.tokens, _ = x.length, b = m.lineHeight, w = m.width, S = 0, M = d, I = g, T = _ - 1, C = void 0; S < _ && (!(C = x[S]).align || "left" === C.align); ) this._placeToken(C, t, b, f, M, "left", y), (w -= C.width), (M += C.width), S++; for (; T >= 0 && "right" === (C = x[T]).align; ) this._placeToken(C, t, b, f, I, "right", y), (w -= C.width), (I -= C.width), T--; for (M += (n - (M - d) - (g - I) - w) / 2; S <= T; ) (C = x[S]), this._placeToken( C, t, b, f, M + C.width / 2, "center", y ), (M += C.width), S++; f += b; } }), (e.prototype._placeToken = function (t, e, n, i, r, o, s) { var l = e.rich[t.styleName] || {}; l.text = t.text; var u = t.verticalAlign, h = i + n / 2; "top" === u ? (h = i + t.height / 2) : "bottom" === u && (h = i + n - t.height / 2), !t.isLineHolder && il(l) && this._renderBackground( l, e, "right" === o ? r - t.width : "center" === o ? r - t.width / 2 : r, h - t.height / 2, t.width, t.height ); var c = !!l.backgroundColor, p = t.textPadding; p && ((r = el(r, o, p)), (h -= t.height / 2 - p[0] - t.innerHeight / 2)); var d = this._getOrCreateChild(Ps), f = d.createStyle(); d.useStyle(f); var g = this._defaultStyle, y = !1, v = 0, m = tl( "fill" in l ? l.fill : "fill" in e ? e.fill : ((y = !0), g.fill) ), x = Qs( "stroke" in l ? l.stroke : "stroke" in e ? e.stroke : c || s || (g.autoStroke && !y) ? null : ((v = 2), g.stroke) ), _ = l.textShadowBlur > 0 || e.textShadowBlur > 0; (f.text = t.text), (f.x = r), (f.y = h), _ && ((f.shadowBlur = l.textShadowBlur || e.textShadowBlur || 0), (f.shadowColor = l.textShadowColor || e.textShadowColor || "transparent"), (f.shadowOffsetX = l.textShadowOffsetX || e.textShadowOffsetX || 0), (f.shadowOffsetY = l.textShadowOffsetY || e.textShadowOffsetY || 0)), (f.textAlign = o), (f.textBaseline = "middle"), (f.font = t.font || a), (f.opacity = ot(l.opacity, e.opacity, 1)), Ks(f, l), x && ((f.lineWidth = ot(l.lineWidth, e.lineWidth, v)), (f.lineDash = rt(l.lineDash, e.lineDash)), (f.lineDashOffset = e.lineDashOffset || 0), (f.stroke = x)), m && (f.fill = m); var b = t.contentWidth, w = t.contentHeight; d.setBoundingRect( new ze( Mr(f.x, b, f.textAlign), Ir(f.y, w, f.textBaseline), b, w ) ); }), (e.prototype._renderBackground = function (t, e, n, i, r, o) { var a, s, l, u = t.backgroundColor, h = t.borderWidth, c = t.borderColor, p = u && u.image, d = u && !p, f = t.borderRadius, g = this; if (d || t.lineHeight || (h && c)) { (a = this._getOrCreateChild(Ws)).useStyle( a.createStyle() ), (a.style.fill = null); var y = a.shape; (y.x = n), (y.y = i), (y.width = r), (y.height = o), (y.r = f), a.dirtyShape(); } if (d) ((l = a.style).fill = u || null), (l.fillOpacity = rt(t.fillOpacity, 1)); else if (p) { (s = this._getOrCreateChild(Ns)).onload = function () { g.dirtyStyle(); }; var v = s.style; (v.image = u.image), (v.x = n), (v.y = i), (v.width = r), (v.height = o); } h && c && (((l = a.style).lineWidth = h), (l.stroke = c), (l.strokeOpacity = rt(t.strokeOpacity, 1)), (l.lineDash = t.borderDash), (l.lineDashOffset = t.borderDashOffset || 0), (a.strokeContainThreshold = 0), a.hasFill() && a.hasStroke() && ((l.strokeFirst = !0), (l.lineWidth *= 2))); var m = (a || s).style; (m.shadowBlur = t.shadowBlur || 0), (m.shadowColor = t.shadowColor || "transparent"), (m.shadowOffsetX = t.shadowOffsetX || 0), (m.shadowOffsetY = t.shadowOffsetY || 0), (m.opacity = ot(t.opacity, e.opacity, 1)); }), (e.makeFont = function (t) { var e = ""; return ( $s(t) && (e = [ t.fontStyle, t.fontWeight, qs(t.fontSize), t.fontFamily || "sans-serif", ].join(" ")), (e && ut(e)) || t.textFont || t.font ); }), e ); })(Da), Us = { left: !0, right: 1, center: 1 }, Zs = { top: 1, bottom: 1, middle: 1 }, js = ["fontStyle", "fontWeight", "fontSize", "fontFamily"]; function qs(t) { return "string" != typeof t || (-1 === t.indexOf("px") && -1 === t.indexOf("rem") && -1 === t.indexOf("em")) ? isNaN(+t) ? "12px" : t + "px" : t; } function Ks(t, e) { for (var n = 0; n < js.length; n++) { var i = js[n], r = e[i]; null != r && (t[i] = r); } } function $s(t) { return null != t.fontSize || t.fontFamily || t.fontWeight; } function Js(t) { if (t) { t.font = Xs.makeFont(t); var e = t.align; "middle" === e && (e = "center"), (t.align = null == e || Us[e] ? e : "left"); var n = t.verticalAlign; "center" === n && (n = "middle"), (t.verticalAlign = null == n || Zs[n] ? n : "top"), t.padding && (t.padding = st(t.padding)); } } function Qs(t, e) { return null == t || e <= 0 || "transparent" === t || "none" === t ? null : t.image || t.colorStops ? "#000" : t; } function tl(t) { return null == t || "none" === t ? null : t.image || t.colorStops ? "#000" : t; } function el(t, e, n) { return "right" === e ? t - n[1] : "center" === e ? t + n[3] / 2 - n[1] / 2 : t + n[3]; } function nl(t) { var e = t.text; return null != e && (e += ""), e; } function il(t) { return !!( t.backgroundColor || t.lineHeight || (t.borderWidth && t.borderColor) ); } var rl = Vo(), ol = function (t, e, n, i) { if (i) { var r = rl(i); (r.dataIndex = n), (r.dataType = e), (r.seriesIndex = t), (r.ssrType = "chart"), "group" === i.type && i.traverse(function (i) { var r = rl(i); (r.seriesIndex = t), (r.dataIndex = n), (r.dataType = e), (r.ssrType = "chart"); }); } }, al = 1, sl = {}, ll = Vo(), ul = Vo(), hl = ["emphasis", "blur", "select"], cl = ["normal", "emphasis", "blur", "select"], pl = 10, dl = "highlight", fl = "downplay", gl = "select", yl = "unselect", vl = "toggleSelect"; function ml(t) { return null != t && "none" !== t; } function xl(t, e, n) { t.onHoverStateChange && (t.hoverState || 0) !== n && t.onHoverStateChange(e), (t.hoverState = n); } function _l(t) { xl(t, "emphasis", 2); } function bl(t) { 2 === t.hoverState && xl(t, "normal", 0); } function wl(t) { xl(t, "blur", 1); } function Sl(t) { 1 === t.hoverState && xl(t, "normal", 0); } function Ml(t) { t.selected = !0; } function Il(t) { t.selected = !1; } function Tl(t, e, n) { e(t, n); } function Cl(t, e, n) { Tl(t, e, n), t.isGroup && t.traverse(function (t) { Tl(t, e, n); }); } function Dl(t, e) { switch (e) { case "emphasis": t.hoverState = 2; break; case "normal": t.hoverState = 0; break; case "blur": t.hoverState = 1; break; case "select": t.selected = !0; } } function Al(t, e) { var n = this.states[t]; if (this.style) { if ("emphasis" === t) return (function (t, e, n, i) { var r = n && P(n, "select") >= 0, o = !1; if (t instanceof ks) { var a = ll(t), s = (r && a.selectFill) || a.normalFill, l = (r && a.selectStroke) || a.normalStroke; if (ml(s) || ml(l)) { var u = (i = i || {}).style || {}; "inherit" === u.fill ? ((o = !0), (i = A({}, i)), ((u = A({}, u)).fill = s)) : !ml(u.fill) && ml(s) ? ((o = !0), (i = A({}, i)), ((u = A({}, u)).fill = si(s))) : !ml(u.stroke) && ml(l) && (o || ((i = A({}, i)), (u = A({}, u))), (u.stroke = si(l))), (i.style = u); } } if (i && null == i.z2) { o || (i = A({}, i)); var h = t.z2EmphasisLift; i.z2 = t.z2 + (null != h ? h : pl); } return i; })(this, 0, e, n); if ("blur" === t) return (function (t, e, n) { var i = P(t.currentStates, e) >= 0, r = t.style.opacity, o = i ? null : (function (t, e, n, i) { for ( var r = t.style, o = {}, a = 0; a < e.length; a++ ) { var s = e[a], l = r[s]; o[s] = null == l ? i && i[s] : l; } for (a = 0; a < t.animators.length; a++) { var u = t.animators[a]; u.__fromStateTransition && u.__fromStateTransition.indexOf(n) < 0 && "style" === u.targetName && u.saveTo(o, e); } return o; })(t, ["opacity"], e, { opacity: 1 }), a = (n = n || {}).style || {}; return ( null == a.opacity && ((n = A({}, n)), (a = A({ opacity: i ? r : 0.1 * o.opacity }, a)), (n.style = a)), n ); })(this, t, n); if ("select" === t) return (function (t, e, n) { if (n && null == n.z2) { n = A({}, n); var i = t.z2SelectLift; n.z2 = t.z2 + (null != i ? i : 9); } return n; })(this, 0, n); } return n; } function kl(t) { t.stateProxy = Al; var e = t.getTextContent(), n = t.getTextGuideLine(); e && (e.stateProxy = Al), n && (n.stateProxy = Al); } function Ll(t, e) { !Bl(t, e) && !t.__highByOuter && Cl(t, _l); } function Pl(t, e) { !Bl(t, e) && !t.__highByOuter && Cl(t, bl); } function Ol(t, e) { (t.__highByOuter |= 1 << (e || 0)), Cl(t, _l); } function Rl(t, e) { !(t.__highByOuter &= ~(1 << (e || 0))) && Cl(t, bl); } function Nl(t) { Cl(t, wl); } function El(t) { Cl(t, Sl); } function zl(t) { Cl(t, Ml); } function Vl(t) { Cl(t, Il); } function Bl(t, e) { return t.__highDownSilentOnTouch && e.zrByTouch; } function Fl(t) { var e = t.getModel(), n = [], i = []; e.eachComponent(function (e, r) { var o = ul(r), a = "series" === e, s = a ? t.getViewOfSeriesModel(r) : t.getViewOfComponentModel(r); !a && i.push(s), o.isBlured && (s.group.traverse(function (t) { Sl(t); }), a && n.push(r)), (o.isBlured = !1); }), E(i, function (t) { t && t.toggleBlurSeries && t.toggleBlurSeries(n, !1, e); }); } function Gl(t, e, n, i) { var r = i.getModel(); function o(t, e) { for (var n = 0; n < e.length; n++) { var i = t.getItemGraphicEl(e[n]); i && El(i); } } if (((n = n || "coordinateSystem"), null != t && e && "none" !== e)) { var a = r.getSeriesByIndex(t), s = a.coordinateSystem; s && s.master && (s = s.master); var l = []; r.eachSeries(function (t) { var r = a === t, u = t.coordinateSystem; if ( (u && u.master && (u = u.master), !( ("series" === n && !r) || ("coordinateSystem" === n && !(u && s ? u === s : r)) || ("series" === e && r) )) ) { if ( (i.getViewOfSeriesModel(t).group.traverse(function (t) { (t.__highByOuter && r && "self" === e) || wl(t); }), N(e)) ) o(t.getData(), e); else if (q(e)) for (var h = G(e), c = 0; c < h.length; c++) o(t.getData(h[c]), e[h[c]]); l.push(t), (ul(t).isBlured = !0); } }), r.eachComponent(function (t, e) { if ("series" !== t) { var n = i.getViewOfComponentModel(e); n && n.toggleBlurSeries && n.toggleBlurSeries(l, !0, r); } }); } } function Wl(t, e, n) { if (null != t && null != e) { var i = n.getModel().getComponent(t, e); if (i) { ul(i).isBlured = !0; var r = n.getViewOfComponentModel(i); r && r.focusBlurEnabled && r.group.traverse(function (t) { wl(t); }); } } } function Hl(t, e, n, i) { var r = { focusSelf: !1, dispatchers: null }; if (null == t || "series" === t || null == e || null == n) return r; var o = i.getModel().getComponent(t, e); if (!o) return r; var a = i.getViewOfComponentModel(o); if (!a || !a.findHighDownDispatchers) return r; for (var s, l = a.findHighDownDispatchers(n), u = 0; u < l.length; u++) if ("self" === rl(l[u]).focus) { s = !0; break; } return { focusSelf: s, dispatchers: l }; } function Yl(t) { E(t.getAllData(), function (e) { var n = e.data, i = e.type; n.eachItemGraphicEl(function (e, n) { t.isSelected(n, i) ? zl(e) : Vl(e); }); }); } function Xl(t) { var e = []; return ( t.eachSeries(function (t) { E(t.getAllData(), function (n) { n.data; var i = n.type, r = t.getSelectedDataIndices(); if (r.length > 0) { var o = { dataIndex: r, seriesIndex: t.seriesIndex }; null != i && (o.dataType = i), e.push(o); } }); }), e ); } function Ul(t, e, n) { Jl(t, !0), Cl(t, kl), jl(t, e, n); } function Zl(t, e, n, i) { i ? (function (t) { Jl(t, !1); })(t) : Ul(t, e, n); } function jl(t, e, n) { var i = rl(t); null != e ? ((i.focus = e), (i.blurScope = n)) : i.focus && (i.focus = null); } var ql = ["emphasis", "blur", "select"], Kl = { itemStyle: "getItemStyle", lineStyle: "getLineStyle", areaStyle: "getAreaStyle", }; function $l(t, e, n, i) { n = n || "itemStyle"; for (var r = 0; r < ql.length; r++) { var o = ql[r], a = e.getModel([o, n]); t.ensureState(o).style = i ? i(a) : a[Kl[n]](); } } function Jl(t, e) { var n = !1 === e, i = t; t.highDownSilentOnTouch && (i.__highDownSilentOnTouch = t.highDownSilentOnTouch), (n && !i.__highDownDispatcher) || ((i.__highByOuter = i.__highByOuter || 0), (i.__highDownDispatcher = !n)); } function Ql(t) { return !(!t || !t.__highDownDispatcher); } function tu(t) { var e = t.type; return e === gl || e === yl || e === vl; } function eu(t) { var e = t.type; return e === dl || e === fl; } var nu = hs.CMD, iu = [[], [], []], ru = Math.sqrt, ou = Math.atan2; function au(t, e) { if (e) { var n, i, r, o, a, s, l = t.data, u = t.len(), h = nu.M, c = nu.C, p = nu.L, d = nu.R, f = nu.A, g = nu.Q; for (r = 0, o = 0; r < u; ) { switch (((n = l[r++]), (o = r), (i = 0), n)) { case h: case p: i = 1; break; case c: i = 3; break; case g: i = 2; break; case f: var y = e[4], v = e[5], m = ru(e[0] * e[0] + e[1] * e[1]), x = ru(e[2] * e[2] + e[3] * e[3]), _ = ou(-e[1] / x, e[0] / m); (l[r] *= m), (l[r++] += y), (l[r] *= x), (l[r++] += v), (l[r++] *= m), (l[r++] *= x), (l[r++] += _), (l[r++] += _), (o = r += 2); break; case d: (s[0] = l[r++]), (s[1] = l[r++]), Wt(s, s, e), (l[o++] = s[0]), (l[o++] = s[1]), (s[0] += l[r++]), (s[1] += l[r++]), Wt(s, s, e), (l[o++] = s[0]), (l[o++] = s[1]); } for (a = 0; a < i; a++) { var b = iu[a]; (b[0] = l[r++]), (b[1] = l[r++]), Wt(b, b, e), (l[o++] = b[0]), (l[o++] = b[1]); } } t.increaseVersion(); } } var su = Math.sqrt, lu = Math.sin, uu = Math.cos, hu = Math.PI; function cu(t) { return Math.sqrt(t[0] * t[0] + t[1] * t[1]); } function pu(t, e) { return (t[0] * e[0] + t[1] * e[1]) / (cu(t) * cu(e)); } function du(t, e) { return (t[0] * e[1] < t[1] * e[0] ? -1 : 1) * Math.acos(pu(t, e)); } function fu(t, e, n, i, r, o, a, s, l, u, h) { var c = l * (hu / 180), p = (uu(c) * (t - n)) / 2 + (lu(c) * (e - i)) / 2, d = (-1 * lu(c) * (t - n)) / 2 + (uu(c) * (e - i)) / 2, f = (p * p) / (a * a) + (d * d) / (s * s); f > 1 && ((a *= su(f)), (s *= su(f))); var g = (r === o ? -1 : 1) * su( (a * a * (s * s) - a * a * (d * d) - s * s * (p * p)) / (a * a * (d * d) + s * s * (p * p)) ) || 0, y = (g * a * d) / s, v = (g * -s * p) / a, m = (t + n) / 2 + uu(c) * y - lu(c) * v, x = (e + i) / 2 + lu(c) * y + uu(c) * v, _ = du([1, 0], [(p - y) / a, (d - v) / s]), b = [(p - y) / a, (d - v) / s], w = [(-1 * p - y) / a, (-1 * d - v) / s], S = du(b, w); if ((pu(b, w) <= -1 && (S = hu), pu(b, w) >= 1 && (S = 0), S < 0)) { var M = Math.round((S / hu) * 1e6) / 1e6; S = 2 * hu + (M % 2) * hu; } h.addData(u, m, x, a, s, _, S, c, o); } var gu = /([mlvhzcqtsa])([^mlvhzcqtsa]*)/gi, yu = /-?([0-9]*\.)?[0-9]+([eE]-?[0-9]+)?/g; var vu = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return n(e, t), (e.prototype.applyTransform = function (t) {}), e; })(ks); function mu(t) { return null != t.setData; } function xu(t, e) { var n = (function (t) { var e = new hs(); if (!t) return e; var n, i = 0, r = 0, o = i, a = r, s = hs.CMD, l = t.match(gu); if (!l) return e; for (var u = 0; u < l.length; u++) { for ( var h = l[u], c = h.charAt(0), p = void 0, d = h.match(yu) || [], f = d.length, g = 0; g < f; g++ ) d[g] = parseFloat(d[g]); for (var y = 0; y < f; ) { var v = void 0, m = void 0, x = void 0, _ = void 0, b = void 0, w = void 0, S = void 0, M = i, I = r, T = void 0, C = void 0; switch (c) { case "l": (i += d[y++]), (r += d[y++]), (p = s.L), e.addData(p, i, r); break; case "L": (i = d[y++]), (r = d[y++]), (p = s.L), e.addData(p, i, r); break; case "m": (i += d[y++]), (r += d[y++]), (p = s.M), e.addData(p, i, r), (o = i), (a = r), (c = "l"); break; case "M": (i = d[y++]), (r = d[y++]), (p = s.M), e.addData(p, i, r), (o = i), (a = r), (c = "L"); break; case "h": (i += d[y++]), (p = s.L), e.addData(p, i, r); break; case "H": (i = d[y++]), (p = s.L), e.addData(p, i, r); break; case "v": (r += d[y++]), (p = s.L), e.addData(p, i, r); break; case "V": (r = d[y++]), (p = s.L), e.addData(p, i, r); break; case "C": (p = s.C), e.addData( p, d[y++], d[y++], d[y++], d[y++], d[y++], d[y++] ), (i = d[y - 2]), (r = d[y - 1]); break; case "c": (p = s.C), e.addData( p, d[y++] + i, d[y++] + r, d[y++] + i, d[y++] + r, d[y++] + i, d[y++] + r ), (i += d[y - 2]), (r += d[y - 1]); break; case "S": (v = i), (m = r), (T = e.len()), (C = e.data), n === s.C && ((v += i - C[T - 4]), (m += r - C[T - 3])), (p = s.C), (M = d[y++]), (I = d[y++]), (i = d[y++]), (r = d[y++]), e.addData(p, v, m, M, I, i, r); break; case "s": (v = i), (m = r), (T = e.len()), (C = e.data), n === s.C && ((v += i - C[T - 4]), (m += r - C[T - 3])), (p = s.C), (M = i + d[y++]), (I = r + d[y++]), (i += d[y++]), (r += d[y++]), e.addData(p, v, m, M, I, i, r); break; case "Q": (M = d[y++]), (I = d[y++]), (i = d[y++]), (r = d[y++]), (p = s.Q), e.addData(p, M, I, i, r); break; case "q": (M = d[y++] + i), (I = d[y++] + r), (i += d[y++]), (r += d[y++]), (p = s.Q), e.addData(p, M, I, i, r); break; case "T": (v = i), (m = r), (T = e.len()), (C = e.data), n === s.Q && ((v += i - C[T - 4]), (m += r - C[T - 3])), (i = d[y++]), (r = d[y++]), (p = s.Q), e.addData(p, v, m, i, r); break; case "t": (v = i), (m = r), (T = e.len()), (C = e.data), n === s.Q && ((v += i - C[T - 4]), (m += r - C[T - 3])), (i += d[y++]), (r += d[y++]), (p = s.Q), e.addData(p, v, m, i, r); break; case "A": (x = d[y++]), (_ = d[y++]), (b = d[y++]), (w = d[y++]), (S = d[y++]), fu( (M = i), (I = r), (i = d[y++]), (r = d[y++]), w, S, x, _, b, (p = s.A), e ); break; case "a": (x = d[y++]), (_ = d[y++]), (b = d[y++]), (w = d[y++]), (S = d[y++]), fu( (M = i), (I = r), (i += d[y++]), (r += d[y++]), w, S, x, _, b, (p = s.A), e ); } } ("z" !== c && "Z" !== c) || ((p = s.Z), e.addData(p), (i = o), (r = a)), (n = p); } return e.toStatic(), e; })(t), i = A({}, e); return ( (i.buildPath = function (t) { if (mu(t)) { t.setData(n.data), (e = t.getContext()) && t.rebuildPath(e, 1); } else { var e = t; n.rebuildPath(e, 1); } }), (i.applyTransform = function (t) { au(n, t), this.dirtyShape(); }), i ); } function _u(t, e) { return new vu(xu(t, e)); } function bu(t, e) { e = e || {}; var n = new ks(); return ( t.shape && n.setShape(t.shape), n.setStyle(t.style), e.bakeTransform ? au(n.path, t.getComputedTransform()) : e.toLocal ? n.setLocalTransform(t.getComputedTransform()) : n.copyTransform(t), (n.buildPath = t.buildPath), (n.applyTransform = n.applyTransform), (n.z = t.z), (n.z2 = t.z2), (n.zlevel = t.zlevel), n ); } var wu = function () { (this.cx = 0), (this.cy = 0), (this.r = 0); }, Su = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new wu(); }), (e.prototype.buildPath = function (t, e) { t.moveTo(e.cx + e.r, e.cy), t.arc(e.cx, e.cy, e.r, 0, 2 * Math.PI); }), e ); })(ks); Su.prototype.type = "circle"; var Mu = function () { (this.cx = 0), (this.cy = 0), (this.rx = 0), (this.ry = 0); }, Iu = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new Mu(); }), (e.prototype.buildPath = function (t, e) { var n = 0.5522848, i = e.cx, r = e.cy, o = e.rx, a = e.ry, s = o * n, l = a * n; t.moveTo(i - o, r), t.bezierCurveTo(i - o, r - l, i - s, r - a, i, r - a), t.bezierCurveTo(i + s, r - a, i + o, r - l, i + o, r), t.bezierCurveTo(i + o, r + l, i + s, r + a, i, r + a), t.bezierCurveTo(i - s, r + a, i - o, r + l, i - o, r), t.closePath(); }), e ); })(ks); Iu.prototype.type = "ellipse"; var Tu = Math.PI, Cu = 2 * Tu, Du = Math.sin, Au = Math.cos, ku = Math.acos, Lu = Math.atan2, Pu = Math.abs, Ou = Math.sqrt, Ru = Math.max, Nu = Math.min, Eu = 1e-4; function zu(t, e, n, i, r, o, a) { var s = t - n, l = e - i, u = (a ? o : -o) / Ou(s * s + l * l), h = u * l, c = -u * s, p = t + h, d = e + c, f = n + h, g = i + c, y = (p + f) / 2, v = (d + g) / 2, m = f - p, x = g - d, _ = m * m + x * x, b = r - o, w = p * g - f * d, S = (x < 0 ? -1 : 1) * Ou(Ru(0, b * b * _ - w * w)), M = (w * x - m * S) / _, I = (-w * m - x * S) / _, T = (w * x + m * S) / _, C = (-w * m + x * S) / _, D = M - y, A = I - v, k = T - y, L = C - v; return ( D * D + A * A > k * k + L * L && ((M = T), (I = C)), { cx: M, cy: I, x0: -h, y0: -c, x1: M * (r / b - 1), y1: I * (r / b - 1), } ); } function Vu(t, e) { var n, i = Ru(e.r, 0), r = Ru(e.r0 || 0, 0), o = i > 0; if (o || r > 0) { if ((o || ((i = r), (r = 0)), r > i)) { var a = i; (i = r), (r = a); } var s = e.startAngle, l = e.endAngle; if (!isNaN(s) && !isNaN(l)) { var u = e.cx, h = e.cy, c = !!e.clockwise, p = Pu(l - s), d = p > Cu && p % Cu; if ((d > Eu && (p = d), i > Eu)) if (p > Cu - Eu) t.moveTo(u + i * Au(s), h + i * Du(s)), t.arc(u, h, i, s, l, !c), r > Eu && (t.moveTo(u + r * Au(l), h + r * Du(l)), t.arc(u, h, r, l, s, c)); else { var f = void 0, g = void 0, y = void 0, v = void 0, m = void 0, x = void 0, _ = void 0, b = void 0, w = void 0, S = void 0, M = void 0, I = void 0, T = void 0, C = void 0, D = void 0, A = void 0, k = i * Au(s), L = i * Du(s), P = r * Au(l), O = r * Du(l), R = p > Eu; if (R) { var N = e.cornerRadius; N && ((n = (function (t) { var e; if (Y(t)) { var n = t.length; if (!n) return t; e = 1 === n ? [t[0], t[0], 0, 0] : 2 === n ? [t[0], t[0], t[1], t[1]] : 3 === n ? t.concat(t[2]) : t; } else e = [t, t, t, t]; return e; })(N)), (f = n[0]), (g = n[1]), (y = n[2]), (v = n[3])); var E = Pu(i - r) / 2; if ( ((m = Nu(E, y)), (x = Nu(E, v)), (_ = Nu(E, f)), (b = Nu(E, g)), (M = w = Ru(m, x)), (I = S = Ru(_, b)), (w > Eu || S > Eu) && ((T = i * Au(l)), (C = i * Du(l)), (D = r * Au(s)), (A = r * Du(s)), p < Tu)) ) { var z = (function (t, e, n, i, r, o, a, s) { var l = n - t, u = i - e, h = a - r, c = s - o, p = c * l - h * u; if (!(p * p < Eu)) return [ t + (p = (h * (e - o) - c * (t - r)) / p) * l, e + p * u, ]; })(k, L, D, A, T, C, P, O); if (z) { var V = k - z[0], B = L - z[1], F = T - z[0], G = C - z[1], W = 1 / Du( ku( (V * F + B * G) / (Ou(V * V + B * B) * Ou(F * F + G * G)) ) / 2 ), H = Ou(z[0] * z[0] + z[1] * z[1]); (M = Nu(w, (i - H) / (W + 1))), (I = Nu(S, (r - H) / (W - 1))); } } } if (R) if (M > Eu) { var X = Nu(y, M), U = Nu(v, M), Z = zu(D, A, k, L, i, X, c), j = zu(T, C, P, O, i, U, c); t.moveTo(u + Z.cx + Z.x0, h + Z.cy + Z.y0), M < w && X === U ? t.arc( u + Z.cx, h + Z.cy, M, Lu(Z.y0, Z.x0), Lu(j.y0, j.x0), !c ) : (X > 0 && t.arc( u + Z.cx, h + Z.cy, X, Lu(Z.y0, Z.x0), Lu(Z.y1, Z.x1), !c ), t.arc( u, h, i, Lu(Z.cy + Z.y1, Z.cx + Z.x1), Lu(j.cy + j.y1, j.cx + j.x1), !c ), U > 0 && t.arc( u + j.cx, h + j.cy, U, Lu(j.y1, j.x1), Lu(j.y0, j.x0), !c )); } else t.moveTo(u + k, h + L), t.arc(u, h, i, s, l, !c); else t.moveTo(u + k, h + L); if (r > Eu && R) if (I > Eu) { (X = Nu(f, I)), (Z = zu(P, O, T, C, r, -(U = Nu(g, I)), c)), (j = zu(k, L, D, A, r, -X, c)); t.lineTo(u + Z.cx + Z.x0, h + Z.cy + Z.y0), I < S && X === U ? t.arc( u + Z.cx, h + Z.cy, I, Lu(Z.y0, Z.x0), Lu(j.y0, j.x0), !c ) : (U > 0 && t.arc( u + Z.cx, h + Z.cy, U, Lu(Z.y0, Z.x0), Lu(Z.y1, Z.x1), !c ), t.arc( u, h, r, Lu(Z.cy + Z.y1, Z.cx + Z.x1), Lu(j.cy + j.y1, j.cx + j.x1), c ), X > 0 && t.arc( u + j.cx, h + j.cy, X, Lu(j.y1, j.x1), Lu(j.y0, j.x0), !c )); } else t.lineTo(u + P, h + O), t.arc(u, h, r, l, s, c); else t.lineTo(u + P, h + O); } else t.moveTo(u, h); t.closePath(); } } } var Bu = function () { (this.cx = 0), (this.cy = 0), (this.r0 = 0), (this.r = 0), (this.startAngle = 0), (this.endAngle = 2 * Math.PI), (this.clockwise = !0), (this.cornerRadius = 0); }, Fu = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new Bu(); }), (e.prototype.buildPath = function (t, e) { Vu(t, e); }), (e.prototype.isZeroArea = function () { return ( this.shape.startAngle === this.shape.endAngle || this.shape.r === this.shape.r0 ); }), e ); })(ks); Fu.prototype.type = "sector"; var Gu = function () { (this.cx = 0), (this.cy = 0), (this.r = 0), (this.r0 = 0); }, Wu = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new Gu(); }), (e.prototype.buildPath = function (t, e) { var n = e.cx, i = e.cy, r = 2 * Math.PI; t.moveTo(n + e.r, i), t.arc(n, i, e.r, 0, r, !1), t.moveTo(n + e.r0, i), t.arc(n, i, e.r0, 0, r, !0); }), e ); })(ks); function Hu(t, e, n) { var i = e.smooth, r = e.points; if (r && r.length >= 2) { if (i) { var o = (function (t, e, n, i) { var r, o, a, s, l = [], u = [], h = [], c = []; if (i) { (a = [1 / 0, 1 / 0]), (s = [-1 / 0, -1 / 0]); for (var p = 0, d = t.length; p < d; p++) Ht(a, a, t[p]), Yt(s, s, t[p]); Ht(a, a, i[0]), Yt(s, s, i[1]); } for (p = 0, d = t.length; p < d; p++) { var f = t[p]; if (n) (r = t[p ? p - 1 : d - 1]), (o = t[(p + 1) % d]); else { if (0 === p || p === d - 1) { l.push(Tt(t[p])); continue; } (r = t[p - 1]), (o = t[p + 1]); } kt(u, o, r), Nt(u, u, e); var g = zt(f, r), y = zt(f, o), v = g + y; 0 !== v && ((g /= v), (y /= v)), Nt(h, u, -g), Nt(c, u, y); var m = Dt([], f, h), x = Dt([], f, c); i && (Yt(m, m, a), Ht(m, m, s), Yt(x, x, a), Ht(x, x, s)), l.push(m), l.push(x); } return n && l.push(l.shift()), l; })(r, i, n, e.smoothConstraint); t.moveTo(r[0][0], r[0][1]); for (var a = r.length, s = 0; s < (n ? a : a - 1); s++) { var l = o[2 * s], u = o[2 * s + 1], h = r[(s + 1) % a]; t.bezierCurveTo(l[0], l[1], u[0], u[1], h[0], h[1]); } } else { t.moveTo(r[0][0], r[0][1]); s = 1; for (var c = r.length; s < c; s++) t.lineTo(r[s][0], r[s][1]); } n && t.closePath(); } } Wu.prototype.type = "ring"; var Yu = function () { (this.points = null), (this.smooth = 0), (this.smoothConstraint = null); }, Xu = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new Yu(); }), (e.prototype.buildPath = function (t, e) { Hu(t, e, !0); }), e ); })(ks); Xu.prototype.type = "polygon"; var Uu = function () { (this.points = null), (this.percent = 1), (this.smooth = 0), (this.smoothConstraint = null); }, Zu = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new Uu(); }), (e.prototype.buildPath = function (t, e) { Hu(t, e, !1); }), e ); })(ks); Zu.prototype.type = "polyline"; var ju = {}, qu = function () { (this.x1 = 0), (this.y1 = 0), (this.x2 = 0), (this.y2 = 0), (this.percent = 1); }, Ku = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new qu(); }), (e.prototype.buildPath = function (t, e) { var n, i, r, o; if (this.subPixelOptimize) { var a = zs(ju, e, this.style); (n = a.x1), (i = a.y1), (r = a.x2), (o = a.y2); } else (n = e.x1), (i = e.y1), (r = e.x2), (o = e.y2); var s = e.percent; 0 !== s && (t.moveTo(n, i), s < 1 && ((r = n * (1 - s) + r * s), (o = i * (1 - s) + o * s)), t.lineTo(r, o)); }), (e.prototype.pointAt = function (t) { var e = this.shape; return [ e.x1 * (1 - t) + e.x2 * t, e.y1 * (1 - t) + e.y2 * t, ]; }), e ); })(ks); Ku.prototype.type = "line"; var $u = [], Ju = function () { (this.x1 = 0), (this.y1 = 0), (this.x2 = 0), (this.y2 = 0), (this.cpx1 = 0), (this.cpy1 = 0), (this.percent = 1); }; function Qu(t, e, n) { var i = t.cpx2, r = t.cpy2; return null != i || null != r ? [ (n ? xn : mn)(t.x1, t.cpx1, t.cpx2, t.x2, e), (n ? xn : mn)(t.y1, t.cpy1, t.cpy2, t.y2, e), ] : [ (n ? Tn : In)(t.x1, t.cpx1, t.x2, e), (n ? Tn : In)(t.y1, t.cpy1, t.y2, e), ]; } var th = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new Ju(); }), (e.prototype.buildPath = function (t, e) { var n = e.x1, i = e.y1, r = e.x2, o = e.y2, a = e.cpx1, s = e.cpy1, l = e.cpx2, u = e.cpy2, h = e.percent; 0 !== h && (t.moveTo(n, i), null == l || null == u ? (h < 1 && (Dn(n, a, r, h, $u), (a = $u[1]), (r = $u[2]), Dn(i, s, o, h, $u), (s = $u[1]), (o = $u[2])), t.quadraticCurveTo(a, s, r, o)) : (h < 1 && (wn(n, a, l, r, h, $u), (a = $u[1]), (l = $u[2]), (r = $u[3]), wn(i, s, u, o, h, $u), (s = $u[1]), (u = $u[2]), (o = $u[3])), t.bezierCurveTo(a, s, l, u, r, o))); }), (e.prototype.pointAt = function (t) { return Qu(this.shape, t, !1); }), (e.prototype.tangentAt = function (t) { var e = Qu(this.shape, t, !0); return Et(e, e); }), e ); })(ks); th.prototype.type = "bezier-curve"; var eh = function () { (this.cx = 0), (this.cy = 0), (this.r = 0), (this.startAngle = 0), (this.endAngle = 2 * Math.PI), (this.clockwise = !0); }, nh = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new eh(); }), (e.prototype.buildPath = function (t, e) { var n = e.cx, i = e.cy, r = Math.max(e.r, 0), o = e.startAngle, a = e.endAngle, s = e.clockwise, l = Math.cos(o), u = Math.sin(o); t.moveTo(l * r + n, u * r + i), t.arc(n, i, r, o, a, !s); }), e ); })(ks); nh.prototype.type = "arc"; var ih = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.type = "compound"), e; } return ( n(e, t), (e.prototype._updatePathDirty = function () { for ( var t = this.shape.paths, e = this.shapeChanged(), n = 0; n < t.length; n++ ) e = e || t[n].shapeChanged(); e && this.dirtyShape(); }), (e.prototype.beforeBrush = function () { this._updatePathDirty(); for ( var t = this.shape.paths || [], e = this.getGlobalScale(), n = 0; n < t.length; n++ ) t[n].path || t[n].createPathProxy(), t[n].path.setScale( e[0], e[1], t[n].segmentIgnoreThreshold ); }), (e.prototype.buildPath = function (t, e) { for (var n = e.paths || [], i = 0; i < n.length; i++) n[i].buildPath(t, n[i].shape, !0); }), (e.prototype.afterBrush = function () { for ( var t = this.shape.paths || [], e = 0; e < t.length; e++ ) t[e].pathUpdated(); }), (e.prototype.getBoundingRect = function () { return ( this._updatePathDirty.call(this), ks.prototype.getBoundingRect.call(this) ); }), e ); })(ks), rh = (function () { function t(t) { this.colorStops = t || []; } return ( (t.prototype.addColorStop = function (t, e) { this.colorStops.push({ offset: t, color: e }); }), t ); })(), oh = (function (t) { function e(e, n, i, r, o, a) { var s = t.call(this, o) || this; return ( (s.x = null == e ? 0 : e), (s.y = null == n ? 0 : n), (s.x2 = null == i ? 1 : i), (s.y2 = null == r ? 0 : r), (s.type = "linear"), (s.global = a || !1), s ); } return n(e, t), e; })(rh), ah = (function (t) { function e(e, n, i, r, o) { var a = t.call(this, r) || this; return ( (a.x = null == e ? 0.5 : e), (a.y = null == n ? 0.5 : n), (a.r = null == i ? 0.5 : i), (a.type = "radial"), (a.global = o || !1), a ); } return n(e, t), e; })(rh), sh = [0, 0], lh = [0, 0], uh = new De(), hh = new De(), ch = (function () { function t(t, e) { (this._corners = []), (this._axes = []), (this._origin = [0, 0]); for (var n = 0; n < 4; n++) this._corners[n] = new De(); for (n = 0; n < 2; n++) this._axes[n] = new De(); t && this.fromBoundingRect(t, e); } return ( (t.prototype.fromBoundingRect = function (t, e) { var n = this._corners, i = this._axes, r = t.x, o = t.y, a = r + t.width, s = o + t.height; if ( (n[0].set(r, o), n[1].set(a, o), n[2].set(a, s), n[3].set(r, s), e) ) for (var l = 0; l < 4; l++) n[l].transform(e); De.sub(i[0], n[1], n[0]), De.sub(i[1], n[3], n[0]), i[0].normalize(), i[1].normalize(); for (l = 0; l < 2; l++) this._origin[l] = i[l].dot(n[0]); }), (t.prototype.intersect = function (t, e) { var n = !0, i = !e; return ( uh.set(1 / 0, 1 / 0), hh.set(0, 0), (!this._intersectCheckOneSide(this, t, uh, hh, i, 1) && ((n = !1), i)) || (!this._intersectCheckOneSide( t, this, uh, hh, i, -1 ) && ((n = !1), i)) || i || De.copy(e, n ? uh : hh), n ); }), (t.prototype._intersectCheckOneSide = function ( t, e, n, i, r, o ) { for (var a = !0, s = 0; s < 2; s++) { var l = this._axes[s]; if ( (this._getProjMinMaxOnAxis(s, t._corners, sh), this._getProjMinMaxOnAxis(s, e._corners, lh), sh[1] < lh[0] || sh[0] > lh[1]) ) { if (((a = !1), r)) return a; var u = Math.abs(lh[0] - sh[1]), h = Math.abs(sh[0] - lh[1]); Math.min(u, h) > i.len() && (u < h ? De.scale(i, l, -u * o) : De.scale(i, l, h * o)); } else if (n) { (u = Math.abs(lh[0] - sh[1])), (h = Math.abs(sh[0] - lh[1])); Math.min(u, h) < n.len() && (u < h ? De.scale(n, l, u * o) : De.scale(n, l, -h * o)); } } return a; }), (t.prototype._getProjMinMaxOnAxis = function (t, e, n) { for ( var i = this._axes[t], r = this._origin, o = e[0].dot(i) + r[t], a = o, s = o, l = 1; l < e.length; l++ ) { var u = e[l].dot(i) + r[t]; (a = Math.min(u, a)), (s = Math.max(u, s)); } (n[0] = a), (n[1] = s); }), t ); })(), ph = [], dh = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return ( (e.notClear = !0), (e.incremental = !0), (e._displayables = []), (e._temporaryDisplayables = []), (e._cursor = 0), e ); } return ( n(e, t), (e.prototype.traverse = function (t, e) { t.call(e, this); }), (e.prototype.useStyle = function () { this.style = {}; }), (e.prototype.getCursor = function () { return this._cursor; }), (e.prototype.innerAfterBrush = function () { this._cursor = this._displayables.length; }), (e.prototype.clearDisplaybles = function () { (this._displayables = []), (this._temporaryDisplayables = []), (this._cursor = 0), this.markRedraw(), (this.notClear = !1); }), (e.prototype.clearTemporalDisplayables = function () { this._temporaryDisplayables = []; }), (e.prototype.addDisplayable = function (t, e) { e ? this._temporaryDisplayables.push(t) : this._displayables.push(t), this.markRedraw(); }), (e.prototype.addDisplayables = function (t, e) { e = e || !1; for (var n = 0; n < t.length; n++) this.addDisplayable(t[n], e); }), (e.prototype.getDisplayables = function () { return this._displayables; }), (e.prototype.getTemporalDisplayables = function () { return this._temporaryDisplayables; }), (e.prototype.eachPendingDisplayable = function (t) { for ( var e = this._cursor; e < this._displayables.length; e++ ) t && t(this._displayables[e]); for (e = 0; e < this._temporaryDisplayables.length; e++) t && t(this._temporaryDisplayables[e]); }), (e.prototype.update = function () { this.updateTransform(); for ( var t = this._cursor; t < this._displayables.length; t++ ) { ((e = this._displayables[t]).parent = this), e.update(), (e.parent = null); } for (t = 0; t < this._temporaryDisplayables.length; t++) { var e; ((e = this._temporaryDisplayables[t]).parent = this), e.update(), (e.parent = null); } }), (e.prototype.getBoundingRect = function () { if (!this._rect) { for ( var t = new ze(1 / 0, 1 / 0, -1 / 0, -1 / 0), e = 0; e < this._displayables.length; e++ ) { var n = this._displayables[e], i = n.getBoundingRect().clone(); n.needLocalTransform() && i.applyTransform(n.getLocalTransform(ph)), t.union(i); } this._rect = t; } return this._rect; }), (e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e); if (this.getBoundingRect().contain(n[0], n[1])) for (var i = 0; i < this._displayables.length; i++) { if (this._displayables[i].contain(t, e)) return !0; } return !1; }), e ); })(Da), fh = Vo(); function gh(t, e, n, i, r) { var o; if (e && e.ecModel) { var a = e.ecModel.getUpdatePayload(); o = a && a.animation; } var s = "update" === t; if (e && e.isAnimationEnabled()) { var l = void 0, u = void 0, h = void 0; return ( i ? ((l = rt(i.duration, 200)), (u = rt(i.easing, "cubicOut")), (h = 0)) : ((l = e.getShallow( s ? "animationDurationUpdate" : "animationDuration" )), (u = e.getShallow( s ? "animationEasingUpdate" : "animationEasing" )), (h = e.getShallow( s ? "animationDelayUpdate" : "animationDelay" ))), o && (null != o.duration && (l = o.duration), null != o.easing && (u = o.easing), null != o.delay && (h = o.delay)), X(h) && (h = h(n, r)), X(l) && (l = l(n)), { duration: l || 0, delay: h, easing: u } ); } return null; } function yh(t, e, n, i, r, o, a) { var s, l = !1; X(r) ? ((a = o), (o = r), (r = null)) : q(r) && ((o = r.cb), (a = r.during), (l = r.isFrom), (s = r.removeOpt), (r = r.dataIndex)); var u = "leave" === t; u || e.stopAnimation("leave"); var h = gh( t, i, r, u ? s || {} : null, i && i.getAnimationDelayParams ? i.getAnimationDelayParams(e, r) : null ); if (h && h.duration > 0) { var c = { duration: h.duration, delay: h.delay || 0, easing: h.easing, done: o, force: !!o || !!a, setToFinal: !u, scope: t, during: a, }; l ? e.animateFrom(n, c) : e.animateTo(n, c); } else e.stopAnimation(), !l && e.attr(n), a && a(1), o && o(); } function vh(t, e, n, i, r, o) { yh("update", t, e, n, i, r, o); } function mh(t, e, n, i, r, o) { yh("enter", t, e, n, i, r, o); } function xh(t) { if (!t.__zr) return !0; for (var e = 0; e < t.animators.length; e++) { if ("leave" === t.animators[e].scope) return !0; } return !1; } function _h(t, e, n, i, r, o) { xh(t) || yh("leave", t, e, n, i, r, o); } function bh(t, e, n, i) { t.removeTextContent(), t.removeTextGuideLine(), _h(t, { style: { opacity: 0 } }, e, n, i); } function wh(t, e, n) { function i() { t.parent && t.parent.remove(t); } t.isGroup ? t.traverse(function (t) { t.isGroup || bh(t, e, n, i); }) : bh(t, e, n, i); } function Sh(t) { fh(t).oldStyle = t.style; } var Mh = Math.max, Ih = Math.min, Th = {}; function Ch(t) { return ks.extend(t); } var Dh = function (t, e) { var i = xu(t, e); return (function (t) { function e(e) { var n = t.call(this, e) || this; return ( (n.applyTransform = i.applyTransform), (n.buildPath = i.buildPath), n ); } return n(e, t), e; })(vu); }; function Ah(t, e) { return Dh(t, e); } function kh(t, e) { Th[t] = e; } function Lh(t) { if (Th.hasOwnProperty(t)) return Th[t]; } function Ph(t, e, n, i) { var r = _u(t, e); return ( n && ("center" === i && (n = Rh(n, r.getBoundingRect())), Eh(r, n)), r ); } function Oh(t, e, n) { var i = new Ns({ style: { image: t, x: e.x, y: e.y, width: e.width, height: e.height, }, onload: function (t) { if ("center" === n) { var r = { width: t.width, height: t.height }; i.setStyle(Rh(e, r)); } }, }); return i; } function Rh(t, e) { var n, i = e.width / e.height, r = t.height * i; return ( (n = r <= t.width ? t.height : (r = t.width) / i), { x: t.x + t.width / 2 - r / 2, y: t.y + t.height / 2 - n / 2, width: r, height: n, } ); } var Nh = function (t, e) { for (var n = [], i = t.length, r = 0; r < i; r++) { var o = t[r]; n.push(o.getUpdatedPathProxy(!0)); } var a = new ks(e); return ( a.createPathProxy(), (a.buildPath = function (t) { if (mu(t)) { t.appendPath(n); var e = t.getContext(); e && t.rebuildPath(e, 1); } }), a ); }; function Eh(t, e) { if (t.applyTransform) { var n = t.getBoundingRect().calculateTransform(e); t.applyTransform(n); } } function zh(t, e) { return zs(t, t, { lineWidth: e }), t; } var Vh = Bs; function Bh(t, e) { for (var n = xe([]); t && t !== e; ) be(n, t.getLocalTransform(), n), (t = t.parent); return n; } function Fh(t, e, n) { return ( e && !N(e) && (e = vr.getLocalTransform(e)), n && (e = Ie([], e)), Wt([], t, e) ); } function Gh(t, e, n) { var i = 0 === e[4] || 0 === e[5] || 0 === e[0] ? 1 : Math.abs((2 * e[4]) / e[0]), r = 0 === e[4] || 0 === e[5] || 0 === e[2] ? 1 : Math.abs((2 * e[4]) / e[2]), o = [ "left" === t ? -i : "right" === t ? i : 0, "top" === t ? -r : "bottom" === t ? r : 0, ]; return ( (o = Fh(o, e, n)), Math.abs(o[0]) > Math.abs(o[1]) ? o[0] > 0 ? "right" : "left" : o[1] > 0 ? "bottom" : "top" ); } function Wh(t) { return !t.isGroup; } function Hh(t, e, n) { if (t && e) { var i, r = ((i = {}), t.traverse(function (t) { Wh(t) && t.anid && (i[t.anid] = t); }), i); e.traverse(function (t) { if (Wh(t) && t.anid) { var e = r[t.anid]; if (e) { var i = o(t); t.attr(o(e)), vh(t, i, n, rl(t).dataIndex); } } }); } function o(t) { var e = { x: t.x, y: t.y, rotation: t.rotation }; return ( (function (t) { return null != t.shape; })(t) && (e.shape = A({}, t.shape)), e ); } } function Yh(t, e) { return z(t, function (t) { var n = t[0]; (n = Mh(n, e.x)), (n = Ih(n, e.x + e.width)); var i = t[1]; return (i = Mh(i, e.y)), [n, (i = Ih(i, e.y + e.height))]; }); } function Xh(t, e) { var n = Mh(t.x, e.x), i = Ih(t.x + t.width, e.x + e.width), r = Mh(t.y, e.y), o = Ih(t.y + t.height, e.y + e.height); if (i >= n && o >= r) return { x: n, y: r, width: i - n, height: o - r }; } function Uh(t, e, n) { var i = A({ rectHover: !0 }, e), r = (i.style = { strokeNoScale: !0 }); if (((n = n || { x: -1, y: -1, width: 2, height: 2 }), t)) return 0 === t.indexOf("image://") ? ((r.image = t.slice(8)), k(r, n), new Ns(i)) : Ph(t.replace("path://", ""), i, n, "center"); } function Zh(t, e, n, i, r) { for (var o = 0, a = r[r.length - 1]; o < r.length; o++) { var s = r[o]; if (jh(t, e, n, i, s[0], s[1], a[0], a[1])) return !0; a = s; } } function jh(t, e, n, i, r, o, a, s) { var l, u = n - t, h = i - e, c = a - r, p = s - o, d = qh(c, p, u, h); if ((l = d) <= 1e-6 && l >= -1e-6) return !1; var f = t - r, g = e - o, y = qh(f, g, u, h) / d; if (y < 0 || y > 1) return !1; var v = qh(f, g, c, p) / d; return !(v < 0 || v > 1); } function qh(t, e, n, i) { return t * i - n * e; } function Kh(t) { var e = t.itemTooltipOption, n = t.componentModel, i = t.itemName, r = U(e) ? { formatter: e } : e, o = n.mainType, a = n.componentIndex, s = { componentType: o, name: i, $vars: ["name"] }; s[o + "Index"] = a; var l = t.formatterParamsExtra; l && E(G(l), function (t) { _t(s, t) || ((s[t] = l[t]), s.$vars.push(t)); }); var u = rl(t.el); (u.componentMainType = o), (u.componentIndex = a), (u.tooltipConfig = { name: i, option: k( { content: i, encodeHTMLContent: !0, formatterParams: s }, r ), }); } function $h(t, e) { var n; t.isGroup && (n = e(t)), n || t.traverse(e); } function Jh(t, e) { if (t) if (Y(t)) for (var n = 0; n < t.length; n++) $h(t[n], e); else $h(t, e); } kh("circle", Su), kh("ellipse", Iu), kh("sector", Fu), kh("ring", Wu), kh("polygon", Xu), kh("polyline", Zu), kh("rect", Ws), kh("line", Ku), kh("bezierCurve", th), kh("arc", nh); var Qh = Object.freeze({ __proto__: null, updateProps: vh, initProps: mh, removeElement: _h, removeElementWithFadeOut: wh, isElementRemoved: xh, extendShape: Ch, extendPath: Ah, registerShape: kh, getShapeClass: Lh, makePath: Ph, makeImage: Oh, mergePath: Nh, resizePath: Eh, subPixelOptimizeLine: zh, subPixelOptimizeRect: function (t) { return Vs(t.shape, t.shape, t.style), t; }, subPixelOptimize: Vh, getTransform: Bh, applyTransform: Fh, transformDirection: Gh, groupTransition: Hh, clipPointsByRect: Yh, clipRectByRect: Xh, createIcon: Uh, linePolygonIntersect: Zh, lineLineIntersect: jh, setTooltipConfig: Kh, traverseElements: Jh, Group: Br, Image: Ns, Text: Xs, Circle: Su, Ellipse: Iu, Sector: Fu, Ring: Wu, Polygon: Xu, Polyline: Zu, Rect: Ws, Line: Ku, BezierCurve: th, Arc: nh, IncrementalDisplayable: dh, CompoundPath: ih, LinearGradient: oh, RadialGradient: ah, BoundingRect: ze, OrientedBoundingRect: ch, Point: De, Path: ks, }), tc = {}; function ec(t, e) { for (var n = 0; n < hl.length; n++) { var i = hl[n], r = e[i], o = t.ensureState(i); (o.style = o.style || {}), (o.style.text = r); } var a = t.currentStates.slice(); t.clearStates(!0), t.setStyle({ text: e.normal }), t.useStates(a, !0); } function nc(t, e, n) { var i, r = t.labelFetcher, o = t.labelDataIndex, a = t.labelDimIndex, s = e.normal; r && (i = r.getFormattedLabel( o, "normal", null, a, s && s.get("formatter"), null != n ? { interpolatedValue: n } : null )), null == i && (i = X(t.defaultText) ? t.defaultText(o, t, n) : t.defaultText); for (var l = { normal: i }, u = 0; u < hl.length; u++) { var h = hl[u], c = e[h]; l[h] = rt( r ? r.getFormattedLabel( o, h, null, a, c && c.get("formatter") ) : null, i ); } return l; } function ic(t, e, n, i) { n = n || tc; for (var r = t instanceof Xs, o = !1, a = 0; a < cl.length; a++) { if ((p = e[cl[a]]) && p.getShallow("show")) { o = !0; break; } } var s = r ? t : t.getTextContent(); if (o) { r || (s || ((s = new Xs()), t.setTextContent(s)), t.stateProxy && (s.stateProxy = t.stateProxy)); var l = nc(n, e), u = e.normal, h = !!u.getShallow("show"), c = oc(u, i && i.normal, n, !1, !r); (c.text = l.normal), r || t.setTextConfig(ac(u, n, !1)); for (a = 0; a < hl.length; a++) { var p, d = hl[a]; if ((p = e[d])) { var f = s.ensureState(d), g = !!rt(p.getShallow("show"), h); if ( (g !== h && (f.ignore = !g), (f.style = oc(p, i && i[d], n, !0, !r)), (f.style.text = l[d]), !r) ) t.ensureState(d).textConfig = ac(p, n, !0); } } (s.silent = !!u.getShallow("silent")), null != s.style.x && (c.x = s.style.x), null != s.style.y && (c.y = s.style.y), (s.ignore = !h), s.useStyle(c), s.dirty(), n.enableTextSetter && (pc(s).setLabelText = function (t) { var i = nc(n, e, t); ec(s, i); }); } else s && (s.ignore = !0); t.dirty(); } function rc(t, e) { e = e || "label"; for (var n = { normal: t.getModel(e) }, i = 0; i < hl.length; i++) { var r = hl[i]; n[r] = t.getModel([r, e]); } return n; } function oc(t, e, n, i, r) { var o = {}; return ( (function (t, e, n, i, r) { n = n || tc; var o, a = e.ecModel, s = a && a.option.textStyle, l = (function (t) { var e; for (; t && t !== t.ecModel; ) { var n = (t.option || tc).rich; if (n) { e = e || {}; for (var i = G(n), r = 0; r < i.length; r++) { e[i[r]] = 1; } } t = t.parentModel; } return e; })(e); if (l) for (var u in ((o = {}), l)) if (l.hasOwnProperty(u)) { var h = e.getModel(["rich", u]); hc((o[u] = {}), h, s, n, i, r, !1, !0); } o && (t.rich = o); var c = e.get("overflow"); c && (t.overflow = c); var p = e.get("minMargin"); null != p && (t.margin = p); hc(t, e, s, n, i, r, !0, !1); })(o, t, n, i, r), e && A(o, e), o ); } function ac(t, e, n) { e = e || {}; var i, r = {}, o = t.getShallow("rotate"), a = rt(t.getShallow("distance"), n ? null : 5), s = t.getShallow("offset"); return ( "outside" === (i = t.getShallow("position") || (n ? null : "inside")) && (i = e.defaultOutsidePosition || "top"), null != i && (r.position = i), null != s && (r.offset = s), null != o && ((o *= Math.PI / 180), (r.rotation = o)), null != a && (r.distance = a), (r.outsideFill = "inherit" === t.get("color") ? e.inheritColor || null : "auto"), r ); } var sc = [ "fontStyle", "fontWeight", "fontSize", "fontFamily", "textShadowColor", "textShadowBlur", "textShadowOffsetX", "textShadowOffsetY", ], lc = [ "align", "lineHeight", "width", "height", "tag", "verticalAlign", "ellipsis", ], uc = [ "padding", "borderWidth", "borderRadius", "borderDashOffset", "backgroundColor", "borderColor", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY", ]; function hc(t, e, n, i, r, o, a, s) { n = (!r && n) || tc; var l = i && i.inheritColor, u = e.getShallow("color"), h = e.getShallow("textBorderColor"), c = rt(e.getShallow("opacity"), n.opacity); ("inherit" !== u && "auto" !== u) || (u = l || null), ("inherit" !== h && "auto" !== h) || (h = l || null), o || ((u = u || n.color), (h = h || n.textBorderColor)), null != u && (t.fill = u), null != h && (t.stroke = h); var p = rt(e.getShallow("textBorderWidth"), n.textBorderWidth); null != p && (t.lineWidth = p); var d = rt(e.getShallow("textBorderType"), n.textBorderType); null != d && (t.lineDash = d); var f = rt( e.getShallow("textBorderDashOffset"), n.textBorderDashOffset ); null != f && (t.lineDashOffset = f), r || null != c || s || (c = i && i.defaultOpacity), null != c && (t.opacity = c), r || o || (null == t.fill && i.inheritColor && (t.fill = i.inheritColor)); for (var g = 0; g < sc.length; g++) { var y = sc[g]; null != (m = rt(e.getShallow(y), n[y])) && (t[y] = m); } for (g = 0; g < lc.length; g++) { y = lc[g]; null != (m = e.getShallow(y)) && (t[y] = m); } if (null == t.verticalAlign) { var v = e.getShallow("baseline"); null != v && (t.verticalAlign = v); } if (!a || !i.disableBox) { for (g = 0; g < uc.length; g++) { var m; y = uc[g]; null != (m = e.getShallow(y)) && (t[y] = m); } var x = e.getShallow("borderType"); null != x && (t.borderDash = x), ("auto" !== t.backgroundColor && "inherit" !== t.backgroundColor) || !l || (t.backgroundColor = l), ("auto" !== t.borderColor && "inherit" !== t.borderColor) || !l || (t.borderColor = l); } } function cc(t, e) { var n = e && e.getModel("textStyle"); return ut( [ t.fontStyle || (n && n.getShallow("fontStyle")) || "", t.fontWeight || (n && n.getShallow("fontWeight")) || "", (t.fontSize || (n && n.getShallow("fontSize")) || 12) + "px", t.fontFamily || (n && n.getShallow("fontFamily")) || "sans-serif", ].join(" ") ); } var pc = Vo(); function dc(t, e, n, i) { if (t) { var r = pc(t); (r.prevValue = r.value), (r.value = n); var o = e.normal; (r.valueAnimation = o.get("valueAnimation")), r.valueAnimation && ((r.precision = o.get("precision")), (r.defaultInterpolatedText = i), (r.statesModels = e)); } } function fc(t, e, n, i, r) { var o = pc(t); if (o.valueAnimation && o.prevValue !== o.value) { var a = o.defaultInterpolatedText, s = rt(o.interpolatedValue, o.prevValue), l = o.value; (t.percent = 0), (null == o.prevValue ? mh : vh)( t, { percent: 1 }, i, e, null, function (i) { var u = Zo(n, o.precision, s, l, i); o.interpolatedValue = 1 === i ? null : u; var h = nc( { labelDataIndex: e, labelFetcher: r, defaultText: a ? a(u) : u + "", }, o.statesModels, u ); ec(t, h); } ); } } var gc, yc, vc = ["textStyle", "color"], mc = [ "fontStyle", "fontWeight", "fontSize", "fontFamily", "padding", "lineHeight", "rich", "width", "height", "overflow", ], xc = new Xs(), _c = (function () { function t() {} return ( (t.prototype.getTextColor = function (t) { var e = this.ecModel; return ( this.getShallow("color") || (!t && e ? e.get(vc) : null) ); }), (t.prototype.getFont = function () { return cc( { fontStyle: this.getShallow("fontStyle"), fontWeight: this.getShallow("fontWeight"), fontSize: this.getShallow("fontSize"), fontFamily: this.getShallow("fontFamily"), }, this.ecModel ); }), (t.prototype.getTextRect = function (t) { for ( var e = { text: t, verticalAlign: this.getShallow("verticalAlign") || this.getShallow("baseline"), }, n = 0; n < mc.length; n++ ) e[mc[n]] = this.getShallow(mc[n]); return xc.useStyle(e), xc.update(), xc.getBoundingRect(); }), t ); })(), bc = [ ["lineWidth", "width"], ["stroke", "color"], ["opacity"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"], ["lineDash", "type"], ["lineDashOffset", "dashOffset"], ["lineCap", "cap"], ["lineJoin", "join"], ["miterLimit"], ], wc = ia(bc), Sc = (function () { function t() {} return ( (t.prototype.getLineStyle = function (t) { return wc(this, t); }), t ); })(), Mc = [ ["fill", "color"], ["stroke", "borderColor"], ["lineWidth", "borderWidth"], ["opacity"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"], ["lineDash", "borderType"], ["lineDashOffset", "borderDashOffset"], ["lineCap", "borderCap"], ["lineJoin", "borderJoin"], ["miterLimit", "borderMiterLimit"], ], Ic = ia(Mc), Tc = (function () { function t() {} return ( (t.prototype.getItemStyle = function (t, e) { return Ic(this, t, e); }), t ); })(), Cc = (function () { function t(t, e, n) { (this.parentModel = e), (this.ecModel = n), (this.option = t); } return ( (t.prototype.init = function (t, e, n) { for (var i = [], r = 3; r < arguments.length; r++) i[r - 3] = arguments[r]; }), (t.prototype.mergeOption = function (t, e) { C(this.option, t, !0); }), (t.prototype.get = function (t, e) { return null == t ? this.option : this._doGet( this.parsePath(t), !e && this.parentModel ); }), (t.prototype.getShallow = function (t, e) { var n = this.option, i = null == n ? n : n[t]; if (null == i && !e) { var r = this.parentModel; r && (i = r.getShallow(t)); } return i; }), (t.prototype.getModel = function (e, n) { var i = null != e, r = i ? this.parsePath(e) : null; return new t( i ? this._doGet(r) : this.option, (n = n || (this.parentModel && this.parentModel.getModel( this.resolveParentPath(r) ))), this.ecModel ); }), (t.prototype.isEmpty = function () { return null == this.option; }), (t.prototype.restoreData = function () {}), (t.prototype.clone = function () { return new (0, this.constructor)(T(this.option)); }), (t.prototype.parsePath = function (t) { return "string" == typeof t ? t.split(".") : t; }), (t.prototype.resolveParentPath = function (t) { return t; }), (t.prototype.isAnimationEnabled = function () { if (!r.node && this.option) { if (null != this.option.animation) return !!this.option.animation; if (this.parentModel) return this.parentModel.isAnimationEnabled(); } }), (t.prototype._doGet = function (t, e) { var n = this.option; if (!t) return n; for ( var i = 0; i < t.length && (!t[i] || null != (n = n && "object" == typeof n ? n[t[i]] : null)); i++ ); return ( null == n && e && (n = e._doGet( this.resolveParentPath(t), e.parentModel )), n ); }), t ); })(); $o(Cc), (gc = Cc), (yc = ["__\0is_clz", Qo++].join("_")), (gc.prototype[yc] = !0), (gc.isInstance = function (t) { return !(!t || !t[yc]); }), R(Cc, Sc), R(Cc, Tc), R(Cc, oa), R(Cc, _c); var Dc = Math.round(10 * Math.random()); function Ac(t) { return [t || "", Dc++].join("_"); } function kc(t, e) { return C(C({}, t, !0), e, !0); } var Lc = "ZH", Pc = "EN", Oc = Pc, Rc = {}, Nc = {}, Ec = r.domSupported && ( document.documentElement.lang || navigator.language || navigator.browserLanguage || Oc ) .toUpperCase() .indexOf(Lc) > -1 ? Lc : Oc; function zc(t, e) { (t = t.toUpperCase()), (Nc[t] = new Cc(e)), (Rc[t] = e); } function Vc(t) { return Nc[t]; } zc(Pc, { time: { month: [ "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December", ], monthAbbr: [ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec", ], dayOfWeek: [ "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday", ], dayOfWeekAbbr: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"], }, legend: { selector: { all: "All", inverse: "Inv" } }, toolbox: { brush: { title: { rect: "Box Select", polygon: "Lasso Select", lineX: "Horizontally Select", lineY: "Vertically Select", keep: "Keep Selections", clear: "Clear Selections", }, }, dataView: { title: "Data View", lang: ["Data View", "Close", "Refresh"], }, dataZoom: { title: { zoom: "Zoom", back: "Zoom Reset" } }, magicType: { title: { line: "Switch to Line Chart", bar: "Switch to Bar Chart", stack: "Stack", tiled: "Tile", }, }, restore: { title: "Restore" }, saveAsImage: { title: "Save as Image", lang: ["Right Click to Save Image"], }, }, series: { typeNames: { pie: "Pie chart", bar: "Bar chart", line: "Line chart", scatter: "Scatter plot", effectScatter: "Ripple scatter plot", radar: "Radar chart", tree: "Tree", treemap: "Treemap", boxplot: "Boxplot", candlestick: "Candlestick", k: "K line chart", heatmap: "Heat map", map: "Map", parallel: "Parallel coordinate map", lines: "Line graph", graph: "Relationship graph", sankey: "Sankey diagram", funnel: "Funnel chart", gauge: "Gauge", pictorialBar: "Pictorial bar", themeRiver: "Theme River Map", sunburst: "Sunburst", custom: "Custom chart", chart: "Chart", }, }, aria: { general: { withTitle: 'This is a chart about "{title}"', withoutTitle: "This is a chart", }, series: { single: { prefix: "", withName: " with type {seriesType} named {seriesName}.", withoutName: " with type {seriesType}.", }, multiple: { prefix: ". It consists of {seriesCount} series count.", withName: " The {seriesId} series is a {seriesType} representing {seriesName}.", withoutName: " The {seriesId} series is a {seriesType}.", separator: { middle: "", end: "" }, }, }, data: { allData: "The data is as follows: ", partialData: "The first {displayCnt} items are: ", withName: "the data for {name} is {value}", withoutName: "{value}", separator: { middle: ", ", end: ". " }, }, }, }), zc(Lc, { time: { month: [ "一月", "二月", "三月", "四月", "五月", "六月", "七月", "八月", "九月", "十月", "十一月", "十二月", ], monthAbbr: [ "1月", "2月", "3月", "4月", "5月", "6月", "7月", "8月", "9月", "10月", "11月", "12月", ], dayOfWeek: [ "星期日", "星期一", "星期二", "星期三", "星期四", "星期五", "星期六", ], dayOfWeekAbbr: ["日", "一", "二", "三", "四", "五", "六"], }, legend: { selector: { all: "全选", inverse: "反选" } }, toolbox: { brush: { title: { rect: "矩形选择", polygon: "圈选", lineX: "横向选择", lineY: "纵向选择", keep: "保持选择", clear: "清除选择", }, }, dataView: { title: "数据视图", lang: ["数据视图", "关闭", "刷新"], }, dataZoom: { title: { zoom: "区域缩放", back: "区域缩放还原" } }, magicType: { title: { line: "切换为折线图", bar: "切换为柱状图", stack: "切换为堆叠", tiled: "切换为平铺", }, }, restore: { title: "还原" }, saveAsImage: { title: "保存为图片", lang: ["右键另存为图片"] }, }, series: { typeNames: { pie: "饼图", bar: "柱状图", line: "折线图", scatter: "散点图", effectScatter: "涟漪散点图", radar: "雷达图", tree: "树图", treemap: "矩形树图", boxplot: "箱型图", candlestick: "K线图", k: "K线图", heatmap: "热力图", map: "地图", parallel: "平行坐标图", lines: "线图", graph: "关系图", sankey: "桑基图", funnel: "漏斗图", gauge: "仪表盘图", pictorialBar: "象形柱图", themeRiver: "主题河流图", sunburst: "旭日图", custom: "自定义图表", chart: "图表", }, }, aria: { general: { withTitle: "这是一个关于“{title}”的图表。", withoutTitle: "这是一个图表,", }, series: { single: { prefix: "", withName: "图表类型是{seriesType},表示{seriesName}。", withoutName: "图表类型是{seriesType}。", }, multiple: { prefix: "它由{seriesCount}个图表系列组成。", withName: "第{seriesId}个系列是一个表示{seriesName}的{seriesType},", withoutName: "第{seriesId}个系列是一个{seriesType},", separator: { middle: ";", end: "。" }, }, }, data: { allData: "其数据是——", partialData: "其中,前{displayCnt}项是——", withName: "{name}的数据是{value}", withoutName: "{value}", separator: { middle: ",", end: "" }, }, }, }); var Bc = 1e3, Fc = 6e4, Gc = 36e5, Wc = 864e5, Hc = 31536e6, Yc = { year: "{yyyy}", month: "{MMM}", day: "{d}", hour: "{HH}:{mm}", minute: "{HH}:{mm}", second: "{HH}:{mm}:{ss}", millisecond: "{HH}:{mm}:{ss} {SSS}", none: "{yyyy}-{MM}-{dd} {HH}:{mm}:{ss} {SSS}", }, Xc = "{yyyy}-{MM}-{dd}", Uc = { year: "{yyyy}", month: "{yyyy}-{MM}", day: Xc, hour: Xc + " " + Yc.hour, minute: Xc + " " + Yc.minute, second: Xc + " " + Yc.second, millisecond: Yc.none, }, Zc = [ "year", "month", "day", "hour", "minute", "second", "millisecond", ], jc = [ "year", "half-year", "quarter", "month", "week", "half-week", "day", "half-day", "quarter-day", "hour", "minute", "second", "millisecond", ]; function qc(t, e) { return "0000".substr(0, e - (t += "").length) + t; } function Kc(t) { switch (t) { case "half-year": case "quarter": return "month"; case "week": case "half-week": return "day"; case "half-day": case "quarter-day": return "hour"; default: return t; } } function $c(t) { return t === Kc(t); } function Jc(t, e, n, i) { var r = uo(t), o = r[ep(n)](), a = r[np(n)]() + 1, s = Math.floor((a - 1) / 3) + 1, l = r[ip(n)](), u = r["get" + (n ? "UTC" : "") + "Day"](), h = r[rp(n)](), c = ((h - 1) % 12) + 1, p = r[op(n)](), d = r[ap(n)](), f = r[sp(n)](), g = h >= 12 ? "pm" : "am", y = g.toUpperCase(), v = (i instanceof Cc ? i : Vc(i || Ec) || Nc[Oc]).getModel("time"), m = v.get("month"), x = v.get("monthAbbr"), _ = v.get("dayOfWeek"), b = v.get("dayOfWeekAbbr"); return (e || "") .replace(/{a}/g, g + "") .replace(/{A}/g, y + "") .replace(/{yyyy}/g, o + "") .replace(/{yy}/g, qc((o % 100) + "", 2)) .replace(/{Q}/g, s + "") .replace(/{MMMM}/g, m[a - 1]) .replace(/{MMM}/g, x[a - 1]) .replace(/{MM}/g, qc(a, 2)) .replace(/{M}/g, a + "") .replace(/{dd}/g, qc(l, 2)) .replace(/{d}/g, l + "") .replace(/{eeee}/g, _[u]) .replace(/{ee}/g, b[u]) .replace(/{e}/g, u + "") .replace(/{HH}/g, qc(h, 2)) .replace(/{H}/g, h + "") .replace(/{hh}/g, qc(c + "", 2)) .replace(/{h}/g, c + "") .replace(/{mm}/g, qc(p, 2)) .replace(/{m}/g, p + "") .replace(/{ss}/g, qc(d, 2)) .replace(/{s}/g, d + "") .replace(/{SSS}/g, qc(f, 3)) .replace(/{S}/g, f + ""); } function Qc(t, e) { var n = uo(t), i = n[np(e)]() + 1, r = n[ip(e)](), o = n[rp(e)](), a = n[op(e)](), s = n[ap(e)](), l = 0 === n[sp(e)](), u = l && 0 === s, h = u && 0 === a, c = h && 0 === o, p = c && 1 === r; return p && 1 === i ? "year" : p ? "month" : c ? "day" : h ? "hour" : u ? "minute" : l ? "second" : "millisecond"; } function tp(t, e, n) { var i = j(t) ? uo(t) : t; switch ((e = e || Qc(t, n))) { case "year": return i[ep(n)](); case "half-year": return i[np(n)]() >= 6 ? 1 : 0; case "quarter": return Math.floor((i[np(n)]() + 1) / 4); case "month": return i[np(n)](); case "day": return i[ip(n)](); case "half-day": return i[rp(n)]() / 24; case "hour": return i[rp(n)](); case "minute": return i[op(n)](); case "second": return i[ap(n)](); case "millisecond": return i[sp(n)](); } } function ep(t) { return t ? "getUTCFullYear" : "getFullYear"; } function np(t) { return t ? "getUTCMonth" : "getMonth"; } function ip(t) { return t ? "getUTCDate" : "getDate"; } function rp(t) { return t ? "getUTCHours" : "getHours"; } function op(t) { return t ? "getUTCMinutes" : "getMinutes"; } function ap(t) { return t ? "getUTCSeconds" : "getSeconds"; } function sp(t) { return t ? "getUTCMilliseconds" : "getMilliseconds"; } function lp(t) { return t ? "setUTCFullYear" : "setFullYear"; } function up(t) { return t ? "setUTCMonth" : "setMonth"; } function hp(t) { return t ? "setUTCDate" : "setDate"; } function cp(t) { return t ? "setUTCHours" : "setHours"; } function pp(t) { return t ? "setUTCMinutes" : "setMinutes"; } function dp(t) { return t ? "setUTCSeconds" : "setSeconds"; } function fp(t) { return t ? "setUTCMilliseconds" : "setMilliseconds"; } function gp(t) { if (!vo(t)) return U(t) ? t : "-"; var e = (t + "").split("."); return ( e[0].replace(/(\d{1,3})(?=(?:\d{3})+(?!\d))/g, "$1,") + (e.length > 1 ? "." + e[1] : "") ); } function yp(t, e) { return ( (t = (t || "").toLowerCase().replace(/-(.)/g, function (t, e) { return e.toUpperCase(); })), e && t && (t = t.charAt(0).toUpperCase() + t.slice(1)), t ); } var vp = st; function mp(t, e, n) { function i(t) { return t && ut(t) ? t : "-"; } function r(t) { return !(null == t || isNaN(t) || !isFinite(t)); } var o = "time" === e, a = t instanceof Date; if (o || a) { var s = o ? uo(t) : t; if (!isNaN(+s)) return Jc(s, "{yyyy}-{MM}-{dd} {HH}:{mm}:{ss}", n); if (a) return "-"; } if ("ordinal" === e) return Z(t) ? i(t) : j(t) && r(t) ? t + "" : "-"; var l = yo(t); return r(l) ? gp(l) : Z(t) ? i(t) : "boolean" == typeof t ? t + "" : "-"; } var xp = ["a", "b", "c", "d", "e", "f", "g"], _p = function (t, e) { return "{" + t + (null == e ? "" : e) + "}"; }; function bp(t, e, n) { Y(e) || (e = [e]); var i = e.length; if (!i) return ""; for (var r = e[0].$vars || [], o = 0; o < r.length; o++) { var a = xp[o]; t = t.replace(_p(a), _p(a, 0)); } for (var s = 0; s < i; s++) for (var l = 0; l < r.length; l++) { var u = e[s][r[l]]; t = t.replace(_p(xp[l], s), n ? re(u) : u); } return t; } function wp(t, e) { var n = U(t) ? { color: t, extraCssText: e } : t || {}, i = n.color, r = n.type; e = n.extraCssText; var o = n.renderMode || "html"; return i ? "html" === o ? "subItem" === r ? '' : '' : { renderMode: o, content: "{" + (n.markerId || "markerX") + "|} ", style: "subItem" === r ? { width: 4, height: 4, borderRadius: 2, backgroundColor: i, } : { width: 10, height: 10, borderRadius: 5, backgroundColor: i, }, } : ""; } function Sp(t, e) { return ( (e = e || "transparent"), U(t) ? t : (q(t) && t.colorStops && (t.colorStops[0] || {}).color) || e ); } function Mp(t, e) { if ("_blank" === e || "blank" === e) { var n = window.open(); (n.opener = null), (n.location.href = t); } else window.open(t, e); } var Ip = E, Tp = ["left", "right", "top", "bottom", "width", "height"], Cp = [ ["width", "left", "right"], ["height", "top", "bottom"], ]; function Dp(t, e, n, i, r) { var o = 0, a = 0; null == i && (i = 1 / 0), null == r && (r = 1 / 0); var s = 0; e.eachChild(function (l, u) { var h, c, p = l.getBoundingRect(), d = e.childAt(u + 1), f = d && d.getBoundingRect(); if ("horizontal" === t) { var g = p.width + (f ? -f.x + p.x : 0); (h = o + g) > i || l.newline ? ((o = 0), (h = g), (a += s + n), (s = p.height)) : (s = Math.max(s, p.height)); } else { var y = p.height + (f ? -f.y + p.y : 0); (c = a + y) > r || l.newline ? ((o += s + n), (a = 0), (c = y), (s = p.width)) : (s = Math.max(s, p.width)); } l.newline || ((l.x = o), (l.y = a), l.markRedraw(), "horizontal" === t ? (o = h + n) : (a = c + n)); }); } var Ap = Dp; H(Dp, "vertical"), H(Dp, "horizontal"); function kp(t, e, n) { n = vp(n || 0); var i = e.width, r = e.height, o = $r(t.left, i), a = $r(t.top, r), s = $r(t.right, i), l = $r(t.bottom, r), u = $r(t.width, i), h = $r(t.height, r), c = n[2] + n[0], p = n[1] + n[3], d = t.aspect; switch ( (isNaN(u) && (u = i - s - p - o), isNaN(h) && (h = r - l - c - a), null != d && (isNaN(u) && isNaN(h) && (d > i / r ? (u = 0.8 * i) : (h = 0.8 * r)), isNaN(u) && (u = d * h), isNaN(h) && (h = u / d)), isNaN(o) && (o = i - s - u - p), isNaN(a) && (a = r - l - h - c), t.left || t.right) ) { case "center": o = i / 2 - u / 2 - n[3]; break; case "right": o = i - u - p; } switch (t.top || t.bottom) { case "middle": case "center": a = r / 2 - h / 2 - n[0]; break; case "bottom": a = r - h - c; } (o = o || 0), (a = a || 0), isNaN(u) && (u = i - p - o - (s || 0)), isNaN(h) && (h = r - c - a - (l || 0)); var f = new ze(o + n[3], a + n[0], u, h); return (f.margin = n), f; } function Lp(t, e, n, i, r, o) { var a, s = !r || !r.hv || r.hv[0], l = !r || !r.hv || r.hv[1], u = (r && r.boundingMode) || "all"; if ((((o = o || t).x = t.x), (o.y = t.y), !s && !l)) return !1; if ("raw" === u) a = "group" === t.type ? new ze(0, 0, +e.width || 0, +e.height || 0) : t.getBoundingRect(); else if (((a = t.getBoundingRect()), t.needLocalTransform())) { var h = t.getLocalTransform(); (a = a.clone()).applyTransform(h); } var c = kp(k({ width: a.width, height: a.height }, e), n, i), p = s ? c.x - a.x : 0, d = l ? c.y - a.y : 0; return ( "raw" === u ? ((o.x = p), (o.y = d)) : ((o.x += p), (o.y += d)), o === t && t.markRedraw(), !0 ); } function Pp(t) { var e = t.layoutMode || t.constructor.layoutMode; return q(e) ? e : e ? { type: e } : null; } function Op(t, e, n) { var i = n && n.ignoreSize; !Y(i) && (i = [i, i]); var r = a(Cp[0], 0), o = a(Cp[1], 1); function a(n, r) { var o = {}, a = 0, u = {}, h = 0; if ( (Ip(n, function (e) { u[e] = t[e]; }), Ip(n, function (t) { s(e, t) && (o[t] = u[t] = e[t]), l(o, t) && a++, l(u, t) && h++; }), i[r]) ) return ( l(e, n[1]) ? (u[n[2]] = null) : l(e, n[2]) && (u[n[1]] = null), u ); if (2 !== h && a) { if (a >= 2) return o; for (var c = 0; c < n.length; c++) { var p = n[c]; if (!s(o, p) && s(t, p)) { o[p] = t[p]; break; } } return o; } return u; } function s(t, e) { return t.hasOwnProperty(e); } function l(t, e) { return null != t[e] && "auto" !== t[e]; } function u(t, e, n) { Ip(t, function (t) { e[t] = n[t]; }); } u(Cp[0], t, r), u(Cp[1], t, o); } function Rp(t) { return Np({}, t); } function Np(t, e) { return ( e && t && Ip(Tp, function (n) { e.hasOwnProperty(n) && (t[n] = e[n]); }), t ); } var Ep = Vo(), zp = (function (t) { function e(e, n, i) { var r = t.call(this, e, n, i) || this; return (r.uid = Ac("ec_cpt_model")), r; } return ( n(e, t), (e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n); }), (e.prototype.mergeDefaultAndTheme = function (t, e) { var n = Pp(this), i = n ? Rp(t) : {}; C(t, e.getTheme().get(this.mainType)), C(t, this.getDefaultOption()), n && Op(t, i, n); }), (e.prototype.mergeOption = function (t, e) { C(this.option, t, !0); var n = Pp(this); n && Op(this.option, t, n); }), (e.prototype.optionUpdated = function (t, e) {}), (e.prototype.getDefaultOption = function () { var t = this.constructor; if ( !(function (t) { return !(!t || !t[qo]); })(t) ) return t.defaultOption; var e = Ep(this); if (!e.defaultOption) { for (var n = [], i = t; i; ) { var r = i.prototype.defaultOption; r && n.push(r), (i = i.superClass); } for (var o = {}, a = n.length - 1; a >= 0; a--) o = C(o, n[a], !0); e.defaultOption = o; } return e.defaultOption; }), (e.prototype.getReferringComponents = function (t, e) { var n = t + "Index", i = t + "Id"; return Yo( this.ecModel, t, { index: this.get(n, !0), id: this.get(i, !0) }, e ); }), (e.prototype.getBoxLayoutParams = function () { var t = this; return { left: t.get("left"), top: t.get("top"), right: t.get("right"), bottom: t.get("bottom"), width: t.get("width"), height: t.get("height"), }; }), (e.prototype.getZLevelKey = function () { return ""; }), (e.prototype.setZLevel = function (t) { this.option.zlevel = t; }), (e.protoInitialize = (function () { var t = e.prototype; (t.type = "component"), (t.id = ""), (t.name = ""), (t.mainType = ""), (t.subType = ""), (t.componentIndex = 0); })()), e ); })(Cc); Jo(zp, Cc), na(zp), (function (t) { var e = {}; (t.registerSubTypeDefaulter = function (t, n) { var i = Ko(t); e[i.main] = n; }), (t.determineSubType = function (n, i) { var r = i.type; if (!r) { var o = Ko(n).main; t.hasSubTypes(n) && e[o] && (r = e[o](i)); } return r; }); })(zp), (function (t, e) { function n(t, e) { return ( t[e] || (t[e] = { predecessor: [], successor: [] }), t[e] ); } t.topologicalTravel = function (t, i, r, o) { if (t.length) { var a = (function (t) { var i = {}, r = []; return ( E(t, function (o) { var a = n(i, o), s = (function (t, e) { var n = []; return ( E(t, function (t) { P(e, t) >= 0 && n.push(t); }), n ); })((a.originalDeps = e(o)), t); (a.entryCount = s.length), 0 === a.entryCount && r.push(o), E(s, function (t) { P(a.predecessor, t) < 0 && a.predecessor.push(t); var e = n(i, t); P(e.successor, t) < 0 && e.successor.push(o); }); }), { graph: i, noEntryList: r } ); })(i), s = a.graph, l = a.noEntryList, u = {}; for ( E(t, function (t) { u[t] = !0; }); l.length; ) { var h = l.pop(), c = s[h], p = !!u[h]; p && (r.call(o, h, c.originalDeps.slice()), delete u[h]), E(c.successor, p ? f : d); } E(u, function () { var t = ""; throw new Error(t); }); } function d(t) { s[t].entryCount--, 0 === s[t].entryCount && l.push(t); } function f(t) { (u[t] = !0), d(t); } }; })(zp, function (t) { var e = []; E(zp.getClassesByMainType(t), function (t) { e = e.concat(t.dependencies || t.prototype.dependencies || []); }), (e = z(e, function (t) { return Ko(t).main; })), "dataset" !== t && P(e, "dataset") <= 0 && e.unshift("dataset"); return e; }); var Vp = ""; "undefined" != typeof navigator && (Vp = navigator.platform || ""); var Bp = "rgba(0, 0, 0, 0.2)", Fp = { darkMode: "auto", colorBy: "series", color: [ "#5470c6", "#91cc75", "#fac858", "#ee6666", "#73c0de", "#3ba272", "#fc8452", "#9a60b4", "#ea7ccc", ], gradientColor: ["#f6efa6", "#d88273", "#bf444c"], aria: { decal: { decals: [ { color: Bp, dashArrayX: [1, 0], dashArrayY: [2, 5], symbolSize: 1, rotation: Math.PI / 6, }, { color: Bp, symbol: "circle", dashArrayX: [ [8, 8], [0, 8, 8, 0], ], dashArrayY: [6, 0], symbolSize: 0.8, }, { color: Bp, dashArrayX: [1, 0], dashArrayY: [4, 3], rotation: -Math.PI / 4, }, { color: Bp, dashArrayX: [ [6, 6], [0, 6, 6, 0], ], dashArrayY: [6, 0], }, { color: Bp, dashArrayX: [ [1, 0], [1, 6], ], dashArrayY: [1, 0, 6, 0], rotation: Math.PI / 4, }, { color: Bp, symbol: "triangle", dashArrayX: [ [9, 9], [0, 9, 9, 0], ], dashArrayY: [7, 2], symbolSize: 0.75, }, ], }, }, textStyle: { fontFamily: Vp.match(/^Win/) ? "Microsoft YaHei" : "sans-serif", fontSize: 12, fontStyle: "normal", fontWeight: "normal", }, blendMode: null, stateAnimation: { duration: 300, easing: "cubicOut" }, animation: "auto", animationDuration: 1e3, animationDurationUpdate: 500, animationEasing: "cubicInOut", animationEasingUpdate: "cubicInOut", animationThreshold: 2e3, progressiveThreshold: 3e3, progressive: 400, hoverLayerThreshold: 3e3, useUTC: !1, }, Gp = yt([ "tooltip", "label", "itemName", "itemId", "itemGroupId", "itemChildGroupId", "seriesName", ]), Wp = "original", Hp = "arrayRows", Yp = "objectRows", Xp = "keyedColumns", Up = "typedArray", Zp = "unknown", jp = "column", qp = "row", Kp = 1, $p = 2, Jp = 3, Qp = Vo(); function td(t, e, n) { var i = {}, r = nd(e); if (!r || !t) return i; var o, a, s = [], l = [], u = e.ecModel, h = Qp(u).datasetMap, c = r.uid + "_" + n.seriesLayoutBy; E((t = t.slice()), function (e, n) { var r = q(e) ? e : (t[n] = { name: e }); "ordinal" === r.type && null == o && ((o = n), (a = f(r))), (i[r.name] = []); }); var p = h.get(c) || h.set(c, { categoryWayDim: a, valueWayDim: 0 }); function d(t, e, n) { for (var i = 0; i < n; i++) t.push(e + i); } function f(t) { var e = t.dimsDef; return e ? e.length : 1; } return ( E(t, function (t, e) { var n = t.name, r = f(t); if (null == o) { var a = p.valueWayDim; d(i[n], a, r), d(l, a, r), (p.valueWayDim += r); } else if (o === e) d(i[n], 0, r), d(s, 0, r); else { a = p.categoryWayDim; d(i[n], a, r), d(l, a, r), (p.categoryWayDim += r); } }), s.length && (i.itemName = s), l.length && (i.seriesName = l), i ); } function ed(t, e, n) { var i = {}; if (!nd(t)) return i; var r, o = e.sourceFormat, a = e.dimensionsDefine; (o !== Yp && o !== Xp) || E(a, function (t, e) { "name" === (q(t) ? t.name : t) && (r = e); }); var s = (function () { for ( var t = {}, i = {}, s = [], l = 0, u = Math.min(5, n); l < u; l++ ) { var h = rd(e.data, o, e.seriesLayoutBy, a, e.startIndex, l); s.push(h); var c = h === Jp; if ( (c && null == t.v && l !== r && (t.v = l), (null == t.n || t.n === t.v || (!c && s[t.n] === Jp)) && (t.n = l), p(t) && s[t.n] !== Jp) ) return t; c || (h === $p && null == i.v && l !== r && (i.v = l), (null != i.n && i.n !== i.v) || (i.n = l)); } function p(t) { return null != t.v && null != t.n; } return p(t) ? t : p(i) ? i : null; })(); if (s) { i.value = [s.v]; var l = null != r ? r : s.n; (i.itemName = [l]), (i.seriesName = [l]); } return i; } function nd(t) { if (!t.get("data", !0)) return Yo( t.ecModel, "dataset", { index: t.get("datasetIndex", !0), id: t.get("datasetId", !0), }, Wo ).models[0]; } function id(t, e) { return rd( t.data, t.sourceFormat, t.seriesLayoutBy, t.dimensionsDefine, t.startIndex, e ); } function rd(t, e, n, i, r, o) { var a, s, l; if ($(t)) return Jp; if (i) { var u = i[o]; q(u) ? ((s = u.name), (l = u.type)) : U(u) && (s = u); } if (null != l) return "ordinal" === l ? Kp : Jp; if (e === Hp) { var h = t; if (n === qp) { for (var c = h[o], p = 0; p < (c || []).length && p < 5; p++) if (null != (a = m(c[r + p]))) return a; } else for (p = 0; p < h.length && p < 5; p++) { var d = h[r + p]; if (d && null != (a = m(d[o]))) return a; } } else if (e === Yp) { var f = t; if (!s) return Jp; for (p = 0; p < f.length && p < 5; p++) { if ((y = f[p]) && null != (a = m(y[s]))) return a; } } else if (e === Xp) { if (!s) return Jp; if (!(c = t[s]) || $(c)) return Jp; for (p = 0; p < c.length && p < 5; p++) if (null != (a = m(c[p]))) return a; } else if (e === Wp) { var g = t; for (p = 0; p < g.length && p < 5; p++) { var y, v = Ao((y = g[p])); if (!Y(v)) return Jp; if (null != (a = m(v[o]))) return a; } } function m(t) { var e = U(t); return null != t && Number.isFinite(Number(t)) && "" !== t ? e ? $p : Jp : e && "-" !== t ? Kp : void 0; } return Jp; } var od = yt(); var ad, sd, ld, ud = Vo(), hd = Vo(), cd = (function () { function t() {} return ( (t.prototype.getColorFromPalette = function (t, e, n) { var i = To(this.get("color", !0)), r = this.get("colorLayer", !0); return dd(this, ud, i, r, t, e, n); }), (t.prototype.clearColorPalette = function () { !(function (t, e) { (e(t).paletteIdx = 0), (e(t).paletteNameMap = {}); })(this, ud); }), t ); })(); function pd(t, e, n, i) { var r = To(t.get(["aria", "decal", "decals"])); return dd(t, hd, r, null, e, n, i); } function dd(t, e, n, i, r, o, a) { var s = e((o = o || t)), l = s.paletteIdx || 0, u = (s.paletteNameMap = s.paletteNameMap || {}); if (u.hasOwnProperty(r)) return u[r]; var h = null != a && i ? (function (t, e) { for (var n = t.length, i = 0; i < n; i++) if (t[i].length > e) return t[i]; return t[n - 1]; })(i, a) : n; if ((h = h || n) && h.length) { var c = h[l]; return r && (u[r] = c), (s.paletteIdx = (l + 1) % h.length), c; } } var fd = "\0_ec_inner"; var gd = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.init = function (t, e, n, i, r, o) { (i = i || {}), (this.option = null), (this._theme = new Cc(i)), (this._locale = new Cc(r)), (this._optionManager = o); }), (e.prototype.setOption = function (t, e, n) { var i = md(e); this._optionManager.setOption(t, n, i), this._resetOption(null, i); }), (e.prototype.resetOption = function (t, e) { return this._resetOption(t, md(e)); }), (e.prototype._resetOption = function (t, e) { var n = !1, i = this._optionManager; if (!t || "recreate" === t) { var r = i.mountOption("recreate" === t); 0, this.option && "recreate" !== t ? (this.restoreData(), this._mergeOption(r, e)) : ld(this, r), (n = !0); } if ( (("timeline" !== t && "media" !== t) || this.restoreData(), !t || "recreate" === t || "timeline" === t) ) { var o = i.getTimelineOption(this); o && ((n = !0), this._mergeOption(o, e)); } if (!t || "recreate" === t || "media" === t) { var a = i.getMediaOption(this); a.length && E( a, function (t) { (n = !0), this._mergeOption(t, e); }, this ); } return n; }), (e.prototype.mergeOption = function (t) { this._mergeOption(t, null); }), (e.prototype._mergeOption = function (t, e) { var n = this.option, i = this._componentsMap, r = this._componentsCount, o = [], a = yt(), s = e && e.replaceMergeMainTypeMap; (Qp(this).datasetMap = yt()), E(t, function (t, e) { null != t && (zp.hasClass(e) ? e && (o.push(e), a.set(e, !0)) : (n[e] = null == n[e] ? T(t) : C(n[e], t, !0))); }), s && s.each(function (t, e) { zp.hasClass(e) && !a.get(e) && (o.push(e), a.set(e, !0)); }), zp.topologicalTravel( o, zp.getAllClassMainTypes(), function (e) { var o = (function (t, e, n) { var i = od.get(e); if (!i) return n; var r = i(t); return r ? n.concat(r) : n; })(this, e, To(t[e])), a = i.get(e), l = a ? s && s.get(e) ? "replaceMerge" : "normalMerge" : "replaceAll", u = Lo(a, o, l); (function (t, e, n) { E(t, function (t) { var i = t.newOption; q(i) && ((t.keyInfo.mainType = e), (t.keyInfo.subType = (function ( t, e, n, i ) { return e.type ? e.type : n ? n.subType : i.determineSubType(t, e); })(e, i, t.existing, n))); }); })(u, e, zp), (n[e] = null), i.set(e, null), r.set(e, 0); var h, c = [], p = [], d = 0; E( u, function (t, n) { var i = t.existing, r = t.newOption; if (r) { var o = "series" === e, a = zp.getClass( e, t.keyInfo.subType, !o ); if (!a) return; if ("tooltip" === e) { if (h) return void 0; h = !0; } if (i && i.constructor === a) (i.name = t.keyInfo.name), i.mergeOption(r, this), i.optionUpdated(r, !1); else { var s = A( { componentIndex: n }, t.keyInfo ); A((i = new a(r, this, this, s)), s), t.brandNew && (i.__requireNewView = !0), i.init(r, this, this), i.optionUpdated(null, !0); } } else i && (i.mergeOption({}, this), i.optionUpdated({}, !1)); i ? (c.push(i.option), p.push(i), d++) : (c.push(void 0), p.push(void 0)); }, this ), (n[e] = c), i.set(e, p), r.set(e, d), "series" === e && ad(this); }, this ), this._seriesIndices || ad(this); }), (e.prototype.getOption = function () { var t = T(this.option); return ( E(t, function (e, n) { if (zp.hasClass(n)) { for ( var i = To(e), r = i.length, o = !1, a = r - 1; a >= 0; a-- ) i[a] && !Eo(i[a]) ? (o = !0) : ((i[a] = null), !o && r--); (i.length = r), (t[n] = i); } }), delete t[fd], t ); }), (e.prototype.getTheme = function () { return this._theme; }), (e.prototype.getLocaleModel = function () { return this._locale; }), (e.prototype.setUpdatePayload = function (t) { this._payload = t; }), (e.prototype.getUpdatePayload = function () { return this._payload; }), (e.prototype.getComponent = function (t, e) { var n = this._componentsMap.get(t); if (n) { var i = n[e || 0]; if (i) return i; if (null == e) for (var r = 0; r < n.length; r++) if (n[r]) return n[r]; } }), (e.prototype.queryComponents = function (t) { var e = t.mainType; if (!e) return []; var n, i = t.index, r = t.id, o = t.name, a = this._componentsMap.get(e); return a && a.length ? (null != i ? ((n = []), E(To(i), function (t) { a[t] && n.push(a[t]); })) : (n = null != r ? yd("id", r, a) : null != o ? yd("name", o, a) : B(a, function (t) { return !!t; })), vd(n, t)) : []; }), (e.prototype.findComponents = function (t) { var e, n, i, r, o, a = t.query, s = t.mainType, l = ((n = s + "Index"), (i = s + "Id"), (r = s + "Name"), !(e = a) || (null == e[n] && null == e[i] && null == e[r]) ? null : { mainType: s, index: e[n], id: e[i], name: e[r], }), u = l ? this.queryComponents(l) : B(this._componentsMap.get(s), function (t) { return !!t; }); return (o = vd(u, t)), t.filter ? B(o, t.filter) : o; }), (e.prototype.eachComponent = function (t, e, n) { var i = this._componentsMap; if (X(t)) { var r = e, o = t; i.each(function (t, e) { for (var n = 0; t && n < t.length; n++) { var i = t[n]; i && o.call(r, e, i, i.componentIndex); } }); } else for ( var a = U(t) ? i.get(t) : q(t) ? this.findComponents(t) : null, s = 0; a && s < a.length; s++ ) { var l = a[s]; l && e.call(n, l, l.componentIndex); } }), (e.prototype.getSeriesByName = function (t) { var e = Ro(t, null); return B(this._componentsMap.get("series"), function (t) { return !!t && null != e && t.name === e; }); }), (e.prototype.getSeriesByIndex = function (t) { return this._componentsMap.get("series")[t]; }), (e.prototype.getSeriesByType = function (t) { return B(this._componentsMap.get("series"), function (e) { return !!e && e.subType === t; }); }), (e.prototype.getSeries = function () { return B(this._componentsMap.get("series"), function (t) { return !!t; }); }), (e.prototype.getSeriesCount = function () { return this._componentsCount.get("series"); }), (e.prototype.eachSeries = function (t, e) { sd(this), E( this._seriesIndices, function (n) { var i = this._componentsMap.get("series")[n]; t.call(e, i, n); }, this ); }), (e.prototype.eachRawSeries = function (t, e) { E(this._componentsMap.get("series"), function (n) { n && t.call(e, n, n.componentIndex); }); }), (e.prototype.eachSeriesByType = function (t, e, n) { sd(this), E( this._seriesIndices, function (i) { var r = this._componentsMap.get("series")[i]; r.subType === t && e.call(n, r, i); }, this ); }), (e.prototype.eachRawSeriesByType = function (t, e, n) { return E(this.getSeriesByType(t), e, n); }), (e.prototype.isSeriesFiltered = function (t) { return ( sd(this), null == this._seriesIndicesMap.get(t.componentIndex) ); }), (e.prototype.getCurrentSeriesIndices = function () { return (this._seriesIndices || []).slice(); }), (e.prototype.filterSeries = function (t, e) { sd(this); var n = []; E( this._seriesIndices, function (i) { var r = this._componentsMap.get("series")[i]; t.call(e, r, i) && n.push(i); }, this ), (this._seriesIndices = n), (this._seriesIndicesMap = yt(n)); }), (e.prototype.restoreData = function (t) { ad(this); var e = this._componentsMap, n = []; e.each(function (t, e) { zp.hasClass(e) && n.push(e); }), zp.topologicalTravel( n, zp.getAllClassMainTypes(), function (n) { E(e.get(n), function (e) { !e || ("series" === n && (function (t, e) { if (e) { var n = e.seriesIndex, i = e.seriesId, r = e.seriesName; return ( (null != n && t.componentIndex !== n) || (null != i && t.id !== i) || (null != r && t.name !== r) ); } })(e, t)) || e.restoreData(); }); } ); }), (e.internalField = ((ad = function (t) { var e = (t._seriesIndices = []); E(t._componentsMap.get("series"), function (t) { t && e.push(t.componentIndex); }), (t._seriesIndicesMap = yt(e)); }), (sd = function (t) {}), void (ld = function (t, e) { (t.option = {}), (t.option[fd] = 1), (t._componentsMap = yt({ series: [] })), (t._componentsCount = yt()); var n = e.aria; q(n) && null == n.enabled && (n.enabled = !0), (function (t, e) { var n = t.color && !t.colorLayer; E(e, function (e, i) { ("colorLayer" === i && n) || zp.hasClass(i) || ("object" == typeof e ? (t[i] = t[i] ? C(t[i], e, !1) : T(e)) : null == t[i] && (t[i] = e)); }); })(e, t._theme.option), C(e, Fp, !1), t._mergeOption(e, null); }))), e ); })(Cc); function yd(t, e, n) { if (Y(e)) { var i = yt(); return ( E(e, function (t) { null != t && null != Ro(t, null) && i.set(t, !0); }), B(n, function (e) { return e && i.get(e[t]); }) ); } var r = Ro(e, null); return B(n, function (e) { return e && null != r && e[t] === r; }); } function vd(t, e) { return e.hasOwnProperty("subType") ? B(t, function (t) { return t && t.subType === e.subType; }) : t; } function md(t) { var e = yt(); return ( t && E(To(t.replaceMerge), function (t) { e.set(t, !0); }), { replaceMergeMainTypeMap: e } ); } R(gd, cd); var xd = [ "getDom", "getZr", "getWidth", "getHeight", "getDevicePixelRatio", "dispatchAction", "isSSR", "isDisposed", "on", "off", "getDataURL", "getConnectedDataURL", "getOption", "getId", "updateLabelLayout", ], _d = function (t) { E( xd, function (e) { this[e] = W(t[e], t); }, this ); }, bd = {}, wd = (function () { function t() { this._coordinateSystems = []; } return ( (t.prototype.create = function (t, e) { var n = []; E(bd, function (i, r) { var o = i.create(t, e); n = n.concat(o || []); }), (this._coordinateSystems = n); }), (t.prototype.update = function (t, e) { E(this._coordinateSystems, function (n) { n.update && n.update(t, e); }); }), (t.prototype.getCoordinateSystems = function () { return this._coordinateSystems.slice(); }), (t.register = function (t, e) { bd[t] = e; }), (t.get = function (t) { return bd[t]; }), t ); })(), Sd = /^(min|max)?(.+)$/, Md = (function () { function t(t) { (this._timelineOptions = []), (this._mediaList = []), (this._currentMediaIndices = []), (this._api = t); } return ( (t.prototype.setOption = function (t, e, n) { t && (E(To(t.series), function (t) { t && t.data && $(t.data) && ct(t.data); }), E(To(t.dataset), function (t) { t && t.source && $(t.source) && ct(t.source); })), (t = T(t)); var i = this._optionBackup, r = (function (t, e, n) { var i, r, o = [], a = t.baseOption, s = t.timeline, l = t.options, u = t.media, h = !!t.media, c = !!(l || s || (a && a.timeline)); a ? (r = a).timeline || (r.timeline = s) : ((c || h) && (t.options = t.media = null), (r = t)); h && Y(u) && E(u, function (t) { t && t.option && (t.query ? o.push(t) : i || (i = t)); }); function p(t) { E(e, function (e) { e(t, n); }); } return ( p(r), E(l, function (t) { return p(t); }), E(o, function (t) { return p(t.option); }), { baseOption: r, timelineOptions: l || [], mediaDefault: i, mediaList: o, } ); })(t, e, !i); (this._newBaseOption = r.baseOption), i ? (r.timelineOptions.length && (i.timelineOptions = r.timelineOptions), r.mediaList.length && (i.mediaList = r.mediaList), r.mediaDefault && (i.mediaDefault = r.mediaDefault)) : (this._optionBackup = r); }), (t.prototype.mountOption = function (t) { var e = this._optionBackup; return ( (this._timelineOptions = e.timelineOptions), (this._mediaList = e.mediaList), (this._mediaDefault = e.mediaDefault), (this._currentMediaIndices = []), T(t ? e.baseOption : this._newBaseOption) ); }), (t.prototype.getTimelineOption = function (t) { var e, n = this._timelineOptions; if (n.length) { var i = t.getComponent("timeline"); i && (e = T(n[i.getCurrentIndex()])); } return e; }), (t.prototype.getMediaOption = function (t) { var e, n, i = this._api.getWidth(), r = this._api.getHeight(), o = this._mediaList, a = this._mediaDefault, s = [], l = []; if (!o.length && !a) return l; for (var u = 0, h = o.length; u < h; u++) Id(o[u].query, i, r) && s.push(u); return ( !s.length && a && (s = [-1]), s.length && ((e = s), (n = this._currentMediaIndices), e.join(",") !== n.join(",")) && (l = z(s, function (t) { return T(-1 === t ? a.option : o[t].option); })), (this._currentMediaIndices = s), l ); }), t ); })(); function Id(t, e, n) { var i = { width: e, height: n, aspectratio: e / n }, r = !0; return ( E(t, function (t, e) { var n = e.match(Sd); if (n && n[1] && n[2]) { var o = n[1], a = n[2].toLowerCase(); (function (t, e, n) { return "min" === n ? t >= e : "max" === n ? t <= e : t === e; })(i[a], t, o) || (r = !1); } }), r ); } var Td = E, Cd = q, Dd = [ "areaStyle", "lineStyle", "nodeStyle", "linkStyle", "chordStyle", "label", "labelLine", ]; function Ad(t) { var e = t && t.itemStyle; if (e) for (var n = 0, i = Dd.length; n < i; n++) { var r = Dd[n], o = e.normal, a = e.emphasis; o && o[r] && ((t[r] = t[r] || {}), t[r].normal ? C(t[r].normal, o[r]) : (t[r].normal = o[r]), (o[r] = null)), a && a[r] && ((t[r] = t[r] || {}), t[r].emphasis ? C(t[r].emphasis, a[r]) : (t[r].emphasis = a[r]), (a[r] = null)); } } function kd(t, e, n) { if (t && t[e] && (t[e].normal || t[e].emphasis)) { var i = t[e].normal, r = t[e].emphasis; i && (n ? ((t[e].normal = t[e].emphasis = null), k(t[e], i)) : (t[e] = i)), r && ((t.emphasis = t.emphasis || {}), (t.emphasis[e] = r), r.focus && (t.emphasis.focus = r.focus), r.blurScope && (t.emphasis.blurScope = r.blurScope)); } } function Ld(t) { kd(t, "itemStyle"), kd(t, "lineStyle"), kd(t, "areaStyle"), kd(t, "label"), kd(t, "labelLine"), kd(t, "upperLabel"), kd(t, "edgeLabel"); } function Pd(t, e) { var n = Cd(t) && t[e], i = Cd(n) && n.textStyle; if (i) { 0; for (var r = 0, o = Do.length; r < o; r++) { var a = Do[r]; i.hasOwnProperty(a) && (n[a] = i[a]); } } } function Od(t) { t && (Ld(t), Pd(t, "label"), t.emphasis && Pd(t.emphasis, "label")); } function Rd(t) { return Y(t) ? t : t ? [t] : []; } function Nd(t) { return (Y(t) ? t[0] : t) || {}; } function Ed(t, e) { Td(Rd(t.series), function (t) { Cd(t) && (function (t) { if (Cd(t)) { Ad(t), Ld(t), Pd(t, "label"), Pd(t, "upperLabel"), Pd(t, "edgeLabel"), t.emphasis && (Pd(t.emphasis, "label"), Pd(t.emphasis, "upperLabel"), Pd(t.emphasis, "edgeLabel")); var e = t.markPoint; e && (Ad(e), Od(e)); var n = t.markLine; n && (Ad(n), Od(n)); var i = t.markArea; i && Od(i); var r = t.data; if ("graph" === t.type) { r = r || t.nodes; var o = t.links || t.edges; if (o && !$(o)) for (var a = 0; a < o.length; a++) Od(o[a]); E(t.categories, function (t) { Ld(t); }); } if (r && !$(r)) for (a = 0; a < r.length; a++) Od(r[a]); if ((e = t.markPoint) && e.data) { var s = e.data; for (a = 0; a < s.length; a++) Od(s[a]); } if ((n = t.markLine) && n.data) { var l = n.data; for (a = 0; a < l.length; a++) Y(l[a]) ? (Od(l[a][0]), Od(l[a][1])) : Od(l[a]); } "gauge" === t.type ? (Pd(t, "axisLabel"), Pd(t, "title"), Pd(t, "detail")) : "treemap" === t.type ? (kd(t.breadcrumb, "itemStyle"), E(t.levels, function (t) { Ld(t); })) : "tree" === t.type && Ld(t.leaves); } })(t); }); var n = [ "xAxis", "yAxis", "radiusAxis", "angleAxis", "singleAxis", "parallelAxis", "radar", ]; e && n.push("valueAxis", "categoryAxis", "logAxis", "timeAxis"), Td(n, function (e) { Td(Rd(t[e]), function (t) { t && (Pd(t, "axisLabel"), Pd(t.axisPointer, "label")); }); }), Td(Rd(t.parallel), function (t) { var e = t && t.parallelAxisDefault; Pd(e, "axisLabel"), Pd(e && e.axisPointer, "label"); }), Td(Rd(t.calendar), function (t) { kd(t, "itemStyle"), Pd(t, "dayLabel"), Pd(t, "monthLabel"), Pd(t, "yearLabel"); }), Td(Rd(t.radar), function (t) { Pd(t, "name"), t.name && null == t.axisName && ((t.axisName = t.name), delete t.name), null != t.nameGap && null == t.axisNameGap && ((t.axisNameGap = t.nameGap), delete t.nameGap); }), Td(Rd(t.geo), function (t) { Cd(t) && (Od(t), Td(Rd(t.regions), function (t) { Od(t); })); }), Td(Rd(t.timeline), function (t) { Od(t), kd(t, "label"), kd(t, "itemStyle"), kd(t, "controlStyle", !0); var e = t.data; Y(e) && E(e, function (t) { q(t) && (kd(t, "label"), kd(t, "itemStyle")); }); }), Td(Rd(t.toolbox), function (t) { kd(t, "iconStyle"), Td(t.feature, function (t) { kd(t, "iconStyle"); }); }), Pd(Nd(t.axisPointer), "label"), Pd(Nd(t.tooltip).axisPointer, "label"); } function zd(t) { t && E(Vd, function (e) { e[0] in t && !(e[1] in t) && (t[e[1]] = t[e[0]]); }); } var Vd = [ ["x", "left"], ["y", "top"], ["x2", "right"], ["y2", "bottom"], ], Bd = [ "grid", "geo", "parallel", "legend", "toolbox", "title", "visualMap", "dataZoom", "timeline", ], Fd = [ ["borderRadius", "barBorderRadius"], ["borderColor", "barBorderColor"], ["borderWidth", "barBorderWidth"], ]; function Gd(t) { var e = t && t.itemStyle; if (e) for (var n = 0; n < Fd.length; n++) { var i = Fd[n][1], r = Fd[n][0]; null != e[i] && (e[r] = e[i]); } } function Wd(t) { t && "edge" === t.alignTo && null != t.margin && null == t.edgeDistance && (t.edgeDistance = t.margin); } function Hd(t) { t && t.downplay && !t.blur && (t.blur = t.downplay); } function Yd(t, e) { if (t) for (var n = 0; n < t.length; n++) e(t[n]), t[n] && Yd(t[n].children, e); } function Xd(t, e) { Ed(t, e), (t.series = To(t.series)), E(t.series, function (t) { if (q(t)) { var e = t.type; if ("line" === e) null != t.clipOverflow && (t.clip = t.clipOverflow); else if ("pie" === e || "gauge" === e) { if ( (null != t.clockWise && (t.clockwise = t.clockWise), Wd(t.label), (r = t.data) && !$(r)) ) for (var n = 0; n < r.length; n++) Wd(r[n]); null != t.hoverOffset && ((t.emphasis = t.emphasis || {}), (t.emphasis.scaleSize = null) && (t.emphasis.scaleSize = t.hoverOffset)); } else if ("gauge" === e) { var i = (function (t, e) { for ( var n = e.split(","), i = t, r = 0; r < n.length && null != (i = i && i[n[r]]); r++ ); return i; })(t, "pointer.color"); null != i && (function (t, e, n, i) { for ( var r, o = e.split(","), a = t, s = 0; s < o.length - 1; s++ ) null == a[(r = o[s])] && (a[r] = {}), (a = a[r]); (i || null == a[o[s]]) && (a[o[s]] = n); })(t, "itemStyle.color", i); } else if ("bar" === e) { var r; if ( (Gd(t), Gd(t.backgroundStyle), Gd(t.emphasis), (r = t.data) && !$(r)) ) for (n = 0; n < r.length; n++) "object" == typeof r[n] && (Gd(r[n]), Gd(r[n] && r[n].emphasis)); } else if ("sunburst" === e) { var o = t.highlightPolicy; o && ((t.emphasis = t.emphasis || {}), t.emphasis.focus || (t.emphasis.focus = o)), Hd(t), Yd(t.data, Hd); } else "graph" === e || "sankey" === e ? (function (t) { t && null != t.focusNodeAdjacency && ((t.emphasis = t.emphasis || {}), null == t.emphasis.focus && (t.emphasis.focus = "adjacency")); })(t) : "map" === e && (t.mapType && !t.map && (t.map = t.mapType), t.mapLocation && k(t, t.mapLocation)); null != t.hoverAnimation && ((t.emphasis = t.emphasis || {}), t.emphasis && null == t.emphasis.scale && (t.emphasis.scale = t.hoverAnimation)), zd(t); } }), t.dataRange && (t.visualMap = t.dataRange), E(Bd, function (e) { var n = t[e]; n && (Y(n) || (n = [n]), E(n, function (t) { zd(t); })); }); } function Ud(t) { E(t, function (e, n) { var i = [], r = [NaN, NaN], o = [e.stackResultDimension, e.stackedOverDimension], a = e.data, s = e.isStackedByIndex, l = e.seriesModel.get("stackStrategy") || "samesign"; a.modify(o, function (o, u, h) { var c, p, d = a.get(e.stackedDimension, h); if (isNaN(d)) return r; s ? (p = a.getRawIndex(h)) : (c = a.get(e.stackedByDimension, h)); for (var f = NaN, g = n - 1; g >= 0; g--) { var y = t[g]; if ( (s || (p = y.data.rawIndexOf(y.stackedByDimension, c)), p >= 0) ) { var v = y.data.getByRawIndex(y.stackResultDimension, p); if ( "all" === l || ("positive" === l && v > 0) || ("negative" === l && v < 0) || ("samesign" === l && d >= 0 && v > 0) || ("samesign" === l && d <= 0 && v < 0) ) { (d = ro(d, v)), (f = v); break; } } } return (i[0] = d), (i[1] = f), i; }); }); } var Zd, jd, qd, Kd, $d, Jd = function (t) { (this.data = t.data || (t.sourceFormat === Xp ? {} : [])), (this.sourceFormat = t.sourceFormat || Zp), (this.seriesLayoutBy = t.seriesLayoutBy || jp), (this.startIndex = t.startIndex || 0), (this.dimensionsDetectedCount = t.dimensionsDetectedCount), (this.metaRawOption = t.metaRawOption); var e = (this.dimensionsDefine = t.dimensionsDefine); if (e) for (var n = 0; n < e.length; n++) { var i = e[n]; null == i.type && id(this, n) === Kp && (i.type = "ordinal"); } }; function Qd(t) { return t instanceof Jd; } function tf(t, e, n) { n = n || nf(t); var i = e.seriesLayoutBy, r = (function (t, e, n, i, r) { var o, a; if (!t) return { dimensionsDefine: rf(r), startIndex: a, dimensionsDetectedCount: o, }; if (e === Hp) { var s = t; "auto" === i || null == i ? of( function (t) { null != t && "-" !== t && (U(t) ? null == a && (a = 1) : (a = 0)); }, n, s, 10 ) : (a = j(i) ? i : i ? 1 : 0), r || 1 !== a || ((r = []), of( function (t, e) { r[e] = null != t ? t + "" : ""; }, n, s, 1 / 0 )), (o = r ? r.length : n === qp ? s.length : s[0] ? s[0].length : null); } else if (e === Yp) r || (r = (function (t) { var e, n = 0; for (; n < t.length && !(e = t[n++]); ); if (e) return G(e); })(t)); else if (e === Xp) r || ((r = []), E(t, function (t, e) { r.push(e); })); else if (e === Wp) { var l = Ao(t[0]); o = (Y(l) && l.length) || 1; } return { startIndex: a, dimensionsDefine: rf(r), dimensionsDetectedCount: o, }; })(t, n, i, e.sourceHeader, e.dimensions); return new Jd({ data: t, sourceFormat: n, seriesLayoutBy: i, dimensionsDefine: r.dimensionsDefine, startIndex: r.startIndex, dimensionsDetectedCount: r.dimensionsDetectedCount, metaRawOption: T(e), }); } function ef(t) { return new Jd({ data: t, sourceFormat: $(t) ? Up : Wp }); } function nf(t) { var e = Zp; if ($(t)) e = Up; else if (Y(t)) { 0 === t.length && (e = Hp); for (var n = 0, i = t.length; n < i; n++) { var r = t[n]; if (null != r) { if (Y(r) || $(r)) { e = Hp; break; } if (q(r)) { e = Yp; break; } } } } else if (q(t)) for (var o in t) if (_t(t, o) && N(t[o])) { e = Xp; break; } return e; } function rf(t) { if (t) { var e = yt(); return z(t, function (t, n) { var i = { name: (t = q(t) ? t : { name: t }).name, displayName: t.displayName, type: t.type, }; if (null == i.name) return i; (i.name += ""), null == i.displayName && (i.displayName = i.name); var r = e.get(i.name); return ( r ? (i.name += "-" + r.count++) : e.set(i.name, { count: 1 }), i ); }); } } function of(t, e, n, i) { if (e === qp) for (var r = 0; r < n.length && r < i; r++) t(n[r] ? n[r][0] : null, r); else { var o = n[0] || []; for (r = 0; r < o.length && r < i; r++) t(o[r], r); } } function af(t) { var e = t.sourceFormat; return e === Yp || e === Xp; } var sf = (function () { function t(t, e) { var n = Qd(t) ? t : ef(t); this._source = n; var i = (this._data = n.data); n.sourceFormat === Up && ((this._offset = 0), (this._dimSize = e), (this._data = i)), $d(this, i, n); } return ( (t.prototype.getSource = function () { return this._source; }), (t.prototype.count = function () { return 0; }), (t.prototype.getItem = function (t, e) {}), (t.prototype.appendData = function (t) {}), (t.prototype.clean = function () {}), (t.protoInitialize = (function () { var e = t.prototype; (e.pure = !1), (e.persistent = !0); })()), (t.internalField = (function () { var t; $d = function (t, r, o) { var a = o.sourceFormat, s = o.seriesLayoutBy, l = o.startIndex, u = o.dimensionsDefine, h = Kd[vf(a, s)]; if ((A(t, h), a === Up)) (t.getItem = e), (t.count = i), (t.fillStorage = n); else { var c = hf(a, s); t.getItem = W(c, null, r, l, u); var p = df(a, s); t.count = W(p, null, r, l, u); } }; var e = function (t, e) { (t -= this._offset), (e = e || []); for ( var n = this._data, i = this._dimSize, r = i * t, o = 0; o < i; o++ ) e[o] = n[r + o]; return e; }, n = function (t, e, n, i) { for ( var r = this._data, o = this._dimSize, a = 0; a < o; a++ ) { for ( var s = i[a], l = null == s[0] ? 1 / 0 : s[0], u = null == s[1] ? -1 / 0 : s[1], h = e - t, c = n[a], p = 0; p < h; p++ ) { var d = r[p * o + a]; (c[t + p] = d), d < l && (l = d), d > u && (u = d); } (s[0] = l), (s[1] = u); } }, i = function () { return this._data ? this._data.length / this._dimSize : 0; }; function r(t) { for (var e = 0; e < t.length; e++) this._data.push(t[e]); } ((t = {})[Hp + "_" + jp] = { pure: !0, appendData: r }), (t[Hp + "_" + qp] = { pure: !0, appendData: function () { throw new Error( 'Do not support appendData when set seriesLayoutBy: "row".' ); }, }), (t[Yp] = { pure: !0, appendData: r }), (t[Xp] = { pure: !0, appendData: function (t) { var e = this._data; E(t, function (t, n) { for ( var i = e[n] || (e[n] = []), r = 0; r < (t || []).length; r++ ) i.push(t[r]); }); }, }), (t[Wp] = { appendData: r }), (t[Up] = { persistent: !1, pure: !0, appendData: function (t) { this._data = t; }, clean: function () { (this._offset += this.count()), (this._data = null); }, }), (Kd = t); })()), t ); })(), lf = function (t, e, n, i) { return t[i]; }, uf = (((Zd = {})[Hp + "_" + jp] = function (t, e, n, i) { return t[i + e]; }), (Zd[Hp + "_" + qp] = function (t, e, n, i, r) { i += e; for (var o = r || [], a = t, s = 0; s < a.length; s++) { var l = a[s]; o[s] = l ? l[i] : null; } return o; }), (Zd[Yp] = lf), (Zd[Xp] = function (t, e, n, i, r) { for (var o = r || [], a = 0; a < n.length; a++) { var s = n[a].name; 0; var l = t[s]; o[a] = l ? l[i] : null; } return o; }), (Zd[Wp] = lf), Zd); function hf(t, e) { var n = uf[vf(t, e)]; return n; } var cf = function (t, e, n) { return t.length; }, pf = (((jd = {})[Hp + "_" + jp] = function (t, e, n) { return Math.max(0, t.length - e); }), (jd[Hp + "_" + qp] = function (t, e, n) { var i = t[0]; return i ? Math.max(0, i.length - e) : 0; }), (jd[Yp] = cf), (jd[Xp] = function (t, e, n) { var i = n[0].name; var r = t[i]; return r ? r.length : 0; }), (jd[Wp] = cf), jd); function df(t, e) { var n = pf[vf(t, e)]; return n; } var ff = function (t, e, n) { return t[e]; }, gf = (((qd = {})[Hp] = ff), (qd[Yp] = function (t, e, n) { return t[n]; }), (qd[Xp] = ff), (qd[Wp] = function (t, e, n) { var i = Ao(t); return i instanceof Array ? i[e] : i; }), (qd[Up] = ff), qd); function yf(t) { var e = gf[t]; return e; } function vf(t, e) { return t === Hp ? t + "_" + e : t; } function mf(t, e, n) { if (t) { var i = t.getRawDataItem(e); if (null != i) { var r = t.getStore(), o = r.getSource().sourceFormat; if (null != n) { var a = t.getDimensionIndex(n), s = r.getDimensionProperty(a); return yf(o)(i, a, s); } var l = i; return o === Wp && (l = Ao(i)), l; } } } var xf = /\{@(.+?)\}/g, _f = (function () { function t() {} return ( (t.prototype.getDataParams = function (t, e) { var n = this.getData(e), i = this.getRawValue(t, e), r = n.getRawIndex(t), o = n.getName(t), a = n.getRawDataItem(t), s = n.getItemVisual(t, "style"), l = s && s[n.getItemVisual(t, "drawType") || "fill"], u = s && s.stroke, h = this.mainType, c = "series" === h, p = n.userOutput && n.userOutput.get(); return { componentType: h, componentSubType: this.subType, componentIndex: this.componentIndex, seriesType: c ? this.subType : null, seriesIndex: this.seriesIndex, seriesId: c ? this.id : null, seriesName: c ? this.name : null, name: o, dataIndex: r, data: a, dataType: e, value: i, color: l, borderColor: u, dimensionNames: p ? p.fullDimensions : null, encode: p ? p.encode : null, $vars: ["seriesName", "name", "value"], }; }), (t.prototype.getFormattedLabel = function (t, e, n, i, r, o) { e = e || "normal"; var a = this.getData(n), s = this.getDataParams(t, n); (o && (s.value = o.interpolatedValue), null != i && Y(s.value) && (s.value = s.value[i]), r) || (r = a .getItemModel(t) .get( "normal" === e ? ["label", "formatter"] : [e, "label", "formatter"] )); return X(r) ? ((s.status = e), (s.dimensionIndex = i), r(s)) : U(r) ? bp(r, s).replace(xf, function (e, n) { var i = n.length, r = n; "[" === r.charAt(0) && "]" === r.charAt(i - 1) && (r = +r.slice(1, i - 1)); var s = mf(a, t, r); if (o && Y(o.interpolatedValue)) { var l = a.getDimensionIndex(r); l >= 0 && (s = o.interpolatedValue[l]); } return null != s ? s + "" : ""; }) : void 0; }), (t.prototype.getRawValue = function (t, e) { return mf(this.getData(e), t); }), (t.prototype.formatTooltip = function (t, e, n) {}), t ); })(); function bf(t) { var e, n; return q(t) ? t.type && (n = t) : (e = t), { text: e, frag: n }; } function wf(t) { return new Sf(t); } var Sf = (function () { function t(t) { (t = t || {}), (this._reset = t.reset), (this._plan = t.plan), (this._count = t.count), (this._onDirty = t.onDirty), (this._dirty = !0); } return ( (t.prototype.perform = function (t) { var e, n = this._upstream, i = t && t.skip; if (this._dirty && n) { var r = this.context; r.data = r.outputData = n.context.outputData; } this.__pipeline && (this.__pipeline.currentTask = this), this._plan && !i && (e = this._plan(this.context)); var o, a = h(this._modBy), s = this._modDataCount || 0, l = h(t && t.modBy), u = (t && t.modDataCount) || 0; function h(t) { return !(t >= 1) && (t = 1), t; } (a === l && s === u) || (e = "reset"), (this._dirty || "reset" === e) && ((this._dirty = !1), (o = this._doReset(i))), (this._modBy = l), (this._modDataCount = u); var c = t && t.step; if ( ((this._dueEnd = n ? n._outputDueEnd : this._count ? this._count(this.context) : 1 / 0), this._progress) ) { var p = this._dueIndex, d = Math.min( null != c ? this._dueIndex + c : 1 / 0, this._dueEnd ); if (!i && (o || p < d)) { var f = this._progress; if (Y(f)) for (var g = 0; g < f.length; g++) this._doProgress(f[g], p, d, l, u); else this._doProgress(f, p, d, l, u); } this._dueIndex = d; var y = null != this._settedOutputEnd ? this._settedOutputEnd : d; 0, (this._outputDueEnd = y); } else this._dueIndex = this._outputDueEnd = null != this._settedOutputEnd ? this._settedOutputEnd : this._dueEnd; return this.unfinished(); }), (t.prototype.dirty = function () { (this._dirty = !0), this._onDirty && this._onDirty(this.context); }), (t.prototype._doProgress = function (t, e, n, i, r) { Mf.reset(e, n, i, r), (this._callingProgress = t), this._callingProgress( { start: e, end: n, count: n - e, next: Mf.next }, this.context ); }), (t.prototype._doReset = function (t) { var e, n; (this._dueIndex = this._outputDueEnd = this._dueEnd = 0), (this._settedOutputEnd = null), !t && this._reset && ((e = this._reset(this.context)) && e.progress && ((n = e.forceFirstProgress), (e = e.progress)), Y(e) && !e.length && (e = null)), (this._progress = e), (this._modBy = this._modDataCount = null); var i = this._downstream; return i && i.dirty(), n; }), (t.prototype.unfinished = function () { return this._progress && this._dueIndex < this._dueEnd; }), (t.prototype.pipe = function (t) { (this._downstream !== t || this._dirty) && ((this._downstream = t), (t._upstream = this), t.dirty()); }), (t.prototype.dispose = function () { this._disposed || (this._upstream && (this._upstream._downstream = null), this._downstream && (this._downstream._upstream = null), (this._dirty = !1), (this._disposed = !0)); }), (t.prototype.getUpstream = function () { return this._upstream; }), (t.prototype.getDownstream = function () { return this._downstream; }), (t.prototype.setOutputEnd = function (t) { this._outputDueEnd = this._settedOutputEnd = t; }), t ); })(), Mf = (function () { var t, e, n, i, r, o = { reset: function (l, u, h, c) { (e = l), (t = u), (n = h), (i = c), (r = Math.ceil(i / n)), (o.next = n > 1 && i > 0 ? s : a); }, }; return o; function a() { return e < t ? e++ : null; } function s() { var o = (e % r) * n + Math.ceil(e / r), a = e >= t ? null : o < i ? o : e; return e++, a; } })(); function If(t, e) { var n = e && e.type; return "ordinal" === n ? t : ("time" !== n || j(t) || null == t || "-" === t || (t = +uo(t)), null == t || "" === t ? NaN : Number(t)); } var Tf = yt({ number: function (t) { return parseFloat(t); }, time: function (t) { return +uo(t); }, trim: function (t) { return U(t) ? ut(t) : t; }, }); function Cf(t) { return Tf.get(t); } var Df = { lt: function (t, e) { return t < e; }, lte: function (t, e) { return t <= e; }, gt: function (t, e) { return t > e; }, gte: function (t, e) { return t >= e; }, }, Af = (function () { function t(t, e) { if (!j(e)) { var n = ""; 0, wo(n); } (this._opFn = Df[t]), (this._rvalFloat = yo(e)); } return ( (t.prototype.evaluate = function (t) { return j(t) ? this._opFn(t, this._rvalFloat) : this._opFn(yo(t), this._rvalFloat); }), t ); })(), kf = (function () { function t(t, e) { var n = "desc" === t; (this._resultLT = n ? 1 : -1), null == e && (e = n ? "min" : "max"), (this._incomparable = "min" === e ? -1 / 0 : 1 / 0); } return ( (t.prototype.evaluate = function (t, e) { var n = j(t) ? t : yo(t), i = j(e) ? e : yo(e), r = isNaN(n), o = isNaN(i); if ( (r && (n = this._incomparable), o && (i = this._incomparable), r && o) ) { var a = U(t), s = U(e); a && (n = s ? t : 0), s && (i = a ? e : 0); } return n < i ? this._resultLT : n > i ? -this._resultLT : 0; }), t ); })(), Lf = (function () { function t(t, e) { (this._rval = e), (this._isEQ = t), (this._rvalTypeof = typeof e), (this._rvalFloat = yo(e)); } return ( (t.prototype.evaluate = function (t) { var e = t === this._rval; if (!e) { var n = typeof t; n === this._rvalTypeof || ("number" !== n && "number" !== this._rvalTypeof) || (e = yo(t) === this._rvalFloat); } return this._isEQ ? e : !e; }), t ); })(); function Pf(t, e) { return "eq" === t || "ne" === t ? new Lf("eq" === t, e) : _t(Df, t) ? new Af(t, e) : null; } var Of = (function () { function t() {} return ( (t.prototype.getRawData = function () { throw new Error("not supported"); }), (t.prototype.getRawDataItem = function (t) { throw new Error("not supported"); }), (t.prototype.cloneRawData = function () {}), (t.prototype.getDimensionInfo = function (t) {}), (t.prototype.cloneAllDimensionInfo = function () {}), (t.prototype.count = function () {}), (t.prototype.retrieveValue = function (t, e) {}), (t.prototype.retrieveValueFromItem = function (t, e) {}), (t.prototype.convertValue = function (t, e) { return If(t, e); }), t ); })(); function Rf(t) { var e = t.sourceFormat; if (!Ff(e)) { var n = ""; 0, wo(n); } return t.data; } function Nf(t) { var e = t.sourceFormat, n = t.data; if (!Ff(e)) { var i = ""; 0, wo(i); } if (e === Hp) { for (var r = [], o = 0, a = n.length; o < a; o++) r.push(n[o].slice()); return r; } if (e === Yp) { for (r = [], o = 0, a = n.length; o < a; o++) r.push(A({}, n[o])); return r; } } function Ef(t, e, n) { if (null != n) return j(n) || (!isNaN(n) && !_t(e, n)) ? t[n] : _t(e, n) ? e[n] : void 0; } function zf(t) { return T(t); } var Vf = yt(); function Bf(t, e, n, i) { var r = ""; e.length || wo(r), q(t) || wo(r); var o = t.type, a = Vf.get(o); a || wo(r); var s = z(e, function (t) { return (function (t, e) { var n = new Of(), i = t.data, r = (n.sourceFormat = t.sourceFormat), o = t.startIndex, a = ""; t.seriesLayoutBy !== jp && wo(a); var s = [], l = {}, u = t.dimensionsDefine; if (u) E(u, function (t, e) { var n = t.name, i = { index: e, name: n, displayName: t.displayName, }; if ((s.push(i), null != n)) { var r = ""; _t(l, n) && wo(r), (l[n] = i); } }); else for (var h = 0; h < t.dimensionsDetectedCount; h++) s.push({ index: h }); var c = hf(r, jp); e.__isBuiltIn && ((n.getRawDataItem = function (t) { return c(i, o, s, t); }), (n.getRawData = W(Rf, null, t))), (n.cloneRawData = W(Nf, null, t)); var p = df(r, jp); n.count = W(p, null, i, o, s); var d = yf(r); n.retrieveValue = function (t, e) { var n = c(i, o, s, t); return f(n, e); }; var f = (n.retrieveValueFromItem = function (t, e) { if (null != t) { var n = s[e]; return n ? d(t, e, n.name) : void 0; } }); return ( (n.getDimensionInfo = W(Ef, null, s, l)), (n.cloneAllDimensionInfo = W(zf, null, s)), n ); })(t, a); }), l = To( a.transform({ upstream: s[0], upstreamList: s, config: T(t.config), }) ); return z(l, function (t, n) { var i, r = ""; q(t) || wo(r), t.data || wo(r), Ff(nf(t.data)) || wo(r); var o = e[0]; if (o && 0 === n && !t.dimensions) { var a = o.startIndex; a && (t.data = o.data.slice(0, a).concat(t.data)), (i = { seriesLayoutBy: jp, sourceHeader: a, dimensions: o.metaRawOption.dimensions, }); } else i = { seriesLayoutBy: jp, sourceHeader: 0, dimensions: t.dimensions }; return tf(t.data, i, null); }); } function Ff(t) { return t === Hp || t === Yp; } var Gf, Wf = "undefined", Hf = typeof Uint32Array === Wf ? Array : Uint32Array, Yf = typeof Uint16Array === Wf ? Array : Uint16Array, Xf = typeof Int32Array === Wf ? Array : Int32Array, Uf = typeof Float64Array === Wf ? Array : Float64Array, Zf = { float: Uf, int: Xf, ordinal: Array, number: Array, time: Uf }; function jf(t) { return t > 65535 ? Hf : Yf; } function qf(t, e, n, i, r) { var o = Zf[n || "float"]; if (r) { var a = t[e], s = a && a.length; if (s !== i) { for (var l = new o(i), u = 0; u < s; u++) l[u] = a[u]; t[e] = l; } } else t[e] = new o(i); } var Kf = (function () { function t() { (this._chunks = []), (this._rawExtent = []), (this._extent = []), (this._count = 0), (this._rawCount = 0), (this._calcDimNameToIdx = yt()); } return ( (t.prototype.initData = function (t, e, n) { (this._provider = t), (this._chunks = []), (this._indices = null), (this.getRawIndex = this._getRawIdxIdentity); var i = t.getSource(), r = (this.defaultDimValueGetter = Gf[i.sourceFormat]); (this._dimValueGetter = n || r), (this._rawExtent = []); af(i); (this._dimensions = z(e, function (t) { return { type: t.type, property: t.property }; })), this._initDataFromProvider(0, t.count()); }), (t.prototype.getProvider = function () { return this._provider; }), (t.prototype.getSource = function () { return this._provider.getSource(); }), (t.prototype.ensureCalculationDimension = function (t, e) { var n = this._calcDimNameToIdx, i = this._dimensions, r = n.get(t); if (null != r) { if (i[r].type === e) return r; } else r = i.length; return ( (i[r] = { type: e }), n.set(t, r), (this._chunks[r] = new Zf[e || "float"]( this._rawCount )), (this._rawExtent[r] = [1 / 0, -1 / 0]), r ); }), (t.prototype.collectOrdinalMeta = function (t, e) { var n = this._chunks[t], i = this._dimensions[t], r = this._rawExtent, o = i.ordinalOffset || 0, a = n.length; 0 === o && (r[t] = [1 / 0, -1 / 0]); for (var s = r[t], l = o; l < a; l++) { var u = (n[l] = e.parseAndCollect(n[l])); isNaN(u) || ((s[0] = Math.min(u, s[0])), (s[1] = Math.max(u, s[1]))); } (i.ordinalMeta = e), (i.ordinalOffset = a), (i.type = "ordinal"); }), (t.prototype.getOrdinalMeta = function (t) { return this._dimensions[t].ordinalMeta; }), (t.prototype.getDimensionProperty = function (t) { var e = this._dimensions[t]; return e && e.property; }), (t.prototype.appendData = function (t) { var e = this._provider, n = this.count(); e.appendData(t); var i = e.count(); return ( e.persistent || (i += n), n < i && this._initDataFromProvider(n, i, !0), [n, i] ); }), (t.prototype.appendValues = function (t, e) { for ( var n = this._chunks, i = this._dimensions, r = i.length, o = this._rawExtent, a = this.count(), s = a + Math.max(t.length, e || 0), l = 0; l < r; l++ ) { qf(n, l, (d = i[l]).type, s, !0); } for (var u = [], h = a; h < s; h++) for (var c = h - a, p = 0; p < r; p++) { var d = i[p], f = Gf.arrayRows.call( this, t[c] || u, d.property, c, p ); n[p][h] = f; var g = o[p]; f < g[0] && (g[0] = f), f > g[1] && (g[1] = f); } return ( (this._rawCount = this._count = s), { start: a, end: s } ); }), (t.prototype._initDataFromProvider = function (t, e, n) { for ( var i = this._provider, r = this._chunks, o = this._dimensions, a = o.length, s = this._rawExtent, l = z(o, function (t) { return t.property; }), u = 0; u < a; u++ ) { var h = o[u]; s[u] || (s[u] = [1 / 0, -1 / 0]), qf(r, u, h.type, e, n); } if (i.fillStorage) i.fillStorage(t, e, r, s); else for (var c = [], p = t; p < e; p++) { c = i.getItem(p, c); for (var d = 0; d < a; d++) { var f = r[d], g = this._dimValueGetter(c, l[d], p, d); f[p] = g; var y = s[d]; g < y[0] && (y[0] = g), g > y[1] && (y[1] = g); } } !i.persistent && i.clean && i.clean(), (this._rawCount = this._count = e), (this._extent = []); }), (t.prototype.count = function () { return this._count; }), (t.prototype.get = function (t, e) { if (!(e >= 0 && e < this._count)) return NaN; var n = this._chunks[t]; return n ? n[this.getRawIndex(e)] : NaN; }), (t.prototype.getValues = function (t, e) { var n = [], i = []; if (null == e) { (e = t), (t = []); for (var r = 0; r < this._dimensions.length; r++) i.push(r); } else i = t; r = 0; for (var o = i.length; r < o; r++) n.push(this.get(i[r], e)); return n; }), (t.prototype.getByRawIndex = function (t, e) { if (!(e >= 0 && e < this._rawCount)) return NaN; var n = this._chunks[t]; return n ? n[e] : NaN; }), (t.prototype.getSum = function (t) { var e = 0; if (this._chunks[t]) for (var n = 0, i = this.count(); n < i; n++) { var r = this.get(t, n); isNaN(r) || (e += r); } return e; }), (t.prototype.getMedian = function (t) { var e = []; this.each([t], function (t) { isNaN(t) || e.push(t); }); var n = e.sort(function (t, e) { return t - e; }), i = this.count(); return 0 === i ? 0 : i % 2 == 1 ? n[(i - 1) / 2] : (n[i / 2] + n[i / 2 - 1]) / 2; }), (t.prototype.indexOfRawIndex = function (t) { if (t >= this._rawCount || t < 0) return -1; if (!this._indices) return t; var e = this._indices, n = e[t]; if (null != n && n < this._count && n === t) return t; for (var i = 0, r = this._count - 1; i <= r; ) { var o = ((i + r) / 2) | 0; if (e[o] < t) i = o + 1; else { if (!(e[o] > t)) return o; r = o - 1; } } return -1; }), (t.prototype.indicesOfNearest = function (t, e, n) { var i = this._chunks[t], r = []; if (!i) return r; null == n && (n = 1 / 0); for ( var o = 1 / 0, a = -1, s = 0, l = 0, u = this.count(); l < u; l++ ) { var h = e - i[this.getRawIndex(l)], c = Math.abs(h); c <= n && ((c < o || (c === o && h >= 0 && a < 0)) && ((o = c), (a = h), (s = 0)), h === a && (r[s++] = l)); } return (r.length = s), r; }), (t.prototype.getIndices = function () { var t, e = this._indices; if (e) { var n = e.constructor, i = this._count; if (n === Array) { t = new n(i); for (var r = 0; r < i; r++) t[r] = e[r]; } else t = new n(e.buffer, 0, i); } else { t = new (n = jf(this._rawCount))(this.count()); for (r = 0; r < t.length; r++) t[r] = r; } return t; }), (t.prototype.filter = function (t, e) { if (!this._count) return this; for ( var n = this.clone(), i = n.count(), r = new (jf(n._rawCount))(i), o = [], a = t.length, s = 0, l = t[0], u = n._chunks, h = 0; h < i; h++ ) { var c = void 0, p = n.getRawIndex(h); if (0 === a) c = e(h); else if (1 === a) { c = e(u[l][p], h); } else { for (var d = 0; d < a; d++) o[d] = u[t[d]][p]; (o[d] = h), (c = e.apply(null, o)); } c && (r[s++] = p); } return ( s < i && (n._indices = r), (n._count = s), (n._extent = []), n._updateGetRawIdx(), n ); }), (t.prototype.selectRange = function (t) { var e = this.clone(), n = e._count; if (!n) return this; var i = G(t), r = i.length; if (!r) return this; var o = e.count(), a = new (jf(e._rawCount))(o), s = 0, l = i[0], u = t[l][0], h = t[l][1], c = e._chunks, p = !1; if (!e._indices) { var d = 0; if (1 === r) { for (var f = c[i[0]], g = 0; g < n; g++) { (((x = f[g]) >= u && x <= h) || isNaN(x)) && (a[s++] = d), d++; } p = !0; } else if (2 === r) { f = c[i[0]]; var y = c[i[1]], v = t[i[1]][0], m = t[i[1]][1]; for (g = 0; g < n; g++) { var x = f[g], _ = y[g]; ((x >= u && x <= h) || isNaN(x)) && ((_ >= v && _ <= m) || isNaN(_)) && (a[s++] = d), d++; } p = !0; } } if (!p) if (1 === r) for (g = 0; g < o; g++) { var b = e.getRawIndex(g); (((x = c[i[0]][b]) >= u && x <= h) || isNaN(x)) && (a[s++] = b); } else for (g = 0; g < o; g++) { for ( var w = !0, S = ((b = e.getRawIndex(g)), 0); S < r; S++ ) { var M = i[S]; ((x = c[M][b]) < t[M][0] || x > t[M][1]) && (w = !1); } w && (a[s++] = e.getRawIndex(g)); } return ( s < o && (e._indices = a), (e._count = s), (e._extent = []), e._updateGetRawIdx(), e ); }), (t.prototype.map = function (t, e) { var n = this.clone(t); return this._updateDims(n, t, e), n; }), (t.prototype.modify = function (t, e) { this._updateDims(this, t, e); }), (t.prototype._updateDims = function (t, e, n) { for ( var i = t._chunks, r = [], o = e.length, a = t.count(), s = [], l = t._rawExtent, u = 0; u < e.length; u++ ) l[e[u]] = [1 / 0, -1 / 0]; for (var h = 0; h < a; h++) { for (var c = t.getRawIndex(h), p = 0; p < o; p++) s[p] = i[e[p]][c]; s[o] = h; var d = n && n.apply(null, s); if (null != d) { "object" != typeof d && ((r[0] = d), (d = r)); for (u = 0; u < d.length; u++) { var f = e[u], g = d[u], y = l[f], v = i[f]; v && (v[c] = g), g < y[0] && (y[0] = g), g > y[1] && (y[1] = g); } } } }), (t.prototype.lttbDownSample = function (t, e) { var n, i, r, o = this.clone([t], !0), a = o._chunks[t], s = this.count(), l = 0, u = Math.floor(1 / e), h = this.getRawIndex(0), c = new (jf(this._rawCount))( Math.min(2 * (Math.ceil(s / u) + 2), s) ); c[l++] = h; for (var p = 1; p < s - 1; p += u) { for ( var d = Math.min(p + u, s - 1), f = Math.min(p + 2 * u, s), g = (f + d) / 2, y = 0, v = d; v < f; v++ ) { var m = a[(I = this.getRawIndex(v))]; isNaN(m) || (y += m); } y /= f - d; var x = p, _ = Math.min(p + u, s), b = p - 1, w = a[h]; (n = -1), (r = x); var S = -1, M = 0; for (v = x; v < _; v++) { var I; m = a[(I = this.getRawIndex(v))]; isNaN(m) ? (M++, S < 0 && (S = I)) : (i = Math.abs( (b - g) * (m - w) - (b - v) * (y - w) )) > n && ((n = i), (r = I)); } M > 0 && M < _ - x && ((c[l++] = Math.min(S, r)), (r = Math.max(S, r))), (c[l++] = r), (h = r); } return ( (c[l++] = this.getRawIndex(s - 1)), (o._count = l), (o._indices = c), (o.getRawIndex = this._getRawIdx), o ); }), (t.prototype.minmaxDownSample = function (t, e) { for ( var n = this.clone([t], !0), i = n._chunks, r = Math.floor(1 / e), o = i[t], a = this.count(), s = new (jf(this._rawCount))(2 * Math.ceil(a / r)), l = 0, u = 0; u < a; u += r ) { var h = u, c = o[this.getRawIndex(h)], p = u, d = o[this.getRawIndex(p)], f = r; u + r > a && (f = a - u); for (var g = 0; g < f; g++) { var y = o[this.getRawIndex(u + g)]; y < c && ((c = y), (h = u + g)), y > d && ((d = y), (p = u + g)); } var v = this.getRawIndex(h), m = this.getRawIndex(p); h < p ? ((s[l++] = v), (s[l++] = m)) : ((s[l++] = m), (s[l++] = v)); } return ( (n._count = l), (n._indices = s), n._updateGetRawIdx(), n ); }), (t.prototype.downSample = function (t, e, n, i) { for ( var r = this.clone([t], !0), o = r._chunks, a = [], s = Math.floor(1 / e), l = o[t], u = this.count(), h = (r._rawExtent[t] = [1 / 0, -1 / 0]), c = new (jf(this._rawCount))(Math.ceil(u / s)), p = 0, d = 0; d < u; d += s ) { s > u - d && ((s = u - d), (a.length = s)); for (var f = 0; f < s; f++) { var g = this.getRawIndex(d + f); a[f] = l[g]; } var y = n(a), v = this.getRawIndex( Math.min(d + i(a, y) || 0, u - 1) ); (l[v] = y), y < h[0] && (h[0] = y), y > h[1] && (h[1] = y), (c[p++] = v); } return ( (r._count = p), (r._indices = c), r._updateGetRawIdx(), r ); }), (t.prototype.each = function (t, e) { if (this._count) for ( var n = t.length, i = this._chunks, r = 0, o = this.count(); r < o; r++ ) { var a = this.getRawIndex(r); switch (n) { case 0: e(r); break; case 1: e(i[t[0]][a], r); break; case 2: e(i[t[0]][a], i[t[1]][a], r); break; default: for (var s = 0, l = []; s < n; s++) l[s] = i[t[s]][a]; (l[s] = r), e.apply(null, l); } } }), (t.prototype.getDataExtent = function (t) { var e = this._chunks[t], n = [1 / 0, -1 / 0]; if (!e) return n; var i, r = this.count(); if (!this._indices) return this._rawExtent[t].slice(); if ((i = this._extent[t])) return i.slice(); for (var o = (i = n)[0], a = i[1], s = 0; s < r; s++) { var l = e[this.getRawIndex(s)]; l < o && (o = l), l > a && (a = l); } return (i = [o, a]), (this._extent[t] = i), i; }), (t.prototype.getRawDataItem = function (t) { var e = this.getRawIndex(t); if (this._provider.persistent) return this._provider.getItem(e); for (var n = [], i = this._chunks, r = 0; r < i.length; r++) n.push(i[r][e]); return n; }), (t.prototype.clone = function (e, n) { var i, r, o = new t(), a = this._chunks, s = e && V( e, function (t, e) { return (t[e] = !0), t; }, {} ); if (s) for (var l = 0; l < a.length; l++) o._chunks[l] = s[l] ? ((i = a[l]), (r = void 0), (r = i.constructor) === Array ? i.slice() : new r(i)) : a[l]; else o._chunks = a; return ( this._copyCommonProps(o), n || (o._indices = this._cloneIndices()), o._updateGetRawIdx(), o ); }), (t.prototype._copyCommonProps = function (t) { (t._count = this._count), (t._rawCount = this._rawCount), (t._provider = this._provider), (t._dimensions = this._dimensions), (t._extent = T(this._extent)), (t._rawExtent = T(this._rawExtent)); }), (t.prototype._cloneIndices = function () { if (this._indices) { var t = this._indices.constructor, e = void 0; if (t === Array) { var n = this._indices.length; e = new t(n); for (var i = 0; i < n; i++) e[i] = this._indices[i]; } else e = new t(this._indices); return e; } return null; }), (t.prototype._getRawIdxIdentity = function (t) { return t; }), (t.prototype._getRawIdx = function (t) { return t < this._count && t >= 0 ? this._indices[t] : -1; }), (t.prototype._updateGetRawIdx = function () { this.getRawIndex = this._indices ? this._getRawIdx : this._getRawIdxIdentity; }), (t.internalField = (function () { function t(t, e, n, i) { return If(t[i], this._dimensions[i]); } Gf = { arrayRows: t, objectRows: function (t, e, n, i) { return If(t[e], this._dimensions[i]); }, keyedColumns: t, original: function (t, e, n, i) { var r = t && (null == t.value ? t : t.value); return If( r instanceof Array ? r[i] : r, this._dimensions[i] ); }, typedArray: function (t, e, n, i) { return t[i]; }, }; })()), t ); })(), $f = (function () { function t(t) { (this._sourceList = []), (this._storeList = []), (this._upstreamSignList = []), (this._versionSignBase = 0), (this._dirty = !0), (this._sourceHost = t); } return ( (t.prototype.dirty = function () { this._setLocalSource([], []), (this._storeList = []), (this._dirty = !0); }), (t.prototype._setLocalSource = function (t, e) { (this._sourceList = t), (this._upstreamSignList = e), this._versionSignBase++, this._versionSignBase > 9e10 && (this._versionSignBase = 0); }), (t.prototype._getVersionSign = function () { return this._sourceHost.uid + "_" + this._versionSignBase; }), (t.prototype.prepareSource = function () { this._isDirty() && (this._createSource(), (this._dirty = !1)); }), (t.prototype._createSource = function () { this._setLocalSource([], []); var t, e, n = this._sourceHost, i = this._getUpstreamSourceManagers(), r = !!i.length; if (Qf(n)) { var o = n, a = void 0, s = void 0, l = void 0; if (r) { var u = i[0]; u.prepareSource(), (a = (l = u.getSource()).data), (s = l.sourceFormat), (e = [u._getVersionSign()]); } else (s = $((a = o.get("data", !0))) ? Up : Wp), (e = []); var h = this._getSourceMetaRawOption() || {}, c = (l && l.metaRawOption) || {}, p = rt(h.seriesLayoutBy, c.seriesLayoutBy) || null, d = rt(h.sourceHeader, c.sourceHeader), f = rt(h.dimensions, c.dimensions); t = p !== c.seriesLayoutBy || !!d != !!c.sourceHeader || f ? [ tf( a, { seriesLayoutBy: p, sourceHeader: d, dimensions: f, }, s ), ] : []; } else { var g = n; if (r) { var y = this._applyTransform(i); (t = y.sourceList), (e = y.upstreamSignList); } else { (t = [ tf( g.get("source", !0), this._getSourceMetaRawOption(), null ), ]), (e = []); } } this._setLocalSource(t, e); }), (t.prototype._applyTransform = function (t) { var e, n = this._sourceHost, i = n.get("transform", !0), r = n.get("fromTransformResult", !0); if (null != r) { var o = ""; 1 !== t.length && tg(o); } var a, s = [], l = []; return ( E(t, function (t) { t.prepareSource(); var e = t.getSource(r || 0), n = ""; null == r || e || tg(n), s.push(e), l.push(t._getVersionSign()); }), i ? (e = (function (t, e, n) { var i = To(t), r = i.length, o = ""; r || wo(o); for (var a = 0, s = r; a < s; a++) (e = Bf(i[a], e)), a !== s - 1 && (e.length = Math.max( e.length, 1 )); return e; })(i, s, n.componentIndex)) : null != r && (e = [ ((a = s[0]), new Jd({ data: a.data, sourceFormat: a.sourceFormat, seriesLayoutBy: a.seriesLayoutBy, dimensionsDefine: T(a.dimensionsDefine), startIndex: a.startIndex, dimensionsDetectedCount: a.dimensionsDetectedCount, })), ]), { sourceList: e, upstreamSignList: l } ); }), (t.prototype._isDirty = function () { if (this._dirty) return !0; for ( var t = this._getUpstreamSourceManagers(), e = 0; e < t.length; e++ ) { var n = t[e]; if ( n._isDirty() || this._upstreamSignList[e] !== n._getVersionSign() ) return !0; } }), (t.prototype.getSource = function (t) { t = t || 0; var e = this._sourceList[t]; if (!e) { var n = this._getUpstreamSourceManagers(); return n[0] && n[0].getSource(t); } return e; }), (t.prototype.getSharedDataStore = function (t) { var e = t.makeStoreSchema(); return this._innerGetDataStore( e.dimensions, t.source, e.hash ); }), (t.prototype._innerGetDataStore = function (t, e, n) { var i = this._storeList, r = i[0]; r || (r = i[0] = {}); var o = r[n]; if (!o) { var a = this._getUpstreamSourceManagers()[0]; Qf(this._sourceHost) && a ? (o = a._innerGetDataStore(t, e, n)) : (o = new Kf()).initData(new sf(e, t.length), t), (r[n] = o); } return o; }), (t.prototype._getUpstreamSourceManagers = function () { var t = this._sourceHost; if (Qf(t)) { var e = nd(t); return e ? [e.getSourceManager()] : []; } return z( (function (t) { return t.get("transform", !0) || t.get("fromTransformResult", !0) ? Yo( t.ecModel, "dataset", { index: t.get("fromDatasetIndex", !0), id: t.get("fromDatasetId", !0), }, Wo ).models : []; })(t), function (t) { return t.getSourceManager(); } ); }), (t.prototype._getSourceMetaRawOption = function () { var t, e, n, i = this._sourceHost; if (Qf(i)) (t = i.get("seriesLayoutBy", !0)), (e = i.get("sourceHeader", !0)), (n = i.get("dimensions", !0)); else if (!this._getUpstreamSourceManagers().length) { var r = i; (t = r.get("seriesLayoutBy", !0)), (e = r.get("sourceHeader", !0)), (n = r.get("dimensions", !0)); } return { seriesLayoutBy: t, sourceHeader: e, dimensions: n, }; }), t ); })(); function Jf(t) { t.option.transform && ct(t.option.transform); } function Qf(t) { return "series" === t.mainType; } function tg(t) { throw new Error(t); } function eg(t) { var e = t.lineHeight; return null == e ? "line-height:1" : "line-height:" + re(e + "") + "px"; } function ng(t, e) { var n = t.color || "#6e7079", i = t.fontSize || 12, r = t.fontWeight || "400", o = t.color || "#464646", a = t.fontSize || 14, s = t.fontWeight || "900"; return "html" === e ? { nameStyle: "font-size:" + re(i + "") + "px;color:" + re(n) + ";font-weight:" + re(r + ""), valueStyle: "font-size:" + re(a + "") + "px;color:" + re(o) + ";font-weight:" + re(s + ""), } : { nameStyle: { fontSize: i, fill: n, fontWeight: r }, valueStyle: { fontSize: a, fill: o, fontWeight: s }, }; } var ig = [0, 10, 20, 30], rg = ["", "\n", "\n\n", "\n\n\n"]; function og(t, e) { return (e.type = t), e; } function ag(t) { return "section" === t.type; } function sg(t) { return ag(t) ? ug : hg; } function lg(t) { if (ag(t)) { var e = 0, n = t.blocks.length, i = n > 1 || (n > 0 && !t.noHeader); return ( E(t.blocks, function (t) { var n = lg(t); n >= e && (e = n + +(i && (!n || (ag(t) && !t.noHeader)))); }), e ); } return 0; } function ug(t, e, n, i) { var r, o = e.noHeader, a = ((r = lg(e)), { html: ig[r], richText: rg[r] }), s = [], l = e.blocks || []; lt(!l || Y(l)), (l = l || []); var u = t.orderMode; if (e.sortBlocks && u) { l = l.slice(); var h = { valueAsc: "asc", valueDesc: "desc" }; if (_t(h, u)) { var c = new kf(h[u], null); l.sort(function (t, e) { return c.evaluate(t.sortParam, e.sortParam); }); } else "seriesDesc" === u && l.reverse(); } E(l, function (n, r) { var o = e.valueFormatter, l = sg(n)( o ? A(A({}, t), { valueFormatter: o }) : t, n, r > 0 ? a.html : 0, i ); null != l && s.push(l); }); var p = "richText" === t.renderMode ? s.join(a.richText) : pg(i, s.join(""), o ? n : a.html); if (o) return p; var d = mp(e.header, "ordinal", t.useUTC), f = ng(i, t.renderMode).nameStyle, g = eg(i); return "richText" === t.renderMode ? dg(t, d, f) + a.richText + p : pg( i, '
' + re(d) + "
" + p, n ); } function hg(t, e, n, i) { var r = t.renderMode, o = e.noName, a = e.noValue, s = !e.markerType, l = e.name, u = t.useUTC, h = e.valueFormatter || t.valueFormatter || function (t) { return z((t = Y(t) ? t : [t]), function (t, e) { return mp(t, Y(d) ? d[e] : d, u); }); }; if (!o || !a) { var c = s ? "" : t.markupStyleCreator.makeTooltipMarker( e.markerType, e.markerColor || "#333", r ), p = o ? "" : mp(l, "ordinal", u), d = e.valueType, f = a ? [] : h(e.value, e.dataIndex), g = !s || !o, y = !s && o, v = ng(i, r), m = v.nameStyle, x = v.valueStyle; return "richText" === r ? (s ? "" : c) + (o ? "" : dg(t, p, m)) + (a ? "" : (function (t, e, n, i, r) { var o = [r], a = i ? 10 : 20; return ( n && o.push({ padding: [0, 0, 0, a], align: "right", }), t.markupStyleCreator.wrapRichTextStyle( Y(e) ? e.join(" ") : e, o ) ); })(t, f, g, y, x)) : pg( i, (s ? "" : c) + (o ? "" : (function (t, e, n) { return ( '' + re(t) + "" ); })(p, !s, m)) + (a ? "" : (function (t, e, n, i) { var r = n ? "10px" : "20px", o = e ? "float:right;margin-left:" + r : ""; return ( (t = Y(t) ? t : [t]), '' + z(t, function (t) { return re(t); }).join("  ") + "" ); })(f, g, y, x)), n ); } } function cg(t, e, n, i, r, o) { if (t) return sg(t)( { useUTC: r, renderMode: n, orderMode: i, markupStyleCreator: e, valueFormatter: t.valueFormatter, }, t, 0, o ); } function pg(t, e, n) { return ( '
' + e + '
' ); } function dg(t, e, n) { return t.markupStyleCreator.wrapRichTextStyle(e, n); } function fg(t, e) { return Sp(t.getData().getItemVisual(e, "style")[t.visualDrawType]); } function gg(t, e) { var n = t.get("padding"); return null != n ? n : "richText" === e ? [8, 10] : 10; } var yg = (function () { function t() { (this.richTextStyles = {}), (this._nextStyleNameId = mo()); } return ( (t.prototype._generateStyleName = function () { return "__EC_aUTo_" + this._nextStyleNameId++; }), (t.prototype.makeTooltipMarker = function (t, e, n) { var i = "richText" === n ? this._generateStyleName() : null, r = wp({ color: e, type: t, renderMode: n, markerId: i }); return U(r) ? r : ((this.richTextStyles[i] = r.style), r.content); }), (t.prototype.wrapRichTextStyle = function (t, e) { var n = {}; Y(e) ? E(e, function (t) { return A(n, t); }) : A(n, e); var i = this._generateStyleName(); return (this.richTextStyles[i] = n), "{" + i + "|" + t + "}"; }), t ); })(); function vg(t) { var e, n, i, r, o = t.series, a = t.dataIndex, s = t.multipleSeries, l = o.getData(), u = l.mapDimensionsAll("defaultedTooltip"), h = u.length, c = o.getRawValue(a), p = Y(c), d = fg(o, a); if (h > 1 || (p && !h)) { var f = (function (t, e, n, i, r) { var o = e.getData(), a = V( t, function (t, e, n) { var i = o.getDimensionInfo(n); return ( t || (i && !1 !== i.tooltip && null != i.displayName) ); }, !1 ), s = [], l = [], u = []; function h(t, e) { var n = o.getDimensionInfo(e); n && !1 !== n.otherDims.tooltip && (a ? u.push( og("nameValue", { markerType: "subItem", markerColor: r, name: n.displayName, value: t, valueType: n.type, }) ) : (s.push(t), l.push(n.type))); } return ( i.length ? E(i, function (t) { h(mf(o, n, t), t); }) : E(t, h), { inlineValues: s, inlineValueTypes: l, blocks: u } ); })(c, o, a, u, d); (e = f.inlineValues), (n = f.inlineValueTypes), (i = f.blocks), (r = f.inlineValues[0]); } else if (h) { var g = l.getDimensionInfo(u[0]); (r = e = mf(l, a, u[0])), (n = g.type); } else r = e = p ? c[0] : c; var y = No(o), v = (y && o.name) || "", m = l.getName(a), x = s ? v : m; return og("section", { header: v, noHeader: s || !y, sortParam: r, blocks: [ og("nameValue", { markerType: "item", markerColor: d, name: x, noName: !ut(x), value: e, valueType: n, dataIndex: a, }), ].concat(i || []), }); } var mg = Vo(); function xg(t, e) { return t.getName(e) || t.getId(e); } var _g = "__universalTransitionEnabled", bg = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e._selectedDataIndicesMap = {}), e; } return ( n(e, t), (e.prototype.init = function (t, e, n) { (this.seriesIndex = this.componentIndex), (this.dataTask = wf({ count: Sg, reset: Mg })), (this.dataTask.context = { model: this }), this.mergeDefaultAndTheme(t, n), (mg(this).sourceManager = new $f(this)).prepareSource(); var i = this.getInitialData(t, n); Tg(i, this), (this.dataTask.context.data = i), (mg(this).dataBeforeProcessed = i), wg(this), this._initSelectedMapFromData(i); }), (e.prototype.mergeDefaultAndTheme = function (t, e) { var n = Pp(this), i = n ? Rp(t) : {}, r = this.subType; zp.hasClass(r) && (r += "Series"), C(t, e.getTheme().get(this.subType)), C(t, this.getDefaultOption()), Co(t, "label", ["show"]), this.fillDataTextStyle(t.data), n && Op(t, i, n); }), (e.prototype.mergeOption = function (t, e) { (t = C(this.option, t, !0)), this.fillDataTextStyle(t.data); var n = Pp(this); n && Op(this.option, t, n); var i = mg(this).sourceManager; i.dirty(), i.prepareSource(); var r = this.getInitialData(t, e); Tg(r, this), this.dataTask.dirty(), (this.dataTask.context.data = r), (mg(this).dataBeforeProcessed = r), wg(this), this._initSelectedMapFromData(r); }), (e.prototype.fillDataTextStyle = function (t) { if (t && !$(t)) for (var e = ["show"], n = 0; n < t.length; n++) t[n] && t[n].label && Co(t[n], "label", e); }), (e.prototype.getInitialData = function (t, e) {}), (e.prototype.appendData = function (t) { this.getRawData().appendData(t.data); }), (e.prototype.getData = function (t) { var e = Dg(this); if (e) { var n = e.context.data; return null != t && n.getLinkedData ? n.getLinkedData(t) : n; } return mg(this).data; }), (e.prototype.getAllData = function () { var t = this.getData(); return t && t.getLinkedDataAll ? t.getLinkedDataAll() : [{ data: t }]; }), (e.prototype.setData = function (t) { var e = Dg(this); if (e) { var n = e.context; (n.outputData = t), e !== this.dataTask && (n.data = t); } mg(this).data = t; }), (e.prototype.getEncode = function () { var t = this.get("encode", !0); if (t) return yt(t); }), (e.prototype.getSourceManager = function () { return mg(this).sourceManager; }), (e.prototype.getSource = function () { return this.getSourceManager().getSource(); }), (e.prototype.getRawData = function () { return mg(this).dataBeforeProcessed; }), (e.prototype.getColorBy = function () { return this.get("colorBy") || "series"; }), (e.prototype.isColorBySeries = function () { return "series" === this.getColorBy(); }), (e.prototype.getBaseAxis = function () { var t = this.coordinateSystem; return t && t.getBaseAxis && t.getBaseAxis(); }), (e.prototype.formatTooltip = function (t, e, n) { return vg({ series: this, dataIndex: t, multipleSeries: e, }); }), (e.prototype.isAnimationEnabled = function () { var t = this.ecModel; if (r.node && (!t || !t.ssr)) return !1; var e = this.getShallow("animation"); return ( e && this.getData().count() > this.getShallow("animationThreshold") && (e = !1), !!e ); }), (e.prototype.restoreData = function () { this.dataTask.dirty(); }), (e.prototype.getColorFromPalette = function (t, e, n) { var i = this.ecModel, r = cd.prototype.getColorFromPalette.call( this, t, e, n ); return r || (r = i.getColorFromPalette(t, e, n)), r; }), (e.prototype.coordDimToDataDim = function (t) { return this.getRawData().mapDimensionsAll(t); }), (e.prototype.getProgressive = function () { return this.get("progressive"); }), (e.prototype.getProgressiveThreshold = function () { return this.get("progressiveThreshold"); }), (e.prototype.select = function (t, e) { this._innerSelect(this.getData(e), t); }), (e.prototype.unselect = function (t, e) { var n = this.option.selectedMap; if (n) { var i = this.option.selectedMode, r = this.getData(e); if ("series" === i || "all" === n) return ( (this.option.selectedMap = {}), void (this._selectedDataIndicesMap = {}) ); for (var o = 0; o < t.length; o++) { var a = xg(r, t[o]); (n[a] = !1), (this._selectedDataIndicesMap[a] = -1); } } }), (e.prototype.toggleSelect = function (t, e) { for (var n = [], i = 0; i < t.length; i++) (n[0] = t[i]), this.isSelected(t[i], e) ? this.unselect(n, e) : this.select(n, e); }), (e.prototype.getSelectedDataIndices = function () { if ("all" === this.option.selectedMap) return [].slice.call(this.getData().getIndices()); for ( var t = this._selectedDataIndicesMap, e = G(t), n = [], i = 0; i < e.length; i++ ) { var r = t[e[i]]; r >= 0 && n.push(r); } return n; }), (e.prototype.isSelected = function (t, e) { var n = this.option.selectedMap; if (!n) return !1; var i = this.getData(e); return ( ("all" === n || n[xg(i, t)]) && !i.getItemModel(t).get(["select", "disabled"]) ); }), (e.prototype.isUniversalTransitionEnabled = function () { if (this[_g]) return !0; var t = this.option.universalTransition; return !!t && (!0 === t || (t && t.enabled)); }), (e.prototype._innerSelect = function (t, e) { var n, i, r = this.option, o = r.selectedMode, a = e.length; if (o && a) if ("series" === o) r.selectedMap = "all"; else if ("multiple" === o) { q(r.selectedMap) || (r.selectedMap = {}); for (var s = r.selectedMap, l = 0; l < a; l++) { var u = e[l]; (s[(c = xg(t, u))] = !0), (this._selectedDataIndicesMap[c] = t.getRawIndex(u)); } } else if ("single" === o || !0 === o) { var h = e[a - 1], c = xg(t, h); (r.selectedMap = (((n = {})[c] = !0), n)), (this._selectedDataIndicesMap = (((i = {})[c] = t.getRawIndex(h)), i)); } }), (e.prototype._initSelectedMapFromData = function (t) { if (!this.option.selectedMap) { var e = []; t.hasItemOption && t.each(function (n) { var i = t.getRawDataItem(n); i && i.selected && e.push(n); }), e.length > 0 && this._innerSelect(t, e); } }), (e.registerClass = function (t) { return zp.registerClass(t); }), (e.protoInitialize = (function () { var t = e.prototype; (t.type = "series.__base__"), (t.seriesIndex = 0), (t.ignoreStyleOnData = !1), (t.hasSymbolVisual = !1), (t.defaultSymbol = "circle"), (t.visualStyleAccessPath = "itemStyle"), (t.visualDrawType = "fill"); })()), e ); })(zp); function wg(t) { var e = t.name; No(t) || (t.name = (function (t) { var e = t.getRawData(), n = e.mapDimensionsAll("seriesName"), i = []; return ( E(n, function (t) { var n = e.getDimensionInfo(t); n.displayName && i.push(n.displayName); }), i.join(" ") ); })(t) || e); } function Sg(t) { return t.model.getRawData().count(); } function Mg(t) { var e = t.model; return e.setData(e.getRawData().cloneShallow()), Ig; } function Ig(t, e) { e.outputData && t.end > e.outputData.count() && e.model.getRawData().cloneShallow(e.outputData); } function Tg(t, e) { E(vt(t.CHANGABLE_METHODS, t.DOWNSAMPLE_METHODS), function (n) { t.wrapMethod(n, H(Cg, e)); }); } function Cg(t, e) { var n = Dg(t); return n && n.setOutputEnd((e || this).count()), e; } function Dg(t) { var e = (t.ecModel || {}).scheduler, n = e && e.getPipeline(t.uid); if (n) { var i = n.currentTask; if (i) { var r = i.agentStubMap; r && (i = r.get(t.uid)); } return i; } } R(bg, _f), R(bg, cd), Jo(bg, zp); var Ag = (function () { function t() { (this.group = new Br()), (this.uid = Ac("viewComponent")); } return ( (t.prototype.init = function (t, e) {}), (t.prototype.render = function (t, e, n, i) {}), (t.prototype.dispose = function (t, e) {}), (t.prototype.updateView = function (t, e, n, i) {}), (t.prototype.updateLayout = function (t, e, n, i) {}), (t.prototype.updateVisual = function (t, e, n, i) {}), (t.prototype.toggleBlurSeries = function (t, e, n) {}), (t.prototype.eachRendered = function (t) { var e = this.group; e && e.traverse(t); }), t ); })(); function kg() { var t = Vo(); return function (e) { var n = t(e), i = e.pipelineContext, r = !!n.large, o = !!n.progressiveRender, a = (n.large = !(!i || !i.large)), s = (n.progressiveRender = !(!i || !i.progressiveRender)); return !(r === a && o === s) && "reset"; }; } $o(Ag), na(Ag); var Lg = Vo(), Pg = kg(), Og = (function () { function t() { (this.group = new Br()), (this.uid = Ac("viewChart")), (this.renderTask = wf({ plan: Eg, reset: zg })), (this.renderTask.context = { view: this }); } return ( (t.prototype.init = function (t, e) {}), (t.prototype.render = function (t, e, n, i) { 0; }), (t.prototype.highlight = function (t, e, n, i) { var r = t.getData(i && i.dataType); r && Ng(r, i, "emphasis"); }), (t.prototype.downplay = function (t, e, n, i) { var r = t.getData(i && i.dataType); r && Ng(r, i, "normal"); }), (t.prototype.remove = function (t, e) { this.group.removeAll(); }), (t.prototype.dispose = function (t, e) {}), (t.prototype.updateView = function (t, e, n, i) { this.render(t, e, n, i); }), (t.prototype.updateLayout = function (t, e, n, i) { this.render(t, e, n, i); }), (t.prototype.updateVisual = function (t, e, n, i) { this.render(t, e, n, i); }), (t.prototype.eachRendered = function (t) { Jh(this.group, t); }), (t.markUpdateMethod = function (t, e) { Lg(t).updateMethod = e; }), (t.protoInitialize = void (t.prototype.type = "chart")), t ); })(); function Rg(t, e, n) { t && Ql(t) && ("emphasis" === e ? Ol : Rl)(t, n); } function Ng(t, e, n) { var i = zo(t, e), r = e && null != e.highlightKey ? (function (t) { var e = sl[t]; return null == e && al <= 32 && (e = sl[t] = al++), e; })(e.highlightKey) : null; null != i ? E(To(i), function (e) { Rg(t.getItemGraphicEl(e), n, r); }) : t.eachItemGraphicEl(function (t) { Rg(t, n, r); }); } function Eg(t) { return Pg(t.model); } function zg(t) { var e = t.model, n = t.ecModel, i = t.api, r = t.payload, o = e.pipelineContext.progressiveRender, a = t.view, s = r && Lg(r).updateMethod, l = o ? "incrementalPrepareRender" : s && a[s] ? s : "render"; return "render" !== l && a[l](e, n, i, r), Vg[l]; } $o(Og), na(Og); var Vg = { incrementalPrepareRender: { progress: function (t, e) { e.view.incrementalRender( t, e.model, e.ecModel, e.api, e.payload ); }, }, render: { forceFirstProgress: !0, progress: function (t, e) { e.view.render(e.model, e.ecModel, e.api, e.payload); }, }, }, Bg = "\0__throttleOriginMethod", Fg = "\0__throttleRate", Gg = "\0__throttleType"; function Wg(t, e, n) { var i, r, o, a, s, l = 0, u = 0, h = null; function c() { (u = new Date().getTime()), (h = null), t.apply(o, a || []); } e = e || 0; var p = function () { for (var t = [], p = 0; p < arguments.length; p++) t[p] = arguments[p]; (i = new Date().getTime()), (o = this), (a = t); var d = s || e, f = s || n; (s = null), (r = i - (f ? l : u) - d), clearTimeout(h), f ? (h = setTimeout(c, d)) : r >= 0 ? c() : (h = setTimeout(c, -r)), (l = i); }; return ( (p.clear = function () { h && (clearTimeout(h), (h = null)); }), (p.debounceNextCall = function (t) { s = t; }), p ); } function Hg(t, e, n, i) { var r = t[e]; if (r) { var o = r[Bg] || r, a = r[Gg]; if (r[Fg] !== n || a !== i) { if (null == n || !i) return (t[e] = o); ((r = t[e] = Wg(o, n, "debounce" === i))[Bg] = o), (r[Gg] = i), (r[Fg] = n); } return r; } } function Yg(t, e) { var n = t[e]; n && n[Bg] && (n.clear && n.clear(), (t[e] = n[Bg])); } var Xg = Vo(), Ug = { itemStyle: ia(Mc, !0), lineStyle: ia(bc, !0) }, Zg = { lineStyle: "stroke", itemStyle: "fill" }; function jg(t, e) { var n = t.visualStyleMapper || Ug[e]; return ( n || (console.warn("Unknown style type '" + e + "'."), Ug.itemStyle) ); } function qg(t, e) { var n = t.visualDrawType || Zg[e]; return n || (console.warn("Unknown style type '" + e + "'."), "fill"); } var Kg = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { var n = t.getData(), i = t.visualStyleAccessPath || "itemStyle", r = t.getModel(i), o = jg(t, i)(r), a = r.getShallow("decal"); a && (n.setVisual("decal", a), (a.dirty = !0)); var s = qg(t, i), l = o[s], u = X(l) ? l : null, h = "auto" === o.fill || "auto" === o.stroke; if (!o[s] || u || h) { var c = t.getColorFromPalette( t.name, null, e.getSeriesCount() ); o[s] || ((o[s] = c), n.setVisual("colorFromPalette", !0)), (o.fill = "auto" === o.fill || X(o.fill) ? c : o.fill), (o.stroke = "auto" === o.stroke || X(o.stroke) ? c : o.stroke); } if ( (n.setVisual("style", o), n.setVisual("drawType", s), !e.isSeriesFiltered(t) && u) ) return ( n.setVisual("colorFromPalette", !1), { dataEach: function (e, n) { var i = t.getDataParams(n), r = A({}, o); (r[s] = u(i)), e.setItemVisual(n, "style", r); }, } ); }, }, $g = new Cc(), Jg = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { if (!t.ignoreStyleOnData && !e.isSeriesFiltered(t)) { var n = t.getData(), i = t.visualStyleAccessPath || "itemStyle", r = jg(t, i), o = n.getVisual("drawType"); return { dataEach: n.hasItemOption ? function (t, e) { var n = t.getRawDataItem(e); if (n && n[i]) { $g.option = n[i]; var a = r($g); A( t.ensureUniqueItemVisual(e, "style"), a ), $g.option.decal && (t.setItemVisual( e, "decal", $g.option.decal ), ($g.option.decal.dirty = !0)), o in a && t.setItemVisual( e, "colorFromPalette", !1 ); } } : null, }; } }, }, Qg = { performRawSeries: !0, overallReset: function (t) { var e = yt(); t.eachSeries(function (t) { var n = t.getColorBy(); if (!t.isColorBySeries()) { var i = t.type + "-" + n, r = e.get(i); r || ((r = {}), e.set(i, r)), (Xg(t).scope = r); } }), t.eachSeries(function (e) { if (!e.isColorBySeries() && !t.isSeriesFiltered(e)) { var n = e.getRawData(), i = {}, r = e.getData(), o = Xg(e).scope, a = e.visualStyleAccessPath || "itemStyle", s = qg(e, a); r.each(function (t) { var e = r.getRawIndex(t); i[e] = t; }), n.each(function (t) { var a = i[t]; if ( r.getItemVisual(a, "colorFromPalette") ) { var l = r.ensureUniqueItemVisual( a, "style" ), u = n.getName(t) || t + "", h = n.count(); l[s] = e.getColorFromPalette(u, o, h); } }); } }); }, }, ty = Math.PI; var ey = (function () { function t(t, e, n, i) { (this._stageTaskMap = yt()), (this.ecInstance = t), (this.api = e), (n = this._dataProcessorHandlers = n.slice()), (i = this._visualHandlers = i.slice()), (this._allHandlers = n.concat(i)); } return ( (t.prototype.restoreData = function (t, e) { t.restoreData(e), this._stageTaskMap.each(function (t) { var e = t.overallTask; e && e.dirty(); }); }), (t.prototype.getPerformArgs = function (t, e) { if (t.__pipeline) { var n = this._pipelineMap.get(t.__pipeline.id), i = n.context, r = !e && n.progressiveEnabled && (!i || i.progressiveRender) && t.__idxInPipeline > n.blockIndex ? n.step : null, o = i && i.modDataCount; return { step: r, modBy: null != o ? Math.ceil(o / r) : null, modDataCount: o, }; } }), (t.prototype.getPipeline = function (t) { return this._pipelineMap.get(t); }), (t.prototype.updateStreamModes = function (t, e) { var n = this._pipelineMap.get(t.uid), i = t.getData().count(), r = n.progressiveEnabled && e.incrementalPrepareRender && i >= n.threshold, o = t.get("large") && i >= t.get("largeThreshold"), a = "mod" === t.get("progressiveChunkMode") ? i : null; t.pipelineContext = n.context = { progressiveRender: r, modDataCount: a, large: o, }; }), (t.prototype.restorePipelines = function (t) { var e = this, n = (e._pipelineMap = yt()); t.eachSeries(function (t) { var i = t.getProgressive(), r = t.uid; n.set(r, { id: r, head: null, tail: null, threshold: t.getProgressiveThreshold(), progressiveEnabled: i && !(t.preventIncremental && t.preventIncremental()), blockIndex: -1, step: Math.round(i || 700), count: 0, }), e._pipe(t, t.dataTask); }); }), (t.prototype.prepareStageTasks = function () { var t = this._stageTaskMap, e = this.api.getModel(), n = this.api; E( this._allHandlers, function (i) { var r = t.get(i.uid) || t.set(i.uid, {}), o = ""; lt(!(i.reset && i.overallReset), o), i.reset && this._createSeriesStageTask(i, r, e, n), i.overallReset && this._createOverallStageTask(i, r, e, n); }, this ); }), (t.prototype.prepareView = function (t, e, n, i) { var r = t.renderTask, o = r.context; (o.model = e), (o.ecModel = n), (o.api = i), (r.__block = !t.incrementalPrepareRender), this._pipe(e, r); }), (t.prototype.performDataProcessorTasks = function (t, e) { this._performStageTasks(this._dataProcessorHandlers, t, e, { block: !0, }); }), (t.prototype.performVisualTasks = function (t, e, n) { this._performStageTasks(this._visualHandlers, t, e, n); }), (t.prototype._performStageTasks = function (t, e, n, i) { i = i || {}; var r = !1, o = this; function a(t, e) { return ( t.setDirty && (!t.dirtyMap || t.dirtyMap.get(e.__pipeline.id)) ); } E(t, function (t, s) { if (!i.visualType || i.visualType === t.visualType) { var l = o._stageTaskMap.get(t.uid), u = l.seriesTaskMap, h = l.overallTask; if (h) { var c, p = h.agentStubMap; p.each(function (t) { a(i, t) && (t.dirty(), (c = !0)); }), c && h.dirty(), o.updatePayload(h, n); var d = o.getPerformArgs(h, i.block); p.each(function (t) { t.perform(d); }), h.perform(d) && (r = !0); } else u && u.each(function (s, l) { a(i, s) && s.dirty(); var u = o.getPerformArgs(s, i.block); (u.skip = !t.performRawSeries && e.isSeriesFiltered(s.context.model)), o.updatePayload(s, n), s.perform(u) && (r = !0); }); } }), (this.unfinished = r || this.unfinished); }), (t.prototype.performSeriesTasks = function (t) { var e; t.eachSeries(function (t) { e = t.dataTask.perform() || e; }), (this.unfinished = e || this.unfinished); }), (t.prototype.plan = function () { this._pipelineMap.each(function (t) { var e = t.tail; do { if (e.__block) { t.blockIndex = e.__idxInPipeline; break; } e = e.getUpstream(); } while (e); }); }), (t.prototype.updatePayload = function (t, e) { "remain" !== e && (t.context.payload = e); }), (t.prototype._createSeriesStageTask = function (t, e, n, i) { var r = this, o = e.seriesTaskMap, a = (e.seriesTaskMap = yt()), s = t.seriesType, l = t.getTargetSeries; function u(e) { var s = e.uid, l = a.set( s, (o && o.get(s)) || wf({ plan: ay, reset: sy, count: hy }) ); (l.context = { model: e, ecModel: n, api: i, useClearVisual: t.isVisual && !t.isLayout, plan: t.plan, reset: t.reset, scheduler: r, }), r._pipe(e, l); } t.createOnAllSeries ? n.eachRawSeries(u) : s ? n.eachRawSeriesByType(s, u) : l && l(n, i).each(u); }), (t.prototype._createOverallStageTask = function (t, e, n, i) { var r = this, o = (e.overallTask = e.overallTask || wf({ reset: ny })); o.context = { ecModel: n, api: i, overallReset: t.overallReset, scheduler: r, }; var a = o.agentStubMap, s = (o.agentStubMap = yt()), l = t.seriesType, u = t.getTargetSeries, h = !0, c = !1, p = ""; function d(t) { var e = t.uid, n = s.set( e, (a && a.get(e)) || ((c = !0), wf({ reset: iy, onDirty: oy })) ); (n.context = { model: t, overallProgress: h }), (n.agent = o), (n.__block = h), r._pipe(t, n); } lt(!t.createOnAllSeries, p), l ? n.eachRawSeriesByType(l, d) : u ? u(n, i).each(d) : ((h = !1), E(n.getSeries(), d)), c && o.dirty(); }), (t.prototype._pipe = function (t, e) { var n = t.uid, i = this._pipelineMap.get(n); !i.head && (i.head = e), i.tail && i.tail.pipe(e), (i.tail = e), (e.__idxInPipeline = i.count++), (e.__pipeline = i); }), (t.wrapStageHandler = function (t, e) { return ( X(t) && (t = { overallReset: t, seriesType: cy(t) }), (t.uid = Ac("stageHandler")), e && (t.visualType = e), t ); }), t ); })(); function ny(t) { t.overallReset(t.ecModel, t.api, t.payload); } function iy(t) { return t.overallProgress && ry; } function ry() { this.agent.dirty(), this.getDownstream().dirty(); } function oy() { this.agent && this.agent.dirty(); } function ay(t) { return t.plan ? t.plan(t.model, t.ecModel, t.api, t.payload) : null; } function sy(t) { t.useClearVisual && t.data.clearAllVisual(); var e = (t.resetDefines = To( t.reset(t.model, t.ecModel, t.api, t.payload) )); return e.length > 1 ? z(e, function (t, e) { return uy(e); }) : ly; } var ly = uy(0); function uy(t) { return function (e, n) { var i = n.data, r = n.resetDefines[t]; if (r && r.dataEach) for (var o = e.start; o < e.end; o++) r.dataEach(i, o); else r && r.progress && r.progress(e, i); }; } function hy(t) { return t.data.count(); } function cy(t) { py = null; try { t(dy, fy); } catch (t) {} return py; } var py, dy = {}, fy = {}; function gy(t, e) { for (var n in e.prototype) t[n] = bt; } gy(dy, gd), gy(fy, _d), (dy.eachSeriesByType = dy.eachRawSeriesByType = function (t) { py = t; }), (dy.eachComponent = function (t) { "series" === t.mainType && t.subType && (py = t.subType); }); var yy = [ "#37A2DA", "#32C5E9", "#67E0E3", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#E062AE", "#E690D1", "#e7bcf3", "#9d96f5", "#8378EA", "#96BFFF", ], vy = { color: yy, colorLayer: [ ["#37A2DA", "#ffd85c", "#fd7b5f"], [ "#37A2DA", "#67E0E3", "#FFDB5C", "#ff9f7f", "#E062AE", "#9d96f5", ], [ "#37A2DA", "#32C5E9", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#e7bcf3", "#8378EA", "#96BFFF", ], yy, ], }, my = "#B9B8CE", xy = "#100C2A", _y = function () { return { axisLine: { lineStyle: { color: my } }, splitLine: { lineStyle: { color: "#484753" } }, splitArea: { areaStyle: { color: [ "rgba(255,255,255,0.02)", "rgba(255,255,255,0.05)", ], }, }, minorSplitLine: { lineStyle: { color: "#20203B" } }, }; }, by = [ "#4992ff", "#7cffb2", "#fddd60", "#ff6e76", "#58d9f9", "#05c091", "#ff8a45", "#8d48e3", "#dd79ff", ], wy = { darkMode: !0, color: by, backgroundColor: xy, axisPointer: { lineStyle: { color: "#817f91" }, crossStyle: { color: "#817f91" }, label: { color: "#fff" }, }, legend: { textStyle: { color: my }, pageTextStyle: { color: my } }, textStyle: { color: my }, title: { textStyle: { color: "#EEF1FA" }, subtextStyle: { color: "#B9B8CE" }, }, toolbox: { iconStyle: { borderColor: my } }, dataZoom: { borderColor: "#71708A", textStyle: { color: my }, brushStyle: { color: "rgba(135,163,206,0.3)" }, handleStyle: { color: "#353450", borderColor: "#C5CBE3" }, moveHandleStyle: { color: "#B0B6C3", opacity: 0.3 }, fillerColor: "rgba(135,163,206,0.2)", emphasis: { handleStyle: { borderColor: "#91B7F2", color: "#4D587D" }, moveHandleStyle: { color: "#636D9A", opacity: 0.7 }, }, dataBackground: { lineStyle: { color: "#71708A", width: 1 }, areaStyle: { color: "#71708A" }, }, selectedDataBackground: { lineStyle: { color: "#87A3CE" }, areaStyle: { color: "#87A3CE" }, }, }, visualMap: { textStyle: { color: my } }, timeline: { lineStyle: { color: my }, label: { color: my }, controlStyle: { color: my, borderColor: my }, }, calendar: { itemStyle: { color: xy }, dayLabel: { color: my }, monthLabel: { color: my }, yearLabel: { color: my }, }, timeAxis: _y(), logAxis: _y(), valueAxis: _y(), categoryAxis: _y(), line: { symbol: "circle" }, graph: { color: by }, gauge: { title: { color: my }, axisLine: { lineStyle: { color: [[1, "rgba(207,212,219,0.2)"]] }, }, axisLabel: { color: my }, detail: { color: "#EEF1FA" }, }, candlestick: { itemStyle: { color: "#f64e56", color0: "#54ea92", borderColor: "#f64e56", borderColor0: "#54ea92", }, }, }; wy.categoryAxis.splitLine.show = !1; var Sy = (function () { function t() {} return ( (t.prototype.normalizeQuery = function (t) { var e = {}, n = {}, i = {}; if (U(t)) { var r = Ko(t); (e.mainType = r.main || null), (e.subType = r.sub || null); } else { var o = ["Index", "Name", "Id"], a = { name: 1, dataIndex: 1, dataType: 1 }; E(t, function (t, r) { for (var s = !1, l = 0; l < o.length; l++) { var u = o[l], h = r.lastIndexOf(u); if (h > 0 && h === r.length - u.length) { var c = r.slice(0, h); "data" !== c && ((e.mainType = c), (e[u.toLowerCase()] = t), (s = !0)); } } a.hasOwnProperty(r) && ((n[r] = t), (s = !0)), s || (i[r] = t); }); } return { cptQuery: e, dataQuery: n, otherQuery: i }; }), (t.prototype.filter = function (t, e) { var n = this.eventInfo; if (!n) return !0; var i = n.targetEl, r = n.packedEvent, o = n.model, a = n.view; if (!o || !a) return !0; var s = e.cptQuery, l = e.dataQuery; return ( u(s, o, "mainType") && u(s, o, "subType") && u(s, o, "index", "componentIndex") && u(s, o, "name") && u(s, o, "id") && u(l, r, "name") && u(l, r, "dataIndex") && u(l, r, "dataType") && (!a.filterForExposedEvent || a.filterForExposedEvent(t, e.otherQuery, i, r)) ); function u(t, e, n, i) { return null == t[n] || e[i || n] === t[n]; } }), (t.prototype.afterTrigger = function () { this.eventInfo = null; }), t ); })(), My = ["symbol", "symbolSize", "symbolRotate", "symbolOffset"], Iy = My.concat(["symbolKeepAspect"]), Ty = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { var n = t.getData(); if ( (t.legendIcon && n.setVisual("legendIcon", t.legendIcon), t.hasSymbolVisual) ) { for ( var i = {}, r = {}, o = !1, a = 0; a < My.length; a++ ) { var s = My[a], l = t.get(s); X(l) ? ((o = !0), (r[s] = l)) : (i[s] = l); } if ( ((i.symbol = i.symbol || t.defaultSymbol), n.setVisual( A( { legendIcon: t.legendIcon || i.symbol, symbolKeepAspect: t.get("symbolKeepAspect"), }, i ) ), !e.isSeriesFiltered(t)) ) { var u = G(r); return { dataEach: o ? function (e, n) { for ( var i = t.getRawValue(n), o = t.getDataParams(n), a = 0; a < u.length; a++ ) { var s = u[a]; e.setItemVisual(n, s, r[s](i, o)); } } : null, }; } } }, }, Cy = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { if (t.hasSymbolVisual && !e.isSeriesFiltered(t)) return { dataEach: t.getData().hasItemOption ? function (t, e) { for ( var n = t.getItemModel(e), i = 0; i < Iy.length; i++ ) { var r = Iy[i], o = n.getShallow(r, !0); null != o && t.setItemVisual(e, r, o); } } : null, }; }, }; function Dy(t, e, n) { switch (n) { case "color": return t.getItemVisual(e, "style")[t.getVisual("drawType")]; case "opacity": return t.getItemVisual(e, "style").opacity; case "symbol": case "symbolSize": case "liftZ": return t.getItemVisual(e, n); } } function Ay(t, e) { switch (e) { case "color": return t.getVisual("style")[t.getVisual("drawType")]; case "opacity": return t.getVisual("style").opacity; case "symbol": case "symbolSize": case "liftZ": return t.getVisual(e); } } function ky(t, e, n, i) { switch (n) { case "color": (t.ensureUniqueItemVisual(e, "style")[t.getVisual("drawType")] = i), t.setItemVisual(e, "colorFromPalette", !1); break; case "opacity": t.ensureUniqueItemVisual(e, "style").opacity = i; break; case "symbol": case "symbolSize": case "liftZ": t.setItemVisual(e, n, i); } } function Ly(t, e) { function n(e, n) { var i = []; return ( e.eachComponent( { mainType: "series", subType: t, query: n }, function (t) { i.push(t.seriesIndex); } ), i ); } E( [ [t + "ToggleSelect", "toggleSelect"], [t + "Select", "select"], [t + "UnSelect", "unselect"], ], function (t) { e(t[0], function (e, i, r) { (e = A({}, e)), r.dispatchAction( A(e, { type: t[1], seriesIndex: n(i, e) }) ); }); } ); } function Py(t, e, n, i, r) { var o = t + e; n.isSilent(o) || i.eachComponent( { mainType: "series", subType: "pie" }, function (t) { for ( var e = t.seriesIndex, i = t.option.selectedMap, a = r.selected, s = 0; s < a.length; s++ ) if (a[s].seriesIndex === e) { var l = t.getData(), u = zo(l, r.fromActionPayload); n.trigger(o, { type: o, seriesId: t.id, name: Y(u) ? l.getName(u[0]) : l.getName(u), selected: U(i) ? i : A({}, i), }); } } ); } function Oy(t, e, n) { for (var i; t && (!e(t) || ((i = t), !n)); ) t = t.__hostTarget || t.parent; return i; } var Ry = Math.round(9 * Math.random()), Ny = "function" == typeof Object.defineProperty, Ey = (function () { function t() { this._id = "__ec_inner_" + Ry++; } return ( (t.prototype.get = function (t) { return this._guard(t)[this._id]; }), (t.prototype.set = function (t, e) { var n = this._guard(t); return ( Ny ? Object.defineProperty(n, this._id, { value: e, enumerable: !1, configurable: !0, }) : (n[this._id] = e), this ); }), (t.prototype.delete = function (t) { return ( !!this.has(t) && (delete this._guard(t)[this._id], !0) ); }), (t.prototype.has = function (t) { return !!this._guard(t)[this._id]; }), (t.prototype._guard = function (t) { if (t !== Object(t)) throw TypeError( "Value of WeakMap is not a non-null object." ); return t; }), t ); })(), zy = ks.extend({ type: "triangle", shape: { cx: 0, cy: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.cx, i = e.cy, r = e.width / 2, o = e.height / 2; t.moveTo(n, i - o), t.lineTo(n + r, i + o), t.lineTo(n - r, i + o), t.closePath(); }, }), Vy = ks.extend({ type: "diamond", shape: { cx: 0, cy: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.cx, i = e.cy, r = e.width / 2, o = e.height / 2; t.moveTo(n, i - o), t.lineTo(n + r, i), t.lineTo(n, i + o), t.lineTo(n - r, i), t.closePath(); }, }), By = ks.extend({ type: "pin", shape: { x: 0, y: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.x, i = e.y, r = (e.width / 5) * 3, o = Math.max(r, e.height), a = r / 2, s = (a * a) / (o - a), l = i - o + a + s, u = Math.asin(s / a), h = Math.cos(u) * a, c = Math.sin(u), p = Math.cos(u), d = 0.6 * a, f = 0.7 * a; t.moveTo(n - h, l + s), t.arc(n, l, a, Math.PI - u, 2 * Math.PI + u), t.bezierCurveTo( n + h - c * d, l + s + p * d, n, i - f, n, i ), t.bezierCurveTo( n, i - f, n - h + c * d, l + s + p * d, n - h, l + s ), t.closePath(); }, }), Fy = ks.extend({ type: "arrow", shape: { x: 0, y: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.height, i = e.width, r = e.x, o = e.y, a = (i / 3) * 2; t.moveTo(r, o), t.lineTo(r + a, o + n), t.lineTo(r, o + (n / 4) * 3), t.lineTo(r - a, o + n), t.lineTo(r, o), t.closePath(); }, }), Gy = { line: function (t, e, n, i, r) { (r.x1 = t), (r.y1 = e + i / 2), (r.x2 = t + n), (r.y2 = e + i / 2); }, rect: function (t, e, n, i, r) { (r.x = t), (r.y = e), (r.width = n), (r.height = i); }, roundRect: function (t, e, n, i, r) { (r.x = t), (r.y = e), (r.width = n), (r.height = i), (r.r = Math.min(n, i) / 4); }, square: function (t, e, n, i, r) { var o = Math.min(n, i); (r.x = t), (r.y = e), (r.width = o), (r.height = o); }, circle: function (t, e, n, i, r) { (r.cx = t + n / 2), (r.cy = e + i / 2), (r.r = Math.min(n, i) / 2); }, diamond: function (t, e, n, i, r) { (r.cx = t + n / 2), (r.cy = e + i / 2), (r.width = n), (r.height = i); }, pin: function (t, e, n, i, r) { (r.x = t + n / 2), (r.y = e + i / 2), (r.width = n), (r.height = i); }, arrow: function (t, e, n, i, r) { (r.x = t + n / 2), (r.y = e + i / 2), (r.width = n), (r.height = i); }, triangle: function (t, e, n, i, r) { (r.cx = t + n / 2), (r.cy = e + i / 2), (r.width = n), (r.height = i); }, }, Wy = {}; E( { line: Ku, rect: Ws, roundRect: Ws, square: Ws, circle: Su, diamond: Vy, pin: By, arrow: Fy, triangle: zy, }, function (t, e) { Wy[e] = new t(); } ); var Hy = ks.extend({ type: "symbol", shape: { symbolType: "", x: 0, y: 0, width: 0, height: 0 }, calculateTextPosition: function (t, e, n) { var i = Dr(t, e, n), r = this.shape; return ( r && "pin" === r.symbolType && "inside" === e.position && (i.y = n.y + 0.4 * n.height), i ); }, buildPath: function (t, e, n) { var i = e.symbolType; if ("none" !== i) { var r = Wy[i]; r || (r = Wy[(i = "rect")]), Gy[i](e.x, e.y, e.width, e.height, r.shape), r.buildPath(t, r.shape, n); } }, }); function Yy(t, e) { if ("image" !== this.type) { var n = this.style; this.__isEmptyBrush ? ((n.stroke = t), (n.fill = e || "#fff"), (n.lineWidth = 2)) : "line" === this.shape.symbolType ? (n.stroke = t) : (n.fill = t), this.markRedraw(); } } function Xy(t, e, n, i, r, o, a) { var s, l = 0 === t.indexOf("empty"); return ( l && (t = t.substr(5, 1).toLowerCase() + t.substr(6)), ((s = 0 === t.indexOf("image://") ? Oh(t.slice(8), new ze(e, n, i, r), a ? "center" : "cover") : 0 === t.indexOf("path://") ? Ph( t.slice(7), {}, new ze(e, n, i, r), a ? "center" : "cover" ) : new Hy({ shape: { symbolType: t, x: e, y: n, width: i, height: r, }, })).__isEmptyBrush = l), (s.setColor = Yy), o && s.setColor(o), s ); } function Uy(t) { return Y(t) || (t = [+t, +t]), [t[0] || 0, t[1] || 0]; } function Zy(t, e) { if (null != t) return ( Y(t) || (t = [t, t]), [$r(t[0], e[0]) || 0, $r(rt(t[1], t[0]), e[1]) || 0] ); } function jy(t) { return isFinite(t); } function qy(t, e, n) { for ( var i = "radial" === e.type ? (function (t, e, n) { var i = n.width, r = n.height, o = Math.min(i, r), a = null == e.x ? 0.5 : e.x, s = null == e.y ? 0.5 : e.y, l = null == e.r ? 0.5 : e.r; return ( e.global || ((a = a * i + n.x), (s = s * r + n.y), (l *= o)), (a = jy(a) ? a : 0.5), (s = jy(s) ? s : 0.5), (l = l >= 0 && jy(l) ? l : 0.5), t.createRadialGradient(a, s, 0, a, s, l) ); })(t, e, n) : (function (t, e, n) { var i = null == e.x ? 0 : e.x, r = null == e.x2 ? 1 : e.x2, o = null == e.y ? 0 : e.y, a = null == e.y2 ? 0 : e.y2; return ( e.global || ((i = i * n.width + n.x), (r = r * n.width + n.x), (o = o * n.height + n.y), (a = a * n.height + n.y)), (i = jy(i) ? i : 0), (r = jy(r) ? r : 1), (o = jy(o) ? o : 0), (a = jy(a) ? a : 0), t.createLinearGradient(i, o, r, a) ); })(t, e, n), r = e.colorStops, o = 0; o < r.length; o++ ) i.addColorStop(r[o].offset, r[o].color); return i; } function Ky(t) { return parseInt(t, 10); } function $y(t, e, n) { var i = ["width", "height"][e], r = ["clientWidth", "clientHeight"][e], o = ["paddingLeft", "paddingTop"][e], a = ["paddingRight", "paddingBottom"][e]; if (null != n[i] && "auto" !== n[i]) return parseFloat(n[i]); var s = document.defaultView.getComputedStyle(t); return ( ((t[r] || Ky(s[i]) || Ky(t.style[i])) - (Ky(s[o]) || 0) - (Ky(s[a]) || 0)) | 0 ); } function Jy(t) { var e, n, i = t.style, r = i.lineDash && i.lineWidth > 0 && ((e = i.lineDash), (n = i.lineWidth), e && "solid" !== e && n > 0 ? "dashed" === e ? [4 * n, 2 * n] : "dotted" === e ? [n] : j(e) ? [e] : Y(e) ? e : null : null), o = i.lineDashOffset; if (r) { var a = i.strokeNoScale && t.getLineScale ? t.getLineScale() : 1; a && 1 !== a && ((r = z(r, function (t) { return t / a; })), (o /= a)); } return [r, o]; } var Qy = new hs(!0); function tv(t) { var e = t.stroke; return !(null == e || "none" === e || !(t.lineWidth > 0)); } function ev(t) { return "string" == typeof t && "none" !== t; } function nv(t) { var e = t.fill; return null != e && "none" !== e; } function iv(t, e) { if (null != e.fillOpacity && 1 !== e.fillOpacity) { var n = t.globalAlpha; (t.globalAlpha = e.fillOpacity * e.opacity), t.fill(), (t.globalAlpha = n); } else t.fill(); } function rv(t, e) { if (null != e.strokeOpacity && 1 !== e.strokeOpacity) { var n = t.globalAlpha; (t.globalAlpha = e.strokeOpacity * e.opacity), t.stroke(), (t.globalAlpha = n); } else t.stroke(); } function ov(t, e, n) { var i = la(e.image, e.__image, n); if (ha(i)) { var r = t.createPattern(i, e.repeat || "repeat"); if ("function" == typeof DOMMatrix && r && r.setTransform) { var o = new DOMMatrix(); o.translateSelf(e.x || 0, e.y || 0), o.rotateSelf(0, 0, (e.rotation || 0) * wt), o.scaleSelf(e.scaleX || 1, e.scaleY || 1), r.setTransform(o); } return r; } } var av = ["shadowBlur", "shadowOffsetX", "shadowOffsetY"], sv = [ ["lineCap", "butt"], ["lineJoin", "miter"], ["miterLimit", 10], ]; function lv(t, e, n, i, r) { var o = !1; if (!i && e === (n = n || {})) return !1; if (i || e.opacity !== n.opacity) { cv(t, r), (o = !0); var a = Math.max(Math.min(e.opacity, 1), 0); t.globalAlpha = isNaN(a) ? Ma.opacity : a; } (i || e.blend !== n.blend) && (o || (cv(t, r), (o = !0)), (t.globalCompositeOperation = e.blend || Ma.blend)); for (var s = 0; s < av.length; s++) { var l = av[s]; (i || e[l] !== n[l]) && (o || (cv(t, r), (o = !0)), (t[l] = t.dpr * (e[l] || 0))); } return ( (i || e.shadowColor !== n.shadowColor) && (o || (cv(t, r), (o = !0)), (t.shadowColor = e.shadowColor || Ma.shadowColor)), o ); } function uv(t, e, n, i, r) { var o = pv(e, r.inHover), a = i ? null : (n && pv(n, r.inHover)) || {}; if (o === a) return !1; var s = lv(t, o, a, i, r); if ( ((i || o.fill !== a.fill) && (s || (cv(t, r), (s = !0)), ev(o.fill) && (t.fillStyle = o.fill)), (i || o.stroke !== a.stroke) && (s || (cv(t, r), (s = !0)), ev(o.stroke) && (t.strokeStyle = o.stroke)), (i || o.opacity !== a.opacity) && (s || (cv(t, r), (s = !0)), (t.globalAlpha = null == o.opacity ? 1 : o.opacity)), e.hasStroke()) ) { var l = o.lineWidth / (o.strokeNoScale && e.getLineScale ? e.getLineScale() : 1); t.lineWidth !== l && (s || (cv(t, r), (s = !0)), (t.lineWidth = l)); } for (var u = 0; u < sv.length; u++) { var h = sv[u], c = h[0]; (i || o[c] !== a[c]) && (s || (cv(t, r), (s = !0)), (t[c] = o[c] || h[1])); } return s; } function hv(t, e) { var n = e.transform, i = t.dpr || 1; n ? t.setTransform( i * n[0], i * n[1], i * n[2], i * n[3], i * n[4], i * n[5] ) : t.setTransform(i, 0, 0, i, 0, 0); } function cv(t, e) { e.batchFill && t.fill(), e.batchStroke && t.stroke(), (e.batchFill = ""), (e.batchStroke = ""); } function pv(t, e) { return (e && t.__hoverStyle) || t.style; } function dv(t, e) { fv(t, e, { inHover: !1, viewWidth: 0, viewHeight: 0 }, !0); } function fv(t, e, n, i) { var r = e.transform; if (!e.shouldBePainted(n.viewWidth, n.viewHeight, !1, !1)) return (e.__dirty &= -2), void (e.__isRendered = !1); var o = e.__clipPaths, s = n.prevElClipPaths, l = !1, u = !1; if ( ((s && !(function (t, e) { if (t === e || (!t && !e)) return !1; if (!t || !e || t.length !== e.length) return !0; for (var n = 0; n < t.length; n++) if (t[n] !== e[n]) return !0; return !1; })(o, s)) || (s && s.length && (cv(t, n), t.restore(), (u = l = !0), (n.prevElClipPaths = null), (n.allClipped = !1), (n.prevEl = null)), o && o.length && (cv(t, n), t.save(), (function (t, e, n) { for (var i = !1, r = 0; r < t.length; r++) { var o = t[r]; (i = i || o.isZeroArea()), hv(e, o), e.beginPath(), o.buildPath(e, o.shape), e.clip(); } n.allClipped = i; })(o, t, n), (l = !0)), (n.prevElClipPaths = o)), n.allClipped) ) e.__isRendered = !1; else { e.beforeBrush && e.beforeBrush(), e.innerBeforeBrush(); var h = n.prevEl; h || (u = l = !0); var c, p, d = e instanceof ks && e.autoBatch && (function (t) { var e = nv(t), n = tv(t); return !( t.lineDash || !(+e ^ +n) || (e && "string" != typeof t.fill) || (n && "string" != typeof t.stroke) || t.strokePercent < 1 || t.strokeOpacity < 1 || t.fillOpacity < 1 ); })(e.style); l || ((c = r), (p = h.transform), c && p ? c[0] !== p[0] || c[1] !== p[1] || c[2] !== p[2] || c[3] !== p[3] || c[4] !== p[4] || c[5] !== p[5] : c || p) ? (cv(t, n), hv(t, e)) : d || cv(t, n); var f = pv(e, n.inHover); e instanceof ks ? (1 !== n.lastDrawType && ((u = !0), (n.lastDrawType = 1)), uv(t, e, h, u, n), (d && (n.batchFill || n.batchStroke)) || t.beginPath(), (function (t, e, n, i) { var r, o = tv(n), a = nv(n), s = n.strokePercent, l = s < 1, u = !e.path; (e.silent && !l) || !u || e.createPathProxy(); var h = e.path || Qy, c = e.__dirty; if (!i) { var p = n.fill, d = n.stroke, f = a && !!p.colorStops, g = o && !!d.colorStops, y = a && !!p.image, v = o && !!d.image, m = void 0, x = void 0, _ = void 0, b = void 0, w = void 0; (f || g) && (w = e.getBoundingRect()), f && ((m = c ? qy(t, p, w) : e.__canvasFillGradient), (e.__canvasFillGradient = m)), g && ((x = c ? qy(t, d, w) : e.__canvasStrokeGradient), (e.__canvasStrokeGradient = x)), y && ((_ = c || !e.__canvasFillPattern ? ov(t, p, e) : e.__canvasFillPattern), (e.__canvasFillPattern = _)), v && ((b = c || !e.__canvasStrokePattern ? ov(t, d, e) : e.__canvasStrokePattern), (e.__canvasStrokePattern = _)), f ? (t.fillStyle = m) : y && (_ ? (t.fillStyle = _) : (a = !1)), g ? (t.strokeStyle = x) : v && (b ? (t.strokeStyle = b) : (o = !1)); } var S, M, I = e.getGlobalScale(); h.setScale(I[0], I[1], e.segmentIgnoreThreshold), t.setLineDash && n.lineDash && ((S = (r = Jy(e))[0]), (M = r[1])); var T = !0; (u || 4 & c) && (h.setDPR(t.dpr), l ? h.setContext(null) : (h.setContext(t), (T = !1)), h.reset(), e.buildPath(h, e.shape, i), h.toStatic(), e.pathUpdated()), T && h.rebuildPath(t, l ? s : 1), S && (t.setLineDash(S), (t.lineDashOffset = M)), i || (n.strokeFirst ? (o && rv(t, n), a && iv(t, n)) : (a && iv(t, n), o && rv(t, n))), S && t.setLineDash([]); })(t, e, f, d), d && ((n.batchFill = f.fill || ""), (n.batchStroke = f.stroke || ""))) : e instanceof Ps ? (3 !== n.lastDrawType && ((u = !0), (n.lastDrawType = 3)), uv(t, e, h, u, n), (function (t, e, n) { var i, r = n.text; if ((null != r && (r += ""), r)) { (t.font = n.font || a), (t.textAlign = n.textAlign), (t.textBaseline = n.textBaseline); var o = void 0, s = void 0; t.setLineDash && n.lineDash && ((o = (i = Jy(e))[0]), (s = i[1])), o && (t.setLineDash(o), (t.lineDashOffset = s)), n.strokeFirst ? (tv(n) && t.strokeText(r, n.x, n.y), nv(n) && t.fillText(r, n.x, n.y)) : (nv(n) && t.fillText(r, n.x, n.y), tv(n) && t.strokeText(r, n.x, n.y)), o && t.setLineDash([]); } })(t, e, f)) : e instanceof Ns ? (2 !== n.lastDrawType && ((u = !0), (n.lastDrawType = 2)), (function (t, e, n, i, r) { lv(t, pv(e, r.inHover), n && pv(n, r.inHover), i, r); })(t, e, h, u, n), (function (t, e, n) { var i = (e.__image = la(n.image, e.__image, e, e.onload)); if (i && ha(i)) { var r = n.x || 0, o = n.y || 0, a = e.getWidth(), s = e.getHeight(), l = i.width / i.height; if ( (null == a && null != s ? (a = s * l) : null == s && null != a ? (s = a / l) : null == a && null == s && ((a = i.width), (s = i.height)), n.sWidth && n.sHeight) ) { var u = n.sx || 0, h = n.sy || 0; t.drawImage( i, u, h, n.sWidth, n.sHeight, r, o, a, s ); } else if (n.sx && n.sy) { var c = a - (u = n.sx), p = s - (h = n.sy); t.drawImage(i, u, h, c, p, r, o, a, s); } else t.drawImage(i, r, o, a, s); } })(t, e, f)) : e.getTemporalDisplayables && (4 !== n.lastDrawType && ((u = !0), (n.lastDrawType = 4)), (function (t, e, n) { var i = e.getDisplayables(), r = e.getTemporalDisplayables(); t.save(); var o, a, s = { prevElClipPaths: null, prevEl: null, allClipped: !1, viewWidth: n.viewWidth, viewHeight: n.viewHeight, inHover: n.inHover, }; for (o = e.getCursor(), a = i.length; o < a; o++) { (h = i[o]).beforeBrush && h.beforeBrush(), h.innerBeforeBrush(), fv(t, h, s, o === a - 1), h.innerAfterBrush(), h.afterBrush && h.afterBrush(), (s.prevEl = h); } for (var l = 0, u = r.length; l < u; l++) { var h; (h = r[l]).beforeBrush && h.beforeBrush(), h.innerBeforeBrush(), fv(t, h, s, l === u - 1), h.innerAfterBrush(), h.afterBrush && h.afterBrush(), (s.prevEl = h); } e.clearTemporalDisplayables(), (e.notClear = !0), t.restore(); })(t, e, n)), d && i && cv(t, n), e.innerAfterBrush(), e.afterBrush && e.afterBrush(), (n.prevEl = e), (e.__dirty = 0), (e.__isRendered = !0); } } var gv = new Ey(), yv = new En(100), vv = [ "symbol", "symbolSize", "symbolKeepAspect", "color", "backgroundColor", "dashArrayX", "dashArrayY", "maxTileWidth", "maxTileHeight", ]; function mv(t, e) { if ("none" === t) return null; var n = e.getDevicePixelRatio(), i = e.getZr(), r = "svg" === i.painter.type; t.dirty && gv.delete(t); var o = gv.get(t); if (o) return o; var a = k(t, { symbol: "rect", symbolSize: 1, symbolKeepAspect: !0, color: "rgba(0, 0, 0, 0.2)", backgroundColor: null, dashArrayX: 5, dashArrayY: 5, rotation: 0, maxTileWidth: 512, maxTileHeight: 512, }); "none" === a.backgroundColor && (a.backgroundColor = null); var s = { repeat: "repeat" }; return ( (function (t) { for (var e, o = [n], s = !0, l = 0; l < vv.length; ++l) { var u = a[vv[l]]; if ( null != u && !Y(u) && !U(u) && !j(u) && "boolean" != typeof u ) { s = !1; break; } o.push(u); } if (s) { e = o.join(",") + (r ? "-svg" : ""); var c = yv.get(e); c && (r ? (t.svgElement = c) : (t.image = c)); } var p, d = _v(a.dashArrayX), f = (function (t) { if (!t || ("object" == typeof t && 0 === t.length)) return [0, 0]; if (j(t)) { var e = Math.ceil(t); return [e, e]; } var n = z(t, function (t) { return Math.ceil(t); }); return t.length % 2 ? n.concat(n) : n; })(a.dashArrayY), g = xv(a.symbol), y = ((b = d), z(b, function (t) { return bv(t); })), v = bv(f), m = !r && h.createCanvas(), x = r && { tag: "g", attrs: {}, key: "dcl", children: [] }, _ = (function () { for (var t = 1, e = 0, n = y.length; e < n; ++e) t = _o(t, y[e]); var i = 1; for (e = 0, n = g.length; e < n; ++e) i = _o(i, g[e].length); t *= i; var r = v * y.length * g.length; return { width: Math.max(1, Math.min(t, a.maxTileWidth)), height: Math.max(1, Math.min(r, a.maxTileHeight)), }; })(); var b; m && ((m.width = _.width * n), (m.height = _.height * n), (p = m.getContext("2d"))); (function () { p && (p.clearRect(0, 0, m.width, m.height), a.backgroundColor && ((p.fillStyle = a.backgroundColor), p.fillRect(0, 0, m.width, m.height))); for (var t = 0, e = 0; e < f.length; ++e) t += f[e]; if (t <= 0) return; var o = -v, s = 0, l = 0, u = 0; for (; o < _.height; ) { if (s % 2 == 0) { for ( var h = (l / 2) % g.length, c = 0, y = 0, b = 0; c < 2 * _.width; ) { var w = 0; for (e = 0; e < d[u].length; ++e) w += d[u][e]; if (w <= 0) break; if (y % 2 == 0) { var S = 0.5 * (1 - a.symbolSize), M = c + d[u][y] * S, I = o + f[s] * S, T = d[u][y] * a.symbolSize, C = f[s] * a.symbolSize, D = (b / 2) % g[h].length; A(M, I, T, C, g[h][D]); } (c += d[u][y]), ++b, ++y === d[u].length && (y = 0); } ++u === d.length && (u = 0); } (o += f[s]), ++l, ++s === f.length && (s = 0); } function A(t, e, o, s, l) { var u = r ? 1 : n, h = Xy( l, t * u, e * u, o * u, s * u, a.color, a.symbolKeepAspect ); if (r) { var c = i.painter.renderOneToVNode(h); c && x.children.push(c); } else dv(p, h); } })(), s && yv.put(e, m || x); (t.image = m), (t.svgElement = x), (t.svgWidth = _.width), (t.svgHeight = _.height); })(s), (s.rotation = a.rotation), (s.scaleX = s.scaleY = r ? 1 : 1 / n), gv.set(t, s), (t.dirty = !1), s ); } function xv(t) { if (!t || 0 === t.length) return [["rect"]]; if (U(t)) return [[t]]; for (var e = !0, n = 0; n < t.length; ++n) if (!U(t[n])) { e = !1; break; } if (e) return xv([t]); var i = []; for (n = 0; n < t.length; ++n) U(t[n]) ? i.push([t[n]]) : i.push(t[n]); return i; } function _v(t) { if (!t || 0 === t.length) return [[0, 0]]; if (j(t)) return [[(r = Math.ceil(t)), r]]; for (var e = !0, n = 0; n < t.length; ++n) if (!j(t[n])) { e = !1; break; } if (e) return _v([t]); var i = []; for (n = 0; n < t.length; ++n) if (j(t[n])) { var r = Math.ceil(t[n]); i.push([r, r]); } else { (r = z(t[n], function (t) { return Math.ceil(t); })).length % 2 == 1 ? i.push(r.concat(r)) : i.push(r); } return i; } function bv(t) { for (var e = 0, n = 0; n < t.length; ++n) e += t[n]; return t.length % 2 == 1 ? 2 * e : e; } var wv = new jt(), Sv = {}; function Mv(t) { return Sv[t]; } var Iv = 2e3, Tv = 4500, Cv = { PROCESSOR: { FILTER: 1e3, SERIES_FILTER: 800, STATISTIC: 5e3 }, VISUAL: { LAYOUT: 1e3, PROGRESSIVE_LAYOUT: 1100, GLOBAL: Iv, CHART: 3e3, POST_CHART_LAYOUT: 4600, COMPONENT: 4e3, BRUSH: 5e3, CHART_ITEM: Tv, ARIA: 6e3, DECAL: 7e3, }, }, Dv = "__flagInMainProcess", Av = "__pendingUpdate", kv = "__needsUpdateStatus", Lv = /^[a-zA-Z0-9_]+$/, Pv = "__connectUpdateStatus"; function Ov(t) { return function () { for (var e = [], n = 0; n < arguments.length; n++) e[n] = arguments[n]; if (!this.isDisposed()) return Nv(this, t, e); om(this.id); }; } function Rv(t) { return function () { for (var e = [], n = 0; n < arguments.length; n++) e[n] = arguments[n]; return Nv(this, t, e); }; } function Nv(t, e, n) { return (n[0] = n[0] && n[0].toLowerCase()), jt.prototype[e].apply(t, n); } var Ev, zv, Vv, Bv, Fv, Gv, Wv, Hv, Yv, Xv, Uv, Zv, jv, qv, Kv, $v, Jv, Qv, tm = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return n(e, t), e; })(jt), em = tm.prototype; (em.on = Rv("on")), (em.off = Rv("off")); var nm = (function (t) { function e(e, n, i) { var r = t.call(this, new Sy()) || this; (r._chartsViews = []), (r._chartsMap = {}), (r._componentsViews = []), (r._componentsMap = {}), (r._pendingActions = []), (i = i || {}), U(n) && (n = cm[n]), (r._dom = e); var o = "canvas", a = "auto", s = !1; i.ssr && Zr(function (t) { var e = rl(t), n = e.dataIndex; if (null != n) { var i = yt(); return ( i.set("series_index", e.seriesIndex), i.set("data_index", n), e.ssrType && i.set("ssr_type", e.ssrType), i ); } }); var l = (r._zr = Yr(e, { renderer: i.renderer || o, devicePixelRatio: i.devicePixelRatio, width: i.width, height: i.height, ssr: i.ssr, useDirtyRect: rt(i.useDirtyRect, s), useCoarsePointer: rt(i.useCoarsePointer, a), pointerSize: i.pointerSize, })); (r._ssr = i.ssr), (r._throttledZrFlush = Wg(W(l.flush, l), 17)), (n = T(n)) && Xd(n, !0), (r._theme = n), (r._locale = (function (t) { if (U(t)) { var e = Rc[t.toUpperCase()] || {}; return t === Lc || t === Pc ? T(e) : C(T(e), T(Rc[Oc]), !1); } return C(T(t), T(Rc[Oc]), !1); })(i.locale || Ec)), (r._coordSysMgr = new wd()); var u = (r._api = Kv(r)); function h(t, e) { return t.__prio - e.__prio; } return ( Qe(hm, h), Qe(lm, h), (r._scheduler = new ey(r, u, lm, hm)), (r._messageCenter = new tm()), r._initEvents(), (r.resize = W(r.resize, r)), l.animation.on("frame", r._onframe, r), Xv(l, r), Uv(l, r), ct(r), r ); } return ( n(e, t), (e.prototype._onframe = function () { if (!this._disposed) { Qv(this); var t = this._scheduler; if (this[Av]) { var e = this[Av].silent; this[Dv] = !0; try { Ev(this), Bv.update.call( this, null, this[Av].updateParams ); } catch (t) { throw ((this[Dv] = !1), (this[Av] = null), t); } this._zr.flush(), (this[Dv] = !1), (this[Av] = null), Hv.call(this, e), Yv.call(this, e); } else if (t.unfinished) { var n = 1, i = this._model, r = this._api; t.unfinished = !1; do { var o = +new Date(); t.performSeriesTasks(i), t.performDataProcessorTasks(i), Gv(this, i), t.performVisualTasks(i), qv(this, this._model, r, "remain", {}), (n -= +new Date() - o); } while (n > 0 && t.unfinished); t.unfinished || this._zr.flush(); } } }), (e.prototype.getDom = function () { return this._dom; }), (e.prototype.getId = function () { return this.id; }), (e.prototype.getZr = function () { return this._zr; }), (e.prototype.isSSR = function () { return this._ssr; }), (e.prototype.setOption = function (t, e, n) { if (!this[Dv]) if (this._disposed) om(this.id); else { var i, r, o; if ( (q(e) && ((n = e.lazyUpdate), (i = e.silent), (r = e.replaceMerge), (o = e.transition), (e = e.notMerge)), (this[Dv] = !0), !this._model || e) ) { var a = new Md(this._api), s = this._theme, l = (this._model = new gd()); (l.scheduler = this._scheduler), (l.ssr = this._ssr), l.init( null, null, null, s, this._locale, a ); } this._model.setOption(t, { replaceMerge: r }, um); var u = { seriesTransition: o, optionChanged: !0 }; if (n) (this[Av] = { silent: i, updateParams: u }), (this[Dv] = !1), this.getZr().wakeUp(); else { try { Ev(this), Bv.update.call(this, null, u); } catch (t) { throw ( ((this[Av] = null), (this[Dv] = !1), t) ); } this._ssr || this._zr.flush(), (this[Av] = null), (this[Dv] = !1), Hv.call(this, i), Yv.call(this, i); } } }), (e.prototype.setTheme = function () { bo(); }), (e.prototype.getModel = function () { return this._model; }), (e.prototype.getOption = function () { return this._model && this._model.getOption(); }), (e.prototype.getWidth = function () { return this._zr.getWidth(); }), (e.prototype.getHeight = function () { return this._zr.getHeight(); }), (e.prototype.getDevicePixelRatio = function () { return ( this._zr.painter.dpr || (r.hasGlobalWindow && window.devicePixelRatio) || 1 ); }), (e.prototype.getRenderedCanvas = function (t) { return this.renderToCanvas(t); }), (e.prototype.renderToCanvas = function (t) { t = t || {}; var e = this._zr.painter; return e.getRenderedCanvas({ backgroundColor: t.backgroundColor || this._model.get("backgroundColor"), pixelRatio: t.pixelRatio || this.getDevicePixelRatio(), }); }), (e.prototype.renderToSVGString = function (t) { t = t || {}; var e = this._zr.painter; return e.renderToString({ useViewBox: t.useViewBox }); }), (e.prototype.getSvgDataURL = function () { if (r.svgSupported) { var t = this._zr; return ( E(t.storage.getDisplayList(), function (t) { t.stopAnimation(null, !0); }), t.painter.toDataURL() ); } }), (e.prototype.getDataURL = function (t) { if (!this._disposed) { var e = (t = t || {}).excludeComponents, n = this._model, i = [], r = this; E(e, function (t) { n.eachComponent({ mainType: t }, function (t) { var e = r._componentsMap[t.__viewId]; e.group.ignore || (i.push(e), (e.group.ignore = !0)); }); }); var o = "svg" === this._zr.painter.getType() ? this.getSvgDataURL() : this.renderToCanvas(t).toDataURL( "image/" + ((t && t.type) || "png") ); return ( E(i, function (t) { t.group.ignore = !1; }), o ); } om(this.id); }), (e.prototype.getConnectedDataURL = function (t) { if (!this._disposed) { var e = "svg" === t.type, n = this.group, i = Math.min, r = Math.max, o = 1 / 0; if (fm[n]) { var a = o, s = o, l = -1 / 0, u = -1 / 0, c = [], p = (t && t.pixelRatio) || this.getDevicePixelRatio(); E(dm, function (o, h) { if (o.group === n) { var p = e ? o.getZr().painter.getSvgDom() .innerHTML : o.renderToCanvas(T(t)), d = o.getDom().getBoundingClientRect(); (a = i(d.left, a)), (s = i(d.top, s)), (l = r(d.right, l)), (u = r(d.bottom, u)), c.push({ dom: p, left: d.left, top: d.top, }); } }); var d = (l *= p) - (a *= p), f = (u *= p) - (s *= p), g = h.createCanvas(), y = Yr(g, { renderer: e ? "svg" : "canvas" }); if ((y.resize({ width: d, height: f }), e)) { var v = ""; return ( E(c, function (t) { var e = t.left - a, n = t.top - s; v += '' + t.dom + ""; }), (y.painter.getSvgRoot().innerHTML = v), t.connectedBackgroundColor && y.painter.setBackgroundColor( t.connectedBackgroundColor ), y.refreshImmediately(), y.painter.toDataURL() ); } return ( t.connectedBackgroundColor && y.add( new Ws({ shape: { x: 0, y: 0, width: d, height: f, }, style: { fill: t.connectedBackgroundColor, }, }) ), E(c, function (t) { var e = new Ns({ style: { x: t.left * p - a, y: t.top * p - s, image: t.dom, }, }); y.add(e); }), y.refreshImmediately(), g.toDataURL("image/" + ((t && t.type) || "png")) ); } return this.getDataURL(t); } om(this.id); }), (e.prototype.convertToPixel = function (t, e) { return Fv(this, "convertToPixel", t, e); }), (e.prototype.convertFromPixel = function (t, e) { return Fv(this, "convertFromPixel", t, e); }), (e.prototype.containPixel = function (t, e) { var n; if (!this._disposed) return ( E( Fo(this._model, t), function (t, i) { i.indexOf("Models") >= 0 && E( t, function (t) { var r = t.coordinateSystem; if (r && r.containPoint) n = n || !!r.containPoint(e); else if ("seriesModels" === i) { var o = this._chartsMap[ t.__viewId ]; o && o.containPoint && (n = n || o.containPoint( e, t )); } else 0; }, this ); }, this ), !!n ); om(this.id); }), (e.prototype.getVisual = function (t, e) { var n = Fo(this._model, t, { defaultMainType: "series" }), i = n.seriesModel; var r = i.getData(), o = n.hasOwnProperty("dataIndexInside") ? n.dataIndexInside : n.hasOwnProperty("dataIndex") ? r.indexOfRawIndex(n.dataIndex) : null; return null != o ? Dy(r, o, e) : Ay(r, e); }), (e.prototype.getViewOfComponentModel = function (t) { return this._componentsMap[t.__viewId]; }), (e.prototype.getViewOfSeriesModel = function (t) { return this._chartsMap[t.__viewId]; }), (e.prototype._initEvents = function () { var t, e, n, i = this; E(rm, function (t) { var e = function (e) { var n, r = i.getModel(), o = e.target, a = "globalout" === t; if ( (a ? (n = {}) : o && Oy( o, function (t) { var e = rl(t); if (e && null != e.dataIndex) { var i = e.dataModel || r.getSeriesByIndex( e.seriesIndex ); return ( (n = (i && i.getDataParams( e.dataIndex, e.dataType, o )) || {}), !0 ); } if (e.eventData) return ( (n = A({}, e.eventData)), !0 ); }, !0 ), n) ) { var s = n.componentType, l = n.componentIndex; ("markLine" !== s && "markPoint" !== s && "markArea" !== s) || ((s = "series"), (l = n.seriesIndex)); var u = s && null != l && r.getComponent(s, l), h = u && i[ "series" === u.mainType ? "_chartsMap" : "_componentsMap" ][u.__viewId]; 0, (n.event = e), (n.type = t), (i._$eventProcessor.eventInfo = { targetEl: o, packedEvent: n, model: u, view: h, }), i.trigger(t, n); } }; (e.zrEventfulCallAtLast = !0), i._zr.on(t, e, i); }), E(sm, function (t, e) { i._messageCenter.on( e, function (t) { this.trigger(e, t); }, i ); }), E(["selectchanged"], function (t) { i._messageCenter.on( t, function (e) { this.trigger(t, e); }, i ); }), (t = this._messageCenter), (e = this), (n = this._api), t.on("selectchanged", function (t) { var i = n.getModel(); t.isFromClick ? (Py("map", "selectchanged", e, i, t), Py("pie", "selectchanged", e, i, t)) : "select" === t.fromAction ? (Py("map", "selected", e, i, t), Py("pie", "selected", e, i, t)) : "unselect" === t.fromAction && (Py("map", "unselected", e, i, t), Py("pie", "unselected", e, i, t)); }); }), (e.prototype.isDisposed = function () { return this._disposed; }), (e.prototype.clear = function () { this._disposed ? om(this.id) : this.setOption({ series: [] }, !0); }), (e.prototype.dispose = function () { if (this._disposed) om(this.id); else { (this._disposed = !0), this.getDom() && Xo(this.getDom(), vm, ""); var t = this, e = t._api, n = t._model; E(t._componentsViews, function (t) { t.dispose(n, e); }), E(t._chartsViews, function (t) { t.dispose(n, e); }), t._zr.dispose(), (t._dom = t._model = t._chartsMap = t._componentsMap = t._chartsViews = t._componentsViews = t._scheduler = t._api = t._zr = t._throttledZrFlush = t._theme = t._coordSysMgr = t._messageCenter = null), delete dm[t.id]; } }), (e.prototype.resize = function (t) { if (!this[Dv]) if (this._disposed) om(this.id); else { this._zr.resize(t); var e = this._model; if ( (this._loadingFX && this._loadingFX.resize(), e) ) { var n = e.resetOption("media"), i = t && t.silent; this[Av] && (null == i && (i = this[Av].silent), (n = !0), (this[Av] = null)), (this[Dv] = !0); try { n && Ev(this), Bv.update.call(this, { type: "resize", animation: A( { duration: 0 }, t && t.animation ), }); } catch (t) { throw ((this[Dv] = !1), t); } (this[Dv] = !1), Hv.call(this, i), Yv.call(this, i); } } }), (e.prototype.showLoading = function (t, e) { if (this._disposed) om(this.id); else if ( (q(t) && ((e = t), (t = "")), (t = t || "default"), this.hideLoading(), pm[t]) ) { var n = pm[t](this._api, e), i = this._zr; (this._loadingFX = n), i.add(n); } }), (e.prototype.hideLoading = function () { this._disposed ? om(this.id) : (this._loadingFX && this._zr.remove(this._loadingFX), (this._loadingFX = null)); }), (e.prototype.makeActionFromEvent = function (t) { var e = A({}, t); return (e.type = sm[t.type]), e; }), (e.prototype.dispatchAction = function (t, e) { if (this._disposed) om(this.id); else if ( (q(e) || (e = { silent: !!e }), am[t.type] && this._model) ) if (this[Dv]) this._pendingActions.push(t); else { var n = e.silent; Wv.call(this, t, n); var i = e.flush; i ? this._zr.flush() : !1 !== i && r.browser.weChat && this._throttledZrFlush(), Hv.call(this, n), Yv.call(this, n); } }), (e.prototype.updateLabelLayout = function () { wv.trigger("series:layoutlabels", this._model, this._api, { updatedSeries: [], }); }), (e.prototype.appendData = function (t) { if (this._disposed) om(this.id); else { var e = t.seriesIndex, n = this.getModel().getSeriesByIndex(e); 0, n.appendData(t), (this._scheduler.unfinished = !0), this.getZr().wakeUp(); } }), (e.internalField = (function () { function t(t) { t.clearColorPalette(), t.eachSeries(function (t) { t.clearColorPalette(); }); } function e(t) { for ( var e = [], n = t.currentStates, i = 0; i < n.length; i++ ) { var r = n[i]; "emphasis" !== r && "blur" !== r && "select" !== r && e.push(r); } t.selected && t.states.select && e.push("select"), 2 === t.hoverState && t.states.emphasis ? e.push("emphasis") : 1 === t.hoverState && t.states.blur && e.push("blur"), t.useStates(e); } function i(t, e) { if (!t.preventAutoZ) { var n = t.get("z") || 0, i = t.get("zlevel") || 0; e.eachRendered(function (t) { return o(t, n, i, -1 / 0), !0; }); } } function o(t, e, n, i) { var r = t.getTextContent(), a = t.getTextGuideLine(); if (t.isGroup) for ( var s = t.childrenRef(), l = 0; l < s.length; l++ ) i = Math.max(o(s[l], e, n, i), i); else (t.z = e), (t.zlevel = n), (i = Math.max(t.z2, i)); if ( (r && ((r.z = e), (r.zlevel = n), isFinite(i) && (r.z2 = i + 2)), a) ) { var u = t.textGuideLineConfig; (a.z = e), (a.zlevel = n), isFinite(i) && (a.z2 = i + (u && u.showAbove ? 1 : -1)); } return i; } function a(t, e) { e.eachRendered(function (t) { if (!xh(t)) { var e = t.getTextContent(), n = t.getTextGuideLine(); t.stateTransition && (t.stateTransition = null), e && e.stateTransition && (e.stateTransition = null), n && n.stateTransition && (n.stateTransition = null), t.hasState() ? ((t.prevStates = t.currentStates), t.clearStates()) : t.prevStates && (t.prevStates = null); } }); } function s(t, n) { var i = t.getModel("stateAnimation"), r = t.isAnimationEnabled(), o = i.get("duration"), a = o > 0 ? { duration: o, delay: i.get("delay"), easing: i.get("easing"), } : null; n.eachRendered(function (t) { if (t.states && t.states.emphasis) { if (xh(t)) return; if ( (t instanceof ks && (function (t) { var e = ll(t); (e.normalFill = t.style.fill), (e.normalStroke = t.style.stroke); var n = t.states.select || {}; (e.selectFill = (n.style && n.style.fill) || null), (e.selectStroke = (n.style && n.style.stroke) || null); })(t), t.__dirty) ) { var n = t.prevStates; n && t.useStates(n); } if (r) { t.stateTransition = a; var i = t.getTextContent(), o = t.getTextGuideLine(); i && (i.stateTransition = a), o && (o.stateTransition = a); } t.__dirty && e(t); } }); } (Ev = function (t) { var e = t._scheduler; e.restorePipelines(t._model), e.prepareStageTasks(), zv(t, !0), zv(t, !1), e.plan(); }), (zv = function (t, e) { for ( var n = t._model, i = t._scheduler, r = e ? t._componentsViews : t._chartsViews, o = e ? t._componentsMap : t._chartsMap, a = t._zr, s = t._api, l = 0; l < r.length; l++ ) r[l].__alive = !1; function u(t) { var l = t.__requireNewView; t.__requireNewView = !1; var u = "_ec_" + t.id + "_" + t.type, h = !l && o[u]; if (!h) { var c = Ko(t.type), p = e ? Ag.getClass(c.main, c.sub) : Og.getClass(c.sub); 0, (h = new p()).init(n, s), (o[u] = h), r.push(h), a.add(h.group); } (t.__viewId = h.__id = u), (h.__alive = !0), (h.__model = t), (h.group.__ecComponentInfo = { mainType: t.mainType, index: t.componentIndex, }), !e && i.prepareView(h, t, n, s); } e ? n.eachComponent(function (t, e) { "series" !== t && u(e); }) : n.eachSeries(u); for (l = 0; l < r.length; ) { var h = r[l]; h.__alive ? l++ : (!e && h.renderTask.dispose(), a.remove(h.group), h.dispose(n, s), r.splice(l, 1), o[h.__id] === h && delete o[h.__id], (h.__id = h.group.__ecComponentInfo = null)); } }), (Vv = function (t, e, n, i, r) { var o = t._model; if ((o.setUpdatePayload(n), i)) { var a = {}; (a[i + "Id"] = n[i + "Id"]), (a[i + "Index"] = n[i + "Index"]), (a[i + "Name"] = n[i + "Name"]); var s = { mainType: i, query: a }; r && (s.subType = r); var l, u = n.excludeSeriesId; null != u && ((l = yt()), E(To(u), function (t) { var e = Ro(t, null); null != e && l.set(e, !0); })), o && o.eachComponent( s, function (e) { if (!(l && null != l.get(e.id))) if (eu(n)) if (e instanceof bg) n.type !== dl || n.notBlur || e.get([ "emphasis", "disabled", ]) || (function ( t, e, n ) { var i = t.seriesIndex, r = t.getData( e.dataType ); if (r) { var o = zo( r, e ); o = (Y( o ) ? o[0] : o) || 0; var a = r.getItemGraphicEl( o ); if (!a) for ( var s = r.count(), l = 0; !a && l < s; ) a = r.getItemGraphicEl( l++ ); if (a) { var u = rl( a ); Gl( i, u.focus, u.blurScope, n ); } else { var h = t.get( [ "emphasis", "focus", ] ), c = t.get( [ "emphasis", "blurScope", ] ); null != h && Gl( i, h, c, n ); } } })( e, n, t._api ); else { var i = Hl( e.mainType, e.componentIndex, n.name, t._api ), r = i.focusSelf, o = i.dispatchers; n.type === dl && r && !n.notBlur && Wl( e.mainType, e.componentIndex, t._api ), o && E( o, function ( t ) { n.type === dl ? Ol( t ) : Rl( t ); } ); } else tu(n) && e instanceof bg && (!(function ( t, e, n ) { if (tu(e)) { var i = e.dataType, r = zo( t.getData( i ), e ); Y(r) || (r = [ r, ]), t[ e.type === vl ? "toggleSelect" : e.type === gl ? "select" : "unselect" ](r, i); } })(e, n, t._api), Yl(e), Jv(t)); }, t ), o && o.eachComponent( s, function (e) { (l && null != l.get(e.id)) || h( t[ "series" === i ? "_chartsMap" : "_componentsMap" ][e.__viewId] ); }, t ); } else E( [] .concat(t._componentsViews) .concat(t._chartsViews), h ); function h(i) { i && i.__alive && i[e] && i[e](i.__model, o, t._api, n); } }), (Bv = { prepareAndUpdate: function (t) { Ev(this), Bv.update.call(this, t, { optionChanged: null != t.newOption, }); }, update: function (e, n) { var i = this._model, r = this._api, o = this._zr, a = this._coordSysMgr, s = this._scheduler; if (i) { i.setUpdatePayload(e), s.restoreData(i, e), s.performSeriesTasks(i), a.create(i, r), s.performDataProcessorTasks(i, e), Gv(this, i), a.update(i, r), t(i), s.performVisualTasks(i, e), Zv(this, i, r, e, n); var l = i.get("backgroundColor") || "transparent", u = i.get("darkMode"); o.setBackgroundColor(l), null != u && "auto" !== u && o.setDarkMode(u), wv.trigger("afterupdate", i, r); } }, updateTransform: function (e) { var n = this, i = this._model, r = this._api; if (i) { i.setUpdatePayload(e); var o = []; i.eachComponent(function (t, a) { if ("series" !== t) { var s = n.getViewOfComponentModel(a); if (s && s.__alive) if (s.updateTransform) { var l = s.updateTransform( a, i, r, e ); l && l.update && o.push(s); } else o.push(s); } }); var a = yt(); i.eachSeries(function (t) { var o = n._chartsMap[t.__viewId]; if (o.updateTransform) { var s = o.updateTransform( t, i, r, e ); s && s.update && a.set(t.uid, 1); } else a.set(t.uid, 1); }), t(i), this._scheduler.performVisualTasks( i, e, { setDirty: !0, dirtyMap: a } ), qv(this, i, r, e, {}, a), wv.trigger("afterupdate", i, r); } }, updateView: function (e) { var n = this._model; n && (n.setUpdatePayload(e), Og.markUpdateMethod(e, "updateView"), t(n), this._scheduler.performVisualTasks(n, e, { setDirty: !0, }), Zv(this, n, this._api, e, {}), wv.trigger("afterupdate", n, this._api)); }, updateVisual: function (e) { var n = this, i = this._model; i && (i.setUpdatePayload(e), i.eachSeries(function (t) { t.getData().clearAllVisual(); }), Og.markUpdateMethod(e, "updateVisual"), t(i), this._scheduler.performVisualTasks(i, e, { visualType: "visual", setDirty: !0, }), i.eachComponent(function (t, r) { if ("series" !== t) { var o = n.getViewOfComponentModel(r); o && o.__alive && o.updateVisual(r, i, n._api, e); } }), i.eachSeries(function (t) { n._chartsMap[t.__viewId].updateVisual( t, i, n._api, e ); }), wv.trigger("afterupdate", i, this._api)); }, updateLayout: function (t) { Bv.update.call(this, t); }, }), (Fv = function (t, e, n, i) { if (t._disposed) om(t.id); else { for ( var r, o = t._model, a = t._coordSysMgr.getCoordinateSystems(), s = Fo(o, n), l = 0; l < a.length; l++ ) { var u = a[l]; if (u[e] && null != (r = u[e](o, s, i))) return r; } 0; } }), (Gv = function (t, e) { var n = t._chartsMap, i = t._scheduler; e.eachSeries(function (t) { i.updateStreamModes(t, n[t.__viewId]); }); }), (Wv = function (t, e) { var n = this, i = this.getModel(), r = t.type, o = t.escapeConnect, a = am[r], s = a.actionInfo, l = (s.update || "update").split(":"), u = l.pop(), h = null != l[0] && Ko(l[0]); this[Dv] = !0; var c = [t], p = !1; t.batch && ((p = !0), (c = z(t.batch, function (e) { return ( ((e = k(A({}, e), t)).batch = null), e ); }))); var d, f = [], g = tu(t), y = eu(t); if ( (y && Fl(this._api), E(c, function (e) { if ( (((d = (d = a.action( e, n._model, n._api )) || A({}, e)).type = s.event || d.type), f.push(d), y) ) { var i = Go(t), r = i.queryOptionMap, o = i.mainTypeSpecified ? r.keys()[0] : "series"; Vv(n, u, e, o), Jv(n); } else g ? (Vv(n, u, e, "series"), Jv(n)) : h && Vv(n, u, e, h.main, h.sub); }), "none" !== u && !y && !g && !h) ) try { this[Av] ? (Ev(this), Bv.update.call(this, t), (this[Av] = null)) : Bv[u].call(this, t); } catch (t) { throw ((this[Dv] = !1), t); } if ( ((d = p ? { type: s.event || r, escapeConnect: o, batch: f, } : f[0]), (this[Dv] = !1), !e) ) { var v = this._messageCenter; if ((v.trigger(d.type, d), g)) { var m = { type: "selectchanged", escapeConnect: o, selected: Xl(i), isFromClick: t.isFromClick || !1, fromAction: t.type, fromActionPayload: t, }; v.trigger(m.type, m); } } }), (Hv = function (t) { for (var e = this._pendingActions; e.length; ) { var n = e.shift(); Wv.call(this, n, t); } }), (Yv = function (t) { !t && this.trigger("updated"); }), (Xv = function (t, e) { t.on("rendered", function (n) { e.trigger("rendered", n), !t.animation.isFinished() || e[Av] || e._scheduler.unfinished || e._pendingActions.length || e.trigger("finished"); }); }), (Uv = function (t, e) { t.on("mouseover", function (t) { var n = Oy(t.target, Ql); n && (!(function (t, e, n) { var i = rl(t), r = Hl( i.componentMainType, i.componentIndex, i.componentHighDownName, n ), o = r.dispatchers, a = r.focusSelf; o ? (a && Wl( i.componentMainType, i.componentIndex, n ), E(o, function (t) { return Ll(t, e); })) : (Gl( i.seriesIndex, i.focus, i.blurScope, n ), "self" === i.focus && Wl( i.componentMainType, i.componentIndex, n ), Ll(t, e)); })(n, t, e._api), Jv(e)); }) .on("mouseout", function (t) { var n = Oy(t.target, Ql); n && (!(function (t, e, n) { Fl(n); var i = rl(t), r = Hl( i.componentMainType, i.componentIndex, i.componentHighDownName, n ).dispatchers; r ? E(r, function (t) { return Pl(t, e); }) : Pl(t, e); })(n, t, e._api), Jv(e)); }) .on("click", function (t) { var n = Oy( t.target, function (t) { return null != rl(t).dataIndex; }, !0 ); if (n) { var i = n.selected ? "unselect" : "select", r = rl(n); e._api.dispatchAction({ type: i, dataType: r.dataType, dataIndexInside: r.dataIndex, seriesIndex: r.seriesIndex, isFromClick: !0, }); } }); }), (Zv = function (t, e, n, i, r) { !(function (t) { var e = [], n = [], i = !1; if ( (t.eachComponent(function (t, r) { var o = r.get("zlevel") || 0, a = r.get("z") || 0, s = r.getZLevelKey(); (i = i || !!s), ("series" === t ? n : e).push({ zlevel: o, z: a, idx: r.componentIndex, type: t, key: s, }); }), i) ) { var r, o, a = e.concat(n); Qe(a, function (t, e) { return t.zlevel === e.zlevel ? t.z - e.z : t.zlevel - e.zlevel; }), E(a, function (e) { var n = t.getComponent( e.type, e.idx ), i = e.zlevel, a = e.key; null != r && (i = Math.max(r, i)), a ? (i === r && a !== o && i++, (o = a)) : o && (i === r && i++, (o = "")), (r = i), n.setZLevel(i); }); } })(e), jv(t, e, n, i, r), E(t._chartsViews, function (t) { t.__alive = !1; }), qv(t, e, n, i, r), E(t._chartsViews, function (t) { t.__alive || t.remove(e, n); }); }), (jv = function (t, e, n, r, o, l) { E(l || t._componentsViews, function (t) { var o = t.__model; a(o, t), t.render(o, e, n, r), i(o, t), s(o, t); }); }), (qv = function (t, e, n, o, l, u) { var h = t._scheduler; (l = A(l || {}, { updatedSeries: e.getSeries() })), wv.trigger("series:beforeupdate", e, n, l); var c = !1; e.eachSeries(function (e) { var n = t._chartsMap[e.__viewId]; n.__alive = !0; var i = n.renderTask; h.updatePayload(i, o), a(e, n), u && u.get(e.uid) && i.dirty(), i.perform(h.getPerformArgs(i)) && (c = !0), (n.group.silent = !!e.get("silent")), (function (t, e) { var n = t.get("blendMode") || null; e.eachRendered(function (t) { t.isGroup || (t.style.blend = n); }); })(e, n), Yl(e); }), (h.unfinished = c || h.unfinished), wv.trigger("series:layoutlabels", e, n, l), wv.trigger("series:transition", e, n, l), e.eachSeries(function (e) { var n = t._chartsMap[e.__viewId]; i(e, n), s(e, n); }), (function (t, e) { var n = t._zr, i = n.storage, o = 0; i.traverse(function (t) { t.isGroup || o++; }), o > e.get("hoverLayerThreshold") && !r.node && !r.worker && e.eachSeries(function (e) { if (!e.preventUsingHoverLayer) { var n = t._chartsMap[ e.__viewId ]; n.__alive && n.eachRendered( function (t) { t.states .emphasis && (t.states.emphasis.hoverLayer = !0); } ); } }); })(t, e), wv.trigger("series:afterupdate", e, n, l); }), (Jv = function (t) { (t[kv] = !0), t.getZr().wakeUp(); }), (Qv = function (t) { t[kv] && (t.getZr().storage.traverse(function (t) { xh(t) || e(t); }), (t[kv] = !1)); }), (Kv = function (t) { return new ((function (e) { function i() { return ( (null !== e && e.apply(this, arguments)) || this ); } return ( n(i, e), (i.prototype.getCoordinateSystems = function () { return t._coordSysMgr.getCoordinateSystems(); }), (i.prototype.getComponentByElement = function (e) { for (; e; ) { var n = e.__ecComponentInfo; if (null != n) return t._model.getComponent( n.mainType, n.index ); e = e.parent; } }), (i.prototype.enterEmphasis = function ( e, n ) { Ol(e, n), Jv(t); }), (i.prototype.leaveEmphasis = function ( e, n ) { Rl(e, n), Jv(t); }), (i.prototype.enterBlur = function (e) { Nl(e), Jv(t); }), (i.prototype.leaveBlur = function (e) { El(e), Jv(t); }), (i.prototype.enterSelect = function (e) { zl(e), Jv(t); }), (i.prototype.leaveSelect = function (e) { Vl(e), Jv(t); }), (i.prototype.getModel = function () { return t.getModel(); }), (i.prototype.getViewOfComponentModel = function (e) { return t.getViewOfComponentModel(e); }), (i.prototype.getViewOfSeriesModel = function (e) { return t.getViewOfSeriesModel(e); }), i ); })(_d))(t); }), ($v = function (t) { function e(t, e) { for (var n = 0; n < t.length; n++) { t[n][Pv] = e; } } E(sm, function (n, i) { t._messageCenter.on(i, function (n) { if (fm[t.group] && 0 !== t[Pv]) { if (n && n.escapeConnect) return; var i = t.makeActionFromEvent(n), r = []; E(dm, function (e) { e !== t && e.group === t.group && r.push(e); }), e(r, 0), E(r, function (t) { 1 !== t[Pv] && t.dispatchAction(i); }), e(r, 2); } }); }); }); })()), e ); })(jt), im = nm.prototype; (im.on = Ov("on")), (im.off = Ov("off")), (im.one = function (t, e, n) { var i = this; bo(), this.on.call( this, t, function n() { for (var r = [], o = 0; o < arguments.length; o++) r[o] = arguments[o]; e && e.apply && e.apply(this, r), i.off(t, n); }, n ); }); var rm = [ "click", "dblclick", "mouseover", "mouseout", "mousemove", "mousedown", "mouseup", "globalout", "contextmenu", ]; function om(t) { 0; } var am = {}, sm = {}, lm = [], um = [], hm = [], cm = {}, pm = {}, dm = {}, fm = {}, gm = +new Date() - 0, ym = +new Date() - 0, vm = "_echarts_instance_"; function mm(t) { fm[t] = !1; } var xm = mm; function _m(t) { return dm[ (function (t, e) { return t.getAttribute ? t.getAttribute(e) : t[e]; })(t, vm) ]; } function bm(t, e) { cm[t] = e; } function wm(t) { P(um, t) < 0 && um.push(t); } function Sm(t, e) { Pm(lm, t, e, 2e3); } function Mm(t) { Tm("afterinit", t); } function Im(t) { Tm("afterupdate", t); } function Tm(t, e) { wv.on(t, e); } function Cm(t, e, n) { X(e) && ((n = e), (e = "")); var i = q(t) ? t.type : [t, (t = { event: e })][0]; (t.event = (t.event || i).toLowerCase()), (e = t.event), sm[e] || (lt(Lv.test(i) && Lv.test(e)), am[i] || (am[i] = { action: n, actionInfo: t }), (sm[e] = i)); } function Dm(t, e) { wd.register(t, e); } function Am(t, e) { Pm(hm, t, e, 1e3, "layout"); } function km(t, e) { Pm(hm, t, e, 3e3, "visual"); } var Lm = []; function Pm(t, e, n, i, r) { if (((X(e) || q(e)) && ((n = e), (e = i)), !(P(Lm, n) >= 0))) { Lm.push(n); var o = ey.wrapStageHandler(n, r); (o.__prio = e), (o.__raw = n), t.push(o); } } function Om(t, e) { pm[t] = e; } function Rm(t, e, n) { var i = Mv("registerMap"); i && i(t, e, n); } var Nm = function (t) { var e = (t = T(t)).type, n = ""; e || wo(n); var i = e.split(":"); 2 !== i.length && wo(n); var r = !1; "echarts" === i[0] && ((e = i[1]), (r = !0)), (t.__isBuiltIn = r), Vf.set(e, t); }; km(Iv, Kg), km(Tv, Jg), km(Tv, Qg), km(Iv, Ty), km(Tv, Cy), km(7e3, function (t, e) { t.eachRawSeries(function (n) { if (!t.isSeriesFiltered(n)) { var i = n.getData(); i.hasItemVisual() && i.each(function (t) { var n = i.getItemVisual(t, "decal"); n && (i.ensureUniqueItemVisual(t, "style").decal = mv(n, e)); }); var r = i.getVisual("decal"); if (r) i.getVisual("style").decal = mv(r, e); } }); }), wm(Xd), Sm(900, function (t) { var e = yt(); t.eachSeries(function (t) { var n = t.get("stack"); if (n) { var i = e.get(n) || e.set(n, []), r = t.getData(), o = { stackResultDimension: r.getCalculationInfo( "stackResultDimension" ), stackedOverDimension: r.getCalculationInfo( "stackedOverDimension" ), stackedDimension: r.getCalculationInfo("stackedDimension"), stackedByDimension: r.getCalculationInfo("stackedByDimension"), isStackedByIndex: r.getCalculationInfo("isStackedByIndex"), data: r, seriesModel: t, }; if ( !o.stackedDimension || (!o.isStackedByIndex && !o.stackedByDimension) ) return; i.length && r.setCalculationInfo( "stackedOnSeries", i[i.length - 1].seriesModel ), i.push(o); } }), e.each(Ud); }), Om("default", function (t, e) { k((e = e || {}), { text: "loading", textColor: "#000", fontSize: 12, fontWeight: "normal", fontStyle: "normal", fontFamily: "sans-serif", maskColor: "rgba(255, 255, 255, 0.8)", showSpinner: !0, color: "#5470c6", spinnerRadius: 10, lineWidth: 5, zlevel: 0, }); var n = new Br(), i = new Ws({ style: { fill: e.maskColor }, zlevel: e.zlevel, z: 1e4, }); n.add(i); var r, o = new Xs({ style: { text: e.text, fill: e.textColor, fontSize: e.fontSize, fontWeight: e.fontWeight, fontStyle: e.fontStyle, fontFamily: e.fontFamily, }, zlevel: e.zlevel, z: 10001, }), a = new Ws({ style: { fill: "none" }, textContent: o, textConfig: { position: "right", distance: 10 }, zlevel: e.zlevel, z: 10001, }); return ( n.add(a), e.showSpinner && ((r = new nh({ shape: { startAngle: -ty / 2, endAngle: -ty / 2 + 0.1, r: e.spinnerRadius, }, style: { stroke: e.color, lineCap: "round", lineWidth: e.lineWidth, }, zlevel: e.zlevel, z: 10001, })) .animateShape(!0) .when(1e3, { endAngle: (3 * ty) / 2 }) .start("circularInOut"), r .animateShape(!0) .when(1e3, { startAngle: (3 * ty) / 2 }) .delay(300) .start("circularInOut"), n.add(r)), (n.resize = function () { var n = o.getBoundingRect().width, s = e.showSpinner ? e.spinnerRadius : 0, l = (t.getWidth() - 2 * s - (e.showSpinner && n ? 10 : 0) - n) / 2 - (e.showSpinner && n ? 0 : 5 + n / 2) + (e.showSpinner ? 0 : n / 2) + (n ? 0 : s), u = t.getHeight() / 2; e.showSpinner && r.setShape({ cx: l, cy: u }), a.setShape({ x: l - s, y: u - s, width: 2 * s, height: 2 * s, }), i.setShape({ x: 0, y: 0, width: t.getWidth(), height: t.getHeight(), }); }), n.resize(), n ); }), Cm({ type: dl, event: dl, update: dl }, bt), Cm({ type: fl, event: fl, update: fl }, bt), Cm({ type: gl, event: gl, update: gl }, bt), Cm({ type: yl, event: yl, update: yl }, bt), Cm({ type: vl, event: vl, update: vl }, bt), bm("light", vy), bm("dark", wy); var Em = [], zm = { registerPreprocessor: wm, registerProcessor: Sm, registerPostInit: Mm, registerPostUpdate: Im, registerUpdateLifecycle: Tm, registerAction: Cm, registerCoordinateSystem: Dm, registerLayout: Am, registerVisual: km, registerTransform: Nm, registerLoading: Om, registerMap: Rm, registerImpl: function (t, e) { Sv[t] = e; }, PRIORITY: Cv, ComponentModel: zp, ComponentView: Ag, SeriesModel: bg, ChartView: Og, registerComponentModel: function (t) { zp.registerClass(t); }, registerComponentView: function (t) { Ag.registerClass(t); }, registerSeriesModel: function (t) { bg.registerClass(t); }, registerChartView: function (t) { Og.registerClass(t); }, registerSubTypeDefaulter: function (t, e) { zp.registerSubTypeDefaulter(t, e); }, registerPainter: function (t, e) { Xr(t, e); }, }; function Vm(t) { Y(t) ? E(t, function (t) { Vm(t); }) : P(Em, t) >= 0 || (Em.push(t), X(t) && (t = { install: t }), t.install(zm)); } function Bm(t) { return null == t ? 0 : t.length || 1; } function Fm(t) { return t; } var Gm = (function () { function t(t, e, n, i, r, o) { (this._old = t), (this._new = e), (this._oldKeyGetter = n || Fm), (this._newKeyGetter = i || Fm), (this.context = r), (this._diffModeMultiple = "multiple" === o); } return ( (t.prototype.add = function (t) { return (this._add = t), this; }), (t.prototype.update = function (t) { return (this._update = t), this; }), (t.prototype.updateManyToOne = function (t) { return (this._updateManyToOne = t), this; }), (t.prototype.updateOneToMany = function (t) { return (this._updateOneToMany = t), this; }), (t.prototype.updateManyToMany = function (t) { return (this._updateManyToMany = t), this; }), (t.prototype.remove = function (t) { return (this._remove = t), this; }), (t.prototype.execute = function () { this[ this._diffModeMultiple ? "_executeMultiple" : "_executeOneToOne" ](); }), (t.prototype._executeOneToOne = function () { var t = this._old, e = this._new, n = {}, i = new Array(t.length), r = new Array(e.length); this._initIndexMap(t, null, i, "_oldKeyGetter"), this._initIndexMap(e, n, r, "_newKeyGetter"); for (var o = 0; o < t.length; o++) { var a = i[o], s = n[a], l = Bm(s); if (l > 1) { var u = s.shift(); 1 === s.length && (n[a] = s[0]), this._update && this._update(u, o); } else 1 === l ? ((n[a] = null), this._update && this._update(s, o)) : this._remove && this._remove(o); } this._performRestAdd(r, n); }), (t.prototype._executeMultiple = function () { var t = this._old, e = this._new, n = {}, i = {}, r = [], o = []; this._initIndexMap(t, n, r, "_oldKeyGetter"), this._initIndexMap(e, i, o, "_newKeyGetter"); for (var a = 0; a < r.length; a++) { var s = r[a], l = n[s], u = i[s], h = Bm(l), c = Bm(u); if (h > 1 && 1 === c) this._updateManyToOne && this._updateManyToOne(u, l), (i[s] = null); else if (1 === h && c > 1) this._updateOneToMany && this._updateOneToMany(u, l), (i[s] = null); else if (1 === h && 1 === c) this._update && this._update(u, l), (i[s] = null); else if (h > 1 && c > 1) this._updateManyToMany && this._updateManyToMany(u, l), (i[s] = null); else if (h > 1) for (var p = 0; p < h; p++) this._remove && this._remove(l[p]); else this._remove && this._remove(l); } this._performRestAdd(o, i); }), (t.prototype._performRestAdd = function (t, e) { for (var n = 0; n < t.length; n++) { var i = t[n], r = e[i], o = Bm(r); if (o > 1) for (var a = 0; a < o; a++) this._add && this._add(r[a]); else 1 === o && this._add && this._add(r); e[i] = null; } }), (t.prototype._initIndexMap = function (t, e, n, i) { for ( var r = this._diffModeMultiple, o = 0; o < t.length; o++ ) { var a = "_ec_" + this[i](t[o], o); if ((r || (n[o] = a), e)) { var s = e[a], l = Bm(s); 0 === l ? ((e[a] = o), r && n.push(a)) : 1 === l ? (e[a] = [s, o]) : s.push(o); } } }), t ); })(), Wm = (function () { function t(t, e) { (this._encode = t), (this._schema = e); } return ( (t.prototype.get = function () { return { fullDimensions: this._getFullDimensionNames(), encode: this._encode, }; }), (t.prototype._getFullDimensionNames = function () { return ( this._cachedDimNames || (this._cachedDimNames = this._schema ? this._schema.makeOutputDimensionNames() : []), this._cachedDimNames ); }), t ); })(); function Hm(t, e) { return t.hasOwnProperty(e) || (t[e] = []), t[e]; } function Ym(t) { return "category" === t ? "ordinal" : "time" === t ? "time" : "float"; } var Xm = function (t) { (this.otherDims = {}), null != t && A(this, t); }, Um = Vo(), Zm = { float: "f", int: "i", ordinal: "o", number: "n", time: "t" }, jm = (function () { function t(t) { (this.dimensions = t.dimensions), (this._dimOmitted = t.dimensionOmitted), (this.source = t.source), (this._fullDimCount = t.fullDimensionCount), this._updateDimOmitted(t.dimensionOmitted); } return ( (t.prototype.isDimensionOmitted = function () { return this._dimOmitted; }), (t.prototype._updateDimOmitted = function (t) { (this._dimOmitted = t), t && (this._dimNameMap || (this._dimNameMap = $m(this.source))); }), (t.prototype.getSourceDimensionIndex = function (t) { return rt(this._dimNameMap.get(t), -1); }), (t.prototype.getSourceDimension = function (t) { var e = this.source.dimensionsDefine; if (e) return e[t]; }), (t.prototype.makeStoreSchema = function () { for ( var t = this._fullDimCount, e = af(this.source), n = !Jm(t), i = "", r = [], o = 0, a = 0; o < t; o++ ) { var s = void 0, l = void 0, u = void 0, h = this.dimensions[a]; if (h && h.storeDimIndex === o) (s = e ? h.name : null), (l = h.type), (u = h.ordinalMeta), a++; else { var c = this.getSourceDimension(o); c && ((s = e ? c.name : null), (l = c.type)); } r.push({ property: s, type: l, ordinalMeta: u }), !e || null == s || (h && h.isCalculationCoord) || (i += n ? s .replace(/\`/g, "`1") .replace(/\$/g, "`2") : s), (i += "$"), (i += Zm[l] || "f"), u && (i += u.uid), (i += "$"); } var p = this.source; return { dimensions: r, hash: [p.seriesLayoutBy, p.startIndex, i].join("$$"), }; }), (t.prototype.makeOutputDimensionNames = function () { for ( var t = [], e = 0, n = 0; e < this._fullDimCount; e++ ) { var i = void 0, r = this.dimensions[n]; if (r && r.storeDimIndex === e) r.isCalculationCoord || (i = r.name), n++; else { var o = this.getSourceDimension(e); o && (i = o.name); } t.push(i); } return t; }), (t.prototype.appendCalculationDimension = function (t) { this.dimensions.push(t), (t.isCalculationCoord = !0), this._fullDimCount++, this._updateDimOmitted(!0); }), t ); })(); function qm(t) { return t instanceof jm; } function Km(t) { for (var e = yt(), n = 0; n < (t || []).length; n++) { var i = t[n], r = q(i) ? i.name : i; null != r && null == e.get(r) && e.set(r, n); } return e; } function $m(t) { var e = Um(t); return e.dimNameMap || (e.dimNameMap = Km(t.dimensionsDefine)); } function Jm(t) { return t > 30; } var Qm, tx, ex, nx, ix, rx, ox, ax = q, sx = z, lx = "undefined" == typeof Int32Array ? Array : Int32Array, ux = [ "hasItemOption", "_nameList", "_idList", "_invertedIndicesMap", "_dimSummary", "userOutput", "_rawData", "_dimValueGetter", "_nameDimIdx", "_idDimIdx", "_nameRepeatCount", ], hx = ["_approximateExtent"], cx = (function () { function t(t, e) { var n; (this.type = "list"), (this._dimOmitted = !1), (this._nameList = []), (this._idList = []), (this._visual = {}), (this._layout = {}), (this._itemVisuals = []), (this._itemLayouts = []), (this._graphicEls = []), (this._approximateExtent = {}), (this._calculationInfo = {}), (this.hasItemOption = !1), (this.TRANSFERABLE_METHODS = [ "cloneShallow", "downSample", "minmaxDownSample", "lttbDownSample", "map", ]), (this.CHANGABLE_METHODS = ["filterSelf", "selectRange"]), (this.DOWNSAMPLE_METHODS = [ "downSample", "minmaxDownSample", "lttbDownSample", ]); var i = !1; qm(t) ? ((n = t.dimensions), (this._dimOmitted = t.isDimensionOmitted()), (this._schema = t)) : ((i = !0), (n = t)), (n = n || ["x", "y"]); for ( var r = {}, o = [], a = {}, s = !1, l = {}, u = 0; u < n.length; u++ ) { var h = n[u], c = U(h) ? new Xm({ name: h }) : h instanceof Xm ? h : new Xm(h), p = c.name; (c.type = c.type || "float"), c.coordDim || ((c.coordDim = p), (c.coordDimIndex = 0)); var d = (c.otherDims = c.otherDims || {}); o.push(p), (r[p] = c), null != l[p] && (s = !0), c.createInvertedIndices && (a[p] = []), 0 === d.itemName && (this._nameDimIdx = u), 0 === d.itemId && (this._idDimIdx = u), i && (c.storeDimIndex = u); } if ( ((this.dimensions = o), (this._dimInfos = r), this._initGetDimensionInfo(s), (this.hostModel = e), (this._invertedIndicesMap = a), this._dimOmitted) ) { var f = (this._dimIdxToName = yt()); E(o, function (t) { f.set(r[t].storeDimIndex, t); }); } } return ( (t.prototype.getDimension = function (t) { var e = this._recognizeDimIndex(t); if (null == e) return t; if (((e = t), !this._dimOmitted)) return this.dimensions[e]; var n = this._dimIdxToName.get(e); if (null != n) return n; var i = this._schema.getSourceDimension(e); return i ? i.name : void 0; }), (t.prototype.getDimensionIndex = function (t) { var e = this._recognizeDimIndex(t); if (null != e) return e; if (null == t) return -1; var n = this._getDimInfo(t); return n ? n.storeDimIndex : this._dimOmitted ? this._schema.getSourceDimensionIndex(t) : -1; }), (t.prototype._recognizeDimIndex = function (t) { if ( j(t) || (null != t && !isNaN(t) && !this._getDimInfo(t) && (!this._dimOmitted || this._schema.getSourceDimensionIndex(t) < 0)) ) return +t; }), (t.prototype._getStoreDimIndex = function (t) { var e = this.getDimensionIndex(t); return e; }), (t.prototype.getDimensionInfo = function (t) { return this._getDimInfo(this.getDimension(t)); }), (t.prototype._initGetDimensionInfo = function (t) { var e = this._dimInfos; this._getDimInfo = t ? function (t) { return e.hasOwnProperty(t) ? e[t] : void 0; } : function (t) { return e[t]; }; }), (t.prototype.getDimensionsOnCoord = function () { return this._dimSummary.dataDimsOnCoord.slice(); }), (t.prototype.mapDimension = function (t, e) { var n = this._dimSummary; if (null == e) return n.encodeFirstDimNotExtra[t]; var i = n.encode[t]; return i ? i[e] : null; }), (t.prototype.mapDimensionsAll = function (t) { return (this._dimSummary.encode[t] || []).slice(); }), (t.prototype.getStore = function () { return this._store; }), (t.prototype.initData = function (t, e, n) { var i, r = this; if ((t instanceof Kf && (i = t), !i)) { var o = this.dimensions, a = Qd(t) || N(t) ? new sf(t, o.length) : t; i = new Kf(); var s = sx(o, function (t) { return { type: r._dimInfos[t].type, property: t }; }); i.initData(a, s, n); } (this._store = i), (this._nameList = (e || []).slice()), (this._idList = []), (this._nameRepeatCount = {}), this._doInit(0, i.count()), (this._dimSummary = (function (t, e) { var n = {}, i = (n.encode = {}), r = yt(), o = [], a = [], s = {}; E(t.dimensions, function (e) { var n, l = t.getDimensionInfo(e), u = l.coordDim; if (u) { var h = l.coordDimIndex; (Hm(i, u)[h] = e), l.isExtraCoord || (r.set(u, 1), "ordinal" !== (n = l.type) && "time" !== n && (o[0] = e), (Hm(s, u)[h] = t.getDimensionIndex( l.name ))), l.defaultTooltip && a.push(e); } Gp.each(function (t, e) { var n = Hm(i, e), r = l.otherDims[e]; null != r && !1 !== r && (n[r] = l.name); }); }); var l = [], u = {}; r.each(function (t, e) { var n = i[e]; (u[e] = n[0]), (l = l.concat(n)); }), (n.dataDimsOnCoord = l), (n.dataDimIndicesOnCoord = z(l, function (e) { return t.getDimensionInfo(e).storeDimIndex; })), (n.encodeFirstDimNotExtra = u); var h = i.label; h && h.length && (o = h.slice()); var c = i.tooltip; return ( c && c.length ? (a = c.slice()) : a.length || (a = o.slice()), (i.defaultedLabel = o), (i.defaultedTooltip = a), (n.userOutput = new Wm(s, e)), n ); })(this, this._schema)), (this.userOutput = this._dimSummary.userOutput); }), (t.prototype.appendData = function (t) { var e = this._store.appendData(t); this._doInit(e[0], e[1]); }), (t.prototype.appendValues = function (t, e) { var n = this._store.appendValues(t, e && e.length), i = n.start, r = n.end, o = this._shouldMakeIdFromName(); if ((this._updateOrdinalMeta(), e)) for (var a = i; a < r; a++) { var s = a - i; (this._nameList[a] = e[s]), o && ox(this, a); } }), (t.prototype._updateOrdinalMeta = function () { for ( var t = this._store, e = this.dimensions, n = 0; n < e.length; n++ ) { var i = this._dimInfos[e[n]]; i.ordinalMeta && t.collectOrdinalMeta( i.storeDimIndex, i.ordinalMeta ); } }), (t.prototype._shouldMakeIdFromName = function () { var t = this._store.getProvider(); return ( null == this._idDimIdx && t.getSource().sourceFormat !== Up && !t.fillStorage ); }), (t.prototype._doInit = function (t, e) { if (!(t >= e)) { var n = this._store.getProvider(); this._updateOrdinalMeta(); var i = this._nameList, r = this._idList; if (n.getSource().sourceFormat === Wp && !n.pure) for (var o = [], a = t; a < e; a++) { var s = n.getItem(a, o); if ( (!this.hasItemOption && ko(s) && (this.hasItemOption = !0), s) ) { var l = s.name; null == i[a] && null != l && (i[a] = Ro(l, null)); var u = s.id; null == r[a] && null != u && (r[a] = Ro(u, null)); } } if (this._shouldMakeIdFromName()) for (a = t; a < e; a++) ox(this, a); Qm(this); } }), (t.prototype.getApproximateExtent = function (t) { return ( this._approximateExtent[t] || this._store.getDataExtent(this._getStoreDimIndex(t)) ); }), (t.prototype.setApproximateExtent = function (t, e) { (e = this.getDimension(e)), (this._approximateExtent[e] = t.slice()); }), (t.prototype.getCalculationInfo = function (t) { return this._calculationInfo[t]; }), (t.prototype.setCalculationInfo = function (t, e) { ax(t) ? A(this._calculationInfo, t) : (this._calculationInfo[t] = e); }), (t.prototype.getName = function (t) { var e = this.getRawIndex(t), n = this._nameList[e]; return ( null == n && null != this._nameDimIdx && (n = ex(this, this._nameDimIdx, e)), null == n && (n = ""), n ); }), (t.prototype._getCategory = function (t, e) { var n = this._store.get(t, e), i = this._store.getOrdinalMeta(t); return i ? i.categories[n] : n; }), (t.prototype.getId = function (t) { return tx(this, this.getRawIndex(t)); }), (t.prototype.count = function () { return this._store.count(); }), (t.prototype.get = function (t, e) { var n = this._store, i = this._dimInfos[t]; if (i) return n.get(i.storeDimIndex, e); }), (t.prototype.getByRawIndex = function (t, e) { var n = this._store, i = this._dimInfos[t]; if (i) return n.getByRawIndex(i.storeDimIndex, e); }), (t.prototype.getIndices = function () { return this._store.getIndices(); }), (t.prototype.getDataExtent = function (t) { return this._store.getDataExtent(this._getStoreDimIndex(t)); }), (t.prototype.getSum = function (t) { return this._store.getSum(this._getStoreDimIndex(t)); }), (t.prototype.getMedian = function (t) { return this._store.getMedian(this._getStoreDimIndex(t)); }), (t.prototype.getValues = function (t, e) { var n = this, i = this._store; return Y(t) ? i.getValues( sx(t, function (t) { return n._getStoreDimIndex(t); }), e ) : i.getValues(t); }), (t.prototype.hasValue = function (t) { for ( var e = this._dimSummary.dataDimIndicesOnCoord, n = 0, i = e.length; n < i; n++ ) if (isNaN(this._store.get(e[n], t))) return !1; return !0; }), (t.prototype.indexOfName = function (t) { for (var e = 0, n = this._store.count(); e < n; e++) if (this.getName(e) === t) return e; return -1; }), (t.prototype.getRawIndex = function (t) { return this._store.getRawIndex(t); }), (t.prototype.indexOfRawIndex = function (t) { return this._store.indexOfRawIndex(t); }), (t.prototype.rawIndexOf = function (t, e) { var n = t && this._invertedIndicesMap[t]; var i = n && n[e]; return null == i || isNaN(i) ? -1 : i; }), (t.prototype.indicesOfNearest = function (t, e, n) { return this._store.indicesOfNearest( this._getStoreDimIndex(t), e, n ); }), (t.prototype.each = function (t, e, n) { X(t) && ((n = e), (e = t), (t = [])); var i = n || this, r = sx(nx(t), this._getStoreDimIndex, this); this._store.each(r, i ? W(e, i) : e); }), (t.prototype.filterSelf = function (t, e, n) { X(t) && ((n = e), (e = t), (t = [])); var i = n || this, r = sx(nx(t), this._getStoreDimIndex, this); return ( (this._store = this._store.filter(r, i ? W(e, i) : e)), this ); }), (t.prototype.selectRange = function (t) { var e = this, n = {}; return ( E(G(t), function (i) { var r = e._getStoreDimIndex(i); n[r] = t[i]; }), (this._store = this._store.selectRange(n)), this ); }), (t.prototype.mapArray = function (t, e, n) { X(t) && ((n = e), (e = t), (t = [])), (n = n || this); var i = []; return ( this.each( t, function () { i.push(e && e.apply(this, arguments)); }, n ), i ); }), (t.prototype.map = function (t, e, n, i) { var r = n || i || this, o = sx(nx(t), this._getStoreDimIndex, this), a = rx(this); return (a._store = this._store.map(o, r ? W(e, r) : e)), a; }), (t.prototype.modify = function (t, e, n, i) { var r = n || i || this; var o = sx(nx(t), this._getStoreDimIndex, this); this._store.modify(o, r ? W(e, r) : e); }), (t.prototype.downSample = function (t, e, n, i) { var r = rx(this); return ( (r._store = this._store.downSample( this._getStoreDimIndex(t), e, n, i )), r ); }), (t.prototype.minmaxDownSample = function (t, e) { var n = rx(this); return ( (n._store = this._store.minmaxDownSample( this._getStoreDimIndex(t), e )), n ); }), (t.prototype.lttbDownSample = function (t, e) { var n = rx(this); return ( (n._store = this._store.lttbDownSample( this._getStoreDimIndex(t), e )), n ); }), (t.prototype.getRawDataItem = function (t) { return this._store.getRawDataItem(t); }), (t.prototype.getItemModel = function (t) { var e = this.hostModel, n = this.getRawDataItem(t); return new Cc(n, e, e && e.ecModel); }), (t.prototype.diff = function (t) { var e = this; return new Gm( t ? t.getStore().getIndices() : [], this.getStore().getIndices(), function (e) { return tx(t, e); }, function (t) { return tx(e, t); } ); }), (t.prototype.getVisual = function (t) { var e = this._visual; return e && e[t]; }), (t.prototype.setVisual = function (t, e) { (this._visual = this._visual || {}), ax(t) ? A(this._visual, t) : (this._visual[t] = e); }), (t.prototype.getItemVisual = function (t, e) { var n = this._itemVisuals[t], i = n && n[e]; return null == i ? this.getVisual(e) : i; }), (t.prototype.hasItemVisual = function () { return this._itemVisuals.length > 0; }), (t.prototype.ensureUniqueItemVisual = function (t, e) { var n = this._itemVisuals, i = n[t]; i || (i = n[t] = {}); var r = i[e]; return ( null == r && (Y((r = this.getVisual(e))) ? (r = r.slice()) : ax(r) && (r = A({}, r)), (i[e] = r)), r ); }), (t.prototype.setItemVisual = function (t, e, n) { var i = this._itemVisuals[t] || {}; (this._itemVisuals[t] = i), ax(e) ? A(i, e) : (i[e] = n); }), (t.prototype.clearAllVisual = function () { (this._visual = {}), (this._itemVisuals = []); }), (t.prototype.setLayout = function (t, e) { ax(t) ? A(this._layout, t) : (this._layout[t] = e); }), (t.prototype.getLayout = function (t) { return this._layout[t]; }), (t.prototype.getItemLayout = function (t) { return this._itemLayouts[t]; }), (t.prototype.setItemLayout = function (t, e, n) { this._itemLayouts[t] = n ? A(this._itemLayouts[t] || {}, e) : e; }), (t.prototype.clearItemLayouts = function () { this._itemLayouts.length = 0; }), (t.prototype.setItemGraphicEl = function (t, e) { var n = this.hostModel && this.hostModel.seriesIndex; ol(n, this.dataType, t, e), (this._graphicEls[t] = e); }), (t.prototype.getItemGraphicEl = function (t) { return this._graphicEls[t]; }), (t.prototype.eachItemGraphicEl = function (t, e) { E(this._graphicEls, function (n, i) { n && t && t.call(e, n, i); }); }), (t.prototype.cloneShallow = function (e) { return ( e || (e = new t( this._schema ? this._schema : sx( this.dimensions, this._getDimInfo, this ), this.hostModel )), ix(e, this), (e._store = this._store), e ); }), (t.prototype.wrapMethod = function (t, e) { var n = this[t]; X(n) && ((this.__wrappedMethods = this.__wrappedMethods || []), this.__wrappedMethods.push(t), (this[t] = function () { var t = n.apply(this, arguments); return e.apply(this, [t].concat(at(arguments))); })); }), (t.internalField = ((Qm = function (t) { var e = t._invertedIndicesMap; E(e, function (n, i) { var r = t._dimInfos[i], o = r.ordinalMeta, a = t._store; if (o) { n = e[i] = new lx(o.categories.length); for (var s = 0; s < n.length; s++) n[s] = -1; for (s = 0; s < a.count(); s++) n[a.get(r.storeDimIndex, s)] = s; } }); }), (ex = function (t, e, n) { return Ro(t._getCategory(e, n), null); }), (tx = function (t, e) { var n = t._idList[e]; return ( null == n && null != t._idDimIdx && (n = ex(t, t._idDimIdx, e)), null == n && (n = "e\0\0" + e), n ); }), (nx = function (t) { return Y(t) || (t = null != t ? [t] : []), t; }), (rx = function (e) { var n = new t( e._schema ? e._schema : sx(e.dimensions, e._getDimInfo, e), e.hostModel ); return ix(n, e), n; }), (ix = function (t, e) { E(ux.concat(e.__wrappedMethods || []), function (n) { e.hasOwnProperty(n) && (t[n] = e[n]); }), (t.__wrappedMethods = e.__wrappedMethods), E(hx, function (n) { t[n] = T(e[n]); }), (t._calculationInfo = A({}, e._calculationInfo)); }), void (ox = function (t, e) { var n = t._nameList, i = t._idList, r = t._nameDimIdx, o = t._idDimIdx, a = n[e], s = i[e]; if ( (null == a && null != r && (n[e] = a = ex(t, r, e)), null == s && null != o && (i[e] = s = ex(t, o, e)), null == s && null != a) ) { var l = t._nameRepeatCount, u = (l[a] = (l[a] || 0) + 1); (s = a), u > 1 && (s += "__ec__" + u), (i[e] = s); } }))), t ); })(); function px(t, e) { Qd(t) || (t = ef(t)); var n = (e = e || {}).coordDimensions || [], i = e.dimensionsDefine || t.dimensionsDefine || [], r = yt(), o = [], a = (function (t, e, n, i) { var r = Math.max( t.dimensionsDetectedCount || 1, e.length, n.length, i || 0 ); return ( E(e, function (t) { var e; q(t) && (e = t.dimsDef) && (r = Math.max(r, e.length)); }), r ); })(t, n, i, e.dimensionsCount), s = e.canOmitUnusedDimensions && Jm(a), l = i === t.dimensionsDefine, u = l ? $m(t) : Km(i), h = e.encodeDefine; !h && e.encodeDefaulter && (h = e.encodeDefaulter(t, a)); for (var c = yt(h), p = new Xf(a), d = 0; d < p.length; d++) p[d] = -1; function f(t) { var e = p[t]; if (e < 0) { var n = i[t], r = q(n) ? n : { name: n }, a = new Xm(), s = r.name; null != s && null != u.get(s) && (a.name = a.displayName = s), null != r.type && (a.type = r.type), null != r.displayName && (a.displayName = r.displayName); var l = o.length; return (p[t] = l), (a.storeDimIndex = t), o.push(a), a; } return o[e]; } if (!s) for (d = 0; d < a; d++) f(d); c.each(function (t, e) { var n = To(t).slice(); if (1 === n.length && !U(n[0]) && n[0] < 0) c.set(e, !1); else { var i = c.set(e, []); E(n, function (t, n) { var r = U(t) ? u.get(t) : t; null != r && r < a && ((i[n] = r), y(f(r), e, n)); }); } }); var g = 0; function y(t, e, n) { null != Gp.get(e) ? (t.otherDims[e] = n) : ((t.coordDim = e), (t.coordDimIndex = n), r.set(e, !0)); } E(n, function (t) { var e, n, i, r; if (U(t)) (e = t), (r = {}); else { e = (r = t).name; var o = r.ordinalMeta; (r.ordinalMeta = null), ((r = A({}, r)).ordinalMeta = o), (n = r.dimsDef), (i = r.otherDims), (r.name = r.coordDim = r.coordDimIndex = r.dimsDef = r.otherDims = null); } var s = c.get(e); if (!1 !== s) { if (!(s = To(s)).length) for (var u = 0; u < ((n && n.length) || 1); u++) { for (; g < a && null != f(g).coordDim; ) g++; g < a && s.push(g++); } E(s, function (t, o) { var a = f(t); if ( (l && null != r.type && (a.type = r.type), y(k(a, r), e, o), null == a.name && n) ) { var s = n[o]; !q(s) && (s = { name: s }), (a.name = a.displayName = s.name), (a.defaultTooltip = s.defaultTooltip); } i && k(a.otherDims, i); }); } }); var v = e.generateCoord, m = e.generateCoordCount, x = null != m; m = v ? m || 1 : 0; var _ = v || "value"; function b(t) { null == t.name && (t.name = t.coordDim); } if (s) E(o, function (t) { b(t); }), o.sort(function (t, e) { return t.storeDimIndex - e.storeDimIndex; }); else for (var w = 0; w < a; w++) { var S = f(w); null == S.coordDim && ((S.coordDim = dx(_, r, x)), (S.coordDimIndex = 0), (!v || m <= 0) && (S.isExtraCoord = !0), m--), b(S), null != S.type || (id(t, w) !== Kp && (!S.isExtraCoord || (null == S.otherDims.itemName && null == S.otherDims.seriesName))) || (S.type = "ordinal"); } return ( (function (t) { for (var e = yt(), n = 0; n < t.length; n++) { var i = t[n], r = i.name, o = e.get(r) || 0; o > 0 && (i.name = r + (o - 1)), o++, e.set(r, o); } })(o), new jm({ source: t, dimensions: o, fullDimensionCount: a, dimensionOmitted: s, }) ); } function dx(t, e, n) { if (n || e.hasKey(t)) { for (var i = 0; e.hasKey(t + i); ) i++; t += i; } return e.set(t, !0), t; } var fx = function (t) { (this.coordSysDims = []), (this.axisMap = yt()), (this.categoryAxisMap = yt()), (this.coordSysName = t); }; var gx = { cartesian2d: function (t, e, n, i) { var r = t.getReferringComponents("xAxis", Wo).models[0], o = t.getReferringComponents("yAxis", Wo).models[0]; (e.coordSysDims = ["x", "y"]), n.set("x", r), n.set("y", o), yx(r) && (i.set("x", r), (e.firstCategoryDimIndex = 0)), yx(o) && (i.set("y", o), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = 1)); }, singleAxis: function (t, e, n, i) { var r = t.getReferringComponents("singleAxis", Wo).models[0]; (e.coordSysDims = ["single"]), n.set("single", r), yx(r) && (i.set("single", r), (e.firstCategoryDimIndex = 0)); }, polar: function (t, e, n, i) { var r = t.getReferringComponents("polar", Wo).models[0], o = r.findAxisModel("radiusAxis"), a = r.findAxisModel("angleAxis"); (e.coordSysDims = ["radius", "angle"]), n.set("radius", o), n.set("angle", a), yx(o) && (i.set("radius", o), (e.firstCategoryDimIndex = 0)), yx(a) && (i.set("angle", a), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = 1)); }, geo: function (t, e, n, i) { e.coordSysDims = ["lng", "lat"]; }, parallel: function (t, e, n, i) { var r = t.ecModel, o = r.getComponent("parallel", t.get("parallelIndex")), a = (e.coordSysDims = o.dimensions.slice()); E(o.parallelAxisIndex, function (t, o) { var s = r.getComponent("parallelAxis", t), l = a[o]; n.set(l, s), yx(s) && (i.set(l, s), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = o)); }); }, }; function yx(t) { return "category" === t.get("type"); } function vx(t, e, n) { var i, r, o, a = (n = n || {}).byIndex, s = n.stackedCoordDimension; !(function (t) { return !qm(t.schema); })(e) ? ((r = e.schema), (i = r.dimensions), (o = e.store)) : (i = e); var l, u, h, c, p = !(!t || !t.get("stack")); if ( (E(i, function (t, e) { U(t) && (i[e] = t = { name: t }), p && !t.isExtraCoord && (a || l || !t.ordinalMeta || (l = t), u || "ordinal" === t.type || "time" === t.type || (s && s !== t.coordDim) || (u = t)); }), !u || a || l || (a = !0), u) ) { (h = "__\0ecstackresult_" + t.id), (c = "__\0ecstackedover_" + t.id), l && (l.createInvertedIndices = !0); var d = u.coordDim, f = u.type, g = 0; E(i, function (t) { t.coordDim === d && g++; }); var y = { name: h, coordDim: d, coordDimIndex: g, type: f, isExtraCoord: !0, isCalculationCoord: !0, storeDimIndex: i.length, }, v = { name: c, coordDim: c, coordDimIndex: g + 1, type: f, isExtraCoord: !0, isCalculationCoord: !0, storeDimIndex: i.length + 1, }; r ? (o && ((y.storeDimIndex = o.ensureCalculationDimension(c, f)), (v.storeDimIndex = o.ensureCalculationDimension(h, f))), r.appendCalculationDimension(y), r.appendCalculationDimension(v)) : (i.push(y), i.push(v)); } return { stackedDimension: u && u.name, stackedByDimension: l && l.name, isStackedByIndex: a, stackedOverDimension: c, stackResultDimension: h, }; } function mx(t, e) { return !!e && e === t.getCalculationInfo("stackedDimension"); } function xx(t, e) { return mx(t, e) ? t.getCalculationInfo("stackResultDimension") : e; } function _x(t, e, n) { n = n || {}; var i, r = e.getSourceManager(), o = !1; t ? ((o = !0), (i = ef(t))) : (o = (i = r.getSource()).sourceFormat === Wp); var a = (function (t) { var e = t.get("coordinateSystem"), n = new fx(e), i = gx[e]; if (i) return i(t, n, n.axisMap, n.categoryAxisMap), n; })(e), s = (function (t, e) { var n, i = t.get("coordinateSystem"), r = wd.get(i); return ( e && e.coordSysDims && (n = z(e.coordSysDims, function (t) { var n = { name: t }, i = e.axisMap.get(t); if (i) { var r = i.get("type"); n.type = Ym(r); } return n; })), n || (n = (r && (r.getDimensionsInfo ? r.getDimensionsInfo() : r.dimensions.slice())) || ["x", "y"]), n ); })(e, a), l = n.useEncodeDefaulter, u = X(l) ? l : l ? H(td, s, e) : null, h = px(i, { coordDimensions: s, generateCoord: n.generateCoord, encodeDefine: e.getEncode(), encodeDefaulter: u, canOmitUnusedDimensions: !o, }), c = (function (t, e, n) { var i, r; return ( n && E(t, function (t, o) { var a = t.coordDim, s = n.categoryAxisMap.get(a); s && (null == i && (i = o), (t.ordinalMeta = s.getOrdinalMeta()), e && (t.createInvertedIndices = !0)), null != t.otherDims.itemName && (r = !0); }), r || null == i || (t[i].otherDims.itemName = 0), i ); })(h.dimensions, n.createInvertedIndices, a), p = o ? null : r.getSharedDataStore(h), d = vx(e, { schema: h, store: p }), f = new cx(h, e); f.setCalculationInfo(d); var g = null != c && (function (t) { if (t.sourceFormat === Wp) { var e = (function (t) { var e = 0; for (; e < t.length && null == t[e]; ) e++; return t[e]; })(t.data || []); return !Y(Ao(e)); } })(i) ? function (t, e, n, i) { return i === c ? n : this.defaultDimValueGetter(t, e, n, i); } : null; return (f.hasItemOption = !1), f.initData(o ? i : p, null, g), f; } var bx = (function () { function t(t) { (this._setting = t || {}), (this._extent = [1 / 0, -1 / 0]); } return ( (t.prototype.getSetting = function (t) { return this._setting[t]; }), (t.prototype.unionExtent = function (t) { var e = this._extent; t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1]); }), (t.prototype.unionExtentFromData = function (t, e) { this.unionExtent(t.getApproximateExtent(e)); }), (t.prototype.getExtent = function () { return this._extent.slice(); }), (t.prototype.setExtent = function (t, e) { var n = this._extent; isNaN(t) || (n[0] = t), isNaN(e) || (n[1] = e); }), (t.prototype.isInExtentRange = function (t) { return this._extent[0] <= t && this._extent[1] >= t; }), (t.prototype.isBlank = function () { return this._isBlank; }), (t.prototype.setBlank = function (t) { this._isBlank = t; }), t ); })(); na(bx); var Sx = 0, Mx = (function () { function t(t) { (this.categories = t.categories || []), (this._needCollect = t.needCollect), (this._deduplication = t.deduplication), (this.uid = ++Sx); } return ( (t.createByAxisModel = function (e) { var n = e.option, i = n.data, r = i && z(i, Ix); return new t({ categories: r, needCollect: !r, deduplication: !1 !== n.dedplication, }); }), (t.prototype.getOrdinal = function (t) { return this._getOrCreateMap().get(t); }), (t.prototype.parseAndCollect = function (t) { var e, n = this._needCollect; if (!U(t) && !n) return t; if (n && !this._deduplication) return ( (e = this.categories.length), (this.categories[e] = t), e ); var i = this._getOrCreateMap(); return ( null == (e = i.get(t)) && (n ? ((e = this.categories.length), (this.categories[e] = t), i.set(t, e)) : (e = NaN)), e ); }), (t.prototype._getOrCreateMap = function () { return this._map || (this._map = yt(this.categories)); }), t ); })(); function Ix(t) { return q(t) && null != t.value ? t.value : t + ""; } function Tx(t) { return "interval" === t.type || "log" === t.type; } function Cx(t, e, n, i) { var r = {}, o = t[1] - t[0], a = (r.interval = po(o / e, !0)); null != n && a < n && (a = r.interval = n), null != i && a > i && (a = r.interval = i); var s = (r.intervalPrecision = Ax(a)); return ( (function (t, e) { !isFinite(t[0]) && (t[0] = e[0]), !isFinite(t[1]) && (t[1] = e[1]), kx(t, 0, e), kx(t, 1, e), t[0] > t[1] && (t[0] = t[1]); })( (r.niceTickExtent = [ Jr(Math.ceil(t[0] / a) * a, s), Jr(Math.floor(t[1] / a) * a, s), ]), t ), r ); } function Dx(t) { var e = Math.pow(10, co(t)), n = t / e; return ( n ? (2 === n ? (n = 3) : 3 === n ? (n = 5) : (n *= 2)) : (n = 1), Jr(n * e) ); } function Ax(t) { return to(t) + 2; } function kx(t, e, n) { t[e] = Math.max(Math.min(t[e], n[1]), n[0]); } function Lx(t, e) { return t >= e[0] && t <= e[1]; } function Px(t, e) { return e[1] === e[0] ? 0.5 : (t - e[0]) / (e[1] - e[0]); } function Ox(t, e) { return t * (e[1] - e[0]) + e[0]; } var Rx = (function (t) { function e(e) { var n = t.call(this, e) || this; n.type = "ordinal"; var i = n.getSetting("ordinalMeta"); return ( i || (i = new Mx({})), Y(i) && (i = new Mx({ categories: z(i, function (t) { return q(t) ? t.value : t; }), })), (n._ordinalMeta = i), (n._extent = n.getSetting("extent") || [ 0, i.categories.length - 1, ]), n ); } return ( n(e, t), (e.prototype.parse = function (t) { return null == t ? NaN : U(t) ? this._ordinalMeta.getOrdinal(t) : Math.round(t); }), (e.prototype.contain = function (t) { return ( Lx((t = this.parse(t)), this._extent) && null != this._ordinalMeta.categories[t] ); }), (e.prototype.normalize = function (t) { return Px( (t = this._getTickNumber(this.parse(t))), this._extent ); }), (e.prototype.scale = function (t) { return ( (t = Math.round(Ox(t, this._extent))), this.getRawOrdinalNumber(t) ); }), (e.prototype.getTicks = function () { for (var t = [], e = this._extent, n = e[0]; n <= e[1]; ) t.push({ value: n }), n++; return t; }), (e.prototype.getMinorTicks = function (t) {}), (e.prototype.setSortInfo = function (t) { if (null != t) { for ( var e = t.ordinalNumbers, n = (this._ordinalNumbersByTick = []), i = (this._ticksByOrdinalNumber = []), r = 0, o = this._ordinalMeta.categories.length, a = Math.min(o, e.length); r < a; ++r ) { var s = e[r]; (n[r] = s), (i[s] = r); } for (var l = 0; r < o; ++r) { for (; null != i[l]; ) l++; n.push(l), (i[l] = r); } } else this._ordinalNumbersByTick = this._ticksByOrdinalNumber = null; }), (e.prototype._getTickNumber = function (t) { var e = this._ticksByOrdinalNumber; return e && t >= 0 && t < e.length ? e[t] : t; }), (e.prototype.getRawOrdinalNumber = function (t) { var e = this._ordinalNumbersByTick; return e && t >= 0 && t < e.length ? e[t] : t; }), (e.prototype.getLabel = function (t) { if (!this.isBlank()) { var e = this.getRawOrdinalNumber(t.value), n = this._ordinalMeta.categories[e]; return null == n ? "" : n + ""; } }), (e.prototype.count = function () { return this._extent[1] - this._extent[0] + 1; }), (e.prototype.unionExtentFromData = function (t, e) { this.unionExtent(t.getApproximateExtent(e)); }), (e.prototype.isInExtentRange = function (t) { return ( (t = this._getTickNumber(t)), this._extent[0] <= t && this._extent[1] >= t ); }), (e.prototype.getOrdinalMeta = function () { return this._ordinalMeta; }), (e.prototype.calcNiceTicks = function () {}), (e.prototype.calcNiceExtent = function () {}), (e.type = "ordinal"), e ); })(bx); bx.registerClass(Rx); var Nx = Jr, Ex = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return ( (e.type = "interval"), (e._interval = 0), (e._intervalPrecision = 2), e ); } return ( n(e, t), (e.prototype.parse = function (t) { return t; }), (e.prototype.contain = function (t) { return Lx(t, this._extent); }), (e.prototype.normalize = function (t) { return Px(t, this._extent); }), (e.prototype.scale = function (t) { return Ox(t, this._extent); }), (e.prototype.setExtent = function (t, e) { var n = this._extent; isNaN(t) || (n[0] = parseFloat(t)), isNaN(e) || (n[1] = parseFloat(e)); }), (e.prototype.unionExtent = function (t) { var e = this._extent; t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1]), this.setExtent(e[0], e[1]); }), (e.prototype.getInterval = function () { return this._interval; }), (e.prototype.setInterval = function (t) { (this._interval = t), (this._niceExtent = this._extent.slice()), (this._intervalPrecision = Ax(t)); }), (e.prototype.getTicks = function (t) { var e = this._interval, n = this._extent, i = this._niceExtent, r = this._intervalPrecision, o = []; if (!e) return o; n[0] < i[0] && (t ? o.push({ value: Nx(i[0] - e, r) }) : o.push({ value: n[0] })); for ( var a = i[0]; a <= i[1] && (o.push({ value: a }), (a = Nx(a + e, r)) !== o[o.length - 1].value); ) if (o.length > 1e4) return []; var s = o.length ? o[o.length - 1].value : i[1]; return ( n[1] > s && (t ? o.push({ value: Nx(s + e, r) }) : o.push({ value: n[1] })), o ); }), (e.prototype.getMinorTicks = function (t) { for ( var e = this.getTicks(!0), n = [], i = this.getExtent(), r = 1; r < e.length; r++ ) { for ( var o = e[r], a = e[r - 1], s = 0, l = [], u = (o.value - a.value) / t; s < t - 1; ) { var h = Nx(a.value + (s + 1) * u); h > i[0] && h < i[1] && l.push(h), s++; } n.push(l); } return n; }), (e.prototype.getLabel = function (t, e) { if (null == t) return ""; var n = e && e.precision; return ( null == n ? (n = to(t.value) || 0) : "auto" === n && (n = this._intervalPrecision), gp(Nx(t.value, n, !0)) ); }), (e.prototype.calcNiceTicks = function (t, e, n) { t = t || 5; var i = this._extent, r = i[1] - i[0]; if (isFinite(r)) { r < 0 && ((r = -r), i.reverse()); var o = Cx(i, t, e, n); (this._intervalPrecision = o.intervalPrecision), (this._interval = o.interval), (this._niceExtent = o.niceTickExtent); } }), (e.prototype.calcNiceExtent = function (t) { var e = this._extent; if (e[0] === e[1]) if (0 !== e[0]) { var n = Math.abs(e[0]); t.fixMax || (e[1] += n / 2), (e[0] -= n / 2); } else e[1] = 1; var i = e[1] - e[0]; isFinite(i) || ((e[0] = 0), (e[1] = 1)), this.calcNiceTicks( t.splitNumber, t.minInterval, t.maxInterval ); var r = this._interval; t.fixMin || (e[0] = Nx(Math.floor(e[0] / r) * r)), t.fixMax || (e[1] = Nx(Math.ceil(e[1] / r) * r)); }), (e.prototype.setNiceExtent = function (t, e) { this._niceExtent = [t, e]; }), (e.type = "interval"), e ); })(bx); bx.registerClass(Ex); var zx = "undefined" != typeof Float32Array, Vx = zx ? Float32Array : Array; function Bx(t) { return Y(t) ? (zx ? new Float32Array(t) : t) : new Vx(t); } var Fx = "__ec_stack_"; function Gx(t) { return t.get("stack") || Fx + t.seriesIndex; } function Wx(t) { return t.dim + t.index; } function Hx(t, e) { var n = []; return ( e.eachSeriesByType(t, function (t) { jx(t) && n.push(t); }), n ); } function Yx(t) { var e = (function (t) { var e = {}; E(t, function (t) { var n = t.coordinateSystem.getBaseAxis(); if ("time" === n.type || "value" === n.type) for ( var i = t.getData(), r = n.dim + "_" + n.index, o = i.getDimensionIndex(i.mapDimension(n.dim)), a = i.getStore(), s = 0, l = a.count(); s < l; ++s ) { var u = a.get(o, s); e[r] ? e[r].push(u) : (e[r] = [u]); } }); var n = {}; for (var i in e) if (e.hasOwnProperty(i)) { var r = e[i]; if (r) { r.sort(function (t, e) { return t - e; }); for (var o = null, a = 1; a < r.length; ++a) { var s = r[a] - r[a - 1]; s > 0 && (o = null === o ? s : Math.min(o, s)); } n[i] = o; } } return n; })(t), n = []; return ( E(t, function (t) { var i, r = t.coordinateSystem.getBaseAxis(), o = r.getExtent(); if ("category" === r.type) i = r.getBandWidth(); else if ("value" === r.type || "time" === r.type) { var a = r.dim + "_" + r.index, s = e[a], l = Math.abs(o[1] - o[0]), u = r.scale.getExtent(), h = Math.abs(u[1] - u[0]); i = s ? (l / h) * s : l; } else { var c = t.getData(); i = Math.abs(o[1] - o[0]) / c.count(); } var p = $r(t.get("barWidth"), i), d = $r(t.get("barMaxWidth"), i), f = $r(t.get("barMinWidth") || (qx(t) ? 0.5 : 1), i), g = t.get("barGap"), y = t.get("barCategoryGap"); n.push({ bandWidth: i, barWidth: p, barMaxWidth: d, barMinWidth: f, barGap: g, barCategoryGap: y, axisKey: Wx(r), stackId: Gx(t), }); }), Xx(n) ); } function Xx(t) { var e = {}; E(t, function (t, n) { var i = t.axisKey, r = t.bandWidth, o = e[i] || { bandWidth: r, remainedWidth: r, autoWidthCount: 0, categoryGap: null, gap: "20%", stacks: {}, }, a = o.stacks; e[i] = o; var s = t.stackId; a[s] || o.autoWidthCount++, (a[s] = a[s] || { width: 0, maxWidth: 0 }); var l = t.barWidth; l && !a[s].width && ((a[s].width = l), (l = Math.min(o.remainedWidth, l)), (o.remainedWidth -= l)); var u = t.barMaxWidth; u && (a[s].maxWidth = u); var h = t.barMinWidth; h && (a[s].minWidth = h); var c = t.barGap; null != c && (o.gap = c); var p = t.barCategoryGap; null != p && (o.categoryGap = p); }); var n = {}; return ( E(e, function (t, e) { n[e] = {}; var i = t.stacks, r = t.bandWidth, o = t.categoryGap; if (null == o) { var a = G(i).length; o = Math.max(35 - 4 * a, 15) + "%"; } var s = $r(o, r), l = $r(t.gap, 1), u = t.remainedWidth, h = t.autoWidthCount, c = (u - s) / (h + (h - 1) * l); (c = Math.max(c, 0)), E(i, function (t) { var e = t.maxWidth, n = t.minWidth; if (t.width) { i = t.width; e && (i = Math.min(i, e)), n && (i = Math.max(i, n)), (t.width = i), (u -= i + l * i), h--; } else { var i = c; e && e < i && (i = Math.min(e, u)), n && n > i && (i = n), i !== c && ((t.width = i), (u -= i + l * i), h--); } }), (c = (u - s) / (h + (h - 1) * l)), (c = Math.max(c, 0)); var p, d = 0; E(i, function (t, e) { t.width || (t.width = c), (p = t), (d += t.width * (1 + l)); }), p && (d -= p.width * l); var f = -d / 2; E(i, function (t, i) { (n[e][i] = n[e][i] || { bandWidth: r, offset: f, width: t.width, }), (f += t.width * (1 + l)); }); }), n ); } function Ux(t, e) { var n = Hx(t, e), i = Yx(n); E(n, function (t) { var e = t.getData(), n = t.coordinateSystem.getBaseAxis(), r = Gx(t), o = i[Wx(n)][r], a = o.offset, s = o.width; e.setLayout({ bandWidth: o.bandWidth, offset: a, size: s }); }); } function Zx(t) { return { seriesType: t, plan: kg(), reset: function (t) { if (jx(t)) { var e = t.getData(), n = t.coordinateSystem, i = n.getBaseAxis(), r = n.getOtherAxis(i), o = e.getDimensionIndex(e.mapDimension(r.dim)), a = e.getDimensionIndex(e.mapDimension(i.dim)), s = t.get("showBackground", !0), l = e.mapDimension(r.dim), u = e.getCalculationInfo("stackResultDimension"), h = mx(e, l) && !!e.getCalculationInfo("stackedOnSeries"), c = r.isHorizontal(), p = (function (t, e) { var n = e.model.get("startValue"); n || (n = 0); return e.toGlobalCoord( e.dataToCoord( "log" === e.type ? (n > 0 ? n : 1) : n ) ); })(0, r), d = qx(t), f = t.get("barMinHeight") || 0, g = u && e.getDimensionIndex(u), y = e.getLayout("size"), v = e.getLayout("offset"); return { progress: function (t, e) { for ( var i, r = t.count, l = d && Bx(3 * r), u = d && s && Bx(3 * r), m = d && Bx(r), x = n.master.getRect(), _ = c ? x.width : x.height, b = e.getStore(), w = 0; null != (i = t.next()); ) { var S = b.get(h ? g : o, i), M = b.get(a, i), I = p, T = void 0; h && (T = +S - b.get(o, i)); var C = void 0, D = void 0, A = void 0, k = void 0; if (c) { var L = n.dataToPoint([S, M]); if (h) I = n.dataToPoint([T, M])[0]; (C = I), (D = L[1] + v), (A = L[0] - I), (k = y), Math.abs(A) < f && (A = (A < 0 ? -1 : 1) * f); } else { L = n.dataToPoint([M, S]); if (h) I = n.dataToPoint([M, T])[1]; (C = L[0] + v), (D = I), (A = y), (k = L[1] - I), Math.abs(k) < f && (k = (k <= 0 ? -1 : 1) * f); } d ? ((l[w] = C), (l[w + 1] = D), (l[w + 2] = c ? A : k), u && ((u[w] = c ? x.x : C), (u[w + 1] = c ? D : x.y), (u[w + 2] = _)), (m[i] = i)) : e.setItemLayout(i, { x: C, y: D, width: A, height: k, }), (w += 3); } d && e.setLayout({ largePoints: l, largeDataIndices: m, largeBackgroundPoints: u, valueAxisHorizontal: c, }); }, }; } }, }; } function jx(t) { return t.coordinateSystem && "cartesian2d" === t.coordinateSystem.type; } function qx(t) { return t.pipelineContext && t.pipelineContext.large; } var Kx = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "time"), n; } return ( n(e, t), (e.prototype.getLabel = function (t) { var e = this.getSetting("useUTC"); return Jc( t.value, Uc[ (function (t) { switch (t) { case "year": case "month": return "day"; case "millisecond": return "millisecond"; default: return "second"; } })(Kc(this._minLevelUnit)) ] || Uc.second, e, this.getSetting("locale") ); }), (e.prototype.getFormattedLabel = function (t, e, n) { var i = this.getSetting("useUTC"); return (function (t, e, n, i, r) { var o = null; if (U(n)) o = n; else if (X(n)) o = n(t.value, e, { level: t.level }); else { var a = A({}, Yc); if (t.level > 0) for (var s = 0; s < Zc.length; ++s) a[Zc[s]] = "{primary|" + a[Zc[s]] + "}"; var l = n ? (!1 === n.inherit ? n : k(n, a)) : a, u = Qc(t.value, r); if (l[u]) o = l[u]; else if (l.inherit) { for (s = jc.indexOf(u) - 1; s >= 0; --s) if (l[u]) { o = l[u]; break; } o = o || a.none; } if (Y(o)) { var h = null == t.level ? 0 : t.level >= 0 ? t.level : o.length + t.level; o = o[(h = Math.min(h, o.length - 1))]; } } return Jc(new Date(t.value), o, r, i); })(t, e, n, this.getSetting("locale"), i); }), (e.prototype.getTicks = function () { var t = this._interval, e = this._extent, n = []; if (!t) return n; n.push({ value: e[0], level: 0 }); var i = this.getSetting("useUTC"), r = (function (t, e, n, i) { var r = 1e4, o = jc, a = 0; function s(t, e, n, r, o, a, s) { for ( var l = new Date(e), u = e, h = l[r](); u < n && u <= i[1]; ) s.push({ value: u }), (h += t), l[o](h), (u = l.getTime()); s.push({ value: u, notAdd: !0 }); } function l(t, r, o) { var a = [], l = !r.length; if ( !(function (t, e, n, i) { var r = uo(e), o = uo(n), a = function (t) { return ( tp(r, t, i) === tp(o, t, i) ); }, s = function () { return a("year"); }, l = function () { return s() && a("month"); }, u = function () { return l() && a("day"); }, h = function () { return u() && a("hour"); }, c = function () { return h() && a("minute"); }, p = function () { return c() && a("second"); }, d = function () { return p() && a("millisecond"); }; switch (t) { case "year": return s(); case "month": return l(); case "day": return u(); case "hour": return h(); case "minute": return c(); case "second": return p(); case "millisecond": return d(); } })(Kc(t), i[0], i[1], n) ) { l && (r = [ { value: i_(new Date(i[0]), t, n) }, { value: i[1] }, ]); for (var u = 0; u < r.length - 1; u++) { var h = r[u].value, c = r[u + 1].value; if (h !== c) { var p = void 0, d = void 0, f = void 0, g = !1; switch (t) { case "year": (p = Math.max( 1, Math.round(e / Wc / 365) )), (d = ep(n)), (f = lp(n)); break; case "half-year": case "quarter": case "month": (p = Qx(e)), (d = np(n)), (f = up(n)); break; case "week": case "half-week": case "day": (p = Jx(e)), (d = ip(n)), (f = hp(n)), (g = !0); break; case "half-day": case "quarter-day": case "hour": (p = t_(e)), (d = rp(n)), (f = cp(n)); break; case "minute": (p = e_(e, !0)), (d = op(n)), (f = pp(n)); break; case "second": (p = e_(e, !1)), (d = ap(n)), (f = dp(n)); break; case "millisecond": (p = n_(e)), (d = sp(n)), (f = fp(n)); } s(p, h, c, d, f, g, a), "year" === t && o.length > 1 && 0 === u && o.unshift({ value: o[0].value - p, }); } } for (u = 0; u < a.length; u++) o.push(a[u]); return a; } } for ( var u = [], h = [], c = 0, p = 0, d = 0; d < o.length && a++ < r; ++d ) { var f = Kc(o[d]); if ($c(o[d])) if ( (l(o[d], u[u.length - 1] || [], h), f !== (o[d + 1] ? Kc(o[d + 1]) : null)) ) { if (h.length) { (p = c), h.sort(function (t, e) { return t.value - e.value; }); for ( var g = [], y = 0; y < h.length; ++y ) { var v = h[y].value; (0 !== y && h[y - 1].value === v) || (g.push(h[y]), v >= i[0] && v <= i[1] && c++); } var m = (i[1] - i[0]) / e; if (c > 1.5 * m && p > m / 1.5) break; if ( (u.push(g), c > m || t === o[d]) ) break; } h = []; } } 0; var x = B( z(u, function (t) { return B(t, function (t) { return ( t.value >= i[0] && t.value <= i[1] && !t.notAdd ); }); }), function (t) { return t.length > 0; } ), _ = [], b = x.length - 1; for (d = 0; d < x.length; ++d) for (var w = x[d], S = 0; S < w.length; ++S) _.push({ value: w[S].value, level: b - d }); _.sort(function (t, e) { return t.value - e.value; }); var M = []; for (d = 0; d < _.length; ++d) (0 !== d && _[d].value === _[d - 1].value) || M.push(_[d]); return M; })(this._minLevelUnit, this._approxInterval, i, e); return (n = n.concat(r)).push({ value: e[1], level: 0 }), n; }), (e.prototype.calcNiceExtent = function (t) { var e = this._extent; if ( (e[0] === e[1] && ((e[0] -= Wc), (e[1] += Wc)), e[1] === -1 / 0 && e[0] === 1 / 0) ) { var n = new Date(); (e[1] = +new Date( n.getFullYear(), n.getMonth(), n.getDate() )), (e[0] = e[1] - Wc); } this.calcNiceTicks( t.splitNumber, t.minInterval, t.maxInterval ); }), (e.prototype.calcNiceTicks = function (t, e, n) { t = t || 10; var i = this._extent, r = i[1] - i[0]; (this._approxInterval = r / t), null != e && this._approxInterval < e && (this._approxInterval = e), null != n && this._approxInterval > n && (this._approxInterval = n); var o = $x.length, a = Math.min( (function (t, e, n, i) { for (; n < i; ) { var r = (n + i) >>> 1; t[r][1] < e ? (n = r + 1) : (i = r); } return n; })($x, this._approxInterval, 0, o), o - 1 ); (this._interval = $x[a][1]), (this._minLevelUnit = $x[Math.max(a - 1, 0)][0]); }), (e.prototype.parse = function (t) { return j(t) ? t : +uo(t); }), (e.prototype.contain = function (t) { return Lx(this.parse(t), this._extent); }), (e.prototype.normalize = function (t) { return Px(this.parse(t), this._extent); }), (e.prototype.scale = function (t) { return Ox(t, this._extent); }), (e.type = "time"), e ); })(Ex), $x = [ ["second", Bc], ["minute", Fc], ["hour", Gc], ["quarter-day", 216e5], ["half-day", 432e5], ["day", 10368e4], ["half-week", 3024e5], ["week", 6048e5], ["month", 26784e5], ["quarter", 8208e6], ["half-year", Hc / 2], ["year", Hc], ]; function Jx(t, e) { return (t /= Wc) > 16 ? 16 : t > 7.5 ? 7 : t > 3.5 ? 4 : t > 1.5 ? 2 : 1; } function Qx(t) { return (t /= 2592e6) > 6 ? 6 : t > 3 ? 3 : t > 2 ? 2 : 1; } function t_(t) { return (t /= Gc) > 12 ? 12 : t > 6 ? 6 : t > 3.5 ? 4 : t > 2 ? 2 : 1; } function e_(t, e) { return (t /= e ? Fc : Bc) > 30 ? 30 : t > 20 ? 20 : t > 15 ? 15 : t > 10 ? 10 : t > 5 ? 5 : t > 2 ? 2 : 1; } function n_(t) { return po(t, !0); } function i_(t, e, n) { var i = new Date(t); switch (Kc(e)) { case "year": case "month": i[up(n)](0); case "day": i[hp(n)](1); case "hour": i[cp(n)](0); case "minute": i[pp(n)](0); case "second": i[dp(n)](0), i[fp(n)](0); } return i.getTime(); } bx.registerClass(Kx); var r_ = bx.prototype, o_ = Ex.prototype, a_ = Jr, s_ = Math.floor, l_ = Math.ceil, u_ = Math.pow, h_ = Math.log, c_ = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return ( (e.type = "log"), (e.base = 10), (e._originalScale = new Ex()), (e._interval = 0), e ); } return ( n(e, t), (e.prototype.getTicks = function (t) { var e = this._originalScale, n = this._extent, i = e.getExtent(); return z( o_.getTicks.call(this, t), function (t) { var e = t.value, r = Jr(u_(this.base, e)); return ( (r = e === n[0] && this._fixMin ? d_(r, i[0]) : r), { value: (r = e === n[1] && this._fixMax ? d_(r, i[1]) : r), } ); }, this ); }), (e.prototype.setExtent = function (t, e) { var n = h_(this.base); (t = h_(Math.max(0, t)) / n), (e = h_(Math.max(0, e)) / n), o_.setExtent.call(this, t, e); }), (e.prototype.getExtent = function () { var t = this.base, e = r_.getExtent.call(this); (e[0] = u_(t, e[0])), (e[1] = u_(t, e[1])); var n = this._originalScale.getExtent(); return ( this._fixMin && (e[0] = d_(e[0], n[0])), this._fixMax && (e[1] = d_(e[1], n[1])), e ); }), (e.prototype.unionExtent = function (t) { this._originalScale.unionExtent(t); var e = this.base; (t[0] = h_(t[0]) / h_(e)), (t[1] = h_(t[1]) / h_(e)), r_.unionExtent.call(this, t); }), (e.prototype.unionExtentFromData = function (t, e) { this.unionExtent(t.getApproximateExtent(e)); }), (e.prototype.calcNiceTicks = function (t) { t = t || 10; var e = this._extent, n = e[1] - e[0]; if (!(n === 1 / 0 || n <= 0)) { var i = ho(n); for ( (t / n) * i <= 0.5 && (i *= 10); !isNaN(i) && Math.abs(i) < 1 && Math.abs(i) > 0; ) i *= 10; var r = [Jr(l_(e[0] / i) * i), Jr(s_(e[1] / i) * i)]; (this._interval = i), (this._niceExtent = r); } }), (e.prototype.calcNiceExtent = function (t) { o_.calcNiceExtent.call(this, t), (this._fixMin = t.fixMin), (this._fixMax = t.fixMax); }), (e.prototype.parse = function (t) { return t; }), (e.prototype.contain = function (t) { return Lx((t = h_(t) / h_(this.base)), this._extent); }), (e.prototype.normalize = function (t) { return Px((t = h_(t) / h_(this.base)), this._extent); }), (e.prototype.scale = function (t) { return (t = Ox(t, this._extent)), u_(this.base, t); }), (e.type = "log"), e ); })(bx), p_ = c_.prototype; function d_(t, e) { return a_(t, to(e)); } (p_.getMinorTicks = o_.getMinorTicks), (p_.getLabel = o_.getLabel), bx.registerClass(c_); var f_ = (function () { function t(t, e, n) { this._prepareParams(t, e, n); } return ( (t.prototype._prepareParams = function (t, e, n) { n[1] < n[0] && (n = [NaN, NaN]), (this._dataMin = n[0]), (this._dataMax = n[1]); var i = (this._isOrdinal = "ordinal" === t.type); this._needCrossZero = "interval" === t.type && e.getNeedCrossZero && e.getNeedCrossZero(); var r = e.get("min", !0); null == r && (r = e.get("startValue", !0)); var o = (this._modelMinRaw = r); X(o) ? (this._modelMinNum = m_( t, o({ min: n[0], max: n[1] }) )) : "dataMin" !== o && (this._modelMinNum = m_(t, o)); var a = (this._modelMaxRaw = e.get("max", !0)); if ( (X(a) ? (this._modelMaxNum = m_( t, a({ min: n[0], max: n[1] }) )) : "dataMax" !== a && (this._modelMaxNum = m_(t, a)), i) ) this._axisDataLen = e.getCategories().length; else { var s = e.get("boundaryGap"), l = Y(s) ? s : [s || 0, s || 0]; "boolean" == typeof l[0] || "boolean" == typeof l[1] ? (this._boundaryGapInner = [0, 0]) : (this._boundaryGapInner = [ Cr(l[0], 1), Cr(l[1], 1), ]); } }), (t.prototype.calculate = function () { var t = this._isOrdinal, e = this._dataMin, n = this._dataMax, i = this._axisDataLen, r = this._boundaryGapInner, o = t ? null : n - e || Math.abs(e), a = "dataMin" === this._modelMinRaw ? e : this._modelMinNum, s = "dataMax" === this._modelMaxRaw ? n : this._modelMaxNum, l = null != a, u = null != s; null == a && (a = t ? (i ? 0 : NaN) : e - r[0] * o), null == s && (s = t ? (i ? i - 1 : NaN) : n + r[1] * o), (null == a || !isFinite(a)) && (a = NaN), (null == s || !isFinite(s)) && (s = NaN); var h = nt(a) || nt(s) || (t && !i); this._needCrossZero && (a > 0 && s > 0 && !l && (a = 0), a < 0 && s < 0 && !u && (s = 0)); var c = this._determinedMin, p = this._determinedMax; return ( null != c && ((a = c), (l = !0)), null != p && ((s = p), (u = !0)), { min: a, max: s, minFixed: l, maxFixed: u, isBlank: h } ); }), (t.prototype.modifyDataMinMax = function (t, e) { this[y_[t]] = e; }), (t.prototype.setDeterminedMinMax = function (t, e) { var n = g_[t]; this[n] = e; }), (t.prototype.freeze = function () { this.frozen = !0; }), t ); })(), g_ = { min: "_determinedMin", max: "_determinedMax" }, y_ = { min: "_dataMin", max: "_dataMax" }; function v_(t, e, n) { var i = t.rawExtentInfo; return i || ((i = new f_(t, e, n)), (t.rawExtentInfo = i), i); } function m_(t, e) { return null == e ? null : nt(e) ? NaN : t.parse(e); } function x_(t, e) { var n = t.type, i = v_(t, e, t.getExtent()).calculate(); t.setBlank(i.isBlank); var r = i.min, o = i.max, a = e.ecModel; if (a && "time" === n) { var s = Hx("bar", a), l = !1; if ( (E(s, function (t) { l = l || t.getBaseAxis() === e.axis; }), l) ) { var u = Yx(s), h = (function (t, e, n, i) { var r = n.axis.getExtent(), o = Math.abs(r[1] - r[0]), a = (function (t, e, n) { if (t && e) { var i = t[Wx(e)]; return null != i && null != n ? i[Gx(n)] : i; } })(i, n.axis); if (void 0 === a) return { min: t, max: e }; var s = 1 / 0; E(a, function (t) { s = Math.min(t.offset, s); }); var l = -1 / 0; E(a, function (t) { l = Math.max(t.offset + t.width, l); }), (s = Math.abs(s)), (l = Math.abs(l)); var u = s + l, h = e - t, c = h / (1 - (s + l) / o) - h; return ( (e += c * (l / u)), (t -= c * (s / u)), { min: t, max: e } ); })(r, o, e, u); (r = h.min), (o = h.max); } } return { extent: [r, o], fixMin: i.minFixed, fixMax: i.maxFixed }; } function __(t, e) { var n = e, i = x_(t, n), r = i.extent, o = n.get("splitNumber"); t instanceof c_ && (t.base = n.get("logBase")); var a = t.type, s = n.get("interval"), l = "interval" === a || "time" === a; t.setExtent(r[0], r[1]), t.calcNiceExtent({ splitNumber: o, fixMin: i.fixMin, fixMax: i.fixMax, minInterval: l ? n.get("minInterval") : null, maxInterval: l ? n.get("maxInterval") : null, }), null != s && t.setInterval && t.setInterval(s); } function b_(t, e) { if ((e = e || t.get("type"))) switch (e) { case "category": return new Rx({ ordinalMeta: t.getOrdinalMeta ? t.getOrdinalMeta() : t.getCategories(), extent: [1 / 0, -1 / 0], }); case "time": return new Kx({ locale: t.ecModel.getLocaleModel(), useUTC: t.ecModel.get("useUTC"), }); default: return new (bx.getClass(e) || Ex)(); } } function w_(t) { var e, n, i = t.getLabelModel().get("formatter"), r = "category" === t.type ? t.scale.getExtent()[0] : null; return "time" === t.scale.type ? ((n = i), function (e, i) { return t.scale.getFormattedLabel(e, i, n); }) : U(i) ? (function (e) { return function (n) { var i = t.scale.getLabel(n); return e.replace("{value}", null != i ? i : ""); }; })(i) : X(i) ? ((e = i), function (n, i) { return ( null != r && (i = n.value - r), e( S_(t, n), i, null != n.level ? { level: n.level } : null ) ); }) : function (e) { return t.scale.getLabel(e); }; } function S_(t, e) { return "category" === t.type ? t.scale.getLabel(e) : e.value; } function M_(t, e) { var n = (e * Math.PI) / 180, i = t.width, r = t.height, o = i * Math.abs(Math.cos(n)) + Math.abs(r * Math.sin(n)), a = i * Math.abs(Math.sin(n)) + Math.abs(r * Math.cos(n)); return new ze(t.x, t.y, o, a); } function I_(t) { var e = t.get("interval"); return null == e ? "auto" : e; } function T_(t) { return "category" === t.type && 0 === I_(t.getLabelModel()); } function C_(t, e) { var n = {}; return ( E(t.mapDimensionsAll(e), function (e) { n[xx(t, e)] = !0; }), G(n) ); } var D_ = (function () { function t() {} return ( (t.prototype.getNeedCrossZero = function () { return !this.option.scale; }), (t.prototype.getCoordSysModel = function () {}), t ); })(); var A_ = { isDimensionStacked: mx, enableDataStack: vx, getStackedDimension: xx, }; var k_ = Object.freeze({ __proto__: null, createList: function (t) { return _x(null, t); }, getLayoutRect: kp, dataStack: A_, createScale: function (t, e) { var n = e; e instanceof Cc || (n = new Cc(e)); var i = b_(n); return i.setExtent(t[0], t[1]), __(i, n), i; }, mixinAxisModelCommonMethods: function (t) { R(t, D_); }, getECData: rl, createTextStyle: function (t, e) { return oc(t, null, null, "normal" !== (e = e || {}).state); }, createDimensions: function (t, e) { return px(t, e).dimensions; }, createSymbol: Xy, enableHoverEmphasis: Ul, }); function L_(t, e) { return Math.abs(t - e) < 1e-8; } function P_(t, e, n) { var i = 0, r = t[0]; if (!r) return !1; for (var o = 1; o < t.length; o++) { var a = t[o]; (i += ms(r[0], r[1], a[0], a[1], e, n)), (r = a); } var s = t[0]; return ( (L_(r[0], s[0]) && L_(r[1], s[1])) || (i += ms(r[0], r[1], s[0], s[1], e, n)), 0 !== i ); } var O_ = []; function R_(t, e) { for (var n = 0; n < t.length; n++) Wt(t[n], t[n], e); } function N_(t, e, n, i) { for (var r = 0; r < t.length; r++) { var o = t[r]; i && (o = i.project(o)), o && isFinite(o[0]) && isFinite(o[1]) && (Ht(e, e, o), Yt(n, n, o)); } } var E_ = (function () { function t(t) { this.name = t; } return ( (t.prototype.setCenter = function (t) { this._center = t; }), (t.prototype.getCenter = function () { var t = this._center; return t || (t = this._center = this.calcCenter()), t; }), t ); })(), z_ = function (t, e) { (this.type = "polygon"), (this.exterior = t), (this.interiors = e); }, V_ = function (t) { (this.type = "linestring"), (this.points = t); }, B_ = (function (t) { function e(e, n, i) { var r = t.call(this, e) || this; return ( (r.type = "geoJSON"), (r.geometries = n), (r._center = i && [i[0], i[1]]), r ); } return ( n(e, t), (e.prototype.calcCenter = function () { for ( var t, e = this.geometries, n = 0, i = 0; i < e.length; i++ ) { var r = e[i], o = r.exterior, a = o && o.length; a > n && ((t = r), (n = a)); } if (t) return (function (t) { for ( var e = 0, n = 0, i = 0, r = t.length, o = t[r - 1][0], a = t[r - 1][1], s = 0; s < r; s++ ) { var l = t[s][0], u = t[s][1], h = o * u - l * a; (e += h), (n += (o + l) * h), (i += (a + u) * h), (o = l), (a = u); } return e ? [n / e / 3, i / e / 3, e] : [t[0][0] || 0, t[0][1] || 0]; })(t.exterior); var s = this.getBoundingRect(); return [s.x + s.width / 2, s.y + s.height / 2]; }), (e.prototype.getBoundingRect = function (t) { var e = this._rect; if (e && !t) return e; var n = [1 / 0, 1 / 0], i = [-1 / 0, -1 / 0]; return ( E(this.geometries, function (e) { "polygon" === e.type ? N_(e.exterior, n, i, t) : E(e.points, function (e) { N_(e, n, i, t); }); }), (isFinite(n[0]) && isFinite(n[1]) && isFinite(i[0]) && isFinite(i[1])) || (n[0] = n[1] = i[0] = i[1] = 0), (e = new ze(n[0], n[1], i[0] - n[0], i[1] - n[1])), t || (this._rect = e), e ); }), (e.prototype.contain = function (t) { var e = this.getBoundingRect(), n = this.geometries; if (!e.contain(t[0], t[1])) return !1; t: for (var i = 0, r = n.length; i < r; i++) { var o = n[i]; if ("polygon" === o.type) { var a = o.exterior, s = o.interiors; if (P_(a, t[0], t[1])) { for (var l = 0; l < (s ? s.length : 0); l++) if (P_(s[l], t[0], t[1])) continue t; return !0; } } } return !1; }), (e.prototype.transformTo = function (t, e, n, i) { var r = this.getBoundingRect(), o = r.width / r.height; n ? i || (i = n / o) : (n = o * i); for ( var a = new ze(t, e, n, i), s = r.calculateTransform(a), l = this.geometries, u = 0; u < l.length; u++ ) { var h = l[u]; "polygon" === h.type ? (R_(h.exterior, s), E(h.interiors, function (t) { R_(t, s); })) : E(h.points, function (t) { R_(t, s); }); } (r = this._rect).copy(a), (this._center = [ r.x + r.width / 2, r.y + r.height / 2, ]); }), (e.prototype.cloneShallow = function (t) { null == t && (t = this.name); var n = new e(t, this.geometries, this._center); return (n._rect = this._rect), (n.transformTo = null), n; }), e ); })(E_), F_ = (function (t) { function e(e, n) { var i = t.call(this, e) || this; return (i.type = "geoSVG"), (i._elOnlyForCalculate = n), i; } return ( n(e, t), (e.prototype.calcCenter = function () { for ( var t = this._elOnlyForCalculate, e = t.getBoundingRect(), n = [e.x + e.width / 2, e.y + e.height / 2], i = xe(O_), r = t; r && !r.isGeoSVGGraphicRoot; ) be(i, r.getLocalTransform(), i), (r = r.parent); return Ie(i, i), Wt(n, n, i), n; }), e ); })(E_); function G_(t, e, n) { for (var i = 0; i < t.length; i++) t[i] = W_(t[i], e[i], n); } function W_(t, e, n) { for (var i = [], r = e[0], o = e[1], a = 0; a < t.length; a += 2) { var s = t.charCodeAt(a) - 64, l = t.charCodeAt(a + 1) - 64; (s = (s >> 1) ^ -(1 & s)), (l = (l >> 1) ^ -(1 & l)), (r = s += r), (o = l += o), i.push([s / n, l / n]); } return i; } function H_(t, e) { return z( B( (t = (function (t) { if (!t.UTF8Encoding) return t; var e = t, n = e.UTF8Scale; return ( null == n && (n = 1024), E(e.features, function (t) { var e = t.geometry, i = e.encodeOffsets, r = e.coordinates; if (i) switch (e.type) { case "LineString": e.coordinates = W_(r, i, n); break; case "Polygon": case "MultiLineString": G_(r, i, n); break; case "MultiPolygon": E(r, function (t, e) { return G_(t, i[e], n); }); } }), (e.UTF8Encoding = !1), e ); })(t)).features, function (t) { return ( t.geometry && t.properties && t.geometry.coordinates.length > 0 ); } ), function (t) { var n = t.properties, i = t.geometry, r = []; switch (i.type) { case "Polygon": var o = i.coordinates; r.push(new z_(o[0], o.slice(1))); break; case "MultiPolygon": E(i.coordinates, function (t) { t[0] && r.push(new z_(t[0], t.slice(1))); }); break; case "LineString": r.push(new V_([i.coordinates])); break; case "MultiLineString": r.push(new V_(i.coordinates)); } var a = new B_(n[e || "name"], r, n.cp); return (a.properties = n), a; } ); } var Y_ = Object.freeze({ __proto__: null, linearMap: Kr, round: Jr, asc: Qr, getPrecision: to, getPrecisionSafe: eo, getPixelPrecision: no, getPercentWithPrecision: function (t, e, n) { return (t[e] && io(t, n)[e]) || 0; }, MAX_SAFE_INTEGER: oo, remRadian: ao, isRadianAroundZero: so, parseDate: uo, quantity: ho, quantityExponent: co, nice: po, quantile: fo, reformIntervals: go, isNumeric: vo, numericToNumber: yo, }), X_ = Object.freeze({ __proto__: null, parse: uo, format: Jc }), U_ = Object.freeze({ __proto__: null, extendShape: Ch, extendPath: Ah, makePath: Ph, makeImage: Oh, mergePath: Nh, resizePath: Eh, createIcon: Uh, updateProps: vh, initProps: mh, getTransform: Bh, clipPointsByRect: Yh, clipRectByRect: Xh, registerShape: kh, getShapeClass: Lh, Group: Br, Image: Ns, Text: Xs, Circle: Su, Ellipse: Iu, Sector: Fu, Ring: Wu, Polygon: Xu, Polyline: Zu, Rect: Ws, Line: Ku, BezierCurve: th, Arc: nh, IncrementalDisplayable: dh, CompoundPath: ih, LinearGradient: oh, RadialGradient: ah, BoundingRect: ze, }), Z_ = Object.freeze({ __proto__: null, addCommas: gp, toCamelCase: yp, normalizeCssArray: vp, encodeHTML: re, formatTpl: bp, getTooltipMarker: wp, formatTime: function (t, e, n) { ("week" !== t && "month" !== t && "quarter" !== t && "half-year" !== t && "year" !== t) || (t = "MM-dd\nyyyy"); var i = uo(e), r = n ? "getUTC" : "get", o = i[r + "FullYear"](), a = i[r + "Month"]() + 1, s = i[r + "Date"](), l = i[r + "Hours"](), u = i[r + "Minutes"](), h = i[r + "Seconds"](), c = i[r + "Milliseconds"](); return (t = t .replace("MM", qc(a, 2)) .replace("M", a) .replace("yyyy", o) .replace("yy", qc((o % 100) + "", 2)) .replace("dd", qc(s, 2)) .replace("d", s) .replace("hh", qc(l, 2)) .replace("h", l) .replace("mm", qc(u, 2)) .replace("m", u) .replace("ss", qc(h, 2)) .replace("s", h) .replace("SSS", qc(c, 3))); }, capitalFirst: function (t) { return t ? t.charAt(0).toUpperCase() + t.substr(1) : t; }, truncateText: function (t, e, n, i, r) { var o = {}; return pa(o, t, e, n, i, r), o.text; }, getTextRect: function (t, e, n, i, r, o, a, s) { return new Xs({ style: { text: t, font: e, align: n, verticalAlign: i, padding: r, rich: o, overflow: a ? "truncate" : null, lineHeight: s, }, }).getBoundingRect(); }, }), j_ = Object.freeze({ __proto__: null, map: z, each: E, indexOf: P, inherits: O, reduce: V, filter: B, bind: W, curry: H, isArray: Y, isString: U, isObject: q, isFunction: X, extend: A, defaults: k, clone: T, merge: C, }), q_ = Vo(); function K_(t, e) { var n = z(e, function (e) { return t.scale.parse(e); }); return ( "time" === t.type && n.length > 0 && (n.sort(), n.unshift(n[0]), n.push(n[n.length - 1])), n ); } function $_(t) { var e = t.getLabelModel().get("customValues"); if (e) { var n = w_(t), i = t.scale.getExtent(); return { labels: z( B(K_(t, e), function (t) { return t >= i[0] && t <= i[1]; }), function (e) { var i = { value: e }; return { formattedLabel: n(i), rawLabel: t.scale.getLabel(i), tickValue: e, }; } ), }; } return "category" === t.type ? (function (t) { var e = t.getLabelModel(), n = Q_(t, e); return !e.get("show") || t.scale.isBlank() ? { labels: [], labelCategoryInterval: n.labelCategoryInterval, } : n; })(t) : (function (t) { var e = t.scale.getTicks(), n = w_(t); return { labels: z(e, function (e, i) { return { level: e.level, formattedLabel: n(e, i), rawLabel: t.scale.getLabel(e), tickValue: e.value, }; }), }; })(t); } function J_(t, e) { var n = t.getTickModel().get("customValues"); if (n) { var i = t.scale.getExtent(); return { ticks: B(K_(t, n), function (t) { return t >= i[0] && t <= i[1]; }), }; } return "category" === t.type ? (function (t, e) { var n, i, r = tb(t, "ticks"), o = I_(e), a = eb(r, o); if (a) return a; (e.get("show") && !t.scale.isBlank()) || (n = []); if (X(o)) n = rb(t, o, !0); else if ("auto" === o) { var s = Q_(t, t.getLabelModel()); (i = s.labelCategoryInterval), (n = z(s.labels, function (t) { return t.tickValue; })); } else n = ib(t, (i = o), !0); return nb(r, o, { ticks: n, tickCategoryInterval: i }); })(t, e) : { ticks: z(t.scale.getTicks(), function (t) { return t.value; }), }; } function Q_(t, e) { var n, i, r = tb(t, "labels"), o = I_(e), a = eb(r, o); return ( a || (X(o) ? (n = rb(t, o)) : ((i = "auto" === o ? (function (t) { var e = q_(t).autoInterval; return null != e ? e : (q_(t).autoInterval = t.calculateCategoryInterval()); })(t) : o), (n = ib(t, i))), nb(r, o, { labels: n, labelCategoryInterval: i })) ); } function tb(t, e) { return q_(t)[e] || (q_(t)[e] = []); } function eb(t, e) { for (var n = 0; n < t.length; n++) if (t[n].key === e) return t[n].value; } function nb(t, e, n) { return t.push({ key: e, value: n }), n; } function ib(t, e, n) { var i = w_(t), r = t.scale, o = r.getExtent(), a = t.getLabelModel(), s = [], l = Math.max((e || 0) + 1, 1), u = o[0], h = r.count(); 0 !== u && l > 1 && h / l > 2 && (u = Math.round(Math.ceil(u / l) * l)); var c = T_(t), p = a.get("showMinLabel") || c, d = a.get("showMaxLabel") || c; p && u !== o[0] && g(o[0]); for (var f = u; f <= o[1]; f += l) g(f); function g(t) { var e = { value: t }; s.push( n ? t : { formattedLabel: i(e), rawLabel: r.getLabel(e), tickValue: t, } ); } return d && f - l !== o[1] && g(o[1]), s; } function rb(t, e, n) { var i = t.scale, r = w_(t), o = []; return ( E(i.getTicks(), function (t) { var a = i.getLabel(t), s = t.value; e(t.value, a) && o.push( n ? s : { formattedLabel: r(t), rawLabel: a, tickValue: s, } ); }), o ); } var ob = [0, 1], ab = (function () { function t(t, e, n) { (this.onBand = !1), (this.inverse = !1), (this.dim = t), (this.scale = e), (this._extent = n || [0, 0]); } return ( (t.prototype.contain = function (t) { var e = this._extent, n = Math.min(e[0], e[1]), i = Math.max(e[0], e[1]); return t >= n && t <= i; }), (t.prototype.containData = function (t) { return this.scale.contain(t); }), (t.prototype.getExtent = function () { return this._extent.slice(); }), (t.prototype.getPixelPrecision = function (t) { return no(t || this.scale.getExtent(), this._extent); }), (t.prototype.setExtent = function (t, e) { var n = this._extent; (n[0] = t), (n[1] = e); }), (t.prototype.dataToCoord = function (t, e) { var n = this._extent, i = this.scale; return ( (t = i.normalize(t)), this.onBand && "ordinal" === i.type && sb((n = n.slice()), i.count()), Kr(t, ob, n, e) ); }), (t.prototype.coordToData = function (t, e) { var n = this._extent, i = this.scale; this.onBand && "ordinal" === i.type && sb((n = n.slice()), i.count()); var r = Kr(t, n, ob, e); return this.scale.scale(r); }), (t.prototype.pointToData = function (t, e) {}), (t.prototype.getTicksCoords = function (t) { var e = (t = t || {}).tickModel || this.getTickModel(), n = z( J_(this, e).ticks, function (t) { return { coord: this.dataToCoord( "ordinal" === this.scale.type ? this.scale.getRawOrdinalNumber(t) : t ), tickValue: t, }; }, this ); return ( (function (t, e, n, i) { var r = e.length; if (!t.onBand || n || !r) return; var o, a, s = t.getExtent(); if (1 === r) (e[0].coord = s[0]), (o = e[1] = { coord: s[1], tickValue: e[0].tickValue, }); else { var l = e[r - 1].tickValue - e[0].tickValue, u = (e[r - 1].coord - e[0].coord) / l; E(e, function (t) { t.coord -= u / 2; }); var h = t.scale.getExtent(); (a = 1 + h[1] - e[r - 1].tickValue), (o = { coord: e[r - 1].coord + u * a, tickValue: h[1] + 1, }), e.push(o); } var c = s[0] > s[1]; p(e[0].coord, s[0]) && (i ? (e[0].coord = s[0]) : e.shift()); i && p(s[0], e[0].coord) && e.unshift({ coord: s[0] }); p(s[1], o.coord) && (i ? (o.coord = s[1]) : e.pop()); i && p(o.coord, s[1]) && e.push({ coord: s[1] }); function p(t, e) { return ( (t = Jr(t)), (e = Jr(e)), c ? t > e : t < e ); } })(this, n, e.get("alignWithLabel"), t.clamp), n ); }), (t.prototype.getMinorTicksCoords = function () { if ("ordinal" === this.scale.type) return []; var t = this.model.getModel("minorTick").get("splitNumber"); return ( (t > 0 && t < 100) || (t = 5), z( this.scale.getMinorTicks(t), function (t) { return z( t, function (t) { return { coord: this.dataToCoord(t), tickValue: t, }; }, this ); }, this ) ); }), (t.prototype.getViewLabels = function () { return $_(this).labels; }), (t.prototype.getLabelModel = function () { return this.model.getModel("axisLabel"); }), (t.prototype.getTickModel = function () { return this.model.getModel("axisTick"); }), (t.prototype.getBandWidth = function () { var t = this._extent, e = this.scale.getExtent(), n = e[1] - e[0] + (this.onBand ? 1 : 0); 0 === n && (n = 1); var i = Math.abs(t[1] - t[0]); return Math.abs(i) / n; }), (t.prototype.calculateCategoryInterval = function () { return (function (t) { var e = (function (t) { var e = t.getLabelModel(); return { axisRotate: t.getRotate ? t.getRotate() : t.isHorizontal && !t.isHorizontal() ? 90 : 0, labelRotate: e.get("rotate") || 0, font: e.getFont(), }; })(t), n = w_(t), i = ((e.axisRotate - e.labelRotate) / 180) * Math.PI, r = t.scale, o = r.getExtent(), a = r.count(); if (o[1] - o[0] < 1) return 0; var s = 1; a > 40 && (s = Math.max(1, Math.floor(a / 40))); for ( var l = o[0], u = t.dataToCoord(l + 1) - t.dataToCoord(l), h = Math.abs(u * Math.cos(i)), c = Math.abs(u * Math.sin(i)), p = 0, d = 0; l <= o[1]; l += s ) { var f, g, y = Sr( n({ value: l }), e.font, "center", "top" ); (f = 1.3 * y.width), (g = 1.3 * y.height), (p = Math.max(p, f, 7)), (d = Math.max(d, g, 7)); } var v = p / h, m = d / c; isNaN(v) && (v = 1 / 0), isNaN(m) && (m = 1 / 0); var x = Math.max(0, Math.floor(Math.min(v, m))), _ = q_(t.model), b = t.getExtent(), w = _.lastAutoInterval, S = _.lastTickCount; return ( null != w && null != S && Math.abs(w - x) <= 1 && Math.abs(S - a) <= 1 && w > x && _.axisExtent0 === b[0] && _.axisExtent1 === b[1] ? (x = w) : ((_.lastTickCount = a), (_.lastAutoInterval = x), (_.axisExtent0 = b[0]), (_.axisExtent1 = b[1])), x ); })(this); }), t ); })(); function sb(t, e) { var n = (t[1] - t[0]) / e / 2; (t[0] += n), (t[1] -= n); } var lb = 2 * Math.PI, ub = hs.CMD, hb = ["top", "right", "bottom", "left"]; function cb(t, e, n, i, r) { var o = n.width, a = n.height; switch (t) { case "top": i.set(n.x + o / 2, n.y - e), r.set(0, -1); break; case "bottom": i.set(n.x + o / 2, n.y + a + e), r.set(0, 1); break; case "left": i.set(n.x - e, n.y + a / 2), r.set(-1, 0); break; case "right": i.set(n.x + o + e, n.y + a / 2), r.set(1, 0); } } function pb(t, e, n, i, r, o, a, s, l) { (a -= t), (s -= e); var u = Math.sqrt(a * a + s * s), h = (a /= u) * n + t, c = (s /= u) * n + e; if (Math.abs(i - r) % lb < 1e-4) return (l[0] = h), (l[1] = c), u - n; if (o) { var p = i; (i = gs(r)), (r = gs(p)); } else (i = gs(i)), (r = gs(r)); i > r && (r += lb); var d = Math.atan2(s, a); if ( (d < 0 && (d += lb), (d >= i && d <= r) || (d + lb >= i && d + lb <= r)) ) return (l[0] = h), (l[1] = c), u - n; var f = n * Math.cos(i) + t, g = n * Math.sin(i) + e, y = n * Math.cos(r) + t, v = n * Math.sin(r) + e, m = (f - a) * (f - a) + (g - s) * (g - s), x = (y - a) * (y - a) + (v - s) * (v - s); return m < x ? ((l[0] = f), (l[1] = g), Math.sqrt(m)) : ((l[0] = y), (l[1] = v), Math.sqrt(x)); } function db(t, e, n, i, r, o, a, s) { var l = r - t, u = o - e, h = n - t, c = i - e, p = Math.sqrt(h * h + c * c), d = (l * (h /= p) + u * (c /= p)) / p; s && (d = Math.min(Math.max(d, 0), 1)), (d *= p); var f = (a[0] = t + d * h), g = (a[1] = e + d * c); return Math.sqrt((f - r) * (f - r) + (g - o) * (g - o)); } function fb(t, e, n, i, r, o, a) { n < 0 && ((t += n), (n = -n)), i < 0 && ((e += i), (i = -i)); var s = t + n, l = e + i, u = (a[0] = Math.min(Math.max(r, t), s)), h = (a[1] = Math.min(Math.max(o, e), l)); return Math.sqrt((u - r) * (u - r) + (h - o) * (h - o)); } var gb = []; function yb(t, e, n) { var i = fb(e.x, e.y, e.width, e.height, t.x, t.y, gb); return n.set(gb[0], gb[1]), i; } function vb(t, e, n) { for ( var i, r, o = 0, a = 0, s = 0, l = 0, u = 1 / 0, h = e.data, c = t.x, p = t.y, d = 0; d < h.length; ) { var f = h[d++]; 1 === d && ((s = o = h[d]), (l = a = h[d + 1])); var g = u; switch (f) { case ub.M: (o = s = h[d++]), (a = l = h[d++]); break; case ub.L: (g = db(o, a, h[d], h[d + 1], c, p, gb, !0)), (o = h[d++]), (a = h[d++]); break; case ub.C: (g = Sn( o, a, h[d++], h[d++], h[d++], h[d++], h[d], h[d + 1], c, p, gb )), (o = h[d++]), (a = h[d++]); break; case ub.Q: (g = An(o, a, h[d++], h[d++], h[d], h[d + 1], c, p, gb)), (o = h[d++]), (a = h[d++]); break; case ub.A: var y = h[d++], v = h[d++], m = h[d++], x = h[d++], _ = h[d++], b = h[d++]; d += 1; var w = !!(1 - h[d++]); (i = Math.cos(_) * m + y), (r = Math.sin(_) * x + v), d <= 1 && ((s = i), (l = r)), (g = pb( y, v, x, _, _ + b, w, ((c - y) * x) / m + y, p, gb )), (o = Math.cos(_ + b) * m + y), (a = Math.sin(_ + b) * x + v); break; case ub.R: g = fb( (s = o = h[d++]), (l = a = h[d++]), h[d++], h[d++], c, p, gb ); break; case ub.Z: (g = db(o, a, s, l, c, p, gb, !0)), (o = s), (a = l); } g < u && ((u = g), n.set(gb[0], gb[1])); } return u; } var mb = new De(), xb = new De(), _b = new De(), bb = new De(), wb = new De(); function Sb(t, e) { if (t) { var n = t.getTextGuideLine(), i = t.getTextContent(); if (i && n) { var r = t.textGuideLineConfig || {}, o = [ [0, 0], [0, 0], [0, 0], ], a = r.candidates || hb, s = i.getBoundingRect().clone(); s.applyTransform(i.getComputedTransform()); var l = 1 / 0, u = r.anchor, h = t.getComputedTransform(), c = h && Ie([], h), p = e.get("length2") || 0; u && _b.copy(u); for (var d = 0; d < a.length; d++) { cb(a[d], 0, s, mb, bb), De.scaleAndAdd(xb, mb, bb, p), xb.transform(c); var f = t.getBoundingRect(), g = u ? u.distance(xb) : t instanceof ks ? vb(xb, t.path, _b) : yb(xb, f, _b); g < l && ((l = g), xb.transform(h), _b.transform(h), _b.toArray(o[0]), xb.toArray(o[1]), mb.toArray(o[2])); } Tb(o, e.get("minTurnAngle")), n.setShape({ points: o }); } } } var Mb = [], Ib = new De(); function Tb(t, e) { if (e <= 180 && e > 0) { (e = (e / 180) * Math.PI), mb.fromArray(t[0]), xb.fromArray(t[1]), _b.fromArray(t[2]), De.sub(bb, mb, xb), De.sub(wb, _b, xb); var n = bb.len(), i = wb.len(); if (!(n < 0.001 || i < 0.001)) { bb.scale(1 / n), wb.scale(1 / i); var r = bb.dot(wb); if (Math.cos(e) < r) { var o = db(xb.x, xb.y, _b.x, _b.y, mb.x, mb.y, Mb, !1); Ib.fromArray(Mb), Ib.scaleAndAdd(wb, o / Math.tan(Math.PI - e)); var a = _b.x !== xb.x ? (Ib.x - xb.x) / (_b.x - xb.x) : (Ib.y - xb.y) / (_b.y - xb.y); if (isNaN(a)) return; a < 0 ? De.copy(Ib, xb) : a > 1 && De.copy(Ib, _b), Ib.toArray(t[1]); } } } } function Cb(t, e, n) { if (n <= 180 && n > 0) { (n = (n / 180) * Math.PI), mb.fromArray(t[0]), xb.fromArray(t[1]), _b.fromArray(t[2]), De.sub(bb, xb, mb), De.sub(wb, _b, xb); var i = bb.len(), r = wb.len(); if (!(i < 0.001 || r < 0.001)) if ( (bb.scale(1 / i), wb.scale(1 / r), bb.dot(e) < Math.cos(n)) ) { var o = db(xb.x, xb.y, _b.x, _b.y, mb.x, mb.y, Mb, !1); Ib.fromArray(Mb); var a = Math.PI / 2, s = a + Math.acos(wb.dot(e)) - n; if (s >= a) De.copy(Ib, _b); else { Ib.scaleAndAdd(wb, o / Math.tan(Math.PI / 2 - s)); var l = _b.x !== xb.x ? (Ib.x - xb.x) / (_b.x - xb.x) : (Ib.y - xb.y) / (_b.y - xb.y); if (isNaN(l)) return; l < 0 ? De.copy(Ib, xb) : l > 1 && De.copy(Ib, _b); } Ib.toArray(t[1]); } } } function Db(t, e, n, i) { var r = "normal" === n, o = r ? t : t.ensureState(n); o.ignore = e; var a = i.get("smooth"); a && !0 === a && (a = 0.3), (o.shape = o.shape || {}), a > 0 && (o.shape.smooth = a); var s = i.getModel("lineStyle").getLineStyle(); r ? t.useStyle(s) : (o.style = s); } function Ab(t, e) { var n = e.smooth, i = e.points; if (i) if ((t.moveTo(i[0][0], i[0][1]), n > 0 && i.length >= 3)) { var r = Vt(i[0], i[1]), o = Vt(i[1], i[2]); if (!r || !o) return ( t.lineTo(i[1][0], i[1][1]), void t.lineTo(i[2][0], i[2][1]) ); var a = Math.min(r, o) * n, s = Gt([], i[1], i[0], a / r), l = Gt([], i[1], i[2], a / o), u = Gt([], s, l, 0.5); t.bezierCurveTo(s[0], s[1], s[0], s[1], u[0], u[1]), t.bezierCurveTo(l[0], l[1], l[0], l[1], i[2][0], i[2][1]); } else for (var h = 1; h < i.length; h++) t.lineTo(i[h][0], i[h][1]); } function kb(t, e, n) { var i = t.getTextGuideLine(), r = t.getTextContent(); if (r) { for ( var o = e.normal, a = o.get("show"), s = r.ignore, l = 0; l < cl.length; l++ ) { var u = cl[l], h = e[u], c = "normal" === u; if (h) { var p = h.get("show"); if ( (c ? s : rt(r.states[u] && r.states[u].ignore, s)) || !rt(p, a) ) { var d = c ? i : i && i.states[u]; d && (d.ignore = !0), i && Db(i, !0, u, h); continue; } i || ((i = new Zu()), t.setTextGuideLine(i), c || (!s && a) || Db(i, !0, "normal", e.normal), t.stateProxy && (i.stateProxy = t.stateProxy)), Db(i, !1, u, h); } } if (i) { k(i.style, n), (i.style.fill = null); var f = o.get("showAbove"); ((t.textGuideLineConfig = t.textGuideLineConfig || {}).showAbove = f || !1), (i.buildPath = Ab); } } else i && t.removeTextGuideLine(); } function Lb(t, e) { e = e || "labelLine"; for (var n = { normal: t.getModel(e) }, i = 0; i < hl.length; i++) { var r = hl[i]; n[r] = t.getModel([r, e]); } return n; } function Pb(t) { for (var e = [], n = 0; n < t.length; n++) { var i = t[n]; if (!i.defaultAttr.ignore) { var r = i.label, o = r.getComputedTransform(), a = r.getBoundingRect(), s = !o || (o[1] < 1e-5 && o[2] < 1e-5), l = r.style.margin || 0, u = a.clone(); u.applyTransform(o), (u.x -= l / 2), (u.y -= l / 2), (u.width += l), (u.height += l); var h = s ? new ch(a, o) : null; e.push({ label: r, labelLine: i.labelLine, rect: u, localRect: a, obb: h, priority: i.priority, defaultAttr: i.defaultAttr, layoutOption: i.computedLayoutOption, axisAligned: s, transform: o, }); } } return e; } function Ob(t, e, n, i, r, o) { var a = t.length; if (!(a < 2)) { t.sort(function (t, n) { return t.rect[e] - n.rect[e]; }); for (var s, l = 0, u = !1, h = 0, c = 0; c < a; c++) { var p = t[c], d = p.rect; (s = d[e] - l) < 0 && ((d[e] -= s), (p.label[e] -= s), (u = !0)), (h += Math.max(-s, 0)), (l = d[e] + d[n]); } h > 0 && o && _(-h / a, 0, a); var f, g, y = t[0], v = t[a - 1]; return ( m(), f < 0 && b(-f, 0.8), g < 0 && b(g, 0.8), m(), x(f, g, 1), x(g, f, -1), m(), f < 0 && w(-f), g < 0 && w(g), u ); } function m() { (f = y.rect[e] - i), (g = r - v.rect[e] - v.rect[n]); } function x(t, e, n) { if (t < 0) { var i = Math.min(e, -t); if (i > 0) { _(i * n, 0, a); var r = i + t; r < 0 && b(-r * n, 1); } else b(-t * n, 1); } } function _(n, i, r) { 0 !== n && (u = !0); for (var o = i; o < r; o++) { var a = t[o]; (a.rect[e] += n), (a.label[e] += n); } } function b(i, r) { for (var o = [], s = 0, l = 1; l < a; l++) { var u = t[l - 1].rect, h = Math.max(t[l].rect[e] - u[e] - u[n], 0); o.push(h), (s += h); } if (s) { var c = Math.min(Math.abs(i) / s, r); if (i > 0) for (l = 0; l < a - 1; l++) { _(o[l] * c, 0, l + 1); } else for (l = a - 1; l > 0; l--) { _(-(o[l - 1] * c), l, a); } } } function w(t) { var e = t < 0 ? -1 : 1; t = Math.abs(t); for (var n = Math.ceil(t / (a - 1)), i = 0; i < a - 1; i++) if ( (e > 0 ? _(n, 0, i + 1) : _(-n, a - i - 1, a), (t -= n) <= 0) ) return; } } function Rb(t, e, n, i) { return Ob(t, "y", "height", e, n, i); } function Nb(t) { var e = []; t.sort(function (t, e) { return e.priority - t.priority; }); var n = new ze(0, 0, 0, 0); function i(t) { if (!t.ignore) { var e = t.ensureState("emphasis"); null == e.ignore && (e.ignore = !1); } t.ignore = !0; } for (var r = 0; r < t.length; r++) { var o = t[r], a = o.axisAligned, s = o.localRect, l = o.transform, u = o.label, h = o.labelLine; n.copy(o.rect), (n.width -= 0.1), (n.height -= 0.1), (n.x += 0.05), (n.y += 0.05); for (var c = o.obb, p = !1, d = 0; d < e.length; d++) { var f = e[d]; if (n.intersect(f.rect)) { if (a && f.axisAligned) { p = !0; break; } if ( (f.obb || (f.obb = new ch(f.localRect, f.transform)), c || (c = new ch(s, l)), c.intersect(f.obb)) ) { p = !0; break; } } } p ? (i(u), h && i(h)) : (u.attr("ignore", o.defaultAttr.ignore), h && h.attr("ignore", o.defaultAttr.labelGuideIgnore), e.push(o)); } } function Eb(t) { if (t) { for (var e = [], n = 0; n < t.length; n++) e.push(t[n].slice()); return e; } } function zb(t, e) { var n = t.label, i = e && e.getTextGuideLine(); return { dataIndex: t.dataIndex, dataType: t.dataType, seriesIndex: t.seriesModel.seriesIndex, text: t.label.style.text, rect: t.hostRect, labelRect: t.rect, align: n.style.align, verticalAlign: n.style.verticalAlign, labelLinePoints: Eb(i && i.shape.points), }; } var Vb = ["align", "verticalAlign", "width", "height", "fontSize"], Bb = new vr(), Fb = Vo(), Gb = Vo(); function Wb(t, e, n) { for (var i = 0; i < n.length; i++) { var r = n[i]; null != e[r] && (t[r] = e[r]); } } var Hb = ["x", "y", "rotation"], Yb = (function () { function t() { (this._labelList = []), (this._chartViewList = []); } return ( (t.prototype.clearLabels = function () { (this._labelList = []), (this._chartViewList = []); }), (t.prototype._addLabel = function (t, e, n, i, r) { var o = i.style, a = i.__hostTarget.textConfig || {}, s = i.getComputedTransform(), l = i.getBoundingRect().plain(); ze.applyTransform(l, l, s), s ? Bb.setLocalTransform(s) : ((Bb.x = Bb.y = Bb.rotation = Bb.originX = Bb.originY = 0), (Bb.scaleX = Bb.scaleY = 1)), (Bb.rotation = gs(Bb.rotation)); var u, h = i.__hostTarget; if (h) { u = h.getBoundingRect().plain(); var c = h.getComputedTransform(); ze.applyTransform(u, u, c); } var p = u && h.getTextGuideLine(); this._labelList.push({ label: i, labelLine: p, seriesModel: n, dataIndex: t, dataType: e, layoutOption: r, computedLayoutOption: null, rect: l, hostRect: u, priority: u ? u.width * u.height : 0, defaultAttr: { ignore: i.ignore, labelGuideIgnore: p && p.ignore, x: Bb.x, y: Bb.y, scaleX: Bb.scaleX, scaleY: Bb.scaleY, rotation: Bb.rotation, style: { x: o.x, y: o.y, align: o.align, verticalAlign: o.verticalAlign, width: o.width, height: o.height, fontSize: o.fontSize, }, cursor: i.cursor, attachedPos: a.position, attachedRot: a.rotation, }, }); }), (t.prototype.addLabelsOfSeries = function (t) { var e = this; this._chartViewList.push(t); var n = t.__model, i = n.get("labelLayout"); (X(i) || G(i).length) && t.group.traverse(function (t) { if (t.ignore) return !0; var r = t.getTextContent(), o = rl(t); r && !r.disableLabelLayout && e._addLabel(o.dataIndex, o.dataType, n, r, i); }); }), (t.prototype.updateLayoutConfig = function (t) { var e = t.getWidth(), n = t.getHeight(); function i(t, e) { return function () { Sb(t, e); }; } for (var r = 0; r < this._labelList.length; r++) { var o = this._labelList[r], a = o.label, s = a.__hostTarget, l = o.defaultAttr, u = void 0; (u = (u = X(o.layoutOption) ? o.layoutOption(zb(o, s)) : o.layoutOption) || {}), (o.computedLayoutOption = u); var h = Math.PI / 180; s && s.setTextConfig({ local: !1, position: null != u.x || null != u.y ? null : l.attachedPos, rotation: null != u.rotate ? u.rotate * h : l.attachedRot, offset: [u.dx || 0, u.dy || 0], }); var c = !1; if ( (null != u.x ? ((a.x = $r(u.x, e)), a.setStyle("x", 0), (c = !0)) : ((a.x = l.x), a.setStyle("x", l.style.x)), null != u.y ? ((a.y = $r(u.y, n)), a.setStyle("y", 0), (c = !0)) : ((a.y = l.y), a.setStyle("y", l.style.y)), u.labelLinePoints) ) { var p = s.getTextGuideLine(); p && (p.setShape({ points: u.labelLinePoints }), (c = !1)); } (Fb(a).needsUpdateLabelLine = c), (a.rotation = null != u.rotate ? u.rotate * h : l.rotation), (a.scaleX = l.scaleX), (a.scaleY = l.scaleY); for (var d = 0; d < Vb.length; d++) { var f = Vb[d]; a.setStyle(f, null != u[f] ? u[f] : l.style[f]); } if (u.draggable) { if (((a.draggable = !0), (a.cursor = "move"), s)) { var g = o.seriesModel; if (null != o.dataIndex) g = o.seriesModel .getData(o.dataType) .getItemModel(o.dataIndex); a.on("drag", i(s, g.getModel("labelLine"))); } } else a.off("drag"), (a.cursor = l.cursor); } }), (t.prototype.layout = function (t) { var e, n = t.getWidth(), i = t.getHeight(), r = Pb(this._labelList), o = B(r, function (t) { return "shiftX" === t.layoutOption.moveOverlap; }), a = B(r, function (t) { return "shiftY" === t.layoutOption.moveOverlap; }); Ob(o, "x", "width", 0, n, e), Rb(a, 0, i), Nb( B(r, function (t) { return t.layoutOption.hideOverlap; }) ); }), (t.prototype.processLabelsOverall = function () { var t = this; E(this._chartViewList, function (e) { var n = e.__model, i = e.ignoreLabelLineUpdate, r = n.isAnimationEnabled(); e.group.traverse(function (e) { if (e.ignore && !e.forceLabelAnimation) return !0; var o = !i, a = e.getTextContent(); !o && a && (o = Fb(a).needsUpdateLabelLine), o && t._updateLabelLine(e, n), r && t._animateLabels(e, n); }); }); }), (t.prototype._updateLabelLine = function (t, e) { var n = t.getTextContent(), i = rl(t), r = i.dataIndex; if (n && null != r) { var o = e.getData(i.dataType), a = o.getItemModel(r), s = {}, l = o.getItemVisual(r, "style"); if (l) { var u = o.getVisual("drawType"); s.stroke = l[u]; } var h = a.getModel("labelLine"); kb(t, Lb(a), s), Sb(t, h); } }), (t.prototype._animateLabels = function (t, e) { var n = t.getTextContent(), i = t.getTextGuideLine(); if ( n && (t.forceLabelAnimation || (!n.ignore && !n.invisible && !t.disableLabelAnimation && !xh(t))) ) { var r = (d = Fb(n)).oldLayout, o = rl(t), a = o.dataIndex, s = { x: n.x, y: n.y, rotation: n.rotation }, l = e.getData(o.dataType); if (r) { n.attr(r); var u = t.prevStates; u && (P(u, "select") >= 0 && n.attr(d.oldLayoutSelect), P(u, "emphasis") >= 0 && n.attr(d.oldLayoutEmphasis)), vh(n, s, e, a); } else if ((n.attr(s), !pc(n).valueAnimation)) { var h = rt(n.style.opacity, 1); (n.style.opacity = 0), mh(n, { style: { opacity: h } }, e, a); } if (((d.oldLayout = s), n.states.select)) { var c = (d.oldLayoutSelect = {}); Wb(c, s, Hb), Wb(c, n.states.select, Hb); } if (n.states.emphasis) { var p = (d.oldLayoutEmphasis = {}); Wb(p, s, Hb), Wb(p, n.states.emphasis, Hb); } fc(n, a, l, e, e); } if (i && !i.ignore && !i.invisible) { r = (d = Gb(i)).oldLayout; var d, f = { points: i.shape.points }; r ? (i.attr({ shape: r }), vh(i, { shape: f }, e)) : (i.setShape(f), (i.style.strokePercent = 0), mh(i, { style: { strokePercent: 1 } }, e)), (d.oldLayout = f); } }), t ); })(), Xb = Vo(); var Ub = Math.sin, Zb = Math.cos, jb = Math.PI, qb = 2 * Math.PI, Kb = 180 / jb, $b = (function () { function t() {} return ( (t.prototype.reset = function (t) { (this._start = !0), (this._d = []), (this._str = ""), (this._p = Math.pow(10, t || 4)); }), (t.prototype.moveTo = function (t, e) { this._add("M", t, e); }), (t.prototype.lineTo = function (t, e) { this._add("L", t, e); }), (t.prototype.bezierCurveTo = function (t, e, n, i, r, o) { this._add("C", t, e, n, i, r, o); }), (t.prototype.quadraticCurveTo = function (t, e, n, i) { this._add("Q", t, e, n, i); }), (t.prototype.arc = function (t, e, n, i, r, o) { this.ellipse(t, e, n, n, 0, i, r, o); }), (t.prototype.ellipse = function (t, e, n, i, r, o, a, s) { var l = a - o, u = !s, h = Math.abs(l), c = pi(h - qb) || (u ? l >= qb : -l >= qb), p = l > 0 ? l % qb : (l % qb) + qb, d = !1; d = !!c || (!pi(h) && p >= jb == !!u); var f = t + n * Zb(o), g = e + i * Ub(o); this._start && this._add("M", f, g); var y = Math.round(r * Kb); if (c) { var v = 1 / this._p, m = (u ? 1 : -1) * (qb - v); this._add( "A", n, i, y, 1, +u, t + n * Zb(o + m), e + i * Ub(o + m) ), v > 0.01 && this._add("A", n, i, y, 0, +u, f, g); } else { var x = t + n * Zb(a), _ = e + i * Ub(a); this._add("A", n, i, y, +d, +u, x, _); } }), (t.prototype.rect = function (t, e, n, i) { this._add("M", t, e), this._add("l", n, 0), this._add("l", 0, i), this._add("l", -n, 0), this._add("Z"); }), (t.prototype.closePath = function () { this._d.length > 0 && this._add("Z"); }), (t.prototype._add = function (t, e, n, i, r, o, a, s, l) { for ( var u = [], h = this._p, c = 1; c < arguments.length; c++ ) { var p = arguments[c]; if (isNaN(p)) return void (this._invalid = !0); u.push(Math.round(p * h) / h); } this._d.push(t + u.join(" ")), (this._start = "Z" === t); }), (t.prototype.generateStr = function () { (this._str = this._invalid ? "" : this._d.join("")), (this._d = []); }), (t.prototype.getStr = function () { return this._str; }), t ); })(), Jb = "none", Qb = Math.round; var tw = ["lineCap", "miterLimit", "lineJoin"], ew = z(tw, function (t) { return "stroke-" + t.toLowerCase(); }); function nw(t, e, n, i) { var r = null == e.opacity ? 1 : e.opacity; if (n instanceof Ns) t("opacity", r); else { if ( (function (t) { var e = t.fill; return null != e && e !== Jb; })(e) ) { var o = hi(e.fill); t("fill", o.color); var a = null != e.fillOpacity ? e.fillOpacity * o.opacity * r : o.opacity * r; (i || a < 1) && t("fill-opacity", a); } else t("fill", Jb); if ( (function (t) { var e = t.stroke; return null != e && e !== Jb; })(e) ) { var s = hi(e.stroke); t("stroke", s.color); var l = e.strokeNoScale ? n.getLineScale() : 1, u = l ? (e.lineWidth || 0) / l : 0, h = null != e.strokeOpacity ? e.strokeOpacity * s.opacity * r : s.opacity * r, c = e.strokeFirst; if ( ((i || 1 !== u) && t("stroke-width", u), (i || c) && t("paint-order", c ? "stroke" : "fill"), (i || h < 1) && t("stroke-opacity", h), e.lineDash) ) { var p = Jy(n), d = p[0], f = p[1]; d && ((f = Qb(f || 0)), t("stroke-dasharray", d.join(",")), (f || i) && t("stroke-dashoffset", f)); } else i && t("stroke-dasharray", Jb); for (var g = 0; g < tw.length; g++) { var y = tw[g]; if (i || e[y] !== Cs[y]) { var v = e[y] || Cs[y]; v && t(ew[g], v); } } } else i && t("stroke", Jb); } } var iw = "http://www.w3.org/2000/svg", rw = "http://www.w3.org/1999/xlink", ow = "ecmeta_"; function aw(t) { return document.createElementNS(iw, t); } function sw(t, e, n, i, r) { return { tag: t, attrs: n || {}, children: i, text: r, key: e }; } function lw(t, e) { var n = (e = e || {}).newline ? "\n" : ""; return (function t(e) { var i = e.children, r = e.tag, o = e.attrs, a = e.text; return ( (function (t, e) { var n = []; if (e) for (var i in e) { var r = e[i], o = i; !1 !== r && (!0 !== r && null != r && (o += '="' + r + '"'), n.push(o)); } return "<" + t + " " + n.join(" ") + ">"; })(r, o) + ("style" !== r ? re(a) : a || "") + (i ? "" + n + z(i, function (e) { return t(e); }).join(n) + n : "") + ("") ); })(t); } function uw(t) { return { zrId: t, shadowCache: {}, patternCache: {}, gradientCache: {}, clipPathCache: {}, defs: {}, cssNodes: {}, cssAnims: {}, cssStyleCache: {}, cssAnimIdx: 0, shadowIdx: 0, gradientIdx: 0, patternIdx: 0, clipPathIdx: 0, }; } function hw(t, e, n, i) { return sw( "svg", "root", { width: t, height: e, xmlns: iw, "xmlns:xlink": rw, version: "1.1", baseProfile: "full", viewBox: !!i && "0 0 " + t + " " + e, }, n ); } var cw = 0; function pw() { return cw++; } var dw = { cubicIn: "0.32,0,0.67,0", cubicOut: "0.33,1,0.68,1", cubicInOut: "0.65,0,0.35,1", quadraticIn: "0.11,0,0.5,0", quadraticOut: "0.5,1,0.89,1", quadraticInOut: "0.45,0,0.55,1", quarticIn: "0.5,0,0.75,0", quarticOut: "0.25,1,0.5,1", quarticInOut: "0.76,0,0.24,1", quinticIn: "0.64,0,0.78,0", quinticOut: "0.22,1,0.36,1", quinticInOut: "0.83,0,0.17,1", sinusoidalIn: "0.12,0,0.39,0", sinusoidalOut: "0.61,1,0.88,1", sinusoidalInOut: "0.37,0,0.63,1", exponentialIn: "0.7,0,0.84,0", exponentialOut: "0.16,1,0.3,1", exponentialInOut: "0.87,0,0.13,1", circularIn: "0.55,0,1,0.45", circularOut: "0,0.55,0.45,1", circularInOut: "0.85,0,0.15,1", }, fw = "transform-origin"; function gw(t, e, n) { var i = A({}, t.shape); A(i, e), t.buildPath(n, i); var r = new $b(); return r.reset(wi(t)), n.rebuildPath(r, 1), r.generateStr(), r.getStr(); } function yw(t, e) { var n = e.originX, i = e.originY; (n || i) && (t[fw] = n + "px " + i + "px"); } var vw = { fill: "fill", opacity: "opacity", lineWidth: "stroke-width", lineDashOffset: "stroke-dashoffset", }; function mw(t, e) { var n = e.zrId + "-ani-" + e.cssAnimIdx++; return (e.cssAnims[n] = t), n; } function xw(t) { return U(t) ? dw[t] ? "cubic-bezier(" + dw[t] + ")" : Pn(t) ? t : "" : ""; } function _w(t, e, n, i) { var r = t.animators, o = r.length, a = []; if (t instanceof ih) { var s = (function (t, e, n) { var i, r, o = t.shape.paths, a = {}; if ( (E(o, function (t) { var e = uw(n.zrId); (e.animation = !0), _w(t, {}, e, !0); var o = e.cssAnims, s = e.cssNodes, l = G(o), u = l.length; if (u) { var h = o[(r = l[u - 1])]; for (var c in h) { var p = h[c]; (a[c] = a[c] || { d: "" }), (a[c].d += p.d || ""); } for (var d in s) { var f = s[d].animation; f.indexOf(r) >= 0 && (i = f); } } }), i) ) { e.d = !1; var s = mw(a, n); return i.replace(r, s); } })(t, e, n); if (s) a.push(s); else if (!o) return; } else if (!o) return; for (var l = {}, u = 0; u < o; u++) { var h = r[u], c = [h.getMaxTime() / 1e3 + "s"], p = xw(h.getClip().easing), d = h.getDelay(); p ? c.push(p) : c.push("linear"), d && c.push(d / 1e3 + "s"), h.getLoop() && c.push("infinite"); var f = c.join(" "); (l[f] = l[f] || [f, []]), l[f][1].push(h); } function g(r) { var o, a = r[1], s = a.length, l = {}, u = {}, h = {}, c = "animation-timing-function"; function p(t, e, n) { for ( var i = t.getTracks(), r = t.getMaxTime(), o = 0; o < i.length; o++ ) { var a = i[o]; if (a.needsAnimate()) { var s = a.keyframes, l = a.propName; if ((n && (l = n(l)), l)) for (var u = 0; u < s.length; u++) { var h = s[u], p = Math.round((h.time / r) * 100) + "%", d = xw(h.easing), f = h.rawValue; (U(f) || j(f)) && ((e[p] = e[p] || {}), (e[p][l] = h.rawValue), d && (e[p][c] = d)); } } } } for (var d = 0; d < s; d++) { (S = (w = a[d]).targetName) ? "shape" === S && p(w, u) : !i && p(w, l); } for (var f in l) { var g = {}; xr(g, t), A(g, l[f]); var y = Si(g), v = l[f][c]; (h[f] = y ? { transform: y } : {}), yw(h[f], g), v && (h[f][c] = v); } var m = !0; for (var f in u) { h[f] = h[f] || {}; var x = !o; v = u[f][c]; x && (o = new hs()); var _ = o.len(); o.reset(), (h[f].d = gw(t, u[f], o)); var b = o.len(); if (!x && _ !== b) { m = !1; break; } v && (h[f][c] = v); } if (!m) for (var f in h) delete h[f].d; if (!i) for (d = 0; d < s; d++) { var w, S; "style" === (S = (w = a[d]).targetName) && p(w, h, function (t) { return vw[t]; }); } var M, I = G(h), T = !0; for (d = 1; d < I.length; d++) { var C = I[d - 1], D = I[d]; if (h[C][fw] !== h[D][fw]) { T = !1; break; } M = h[C][fw]; } if (T && M) { for (var f in h) h[f][fw] && delete h[f][fw]; e[fw] = M; } if ( B(I, function (t) { return G(h[t]).length > 0; }).length ) return mw(h, n) + " " + r[0] + " both"; } for (var y in l) { (s = g(l[y])) && a.push(s); } if (a.length) { var v = n.zrId + "-cls-" + pw(); (n.cssNodes["." + v] = { animation: a.join(",") }), (e.class = v); } } function bw(t, e, n, i) { var r = JSON.stringify(t), o = n.cssStyleCache[r]; o || ((o = n.zrId + "-cls-" + pw()), (n.cssStyleCache[r] = o), (n.cssNodes["." + o + (i ? ":hover" : "")] = t)), (e.class = e.class ? e.class + " " + o : o); } var ww = Math.round; function Sw(t) { return t && U(t.src); } function Mw(t) { return t && X(t.toDataURL); } function Iw(t, e, n, i) { nw( function (r, o) { var a = "fill" === r || "stroke" === r; a && _i(o) ? Ew(e, t, r, i) : a && vi(o) ? zw(n, t, r, i) : (t[r] = o), a && i.ssr && "none" === o && (t["pointer-events"] = "visible"); }, e, n, !1 ), (function (t, e, n) { var i = t.style; if ( (function (t) { return ( t && (t.shadowBlur || t.shadowOffsetX || t.shadowOffsetY) ); })(i) ) { var r = (function (t) { var e = t.style, n = t.getGlobalScale(); return [ e.shadowColor, (e.shadowBlur || 0).toFixed(2), (e.shadowOffsetX || 0).toFixed(2), (e.shadowOffsetY || 0).toFixed(2), n[0], n[1], ].join(","); })(t), o = n.shadowCache, a = o[r]; if (!a) { var s = t.getGlobalScale(), l = s[0], u = s[1]; if (!l || !u) return; var h = i.shadowOffsetX || 0, c = i.shadowOffsetY || 0, p = i.shadowBlur, d = hi(i.shadowColor), f = d.opacity, g = d.color, y = p / 2 / l + " " + p / 2 / u; (a = n.zrId + "-s" + n.shadowIdx++), (n.defs[a] = sw( "filter", a, { id: a, x: "-100%", y: "-100%", width: "300%", height: "300%", }, [ sw("feDropShadow", "", { dx: h / l, dy: c / u, stdDeviation: y, "flood-color": g, "flood-opacity": f, }), ] )), (o[r] = a); } e.filter = bi(a); } })(n, t, i); } function Tw(t, e) { var n = Ur(e); n && (n.each(function (e, n) { null != e && (t[(ow + n).toLowerCase()] = e + ""); }), e.isSilent() && (t[ow + "silent"] = "true")); } function Cw(t) { return pi(t[0] - 1) && pi(t[1]) && pi(t[2]) && pi(t[3] - 1); } function Dw(t, e, n) { if ( e && (!(function (t) { return pi(t[4]) && pi(t[5]); })(e) || !Cw(e)) ) { var i = n ? 10 : 1e4; t.transform = Cw(e) ? "translate(" + ww(e[4] * i) / i + " " + ww(e[5] * i) / i + ")" : (function (t) { return ( "matrix(" + di(t[0]) + "," + di(t[1]) + "," + di(t[2]) + "," + di(t[3]) + "," + fi(t[4]) + "," + fi(t[5]) + ")" ); })(e); } } function Aw(t, e, n) { for (var i = t.points, r = [], o = 0; o < i.length; o++) r.push(ww(i[o][0] * n) / n), r.push(ww(i[o][1] * n) / n); e.points = r.join(" "); } function kw(t) { return !t.smooth; } var Lw, Pw, Ow = { circle: [ ((Lw = ["cx", "cy", "r"]), (Pw = z(Lw, function (t) { return "string" == typeof t ? [t, t] : t; })), function (t, e, n) { for (var i = 0; i < Pw.length; i++) { var r = Pw[i], o = t[r[0]]; null != o && (e[r[1]] = ww(o * n) / n); } }), ], polyline: [Aw, kw], polygon: [Aw, kw], }; function Rw(t, e) { var n = t.style, i = t.shape, r = Ow[t.type], o = {}, a = e.animation, s = "path", l = t.style.strokePercent, u = (e.compress && wi(t)) || 4; if ( !r || e.willUpdate || (r[1] && !r[1](i)) || (a && (function (t) { for (var e = t.animators, n = 0; n < e.length; n++) if ("shape" === e[n].targetName) return !0; return !1; })(t)) || l < 1 ) { var h = !t.path || t.shapeChanged(); t.path || t.createPathProxy(); var c = t.path; h && (c.beginPath(), t.buildPath(c, t.shape), t.pathUpdated()); var p = c.getVersion(), d = t, f = d.__svgPathBuilder; (d.__svgPathVersion === p && f && l === d.__svgPathStrokePercent) || (f || (f = d.__svgPathBuilder = new $b()), f.reset(u), c.rebuildPath(f, l), f.generateStr(), (d.__svgPathVersion = p), (d.__svgPathStrokePercent = l)), (o.d = f.getStr()); } else { s = t.type; var g = Math.pow(10, u); r[0](i, o, g); } return ( Dw(o, t.transform), Iw(o, n, t, e), Tw(o, t), e.animation && _w(t, o, e), e.emphasis && (function (t, e, n) { if (!t.ignore) if (t.isSilent()) bw((u = { "pointer-events": "none" }), e, n, !0); else { var i = t.states.emphasis && t.states.emphasis.style ? t.states.emphasis.style : {}, r = i.fill; if (!r) { var o = t.style && t.style.fill, a = t.states.select && t.states.select.style && t.states.select.style.fill, s = (t.currentStates.indexOf("select") >= 0 && a) || o; s && (r = si(s)); } var l = i.lineWidth; l && (l /= !i.strokeNoScale && t.transform ? t.transform[0] : 1); var u = { cursor: "pointer" }; r && (u.fill = r), i.stroke && (u.stroke = i.stroke), l && (u["stroke-width"] = l), bw(u, e, n, !0); } })(t, o, e), sw(s, t.id + "", o) ); } function Nw(t, e) { return t instanceof ks ? Rw(t, e) : t instanceof Ns ? (function (t, e) { var n = t.style, i = n.image; if ( (i && !U(i) && (Sw(i) ? (i = i.src) : Mw(i) && (i = i.toDataURL())), i) ) { var r = n.x || 0, o = n.y || 0, a = { href: i, width: n.width, height: n.height }; return ( r && (a.x = r), o && (a.y = o), Dw(a, t.transform), Iw(a, n, t, e), Tw(a, t), e.animation && _w(t, a, e), sw("image", t.id + "", a) ); } })(t, e) : t instanceof Ps ? (function (t, e) { var n = t.style, i = n.text; if ( (null != i && (i += ""), i && !isNaN(n.x) && !isNaN(n.y)) ) { var r = n.font || a, s = n.x || 0, l = (function (t, e, n) { return ( "top" === n ? (t += e / 2) : "bottom" === n && (t -= e / 2), t ); })(n.y || 0, Tr(r), n.textBaseline), u = { "dominant-baseline": "central", "text-anchor": gi[n.textAlign] || n.textAlign, }; if ($s(n)) { var h = "", c = n.fontStyle, p = qs(n.fontSize); if (!parseFloat(p)) return; var d = n.fontFamily || o, f = n.fontWeight; (h += "font-size:" + p + ";font-family:" + d + ";"), c && "normal" !== c && (h += "font-style:" + c + ";"), f && "normal" !== f && (h += "font-weight:" + f + ";"), (u.style = h); } else u.style = "font: " + r; return ( i.match(/\s/) && (u["xml:space"] = "preserve"), s && (u.x = s), l && (u.y = l), Dw(u, t.transform), Iw(u, n, t, e), Tw(u, t), e.animation && _w(t, u, e), sw("text", t.id + "", u, void 0, i) ); } })(t, e) : void 0; } function Ew(t, e, n, i) { var r, o = t[n], a = { gradientUnits: o.global ? "userSpaceOnUse" : "objectBoundingBox", }; if (mi(o)) (r = "linearGradient"), (a.x1 = o.x), (a.y1 = o.y), (a.x2 = o.x2), (a.y2 = o.y2); else { if (!xi(o)) return void 0; (r = "radialGradient"), (a.cx = rt(o.x, 0.5)), (a.cy = rt(o.y, 0.5)), (a.r = rt(o.r, 0.5)); } for (var s = o.colorStops, l = [], u = 0, h = s.length; u < h; ++u) { var c = 100 * fi(s[u].offset) + "%", p = hi(s[u].color), d = p.color, f = p.opacity, g = { offset: c }; (g["stop-color"] = d), f < 1 && (g["stop-opacity"] = f), l.push(sw("stop", u + "", g)); } var y = lw(sw(r, "", a, l)), v = i.gradientCache, m = v[y]; m || ((m = i.zrId + "-g" + i.gradientIdx++), (v[y] = m), (a.id = m), (i.defs[m] = sw(r, m, a, l))), (e[n] = bi(m)); } function zw(t, e, n, i) { var r, o = t.style[n], a = t.getBoundingRect(), s = {}, l = o.repeat, u = "no-repeat" === l, h = "repeat-x" === l, c = "repeat-y" === l; if (yi(o)) { var p = o.imageWidth, d = o.imageHeight, f = void 0, g = o.image; if ( (U(g) ? (f = g) : Sw(g) ? (f = g.src) : Mw(g) && (f = g.toDataURL()), "undefined" == typeof Image) ) { var y = "Image width/height must been given explictly in svg-ssr renderer."; lt(p, y), lt(d, y); } else if (null == p || null == d) { var v = function (t, e) { if (t) { var n = t.elm, i = p || e.width, r = d || e.height; "pattern" === t.tag && (h ? ((r = 1), (i /= a.width)) : c && ((i = 1), (r /= a.height))), (t.attrs.width = i), (t.attrs.height = r), n && (n.setAttribute("width", i), n.setAttribute("height", r)); } }, m = la(f, null, t, function (t) { u || v(w, t), v(r, t); }); m && m.width && m.height && ((p = p || m.width), (d = d || m.height)); } (r = sw("image", "img", { href: f, width: p, height: d })), (s.width = p), (s.height = d); } else o.svgElement && ((r = T(o.svgElement)), (s.width = o.svgWidth), (s.height = o.svgHeight)); if (r) { var x, _; u ? (x = _ = 1) : h ? ((_ = 1), (x = s.width / a.width)) : c ? ((x = 1), (_ = s.height / a.height)) : (s.patternUnits = "userSpaceOnUse"), null == x || isNaN(x) || (s.width = x), null == _ || isNaN(_) || (s.height = _); var b = Si(o); b && (s.patternTransform = b); var w = sw("pattern", "", s, [r]), S = lw(w), M = i.patternCache, I = M[S]; I || ((I = i.zrId + "-p" + i.patternIdx++), (M[S] = I), (s.id = I), (w = i.defs[I] = sw("pattern", I, s, [r]))), (e[n] = bi(I)); } } function Vw(t, e, n) { var i = n.clipPathCache, r = n.defs, o = i[t.id]; if (!o) { var a = { id: (o = n.zrId + "-c" + n.clipPathIdx++) }; (i[t.id] = o), (r[o] = sw("clipPath", o, a, [Rw(t, n)])); } e["clip-path"] = bi(o); } function Bw(t) { return document.createTextNode(t); } function Fw(t, e, n) { t.insertBefore(e, n); } function Gw(t, e) { t.removeChild(e); } function Ww(t, e) { t.appendChild(e); } function Hw(t) { return t.parentNode; } function Yw(t) { return t.nextSibling; } function Xw(t, e) { t.textContent = e; } var Uw = sw("", ""); function Zw(t) { return void 0 === t; } function jw(t) { return void 0 !== t; } function qw(t, e, n) { for (var i = {}, r = e; r <= n; ++r) { var o = t[r].key; void 0 !== o && (i[o] = r); } return i; } function Kw(t, e) { var n = t.key === e.key; return t.tag === e.tag && n; } function $w(t) { var e, n = t.children, i = t.tag; if (jw(i)) { var r = (t.elm = aw(i)); if ((tS(Uw, t), Y(n))) for (e = 0; e < n.length; ++e) { var o = n[e]; null != o && Ww(r, $w(o)); } else jw(t.text) && !q(t.text) && Ww(r, Bw(t.text)); } else t.elm = Bw(t.text); return t.elm; } function Jw(t, e, n, i, r) { for (; i <= r; ++i) { var o = n[i]; null != o && Fw(t, $w(o), e); } } function Qw(t, e, n, i) { for (; n <= i; ++n) { var r = e[n]; if (null != r) if (jw(r.tag)) Gw(Hw(r.elm), r.elm); else Gw(t, r.elm); } } function tS(t, e) { var n, i = e.elm, r = (t && t.attrs) || {}, o = e.attrs || {}; if (r !== o) { for (n in o) { var a = o[n]; r[n] !== a && (!0 === a ? i.setAttribute(n, "") : !1 === a ? i.removeAttribute(n) : "style" === n ? (i.style.cssText = a) : 120 !== n.charCodeAt(0) ? i.setAttribute(n, a) : "xmlns:xlink" === n || "xmlns" === n ? i.setAttributeNS( "http://www.w3.org/2000/xmlns/", n, a ) : 58 === n.charCodeAt(3) ? i.setAttributeNS( "http://www.w3.org/XML/1998/namespace", n, a ) : 58 === n.charCodeAt(5) ? i.setAttributeNS(rw, n, a) : i.setAttribute(n, a)); } for (n in r) n in o || i.removeAttribute(n); } } function eS(t, e) { var n = (e.elm = t.elm), i = t.children, r = e.children; t !== e && (tS(t, e), Zw(e.text) ? jw(i) && jw(r) ? i !== r && (function (t, e, n) { for ( var i, r, o, a = 0, s = 0, l = e.length - 1, u = e[0], h = e[l], c = n.length - 1, p = n[0], d = n[c]; a <= l && s <= c; ) null == u ? (u = e[++a]) : null == h ? (h = e[--l]) : null == p ? (p = n[++s]) : null == d ? (d = n[--c]) : Kw(u, p) ? (eS(u, p), (u = e[++a]), (p = n[++s])) : Kw(h, d) ? (eS(h, d), (h = e[--l]), (d = n[--c])) : Kw(u, d) ? (eS(u, d), Fw(t, u.elm, Yw(h.elm)), (u = e[++a]), (d = n[--c])) : Kw(h, p) ? (eS(h, p), Fw(t, h.elm, u.elm), (h = e[--l]), (p = n[++s])) : (Zw(i) && (i = qw(e, a, l)), Zw((r = i[p.key])) || (o = e[r]).tag !== p.tag ? Fw(t, $w(p), u.elm) : (eS(o, p), (e[r] = void 0), Fw(t, o.elm, u.elm)), (p = n[++s])); (a <= l || s <= c) && (a > l ? Jw( t, null == n[c + 1] ? null : n[c + 1].elm, n, s, c ) : Qw(t, e, a, l)); })(n, i, r) : jw(r) ? (jw(t.text) && Xw(n, ""), Jw(n, null, r, 0, r.length - 1)) : jw(i) ? Qw(n, i, 0, i.length - 1) : jw(t.text) && Xw(n, "") : t.text !== e.text && (jw(i) && Qw(n, i, 0, i.length - 1), Xw(n, e.text))); } var nS = 0, iS = (function () { function t(t, e, n) { if ( ((this.type = "svg"), (this.refreshHover = rS("refreshHover")), (this.configLayer = rS("configLayer")), (this.storage = e), (this._opts = n = A({}, n)), (this.root = t), (this._id = "zr" + nS++), (this._oldVNode = hw(n.width, n.height)), t && !n.ssr) ) { var i = (this._viewport = document.createElement("div")); i.style.cssText = "position:relative;overflow:hidden"; var r = (this._svgDom = this._oldVNode.elm = aw("svg")); tS(null, this._oldVNode), i.appendChild(r), t.appendChild(i); } this.resize(n.width, n.height); } return ( (t.prototype.getType = function () { return this.type; }), (t.prototype.getViewportRoot = function () { return this._viewport; }), (t.prototype.getViewportRootOffset = function () { var t = this.getViewportRoot(); if (t) return { offsetLeft: t.offsetLeft || 0, offsetTop: t.offsetTop || 0, }; }), (t.prototype.getSvgDom = function () { return this._svgDom; }), (t.prototype.refresh = function () { if (this.root) { var t = this.renderToVNode({ willUpdate: !0 }); (t.attrs.style = "position:absolute;left:0;top:0;user-select:none"), (function (t, e) { if (Kw(t, e)) eS(t, e); else { var n = t.elm, i = Hw(n); $w(e), null !== i && (Fw(i, e.elm, Yw(n)), Qw(i, [t], 0, 0)); } })(this._oldVNode, t), (this._oldVNode = t); } }), (t.prototype.renderOneToVNode = function (t) { return Nw(t, uw(this._id)); }), (t.prototype.renderToVNode = function (t) { t = t || {}; var e = this.storage.getDisplayList(!0), n = this._width, i = this._height, r = uw(this._id); (r.animation = t.animation), (r.willUpdate = t.willUpdate), (r.compress = t.compress), (r.emphasis = t.emphasis), (r.ssr = this._opts.ssr); var o = [], a = (this._bgVNode = (function (t, e, n, i) { var r; if (n && "none" !== n) if ( ((r = sw("rect", "bg", { width: t, height: e, x: "0", y: "0", })), _i(n)) ) Ew({ fill: n }, r.attrs, "fill", i); else if (vi(n)) zw( { style: { fill: n }, dirty: bt, getBoundingRect: function () { return { width: t, height: e }; }, }, r.attrs, "fill", i ); else { var o = hi(n), a = o.color, s = o.opacity; (r.attrs.fill = a), s < 1 && (r.attrs["fill-opacity"] = s); } return r; })(n, i, this._backgroundColor, r)); a && o.push(a); var s = t.compress ? null : (this._mainVNode = sw("g", "main", {}, [])); this._paintList(e, r, s ? s.children : o), s && o.push(s); var l = z(G(r.defs), function (t) { return r.defs[t]; }); if ( (l.length && o.push(sw("defs", "defs", {}, l)), t.animation) ) { var u = (function (t, e, n) { var i = (n = n || {}).newline ? "\n" : "", r = " {" + i, o = i + "}", a = z(G(t), function (e) { return ( e + r + z(G(t[e]), function (n) { return n + ":" + t[e][n] + ";"; }).join(i) + o ); }).join(i), s = z(G(e), function (t) { return ( "@keyframes " + t + r + z(G(e[t]), function (n) { return ( n + r + z(G(e[t][n]), function (i) { var r = e[t][n][i]; return ( "d" === i && (r = 'path("' + r + '")'), i + ":" + r + ";" ); }).join(i) + o ); }).join(i) + o ); }).join(i); return a || s ? [""].join(i) : ""; })(r.cssNodes, r.cssAnims, { newline: !0 }); if (u) { var h = sw("style", "stl", {}, [], u); o.push(h); } } return hw(n, i, o, t.useViewBox); }), (t.prototype.renderToString = function (t) { return ( (t = t || {}), lw( this.renderToVNode({ animation: rt(t.cssAnimation, !0), emphasis: rt(t.cssEmphasis, !0), willUpdate: !1, compress: !0, useViewBox: rt(t.useViewBox, !0), }), { newline: !0 } ) ); }), (t.prototype.setBackgroundColor = function (t) { this._backgroundColor = t; }), (t.prototype.getSvgRoot = function () { return this._mainVNode && this._mainVNode.elm; }), (t.prototype._paintList = function (t, e, n) { for ( var i, r, o = t.length, a = [], s = 0, l = 0, u = 0; u < o; u++ ) { var h = t[u]; if (!h.invisible) { var c = h.__clipPaths, p = (c && c.length) || 0, d = (r && r.length) || 0, f = void 0; for ( f = Math.max(p - 1, d - 1); f >= 0 && (!c || !r || c[f] !== r[f]); f-- ); for (var g = d - 1; g > f; g--) i = a[--s - 1]; for (var y = f + 1; y < p; y++) { var v = {}; Vw(c[y], v, e); var m = sw("g", "clip-g-" + l++, v, []); (i ? i.children : n).push(m), (a[s++] = m), (i = m); } r = c; var x = Nw(h, e); x && (i ? i.children : n).push(x); } } }), (t.prototype.resize = function (t, e) { var n = this._opts, i = this.root, r = this._viewport; if ( (null != t && (n.width = t), null != e && (n.height = e), i && r && ((r.style.display = "none"), (t = $y(i, 0, n)), (e = $y(i, 1, n)), (r.style.display = "")), this._width !== t || this._height !== e) ) { if (((this._width = t), (this._height = e), r)) { var o = r.style; (o.width = t + "px"), (o.height = e + "px"); } if (vi(this._backgroundColor)) this.refresh(); else { var a = this._svgDom; a && (a.setAttribute("width", t), a.setAttribute("height", e)); var s = this._bgVNode && this._bgVNode.elm; s && (s.setAttribute("width", t), s.setAttribute("height", e)); } } }), (t.prototype.getWidth = function () { return this._width; }), (t.prototype.getHeight = function () { return this._height; }), (t.prototype.dispose = function () { this.root && (this.root.innerHTML = ""), (this._svgDom = this._viewport = this.storage = this._oldVNode = this._bgVNode = this._mainVNode = null); }), (t.prototype.clear = function () { this._svgDom && (this._svgDom.innerHTML = null), (this._oldVNode = null); }), (t.prototype.toDataURL = function (t) { var e = this.renderToString(), n = "data:image/svg+xml;"; return t ? (e = Mi(e)) && n + "base64," + e : n + "charset=UTF-8," + encodeURIComponent(e); }), t ); })(); function rS(t) { return function () { 0; }; } function oS(t, e, n) { var i = h.createCanvas(), r = e.getWidth(), o = e.getHeight(), a = i.style; return ( a && ((a.position = "absolute"), (a.left = "0"), (a.top = "0"), (a.width = r + "px"), (a.height = o + "px"), i.setAttribute("data-zr-dom-id", t)), (i.width = r * n), (i.height = o * n), i ); } var aS = (function (t) { function e(e, n, i) { var r, o = t.call(this) || this; (o.motionBlur = !1), (o.lastFrameAlpha = 0.7), (o.dpr = 1), (o.virtual = !1), (o.config = {}), (o.incremental = !1), (o.zlevel = 0), (o.maxRepaintRectCount = 5), (o.__dirty = !0), (o.__firstTimePaint = !0), (o.__used = !1), (o.__drawIndex = 0), (o.__startIndex = 0), (o.__endIndex = 0), (o.__prevStartIndex = null), (o.__prevEndIndex = null), (i = i || sr), "string" == typeof e ? (r = oS(e, n, i)) : q(e) && (e = (r = e).id), (o.id = e), (o.dom = r); var a = r.style; return ( a && (xt(r), (r.onselectstart = function () { return !1; }), (a.padding = "0"), (a.margin = "0"), (a.borderWidth = "0")), (o.painter = n), (o.dpr = i), o ); } return ( n(e, t), (e.prototype.getElementCount = function () { return this.__endIndex - this.__startIndex; }), (e.prototype.afterBrush = function () { (this.__prevStartIndex = this.__startIndex), (this.__prevEndIndex = this.__endIndex); }), (e.prototype.initContext = function () { (this.ctx = this.dom.getContext("2d")), (this.ctx.dpr = this.dpr); }), (e.prototype.setUnpainted = function () { this.__firstTimePaint = !0; }), (e.prototype.createBackBuffer = function () { var t = this.dpr; (this.domBack = oS("back-" + this.id, this.painter, t)), (this.ctxBack = this.domBack.getContext("2d")), 1 !== t && this.ctxBack.scale(t, t); }), (e.prototype.createRepaintRects = function (t, e, n, i) { if (this.__firstTimePaint) return (this.__firstTimePaint = !1), null; var r, o = [], a = this.maxRepaintRectCount, s = !1, l = new ze(0, 0, 0, 0); function u(t) { if (t.isFinite() && !t.isZero()) if (0 === o.length) { (e = new ze(0, 0, 0, 0)).copy(t), o.push(e); } else { for ( var e, n = !1, i = 1 / 0, r = 0, u = 0; u < o.length; ++u ) { var h = o[u]; if (h.intersect(t)) { var c = new ze(0, 0, 0, 0); c.copy(h), c.union(t), (o[u] = c), (n = !0); break; } if (s) { l.copy(t), l.union(h); var p = t.width * t.height, d = h.width * h.height, f = l.width * l.height - p - d; f < i && ((i = f), (r = u)); } } if ((s && (o[r].union(t), (n = !0)), !n)) (e = new ze(0, 0, 0, 0)).copy(t), o.push(e); s || (s = o.length >= a); } } for (var h = this.__startIndex; h < this.__endIndex; ++h) { if ((d = t[h])) { var c = d.shouldBePainted(n, i, !0, !0); (f = d.__isRendered && (1 & d.__dirty || !c) ? d.getPrevPaintRect() : null) && u(f); var p = c && (1 & d.__dirty || !d.__isRendered) ? d.getPaintRect() : null; p && u(p); } } for ( h = this.__prevStartIndex; h < this.__prevEndIndex; ++h ) { var d, f; c = (d = e[h]) && d.shouldBePainted(n, i, !0, !0); if (d && (!c || !d.__zr) && d.__isRendered) (f = d.getPrevPaintRect()) && u(f); } do { r = !1; for (h = 0; h < o.length; ) if (o[h].isZero()) o.splice(h, 1); else { for (var g = h + 1; g < o.length; ) o[h].intersect(o[g]) ? ((r = !0), o[h].union(o[g]), o.splice(g, 1)) : g++; h++; } } while (r); return (this._paintRects = o), o; }), (e.prototype.debugGetPaintRects = function () { return (this._paintRects || []).slice(); }), (e.prototype.resize = function (t, e) { var n = this.dpr, i = this.dom, r = i.style, o = this.domBack; r && ((r.width = t + "px"), (r.height = e + "px")), (i.width = t * n), (i.height = e * n), o && ((o.width = t * n), (o.height = e * n), 1 !== n && this.ctxBack.scale(n, n)); }), (e.prototype.clear = function (t, e, n) { var i = this.dom, r = this.ctx, o = i.width, a = i.height; e = e || this.clearColor; var s = this.motionBlur && !t, l = this.lastFrameAlpha, u = this.dpr, h = this; s && (this.domBack || this.createBackBuffer(), (this.ctxBack.globalCompositeOperation = "copy"), this.ctxBack.drawImage(i, 0, 0, o / u, a / u)); var c = this.domBack; function p(t, n, i, o) { if ( (r.clearRect(t, n, i, o), e && "transparent" !== e) ) { var a = void 0; if (Q(e)) (a = ((e.global || (e.__width === i && e.__height === o)) && e.__canvasGradient) || qy(r, e, { x: 0, y: 0, width: i, height: o, })), (e.__canvasGradient = a), (e.__width = i), (e.__height = o); else tt(e) && ((e.scaleX = e.scaleX || u), (e.scaleY = e.scaleY || u), (a = ov(r, e, { dirty: function () { h.setUnpainted(), h.painter.refresh(); }, }))); r.save(), (r.fillStyle = a || e), r.fillRect(t, n, i, o), r.restore(); } s && (r.save(), (r.globalAlpha = l), r.drawImage(c, t, n, i, o), r.restore()); } !n || s ? p(0, 0, o, a) : n.length && E(n, function (t) { p(t.x * u, t.y * u, t.width * u, t.height * u); }); }), e ); })(jt), sS = 1e5, lS = 314159, uS = 0.01; var hS = (function () { function t(t, e, n, i) { (this.type = "canvas"), (this._zlevelList = []), (this._prevDisplayList = []), (this._layers = {}), (this._layerConfig = {}), (this._needsManuallyCompositing = !1), (this.type = "canvas"); var r = !t.nodeName || "CANVAS" === t.nodeName.toUpperCase(); (this._opts = n = A({}, n || {})), (this.dpr = n.devicePixelRatio || sr), (this._singleCanvas = r), (this.root = t), t.style && (xt(t), (t.innerHTML = "")), (this.storage = e); var o = this._zlevelList; this._prevDisplayList = []; var a = this._layers; if (r) { var s = t, l = s.width, u = s.height; null != n.width && (l = n.width), null != n.height && (u = n.height), (this.dpr = n.devicePixelRatio || 1), (s.width = l * this.dpr), (s.height = u * this.dpr), (this._width = l), (this._height = u); var h = new aS(s, this, this.dpr); (h.__builtin__ = !0), h.initContext(), (a[314159] = h), (h.zlevel = lS), o.push(lS), (this._domRoot = t); } else { (this._width = $y(t, 0, n)), (this._height = $y(t, 1, n)); var c = (this._domRoot = (function (t, e) { var n = document.createElement("div"); return ( (n.style.cssText = [ "position:relative", "width:" + t + "px", "height:" + e + "px", "padding:0", "margin:0", "border-width:0", ].join(";") + ";"), n ); })(this._width, this._height)); t.appendChild(c); } } return ( (t.prototype.getType = function () { return "canvas"; }), (t.prototype.isSingleCanvas = function () { return this._singleCanvas; }), (t.prototype.getViewportRoot = function () { return this._domRoot; }), (t.prototype.getViewportRootOffset = function () { var t = this.getViewportRoot(); if (t) return { offsetLeft: t.offsetLeft || 0, offsetTop: t.offsetTop || 0, }; }), (t.prototype.refresh = function (t) { var e = this.storage.getDisplayList(!0), n = this._prevDisplayList, i = this._zlevelList; (this._redrawId = Math.random()), this._paintList(e, n, t, this._redrawId); for (var r = 0; r < i.length; r++) { var o = i[r], a = this._layers[o]; if (!a.__builtin__ && a.refresh) { var s = 0 === r ? this._backgroundColor : null; a.refresh(s); } } return ( this._opts.useDirtyRect && (this._prevDisplayList = e.slice()), this ); }), (t.prototype.refreshHover = function () { this._paintHoverList(this.storage.getDisplayList(!1)); }), (t.prototype._paintHoverList = function (t) { var e = t.length, n = this._hoverlayer; if ((n && n.clear(), e)) { for ( var i, r = { inHover: !0, viewWidth: this._width, viewHeight: this._height, }, o = 0; o < e; o++ ) { var a = t[o]; a.__inHover && (n || (n = this._hoverlayer = this.getLayer(sS)), i || (i = n.ctx).save(), fv(i, a, r, o === e - 1)); } i && i.restore(); } }), (t.prototype.getHoverLayer = function () { return this.getLayer(sS); }), (t.prototype.paintOne = function (t, e) { dv(t, e); }), (t.prototype._paintList = function (t, e, n, i) { if (this._redrawId === i) { (n = n || !1), this._updateLayerStatus(t); var r = this._doPaintList(t, e, n), o = r.finished, a = r.needsRefreshHover; if ( (this._needsManuallyCompositing && this._compositeManually(), a && this._paintHoverList(t), o) ) this.eachLayer(function (t) { t.afterBrush && t.afterBrush(); }); else { var s = this; on(function () { s._paintList(t, e, n, i); }); } } }), (t.prototype._compositeManually = function () { var t = this.getLayer(lS).ctx, e = this._domRoot.width, n = this._domRoot.height; t.clearRect(0, 0, e, n), this.eachBuiltinLayer(function (i) { i.virtual && t.drawImage(i.dom, 0, 0, e, n); }); }), (t.prototype._doPaintList = function (t, e, n) { for ( var i = this, o = [], a = this._opts.useDirtyRect, s = 0; s < this._zlevelList.length; s++ ) { var l = this._zlevelList[s], u = this._layers[l]; u.__builtin__ && u !== this._hoverlayer && (u.__dirty || n) && o.push(u); } for ( var h = !0, c = !1, p = function (r) { var s, l = o[r], u = l.ctx, p = a && l.createRepaintRects( t, e, d._width, d._height ), f = n ? l.__startIndex : l.__drawIndex, g = !n && l.incremental && Date.now, y = g && Date.now(), v = l.zlevel === d._zlevelList[0] ? d._backgroundColor : null; if (l.__startIndex === l.__endIndex) l.clear(!1, v, p); else if (f === l.__startIndex) { var m = t[f]; (m.incremental && m.notClear && !n) || l.clear(!1, v, p); } -1 === f && (console.error( "For some unknown reason. drawIndex is -1" ), (f = l.__startIndex)); var x = function (e) { var n = { inHover: !1, allClipped: !1, prevEl: null, viewWidth: i._width, viewHeight: i._height, }; for (s = f; s < l.__endIndex; s++) { var r = t[s]; if ( (r.__inHover && (c = !0), i._doPaintEl( r, l, a, e, n, s === l.__endIndex - 1 ), g) ) if (Date.now() - y > 15) break; } n.prevElClipPaths && u.restore(); }; if (p) if (0 === p.length) s = l.__endIndex; else for ( var _ = d.dpr, b = 0; b < p.length; ++b ) { var w = p[b]; u.save(), u.beginPath(), u.rect( w.x * _, w.y * _, w.width * _, w.height * _ ), u.clip(), x(w), u.restore(); } else u.save(), x(), u.restore(); (l.__drawIndex = s), l.__drawIndex < l.__endIndex && (h = !1); }, d = this, f = 0; f < o.length; f++ ) p(f); return ( r.wxa && E(this._layers, function (t) { t && t.ctx && t.ctx.draw && t.ctx.draw(); }), { finished: h, needsRefreshHover: c } ); }), (t.prototype._doPaintEl = function (t, e, n, i, r, o) { var a = e.ctx; if (n) { var s = t.getPaintRect(); (!i || (s && s.intersect(i))) && (fv(a, t, r, o), t.setPrevPaintRect(s)); } else fv(a, t, r, o); }), (t.prototype.getLayer = function (t, e) { this._singleCanvas && !this._needsManuallyCompositing && (t = lS); var n = this._layers[t]; return ( n || (((n = new aS("zr_" + t, this, this.dpr)).zlevel = t), (n.__builtin__ = !0), this._layerConfig[t] ? C(n, this._layerConfig[t], !0) : this._layerConfig[t - uS] && C(n, this._layerConfig[t - uS], !0), e && (n.virtual = e), this.insertLayer(t, n), n.initContext()), n ); }), (t.prototype.insertLayer = function (t, e) { var n = this._layers, i = this._zlevelList, r = i.length, o = this._domRoot, a = null, s = -1; if ( !n[t] && (function (t) { return ( !!t && (!!t.__builtin__ || ("function" == typeof t.resize && "function" == typeof t.refresh)) ); })(e) ) { if (r > 0 && t > i[0]) { for ( s = 0; s < r - 1 && !(i[s] < t && i[s + 1] > t); s++ ); a = n[i[s]]; } if ((i.splice(s + 1, 0, t), (n[t] = e), !e.virtual)) if (a) { var l = a.dom; l.nextSibling ? o.insertBefore(e.dom, l.nextSibling) : o.appendChild(e.dom); } else o.firstChild ? o.insertBefore(e.dom, o.firstChild) : o.appendChild(e.dom); e.painter || (e.painter = this); } }), (t.prototype.eachLayer = function (t, e) { for (var n = this._zlevelList, i = 0; i < n.length; i++) { var r = n[i]; t.call(e, this._layers[r], r); } }), (t.prototype.eachBuiltinLayer = function (t, e) { for (var n = this._zlevelList, i = 0; i < n.length; i++) { var r = n[i], o = this._layers[r]; o.__builtin__ && t.call(e, o, r); } }), (t.prototype.eachOtherLayer = function (t, e) { for (var n = this._zlevelList, i = 0; i < n.length; i++) { var r = n[i], o = this._layers[r]; o.__builtin__ || t.call(e, o, r); } }), (t.prototype.getLayers = function () { return this._layers; }), (t.prototype._updateLayerStatus = function (t) { function e(t) { o && (o.__endIndex !== t && (o.__dirty = !0), (o.__endIndex = t)); } if ( (this.eachBuiltinLayer(function (t, e) { t.__dirty = t.__used = !1; }), this._singleCanvas) ) for (var n = 1; n < t.length; n++) { if ( (s = t[n]).zlevel !== t[n - 1].zlevel || s.incremental ) { this._needsManuallyCompositing = !0; break; } } var i, r, o = null, a = 0; for (r = 0; r < t.length; r++) { var s, l = (s = t[r]).zlevel, u = void 0; i !== l && ((i = l), (a = 0)), s.incremental ? (((u = this.getLayer( l + 0.001, this._needsManuallyCompositing )).incremental = !0), (a = 1)) : (u = this.getLayer( l + (a > 0 ? uS : 0), this._needsManuallyCompositing )), u.__builtin__ || I( "ZLevel " + l + " has been used by unkown layer " + u.id ), u !== o && ((u.__used = !0), u.__startIndex !== r && (u.__dirty = !0), (u.__startIndex = r), u.incremental ? (u.__drawIndex = -1) : (u.__drawIndex = r), e(r), (o = u)), 1 & s.__dirty && !s.__inHover && ((u.__dirty = !0), u.incremental && u.__drawIndex < 0 && (u.__drawIndex = r)); } e(r), this.eachBuiltinLayer(function (t, e) { !t.__used && t.getElementCount() > 0 && ((t.__dirty = !0), (t.__startIndex = t.__endIndex = t.__drawIndex = 0)), t.__dirty && t.__drawIndex < 0 && (t.__drawIndex = t.__startIndex); }); }), (t.prototype.clear = function () { return this.eachBuiltinLayer(this._clearLayer), this; }), (t.prototype._clearLayer = function (t) { t.clear(); }), (t.prototype.setBackgroundColor = function (t) { (this._backgroundColor = t), E(this._layers, function (t) { t.setUnpainted(); }); }), (t.prototype.configLayer = function (t, e) { if (e) { var n = this._layerConfig; n[t] ? C(n[t], e, !0) : (n[t] = e); for (var i = 0; i < this._zlevelList.length; i++) { var r = this._zlevelList[i]; if (r === t || r === t + uS) C(this._layers[r], n[t], !0); } } }), (t.prototype.delLayer = function (t) { var e = this._layers, n = this._zlevelList, i = e[t]; i && (i.dom.parentNode.removeChild(i.dom), delete e[t], n.splice(P(n, t), 1)); }), (t.prototype.resize = function (t, e) { if (this._domRoot.style) { var n = this._domRoot; n.style.display = "none"; var i = this._opts, r = this.root; if ( (null != t && (i.width = t), null != e && (i.height = e), (t = $y(r, 0, i)), (e = $y(r, 1, i)), (n.style.display = ""), this._width !== t || e !== this._height) ) { for (var o in ((n.style.width = t + "px"), (n.style.height = e + "px"), this._layers)) this._layers.hasOwnProperty(o) && this._layers[o].resize(t, e); this.refresh(!0); } (this._width = t), (this._height = e); } else { if (null == t || null == e) return; (this._width = t), (this._height = e), this.getLayer(lS).resize(t, e); } return this; }), (t.prototype.clearLayer = function (t) { var e = this._layers[t]; e && e.clear(); }), (t.prototype.dispose = function () { (this.root.innerHTML = ""), (this.root = this.storage = this._domRoot = this._layers = null); }), (t.prototype.getRenderedCanvas = function (t) { if ( ((t = t || {}), this._singleCanvas && !this._compositeManually) ) return this._layers[314159].dom; var e = new aS("image", this, t.pixelRatio || this.dpr); e.initContext(), e.clear(!1, t.backgroundColor || this._backgroundColor); var n = e.ctx; if (t.pixelRatio <= this.dpr) { this.refresh(); var i = e.dom.width, r = e.dom.height; this.eachLayer(function (t) { t.__builtin__ ? n.drawImage(t.dom, 0, 0, i, r) : t.renderToCanvas && (n.save(), t.renderToCanvas(n), n.restore()); }); } else for ( var o = { inHover: !1, viewWidth: this._width, viewHeight: this._height, }, a = this.storage.getDisplayList(!0), s = 0, l = a.length; s < l; s++ ) { var u = a[s]; fv(n, u, o, s === l - 1); } return e.dom; }), (t.prototype.getWidth = function () { return this._width; }), (t.prototype.getHeight = function () { return this._height; }), t ); })(); var cS = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.hasSymbolVisual = !0), n; } return ( n(e, t), (e.prototype.getInitialData = function (t) { return _x(null, this, { useEncodeDefaulter: !0 }); }), (e.prototype.getLegendIcon = function (t) { var e = new Br(), n = Xy( "line", 0, t.itemHeight / 2, t.itemWidth, 0, t.lineStyle.stroke, !1 ); e.add(n), n.setStyle(t.lineStyle); var i = this.getData().getVisual("symbol"), r = this.getData().getVisual("symbolRotate"), o = "none" === i ? "circle" : i, a = 0.8 * t.itemHeight, s = Xy( o, (t.itemWidth - a) / 2, (t.itemHeight - a) / 2, a, a, t.itemStyle.fill ); e.add(s), s.setStyle(t.itemStyle); var l = "inherit" === t.iconRotate ? r : t.iconRotate || 0; return ( (s.rotation = (l * Math.PI) / 180), s.setOrigin([t.itemWidth / 2, t.itemHeight / 2]), o.indexOf("empty") > -1 && ((s.style.stroke = s.style.fill), (s.style.fill = "#fff"), (s.style.lineWidth = 2)), e ); }), (e.type = "series.line"), (e.dependencies = ["grid", "polar"]), (e.defaultOption = { z: 3, coordinateSystem: "cartesian2d", legendHoverLink: !0, clip: !0, label: { position: "top" }, endLabel: { show: !1, valueAnimation: !0, distance: 8 }, lineStyle: { width: 2, type: "solid" }, emphasis: { scale: !0 }, step: !1, smooth: !1, smoothMonotone: null, symbol: "emptyCircle", symbolSize: 4, symbolRotate: null, showSymbol: !0, showAllSymbol: "auto", connectNulls: !1, sampling: "none", animationEasing: "linear", progressive: 0, hoverLayerThreshold: 1 / 0, universalTransition: { divideShape: "clone" }, triggerLineEvent: !1, }), e ); })(bg); function pS(t, e) { var n = t.mapDimensionsAll("defaultedLabel"), i = n.length; if (1 === i) { var r = mf(t, e, n[0]); return null != r ? r + "" : null; } if (i) { for (var o = [], a = 0; a < n.length; a++) o.push(mf(t, e, n[a])); return o.join(" "); } } function dS(t, e) { var n = t.mapDimensionsAll("defaultedLabel"); if (!Y(e)) return e + ""; for (var i = [], r = 0; r < n.length; r++) { var o = t.getDimensionIndex(n[r]); o >= 0 && i.push(e[o]); } return i.join(" "); } var fS = (function (t) { function e(e, n, i, r) { var o = t.call(this) || this; return o.updateData(e, n, i, r), o; } return ( n(e, t), (e.prototype._createSymbol = function (t, e, n, i, r) { this.removeAll(); var o = Xy(t, -1, -1, 2, 2, null, r); o.attr({ z2: 100, culling: !0, scaleX: i[0] / 2, scaleY: i[1] / 2, }), (o.drift = gS), (this._symbolType = t), this.add(o); }), (e.prototype.stopSymbolAnimation = function (t) { this.childAt(0).stopAnimation(null, t); }), (e.prototype.getSymbolType = function () { return this._symbolType; }), (e.prototype.getSymbolPath = function () { return this.childAt(0); }), (e.prototype.highlight = function () { Ol(this.childAt(0)); }), (e.prototype.downplay = function () { Rl(this.childAt(0)); }), (e.prototype.setZ = function (t, e) { var n = this.childAt(0); (n.zlevel = t), (n.z = e); }), (e.prototype.setDraggable = function (t, e) { var n = this.childAt(0); (n.draggable = t), (n.cursor = !e && t ? "move" : n.cursor); }), (e.prototype.updateData = function (t, n, i, r) { this.silent = !1; var o = t.getItemVisual(n, "symbol") || "circle", a = t.hostModel, s = e.getSymbolSize(t, n), l = o !== this._symbolType, u = r && r.disableAnimation; if (l) { var h = t.getItemVisual(n, "symbolKeepAspect"); this._createSymbol(o, t, n, s, h); } else { (p = this.childAt(0)).silent = !1; var c = { scaleX: s[0] / 2, scaleY: s[1] / 2 }; u ? p.attr(c) : vh(p, c, a, n), Sh(p); } if ((this._updateCommon(t, n, s, i, r), l)) { var p = this.childAt(0); if (!u) { c = { scaleX: this._sizeX, scaleY: this._sizeY, style: { opacity: p.style.opacity }, }; (p.scaleX = p.scaleY = 0), (p.style.opacity = 0), mh(p, c, a, n); } } u && this.childAt(0).stopAnimation("leave"); }), (e.prototype._updateCommon = function (t, e, n, i, r) { var o, a, s, l, u, h, c, p, d, f = this.childAt(0), g = t.hostModel; if ( (i && ((o = i.emphasisItemStyle), (a = i.blurItemStyle), (s = i.selectItemStyle), (l = i.focus), (u = i.blurScope), (c = i.labelStatesModels), (p = i.hoverScale), (d = i.cursorStyle), (h = i.emphasisDisabled)), !i || t.hasItemOption) ) { var y = i && i.itemModel ? i.itemModel : t.getItemModel(e), v = y.getModel("emphasis"); (o = v.getModel("itemStyle").getItemStyle()), (s = y .getModel(["select", "itemStyle"]) .getItemStyle()), (a = y.getModel(["blur", "itemStyle"]).getItemStyle()), (l = v.get("focus")), (u = v.get("blurScope")), (h = v.get("disabled")), (c = rc(y)), (p = v.getShallow("scale")), (d = y.getShallow("cursor")); } var m = t.getItemVisual(e, "symbolRotate"); f.attr("rotation", ((m || 0) * Math.PI) / 180 || 0); var x = Zy(t.getItemVisual(e, "symbolOffset"), n); x && ((f.x = x[0]), (f.y = x[1])), d && f.attr("cursor", d); var _ = t.getItemVisual(e, "style"), b = _.fill; if (f instanceof Ns) { var w = f.style; f.useStyle( A( { image: w.image, x: w.x, y: w.y, width: w.width, height: w.height, }, _ ) ); } else f.__isEmptyBrush ? f.useStyle(A({}, _)) : f.useStyle(_), (f.style.decal = null), f.setColor(b, r && r.symbolInnerColor), (f.style.strokeNoScale = !0); var S = t.getItemVisual(e, "liftZ"), M = this._z2; null != S ? null == M && ((this._z2 = f.z2), (f.z2 += S)) : null != M && ((f.z2 = M), (this._z2 = null)); var I = r && r.useNameLabel; ic(f, c, { labelFetcher: g, labelDataIndex: e, defaultText: function (e) { return I ? t.getName(e) : pS(t, e); }, inheritColor: b, defaultOpacity: _.opacity, }), (this._sizeX = n[0] / 2), (this._sizeY = n[1] / 2); var T = f.ensureState("emphasis"); (T.style = o), (f.ensureState("select").style = s), (f.ensureState("blur").style = a); var C = null == p || !0 === p ? Math.max(1.1, 3 / this._sizeY) : isFinite(p) && p > 0 ? +p : 1; (T.scaleX = this._sizeX * C), (T.scaleY = this._sizeY * C), this.setSymbolScale(1), Zl(this, l, u, h); }), (e.prototype.setSymbolScale = function (t) { this.scaleX = this.scaleY = t; }), (e.prototype.fadeOut = function (t, e, n) { var i = this.childAt(0), r = rl(this).dataIndex, o = n && n.animation; if (((this.silent = i.silent = !0), n && n.fadeLabel)) { var a = i.getTextContent(); a && _h(a, { style: { opacity: 0 } }, e, { dataIndex: r, removeOpt: o, cb: function () { i.removeTextContent(); }, }); } else i.removeTextContent(); _h(i, { style: { opacity: 0 }, scaleX: 0, scaleY: 0 }, e, { dataIndex: r, cb: t, removeOpt: o, }); }), (e.getSymbolSize = function (t, e) { return Uy(t.getItemVisual(e, "symbolSize")); }), e ); })(Br); function gS(t, e) { this.parent.drift(t, e); } function yS(t, e, n, i) { return ( e && !isNaN(e[0]) && !isNaN(e[1]) && !(i.isIgnore && i.isIgnore(n)) && !(i.clipShape && !i.clipShape.contain(e[0], e[1])) && "none" !== t.getItemVisual(n, "symbol") ); } function vS(t) { return null == t || q(t) || (t = { isIgnore: t }), t || {}; } function mS(t) { var e = t.hostModel, n = e.getModel("emphasis"); return { emphasisItemStyle: n.getModel("itemStyle").getItemStyle(), blurItemStyle: e.getModel(["blur", "itemStyle"]).getItemStyle(), selectItemStyle: e.getModel(["select", "itemStyle"]).getItemStyle(), focus: n.get("focus"), blurScope: n.get("blurScope"), emphasisDisabled: n.get("disabled"), hoverScale: n.get("scale"), labelStatesModels: rc(e), cursorStyle: e.get("cursor"), }; } var xS = (function () { function t(t) { (this.group = new Br()), (this._SymbolCtor = t || fS); } return ( (t.prototype.updateData = function (t, e) { (this._progressiveEls = null), (e = vS(e)); var n = this.group, i = t.hostModel, r = this._data, o = this._SymbolCtor, a = e.disableAnimation, s = mS(t), l = { disableAnimation: a }, u = e.getSymbolPoint || function (e) { return t.getItemLayout(e); }; r || n.removeAll(), t .diff(r) .add(function (i) { var r = u(i); if (yS(t, r, i, e)) { var a = new o(t, i, s, l); a.setPosition(r), t.setItemGraphicEl(i, a), n.add(a); } }) .update(function (h, c) { var p = r.getItemGraphicEl(c), d = u(h); if (yS(t, d, h, e)) { var f = t.getItemVisual(h, "symbol") || "circle", g = p && p.getSymbolType && p.getSymbolType(); if (!p || (g && g !== f)) n.remove(p), (p = new o(t, h, s, l)).setPosition(d); else { p.updateData(t, h, s, l); var y = { x: d[0], y: d[1] }; a ? p.attr(y) : vh(p, y, i); } n.add(p), t.setItemGraphicEl(h, p); } else n.remove(p); }) .remove(function (t) { var e = r.getItemGraphicEl(t); e && e.fadeOut(function () { n.remove(e); }, i); }) .execute(), (this._getSymbolPoint = u), (this._data = t); }), (t.prototype.updateLayout = function () { var t = this, e = this._data; e && e.eachItemGraphicEl(function (e, n) { var i = t._getSymbolPoint(n); e.setPosition(i), e.markRedraw(); }); }), (t.prototype.incrementalPrepareUpdate = function (t) { (this._seriesScope = mS(t)), (this._data = null), this.group.removeAll(); }), (t.prototype.incrementalUpdate = function (t, e, n) { function i(t) { t.isGroup || ((t.incremental = !0), (t.ensureState("emphasis").hoverLayer = !0)); } (this._progressiveEls = []), (n = vS(n)); for (var r = t.start; r < t.end; r++) { var o = e.getItemLayout(r); if (yS(e, o, r, n)) { var a = new this._SymbolCtor(e, r, this._seriesScope); a.traverse(i), a.setPosition(o), this.group.add(a), e.setItemGraphicEl(r, a), this._progressiveEls.push(a); } } }), (t.prototype.eachRendered = function (t) { Jh(this._progressiveEls || this.group, t); }), (t.prototype.remove = function (t) { var e = this.group, n = this._data; n && t ? n.eachItemGraphicEl(function (t) { t.fadeOut(function () { e.remove(t); }, n.hostModel); }) : e.removeAll(); }), t ); })(); function _S(t, e, n) { var i = t.getBaseAxis(), r = t.getOtherAxis(i), o = (function (t, e) { var n = 0, i = t.scale.getExtent(); "start" === e ? (n = i[0]) : "end" === e ? (n = i[1]) : j(e) && !isNaN(e) ? (n = e) : i[0] > 0 ? (n = i[0]) : i[1] < 0 && (n = i[1]); return n; })(r, n), a = i.dim, s = r.dim, l = e.mapDimension(s), u = e.mapDimension(a), h = "x" === s || "radius" === s ? 1 : 0, c = z(t.dimensions, function (t) { return e.mapDimension(t); }), p = !1, d = e.getCalculationInfo("stackResultDimension"); return ( mx(e, c[0]) && ((p = !0), (c[0] = d)), mx(e, c[1]) && ((p = !0), (c[1] = d)), { dataDimsForPoint: c, valueStart: o, valueAxisDim: s, baseAxisDim: a, stacked: !!p, valueDim: l, baseDim: u, baseDataOffset: h, stackedOverDimension: e.getCalculationInfo( "stackedOverDimension" ), } ); } function bS(t, e, n, i) { var r = NaN; t.stacked && (r = n.get(n.getCalculationInfo("stackedOverDimension"), i)), isNaN(r) && (r = t.valueStart); var o = t.baseDataOffset, a = []; return (a[o] = n.get(t.baseDim, i)), (a[1 - o] = r), e.dataToPoint(a); } var wS = Math.min, SS = Math.max; function MS(t, e) { return isNaN(t) || isNaN(e); } function IS(t, e, n, i, r, o, a, s, l) { for (var u, h, c, p, d, f, g = n, y = 0; y < i; y++) { var v = e[2 * g], m = e[2 * g + 1]; if (g >= r || g < 0) break; if (MS(v, m)) { if (l) { g += o; continue; } break; } if (g === n) t[o > 0 ? "moveTo" : "lineTo"](v, m), (c = v), (p = m); else { var x = v - u, _ = m - h; if (x * x + _ * _ < 0.5) { g += o; continue; } if (a > 0) { for ( var b = g + o, w = e[2 * b], S = e[2 * b + 1]; w === v && S === m && y < i; ) y++, (g += o), (w = e[2 * (b += o)]), (S = e[2 * b + 1]), (x = (v = e[2 * g]) - u), (_ = (m = e[2 * g + 1]) - h); var M = y + 1; if (l) for (; MS(w, S) && M < i; ) M++, (w = e[2 * (b += o)]), (S = e[2 * b + 1]); var I = 0.5, T = 0, C = 0, D = void 0, A = void 0; if (M >= i || MS(w, S)) (d = v), (f = m); else { (T = w - u), (C = S - h); var k = v - u, L = w - v, P = m - h, O = S - m, R = void 0, N = void 0; if ("x" === s) { var E = T > 0 ? 1 : -1; (d = v - E * (R = Math.abs(k)) * a), (f = m), (D = v + E * (N = Math.abs(L)) * a), (A = m); } else if ("y" === s) { var z = C > 0 ? 1 : -1; (d = v), (f = m - z * (R = Math.abs(P)) * a), (D = v), (A = m + z * (N = Math.abs(O)) * a); } else (R = Math.sqrt(k * k + P * P)), (d = v - T * a * (1 - (I = (N = Math.sqrt(L * L + O * O)) / (N + R)))), (f = m - C * a * (1 - I)), (A = m + C * a * I), (D = wS((D = v + T * a * I), SS(w, v))), (A = wS(A, SS(S, m))), (D = SS(D, wS(w, v))), (f = m - ((C = (A = SS(A, wS(S, m))) - m) * R) / N), (d = wS( (d = v - ((T = D - v) * R) / N), SS(u, v) )), (f = wS(f, SS(h, m))), (D = v + ((T = v - (d = SS(d, wS(u, v)))) * N) / R), (A = m + ((C = m - (f = SS(f, wS(h, m)))) * N) / R); } t.bezierCurveTo(c, p, d, f, v, m), (c = D), (p = A); } else t.lineTo(v, m); } (u = v), (h = m), (g += o); } return y; } var TS = function () { (this.smooth = 0), (this.smoothConstraint = !0); }, CS = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "ec-polyline"), n; } return ( n(e, t), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new TS(); }), (e.prototype.buildPath = function (t, e) { var n = e.points, i = 0, r = n.length / 2; if (e.connectNulls) { for (; r > 0 && MS(n[2 * r - 2], n[2 * r - 1]); r--); for (; i < r && MS(n[2 * i], n[2 * i + 1]); i++); } for (; i < r; ) i += IS( t, n, i, r, r, 1, e.smooth, e.smoothMonotone, e.connectNulls ) + 1; }), (e.prototype.getPointOn = function (t, e) { this.path || (this.createPathProxy(), this.buildPath(this.path, this.shape)); for ( var n, i, r = this.path.data, o = hs.CMD, a = "x" === e, s = [], l = 0; l < r.length; ) { var u = void 0, h = void 0, c = void 0, p = void 0, d = void 0, f = void 0, g = void 0; switch (r[l++]) { case o.M: (n = r[l++]), (i = r[l++]); break; case o.L: if ( ((u = r[l++]), (h = r[l++]), (g = a ? (t - n) / (u - n) : (t - i) / (h - i)) <= 1 && g >= 0) ) { var y = a ? (h - i) * g + i : (u - n) * g + n; return a ? [t, y] : [y, t]; } (n = u), (i = h); break; case o.C: (u = r[l++]), (h = r[l++]), (c = r[l++]), (p = r[l++]), (d = r[l++]), (f = r[l++]); var v = a ? _n(n, u, c, d, t, s) : _n(i, h, p, f, t, s); if (v > 0) for (var m = 0; m < v; m++) { var x = s[m]; if (x <= 1 && x >= 0) { y = a ? mn(i, h, p, f, x) : mn(n, u, c, d, x); return a ? [t, y] : [y, t]; } } (n = d), (i = f); } } }), e ); })(ks), DS = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return n(e, t), e; })(TS), AS = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "ec-polygon"), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new DS(); }), (e.prototype.buildPath = function (t, e) { var n = e.points, i = e.stackedOnPoints, r = 0, o = n.length / 2, a = e.smoothMonotone; if (e.connectNulls) { for (; o > 0 && MS(n[2 * o - 2], n[2 * o - 1]); o--); for (; r < o && MS(n[2 * r], n[2 * r + 1]); r++); } for (; r < o; ) { var s = IS( t, n, r, o, o, 1, e.smooth, a, e.connectNulls ); IS( t, i, r + s - 1, s, o, -1, e.stackedOnSmooth, a, e.connectNulls ), (r += s + 1), t.closePath(); } }), e ); })(ks); function kS(t, e, n, i, r) { var o = t.getArea(), a = o.x, s = o.y, l = o.width, u = o.height, h = n.get(["lineStyle", "width"]) || 0; (a -= h / 2), (s -= h / 2), (l += h), (u += h), (l = Math.ceil(l)), a !== Math.floor(a) && ((a = Math.floor(a)), l++); var c = new Ws({ shape: { x: a, y: s, width: l, height: u } }); if (e) { var p = t.getBaseAxis(), d = p.isHorizontal(), f = p.inverse; d ? (f && (c.shape.x += l), (c.shape.width = 0)) : (f || (c.shape.y += u), (c.shape.height = 0)); var g = X(r) ? function (t) { r(t, c); } : null; mh( c, { shape: { width: l, height: u, x: a, y: s } }, n, null, i, g ); } return c; } function LS(t, e, n) { var i = t.getArea(), r = Jr(i.r0, 1), o = Jr(i.r, 1), a = new Fu({ shape: { cx: Jr(t.cx, 1), cy: Jr(t.cy, 1), r0: r, r: o, startAngle: i.startAngle, endAngle: i.endAngle, clockwise: i.clockwise, }, }); e && ("angle" === t.getBaseAxis().dim ? (a.shape.endAngle = i.startAngle) : (a.shape.r = r), mh(a, { shape: { endAngle: i.endAngle, r: o } }, n)); return a; } function PS(t, e, n, i, r) { return t ? "polar" === t.type ? LS(t, e, n) : "cartesian2d" === t.type ? kS(t, e, n, i, r) : null : null; } function OS(t, e) { return t.type === e; } function RS(t, e) { if (t.length === e.length) { for (var n = 0; n < t.length; n++) if (t[n] !== e[n]) return; return !0; } } function NS(t) { for ( var e = 1 / 0, n = 1 / 0, i = -1 / 0, r = -1 / 0, o = 0; o < t.length; ) { var a = t[o++], s = t[o++]; isNaN(a) || ((e = Math.min(a, e)), (i = Math.max(a, i))), isNaN(s) || ((n = Math.min(s, n)), (r = Math.max(s, r))); } return [ [e, n], [i, r], ]; } function ES(t, e) { var n = NS(t), i = n[0], r = n[1], o = NS(e), a = o[0], s = o[1]; return Math.max( Math.abs(i[0] - a[0]), Math.abs(i[1] - a[1]), Math.abs(r[0] - s[0]), Math.abs(r[1] - s[1]) ); } function zS(t) { return j(t) ? t : t ? 0.5 : 0; } function VS(t, e, n, i, r) { var o = n.getBaseAxis(), a = "x" === o.dim || "radius" === o.dim ? 0 : 1, s = [], l = 0, u = [], h = [], c = [], p = []; if (r) { for (l = 0; l < t.length; l += 2) { var d = e || t; isNaN(d[l]) || isNaN(d[l + 1]) || p.push(t[l], t[l + 1]); } t = p; } for (l = 0; l < t.length - 2; l += 2) switch ( ((c[0] = t[l + 2]), (c[1] = t[l + 3]), (h[0] = t[l]), (h[1] = t[l + 1]), s.push(h[0], h[1]), i) ) { case "end": (u[a] = c[a]), (u[1 - a] = h[1 - a]), s.push(u[0], u[1]); break; case "middle": var f = (h[a] + c[a]) / 2, g = []; (u[a] = g[a] = f), (u[1 - a] = h[1 - a]), (g[1 - a] = c[1 - a]), s.push(u[0], u[1]), s.push(g[0], g[1]); break; default: (u[a] = h[a]), (u[1 - a] = c[1 - a]), s.push(u[0], u[1]); } return s.push(t[l++], t[l++]), s; } function BS(t, e, n) { var i = t.getVisual("visualMeta"); if (i && i.length && t.count() && "cartesian2d" === e.type) { for (var r, o, a = i.length - 1; a >= 0; a--) { var s = t.getDimensionInfo(i[a].dimension); if ("x" === (r = s && s.coordDim) || "y" === r) { o = i[a]; break; } } if (o) { var l = e.getAxis(r), u = z(o.stops, function (t) { return { coord: l.toGlobalCoord(l.dataToCoord(t.value)), color: t.color, }; }), h = u.length, c = o.outerColors.slice(); h && u[0].coord > u[h - 1].coord && (u.reverse(), c.reverse()); var p = (function (t, e) { var n, i, r = [], o = t.length; function a(t, e, n) { var i = t.coord; return { coord: n, color: ti((n - i) / (e.coord - i), [ t.color, e.color, ]), }; } for (var s = 0; s < o; s++) { var l = t[s], u = l.coord; if (u < 0) n = l; else { if (u > e) { i ? r.push(a(i, l, e)) : n && r.push(a(n, l, 0), a(n, l, e)); break; } n && (r.push(a(n, l, 0)), (n = null)), r.push(l), (i = l); } } return r; })(u, "x" === r ? n.getWidth() : n.getHeight()), d = p.length; if (!d && h) return u[0].coord < 0 ? c[1] ? c[1] : u[h - 1].color : c[0] ? c[0] : u[0].color; var f = p[0].coord - 10, g = p[d - 1].coord + 10, y = g - f; if (y < 0.001) return "transparent"; E(p, function (t) { t.offset = (t.coord - f) / y; }), p.push({ offset: d ? p[d - 1].offset : 0.5, color: c[1] || "transparent", }), p.unshift({ offset: d ? p[0].offset : 0.5, color: c[0] || "transparent", }); var v = new oh(0, 0, 0, 0, p, !0); return (v[r] = f), (v[r + "2"] = g), v; } } } function FS(t, e, n) { var i = t.get("showAllSymbol"), r = "auto" === i; if (!i || r) { var o = n.getAxesByScale("ordinal")[0]; if ( o && (!r || !(function (t, e) { var n = t.getExtent(), i = Math.abs(n[1] - n[0]) / t.scale.count(); isNaN(i) && (i = 0); for ( var r = e.count(), o = Math.max(1, Math.round(r / 5)), a = 0; a < r; a += o ) if ( 1.5 * fS.getSymbolSize(e, a)[ t.isHorizontal() ? 1 : 0 ] > i ) return !1; return !0; })(o, e)) ) { var a = e.mapDimension(o.dim), s = {}; return ( E(o.getViewLabels(), function (t) { var e = o.scale.getRawOrdinalNumber(t.tickValue); s[e] = 1; }), function (t) { return !s.hasOwnProperty(e.get(a, t)); } ); } } } function GS(t, e) { return [t[2 * e], t[2 * e + 1]]; } function WS(t) { if (t.get(["endLabel", "show"])) return !0; for (var e = 0; e < hl.length; e++) if (t.get([hl[e], "endLabel", "show"])) return !0; return !1; } function HS(t, e, n, i) { if (OS(e, "cartesian2d")) { var r = i.getModel("endLabel"), o = r.get("valueAnimation"), a = i.getData(), s = { lastFrameIndex: 0 }, l = WS(i) ? function (n, i) { t._endLabelOnDuring(n, i, a, s, o, r, e); } : null, u = e.getBaseAxis().isHorizontal(), h = kS( e, n, i, function () { var e = t._endLabel; e && n && null != s.originalX && e.attr({ x: s.originalX, y: s.originalY }); }, l ); if (!i.get("clip", !0)) { var c = h.shape, p = Math.max(c.width, c.height); u ? ((c.y -= p), (c.height += 2 * p)) : ((c.x -= p), (c.width += 2 * p)); } return l && l(1, h), h; } return LS(e, n, i); } var YS = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.init = function () { var t = new Br(), e = new xS(); this.group.add(e.group), (this._symbolDraw = e), (this._lineGroup = t), (this._changePolyState = W(this._changePolyState, this)); }), (e.prototype.render = function (t, e, n) { var i = t.coordinateSystem, r = this.group, o = t.getData(), a = t.getModel("lineStyle"), s = t.getModel("areaStyle"), l = o.getLayout("points") || [], u = "polar" === i.type, h = this._coordSys, c = this._symbolDraw, p = this._polyline, d = this._polygon, f = this._lineGroup, g = !e.ssr && t.get("animation"), y = !s.isEmpty(), v = s.get("origin"), m = _S(i, o, v), x = y && (function (t, e, n) { if (!n.valueDim) return []; for ( var i = e.count(), r = Bx(2 * i), o = 0; o < i; o++ ) { var a = bS(n, t, e, o); (r[2 * o] = a[0]), (r[2 * o + 1] = a[1]); } return r; })(i, o, m), _ = t.get("showSymbol"), b = t.get("connectNulls"), w = _ && !u && FS(t, o, i), S = this._data; S && S.eachItemGraphicEl(function (t, e) { t.__temp && (r.remove(t), S.setItemGraphicEl(e, null)); }), _ || c.remove(), r.add(f); var M, I = !u && t.get("step"); i && i.getArea && t.get("clip", !0) && (null != (M = i.getArea()).width ? ((M.x -= 0.1), (M.y -= 0.1), (M.width += 0.2), (M.height += 0.2)) : M.r0 && ((M.r0 -= 0.5), (M.r += 0.5))), (this._clipShapeForSymbol = M); var T = BS(o, i, n) || o.getVisual("style")[o.getVisual("drawType")]; if (p && h.type === i.type && I === this._step) { y && !d ? (d = this._newPolygon(l, x)) : d && !y && (f.remove(d), (d = this._polygon = null)), u || this._initOrUpdateEndLabel(t, i, Sp(T)); var C = f.getClipPath(); if (C) mh(C, { shape: HS(this, i, !1, t).shape }, t); else f.setClipPath(HS(this, i, !0, t)); _ && c.updateData(o, { isIgnore: w, clipShape: M, disableAnimation: !0, getSymbolPoint: function (t) { return [l[2 * t], l[2 * t + 1]]; }, }), (RS(this._stackedOnPoints, x) && RS(this._points, l)) || (g ? this._doUpdateAnimation(o, x, i, n, I, v, b) : (I && (x && (x = VS(x, l, i, I, b)), (l = VS(l, null, i, I, b))), p.setShape({ points: l }), d && d.setShape({ points: l, stackedOnPoints: x, }))); } else _ && c.updateData(o, { isIgnore: w, clipShape: M, disableAnimation: !0, getSymbolPoint: function (t) { return [l[2 * t], l[2 * t + 1]]; }, }), g && this._initSymbolLabelAnimation(o, i, M), I && (x && (x = VS(x, l, i, I, b)), (l = VS(l, null, i, I, b))), (p = this._newPolyline(l)), y ? (d = this._newPolygon(l, x)) : d && (f.remove(d), (d = this._polygon = null)), u || this._initOrUpdateEndLabel(t, i, Sp(T)), f.setClipPath(HS(this, i, !0, t)); var D = t.getModel("emphasis"), A = D.get("focus"), L = D.get("blurScope"), P = D.get("disabled"); (p.useStyle( k(a.getLineStyle(), { fill: "none", stroke: T, lineJoin: "bevel", }) ), $l(p, t, "lineStyle"), p.style.lineWidth > 0 && "bolder" === t.get(["emphasis", "lineStyle", "width"])) && (p.getState("emphasis").style.lineWidth = +p.style.lineWidth + 1); (rl(p).seriesIndex = t.seriesIndex), Zl(p, A, L, P); var O = zS(t.get("smooth")), R = t.get("smoothMonotone"); if ( (p.setShape({ smooth: O, smoothMonotone: R, connectNulls: b, }), d) ) { var N = o.getCalculationInfo("stackedOnSeries"), E = 0; d.useStyle( k(s.getAreaStyle(), { fill: T, opacity: 0.7, lineJoin: "bevel", decal: o.getVisual("style").decal, }) ), N && (E = zS(N.get("smooth"))), d.setShape({ smooth: O, stackedOnSmooth: E, smoothMonotone: R, connectNulls: b, }), $l(d, t, "areaStyle"), (rl(d).seriesIndex = t.seriesIndex), Zl(d, A, L, P); } var z = this._changePolyState; o.eachItemGraphicEl(function (t) { t && (t.onHoverStateChange = z); }), (this._polyline.onHoverStateChange = z), (this._data = o), (this._coordSys = i), (this._stackedOnPoints = x), (this._points = l), (this._step = I), (this._valueOrigin = v), t.get("triggerLineEvent") && (this.packEventData(t, p), d && this.packEventData(t, d)); }), (e.prototype.packEventData = function (t, e) { rl(e).eventData = { componentType: "series", componentSubType: "line", componentIndex: t.componentIndex, seriesIndex: t.seriesIndex, seriesName: t.name, seriesType: "line", }; }), (e.prototype.highlight = function (t, e, n, i) { var r = t.getData(), o = zo(r, i); if ( (this._changePolyState("emphasis"), !(o instanceof Array) && null != o && o >= 0) ) { var a = r.getLayout("points"), s = r.getItemGraphicEl(o); if (!s) { var l = a[2 * o], u = a[2 * o + 1]; if (isNaN(l) || isNaN(u)) return; if ( this._clipShapeForSymbol && !this._clipShapeForSymbol.contain(l, u) ) return; var h = t.get("zlevel") || 0, c = t.get("z") || 0; ((s = new fS(r, o)).x = l), (s.y = u), s.setZ(h, c); var p = s.getSymbolPath().getTextContent(); p && ((p.zlevel = h), (p.z = c), (p.z2 = this._polyline.z2 + 1)), (s.__temp = !0), r.setItemGraphicEl(o, s), s.stopSymbolAnimation(!0), this.group.add(s); } s.highlight(); } else Og.prototype.highlight.call(this, t, e, n, i); }), (e.prototype.downplay = function (t, e, n, i) { var r = t.getData(), o = zo(r, i); if ((this._changePolyState("normal"), null != o && o >= 0)) { var a = r.getItemGraphicEl(o); a && (a.__temp ? (r.setItemGraphicEl(o, null), this.group.remove(a)) : a.downplay()); } else Og.prototype.downplay.call(this, t, e, n, i); }), (e.prototype._changePolyState = function (t) { var e = this._polygon; Dl(this._polyline, t), e && Dl(e, t); }), (e.prototype._newPolyline = function (t) { var e = this._polyline; return ( e && this._lineGroup.remove(e), (e = new CS({ shape: { points: t }, segmentIgnoreThreshold: 2, z2: 10, })), this._lineGroup.add(e), (this._polyline = e), e ); }), (e.prototype._newPolygon = function (t, e) { var n = this._polygon; return ( n && this._lineGroup.remove(n), (n = new AS({ shape: { points: t, stackedOnPoints: e }, segmentIgnoreThreshold: 2, })), this._lineGroup.add(n), (this._polygon = n), n ); }), (e.prototype._initSymbolLabelAnimation = function (t, e, n) { var i, r, o = e.getBaseAxis(), a = o.inverse; "cartesian2d" === e.type ? ((i = o.isHorizontal()), (r = !1)) : "polar" === e.type && ((i = "angle" === o.dim), (r = !0)); var s = t.hostModel, l = s.get("animationDuration"); X(l) && (l = l(null)); var u = s.get("animationDelay") || 0, h = X(u) ? u(null) : u; t.eachItemGraphicEl(function (t, o) { var s = t; if (s) { var c = [t.x, t.y], p = void 0, d = void 0, f = void 0; if (n) if (r) { var g = n, y = e.pointToCoord(c); i ? ((p = g.startAngle), (d = g.endAngle), (f = (-y[1] / 180) * Math.PI)) : ((p = g.r0), (d = g.r), (f = y[0])); } else { var v = n; i ? ((p = v.x), (d = v.x + v.width), (f = t.x)) : ((p = v.y + v.height), (d = v.y), (f = t.y)); } var m = d === p ? 0 : (f - p) / (d - p); a && (m = 1 - m); var x = X(u) ? u(o) : l * m + h, _ = s.getSymbolPath(), b = _.getTextContent(); s.attr({ scaleX: 0, scaleY: 0 }), s.animateTo( { scaleX: 1, scaleY: 1 }, { duration: 200, setToFinal: !0, delay: x } ), b && b.animateFrom( { style: { opacity: 0 } }, { duration: 300, delay: x } ), (_.disableLabelAnimation = !0); } }); }), (e.prototype._initOrUpdateEndLabel = function (t, e, n) { var i = t.getModel("endLabel"); if (WS(t)) { var r = t.getData(), o = this._polyline, a = r.getLayout("points"); if (!a) return ( o.removeTextContent(), void (this._endLabel = null) ); var s = this._endLabel; s || (((s = this._endLabel = new Xs({ z2: 200 })).ignoreClip = !0), o.setTextContent(this._endLabel), (o.disableLabelAnimation = !0)); var l = (function (t) { for ( var e, n, i = t.length / 2; i > 0 && ((e = t[2 * i - 2]), (n = t[2 * i - 1]), isNaN(e) || isNaN(n)); i-- ); return i - 1; })(a); l >= 0 && (ic( o, rc(t, "endLabel"), { inheritColor: n, labelFetcher: t, labelDataIndex: l, defaultText: function (t, e, n) { return null != n ? dS(r, n) : pS(r, t); }, enableTextSetter: !0, }, (function (t, e) { var n = e.getBaseAxis(), i = n.isHorizontal(), r = n.inverse, o = i ? (r ? "right" : "left") : "center", a = i ? "middle" : r ? "top" : "bottom"; return { normal: { align: t.get("align") || o, verticalAlign: t.get("verticalAlign") || a, }, }; })(i, e) ), (o.textConfig.position = null)); } else this._endLabel && (this._polyline.removeTextContent(), (this._endLabel = null)); }), (e.prototype._endLabelOnDuring = function (t, e, n, i, r, o, a) { var s = this._endLabel, l = this._polyline; if (s) { t < 1 && null == i.originalX && ((i.originalX = s.x), (i.originalY = s.y)); var u = n.getLayout("points"), h = n.hostModel, c = h.get("connectNulls"), p = o.get("precision"), d = o.get("distance") || 0, f = a.getBaseAxis(), g = f.isHorizontal(), y = f.inverse, v = e.shape, m = y ? g ? v.x : v.y + v.height : g ? v.x + v.width : v.y, x = (g ? d : 0) * (y ? -1 : 1), _ = (g ? 0 : -d) * (y ? -1 : 1), b = g ? "x" : "y", w = (function (t, e, n) { for ( var i, r, o = t.length / 2, a = "x" === n ? 0 : 1, s = 0, l = -1, u = 0; u < o; u++ ) if ( ((r = t[2 * u + a]), !isNaN(r) && !isNaN(t[2 * u + 1 - a])) ) if (0 !== u) { if ( (i <= e && r >= e) || (i >= e && r <= e) ) { l = u; break; } (s = u), (i = r); } else i = r; return { range: [s, l], t: (e - i) / (r - i) }; })(u, m, b), S = w.range, M = S[1] - S[0], I = void 0; if (M >= 1) { if (M > 1 && !c) { var T = GS(u, S[0]); s.attr({ x: T[0] + x, y: T[1] + _ }), r && (I = h.getRawValue(S[0])); } else { (T = l.getPointOn(m, b)) && s.attr({ x: T[0] + x, y: T[1] + _ }); var C = h.getRawValue(S[0]), D = h.getRawValue(S[1]); r && (I = Zo(n, p, C, D, w.t)); } i.lastFrameIndex = S[0]; } else { var A = 1 === t || i.lastFrameIndex > 0 ? S[0] : 0; T = GS(u, A); r && (I = h.getRawValue(A)), s.attr({ x: T[0] + x, y: T[1] + _ }); } if (r) { var k = pc(s); "function" == typeof k.setLabelText && k.setLabelText(I); } } }), (e.prototype._doUpdateAnimation = function (t, e, n, i, r, o, a) { var s = this._polyline, l = this._polygon, u = t.hostModel, h = (function (t, e, n, i, r, o, a, s) { for ( var l = (function (t, e) { var n = []; return ( e .diff(t) .add(function (t) { n.push({ cmd: "+", idx: t }); }) .update(function (t, e) { n.push({ cmd: "=", idx: e, idx1: t, }); }) .remove(function (t) { n.push({ cmd: "-", idx: t }); }) .execute(), n ); })(t, e), u = [], h = [], c = [], p = [], d = [], f = [], g = [], y = _S(r, e, a), v = t.getLayout("points") || [], m = e.getLayout("points") || [], x = 0; x < l.length; x++ ) { var _ = l[x], b = !0, w = void 0, S = void 0; switch (_.cmd) { case "=": (w = 2 * _.idx), (S = 2 * _.idx1); var M = v[w], I = v[w + 1], T = m[S], C = m[S + 1]; (isNaN(M) || isNaN(I)) && ((M = T), (I = C)), u.push(M, I), h.push(T, C), c.push(n[w], n[w + 1]), p.push(i[S], i[S + 1]), g.push(e.getRawIndex(_.idx1)); break; case "+": var D = _.idx, A = y.dataDimsForPoint, k = r.dataToPoint([ e.get(A[0], D), e.get(A[1], D), ]); (S = 2 * D), u.push(k[0], k[1]), h.push(m[S], m[S + 1]); var L = bS(y, r, e, D); c.push(L[0], L[1]), p.push(i[S], i[S + 1]), g.push(e.getRawIndex(D)); break; case "-": b = !1; } b && (d.push(_), f.push(f.length)); } f.sort(function (t, e) { return g[t] - g[e]; }); var P = u.length, O = Bx(P), R = Bx(P), N = Bx(P), E = Bx(P), z = []; for (x = 0; x < f.length; x++) { var V = f[x], B = 2 * x, F = 2 * V; (O[B] = u[F]), (O[B + 1] = u[F + 1]), (R[B] = h[F]), (R[B + 1] = h[F + 1]), (N[B] = c[F]), (N[B + 1] = c[F + 1]), (E[B] = p[F]), (E[B + 1] = p[F + 1]), (z[x] = d[V]); } return { current: O, next: R, stackedOnCurrent: N, stackedOnNext: E, status: z, }; })( this._data, t, this._stackedOnPoints, e, this._coordSys, 0, this._valueOrigin ), c = h.current, p = h.stackedOnCurrent, d = h.next, f = h.stackedOnNext; if ( (r && ((p = VS(h.stackedOnCurrent, h.current, n, r, a)), (c = VS(h.current, null, n, r, a)), (f = VS(h.stackedOnNext, h.next, n, r, a)), (d = VS(h.next, null, n, r, a))), ES(c, d) > 3e3 || (l && ES(p, f) > 3e3)) ) return ( s.stopAnimation(), s.setShape({ points: d }), void ( l && (l.stopAnimation(), l.setShape({ points: d, stackedOnPoints: f })) ) ); (s.shape.__points = h.current), (s.shape.points = c); var g = { shape: { points: d } }; h.current !== c && (g.shape.__points = h.next), s.stopAnimation(), vh(s, g, u), l && (l.setShape({ points: c, stackedOnPoints: p }), l.stopAnimation(), vh(l, { shape: { stackedOnPoints: f } }, u), s.shape.points !== l.shape.points && (l.shape.points = s.shape.points)); for (var y = [], v = h.status, m = 0; m < v.length; m++) { if ("=" === v[m].cmd) { var x = t.getItemGraphicEl(v[m].idx1); x && y.push({ el: x, ptIdx: m }); } } s.animators && s.animators.length && s.animators[0].during(function () { l && l.dirtyShape(); for ( var t = s.shape.__points, e = 0; e < y.length; e++ ) { var n = y[e].el, i = 2 * y[e].ptIdx; (n.x = t[i]), (n.y = t[i + 1]), n.markRedraw(); } }); }), (e.prototype.remove = function (t) { var e = this.group, n = this._data; this._lineGroup.removeAll(), this._symbolDraw.remove(!0), n && n.eachItemGraphicEl(function (t, i) { t.__temp && (e.remove(t), n.setItemGraphicEl(i, null)); }), (this._polyline = this._polygon = this._coordSys = this._points = this._stackedOnPoints = this._endLabel = this._data = null); }), (e.type = "line"), e ); })(Og); function XS(t, e) { return { seriesType: t, plan: kg(), reset: function (t) { var n = t.getData(), i = t.coordinateSystem, r = t.pipelineContext, o = e || r.large; if (i) { var a = z(i.dimensions, function (t) { return n.mapDimension(t); }).slice(0, 2), s = a.length, l = n.getCalculationInfo("stackResultDimension"); mx(n, a[0]) && (a[0] = l), mx(n, a[1]) && (a[1] = l); var u = n.getStore(), h = n.getDimensionIndex(a[0]), c = n.getDimensionIndex(a[1]); return ( s && { progress: function (t, e) { for ( var n = t.end - t.start, r = o && Bx(n * s), a = [], l = [], p = t.start, d = 0; p < t.end; p++ ) { var f = void 0; if (1 === s) { var g = u.get(h, p); f = i.dataToPoint(g, null, l); } else (a[0] = u.get(h, p)), (a[1] = u.get(c, p)), (f = i.dataToPoint(a, null, l)); o ? ((r[d++] = f[0]), (r[d++] = f[1])) : e.setItemLayout(p, f.slice()); } o && e.setLayout("points", r); }, } ); } }, }; } var US = { average: function (t) { for (var e = 0, n = 0, i = 0; i < t.length; i++) isNaN(t[i]) || ((e += t[i]), n++); return 0 === n ? NaN : e / n; }, sum: function (t) { for (var e = 0, n = 0; n < t.length; n++) e += t[n] || 0; return e; }, max: function (t) { for (var e = -1 / 0, n = 0; n < t.length; n++) t[n] > e && (e = t[n]); return isFinite(e) ? e : NaN; }, min: function (t) { for (var e = 1 / 0, n = 0; n < t.length; n++) t[n] < e && (e = t[n]); return isFinite(e) ? e : NaN; }, nearest: function (t) { return t[0]; }, }, ZS = function (t) { return Math.round(t.length / 2); }; function jS(t) { return { seriesType: t, reset: function (t, e, n) { var i = t.getData(), r = t.get("sampling"), o = t.coordinateSystem, a = i.count(); if (a > 10 && "cartesian2d" === o.type && r) { var s = o.getBaseAxis(), l = o.getOtherAxis(s), u = s.getExtent(), h = n.getDevicePixelRatio(), c = Math.abs(u[1] - u[0]) * (h || 1), p = Math.round(a / c); if (isFinite(p) && p > 1) { "lttb" === r ? t.setData( i.lttbDownSample(i.mapDimension(l.dim), 1 / p) ) : "minmax" === r && t.setData( i.minmaxDownSample( i.mapDimension(l.dim), 1 / p ) ); var d = void 0; U(r) ? (d = US[r]) : X(r) && (d = r), d && t.setData( i.downSample( i.mapDimension(l.dim), 1 / p, d, ZS ) ); } } }, }; } var qS = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { return _x(null, this, { useEncodeDefaulter: !0 }); }), (e.prototype.getMarkerPosition = function (t, e, n) { var i = this.coordinateSystem; if (i && i.clampData) { var r = i.clampData(t), o = i.dataToPoint(r); if (n) E(i.getAxes(), function (t, n) { if ("category" === t.type && null != e) { var i = t.getTicksCoords(), a = t.getTickModel().get("alignWithLabel"), s = r[n], l = "x1" === e[n] || "y1" === e[n]; if ((l && !a && (s += 1), i.length < 2)) return; if (2 === i.length) return void (o[n] = t.toGlobalCoord( t.getExtent()[l ? 1 : 0] )); for ( var u = void 0, h = void 0, c = 1, p = 0; p < i.length; p++ ) { var d = i[p].coord, f = p === i.length - 1 ? i[p - 1].tickValue + c : i[p].tickValue; if (f === s) { h = d; break; } if (f < s) u = d; else if (null != u && f > s) { h = (d + u) / 2; break; } 1 === p && (c = f - i[0].tickValue); } null == h && (u ? u && (h = i[i.length - 1].coord) : (h = i[0].coord)), (o[n] = t.toGlobalCoord(h)); } }); else { var a = this.getData(), s = a.getLayout("offset"), l = a.getLayout("size"), u = i.getBaseAxis().isHorizontal() ? 0 : 1; o[u] += s + l / 2; } return o; } return [NaN, NaN]; }), (e.type = "series.__base_bar__"), (e.defaultOption = { z: 2, coordinateSystem: "cartesian2d", legendHoverLink: !0, barMinHeight: 0, barMinAngle: 0, large: !1, largeThreshold: 400, progressive: 3e3, progressiveChunkMode: "mod", }), e ); })(bg); bg.registerClass(qS); var KS = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.getInitialData = function () { return _x(null, this, { useEncodeDefaulter: !0, createInvertedIndices: !!this.get("realtimeSort", !0) || null, }); }), (e.prototype.getProgressive = function () { return !!this.get("large") && this.get("progressive"); }), (e.prototype.getProgressiveThreshold = function () { var t = this.get("progressiveThreshold"), e = this.get("largeThreshold"); return e > t && (t = e), t; }), (e.prototype.brushSelector = function (t, e, n) { return n.rect(e.getItemLayout(t)); }), (e.type = "series.bar"), (e.dependencies = ["grid", "polar"]), (e.defaultOption = kc(qS.defaultOption, { clip: !0, roundCap: !1, showBackground: !1, backgroundStyle: { color: "rgba(180, 180, 180, 0.2)", borderColor: null, borderWidth: 0, borderType: "solid", borderRadius: 0, shadowBlur: 0, shadowColor: null, shadowOffsetX: 0, shadowOffsetY: 0, opacity: 1, }, select: { itemStyle: { borderColor: "#212121" } }, realtimeSort: !1, })), e ); })(qS), $S = function () { (this.cx = 0), (this.cy = 0), (this.r0 = 0), (this.r = 0), (this.startAngle = 0), (this.endAngle = 2 * Math.PI), (this.clockwise = !0); }, JS = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "sausage"), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new $S(); }), (e.prototype.buildPath = function (t, e) { var n = e.cx, i = e.cy, r = Math.max(e.r0 || 0, 0), o = Math.max(e.r, 0), a = 0.5 * (o - r), s = r + a, l = e.startAngle, u = e.endAngle, h = e.clockwise, c = 2 * Math.PI, p = h ? u - l < c : l - u < c; p || (l = u - (h ? c : -c)); var d = Math.cos(l), f = Math.sin(l), g = Math.cos(u), y = Math.sin(u); p ? (t.moveTo(d * r + n, f * r + i), t.arc(d * s + n, f * s + i, a, -Math.PI + l, l, !h)) : t.moveTo(d * o + n, f * o + i), t.arc(n, i, o, l, u, !h), t.arc( g * s + n, y * s + i, a, u - 2 * Math.PI, u - Math.PI, !h ), 0 !== r && t.arc(n, i, r, u, l, h); }), e ); })(ks); function QS(t, e, n) { return e * Math.sin(t) * (n ? -1 : 1); } function tM(t, e, n) { return e * Math.cos(t) * (n ? 1 : -1); } function eM(t, e, n) { var i = t.get("borderRadius"); if (null == i) return n ? { cornerRadius: 0 } : null; Y(i) || (i = [i, i, i, i]); var r = Math.abs(e.r || 0 - e.r0 || 0); return { cornerRadius: z(i, function (t) { return Cr(t, r); }), }; } var nM = Math.max, iM = Math.min; var rM = (function (t) { function e() { var n = t.call(this) || this; return (n.type = e.type), (n._isFirstFrame = !0), n; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { (this._model = t), this._removeOnRenderedListener(n), this._updateDrawMode(t); var r = t.get("coordinateSystem"); ("cartesian2d" === r || "polar" === r) && ((this._progressiveEls = null), this._isLargeDraw ? this._renderLarge(t, e, n) : this._renderNormal(t, e, n, i)); }), (e.prototype.incrementalPrepareRender = function (t) { this._clear(), this._updateDrawMode(t), this._updateLargeClip(t); }), (e.prototype.incrementalRender = function (t, e) { (this._progressiveEls = []), this._incrementalRenderLarge(t, e); }), (e.prototype.eachRendered = function (t) { Jh(this._progressiveEls || this.group, t); }), (e.prototype._updateDrawMode = function (t) { var e = t.pipelineContext.large; (null != this._isLargeDraw && e === this._isLargeDraw) || ((this._isLargeDraw = e), this._clear()); }), (e.prototype._renderNormal = function (t, e, n, i) { var r, o = this.group, a = t.getData(), s = this._data, l = t.coordinateSystem, u = l.getBaseAxis(); "cartesian2d" === l.type ? (r = u.isHorizontal()) : "polar" === l.type && (r = "angle" === u.dim); var h = t.isAnimationEnabled() ? t : null, c = (function (t, e) { var n = t.get("realtimeSort", !0), i = e.getBaseAxis(); 0; if ( n && "category" === i.type && "cartesian2d" === e.type ) return { baseAxis: i, otherAxis: e.getOtherAxis(i), }; })(t, l); c && this._enableRealtimeSort(c, a, n); var p = t.get("clip", !0) || c, d = (function (t, e) { var n = t.getArea && t.getArea(); if (OS(t, "cartesian2d")) { var i = t.getBaseAxis(); if ("category" !== i.type || !i.onBand) { var r = e.getLayout("bandWidth"); i.isHorizontal() ? ((n.x -= r), (n.width += 2 * r)) : ((n.y -= r), (n.height += 2 * r)); } } return n; })(l, a); o.removeClipPath(); var f = t.get("roundCap", !0), g = t.get("showBackground", !0), y = t.getModel("backgroundStyle"), v = y.get("borderRadius") || 0, m = [], x = this._backgroundEls, _ = i && i.isInitSort, b = i && "changeAxisOrder" === i.type; function w(t) { var e = pM[l.type](a, t), n = (function (t, e, n) { var i = "polar" === t.type ? Fu : Ws; return new i({ shape: xM(e, n, t), silent: !0, z2: 0, }); })(l, r, e); return ( n.useStyle(y.getItemStyle()), "cartesian2d" === l.type ? n.setShape("r", v) : n.setShape("cornerRadius", v), (m[t] = n), n ); } a.diff(s) .add(function (e) { var n = a.getItemModel(e), i = pM[l.type](a, e, n); if ((g && w(e), a.hasValue(e) && cM[l.type](i))) { var s = !1; p && (s = oM[l.type](d, i)); var y = aM[l.type]( t, a, e, i, r, h, u.model, !1, f ); c && (y.forceLabelAnimation = !0), fM(y, a, e, n, i, t, r, "polar" === l.type), _ ? y.attr({ shape: i }) : c ? sM(c, h, y, i, e, r, !1, !1) : mh(y, { shape: i }, t, e), a.setItemGraphicEl(e, y), o.add(y), (y.ignore = s); } }) .update(function (e, n) { var i = a.getItemModel(e), S = pM[l.type](a, e, i); if (g) { var M = void 0; 0 === x.length ? (M = w(n)) : ((M = x[n]).useStyle(y.getItemStyle()), "cartesian2d" === l.type ? M.setShape("r", v) : M.setShape("cornerRadius", v), (m[e] = M)); var I = pM[l.type](a, e); vh(M, { shape: xM(r, I, l) }, h, e); } var T = s.getItemGraphicEl(n); if (a.hasValue(e) && cM[l.type](S)) { var C = !1; if ( (p && (C = oM[l.type](d, S)) && o.remove(T), T ? Sh(T) : (T = aM[l.type]( t, a, e, S, r, h, u.model, !!T, f )), c && (T.forceLabelAnimation = !0), b) ) { var D = T.getTextContent(); if (D) { var A = pc(D); null != A.prevValue && (A.prevValue = A.value); } } else fM(T, a, e, i, S, t, r, "polar" === l.type); _ ? T.attr({ shape: S }) : c ? sM(c, h, T, S, e, r, !0, b) : vh(T, { shape: S }, t, e, null), a.setItemGraphicEl(e, T), (T.ignore = C), o.add(T); } else o.remove(T); }) .remove(function (e) { var n = s.getItemGraphicEl(e); n && wh(n, t, e); }) .execute(); var S = this._backgroundGroup || (this._backgroundGroup = new Br()); S.removeAll(); for (var M = 0; M < m.length; ++M) S.add(m[M]); o.add(S), (this._backgroundEls = m), (this._data = a); }), (e.prototype._renderLarge = function (t, e, n) { this._clear(), vM(t, this.group), this._updateLargeClip(t); }), (e.prototype._incrementalRenderLarge = function (t, e) { this._removeBackground(), vM(e, this.group, this._progressiveEls, !0); }), (e.prototype._updateLargeClip = function (t) { var e = t.get("clip", !0) && PS(t.coordinateSystem, !1, t), n = this.group; e ? n.setClipPath(e) : n.removeClipPath(); }), (e.prototype._enableRealtimeSort = function (t, e, n) { var i = this; if (e.count()) { var r = t.baseAxis; if (this._isFirstFrame) this._dispatchInitSort(e, t, n), (this._isFirstFrame = !1); else { var o = function (t) { var n = e.getItemGraphicEl(t), i = n && n.shape; return ( (i && Math.abs( r.isHorizontal() ? i.height : i.width )) || 0 ); }; (this._onRendered = function () { i._updateSortWithinSameData(e, o, r, n); }), n.getZr().on("rendered", this._onRendered); } } }), (e.prototype._dataSort = function (t, e, n) { var i = []; return ( t.each(t.mapDimension(e.dim), function (t, e) { var r = n(e); (r = null == r ? NaN : r), i.push({ dataIndex: e, mappedValue: r, ordinalNumber: t, }); }), i.sort(function (t, e) { return e.mappedValue - t.mappedValue; }), { ordinalNumbers: z(i, function (t) { return t.ordinalNumber; }), } ); }), (e.prototype._isOrderChangedWithinSameData = function ( t, e, n ) { for ( var i = n.scale, r = t.mapDimension(n.dim), o = Number.MAX_VALUE, a = 0, s = i.getOrdinalMeta().categories.length; a < s; ++a ) { var l = t.rawIndexOf(r, i.getRawOrdinalNumber(a)), u = l < 0 ? Number.MIN_VALUE : e(t.indexOfRawIndex(l)); if (u > o) return !0; o = u; } return !1; }), (e.prototype._isOrderDifferentInView = function (t, e) { for ( var n = e.scale, i = n.getExtent(), r = Math.max(0, i[0]), o = Math.min( i[1], n.getOrdinalMeta().categories.length - 1 ); r <= o; ++r ) if (t.ordinalNumbers[r] !== n.getRawOrdinalNumber(r)) return !0; }), (e.prototype._updateSortWithinSameData = function (t, e, n, i) { if (this._isOrderChangedWithinSameData(t, e, n)) { var r = this._dataSort(t, n, e); this._isOrderDifferentInView(r, n) && (this._removeOnRenderedListener(i), i.dispatchAction({ type: "changeAxisOrder", componentType: n.dim + "Axis", axisId: n.index, sortInfo: r, })); } }), (e.prototype._dispatchInitSort = function (t, e, n) { var i = e.baseAxis, r = this._dataSort(t, i, function (n) { return t.get(t.mapDimension(e.otherAxis.dim), n); }); n.dispatchAction({ type: "changeAxisOrder", componentType: i.dim + "Axis", isInitSort: !0, axisId: i.index, sortInfo: r, }); }), (e.prototype.remove = function (t, e) { this._clear(this._model), this._removeOnRenderedListener(e); }), (e.prototype.dispose = function (t, e) { this._removeOnRenderedListener(e); }), (e.prototype._removeOnRenderedListener = function (t) { this._onRendered && (t.getZr().off("rendered", this._onRendered), (this._onRendered = null)); }), (e.prototype._clear = function (t) { var e = this.group, n = this._data; t && t.isAnimationEnabled() && n && !this._isLargeDraw ? (this._removeBackground(), (this._backgroundEls = []), n.eachItemGraphicEl(function (e) { wh(e, t, rl(e).dataIndex); })) : e.removeAll(), (this._data = null), (this._isFirstFrame = !0); }), (e.prototype._removeBackground = function () { this.group.remove(this._backgroundGroup), (this._backgroundGroup = null); }), (e.type = "bar"), e ); })(Og), oM = { cartesian2d: function (t, e) { var n = e.width < 0 ? -1 : 1, i = e.height < 0 ? -1 : 1; n < 0 && ((e.x += e.width), (e.width = -e.width)), i < 0 && ((e.y += e.height), (e.height = -e.height)); var r = t.x + t.width, o = t.y + t.height, a = nM(e.x, t.x), s = iM(e.x + e.width, r), l = nM(e.y, t.y), u = iM(e.y + e.height, o), h = s < a, c = u < l; return ( (e.x = h && a > r ? s : a), (e.y = c && l > o ? u : l), (e.width = h ? 0 : s - a), (e.height = c ? 0 : u - l), n < 0 && ((e.x += e.width), (e.width = -e.width)), i < 0 && ((e.y += e.height), (e.height = -e.height)), h || c ); }, polar: function (t, e) { var n = e.r0 <= e.r ? 1 : -1; if (n < 0) { var i = e.r; (e.r = e.r0), (e.r0 = i); } var r = iM(e.r, t.r), o = nM(e.r0, t.r0); (e.r = r), (e.r0 = o); var a = r - o < 0; if (n < 0) { i = e.r; (e.r = e.r0), (e.r0 = i); } return a; }, }, aM = { cartesian2d: function (t, e, n, i, r, o, a, s, l) { var u = new Ws({ shape: A({}, i), z2: 1 }); ((u.__dataIndex = n), (u.name = "item"), o) && (u.shape[r ? "height" : "width"] = 0); return u; }, polar: function (t, e, n, i, r, o, a, s, l) { var u = !r && l ? JS : Fu, h = new u({ shape: i, z2: 1 }); h.name = "item"; var c, p, d = dM(r); if ( ((h.calculateTextPosition = ((c = d), (p = ({ isRoundCap: u === JS } || {}).isRoundCap), function (t, e, n) { var i = e.position; if (!i || i instanceof Array) return Dr(t, e, n); var r = c(i), o = null != e.distance ? e.distance : 5, a = this.shape, s = a.cx, l = a.cy, u = a.r, h = a.r0, d = (u + h) / 2, f = a.startAngle, g = a.endAngle, y = (f + g) / 2, v = p ? Math.abs(u - h) / 2 : 0, m = Math.cos, x = Math.sin, _ = s + u * m(f), b = l + u * x(f), w = "left", S = "top"; switch (r) { case "startArc": (_ = s + (h - o) * m(y)), (b = l + (h - o) * x(y)), (w = "center"), (S = "top"); break; case "insideStartArc": (_ = s + (h + o) * m(y)), (b = l + (h + o) * x(y)), (w = "center"), (S = "bottom"); break; case "startAngle": (_ = s + d * m(f) + QS(f, o + v, !1)), (b = l + d * x(f) + tM(f, o + v, !1)), (w = "right"), (S = "middle"); break; case "insideStartAngle": (_ = s + d * m(f) + QS(f, -o + v, !1)), (b = l + d * x(f) + tM(f, -o + v, !1)), (w = "left"), (S = "middle"); break; case "middle": (_ = s + d * m(y)), (b = l + d * x(y)), (w = "center"), (S = "middle"); break; case "endArc": (_ = s + (u + o) * m(y)), (b = l + (u + o) * x(y)), (w = "center"), (S = "bottom"); break; case "insideEndArc": (_ = s + (u - o) * m(y)), (b = l + (u - o) * x(y)), (w = "center"), (S = "top"); break; case "endAngle": (_ = s + d * m(g) + QS(g, o + v, !0)), (b = l + d * x(g) + tM(g, o + v, !0)), (w = "left"), (S = "middle"); break; case "insideEndAngle": (_ = s + d * m(g) + QS(g, -o + v, !0)), (b = l + d * x(g) + tM(g, -o + v, !0)), (w = "right"), (S = "middle"); break; default: return Dr(t, e, n); } return ( ((t = t || {}).x = _), (t.y = b), (t.align = w), (t.verticalAlign = S), t ); })), o) ) { var f = r ? "r" : "endAngle", g = {}; (h.shape[f] = r ? i.r0 : i.startAngle), (g[f] = i[f]), (s ? vh : mh)(h, { shape: g }, o); } return h; }, }; function sM(t, e, n, i, r, o, a, s) { var l, u; o ? ((u = { x: i.x, width: i.width }), (l = { y: i.y, height: i.height })) : ((u = { y: i.y, height: i.height }), (l = { x: i.x, width: i.width })), s || (a ? vh : mh)(n, { shape: l }, e, r, null), (a ? vh : mh)(n, { shape: u }, e ? t.baseAxis.model : null, r); } function lM(t, e) { for (var n = 0; n < e.length; n++) if (!isFinite(t[e[n]])) return !0; return !1; } var uM = ["x", "y", "width", "height"], hM = ["cx", "cy", "r", "startAngle", "endAngle"], cM = { cartesian2d: function (t) { return !lM(t, uM); }, polar: function (t) { return !lM(t, hM); }, }, pM = { cartesian2d: function (t, e, n) { var i = t.getItemLayout(e), r = n ? (function (t, e) { var n = t.get(["itemStyle", "borderColor"]); if (!n || "none" === n) return 0; var i = t.get(["itemStyle", "borderWidth"]) || 0, r = isNaN(e.width) ? Number.MAX_VALUE : Math.abs(e.width), o = isNaN(e.height) ? Number.MAX_VALUE : Math.abs(e.height); return Math.min(i, r, o); })(n, i) : 0, o = i.width > 0 ? 1 : -1, a = i.height > 0 ? 1 : -1; return { x: i.x + (o * r) / 2, y: i.y + (a * r) / 2, width: i.width - o * r, height: i.height - a * r, }; }, polar: function (t, e, n) { var i = t.getItemLayout(e); return { cx: i.cx, cy: i.cy, r0: i.r0, r: i.r, startAngle: i.startAngle, endAngle: i.endAngle, clockwise: i.clockwise, }; }, }; function dM(t) { return (function (t) { var e = t ? "Arc" : "Angle"; return function (t) { switch (t) { case "start": case "insideStart": case "end": case "insideEnd": return t + e; default: return t; } }; })(t); } function fM(t, e, n, i, r, o, a, s) { var l = e.getItemVisual(n, "style"); if (s) { if (!o.get("roundCap")) { var u = t.shape; A(u, eM(i.getModel("itemStyle"), u, !0)), t.setShape(u); } } else { var h = i.get(["itemStyle", "borderRadius"]) || 0; t.setShape("r", h); } t.useStyle(l); var c = i.getShallow("cursor"); c && t.attr("cursor", c); var p = s ? a ? r.r >= r.r0 ? "endArc" : "startArc" : r.endAngle >= r.startAngle ? "endAngle" : "startAngle" : a ? r.height >= 0 ? "bottom" : "top" : r.width >= 0 ? "right" : "left", d = rc(i); ic(t, d, { labelFetcher: o, labelDataIndex: n, defaultText: pS(o.getData(), n), inheritColor: l.fill, defaultOpacity: l.opacity, defaultOutsidePosition: p, }); var f = t.getTextContent(); if (s && f) { var g = i.get(["label", "position"]); (t.textConfig.inside = "middle" === g || null), (function (t, e, n, i) { if (j(i)) t.setTextConfig({ rotation: i }); else if (Y(e)) t.setTextConfig({ rotation: 0 }); else { var r, o = t.shape, a = o.clockwise ? o.startAngle : o.endAngle, s = o.clockwise ? o.endAngle : o.startAngle, l = (a + s) / 2, u = n(e); switch (u) { case "startArc": case "insideStartArc": case "middle": case "insideEndArc": case "endArc": r = l; break; case "startAngle": case "insideStartAngle": r = a; break; case "endAngle": case "insideEndAngle": r = s; break; default: return void t.setTextConfig({ rotation: 0 }); } var h = 1.5 * Math.PI - r; "middle" === u && h > Math.PI / 2 && h < 1.5 * Math.PI && (h -= Math.PI), t.setTextConfig({ rotation: h }); } })( t, "outside" === g ? p : g, dM(a), i.get(["label", "rotate"]) ); } dc(f, d, o.getRawValue(n), function (t) { return dS(e, t); }); var y = i.getModel(["emphasis"]); Zl(t, y.get("focus"), y.get("blurScope"), y.get("disabled")), $l(t, i), (function (t) { return ( null != t.startAngle && null != t.endAngle && t.startAngle === t.endAngle ); })(r) && ((t.style.fill = "none"), (t.style.stroke = "none"), E(t.states, function (t) { t.style && (t.style.fill = t.style.stroke = "none"); })); } var gM = function () {}, yM = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "largeBar"), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new gM(); }), (e.prototype.buildPath = function (t, e) { for ( var n = e.points, i = this.baseDimIdx, r = 1 - this.baseDimIdx, o = [], a = [], s = this.barWidth, l = 0; l < n.length; l += 3 ) (a[i] = s), (a[r] = n[l + 2]), (o[i] = n[l + i]), (o[r] = n[l + r]), t.rect(o[0], o[1], a[0], a[1]); }), e ); })(ks); function vM(t, e, n, i) { var r = t.getData(), o = r.getLayout("valueAxisHorizontal") ? 1 : 0, a = r.getLayout("largeDataIndices"), s = r.getLayout("size"), l = t.getModel("backgroundStyle"), u = r.getLayout("largeBackgroundPoints"); if (u) { var h = new yM({ shape: { points: u }, incremental: !!i, silent: !0, z2: 0, }); (h.baseDimIdx = o), (h.largeDataIndices = a), (h.barWidth = s), h.useStyle(l.getItemStyle()), e.add(h), n && n.push(h); } var c = new yM({ shape: { points: r.getLayout("largePoints") }, incremental: !!i, ignoreCoarsePointer: !0, z2: 1, }); (c.baseDimIdx = o), (c.largeDataIndices = a), (c.barWidth = s), e.add(c), c.useStyle(r.getVisual("style")), (c.style.stroke = null), (rl(c).seriesIndex = t.seriesIndex), t.get("silent") || (c.on("mousedown", mM), c.on("mousemove", mM)), n && n.push(c); } var mM = Wg( function (t) { var e = (function (t, e, n) { for ( var i = t.baseDimIdx, r = 1 - i, o = t.shape.points, a = t.largeDataIndices, s = [], l = [], u = t.barWidth, h = 0, c = o.length / 3; h < c; h++ ) { var p = 3 * h; if ( ((l[i] = u), (l[r] = o[p + 2]), (s[i] = o[p + i]), (s[r] = o[p + r]), l[r] < 0 && ((s[r] += l[r]), (l[r] = -l[r])), e >= s[0] && e <= s[0] + l[0] && n >= s[1] && n <= s[1] + l[1]) ) return a[h]; } return -1; })(this, t.offsetX, t.offsetY); rl(this).dataIndex = e >= 0 ? e : null; }, 30, !1 ); function xM(t, e, n) { if (OS(n, "cartesian2d")) { var i = e, r = n.getArea(); return { x: t ? i.x : r.x, y: t ? r.y : i.y, width: t ? i.width : r.width, height: t ? r.height : i.height, }; } var o = e; return { cx: (r = n.getArea()).cx, cy: r.cy, r0: t ? r.r0 : o.r0, r: t ? r.r : o.r, startAngle: t ? o.startAngle : 0, endAngle: t ? o.endAngle : 2 * Math.PI, }; } var _M = 2 * Math.PI, bM = Math.PI / 180; function wM(t, e) { return kp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight(), }); } function SM(t, e) { var n = wM(t, e), i = t.get("center"), r = t.get("radius"); Y(r) || (r = [0, r]); var o, a, s = $r(n.width, e.getWidth()), l = $r(n.height, e.getHeight()), u = Math.min(s, l), h = $r(r[0], u / 2), c = $r(r[1], u / 2), p = t.coordinateSystem; if (p) { var d = p.dataToPoint(i); (o = d[0] || 0), (a = d[1] || 0); } else Y(i) || (i = [i, i]), (o = $r(i[0], s) + n.x), (a = $r(i[1], l) + n.y); return { cx: o, cy: a, r0: h, r: c }; } function MM(t, e, n) { e.eachSeriesByType(t, function (t) { var e = t.getData(), i = e.mapDimension("value"), r = wM(t, n), o = SM(t, n), a = o.cx, s = o.cy, l = o.r, u = o.r0, h = -t.get("startAngle") * bM, c = t.get("endAngle"), p = t.get("padAngle") * bM; c = "auto" === c ? h - _M : -c * bM; var d = t.get("minAngle") * bM + p, f = 0; e.each(i, function (t) { !isNaN(t) && f++; }); var g = e.getSum(i), y = (Math.PI / (g || f)) * 2, v = t.get("clockwise"), m = t.get("roseType"), x = t.get("stillShowZeroSum"), _ = e.getDataExtent(i); _[0] = 0; var b = v ? 1 : -1, w = [h, c], S = (b * p) / 2; us(w, !v), (h = w[0]), (c = w[1]); var M = IM(t); (M.startAngle = h), (M.endAngle = c), (M.clockwise = v); var I = Math.abs(c - h), T = I, C = 0, D = h; if ( (e.setLayout({ viewRect: r, r: l }), e.each(i, function (t, n) { var i; if (isNaN(t)) e.setItemLayout(n, { angle: NaN, startAngle: NaN, endAngle: NaN, clockwise: v, cx: a, cy: s, r0: u, r: m ? NaN : l, }); else { (i = "area" !== m ? (0 === g && x ? y : t * y) : I / f) < d ? ((i = d), (T -= d)) : (C += t); var r = D + b * i, o = 0, h = 0; p > i ? (h = o = D + (b * i) / 2) : ((o = D + S), (h = r - S)), e.setItemLayout(n, { angle: i, startAngle: o, endAngle: h, clockwise: v, cx: a, cy: s, r0: u, r: m ? Kr(t, _, [u, l]) : l, }), (D = r); } }), T < _M && f) ) if (T <= 0.001) { var A = I / f; e.each(i, function (t, n) { if (!isNaN(t)) { var i = e.getItemLayout(n); i.angle = A; var r = 0, o = 0; A < p ? (o = r = h + b * (n + 0.5) * A) : ((r = h + b * n * A + S), (o = h + b * (n + 1) * A - S)), (i.startAngle = r), (i.endAngle = o); } }); } else (y = T / C), (D = h), e.each(i, function (t, n) { if (!isNaN(t)) { var i = e.getItemLayout(n), r = i.angle === d ? d : t * y, o = 0, a = 0; r < p ? (a = o = D + (b * r) / 2) : ((o = D + S), (a = D + b * r - S)), (i.startAngle = o), (i.endAngle = a), (D += b * r); } }); }); } var IM = Vo(); function TM(t) { return { seriesType: t, reset: function (t, e) { var n = e.findComponents({ mainType: "legend" }); if (n && n.length) { var i = t.getData(); i.filterSelf(function (t) { for (var e = i.getName(t), r = 0; r < n.length; r++) if (!n[r].isSelected(e)) return !1; return !0; }); } }, }; } var CM = Math.PI / 180; function DM(t, e, n, i, r, o, a, s, l, u) { if (!(t.length < 2)) { for (var h = t.length, c = 0; c < h; c++) if ( "outer" === t[c].position && "labelLine" === t[c].labelAlignTo ) { var p = t[c].label.x - u; (t[c].linePoints[1][0] += p), (t[c].label.x = u); } Rb(t, l, l + a) && (function (t) { for ( var o = { list: [], maxY: 0 }, a = { list: [], maxY: 0 }, s = 0; s < t.length; s++ ) if ("none" === t[s].labelAlignTo) { var l = t[s], u = l.label.y > n ? a : o, h = Math.abs(l.label.y - n); if (h >= u.maxY) { var c = l.label.x - e - l.len2 * r, p = i + l.len, f = Math.abs(c) < p ? Math.sqrt( (h * h) / (1 - (c * c) / p / p) ) : p; (u.rB = f), (u.maxY = h); } u.list.push(l); } d(o), d(a); })(t); } function d(t) { for (var o = t.rB, a = o * o, s = 0; s < t.list.length; s++) { var l = t.list[s], u = Math.abs(l.label.y - n), h = i + l.len, c = h * h, p = Math.sqrt(Math.abs((1 - (u * u) / a) * c)), d = e + (p + l.len2) * r, f = d - l.label.x; AM(l, l.targetTextWidth - f * r, !0), (l.label.x = d); } } } function AM(t, e, n) { if ((void 0 === n && (n = !1), null == t.labelStyleWidth)) { var i = t.label, r = i.style, o = t.rect, a = r.backgroundColor, s = r.padding, l = s ? s[1] + s[3] : 0, u = r.overflow, h = o.width + (a ? 0 : l); if (e < h || n) { var c = o.height; if (u && u.match("break")) { i.setStyle("backgroundColor", null), i.setStyle("width", e - l); var p = i.getBoundingRect(); i.setStyle("width", Math.ceil(p.width)), i.setStyle("backgroundColor", a); } else { var d = e - l, f = e < h ? d : n ? d > t.unconstrainedWidth ? null : d : null; i.setStyle("width", f); } var g = i.getBoundingRect(); o.width = g.width; var y = (i.style.margin || 0) + 2.1; (o.height = g.height + y), (o.y -= (o.height - c) / 2); } } } function kM(t) { return "center" === t.position; } function LM(t) { var e, n, i = t.getData(), r = [], o = !1, a = (t.get("minShowLabelAngle") || 0) * CM, s = i.getLayout("viewRect"), l = i.getLayout("r"), u = s.width, h = s.x, c = s.y, p = s.height; function d(t) { t.ignore = !0; } i.each(function (t) { var s = i.getItemGraphicEl(t), c = s.shape, p = s.getTextContent(), f = s.getTextGuideLine(), g = i.getItemModel(t), y = g.getModel("label"), v = y.get("position") || g.get(["emphasis", "label", "position"]), m = y.get("distanceToLabelLine"), x = y.get("alignTo"), _ = $r(y.get("edgeDistance"), u), b = y.get("bleedMargin"), w = g.getModel("labelLine"), S = w.get("length"); S = $r(S, u); var M = w.get("length2"); if (((M = $r(M, u)), Math.abs(c.endAngle - c.startAngle) < a)) return ( E(p.states, d), (p.ignore = !0), void (f && (E(f.states, d), (f.ignore = !0))) ); if ( (function (t) { if (!t.ignore) return !0; for (var e in t.states) if (!1 === t.states[e].ignore) return !0; return !1; })(p) ) { var I, T, C, D, A = (c.startAngle + c.endAngle) / 2, k = Math.cos(A), L = Math.sin(A); (e = c.cx), (n = c.cy); var P = "inside" === v || "inner" === v; if ("center" === v) (I = c.cx), (T = c.cy), (D = "center"); else { var O = (P ? ((c.r + c.r0) / 2) * k : c.r * k) + e, R = (P ? ((c.r + c.r0) / 2) * L : c.r * L) + n; if (((I = O + 3 * k), (T = R + 3 * L), !P)) { var N = O + k * (S + l - c.r), z = R + L * (S + l - c.r), V = N + (k < 0 ? -1 : 1) * M; (I = "edge" === x ? k < 0 ? h + _ : h + u - _ : V + (k < 0 ? -m : m)), (T = z), (C = [ [O, R], [N, z], [V, z], ]); } D = P ? "center" : "edge" === x ? k > 0 ? "right" : "left" : k > 0 ? "left" : "right"; } var B = Math.PI, F = 0, G = y.get("rotate"); if (j(G)) F = G * (B / 180); else if ("center" === v) F = 0; else if ("radial" === G || !0 === G) { F = k < 0 ? -A + B : -A; } else if ( "tangential" === G && "outside" !== v && "outer" !== v ) { var W = Math.atan2(k, L); W < 0 && (W = 2 * B + W), L > 0 && (W = B + W), (F = W - B); } if ( ((o = !!F), (p.x = I), (p.y = T), (p.rotation = F), p.setStyle({ verticalAlign: "middle" }), P) ) { p.setStyle({ align: D }); var H = p.states.select; H && ((H.x += p.x), (H.y += p.y)); } else { var Y = p.getBoundingRect().clone(); Y.applyTransform(p.getComputedTransform()); var X = (p.style.margin || 0) + 2.1; (Y.y -= X / 2), (Y.height += X), r.push({ label: p, labelLine: f, position: v, len: S, len2: M, minTurnAngle: w.get("minTurnAngle"), maxSurfaceAngle: w.get("maxSurfaceAngle"), surfaceNormal: new De(k, L), linePoints: C, textAlign: D, labelDistance: m, labelAlignTo: x, edgeDistance: _, bleedMargin: b, rect: Y, unconstrainedWidth: Y.width, labelStyleWidth: p.style.width, }); } s.setTextConfig({ inside: P }); } }), !o && t.get("avoidLabelOverlap") && (function (t, e, n, i, r, o, a, s) { for ( var l = [], u = [], h = Number.MAX_VALUE, c = -Number.MAX_VALUE, p = 0; p < t.length; p++ ) { var d = t[p].label; kM(t[p]) || (d.x < e ? ((h = Math.min(h, d.x)), l.push(t[p])) : ((c = Math.max(c, d.x)), u.push(t[p]))); } for (p = 0; p < t.length; p++) if (!kM((y = t[p])) && y.linePoints) { if (null != y.labelStyleWidth) continue; d = y.label; var f = y.linePoints, g = void 0; (g = "edge" === y.labelAlignTo ? d.x < e ? f[2][0] - y.labelDistance - a - y.edgeDistance : a + r - y.edgeDistance - f[2][0] - y.labelDistance : "labelLine" === y.labelAlignTo ? d.x < e ? h - a - y.bleedMargin : a + r - c - y.bleedMargin : d.x < e ? d.x - a - y.bleedMargin : a + r - d.x - y.bleedMargin), (y.targetTextWidth = g), AM(y, g); } for ( DM(u, e, n, i, 1, 0, o, 0, s, c), DM(l, e, n, i, -1, 0, o, 0, s, h), p = 0; p < t.length; p++ ) { var y; if (!kM((y = t[p])) && y.linePoints) { (d = y.label), (f = y.linePoints); var v = "edge" === y.labelAlignTo, m = d.style.padding, x = m ? m[1] + m[3] : 0, _ = d.style.backgroundColor ? 0 : x, b = y.rect.width + _, w = f[1][0] - f[2][0]; v ? d.x < e ? (f[2][0] = a + y.edgeDistance + b + y.labelDistance) : (f[2][0] = a + r - y.edgeDistance - b - y.labelDistance) : (d.x < e ? (f[2][0] = d.x + y.labelDistance) : (f[2][0] = d.x - y.labelDistance), (f[1][0] = f[2][0] + w)), (f[1][1] = f[2][1] = d.y); } } })(r, e, n, l, u, p, h, c); for (var f = 0; f < r.length; f++) { var g = r[f], y = g.label, v = g.labelLine, m = isNaN(y.x) || isNaN(y.y); if (y) { y.setStyle({ align: g.textAlign }), m && (E(y.states, d), (y.ignore = !0)); var x = y.states.select; x && ((x.x += y.x), (x.y += y.y)); } if (v) { var _ = g.linePoints; m || !_ ? (E(v.states, d), (v.ignore = !0)) : (Tb(_, g.minTurnAngle), Cb(_, g.surfaceNormal, g.maxSurfaceAngle), v.setShape({ points: _ }), (y.__hostTarget.textGuideLineConfig = { anchor: new De(_[0][0], _[0][1]), })); } } } var PM = (function (t) { function e(e, n, i) { var r = t.call(this) || this; r.z2 = 2; var o = new Xs(); return r.setTextContent(o), r.updateData(e, n, i, !0), r; } return ( n(e, t), (e.prototype.updateData = function (t, e, n, i) { var r = this, o = t.hostModel, a = t.getItemModel(e), s = a.getModel("emphasis"), l = t.getItemLayout(e), u = A(eM(a.getModel("itemStyle"), l, !0), l); if (isNaN(u.startAngle)) r.setShape(u); else { if (i) { r.setShape(u); var h = o.getShallow("animationType"); o.ecModel.ssr ? (mh(r, { scaleX: 0, scaleY: 0 }, o, { dataIndex: e, isFrom: !0, }), (r.originX = u.cx), (r.originY = u.cy)) : "scale" === h ? ((r.shape.r = l.r0), mh(r, { shape: { r: l.r } }, o, e)) : null != n ? (r.setShape({ startAngle: n, endAngle: n }), mh( r, { shape: { startAngle: l.startAngle, endAngle: l.endAngle, }, }, o, e )) : ((r.shape.endAngle = l.startAngle), vh( r, { shape: { endAngle: l.endAngle } }, o, e )); } else Sh(r), vh(r, { shape: u }, o, e); r.useStyle(t.getItemVisual(e, "style")), $l(r, a); var c = (l.startAngle + l.endAngle) / 2, p = o.get("selectedOffset"), d = Math.cos(c) * p, f = Math.sin(c) * p, g = a.getShallow("cursor"); g && r.attr("cursor", g), this._updateLabel(o, t, e), (r.ensureState("emphasis").shape = A( { r: l.r + ((s.get("scale") && s.get("scaleSize")) || 0), }, eM(s.getModel("itemStyle"), l) )), A(r.ensureState("select"), { x: d, y: f, shape: eM( a.getModel(["select", "itemStyle"]), l ), }), A(r.ensureState("blur"), { shape: eM(a.getModel(["blur", "itemStyle"]), l), }); var y = r.getTextGuideLine(), v = r.getTextContent(); y && A(y.ensureState("select"), { x: d, y: f }), A(v.ensureState("select"), { x: d, y: f }), Zl( this, s.get("focus"), s.get("blurScope"), s.get("disabled") ); } }), (e.prototype._updateLabel = function (t, e, n) { var i = this, r = e.getItemModel(n), o = r.getModel("labelLine"), a = e.getItemVisual(n, "style"), s = a && a.fill, l = a && a.opacity; ic(i, rc(r), { labelFetcher: e.hostModel, labelDataIndex: n, inheritColor: s, defaultOpacity: l, defaultText: t.getFormattedLabel(n, "normal") || e.getName(n), }); var u = i.getTextContent(); i.setTextConfig({ position: null, rotation: null }), u.attr({ z2: 10 }); var h = t.get(["label", "position"]); if ("outside" !== h && "outer" !== h) i.removeTextGuideLine(); else { var c = this.getTextGuideLine(); c || ((c = new Zu()), this.setTextGuideLine(c)), kb(this, Lb(r), { stroke: s, opacity: ot( o.get(["lineStyle", "opacity"]), l, 1 ), }); } }), e ); })(Fu), OM = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.ignoreLabelLineUpdate = !0), e; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { var r, o = t.getData(), a = this._data, s = this.group; if (!a && o.count() > 0) { for ( var l = o.getItemLayout(0), u = 1; isNaN(l && l.startAngle) && u < o.count(); ++u ) l = o.getItemLayout(u); l && (r = l.startAngle); } if ( (this._emptyCircleSector && s.remove(this._emptyCircleSector), 0 === o.count() && t.get("showEmptyCircle")) ) { var h = IM(t), c = new Fu({ shape: A(SM(t, n), h) }); c.useStyle( t.getModel("emptyCircleStyle").getItemStyle() ), (this._emptyCircleSector = c), s.add(c); } o .diff(a) .add(function (t) { var e = new PM(o, t, r); o.setItemGraphicEl(t, e), s.add(e); }) .update(function (t, e) { var n = a.getItemGraphicEl(e); n.updateData(o, t, r), n.off("click"), s.add(n), o.setItemGraphicEl(t, n); }) .remove(function (e) { wh(a.getItemGraphicEl(e), t, e); }) .execute(), LM(t), "expansion" !== t.get("animationTypeUpdate") && (this._data = o); }), (e.prototype.dispose = function () {}), (e.prototype.containPoint = function (t, e) { var n = e.getData().getItemLayout(0); if (n) { var i = t[0] - n.cx, r = t[1] - n.cy, o = Math.sqrt(i * i + r * r); return o <= n.r && o >= n.r0; } }), (e.type = "pie"), e ); })(Og); function RM(t, e, n) { e = (Y(e) && { coordDimensions: e }) || A({ encodeDefine: t.getEncode() }, e); var i = t.getSource(), r = px(i, e).dimensions, o = new cx(r, t); return o.initData(i, n), o; } var NM = (function () { function t(t, e) { (this._getDataWithEncodedVisual = t), (this._getRawData = e); } return ( (t.prototype.getAllNames = function () { var t = this._getRawData(); return t.mapArray(t.getName); }), (t.prototype.containName = function (t) { return this._getRawData().indexOfName(t) >= 0; }), (t.prototype.indexOfName = function (t) { return this._getDataWithEncodedVisual().indexOfName(t); }), (t.prototype.getItemVisual = function (t, e) { return this._getDataWithEncodedVisual().getItemVisual(t, e); }), t ); })(), EM = Vo(), zM = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), (this.legendVisualProvider = new NM( W(this.getData, this), W(this.getRawData, this) )), this._defaultLabelLine(e); }), (e.prototype.mergeOption = function () { t.prototype.mergeOption.apply(this, arguments); }), (e.prototype.getInitialData = function () { return RM(this, { coordDimensions: ["value"], encodeDefaulter: H(ed, this), }); }), (e.prototype.getDataParams = function (e) { var n = this.getData(), i = EM(n), r = i.seats; if (!r) { var o = []; n.each(n.mapDimension("value"), function (t) { o.push(t); }), (r = i.seats = io(o, n.hostModel.get("percentPrecision"))); } var a = t.prototype.getDataParams.call(this, e); return (a.percent = r[e] || 0), a.$vars.push("percent"), a; }), (e.prototype._defaultLabelLine = function (t) { Co(t, "labelLine", ["show"]); var e = t.labelLine, n = t.emphasis.labelLine; (e.show = e.show && t.label.show), (n.show = n.show && t.emphasis.label.show); }), (e.type = "series.pie"), (e.defaultOption = { z: 2, legendHoverLink: !0, colorBy: "data", center: ["50%", "50%"], radius: [0, "75%"], clockwise: !0, startAngle: 90, endAngle: "auto", padAngle: 0, minAngle: 0, minShowLabelAngle: 0, selectedOffset: 10, percentPrecision: 2, stillShowZeroSum: !0, left: 0, top: 0, right: 0, bottom: 0, width: null, height: null, label: { rotate: 0, show: !0, overflow: "truncate", position: "outer", alignTo: "none", edgeDistance: "25%", bleedMargin: 10, distanceToLabelLine: 5, }, labelLine: { show: !0, length: 15, length2: 15, smooth: !1, minTurnAngle: 90, maxSurfaceAngle: 90, lineStyle: { width: 1, type: "solid" }, }, itemStyle: { borderWidth: 1, borderJoin: "round" }, showEmptyCircle: !0, emptyCircleStyle: { color: "lightgray", opacity: 1 }, labelLayout: { hideOverlap: !0 }, emphasis: { scale: !0, scaleSize: 5 }, avoidLabelOverlap: !0, animationType: "expansion", animationDuration: 1e3, animationTypeUpdate: "transition", animationEasingUpdate: "cubicInOut", animationDurationUpdate: 500, animationEasing: "cubicInOut", }), e ); })(bg); var VM = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.hasSymbolVisual = !0), n; } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { return _x(null, this, { useEncodeDefaulter: !0 }); }), (e.prototype.getProgressive = function () { var t = this.option.progressive; return null == t ? this.option.large ? 5e3 : this.get("progressive") : t; }), (e.prototype.getProgressiveThreshold = function () { var t = this.option.progressiveThreshold; return null == t ? this.option.large ? 1e4 : this.get("progressiveThreshold") : t; }), (e.prototype.brushSelector = function (t, e, n) { return n.point(e.getItemLayout(t)); }), (e.prototype.getZLevelKey = function () { return this.getData().count() > this.getProgressiveThreshold() ? this.id : ""; }), (e.type = "series.scatter"), (e.dependencies = [ "grid", "polar", "geo", "singleAxis", "calendar", ]), (e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, legendHoverLink: !0, symbolSize: 10, large: !1, largeThreshold: 2e3, itemStyle: { opacity: 0.8 }, emphasis: { scale: !0 }, clip: !0, select: { itemStyle: { borderColor: "#212121" } }, universalTransition: { divideShape: "clone" }, }), e ); })(bg), BM = function () {}, FM = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n._off = 0), (n.hoverDataIdx = -1), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new BM(); }), (e.prototype.reset = function () { (this.notClear = !1), (this._off = 0); }), (e.prototype.buildPath = function (t, e) { var n, i = e.points, r = e.size, o = this.symbolProxy, a = o.shape, s = t.getContext ? t.getContext() : t, l = s && r[0] < 4, u = this.softClipShape; if (l) this._ctx = s; else { for (this._ctx = null, n = this._off; n < i.length; ) { var h = i[n++], c = i[n++]; isNaN(h) || isNaN(c) || (u && !u.contain(h, c)) || ((a.x = h - r[0] / 2), (a.y = c - r[1] / 2), (a.width = r[0]), (a.height = r[1]), o.buildPath(t, a, !0)); } this.incremental && ((this._off = n), (this.notClear = !0)); } }), (e.prototype.afterBrush = function () { var t, e = this.shape, n = e.points, i = e.size, r = this._ctx, o = this.softClipShape; if (r) { for (t = this._off; t < n.length; ) { var a = n[t++], s = n[t++]; isNaN(a) || isNaN(s) || (o && !o.contain(a, s)) || r.fillRect( a - i[0] / 2, s - i[1] / 2, i[0], i[1] ); } this.incremental && ((this._off = t), (this.notClear = !0)); } }), (e.prototype.findDataIndex = function (t, e) { for ( var n = this.shape, i = n.points, r = n.size, o = Math.max(r[0], 4), a = Math.max(r[1], 4), s = i.length / 2 - 1; s >= 0; s-- ) { var l = 2 * s, u = i[l] - o / 2, h = i[l + 1] - a / 2; if (t >= u && e >= h && t <= u + o && e <= h + a) return s; } return -1; }), (e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e), i = this.getBoundingRect(); return ( (t = n[0]), (e = n[1]), i.contain(t, e) ? (this.hoverDataIdx = this.findDataIndex(t, e)) >= 0 : ((this.hoverDataIdx = -1), !1) ); }), (e.prototype.getBoundingRect = function () { var t = this._rect; if (!t) { for ( var e = this.shape, n = e.points, i = e.size, r = i[0], o = i[1], a = 1 / 0, s = 1 / 0, l = -1 / 0, u = -1 / 0, h = 0; h < n.length; ) { var c = n[h++], p = n[h++]; (a = Math.min(c, a)), (l = Math.max(c, l)), (s = Math.min(p, s)), (u = Math.max(p, u)); } t = this._rect = new ze( a - r / 2, s - o / 2, l - a + r, u - s + o ); } return t; }), e ); })(ks), GM = (function () { function t() { this.group = new Br(); } return ( (t.prototype.updateData = function (t, e) { this._clear(); var n = this._create(); n.setShape({ points: t.getLayout("points") }), this._setCommon(n, t, e); }), (t.prototype.updateLayout = function (t) { var e = t.getLayout("points"); this.group.eachChild(function (t) { if (null != t.startIndex) { var n = 2 * (t.endIndex - t.startIndex), i = 4 * t.startIndex * 2; e = new Float32Array(e.buffer, i, n); } t.setShape("points", e), t.reset(); }); }), (t.prototype.incrementalPrepareUpdate = function (t) { this._clear(); }), (t.prototype.incrementalUpdate = function (t, e, n) { var i = this._newAdded[0], r = e.getLayout("points"), o = i && i.shape.points; if (o && o.length < 2e4) { var a = o.length, s = new Float32Array(a + r.length); s.set(o), s.set(r, a), (i.endIndex = t.end), i.setShape({ points: s }); } else { this._newAdded = []; var l = this._create(); (l.startIndex = t.start), (l.endIndex = t.end), (l.incremental = !0), l.setShape({ points: r }), this._setCommon(l, e, n); } }), (t.prototype.eachRendered = function (t) { this._newAdded[0] && t(this._newAdded[0]); }), (t.prototype._create = function () { var t = new FM({ cursor: "default" }); return ( (t.ignoreCoarsePointer = !0), this.group.add(t), this._newAdded.push(t), t ); }), (t.prototype._setCommon = function (t, e, n) { var i = e.hostModel; n = n || {}; var r = e.getVisual("symbolSize"); t.setShape("size", r instanceof Array ? r : [r, r]), (t.softClipShape = n.clipShape || null), (t.symbolProxy = Xy(e.getVisual("symbol"), 0, 0, 0, 0)), (t.setColor = t.symbolProxy.setColor); var o = t.shape.size[0] < 4; t.useStyle( i .getModel("itemStyle") .getItemStyle( o ? ["color", "shadowBlur", "shadowColor"] : ["color"] ) ); var a = e.getVisual("style"), s = a && a.fill; s && t.setColor(s); var l = rl(t); (l.seriesIndex = i.seriesIndex), t.on("mousemove", function (e) { l.dataIndex = null; var n = t.hoverDataIdx; n >= 0 && (l.dataIndex = n + (t.startIndex || 0)); }); }), (t.prototype.remove = function () { this._clear(); }), (t.prototype._clear = function () { (this._newAdded = []), this.group.removeAll(); }), t ); })(), WM = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = t.getData(); this._updateSymbolDraw(i, t).updateData(i, { clipShape: this._getClipShape(t), }), (this._finished = !0); }), (e.prototype.incrementalPrepareRender = function (t, e, n) { var i = t.getData(); this._updateSymbolDraw(i, t).incrementalPrepareUpdate(i), (this._finished = !1); }), (e.prototype.incrementalRender = function (t, e, n) { this._symbolDraw.incrementalUpdate(t, e.getData(), { clipShape: this._getClipShape(e), }), (this._finished = t.end === e.getData().count()); }), (e.prototype.updateTransform = function (t, e, n) { var i = t.getData(); if ( (this.group.dirty(), !this._finished || i.count() > 1e4) ) return { update: !0 }; var r = XS("").reset(t, e, n); r.progress && r.progress( { start: 0, end: i.count(), count: i.count() }, i ), this._symbolDraw.updateLayout(i); }), (e.prototype.eachRendered = function (t) { this._symbolDraw && this._symbolDraw.eachRendered(t); }), (e.prototype._getClipShape = function (t) { if (t.get("clip", !0)) { var e = t.coordinateSystem; return e && e.getArea && e.getArea(0.1); } }), (e.prototype._updateSymbolDraw = function (t, e) { var n = this._symbolDraw, i = e.pipelineContext.large; return ( (n && i === this._isLargeDraw) || (n && n.remove(), (n = this._symbolDraw = i ? new GM() : new xS()), (this._isLargeDraw = i), this.group.removeAll()), this.group.add(n.group), n ); }), (e.prototype.remove = function (t, e) { this._symbolDraw && this._symbolDraw.remove(!0), (this._symbolDraw = null); }), (e.prototype.dispose = function () {}), (e.type = "scatter"), e ); })(Og), HM = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.type = "grid"), (e.dependencies = ["xAxis", "yAxis"]), (e.layoutMode = "box"), (e.defaultOption = { show: !1, z: 0, left: "10%", top: 60, right: "10%", bottom: 70, containLabel: !1, backgroundColor: "rgba(0,0,0,0)", borderWidth: 1, borderColor: "#ccc", }), e ); })(zp), YM = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.getCoordSysModel = function () { return this.getReferringComponents("grid", Wo).models[0]; }), (e.type = "cartesian2dAxis"), e ); })(zp); R(YM, D_); var XM = { show: !0, z: 0, inverse: !1, name: "", nameLocation: "end", nameRotate: null, nameTruncate: { maxWidth: null, ellipsis: "...", placeholder: "." }, nameTextStyle: {}, nameGap: 15, silent: !1, triggerEvent: !1, tooltip: { show: !1 }, axisPointer: {}, axisLine: { show: !0, onZero: !0, onZeroAxisIndex: null, lineStyle: { color: "#6E7079", width: 1, type: "solid" }, symbol: ["none", "none"], symbolSize: [10, 15], }, axisTick: { show: !0, inside: !1, length: 5, lineStyle: { width: 1 }, }, axisLabel: { show: !0, inside: !1, rotate: 0, showMinLabel: null, showMaxLabel: null, margin: 8, fontSize: 12, }, splitLine: { show: !0, showMinLine: !0, showMaxLine: !0, lineStyle: { color: ["#E0E6F1"], width: 1, type: "solid" }, }, splitArea: { show: !1, areaStyle: { color: ["rgba(250,250,250,0.2)", "rgba(210,219,238,0.2)"], }, }, }, UM = C( { boundaryGap: !0, deduplication: null, splitLine: { show: !1 }, axisTick: { alignWithLabel: !1, interval: "auto" }, axisLabel: { interval: "auto" }, }, XM ), ZM = C( { boundaryGap: [0, 0], axisLine: { show: "auto" }, axisTick: { show: "auto" }, splitNumber: 5, minorTick: { show: !1, splitNumber: 5, length: 3, lineStyle: {}, }, minorSplitLine: { show: !1, lineStyle: { color: "#F4F7FD", width: 1 }, }, }, XM ), jM = { category: UM, value: ZM, time: C( { splitNumber: 6, axisLabel: { showMinLabel: !1, showMaxLabel: !1, rich: { primary: { fontWeight: "bold" } }, }, splitLine: { show: !1 }, }, ZM ), log: k({ logBase: 10 }, ZM), }, qM = { value: 1, category: 1, time: 1, log: 1 }; function KM(t, e, i, r) { E(qM, function (o, a) { var s = C(C({}, jM[a], !0), r, !0), l = (function (t) { function i() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e + "Axis." + a), n; } return ( n(i, t), (i.prototype.mergeDefaultAndTheme = function (t, e) { var n = Pp(this), i = n ? Rp(t) : {}; C(t, e.getTheme().get(a + "Axis")), C(t, this.getDefaultOption()), (t.type = $M(t)), n && Op(t, i, n); }), (i.prototype.optionUpdated = function () { "category" === this.option.type && (this.__ordinalMeta = Mx.createByAxisModel(this)); }), (i.prototype.getCategories = function (t) { var e = this.option; if ("category" === e.type) return t ? e.data : this.__ordinalMeta.categories; }), (i.prototype.getOrdinalMeta = function () { return this.__ordinalMeta; }), (i.type = e + "Axis." + a), (i.defaultOption = s), i ); })(i); t.registerComponentModel(l); }), t.registerSubTypeDefaulter(e + "Axis", $M); } function $M(t) { return t.type || (t.data ? "category" : "value"); } var JM = (function () { function t(t) { (this.type = "cartesian"), (this._dimList = []), (this._axes = {}), (this.name = t || ""); } return ( (t.prototype.getAxis = function (t) { return this._axes[t]; }), (t.prototype.getAxes = function () { return z( this._dimList, function (t) { return this._axes[t]; }, this ); }), (t.prototype.getAxesByScale = function (t) { return ( (t = t.toLowerCase()), B(this.getAxes(), function (e) { return e.scale.type === t; }) ); }), (t.prototype.addAxis = function (t) { var e = t.dim; (this._axes[e] = t), this._dimList.push(e); }), t ); })(), QM = ["x", "y"]; function tI(t) { return "interval" === t.type || "time" === t.type; } var eI = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.type = "cartesian2d"), (e.dimensions = QM), e; } return ( n(e, t), (e.prototype.calcAffineTransform = function () { this._transform = this._invTransform = null; var t = this.getAxis("x").scale, e = this.getAxis("y").scale; if (tI(t) && tI(e)) { var n = t.getExtent(), i = e.getExtent(), r = this.dataToPoint([n[0], i[0]]), o = this.dataToPoint([n[1], i[1]]), a = n[1] - n[0], s = i[1] - i[0]; if (a && s) { var l = (o[0] - r[0]) / a, u = (o[1] - r[1]) / s, h = r[0] - n[0] * l, c = r[1] - i[0] * u, p = (this._transform = [l, 0, 0, u, h, c]); this._invTransform = Ie([], p); } } }), (e.prototype.getBaseAxis = function () { return ( this.getAxesByScale("ordinal")[0] || this.getAxesByScale("time")[0] || this.getAxis("x") ); }), (e.prototype.containPoint = function (t) { var e = this.getAxis("x"), n = this.getAxis("y"); return ( e.contain(e.toLocalCoord(t[0])) && n.contain(n.toLocalCoord(t[1])) ); }), (e.prototype.containData = function (t) { return ( this.getAxis("x").containData(t[0]) && this.getAxis("y").containData(t[1]) ); }), (e.prototype.containZone = function (t, e) { var n = this.dataToPoint(t), i = this.dataToPoint(e), r = this.getArea(), o = new ze(n[0], n[1], i[0] - n[0], i[1] - n[1]); return r.intersect(o); }), (e.prototype.dataToPoint = function (t, e, n) { n = n || []; var i = t[0], r = t[1]; if ( this._transform && null != i && isFinite(i) && null != r && isFinite(r) ) return Wt(n, t, this._transform); var o = this.getAxis("x"), a = this.getAxis("y"); return ( (n[0] = o.toGlobalCoord(o.dataToCoord(i, e))), (n[1] = a.toGlobalCoord(a.dataToCoord(r, e))), n ); }), (e.prototype.clampData = function (t, e) { var n = this.getAxis("x").scale, i = this.getAxis("y").scale, r = n.getExtent(), o = i.getExtent(), a = n.parse(t[0]), s = i.parse(t[1]); return ( ((e = e || [])[0] = Math.min( Math.max(Math.min(r[0], r[1]), a), Math.max(r[0], r[1]) )), (e[1] = Math.min( Math.max(Math.min(o[0], o[1]), s), Math.max(o[0], o[1]) )), e ); }), (e.prototype.pointToData = function (t, e) { var n = []; if (this._invTransform) return Wt(n, t, this._invTransform); var i = this.getAxis("x"), r = this.getAxis("y"); return ( (n[0] = i.coordToData(i.toLocalCoord(t[0]), e)), (n[1] = r.coordToData(r.toLocalCoord(t[1]), e)), n ); }), (e.prototype.getOtherAxis = function (t) { return this.getAxis("x" === t.dim ? "y" : "x"); }), (e.prototype.getArea = function (t) { t = t || 0; var e = this.getAxis("x").getGlobalExtent(), n = this.getAxis("y").getGlobalExtent(), i = Math.min(e[0], e[1]) - t, r = Math.min(n[0], n[1]) - t, o = Math.max(e[0], e[1]) - i + t, a = Math.max(n[0], n[1]) - r + t; return new ze(i, r, o, a); }), e ); })(JM), nI = (function (t) { function e(e, n, i, r, o) { var a = t.call(this, e, n, i) || this; return ( (a.index = 0), (a.type = r || "value"), (a.position = o || "bottom"), a ); } return ( n(e, t), (e.prototype.isHorizontal = function () { var t = this.position; return "top" === t || "bottom" === t; }), (e.prototype.getGlobalExtent = function (t) { var e = this.getExtent(); return ( (e[0] = this.toGlobalCoord(e[0])), (e[1] = this.toGlobalCoord(e[1])), t && e[0] > e[1] && e.reverse(), e ); }), (e.prototype.pointToData = function (t, e) { return this.coordToData( this.toLocalCoord(t["x" === this.dim ? 0 : 1]), e ); }), (e.prototype.setCategorySortInfo = function (t) { if ("category" !== this.type) return !1; (this.model.option.categorySortInfo = t), this.scale.setSortInfo(t); }), e ); })(ab); function iI(t, e, n) { n = n || {}; var i = t.coordinateSystem, r = e.axis, o = {}, a = r.getAxesOnZeroOf()[0], s = r.position, l = a ? "onZero" : s, u = r.dim, h = i.getRect(), c = [h.x, h.x + h.width, h.y, h.y + h.height], p = { left: 0, right: 1, top: 0, bottom: 1, onZero: 2 }, d = e.get("offset") || 0, f = "x" === u ? [c[2] - d, c[3] + d] : [c[0] - d, c[1] + d]; if (a) { var g = a.toGlobalCoord(a.dataToCoord(0)); f[p.onZero] = Math.max(Math.min(g, f[1]), f[0]); } (o.position = ["y" === u ? f[p[l]] : c[0], "x" === u ? f[p[l]] : c[3]]), (o.rotation = (Math.PI / 2) * ("x" === u ? 0 : 1)); (o.labelDirection = o.tickDirection = o.nameDirection = { top: -1, bottom: 1, left: -1, right: 1 }[s]), (o.labelOffset = a ? f[p[s]] - f[p.onZero] : 0), e.get(["axisTick", "inside"]) && (o.tickDirection = -o.tickDirection), it(n.labelInside, e.get(["axisLabel", "inside"])) && (o.labelDirection = -o.labelDirection); var y = e.get(["axisLabel", "rotate"]); return (o.labelRotate = "top" === l ? -y : y), (o.z2 = 1), o; } function rI(t) { return "cartesian2d" === t.get("coordinateSystem"); } function oI(t) { var e = { xAxisModel: null, yAxisModel: null }; return ( E(e, function (n, i) { var r = i.replace(/Model$/, ""), o = t.getReferringComponents(r, Wo).models[0]; e[i] = o; }), e ); } var aI = Math.log; function sI(t, e, n) { var i = Ex.prototype, r = i.getTicks.call(n), o = i.getTicks.call(n, !0), a = r.length - 1, s = i.getInterval.call(n), l = x_(t, e), u = l.extent, h = l.fixMin, c = l.fixMax; if ("log" === t.type) { var p = aI(t.base); u = [aI(u[0]) / p, aI(u[1]) / p]; } t.setExtent(u[0], u[1]), t.calcNiceExtent({ splitNumber: a, fixMin: h, fixMax: c }); var d = i.getExtent.call(t); h && (u[0] = d[0]), c && (u[1] = d[1]); var f = i.getInterval.call(t), g = u[0], y = u[1]; if (h && c) f = (y - g) / a; else if (h) for (y = u[0] + f * a; y < u[1] && isFinite(y) && isFinite(u[1]); ) (f = Dx(f)), (y = u[0] + f * a); else if (c) for (g = u[1] - f * a; g > u[0] && isFinite(g) && isFinite(u[0]); ) (f = Dx(f)), (g = u[1] - f * a); else { t.getTicks().length - 1 > a && (f = Dx(f)); var v = f * a; (g = Jr((y = Math.ceil(u[1] / f) * f) - v)) < 0 && u[0] >= 0 ? ((g = 0), (y = Jr(v))) : y > 0 && u[1] <= 0 && ((y = 0), (g = -Jr(v))); } var m = (r[0].value - o[0].value) / s, x = (r[a].value - o[a].value) / s; i.setExtent.call(t, g + f * m, y + f * x), i.setInterval.call(t, f), (m || x) && i.setNiceExtent.call(t, g + f, y - f); } var lI = (function () { function t(t, e, n) { (this.type = "grid"), (this._coordsMap = {}), (this._coordsList = []), (this._axesMap = {}), (this._axesList = []), (this.axisPointerEnabled = !0), (this.dimensions = QM), this._initCartesian(t, e, n), (this.model = t); } return ( (t.prototype.getRect = function () { return this._rect; }), (t.prototype.update = function (t, e) { var n = this._axesMap; function i(t) { var e, n = G(t), i = n.length; if (i) { for (var r = [], o = i - 1; o >= 0; o--) { var a = t[+n[o]], s = a.model, l = a.scale; Tx(l) && s.get("alignTicks") && null == s.get("interval") ? r.push(a) : (__(l, s), Tx(l) && (e = a)); } r.length && (e || __((e = r.pop()).scale, e.model), E(r, function (t) { sI(t.scale, t.model, e.scale); })); } } this._updateScale(t, this.model), i(n.x), i(n.y); var r = {}; E(n.x, function (t) { hI(n, "y", t, r); }), E(n.y, function (t) { hI(n, "x", t, r); }), this.resize(this.model, e); }), (t.prototype.resize = function (t, e, n) { var i = t.getBoxLayoutParams(), r = !n && t.get("containLabel"), o = kp(i, { width: e.getWidth(), height: e.getHeight() }); this._rect = o; var a = this._axesList; function s() { E(a, function (t) { var e = t.isHorizontal(), n = e ? [0, o.width] : [0, o.height], i = t.inverse ? 1 : 0; t.setExtent(n[i], n[1 - i]), (function (t, e) { var n = t.getExtent(), i = n[0] + n[1]; (t.toGlobalCoord = "x" === t.dim ? function (t) { return t + e; } : function (t) { return i - t + e; }), (t.toLocalCoord = "x" === t.dim ? function (t) { return t - e; } : function (t) { return i - t + e; }); })(t, e ? o.x : o.y); }); } s(), r && (E(a, function (t) { if (!t.model.get(["axisLabel", "inside"])) { var e = (function (t) { var e = t.model, n = t.scale; if ( e.get(["axisLabel", "show"]) && !n.isBlank() ) { var i, r, o = n.getExtent(); r = n instanceof Rx ? n.count() : (i = n.getTicks()).length; var a, s = t.getLabelModel(), l = w_(t), u = 1; r > 40 && (u = Math.ceil(r / 40)); for (var h = 0; h < r; h += u) { var c = l( i ? i[h] : { value: o[0] + h }, h ), p = M_( s.getTextRect(c), s.get("rotate") || 0 ); a ? a.union(p) : (a = p); } return a; } })(t); if (e) { var n = t.isHorizontal() ? "height" : "width", i = t.model.get([ "axisLabel", "margin", ]); (o[n] -= e[n] + i), "top" === t.position ? (o.y += e.height + i) : "left" === t.position && (o.x += e.width + i); } } }), s()), E(this._coordsList, function (t) { t.calcAffineTransform(); }); }), (t.prototype.getAxis = function (t, e) { var n = this._axesMap[t]; if (null != n) return n[e || 0]; }), (t.prototype.getAxes = function () { return this._axesList.slice(); }), (t.prototype.getCartesian = function (t, e) { if (null != t && null != e) { var n = "x" + t + "y" + e; return this._coordsMap[n]; } q(t) && ((e = t.yAxisIndex), (t = t.xAxisIndex)); for (var i = 0, r = this._coordsList; i < r.length; i++) if ( r[i].getAxis("x").index === t || r[i].getAxis("y").index === e ) return r[i]; }), (t.prototype.getCartesians = function () { return this._coordsList.slice(); }), (t.prototype.convertToPixel = function (t, e, n) { var i = this._findConvertTarget(e); return i.cartesian ? i.cartesian.dataToPoint(n) : i.axis ? i.axis.toGlobalCoord(i.axis.dataToCoord(n)) : null; }), (t.prototype.convertFromPixel = function (t, e, n) { var i = this._findConvertTarget(e); return i.cartesian ? i.cartesian.pointToData(n) : i.axis ? i.axis.coordToData(i.axis.toLocalCoord(n)) : null; }), (t.prototype._findConvertTarget = function (t) { var e, n, i = t.seriesModel, r = t.xAxisModel || (i && i.getReferringComponents("xAxis", Wo).models[0]), o = t.yAxisModel || (i && i.getReferringComponents("yAxis", Wo).models[0]), a = t.gridModel, s = this._coordsList; if (i) P(s, (e = i.coordinateSystem)) < 0 && (e = null); else if (r && o) e = this.getCartesian(r.componentIndex, o.componentIndex); else if (r) n = this.getAxis("x", r.componentIndex); else if (o) n = this.getAxis("y", o.componentIndex); else if (a) { a.coordinateSystem === this && (e = this._coordsList[0]); } return { cartesian: e, axis: n }; }), (t.prototype.containPoint = function (t) { var e = this._coordsList[0]; if (e) return e.containPoint(t); }), (t.prototype._initCartesian = function (t, e, n) { var i = this, r = this, o = { left: !1, right: !1, top: !1, bottom: !1 }, a = { x: {}, y: {} }, s = { x: 0, y: 0 }; if ( (e.eachComponent("xAxis", l("x"), this), e.eachComponent("yAxis", l("y"), this), !s.x || !s.y) ) return (this._axesMap = {}), void (this._axesList = []); function l(e) { return function (n, i) { if (uI(n, t)) { var l = n.get("position"); "x" === e ? "top" !== l && "bottom" !== l && (l = o.bottom ? "top" : "bottom") : "left" !== l && "right" !== l && (l = o.left ? "right" : "left"), (o[l] = !0); var u = new nI(e, b_(n), [0, 0], n.get("type"), l), h = "category" === u.type; (u.onBand = h && n.get("boundaryGap")), (u.inverse = n.get("inverse")), (n.axis = u), (u.model = n), (u.grid = r), (u.index = i), r._axesList.push(u), (a[e][i] = u), s[e]++; } }; } (this._axesMap = a), E(a.x, function (e, n) { E(a.y, function (r, o) { var a = "x" + n + "y" + o, s = new eI(a); (s.master = i), (s.model = t), (i._coordsMap[a] = s), i._coordsList.push(s), s.addAxis(e), s.addAxis(r); }); }); }), (t.prototype._updateScale = function (t, e) { function n(t, e) { E(C_(t, e.dim), function (n) { e.scale.unionExtentFromData(t, n); }); } E(this._axesList, function (t) { if ( (t.scale.setExtent(1 / 0, -1 / 0), "category" === t.type) ) { var e = t.model.get("categorySortInfo"); t.scale.setSortInfo(e); } }), t.eachSeries(function (t) { if (rI(t)) { var i = oI(t), r = i.xAxisModel, o = i.yAxisModel; if (!uI(r, e) || !uI(o, e)) return; var a = this.getCartesian( r.componentIndex, o.componentIndex ), s = t.getData(), l = a.getAxis("x"), u = a.getAxis("y"); n(s, l), n(s, u); } }, this); }), (t.prototype.getTooltipAxes = function (t) { var e = [], n = []; return ( E(this.getCartesians(), function (i) { var r = null != t && "auto" !== t ? i.getAxis(t) : i.getBaseAxis(), o = i.getOtherAxis(r); P(e, r) < 0 && e.push(r), P(n, o) < 0 && n.push(o); }), { baseAxes: e, otherAxes: n } ); }), (t.create = function (e, n) { var i = []; return ( e.eachComponent("grid", function (r, o) { var a = new t(r, e, n); (a.name = "grid_" + o), a.resize(r, n, !0), (r.coordinateSystem = a), i.push(a); }), e.eachSeries(function (t) { if (rI(t)) { var e = oI(t), n = e.xAxisModel, i = e.yAxisModel, r = n.getCoordSysModel(); 0; var o = r.coordinateSystem; t.coordinateSystem = o.getCartesian( n.componentIndex, i.componentIndex ); } }), i ); }), (t.dimensions = QM), t ); })(); function uI(t, e) { return t.getCoordSysModel() === e; } function hI(t, e, n, i) { n.getAxesOnZeroOf = function () { return r ? [r] : []; }; var r, o = t[e], a = n.model, s = a.get(["axisLine", "onZero"]), l = a.get(["axisLine", "onZeroAxisIndex"]); if (s) { if (null != l) cI(o[l]) && (r = o[l]); else for (var u in o) if (o.hasOwnProperty(u) && cI(o[u]) && !i[h(o[u])]) { r = o[u]; break; } r && (i[h(r)] = !0); } function h(t) { return t.dim + "_" + t.index; } } function cI(t) { return ( t && "category" !== t.type && "time" !== t.type && (function (t) { var e = t.scale.getExtent(), n = e[0], i = e[1]; return !((n > 0 && i > 0) || (n < 0 && i < 0)); })(t) ); } var pI = Math.PI, dI = (function () { function t(t, e) { (this.group = new Br()), (this.opt = e), (this.axisModel = t), k(e, { labelOffset: 0, nameDirection: 1, tickDirection: 1, labelDirection: 1, silent: !0, handleAutoShown: function () { return !0; }, }); var n = new Br({ x: e.position[0], y: e.position[1], rotation: e.rotation, }); n.updateTransform(), (this._transformGroup = n); } return ( (t.prototype.hasBuilder = function (t) { return !!fI[t]; }), (t.prototype.add = function (t) { fI[t]( this.opt, this.axisModel, this.group, this._transformGroup ); }), (t.prototype.getGroup = function () { return this.group; }), (t.innerTextLayout = function (t, e, n) { var i, r, o = ao(e - t); return ( so(o) ? ((r = n > 0 ? "top" : "bottom"), (i = "center")) : so(o - pI) ? ((r = n > 0 ? "bottom" : "top"), (i = "center")) : ((r = "middle"), (i = o > 0 && o < pI ? n > 0 ? "right" : "left" : n > 0 ? "left" : "right")), { rotation: o, textAlign: i, textVerticalAlign: r } ); }), (t.makeAxisEventDataBase = function (t) { var e = { componentType: t.mainType, componentIndex: t.componentIndex, }; return (e[t.mainType + "Index"] = t.componentIndex), e; }), (t.isLabelSilent = function (t) { var e = t.get("tooltip"); return ( t.get("silent") || !(t.get("triggerEvent") || (e && e.show)) ); }), t ); })(), fI = { axisLine: function (t, e, n, i) { var r = e.get(["axisLine", "show"]); if ( ("auto" === r && t.handleAutoShown && (r = t.handleAutoShown("axisLine")), r) ) { var o = e.axis.getExtent(), a = i.transform, s = [o[0], 0], l = [o[1], 0], u = s[0] > l[0]; a && (Wt(s, s, a), Wt(l, l, a)); var h = A( { lineCap: "round" }, e.getModel(["axisLine", "lineStyle"]).getLineStyle() ), c = new Ku({ shape: { x1: s[0], y1: s[1], x2: l[0], y2: l[1] }, style: h, strokeContainThreshold: t.strokeContainThreshold || 5, silent: !0, z2: 1, }); zh(c.shape, c.style.lineWidth), (c.anid = "line"), n.add(c); var p = e.get(["axisLine", "symbol"]); if (null != p) { var d = e.get(["axisLine", "symbolSize"]); U(p) && (p = [p, p]), (U(d) || j(d)) && (d = [d, d]); var f = Zy(e.get(["axisLine", "symbolOffset"]) || 0, d), g = d[0], y = d[1]; E( [ { rotate: t.rotation + Math.PI / 2, offset: f[0], r: 0, }, { rotate: t.rotation - Math.PI / 2, offset: f[1], r: Math.sqrt( (s[0] - l[0]) * (s[0] - l[0]) + (s[1] - l[1]) * (s[1] - l[1]) ), }, ], function (e, i) { if ("none" !== p[i] && null != p[i]) { var r = Xy( p[i], -g / 2, -y / 2, g, y, h.stroke, !0 ), o = e.r + e.offset, a = u ? l : s; r.attr({ rotation: e.rotate, x: a[0] + o * Math.cos(t.rotation), y: a[1] - o * Math.sin(t.rotation), silent: !0, z2: 11, }), n.add(r); } } ); } } }, axisTickLabel: function (t, e, n, i) { var r = (function (t, e, n, i) { var r = n.axis, o = n.getModel("axisTick"), a = o.get("show"); "auto" === a && i.handleAutoShown && (a = i.handleAutoShown("axisTick")); if (!a || r.scale.isBlank()) return; for ( var s = o.getModel("lineStyle"), l = i.tickDirection * o.get("length"), u = mI( r.getTicksCoords(), e.transform, l, k(s.getLineStyle(), { stroke: n.get([ "axisLine", "lineStyle", "color", ]), }), "ticks" ), h = 0; h < u.length; h++ ) t.add(u[h]); return u; })(n, i, e, t), o = (function (t, e, n, i) { var r = n.axis, o = it( i.axisLabelShow, n.get(["axisLabel", "show"]) ); if (!o || r.scale.isBlank()) return; var a = n.getModel("axisLabel"), s = a.get("margin"), l = r.getViewLabels(), u = ((it(i.labelRotate, a.get("rotate")) || 0) * pI) / 180, h = dI.innerTextLayout( i.rotation, u, i.labelDirection ), c = n.getCategories && n.getCategories(!0), p = [], d = dI.isLabelSilent(n), f = n.get("triggerEvent"); return ( E(l, function (o, u) { var g = "ordinal" === r.scale.type ? r.scale.getRawOrdinalNumber( o.tickValue ) : o.tickValue, y = o.formattedLabel, v = o.rawLabel, m = a; if (c && c[g]) { var x = c[g]; q(x) && x.textStyle && (m = new Cc(x.textStyle, a, n.ecModel)); } var _ = m.getTextColor() || n.get([ "axisLine", "lineStyle", "color", ]), b = r.dataToCoord(g), w = m.getShallow("align", !0) || h.textAlign, S = rt( m.getShallow("alignMinLabel", !0), w ), M = rt( m.getShallow("alignMaxLabel", !0), w ), I = m.getShallow("verticalAlign", !0) || m.getShallow("baseline", !0) || h.textVerticalAlign, T = rt( m.getShallow( "verticalAlignMinLabel", !0 ), I ), C = rt( m.getShallow( "verticalAlignMaxLabel", !0 ), I ), D = new Xs({ x: b, y: i.labelOffset + i.labelDirection * s, rotation: h.rotation, silent: d, z2: 10 + (o.level || 0), style: oc(m, { text: y, align: 0 === u ? S : u === l.length - 1 ? M : w, verticalAlign: 0 === u ? T : u === l.length - 1 ? C : I, fill: X(_) ? _( "category" === r.type ? v : "value" === r.type ? g + "" : g, u ) : _, }), }); if ( ((D.anid = "label_" + g), Kh({ el: D, componentModel: n, itemName: y, formatterParamsExtra: { isTruncated: function () { return D.isTruncated; }, value: v, tickIndex: u, }, }), f) ) { var A = dI.makeAxisEventDataBase(n); (A.targetType = "axisLabel"), (A.value = v), (A.tickIndex = u), "category" === r.type && (A.dataIndex = g), (rl(D).eventData = A); } e.add(D), D.updateTransform(), p.push(D), t.add(D), D.decomposeTransform(); }), p ); })(n, i, e, t); ((function (t, e, n) { if (T_(t.axis)) return; var i = t.get(["axisLabel", "showMinLabel"]), r = t.get(["axisLabel", "showMaxLabel"]); (e = e || []), (n = n || []); var o = e[0], a = e[1], s = e[e.length - 1], l = e[e.length - 2], u = n[0], h = n[1], c = n[n.length - 1], p = n[n.length - 2]; !1 === i ? (gI(o), gI(u)) : yI(o, a) && (i ? (gI(a), gI(h)) : (gI(o), gI(u))); !1 === r ? (gI(s), gI(c)) : yI(l, s) && (r ? (gI(l), gI(p)) : (gI(s), gI(c))); })(e, o, r), (function (t, e, n, i) { var r = n.axis, o = n.getModel("minorTick"); if (!o.get("show") || r.scale.isBlank()) return; var a = r.getMinorTicksCoords(); if (!a.length) return; for ( var s = o.getModel("lineStyle"), l = i * o.get("length"), u = k( s.getLineStyle(), k(n.getModel("axisTick").getLineStyle(), { stroke: n.get([ "axisLine", "lineStyle", "color", ]), }) ), h = 0; h < a.length; h++ ) for ( var c = mI( a[h], e.transform, l, u, "minorticks_" + h ), p = 0; p < c.length; p++ ) t.add(c[p]); })(n, i, e, t.tickDirection), e.get(["axisLabel", "hideOverlap"])) && Nb( Pb( z(o, function (t) { return { label: t, priority: t.z2, defaultAttr: { ignore: t.ignore }, }; }) ) ); }, axisName: function (t, e, n, i) { var r = it(t.axisName, e.get("name")); if (r) { var o, a, s = e.get("nameLocation"), l = t.nameDirection, u = e.getModel("nameTextStyle"), h = e.get("nameGap") || 0, c = e.axis.getExtent(), p = c[0] > c[1] ? -1 : 1, d = [ "start" === s ? c[0] - p * h : "end" === s ? c[1] + p * h : (c[0] + c[1]) / 2, vI(s) ? t.labelOffset + l * h : 0, ], f = e.get("nameRotate"); null != f && (f = (f * pI) / 180), vI(s) ? (o = dI.innerTextLayout( t.rotation, null != f ? f : t.rotation, l )) : ((o = (function (t, e, n, i) { var r, o, a = ao(n - t), s = i[0] > i[1], l = ("start" === e && !s) || ("start" !== e && s); so(a - pI / 2) ? ((o = l ? "bottom" : "top"), (r = "center")) : so(a - 1.5 * pI) ? ((o = l ? "top" : "bottom"), (r = "center")) : ((o = "middle"), (r = a < 1.5 * pI && a > pI / 2 ? l ? "left" : "right" : l ? "right" : "left")); return { rotation: a, textAlign: r, textVerticalAlign: o, }; })(t.rotation, s, f || 0, c)), null != (a = t.axisNameAvailableWidth) && ((a = Math.abs(a / Math.sin(o.rotation))), !isFinite(a) && (a = null))); var g = u.getFont(), y = e.get("nameTruncate", !0) || {}, v = y.ellipsis, m = it(t.nameTruncateMaxWidth, y.maxWidth, a), x = new Xs({ x: d[0], y: d[1], rotation: o.rotation, silent: dI.isLabelSilent(e), style: oc(u, { text: r, font: g, overflow: "truncate", width: m, ellipsis: v, fill: u.getTextColor() || e.get(["axisLine", "lineStyle", "color"]), align: u.get("align") || o.textAlign, verticalAlign: u.get("verticalAlign") || o.textVerticalAlign, }), z2: 1, }); if ( (Kh({ el: x, componentModel: e, itemName: r }), (x.__fullText = r), (x.anid = "name"), e.get("triggerEvent")) ) { var _ = dI.makeAxisEventDataBase(e); (_.targetType = "axisName"), (_.name = r), (rl(x).eventData = _); } i.add(x), x.updateTransform(), n.add(x), x.decomposeTransform(); } }, }; function gI(t) { t && (t.ignore = !0); } function yI(t, e) { var n = t && t.getBoundingRect().clone(), i = e && e.getBoundingRect().clone(); if (n && i) { var r = xe([]); return ( Se(r, r, -t.rotation), n.applyTransform(be([], r, t.getLocalTransform())), i.applyTransform(be([], r, e.getLocalTransform())), n.intersect(i) ); } } function vI(t) { return "middle" === t || "center" === t; } function mI(t, e, n, i, r) { for (var o = [], a = [], s = [], l = 0; l < t.length; l++) { var u = t[l].coord; (a[0] = u), (a[1] = 0), (s[0] = u), (s[1] = n), e && (Wt(a, a, e), Wt(s, s, e)); var h = new Ku({ shape: { x1: a[0], y1: a[1], x2: s[0], y2: s[1] }, style: i, z2: 2, autoBatch: !0, silent: !0, }); zh(h.shape, h.style.lineWidth), (h.anid = r + "_" + t[l].tickValue), o.push(h); } return o; } function xI(t, e) { var n = { axesInfo: {}, seriesInvolved: !1, coordSysAxesInfo: {}, coordSysMap: {}, }; return ( (function (t, e, n) { var i = e.getComponent("tooltip"), r = e.getComponent("axisPointer"), o = r.get("link", !0) || [], a = []; E(n.getCoordinateSystems(), function (n) { if (n.axisPointerEnabled) { var s = MI(n.model), l = (t.coordSysAxesInfo[s] = {}); t.coordSysMap[s] = n; var u = n.model.getModel("tooltip", i); if ( (E(n.getAxes(), H(d, !1, null)), n.getTooltipAxes && i && u.get("show")) ) { var h = "axis" === u.get("trigger"), c = "cross" === u.get(["axisPointer", "type"]), p = n.getTooltipAxes( u.get(["axisPointer", "axis"]) ); (h || c) && E(p.baseAxes, H(d, !c || "cross", h)), c && E(p.otherAxes, H(d, "cross", !1)); } } function d(i, s, h) { var c = h.model.getModel("axisPointer", r), p = c.get("show"); if (p && ("auto" !== p || i || SI(c))) { null == s && (s = c.get("triggerTooltip")), (c = i ? (function (t, e, n, i, r, o) { var a = e.getModel("axisPointer"), s = {}; E( [ "type", "snap", "lineStyle", "shadowStyle", "label", "animation", "animationDurationUpdate", "animationEasingUpdate", "z", ], function (t) { s[t] = T(a.get(t)); } ), (s.snap = "category" !== t.type && !!o), "cross" === a.get("type") && (s.type = "line"); var l = s.label || (s.label = {}); if ( (null == l.show && (l.show = !1), "cross" === r) ) { var u = a.get(["label", "show"]); if ( ((l.show = null == u || u), !o) ) { var h = (s.lineStyle = a.get("crossStyle")); h && k(l, h.textStyle); } } return t.model.getModel( "axisPointer", new Cc(s, n, i) ); })(h, u, r, e, i, s) : c); var d = c.get("snap"), f = c.get("triggerEmphasis"), g = MI(h.model), y = s || d || "category" === h.type, v = (t.axesInfo[g] = { key: g, axis: h, coordSys: n, axisPointerModel: c, triggerTooltip: s, triggerEmphasis: f, involveSeries: y, snap: d, useHandle: SI(c), seriesModels: [], linkGroup: null, }); (l[g] = v), (t.seriesInvolved = t.seriesInvolved || y); var m = (function (t, e) { for ( var n = e.model, i = e.dim, r = 0; r < t.length; r++ ) { var o = t[r] || {}; if ( _I(o[i + "AxisId"], n.id) || _I( o[i + "AxisIndex"], n.componentIndex ) || _I(o[i + "AxisName"], n.name) ) return r; } })(o, h); if (null != m) { var x = a[m] || (a[m] = { axesInfo: {} }); (x.axesInfo[g] = v), (x.mapper = o[m].mapper), (v.linkGroup = x); } } } }); })(n, t, e), n.seriesInvolved && (function (t, e) { e.eachSeries(function (e) { var n = e.coordinateSystem, i = e.get(["tooltip", "trigger"], !0), r = e.get(["tooltip", "show"], !0); n && "none" !== i && !1 !== i && "item" !== i && !1 !== r && !1 !== e.get(["axisPointer", "show"], !0) && E(t.coordSysAxesInfo[MI(n.model)], function (t) { var i = t.axis; n.getAxis(i.dim) === i && (t.seriesModels.push(e), null == t.seriesDataCount && (t.seriesDataCount = 0), (t.seriesDataCount += e.getData().count())); }); }); })(n, t), n ); } function _I(t, e) { return "all" === t || (Y(t) && P(t, e) >= 0) || t === e; } function bI(t) { var e = wI(t); if (e) { var n = e.axisPointerModel, i = e.axis.scale, r = n.option, o = n.get("status"), a = n.get("value"); null != a && (a = i.parse(a)); var s = SI(n); null == o && (r.status = s ? "show" : "hide"); var l = i.getExtent().slice(); l[0] > l[1] && l.reverse(), (null == a || a > l[1]) && (a = l[1]), a < l[0] && (a = l[0]), (r.value = a), s && (r.status = e.axis.scale.isBlank() ? "hide" : "show"); } } function wI(t) { var e = (t.ecModel.getComponent("axisPointer") || {}).coordSysAxesInfo; return e && e.axesInfo[MI(t)]; } function SI(t) { return !!t.get(["handle", "show"]); } function MI(t) { return t.type + "||" + t.id; } var II = {}, TI = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (e, n, i, r) { this.axisPointerClass && bI(e), t.prototype.render.apply(this, arguments), this._doUpdateAxisPointerClass(e, i, !0); }), (e.prototype.updateAxisPointer = function (t, e, n, i) { this._doUpdateAxisPointerClass(t, n, !1); }), (e.prototype.remove = function (t, e) { var n = this._axisPointer; n && n.remove(e); }), (e.prototype.dispose = function (e, n) { this._disposeAxisPointer(n), t.prototype.dispose.apply(this, arguments); }), (e.prototype._doUpdateAxisPointerClass = function (t, n, i) { var r = e.getAxisPointerClass(this.axisPointerClass); if (r) { var o = (function (t) { var e = wI(t); return e && e.axisPointerModel; })(t); o ? ( this._axisPointer || (this._axisPointer = new r()) ).render(t, o, n, i) : this._disposeAxisPointer(n); } }), (e.prototype._disposeAxisPointer = function (t) { this._axisPointer && this._axisPointer.dispose(t), (this._axisPointer = null); }), (e.registerAxisPointerClass = function (t, e) { II[t] = e; }), (e.getAxisPointerClass = function (t) { return t && II[t]; }), (e.type = "axis"), e ); })(Ag), CI = Vo(); function DI(t, e, n, i) { var r = n.axis; if (!r.scale.isBlank()) { var o = n.getModel("splitArea"), a = o.getModel("areaStyle"), s = a.get("color"), l = i.coordinateSystem.getRect(), u = r.getTicksCoords({ tickModel: o, clamp: !0 }); if (u.length) { var h = s.length, c = CI(t).splitAreaColors, p = yt(), d = 0; if (c) for (var f = 0; f < u.length; f++) { var g = c.get(u[f].tickValue); if (null != g) { d = (g + (h - 1) * f) % h; break; } } var y = r.toGlobalCoord(u[0].coord), v = a.getAreaStyle(); s = Y(s) ? s : [s]; for (f = 1; f < u.length; f++) { var m = r.toGlobalCoord(u[f].coord), x = void 0, _ = void 0, b = void 0, w = void 0; r.isHorizontal() ? ((x = y), (_ = l.y), (b = m - x), (w = l.height), (y = x + b)) : ((x = l.x), (_ = y), (b = l.width), (y = _ + (w = m - _))); var S = u[f - 1].tickValue; null != S && p.set(S, d), e.add( new Ws({ anid: null != S ? "area_" + S : null, shape: { x: x, y: _, width: b, height: w }, style: k({ fill: s[d] }, v), autoBatch: !0, silent: !0, }) ), (d = (d + 1) % h); } CI(t).splitAreaColors = p; } } } function AI(t) { CI(t).splitAreaColors = null; } var kI = ["axisLine", "axisTickLabel", "axisName"], LI = ["splitArea", "splitLine", "minorSplitLine"], PI = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.axisPointerClass = "CartesianAxisPointer"), n ); } return ( n(e, t), (e.prototype.render = function (e, n, i, r) { this.group.removeAll(); var o = this._axisGroup; if ( ((this._axisGroup = new Br()), this.group.add(this._axisGroup), e.get("show")) ) { var a = e.getCoordSysModel(), s = iI(a, e), l = new dI( e, A( { handleAutoShown: function (t) { for ( var n = a.coordinateSystem.getCartesians(), i = 0; i < n.length; i++ ) if ( Tx( n[i].getOtherAxis( e.axis ).scale ) ) return !0; return !1; }, }, s ) ); E(kI, l.add, l), this._axisGroup.add(l.getGroup()), E( LI, function (t) { e.get([t, "show"]) && OI[t](this, this._axisGroup, e, a); }, this ), (r && "changeAxisOrder" === r.type && r.isInitSort) || Hh(o, this._axisGroup, e), t.prototype.render.call(this, e, n, i, r); } }), (e.prototype.remove = function () { AI(this); }), (e.type = "cartesianAxis"), e ); })(TI), OI = { splitLine: function (t, e, n, i) { var r = n.axis; if (!r.scale.isBlank()) { var o = n.getModel("splitLine"), a = o.getModel("lineStyle"), s = a.get("color"), l = !1 !== o.get("showMinLine"), u = !1 !== o.get("showMaxLine"); s = Y(s) ? s : [s]; for ( var h = i.coordinateSystem.getRect(), c = r.isHorizontal(), p = 0, d = r.getTicksCoords({ tickModel: o }), f = [], g = [], y = a.getLineStyle(), v = 0; v < d.length; v++ ) { var m = r.toGlobalCoord(d[v].coord); if ((0 !== v || l) && (v !== d.length - 1 || u)) { var x = d[v].tickValue; c ? ((f[0] = m), (f[1] = h.y), (g[0] = m), (g[1] = h.y + h.height)) : ((f[0] = h.x), (f[1] = m), (g[0] = h.x + h.width), (g[1] = m)); var _ = p++ % s.length, b = new Ku({ anid: null != x ? "line_" + x : null, autoBatch: !0, shape: { x1: f[0], y1: f[1], x2: g[0], y2: g[1], }, style: k({ stroke: s[_] }, y), silent: !0, }); zh(b.shape, y.lineWidth), e.add(b); } } } }, minorSplitLine: function (t, e, n, i) { var r = n.axis, o = n.getModel("minorSplitLine").getModel("lineStyle"), a = i.coordinateSystem.getRect(), s = r.isHorizontal(), l = r.getMinorTicksCoords(); if (l.length) for ( var u = [], h = [], c = o.getLineStyle(), p = 0; p < l.length; p++ ) for (var d = 0; d < l[p].length; d++) { var f = r.toGlobalCoord(l[p][d].coord); s ? ((u[0] = f), (u[1] = a.y), (h[0] = f), (h[1] = a.y + a.height)) : ((u[0] = a.x), (u[1] = f), (h[0] = a.x + a.width), (h[1] = f)); var g = new Ku({ anid: "minor_line_" + l[p][d].tickValue, autoBatch: !0, shape: { x1: u[0], y1: u[1], x2: h[0], y2: h[1], }, style: c, silent: !0, }); zh(g.shape, c.lineWidth), e.add(g); } }, splitArea: function (t, e, n, i) { DI(t, e, n, i); }, }, RI = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "xAxis"), e; })(PI), NI = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.type = RI.type), e; } return n(e, t), (e.type = "yAxis"), e; })(PI), EI = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.type = "grid"), e; } return ( n(e, t), (e.prototype.render = function (t, e) { this.group.removeAll(), t.get("show") && this.group.add( new Ws({ shape: t.coordinateSystem.getRect(), style: k( { fill: t.get("backgroundColor") }, t.getItemStyle() ), silent: !0, z2: -1, }) ); }), (e.type = "grid"), e ); })(Ag), zI = { offset: 0 }; function VI(t) { t.registerComponentView(EI), t.registerComponentModel(HM), t.registerCoordinateSystem("cartesian2d", lI), KM(t, "x", YM, zI), KM(t, "y", YM, zI), t.registerComponentView(RI), t.registerComponentView(NI), t.registerPreprocessor(function (t) { t.xAxis && t.yAxis && !t.grid && (t.grid = {}); }); } function BI(t) { t.eachSeriesByType("radar", function (t) { var e = t.getData(), n = [], i = t.coordinateSystem; if (i) { var r = i.getIndicatorAxes(); E(r, function (t, o) { e.each(e.mapDimension(r[o].dim), function (t, e) { n[e] = n[e] || []; var r = i.dataToPoint(t, o); n[e][o] = FI(r) ? r : GI(i); }); }), e.each(function (t) { var r = F(n[t], function (t) { return FI(t); }) || GI(i); n[t].push(r.slice()), e.setItemLayout(t, n[t]); }); } }); } function FI(t) { return !isNaN(t[0]) && !isNaN(t[1]); } function GI(t) { return [t.cx, t.cy]; } function WI(t) { var e = t.polar; if (e) { Y(e) || (e = [e]); var n = []; E(e, function (e, i) { e.indicator ? (e.type && !e.shape && (e.shape = e.type), (t.radar = t.radar || []), Y(t.radar) || (t.radar = [t.radar]), t.radar.push(e)) : n.push(e); }), (t.polar = n); } E(t.series, function (t) { t && "radar" === t.type && t.polarIndex && (t.radarIndex = t.polarIndex); }); } var HI = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = t.coordinateSystem, r = this.group, o = t.getData(), a = this._data; function s(t, e) { var n = t.getItemVisual(e, "symbol") || "circle"; if ("none" !== n) { var i = Uy(t.getItemVisual(e, "symbolSize")), r = Xy(n, -1, -1, 2, 2), o = t.getItemVisual(e, "symbolRotate") || 0; return ( r.attr({ style: { strokeNoScale: !0 }, z2: 100, scaleX: i[0] / 2, scaleY: i[1] / 2, rotation: (o * Math.PI) / 180 || 0, }), r ); } } function l(e, n, i, r, o, a) { i.removeAll(); for (var l = 0; l < n.length - 1; l++) { var u = s(r, o); u && ((u.__dimIdx = l), e[l] ? (u.setPosition(e[l]), Qh[a ? "initProps" : "updateProps"]( u, { x: n[l][0], y: n[l][1] }, t, o )) : u.setPosition(n[l]), i.add(u)); } } function u(t) { return z(t, function (t) { return [i.cx, i.cy]; }); } o .diff(a) .add(function (e) { var n = o.getItemLayout(e); if (n) { var i = new Xu(), r = new Zu(), a = { shape: { points: n } }; (i.shape.points = u(n)), (r.shape.points = u(n)), mh(i, a, t, e), mh(r, a, t, e); var s = new Br(), h = new Br(); s.add(r), s.add(i), s.add(h), l(r.shape.points, n, h, o, e, !0), o.setItemGraphicEl(e, s); } }) .update(function (e, n) { var i = a.getItemGraphicEl(n), r = i.childAt(0), s = i.childAt(1), u = i.childAt(2), h = { shape: { points: o.getItemLayout(e) } }; h.shape.points && (l(r.shape.points, h.shape.points, u, o, e, !1), Sh(s), Sh(r), vh(r, h, t), vh(s, h, t), o.setItemGraphicEl(e, i)); }) .remove(function (t) { r.remove(a.getItemGraphicEl(t)); }) .execute(), o.eachItemGraphicEl(function (t, e) { var n = o.getItemModel(e), i = t.childAt(0), a = t.childAt(1), s = t.childAt(2), l = o.getItemVisual(e, "style"), u = l.fill; r.add(t), i.useStyle( k(n.getModel("lineStyle").getLineStyle(), { fill: "none", stroke: u, }) ), $l(i, n, "lineStyle"), $l(a, n, "areaStyle"); var h = n.getModel("areaStyle"), c = h.isEmpty() && h.parentModel.isEmpty(); (a.ignore = c), E(["emphasis", "select", "blur"], function (t) { var e = n.getModel([t, "areaStyle"]), i = e.isEmpty() && e.parentModel.isEmpty(); a.ensureState(t).ignore = i && c; }), a.useStyle( k(h.getAreaStyle(), { fill: u, opacity: 0.7, decal: l.decal, }) ); var p = n.getModel("emphasis"), d = p.getModel("itemStyle").getItemStyle(); s.eachChild(function (t) { if (t instanceof Ns) { var i = t.style; t.useStyle( A( { image: i.image, x: i.x, y: i.y, width: i.width, height: i.height, }, l ) ); } else t.useStyle(l), t.setColor(u), (t.style.strokeNoScale = !0); t.ensureState("emphasis").style = T(d); var r = o .getStore() .get(o.getDimensionIndex(t.__dimIdx), e); (null == r || isNaN(r)) && (r = ""), ic(t, rc(n), { labelFetcher: o.hostModel, labelDataIndex: e, labelDimIndex: t.__dimIdx, defaultText: r, inheritColor: u, defaultOpacity: l.opacity, }); }), Zl( t, p.get("focus"), p.get("blurScope"), p.get("disabled") ); }), (this._data = o); }), (e.prototype.remove = function () { this.group.removeAll(), (this._data = null); }), (e.type = "radar"), e ); })(Og), YI = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.hasSymbolVisual = !0), n; } return ( n(e, t), (e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), (this.legendVisualProvider = new NM( W(this.getData, this), W(this.getRawData, this) )); }), (e.prototype.getInitialData = function (t, e) { return RM(this, { generateCoord: "indicator_", generateCoordCount: 1 / 0, }); }), (e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(), r = this.coordinateSystem.getIndicatorAxes(), o = this.getData().getName(t), a = "" === o ? this.name : o, s = fg(this, t); return og("section", { header: a, sortBlocks: !0, blocks: z(r, function (e) { var n = i.get(i.mapDimension(e.dim), t); return og("nameValue", { markerType: "subItem", markerColor: s, name: e.name, value: n, sortParam: n, }); }), }); }), (e.prototype.getTooltipPosition = function (t) { if (null != t) for ( var e = this.getData(), n = this.coordinateSystem, i = e.getValues( z(n.dimensions, function (t) { return e.mapDimension(t); }), t ), r = 0, o = i.length; r < o; r++ ) if (!isNaN(i[r])) { var a = n.getIndicatorAxes(); return n.coordToPoint( a[r].dataToCoord(i[r]), r ); } }), (e.type = "series.radar"), (e.dependencies = ["radar"]), (e.defaultOption = { z: 2, colorBy: "data", coordinateSystem: "radar", legendHoverLink: !0, radarIndex: 0, lineStyle: { width: 2, type: "solid", join: "round" }, label: { position: "top" }, symbolSize: 8, }), e ); })(bg), XI = jM.value; function UI(t, e) { return k({ show: e }, t); } var ZI = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.optionUpdated = function () { var t = this.get("boundaryGap"), e = this.get("splitNumber"), n = this.get("scale"), i = this.get("axisLine"), r = this.get("axisTick"), o = this.get("axisLabel"), a = this.get("axisName"), s = this.get(["axisName", "show"]), l = this.get(["axisName", "formatter"]), u = this.get("axisNameGap"), h = this.get("triggerEvent"), c = z( this.get("indicator") || [], function (c) { null != c.max && c.max > 0 && !c.min ? (c.min = 0) : null != c.min && c.min < 0 && !c.max && (c.max = 0); var p = a; null != c.color && (p = k({ color: c.color }, a)); var d = C( T(c), { boundaryGap: t, splitNumber: e, scale: n, axisLine: i, axisTick: r, axisLabel: o, name: c.text, showName: s, nameLocation: "end", nameGap: u, nameTextStyle: p, triggerEvent: h, }, !1 ); if (U(l)) { var f = d.name; d.name = l.replace( "{value}", null != f ? f : "" ); } else X(l) && (d.name = l(d.name, d)); var g = new Cc(d, null, this.ecModel); return ( R(g, D_.prototype), (g.mainType = "radar"), (g.componentIndex = this.componentIndex), g ); }, this ); this._indicatorModels = c; }), (e.prototype.getIndicatorModels = function () { return this._indicatorModels; }), (e.type = "radar"), (e.defaultOption = { z: 0, center: ["50%", "50%"], radius: "75%", startAngle: 90, axisName: { show: !0 }, boundaryGap: [0, 0], splitNumber: 5, axisNameGap: 15, scale: !1, shape: "polygon", axisLine: C({ lineStyle: { color: "#bbb" } }, XI.axisLine), axisLabel: UI(XI.axisLabel, !1), axisTick: UI(XI.axisTick, !1), splitLine: UI(XI.splitLine, !0), splitArea: UI(XI.splitArea, !0), indicator: [], }), e ); })(zp), jI = ["axisLine", "axisTickLabel", "axisName"], qI = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { this.group.removeAll(), this._buildAxes(t), this._buildSplitLineAndArea(t); }), (e.prototype._buildAxes = function (t) { var e = t.coordinateSystem; E( z(e.getIndicatorAxes(), function (t) { var n = t.model.get("showName") ? t.name : ""; return new dI(t.model, { axisName: n, position: [e.cx, e.cy], rotation: t.angle, labelDirection: -1, tickDirection: -1, nameDirection: 1, }); }), function (t) { E(jI, t.add, t), this.group.add(t.getGroup()); }, this ); }), (e.prototype._buildSplitLineAndArea = function (t) { var e = t.coordinateSystem, n = e.getIndicatorAxes(); if (n.length) { var i = t.get("shape"), r = t.getModel("splitLine"), o = t.getModel("splitArea"), a = r.getModel("lineStyle"), s = o.getModel("areaStyle"), l = r.get("show"), u = o.get("show"), h = a.get("color"), c = s.get("color"), p = Y(h) ? h : [h], d = Y(c) ? c : [c], f = [], g = []; if ("circle" === i) for ( var y = n[0].getTicksCoords(), v = e.cx, m = e.cy, x = 0; x < y.length; x++ ) { if (l) f[C(f, p, x)].push( new Su({ shape: { cx: v, cy: m, r: y[x].coord, }, }) ); if (u && x < y.length - 1) g[C(g, d, x)].push( new Wu({ shape: { cx: v, cy: m, r0: y[x].coord, r: y[x + 1].coord, }, }) ); } else { var _, b = z(n, function (t, n) { var i = t.getTicksCoords(); return ( (_ = null == _ ? i.length - 1 : Math.min(i.length - 1, _)), z(i, function (t) { return e.coordToPoint(t.coord, n); }) ); }), w = []; for (x = 0; x <= _; x++) { for (var S = [], M = 0; M < n.length; M++) S.push(b[M][x]); if ((S[0] && S.push(S[0].slice()), l)) f[C(f, p, x)].push( new Zu({ shape: { points: S } }) ); if (u && w) g[C(g, d, x - 1)].push( new Xu({ shape: { points: S.concat(w) }, }) ); w = S.slice().reverse(); } } var I = a.getLineStyle(), T = s.getAreaStyle(); E( g, function (t, e) { this.group.add( Nh(t, { style: k( { stroke: "none", fill: d[e % d.length], }, T ), silent: !0, }) ); }, this ), E( f, function (t, e) { this.group.add( Nh(t, { style: k( { fill: "none", stroke: p[e % p.length], }, I ), silent: !0, }) ); }, this ); } function C(t, e, n) { var i = n % e.length; return (t[i] = t[i] || []), i; } }), (e.type = "radar"), e ); })(Ag), KI = (function (t) { function e(e, n, i) { var r = t.call(this, e, n, i) || this; return (r.type = "value"), (r.angle = 0), (r.name = ""), r; } return n(e, t), e; })(ab), $I = (function () { function t(t, e, n) { (this.dimensions = []), (this._model = t), (this._indicatorAxes = z( t.getIndicatorModels(), function (t, e) { var n = "indicator_" + e, i = new KI(n, new Ex()); return ( (i.name = t.get("name")), (i.model = t), (t.axis = i), this.dimensions.push(n), i ); }, this )), this.resize(t, n); } return ( (t.prototype.getIndicatorAxes = function () { return this._indicatorAxes; }), (t.prototype.dataToPoint = function (t, e) { var n = this._indicatorAxes[e]; return this.coordToPoint(n.dataToCoord(t), e); }), (t.prototype.coordToPoint = function (t, e) { var n = this._indicatorAxes[e].angle; return [ this.cx + t * Math.cos(n), this.cy - t * Math.sin(n), ]; }), (t.prototype.pointToData = function (t) { var e = t[0] - this.cx, n = t[1] - this.cy, i = Math.sqrt(e * e + n * n); (e /= i), (n /= i); for ( var r, o = Math.atan2(-n, e), a = 1 / 0, s = -1, l = 0; l < this._indicatorAxes.length; l++ ) { var u = this._indicatorAxes[l], h = Math.abs(o - u.angle); h < a && ((r = u), (s = l), (a = h)); } return [s, +(r && r.coordToData(i))]; }), (t.prototype.resize = function (t, e) { var n = t.get("center"), i = e.getWidth(), r = e.getHeight(), o = Math.min(i, r) / 2; (this.cx = $r(n[0], i)), (this.cy = $r(n[1], r)), (this.startAngle = (t.get("startAngle") * Math.PI) / 180); var a = t.get("radius"); (U(a) || j(a)) && (a = [0, a]), (this.r0 = $r(a[0], o)), (this.r = $r(a[1], o)), E( this._indicatorAxes, function (t, e) { t.setExtent(this.r0, this.r); var n = this.startAngle + (e * Math.PI * 2) / this._indicatorAxes.length; (n = Math.atan2(Math.sin(n), Math.cos(n))), (t.angle = n); }, this ); }), (t.prototype.update = function (t, e) { var n = this._indicatorAxes, i = this._model; E(n, function (t) { t.scale.setExtent(1 / 0, -1 / 0); }), t.eachSeriesByType( "radar", function (e, r) { if ( "radar" === e.get("coordinateSystem") && t.getComponent( "radar", e.get("radarIndex") ) === i ) { var o = e.getData(); E(n, function (t) { t.scale.unionExtentFromData( o, o.mapDimension(t.dim) ); }); } }, this ); var r = i.get("splitNumber"), o = new Ex(); o.setExtent(0, r), o.setInterval(1), E(n, function (t, e) { sI(t.scale, t.model, o); }); }), (t.prototype.convertToPixel = function (t, e, n) { return console.warn("Not implemented."), null; }), (t.prototype.convertFromPixel = function (t, e, n) { return console.warn("Not implemented."), null; }), (t.prototype.containPoint = function (t) { return console.warn("Not implemented."), !1; }), (t.create = function (e, n) { var i = []; return ( e.eachComponent("radar", function (r) { var o = new t(r, e, n); i.push(o), (r.coordinateSystem = o); }), e.eachSeriesByType("radar", function (t) { "radar" === t.get("coordinateSystem") && (t.coordinateSystem = i[t.get("radarIndex") || 0]); }), i ); }), (t.dimensions = []), t ); })(); function JI(t) { t.registerCoordinateSystem("radar", $I), t.registerComponentModel(ZI), t.registerComponentView(qI), t.registerVisual({ seriesType: "radar", reset: function (t) { var e = t.getData(); e.each(function (t) { e.setItemVisual(t, "legendIcon", "roundRect"); }), e.setVisual("legendIcon", "roundRect"); }, }); } var QI = "\0_ec_interaction_mutex"; function tT(t, e) { return !!eT(t)[e]; } function eT(t) { return t[QI] || (t[QI] = {}); } Cm( { type: "takeGlobalCursor", event: "globalCursorTaken", update: "update", }, bt ); var nT = (function (t) { function e(e) { var n = t.call(this) || this; n._zr = e; var i = W(n._mousedownHandler, n), r = W(n._mousemoveHandler, n), o = W(n._mouseupHandler, n), a = W(n._mousewheelHandler, n), s = W(n._pinchHandler, n); return ( (n.enable = function (t, n) { this.disable(), (this._opt = k(T(n) || {}, { zoomOnMouseWheel: !0, moveOnMouseMove: !0, moveOnMouseWheel: !1, preventDefaultMouseMove: !0, })), null == t && (t = !0), (!0 !== t && "move" !== t && "pan" !== t) || (e.on("mousedown", i), e.on("mousemove", r), e.on("mouseup", o)), (!0 !== t && "scale" !== t && "zoom" !== t) || (e.on("mousewheel", a), e.on("pinch", s)); }), (n.disable = function () { e.off("mousedown", i), e.off("mousemove", r), e.off("mouseup", o), e.off("mousewheel", a), e.off("pinch", s); }), n ); } return ( n(e, t), (e.prototype.isDragging = function () { return this._dragging; }), (e.prototype.isPinching = function () { return this._pinching; }), (e.prototype.setPointerChecker = function (t) { this.pointerChecker = t; }), (e.prototype.dispose = function () { this.disable(); }), (e.prototype._mousedownHandler = function (t) { if (!fe(t)) { for (var e = t.target; e; ) { if (e.draggable) return; e = e.__hostTarget || e.parent; } var n = t.offsetX, i = t.offsetY; this.pointerChecker && this.pointerChecker(t, n, i) && ((this._x = n), (this._y = i), (this._dragging = !0)); } }), (e.prototype._mousemoveHandler = function (t) { if ( this._dragging && oT("moveOnMouseMove", t, this._opt) && "pinch" !== t.gestureEvent && !tT(this._zr, "globalPan") ) { var e = t.offsetX, n = t.offsetY, i = this._x, r = this._y, o = e - i, a = n - r; (this._x = e), (this._y = n), this._opt.preventDefaultMouseMove && de(t.event), rT(this, "pan", "moveOnMouseMove", t, { dx: o, dy: a, oldX: i, oldY: r, newX: e, newY: n, isAvailableBehavior: null, }); } }), (e.prototype._mouseupHandler = function (t) { fe(t) || (this._dragging = !1); }), (e.prototype._mousewheelHandler = function (t) { var e = oT("zoomOnMouseWheel", t, this._opt), n = oT("moveOnMouseWheel", t, this._opt), i = t.wheelDelta, r = Math.abs(i), o = t.offsetX, a = t.offsetY; if (0 !== i && (e || n)) { if (e) { var s = r > 3 ? 1.4 : r > 1 ? 1.2 : 1.1; iT(this, "zoom", "zoomOnMouseWheel", t, { scale: i > 0 ? s : 1 / s, originX: o, originY: a, isAvailableBehavior: null, }); } if (n) { var l = Math.abs(i); iT(this, "scrollMove", "moveOnMouseWheel", t, { scrollDelta: (i > 0 ? 1 : -1) * (l > 3 ? 0.4 : l > 1 ? 0.15 : 0.05), originX: o, originY: a, isAvailableBehavior: null, }); } } }), (e.prototype._pinchHandler = function (t) { tT(this._zr, "globalPan") || iT(this, "zoom", null, t, { scale: t.pinchScale > 1 ? 1.1 : 1 / 1.1, originX: t.pinchX, originY: t.pinchY, isAvailableBehavior: null, }); }), e ); })(jt); function iT(t, e, n, i, r) { t.pointerChecker && t.pointerChecker(i, r.originX, r.originY) && (de(i.event), rT(t, e, n, i, r)); } function rT(t, e, n, i, r) { (r.isAvailableBehavior = W(oT, null, n, i)), t.trigger(e, r); } function oT(t, e, n) { var i = n[t]; return !t || (i && (!U(i) || e.event[i + "Key"])); } function aT(t, e, n) { var i = t.target; (i.x += e), (i.y += n), i.dirty(); } function sT(t, e, n, i) { var r = t.target, o = t.zoomLimit, a = (t.zoom = t.zoom || 1); if (((a *= e), o)) { var s = o.min || 0, l = o.max || 1 / 0; a = Math.max(Math.min(l, a), s); } var u = a / t.zoom; (t.zoom = a), (r.x -= (n - r.x) * (u - 1)), (r.y -= (i - r.y) * (u - 1)), (r.scaleX *= u), (r.scaleY *= u), r.dirty(); } var lT, uT = { axisPointer: 1, tooltip: 1, brush: 1 }; function hT(t, e, n) { var i = e.getComponentByElement(t.topTarget), r = i && i.coordinateSystem; return ( i && i !== n && !uT.hasOwnProperty(i.mainType) && r && r.model !== n ); } function cT(t) { U(t) && (t = new DOMParser().parseFromString(t, "text/xml")); var e = t; for ( 9 === e.nodeType && (e = e.firstChild); "svg" !== e.nodeName.toLowerCase() || 1 !== e.nodeType; ) e = e.nextSibling; return e; } var pT = { fill: "fill", stroke: "stroke", "stroke-width": "lineWidth", opacity: "opacity", "fill-opacity": "fillOpacity", "stroke-opacity": "strokeOpacity", "stroke-dasharray": "lineDash", "stroke-dashoffset": "lineDashOffset", "stroke-linecap": "lineCap", "stroke-linejoin": "lineJoin", "stroke-miterlimit": "miterLimit", "font-family": "fontFamily", "font-size": "fontSize", "font-style": "fontStyle", "font-weight": "fontWeight", "text-anchor": "textAlign", visibility: "visibility", display: "display", }, dT = G(pT), fT = { "alignment-baseline": "textBaseline", "stop-color": "stopColor", }, gT = G(fT), yT = (function () { function t() { (this._defs = {}), (this._root = null); } return ( (t.prototype.parse = function (t, e) { e = e || {}; var n = cT(t); this._defsUsePending = []; var i = new Br(); this._root = i; var r = [], o = n.getAttribute("viewBox") || "", a = parseFloat(n.getAttribute("width") || e.width), s = parseFloat(n.getAttribute("height") || e.height); isNaN(a) && (a = null), isNaN(s) && (s = null), wT(n, i, null, !0, !1); for (var l, u, h = n.firstChild; h; ) this._parseNode(h, i, r, null, !1, !1), (h = h.nextSibling); if ( ((function (t, e) { for (var n = 0; n < e.length; n++) { var i = e[n]; i[0].style[i[1]] = t[i[2]]; } })(this._defs, this._defsUsePending), (this._defsUsePending = []), o) ) { var c = TT(o); c.length >= 4 && (l = { x: parseFloat(c[0] || 0), y: parseFloat(c[1] || 0), width: parseFloat(c[2]), height: parseFloat(c[3]), }); } if ( l && null != a && null != s && ((u = LT(l, { x: 0, y: 0, width: a, height: s })), !e.ignoreViewBox) ) { var p = i; (i = new Br()).add(p), (p.scaleX = p.scaleY = u.scale), (p.x = u.x), (p.y = u.y); } return ( e.ignoreRootClip || null == a || null == s || i.setClipPath( new Ws({ shape: { x: 0, y: 0, width: a, height: s }, }) ), { root: i, width: a, height: s, viewBoxRect: l, viewBoxTransform: u, named: r, } ); }), (t.prototype._parseNode = function (t, e, n, i, r, o) { var a, s = t.nodeName.toLowerCase(), l = i; if ( ("defs" === s && (r = !0), "text" === s && (o = !0), "defs" === s || "switch" === s) ) a = e; else { if (!r) { var u = lT[s]; if (u && _t(lT, s)) { a = u.call(this, t, e); var h = t.getAttribute("name"); if (h) { var c = { name: h, namedFrom: null, svgNodeTagLower: s, el: a, }; n.push(c), "g" === s && (l = c); } else i && n.push({ name: i.name, namedFrom: i, svgNodeTagLower: s, el: a, }); e.add(a); } } var p = vT[s]; if (p && _t(vT, s)) { var d = p.call(this, t), f = t.getAttribute("id"); f && (this._defs[f] = d); } } if (a && a.isGroup) for (var g = t.firstChild; g; ) 1 === g.nodeType ? this._parseNode(g, a, n, l, r, o) : 3 === g.nodeType && o && this._parseText(g, a), (g = g.nextSibling); }), (t.prototype._parseText = function (t, e) { var n = new Ps({ style: { text: t.textContent }, silent: !0, x: this._textX || 0, y: this._textY || 0, }); _T(e, n), wT(t, n, this._defsUsePending, !1, !1), (function (t, e) { var n = e.__selfStyle; if (n) { var i = n.textBaseline, r = i; i && "auto" !== i ? "baseline" === i ? (r = "alphabetic") : "before-edge" === i || "text-before-edge" === i ? (r = "top") : "after-edge" === i || "text-after-edge" === i ? (r = "bottom") : ("central" !== i && "mathematical" !== i) || (r = "middle") : (r = "alphabetic"), (t.style.textBaseline = r); } var o = e.__inheritedStyle; if (o) { var a = o.textAlign, s = a; a && ("middle" === a && (s = "center"), (t.style.textAlign = s)); } })(n, e); var i = n.style, r = i.fontSize; r && r < 9 && ((i.fontSize = 9), (n.scaleX *= r / 9), (n.scaleY *= r / 9)); var o = (i.fontSize || i.fontFamily) && [ i.fontStyle, i.fontWeight, (i.fontSize || 12) + "px", i.fontFamily || "sans-serif", ].join(" "); i.font = o; var a = n.getBoundingRect(); return (this._textX += a.width), e.add(n), n; }), (t.internalField = void (lT = { g: function (t, e) { var n = new Br(); return ( _T(e, n), wT(t, n, this._defsUsePending, !1, !1), n ); }, rect: function (t, e) { var n = new Ws(); return ( _T(e, n), wT(t, n, this._defsUsePending, !1, !1), n.setShape({ x: parseFloat(t.getAttribute("x") || "0"), y: parseFloat(t.getAttribute("y") || "0"), width: parseFloat( t.getAttribute("width") || "0" ), height: parseFloat( t.getAttribute("height") || "0" ), }), (n.silent = !0), n ); }, circle: function (t, e) { var n = new Su(); return ( _T(e, n), wT(t, n, this._defsUsePending, !1, !1), n.setShape({ cx: parseFloat(t.getAttribute("cx") || "0"), cy: parseFloat(t.getAttribute("cy") || "0"), r: parseFloat(t.getAttribute("r") || "0"), }), (n.silent = !0), n ); }, line: function (t, e) { var n = new Ku(); return ( _T(e, n), wT(t, n, this._defsUsePending, !1, !1), n.setShape({ x1: parseFloat(t.getAttribute("x1") || "0"), y1: parseFloat(t.getAttribute("y1") || "0"), x2: parseFloat(t.getAttribute("x2") || "0"), y2: parseFloat(t.getAttribute("y2") || "0"), }), (n.silent = !0), n ); }, ellipse: function (t, e) { var n = new Iu(); return ( _T(e, n), wT(t, n, this._defsUsePending, !1, !1), n.setShape({ cx: parseFloat(t.getAttribute("cx") || "0"), cy: parseFloat(t.getAttribute("cy") || "0"), rx: parseFloat(t.getAttribute("rx") || "0"), ry: parseFloat(t.getAttribute("ry") || "0"), }), (n.silent = !0), n ); }, polygon: function (t, e) { var n, i = t.getAttribute("points"); i && (n = bT(i)); var r = new Xu({ shape: { points: n || [] }, silent: !0, }); return ( _T(e, r), wT(t, r, this._defsUsePending, !1, !1), r ); }, polyline: function (t, e) { var n, i = t.getAttribute("points"); i && (n = bT(i)); var r = new Zu({ shape: { points: n || [] }, silent: !0, }); return ( _T(e, r), wT(t, r, this._defsUsePending, !1, !1), r ); }, image: function (t, e) { var n = new Ns(); return ( _T(e, n), wT(t, n, this._defsUsePending, !1, !1), n.setStyle({ image: t.getAttribute("xlink:href") || t.getAttribute("href"), x: +t.getAttribute("x"), y: +t.getAttribute("y"), width: +t.getAttribute("width"), height: +t.getAttribute("height"), }), (n.silent = !0), n ); }, text: function (t, e) { var n = t.getAttribute("x") || "0", i = t.getAttribute("y") || "0", r = t.getAttribute("dx") || "0", o = t.getAttribute("dy") || "0"; (this._textX = parseFloat(n) + parseFloat(r)), (this._textY = parseFloat(i) + parseFloat(o)); var a = new Br(); return ( _T(e, a), wT(t, a, this._defsUsePending, !1, !0), a ); }, tspan: function (t, e) { var n = t.getAttribute("x"), i = t.getAttribute("y"); null != n && (this._textX = parseFloat(n)), null != i && (this._textY = parseFloat(i)); var r = t.getAttribute("dx") || "0", o = t.getAttribute("dy") || "0", a = new Br(); return ( _T(e, a), wT(t, a, this._defsUsePending, !1, !0), (this._textX += parseFloat(r)), (this._textY += parseFloat(o)), a ); }, path: function (t, e) { var n = _u(t.getAttribute("d") || ""); return ( _T(e, n), wT(t, n, this._defsUsePending, !1, !1), (n.silent = !0), n ); }, })), t ); })(), vT = { lineargradient: function (t) { var e = parseInt(t.getAttribute("x1") || "0", 10), n = parseInt(t.getAttribute("y1") || "0", 10), i = parseInt(t.getAttribute("x2") || "10", 10), r = parseInt(t.getAttribute("y2") || "0", 10), o = new oh(e, n, i, r); return mT(t, o), xT(t, o), o; }, radialgradient: function (t) { var e = parseInt(t.getAttribute("cx") || "0", 10), n = parseInt(t.getAttribute("cy") || "0", 10), i = parseInt(t.getAttribute("r") || "0", 10), r = new ah(e, n, i); return mT(t, r), xT(t, r), r; }, }; function mT(t, e) { "userSpaceOnUse" === t.getAttribute("gradientUnits") && (e.global = !0); } function xT(t, e) { for (var n = t.firstChild; n; ) { if (1 === n.nodeType && "stop" === n.nodeName.toLocaleLowerCase()) { var i = n.getAttribute("offset"), r = void 0; r = i && i.indexOf("%") > 0 ? parseInt(i, 10) / 100 : i ? parseFloat(i) : 0; var o = {}; kT(n, o, o); var a = o.stopColor || n.getAttribute("stop-color") || "#000000"; e.colorStops.push({ offset: r, color: a }); } n = n.nextSibling; } } function _T(t, e) { t && t.__inheritedStyle && (e.__inheritedStyle || (e.__inheritedStyle = {}), k(e.__inheritedStyle, t.__inheritedStyle)); } function bT(t) { for (var e = TT(t), n = [], i = 0; i < e.length; i += 2) { var r = parseFloat(e[i]), o = parseFloat(e[i + 1]); n.push([r, o]); } return n; } function wT(t, e, n, i, r) { var o = e, a = (o.__inheritedStyle = o.__inheritedStyle || {}), s = {}; 1 === t.nodeType && ((function (t, e) { var n = t.getAttribute("transform"); if (n) { n = n.replace(/,/g, " "); var i = [], r = null; n.replace(CT, function (t, e, n) { return i.push(e, n), ""; }); for (var o = i.length - 1; o > 0; o -= 2) { var a = i[o], s = i[o - 1], l = TT(a); switch (((r = r || [1, 0, 0, 1, 0, 0]), s)) { case "translate": we(r, r, [ parseFloat(l[0]), parseFloat(l[1] || "0"), ]); break; case "scale": Me(r, r, [ parseFloat(l[0]), parseFloat(l[1] || l[0]), ]); break; case "rotate": Se(r, r, -parseFloat(l[0]) * DT, [ parseFloat(l[1] || "0"), parseFloat(l[2] || "0"), ]); break; case "skewX": be( r, [ 1, 0, Math.tan(parseFloat(l[0]) * DT), 1, 0, 0, ], r ); break; case "skewY": be( r, [ 1, Math.tan(parseFloat(l[0]) * DT), 0, 1, 0, 0, ], r ); break; case "matrix": (r[0] = parseFloat(l[0])), (r[1] = parseFloat(l[1])), (r[2] = parseFloat(l[2])), (r[3] = parseFloat(l[3])), (r[4] = parseFloat(l[4])), (r[5] = parseFloat(l[5])); } } e.setLocalTransform(r); } })(t, e), kT(t, a, s), i || (function (t, e, n) { for (var i = 0; i < dT.length; i++) { var r = dT[i]; null != (o = t.getAttribute(r)) && (e[pT[r]] = o); } for (i = 0; i < gT.length; i++) { var o; r = gT[i]; null != (o = t.getAttribute(r)) && (n[fT[r]] = o); } })(t, a, s)), (o.style = o.style || {}), null != a.fill && (o.style.fill = MT(o, "fill", a.fill, n)), null != a.stroke && (o.style.stroke = MT(o, "stroke", a.stroke, n)), E( [ "lineWidth", "opacity", "fillOpacity", "strokeOpacity", "miterLimit", "fontSize", ], function (t) { null != a[t] && (o.style[t] = parseFloat(a[t])); } ), E( [ "lineDashOffset", "lineCap", "lineJoin", "fontWeight", "fontFamily", "fontStyle", "textAlign", ], function (t) { null != a[t] && (o.style[t] = a[t]); } ), r && (o.__selfStyle = s), a.lineDash && (o.style.lineDash = z(TT(a.lineDash), function (t) { return parseFloat(t); })), ("hidden" !== a.visibility && "collapse" !== a.visibility) || (o.invisible = !0), "none" === a.display && (o.ignore = !0); } var ST = /^url\(\s*#(.*?)\)/; function MT(t, e, n, i) { var r = n && n.match(ST); if (!r) return "none" === n && (n = null), n; var o = ut(r[1]); i.push([t, e, o]); } var IT = /-?([0-9]*\.)?[0-9]+([eE]-?[0-9]+)?/g; function TT(t) { return t.match(IT) || []; } var CT = /(translate|scale|rotate|skewX|skewY|matrix)\(([\-\s0-9\.eE,]*)\)/g, DT = Math.PI / 180; var AT = /([^\s:;]+)\s*:\s*([^:;]+)/g; function kT(t, e, n) { var i, r = t.getAttribute("style"); if (r) for (AT.lastIndex = 0; null != (i = AT.exec(r)); ) { var o = i[1], a = _t(pT, o) ? pT[o] : null; a && (e[a] = i[2]); var s = _t(fT, o) ? fT[o] : null; s && (n[s] = i[2]); } } function LT(t, e) { var n = e.width / t.width, i = e.height / t.height, r = Math.min(n, i); return { scale: r, x: -(t.x + t.width / 2) * r + (e.x + e.width / 2), y: -(t.y + t.height / 2) * r + (e.y + e.height / 2), }; } var PT = yt([ "rect", "circle", "line", "ellipse", "polygon", "polyline", "path", "text", "tspan", "g", ]), OT = (function () { function t(t, e) { (this.type = "geoSVG"), (this._usedGraphicMap = yt()), (this._freedGraphics = []), (this._mapName = t), (this._parsedXML = cT(e)); } return ( (t.prototype.load = function () { var t = this._firstGraphic; if (!t) { (t = this._firstGraphic = this._buildGraphic(this._parsedXML)), this._freedGraphics.push(t), (this._boundingRect = this._firstGraphic.boundingRect.clone()); var e = (function (t) { var e = [], n = yt(); return ( E(t, function (t) { if (null == t.namedFrom) { var i = new F_(t.name, t.el); e.push(i), n.set(t.name, i); } }), { regions: e, regionsMap: n } ); })(t.named), n = e.regions, i = e.regionsMap; (this._regions = n), (this._regionsMap = i); } return { boundingRect: this._boundingRect, regions: this._regions, regionsMap: this._regionsMap, }; }), (t.prototype._buildGraphic = function (t) { var e, n, i, r; try { lt( null != (n = (e = (t && ((i = t), (r = { ignoreViewBox: !0, ignoreRootClip: !0, }), new yT().parse(i, r))) || {}).root) ); } catch (t) { throw new Error("Invalid svg format\n" + t.message); } var o = new Br(); o.add(n), (o.isGeoSVGGraphicRoot = !0); var a = e.width, s = e.height, l = e.viewBoxRect, u = this._boundingRect; if (!u) { var h = void 0, c = void 0, p = void 0, d = void 0; if ( (null != a ? ((h = 0), (p = a)) : l && ((h = l.x), (p = l.width)), null != s ? ((c = 0), (d = s)) : l && ((c = l.y), (d = l.height)), null == h || null == c) ) { var f = n.getBoundingRect(); null == h && ((h = f.x), (p = f.width)), null == c && ((c = f.y), (d = f.height)); } u = this._boundingRect = new ze(h, c, p, d); } if (l) { var g = LT(l, u); (n.scaleX = n.scaleY = g.scale), (n.x = g.x), (n.y = g.y); } o.setClipPath(new Ws({ shape: u.plain() })); var y = []; return ( E(e.named, function (t) { var e; null != PT.get(t.svgNodeTagLower) && (y.push(t), ((e = t.el).silent = !1), e.isGroup && e.traverse(function (t) { t.silent = !1; })); }), { root: o, boundingRect: u, named: y } ); }), (t.prototype.useGraphic = function (t) { var e = this._usedGraphicMap, n = e.get(t); return ( n || ((n = this._freedGraphics.pop() || this._buildGraphic(this._parsedXML)), e.set(t, n), n) ); }), (t.prototype.freeGraphic = function (t) { var e = this._usedGraphicMap, n = e.get(t); n && (e.removeKey(t), this._freedGraphics.push(n)); }), t ); })(); for ( var RT = [126, 25], NT = "南海诸岛", ET = [ [ [0, 3.5], [7, 11.2], [15, 11.9], [30, 7], [42, 0.7], [52, 0.7], [56, 7.7], [59, 0.7], [64, 0.7], [64, 0], [5, 0], [0, 3.5], ], [ [13, 16.1], [19, 14.7], [16, 21.7], [11, 23.1], [13, 16.1], ], [ [12, 32.2], [14, 38.5], [15, 38.5], [13, 32.2], [12, 32.2], ], [ [16, 47.6], [12, 53.2], [13, 53.2], [18, 47.6], [16, 47.6], ], [ [6, 64.4], [8, 70], [9, 70], [8, 64.4], [6, 64.4], ], [ [23, 82.6], [29, 79.8], [30, 79.8], [25, 82.6], [23, 82.6], ], [ [37, 70.7], [43, 62.3], [44, 62.3], [39, 70.7], [37, 70.7], ], [ [48, 51.1], [51, 45.5], [53, 45.5], [50, 51.1], [48, 51.1], ], [ [51, 35], [51, 28.7], [53, 28.7], [53, 35], [51, 35], ], [ [52, 22.4], [55, 17.5], [56, 17.5], [53, 22.4], [52, 22.4], ], [ [58, 12.6], [62, 7], [63, 7], [60, 12.6], [58, 12.6], ], [ [0, 3.5], [0, 93.1], [64, 93.1], [64, 0], [63, 0], [63, 92.4], [1, 92.4], [1, 3.5], [0, 3.5], ], ], zT = 0; zT < ET.length; zT++ ) for (var VT = 0; VT < ET[zT].length; VT++) (ET[zT][VT][0] /= 10.5), (ET[zT][VT][1] /= -14), (ET[zT][VT][0] += RT[0]), (ET[zT][VT][1] += RT[1]); var BT = { 南海诸岛: [32, 80], 广东: [0, -10], 香港: [10, 5], 澳门: [-10, 10], 天津: [5, 5], }; var FT = [ [ [123.45165252685547, 25.73527164402261], [123.49731445312499, 25.73527164402261], [123.49731445312499, 25.750734064600884], [123.45165252685547, 25.750734064600884], [123.45165252685547, 25.73527164402261], ], ]; var GT = (function () { function t(t, e, n) { var i; (this.type = "geoJSON"), (this._parsedMap = yt()), (this._mapName = t), (this._specialAreas = n), (this._geoJSON = U((i = e)) ? "undefined" != typeof JSON && JSON.parse ? JSON.parse(i) : new Function("return (" + i + ");")() : i); } return ( (t.prototype.load = function (t, e) { e = e || "name"; var n = this._parsedMap.get(e); if (!n) { var i = this._parseToRegions(e); n = this._parsedMap.set(e, { regions: i, boundingRect: WT(i), }); } var r = yt(), o = []; return ( E(n.regions, function (e) { var n = e.name; t && _t(t, n) && (e = e.cloneShallow((n = t[n]))), o.push(e), r.set(n, e); }), { regions: o, boundingRect: n.boundingRect || new ze(0, 0, 0, 0), regionsMap: r, } ); }), (t.prototype._parseToRegions = function (t) { var e, n = this._mapName, i = this._geoJSON; try { e = i ? H_(i, t) : []; } catch (t) { throw new Error("Invalid geoJson format\n" + t.message); } return ( (function (t, e) { if ("china" === t) { for (var n = 0; n < e.length; n++) if (e[n].name === NT) return; e.push( new B_( NT, z(ET, function (t) { return { type: "polygon", exterior: t }; }), RT ) ); } })(n, e), E( e, function (t) { var e = t.name; !(function (t, e) { if ("china" === t) { var n = BT[e.name]; if (n) { var i = e.getCenter(); (i[0] += n[0] / 10.5), (i[1] += -n[1] / 14), e.setCenter(i); } } })(n, t), (function (t, e) { "china" === t && "台湾" === e.name && e.geometries.push({ type: "polygon", exterior: FT[0], }); })(n, t); var i = this._specialAreas && this._specialAreas[e]; i && t.transformTo(i.left, i.top, i.width, i.height); }, this ), e ); }), (t.prototype.getMapForUser = function () { return { geoJson: this._geoJSON, geoJSON: this._geoJSON, specialAreas: this._specialAreas, }; }), t ); })(); function WT(t) { for (var e, n = 0; n < t.length; n++) { var i = t[n].getBoundingRect(); (e = e || i.clone()).union(i); } return e; } var HT = yt(), YT = function (t, e, n) { if (e.svg) { var i = new OT(t, e.svg); HT.set(t, i); } else { var r = e.geoJson || e.geoJSON; r && !e.features ? (n = e.specialAreas) : (r = e); i = new GT(t, r, n); HT.set(t, i); } }, XT = function (t) { return HT.get(t); }, UT = function (t) { var e = HT.get(t); return e && "geoJSON" === e.type && e.getMapForUser(); }, ZT = function (t, e, n) { var i = HT.get(t); if (i) return i.load(e, n); }, jT = [ "rect", "circle", "line", "ellipse", "polygon", "polyline", "path", ], qT = yt(jT), KT = yt(jT.concat(["g"])), $T = yt(jT.concat(["g"])), JT = Vo(); function QT(t) { var e = t.getItemStyle(), n = t.get("areaColor"); return null != n && (e.fill = n), e; } function tC(t) { var e = t.style; e && ((e.stroke = e.stroke || e.fill), (e.fill = null)); } var eC = (function () { function t(t) { var e = new Br(); (this.uid = Ac("ec_map_draw")), (this._controller = new nT(t.getZr())), (this._controllerHost = { target: e }), (this.group = e), e.add((this._regionsGroup = new Br())), e.add((this._svgGroup = new Br())); } return ( (t.prototype.draw = function (t, e, n, i, r) { var o = "geo" === t.mainType, a = t.getData && t.getData(); o && e.eachComponent( { mainType: "series", subType: "map" }, function (e) { a || e.getHostGeoModel() !== t || (a = e.getData()); } ); var s = t.coordinateSystem, l = this._regionsGroup, u = this.group, h = s.getTransformInfo(), c = h.raw, p = h.roam; !l.childAt(0) || r ? ((u.x = p.x), (u.y = p.y), (u.scaleX = p.scaleX), (u.scaleY = p.scaleY), u.dirty()) : vh(u, p, t); var d = a && a.getVisual("visualMeta") && a.getVisual("visualMeta").length > 0, f = { api: n, geo: s, mapOrGeoModel: t, data: a, isVisualEncodedByVisualMap: d, isGeo: o, transformInfoRaw: c, }; "geoJSON" === s.resourceType ? this._buildGeoJSON(f) : "geoSVG" === s.resourceType && this._buildSVG(f), this._updateController(t, e, n), this._updateMapSelectHandler(t, l, n, i); }), (t.prototype._buildGeoJSON = function (t) { var e = (this._regionsGroupByName = yt()), n = yt(), i = this._regionsGroup, r = t.transformInfoRaw, o = t.mapOrGeoModel, a = t.data, s = t.geo.projection, l = s && s.stream; function u(t, e) { return ( e && (t = e(t)), t && [t[0] * r.scaleX + r.x, t[1] * r.scaleY + r.y] ); } function h(t) { for ( var e = [], n = !l && s && s.project, i = 0; i < t.length; ++i ) { var r = u(t[i], n); r && e.push(r); } return e; } function c(t) { return { shape: { points: h(t) } }; } i.removeAll(), E(t.geo.regions, function (r) { var h = r.name, p = e.get(h), d = n.get(h) || {}, f = d.dataIdx, g = d.regionModel; if (!p) { (p = e.set(h, new Br())), i.add(p), (f = a ? a.indexOfName(h) : null); var y = (g = t.isGeo ? o.getRegionModel(h) : a ? a.getItemModel(f) : null).get("silent", !0); null != y && (p.silent = y), n.set(h, { dataIdx: f, regionModel: g }); } var v = [], m = []; E(r.geometries, function (t) { if ("polygon" === t.type) { var e = [t.exterior].concat(t.interiors || []); l && (e = sC(e, l)), E(e, function (t) { v.push(new Xu(c(t))); }); } else { var n = t.points; l && (n = sC(n, l, !0)), E(n, function (t) { m.push(new Zu(c(t))); }); } }); var x = u(r.getCenter(), s && s.project); function _(e, n) { if (e.length) { var i = new ih({ culling: !0, segmentIgnoreThreshold: 1, shape: { paths: e }, }); p.add(i), nC(t, i, f, g), iC(t, i, h, g, o, f, x), n && (tC(i), E(i.states, tC)); } } _(v), _(m, !0); }), e.each(function (e, i) { var r = n.get(i), a = r.dataIdx, s = r.regionModel; rC(t, e, i, s, o, a), oC(t, e, i, s, o), aC(t, e, i, s, o); }, this); }), (t.prototype._buildSVG = function (t) { var e = t.geo.map, n = t.transformInfoRaw; (this._svgGroup.x = n.x), (this._svgGroup.y = n.y), (this._svgGroup.scaleX = n.scaleX), (this._svgGroup.scaleY = n.scaleY), this._svgResourceChanged(e) && (this._freeSVG(), this._useSVG(e)); var i = (this._svgDispatcherMap = yt()), r = !1; E( this._svgGraphicRecord.named, function (e) { var n = e.name, o = t.mapOrGeoModel, a = t.data, s = e.svgNodeTagLower, l = e.el, u = a ? a.indexOfName(n) : null, h = o.getRegionModel(n); null != qT.get(s) && l instanceof Da && nC(t, l, u, h), l instanceof Da && (l.culling = !0); var c = h.get("silent", !0); (null != c && (l.silent = c), (l.z2EmphasisLift = 0), e.namedFrom) || (null != $T.get(s) && iC(t, l, n, h, o, u, null), rC(t, l, n, h, o, u), oC(t, l, n, h, o), null != KT.get(s) && ("self" === aC(t, l, n, h, o) && (r = !0), (i.get(n) || i.set(n, [])).push(l))); }, this ), this._enableBlurEntireSVG(r, t); }), (t.prototype._enableBlurEntireSVG = function (t, e) { if (t && e.isGeo) { var n = e.mapOrGeoModel .getModel(["blur", "itemStyle"]) .getItemStyle().opacity; this._svgGraphicRecord.root.traverse(function (t) { if (!t.isGroup) { kl(t); var e = t.ensureState("blur").style || {}; null == e.opacity && null != n && (e.opacity = n), t.ensureState("emphasis"); } }); } }), (t.prototype.remove = function () { this._regionsGroup.removeAll(), (this._regionsGroupByName = null), this._svgGroup.removeAll(), this._freeSVG(), this._controller.dispose(), (this._controllerHost = null); }), (t.prototype.findHighDownDispatchers = function (t, e) { if (null == t) return []; var n = e.coordinateSystem; if ("geoJSON" === n.resourceType) { var i = this._regionsGroupByName; if (i) { var r = i.get(t); return r ? [r] : []; } } else if ("geoSVG" === n.resourceType) return ( (this._svgDispatcherMap && this._svgDispatcherMap.get(t)) || [] ); }), (t.prototype._svgResourceChanged = function (t) { return this._svgMapName !== t; }), (t.prototype._useSVG = function (t) { var e = XT(t); if (e && "geoSVG" === e.type) { var n = e.useGraphic(this.uid); this._svgGroup.add(n.root), (this._svgGraphicRecord = n), (this._svgMapName = t); } }), (t.prototype._freeSVG = function () { var t = this._svgMapName; if (null != t) { var e = XT(t); e && "geoSVG" === e.type && e.freeGraphic(this.uid), (this._svgGraphicRecord = null), (this._svgDispatcherMap = null), this._svgGroup.removeAll(), (this._svgMapName = null); } }), (t.prototype._updateController = function (t, e, n) { var i = t.coordinateSystem, r = this._controller, o = this._controllerHost; (o.zoomLimit = t.get("scaleLimit")), (o.zoom = i.getZoom()), r.enable(t.get("roam") || !1); var a = t.mainType; function s() { var e = { type: "geoRoam", componentType: a }; return (e[a + "Id"] = t.id), e; } r.off("pan").on( "pan", function (t) { (this._mouseDownFlag = !1), aT(o, t.dx, t.dy), n.dispatchAction( A(s(), { dx: t.dx, dy: t.dy, animation: { duration: 0 }, }) ); }, this ), r.off("zoom").on( "zoom", function (t) { (this._mouseDownFlag = !1), sT(o, t.scale, t.originX, t.originY), n.dispatchAction( A(s(), { totalZoom: o.zoom, zoom: t.scale, originX: t.originX, originY: t.originY, animation: { duration: 0 }, }) ); }, this ), r.setPointerChecker(function (e, r, o) { return i.containPoint([r, o]) && !hT(e, n, t); }); }), (t.prototype.resetForLabelLayout = function () { this.group.traverse(function (t) { var e = t.getTextContent(); e && (e.ignore = JT(e).ignore); }); }), (t.prototype._updateMapSelectHandler = function (t, e, n, i) { var r = this; e.off("mousedown"), e.off("click"), t.get("selectedMode") && (e.on("mousedown", function () { r._mouseDownFlag = !0; }), e.on("click", function (t) { r._mouseDownFlag && (r._mouseDownFlag = !1); })); }), t ); })(); function nC(t, e, n, i) { var r = i.getModel("itemStyle"), o = i.getModel(["emphasis", "itemStyle"]), a = i.getModel(["blur", "itemStyle"]), s = i.getModel(["select", "itemStyle"]), l = QT(r), u = QT(o), h = QT(s), c = QT(a), p = t.data; if (p) { var d = p.getItemVisual(n, "style"), f = p.getItemVisual(n, "decal"); t.isVisualEncodedByVisualMap && d.fill && (l.fill = d.fill), f && (l.decal = mv(f, t.api)); } e.setStyle(l), (e.style.strokeNoScale = !0), (e.ensureState("emphasis").style = u), (e.ensureState("select").style = h), (e.ensureState("blur").style = c), kl(e); } function iC(t, e, n, i, r, o, a) { var s = t.data, l = t.isGeo, u = s && isNaN(s.get(s.mapDimension("value"), o)), h = s && s.getItemLayout(o); if (l || u || (h && h.showLabel)) { var c = l ? n : o, p = void 0; (!s || o >= 0) && (p = r); var d = a ? { normal: { align: "center", verticalAlign: "middle" } } : null; ic( e, rc(i), { labelFetcher: p, labelDataIndex: c, defaultText: n }, d ); var f = e.getTextContent(); if (f && ((JT(f).ignore = f.ignore), e.textConfig && a)) { var g = e.getBoundingRect().clone(); (e.textConfig.layoutRect = g), (e.textConfig.position = [ ((a[0] - g.x) / g.width) * 100 + "%", ((a[1] - g.y) / g.height) * 100 + "%", ]); } e.disableLabelAnimation = !0; } else e.removeTextContent(), e.removeTextConfig(), (e.disableLabelAnimation = null); } function rC(t, e, n, i, r, o) { t.data ? t.data.setItemGraphicEl(o, e) : (rl(e).eventData = { componentType: "geo", componentIndex: r.componentIndex, geoIndex: r.componentIndex, name: n, region: (i && i.option) || {}, }); } function oC(t, e, n, i, r) { t.data || Kh({ el: e, componentModel: r, itemName: n, itemTooltipOption: i.get("tooltip"), }); } function aC(t, e, n, i, r) { e.highDownSilentOnTouch = !!r.get("selectedMode"); var o = i.getModel("emphasis"), a = o.get("focus"); return ( Zl(e, a, o.get("blurScope"), o.get("disabled")), t.isGeo && (function (t, e, n) { var i = rl(t); (i.componentMainType = e.mainType), (i.componentIndex = e.componentIndex), (i.componentHighDownName = n); })(e, r, n), a ); } function sC(t, e, n) { var i, r = []; function o() { i = []; } function a() { i.length && (r.push(i), (i = [])); } var s = e({ polygonStart: o, polygonEnd: a, lineStart: o, lineEnd: a, point: function (t, e) { isFinite(t) && isFinite(e) && i.push([t, e]); }, sphere: function () {}, }); return ( !n && s.polygonStart(), E(t, function (t) { s.lineStart(); for (var e = 0; e < t.length; e++) s.point(t[e][0], t[e][1]); s.lineEnd(); }), !n && s.polygonEnd(), r ); } var lC = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { if ( !i || "mapToggleSelect" !== i.type || i.from !== this.uid ) { var r = this.group; if ((r.removeAll(), !t.getHostGeoModel())) { if ( (this._mapDraw && i && "geoRoam" === i.type && this._mapDraw.resetForLabelLayout(), i && "geoRoam" === i.type && "series" === i.componentType && i.seriesId === t.id) ) (o = this._mapDraw) && r.add(o.group); else if (t.needsDrawMap) { var o = this._mapDraw || new eC(n); r.add(o.group), o.draw(t, e, n, this, i), (this._mapDraw = o); } else this._mapDraw && this._mapDraw.remove(), (this._mapDraw = null); t.get("showLegendSymbol") && e.getComponent("legend") && this._renderSymbols(t, e, n); } } }), (e.prototype.remove = function () { this._mapDraw && this._mapDraw.remove(), (this._mapDraw = null), this.group.removeAll(); }), (e.prototype.dispose = function () { this._mapDraw && this._mapDraw.remove(), (this._mapDraw = null); }), (e.prototype._renderSymbols = function (t, e, n) { var i = t.originalData, r = this.group; i.each(i.mapDimension("value"), function (e, n) { if (!isNaN(e)) { var o = i.getItemLayout(n); if (o && o.point) { var a = o.point, s = o.offset, l = new Su({ style: { fill: t.getData().getVisual("style") .fill, }, shape: { cx: a[0] + 9 * s, cy: a[1], r: 3, }, silent: !0, z2: 8 + (s ? 0 : 11), }); if (!s) { var u = t.mainSeries.getData(), h = i.getName(n), c = u.indexOfName(h), p = i.getItemModel(n), d = p.getModel("label"), f = u.getItemGraphicEl(c); ic(l, rc(p), { labelFetcher: { getFormattedLabel: function (e, n) { return t.getFormattedLabel( c, n ); }, }, defaultText: h, }), (l.disableLabelAnimation = !0), d.get("position") || l.setTextConfig({ position: "bottom", }), (f.onHoverStateChange = function (t) { Dl(l, t); }); } r.add(l); } } }); }), (e.type = "map"), e ); })(Og), uC = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.needsDrawMap = !1), (n.seriesGroup = []), (n.getTooltipPosition = function (t) { if (null != t) { var e = this.getData().getName(t), n = this.coordinateSystem, i = n.getRegion(e); return i && n.dataToPoint(i.getCenter()); } }), n ); } return ( n(e, t), (e.prototype.getInitialData = function (t) { for ( var e = RM(this, { coordDimensions: ["value"], encodeDefaulter: H(ed, this), }), n = yt(), i = [], r = 0, o = e.count(); r < o; r++ ) { var a = e.getName(r); n.set(a, r); } return ( E( ZT( this.getMapType(), this.option.nameMap, this.option.nameProperty ).regions, function (t) { var r, o = t.name, a = n.get(o), s = t.properties && t.properties.echartsStyle; null == a ? ((r = { name: o }), i.push(r)) : (r = e.getRawDataItem(a)), s && C(r, s); } ), e.appendData(i), e ); }), (e.prototype.getHostGeoModel = function () { var t = this.option.geoIndex; return null != t ? this.ecModel.getComponent("geo", t) : null; }), (e.prototype.getMapType = function () { return (this.getHostGeoModel() || this).option.map; }), (e.prototype.getRawValue = function (t) { var e = this.getData(); return e.get(e.mapDimension("value"), t); }), (e.prototype.getRegionModel = function (t) { var e = this.getData(); return e.getItemModel(e.indexOfName(t)); }), (e.prototype.formatTooltip = function (t, e, n) { for ( var i = this.getData(), r = this.getRawValue(t), o = i.getName(t), a = this.seriesGroup, s = [], l = 0; l < a.length; l++ ) { var u = a[l].originalData.indexOfName(o), h = i.mapDimension("value"); isNaN(a[l].originalData.get(h, u)) || s.push(a[l].name); } return og("section", { header: s.join(", "), noHeader: !s.length, blocks: [og("nameValue", { name: o, value: r })], }); }), (e.prototype.setZoom = function (t) { this.option.zoom = t; }), (e.prototype.setCenter = function (t) { this.option.center = t; }), (e.prototype.getLegendIcon = function (t) { var e = t.icon || "roundRect", n = Xy( e, 0, 0, t.itemWidth, t.itemHeight, t.itemStyle.fill ); return ( n.setStyle(t.itemStyle), (n.style.stroke = "none"), e.indexOf("empty") > -1 && ((n.style.stroke = n.style.fill), (n.style.fill = "#fff"), (n.style.lineWidth = 2)), n ); }), (e.type = "series.map"), (e.dependencies = ["geo"]), (e.layoutMode = "box"), (e.defaultOption = { z: 2, coordinateSystem: "geo", map: "", left: "center", top: "center", aspectScale: null, showLegendSymbol: !0, boundingCoords: null, center: null, zoom: 1, scaleLimit: null, selectedMode: !0, label: { show: !1, color: "#000" }, itemStyle: { borderWidth: 0.5, borderColor: "#444", areaColor: "#eee", }, emphasis: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { areaColor: "rgba(255,215,0,0.8)" }, }, select: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { color: "rgba(255,215,0,0.8)" }, }, nameProperty: "name", }), e ); })(bg); function hC(t) { var e = {}; t.eachSeriesByType("map", function (t) { var n = t.getHostGeoModel(), i = n ? "o" + n.id : "i" + t.getMapType(); (e[i] = e[i] || []).push(t); }), E(e, function (t, e) { for ( var n, i, r, o = ((n = z(t, function (t) { return t.getData(); })), (i = t[0].get("mapValueCalculation")), (r = {}), E(n, function (t) { t.each( t.mapDimension("value"), function (e, n) { var i = "ec-" + t.getName(n); (r[i] = r[i] || []), isNaN(e) || r[i].push(e); } ); }), n[0].map( n[0].mapDimension("value"), function (t, e) { for ( var o = "ec-" + n[0].getName(e), a = 0, s = 1 / 0, l = -1 / 0, u = r[o].length, h = 0; h < u; h++ ) (s = Math.min(s, r[o][h])), (l = Math.max(l, r[o][h])), (a += r[o][h]); return 0 === u ? NaN : "min" === i ? s : "max" === i ? l : "average" === i ? a / u : a; } )), a = 0; a < t.length; a++ ) t[a].originalData = t[a].getData(); for (a = 0; a < t.length; a++) (t[a].seriesGroup = t), (t[a].needsDrawMap = 0 === a && !t[a].getHostGeoModel()), t[a].setData(o.cloneShallow()), (t[a].mainSeries = t[0]); }); } function cC(t) { var e = {}; t.eachSeriesByType("map", function (n) { var i = n.getMapType(); if (!n.getHostGeoModel() && !e[i]) { var r = {}; E(n.seriesGroup, function (e) { var n = e.coordinateSystem, i = e.originalData; e.get("showLegendSymbol") && t.getComponent("legend") && i.each(i.mapDimension("value"), function (t, e) { var o = i.getName(e), a = n.getRegion(o); if (a && !isNaN(t)) { var s = r[o] || 0, l = n.dataToPoint(a.getCenter()); (r[o] = s + 1), i.setItemLayout(e, { point: l, offset: s }); } }); }); var o = n.getData(); o.each(function (t) { var e = o.getName(t), n = o.getItemLayout(t) || {}; (n.showLabel = !r[e]), o.setItemLayout(t, n); }), (e[i] = !0); } }); } var pC = Wt, dC = (function (t) { function e(e) { var n = t.call(this) || this; return ( (n.type = "view"), (n.dimensions = ["x", "y"]), (n._roamTransformable = new vr()), (n._rawTransformable = new vr()), (n.name = e), n ); } return ( n(e, t), (e.prototype.setBoundingRect = function (t, e, n, i) { return (this._rect = new ze(t, e, n, i)), this._rect; }), (e.prototype.getBoundingRect = function () { return this._rect; }), (e.prototype.setViewRect = function (t, e, n, i) { this._transformTo(t, e, n, i), (this._viewRect = new ze(t, e, n, i)); }), (e.prototype._transformTo = function (t, e, n, i) { var r = this.getBoundingRect(), o = this._rawTransformable; o.transform = r.calculateTransform(new ze(t, e, n, i)); var a = o.parent; (o.parent = null), o.decomposeTransform(), (o.parent = a), this._updateTransform(); }), (e.prototype.setCenter = function (t, e) { t && ((this._center = [ $r(t[0], e.getWidth()), $r(t[1], e.getHeight()), ]), this._updateCenterAndZoom()); }), (e.prototype.setZoom = function (t) { t = t || 1; var e = this.zoomLimit; e && (null != e.max && (t = Math.min(e.max, t)), null != e.min && (t = Math.max(e.min, t))), (this._zoom = t), this._updateCenterAndZoom(); }), (e.prototype.getDefaultCenter = function () { var t = this.getBoundingRect(); return [t.x + t.width / 2, t.y + t.height / 2]; }), (e.prototype.getCenter = function () { return this._center || this.getDefaultCenter(); }), (e.prototype.getZoom = function () { return this._zoom || 1; }), (e.prototype.getRoamTransform = function () { return this._roamTransformable.getLocalTransform(); }), (e.prototype._updateCenterAndZoom = function () { var t = this._rawTransformable.getLocalTransform(), e = this._roamTransformable, n = this.getDefaultCenter(), i = this.getCenter(), r = this.getZoom(); (i = Wt([], i, t)), (n = Wt([], n, t)), (e.originX = i[0]), (e.originY = i[1]), (e.x = n[0] - i[0]), (e.y = n[1] - i[1]), (e.scaleX = e.scaleY = r), this._updateTransform(); }), (e.prototype._updateTransform = function () { var t = this._roamTransformable, e = this._rawTransformable; (e.parent = t), t.updateTransform(), e.updateTransform(), _e( this.transform || (this.transform = []), e.transform || [1, 0, 0, 1, 0, 0] ), (this._rawTransform = e.getLocalTransform()), (this.invTransform = this.invTransform || []), Ie(this.invTransform, this.transform), this.decomposeTransform(); }), (e.prototype.getTransformInfo = function () { var t = this._rawTransformable, e = this._roamTransformable, n = new vr(); return ( (n.transform = e.transform), n.decomposeTransform(), { roam: { x: n.x, y: n.y, scaleX: n.scaleX, scaleY: n.scaleY, }, raw: { x: t.x, y: t.y, scaleX: t.scaleX, scaleY: t.scaleY, }, } ); }), (e.prototype.getViewRect = function () { return this._viewRect; }), (e.prototype.getViewRectAfterRoam = function () { var t = this.getBoundingRect().clone(); return t.applyTransform(this.transform), t; }), (e.prototype.dataToPoint = function (t, e, n) { var i = e ? this._rawTransform : this.transform; return (n = n || []), i ? pC(n, t, i) : It(n, t); }), (e.prototype.pointToData = function (t) { var e = this.invTransform; return e ? pC([], t, e) : [t[0], t[1]]; }), (e.prototype.convertToPixel = function (t, e, n) { var i = fC(e); return i === this ? i.dataToPoint(n) : null; }), (e.prototype.convertFromPixel = function (t, e, n) { var i = fC(e); return i === this ? i.pointToData(n) : null; }), (e.prototype.containPoint = function (t) { return this.getViewRectAfterRoam().contain(t[0], t[1]); }), (e.dimensions = ["x", "y"]), e ); })(vr); function fC(t) { var e = t.seriesModel; return e ? e.coordinateSystem : null; } var gC = { geoJSON: { aspectScale: 0.75, invertLongitute: !0 }, geoSVG: { aspectScale: 1, invertLongitute: !1 }, }, yC = ["lng", "lat"], vC = (function (t) { function e(e, n, i) { var r = t.call(this, e) || this; (r.dimensions = yC), (r.type = "geo"), (r._nameCoordMap = yt()), (r.map = n); var o, a = i.projection, s = ZT(n, i.nameMap, i.nameProperty), l = XT(n), u = ((r.resourceType = l ? l.type : null), (r.regions = s.regions)), h = gC[l.type]; if ( ((r._regionsMap = s.regionsMap), (r.regions = s.regions), (r.projection = a), a) ) for (var c = 0; c < u.length; c++) { var p = u[c].getBoundingRect(a); (o = o || p.clone()).union(p); } else o = s.boundingRect; return ( r.setBoundingRect(o.x, o.y, o.width, o.height), (r.aspectScale = a ? 1 : rt(i.aspectScale, h.aspectScale)), (r._invertLongitute = !a && h.invertLongitute), r ); } return ( n(e, t), (e.prototype._transformTo = function (t, e, n, i) { var r = this.getBoundingRect(), o = this._invertLongitute; (r = r.clone()), o && (r.y = -r.y - r.height); var a = this._rawTransformable; a.transform = r.calculateTransform(new ze(t, e, n, i)); var s = a.parent; (a.parent = null), a.decomposeTransform(), (a.parent = s), o && (a.scaleY = -a.scaleY), this._updateTransform(); }), (e.prototype.getRegion = function (t) { return this._regionsMap.get(t); }), (e.prototype.getRegionByCoord = function (t) { for (var e = this.regions, n = 0; n < e.length; n++) { var i = e[n]; if ("geoJSON" === i.type && i.contain(t)) return e[n]; } }), (e.prototype.addGeoCoord = function (t, e) { this._nameCoordMap.set(t, e); }), (e.prototype.getGeoCoord = function (t) { var e = this._regionsMap.get(t); return this._nameCoordMap.get(t) || (e && e.getCenter()); }), (e.prototype.dataToPoint = function (t, e, n) { if ((U(t) && (t = this.getGeoCoord(t)), t)) { var i = this.projection; return ( i && (t = i.project(t)), t && this.projectedToPoint(t, e, n) ); } }), (e.prototype.pointToData = function (t) { var e = this.projection; return ( e && (t = e.unproject(t)), t && this.pointToProjected(t) ); }), (e.prototype.pointToProjected = function (e) { return t.prototype.pointToData.call(this, e); }), (e.prototype.projectedToPoint = function (e, n, i) { return t.prototype.dataToPoint.call(this, e, n, i); }), (e.prototype.convertToPixel = function (t, e, n) { var i = mC(e); return i === this ? i.dataToPoint(n) : null; }), (e.prototype.convertFromPixel = function (t, e, n) { var i = mC(e); return i === this ? i.pointToData(n) : null; }), e ); })(dC); function mC(t) { var e = t.geoModel, n = t.seriesModel; return e ? e.coordinateSystem : n ? n.coordinateSystem || (n.getReferringComponents("geo", Wo).models[0] || {}) .coordinateSystem : null; } function xC(t, e) { var n = t.get("boundingCoords"); if (null != n) { var i = n[0], r = n[1]; if ( isFinite(i[0]) && isFinite(i[1]) && isFinite(r[0]) && isFinite(r[1]) ) { var o = this.projection; if (o) { var a = i[0], s = i[1], l = r[0], u = r[1]; (i = [1 / 0, 1 / 0]), (r = [-1 / 0, -1 / 0]); var h = function (t, e, n, a) { for (var s = n - t, l = a - e, u = 0; u <= 100; u++) { var h = u / 100, c = o.project([t + s * h, e + l * h]); Ht(i, i, c), Yt(r, r, c); } }; h(a, s, l, s), h(l, s, l, u), h(l, u, a, u), h(a, u, l, s); } this.setBoundingRect(i[0], i[1], r[0] - i[0], r[1] - i[1]); } else 0; } var c, p, d, f = this.getBoundingRect(), g = t.get("layoutCenter"), y = t.get("layoutSize"), v = e.getWidth(), m = e.getHeight(), x = (f.width / f.height) * this.aspectScale, _ = !1; if ( (g && y && ((c = [$r(g[0], v), $r(g[1], m)]), (p = $r(y, Math.min(v, m))), isNaN(c[0]) || isNaN(c[1]) || isNaN(p) || (_ = !0)), _) ) (d = {}), x > 1 ? ((d.width = p), (d.height = p / x)) : ((d.height = p), (d.width = p * x)), (d.y = c[1] - d.height / 2), (d.x = c[0] - d.width / 2); else { var b = t.getBoxLayoutParams(); (b.aspect = x), (d = kp(b, { width: v, height: m })); } this.setViewRect(d.x, d.y, d.width, d.height), this.setCenter(t.get("center"), e), this.setZoom(t.get("zoom")); } R(vC, dC); var _C = (function () { function t() { this.dimensions = yC; } return ( (t.prototype.create = function (t, e) { var n = []; function i(t) { return { nameProperty: t.get("nameProperty"), aspectScale: t.get("aspectScale"), projection: t.get("projection"), }; } t.eachComponent("geo", function (t, r) { var o = t.get("map"), a = new vC( o + r, o, A({ nameMap: t.get("nameMap") }, i(t)) ); (a.zoomLimit = t.get("scaleLimit")), n.push(a), (t.coordinateSystem = a), (a.model = t), (a.resize = xC), a.resize(t, e); }), t.eachSeries(function (t) { if ("geo" === t.get("coordinateSystem")) { var e = t.get("geoIndex") || 0; t.coordinateSystem = n[e]; } }); var r = {}; return ( t.eachSeriesByType("map", function (t) { if (!t.getHostGeoModel()) { var e = t.getMapType(); (r[e] = r[e] || []), r[e].push(t); } }), E(r, function (t, r) { var o = z(t, function (t) { return t.get("nameMap"); }), a = new vC(r, r, A({ nameMap: D(o) }, i(t[0]))); (a.zoomLimit = it.apply( null, z(t, function (t) { return t.get("scaleLimit"); }) )), n.push(a), (a.resize = xC), a.resize(t[0], e), E(t, function (t) { (t.coordinateSystem = a), (function (t, e) { E( e.get("geoCoord"), function (e, n) { t.addGeoCoord(n, e); } ); })(a, t); }); }), n ); }), (t.prototype.getFilledRegions = function (t, e, n, i) { for ( var r = (t || []).slice(), o = yt(), a = 0; a < r.length; a++ ) o.set(r[a].name, r[a]); return ( E(ZT(e, n, i).regions, function (t) { var e = t.name, n = o.get(e), i = t.properties && t.properties.echartsStyle; n || ((n = { name: e }), r.push(n)), i && C(n, i); }), r ); }), t ); })(), bC = new _C(), wC = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (t, e, n) { var i = XT(t.map); if (i && "geoJSON" === i.type) { var r = (t.itemStyle = t.itemStyle || {}); "color" in r || (r.color = "#eee"); } this.mergeDefaultAndTheme(t, n), Co(t, "label", ["show"]); }), (e.prototype.optionUpdated = function () { var t = this, e = this.option; e.regions = bC.getFilledRegions( e.regions, e.map, e.nameMap, e.nameProperty ); var n = {}; (this._optionModelMap = V( e.regions || [], function (e, i) { var r = i.name; return ( r && (e.set(r, new Cc(i, t, t.ecModel)), i.selected && (n[r] = !0)), e ); }, yt() )), e.selectedMap || (e.selectedMap = n); }), (e.prototype.getRegionModel = function (t) { return ( this._optionModelMap.get(t) || new Cc(null, this, this.ecModel) ); }), (e.prototype.getFormattedLabel = function (t, e) { var n = this.getRegionModel(t), i = "normal" === e ? n.get(["label", "formatter"]) : n.get(["emphasis", "label", "formatter"]), r = { name: t }; return X(i) ? ((r.status = e), i(r)) : U(i) ? i.replace("{a}", null != t ? t : "") : void 0; }), (e.prototype.setZoom = function (t) { this.option.zoom = t; }), (e.prototype.setCenter = function (t) { this.option.center = t; }), (e.prototype.select = function (t) { var e = this.option, n = e.selectedMode; n && ("multiple" !== n && (e.selectedMap = null), ((e.selectedMap || (e.selectedMap = {}))[t] = !0)); }), (e.prototype.unSelect = function (t) { var e = this.option.selectedMap; e && (e[t] = !1); }), (e.prototype.toggleSelected = function (t) { this[this.isSelected(t) ? "unSelect" : "select"](t); }), (e.prototype.isSelected = function (t) { var e = this.option.selectedMap; return !(!e || !e[t]); }), (e.type = "geo"), (e.layoutMode = "box"), (e.defaultOption = { z: 0, show: !0, left: "center", top: "center", aspectScale: null, silent: !1, map: "", boundingCoords: null, center: null, zoom: 1, scaleLimit: null, label: { show: !1, color: "#000" }, itemStyle: { borderWidth: 0.5, borderColor: "#444" }, emphasis: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { color: "rgba(255,215,0,0.8)" }, }, select: { label: { show: !0, color: "rgb(100,0,0)" }, itemStyle: { color: "rgba(255,215,0,0.8)" }, }, regions: [], }), e ); })(zp); function SC(t, e) { return t.pointToProjected ? t.pointToProjected(e) : t.pointToData(e); } function MC(t, e, n, i) { var r = t.getZoom(), o = t.getCenter(), a = e.zoom, s = t.projectedToPoint ? t.projectedToPoint(o) : t.dataToPoint(o); if ( (null != e.dx && null != e.dy && ((s[0] -= e.dx), (s[1] -= e.dy), t.setCenter(SC(t, s), i)), null != a) ) { if (n) { var l = n.min || 0, u = n.max || 1 / 0; a = Math.max(Math.min(r * a, u), l) / r; } (t.scaleX *= a), (t.scaleY *= a); var h = (e.originX - t.x) * (a - 1), c = (e.originY - t.y) * (a - 1); (t.x -= h), (t.y -= c), t.updateTransform(), t.setCenter(SC(t, s), i), t.setZoom(a * r); } return { center: t.getCenter(), zoom: t.getZoom() }; } var IC = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.focusBlurEnabled = !0), n; } return ( n(e, t), (e.prototype.init = function (t, e) { this._api = e; }), (e.prototype.render = function (t, e, n, i) { if (((this._model = t), !t.get("show"))) return ( this._mapDraw && this._mapDraw.remove(), void (this._mapDraw = null) ); this._mapDraw || (this._mapDraw = new eC(n)); var r = this._mapDraw; r.draw(t, e, n, this, i), r.group.on("click", this._handleRegionClick, this), (r.group.silent = t.get("silent")), this.group.add(r.group), this.updateSelectStatus(t, e, n); }), (e.prototype._handleRegionClick = function (t) { var e; Oy( t.target, function (t) { return null != (e = rl(t).eventData); }, !0 ), e && this._api.dispatchAction({ type: "geoToggleSelect", geoId: this._model.id, name: e.name, }); }), (e.prototype.updateSelectStatus = function (t, e, n) { var i = this; this._mapDraw.group.traverse(function (t) { var e = rl(t).eventData; if (e) return ( i._model.isSelected(e.name) ? n.enterSelect(t) : n.leaveSelect(t), !0 ); }); }), (e.prototype.findHighDownDispatchers = function (t) { return ( this._mapDraw && this._mapDraw.findHighDownDispatchers(t, this._model) ); }), (e.prototype.dispose = function () { this._mapDraw && this._mapDraw.remove(); }), (e.type = "geo"), e ); })(Ag); function TC(t, e, n) { YT(t, e, n); } function CC(t) { function e(e, n) { (n.update = "geo:updateSelectStatus"), t.registerAction(n, function (t, n) { var i = {}, r = []; return ( n.eachComponent( { mainType: "geo", query: t }, function (n) { n[e](t.name), E(n.coordinateSystem.regions, function (t) { i[t.name] = n.isSelected(t.name) || !1; }); var o = []; E(i, function (t, e) { i[e] && o.push(e); }), r.push({ geoIndex: n.componentIndex, name: o, }); } ), { selected: i, allSelected: r, name: t.name } ); }); } t.registerCoordinateSystem("geo", bC), t.registerComponentModel(wC), t.registerComponentView(IC), t.registerImpl("registerMap", TC), t.registerImpl("getMap", function (t) { return UT(t); }), e("toggleSelected", { type: "geoToggleSelect", event: "geoselectchanged", }), e("select", { type: "geoSelect", event: "geoselected" }), e("unSelect", { type: "geoUnSelect", event: "geounselected" }), t.registerAction( { type: "geoRoam", event: "geoRoam", update: "updateTransform", }, function (t, e, n) { var i = t.componentType || "series"; e.eachComponent({ mainType: i, query: t }, function (e) { var r = e.coordinateSystem; if ("geo" === r.type) { var o = MC(r, t, e.get("scaleLimit"), n); e.setCenter && e.setCenter(o.center), e.setZoom && e.setZoom(o.zoom), "series" === i && E(e.seriesGroup, function (t) { t.setCenter(o.center), t.setZoom(o.zoom); }); } }); } ); } function DC(t, e) { var n = t.isExpand ? t.children : [], i = t.parentNode.children, r = t.hierNode.i ? i[t.hierNode.i - 1] : null; if (n.length) { !(function (t) { var e = t.children, n = e.length, i = 0, r = 0; for (; --n >= 0; ) { var o = e[n]; (o.hierNode.prelim += i), (o.hierNode.modifier += i), (r += o.hierNode.change), (i += o.hierNode.shift + r); } })(t); var o = (n[0].hierNode.prelim + n[n.length - 1].hierNode.prelim) / 2; r ? ((t.hierNode.prelim = r.hierNode.prelim + e(t, r)), (t.hierNode.modifier = t.hierNode.prelim - o)) : (t.hierNode.prelim = o); } else r && (t.hierNode.prelim = r.hierNode.prelim + e(t, r)); t.parentNode.hierNode.defaultAncestor = (function (t, e, n, i) { if (e) { for ( var r = t, o = t, a = o.parentNode.children[0], s = e, l = r.hierNode.modifier, u = o.hierNode.modifier, h = a.hierNode.modifier, c = s.hierNode.modifier; (s = PC(s)), (o = OC(o)), s && o; ) { (r = PC(r)), (a = OC(a)), (r.hierNode.ancestor = t); var p = s.hierNode.prelim + c - o.hierNode.prelim - u + i(s, o); p > 0 && (NC(RC(s, t, n), t, p), (u += p), (l += p)), (c += s.hierNode.modifier), (u += o.hierNode.modifier), (l += r.hierNode.modifier), (h += a.hierNode.modifier); } s && !PC(r) && ((r.hierNode.thread = s), (r.hierNode.modifier += c - l)), o && !OC(a) && ((a.hierNode.thread = o), (a.hierNode.modifier += u - h), (n = t)); } return n; })(t, r, t.parentNode.hierNode.defaultAncestor || i[0], e); } function AC(t) { var e = t.hierNode.prelim + t.parentNode.hierNode.modifier; t.setLayout({ x: e }, !0), (t.hierNode.modifier += t.parentNode.hierNode.modifier); } function kC(t) { return arguments.length ? t : EC; } function LC(t, e) { return (t -= Math.PI / 2), { x: e * Math.cos(t), y: e * Math.sin(t) }; } function PC(t) { var e = t.children; return e.length && t.isExpand ? e[e.length - 1] : t.hierNode.thread; } function OC(t) { var e = t.children; return e.length && t.isExpand ? e[0] : t.hierNode.thread; } function RC(t, e, n) { return t.hierNode.ancestor.parentNode === e.parentNode ? t.hierNode.ancestor : n; } function NC(t, e, n) { var i = n / (e.hierNode.i - t.hierNode.i); (e.hierNode.change -= i), (e.hierNode.shift += n), (e.hierNode.modifier += n), (e.hierNode.prelim += n), (t.hierNode.change += i); } function EC(t, e) { return t.parentNode === e.parentNode ? 1 : 2; } var zC = function () { (this.parentPoint = []), (this.childPoints = []); }, VC = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new zC(); }), (e.prototype.buildPath = function (t, e) { var n = e.childPoints, i = n.length, r = e.parentPoint, o = n[0], a = n[i - 1]; if (1 === i) return t.moveTo(r[0], r[1]), void t.lineTo(o[0], o[1]); var s = e.orient, l = "TB" === s || "BT" === s ? 0 : 1, u = 1 - l, h = $r(e.forkPosition, 1), c = []; (c[l] = r[l]), (c[u] = r[u] + (a[u] - r[u]) * h), t.moveTo(r[0], r[1]), t.lineTo(c[0], c[1]), t.moveTo(o[0], o[1]), (c[l] = o[l]), t.lineTo(c[0], c[1]), (c[l] = a[l]), t.lineTo(c[0], c[1]), t.lineTo(a[0], a[1]); for (var p = 1; p < i - 1; p++) { var d = n[p]; t.moveTo(d[0], d[1]), (c[l] = d[l]), t.lineTo(c[0], c[1]); } }), e ); })(ks), BC = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n._mainGroup = new Br()), n; } return ( n(e, t), (e.prototype.init = function (t, e) { (this._controller = new nT(e.getZr())), (this._controllerHost = { target: this.group }), this.group.add(this._mainGroup); }), (e.prototype.render = function (t, e, n) { var i = t.getData(), r = t.layoutInfo, o = this._mainGroup; "radial" === t.get("layout") ? ((o.x = r.x + r.width / 2), (o.y = r.y + r.height / 2)) : ((o.x = r.x), (o.y = r.y)), this._updateViewCoordSys(t, n), this._updateController(t, e, n); var a = this._data; i .diff(a) .add(function (e) { FC(i, e) && GC(i, e, null, o, t); }) .update(function (e, n) { var r = a.getItemGraphicEl(n); FC(i, e) ? GC(i, e, r, o, t) : r && YC(a, n, r, o, t); }) .remove(function (e) { var n = a.getItemGraphicEl(e); n && YC(a, e, n, o, t); }) .execute(), (this._nodeScaleRatio = t.get("nodeScaleRatio")), this._updateNodeAndLinkScale(t), !0 === t.get("expandAndCollapse") && i.eachItemGraphicEl(function (e, i) { e.off("click").on("click", function () { n.dispatchAction({ type: "treeExpandAndCollapse", seriesId: t.id, dataIndex: i, }); }); }), (this._data = i); }), (e.prototype._updateViewCoordSys = function (t, e) { var n = t.getData(), i = []; n.each(function (t) { var e = n.getItemLayout(t); !e || isNaN(e.x) || isNaN(e.y) || i.push([+e.x, +e.y]); }); var r = [], o = []; Ba(i, r, o); var a = this._min, s = this._max; o[0] - r[0] == 0 && ((r[0] = a ? a[0] : r[0] - 1), (o[0] = s ? s[0] : o[0] + 1)), o[1] - r[1] == 0 && ((r[1] = a ? a[1] : r[1] - 1), (o[1] = s ? s[1] : o[1] + 1)); var l = (t.coordinateSystem = new dC()); (l.zoomLimit = t.get("scaleLimit")), l.setBoundingRect(r[0], r[1], o[0] - r[0], o[1] - r[1]), l.setCenter(t.get("center"), e), l.setZoom(t.get("zoom")), this.group.attr({ x: l.x, y: l.y, scaleX: l.scaleX, scaleY: l.scaleY, }), (this._min = r), (this._max = o); }), (e.prototype._updateController = function (t, e, n) { var i = this, r = this._controller, o = this._controllerHost, a = this.group; r.setPointerChecker(function (e, i, r) { var o = a.getBoundingRect(); return ( o.applyTransform(a.transform), o.contain(i, r) && !hT(e, n, t) ); }), r.enable(t.get("roam")), (o.zoomLimit = t.get("scaleLimit")), (o.zoom = t.coordinateSystem.getZoom()), r .off("pan") .off("zoom") .on("pan", function (e) { aT(o, e.dx, e.dy), n.dispatchAction({ seriesId: t.id, type: "treeRoam", dx: e.dx, dy: e.dy, }); }) .on("zoom", function (e) { sT(o, e.scale, e.originX, e.originY), n.dispatchAction({ seriesId: t.id, type: "treeRoam", zoom: e.scale, originX: e.originX, originY: e.originY, }), i._updateNodeAndLinkScale(t), n.updateLabelLayout(); }); }), (e.prototype._updateNodeAndLinkScale = function (t) { var e = t.getData(), n = this._getNodeGlobalScale(t); e.eachItemGraphicEl(function (t, e) { t.setSymbolScale(n); }); }), (e.prototype._getNodeGlobalScale = function (t) { var e = t.coordinateSystem; if ("view" !== e.type) return 1; var n = this._nodeScaleRatio, i = e.scaleX || 1; return ((e.getZoom() - 1) * n + 1) / i; }), (e.prototype.dispose = function () { this._controller && this._controller.dispose(), (this._controllerHost = null); }), (e.prototype.remove = function () { this._mainGroup.removeAll(), (this._data = null); }), (e.type = "tree"), e ); })(Og); function FC(t, e) { var n = t.getItemLayout(e); return n && !isNaN(n.x) && !isNaN(n.y); } function GC(t, e, n, i, r) { var o = !n, a = t.tree.getNodeByDataIndex(e), s = a.getModel(), l = a.getVisual("style").fill, u = !1 === a.isExpand && 0 !== a.children.length ? l : "#fff", h = t.tree.root, c = a.parentNode === h ? a : a.parentNode || a, p = t.getItemGraphicEl(c.dataIndex), d = c.getLayout(), f = p ? { x: p.__oldX, y: p.__oldY, rawX: p.__radialOldRawX, rawY: p.__radialOldRawY, } : d, g = a.getLayout(); o ? (((n = new fS(t, e, null, { symbolInnerColor: u, useNameLabel: !0, })).x = f.x), (n.y = f.y)) : n.updateData(t, e, null, { symbolInnerColor: u, useNameLabel: !0, }), (n.__radialOldRawX = n.__radialRawX), (n.__radialOldRawY = n.__radialRawY), (n.__radialRawX = g.rawX), (n.__radialRawY = g.rawY), i.add(n), t.setItemGraphicEl(e, n), (n.__oldX = n.x), (n.__oldY = n.y), vh(n, { x: g.x, y: g.y }, r); var y = n.getSymbolPath(); if ("radial" === r.get("layout")) { var v = h.children[0], m = v.getLayout(), x = v.children.length, _ = void 0, b = void 0; if (g.x === m.x && !0 === a.isExpand && v.children.length) { var w = { x: (v.children[0].getLayout().x + v.children[x - 1].getLayout().x) / 2, y: (v.children[0].getLayout().y + v.children[x - 1].getLayout().y) / 2, }; (_ = Math.atan2(w.y - m.y, w.x - m.x)) < 0 && (_ = 2 * Math.PI + _), (b = w.x < m.x) && (_ -= Math.PI); } else (_ = Math.atan2(g.y - m.y, g.x - m.x)) < 0 && (_ = 2 * Math.PI + _), 0 === a.children.length || (0 !== a.children.length && !1 === a.isExpand) ? (b = g.x < m.x) && (_ -= Math.PI) : (b = g.x > m.x) || (_ -= Math.PI); var S = b ? "left" : "right", M = s.getModel("label"), I = M.get("rotate"), T = I * (Math.PI / 180), C = y.getTextContent(); C && (y.setTextConfig({ position: M.get("position") || S, rotation: null == I ? -_ : T, origin: "center", }), C.setStyle("verticalAlign", "middle")); } var D = s.get(["emphasis", "focus"]), A = "relative" === D ? vt(a.getAncestorsIndices(), a.getDescendantIndices()) : "ancestor" === D ? a.getAncestorsIndices() : "descendant" === D ? a.getDescendantIndices() : null; A && (rl(n).focus = A), (function (t, e, n, i, r, o, a, s) { var l = e.getModel(), u = t.get("edgeShape"), h = t.get("layout"), c = t.getOrient(), p = t.get(["lineStyle", "curveness"]), d = t.get("edgeForkPosition"), f = l.getModel("lineStyle").getLineStyle(), g = i.__edge; if ("curve" === u) e.parentNode && e.parentNode !== n && (g || (g = i.__edge = new th({ shape: XC(h, c, p, r, r) })), vh(g, { shape: XC(h, c, p, o, a) }, t)); else if ("polyline" === u) if ("orthogonal" === h) { if ( e !== n && e.children && 0 !== e.children.length && !0 === e.isExpand ) { for ( var y = e.children, v = [], m = 0; m < y.length; m++ ) { var x = y[m].getLayout(); v.push([x.x, x.y]); } g || (g = i.__edge = new VC({ shape: { parentPoint: [a.x, a.y], childPoints: [[a.x, a.y]], orient: c, forkPosition: d, }, })), vh( g, { shape: { parentPoint: [a.x, a.y], childPoints: v, }, }, t ); } } else 0; g && ("polyline" !== u || e.isExpand) && (g.useStyle(k({ strokeNoScale: !0, fill: null }, f)), $l(g, l, "lineStyle"), kl(g), s.add(g)); })(r, a, h, n, f, d, g, i), n.__edge && (n.onHoverStateChange = function (e) { if ("blur" !== e) { var i = a.parentNode && t.getItemGraphicEl(a.parentNode.dataIndex); (i && 1 === i.hoverState) || Dl(n.__edge, e); } }); } function WC(t, e, n, i, r) { var o = HC(e.tree.root, t), a = o.source, s = o.sourceLayout, l = e.getItemGraphicEl(t.dataIndex); if (l) { var u = e.getItemGraphicEl(a.dataIndex).__edge, h = l.__edge || (!1 === a.isExpand || 1 === a.children.length ? u : void 0), c = i.get("edgeShape"), p = i.get("layout"), d = i.get("orient"), f = i.get(["lineStyle", "curveness"]); h && ("curve" === c ? _h( h, { shape: XC(p, d, f, s, s), style: { opacity: 0 } }, i, { cb: function () { n.remove(h); }, removeOpt: r, } ) : "polyline" === c && "orthogonal" === i.get("layout") && _h( h, { shape: { parentPoint: [s.x, s.y], childPoints: [[s.x, s.y]], }, style: { opacity: 0 }, }, i, { cb: function () { n.remove(h); }, removeOpt: r, } )); } } function HC(t, e) { for ( var n, i = e.parentNode === t ? e : e.parentNode || e; null == (n = i.getLayout()); ) i = i.parentNode === t ? i : i.parentNode || i; return { source: i, sourceLayout: n }; } function YC(t, e, n, i, r) { var o = t.tree.getNodeByDataIndex(e), a = HC(t.tree.root, o).sourceLayout, s = { duration: r.get("animationDurationUpdate"), easing: r.get("animationEasingUpdate"), }; _h(n, { x: a.x + 1, y: a.y + 1 }, r, { cb: function () { i.remove(n), t.setItemGraphicEl(e, null); }, removeOpt: s, }), n.fadeOut(null, t.hostModel, { fadeLabel: !0, animation: s }), o.children.forEach(function (e) { WC(e, t, i, r, s); }), WC(o, t, i, r, s); } function XC(t, e, n, i, r) { var o, a, s, l, u, h, c, p; if ("radial" === t) { (u = i.rawX), (c = i.rawY), (h = r.rawX), (p = r.rawY); var d = LC(u, c), f = LC(u, c + (p - c) * n), g = LC(h, p + (c - p) * n), y = LC(h, p); return { x1: d.x || 0, y1: d.y || 0, x2: y.x || 0, y2: y.y || 0, cpx1: f.x || 0, cpy1: f.y || 0, cpx2: g.x || 0, cpy2: g.y || 0, }; } return ( (u = i.x), (c = i.y), (h = r.x), (p = r.y), ("LR" !== e && "RL" !== e) || ((o = u + (h - u) * n), (a = c), (s = h + (u - h) * n), (l = p)), ("TB" !== e && "BT" !== e) || ((o = u), (a = c + (p - c) * n), (s = h), (l = p + (c - p) * n)), { x1: u, y1: c, x2: h, y2: p, cpx1: o, cpy1: a, cpx2: s, cpy2: l } ); } var UC = Vo(); function ZC(t) { var e = t.mainData, n = t.datas; n || ((n = { main: e }), (t.datasAttr = { main: "data" })), (t.datas = t.mainData = null), QC(e, n, t), E(n, function (n) { E(e.TRANSFERABLE_METHODS, function (e) { n.wrapMethod(e, H(jC, t)); }); }), e.wrapMethod("cloneShallow", H(KC, t)), E(e.CHANGABLE_METHODS, function (n) { e.wrapMethod(n, H(qC, t)); }), lt(n[e.dataType] === e); } function jC(t, e) { if (UC((i = this)).mainData === i) { var n = A({}, UC(this).datas); (n[this.dataType] = e), QC(e, n, t); } else tD(e, this.dataType, UC(this).mainData, t); var i; return e; } function qC(t, e) { return t.struct && t.struct.update(), e; } function KC(t, e) { return ( E(UC(e).datas, function (n, i) { n !== e && tD(n.cloneShallow(), i, e, t); }), e ); } function $C(t) { var e = UC(this).mainData; return null == t || null == e ? e : UC(e).datas[t]; } function JC() { var t = UC(this).mainData; return null == t ? [{ data: t }] : z(G(UC(t).datas), function (e) { return { type: e, data: UC(t).datas[e] }; }); } function QC(t, e, n) { (UC(t).datas = {}), E(e, function (e, i) { tD(e, i, t, n); }); } function tD(t, e, n, i) { (UC(n).datas[e] = t), (UC(t).mainData = n), (t.dataType = e), i.struct && ((t[i.structAttr] = i.struct), (i.struct[i.datasAttr[e]] = t)), (t.getLinkedData = $C), (t.getLinkedDataAll = JC); } var eD = (function () { function t(t, e) { (this.depth = 0), (this.height = 0), (this.dataIndex = -1), (this.children = []), (this.viewChildren = []), (this.isExpand = !1), (this.name = t || ""), (this.hostTree = e); } return ( (t.prototype.isRemoved = function () { return this.dataIndex < 0; }), (t.prototype.eachNode = function (t, e, n) { X(t) && ((n = e), (e = t), (t = null)), U((t = t || {})) && (t = { order: t }); var i, r = t.order || "preorder", o = this[t.attr || "children"]; "preorder" === r && (i = e.call(n, this)); for (var a = 0; !i && a < o.length; a++) o[a].eachNode(t, e, n); "postorder" === r && e.call(n, this); }), (t.prototype.updateDepthAndHeight = function (t) { var e = 0; this.depth = t; for (var n = 0; n < this.children.length; n++) { var i = this.children[n]; i.updateDepthAndHeight(t + 1), i.height > e && (e = i.height); } this.height = e + 1; }), (t.prototype.getNodeById = function (t) { if (this.getId() === t) return this; for ( var e = 0, n = this.children, i = n.length; e < i; e++ ) { var r = n[e].getNodeById(t); if (r) return r; } }), (t.prototype.contains = function (t) { if (t === this) return !0; for ( var e = 0, n = this.children, i = n.length; e < i; e++ ) { var r = n[e].contains(t); if (r) return r; } }), (t.prototype.getAncestors = function (t) { for (var e = [], n = t ? this : this.parentNode; n; ) e.push(n), (n = n.parentNode); return e.reverse(), e; }), (t.prototype.getAncestorsIndices = function () { for (var t = [], e = this; e; ) t.push(e.dataIndex), (e = e.parentNode); return t.reverse(), t; }), (t.prototype.getDescendantIndices = function () { var t = []; return ( this.eachNode(function (e) { t.push(e.dataIndex); }), t ); }), (t.prototype.getValue = function (t) { var e = this.hostTree.data; return e .getStore() .get(e.getDimensionIndex(t || "value"), this.dataIndex); }), (t.prototype.setLayout = function (t, e) { this.dataIndex >= 0 && this.hostTree.data.setItemLayout(this.dataIndex, t, e); }), (t.prototype.getLayout = function () { return this.hostTree.data.getItemLayout(this.dataIndex); }), (t.prototype.getModel = function (t) { if (!(this.dataIndex < 0)) return this.hostTree.data .getItemModel(this.dataIndex) .getModel(t); }), (t.prototype.getLevelModel = function () { return (this.hostTree.levelModels || [])[this.depth]; }), (t.prototype.setVisual = function (t, e) { this.dataIndex >= 0 && this.hostTree.data.setItemVisual(this.dataIndex, t, e); }), (t.prototype.getVisual = function (t) { return this.hostTree.data.getItemVisual(this.dataIndex, t); }), (t.prototype.getRawIndex = function () { return this.hostTree.data.getRawIndex(this.dataIndex); }), (t.prototype.getId = function () { return this.hostTree.data.getId(this.dataIndex); }), (t.prototype.getChildIndex = function () { if (this.parentNode) { for ( var t = this.parentNode.children, e = 0; e < t.length; ++e ) if (t[e] === this) return e; return -1; } return -1; }), (t.prototype.isAncestorOf = function (t) { for (var e = t.parentNode; e; ) { if (e === this) return !0; e = e.parentNode; } return !1; }), (t.prototype.isDescendantOf = function (t) { return t !== this && t.isAncestorOf(this); }), t ); })(), nD = (function () { function t(t) { (this.type = "tree"), (this._nodes = []), (this.hostModel = t); } return ( (t.prototype.eachNode = function (t, e, n) { this.root.eachNode(t, e, n); }), (t.prototype.getNodeByDataIndex = function (t) { var e = this.data.getRawIndex(t); return this._nodes[e]; }), (t.prototype.getNodeById = function (t) { return this.root.getNodeById(t); }), (t.prototype.update = function () { for ( var t = this.data, e = this._nodes, n = 0, i = e.length; n < i; n++ ) e[n].dataIndex = -1; for (n = 0, i = t.count(); n < i; n++) e[t.getRawIndex(n)].dataIndex = n; }), (t.prototype.clearLayouts = function () { this.data.clearItemLayouts(); }), (t.createTree = function (e, n, i) { var r = new t(n), o = [], a = 1; !(function t(e, n) { var i = e.value; (a = Math.max(a, Y(i) ? i.length : 1)), o.push(e); var s = new eD(Ro(e.name, ""), r); n ? (function (t, e) { var n = e.children; if (t.parentNode === e) return; n.push(t), (t.parentNode = e); })(s, n) : (r.root = s), r._nodes.push(s); var l = e.children; if (l) for (var u = 0; u < l.length; u++) t(l[u], s); })(e), r.root.updateDepthAndHeight(0); var s = px(o, { coordDimensions: ["value"], dimensionsCount: a, }).dimensions, l = new cx(s, n); return ( l.initData(o), i && i(l), ZC({ mainData: l, struct: r, structAttr: "tree" }), r.update(), r ); }), t ); })(); function iD(t, e, n) { if (t && P(e, t.type) >= 0) { var i = n.getData().tree.root, r = t.targetNode; if ((U(r) && (r = i.getNodeById(r)), r && i.contains(r))) return { node: r }; var o = t.targetNodeId; if (null != o && (r = i.getNodeById(o))) return { node: r }; } } function rD(t) { for (var e = []; t; ) (t = t.parentNode) && e.push(t); return e.reverse(); } function oD(t, e) { return P(rD(t), e) >= 0; } function aD(t, e) { for (var n = []; t; ) { var i = t.dataIndex; n.push({ name: t.name, dataIndex: i, value: e.getRawValue(i) }), (t = t.parentNode); } return n.reverse(), n; } var sD = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.hasSymbolVisual = !0), (e.ignoreStyleOnData = !0), e; } return ( n(e, t), (e.prototype.getInitialData = function (t) { var e = { name: t.name, children: t.data }, n = t.leaves || {}, i = new Cc(n, this, this.ecModel), r = nD.createTree(e, this, function (t) { t.wrapMethod("getItemModel", function (t, e) { var n = r.getNodeByDataIndex(e); return ( (n && n.children.length && n.isExpand) || (t.parentModel = i), t ); }); }); var o = 0; r.eachNode("preorder", function (t) { t.depth > o && (o = t.depth); }); var a = t.expandAndCollapse && t.initialTreeDepth >= 0 ? t.initialTreeDepth : o; return ( r.root.eachNode("preorder", function (t) { var e = t.hostTree.data.getRawDataItem(t.dataIndex); t.isExpand = e && null != e.collapsed ? !e.collapsed : t.depth <= a; }), r.data ); }), (e.prototype.getOrient = function () { var t = this.get("orient"); return ( "horizontal" === t ? (t = "LR") : "vertical" === t && (t = "TB"), t ); }), (e.prototype.setZoom = function (t) { this.option.zoom = t; }), (e.prototype.setCenter = function (t) { this.option.center = t; }), (e.prototype.formatTooltip = function (t, e, n) { for ( var i = this.getData().tree, r = i.root.children[0], o = i.getNodeByDataIndex(t), a = o.getValue(), s = o.name; o && o !== r; ) (s = o.parentNode.name + "." + s), (o = o.parentNode); return og("nameValue", { name: s, value: a, noValue: isNaN(a) || null == a, }); }), (e.prototype.getDataParams = function (e) { var n = t.prototype.getDataParams.apply(this, arguments), i = this.getData().tree.getNodeByDataIndex(e); return ( (n.treeAncestors = aD(i, this)), (n.collapsed = !i.isExpand), n ); }), (e.type = "series.tree"), (e.layoutMode = "box"), (e.defaultOption = { z: 2, coordinateSystem: "view", left: "12%", top: "12%", right: "12%", bottom: "12%", layout: "orthogonal", edgeShape: "curve", edgeForkPosition: "50%", roam: !1, nodeScaleRatio: 0.4, center: null, zoom: 1, orient: "LR", symbol: "emptyCircle", symbolSize: 7, expandAndCollapse: !0, initialTreeDepth: 2, lineStyle: { color: "#ccc", width: 1.5, curveness: 0.5 }, itemStyle: { color: "lightsteelblue", borderWidth: 1.5 }, label: { show: !0 }, animationEasing: "linear", animationDuration: 700, animationDurationUpdate: 500, }), e ); })(bg); function lD(t, e) { for (var n, i = [t]; (n = i.pop()); ) if ((e(n), n.isExpand)) { var r = n.children; if (r.length) for (var o = r.length - 1; o >= 0; o--) i.push(r[o]); } } function uD(t, e) { t.eachSeriesByType("tree", function (t) { !(function (t, e) { var n = (function (t, e) { return kp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight(), }); })(t, e); t.layoutInfo = n; var i = t.get("layout"), r = 0, o = 0, a = null; "radial" === i ? ((r = 2 * Math.PI), (o = Math.min(n.height, n.width) / 2), (a = kC(function (t, e) { return ( (t.parentNode === e.parentNode ? 1 : 2) / t.depth ); }))) : ((r = n.width), (o = n.height), (a = kC())); var s = t.getData().tree.root, l = s.children[0]; if (l) { !(function (t) { var e = t; e.hierNode = { defaultAncestor: null, ancestor: e, prelim: 0, modifier: 0, change: 0, shift: 0, i: 0, thread: null, }; for (var n, i, r = [e]; (n = r.pop()); ) if (((i = n.children), n.isExpand && i.length)) for (var o = i.length - 1; o >= 0; o--) { var a = i[o]; (a.hierNode = { defaultAncestor: null, ancestor: a, prelim: 0, modifier: 0, change: 0, shift: 0, i: o, thread: null, }), r.push(a); } })(s), (function (t, e, n) { for (var i, r = [t], o = []; (i = r.pop()); ) if ((o.push(i), i.isExpand)) { var a = i.children; if (a.length) for (var s = 0; s < a.length; s++) r.push(a[s]); } for (; (i = o.pop()); ) e(i, n); })(l, DC, a), (s.hierNode.modifier = -l.hierNode.prelim), lD(l, AC); var u = l, h = l, c = l; lD(l, function (t) { var e = t.getLayout().x; e < u.getLayout().x && (u = t), e > h.getLayout().x && (h = t), t.depth > c.depth && (c = t); }); var p = u === h ? 1 : a(u, h) / 2, d = p - u.getLayout().x, f = 0, g = 0, y = 0, v = 0; if ("radial" === i) (f = r / (h.getLayout().x + p + d)), (g = o / (c.depth - 1 || 1)), lD(l, function (t) { (y = (t.getLayout().x + d) * f), (v = (t.depth - 1) * g); var e = LC(y, v); t.setLayout( { x: e.x, y: e.y, rawX: y, rawY: v }, !0 ); }); else { var m = t.getOrient(); "RL" === m || "LR" === m ? ((g = o / (h.getLayout().x + p + d)), (f = r / (c.depth - 1 || 1)), lD(l, function (t) { (v = (t.getLayout().x + d) * g), (y = "LR" === m ? (t.depth - 1) * f : r - (t.depth - 1) * f), t.setLayout({ x: y, y: v }, !0); })) : ("TB" !== m && "BT" !== m) || ((f = r / (h.getLayout().x + p + d)), (g = o / (c.depth - 1 || 1)), lD(l, function (t) { (y = (t.getLayout().x + d) * f), (v = "TB" === m ? (t.depth - 1) * g : o - (t.depth - 1) * g), t.setLayout({ x: y, y: v }, !0); })); } } })(t, e); }); } function hD(t) { t.eachSeriesByType("tree", function (t) { var e = t.getData(); e.tree.eachNode(function (t) { var n = t.getModel().getModel("itemStyle").getItemStyle(); A(e.ensureUniqueItemVisual(t.dataIndex, "style"), n); }); }); } var cD = ["treemapZoomToNode", "treemapRender", "treemapMove"]; function pD(t) { var e = t.getData().tree, n = {}; e.eachNode(function (e) { for (var i = e; i && i.depth > 1; ) i = i.parentNode; var r = pd(t.ecModel, i.name || i.dataIndex + "", n); e.setVisual("decal", r); }); } var dD = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.preventUsingHoverLayer = !0), n; } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { var n = { name: t.name, children: t.data }; fD(n); var i = t.levels || [], r = (this.designatedVisualItemStyle = {}), o = new Cc({ itemStyle: r }, this, e); i = t.levels = (function (t, e) { var n, i, r = To(e.get("color")), o = To(e.get(["aria", "decal", "decals"])); if (!r) return; (t = t || []), E(t, function (t) { var e = new Cc(t), r = e.get("color"), o = e.get("decal"); (e.get(["itemStyle", "color"]) || (r && "none" !== r)) && (n = !0), (e.get(["itemStyle", "decal"]) || (o && "none" !== o)) && (i = !0); }); var a = t[0] || (t[0] = {}); n || (a.color = r.slice()); !i && o && (a.decal = o.slice()); return t; })(i, e); var a = z( i || [], function (t) { return new Cc(t, o, e); }, this ), s = nD.createTree(n, this, function (t) { t.wrapMethod("getItemModel", function (t, e) { var n = s.getNodeByDataIndex(e), i = n ? a[n.depth] : null; return (t.parentModel = i || o), t; }); }); return s.data; }), (e.prototype.optionUpdated = function () { this.resetViewRoot(); }), (e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(), r = this.getRawValue(t); return og("nameValue", { name: i.getName(t), value: r }); }), (e.prototype.getDataParams = function (e) { var n = t.prototype.getDataParams.apply(this, arguments), i = this.getData().tree.getNodeByDataIndex(e); return ( (n.treeAncestors = aD(i, this)), (n.treePathInfo = n.treeAncestors), n ); }), (e.prototype.setLayoutInfo = function (t) { (this.layoutInfo = this.layoutInfo || {}), A(this.layoutInfo, t); }), (e.prototype.mapIdToIndex = function (t) { var e = this._idIndexMap; e || ((e = this._idIndexMap = yt()), (this._idIndexMapCount = 0)); var n = e.get(t); return null == n && e.set(t, (n = this._idIndexMapCount++)), n; }), (e.prototype.getViewRoot = function () { return this._viewRoot; }), (e.prototype.resetViewRoot = function (t) { t ? (this._viewRoot = t) : (t = this._viewRoot); var e = this.getRawData().tree.root; (t && (t === e || e.contains(t))) || (this._viewRoot = e); }), (e.prototype.enableAriaDecal = function () { pD(this); }), (e.type = "series.treemap"), (e.layoutMode = "box"), (e.defaultOption = { progressive: 0, left: "center", top: "middle", width: "80%", height: "80%", sort: !0, clipWindow: "origin", squareRatio: 0.5 * (1 + Math.sqrt(5)), leafDepth: null, drillDownIcon: "▶", zoomToNodeRatio: 0.1024, scaleLimit: null, roam: !0, nodeClick: "zoomToNode", animation: !0, animationDurationUpdate: 900, animationEasing: "quinticInOut", breadcrumb: { show: !0, height: 22, left: "center", top: "bottom", emptyItemWidth: 25, itemStyle: { color: "rgba(0,0,0,0.7)", textStyle: { color: "#fff" }, }, emphasis: { itemStyle: { color: "rgba(0,0,0,0.9)" } }, }, label: { show: !0, distance: 0, padding: 5, position: "inside", color: "#fff", overflow: "truncate", }, upperLabel: { show: !1, position: [0, "50%"], height: 20, overflow: "truncate", verticalAlign: "middle", }, itemStyle: { color: null, colorAlpha: null, colorSaturation: null, borderWidth: 0, gapWidth: 0, borderColor: "#fff", borderColorSaturation: null, }, emphasis: { upperLabel: { show: !0, position: [0, "50%"], overflow: "truncate", verticalAlign: "middle", }, }, visualDimension: 0, visualMin: null, visualMax: null, color: [], colorAlpha: null, colorSaturation: null, colorMappingBy: "index", visibleMin: 10, childrenVisibleMin: null, levels: [], }), e ); })(bg); function fD(t) { var e = 0; E(t.children, function (t) { fD(t); var n = t.value; Y(n) && (n = n[0]), (e += n); }); var n = t.value; Y(n) && (n = n[0]), (null == n || isNaN(n)) && (n = e), n < 0 && (n = 0), Y(t.value) ? (t.value[0] = n) : (t.value = n); } var gD = (function () { function t(t) { (this.group = new Br()), t.add(this.group); } return ( (t.prototype.render = function (t, e, n, i) { var r = t.getModel("breadcrumb"), o = this.group; if ((o.removeAll(), r.get("show") && n)) { var a = r.getModel("itemStyle"), s = r.getModel("emphasis"), l = a.getModel("textStyle"), u = s.getModel(["itemStyle", "textStyle"]), h = { pos: { left: r.get("left"), right: r.get("right"), top: r.get("top"), bottom: r.get("bottom"), }, box: { width: e.getWidth(), height: e.getHeight() }, emptyItemWidth: r.get("emptyItemWidth"), totalWidth: 0, renderList: [], }; this._prepare(n, h, l), this._renderContent(t, h, a, s, l, u, i), Lp(o, h.pos, h.box); } }), (t.prototype._prepare = function (t, e, n) { for (var i = t; i; i = i.parentNode) { var r = Ro(i.getModel().get("name"), ""), o = n.getTextRect(r), a = Math.max(o.width + 16, e.emptyItemWidth); (e.totalWidth += a + 8), e.renderList.push({ node: i, text: r, width: a }); } }), (t.prototype._renderContent = function (t, e, n, i, r, o, a) { for ( var s, l, u, h, c, p, d, f, g, y = 0, v = e.emptyItemWidth, m = t.get(["breadcrumb", "height"]), x = ((s = e.pos), (l = e.box), (h = l.width), (c = l.height), (p = $r(s.left, h)), (d = $r(s.top, c)), (f = $r(s.right, h)), (g = $r(s.bottom, c)), (isNaN(p) || isNaN(parseFloat(s.left))) && (p = 0), (isNaN(f) || isNaN(parseFloat(s.right))) && (f = h), (isNaN(d) || isNaN(parseFloat(s.top))) && (d = 0), (isNaN(g) || isNaN(parseFloat(s.bottom))) && (g = c), (u = vp(u || 0)), { width: Math.max(f - p - u[1] - u[3], 0), height: Math.max(g - d - u[0] - u[2], 0), }), _ = e.totalWidth, b = e.renderList, w = i.getModel("itemStyle").getItemStyle(), S = b.length - 1; S >= 0; S-- ) { var M = b[S], I = M.node, T = M.width, C = M.text; _ > x.width && ((_ -= T - v), (T = v), (C = null)); var D = new Xu({ shape: { points: yD(y, 0, T, m, S === b.length - 1, 0 === S), }, style: k(n.getItemStyle(), { lineJoin: "bevel" }), textContent: new Xs({ style: oc(r, { text: C }) }), textConfig: { position: "inside" }, z2: 1e5, onclick: H(a, I), }); (D.disableLabelAnimation = !0), (D.getTextContent().ensureState("emphasis").style = oc( o, { text: C } )), (D.ensureState("emphasis").style = w), Zl( D, i.get("focus"), i.get("blurScope"), i.get("disabled") ), this.group.add(D), vD(D, t, I), (y += T + 8); } }), (t.prototype.remove = function () { this.group.removeAll(); }), t ); })(); function yD(t, e, n, i, r, o) { var a = [ [r ? t : t - 5, e], [t + n, e], [t + n, e + i], [r ? t : t - 5, e + i], ]; return ( !o && a.splice(2, 0, [t + n + 5, e + i / 2]), !r && a.push([t, e + i / 2]), a ); } function vD(t, e, n) { rl(t).eventData = { componentType: "series", componentSubType: "treemap", componentIndex: e.componentIndex, seriesIndex: e.seriesIndex, seriesName: e.name, seriesType: "treemap", selfType: "breadcrumb", nodeData: { dataIndex: n && n.dataIndex, name: n && n.name }, treePathInfo: n && aD(n, e), }; } var mD = (function () { function t() { (this._storage = []), (this._elExistsMap = {}); } return ( (t.prototype.add = function (t, e, n, i, r) { return ( !this._elExistsMap[t.id] && ((this._elExistsMap[t.id] = !0), this._storage.push({ el: t, target: e, duration: n, delay: i, easing: r, }), !0) ); }), (t.prototype.finished = function (t) { return (this._finishedCallback = t), this; }), (t.prototype.start = function () { for ( var t = this, e = this._storage.length, n = function () { --e <= 0 && ((t._storage.length = 0), (t._elExistsMap = {}), t._finishedCallback && t._finishedCallback()); }, i = 0, r = this._storage.length; i < r; i++ ) { var o = this._storage[i]; o.el.animateTo(o.target, { duration: o.duration, delay: o.delay, easing: o.easing, setToFinal: !0, done: n, aborted: n, }); } return this; }), t ); })(); var xD = Br, _D = Ws, bD = "label", wD = "upperLabel", SD = ia([ ["fill", "color"], ["stroke", "strokeColor"], ["lineWidth", "strokeWidth"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"], ]), MD = function (t) { var e = SD(t); return (e.stroke = e.fill = e.lineWidth = null), e; }, ID = Vo(), TD = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n._state = "ready"), (n._storage = { nodeGroup: [], background: [], content: [], }), n ); } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { if ( !( P( e.findComponents({ mainType: "series", subType: "treemap", query: i, }), t ) < 0 ) ) { (this.seriesModel = t), (this.api = n), (this.ecModel = e); var r = iD( i, ["treemapZoomToNode", "treemapRootToNode"], t ), o = i && i.type, a = t.layoutInfo, s = !this._oldTree, l = this._storage, u = "treemapRootToNode" === o && r && l ? { rootNodeGroup: l.nodeGroup[r.node.getRawIndex()], direction: i.direction, } : null, h = this._giveContainerGroup(a), c = t.get("animation"), p = this._doRender(h, t, u); !c || s || (o && "treemapZoomToNode" !== o && "treemapRootToNode" !== o) ? p.renderFinally() : this._doAnimation(h, p, t, u), this._resetController(n), this._renderBreadcrumb(t, n, r); } }), (e.prototype._giveContainerGroup = function (t) { var e = this._containerGroup; return ( e || ((e = this._containerGroup = new xD()), this._initEvents(e), this.group.add(e)), (e.x = t.x), (e.y = t.y), e ); }), (e.prototype._doRender = function (t, e, n) { var i = e.getData().tree, r = this._oldTree, o = { nodeGroup: [], background: [], content: [] }, a = { nodeGroup: [], background: [], content: [] }, s = this._storage, l = []; function u(t, i, r, u) { return (function (t, e, n, i, r, o, a, s, l, u) { if (!a) return; var h = a.getLayout(), c = t.getData(), p = a.getModel(); if ( (c.setItemGraphicEl(a.dataIndex, null), !h || !h.isInView) ) return; var d = h.width, f = h.height, g = h.borderWidth, y = h.invisible, v = a.getRawIndex(), m = s && s.getRawIndex(), x = a.viewChildren, _ = h.upperHeight, b = x && x.length, w = p.getModel("itemStyle"), S = p.getModel(["emphasis", "itemStyle"]), M = p.getModel(["blur", "itemStyle"]), I = p.getModel(["select", "itemStyle"]), T = w.get("borderRadius") || 0, C = W("nodeGroup", xD); if (!C) return; if ( (l.add(C), (C.x = h.x || 0), (C.y = h.y || 0), C.markRedraw(), (ID(C).nodeWidth = d), (ID(C).nodeHeight = f), h.isAboveViewRoot) ) return C; var D = W("background", _D, u, 20); D && z(C, D, b && h.upperLabelHeight); var k = p.getModel("emphasis"), L = k.get("focus"), P = k.get("blurScope"), O = k.get("disabled"), R = "ancestor" === L ? a.getAncestorsIndices() : "descendant" === L ? a.getDescendantIndices() : L; if (b) Ql(C) && Jl(C, !1), D && (Jl(D, !O), c.setItemGraphicEl(a.dataIndex, D), jl(D, R, P)); else { var N = W("content", _D, u, 30); N && V(C, N), (D.disableMorphing = !0), D && Ql(D) && Jl(D, !1), Jl(C, !O), c.setItemGraphicEl(a.dataIndex, C); var E = p.getShallow("cursor"); E && N.attr("cursor", E), jl(C, R, P); } return C; function z(e, n, i) { var r = rl(n); if ( ((r.dataIndex = a.dataIndex), (r.seriesIndex = t.seriesIndex), n.setShape({ x: 0, y: 0, width: d, height: f, r: T, }), y) ) B(n); else { n.invisible = !1; var o = a.getVisual("style"), s = o.stroke, l = MD(w); l.fill = s; var u = SD(S); u.fill = S.get("borderColor"); var h = SD(M); h.fill = M.get("borderColor"); var c = SD(I); if (((c.fill = I.get("borderColor")), i)) { var p = d - 2 * g; F(n, s, o.opacity, { x: g, y: 0, width: p, height: _, }); } else n.removeTextContent(); n.setStyle(l), (n.ensureState("emphasis").style = u), (n.ensureState("blur").style = h), (n.ensureState("select").style = c), kl(n); } e.add(n); } function V(e, n) { var i = rl(n); (i.dataIndex = a.dataIndex), (i.seriesIndex = t.seriesIndex); var r = Math.max(d - 2 * g, 0), o = Math.max(f - 2 * g, 0); if ( ((n.culling = !0), n.setShape({ x: g, y: g, width: r, height: o, r: T, }), y) ) B(n); else { n.invisible = !1; var s = a.getVisual("style"), l = s.fill, u = MD(w); (u.fill = l), (u.decal = s.decal); var h = SD(S), c = SD(M), p = SD(I); F(n, l, s.opacity, null), n.setStyle(u), (n.ensureState("emphasis").style = h), (n.ensureState("blur").style = c), (n.ensureState("select").style = p), kl(n); } e.add(n); } function B(t) { !t.invisible && o.push(t); } function F(e, n, i, r) { var o = p.getModel(r ? wD : bD), s = Ro(p.get("name"), null), l = o.getShallow("show"); ic(e, rc(p, r ? wD : bD), { defaultText: l ? s : null, inheritColor: n, defaultOpacity: i, labelFetcher: t, labelDataIndex: a.dataIndex, }); var u = e.getTextContent(); if (u) { var c = u.style, d = st(c.padding || 0); r && (e.setTextConfig({ layoutRect: r }), (u.disableLabelLayout = !0)), (u.beforeUpdate = function () { var t = Math.max( (r ? r.width : e.shape.width) - d[1] - d[3], 0 ), n = Math.max( (r ? r.height : e.shape.height) - d[0] - d[2], 0 ); (c.width === t && c.height === n) || u.setStyle({ width: t, height: n, }); }), (c.truncateMinChar = 2), (c.lineOverflow = "truncate"), G(c, r, h); var f = u.getState("emphasis"); G(f ? f.style : null, r, h); } } function G(e, n, i) { var r = e ? e.text : null; if (!n && i.isLeafRoot && null != r) { var o = t.get("drillDownIcon", !0); e.text = o ? o + " " + r : r; } } function W(t, i, o, a) { var s = null != m && n[t][m], l = r[t]; return ( s ? ((n[t][m] = null), H(l, s)) : y || ((s = new i()) instanceof Da && (s.z2 = (function (t, e) { return 100 * t + e; })(o, a)), Y(l, s)), (e[t][v] = s) ); } function H(t, e) { var n = (t[v] = {}); e instanceof xD ? ((n.oldX = e.x), (n.oldY = e.y)) : (n.oldShape = A({}, e.shape)); } function Y(t, e) { var n = (t[v] = {}), o = a.parentNode, s = e instanceof Br; if (o && (!i || "drillDown" === i.direction)) { var l = 0, u = 0, h = r.background[o.getRawIndex()]; !i && h && h.oldShape && ((l = h.oldShape.width), (u = h.oldShape.height)), s ? ((n.oldX = 0), (n.oldY = u)) : (n.oldShape = { x: l, y: u, width: 0, height: 0, }); } n.fadein = !s; } })(e, a, s, n, o, l, t, i, r, u); } !(function t(e, n, i, r, o) { r ? ((n = e), E(e, function (t, e) { !t.isRemoved() && s(e, e); })) : new Gm(n, e, a, a) .add(s) .update(s) .remove(H(s, null)) .execute(); function a(t) { return t.getId(); } function s(a, s) { var l = null != a ? e[a] : null, h = null != s ? n[s] : null, c = u(l, h, i, o); c && t( (l && l.viewChildren) || [], (h && h.viewChildren) || [], c, r, o + 1 ); } })( i.root ? [i.root] : [], r && r.root ? [r.root] : [], t, i === r || !r, 0 ); var h = (function (t) { var e = { nodeGroup: [], background: [], content: [] }; return ( t && E(t, function (t, n) { var i = e[n]; E(t, function (t) { t && (i.push(t), (ID(t).willDelete = !0)); }); }), e ); })(s); if ( ((this._oldTree = i), (this._storage = a), this._controllerHost) ) { var c = this.seriesModel.layoutInfo, p = i.root.getLayout(); p.width === c.width && p.height === c.height && (this._controllerHost.zoom = 1); } return { lastsForAnimation: o, willDeleteEls: h, renderFinally: function () { E(h, function (t) { E(t, function (t) { t.parent && t.parent.remove(t); }); }), E(l, function (t) { (t.invisible = !0), t.dirty(); }); }, }; }), (e.prototype._doAnimation = function (t, e, n, i) { var r = n.get("animationDurationUpdate"), o = n.get("animationEasing"), a = (X(r) ? 0 : r) || 0, s = (X(o) ? null : o) || "cubicOut", l = new mD(); E(e.willDeleteEls, function (t, e) { E(t, function (t, n) { if (!t.invisible) { var r, o = t.parent, u = ID(o); if (i && "drillDown" === i.direction) r = o === i.rootNodeGroup ? { shape: { x: 0, y: 0, width: u.nodeWidth, height: u.nodeHeight, }, style: { opacity: 0 }, } : { style: { opacity: 0 } }; else { var h = 0, c = 0; u.willDelete || ((h = u.nodeWidth / 2), (c = u.nodeHeight / 2)), (r = "nodeGroup" === e ? { x: h, y: c, style: { opacity: 0 }, } : { shape: { x: h, y: c, width: 0, height: 0, }, style: { opacity: 0 }, }); } r && l.add(t, r, a, 0, s); } }); }), E( this._storage, function (t, n) { E(t, function (t, i) { var r = e.lastsForAnimation[n][i], o = {}; r && (t instanceof Br ? null != r.oldX && ((o.x = t.x), (o.y = t.y), (t.x = r.oldX), (t.y = r.oldY)) : (r.oldShape && ((o.shape = A({}, t.shape)), t.setShape(r.oldShape)), r.fadein ? (t.setStyle("opacity", 0), (o.style = { opacity: 1 })) : 1 !== t.style.opacity && (o.style = { opacity: 1 })), l.add(t, o, a, 0, s)); }); }, this ), (this._state = "animating"), l .finished( W(function () { (this._state = "ready"), e.renderFinally(); }, this) ) .start(); }), (e.prototype._resetController = function (t) { var e = this._controller, n = this._controllerHost; n || ((this._controllerHost = { target: this.group }), (n = this._controllerHost)), e || ((e = this._controller = new nT(t.getZr())).enable( this.seriesModel.get("roam") ), (n.zoomLimit = this.seriesModel.get("scaleLimit")), (n.zoom = this.seriesModel.get("zoom")), e.on("pan", W(this._onPan, this)), e.on("zoom", W(this._onZoom, this))); var i = new ze(0, 0, t.getWidth(), t.getHeight()); e.setPointerChecker(function (t, e, n) { return i.contain(e, n); }); }), (e.prototype._clearController = function () { var t = this._controller; (this._controllerHost = null), t && (t.dispose(), (t = null)); }), (e.prototype._onPan = function (t) { if ( "animating" !== this._state && (Math.abs(t.dx) > 3 || Math.abs(t.dy) > 3) ) { var e = this.seriesModel.getData().tree.root; if (!e) return; var n = e.getLayout(); if (!n) return; this.api.dispatchAction({ type: "treemapMove", from: this.uid, seriesId: this.seriesModel.id, rootRect: { x: n.x + t.dx, y: n.y + t.dy, width: n.width, height: n.height, }, }); } }), (e.prototype._onZoom = function (t) { var e = t.originX, n = t.originY, i = t.scale; if ("animating" !== this._state) { var r = this.seriesModel.getData().tree.root; if (!r) return; var o = r.getLayout(); if (!o) return; var a, s = new ze(o.x, o.y, o.width, o.height), l = this._controllerHost; a = l.zoomLimit; var u = (l.zoom = l.zoom || 1); if (((u *= i), a)) { var h = a.min || 0, c = a.max || 1 / 0; u = Math.max(Math.min(c, u), h); } var p = u / l.zoom; l.zoom = u; var d = this.seriesModel.layoutInfo, f = [1, 0, 0, 1, 0, 0]; we(f, f, [-(e -= d.x), -(n -= d.y)]), Me(f, f, [p, p]), we(f, f, [e, n]), s.applyTransform(f), this.api.dispatchAction({ type: "treemapRender", from: this.uid, seriesId: this.seriesModel.id, rootRect: { x: s.x, y: s.y, width: s.width, height: s.height, }, }); } }), (e.prototype._initEvents = function (t) { var e = this; t.on( "click", function (t) { if ("ready" === e._state) { var n = e.seriesModel.get("nodeClick", !0); if (n) { var i = e.findTarget(t.offsetX, t.offsetY); if (i) { var r = i.node; if (r.getLayout().isLeafRoot) e._rootToNode(i); else if ("zoomToNode" === n) e._zoomToNode(i); else if ("link" === n) { var o = r.hostTree.data.getItemModel( r.dataIndex ), a = o.get("link", !0), s = o.get("target", !0) || "blank"; a && Mp(a, s); } } } } }, this ); }), (e.prototype._renderBreadcrumb = function (t, e, n) { var i = this; n || (n = null != t.get("leafDepth", !0) ? { node: t.getViewRoot() } : this.findTarget( e.getWidth() / 2, e.getHeight() / 2 )) || (n = { node: t.getData().tree.root }), ( this._breadcrumb || (this._breadcrumb = new gD(this.group)) ).render(t, e, n.node, function (e) { "animating" !== i._state && (oD(t.getViewRoot(), e) ? i._rootToNode({ node: e }) : i._zoomToNode({ node: e })); }); }), (e.prototype.remove = function () { this._clearController(), this._containerGroup && this._containerGroup.removeAll(), (this._storage = { nodeGroup: [], background: [], content: [], }), (this._state = "ready"), this._breadcrumb && this._breadcrumb.remove(); }), (e.prototype.dispose = function () { this._clearController(); }), (e.prototype._zoomToNode = function (t) { this.api.dispatchAction({ type: "treemapZoomToNode", from: this.uid, seriesId: this.seriesModel.id, targetNode: t.node, }); }), (e.prototype._rootToNode = function (t) { this.api.dispatchAction({ type: "treemapRootToNode", from: this.uid, seriesId: this.seriesModel.id, targetNode: t.node, }); }), (e.prototype.findTarget = function (t, e) { var n; return ( this.seriesModel.getViewRoot().eachNode( { attr: "viewChildren", order: "preorder" }, function (i) { var r = this._storage.background[i.getRawIndex()]; if (r) { var o = r.transformCoordToLocal(t, e), a = r.shape; if ( !( a.x <= o[0] && o[0] <= a.x + a.width && a.y <= o[1] && o[1] <= a.y + a.height ) ) return !1; n = { node: i, offsetX: o[0], offsetY: o[1], }; } }, this ), n ); }), (e.type = "treemap"), e ); })(Og); var CD = E, DD = q, AD = -1, kD = (function () { function t(e) { var n = e.mappingMethod, i = e.type, r = (this.option = T(e)); (this.type = i), (this.mappingMethod = n), (this._normalizeData = FD[n]); var o = t.visualHandlers[i]; (this.applyVisual = o.applyVisual), (this.getColorMapper = o.getColorMapper), (this._normalizedToVisual = o._normalizedToVisual[n]), "piecewise" === n ? (LD(r), (function (t) { var e = t.pieceList; (t.hasSpecialVisual = !1), E(e, function (e, n) { (e.originIndex = n), null != e.visual && (t.hasSpecialVisual = !0); }); })(r)) : "category" === n ? r.categories ? (function (t) { var e = t.categories, n = (t.categoryMap = {}), i = t.visual; if ( (CD(e, function (t, e) { n[t] = e; }), !Y(i)) ) { var r = []; q(i) ? CD(i, function (t, e) { var i = n[e]; r[null != i ? i : AD] = t; }) : (r[-1] = i), (i = BD(t, r)); } for (var o = e.length - 1; o >= 0; o--) null == i[o] && (delete n[e[o]], e.pop()); })(r) : LD(r, !0) : (lt("linear" !== n || r.dataExtent), LD(r)); } return ( (t.prototype.mapValueToVisual = function (t) { var e = this._normalizeData(t); return this._normalizedToVisual(e, t); }), (t.prototype.getNormalizer = function () { return W(this._normalizeData, this); }), (t.listVisualTypes = function () { return G(t.visualHandlers); }), (t.isValidType = function (e) { return t.visualHandlers.hasOwnProperty(e); }), (t.eachVisual = function (t, e, n) { q(t) ? E(t, e, n) : e.call(n, t); }), (t.mapVisual = function (e, n, i) { var r, o = Y(e) ? [] : q(e) ? {} : ((r = !0), null); return ( t.eachVisual(e, function (t, e) { var a = n.call(i, t, e); r ? (o = a) : (o[e] = a); }), o ); }), (t.retrieveVisuals = function (e) { var n, i = {}; return ( e && CD(t.visualHandlers, function (t, r) { e.hasOwnProperty(r) && ((i[r] = e[r]), (n = !0)); }), n ? i : null ); }), (t.prepareVisualTypes = function (t) { if (Y(t)) t = t.slice(); else { if (!DD(t)) return []; var e = []; CD(t, function (t, n) { e.push(n); }), (t = e); } return ( t.sort(function (t, e) { return "color" === e && "color" !== t && 0 === t.indexOf("color") ? 1 : -1; }), t ); }), (t.dependsOn = function (t, e) { return "color" === e ? !(!t || 0 !== t.indexOf(e)) : t === e; }), (t.findPieceIndex = function (t, e, n) { for (var i, r = 1 / 0, o = 0, a = e.length; o < a; o++) { var s = e[o].value; if (null != s) { if (s === t || (U(s) && s === t + "")) return o; n && c(s, o); } } for (o = 0, a = e.length; o < a; o++) { var l = e[o], u = l.interval, h = l.close; if (u) { if (u[0] === -1 / 0) { if (GD(h[1], t, u[1])) return o; } else if (u[1] === 1 / 0) { if (GD(h[0], u[0], t)) return o; } else if (GD(h[0], u[0], t) && GD(h[1], t, u[1])) return o; n && c(u[0], o), n && c(u[1], o); } } if (n) return t === 1 / 0 ? e.length - 1 : t === -1 / 0 ? 0 : i; function c(e, n) { var o = Math.abs(e - t); o < r && ((r = o), (i = n)); } }), (t.visualHandlers = { color: { applyVisual: RD("color"), getColorMapper: function () { var t = this.option; return W( "category" === t.mappingMethod ? function (t, e) { return ( !e && (t = this._normalizeData(t)), ND.call(this, t) ); } : function (e, n, i) { var r = !!i; return ( !n && (e = this._normalizeData(e)), (i = Jn(e, t.parsedVisual, i)), r ? i : ri(i, "rgba") ); }, this ); }, _normalizedToVisual: { linear: function (t) { return ri( Jn(t, this.option.parsedVisual), "rgba" ); }, category: ND, piecewise: function (t, e) { var n = VD.call(this, e); return ( null == n && (n = ri( Jn(t, this.option.parsedVisual), "rgba" )), n ); }, fixed: ED, }, }, colorHue: PD(function (t, e) { return ni(t, e); }), colorSaturation: PD(function (t, e) { return ni(t, null, e); }), colorLightness: PD(function (t, e) { return ni(t, null, null, e); }), colorAlpha: PD(function (t, e) { return ii(t, e); }), decal: { applyVisual: RD("decal"), _normalizedToVisual: { linear: null, category: ND, piecewise: null, fixed: null, }, }, opacity: { applyVisual: RD("opacity"), _normalizedToVisual: zD([0, 1]), }, liftZ: { applyVisual: RD("liftZ"), _normalizedToVisual: { linear: ED, category: ED, piecewise: ED, fixed: ED, }, }, symbol: { applyVisual: function (t, e, n) { n("symbol", this.mapValueToVisual(t)); }, _normalizedToVisual: { linear: OD, category: ND, piecewise: function (t, e) { var n = VD.call(this, e); return null == n && (n = OD.call(this, t)), n; }, fixed: ED, }, }, symbolSize: { applyVisual: RD("symbolSize"), _normalizedToVisual: zD([0, 1]), }, }), t ); })(); function LD(t, e) { var n = t.visual, i = []; q(n) ? CD(n, function (t) { i.push(t); }) : null != n && i.push(n); e || 1 !== i.length || { color: 1, symbol: 1 }.hasOwnProperty(t.type) || (i[1] = i[0]), BD(t, i); } function PD(t) { return { applyVisual: function (e, n, i) { var r = this.mapValueToVisual(e); i("color", t(n("color"), r)); }, _normalizedToVisual: zD([0, 1]), }; } function OD(t) { var e = this.option.visual; return e[Math.round(Kr(t, [0, 1], [0, e.length - 1], !0))] || {}; } function RD(t) { return function (e, n, i) { i(t, this.mapValueToVisual(e)); }; } function ND(t) { var e = this.option.visual; return e[this.option.loop && t !== AD ? t % e.length : t]; } function ED() { return this.option.visual[0]; } function zD(t) { return { linear: function (e) { return Kr(e, t, this.option.visual, !0); }, category: ND, piecewise: function (e, n) { var i = VD.call(this, n); return null == i && (i = Kr(e, t, this.option.visual, !0)), i; }, fixed: ED, }; } function VD(t) { var e = this.option, n = e.pieceList; if (e.hasSpecialVisual) { var i = n[kD.findPieceIndex(t, n)]; if (i && i.visual) return i.visual[this.type]; } } function BD(t, e) { return ( (t.visual = e), "color" === t.type && (t.parsedVisual = z(e, function (t) { var e = qn(t); return e || [0, 0, 0, 1]; })), e ); } var FD = { linear: function (t) { return Kr(t, this.option.dataExtent, [0, 1], !0); }, piecewise: function (t) { var e = this.option.pieceList, n = kD.findPieceIndex(t, e, !0); if (null != n) return Kr(n, [0, e.length - 1], [0, 1], !0); }, category: function (t) { var e = this.option.categories ? this.option.categoryMap[t] : t; return null == e ? AD : e; }, fixed: bt, }; function GD(t, e, n) { return t ? e <= n : e < n; } var WD = Vo(), HD = { seriesType: "treemap", reset: function (t) { var e = t.getData().tree.root; e.isRemoved() || YD(e, {}, t.getViewRoot().getAncestors(), t); }, }; function YD(t, e, n, i) { var r = t.getModel(), o = t.getLayout(), a = t.hostTree.data; if (o && !o.invisible && o.isInView) { var s, l = r.getModel("itemStyle"), u = (function (t, e, n) { var i = A({}, e), r = n.designatedVisualItemStyle; return ( E( ["color", "colorAlpha", "colorSaturation"], function (n) { r[n] = e[n]; var o = t.get(n); (r[n] = null), null != o && (i[n] = o); } ), i ); })(l, e, i), h = a.ensureUniqueItemVisual(t.dataIndex, "style"), c = l.get("borderColor"), p = l.get("borderColorSaturation"); null != p && (c = (function (t, e) { return null != e ? ni(e, null, null, t) : null; })(p, (s = XD(u)))), (h.stroke = c); var d = t.viewChildren; if (d && d.length) { var f = (function (t, e, n, i, r, o) { if (!o || !o.length) return; var a = ZD(e, "color") || (null != r.color && "none" !== r.color && (ZD(e, "colorAlpha") || ZD(e, "colorSaturation"))); if (!a) return; var s = e.get("visualMin"), l = e.get("visualMax"), u = n.dataExtent.slice(); null != s && s < u[0] && (u[0] = s), null != l && l > u[1] && (u[1] = l); var h = e.get("colorMappingBy"), c = { type: a.name, dataExtent: u, visual: a.range }; "color" !== c.type || ("index" !== h && "id" !== h) ? (c.mappingMethod = "linear") : ((c.mappingMethod = "category"), (c.loop = !0)); var p = new kD(c); return (WD(p).drColorMappingBy = h), p; })(0, r, o, 0, u, d); E(d, function (t, e) { if (t.depth >= n.length || t === n[t.depth]) { var o = (function (t, e, n, i, r, o) { var a = A({}, e); if (r) { var s = r.type, l = "color" === s && WD(r).drColorMappingBy, u = "index" === l ? i : "id" === l ? o.mapIdToIndex(n.getId()) : n.getValue( t.get("visualDimension") ); a[s] = r.mapValueToVisual(u); } return a; })(r, u, t, e, f, i); YD(t, o, n, i); } }); } else (s = XD(u)), (h.fill = s); } } function XD(t) { var e = UD(t, "color"); if (e) { var n = UD(t, "colorAlpha"), i = UD(t, "colorSaturation"); return i && (e = ni(e, null, null, i)), n && (e = ii(e, n)), e; } } function UD(t, e) { var n = t[e]; if (null != n && "none" !== n) return n; } function ZD(t, e) { var n = t.get(e); return Y(n) && n.length ? { name: e, range: n } : null; } var jD = Math.max, qD = Math.min, KD = it, $D = E, JD = ["itemStyle", "borderWidth"], QD = ["itemStyle", "gapWidth"], tA = ["upperLabel", "show"], eA = ["upperLabel", "height"], nA = { seriesType: "treemap", reset: function (t, e, n, i) { var r = n.getWidth(), o = n.getHeight(), a = t.option, s = kp(t.getBoxLayoutParams(), { width: n.getWidth(), height: n.getHeight(), }), l = a.size || [], u = $r(KD(s.width, l[0]), r), h = $r(KD(s.height, l[1]), o), c = i && i.type, p = iD(i, ["treemapZoomToNode", "treemapRootToNode"], t), d = "treemapRender" === c || "treemapMove" === c ? i.rootRect : null, f = t.getViewRoot(), g = rD(f); if ("treemapMove" !== c) { var y = "treemapZoomToNode" === c ? (function (t, e, n, i, r) { var o, a = (e || {}).node, s = [i, r]; if (!a || a === n) return s; var l = i * r, u = l * t.option.zoomToNodeRatio; for (; (o = a.parentNode); ) { for ( var h = 0, c = o.children, p = 0, d = c.length; p < d; p++ ) h += c[p].getValue(); var f = a.getValue(); if (0 === f) return s; u *= h / f; var g = o.getModel(), y = g.get(JD); (u += 4 * y * y + (3 * y + Math.max(y, sA(g))) * Math.pow(u, 0.5)) > oo && (u = oo), (a = o); } u < l && (u = l); var v = Math.pow(u / l, 0.5); return [i * v, r * v]; })(t, p, f, u, h) : d ? [d.width, d.height] : [u, h], v = a.sort; v && "asc" !== v && "desc" !== v && (v = "desc"); var m = { squareRatio: a.squareRatio, sort: v, leafDepth: a.leafDepth, }; f.hostTree.clearLayouts(); var x = { x: 0, y: 0, width: y[0], height: y[1], area: y[0] * y[1], }; f.setLayout(x), iA(f, m, !1, 0), (x = f.getLayout()), $D(g, function (t, e) { var n = (g[e + 1] || f).getValue(); t.setLayout( A( { dataExtent: [n, n], borderWidth: 0, upperHeight: 0, }, x ) ); }); } var _ = t.getData().tree.root; _.setLayout( (function (t, e, n) { if (e) return { x: e.x, y: e.y }; var i = { x: 0, y: 0 }; if (!n) return i; var r = n.node, o = r.getLayout(); if (!o) return i; var a = [o.width / 2, o.height / 2], s = r; for (; s; ) { var l = s.getLayout(); (a[0] += l.x), (a[1] += l.y), (s = s.parentNode); } return { x: t.width / 2 - a[0], y: t.height / 2 - a[1], }; })(s, d, p), !0 ), t.setLayoutInfo(s), aA(_, new ze(-s.x, -s.y, r, o), g, f, 0); }, }; function iA(t, e, n, i) { var r, o; if (!t.isRemoved()) { var a = t.getLayout(); (r = a.width), (o = a.height); var s = t.getModel(), l = s.get(JD), u = s.get(QD) / 2, h = sA(s), c = Math.max(l, h), p = l - u, d = c - u; t.setLayout( { borderWidth: l, upperHeight: c, upperLabelHeight: h }, !0 ); var f = (r = jD(r - 2 * p, 0)) * (o = jD(o - p - d, 0)), g = (function (t, e, n, i, r, o) { var a = t.children || [], s = i.sort; "asc" !== s && "desc" !== s && (s = null); var l = null != i.leafDepth && i.leafDepth <= o; if (r && !l) return (t.viewChildren = []); (a = B(a, function (t) { return !t.isRemoved(); })), (function (t, e) { e && t.sort(function (t, n) { var i = "asc" === e ? t.getValue() - n.getValue() : n.getValue() - t.getValue(); return 0 === i ? "asc" === e ? t.dataIndex - n.dataIndex : n.dataIndex - t.dataIndex : i; }); })(a, s); var u = (function (t, e, n) { for (var i = 0, r = 0, o = e.length; r < o; r++) i += e[r].getValue(); var a, s = t.get("visualDimension"); e && e.length ? "value" === s && n ? ((a = [ e[e.length - 1].getValue(), e[0].getValue(), ]), "asc" === n && a.reverse()) : ((a = [1 / 0, -1 / 0]), $D(e, function (t) { var e = t.getValue(s); e < a[0] && (a[0] = e), e > a[1] && (a[1] = e); })) : (a = [NaN, NaN]); return { sum: i, dataExtent: a }; })(e, a, s); if (0 === u.sum) return (t.viewChildren = []); if ( ((u.sum = (function (t, e, n, i, r) { if (!i) return n; for ( var o = t.get("visibleMin"), a = r.length, s = a, l = a - 1; l >= 0; l-- ) { var u = r["asc" === i ? a - l - 1 : l].getValue(); (u / n) * e < o && ((s = l), (n -= u)); } return ( "asc" === i ? r.splice(0, a - s) : r.splice(s, a - s), n ); })(e, n, u.sum, s, a)), 0 === u.sum) ) return (t.viewChildren = []); for (var h = 0, c = a.length; h < c; h++) { var p = (a[h].getValue() / u.sum) * n; a[h].setLayout({ area: p }); } l && (a.length && t.setLayout({ isLeafRoot: !0 }, !0), (a.length = 0)); return ( (t.viewChildren = a), t.setLayout({ dataExtent: u.dataExtent }, !0), a ); })(t, s, f, e, n, i); if (g.length) { var y = { x: p, y: d, width: r, height: o }, v = qD(r, o), m = 1 / 0, x = []; x.area = 0; for (var _ = 0, b = g.length; _ < b; ) { var w = g[_]; x.push(w), (x.area += w.getLayout().area); var S = rA(x, v, e.squareRatio); S <= m ? (_++, (m = S)) : ((x.area -= x.pop().getLayout().area), oA(x, v, y, u, !1), (v = qD(y.width, y.height)), (x.length = x.area = 0), (m = 1 / 0)); } if ((x.length && oA(x, v, y, u, !0), !n)) { var M = s.get("childrenVisibleMin"); null != M && f < M && (n = !0); } for (_ = 0, b = g.length; _ < b; _++) iA(g[_], e, n, i + 1); } } } function rA(t, e, n) { for (var i = 0, r = 1 / 0, o = 0, a = void 0, s = t.length; o < s; o++) (a = t[o].getLayout().area) && (a < r && (r = a), a > i && (i = a)); var l = t.area * t.area, u = e * e * n; return l ? jD((u * i) / l, l / (u * r)) : 1 / 0; } function oA(t, e, n, i, r) { var o = e === n.width ? 0 : 1, a = 1 - o, s = ["x", "y"], l = ["width", "height"], u = n[s[o]], h = e ? t.area / e : 0; (r || h > n[l[a]]) && (h = n[l[a]]); for (var c = 0, p = t.length; c < p; c++) { var d = t[c], f = {}, g = h ? d.getLayout().area / h : 0, y = (f[l[a]] = jD(h - 2 * i, 0)), v = n[s[o]] + n[l[o]] - u, m = c === p - 1 || v < g ? v : g, x = (f[l[o]] = jD(m - 2 * i, 0)); (f[s[a]] = n[s[a]] + qD(i, y / 2)), (f[s[o]] = u + qD(i, x / 2)), (u += m), d.setLayout(f, !0); } (n[s[a]] += h), (n[l[a]] -= h); } function aA(t, e, n, i, r) { var o = t.getLayout(), a = n[r], s = a && a === t; if (!((a && !s) || (r === n.length && t !== i))) { t.setLayout( { isInView: !0, invisible: !s && !e.intersect(o), isAboveViewRoot: s, }, !0 ); var l = new ze(e.x - o.x, e.y - o.y, e.width, e.height); $D(t.viewChildren || [], function (t) { aA(t, l, n, i, r + 1); }); } } function sA(t) { return t.get(tA) ? t.get(eA) : 0; } function lA(t) { var e = t.findComponents({ mainType: "legend" }); e && e.length && t.eachSeriesByType("graph", function (t) { var n = t.getCategoriesData(), i = t.getGraph().data, r = n.mapArray(n.getName); i.filterSelf(function (t) { var n = i.getItemModel(t).getShallow("category"); if (null != n) { j(n) && (n = r[n]); for (var o = 0; o < e.length; o++) if (!e[o].isSelected(n)) return !1; } return !0; }); }); } function uA(t) { var e = {}; t.eachSeriesByType("graph", function (t) { var n = t.getCategoriesData(), i = t.getData(), r = {}; n.each(function (i) { var o = n.getName(i); r["ec-" + o] = i; var a = n.getItemModel(i), s = a.getModel("itemStyle").getItemStyle(); s.fill || (s.fill = t.getColorFromPalette(o, e)), n.setItemVisual(i, "style", s); for ( var l = ["symbol", "symbolSize", "symbolKeepAspect"], u = 0; u < l.length; u++ ) { var h = a.getShallow(l[u], !0); null != h && n.setItemVisual(i, l[u], h); } }), n.count() && i.each(function (t) { var e = i.getItemModel(t).getShallow("category"); if (null != e) { U(e) && (e = r["ec-" + e]); var o = n.getItemVisual(e, "style"); A(i.ensureUniqueItemVisual(t, "style"), o); for ( var a = [ "symbol", "symbolSize", "symbolKeepAspect", ], s = 0; s < a.length; s++ ) i.setItemVisual( t, a[s], n.getItemVisual(e, a[s]) ); } }); }); } function hA(t) { return t instanceof Array || (t = [t, t]), t; } function cA(t) { t.eachSeriesByType("graph", function (t) { var e = t.getGraph(), n = t.getEdgeData(), i = hA(t.get("edgeSymbol")), r = hA(t.get("edgeSymbolSize")); n.setVisual("fromSymbol", i && i[0]), n.setVisual("toSymbol", i && i[1]), n.setVisual("fromSymbolSize", r && r[0]), n.setVisual("toSymbolSize", r && r[1]), n.setVisual("style", t.getModel("lineStyle").getLineStyle()), n.each(function (t) { var i = n.getItemModel(t), r = e.getEdgeByIndex(t), o = hA(i.getShallow("symbol", !0)), a = hA(i.getShallow("symbolSize", !0)), s = i.getModel("lineStyle").getLineStyle(), l = n.ensureUniqueItemVisual(t, "style"); switch ((A(l, s), l.stroke)) { case "source": var u = r.node1.getVisual("style"); l.stroke = u && u.fill; break; case "target": u = r.node2.getVisual("style"); l.stroke = u && u.fill; } o[0] && r.setVisual("fromSymbol", o[0]), o[1] && r.setVisual("toSymbol", o[1]), a[0] && r.setVisual("fromSymbolSize", a[0]), a[1] && r.setVisual("toSymbolSize", a[1]); }); }); } var pA = "--\x3e", dA = function (t) { return t.get("autoCurveness") || null; }, fA = function (t, e) { var n = dA(t), i = 20, r = []; if (j(n)) i = n; else if (Y(n)) return void (t.__curvenessList = n); e > i && (i = e); var o = i % 2 ? i + 2 : i + 3; r = []; for (var a = 0; a < o; a++) r.push(((a % 2 ? a + 1 : a) / 10) * (a % 2 ? -1 : 1)); t.__curvenessList = r; }, gA = function (t, e, n) { var i = [t.id, t.dataIndex].join("."), r = [e.id, e.dataIndex].join("."); return [n.uid, i, r].join(pA); }, yA = function (t) { var e = t.split(pA); return [e[0], e[2], e[1]].join(pA); }, vA = function (t, e) { var n = e.__edgeMap; return n[t] ? n[t].length : 0; }; function mA(t, e, n, i) { var r = dA(e), o = Y(r); if (!r) return null; var a = (function (t, e) { var n = gA(t.node1, t.node2, e); return e.__edgeMap[n]; })(t, e); if (!a) return null; for (var s = -1, l = 0; l < a.length; l++) if (a[l] === n) { s = l; break; } var u = (function (t, e) { return ( vA(gA(t.node1, t.node2, e), e) + vA(gA(t.node2, t.node1, e), e) ); })(t, e); fA(e, u), (t.lineStyle = t.lineStyle || {}); var h = gA(t.node1, t.node2, e), c = e.__curvenessList, p = o || u % 2 ? 0 : 1; if (a.isForward) return c[p + s]; var d = yA(h), f = vA(d, e), g = c[s + f + p]; return i ? o ? r && 0 === r[0] ? (f + p) % 2 ? g : -g : ((f % 2 ? 0 : 1) + p) % 2 ? g : -g : (f + p) % 2 ? g : -g : c[s + f + p]; } function xA(t) { var e = t.coordinateSystem; if (!e || "view" === e.type) { var n = t.getGraph(); n.eachNode(function (t) { var e = t.getModel(); t.setLayout([+e.get("x"), +e.get("y")]); }), _A(n, t); } } function _A(t, e) { t.eachEdge(function (t, n) { var i = ot( t.getModel().get(["lineStyle", "curveness"]), -mA(t, e, n, !0), 0 ), r = Tt(t.node1.getLayout()), o = Tt(t.node2.getLayout()), a = [r, o]; +i && a.push([ (r[0] + o[0]) / 2 - (r[1] - o[1]) * i, (r[1] + o[1]) / 2 - (o[0] - r[0]) * i, ]), t.setLayout(a); }); } function bA(t, e) { t.eachSeriesByType("graph", function (t) { var e = t.get("layout"), n = t.coordinateSystem; if (n && "view" !== n.type) { var i = t.getData(), r = []; E(n.dimensions, function (t) { r = r.concat(i.mapDimensionsAll(t)); }); for (var o = 0; o < i.count(); o++) { for (var a = [], s = !1, l = 0; l < r.length; l++) { var u = i.get(r[l], o); isNaN(u) || (s = !0), a.push(u); } s ? i.setItemLayout(o, n.dataToPoint(a)) : i.setItemLayout(o, [NaN, NaN]); } _A(i.graph, t); } else (e && "none" !== e) || xA(t); }); } function wA(t) { var e = t.coordinateSystem; if ("view" !== e.type) return 1; var n = t.option.nodeScaleRatio, i = e.scaleX; return ((e.getZoom() - 1) * n + 1) / i; } function SA(t) { var e = t.getVisual("symbolSize"); return e instanceof Array && (e = (e[0] + e[1]) / 2), +e; } var MA = Math.PI, IA = []; function TA(t, e, n, i) { var r = t.coordinateSystem; if (!r || "view" === r.type) { var o = r.getBoundingRect(), a = t.getData(), s = a.graph, l = o.width / 2 + o.x, u = o.height / 2 + o.y, h = Math.min(o.width, o.height) / 2, c = a.count(); if ((a.setLayout({ cx: l, cy: u }), c)) { if (n) { var p = r.pointToData(i), d = p[0], f = p[1], g = [d - l, f - u]; Et(g, g), Nt(g, g, h), n.setLayout([l + g[0], u + g[1]], !0), DA(n, t.get(["circular", "rotateLabel"]), l, u); } CA[e](t, s, a, h, l, u, c), s.eachEdge(function (e, n) { var i, r = ot( e.getModel().get(["lineStyle", "curveness"]), mA(e, t, n), 0 ), o = Tt(e.node1.getLayout()), a = Tt(e.node2.getLayout()), s = (o[0] + a[0]) / 2, h = (o[1] + a[1]) / 2; +r && (i = [ l * (r *= 3) + s * (1 - r), u * r + h * (1 - r), ]), e.setLayout([o, a, i]); }); } } } var CA = { value: function (t, e, n, i, r, o, a) { var s = 0, l = n.getSum("value"), u = (2 * Math.PI) / (l || a); e.eachNode(function (t) { var e = t.getValue("value"), n = (u * (l ? e : 1)) / 2; (s += n), t.setLayout([i * Math.cos(s) + r, i * Math.sin(s) + o]), (s += n); }); }, symbolSize: function (t, e, n, i, r, o, a) { var s = 0; IA.length = a; var l = wA(t); e.eachNode(function (t) { var e = SA(t); isNaN(e) && (e = 2), e < 0 && (e = 0), (e *= l); var n = Math.asin(e / 2 / i); isNaN(n) && (n = MA / 2), (IA[t.dataIndex] = n), (s += 2 * n); }); var u = (2 * MA - s) / a / 2, h = 0; e.eachNode(function (t) { var e = u + IA[t.dataIndex]; (h += e), (!t.getLayout() || !t.getLayout().fixed) && t.setLayout([i * Math.cos(h) + r, i * Math.sin(h) + o]), (h += e); }); }, }; function DA(t, e, n, i) { var r = t.getGraphicEl(); if (r) { var o = t.getModel().get(["label", "rotate"]) || 0, a = r.getSymbolPath(); if (e) { var s = t.getLayout(), l = Math.atan2(s[1] - i, s[0] - n); l < 0 && (l = 2 * Math.PI + l); var u = s[0] < n; u && (l -= Math.PI); var h = u ? "left" : "right"; a.setTextConfig({ rotation: -l, position: h, origin: "center", }); var c = a.ensureState("emphasis"); A(c.textConfig || (c.textConfig = {}), { position: h }); } else a.setTextConfig({ rotation: (o *= Math.PI / 180) }); } } function AA(t) { t.eachSeriesByType("graph", function (t) { "circular" === t.get("layout") && TA(t, "symbolSize"); }); } var kA = At; function LA(t) { t.eachSeriesByType("graph", function (t) { var e = t.coordinateSystem; if (!e || "view" === e.type) if ("force" === t.get("layout")) { var n = t.preservedPoints || {}, i = t.getGraph(), r = i.data, o = i.edgeData, a = t.getModel("force"), s = a.get("initLayout"); t.preservedPoints ? r.each(function (t) { var e = r.getId(t); r.setItemLayout(t, n[e] || [NaN, NaN]); }) : s && "none" !== s ? "circular" === s && TA(t, "value") : xA(t); var l = r.getDataExtent("value"), u = o.getDataExtent("value"), h = a.get("repulsion"), c = a.get("edgeLength"), p = Y(h) ? h : [h, h], d = Y(c) ? c : [c, c]; d = [d[1], d[0]]; var f = r.mapArray("value", function (t, e) { var n = r.getItemLayout(e), i = Kr(t, l, p); return ( isNaN(i) && (i = (p[0] + p[1]) / 2), { w: i, rep: i, fixed: r.getItemModel(e).get("fixed"), p: !n || isNaN(n[0]) || isNaN(n[1]) ? null : n, } ); }), g = o.mapArray("value", function (e, n) { var r = i.getEdgeByIndex(n), o = Kr(e, u, d); isNaN(o) && (o = (d[0] + d[1]) / 2); var a = r.getModel(), s = ot( r .getModel() .get(["lineStyle", "curveness"]), -mA(r, t, n, !0), 0 ); return { n1: f[r.node1.dataIndex], n2: f[r.node2.dataIndex], d: o, curveness: s, ignoreForceLayout: a.get("ignoreForceLayout"), }; }), y = e.getBoundingRect(), v = (function (t, e, n) { for ( var i = t, r = e, o = n.rect, a = o.width, s = o.height, l = [o.x + a / 2, o.y + s / 2], u = null == n.gravity ? 0.1 : n.gravity, h = 0; h < i.length; h++ ) { var c = i[h]; c.p || (c.p = Mt( a * (Math.random() - 0.5) + l[0], s * (Math.random() - 0.5) + l[1] )), (c.pp = Tt(c.p)), (c.edges = null); } var p, d, f = null == n.friction ? 0.6 : n.friction, g = f; return { warmUp: function () { g = 0.8 * f; }, setFixed: function (t) { i[t].fixed = !0; }, setUnfixed: function (t) { i[t].fixed = !1; }, beforeStep: function (t) { p = t; }, afterStep: function (t) { d = t; }, step: function (t) { p && p(i, r); for ( var e = [], n = i.length, o = 0; o < r.length; o++ ) { var a = r[o]; if (!a.ignoreForceLayout) { var s = a.n1; kt(e, (y = a.n2).p, s.p); var h = Lt(e) - a.d, c = y.w / (s.w + y.w); isNaN(c) && (c = 0), Et(e, e), !s.fixed && kA(s.p, s.p, e, c * h * g), !y.fixed && kA( y.p, y.p, e, -(1 - c) * h * g ); } } for (o = 0; o < n; o++) (x = i[o]).fixed || (kt(e, l, x.p), kA(x.p, x.p, e, u * g)); for (o = 0; o < n; o++) { s = i[o]; for (var f = o + 1; f < n; f++) { var y; kt(e, (y = i[f]).p, s.p), 0 === (h = Lt(e)) && (Ct( e, Math.random() - 0.5, Math.random() - 0.5 ), (h = 1)); var v = (s.rep + y.rep) / h / h; !s.fixed && kA(s.pp, s.pp, e, v), !y.fixed && kA(y.pp, y.pp, e, -v); } } var m = []; for (o = 0; o < n; o++) { var x; (x = i[o]).fixed || (kt(m, x.p, x.pp), kA(x.p, x.p, m, g), It(x.pp, x.p)); } var _ = (g *= 0.992) < 0.01; d && d(i, r, _), t && t(_); }, }; })(f, g, { rect: y, gravity: a.get("gravity"), friction: a.get("friction"), }); v.beforeStep(function (t, e) { for (var n = 0, r = t.length; n < r; n++) t[n].fixed && It(t[n].p, i.getNodeByIndex(n).getLayout()); }), v.afterStep(function (t, e, o) { for (var a = 0, s = t.length; a < s; a++) t[a].fixed || i.getNodeByIndex(a).setLayout(t[a].p), (n[r.getId(a)] = t[a].p); for (a = 0, s = e.length; a < s; a++) { var l = e[a], u = i.getEdgeByIndex(a), h = l.n1.p, c = l.n2.p, p = u.getLayout(); ((p = p ? p.slice() : [])[0] = p[0] || []), (p[1] = p[1] || []), It(p[0], h), It(p[1], c), +l.curveness && (p[2] = [ (h[0] + c[0]) / 2 - (h[1] - c[1]) * l.curveness, (h[1] + c[1]) / 2 - (c[0] - h[0]) * l.curveness, ]), u.setLayout(p); } }), (t.forceLayout = v), (t.preservedPoints = n), v.step(); } else t.forceLayout = null; }); } function PA(t, e) { var n = []; return ( t.eachSeriesByType("graph", function (t) { var i = t.get("coordinateSystem"); if (!i || "view" === i) { var r = t.getData(), o = [], a = []; Ba( r.mapArray(function (t) { var e = r.getItemModel(t); return [+e.get("x"), +e.get("y")]; }), o, a ), a[0] - o[0] == 0 && ((a[0] += 1), (o[0] -= 1)), a[1] - o[1] == 0 && ((a[1] += 1), (o[1] -= 1)); var s = (a[0] - o[0]) / (a[1] - o[1]), l = (function (t, e, n) { return kp( A(t.getBoxLayoutParams(), { aspect: n }), { width: e.getWidth(), height: e.getHeight() } ); })(t, e, s); isNaN(s) && ((o = [l.x, l.y]), (a = [l.x + l.width, l.y + l.height])); var u = a[0] - o[0], h = a[1] - o[1], c = l.width, p = l.height, d = (t.coordinateSystem = new dC()); (d.zoomLimit = t.get("scaleLimit")), d.setBoundingRect(o[0], o[1], u, h), d.setViewRect(l.x, l.y, c, p), d.setCenter(t.get("center"), e), d.setZoom(t.get("zoom")), n.push(d); } }), n ); } var OA = Ku.prototype, RA = th.prototype, NA = function () { (this.x1 = 0), (this.y1 = 0), (this.x2 = 0), (this.y2 = 0), (this.percent = 1); }; !(function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } n(e, t); })(NA); function EA(t) { return isNaN(+t.cpx1) || isNaN(+t.cpy1); } var zA = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "ec-line"), n; } return ( n(e, t), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new NA(); }), (e.prototype.buildPath = function (t, e) { EA(e) ? OA.buildPath.call(this, t, e) : RA.buildPath.call(this, t, e); }), (e.prototype.pointAt = function (t) { return EA(this.shape) ? OA.pointAt.call(this, t) : RA.pointAt.call(this, t); }), (e.prototype.tangentAt = function (t) { var e = this.shape, n = EA(e) ? [e.x2 - e.x1, e.y2 - e.y1] : RA.tangentAt.call(this, t); return Et(n, n); }), e ); })(ks), VA = ["fromSymbol", "toSymbol"]; function BA(t) { return "_" + t + "Type"; } function FA(t, e, n) { var i = e.getItemVisual(n, t); if (!i || "none" === i) return i; var r = e.getItemVisual(n, t + "Size"), o = e.getItemVisual(n, t + "Rotate"), a = e.getItemVisual(n, t + "Offset"), s = e.getItemVisual(n, t + "KeepAspect"), l = Uy(r); return i + l + Zy(a || 0, l) + (o || "") + (s || ""); } function GA(t, e, n) { var i = e.getItemVisual(n, t); if (i && "none" !== i) { var r = e.getItemVisual(n, t + "Size"), o = e.getItemVisual(n, t + "Rotate"), a = e.getItemVisual(n, t + "Offset"), s = e.getItemVisual(n, t + "KeepAspect"), l = Uy(r), u = Zy(a || 0, l), h = Xy( i, -l[0] / 2 + u[0], -l[1] / 2 + u[1], l[0], l[1], null, s ); return ( (h.__specifiedRotation = null == o || isNaN(o) ? void 0 : (+o * Math.PI) / 180 || 0), (h.name = t), h ); } } function WA(t, e) { (t.x1 = e[0][0]), (t.y1 = e[0][1]), (t.x2 = e[1][0]), (t.y2 = e[1][1]), (t.percent = 1); var n = e[2]; n ? ((t.cpx1 = n[0]), (t.cpy1 = n[1])) : ((t.cpx1 = NaN), (t.cpy1 = NaN)); } var HA = (function (t) { function e(e, n, i) { var r = t.call(this) || this; return r._createLine(e, n, i), r; } return ( n(e, t), (e.prototype._createLine = function (t, e, n) { var i = t.hostModel, r = (function (t) { var e = new zA({ name: "line", subPixelOptimize: !0, }); return WA(e.shape, t), e; })(t.getItemLayout(e)); (r.shape.percent = 0), mh(r, { shape: { percent: 1 } }, i, e), this.add(r), E( VA, function (n) { var i = GA(n, t, e); this.add(i), (this[BA(n)] = FA(n, t, e)); }, this ), this._updateCommonStl(t, e, n); }), (e.prototype.updateData = function (t, e, n) { var i = t.hostModel, r = this.childOfName("line"), o = t.getItemLayout(e), a = { shape: {} }; WA(a.shape, o), vh(r, a, i, e), E( VA, function (n) { var i = FA(n, t, e), r = BA(n); if (this[r] !== i) { this.remove(this.childOfName(n)); var o = GA(n, t, e); this.add(o); } this[r] = i; }, this ), this._updateCommonStl(t, e, n); }), (e.prototype.getLinePath = function () { return this.childAt(0); }), (e.prototype._updateCommonStl = function (t, e, n) { var i = t.hostModel, r = this.childOfName("line"), o = n && n.emphasisLineStyle, a = n && n.blurLineStyle, s = n && n.selectLineStyle, l = n && n.labelStatesModels, u = n && n.emphasisDisabled, h = n && n.focus, c = n && n.blurScope; if (!n || t.hasItemOption) { var p = t.getItemModel(e), d = p.getModel("emphasis"); (o = d.getModel("lineStyle").getLineStyle()), (a = p .getModel(["blur", "lineStyle"]) .getLineStyle()), (s = p .getModel(["select", "lineStyle"]) .getLineStyle()), (u = d.get("disabled")), (h = d.get("focus")), (c = d.get("blurScope")), (l = rc(p)); } var f = t.getItemVisual(e, "style"), g = f.stroke; r.useStyle(f), (r.style.fill = null), (r.style.strokeNoScale = !0), (r.ensureState("emphasis").style = o), (r.ensureState("blur").style = a), (r.ensureState("select").style = s), E( VA, function (t) { var e = this.childOfName(t); if (e) { e.setColor(g), (e.style.opacity = f.opacity); for (var n = 0; n < hl.length; n++) { var i = hl[n], o = r.getState(i); if (o) { var a = o.style || {}, s = e.ensureState(i), l = s.style || (s.style = {}); null != a.stroke && (l[ e.__isEmptyBrush ? "stroke" : "fill" ] = a.stroke), null != a.opacity && (l.opacity = a.opacity); } } e.markRedraw(); } }, this ); var y = i.getRawValue(e); ic(this, l, { labelDataIndex: e, labelFetcher: { getFormattedLabel: function (e, n) { return i.getFormattedLabel(e, n, t.dataType); }, }, inheritColor: g || "#000", defaultOpacity: f.opacity, defaultText: (null == y ? t.getName(e) : isFinite(y) ? Jr(y) : y) + "", }); var v = this.getTextContent(); if (v) { var m = l.normal; (v.__align = v.style.align), (v.__verticalAlign = v.style.verticalAlign), (v.__position = m.get("position") || "middle"); var x = m.get("distance"); Y(x) || (x = [x, x]), (v.__labelDistance = x); } this.setTextConfig({ position: null, local: !0, inside: !1, }), Zl(this, h, c, u); }), (e.prototype.highlight = function () { Ol(this); }), (e.prototype.downplay = function () { Rl(this); }), (e.prototype.updateLayout = function (t, e) { this.setLinePoints(t.getItemLayout(e)); }), (e.prototype.setLinePoints = function (t) { var e = this.childOfName("line"); WA(e.shape, t), e.dirty(); }), (e.prototype.beforeUpdate = function () { var t = this, e = t.childOfName("fromSymbol"), n = t.childOfName("toSymbol"), i = t.getTextContent(); if (e || n || (i && !i.ignore)) { for (var r = 1, o = this.parent; o; ) o.scaleX && (r /= o.scaleX), (o = o.parent); var a = t.childOfName("line"); if (this.__dirty || a.__dirty) { var s = a.shape.percent, l = a.pointAt(0), u = a.pointAt(s), h = kt([], u, l); if ( (Et(h, h), e && (e.setPosition(l), S(e, 0), (e.scaleX = e.scaleY = r * s), e.markRedraw()), n && (n.setPosition(u), S(n, 1), (n.scaleX = n.scaleY = r * s), n.markRedraw()), i && !i.ignore) ) { (i.x = i.y = 0), (i.originX = i.originY = 0); var c = void 0, p = void 0, d = i.__labelDistance, f = d[0] * r, g = d[1] * r, y = s / 2, v = a.tangentAt(y), m = [v[1], -v[0]], x = a.pointAt(y); m[1] > 0 && ((m[0] = -m[0]), (m[1] = -m[1])); var _ = v[0] < 0 ? -1 : 1; if ( "start" !== i.__position && "end" !== i.__position ) { var b = -Math.atan2(v[1], v[0]); u[0] < l[0] && (b = Math.PI + b), (i.rotation = b); } var w = void 0; switch (i.__position) { case "insideStartTop": case "insideMiddleTop": case "insideEndTop": case "middle": (w = -g), (p = "bottom"); break; case "insideStartBottom": case "insideMiddleBottom": case "insideEndBottom": (w = g), (p = "top"); break; default: (w = 0), (p = "middle"); } switch (i.__position) { case "end": (i.x = h[0] * f + u[0]), (i.y = h[1] * g + u[1]), (c = h[0] > 0.8 ? "left" : h[0] < -0.8 ? "right" : "center"), (p = h[1] > 0.8 ? "top" : h[1] < -0.8 ? "bottom" : "middle"); break; case "start": (i.x = -h[0] * f + l[0]), (i.y = -h[1] * g + l[1]), (c = h[0] > 0.8 ? "right" : h[0] < -0.8 ? "left" : "center"), (p = h[1] > 0.8 ? "bottom" : h[1] < -0.8 ? "top" : "middle"); break; case "insideStartTop": case "insideStart": case "insideStartBottom": (i.x = f * _ + l[0]), (i.y = l[1] + w), (c = v[0] < 0 ? "right" : "left"), (i.originX = -f * _), (i.originY = -w); break; case "insideMiddleTop": case "insideMiddle": case "insideMiddleBottom": case "middle": (i.x = x[0]), (i.y = x[1] + w), (c = "center"), (i.originY = -w); break; case "insideEndTop": case "insideEnd": case "insideEndBottom": (i.x = -f * _ + u[0]), (i.y = u[1] + w), (c = v[0] >= 0 ? "right" : "left"), (i.originX = f * _), (i.originY = -w); } (i.scaleX = i.scaleY = r), i.setStyle({ verticalAlign: i.__verticalAlign || p, align: i.__align || c, }); } } } function S(t, e) { var n = t.__specifiedRotation; if (null == n) { var i = a.tangentAt(e); t.attr( "rotation", ((1 === e ? -1 : 1) * Math.PI) / 2 - Math.atan2(i[1], i[0]) ); } else t.attr("rotation", n); } }), e ); })(Br), YA = (function () { function t(t) { (this.group = new Br()), (this._LineCtor = t || HA); } return ( (t.prototype.updateData = function (t) { var e = this; this._progressiveEls = null; var n = this, i = n.group, r = n._lineData; (n._lineData = t), r || i.removeAll(); var o = XA(t); t.diff(r) .add(function (n) { e._doAdd(t, n, o); }) .update(function (n, i) { e._doUpdate(r, t, i, n, o); }) .remove(function (t) { i.remove(r.getItemGraphicEl(t)); }) .execute(); }), (t.prototype.updateLayout = function () { var t = this._lineData; t && t.eachItemGraphicEl(function (e, n) { e.updateLayout(t, n); }, this); }), (t.prototype.incrementalPrepareUpdate = function (t) { (this._seriesScope = XA(t)), (this._lineData = null), this.group.removeAll(); }), (t.prototype.incrementalUpdate = function (t, e) { function n(t) { t.isGroup || (function (t) { return t.animators && t.animators.length > 0; })(t) || ((t.incremental = !0), (t.ensureState("emphasis").hoverLayer = !0)); } this._progressiveEls = []; for (var i = t.start; i < t.end; i++) { if (ZA(e.getItemLayout(i))) { var r = new this._LineCtor(e, i, this._seriesScope); r.traverse(n), this.group.add(r), e.setItemGraphicEl(i, r), this._progressiveEls.push(r); } } }), (t.prototype.remove = function () { this.group.removeAll(); }), (t.prototype.eachRendered = function (t) { Jh(this._progressiveEls || this.group, t); }), (t.prototype._doAdd = function (t, e, n) { if (ZA(t.getItemLayout(e))) { var i = new this._LineCtor(t, e, n); t.setItemGraphicEl(e, i), this.group.add(i); } }), (t.prototype._doUpdate = function (t, e, n, i, r) { var o = t.getItemGraphicEl(n); ZA(e.getItemLayout(i)) ? (o ? o.updateData(e, i, r) : (o = new this._LineCtor(e, i, r)), e.setItemGraphicEl(i, o), this.group.add(o)) : this.group.remove(o); }), t ); })(); function XA(t) { var e = t.hostModel, n = e.getModel("emphasis"); return { lineStyle: e.getModel("lineStyle").getLineStyle(), emphasisLineStyle: n.getModel(["lineStyle"]).getLineStyle(), blurLineStyle: e.getModel(["blur", "lineStyle"]).getLineStyle(), selectLineStyle: e.getModel(["select", "lineStyle"]).getLineStyle(), emphasisDisabled: n.get("disabled"), blurScope: n.get("blurScope"), focus: n.get("focus"), labelStatesModels: rc(e), }; } function UA(t) { return isNaN(t[0]) || isNaN(t[1]); } function ZA(t) { return t && !UA(t[0]) && !UA(t[1]); } var jA = [], qA = [], KA = [], $A = In, JA = Ft, QA = Math.abs; function tk(t, e, n) { for ( var i, r = t[0], o = t[1], a = t[2], s = 1 / 0, l = n * n, u = 0.1, h = 0.1; h <= 0.9; h += 0.1 ) { (jA[0] = $A(r[0], o[0], a[0], h)), (jA[1] = $A(r[1], o[1], a[1], h)), (d = QA(JA(jA, e) - l)) < s && ((s = d), (i = h)); } for (var c = 0; c < 32; c++) { var p = i + u; (qA[0] = $A(r[0], o[0], a[0], i)), (qA[1] = $A(r[1], o[1], a[1], i)), (KA[0] = $A(r[0], o[0], a[0], p)), (KA[1] = $A(r[1], o[1], a[1], p)); var d = JA(qA, e) - l; if (QA(d) < 0.01) break; var f = JA(KA, e) - l; (u /= 2), d < 0 ? f >= 0 ? (i += u) : (i -= u) : f >= 0 ? (i -= u) : (i += u); } return i; } function ek(t, e) { var n = [], i = Dn, r = [[], [], []], o = [[], []], a = []; (e /= 2), t.eachEdge(function (t, s) { var l = t.getLayout(), u = t.getVisual("fromSymbol"), h = t.getVisual("toSymbol"); l.__original || ((l.__original = [Tt(l[0]), Tt(l[1])]), l[2] && l.__original.push(Tt(l[2]))); var c = l.__original; if (null != l[2]) { if ( (It(r[0], c[0]), It(r[1], c[2]), It(r[2], c[1]), u && "none" !== u) ) { var p = SA(t.node1), d = tk(r, c[0], p * e); i(r[0][0], r[1][0], r[2][0], d, n), (r[0][0] = n[3]), (r[1][0] = n[4]), i(r[0][1], r[1][1], r[2][1], d, n), (r[0][1] = n[3]), (r[1][1] = n[4]); } if (h && "none" !== h) { (p = SA(t.node2)), (d = tk(r, c[1], p * e)); i(r[0][0], r[1][0], r[2][0], d, n), (r[1][0] = n[1]), (r[2][0] = n[2]), i(r[0][1], r[1][1], r[2][1], d, n), (r[1][1] = n[1]), (r[2][1] = n[2]); } It(l[0], r[0]), It(l[1], r[2]), It(l[2], r[1]); } else { if ( (It(o[0], c[0]), It(o[1], c[1]), kt(a, o[1], o[0]), Et(a, a), u && "none" !== u) ) { p = SA(t.node1); At(o[0], o[0], a, p * e); } if (h && "none" !== h) { p = SA(t.node2); At(o[1], o[1], a, -p * e); } It(l[0], o[0]), It(l[1], o[1]); } }); } function nk(t) { return "view" === t.type; } var ik = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (t, e) { var n = new xS(), i = new YA(), r = this.group; (this._controller = new nT(e.getZr())), (this._controllerHost = { target: r }), r.add(n.group), r.add(i.group), (this._symbolDraw = n), (this._lineDraw = i), (this._firstRender = !0); }), (e.prototype.render = function (t, e, n) { var i = this, r = t.coordinateSystem; this._model = t; var o = this._symbolDraw, a = this._lineDraw, s = this.group; if (nk(r)) { var l = { x: r.x, y: r.y, scaleX: r.scaleX, scaleY: r.scaleY, }; this._firstRender ? s.attr(l) : vh(s, l, t); } ek(t.getGraph(), wA(t)); var u = t.getData(); o.updateData(u); var h = t.getEdgeData(); a.updateData(h), this._updateNodeAndLinkScale(), this._updateController(t, e, n), clearTimeout(this._layoutTimeout); var c = t.forceLayout, p = t.get(["force", "layoutAnimation"]); c && this._startForceLayoutIteration(c, p); var d = t.get("layout"); u.graph.eachNode(function (e) { var n = e.dataIndex, r = e.getGraphicEl(), o = e.getModel(); if (r) { r.off("drag").off("dragend"); var a = o.get("draggable"); a && r .on("drag", function (o) { switch (d) { case "force": c.warmUp(), !i._layouting && i._startForceLayoutIteration( c, p ), c.setFixed(n), u.setItemLayout(n, [r.x, r.y]); break; case "circular": u.setItemLayout(n, [r.x, r.y]), e.setLayout({ fixed: !0 }, !0), TA(t, "symbolSize", e, [ o.offsetX, o.offsetY, ]), i.updateLayout(t); break; default: u.setItemLayout(n, [r.x, r.y]), _A(t.getGraph(), t), i.updateLayout(t); } }) .on("dragend", function () { c && c.setUnfixed(n); }), r.setDraggable(a, !!o.get("cursor")), "adjacency" === o.get(["emphasis", "focus"]) && (rl(r).focus = e.getAdjacentDataIndices()); } }), u.graph.eachEdge(function (t) { var e = t.getGraphicEl(), n = t.getModel().get(["emphasis", "focus"]); e && "adjacency" === n && (rl(e).focus = { edge: [t.dataIndex], node: [t.node1.dataIndex, t.node2.dataIndex], }); }); var f = "circular" === t.get("layout") && t.get(["circular", "rotateLabel"]), g = u.getLayout("cx"), y = u.getLayout("cy"); u.graph.eachNode(function (t) { DA(t, f, g, y); }), (this._firstRender = !1); }), (e.prototype.dispose = function () { this.remove(), this._controller && this._controller.dispose(), (this._controllerHost = null); }), (e.prototype._startForceLayoutIteration = function (t, e) { var n = this; !(function i() { t.step(function (t) { n.updateLayout(n._model), (n._layouting = !t) && (e ? (n._layoutTimeout = setTimeout(i, 16)) : i()); }); })(); }), (e.prototype._updateController = function (t, e, n) { var i = this, r = this._controller, o = this._controllerHost, a = this.group; r.setPointerChecker(function (e, i, r) { var o = a.getBoundingRect(); return ( o.applyTransform(a.transform), o.contain(i, r) && !hT(e, n, t) ); }), nk(t.coordinateSystem) ? (r.enable(t.get("roam")), (o.zoomLimit = t.get("scaleLimit")), (o.zoom = t.coordinateSystem.getZoom()), r .off("pan") .off("zoom") .on("pan", function (e) { aT(o, e.dx, e.dy), n.dispatchAction({ seriesId: t.id, type: "graphRoam", dx: e.dx, dy: e.dy, }); }) .on("zoom", function (e) { sT(o, e.scale, e.originX, e.originY), n.dispatchAction({ seriesId: t.id, type: "graphRoam", zoom: e.scale, originX: e.originX, originY: e.originY, }), i._updateNodeAndLinkScale(), ek(t.getGraph(), wA(t)), i._lineDraw.updateLayout(), n.updateLabelLayout(); })) : r.disable(); }), (e.prototype._updateNodeAndLinkScale = function () { var t = this._model, e = t.getData(), n = wA(t); e.eachItemGraphicEl(function (t, e) { t && t.setSymbolScale(n); }); }), (e.prototype.updateLayout = function (t) { ek(t.getGraph(), wA(t)), this._symbolDraw.updateLayout(), this._lineDraw.updateLayout(); }), (e.prototype.remove = function () { clearTimeout(this._layoutTimeout), (this._layouting = !1), (this._layoutTimeout = null), this._symbolDraw && this._symbolDraw.remove(), this._lineDraw && this._lineDraw.remove(); }), (e.type = "graph"), e ); })(Og); function rk(t) { return "_EC_" + t; } var ok = (function () { function t(t) { (this.type = "graph"), (this.nodes = []), (this.edges = []), (this._nodesMap = {}), (this._edgesMap = {}), (this._directed = t || !1); } return ( (t.prototype.isDirected = function () { return this._directed; }), (t.prototype.addNode = function (t, e) { t = null == t ? "" + e : "" + t; var n = this._nodesMap; if (!n[rk(t)]) { var i = new ak(t, e); return ( (i.hostGraph = this), this.nodes.push(i), (n[rk(t)] = i), i ); } }), (t.prototype.getNodeByIndex = function (t) { var e = this.data.getRawIndex(t); return this.nodes[e]; }), (t.prototype.getNodeById = function (t) { return this._nodesMap[rk(t)]; }), (t.prototype.addEdge = function (t, e, n) { var i = this._nodesMap, r = this._edgesMap; if ( (j(t) && (t = this.nodes[t]), j(e) && (e = this.nodes[e]), t instanceof ak || (t = i[rk(t)]), e instanceof ak || (e = i[rk(e)]), t && e) ) { var o = t.id + "-" + e.id, a = new sk(t, e, n); return ( (a.hostGraph = this), this._directed && (t.outEdges.push(a), e.inEdges.push(a)), t.edges.push(a), t !== e && e.edges.push(a), this.edges.push(a), (r[o] = a), a ); } }), (t.prototype.getEdgeByIndex = function (t) { var e = this.edgeData.getRawIndex(t); return this.edges[e]; }), (t.prototype.getEdge = function (t, e) { t instanceof ak && (t = t.id), e instanceof ak && (e = e.id); var n = this._edgesMap; return this._directed ? n[t + "-" + e] : n[t + "-" + e] || n[e + "-" + t]; }), (t.prototype.eachNode = function (t, e) { for (var n = this.nodes, i = n.length, r = 0; r < i; r++) n[r].dataIndex >= 0 && t.call(e, n[r], r); }), (t.prototype.eachEdge = function (t, e) { for (var n = this.edges, i = n.length, r = 0; r < i; r++) n[r].dataIndex >= 0 && n[r].node1.dataIndex >= 0 && n[r].node2.dataIndex >= 0 && t.call(e, n[r], r); }), (t.prototype.breadthFirstTraverse = function (t, e, n, i) { if ((e instanceof ak || (e = this._nodesMap[rk(e)]), e)) { for ( var r = "out" === n ? "outEdges" : "in" === n ? "inEdges" : "edges", o = 0; o < this.nodes.length; o++ ) this.nodes[o].__visited = !1; if (!t.call(i, e, null)) for (var a = [e]; a.length; ) { var s = a.shift(), l = s[r]; for (o = 0; o < l.length; o++) { var u = l[o], h = u.node1 === s ? u.node2 : u.node1; if (!h.__visited) { if (t.call(i, h, s)) return; a.push(h), (h.__visited = !0); } } } } }), (t.prototype.update = function () { for ( var t = this.data, e = this.edgeData, n = this.nodes, i = this.edges, r = 0, o = n.length; r < o; r++ ) n[r].dataIndex = -1; for (r = 0, o = t.count(); r < o; r++) n[t.getRawIndex(r)].dataIndex = r; e.filterSelf(function (t) { var n = i[e.getRawIndex(t)]; return n.node1.dataIndex >= 0 && n.node2.dataIndex >= 0; }); for (r = 0, o = i.length; r < o; r++) i[r].dataIndex = -1; for (r = 0, o = e.count(); r < o; r++) i[e.getRawIndex(r)].dataIndex = r; }), (t.prototype.clone = function () { for ( var e = new t(this._directed), n = this.nodes, i = this.edges, r = 0; r < n.length; r++ ) e.addNode(n[r].id, n[r].dataIndex); for (r = 0; r < i.length; r++) { var o = i[r]; e.addEdge(o.node1.id, o.node2.id, o.dataIndex); } return e; }), t ); })(), ak = (function () { function t(t, e) { (this.inEdges = []), (this.outEdges = []), (this.edges = []), (this.dataIndex = -1), (this.id = null == t ? "" : t), (this.dataIndex = null == e ? -1 : e); } return ( (t.prototype.degree = function () { return this.edges.length; }), (t.prototype.inDegree = function () { return this.inEdges.length; }), (t.prototype.outDegree = function () { return this.outEdges.length; }), (t.prototype.getModel = function (t) { if (!(this.dataIndex < 0)) return this.hostGraph.data .getItemModel(this.dataIndex) .getModel(t); }), (t.prototype.getAdjacentDataIndices = function () { for ( var t = { edge: [], node: [] }, e = 0; e < this.edges.length; e++ ) { var n = this.edges[e]; n.dataIndex < 0 || (t.edge.push(n.dataIndex), t.node.push(n.node1.dataIndex, n.node2.dataIndex)); } return t; }), (t.prototype.getTrajectoryDataIndices = function () { for ( var t = yt(), e = yt(), n = 0; n < this.edges.length; n++ ) { var i = this.edges[n]; if (!(i.dataIndex < 0)) { t.set(i.dataIndex, !0); for ( var r = [i.node1], o = [i.node2], a = 0; a < r.length; ) { var s = r[a]; a++, e.set(s.dataIndex, !0); for (var l = 0; l < s.inEdges.length; l++) t.set(s.inEdges[l].dataIndex, !0), r.push(s.inEdges[l].node1); } for (a = 0; a < o.length; ) { var u = o[a]; a++, e.set(u.dataIndex, !0); for (l = 0; l < u.outEdges.length; l++) t.set(u.outEdges[l].dataIndex, !0), o.push(u.outEdges[l].node2); } } } return { edge: t.keys(), node: e.keys() }; }), t ); })(), sk = (function () { function t(t, e, n) { (this.dataIndex = -1), (this.node1 = t), (this.node2 = e), (this.dataIndex = null == n ? -1 : n); } return ( (t.prototype.getModel = function (t) { if (!(this.dataIndex < 0)) return this.hostGraph.edgeData .getItemModel(this.dataIndex) .getModel(t); }), (t.prototype.getAdjacentDataIndices = function () { return { edge: [this.dataIndex], node: [this.node1.dataIndex, this.node2.dataIndex], }; }), (t.prototype.getTrajectoryDataIndices = function () { var t = yt(), e = yt(); t.set(this.dataIndex, !0); for ( var n = [this.node1], i = [this.node2], r = 0; r < n.length; ) { var o = n[r]; r++, e.set(o.dataIndex, !0); for (var a = 0; a < o.inEdges.length; a++) t.set(o.inEdges[a].dataIndex, !0), n.push(o.inEdges[a].node1); } for (r = 0; r < i.length; ) { var s = i[r]; r++, e.set(s.dataIndex, !0); for (a = 0; a < s.outEdges.length; a++) t.set(s.outEdges[a].dataIndex, !0), i.push(s.outEdges[a].node2); } return { edge: t.keys(), node: e.keys() }; }), t ); })(); function lk(t, e) { return { getValue: function (n) { var i = this[t][e]; return i .getStore() .get(i.getDimensionIndex(n || "value"), this.dataIndex); }, setVisual: function (n, i) { this.dataIndex >= 0 && this[t][e].setItemVisual(this.dataIndex, n, i); }, getVisual: function (n) { return this[t][e].getItemVisual(this.dataIndex, n); }, setLayout: function (n, i) { this.dataIndex >= 0 && this[t][e].setItemLayout(this.dataIndex, n, i); }, getLayout: function () { return this[t][e].getItemLayout(this.dataIndex); }, getGraphicEl: function () { return this[t][e].getItemGraphicEl(this.dataIndex); }, getRawIndex: function () { return this[t][e].getRawIndex(this.dataIndex); }, }; } function uk(t, e, n, i, r) { for (var o = new ok(i), a = 0; a < t.length; a++) o.addNode(it(t[a].id, t[a].name, a), a); var s = [], l = [], u = 0; for (a = 0; a < e.length; a++) { var h = e[a], c = h.source, p = h.target; o.addEdge(c, p, u) && (l.push(h), s.push(it(Ro(h.id, null), c + " > " + p)), u++); } var d, f = n.get("coordinateSystem"); if ("cartesian2d" === f || "polar" === f) d = _x(t, n); else { var g = wd.get(f), y = (g && g.dimensions) || []; P(y, "value") < 0 && y.concat(["value"]); var v = px(t, { coordDimensions: y, encodeDefine: n.getEncode(), }).dimensions; (d = new cx(v, n)).initData(t); } var m = new cx(["value"], n); return ( m.initData(l, s), r && r(d, m), ZC({ mainData: d, struct: o, structAttr: "graph", datas: { node: d, edge: m }, datasAttr: { node: "data", edge: "edgeData" }, }), o.update(), o ); } R(ak, lk("hostGraph", "data")), R(sk, lk("hostGraph", "edgeData")); var hk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.hasSymbolVisual = !0), n; } return ( n(e, t), (e.prototype.init = function (e) { t.prototype.init.apply(this, arguments); var n = this; function i() { return n._categoriesData; } (this.legendVisualProvider = new NM(i, i)), this.fillDataTextStyle(e.edges || e.links), this._updateCategoriesData(); }), (e.prototype.mergeOption = function (e) { t.prototype.mergeOption.apply(this, arguments), this.fillDataTextStyle(e.edges || e.links), this._updateCategoriesData(); }), (e.prototype.mergeDefaultAndTheme = function (e) { t.prototype.mergeDefaultAndTheme.apply(this, arguments), Co(e, "edgeLabel", ["show"]); }), (e.prototype.getInitialData = function (t, e) { var n, i = t.edges || t.links || [], r = t.data || t.nodes || [], o = this; if (r && i) { dA((n = this)) && ((n.__curvenessList = []), (n.__edgeMap = {}), fA(n)); var a = uk(r, i, this, !0, function (t, e) { t.wrapMethod("getItemModel", function (t) { var e = o._categoriesModels[ t.getShallow("category") ]; return ( e && ((e.parentModel = t.parentModel), (t.parentModel = e)), t ); }); var n = Cc.prototype.getModel; function i(t, e) { var i = n.call(this, t, e); return (i.resolveParentPath = r), i; } function r(t) { if ( t && ("label" === t[0] || "label" === t[1]) ) { var e = t.slice(); return ( "label" === t[0] ? (e[0] = "edgeLabel") : "label" === t[1] && (e[1] = "edgeLabel"), e ); } return t; } e.wrapMethod("getItemModel", function (t) { return ( (t.resolveParentPath = r), (t.getModel = i), t ); }); }); return ( E( a.edges, function (t) { !(function (t, e, n, i) { if (dA(n)) { var r = gA(t, e, n), o = n.__edgeMap, a = o[yA(r)]; o[r] && !a ? (o[r].isForward = !0) : a && o[r] && ((a.isForward = !0), (o[r].isForward = !1)), (o[r] = o[r] || []), o[r].push(i); } })(t.node1, t.node2, this, t.dataIndex); }, this ), a.data ); } }), (e.prototype.getGraph = function () { return this.getData().graph; }), (e.prototype.getEdgeData = function () { return this.getGraph().edgeData; }), (e.prototype.getCategoriesData = function () { return this._categoriesData; }), (e.prototype.formatTooltip = function (t, e, n) { if ("edge" === n) { var i = this.getData(), r = this.getDataParams(t, n), o = i.graph.getEdgeByIndex(t), a = i.getName(o.node1.dataIndex), s = i.getName(o.node2.dataIndex), l = []; return ( null != a && l.push(a), null != s && l.push(s), og("nameValue", { name: l.join(" > "), value: r.value, noValue: null == r.value, }) ); } return vg({ series: this, dataIndex: t, multipleSeries: e, }); }), (e.prototype._updateCategoriesData = function () { var t = z(this.option.categories || [], function (t) { return null != t.value ? t : A({ value: 0 }, t); }), e = new cx(["value"], this); e.initData(t), (this._categoriesData = e), (this._categoriesModels = e.mapArray(function (t) { return e.getItemModel(t); })); }), (e.prototype.setZoom = function (t) { this.option.zoom = t; }), (e.prototype.setCenter = function (t) { this.option.center = t; }), (e.prototype.isAnimationEnabled = function () { return ( t.prototype.isAnimationEnabled.call(this) && !( "force" === this.get("layout") && this.get(["force", "layoutAnimation"]) ) ); }), (e.type = "series.graph"), (e.dependencies = [ "grid", "polar", "geo", "singleAxis", "calendar", ]), (e.defaultOption = { z: 2, coordinateSystem: "view", legendHoverLink: !0, layout: null, circular: { rotateLabel: !1 }, force: { initLayout: null, repulsion: [0, 50], gravity: 0.1, friction: 0.6, edgeLength: 30, layoutAnimation: !0, }, left: "center", top: "center", symbol: "circle", symbolSize: 10, edgeSymbol: ["none", "none"], edgeSymbolSize: 10, edgeLabel: { position: "middle", distance: 5 }, draggable: !1, roam: !1, center: null, zoom: 1, nodeScaleRatio: 0.6, label: { show: !1, formatter: "{b}" }, itemStyle: {}, lineStyle: { color: "#aaa", width: 1, opacity: 0.5 }, emphasis: { scale: !0, label: { show: !0 } }, select: { itemStyle: { borderColor: "#212121" } }, }), e ); })(bg), ck = { type: "graphRoam", event: "graphRoam", update: "none" }; var pk = function () { (this.angle = 0), (this.width = 10), (this.r = 10), (this.x = 0), (this.y = 0); }, dk = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "pointer"), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new pk(); }), (e.prototype.buildPath = function (t, e) { var n = Math.cos, i = Math.sin, r = e.r, o = e.width, a = e.angle, s = e.x - n(a) * o * (o >= r / 3 ? 1 : 2), l = e.y - i(a) * o * (o >= r / 3 ? 1 : 2); (a = e.angle - Math.PI / 2), t.moveTo(s, l), t.lineTo(e.x + n(a) * o, e.y + i(a) * o), t.lineTo(e.x + n(e.angle) * r, e.y + i(e.angle) * r), t.lineTo(e.x - n(a) * o, e.y - i(a) * o), t.lineTo(s, l); }), e ); })(ks); function fk(t, e) { var n = null == t ? "" : t + ""; return ( e && (U(e) ? (n = e.replace("{value}", n)) : X(e) && (n = e(t))), n ); } var gk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { this.group.removeAll(); var i = t.get(["axisLine", "lineStyle", "color"]), r = (function (t, e) { var n = t.get("center"), i = e.getWidth(), r = e.getHeight(), o = Math.min(i, r); return { cx: $r(n[0], e.getWidth()), cy: $r(n[1], e.getHeight()), r: $r(t.get("radius"), o / 2), }; })(t, n); this._renderMain(t, e, n, i, r), (this._data = t.getData()); }), (e.prototype.dispose = function () {}), (e.prototype._renderMain = function (t, e, n, i, r) { var o = this.group, a = t.get("clockwise"), s = (-t.get("startAngle") / 180) * Math.PI, l = (-t.get("endAngle") / 180) * Math.PI, u = t.getModel("axisLine"), h = u.get("roundCap") ? JS : Fu, c = u.get("show"), p = u.getModel("lineStyle"), d = p.get("width"), f = [s, l]; us(f, !a); for ( var g = (l = f[1]) - (s = f[0]), y = s, v = [], m = 0; c && m < i.length; m++ ) { var x = new h({ shape: { startAngle: y, endAngle: (l = s + g * Math.min(Math.max(i[m][0], 0), 1)), cx: r.cx, cy: r.cy, clockwise: a, r0: r.r - d, r: r.r, }, silent: !0, }); x.setStyle({ fill: i[m][1] }), x.setStyle(p.getLineStyle(["color", "width"])), v.push(x), (y = l); } v.reverse(), E(v, function (t) { return o.add(t); }); var _ = function (t) { if (t <= 0) return i[0][1]; var e; for (e = 0; e < i.length; e++) if (i[e][0] >= t && (0 === e ? 0 : i[e - 1][0]) < t) return i[e][1]; return i[e - 1][1]; }; this._renderTicks(t, e, n, _, r, s, l, a, d), this._renderTitleAndDetail(t, e, n, _, r), this._renderAnchor(t, r), this._renderPointer(t, e, n, _, r, s, l, a, d); }), (e.prototype._renderTicks = function ( t, e, n, i, r, o, a, s, l ) { for ( var u, h, c = this.group, p = r.cx, d = r.cy, f = r.r, g = +t.get("min"), y = +t.get("max"), v = t.getModel("splitLine"), m = t.getModel("axisTick"), x = t.getModel("axisLabel"), _ = t.get("splitNumber"), b = m.get("splitNumber"), w = $r(v.get("length"), f), S = $r(m.get("length"), f), M = o, I = (a - o) / _, T = I / b, C = v.getModel("lineStyle").getLineStyle(), D = m.getModel("lineStyle").getLineStyle(), A = v.get("distance"), k = 0; k <= _; k++ ) { if ( ((u = Math.cos(M)), (h = Math.sin(M)), v.get("show")) ) { var L = new Ku({ shape: { x1: u * (f - (P = A ? A + l : l)) + p, y1: h * (f - P) + d, x2: u * (f - w - P) + p, y2: h * (f - w - P) + d, }, style: C, silent: !0, }); "auto" === C.stroke && L.setStyle({ stroke: i(k / _) }), c.add(L); } if (x.get("show")) { var P = x.get("distance") + A, O = fk( Jr((k / _) * (y - g) + g), x.get("formatter") ), R = i(k / _), N = u * (f - w - P) + p, E = h * (f - w - P) + d, z = x.get("rotate"), V = 0; "radial" === z ? (V = -M + 2 * Math.PI) > Math.PI / 2 && (V += Math.PI) : "tangential" === z ? (V = -M - Math.PI / 2) : j(z) && (V = (z * Math.PI) / 180), 0 === V ? c.add( new Xs({ style: oc( x, { text: O, x: N, y: E, verticalAlign: h < -0.8 ? "top" : h > 0.8 ? "bottom" : "middle", align: u < -0.4 ? "left" : u > 0.4 ? "right" : "center", }, { inheritColor: R } ), silent: !0, }) ) : c.add( new Xs({ style: oc( x, { text: O, x: N, y: E, verticalAlign: "middle", align: "center", }, { inheritColor: R } ), silent: !0, originX: N, originY: E, rotation: V, }) ); } if (m.get("show") && k !== _) { P = (P = m.get("distance")) ? P + l : l; for (var B = 0; B <= b; B++) { (u = Math.cos(M)), (h = Math.sin(M)); var F = new Ku({ shape: { x1: u * (f - P) + p, y1: h * (f - P) + d, x2: u * (f - S - P) + p, y2: h * (f - S - P) + d, }, silent: !0, style: D, }); "auto" === D.stroke && F.setStyle({ stroke: i((k + B / b) / _) }), c.add(F), (M += T); } M -= T; } else M += I; } }), (e.prototype._renderPointer = function ( t, e, n, i, r, o, a, s, l ) { var u = this.group, h = this._data, c = this._progressEls, p = [], d = t.get(["pointer", "show"]), f = t.getModel("progress"), g = f.get("show"), y = t.getData(), v = y.mapDimension("value"), m = +t.get("min"), x = +t.get("max"), _ = [m, x], b = [o, a]; function w(e, n) { var i, o = y.getItemModel(e).getModel("pointer"), a = $r(o.get("width"), r.r), s = $r(o.get("length"), r.r), l = t.get(["pointer", "icon"]), u = o.get("offsetCenter"), h = $r(u[0], r.r), c = $r(u[1], r.r), p = o.get("keepAspect"); return ( ((i = l ? Xy(l, h - a / 2, c - s, a, s, null, p) : new dk({ shape: { angle: -Math.PI / 2, width: a, r: s, x: h, y: c, }, })).rotation = -(n + Math.PI / 2)), (i.x = r.cx), (i.y = r.cy), i ); } function S(t, e) { var n = f.get("roundCap") ? JS : Fu, i = f.get("overlap"), a = i ? f.get("width") : l / y.count(), u = i ? r.r - a : r.r - (t + 1) * a, h = i ? r.r : r.r - t * a, c = new n({ shape: { startAngle: o, endAngle: e, cx: r.cx, cy: r.cy, clockwise: s, r0: u, r: h, }, }); return ( i && (c.z2 = Kr(y.get(v, t), [m, x], [100, 0], !0)), c ); } (g || d) && (y .diff(h) .add(function (e) { var n = y.get(v, e); if (d) { var i = w(e, o); mh( i, { rotation: -( (isNaN(+n) ? b[0] : Kr(n, _, b, !0)) + Math.PI / 2 ), }, t ), u.add(i), y.setItemGraphicEl(e, i); } if (g) { var r = S(e, o), a = f.get("clip"); mh( r, { shape: { endAngle: Kr(n, _, b, a) } }, t ), u.add(r), ol(t.seriesIndex, y.dataType, e, r), (p[e] = r); } }) .update(function (e, n) { var i = y.get(v, e); if (d) { var r = h.getItemGraphicEl(n), a = r ? r.rotation : o, s = w(e, a); (s.rotation = a), vh( s, { rotation: -( (isNaN(+i) ? b[0] : Kr(i, _, b, !0)) + Math.PI / 2 ), }, t ), u.add(s), y.setItemGraphicEl(e, s); } if (g) { var l = c[n], m = S(e, l ? l.shape.endAngle : o), x = f.get("clip"); vh( m, { shape: { endAngle: Kr(i, _, b, x) } }, t ), u.add(m), ol(t.seriesIndex, y.dataType, e, m), (p[e] = m); } }) .execute(), y.each(function (t) { var e = y.getItemModel(t), n = e.getModel("emphasis"), r = n.get("focus"), o = n.get("blurScope"), a = n.get("disabled"); if (d) { var s = y.getItemGraphicEl(t), l = y.getItemVisual(t, "style"), u = l.fill; if (s instanceof Ns) { var h = s.style; s.useStyle( A( { image: h.image, x: h.x, y: h.y, width: h.width, height: h.height, }, l ) ); } else s.useStyle(l), "pointer" !== s.type && s.setColor(u); s.setStyle( e .getModel(["pointer", "itemStyle"]) .getItemStyle() ), "auto" === s.style.fill && s.setStyle( "fill", i(Kr(y.get(v, t), _, [0, 1], !0)) ), (s.z2EmphasisLift = 0), $l(s, e), Zl(s, r, o, a); } if (g) { var c = p[t]; c.useStyle(y.getItemVisual(t, "style")), c.setStyle( e .getModel(["progress", "itemStyle"]) .getItemStyle() ), (c.z2EmphasisLift = 0), $l(c, e), Zl(c, r, o, a); } }), (this._progressEls = p)); }), (e.prototype._renderAnchor = function (t, e) { var n = t.getModel("anchor"); if (n.get("show")) { var i = n.get("size"), r = n.get("icon"), o = n.get("offsetCenter"), a = n.get("keepAspect"), s = Xy( r, e.cx - i / 2 + $r(o[0], e.r), e.cy - i / 2 + $r(o[1], e.r), i, i, null, a ); (s.z2 = n.get("showAbove") ? 1 : 0), s.setStyle(n.getModel("itemStyle").getItemStyle()), this.group.add(s); } }), (e.prototype._renderTitleAndDetail = function (t, e, n, i, r) { var o = this, a = t.getData(), s = a.mapDimension("value"), l = +t.get("min"), u = +t.get("max"), h = new Br(), c = [], p = [], d = t.isAnimationEnabled(), f = t.get(["pointer", "showAbove"]); a .diff(this._data) .add(function (t) { (c[t] = new Xs({ silent: !0 })), (p[t] = new Xs({ silent: !0 })); }) .update(function (t, e) { (c[t] = o._titleEls[e]), (p[t] = o._detailEls[e]); }) .execute(), a.each(function (e) { var n = a.getItemModel(e), o = a.get(s, e), g = new Br(), y = i(Kr(o, [l, u], [0, 1], !0)), v = n.getModel("title"); if (v.get("show")) { var m = v.get("offsetCenter"), x = r.cx + $r(m[0], r.r), _ = r.cy + $r(m[1], r.r); (D = c[e]).attr({ z2: f ? 0 : 2, style: oc( v, { x: x, y: _, text: a.getName(e), align: "center", verticalAlign: "middle", }, { inheritColor: y } ), }), g.add(D); } var b = n.getModel("detail"); if (b.get("show")) { var w = b.get("offsetCenter"), S = r.cx + $r(w[0], r.r), M = r.cy + $r(w[1], r.r), I = $r(b.get("width"), r.r), T = $r(b.get("height"), r.r), C = t.get(["progress", "show"]) ? a.getItemVisual(e, "style").fill : y, D = p[e], A = b.get("formatter"); D.attr({ z2: f ? 0 : 2, style: oc( b, { x: S, y: M, text: fk(o, A), width: isNaN(I) ? null : I, height: isNaN(T) ? null : T, align: "center", verticalAlign: "middle", }, { inheritColor: C } ), }), dc(D, { normal: b }, o, function (t) { return fk(t, A); }), d && fc(D, e, a, t, { getFormattedLabel: function ( t, e, n, i, r, a ) { return fk( a ? a.interpolatedValue : o, A ); }, }), g.add(D); } h.add(g); }), this.group.add(h), (this._titleEls = c), (this._detailEls = p); }), (e.type = "gauge"), e ); })(Og), yk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.visualStyleAccessPath = "itemStyle"), n ); } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { return RM(this, ["value"]); }), (e.type = "series.gauge"), (e.defaultOption = { z: 2, colorBy: "data", center: ["50%", "50%"], legendHoverLink: !0, radius: "75%", startAngle: 225, endAngle: -45, clockwise: !0, min: 0, max: 100, splitNumber: 10, axisLine: { show: !0, roundCap: !1, lineStyle: { color: [[1, "#E6EBF8"]], width: 10 }, }, progress: { show: !1, overlap: !0, width: 10, roundCap: !1, clip: !0, }, splitLine: { show: !0, length: 10, distance: 10, lineStyle: { color: "#63677A", width: 3, type: "solid", }, }, axisTick: { show: !0, splitNumber: 5, length: 6, distance: 10, lineStyle: { color: "#63677A", width: 1, type: "solid", }, }, axisLabel: { show: !0, distance: 15, color: "#464646", fontSize: 12, rotate: 0, }, pointer: { icon: null, offsetCenter: [0, 0], show: !0, showAbove: !0, length: "60%", width: 6, keepAspect: !1, }, anchor: { show: !1, showAbove: !1, size: 6, icon: "circle", offsetCenter: [0, 0], keepAspect: !1, itemStyle: { color: "#fff", borderWidth: 0, borderColor: "#5470c6", }, }, title: { show: !0, offsetCenter: [0, "20%"], color: "#464646", fontSize: 16, valueAnimation: !1, }, detail: { show: !0, backgroundColor: "rgba(0,0,0,0)", borderWidth: 0, borderColor: "#ccc", width: 100, height: null, padding: [5, 10], offsetCenter: [0, "40%"], color: "#464646", fontSize: 30, fontWeight: "bold", lineHeight: 30, valueAnimation: !1, }, }), e ); })(bg); var vk = ["itemStyle", "opacity"], mk = (function (t) { function e(e, n) { var i = t.call(this) || this, r = i, o = new Zu(), a = new Xs(); return ( r.setTextContent(a), i.setTextGuideLine(o), i.updateData(e, n, !0), i ); } return ( n(e, t), (e.prototype.updateData = function (t, e, n) { var i = this, r = t.hostModel, o = t.getItemModel(e), a = t.getItemLayout(e), s = o.getModel("emphasis"), l = o.get(vk); (l = null == l ? 1 : l), n || Sh(i), i.useStyle(t.getItemVisual(e, "style")), (i.style.lineJoin = "round"), n ? (i.setShape({ points: a.points }), (i.style.opacity = 0), mh(i, { style: { opacity: l } }, r, e)) : vh( i, { style: { opacity: l }, shape: { points: a.points }, }, r, e ), $l(i, o), this._updateLabel(t, e), Zl( this, s.get("focus"), s.get("blurScope"), s.get("disabled") ); }), (e.prototype._updateLabel = function (t, e) { var n = this, i = this.getTextGuideLine(), r = n.getTextContent(), o = t.hostModel, a = t.getItemModel(e), s = t.getItemLayout(e).label, l = t.getItemVisual(e, "style"), u = l.fill; ic( r, rc(a), { labelFetcher: t.hostModel, labelDataIndex: e, defaultOpacity: l.opacity, defaultText: t.getName(e), }, { normal: { align: s.textAlign, verticalAlign: s.verticalAlign, }, } ), n.setTextConfig({ local: !0, inside: !!s.inside, insideStroke: u, outsideFill: u, }); var h = s.linePoints; i.setShape({ points: h }), (n.textGuideLineConfig = { anchor: h ? new De(h[0][0], h[0][1]) : null, }), vh(r, { style: { x: s.x, y: s.y } }, o, e), r.attr({ rotation: s.rotation, originX: s.x, originY: s.y, z2: 10, }), kb(n, Lb(a), { stroke: u }); }), e ); })(Xu), xk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.ignoreLabelLineUpdate = !0), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = t.getData(), r = this._data, o = this.group; i .diff(r) .add(function (t) { var e = new mk(i, t); i.setItemGraphicEl(t, e), o.add(e); }) .update(function (t, e) { var n = r.getItemGraphicEl(e); n.updateData(i, t), o.add(n), i.setItemGraphicEl(t, n); }) .remove(function (e) { wh(r.getItemGraphicEl(e), t, e); }) .execute(), (this._data = i); }), (e.prototype.remove = function () { this.group.removeAll(), (this._data = null); }), (e.prototype.dispose = function () {}), (e.type = "funnel"), e ); })(Og), _k = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), (this.legendVisualProvider = new NM( W(this.getData, this), W(this.getRawData, this) )), this._defaultLabelLine(e); }), (e.prototype.getInitialData = function (t, e) { return RM(this, { coordDimensions: ["value"], encodeDefaulter: H(ed, this), }); }), (e.prototype._defaultLabelLine = function (t) { Co(t, "labelLine", ["show"]); var e = t.labelLine, n = t.emphasis.labelLine; (e.show = e.show && t.label.show), (n.show = n.show && t.emphasis.label.show); }), (e.prototype.getDataParams = function (e) { var n = this.getData(), i = t.prototype.getDataParams.call(this, e), r = n.mapDimension("value"), o = n.getSum(r); return ( (i.percent = o ? +((n.get(r, e) / o) * 100).toFixed(2) : 0), i.$vars.push("percent"), i ); }), (e.type = "series.funnel"), (e.defaultOption = { z: 2, legendHoverLink: !0, colorBy: "data", left: 80, top: 60, right: 80, bottom: 60, minSize: "0%", maxSize: "100%", sort: "descending", orient: "vertical", gap: 0, funnelAlign: "center", label: { show: !0, position: "outer" }, labelLine: { show: !0, length: 20, lineStyle: { width: 1 }, }, itemStyle: { borderColor: "#fff", borderWidth: 1 }, emphasis: { label: { show: !0 } }, select: { itemStyle: { borderColor: "#212121" } }, }), e ); })(bg); function bk(t, e) { t.eachSeriesByType("funnel", function (t) { var n = t.getData(), i = n.mapDimension("value"), r = t.get("sort"), o = (function (t, e) { return kp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight(), }); })(t, e), a = t.get("orient"), s = o.width, l = o.height, u = (function (t, e) { for ( var n = t.mapDimension("value"), i = t.mapArray(n, function (t) { return t; }), r = [], o = "ascending" === e, a = 0, s = t.count(); a < s; a++ ) r[a] = a; return ( X(e) ? r.sort(e) : "none" !== e && r.sort(function (t, e) { return o ? i[t] - i[e] : i[e] - i[t]; }), r ); })(n, r), h = o.x, c = o.y, p = "horizontal" === a ? [$r(t.get("minSize"), l), $r(t.get("maxSize"), l)] : [$r(t.get("minSize"), s), $r(t.get("maxSize"), s)], d = n.getDataExtent(i), f = t.get("min"), g = t.get("max"); null == f && (f = Math.min(d[0], 0)), null == g && (g = d[1]); var y = t.get("funnelAlign"), v = t.get("gap"), m = (("horizontal" === a ? s : l) - v * (n.count() - 1)) / n.count(), x = function (t, e) { if ("horizontal" === a) { var r = Kr(n.get(i, t) || 0, [f, g], p, !0), o = void 0; switch (y) { case "top": o = c; break; case "center": o = c + (l - r) / 2; break; case "bottom": o = c + (l - r); } return [ [e, o], [e, o + r], ]; } var u, d = Kr(n.get(i, t) || 0, [f, g], p, !0); switch (y) { case "left": u = h; break; case "center": u = h + (s - d) / 2; break; case "right": u = h + s - d; } return [ [u, e], [u + d, e], ]; }; "ascending" === r && ((m = -m), (v = -v), "horizontal" === a ? (h += s) : (c += l), (u = u.reverse())); for (var _ = 0; _ < u.length; _++) { var b = u[_], w = u[_ + 1], S = n.getItemModel(b); if ("horizontal" === a) { var M = S.get(["itemStyle", "width"]); null == M ? (M = m) : ((M = $r(M, s)), "ascending" === r && (M = -M)); var I = x(b, h), T = x(w, h + M); (h += M + v), n.setItemLayout(b, { points: I.concat(T.slice().reverse()), }); } else { var C = S.get(["itemStyle", "height"]); null == C ? (C = m) : ((C = $r(C, l)), "ascending" === r && (C = -C)); (I = x(b, c)), (T = x(w, c + C)); (c += C + v), n.setItemLayout(b, { points: I.concat(T.slice().reverse()), }); } } !(function (t) { var e = t.hostModel.get("orient"); t.each(function (n) { var i, r, o, a, s = t.getItemModel(n), l = s.getModel("label").get("position"), u = s.getModel("labelLine"), h = t.getItemLayout(n), c = h.points, p = "inner" === l || "inside" === l || "center" === l || "insideLeft" === l || "insideRight" === l; if (p) "insideLeft" === l ? ((r = (c[0][0] + c[3][0]) / 2 + 5), (o = (c[0][1] + c[3][1]) / 2), (i = "left")) : "insideRight" === l ? ((r = (c[1][0] + c[2][0]) / 2 - 5), (o = (c[1][1] + c[2][1]) / 2), (i = "right")) : ((r = (c[0][0] + c[1][0] + c[2][0] + c[3][0]) / 4), (o = (c[0][1] + c[1][1] + c[2][1] + c[3][1]) / 4), (i = "center")), (a = [ [r, o], [r, o], ]); else { var d = void 0, f = void 0, g = void 0, y = void 0, v = u.get("length"); "left" === l ? ((d = (c[3][0] + c[0][0]) / 2), (f = (c[3][1] + c[0][1]) / 2), (r = (g = d - v) - 5), (i = "right")) : "right" === l ? ((d = (c[1][0] + c[2][0]) / 2), (f = (c[1][1] + c[2][1]) / 2), (r = (g = d + v) + 5), (i = "left")) : "top" === l ? ((d = (c[3][0] + c[0][0]) / 2), (o = (y = (f = (c[3][1] + c[0][1]) / 2) - v) - 5), (i = "center")) : "bottom" === l ? ((d = (c[1][0] + c[2][0]) / 2), (o = (y = (f = (c[1][1] + c[2][1]) / 2) + v) + 5), (i = "center")) : "rightTop" === l ? ((d = "horizontal" === e ? c[3][0] : c[1][0]), (f = "horizontal" === e ? c[3][1] : c[1][1]), "horizontal" === e ? ((o = (y = f - v) - 5), (i = "center")) : ((r = (g = d + v) + 5), (i = "top"))) : "rightBottom" === l ? ((d = c[2][0]), (f = c[2][1]), "horizontal" === e ? ((o = (y = f + v) + 5), (i = "center")) : ((r = (g = d + v) + 5), (i = "bottom"))) : "leftTop" === l ? ((d = c[0][0]), (f = "horizontal" === e ? c[0][1] : c[1][1]), "horizontal" === e ? ((o = (y = f - v) - 5), (i = "center")) : ((r = (g = d - v) - 5), (i = "right"))) : "leftBottom" === l ? ((d = "horizontal" === e ? c[1][0] : c[3][0]), (f = "horizontal" === e ? c[1][1] : c[2][1]), "horizontal" === e ? ((o = (y = f + v) + 5), (i = "center")) : ((r = (g = d - v) - 5), (i = "right"))) : ((d = (c[1][0] + c[2][0]) / 2), (f = (c[1][1] + c[2][1]) / 2), "horizontal" === e ? ((o = (y = f + v) + 5), (i = "center")) : ((r = (g = d + v) + 5), (i = "left"))), "horizontal" === e ? (r = g = d) : (o = y = f), (a = [ [d, f], [g, y], ]); } h.label = { linePoints: a, x: r, y: o, verticalAlign: "middle", textAlign: i, inside: p, }; }); })(n); }); } var wk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n._dataGroup = new Br()), (n._initialized = !1), n ); } return ( n(e, t), (e.prototype.init = function () { this.group.add(this._dataGroup); }), (e.prototype.render = function (t, e, n, i) { this._progressiveEls = null; var r = this._dataGroup, o = t.getData(), a = this._data, s = t.coordinateSystem, l = s.dimensions, u = Ik(t); if ( (o .diff(a) .add(function (t) { Tk(Mk(o, r, t, l, s), o, t, u); }) .update(function (e, n) { var i = a.getItemGraphicEl(n), r = Sk(o, e, l, s); o.setItemGraphicEl(e, i), vh(i, { shape: { points: r } }, t, e), Sh(i), Tk(i, o, e, u); }) .remove(function (t) { var e = a.getItemGraphicEl(t); r.remove(e); }) .execute(), !this._initialized) ) { this._initialized = !0; var h = (function (t, e, n) { var i = t.model, r = t.getRect(), o = new Ws({ shape: { x: r.x, y: r.y, width: r.width, height: r.height, }, }), a = "horizontal" === i.get("layout") ? "width" : "height"; return ( o.setShape(a, 0), mh( o, { shape: { width: r.width, height: r.height } }, e, n ), o ); })(s, t, function () { setTimeout(function () { r.removeClipPath(); }); }); r.setClipPath(h); } this._data = o; }), (e.prototype.incrementalPrepareRender = function (t, e, n) { (this._initialized = !0), (this._data = null), this._dataGroup.removeAll(); }), (e.prototype.incrementalRender = function (t, e, n) { for ( var i = e.getData(), r = e.coordinateSystem, o = r.dimensions, a = Ik(e), s = (this._progressiveEls = []), l = t.start; l < t.end; l++ ) { var u = Mk(i, this._dataGroup, l, o, r); (u.incremental = !0), Tk(u, i, l, a), s.push(u); } }), (e.prototype.remove = function () { this._dataGroup && this._dataGroup.removeAll(), (this._data = null); }), (e.type = "parallel"), e ); })(Og); function Sk(t, e, n, i) { for (var r, o = [], a = 0; a < n.length; a++) { var s = n[a], l = t.get(t.mapDimension(s), e); (r = l), ("category" === i.getAxis(s).type ? null == r : null == r || isNaN(r)) || o.push(i.dataToPoint(l, s)); } return o; } function Mk(t, e, n, i, r) { var o = Sk(t, n, i, r), a = new Zu({ shape: { points: o }, z2: 10 }); return e.add(a), t.setItemGraphicEl(n, a), a; } function Ik(t) { var e = t.get("smooth", !0); return !0 === e && (e = 0.3), nt((e = yo(e))) && (e = 0), { smooth: e }; } function Tk(t, e, n, i) { t.useStyle(e.getItemVisual(n, "style")), (t.style.fill = null), t.setShape("smooth", i.smooth); var r = e.getItemModel(n), o = r.getModel("emphasis"); $l(t, r, "lineStyle"), Zl(t, o.get("focus"), o.get("blurScope"), o.get("disabled")); } var Ck = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.visualStyleAccessPath = "lineStyle"), (n.visualDrawType = "stroke"), n ); } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { return _x(null, this, { useEncodeDefaulter: W(Dk, null, this), }); }), (e.prototype.getRawIndicesByActiveState = function (t) { var e = this.coordinateSystem, n = this.getData(), i = []; return ( e.eachActiveState(n, function (e, r) { t === e && i.push(n.getRawIndex(r)); }), i ); }), (e.type = "series.parallel"), (e.dependencies = ["parallel"]), (e.defaultOption = { z: 2, coordinateSystem: "parallel", parallelIndex: 0, label: { show: !1 }, inactiveOpacity: 0.05, activeOpacity: 1, lineStyle: { width: 1, opacity: 0.45, type: "solid" }, emphasis: { label: { show: !1 } }, progressive: 500, smooth: !1, animationEasing: "linear", }), e ); })(bg); function Dk(t) { var e = t.ecModel.getComponent("parallel", t.get("parallelIndex")); if (e) { var n = {}; return ( E(e.dimensions, function (t) { var e = +t.replace("dim", ""); n[t] = e; }), n ); } } var Ak = ["lineStyle", "opacity"], kk = { seriesType: "parallel", reset: function (t, e) { var n = t.coordinateSystem, i = { normal: t.get(["lineStyle", "opacity"]), active: t.get("activeOpacity"), inactive: t.get("inactiveOpacity"), }; return { progress: function (t, e) { n.eachActiveState( e, function (t, n) { var r = i[t]; if ("normal" === t && e.hasItemOption) { var o = e.getItemModel(n).get(Ak, !0); null != o && (r = o); } e.ensureUniqueItemVisual(n, "style").opacity = r; }, t.start, t.end ); }, }; }, }; function Lk(t) { !(function (t) { if (t.parallel) return; var e = !1; E(t.series, function (t) { t && "parallel" === t.type && (e = !0); }), e && (t.parallel = [{}]); })(t), (function (t) { var e = To(t.parallelAxis); E(e, function (e) { if (q(e)) { var n = e.parallelIndex || 0, i = To(t.parallel)[n]; i && i.parallelAxisDefault && C(e, i.parallelAxisDefault, !1); } }); })(t); } var Pk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { (this._model = t), (this._api = n), this._handlers || ((this._handlers = {}), E( Ok, function (t, e) { n.getZr().on( e, (this._handlers[e] = W(t, this)) ); }, this )), Hg( this, "_throttledDispatchExpand", t.get("axisExpandRate"), "fixRate" ); }), (e.prototype.dispose = function (t, e) { Yg(this, "_throttledDispatchExpand"), E(this._handlers, function (t, n) { e.getZr().off(n, t); }), (this._handlers = null); }), (e.prototype._throttledDispatchExpand = function (t) { this._dispatchExpand(t); }), (e.prototype._dispatchExpand = function (t) { t && this._api.dispatchAction( A({ type: "parallelAxisExpand" }, t) ); }), (e.type = "parallel"), e ); })(Ag), Ok = { mousedown: function (t) { Rk(this, "click") && (this._mouseDownPoint = [t.offsetX, t.offsetY]); }, mouseup: function (t) { var e = this._mouseDownPoint; if (Rk(this, "click") && e) { var n = [t.offsetX, t.offsetY]; if (Math.pow(e[0] - n[0], 2) + Math.pow(e[1] - n[1], 2) > 5) return; var i = this._model.coordinateSystem.getSlidedAxisExpandWindow([ t.offsetX, t.offsetY, ]); "none" !== i.behavior && this._dispatchExpand({ axisExpandWindow: i.axisExpandWindow, }); } this._mouseDownPoint = null; }, mousemove: function (t) { if (!this._mouseDownPoint && Rk(this, "mousemove")) { var e = this._model, n = e.coordinateSystem.getSlidedAxisExpandWindow([ t.offsetX, t.offsetY, ]), i = n.behavior; "jump" === i && this._throttledDispatchExpand.debounceNextCall( e.get("axisExpandDebounce") ), this._throttledDispatchExpand( "none" === i ? null : { axisExpandWindow: n.axisExpandWindow, animation: "jump" === i ? null : { duration: 0 }, } ); } }, }; function Rk(t, e) { var n = t._model; return n.get("axisExpandable") && n.get("axisExpandTriggerOn") === e; } var Nk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function () { t.prototype.init.apply(this, arguments), this.mergeOption({}); }), (e.prototype.mergeOption = function (t) { var e = this.option; t && C(e, t, !0), this._initDimensions(); }), (e.prototype.contains = function (t, e) { var n = t.get("parallelIndex"); return null != n && e.getComponent("parallel", n) === this; }), (e.prototype.setAxisExpand = function (t) { E( [ "axisExpandable", "axisExpandCenter", "axisExpandCount", "axisExpandWidth", "axisExpandWindow", ], function (e) { t.hasOwnProperty(e) && (this.option[e] = t[e]); }, this ); }), (e.prototype._initDimensions = function () { var t = (this.dimensions = []), e = (this.parallelAxisIndex = []); E( B( this.ecModel.queryComponents({ mainType: "parallelAxis", }), function (t) { return ( (t.get("parallelIndex") || 0) === this.componentIndex ); }, this ), function (n) { t.push("dim" + n.get("dim")), e.push(n.componentIndex); } ); }), (e.type = "parallel"), (e.dependencies = ["parallelAxis"]), (e.layoutMode = "box"), (e.defaultOption = { z: 0, left: 80, top: 60, right: 80, bottom: 60, layout: "horizontal", axisExpandable: !1, axisExpandCenter: null, axisExpandCount: 0, axisExpandWidth: 50, axisExpandRate: 17, axisExpandDebounce: 50, axisExpandSlideTriggerArea: [-0.15, 0.05, 0.4], axisExpandTriggerOn: "click", parallelAxisDefault: null, }), e ); })(zp), Ek = (function (t) { function e(e, n, i, r, o) { var a = t.call(this, e, n, i) || this; return (a.type = r || "value"), (a.axisIndex = o), a; } return ( n(e, t), (e.prototype.isHorizontal = function () { return ( "horizontal" !== this.coordinateSystem.getModel().get("layout") ); }), e ); })(ab); function zk(t, e, n, i, r, o) { t = t || 0; var a = n[1] - n[0]; if ( (null != r && (r = Bk(r, [0, a])), null != o && (o = Math.max(o, null != r ? r : 0)), "all" === i) ) { var s = Math.abs(e[1] - e[0]); (s = Bk(s, [0, a])), (r = o = Bk(s, [r, o])), (i = 0); } (e[0] = Bk(e[0], n)), (e[1] = Bk(e[1], n)); var l = Vk(e, i); e[i] += t; var u, h = r || 0, c = n.slice(); return ( l.sign < 0 ? (c[0] += h) : (c[1] -= h), (e[i] = Bk(e[i], c)), (u = Vk(e, i)), null != r && (u.sign !== l.sign || u.span < r) && (e[1 - i] = e[i] + l.sign * r), (u = Vk(e, i)), null != o && u.span > o && (e[1 - i] = e[i] + u.sign * o), e ); } function Vk(t, e) { var n = t[e] - t[1 - e]; return { span: Math.abs(n), sign: n > 0 ? -1 : n < 0 ? 1 : e ? -1 : 1 }; } function Bk(t, e) { return Math.min( null != e[1] ? e[1] : 1 / 0, Math.max(null != e[0] ? e[0] : -1 / 0, t) ); } var Fk = E, Gk = Math.min, Wk = Math.max, Hk = Math.floor, Yk = Math.ceil, Xk = Jr, Uk = Math.PI, Zk = (function () { function t(t, e, n) { (this.type = "parallel"), (this._axesMap = yt()), (this._axesLayout = {}), (this.dimensions = t.dimensions), (this._model = t), this._init(t, e, n); } return ( (t.prototype._init = function (t, e, n) { var i = t.dimensions, r = t.parallelAxisIndex; Fk( i, function (t, n) { var i = r[n], o = e.getComponent("parallelAxis", i), a = this._axesMap.set( t, new Ek(t, b_(o), [0, 0], o.get("type"), i) ), s = "category" === a.type; (a.onBand = s && o.get("boundaryGap")), (a.inverse = o.get("inverse")), (o.axis = a), (a.model = o), (a.coordinateSystem = o.coordinateSystem = this); }, this ); }), (t.prototype.update = function (t, e) { this._updateAxesFromSeries(this._model, t); }), (t.prototype.containPoint = function (t) { var e = this._makeLayoutInfo(), n = e.axisBase, i = e.layoutBase, r = e.pixelDimIndex, o = t[1 - r], a = t[r]; return ( o >= n && o <= n + e.axisLength && a >= i && a <= i + e.layoutLength ); }), (t.prototype.getModel = function () { return this._model; }), (t.prototype._updateAxesFromSeries = function (t, e) { e.eachSeries(function (n) { if (t.contains(n, e)) { var i = n.getData(); Fk( this.dimensions, function (t) { var e = this._axesMap.get(t); e.scale.unionExtentFromData( i, i.mapDimension(t) ), __(e.scale, e.model); }, this ); } }, this); }), (t.prototype.resize = function (t, e) { (this._rect = kp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight(), })), this._layoutAxes(); }), (t.prototype.getRect = function () { return this._rect; }), (t.prototype._makeLayoutInfo = function () { var t, e = this._model, n = this._rect, i = ["x", "y"], r = ["width", "height"], o = e.get("layout"), a = "horizontal" === o ? 0 : 1, s = n[r[a]], l = [0, s], u = this.dimensions.length, h = jk(e.get("axisExpandWidth"), l), c = jk(e.get("axisExpandCount") || 0, [0, u]), p = e.get("axisExpandable") && u > 3 && u > c && c > 1 && h > 0 && s > 0, d = e.get("axisExpandWindow"); d ? ((t = jk(d[1] - d[0], l)), (d[1] = d[0] + t)) : ((t = jk(h * (c - 1), l)), ((d = [ h * (e.get("axisExpandCenter") || Hk(u / 2)) - t / 2, ])[1] = d[0] + t)); var f = (s - t) / (u - c); f < 3 && (f = 0); var g = [Hk(Xk(d[0] / h, 1)) + 1, Yk(Xk(d[1] / h, 1)) - 1], y = (f / h) * d[0]; return { layout: o, pixelDimIndex: a, layoutBase: n[i[a]], layoutLength: s, axisBase: n[i[1 - a]], axisLength: n[r[1 - a]], axisExpandable: p, axisExpandWidth: h, axisCollapseWidth: f, axisExpandWindow: d, axisCount: u, winInnerIndices: g, axisExpandWindow0Pos: y, }; }), (t.prototype._layoutAxes = function () { var t = this._rect, e = this._axesMap, n = this.dimensions, i = this._makeLayoutInfo(), r = i.layout; e.each(function (t) { var e = [0, i.axisLength], n = t.inverse ? 1 : 0; t.setExtent(e[n], e[1 - n]); }), Fk( n, function (e, n) { var o = (i.axisExpandable ? Kk : qk)(n, i), a = { horizontal: { x: o.position, y: i.axisLength, }, vertical: { x: 0, y: o.position }, }, s = { horizontal: Uk / 2, vertical: 0 }, l = [a[r].x + t.x, a[r].y + t.y], u = s[r], h = [1, 0, 0, 1, 0, 0]; Se(h, h, u), we(h, h, l), (this._axesLayout[e] = { position: l, rotation: u, transform: h, axisNameAvailableWidth: o.axisNameAvailableWidth, axisLabelShow: o.axisLabelShow, nameTruncateMaxWidth: o.nameTruncateMaxWidth, tickDirection: 1, labelDirection: 1, }); }, this ); }), (t.prototype.getAxis = function (t) { return this._axesMap.get(t); }), (t.prototype.dataToPoint = function (t, e) { return this.axisCoordToPoint( this._axesMap.get(e).dataToCoord(t), e ); }), (t.prototype.eachActiveState = function (t, e, n, i) { null == n && (n = 0), null == i && (i = t.count()); var r = this._axesMap, o = this.dimensions, a = [], s = []; E(o, function (e) { a.push(t.mapDimension(e)), s.push(r.get(e).model); }); for (var l = this.hasAxisBrushed(), u = n; u < i; u++) { var h = void 0; if (l) { h = "active"; for ( var c = t.getValues(a, u), p = 0, d = o.length; p < d; p++ ) { if ("inactive" === s[p].getActiveState(c[p])) { h = "inactive"; break; } } } else h = "normal"; e(h, u); } }), (t.prototype.hasAxisBrushed = function () { for ( var t = this.dimensions, e = this._axesMap, n = !1, i = 0, r = t.length; i < r; i++ ) "normal" !== e.get(t[i]).model.getActiveState() && (n = !0); return n; }), (t.prototype.axisCoordToPoint = function (t, e) { return Fh([t, 0], this._axesLayout[e].transform); }), (t.prototype.getAxisLayout = function (t) { return T(this._axesLayout[t]); }), (t.prototype.getSlidedAxisExpandWindow = function (t) { var e = this._makeLayoutInfo(), n = e.pixelDimIndex, i = e.axisExpandWindow.slice(), r = i[1] - i[0], o = [0, e.axisExpandWidth * (e.axisCount - 1)]; if (!this.containPoint(t)) return { behavior: "none", axisExpandWindow: i }; var a, s = t[n] - e.layoutBase - e.axisExpandWindow0Pos, l = "slide", u = e.axisCollapseWidth, h = this._model.get("axisExpandSlideTriggerArea"), c = null != h[0]; if (u) c && u && s < r * h[0] ? ((l = "jump"), (a = s - r * h[2])) : c && u && s > r * (1 - h[0]) ? ((l = "jump"), (a = s - r * (1 - h[2]))) : (a = s - r * h[1]) >= 0 && (a = s - r * (1 - h[1])) <= 0 && (a = 0), (a *= e.axisExpandWidth / u) ? zk(a, i, o, "all") : (l = "none"); else { var p = i[1] - i[0]; ((i = [Wk(0, (o[1] * s) / p - p / 2)])[1] = Gk( o[1], i[0] + p )), (i[0] = i[1] - p); } return { axisExpandWindow: i, behavior: l }; }), t ); })(); function jk(t, e) { return Gk(Wk(t, e[0]), e[1]); } function qk(t, e) { var n = e.layoutLength / (e.axisCount - 1); return { position: n * t, axisNameAvailableWidth: n, axisLabelShow: !0, }; } function Kk(t, e) { var n, i, r = e.layoutLength, o = e.axisExpandWidth, a = e.axisCount, s = e.axisCollapseWidth, l = e.winInnerIndices, u = s, h = !1; return ( t < l[0] ? ((n = t * s), (i = s)) : t <= l[1] ? ((n = e.axisExpandWindow0Pos + t * o - e.axisExpandWindow[0]), (u = o), (h = !0)) : ((n = r - (a - 1 - t) * s), (i = s)), { position: n, axisNameAvailableWidth: u, axisLabelShow: h, nameTruncateMaxWidth: i, } ); } var $k = { create: function (t, e) { var n = []; return ( t.eachComponent("parallel", function (i, r) { var o = new Zk(i, t, e); (o.name = "parallel_" + r), o.resize(i, e), (i.coordinateSystem = o), (o.model = i), n.push(o); }), t.eachSeries(function (t) { if ("parallel" === t.get("coordinateSystem")) { var e = t.getReferringComponents("parallel", Wo) .models[0]; t.coordinateSystem = e.coordinateSystem; } }), n ); }, }, Jk = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.activeIntervals = []), n; } return ( n(e, t), (e.prototype.getAreaSelectStyle = function () { return ia([ ["fill", "color"], ["lineWidth", "borderWidth"], ["stroke", "borderColor"], ["width", "width"], ["opacity", "opacity"], ])(this.getModel("areaSelectStyle")); }), (e.prototype.setActiveIntervals = function (t) { var e = (this.activeIntervals = T(t)); if (e) for (var n = e.length - 1; n >= 0; n--) Qr(e[n]); }), (e.prototype.getActiveState = function (t) { var e = this.activeIntervals; if (!e.length) return "normal"; if (null == t || isNaN(+t)) return "inactive"; if (1 === e.length) { var n = e[0]; if (n[0] <= t && t <= n[1]) return "active"; } else for (var i = 0, r = e.length; i < r; i++) if (e[i][0] <= t && t <= e[i][1]) return "active"; return "inactive"; }), e ); })(zp); R(Jk, D_); var Qk = !0, tL = Math.min, eL = Math.max, nL = Math.pow, iL = "globalPan", rL = { w: [0, 0], e: [0, 1], n: [1, 0], s: [1, 1] }, oL = { w: "ew", e: "ew", n: "ns", s: "ns", ne: "nesw", sw: "nesw", nw: "nwse", se: "nwse", }, aL = { brushStyle: { lineWidth: 2, stroke: "rgba(210,219,238,0.3)", fill: "#D2DBEE", }, transformable: !0, brushMode: "single", removeOnClick: !1, }, sL = 0, lL = (function (t) { function e(e) { var n = t.call(this) || this; return ( (n._track = []), (n._covers = []), (n._handlers = {}), (n._zr = e), (n.group = new Br()), (n._uid = "brushController_" + sL++), E( NL, function (t, e) { this._handlers[e] = W(t, this); }, n ), n ); } return ( n(e, t), (e.prototype.enableBrush = function (t) { return ( this._brushType && this._doDisableBrush(), t.brushType && this._doEnableBrush(t), this ); }), (e.prototype._doEnableBrush = function (t) { var e = this._zr; this._enableGlobalPan || (function (t, e, n) { eT(t)[e] = n; })(e, iL, this._uid), E(this._handlers, function (t, n) { e.on(n, t); }), (this._brushType = t.brushType), (this._brushOption = C(T(aL), t, !0)); }), (e.prototype._doDisableBrush = function () { var t = this._zr; !(function (t, e, n) { var i = eT(t); i[e] === n && (i[e] = null); })(t, iL, this._uid), E(this._handlers, function (e, n) { t.off(n, e); }), (this._brushType = this._brushOption = null); }), (e.prototype.setPanels = function (t) { if (t && t.length) { var e = (this._panels = {}); E(t, function (t) { e[t.panelId] = T(t); }); } else this._panels = null; return this; }), (e.prototype.mount = function (t) { (t = t || {}), (this._enableGlobalPan = t.enableGlobalPan); var e = this.group; return ( this._zr.add(e), e.attr({ x: t.x || 0, y: t.y || 0, rotation: t.rotation || 0, scaleX: t.scaleX || 1, scaleY: t.scaleY || 1, }), (this._transform = e.getLocalTransform()), this ); }), (e.prototype.updateCovers = function (t) { t = z(t, function (t) { return C(T(aL), t, !0); }); var e = this._covers, n = (this._covers = []), i = this, r = this._creatingCover; return ( new Gm( e, t, function (t, e) { return o(t.__brushOption, e); }, o ) .add(a) .update(a) .remove(function (t) { e[t] !== r && i.group.remove(e[t]); }) .execute(), this ); function o(t, e) { return ( (null != t.id ? t.id : "\0-brush-index-" + e) + "-" + t.brushType ); } function a(o, a) { var s = t[o]; if (null != a && e[a] === r) n[o] = e[a]; else { var l = (n[o] = null != a ? ((e[a].__brushOption = s), e[a]) : hL(i, uL(i, s))); dL(i, l); } } }), (e.prototype.unmount = function () { return ( this.enableBrush(!1), vL(this), this._zr.remove(this.group), this ); }), (e.prototype.dispose = function () { this.unmount(), this.off(); }), e ); })(jt); function uL(t, e) { var n = zL[e.brushType].createCover(t, e); return (n.__brushOption = e), pL(n, e), t.group.add(n), n; } function hL(t, e) { var n = fL(e); return ( n.endCreating && (n.endCreating(t, e), pL(e, e.__brushOption)), e ); } function cL(t, e) { var n = e.__brushOption; fL(e).updateCoverShape(t, e, n.range, n); } function pL(t, e) { var n = e.z; null == n && (n = 1e4), t.traverse(function (t) { (t.z = n), (t.z2 = n); }); } function dL(t, e) { fL(e).updateCommon(t, e), cL(t, e); } function fL(t) { return zL[t.__brushOption.brushType]; } function gL(t, e, n) { var i, r = t._panels; if (!r) return Qk; var o = t._transform; return ( E(r, function (t) { t.isTargetByCursor(e, n, o) && (i = t); }), i ); } function yL(t, e) { var n = t._panels; if (!n) return Qk; var i = e.__brushOption.panelId; return null != i ? n[i] : Qk; } function vL(t) { var e = t._covers, n = e.length; return ( E( e, function (e) { t.group.remove(e); }, t ), (e.length = 0), !!n ); } function mL(t, e) { var n = z(t._covers, function (t) { var e = t.__brushOption, n = T(e.range); return { brushType: e.brushType, panelId: e.panelId, range: n }; }); t.trigger("brush", { areas: n, isEnd: !!e.isEnd, removeOnClick: !!e.removeOnClick, }); } function xL(t) { var e = t.length - 1; return e < 0 && (e = 0), [t[0], t[e]]; } function _L(t, e, n, i) { var r = new Br(); return ( r.add( new Ws({ name: "main", style: ML(n), silent: !0, draggable: !0, cursor: "move", drift: H(CL, t, e, r, ["n", "s", "w", "e"]), ondragend: H(mL, e, { isEnd: !0 }), }) ), E(i, function (n) { r.add( new Ws({ name: n.join(""), style: { opacity: 0 }, draggable: !0, silent: !0, invisible: !0, drift: H(CL, t, e, r, n), ondragend: H(mL, e, { isEnd: !0 }), }) ); }), r ); } function bL(t, e, n, i) { var r = i.brushStyle.lineWidth || 0, o = eL(r, 6), a = n[0][0], s = n[1][0], l = a - r / 2, u = s - r / 2, h = n[0][1], c = n[1][1], p = h - o + r / 2, d = c - o + r / 2, f = h - a, g = c - s, y = f + r, v = g + r; SL(t, e, "main", a, s, f, g), i.transformable && (SL(t, e, "w", l, u, o, v), SL(t, e, "e", p, u, o, v), SL(t, e, "n", l, u, y, o), SL(t, e, "s", l, d, y, o), SL(t, e, "nw", l, u, o, o), SL(t, e, "ne", p, u, o, o), SL(t, e, "sw", l, d, o, o), SL(t, e, "se", p, d, o, o)); } function wL(t, e) { var n = e.__brushOption, i = n.transformable, r = e.childAt(0); r.useStyle(ML(n)), r.attr({ silent: !i, cursor: i ? "move" : "default" }), E( [ ["w"], ["e"], ["n"], ["s"], ["s", "e"], ["s", "w"], ["n", "e"], ["n", "w"], ], function (n) { var r = e.childOfName(n.join("")), o = 1 === n.length ? TL(t, n[0]) : (function (t, e) { var n = [TL(t, e[0]), TL(t, e[1])]; return ( ("e" === n[0] || "w" === n[0]) && n.reverse(), n.join("") ); })(t, n); r && r.attr({ silent: !i, invisible: !i, cursor: i ? oL[o] + "-resize" : null, }); } ); } function SL(t, e, n, i, r, o, a) { var s = e.childOfName(n); s && s.setShape( (function (t) { var e = tL(t[0][0], t[1][0]), n = tL(t[0][1], t[1][1]), i = eL(t[0][0], t[1][0]), r = eL(t[0][1], t[1][1]); return { x: e, y: n, width: i - e, height: r - n }; })( kL(t, e, [ [i, r], [i + o, r + a], ]) ) ); } function ML(t) { return k({ strokeNoScale: !0 }, t.brushStyle); } function IL(t, e, n, i) { var r = [tL(t, n), tL(e, i)], o = [eL(t, n), eL(e, i)]; return [ [r[0], o[0]], [r[1], o[1]], ]; } function TL(t, e) { var n = Gh( { w: "left", e: "right", n: "top", s: "bottom" }[e], (function (t) { return Bh(t.group); })(t) ); return { left: "w", right: "e", top: "n", bottom: "s" }[n]; } function CL(t, e, n, i, r, o) { var a = n.__brushOption, s = t.toRectRange(a.range), l = AL(e, r, o); E(i, function (t) { var e = rL[t]; s[e[0]][e[1]] += l[e[0]]; }), (a.range = t.fromRectRange(IL(s[0][0], s[1][0], s[0][1], s[1][1]))), dL(e, n), mL(e, { isEnd: !1 }); } function DL(t, e, n, i) { var r = e.__brushOption.range, o = AL(t, n, i); E(r, function (t) { (t[0] += o[0]), (t[1] += o[1]); }), dL(t, e), mL(t, { isEnd: !1 }); } function AL(t, e, n) { var i = t.group, r = i.transformCoordToLocal(e, n), o = i.transformCoordToLocal(0, 0); return [r[0] - o[0], r[1] - o[1]]; } function kL(t, e, n) { var i = yL(t, e); return i && i !== Qk ? i.clipPath(n, t._transform) : T(n); } function LL(t) { var e = t.event; e.preventDefault && e.preventDefault(); } function PL(t, e, n) { return t.childOfName("main").contain(e, n); } function OL(t, e, n, i) { var r, o = t._creatingCover, a = t._creatingPanel, s = t._brushOption; if ( (t._track.push(n.slice()), (function (t) { var e = t._track; if (!e.length) return !1; var n = e[e.length - 1], i = e[0], r = n[0] - i[0], o = n[1] - i[1]; return nL(r * r + o * o, 0.5) > 6; })(t) || o) ) { if (a && !o) { "single" === s.brushMode && vL(t); var l = T(s); (l.brushType = RL(l.brushType, a)), (l.panelId = a === Qk ? null : a.panelId), (o = t._creatingCover = uL(t, l)), t._covers.push(o); } if (o) { var u = zL[RL(t._brushType, a)]; (o.__brushOption.range = u.getCreatingRange( kL(t, o, t._track) )), i && (hL(t, o), u.updateCommon(t, o)), cL(t, o), (r = { isEnd: i }); } } else i && "single" === s.brushMode && s.removeOnClick && gL(t, e, n) && vL(t) && (r = { isEnd: i, removeOnClick: !0 }); return r; } function RL(t, e) { return "auto" === t ? e.defaultBrushType : t; } var NL = { mousedown: function (t) { if (this._dragging) EL(this, t); else if (!t.target || !t.target.draggable) { LL(t); var e = this.group.transformCoordToLocal(t.offsetX, t.offsetY); (this._creatingCover = null), (this._creatingPanel = gL(this, t, e)) && ((this._dragging = !0), (this._track = [e.slice()])); } }, mousemove: function (t) { var e = t.offsetX, n = t.offsetY, i = this.group.transformCoordToLocal(e, n); if ( ((function (t, e, n) { if ( t._brushType && !(function (t, e, n) { var i = t._zr; return ( e < 0 || e > i.getWidth() || n < 0 || n > i.getHeight() ); })(t, e.offsetX, e.offsetY) ) { var i = t._zr, r = t._covers, o = gL(t, e, n); if (!t._dragging) for (var a = 0; a < r.length; a++) { var s = r[a].__brushOption; if ( o && (o === Qk || s.panelId === o.panelId) && zL[s.brushType].contain(r[a], n[0], n[1]) ) return; } o && i.setCursorStyle("crosshair"); } })(this, t, i), this._dragging) ) { LL(t); var r = OL(this, t, i, !1); r && mL(this, r); } }, mouseup: function (t) { EL(this, t); }, }; function EL(t, e) { if (t._dragging) { LL(e); var n = e.offsetX, i = e.offsetY, r = t.group.transformCoordToLocal(n, i), o = OL(t, e, r, !0); (t._dragging = !1), (t._track = []), (t._creatingCover = null), o && mL(t, o); } } var zL = { lineX: VL(0), lineY: VL(1), rect: { createCover: function (t, e) { function n(t) { return t; } return _L({ toRectRange: n, fromRectRange: n }, t, e, [ ["w"], ["e"], ["n"], ["s"], ["s", "e"], ["s", "w"], ["n", "e"], ["n", "w"], ]); }, getCreatingRange: function (t) { var e = xL(t); return IL(e[1][0], e[1][1], e[0][0], e[0][1]); }, updateCoverShape: function (t, e, n, i) { bL(t, e, n, i); }, updateCommon: wL, contain: PL, }, polygon: { createCover: function (t, e) { var n = new Br(); return ( n.add(new Zu({ name: "main", style: ML(e), silent: !0 })), n ); }, getCreatingRange: function (t) { return t; }, endCreating: function (t, e) { e.remove(e.childAt(0)), e.add( new Xu({ name: "main", draggable: !0, drift: H(DL, t, e), ondragend: H(mL, t, { isEnd: !0 }), }) ); }, updateCoverShape: function (t, e, n, i) { e.childAt(0).setShape({ points: kL(t, e, n) }); }, updateCommon: wL, contain: PL, }, }; function VL(t) { return { createCover: function (e, n) { return _L( { toRectRange: function (e) { var n = [e, [0, 100]]; return t && n.reverse(), n; }, fromRectRange: function (e) { return e[t]; }, }, e, n, [ [["w"], ["e"]], [["n"], ["s"]], ][t] ); }, getCreatingRange: function (e) { var n = xL(e); return [tL(n[0][t], n[1][t]), eL(n[0][t], n[1][t])]; }, updateCoverShape: function (e, n, i, r) { var o, a = yL(e, n); if (a !== Qk && a.getLinearBrushOtherExtent) o = a.getLinearBrushOtherExtent(t); else { var s = e._zr; o = [0, [s.getWidth(), s.getHeight()][1 - t]]; } var l = [i, o]; t && l.reverse(), bL(e, n, l, r); }, updateCommon: wL, contain: PL, }; } function BL(t) { return ( (t = WL(t)), function (e) { return Yh(e, t); } ); } function FL(t, e) { return ( (t = WL(t)), function (n) { var i = null != e ? e : n, r = i ? t.width : t.height, o = i ? t.x : t.y; return [o, o + (r || 0)]; } ); } function GL(t, e, n) { var i = WL(t); return function (t, r) { return i.contain(r[0], r[1]) && !hT(t, e, n); }; } function WL(t) { return ze.create(t); } var HL = ["axisLine", "axisTickLabel", "axisName"], YL = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (e, n) { t.prototype.init.apply(this, arguments), (this._brushController = new lL(n.getZr())).on( "brush", W(this._onBrush, this) ); }), (e.prototype.render = function (t, e, n, i) { if ( !(function (t, e, n) { return ( n && "axisAreaSelect" === n.type && e.findComponents({ mainType: "parallelAxis", query: n, })[0] === t ); })(t, e, i) ) { (this.axisModel = t), (this.api = n), this.group.removeAll(); var r = this._axisGroup; if ( ((this._axisGroup = new Br()), this.group.add(this._axisGroup), t.get("show")) ) { var o = (function (t, e) { return e.getComponent( "parallel", t.get("parallelIndex") ); })(t, e), a = o.coordinateSystem, s = t.getAreaSelectStyle(), l = s.width, u = t.axis.dim, h = A( { strokeContainThreshold: l }, a.getAxisLayout(u) ), c = new dI(t, h); E(HL, c.add, c), this._axisGroup.add(c.getGroup()), this._refreshBrushController(h, s, t, o, l, n), Hh(r, this._axisGroup, t); } } }), (e.prototype._refreshBrushController = function ( t, e, n, i, r, o ) { var a = n.axis.getExtent(), s = a[1] - a[0], l = Math.min(30, 0.1 * Math.abs(s)), u = ze.create({ x: a[0], y: -r / 2, width: s, height: r, }); (u.x -= l), (u.width += 2 * l), this._brushController .mount({ enableGlobalPan: !0, rotation: t.rotation, x: t.position[0], y: t.position[1], }) .setPanels([ { panelId: "pl", clipPath: BL(u), isTargetByCursor: GL(u, o, i), getLinearBrushOtherExtent: FL(u, 0), }, ]) .enableBrush({ brushType: "lineX", brushStyle: e, removeOnClick: !0, }) .updateCovers( (function (t) { var e = t.axis; return z(t.activeIntervals, function (t) { return { brushType: "lineX", panelId: "pl", range: [ e.dataToCoord(t[0], !0), e.dataToCoord(t[1], !0), ], }; }); })(n) ); }), (e.prototype._onBrush = function (t) { var e = t.areas, n = this.axisModel, i = n.axis, r = z(e, function (t) { return [ i.coordToData(t.range[0], !0), i.coordToData(t.range[1], !0), ]; }); (!n.option.realtime === t.isEnd || t.removeOnClick) && this.api.dispatchAction({ type: "axisAreaSelect", parallelAxisId: n.id, intervals: r, }); }), (e.prototype.dispose = function () { this._brushController.dispose(); }), (e.type = "parallelAxis"), e ); })(Ag); var XL = { type: "axisAreaSelect", event: "axisAreaSelected" }; var UL = { type: "value", areaSelectStyle: { width: 20, borderWidth: 1, borderColor: "rgba(160,197,232)", color: "rgba(160,197,232)", opacity: 0.3, }, realtime: !0, z: 10, }; function ZL(t) { t.registerComponentView(Pk), t.registerComponentModel(Nk), t.registerCoordinateSystem("parallel", $k), t.registerPreprocessor(Lk), t.registerComponentModel(Jk), t.registerComponentView(YL), KM(t, "parallel", Jk, UL), (function (t) { t.registerAction(XL, function (t, e) { e.eachComponent( { mainType: "parallelAxis", query: t }, function (e) { e.axis.model.setActiveIntervals(t.intervals); } ); }), t.registerAction("parallelAxisExpand", function (t, e) { e.eachComponent( { mainType: "parallel", query: t }, function (e) { e.setAxisExpand(t); } ); }); })(t); } var jL = function () { (this.x1 = 0), (this.y1 = 0), (this.x2 = 0), (this.y2 = 0), (this.cpx1 = 0), (this.cpy1 = 0), (this.cpx2 = 0), (this.cpy2 = 0), (this.extent = 0); }, qL = (function (t) { function e(e) { return t.call(this, e) || this; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new jL(); }), (e.prototype.buildPath = function (t, e) { var n = e.extent; t.moveTo(e.x1, e.y1), t.bezierCurveTo( e.cpx1, e.cpy1, e.cpx2, e.cpy2, e.x2, e.y2 ), "vertical" === e.orient ? (t.lineTo(e.x2 + n, e.y2), t.bezierCurveTo( e.cpx2 + n, e.cpy2, e.cpx1 + n, e.cpy1, e.x1 + n, e.y1 )) : (t.lineTo(e.x2, e.y2 + n), t.bezierCurveTo( e.cpx2, e.cpy2 + n, e.cpx1, e.cpy1 + n, e.x1, e.y1 + n )), t.closePath(); }), (e.prototype.highlight = function () { Ol(this); }), (e.prototype.downplay = function () { Rl(this); }), e ); })(ks), KL = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n._focusAdjacencyDisabled = !1), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = this, r = t.getGraph(), o = this.group, a = t.layoutInfo, s = a.width, l = a.height, u = t.getData(), h = t.getData("edge"), c = t.get("orient"); (this._model = t), o.removeAll(), (o.x = a.x), (o.y = a.y), r.eachEdge(function (e) { var n = new qL(), i = rl(n); (i.dataIndex = e.dataIndex), (i.seriesIndex = t.seriesIndex), (i.dataType = "edge"); var r, a, u, p, d, f, g, y, v = e.getModel(), m = v.getModel("lineStyle"), x = m.get("curveness"), _ = e.node1.getLayout(), b = e.node1.getModel(), w = b.get("localX"), S = b.get("localY"), M = e.node2.getLayout(), I = e.node2.getModel(), T = I.get("localX"), C = I.get("localY"), D = e.getLayout(); (n.shape.extent = Math.max(1, D.dy)), (n.shape.orient = c), "vertical" === c ? ((r = (null != w ? w * s : _.x) + D.sy), (a = (null != S ? S * l : _.y) + _.dy), (u = (null != T ? T * s : M.x) + D.ty), (d = r), (f = a * (1 - x) + (p = null != C ? C * l : M.y) * x), (g = u), (y = a * x + p * (1 - x))) : ((r = (null != w ? w * s : _.x) + _.dx), (a = (null != S ? S * l : _.y) + D.sy), (d = r * (1 - x) + (u = null != T ? T * s : M.x) * x), (f = a), (g = r * x + u * (1 - x)), (y = p = (null != C ? C * l : M.y) + D.ty)), n.setShape({ x1: r, y1: a, x2: u, y2: p, cpx1: d, cpy1: f, cpx2: g, cpy2: y, }), n.useStyle(m.getItemStyle()), $L(n.style, c, e); var A = "" + v.get("value"), k = rc(v, "edgeLabel"); ic(n, k, { labelFetcher: { getFormattedLabel: function ( e, n, i, r, o, a ) { return t.getFormattedLabel( e, n, "edge", r, ot( o, k.normal && k.normal.get("formatter"), A ), a ); }, }, labelDataIndex: e.dataIndex, defaultText: A, }), n.setTextConfig({ position: "inside" }); var L = v.getModel("emphasis"); $l(n, v, "lineStyle", function (t) { var n = t.getItemStyle(); return $L(n, c, e), n; }), o.add(n), h.setItemGraphicEl(e.dataIndex, n); var P = L.get("focus"); Zl( n, "adjacency" === P ? e.getAdjacentDataIndices() : "trajectory" === P ? e.getTrajectoryDataIndices() : P, L.get("blurScope"), L.get("disabled") ); }), r.eachNode(function (e) { var n = e.getLayout(), i = e.getModel(), r = i.get("localX"), a = i.get("localY"), h = i.getModel("emphasis"), c = i.get(["itemStyle", "borderRadius"]) || 0, p = new Ws({ shape: { x: null != r ? r * s : n.x, y: null != a ? a * l : n.y, width: n.dx, height: n.dy, r: c, }, style: i .getModel("itemStyle") .getItemStyle(), z2: 10, }); ic(p, rc(i), { labelFetcher: { getFormattedLabel: function (e, n) { return t.getFormattedLabel( e, n, "node" ); }, }, labelDataIndex: e.dataIndex, defaultText: e.id, }), (p.disableLabelAnimation = !0), p.setStyle("fill", e.getVisual("color")), p.setStyle("decal", e.getVisual("style").decal), $l(p, i), o.add(p), u.setItemGraphicEl(e.dataIndex, p), (rl(p).dataType = "node"); var d = h.get("focus"); Zl( p, "adjacency" === d ? e.getAdjacentDataIndices() : "trajectory" === d ? e.getTrajectoryDataIndices() : d, h.get("blurScope"), h.get("disabled") ); }), u.eachItemGraphicEl(function (e, r) { u.getItemModel(r).get("draggable") && ((e.drift = function (e, o) { (i._focusAdjacencyDisabled = !0), (this.shape.x += e), (this.shape.y += o), this.dirty(), n.dispatchAction({ type: "dragNode", seriesId: t.id, dataIndex: u.getRawIndex(r), localX: this.shape.x / s, localY: this.shape.y / l, }); }), (e.ondragend = function () { i._focusAdjacencyDisabled = !1; }), (e.draggable = !0), (e.cursor = "move")); }), !this._data && t.isAnimationEnabled() && o.setClipPath( (function (t, e, n) { var i = new Ws({ shape: { x: t.x - 10, y: t.y - 10, width: 0, height: t.height + 20, }, }); return ( mh( i, { shape: { width: t.width + 20 } }, e, n ), i ); })(o.getBoundingRect(), t, function () { o.removeClipPath(); }) ), (this._data = t.getData()); }), (e.prototype.dispose = function () {}), (e.type = "sankey"), e ); })(Og); function $L(t, e, n) { switch (t.fill) { case "source": (t.fill = n.node1.getVisual("color")), (t.decal = n.node1.getVisual("style").decal); break; case "target": (t.fill = n.node2.getVisual("color")), (t.decal = n.node2.getVisual("style").decal); break; case "gradient": var i = n.node1.getVisual("color"), r = n.node2.getVisual("color"); U(i) && U(r) && (t.fill = new oh( 0, 0, +("horizontal" === e), +("vertical" === e), [ { color: i, offset: 0 }, { color: r, offset: 1 }, ] )); } } var JL = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { var n = t.edges || t.links || [], i = t.data || t.nodes || [], r = t.levels || []; this.levelModels = []; for (var o = this.levelModels, a = 0; a < r.length; a++) null != r[a].depth && r[a].depth >= 0 && (o[r[a].depth] = new Cc(r[a], this, e)); var s = uk(i, n, this, !0, function (t, e) { t.wrapMethod("getItemModel", function (t, e) { var n = t.parentModel, i = n.getData().getItemLayout(e); if (i) { var r = i.depth, o = n.levelModels[r]; o && (t.parentModel = o); } return t; }), e.wrapMethod("getItemModel", function (t, e) { var n = t.parentModel, i = n .getGraph() .getEdgeByIndex(e) .node1.getLayout(); if (i) { var r = i.depth, o = n.levelModels[r]; o && (t.parentModel = o); } return t; }); }); return s.data; }), (e.prototype.setNodePosition = function (t, e) { var n = (this.option.data || this.option.nodes)[t]; (n.localX = e[0]), (n.localY = e[1]); }), (e.prototype.getGraph = function () { return this.getData().graph; }), (e.prototype.getEdgeData = function () { return this.getGraph().edgeData; }), (e.prototype.formatTooltip = function (t, e, n) { function i(t) { return isNaN(t) || null == t; } if ("edge" === n) { var r = this.getDataParams(t, n), o = r.data, a = r.value; return og("nameValue", { name: o.source + " -- " + o.target, value: a, noValue: i(a), }); } var s = this.getGraph().getNodeByIndex(t).getLayout().value, l = this.getDataParams(t, n).data.name; return og("nameValue", { name: null != l ? l + "" : null, value: s, noValue: i(s), }); }), (e.prototype.optionUpdated = function () {}), (e.prototype.getDataParams = function (e, n) { var i = t.prototype.getDataParams.call(this, e, n); if (null == i.value && "node" === n) { var r = this.getGraph().getNodeByIndex(e).getLayout().value; i.value = r; } return i; }), (e.type = "series.sankey"), (e.defaultOption = { z: 2, coordinateSystem: "view", left: "5%", top: "5%", right: "20%", bottom: "5%", orient: "horizontal", nodeWidth: 20, nodeGap: 8, draggable: !0, layoutIterations: 32, label: { show: !0, position: "right", fontSize: 12 }, edgeLabel: { show: !1, fontSize: 12 }, levels: [], nodeAlign: "justify", lineStyle: { color: "#314656", opacity: 0.2, curveness: 0.5 }, emphasis: { label: { show: !0 }, lineStyle: { opacity: 0.5 } }, select: { itemStyle: { borderColor: "#212121" } }, animationEasing: "linear", animationDuration: 1e3, }), e ); })(bg); function QL(t, e) { t.eachSeriesByType("sankey", function (t) { var n = t.get("nodeWidth"), i = t.get("nodeGap"), r = (function (t, e) { return kp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight(), }); })(t, e); t.layoutInfo = r; var o = r.width, a = r.height, s = t.getGraph(), l = s.nodes, u = s.edges; !(function (t) { E(t, function (t) { var e = uP(t.outEdges, lP), n = uP(t.inEdges, lP), i = t.getValue() || 0, r = Math.max(e, n, i); t.setLayout({ value: r }, !0); }); })(l), (function (t, e, n, i, r, o, a, s, l) { (function (t, e, n, i, r, o, a) { for ( var s = [], l = [], u = [], h = [], c = 0, p = 0; p < e.length; p++ ) s[p] = 1; for (p = 0; p < t.length; p++) (l[p] = t[p].inEdges.length), 0 === l[p] && u.push(t[p]); var d = -1; for (; u.length; ) { for (var f = 0; f < u.length; f++) { var g = u[f], y = g.hostGraph.data.getRawDataItem( g.dataIndex ), v = null != y.depth && y.depth >= 0; v && y.depth > d && (d = y.depth), g.setLayout({ depth: v ? y.depth : c }, !0), "vertical" === o ? g.setLayout({ dy: n }, !0) : g.setLayout({ dx: n }, !0); for (var m = 0; m < g.outEdges.length; m++) { var x = g.outEdges[m]; s[e.indexOf(x)] = 0; var _ = x.node2; 0 == --l[t.indexOf(_)] && h.indexOf(_) < 0 && h.push(_); } } ++c, (u = h), (h = []); } for (p = 0; p < s.length; p++) if (1 === s[p]) throw new Error( "Sankey is a DAG, the original data has cycle!" ); var b = d > c - 1 ? d : c - 1; a && "left" !== a && (function (t, e, n, i) { if ("right" === e) { for (var r = [], o = t, a = 0; o.length; ) { for (var s = 0; s < o.length; s++) { var l = o[s]; l.setLayout( { skNodeHeight: a }, !0 ); for ( var u = 0; u < l.inEdges.length; u++ ) { var h = l.inEdges[u]; r.indexOf(h.node1) < 0 && r.push(h.node1); } } (o = r), (r = []), ++a; } E(t, function (t) { tP(t) || t.setLayout( { depth: Math.max( 0, i - t.getLayout() .skNodeHeight ), }, !0 ); }); } else "justify" === e && (function (t, e) { E(t, function (t) { tP(t) || t.outEdges.length || t.setLayout( { depth: e }, !0 ); }); })(t, i); })(t, a, 0, b); var w = "vertical" === o ? (r - n) / b : (i - n) / b; !(function (t, e, n) { E(t, function (t) { var i = t.getLayout().depth * e; "vertical" === n ? t.setLayout({ y: i }, !0) : t.setLayout({ x: i }, !0); }); })(t, w, o); })(t, e, n, r, o, s, l), (function (t, e, n, i, r, o, a) { var s = (function (t, e) { var n = [], i = "vertical" === e ? "y" : "x", r = Uo(t, function (t) { return t.getLayout()[i]; }); return ( r.keys.sort(function (t, e) { return t - e; }), E(r.keys, function (t) { n.push(r.buckets.get(t)); }), n ); })(t, a); (function (t, e, n, i, r, o) { var a = 1 / 0; E(t, function (t) { var e = t.length, s = 0; E(t, function (t) { s += t.getLayout().value; }); var l = "vertical" === o ? (i - (e - 1) * r) / s : (n - (e - 1) * r) / s; l < a && (a = l); }), E(t, function (t) { E(t, function (t, e) { var n = t.getLayout().value * a; "vertical" === o ? (t.setLayout({ x: e }, !0), t.setLayout({ dx: n }, !0)) : (t.setLayout({ y: e }, !0), t.setLayout({ dy: n }, !0)); }); }), E(e, function (t) { var e = +t.getValue() * a; t.setLayout({ dy: e }, !0); }); })(s, e, n, i, r, a), eP(s, r, n, i, a); for (var l = 1; o > 0; o--) nP(s, (l *= 0.99), a), eP(s, r, n, i, a), hP(s, l, a), eP(s, r, n, i, a); })(t, e, o, r, i, a, s), (function (t, e) { var n = "vertical" === e ? "x" : "y"; E(t, function (t) { t.outEdges.sort(function (t, e) { return ( t.node2.getLayout()[n] - e.node2.getLayout()[n] ); }), t.inEdges.sort(function (t, e) { return ( t.node1.getLayout()[n] - e.node1.getLayout()[n] ); }); }), E(t, function (t) { var e = 0, n = 0; E(t.outEdges, function (t) { t.setLayout({ sy: e }, !0), (e += t.getLayout().dy); }), E(t.inEdges, function (t) { t.setLayout({ ty: n }, !0), (n += t.getLayout().dy); }); }); })(t, s); })( l, u, n, i, o, a, 0 !== B(l, function (t) { return 0 === t.getLayout().value; }).length ? 0 : t.get("layoutIterations"), t.get("orient"), t.get("nodeAlign") ); }); } function tP(t) { var e = t.hostGraph.data.getRawDataItem(t.dataIndex); return null != e.depth && e.depth >= 0; } function eP(t, e, n, i, r) { var o = "vertical" === r ? "x" : "y"; E(t, function (t) { var a, s, l; t.sort(function (t, e) { return t.getLayout()[o] - e.getLayout()[o]; }); for ( var u = 0, h = t.length, c = "vertical" === r ? "dx" : "dy", p = 0; p < h; p++ ) (l = u - (s = t[p]).getLayout()[o]) > 0 && ((a = s.getLayout()[o] + l), "vertical" === r ? s.setLayout({ x: a }, !0) : s.setLayout({ y: a }, !0)), (u = s.getLayout()[o] + s.getLayout()[c] + e); if ((l = u - e - ("vertical" === r ? i : n)) > 0) { (a = s.getLayout()[o] - l), "vertical" === r ? s.setLayout({ x: a }, !0) : s.setLayout({ y: a }, !0), (u = a); for (p = h - 2; p >= 0; --p) (l = (s = t[p]).getLayout()[o] + s.getLayout()[c] + e - u) > 0 && ((a = s.getLayout()[o] - l), "vertical" === r ? s.setLayout({ x: a }, !0) : s.setLayout({ y: a }, !0)), (u = s.getLayout()[o]); } }); } function nP(t, e, n) { E(t.slice().reverse(), function (t) { E(t, function (t) { if (t.outEdges.length) { var i = uP(t.outEdges, iP, n) / uP(t.outEdges, lP); if (isNaN(i)) { var r = t.outEdges.length; i = r ? uP(t.outEdges, rP, n) / r : 0; } if ("vertical" === n) { var o = t.getLayout().x + (i - sP(t, n)) * e; t.setLayout({ x: o }, !0); } else { var a = t.getLayout().y + (i - sP(t, n)) * e; t.setLayout({ y: a }, !0); } } }); }); } function iP(t, e) { return sP(t.node2, e) * t.getValue(); } function rP(t, e) { return sP(t.node2, e); } function oP(t, e) { return sP(t.node1, e) * t.getValue(); } function aP(t, e) { return sP(t.node1, e); } function sP(t, e) { return "vertical" === e ? t.getLayout().x + t.getLayout().dx / 2 : t.getLayout().y + t.getLayout().dy / 2; } function lP(t) { return t.getValue(); } function uP(t, e, n) { for (var i = 0, r = t.length, o = -1; ++o < r; ) { var a = +e(t[o], n); isNaN(a) || (i += a); } return i; } function hP(t, e, n) { E(t, function (t) { E(t, function (t) { if (t.inEdges.length) { var i = uP(t.inEdges, oP, n) / uP(t.inEdges, lP); if (isNaN(i)) { var r = t.inEdges.length; i = r ? uP(t.inEdges, aP, n) / r : 0; } if ("vertical" === n) { var o = t.getLayout().x + (i - sP(t, n)) * e; t.setLayout({ x: o }, !0); } else { var a = t.getLayout().y + (i - sP(t, n)) * e; t.setLayout({ y: a }, !0); } } }); }); } function cP(t) { t.eachSeriesByType("sankey", function (t) { var e = t.getGraph(), n = e.nodes, i = e.edges; if (n.length) { var r = 1 / 0, o = -1 / 0; E(n, function (t) { var e = t.getLayout().value; e < r && (r = e), e > o && (o = e); }), E(n, function (e) { var n = new kD({ type: "color", mappingMethod: "linear", dataExtent: [r, o], visual: t.get("color"), }).mapValueToVisual(e.getLayout().value), i = e.getModel().get(["itemStyle", "color"]); null != i ? (e.setVisual("color", i), e.setVisual("style", { fill: i })) : (e.setVisual("color", n), e.setVisual("style", { fill: n })); }); } i.length && E(i, function (t) { var e = t.getModel().get("lineStyle"); t.setVisual("style", e); }); }); } var pP = (function () { function t() {} return ( (t.prototype._hasEncodeRule = function (t) { var e = this.getEncode(); return e && null != e.get(t); }), (t.prototype.getInitialData = function (t, e) { var n, i, r = e.getComponent("xAxis", this.get("xAxisIndex")), o = e.getComponent("yAxis", this.get("yAxisIndex")), a = r.get("type"), s = o.get("type"); "category" === a ? ((t.layout = "horizontal"), (n = r.getOrdinalMeta()), (i = !this._hasEncodeRule("x"))) : "category" === s ? ((t.layout = "vertical"), (n = o.getOrdinalMeta()), (i = !this._hasEncodeRule("y"))) : (t.layout = t.layout || "horizontal"); var l = ["x", "y"], u = "horizontal" === t.layout ? 0 : 1, h = (this._baseAxisDim = l[u]), c = l[1 - u], p = [r, o], d = p[u].get("type"), f = p[1 - u].get("type"), g = t.data; if (g && i) { var y = []; E(g, function (t, e) { var n; Y(t) ? ((n = t.slice()), t.unshift(e)) : Y(t.value) ? (((n = A({}, t)).value = n.value.slice()), t.value.unshift(e)) : (n = t), y.push(n); }), (t.data = y); } var v = this.defaultValueDimensions, m = [ { name: h, type: Ym(d), ordinalMeta: n, otherDims: { tooltip: !1, itemName: 0 }, dimsDef: ["base"], }, { name: c, type: Ym(f), dimsDef: v.slice() }, ]; return RM(this, { coordDimensions: m, dimensionsCount: v.length + 1, encodeDefaulter: H(td, m, this), }); }), (t.prototype.getBaseAxis = function () { var t = this._baseAxisDim; return this.ecModel.getComponent( t + "Axis", this.get(t + "AxisIndex") ).axis; }), t ); })(), dP = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.defaultValueDimensions = [ { name: "min", defaultTooltip: !0 }, { name: "Q1", defaultTooltip: !0 }, { name: "median", defaultTooltip: !0 }, { name: "Q3", defaultTooltip: !0 }, { name: "max", defaultTooltip: !0 }, ]), (n.visualDrawType = "stroke"), n ); } return ( n(e, t), (e.type = "series.boxplot"), (e.dependencies = ["xAxis", "yAxis", "grid"]), (e.defaultOption = { z: 2, coordinateSystem: "cartesian2d", legendHoverLink: !0, layout: null, boxWidth: [7, 50], itemStyle: { color: "#fff", borderWidth: 1 }, emphasis: { scale: !0, itemStyle: { borderWidth: 2, shadowBlur: 5, shadowOffsetX: 1, shadowOffsetY: 1, shadowColor: "rgba(0,0,0,0.2)", }, }, animationDuration: 800, }), e ); })(bg); R(dP, pP, !0); var fP = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = t.getData(), r = this.group, o = this._data; this._data || r.removeAll(); var a = "horizontal" === t.get("layout") ? 1 : 0; i .diff(o) .add(function (t) { if (i.hasValue(t)) { var e = vP(i.getItemLayout(t), i, t, a, !0); i.setItemGraphicEl(t, e), r.add(e); } }) .update(function (t, e) { var n = o.getItemGraphicEl(e); if (i.hasValue(t)) { var s = i.getItemLayout(t); n ? (Sh(n), mP(s, n, i, t)) : (n = vP(s, i, t, a)), r.add(n), i.setItemGraphicEl(t, n); } else r.remove(n); }) .remove(function (t) { var e = o.getItemGraphicEl(t); e && r.remove(e); }) .execute(), (this._data = i); }), (e.prototype.remove = function (t) { var e = this.group, n = this._data; (this._data = null), n && n.eachItemGraphicEl(function (t) { t && e.remove(t); }); }), (e.type = "boxplot"), e ); })(Og), gP = function () {}, yP = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "boxplotBoxPath"), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new gP(); }), (e.prototype.buildPath = function (t, e) { var n = e.points, i = 0; for (t.moveTo(n[i][0], n[i][1]), i++; i < 4; i++) t.lineTo(n[i][0], n[i][1]); for (t.closePath(); i < n.length; i++) t.moveTo(n[i][0], n[i][1]), i++, t.lineTo(n[i][0], n[i][1]); }), e ); })(ks); function vP(t, e, n, i, r) { var o = t.ends, a = new yP({ shape: { points: r ? xP(o, i, t) : o } }); return mP(t, a, e, n, r), a; } function mP(t, e, n, i, r) { var o = n.hostModel; (0, Qh[r ? "initProps" : "updateProps"])( e, { shape: { points: t.ends } }, o, i ), e.useStyle(n.getItemVisual(i, "style")), (e.style.strokeNoScale = !0), (e.z2 = 100); var a = n.getItemModel(i), s = a.getModel("emphasis"); $l(e, a), Zl(e, s.get("focus"), s.get("blurScope"), s.get("disabled")); } function xP(t, e, n) { return z(t, function (t) { return ((t = t.slice())[e] = n.initBaseline), t; }); } var _P = E; function bP(t) { var e = (function (t) { var e = [], n = []; return ( t.eachSeriesByType("boxplot", function (t) { var i = t.getBaseAxis(), r = P(n, i); r < 0 && ((r = n.length), (n[r] = i), (e[r] = { axis: i, seriesModels: [] })), e[r].seriesModels.push(t); }), e ); })(t); _P(e, function (t) { var e = t.seriesModels; e.length && (!(function (t) { var e, n = t.axis, i = t.seriesModels, r = i.length, o = (t.boxWidthList = []), a = (t.boxOffsetList = []), s = []; if ("category" === n.type) e = n.getBandWidth(); else { var l = 0; _P(i, function (t) { l = Math.max(l, t.getData().count()); }); var u = n.getExtent(); e = Math.abs(u[1] - u[0]) / l; } _P(i, function (t) { var n = t.get("boxWidth"); Y(n) || (n = [n, n]), s.push([$r(n[0], e) || 0, $r(n[1], e) || 0]); }); var h = 0.8 * e - 2, c = (h / r) * 0.3, p = (h - c * (r - 1)) / r, d = p / 2 - h / 2; _P(i, function (t, e) { a.push(d), (d += c + p), o.push(Math.min(Math.max(p, s[e][0]), s[e][1])); }); })(t), _P(e, function (e, n) { !(function (t, e, n) { var i = t.coordinateSystem, r = t.getData(), o = n / 2, a = "horizontal" === t.get("layout") ? 0 : 1, s = 1 - a, l = ["x", "y"], u = r.mapDimension(l[a]), h = r.mapDimensionsAll(l[s]); if (null == u || h.length < 5) return; for (var c = 0; c < r.count(); c++) { var p = r.get(u, c), d = x(p, h[2], c), f = x(p, h[0], c), g = x(p, h[1], c), y = x(p, h[3], c), v = x(p, h[4], c), m = []; _(m, g, !1), _(m, y, !0), m.push(f, g, v, y), b(m, f), b(m, v), b(m, d), r.setItemLayout(c, { initBaseline: d[s], ends: m, }); } function x(t, n, o) { var l, u = r.get(n, o), h = []; return ( (h[a] = t), (h[s] = u), isNaN(t) || isNaN(u) ? (l = [NaN, NaN]) : ((l = i.dataToPoint(h))[a] += e), l ); } function _(t, e, n) { var i = e.slice(), r = e.slice(); (i[a] += o), (r[a] -= o), n ? t.push(i, r) : t.push(r, i); } function b(t, e) { var n = e.slice(), i = e.slice(); (n[a] -= o), (i[a] += o), t.push(n, i); } })(e, t.boxOffsetList[n], t.boxWidthList[n]); })); }); } var wP = { type: "echarts:boxplot", transform: function (t) { var e = t.upstream; if (e.sourceFormat !== Hp) { var n = ""; 0, wo(n); } var i = (function (t, e) { for ( var n = [], i = [], r = (e = e || {}).boundIQR, o = "none" === r || 0 === r, a = 0; a < t.length; a++ ) { var s = Qr(t[a].slice()), l = fo(s, 0.25), u = fo(s, 0.5), h = fo(s, 0.75), c = s[0], p = s[s.length - 1], d = (null == r ? 1.5 : r) * (h - l), f = o ? c : Math.max(c, l - d), g = o ? p : Math.min(p, h + d), y = e.itemNameFormatter, v = X(y) ? y({ value: a }) : U(y) ? y.replace("{value}", a + "") : a + ""; n.push([v, f, l, u, h, g]); for (var m = 0; m < s.length; m++) { var x = s[m]; if (x < f || x > g) { var _ = [v, x]; i.push(_); } } } return { boxData: n, outliers: i }; })(e.getRawData(), t.config); return [ { dimensions: ["ItemName", "Low", "Q1", "Q2", "Q3", "High"], data: i.boxData, }, { data: i.outliers }, ]; }, }; var SP = ["itemStyle", "borderColor"], MP = ["itemStyle", "borderColor0"], IP = ["itemStyle", "borderColorDoji"], TP = ["itemStyle", "color"], CP = ["itemStyle", "color0"]; function DP(t, e) { return e.get(t > 0 ? TP : CP); } function AP(t, e) { return e.get(0 === t ? IP : t > 0 ? SP : MP); } var kP = { seriesType: "candlestick", plan: kg(), performRawSeries: !0, reset: function (t, e) { if (!e.isSeriesFiltered(t)) return ( !t.pipelineContext.large && { progress: function (t, e) { for (var n; null != (n = t.next()); ) { var i = e.getItemModel(n), r = e.getItemLayout(n).sign, o = i.getItemStyle(); (o.fill = DP(r, i)), (o.stroke = AP(r, i) || o.fill), A( e.ensureUniqueItemVisual( n, "style" ), o ); } }, } ); }, }, LP = ["color", "borderColor"], PP = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { this.group.removeClipPath(), (this._progressiveEls = null), this._updateDrawMode(t), this._isLargeDraw ? this._renderLarge(t) : this._renderNormal(t); }), (e.prototype.incrementalPrepareRender = function (t, e, n) { this._clear(), this._updateDrawMode(t); }), (e.prototype.incrementalRender = function (t, e, n, i) { (this._progressiveEls = []), this._isLargeDraw ? this._incrementalRenderLarge(t, e) : this._incrementalRenderNormal(t, e); }), (e.prototype.eachRendered = function (t) { Jh(this._progressiveEls || this.group, t); }), (e.prototype._updateDrawMode = function (t) { var e = t.pipelineContext.large; (null != this._isLargeDraw && e === this._isLargeDraw) || ((this._isLargeDraw = e), this._clear()); }), (e.prototype._renderNormal = function (t) { var e = t.getData(), n = this._data, i = this.group, r = e.getLayout("isSimpleBox"), o = t.get("clip", !0), a = t.coordinateSystem, s = a.getArea && a.getArea(); this._data || i.removeAll(), e .diff(n) .add(function (n) { if (e.hasValue(n)) { var a = e.getItemLayout(n); if (o && EP(s, a)) return; var l = NP(a, n, !0); mh(l, { shape: { points: a.ends } }, t, n), zP(l, e, n, r), i.add(l), e.setItemGraphicEl(n, l); } }) .update(function (a, l) { var u = n.getItemGraphicEl(l); if (e.hasValue(a)) { var h = e.getItemLayout(a); o && EP(s, h) ? i.remove(u) : (u ? (vh( u, { shape: { points: h.ends, }, }, t, a ), Sh(u)) : (u = NP(h)), zP(u, e, a, r), i.add(u), e.setItemGraphicEl(a, u)); } else i.remove(u); }) .remove(function (t) { var e = n.getItemGraphicEl(t); e && i.remove(e); }) .execute(), (this._data = e); }), (e.prototype._renderLarge = function (t) { this._clear(), GP(t, this.group); var e = t.get("clip", !0) ? PS(t.coordinateSystem, !1, t) : null; e ? this.group.setClipPath(e) : this.group.removeClipPath(); }), (e.prototype._incrementalRenderNormal = function (t, e) { for ( var n, i = e.getData(), r = i.getLayout("isSimpleBox"); null != (n = t.next()); ) { var o = NP(i.getItemLayout(n)); zP(o, i, n, r), (o.incremental = !0), this.group.add(o), this._progressiveEls.push(o); } }), (e.prototype._incrementalRenderLarge = function (t, e) { GP(e, this.group, this._progressiveEls, !0); }), (e.prototype.remove = function (t) { this._clear(); }), (e.prototype._clear = function () { this.group.removeAll(), (this._data = null); }), (e.type = "candlestick"), e ); })(Og), OP = function () {}, RP = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "normalCandlestickBox"), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new OP(); }), (e.prototype.buildPath = function (t, e) { var n = e.points; this.__simpleBox ? (t.moveTo(n[4][0], n[4][1]), t.lineTo(n[6][0], n[6][1])) : (t.moveTo(n[0][0], n[0][1]), t.lineTo(n[1][0], n[1][1]), t.lineTo(n[2][0], n[2][1]), t.lineTo(n[3][0], n[3][1]), t.closePath(), t.moveTo(n[4][0], n[4][1]), t.lineTo(n[5][0], n[5][1]), t.moveTo(n[6][0], n[6][1]), t.lineTo(n[7][0], n[7][1])); }), e ); })(ks); function NP(t, e, n) { var i = t.ends; return new RP({ shape: { points: n ? VP(i, t) : i }, z2: 100 }); } function EP(t, e) { for (var n = !0, i = 0; i < e.ends.length; i++) if (t.contain(e.ends[i][0], e.ends[i][1])) { n = !1; break; } return n; } function zP(t, e, n, i) { var r = e.getItemModel(n); t.useStyle(e.getItemVisual(n, "style")), (t.style.strokeNoScale = !0), (t.__simpleBox = i), $l(t, r); var o = e.getItemLayout(n).sign; E(t.states, function (t, e) { var n = r.getModel(e), i = DP(o, n), a = AP(o, n) || i, s = t.style || (t.style = {}); i && (s.fill = i), a && (s.stroke = a); }); var a = r.getModel("emphasis"); Zl(t, a.get("focus"), a.get("blurScope"), a.get("disabled")); } function VP(t, e) { return z(t, function (t) { return ((t = t.slice())[1] = e.initBaseline), t; }); } var BP = function () {}, FP = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n.type = "largeCandlestickBox"), n; } return ( n(e, t), (e.prototype.getDefaultShape = function () { return new BP(); }), (e.prototype.buildPath = function (t, e) { for (var n = e.points, i = 0; i < n.length; ) if (this.__sign === n[i++]) { var r = n[i++]; t.moveTo(r, n[i++]), t.lineTo(r, n[i++]); } else i += 3; }), e ); })(ks); function GP(t, e, n, i) { var r = t.getData().getLayout("largePoints"), o = new FP({ shape: { points: r }, __sign: 1, ignoreCoarsePointer: !0, }); e.add(o); var a = new FP({ shape: { points: r }, __sign: -1, ignoreCoarsePointer: !0, }); e.add(a); var s = new FP({ shape: { points: r }, __sign: 0, ignoreCoarsePointer: !0, }); e.add(s), WP(1, o, t), WP(-1, a, t), WP(0, s, t), i && ((o.incremental = !0), (a.incremental = !0)), n && n.push(o, a); } function WP(t, e, n, i) { var r = AP(t, n) || DP(t, n), o = n.getModel("itemStyle").getItemStyle(LP); e.useStyle(o), (e.style.fill = null), (e.style.stroke = r); } var HP = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.defaultValueDimensions = [ { name: "open", defaultTooltip: !0 }, { name: "close", defaultTooltip: !0 }, { name: "lowest", defaultTooltip: !0 }, { name: "highest", defaultTooltip: !0 }, ]), n ); } return ( n(e, t), (e.prototype.getShadowDim = function () { return "open"; }), (e.prototype.brushSelector = function (t, e, n) { var i = e.getItemLayout(t); return i && n.rect(i.brushRect); }), (e.type = "series.candlestick"), (e.dependencies = ["xAxis", "yAxis", "grid"]), (e.defaultOption = { z: 2, coordinateSystem: "cartesian2d", legendHoverLink: !0, layout: null, clip: !0, itemStyle: { color: "#eb5454", color0: "#47b262", borderColor: "#eb5454", borderColor0: "#47b262", borderColorDoji: null, borderWidth: 1, }, emphasis: { itemStyle: { borderWidth: 2 } }, barMaxWidth: null, barMinWidth: null, barWidth: null, large: !0, largeThreshold: 600, progressive: 3e3, progressiveThreshold: 1e4, progressiveChunkMode: "mod", animationEasing: "linear", animationDuration: 300, }), e ); })(bg); function YP(t) { t && Y(t.series) && E(t.series, function (t) { q(t) && "k" === t.type && (t.type = "candlestick"); }); } R(HP, pP, !0); var XP = { seriesType: "candlestick", plan: kg(), reset: function (t) { var e = t.coordinateSystem, n = t.getData(), i = (function (t, e) { var n, i = t.getBaseAxis(), r = "category" === i.type ? i.getBandWidth() : ((n = i.getExtent()), Math.abs(n[1] - n[0]) / e.count()), o = $r(rt(t.get("barMaxWidth"), r), r), a = $r(rt(t.get("barMinWidth"), 1), r), s = t.get("barWidth"); return null != s ? $r(s, r) : Math.max(Math.min(r / 2, o), a); })(t, n), r = ["x", "y"], o = n.getDimensionIndex(n.mapDimension(r[0])), a = z(n.mapDimensionsAll(r[1]), n.getDimensionIndex, n), s = a[0], l = a[1], u = a[2], h = a[3]; if ( (n.setLayout({ candleWidth: i, isSimpleBox: i <= 1.3 }), !(o < 0 || a.length < 4)) ) return { progress: t.pipelineContext.large ? function (n, i) { var r, a, c = Bx(4 * n.count), p = 0, d = [], f = [], g = i.getStore(), y = !!t.get(["itemStyle", "borderColorDoji"]); for (; null != (a = n.next()); ) { var v = g.get(o, a), m = g.get(s, a), x = g.get(l, a), _ = g.get(u, a), b = g.get(h, a); isNaN(v) || isNaN(_) || isNaN(b) ? ((c[p++] = NaN), (p += 3)) : ((c[p++] = UP(g, a, m, x, l, y)), (d[0] = v), (d[1] = _), (r = e.dataToPoint(d, null, f)), (c[p++] = r ? r[0] : NaN), (c[p++] = r ? r[1] : NaN), (d[1] = b), (r = e.dataToPoint(d, null, f)), (c[p++] = r ? r[1] : NaN)); } i.setLayout("largePoints", c); } : function (t, n) { var r, a = n.getStore(); for (; null != (r = t.next()); ) { var c = a.get(o, r), p = a.get(s, r), d = a.get(l, r), f = a.get(u, r), g = a.get(h, r), y = Math.min(p, d), v = Math.max(p, d), m = M(y, c), x = M(v, c), _ = M(f, c), b = M(g, c), w = []; I(w, x, 0), I(w, m, 1), w.push(C(b), C(x), C(_), C(m)); var S = !!n .getItemModel(r) .get(["itemStyle", "borderColorDoji"]); n.setItemLayout(r, { sign: UP(a, r, p, d, l, S), initBaseline: p > d ? x[1] : m[1], ends: w, brushRect: T(f, g, c), }); } function M(t, n) { var i = []; return ( (i[0] = n), (i[1] = t), isNaN(n) || isNaN(t) ? [NaN, NaN] : e.dataToPoint(i) ); } function I(t, e, n) { var r = e.slice(), o = e.slice(); (r[0] = Vh(r[0] + i / 2, 1, !1)), (o[0] = Vh(o[0] - i / 2, 1, !0)), n ? t.push(r, o) : t.push(o, r); } function T(t, e, n) { var r = M(t, n), o = M(e, n); return ( (r[0] -= i / 2), (o[0] -= i / 2), { x: r[0], y: r[1], width: i, height: o[1] - r[1], } ); } function C(t) { return (t[0] = Vh(t[0], 1)), t; } }, }; }, }; function UP(t, e, n, i, r, o) { return n > i ? -1 : n < i ? 1 : o ? 0 : e > 0 ? t.get(r, e - 1) <= i ? 1 : -1 : 1; } function ZP(t, e) { var n = e.rippleEffectColor || e.color; t.eachChild(function (t) { t.attr({ z: e.z, zlevel: e.zlevel, style: { stroke: "stroke" === e.brushType ? n : null, fill: "fill" === e.brushType ? n : null, }, }); }); } var jP = (function (t) { function e(e, n) { var i = t.call(this) || this, r = new fS(e, n), o = new Br(); return i.add(r), i.add(o), i.updateData(e, n), i; } return ( n(e, t), (e.prototype.stopEffectAnimation = function () { this.childAt(1).removeAll(); }), (e.prototype.startEffectAnimation = function (t) { for ( var e = t.symbolType, n = t.color, i = t.rippleNumber, r = this.childAt(1), o = 0; o < i; o++ ) { var a = Xy(e, -1, -1, 2, 2, n); a.attr({ style: { strokeNoScale: !0 }, z2: 99, silent: !0, scaleX: 0.5, scaleY: 0.5, }); var s = (-o / i) * t.period + t.effectOffset; a .animate("", !0) .when(t.period, { scaleX: t.rippleScale / 2, scaleY: t.rippleScale / 2, }) .delay(s) .start(), a .animateStyle(!0) .when(t.period, { opacity: 0 }) .delay(s) .start(), r.add(a); } ZP(r, t); }), (e.prototype.updateEffectAnimation = function (t) { for ( var e = this._effectCfg, n = this.childAt(1), i = [ "symbolType", "period", "rippleScale", "rippleNumber", ], r = 0; r < i.length; r++ ) { var o = i[r]; if (e[o] !== t[o]) return ( this.stopEffectAnimation(), void this.startEffectAnimation(t) ); } ZP(n, t); }), (e.prototype.highlight = function () { Ol(this); }), (e.prototype.downplay = function () { Rl(this); }), (e.prototype.getSymbolType = function () { var t = this.childAt(0); return t && t.getSymbolType(); }), (e.prototype.updateData = function (t, e) { var n = this, i = t.hostModel; this.childAt(0).updateData(t, e); var r = this.childAt(1), o = t.getItemModel(e), a = t.getItemVisual(e, "symbol"), s = Uy(t.getItemVisual(e, "symbolSize")), l = t.getItemVisual(e, "style"), u = l && l.fill, h = o.getModel("emphasis"); r.setScale(s), r.traverse(function (t) { t.setStyle("fill", u); }); var c = Zy(t.getItemVisual(e, "symbolOffset"), s); c && ((r.x = c[0]), (r.y = c[1])); var p = t.getItemVisual(e, "symbolRotate"); r.rotation = ((p || 0) * Math.PI) / 180 || 0; var d = {}; (d.showEffectOn = i.get("showEffectOn")), (d.rippleScale = o.get(["rippleEffect", "scale"])), (d.brushType = o.get(["rippleEffect", "brushType"])), (d.period = 1e3 * o.get(["rippleEffect", "period"])), (d.effectOffset = e / t.count()), (d.z = i.getShallow("z") || 0), (d.zlevel = i.getShallow("zlevel") || 0), (d.symbolType = a), (d.color = u), (d.rippleEffectColor = o.get([ "rippleEffect", "color", ])), (d.rippleNumber = o.get(["rippleEffect", "number"])), "render" === d.showEffectOn ? (this._effectCfg ? this.updateEffectAnimation(d) : this.startEffectAnimation(d), (this._effectCfg = d)) : ((this._effectCfg = null), this.stopEffectAnimation(), (this.onHoverStateChange = function (t) { "emphasis" === t ? "render" !== d.showEffectOn && n.startEffectAnimation(d) : "normal" === t && "render" !== d.showEffectOn && n.stopEffectAnimation(); })), (this._effectCfg = d), Zl( this, h.get("focus"), h.get("blurScope"), h.get("disabled") ); }), (e.prototype.fadeOut = function (t) { t && t(); }), e ); })(Br), qP = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function () { this._symbolDraw = new xS(jP); }), (e.prototype.render = function (t, e, n) { var i = t.getData(), r = this._symbolDraw; r.updateData(i, { clipShape: this._getClipShape(t) }), this.group.add(r.group); }), (e.prototype._getClipShape = function (t) { var e = t.coordinateSystem, n = e && e.getArea && e.getArea(); return t.get("clip", !0) ? n : null; }), (e.prototype.updateTransform = function (t, e, n) { var i = t.getData(); this.group.dirty(); var r = XS("").reset(t, e, n); r.progress && r.progress( { start: 0, end: i.count(), count: i.count() }, i ), this._symbolDraw.updateLayout(); }), (e.prototype._updateGroupTransform = function (t) { var e = t.coordinateSystem; e && e.getRoamTransform && ((this.group.transform = Te(e.getRoamTransform())), this.group.decomposeTransform()); }), (e.prototype.remove = function (t, e) { this._symbolDraw && this._symbolDraw.remove(!0); }), (e.type = "effectScatter"), e ); })(Og), KP = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.hasSymbolVisual = !0), n; } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { return _x(null, this, { useEncodeDefaulter: !0 }); }), (e.prototype.brushSelector = function (t, e, n) { return n.point(e.getItemLayout(t)); }), (e.type = "series.effectScatter"), (e.dependencies = ["grid", "polar"]), (e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, legendHoverLink: !0, effectType: "ripple", progressive: 0, showEffectOn: "render", clip: !0, rippleEffect: { period: 4, scale: 2.5, brushType: "fill", number: 3, }, universalTransition: { divideShape: "clone" }, symbolSize: 10, }), e ); })(bg); var $P = (function (t) { function e(e, n, i) { var r = t.call(this) || this; return ( r.add(r.createLine(e, n, i)), r._updateEffectSymbol(e, n), r ); } return ( n(e, t), (e.prototype.createLine = function (t, e, n) { return new HA(t, e, n); }), (e.prototype._updateEffectSymbol = function (t, e) { var n = t.getItemModel(e).getModel("effect"), i = n.get("symbolSize"), r = n.get("symbol"); Y(i) || (i = [i, i]); var o = t.getItemVisual(e, "style"), a = n.get("color") || (o && o.stroke), s = this.childAt(1); this._symbolType !== r && (this.remove(s), ((s = Xy(r, -0.5, -0.5, 1, 1, a)).z2 = 100), (s.culling = !0), this.add(s)), s && (s.setStyle("shadowColor", a), s.setStyle(n.getItemStyle(["color"])), (s.scaleX = i[0]), (s.scaleY = i[1]), s.setColor(a), (this._symbolType = r), (this._symbolScale = i), this._updateEffectAnimation(t, n, e)); }), (e.prototype._updateEffectAnimation = function (t, e, n) { var i = this.childAt(1); if (i) { var r = t.getItemLayout(n), o = 1e3 * e.get("period"), a = e.get("loop"), s = e.get("roundTrip"), l = e.get("constantSpeed"), u = it(e.get("delay"), function (e) { return ((e / t.count()) * o) / 3; }); if ( ((i.ignore = !0), this._updateAnimationPoints(i, r), l > 0 && (o = (this._getLineLength(i) / l) * 1e3), o !== this._period || a !== this._loop || s !== this._roundTrip) ) { i.stopAnimation(); var h = void 0; (h = X(u) ? u(n) : u), i.__t > 0 && (h = -o * i.__t), this._animateSymbol(i, o, h, a, s); } (this._period = o), (this._loop = a), (this._roundTrip = s); } }), (e.prototype._animateSymbol = function (t, e, n, i, r) { if (e > 0) { t.__t = 0; var o = this, a = t .animate("", i) .when(r ? 2 * e : e, { __t: r ? 2 : 1 }) .delay(n) .during(function () { o._updateSymbolPosition(t); }); i || a.done(function () { o.remove(t); }), a.start(); } }), (e.prototype._getLineLength = function (t) { return Vt(t.__p1, t.__cp1) + Vt(t.__cp1, t.__p2); }), (e.prototype._updateAnimationPoints = function (t, e) { (t.__p1 = e[0]), (t.__p2 = e[1]), (t.__cp1 = e[2] || [ (e[0][0] + e[1][0]) / 2, (e[0][1] + e[1][1]) / 2, ]); }), (e.prototype.updateData = function (t, e, n) { this.childAt(0).updateData(t, e, n), this._updateEffectSymbol(t, e); }), (e.prototype._updateSymbolPosition = function (t) { var e = t.__p1, n = t.__p2, i = t.__cp1, r = t.__t < 1 ? t.__t : 2 - t.__t, o = [t.x, t.y], a = o.slice(), s = In, l = Tn; (o[0] = s(e[0], i[0], n[0], r)), (o[1] = s(e[1], i[1], n[1], r)); var u = t.__t < 1 ? l(e[0], i[0], n[0], r) : l(n[0], i[0], e[0], 1 - r), h = t.__t < 1 ? l(e[1], i[1], n[1], r) : l(n[1], i[1], e[1], 1 - r); (t.rotation = -Math.atan2(h, u) - Math.PI / 2), ("line" !== this._symbolType && "rect" !== this._symbolType && "roundRect" !== this._symbolType) || (void 0 !== t.__lastT && t.__lastT < t.__t ? ((t.scaleY = 1.05 * Vt(a, o)), 1 === r && ((o[0] = a[0] + (o[0] - a[0]) / 2), (o[1] = a[1] + (o[1] - a[1]) / 2))) : 1 === t.__lastT ? (t.scaleY = 2 * Vt(e, o)) : (t.scaleY = this._symbolScale[1])), (t.__lastT = t.__t), (t.ignore = !1), (t.x = o[0]), (t.y = o[1]); }), (e.prototype.updateLayout = function (t, e) { this.childAt(0).updateLayout(t, e); var n = t.getItemModel(e).getModel("effect"); this._updateEffectAnimation(t, n, e); }), e ); })(Br), JP = (function (t) { function e(e, n, i) { var r = t.call(this) || this; return r._createPolyline(e, n, i), r; } return ( n(e, t), (e.prototype._createPolyline = function (t, e, n) { var i = t.getItemLayout(e), r = new Zu({ shape: { points: i } }); this.add(r), this._updateCommonStl(t, e, n); }), (e.prototype.updateData = function (t, e, n) { var i = t.hostModel; vh( this.childAt(0), { shape: { points: t.getItemLayout(e) } }, i, e ), this._updateCommonStl(t, e, n); }), (e.prototype._updateCommonStl = function (t, e, n) { var i = this.childAt(0), r = t.getItemModel(e), o = n && n.emphasisLineStyle, a = n && n.focus, s = n && n.blurScope, l = n && n.emphasisDisabled; if (!n || t.hasItemOption) { var u = r.getModel("emphasis"); (o = u.getModel("lineStyle").getLineStyle()), (l = u.get("disabled")), (a = u.get("focus")), (s = u.get("blurScope")); } i.useStyle(t.getItemVisual(e, "style")), (i.style.fill = null), (i.style.strokeNoScale = !0), (i.ensureState("emphasis").style = o), Zl(this, a, s, l); }), (e.prototype.updateLayout = function (t, e) { this.childAt(0).setShape("points", t.getItemLayout(e)); }), e ); })(Br), QP = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e._lastFrame = 0), (e._lastFramePercent = 0), e; } return ( n(e, t), (e.prototype.createLine = function (t, e, n) { return new JP(t, e, n); }), (e.prototype._updateAnimationPoints = function (t, e) { this._points = e; for (var n = [0], i = 0, r = 1; r < e.length; r++) { var o = e[r - 1], a = e[r]; (i += Vt(o, a)), n.push(i); } if (0 !== i) { for (r = 0; r < n.length; r++) n[r] /= i; (this._offsets = n), (this._length = i); } else this._length = 0; }), (e.prototype._getLineLength = function () { return this._length; }), (e.prototype._updateSymbolPosition = function (t) { var e = t.__t < 1 ? t.__t : 2 - t.__t, n = this._points, i = this._offsets, r = n.length; if (i) { var o, a = this._lastFrame; if (e < this._lastFramePercent) { for ( o = Math.min(a + 1, r - 1); o >= 0 && !(i[o] <= e); o-- ); o = Math.min(o, r - 2); } else { for (o = a; o < r && !(i[o] > e); o++); o = Math.min(o - 1, r - 2); } var s = (e - i[o]) / (i[o + 1] - i[o]), l = n[o], u = n[o + 1]; (t.x = l[0] * (1 - s) + s * u[0]), (t.y = l[1] * (1 - s) + s * u[1]); var h = t.__t < 1 ? u[0] - l[0] : l[0] - u[0], c = t.__t < 1 ? u[1] - l[1] : l[1] - u[1]; (t.rotation = -Math.atan2(c, h) - Math.PI / 2), (this._lastFrame = o), (this._lastFramePercent = e), (t.ignore = !1); } }), e ); })($P), tO = function () { (this.polyline = !1), (this.curveness = 0), (this.segs = []); }, eO = (function (t) { function e(e) { var n = t.call(this, e) || this; return (n._off = 0), (n.hoverDataIdx = -1), n; } return ( n(e, t), (e.prototype.reset = function () { (this.notClear = !1), (this._off = 0); }), (e.prototype.getDefaultStyle = function () { return { stroke: "#000", fill: null }; }), (e.prototype.getDefaultShape = function () { return new tO(); }), (e.prototype.buildPath = function (t, e) { var n, i = e.segs, r = e.curveness; if (e.polyline) for (n = this._off; n < i.length; ) { var o = i[n++]; if (o > 0) { t.moveTo(i[n++], i[n++]); for (var a = 1; a < o; a++) t.lineTo(i[n++], i[n++]); } } else for (n = this._off; n < i.length; ) { var s = i[n++], l = i[n++], u = i[n++], h = i[n++]; if ((t.moveTo(s, l), r > 0)) { var c = (s + u) / 2 - (l - h) * r, p = (l + h) / 2 - (u - s) * r; t.quadraticCurveTo(c, p, u, h); } else t.lineTo(u, h); } this.incremental && ((this._off = n), (this.notClear = !0)); }), (e.prototype.findDataIndex = function (t, e) { var n = this.shape, i = n.segs, r = n.curveness, o = this.style.lineWidth; if (n.polyline) for (var a = 0, s = 0; s < i.length; ) { var l = i[s++]; if (l > 0) for ( var u = i[s++], h = i[s++], c = 1; c < l; c++ ) { if ( cs( u, h, (p = i[s++]), (d = i[s++]), o, t, e ) ) return a; } a++; } else for (a = 0, s = 0; s < i.length; ) { (u = i[s++]), (h = i[s++]); var p = i[s++], d = i[s++]; if (r > 0) { if ( ds( u, h, (u + p) / 2 - (h - d) * r, (h + d) / 2 - (p - u) * r, p, d, o, t, e ) ) return a; } else if (cs(u, h, p, d, o, t, e)) return a; a++; } return -1; }), (e.prototype.contain = function (t, e) { var n = this.transformCoordToLocal(t, e), i = this.getBoundingRect(); return ( (t = n[0]), (e = n[1]), i.contain(t, e) ? (this.hoverDataIdx = this.findDataIndex(t, e)) >= 0 : ((this.hoverDataIdx = -1), !1) ); }), (e.prototype.getBoundingRect = function () { var t = this._rect; if (!t) { for ( var e = this.shape.segs, n = 1 / 0, i = 1 / 0, r = -1 / 0, o = -1 / 0, a = 0; a < e.length; ) { var s = e[a++], l = e[a++]; (n = Math.min(s, n)), (r = Math.max(s, r)), (i = Math.min(l, i)), (o = Math.max(l, o)); } t = this._rect = new ze(n, i, r, o); } return t; }), e ); })(ks), nO = (function () { function t() { this.group = new Br(); } return ( (t.prototype.updateData = function (t) { this._clear(); var e = this._create(); e.setShape({ segs: t.getLayout("linesPoints") }), this._setCommon(e, t); }), (t.prototype.incrementalPrepareUpdate = function (t) { this.group.removeAll(), this._clear(); }), (t.prototype.incrementalUpdate = function (t, e) { var n = this._newAdded[0], i = e.getLayout("linesPoints"), r = n && n.shape.segs; if (r && r.length < 2e4) { var o = r.length, a = new Float32Array(o + i.length); a.set(r), a.set(i, o), n.setShape({ segs: a }); } else { this._newAdded = []; var s = this._create(); (s.incremental = !0), s.setShape({ segs: i }), this._setCommon(s, e), (s.__startIndex = t.start); } }), (t.prototype.remove = function () { this._clear(); }), (t.prototype.eachRendered = function (t) { this._newAdded[0] && t(this._newAdded[0]); }), (t.prototype._create = function () { var t = new eO({ cursor: "default", ignoreCoarsePointer: !0, }); return this._newAdded.push(t), this.group.add(t), t; }), (t.prototype._setCommon = function (t, e, n) { var i = e.hostModel; t.setShape({ polyline: i.get("polyline"), curveness: i.get(["lineStyle", "curveness"]), }), t.useStyle(i.getModel("lineStyle").getLineStyle()), (t.style.strokeNoScale = !0); var r = e.getVisual("style"); r && r.stroke && t.setStyle("stroke", r.stroke), t.setStyle("fill", null); var o = rl(t); (o.seriesIndex = i.seriesIndex), t.on("mousemove", function (e) { o.dataIndex = null; var n = t.hoverDataIdx; n > 0 && (o.dataIndex = n + t.__startIndex); }); }), (t.prototype._clear = function () { (this._newAdded = []), this.group.removeAll(); }), t ); })(), iO = { seriesType: "lines", plan: kg(), reset: function (t) { var e = t.coordinateSystem; if (e) { var n = t.get("polyline"), i = t.pipelineContext.large; return { progress: function (r, o) { var a = []; if (i) { var s = void 0, l = r.end - r.start; if (n) { for (var u = 0, h = r.start; h < r.end; h++) u += t.getLineCoordsCount(h); s = new Float32Array(l + 2 * u); } else s = new Float32Array(4 * l); var c = 0, p = []; for (h = r.start; h < r.end; h++) { var d = t.getLineCoords(h, a); n && (s[c++] = d); for (var f = 0; f < d; f++) (p = e.dataToPoint(a[f], !1, p)), (s[c++] = p[0]), (s[c++] = p[1]); } o.setLayout("linesPoints", s); } else for (h = r.start; h < r.end; h++) { var g = o.getItemModel(h), y = ((d = t.getLineCoords(h, a)), []); if (n) for (var v = 0; v < d; v++) y.push(e.dataToPoint(a[v])); else { (y[0] = e.dataToPoint(a[0])), (y[1] = e.dataToPoint(a[1])); var m = g.get([ "lineStyle", "curveness", ]); +m && (y[2] = [ (y[0][0] + y[1][0]) / 2 - (y[0][1] - y[1][1]) * m, (y[0][1] + y[1][1]) / 2 - (y[1][0] - y[0][0]) * m, ]); } o.setItemLayout(h, y); } }, }; } }, }, rO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = t.getData(), r = this._updateLineDraw(i, t), o = t.get("zlevel"), a = t.get(["effect", "trailLength"]), s = n.getZr(), l = "svg" === s.painter.getType(); l || s.painter.getLayer(o).clear(!0), null == this._lastZlevel || l || s.configLayer(this._lastZlevel, { motionBlur: !1 }), this._showEffect(t) && a > 0 && (l || s.configLayer(o, { motionBlur: !0, lastFrameAlpha: Math.max( Math.min(a / 10 + 0.9, 1), 0 ), })), r.updateData(i); var u = t.get("clip", !0) && PS(t.coordinateSystem, !1, t); u ? this.group.setClipPath(u) : this.group.removeClipPath(), (this._lastZlevel = o), (this._finished = !0); }), (e.prototype.incrementalPrepareRender = function (t, e, n) { var i = t.getData(); this._updateLineDraw(i, t).incrementalPrepareUpdate(i), this._clearLayer(n), (this._finished = !1); }), (e.prototype.incrementalRender = function (t, e, n) { this._lineDraw.incrementalUpdate(t, e.getData()), (this._finished = t.end === e.getData().count()); }), (e.prototype.eachRendered = function (t) { this._lineDraw && this._lineDraw.eachRendered(t); }), (e.prototype.updateTransform = function (t, e, n) { var i = t.getData(), r = t.pipelineContext; if (!this._finished || r.large || r.progressiveRender) return { update: !0 }; var o = iO.reset(t, e, n); o.progress && o.progress( { start: 0, end: i.count(), count: i.count() }, i ), this._lineDraw.updateLayout(), this._clearLayer(n); }), (e.prototype._updateLineDraw = function (t, e) { var n = this._lineDraw, i = this._showEffect(e), r = !!e.get("polyline"), o = e.pipelineContext.large; return ( (n && i === this._hasEffet && r === this._isPolyline && o === this._isLargeDraw) || (n && n.remove(), (n = this._lineDraw = o ? new nO() : new YA(r ? (i ? QP : JP) : i ? $P : HA)), (this._hasEffet = i), (this._isPolyline = r), (this._isLargeDraw = o)), this.group.add(n.group), n ); }), (e.prototype._showEffect = function (t) { return !!t.get(["effect", "show"]); }), (e.prototype._clearLayer = function (t) { var e = t.getZr(); "svg" === e.painter.getType() || null == this._lastZlevel || e.painter.getLayer(this._lastZlevel).clear(!0); }), (e.prototype.remove = function (t, e) { this._lineDraw && this._lineDraw.remove(), (this._lineDraw = null), this._clearLayer(e); }), (e.prototype.dispose = function (t, e) { this.remove(t, e); }), (e.type = "lines"), e ); })(Og), oO = "undefined" == typeof Uint32Array ? Array : Uint32Array, aO = "undefined" == typeof Float64Array ? Array : Float64Array; function sO(t) { var e = t.data; e && e[0] && e[0][0] && e[0][0].coord && (t.data = z(e, function (t) { var e = { coords: [t[0].coord, t[1].coord] }; return ( t[0].name && (e.fromName = t[0].name), t[1].name && (e.toName = t[1].name), D([e, t[0], t[1]]) ); })); } var lO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.visualStyleAccessPath = "lineStyle"), (n.visualDrawType = "stroke"), n ); } return ( n(e, t), (e.prototype.init = function (e) { (e.data = e.data || []), sO(e); var n = this._processFlatCoordsArray(e.data); (this._flatCoords = n.flatCoords), (this._flatCoordsOffset = n.flatCoordsOffset), n.flatCoords && (e.data = new Float32Array(n.count)), t.prototype.init.apply(this, arguments); }), (e.prototype.mergeOption = function (e) { if ((sO(e), e.data)) { var n = this._processFlatCoordsArray(e.data); (this._flatCoords = n.flatCoords), (this._flatCoordsOffset = n.flatCoordsOffset), n.flatCoords && (e.data = new Float32Array(n.count)); } t.prototype.mergeOption.apply(this, arguments); }), (e.prototype.appendData = function (t) { var e = this._processFlatCoordsArray(t.data); e.flatCoords && (this._flatCoords ? ((this._flatCoords = vt( this._flatCoords, e.flatCoords )), (this._flatCoordsOffset = vt( this._flatCoordsOffset, e.flatCoordsOffset ))) : ((this._flatCoords = e.flatCoords), (this._flatCoordsOffset = e.flatCoordsOffset)), (t.data = new Float32Array(e.count))), this.getRawData().appendData(t.data); }), (e.prototype._getCoordsFromItemModel = function (t) { var e = this.getData().getItemModel(t), n = e.option instanceof Array ? e.option : e.getShallow("coords"); return n; }), (e.prototype.getLineCoordsCount = function (t) { return this._flatCoordsOffset ? this._flatCoordsOffset[2 * t + 1] : this._getCoordsFromItemModel(t).length; }), (e.prototype.getLineCoords = function (t, e) { if (this._flatCoordsOffset) { for ( var n = this._flatCoordsOffset[2 * t], i = this._flatCoordsOffset[2 * t + 1], r = 0; r < i; r++ ) (e[r] = e[r] || []), (e[r][0] = this._flatCoords[n + 2 * r]), (e[r][1] = this._flatCoords[n + 2 * r + 1]); return i; } var o = this._getCoordsFromItemModel(t); for (r = 0; r < o.length; r++) (e[r] = e[r] || []), (e[r][0] = o[r][0]), (e[r][1] = o[r][1]); return o.length; }), (e.prototype._processFlatCoordsArray = function (t) { var e = 0; if ( (this._flatCoords && (e = this._flatCoords.length), j(t[0])) ) { for ( var n = t.length, i = new oO(n), r = new aO(n), o = 0, a = 0, s = 0, l = 0; l < n; ) { s++; var u = t[l++]; (i[a++] = o + e), (i[a++] = u); for (var h = 0; h < u; h++) { var c = t[l++], p = t[l++]; (r[o++] = c), (r[o++] = p); } } return { flatCoordsOffset: new Uint32Array(i.buffer, 0, a), flatCoords: r, count: s, }; } return { flatCoordsOffset: null, flatCoords: null, count: t.length, }; }), (e.prototype.getInitialData = function (t, e) { var n = new cx(["value"], this); return ( (n.hasItemOption = !1), n.initData(t.data, [], function (t, e, i, r) { if (t instanceof Array) return NaN; n.hasItemOption = !0; var o = t.value; return null != o ? o instanceof Array ? o[r] : o : void 0; }), n ); }), (e.prototype.formatTooltip = function (t, e, n) { var i = this.getData().getItemModel(t), r = i.get("name"); if (r) return r; var o = i.get("fromName"), a = i.get("toName"), s = []; return ( null != o && s.push(o), null != a && s.push(a), og("nameValue", { name: s.join(" > ") }) ); }), (e.prototype.preventIncremental = function () { return !!this.get(["effect", "show"]); }), (e.prototype.getProgressive = function () { var t = this.option.progressive; return null == t ? this.option.large ? 1e4 : this.get("progressive") : t; }), (e.prototype.getProgressiveThreshold = function () { var t = this.option.progressiveThreshold; return null == t ? this.option.large ? 2e4 : this.get("progressiveThreshold") : t; }), (e.prototype.getZLevelKey = function () { var t = this.getModel("effect"), e = t.get("trailLength"); return this.getData().count() > this.getProgressiveThreshold() ? this.id : t.get("show") && e > 0 ? e + "" : ""; }), (e.type = "series.lines"), (e.dependencies = ["grid", "polar", "geo", "calendar"]), (e.defaultOption = { coordinateSystem: "geo", z: 2, legendHoverLink: !0, xAxisIndex: 0, yAxisIndex: 0, symbol: ["none", "none"], symbolSize: [10, 10], geoIndex: 0, effect: { show: !1, period: 4, constantSpeed: 0, symbol: "circle", symbolSize: 3, loop: !0, trailLength: 0.2, }, large: !1, largeThreshold: 2e3, polyline: !1, clip: !0, label: { show: !1, position: "end" }, lineStyle: { opacity: 0.5 }, }), e ); })(bg); function uO(t) { return t instanceof Array || (t = [t, t]), t; } var hO = { seriesType: "lines", reset: function (t) { var e = uO(t.get("symbol")), n = uO(t.get("symbolSize")), i = t.getData(); return ( i.setVisual("fromSymbol", e && e[0]), i.setVisual("toSymbol", e && e[1]), i.setVisual("fromSymbolSize", n && n[0]), i.setVisual("toSymbolSize", n && n[1]), { dataEach: i.hasItemOption ? function (t, e) { var n = t.getItemModel(e), i = uO(n.getShallow("symbol", !0)), r = uO(n.getShallow("symbolSize", !0)); i[0] && t.setItemVisual(e, "fromSymbol", i[0]), i[1] && t.setItemVisual(e, "toSymbol", i[1]), r[0] && t.setItemVisual( e, "fromSymbolSize", r[0] ), r[1] && t.setItemVisual(e, "toSymbolSize", r[1]); } : null, } ); }, }; var cO = (function () { function t() { (this.blurSize = 30), (this.pointSize = 20), (this.maxOpacity = 1), (this.minOpacity = 0), (this._gradientPixels = { inRange: null, outOfRange: null }); var t = h.createCanvas(); this.canvas = t; } return ( (t.prototype.update = function (t, e, n, i, r, o) { var a = this._getBrush(), s = this._getGradient(r, "inRange"), l = this._getGradient(r, "outOfRange"), u = this.pointSize + this.blurSize, h = this.canvas, c = h.getContext("2d"), p = t.length; (h.width = e), (h.height = n); for (var d = 0; d < p; ++d) { var f = t[d], g = f[0], y = f[1], v = i(f[2]); (c.globalAlpha = v), c.drawImage(a, g - u, y - u); } if (!h.width || !h.height) return h; for ( var m = c.getImageData(0, 0, h.width, h.height), x = m.data, _ = 0, b = x.length, w = this.minOpacity, S = this.maxOpacity - w; _ < b; ) { v = x[_ + 3] / 256; var M = 4 * Math.floor(255 * v); if (v > 0) { var I = o(v) ? s : l; v > 0 && (v = v * S + w), (x[_++] = I[M]), (x[_++] = I[M + 1]), (x[_++] = I[M + 2]), (x[_++] = I[M + 3] * v * 256); } else _ += 4; } return c.putImageData(m, 0, 0), h; }), (t.prototype._getBrush = function () { var t = this._brushCanvas || (this._brushCanvas = h.createCanvas()), e = this.pointSize + this.blurSize, n = 2 * e; (t.width = n), (t.height = n); var i = t.getContext("2d"); return ( i.clearRect(0, 0, n, n), (i.shadowOffsetX = n), (i.shadowBlur = this.blurSize), (i.shadowColor = "#000"), i.beginPath(), i.arc(-e, e, this.pointSize, 0, 2 * Math.PI, !0), i.closePath(), i.fill(), t ); }), (t.prototype._getGradient = function (t, e) { for ( var n = this._gradientPixels, i = n[e] || (n[e] = new Uint8ClampedArray(1024)), r = [0, 0, 0, 0], o = 0, a = 0; a < 256; a++ ) t[e](a / 255, !0, r), (i[o++] = r[0]), (i[o++] = r[1]), (i[o++] = r[2]), (i[o++] = r[3]); return i; }), t ); })(); function pO(t) { var e = t.dimensions; return "lng" === e[0] && "lat" === e[1]; } var dO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i; e.eachComponent("visualMap", function (e) { e.eachTargetSeries(function (n) { n === t && (i = e); }); }), (this._progressiveEls = null), this.group.removeAll(); var r = t.coordinateSystem; "cartesian2d" === r.type || "calendar" === r.type ? this._renderOnCartesianAndCalendar( t, n, 0, t.getData().count() ) : pO(r) && this._renderOnGeo(r, t, i, n); }), (e.prototype.incrementalPrepareRender = function (t, e, n) { this.group.removeAll(); }), (e.prototype.incrementalRender = function (t, e, n, i) { var r = e.coordinateSystem; r && (pO(r) ? this.render(e, n, i) : ((this._progressiveEls = []), this._renderOnCartesianAndCalendar( e, i, t.start, t.end, !0 ))); }), (e.prototype.eachRendered = function (t) { Jh(this._progressiveEls || this.group, t); }), (e.prototype._renderOnCartesianAndCalendar = function ( t, e, n, i, r ) { var o, a, s, l, u = t.coordinateSystem, h = OS(u, "cartesian2d"); if (h) { var c = u.getAxis("x"), p = u.getAxis("y"); 0, (o = c.getBandWidth() + 0.5), (a = p.getBandWidth() + 0.5), (s = c.scale.getExtent()), (l = p.scale.getExtent()); } for ( var d = this.group, f = t.getData(), g = t .getModel(["emphasis", "itemStyle"]) .getItemStyle(), y = t .getModel(["blur", "itemStyle"]) .getItemStyle(), v = t .getModel(["select", "itemStyle"]) .getItemStyle(), m = t.get(["itemStyle", "borderRadius"]), x = rc(t), _ = t.getModel("emphasis"), b = _.get("focus"), w = _.get("blurScope"), S = _.get("disabled"), M = h ? [ f.mapDimension("x"), f.mapDimension("y"), f.mapDimension("value"), ] : [ f.mapDimension("time"), f.mapDimension("value"), ], I = n; I < i; I++ ) { var T = void 0, C = f.getItemVisual(I, "style"); if (h) { var D = f.get(M[0], I), A = f.get(M[1], I); if ( isNaN(f.get(M[2], I)) || isNaN(D) || isNaN(A) || D < s[0] || D > s[1] || A < l[0] || A > l[1] ) continue; var k = u.dataToPoint([D, A]); T = new Ws({ shape: { x: k[0] - o / 2, y: k[1] - a / 2, width: o, height: a, }, style: C, }); } else { if (isNaN(f.get(M[1], I))) continue; T = new Ws({ z2: 1, shape: u.dataToRect([f.get(M[0], I)]) .contentShape, style: C, }); } if (f.hasItemOption) { var L = f.getItemModel(I), P = L.getModel("emphasis"); (g = P.getModel("itemStyle").getItemStyle()), (y = L.getModel([ "blur", "itemStyle", ]).getItemStyle()), (v = L.getModel([ "select", "itemStyle", ]).getItemStyle()), (m = L.get(["itemStyle", "borderRadius"])), (b = P.get("focus")), (w = P.get("blurScope")), (S = P.get("disabled")), (x = rc(L)); } T.shape.r = m; var O = t.getRawValue(I), R = "-"; O && null != O[2] && (R = O[2] + ""), ic(T, x, { labelFetcher: t, labelDataIndex: I, defaultOpacity: C.opacity, defaultText: R, }), (T.ensureState("emphasis").style = g), (T.ensureState("blur").style = y), (T.ensureState("select").style = v), Zl(T, b, w, S), (T.incremental = r), r && (T.states.emphasis.hoverLayer = !0), d.add(T), f.setItemGraphicEl(I, T), this._progressiveEls && this._progressiveEls.push(T); } }), (e.prototype._renderOnGeo = function (t, e, n, i) { var r = n.targetVisuals.inRange, o = n.targetVisuals.outOfRange, a = e.getData(), s = this._hmLayer || this._hmLayer || new cO(); (s.blurSize = e.get("blurSize")), (s.pointSize = e.get("pointSize")), (s.minOpacity = e.get("minOpacity")), (s.maxOpacity = e.get("maxOpacity")); var l = t.getViewRect().clone(), u = t.getRoamTransform(); l.applyTransform(u); var h = Math.max(l.x, 0), c = Math.max(l.y, 0), p = Math.min(l.width + l.x, i.getWidth()), d = Math.min(l.height + l.y, i.getHeight()), f = p - h, g = d - c, y = [ a.mapDimension("lng"), a.mapDimension("lat"), a.mapDimension("value"), ], v = a.mapArray(y, function (e, n, i) { var r = t.dataToPoint([e, n]); return (r[0] -= h), (r[1] -= c), r.push(i), r; }), m = n.getExtent(), x = "visualMap.continuous" === n.type ? (function (t, e) { var n = t[1] - t[0]; return ( (e = [ (e[0] - t[0]) / n, (e[1] - t[0]) / n, ]), function (t) { return t >= e[0] && t <= e[1]; } ); })(m, n.option.range) : (function (t, e, n) { var i = t[1] - t[0], r = (e = z(e, function (e) { return { interval: [ (e.interval[0] - t[0]) / i, (e.interval[1] - t[0]) / i, ], }; })).length, o = 0; return function (t) { var i; for (i = o; i < r; i++) if ( (a = e[i].interval)[0] <= t && t <= a[1] ) { o = i; break; } if (i === r) for (i = o - 1; i >= 0; i--) { var a; if ( (a = e[i].interval)[0] <= t && t <= a[1] ) { o = i; break; } } return i >= 0 && i < r && n[i]; }; })(m, n.getPieceList(), n.option.selected); s.update( v, f, g, r.color.getNormalizer(), { inRange: r.color.getColorMapper(), outOfRange: o.color.getColorMapper(), }, x ); var _ = new Ns({ style: { width: f, height: g, x: h, y: c, image: s.canvas, }, silent: !0, }); this.group.add(_); }), (e.type = "heatmap"), e ); })(Og), fO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { return _x(null, this, { generateCoord: "value" }); }), (e.prototype.preventIncremental = function () { var t = wd.get(this.get("coordinateSystem")); if (t && t.dimensions) return ( "lng" === t.dimensions[0] && "lat" === t.dimensions[1] ); }), (e.type = "series.heatmap"), (e.dependencies = ["grid", "geo", "calendar"]), (e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, geoIndex: 0, blurSize: 30, pointSize: 20, maxOpacity: 1, minOpacity: 0, select: { itemStyle: { borderColor: "#212121" } }, }), e ); })(bg); var gO = ["itemStyle", "borderWidth"], yO = [ { xy: "x", wh: "width", index: 0, posDesc: ["left", "right"] }, { xy: "y", wh: "height", index: 1, posDesc: ["top", "bottom"] }, ], vO = new Su(), mO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = this.group, r = t.getData(), o = this._data, a = t.coordinateSystem, s = a.getBaseAxis().isHorizontal(), l = a.master.getRect(), u = { ecSize: { width: n.getWidth(), height: n.getHeight(), }, seriesModel: t, coordSys: a, coordSysExtent: [ [l.x, l.x + l.width], [l.y, l.y + l.height], ], isHorizontal: s, valueDim: yO[+s], categoryDim: yO[1 - +s], }; r.diff(o) .add(function (t) { if (r.hasValue(t)) { var e = TO(r, t), n = xO(r, t, e, u), o = AO(r, u, n); r.setItemGraphicEl(t, o), i.add(o), RO(o, u, n); } }) .update(function (t, e) { var n = o.getItemGraphicEl(e); if (r.hasValue(t)) { var a = TO(r, t), s = xO(r, t, a, u), l = LO(r, s); n && l !== n.__pictorialShapeStr && (i.remove(n), r.setItemGraphicEl(t, null), (n = null)), n ? (function (t, e, n) { var i = n.animationModel, r = n.dataIndex, o = t.__pictorialBundle; vh( o, { x: n.bundlePosition[0], y: n.bundlePosition[1], }, i, r ), n.symbolRepeat ? wO(t, e, n, !0) : SO(t, e, n, !0); MO(t, n, !0), IO(t, e, n, !0); })(n, u, s) : (n = AO(r, u, s, !0)), r.setItemGraphicEl(t, n), (n.__pictorialSymbolMeta = s), i.add(n), RO(n, u, s); } else i.remove(n); }) .remove(function (t) { var e = o.getItemGraphicEl(t); e && kO( o, t, e.__pictorialSymbolMeta.animationModel, e ); }) .execute(); var h = t.get("clip", !0) ? PS(t.coordinateSystem, !1, t) : null; return ( h ? i.setClipPath(h) : i.removeClipPath(), (this._data = r), this.group ); }), (e.prototype.remove = function (t, e) { var n = this.group, i = this._data; t.get("animation") ? i && i.eachItemGraphicEl(function (e) { kO(i, rl(e).dataIndex, t, e); }) : n.removeAll(); }), (e.type = "pictorialBar"), e ); })(Og); function xO(t, e, n, i) { var r = t.getItemLayout(e), o = n.get("symbolRepeat"), a = n.get("symbolClip"), s = n.get("symbolPosition") || "start", l = ((n.get("symbolRotate") || 0) * Math.PI) / 180 || 0, u = n.get("symbolPatternSize") || 2, h = n.isAnimationEnabled(), c = { dataIndex: e, layout: r, itemModel: n, symbolType: t.getItemVisual(e, "symbol") || "circle", style: t.getItemVisual(e, "style"), symbolClip: a, symbolRepeat: o, symbolRepeatDirection: n.get("symbolRepeatDirection"), symbolPatternSize: u, rotation: l, animationModel: h ? n : null, hoverScale: h && n.get(["emphasis", "scale"]), z2: n.getShallow("z", !0) || 0, }; !(function (t, e, n, i, r) { var o, a = i.valueDim, s = t.get("symbolBoundingData"), l = i.coordSys.getOtherAxis(i.coordSys.getBaseAxis()), u = l.toGlobalCoord(l.dataToCoord(0)), h = 1 - +(n[a.wh] <= 0); if (Y(s)) { var c = [_O(l, s[0]) - u, _O(l, s[1]) - u]; c[1] < c[0] && c.reverse(), (o = c[h]); } else o = null != s ? _O(l, s) - u : e ? i.coordSysExtent[a.index][h] - u : n[a.wh]; (r.boundingLength = o), e && (r.repeatCutLength = n[a.wh]); var p = "x" === a.xy, d = l.inverse; r.pxSign = (p && !d) || (!p && d) ? (o >= 0 ? 1 : -1) : o > 0 ? 1 : -1; })(n, o, r, i, c), (function (t, e, n, i, r, o, a, s, l, u) { var h, c = l.valueDim, p = l.categoryDim, d = Math.abs(n[p.wh]), f = t.getItemVisual(e, "symbolSize"); h = Y(f) ? f.slice() : null == f ? ["100%", "100%"] : [f, f]; (h[p.index] = $r(h[p.index], d)), (h[c.index] = $r(h[c.index], i ? d : Math.abs(o))), (u.symbolSize = h); var g = (u.symbolScale = [h[0] / s, h[1] / s]); g[c.index] *= (l.isHorizontal ? -1 : 1) * a; })(t, e, r, o, 0, c.boundingLength, c.pxSign, u, i, c), (function (t, e, n, i, r) { var o = t.get(gO) || 0; o && (vO.attr({ scaleX: e[0], scaleY: e[1], rotation: n }), vO.updateTransform(), (o /= vO.getLineScale()), (o *= e[i.valueDim.index])); r.valueLineWidth = o || 0; })(n, c.symbolScale, l, i, c); var p = c.symbolSize, d = Zy(n.get("symbolOffset"), p); return ( (function (t, e, n, i, r, o, a, s, l, u, h, c) { var p = h.categoryDim, d = h.valueDim, f = c.pxSign, g = Math.max(e[d.index] + s, 0), y = g; if (i) { var v = Math.abs(l), m = it(t.get("symbolMargin"), "15%") + "", x = !1; m.lastIndexOf("!") === m.length - 1 && ((x = !0), (m = m.slice(0, m.length - 1))); var _ = $r(m, e[d.index]), b = Math.max(g + 2 * _, 0), w = x ? 0 : 2 * _, S = vo(i), M = S ? i : NO((v + w) / b); (b = g + 2 * (_ = (v - M * g) / 2 / (x ? M : Math.max(M - 1, 1)))), (w = x ? 0 : 2 * _), S || "fixed" === i || (M = u ? NO((Math.abs(u) + w) / b) : 0), (y = M * b - w), (c.repeatTimes = M), (c.symbolMargin = _); } var I = f * (y / 2), T = (c.pathPosition = []); (T[p.index] = n[p.wh] / 2), (T[d.index] = "start" === a ? I : "end" === a ? l - I : l / 2), o && ((T[0] += o[0]), (T[1] += o[1])); var C = (c.bundlePosition = []); (C[p.index] = n[p.xy]), (C[d.index] = n[d.xy]); var D = (c.barRectShape = A({}, n)); (D[d.wh] = f * Math.max(Math.abs(n[d.wh]), Math.abs(T[d.index] + I))), (D[p.wh] = n[p.wh]); var k = (c.clipShape = {}); (k[p.xy] = -n[p.xy]), (k[p.wh] = h.ecSize[p.wh]), (k[d.xy] = 0), (k[d.wh] = n[d.wh]); })( n, p, r, o, 0, d, s, c.valueLineWidth, c.boundingLength, c.repeatCutLength, i, c ), c ); } function _O(t, e) { return t.toGlobalCoord(t.dataToCoord(t.scale.parse(e))); } function bO(t) { var e = t.symbolPatternSize, n = Xy(t.symbolType, -e / 2, -e / 2, e, e); return ( n.attr({ culling: !0 }), "image" !== n.type && n.setStyle({ strokeNoScale: !0 }), n ); } function wO(t, e, n, i) { var r = t.__pictorialBundle, o = n.symbolSize, a = n.valueLineWidth, s = n.pathPosition, l = e.valueDim, u = n.repeatTimes || 0, h = 0, c = o[e.valueDim.index] + a + 2 * n.symbolMargin; for ( PO(t, function (t) { (t.__pictorialAnimationIndex = h), (t.__pictorialRepeatTimes = u), h < u ? OO(t, null, f(h), n, i) : OO( t, null, { scaleX: 0, scaleY: 0 }, n, i, function () { r.remove(t); } ), h++; }); h < u; h++ ) { var p = bO(n); (p.__pictorialAnimationIndex = h), (p.__pictorialRepeatTimes = u), r.add(p); var d = f(h); OO( p, { x: d.x, y: d.y, scaleX: 0, scaleY: 0 }, { scaleX: d.scaleX, scaleY: d.scaleY, rotation: d.rotation }, n, i ); } function f(t) { var e = s.slice(), i = n.pxSign, r = t; return ( ("start" === n.symbolRepeatDirection ? i > 0 : i < 0) && (r = u - 1 - t), (e[l.index] = c * (r - u / 2 + 0.5) + s[l.index]), { x: e[0], y: e[1], scaleX: n.symbolScale[0], scaleY: n.symbolScale[1], rotation: n.rotation, } ); } } function SO(t, e, n, i) { var r = t.__pictorialBundle, o = t.__pictorialMainPath; o ? OO( o, null, { x: n.pathPosition[0], y: n.pathPosition[1], scaleX: n.symbolScale[0], scaleY: n.symbolScale[1], rotation: n.rotation, }, n, i ) : ((o = t.__pictorialMainPath = bO(n)), r.add(o), OO( o, { x: n.pathPosition[0], y: n.pathPosition[1], scaleX: 0, scaleY: 0, rotation: n.rotation, }, { scaleX: n.symbolScale[0], scaleY: n.symbolScale[1] }, n, i )); } function MO(t, e, n) { var i = A({}, e.barRectShape), r = t.__pictorialBarRect; r ? OO(r, null, { shape: i }, e, n) : (((r = t.__pictorialBarRect = new Ws({ z2: 2, shape: i, silent: !0, style: { stroke: "transparent", fill: "transparent", lineWidth: 0, }, })).disableMorphing = !0), t.add(r)); } function IO(t, e, n, i) { if (n.symbolClip) { var r = t.__pictorialClipPath, o = A({}, n.clipShape), a = e.valueDim, s = n.animationModel, l = n.dataIndex; if (r) vh(r, { shape: o }, s, l); else { (o[a.wh] = 0), (r = new Ws({ shape: o })), t.__pictorialBundle.setClipPath(r), (t.__pictorialClipPath = r); var u = {}; (u[a.wh] = n.clipShape[a.wh]), Qh[i ? "updateProps" : "initProps"](r, { shape: u }, s, l); } } } function TO(t, e) { var n = t.getItemModel(e); return (n.getAnimationDelayParams = CO), (n.isAnimationEnabled = DO), n; } function CO(t) { return { index: t.__pictorialAnimationIndex, count: t.__pictorialRepeatTimes, }; } function DO() { return ( this.parentModel.isAnimationEnabled() && !!this.getShallow("animation") ); } function AO(t, e, n, i) { var r = new Br(), o = new Br(); return ( r.add(o), (r.__pictorialBundle = o), (o.x = n.bundlePosition[0]), (o.y = n.bundlePosition[1]), n.symbolRepeat ? wO(r, e, n) : SO(r, 0, n), MO(r, n, i), IO(r, e, n, i), (r.__pictorialShapeStr = LO(t, n)), (r.__pictorialSymbolMeta = n), r ); } function kO(t, e, n, i) { var r = i.__pictorialBarRect; r && r.removeTextContent(); var o = []; PO(i, function (t) { o.push(t); }), i.__pictorialMainPath && o.push(i.__pictorialMainPath), i.__pictorialClipPath && (n = null), E(o, function (t) { _h(t, { scaleX: 0, scaleY: 0 }, n, e, function () { i.parent && i.parent.remove(i); }); }), t.setItemGraphicEl(e, null); } function LO(t, e) { return [ t.getItemVisual(e.dataIndex, "symbol") || "none", !!e.symbolRepeat, !!e.symbolClip, ].join(":"); } function PO(t, e, n) { E(t.__pictorialBundle.children(), function (i) { i !== t.__pictorialBarRect && e.call(n, i); }); } function OO(t, e, n, i, r, o) { e && t.attr(e), i.symbolClip && !r ? n && t.attr(n) : n && Qh[r ? "updateProps" : "initProps"]( t, n, i.animationModel, i.dataIndex, o ); } function RO(t, e, n) { var i = n.dataIndex, r = n.itemModel, o = r.getModel("emphasis"), a = o.getModel("itemStyle").getItemStyle(), s = r.getModel(["blur", "itemStyle"]).getItemStyle(), l = r.getModel(["select", "itemStyle"]).getItemStyle(), u = r.getShallow("cursor"), h = o.get("focus"), c = o.get("blurScope"), p = o.get("scale"); PO(t, function (t) { if (t instanceof Ns) { var e = t.style; t.useStyle( A( { image: e.image, x: e.x, y: e.y, width: e.width, height: e.height, }, n.style ) ); } else t.useStyle(n.style); var i = t.ensureState("emphasis"); (i.style = a), p && ((i.scaleX = 1.1 * t.scaleX), (i.scaleY = 1.1 * t.scaleY)), (t.ensureState("blur").style = s), (t.ensureState("select").style = l), u && (t.cursor = u), (t.z2 = n.z2); }); var d = e.valueDim.posDesc[+(n.boundingLength > 0)], f = t.__pictorialBarRect; (f.ignoreClip = !0), ic(f, rc(r), { labelFetcher: e.seriesModel, labelDataIndex: i, defaultText: pS(e.seriesModel.getData(), i), inheritColor: n.style.fill, defaultOpacity: n.style.opacity, defaultOutsidePosition: d, }), Zl(t, h, c, o.get("disabled")); } function NO(t) { var e = Math.round(t); return Math.abs(t - e) < 1e-4 ? e : Math.ceil(t); } var EO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.hasSymbolVisual = !0), (n.defaultSymbol = "roundRect"), n ); } return ( n(e, t), (e.prototype.getInitialData = function (e) { return ( (e.stack = null), t.prototype.getInitialData.apply(this, arguments) ); }), (e.type = "series.pictorialBar"), (e.dependencies = ["grid"]), (e.defaultOption = kc(qS.defaultOption, { symbol: "circle", symbolSize: null, symbolRotate: null, symbolPosition: null, symbolOffset: null, symbolMargin: null, symbolRepeat: !1, symbolRepeatDirection: "end", symbolClip: !1, symbolBoundingData: null, symbolPatternSize: 400, barGap: "-100%", clip: !1, progressive: 0, emphasis: { scale: !1 }, select: { itemStyle: { borderColor: "#212121" } }, })), e ); })(qS); var zO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n._layers = []), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = t.getData(), r = this, o = this.group, a = t.getLayerSeries(), s = i.getLayout("layoutInfo"), l = s.rect, u = s.boundaryGap; function h(t) { return t.name; } (o.x = 0), (o.y = l.y + u[0]); var c = new Gm(this._layersSeries || [], a, h, h), p = []; function d(e, n, s) { var l = r._layers; if ("remove" !== e) { for ( var u, h, c = [], d = [], f = a[n].indices, g = 0; g < f.length; g++ ) { var y = i.getItemLayout(f[g]), v = y.x, m = y.y0, x = y.y; c.push(v, m), d.push(v, m + x), (u = i.getItemVisual(f[g], "style")); } var _ = i.getItemLayout(f[0]), b = t.getModel("label").get("margin"), w = t.getModel("emphasis"); if ("add" === e) { var S = (p[n] = new Br()); (h = new AS({ shape: { points: c, stackedOnPoints: d, smooth: 0.4, stackedOnSmooth: 0.4, smoothConstraint: !1, }, z2: 0, })), S.add(h), o.add(S), t.isAnimationEnabled() && h.setClipPath( (function (t, e, n) { var i = new Ws({ shape: { x: t.x - 10, y: t.y - 10, width: 0, height: t.height + 20, }, }); return ( mh( i, { shape: { x: t.x - 50, width: t.width + 100, height: t.height + 20, }, }, e, n ), i ); })(h.getBoundingRect(), t, function () { h.removeClipPath(); }) ); } else { S = l[s]; (h = S.childAt(0)), o.add(S), (p[n] = S), vh( h, { shape: { points: c, stackedOnPoints: d, }, }, t ), Sh(h); } ic( h, rc(t), { labelDataIndex: f[g - 1], defaultText: i.getName(f[g - 1]), inheritColor: u.fill, }, { normal: { verticalAlign: "middle" } } ), h.setTextConfig({ position: null, local: !0 }); var M = h.getTextContent(); M && ((M.x = _.x - b), (M.y = _.y0 + _.y / 2)), h.useStyle(u), i.setItemGraphicEl(n, h), $l(h, t), Zl( h, w.get("focus"), w.get("blurScope"), w.get("disabled") ); } else o.remove(l[n]); } c .add(W(d, this, "add")) .update(W(d, this, "update")) .remove(W(d, this, "remove")) .execute(), (this._layersSeries = a), (this._layers = p); }), (e.type = "themeRiver"), e ); })(Og); var VO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (e) { t.prototype.init.apply(this, arguments), (this.legendVisualProvider = new NM( W(this.getData, this), W(this.getRawData, this) )); }), (e.prototype.fixData = function (t) { var e = t.length, n = {}, i = Uo(t, function (t) { return ( n.hasOwnProperty(t[0] + "") || (n[t[0] + ""] = -1), t[2] ); }), r = []; i.buckets.each(function (t, e) { r.push({ name: e, dataList: t }); }); for (var o = r.length, a = 0; a < o; ++a) { for ( var s = r[a].name, l = 0; l < r[a].dataList.length; ++l ) { var u = r[a].dataList[l][0] + ""; n[u] = a; } for (var u in n) n.hasOwnProperty(u) && n[u] !== a && ((n[u] = a), (t[e] = [u, 0, s]), e++); } return t; }), (e.prototype.getInitialData = function (t, e) { for ( var n = this.getReferringComponents( "singleAxis", Wo ).models[0].get("type"), i = B(t.data, function (t) { return void 0 !== t[2]; }), r = this.fixData(i || []), o = [], a = (this.nameMap = yt()), s = 0, l = 0; l < r.length; ++l ) o.push(r[l][2]), a.get(r[l][2]) || (a.set(r[l][2], s), s++); var u = px(r, { coordDimensions: ["single"], dimensionsDefine: [ { name: "time", type: Ym(n) }, { name: "value", type: "float" }, { name: "name", type: "ordinal" }, ], encodeDefine: { single: 0, value: 1, itemName: 2 }, }).dimensions, h = new cx(u, this); return h.initData(r), h; }), (e.prototype.getLayerSeries = function () { for ( var t = this.getData(), e = t.count(), n = [], i = 0; i < e; ++i ) n[i] = i; var r = t.mapDimension("single"), o = Uo(n, function (e) { return t.get("name", e); }), a = []; return ( o.buckets.each(function (e, n) { e.sort(function (e, n) { return t.get(r, e) - t.get(r, n); }), a.push({ name: n, indices: e }); }), a ); }), (e.prototype.getAxisTooltipData = function (t, e, n) { Y(t) || (t = t ? [t] : []); for ( var i, r = this.getData(), o = this.getLayerSeries(), a = [], s = o.length, l = 0; l < s; ++l ) { for ( var u = Number.MAX_VALUE, h = -1, c = o[l].indices.length, p = 0; p < c; ++p ) { var d = r.get(t[0], o[l].indices[p]), f = Math.abs(d - e); f <= u && ((i = d), (u = f), (h = o[l].indices[p])); } a.push(h); } return { dataIndices: a, nestestValue: i }; }), (e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(); return og("nameValue", { name: i.getName(t), value: i.get(i.mapDimension("value"), t), }); }), (e.type = "series.themeRiver"), (e.dependencies = ["singleAxis"]), (e.defaultOption = { z: 2, colorBy: "data", coordinateSystem: "singleAxis", boundaryGap: ["10%", "10%"], singleAxisIndex: 0, animationEasing: "linear", label: { margin: 4, show: !0, position: "left", fontSize: 11 }, emphasis: { label: { show: !0 } }, }), e ); })(bg); function BO(t, e) { t.eachSeriesByType("themeRiver", function (t) { var e = t.getData(), n = t.coordinateSystem, i = {}, r = n.getRect(); i.rect = r; var o = t.get("boundaryGap"), a = n.getAxis(); ((i.boundaryGap = o), "horizontal" === a.orient) ? ((o[0] = $r(o[0], r.height)), (o[1] = $r(o[1], r.height)), FO(e, t, r.height - o[0] - o[1])) : ((o[0] = $r(o[0], r.width)), (o[1] = $r(o[1], r.width)), FO(e, t, r.width - o[0] - o[1])); e.setLayout("layoutInfo", i); }); } function FO(t, e, n) { if (t.count()) for ( var i, r = e.coordinateSystem, o = e.getLayerSeries(), a = t.mapDimension("single"), s = t.mapDimension("value"), l = z(o, function (e) { return z(e.indices, function (e) { var n = r.dataToPoint(t.get(a, e)); return (n[1] = t.get(s, e)), n; }); }), u = (function (t) { for ( var e = t.length, n = t[0].length, i = [], r = [], o = 0, a = 0; a < n; ++a ) { for (var s = 0, l = 0; l < e; ++l) s += t[l][a][1]; s > o && (o = s), i.push(s); } for (var u = 0; u < n; ++u) r[u] = (o - i[u]) / 2; o = 0; for (var h = 0; h < n; ++h) { var c = i[h] + r[h]; c > o && (o = c); } return { y0: r, max: o }; })(l), h = u.y0, c = n / u.max, p = o.length, d = o[0].indices.length, f = 0; f < d; ++f ) { (i = h[f] * c), t.setItemLayout(o[0].indices[f], { layerIndex: 0, x: l[0][f][0], y0: i, y: l[0][f][1] * c, }); for (var g = 1; g < p; ++g) (i += l[g - 1][f][1] * c), t.setItemLayout(o[g].indices[f], { layerIndex: g, x: l[g][f][0], y0: i, y: l[g][f][1] * c, }); } } var GO = (function (t) { function e(e, n, i, r) { var o = t.call(this) || this; (o.z2 = 2), (o.textConfig = { inside: !0 }), (rl(o).seriesIndex = n.seriesIndex); var a = new Xs({ z2: 4, silent: e.getModel().get(["label", "silent"]), }); return o.setTextContent(a), o.updateData(!0, e, n, i, r), o; } return ( n(e, t), (e.prototype.updateData = function (t, e, n, i, r) { (this.node = e), (e.piece = this), (n = n || this._seriesModel), (i = i || this._ecModel); var o = this; rl(o).dataIndex = e.dataIndex; var a = e.getModel(), s = a.getModel("emphasis"), l = e.getLayout(), u = A({}, l); u.label = null; var h = e.getVisual("style"); h.lineJoin = "bevel"; var c = e.getVisual("decal"); c && (h.decal = mv(c, r)); var p = eM(a.getModel("itemStyle"), u, !0); A(u, p), E(hl, function (t) { var e = o.ensureState(t), n = a.getModel([t, "itemStyle"]); e.style = n.getItemStyle(); var i = eM(n, u); i && (e.shape = i); }), t ? (o.setShape(u), (o.shape.r = l.r0), mh(o, { shape: { r: l.r } }, n, e.dataIndex)) : (vh(o, { shape: u }, n), Sh(o)), o.useStyle(h), this._updateLabel(n); var d = a.getShallow("cursor"); d && o.attr("cursor", d), (this._seriesModel = n || this._seriesModel), (this._ecModel = i || this._ecModel); var f = s.get("focus"); Zl( this, "relative" === f ? vt( e.getAncestorsIndices(), e.getDescendantIndices() ) : "ancestor" === f ? e.getAncestorsIndices() : "descendant" === f ? e.getDescendantIndices() : f, s.get("blurScope"), s.get("disabled") ); }), (e.prototype._updateLabel = function (t) { var e = this, n = this.node.getModel(), i = n.getModel("label"), r = this.node.getLayout(), o = r.endAngle - r.startAngle, a = (r.startAngle + r.endAngle) / 2, s = Math.cos(a), l = Math.sin(a), u = this, h = u.getTextContent(), c = this.node.dataIndex, p = (i.get("minAngle") / 180) * Math.PI, d = i.get("show") && !(null != p && Math.abs(o) < p); function f(t, e) { var n = t.get(e); return null == n ? i.get(e) : n; } (h.ignore = !d), E(cl, function (i) { var p = "normal" === i ? n.getModel("label") : n.getModel([i, "label"]), d = "normal" === i, g = d ? h : h.ensureState(i), y = t.getFormattedLabel(c, i); d && (y = y || e.node.name), (g.style = oc(p, {}, null, "normal" !== i, !0)), y && (g.style.text = y); var v = p.get("show"); null == v || d || (g.ignore = !v); var m, x = f(p, "position"), _ = d ? u : u.states[i], b = _.style.fill; _.textConfig = { outsideFill: "inherit" === p.get("color") ? b : null, inside: "outside" !== x, }; var w = f(p, "distance") || 0, S = f(p, "align"), M = f(p, "rotate"), I = 0.5 * Math.PI, T = 1.5 * Math.PI, C = gs( "tangential" === M ? Math.PI / 2 - a : a ), D = C > I && !so(C - I) && C < T; "outside" === x ? ((m = r.r + w), (S = D ? "right" : "left")) : S && "center" !== S ? "left" === S ? ((m = r.r0 + w), (S = D ? "right" : "left")) : "right" === S && ((m = r.r - w), (S = D ? "left" : "right")) : ((m = o === 2 * Math.PI && 0 === r.r0 ? 0 : (r.r + r.r0) / 2), (S = "center")), (g.style.align = S), (g.style.verticalAlign = f(p, "verticalAlign") || "middle"), (g.x = m * s + r.cx), (g.y = m * l + r.cy); var A = 0; "radial" === M ? (A = gs(-a) + (D ? Math.PI : 0)) : "tangential" === M ? (A = gs(Math.PI / 2 - a) + (D ? Math.PI : 0)) : j(M) && (A = (M * Math.PI) / 180), (g.rotation = gs(A)); }), h.dirtyStyle(); }), e ); })(Fu), WO = "sunburstRootToNode", HO = "sunburstHighlight"; var YO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { var r = this; (this.seriesModel = t), (this.api = n), (this.ecModel = e); var o = t.getData(), a = o.tree.root, s = t.getViewRoot(), l = this.group, u = t.get("renderLabelForZeroData"), h = []; s.eachNode(function (t) { h.push(t); }); var c = this._oldChildren || []; !(function (i, r) { if (0 === i.length && 0 === r.length) return; function s(t) { return t.getId(); } function h(s, h) { !(function (i, r) { u || !i || i.getValue() || (i = null); if (i !== a && r !== a) if (r && r.piece) i ? (r.piece.updateData( !1, i, t, e, n ), o.setItemGraphicEl( i.dataIndex, r.piece )) : (function (t) { if (!t) return; t.piece && (l.remove(t.piece), (t.piece = null)); })(r); else if (i) { var s = new GO(i, t, e, n); l.add(s), o.setItemGraphicEl(i.dataIndex, s); } })( null == s ? null : i[s], null == h ? null : r[h] ); } new Gm(r, i, s, s) .add(h) .update(h) .remove(H(h, null)) .execute(); })(h, c), (function (i, o) { o.depth > 0 ? (r.virtualPiece ? r.virtualPiece.updateData( !1, i, t, e, n ) : ((r.virtualPiece = new GO(i, t, e, n)), l.add(r.virtualPiece)), o.piece.off("click"), r.virtualPiece.on("click", function (t) { r._rootToNode(o.parentNode); })) : r.virtualPiece && (l.remove(r.virtualPiece), (r.virtualPiece = null)); })(a, s), this._initEvents(), (this._oldChildren = h); }), (e.prototype._initEvents = function () { var t = this; this.group.off("click"), this.group.on("click", function (e) { var n = !1; t.seriesModel.getViewRoot().eachNode(function (i) { if (!n && i.piece && i.piece === e.target) { var r = i.getModel().get("nodeClick"); if ("rootToNode" === r) t._rootToNode(i); else if ("link" === r) { var o = i.getModel(), a = o.get("link"); if (a) Mp( a, o.get("target", !0) || "_blank" ); } n = !0; } }); }); }), (e.prototype._rootToNode = function (t) { t !== this.seriesModel.getViewRoot() && this.api.dispatchAction({ type: WO, from: this.uid, seriesId: this.seriesModel.id, targetNode: t, }); }), (e.prototype.containPoint = function (t, e) { var n = e.getData().getItemLayout(0); if (n) { var i = t[0] - n.cx, r = t[1] - n.cy, o = Math.sqrt(i * i + r * r); return o <= n.r && o >= n.r0; } }), (e.type = "sunburst"), e ); })(Og), XO = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.ignoreStyleOnData = !0), n; } return ( n(e, t), (e.prototype.getInitialData = function (t, e) { var n = { name: t.name, children: t.data }; UO(n); var i = (this._levelModels = z( t.levels || [], function (t) { return new Cc(t, this, e); }, this )), r = nD.createTree(n, this, function (t) { t.wrapMethod("getItemModel", function (t, e) { var n = r.getNodeByDataIndex(e), o = i[n.depth]; return o && (t.parentModel = o), t; }); }); return r.data; }), (e.prototype.optionUpdated = function () { this.resetViewRoot(); }), (e.prototype.getDataParams = function (e) { var n = t.prototype.getDataParams.apply(this, arguments), i = this.getData().tree.getNodeByDataIndex(e); return (n.treePathInfo = aD(i, this)), n; }), (e.prototype.getLevelModel = function (t) { return this._levelModels && this._levelModels[t.depth]; }), (e.prototype.getViewRoot = function () { return this._viewRoot; }), (e.prototype.resetViewRoot = function (t) { t ? (this._viewRoot = t) : (t = this._viewRoot); var e = this.getRawData().tree.root; (t && (t === e || e.contains(t))) || (this._viewRoot = e); }), (e.prototype.enableAriaDecal = function () { pD(this); }), (e.type = "series.sunburst"), (e.defaultOption = { z: 2, center: ["50%", "50%"], radius: [0, "75%"], clockwise: !0, startAngle: 90, minAngle: 0, stillShowZeroSum: !0, nodeClick: "rootToNode", renderLabelForZeroData: !1, label: { rotate: "radial", show: !0, opacity: 1, align: "center", position: "inside", distance: 5, silent: !0, }, itemStyle: { borderWidth: 1, borderColor: "white", borderType: "solid", shadowBlur: 0, shadowColor: "rgba(0, 0, 0, 0.2)", shadowOffsetX: 0, shadowOffsetY: 0, opacity: 1, }, emphasis: { focus: "descendant" }, blur: { itemStyle: { opacity: 0.2 }, label: { opacity: 0.1 }, }, animationType: "expansion", animationDuration: 1e3, animationDurationUpdate: 500, data: [], sort: "desc", }), e ); })(bg); function UO(t) { var e = 0; E(t.children, function (t) { UO(t); var n = t.value; Y(n) && (n = n[0]), (e += n); }); var n = t.value; Y(n) && (n = n[0]), (null == n || isNaN(n)) && (n = e), n < 0 && (n = 0), Y(t.value) ? (t.value[0] = n) : (t.value = n); } var ZO = Math.PI / 180; function jO(t, e, n) { e.eachSeriesByType(t, function (t) { var e = t.get("center"), i = t.get("radius"); Y(i) || (i = [0, i]), Y(e) || (e = [e, e]); var r = n.getWidth(), o = n.getHeight(), a = Math.min(r, o), s = $r(e[0], r), l = $r(e[1], o), u = $r(i[0], a / 2), h = $r(i[1], a / 2), c = -t.get("startAngle") * ZO, p = t.get("minAngle") * ZO, d = t.getData().tree.root, f = t.getViewRoot(), g = f.depth, y = t.get("sort"); null != y && qO(f, y); var v = 0; E(f.children, function (t) { !isNaN(t.getValue()) && v++; }); var m = f.getValue(), x = (Math.PI / (m || v)) * 2, _ = f.depth > 0, b = f.height - (_ ? -1 : 1), w = (h - u) / (b || 1), S = t.get("clockwise"), M = t.get("stillShowZeroSum"), I = S ? 1 : -1, T = function (e, n) { if (e) { var i = n; if (e !== d) { var r = e.getValue(), o = 0 === m && M ? x : r * x; o < p && (o = p), (i = n + I * o); var h = e.depth - g - (_ ? -1 : 1), c = u + w * h, f = u + w * (h + 1), y = t.getLevelModel(e); if (y) { var v = y.get("r0", !0), b = y.get("r", !0), C = y.get("radius", !0); null != C && ((v = C[0]), (b = C[1])), null != v && (c = $r(v, a / 2)), null != b && (f = $r(b, a / 2)); } e.setLayout({ angle: o, startAngle: n, endAngle: i, clockwise: S, cx: s, cy: l, r0: c, r: f, }); } if (e.children && e.children.length) { var D = 0; E(e.children, function (t) { D += T(t, n + D); }); } return i - n; } }; if (_) { var C = u, D = u + w, A = 2 * Math.PI; d.setLayout({ angle: A, startAngle: c, endAngle: c + A, clockwise: S, cx: s, cy: l, r0: C, r: D, }); } T(f, c); }); } function qO(t, e) { var n = t.children || []; (t.children = (function (t, e) { if (X(e)) { var n = z(t, function (t, e) { var n = t.getValue(); return { params: { depth: t.depth, height: t.height, dataIndex: t.dataIndex, getValue: function () { return n; }, }, index: e, }; }); return ( n.sort(function (t, n) { return e(t.params, n.params); }), z(n, function (e) { return t[e.index]; }) ); } var i = "asc" === e; return t.sort(function (t, e) { var n = (t.getValue() - e.getValue()) * (i ? 1 : -1); return 0 === n ? (t.dataIndex - e.dataIndex) * (i ? -1 : 1) : n; }); })(n, e)), n.length && E(t.children, function (t) { qO(t, e); }); } function KO(t) { var e = {}; t.eachSeriesByType("sunburst", function (t) { var n = t.getData(), i = n.tree; i.eachNode(function (r) { var o = r.getModel().getModel("itemStyle").getItemStyle(); o.fill || (o.fill = (function (t, n, i) { for (var r = t; r && r.depth > 1; ) r = r.parentNode; var o = n.getColorFromPalette( r.name || r.dataIndex + "", e ); return ( t.depth > 1 && U(o) && (o = $n(o, ((t.depth - 1) / (i - 1)) * 0.5)), o ); })(r, t, i.root.height)), A(n.ensureUniqueItemVisual(r.dataIndex, "style"), o); }); }); } var $O = { color: "fill", borderColor: "stroke" }, JO = { symbol: 1, symbolSize: 1, symbolKeepAspect: 1, legendIcon: 1, visualMeta: 1, liftZ: 1, decal: 1, }, QO = Vo(), tR = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.optionUpdated = function () { (this.currentZLevel = this.get("zlevel", !0)), (this.currentZ = this.get("z", !0)); }), (e.prototype.getInitialData = function (t, e) { return _x(null, this); }), (e.prototype.getDataParams = function (e, n, i) { var r = t.prototype.getDataParams.call(this, e, n); return i && (r.info = QO(i).info), r; }), (e.type = "series.custom"), (e.dependencies = [ "grid", "polar", "geo", "singleAxis", "calendar", ]), (e.defaultOption = { coordinateSystem: "cartesian2d", z: 2, legendHoverLink: !0, clip: !1, }), e ); })(bg); function eR(t, e) { return ( (e = e || [0, 0]), z( ["x", "y"], function (n, i) { var r = this.getAxis(n), o = e[i], a = t[i] / 2; return "category" === r.type ? r.getBandWidth() : Math.abs(r.dataToCoord(o - a) - r.dataToCoord(o + a)); }, this ) ); } function nR(t, e) { return ( (e = e || [0, 0]), z( [0, 1], function (n) { var i = e[n], r = t[n] / 2, o = [], a = []; return ( (o[n] = i - r), (a[n] = i + r), (o[1 - n] = a[1 - n] = e[1 - n]), Math.abs( this.dataToPoint(o)[n] - this.dataToPoint(a)[n] ) ); }, this ) ); } function iR(t, e) { var n = this.getAxis(), i = e instanceof Array ? e[0] : e, r = (t instanceof Array ? t[0] : t) / 2; return "category" === n.type ? n.getBandWidth() : Math.abs(n.dataToCoord(i - r) - n.dataToCoord(i + r)); } function rR(t, e) { return ( (e = e || [0, 0]), z( ["Radius", "Angle"], function (n, i) { var r = this["get" + n + "Axis"](), o = e[i], a = t[i] / 2, s = "category" === r.type ? r.getBandWidth() : Math.abs( r.dataToCoord(o - a) - r.dataToCoord(o + a) ); return "Angle" === n && (s = (s * Math.PI) / 180), s; }, this ) ); } function oR(t, e, n, i) { return ( t && (t.legacy || (!1 !== t.legacy && !n && !i && "tspan" !== e && ("text" === e || _t(t, "text")))) ); } function aR(t, e, n) { var i, r, o, a = t; if ("text" === e) o = a; else { (o = {}), _t(a, "text") && (o.text = a.text), _t(a, "rich") && (o.rich = a.rich), _t(a, "textFill") && (o.fill = a.textFill), _t(a, "textStroke") && (o.stroke = a.textStroke), _t(a, "fontFamily") && (o.fontFamily = a.fontFamily), _t(a, "fontSize") && (o.fontSize = a.fontSize), _t(a, "fontStyle") && (o.fontStyle = a.fontStyle), _t(a, "fontWeight") && (o.fontWeight = a.fontWeight), (r = { type: "text", style: o, silent: !0 }), (i = {}); var s = _t(a, "textPosition"); n ? (i.position = s ? a.textPosition : "inside") : s && (i.position = a.textPosition), _t(a, "textPosition") && (i.position = a.textPosition), _t(a, "textOffset") && (i.offset = a.textOffset), _t(a, "textRotation") && (i.rotation = a.textRotation), _t(a, "textDistance") && (i.distance = a.textDistance); } return ( sR(o, t), E(o.rich, function (t) { sR(t, t); }), { textConfig: i, textContent: r } ); } function sR(t, e) { e && ((e.font = e.textFont || e.font), _t(e, "textStrokeWidth") && (t.lineWidth = e.textStrokeWidth), _t(e, "textAlign") && (t.align = e.textAlign), _t(e, "textVerticalAlign") && (t.verticalAlign = e.textVerticalAlign), _t(e, "textLineHeight") && (t.lineHeight = e.textLineHeight), _t(e, "textWidth") && (t.width = e.textWidth), _t(e, "textHeight") && (t.height = e.textHeight), _t(e, "textBackgroundColor") && (t.backgroundColor = e.textBackgroundColor), _t(e, "textPadding") && (t.padding = e.textPadding), _t(e, "textBorderColor") && (t.borderColor = e.textBorderColor), _t(e, "textBorderWidth") && (t.borderWidth = e.textBorderWidth), _t(e, "textBorderRadius") && (t.borderRadius = e.textBorderRadius), _t(e, "textBoxShadowColor") && (t.shadowColor = e.textBoxShadowColor), _t(e, "textBoxShadowBlur") && (t.shadowBlur = e.textBoxShadowBlur), _t(e, "textBoxShadowOffsetX") && (t.shadowOffsetX = e.textBoxShadowOffsetX), _t(e, "textBoxShadowOffsetY") && (t.shadowOffsetY = e.textBoxShadowOffsetY)); } function lR(t, e, n) { var i = t; (i.textPosition = i.textPosition || n.position || "inside"), null != n.offset && (i.textOffset = n.offset), null != n.rotation && (i.textRotation = n.rotation), null != n.distance && (i.textDistance = n.distance); var r = i.textPosition.indexOf("inside") >= 0, o = t.fill || "#000"; uR(i, e); var a = null == i.textFill; return ( r ? a && ((i.textFill = n.insideFill || "#fff"), !i.textStroke && n.insideStroke && (i.textStroke = n.insideStroke), !i.textStroke && (i.textStroke = o), null == i.textStrokeWidth && (i.textStrokeWidth = 2)) : (a && (i.textFill = t.fill || n.outsideFill || "#000"), !i.textStroke && n.outsideStroke && (i.textStroke = n.outsideStroke)), (i.text = e.text), (i.rich = e.rich), E(e.rich, function (t) { uR(t, t); }), i ); } function uR(t, e) { e && (_t(e, "fill") && (t.textFill = e.fill), _t(e, "stroke") && (t.textStroke = e.fill), _t(e, "lineWidth") && (t.textStrokeWidth = e.lineWidth), _t(e, "font") && (t.font = e.font), _t(e, "fontStyle") && (t.fontStyle = e.fontStyle), _t(e, "fontWeight") && (t.fontWeight = e.fontWeight), _t(e, "fontSize") && (t.fontSize = e.fontSize), _t(e, "fontFamily") && (t.fontFamily = e.fontFamily), _t(e, "align") && (t.textAlign = e.align), _t(e, "verticalAlign") && (t.textVerticalAlign = e.verticalAlign), _t(e, "lineHeight") && (t.textLineHeight = e.lineHeight), _t(e, "width") && (t.textWidth = e.width), _t(e, "height") && (t.textHeight = e.height), _t(e, "backgroundColor") && (t.textBackgroundColor = e.backgroundColor), _t(e, "padding") && (t.textPadding = e.padding), _t(e, "borderColor") && (t.textBorderColor = e.borderColor), _t(e, "borderWidth") && (t.textBorderWidth = e.borderWidth), _t(e, "borderRadius") && (t.textBorderRadius = e.borderRadius), _t(e, "shadowColor") && (t.textBoxShadowColor = e.shadowColor), _t(e, "shadowBlur") && (t.textBoxShadowBlur = e.shadowBlur), _t(e, "shadowOffsetX") && (t.textBoxShadowOffsetX = e.shadowOffsetX), _t(e, "shadowOffsetY") && (t.textBoxShadowOffsetY = e.shadowOffsetY), _t(e, "textShadowColor") && (t.textShadowColor = e.textShadowColor), _t(e, "textShadowBlur") && (t.textShadowBlur = e.textShadowBlur), _t(e, "textShadowOffsetX") && (t.textShadowOffsetX = e.textShadowOffsetX), _t(e, "textShadowOffsetY") && (t.textShadowOffsetY = e.textShadowOffsetY)); } var hR = { position: ["x", "y"], scale: ["scaleX", "scaleY"], origin: ["originX", "originY"], }, cR = G(hR), pR = (V( mr, function (t, e) { return (t[e] = 1), t; }, {} ), mr.join(", "), ["", "style", "shape", "extra"]), dR = Vo(); function fR(t, e, n, i, r) { var o = t + "Animation", a = gh(t, i, r) || {}, s = dR(e).userDuring; return ( a.duration > 0 && ((a.during = s ? W(bR, { el: e, userDuring: s }) : null), (a.setToFinal = !0), (a.scope = t)), A(a, n[o]), a ); } function gR(t, e, n, i) { var r = (i = i || {}).dataIndex, o = i.isInit, a = i.clearStyle, s = n.isAnimationEnabled(), l = dR(t), u = e.style; l.userDuring = e.during; var h = {}, c = {}; if ( ((function (t, e, n) { for (var i = 0; i < cR.length; i++) { var r = cR[i], o = hR[r], a = e[r]; a && ((n[o[0]] = a[0]), (n[o[1]] = a[1])); } for (i = 0; i < mr.length; i++) { var s = mr[i]; null != e[s] && (n[s] = e[s]); } })(0, e, c), SR("shape", e, c), SR("extra", e, c), !o && s && ((function (t, e, n) { for ( var i = e.transition, r = mR(i) ? mr : To(i || []), o = 0; o < r.length; o++ ) { var a = r[o]; if ("style" !== a && "shape" !== a && "extra" !== a) { var s = t[a]; 0, (n[a] = s); } } })(t, e, h), wR("shape", t, e, h), wR("extra", t, e, h), (function (t, e, n, i) { if (!n) return; var r, o = t.style; if (o) { var a = n.transition, s = e.transition; if (a && !mR(a)) { var l = To(a); !r && (r = i.style = {}); for (var u = 0; u < l.length; u++) { var h = o[(f = l[u])]; r[f] = h; } } else if ( t.getAnimationStyleProps && (mR(s) || mR(a) || P(s, "style") >= 0) ) { var c = t.getAnimationStyleProps(), p = c ? c.style : null; if (p) { !r && (r = i.style = {}); var d = G(n); for (u = 0; u < d.length; u++) { var f; if (p[(f = d[u])]) { h = o[f]; r[f] = h; } } } } } })(t, e, u, h)), (c.style = u), (function (t, e, n) { var i = e.style; if (!t.isGroup && i) { if (n) { t.useStyle({}); for (var r = t.animators, o = 0; o < r.length; o++) { var a = r[o]; "style" === a.targetName && a.changeTarget(t.style); } } t.setStyle(i); } e && ((e.style = null), e && t.attr(e), (e.style = i)); })(t, c, a), (function (t, e) { _t(e, "silent") && (t.silent = e.silent), _t(e, "ignore") && (t.ignore = e.ignore), t instanceof Da && _t(e, "invisible") && (t.invisible = e.invisible); t instanceof ks && _t(e, "autoBatch") && (t.autoBatch = e.autoBatch); })(t, e), s) ) if (o) { var p = {}; E(pR, function (t) { var n = t ? e[t] : e; n && n.enterFrom && (t && (p[t] = p[t] || {}), A(t ? p[t] : p, n.enterFrom)); }); var d = fR("enter", t, e, n, r); d.duration > 0 && t.animateFrom(p, d); } else !(function (t, e, n, i, r) { if (r) { var o = fR("update", t, e, i, n); o.duration > 0 && t.animateFrom(r, o); } })(t, e, r || 0, n, h); yR(t, e), u ? t.dirty() : t.markRedraw(); } function yR(t, e) { for (var n = dR(t).leaveToProps, i = 0; i < pR.length; i++) { var r = pR[i], o = r ? e[r] : e; o && o.leaveTo && (n || (n = dR(t).leaveToProps = {}), r && (n[r] = n[r] || {}), A(r ? n[r] : n, o.leaveTo)); } } function vR(t, e, n, i) { if (t) { var r = t.parent, o = dR(t).leaveToProps; if (o) { var a = fR("update", t, e, n, 0); (a.done = function () { r.remove(t), i && i(); }), t.animateTo(o, a); } else r.remove(t), i && i(); } } function mR(t) { return "all" === t; } var xR = {}, _R = { setTransform: function (t, e) { return (xR.el[t] = e), this; }, getTransform: function (t) { return xR.el[t]; }, setShape: function (t, e) { var n = xR.el; return ( ((n.shape || (n.shape = {}))[t] = e), n.dirtyShape && n.dirtyShape(), this ); }, getShape: function (t) { var e = xR.el.shape; if (e) return e[t]; }, setStyle: function (t, e) { var n = xR.el, i = n.style; return i && ((i[t] = e), n.dirtyStyle && n.dirtyStyle()), this; }, getStyle: function (t) { var e = xR.el.style; if (e) return e[t]; }, setExtra: function (t, e) { return ((xR.el.extra || (xR.el.extra = {}))[t] = e), this; }, getExtra: function (t) { var e = xR.el.extra; if (e) return e[t]; }, }; function bR() { var t = this, e = t.el; if (e) { var n = dR(e).userDuring, i = t.userDuring; n === i ? ((xR.el = e), i(_R)) : (t.el = t.userDuring = null); } } function wR(t, e, n, i) { var r = n[t]; if (r) { var o, a = e[t]; if (a) { var s = n.transition, l = r.transition; if (l) if ((!o && (o = i[t] = {}), mR(l))) A(o, a); else for (var u = To(l), h = 0; h < u.length; h++) { var c = a[(d = u[h])]; o[d] = c; } else if (mR(s) || P(s, t) >= 0) { !o && (o = i[t] = {}); var p = G(a); for (h = 0; h < p.length; h++) { var d; c = a[(d = p[h])]; MR(r[d], c) && (o[d] = c); } } } } } function SR(t, e, n) { var i = e[t]; if (i) for (var r = (n[t] = {}), o = G(i), a = 0; a < o.length; a++) { var s = o[a]; r[s] = Pi(i[s]); } } function MR(t, e) { return N(t) ? t !== e : null != t && isFinite(t); } var IR = Vo(), TR = ["percent", "easing", "shape", "style", "extra"]; function CR(t) { t.stopAnimation("keyframe"), t.attr(IR(t)); } function DR(t, e, n) { if (n.isAnimationEnabled() && e) if (Y(e)) E(e, function (e) { DR(t, e, n); }); else { var i = e.keyframes, r = e.duration; if (n && null == r) { var o = gh("enter", n, 0); r = o && o.duration; } if (i && r) { var a = IR(t); E(pR, function (n) { if (!n || t[n]) { var o; i.sort(function (t, e) { return t.percent - e.percent; }), E(i, function (i) { var s = t.animators, l = n ? i[n] : i; if (l) { var u = G(l); if ( (n || (u = B(u, function (t) { return P(TR, t) < 0; })), u.length) ) { o || ((o = t.animate( n, e.loop, !0 )).scope = "keyframe"); for (var h = 0; h < s.length; h++) s[h] !== o && s[h].targetName === o.targetName && s[h].stopTracks(u); n && (a[n] = a[n] || {}); var c = n ? a[n] : a; E(u, function (e) { c[e] = ((n ? t[n] : t) || {})[ e ]; }), o.whenWithKeys( r * i.percent, l, u, i.easing ); } } }), o && o .delay(e.delay || 0) .duration(r) .start(e.easing); } }); } } } var AR = "emphasis", kR = "normal", LR = "blur", PR = "select", OR = [kR, AR, LR, PR], RR = { normal: ["itemStyle"], emphasis: [AR, "itemStyle"], blur: [LR, "itemStyle"], select: [PR, "itemStyle"], }, NR = { normal: ["label"], emphasis: [AR, "label"], blur: [LR, "label"], select: [PR, "label"], }, ER = ["x", "y"], zR = { normal: {}, emphasis: {}, blur: {}, select: {} }, VR = { cartesian2d: function (t) { var e = t.master.getRect(); return { coordSys: { type: "cartesian2d", x: e.x, y: e.y, width: e.width, height: e.height, }, api: { coord: function (e) { return t.dataToPoint(e); }, size: W(eR, t), }, }; }, geo: function (t) { var e = t.getBoundingRect(); return { coordSys: { type: "geo", x: e.x, y: e.y, width: e.width, height: e.height, zoom: t.getZoom(), }, api: { coord: function (e) { return t.dataToPoint(e); }, size: W(nR, t), }, }; }, single: function (t) { var e = t.getRect(); return { coordSys: { type: "singleAxis", x: e.x, y: e.y, width: e.width, height: e.height, }, api: { coord: function (e) { return t.dataToPoint(e); }, size: W(iR, t), }, }; }, polar: function (t) { var e = t.getRadiusAxis(), n = t.getAngleAxis(), i = e.getExtent(); return ( i[0] > i[1] && i.reverse(), { coordSys: { type: "polar", cx: t.cx, cy: t.cy, r: i[1], r0: i[0], }, api: { coord: function (i) { var r = e.dataToRadius(i[0]), o = n.dataToAngle(i[1]), a = t.coordToPoint([r, o]); return a.push(r, (o * Math.PI) / 180), a; }, size: W(rR, t), }, } ); }, calendar: function (t) { var e = t.getRect(), n = t.getRangeInfo(); return { coordSys: { type: "calendar", x: e.x, y: e.y, width: e.width, height: e.height, cellWidth: t.getCellWidth(), cellHeight: t.getCellHeight(), rangeInfo: { start: n.start, end: n.end, weeks: n.weeks, dayCount: n.allDay, }, }, api: { coord: function (e, n) { return t.dataToPoint(e, n); }, }, }; }, }; function BR(t) { return t instanceof ks; } function FR(t) { return t instanceof Da; } var GR = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { this._progressiveEls = null; var r = this._data, o = t.getData(), a = this.group, s = UR(t, o, e, n); r || a.removeAll(), o .diff(r) .add(function (e) { jR(n, null, e, s(e, i), t, a, o); }) .remove(function (e) { var n = r.getItemGraphicEl(e); n && vR(n, QO(n).option, t); }) .update(function (e, l) { var u = r.getItemGraphicEl(l); jR(n, u, e, s(e, i), t, a, o); }) .execute(); var l = t.get("clip", !0) ? PS(t.coordinateSystem, !1, t) : null; l ? a.setClipPath(l) : a.removeClipPath(), (this._data = o); }), (e.prototype.incrementalPrepareRender = function (t, e, n) { this.group.removeAll(), (this._data = null); }), (e.prototype.incrementalRender = function (t, e, n, i, r) { var o = e.getData(), a = UR(e, o, n, i), s = (this._progressiveEls = []); function l(t) { t.isGroup || ((t.incremental = !0), (t.ensureState("emphasis").hoverLayer = !0)); } for (var u = t.start; u < t.end; u++) { var h = jR(null, null, u, a(u, r), e, this.group, o); h && (h.traverse(l), s.push(h)); } }), (e.prototype.eachRendered = function (t) { Jh(this._progressiveEls || this.group, t); }), (e.prototype.filterForExposedEvent = function (t, e, n, i) { var r = e.element; if (null == r || n.name === r) return !0; for (; (n = n.__hostTarget || n.parent) && n !== this.group; ) if (n.name === r) return !0; return !1; }), (e.type = "custom"), e ); })(Og); function WR(t) { var e, n = t.type; if ("path" === n) { var i = t.shape, r = null != i.width && null != i.height ? { x: i.x || 0, y: i.y || 0, width: i.width, height: i.height, } : null, o = rN(i); (e = Ph(o, null, r, i.layout || "center")), (QO(e).customPathData = o); } else if ("image" === n) (e = new Ns({})), (QO(e).customImagePath = t.style.image); else if ("text" === n) e = new Xs({}); else if ("group" === n) e = new Br(); else { if ("compoundPath" === n) throw new Error('"compoundPath" is not supported yet.'); var a = Lh(n); if (!a) { var s = ""; 0, wo(s); } e = new a(); } return ( (QO(e).customGraphicType = n), (e.name = t.name), (e.z2EmphasisLift = 1), (e.z2SelectLift = 1), e ); } function HR(t, e, n, i, r, o, a) { CR(e); var s = r && r.normal.cfg; s && e.setTextConfig(s), i && null == i.transition && (i.transition = ER); var l = i && i.style; if (l) { if ("text" === e.type) { var u = l; _t(u, "textFill") && (u.fill = u.textFill), _t(u, "textStroke") && (u.stroke = u.textStroke); } var h = void 0, c = BR(e) ? l.decal : null; t && c && ((c.dirty = !0), (h = mv(c, t))), (l.__decalPattern = h); } FR(e) && l && (h = l.__decalPattern) && (l.decal = h); gR(e, i, o, { dataIndex: n, isInit: a, clearStyle: !0 }), DR(e, i.keyframeAnimation, o); } function YR(t, e, n, i, r) { var o = e.isGroup ? null : e, a = r && r[t].cfg; if (o) { var s = o.ensureState(t); if (!1 === i) { var l = o.getState(t); l && (l.style = null); } else s.style = i || null; a && (s.textConfig = a), kl(o); } } function XR(t, e, n) { var i = n === kR, r = i ? e : JR(e, n), o = r ? r.z2 : null; null != o && ((i ? t : t.ensureState(n)).z2 = o || 0); } function UR(t, e, n, i) { var r = t.get("renderItem"), o = t.coordinateSystem, a = {}; o && (a = o.prepareCustoms ? o.prepareCustoms(o) : VR[o.type](o)); for ( var s, l, u = k( { getWidth: i.getWidth, getHeight: i.getHeight, getZr: i.getZr, getDevicePixelRatio: i.getDevicePixelRatio, value: function (t, n) { return ( null == n && (n = s), e.getStore().get(e.getDimensionIndex(t || 0), n) ); }, style: function (n, i) { 0; null == i && (i = s); var r = e.getItemVisual(i, "style"), o = r && r.fill, a = r && r.opacity, l = m(i, kR).getItemStyle(); null != o && (l.fill = o), null != a && (l.opacity = a); var u = { inheritColor: U(o) ? o : "#000" }, h = x(i, kR), c = oc(h, null, u, !1, !0); c.text = h.getShallow("show") ? rt(t.getFormattedLabel(i, kR), pS(e, i)) : null; var p = ac(h, u, !1); return ( b(n, l), (l = lR(l, c, p)), n && _(l, n), (l.legacy = !0), l ); }, ordinalRawValue: function (t, n) { null == n && (n = s), (t = t || 0); var i = e.getDimensionInfo(t); if (!i) { var r = e.getDimensionIndex(t); return r >= 0 ? e.getStore().get(r, n) : void 0; } var o = e.get(i.name, n), a = i && i.ordinalMeta; return a ? a.categories[o] : o; }, styleEmphasis: function (n, i) { 0; null == i && (i = s); var r = m(i, AR).getItemStyle(), o = x(i, AR), a = oc(o, null, null, !0, !0); a.text = o.getShallow("show") ? ot( t.getFormattedLabel(i, AR), t.getFormattedLabel(i, kR), pS(e, i) ) : null; var l = ac(o, null, !0); return ( b(n, r), (r = lR(r, a, l)), n && _(r, n), (r.legacy = !0), r ); }, visual: function (t, n) { if ((null == n && (n = s), _t($O, t))) { var i = e.getItemVisual(n, "style"); return i ? i[$O[t]] : null; } if (_t(JO, t)) return e.getItemVisual(n, t); }, barLayout: function (t) { if ("cartesian2d" === o.type) { return (function (t) { var e = [], n = t.axis, i = "axis0"; if ("category" === n.type) { for ( var r = n.getBandWidth(), o = 0; o < t.count; o++ ) e.push( k( { bandWidth: r, axisKey: i, stackId: Fx + o, }, t ) ); var a = Xx(e), s = []; for (o = 0; o < t.count; o++) { var l = a[i][Fx + o]; (l.offsetCenter = l.offset + l.width / 2), s.push(l); } return s; } })(k({ axis: o.getBaseAxis() }, t)); } }, currentSeriesIndices: function () { return n.getCurrentSeriesIndices(); }, font: function (t) { return cc(t, n); }, }, a.api || {} ), h = { context: {}, seriesId: t.id, seriesName: t.name, seriesIndex: t.seriesIndex, coordSys: a.coordSys, dataInsideLength: e.count(), encode: ZR(t.getData()), }, c = {}, p = {}, d = {}, f = {}, g = 0; g < OR.length; g++ ) { var y = OR[g]; (d[y] = t.getModel(RR[y])), (f[y] = t.getModel(NR[y])); } function v(t) { return t === s ? l || (l = e.getItemModel(t)) : e.getItemModel(t); } function m(t, n) { return e.hasItemOption ? t === s ? c[n] || (c[n] = v(t).getModel(RR[n])) : v(t).getModel(RR[n]) : d[n]; } function x(t, n) { return e.hasItemOption ? t === s ? p[n] || (p[n] = v(t).getModel(NR[n])) : v(t).getModel(NR[n]) : f[n]; } return function (t, n) { return ( (s = t), (l = null), (c = {}), (p = {}), r && r( k( { dataIndexInside: t, dataIndex: e.getRawIndex(t), actionType: n ? n.type : null, }, h ), u ) ); }; function _(t, e) { for (var n in e) _t(e, n) && (t[n] = e[n]); } function b(t, e) { t && (t.textFill && (e.textFill = t.textFill), t.textPosition && (e.textPosition = t.textPosition)); } } function ZR(t) { var e = {}; return ( E(t.dimensions, function (n) { var i = t.getDimensionInfo(n); if (!i.isExtraCoord) { var r = i.coordDim; (e[r] = e[r] || [])[i.coordDimIndex] = t.getDimensionIndex(n); } }), e ); } function jR(t, e, n, i, r, o, a) { if (i) { var s = qR(t, e, n, i, r, o); return ( s && a.setItemGraphicEl(n, s), s && Zl(s, i.focus, i.blurScope, i.emphasisDisabled), s ); } o.remove(e); } function qR(t, e, n, i, r, o) { var a = -1, s = e; e && KR(e, i, r) && ((a = P(o.childrenRef(), e)), (e = null)); var l, u, h = !e, c = e; c ? c.clearStates() : ((c = WR(i)), s && ((l = s), (u = c).copyTransform(l), FR(u) && FR(l) && (u.setStyle(l.style), (u.z = l.z), (u.z2 = l.z2), (u.zlevel = l.zlevel), (u.invisible = l.invisible), (u.ignore = l.ignore), BR(u) && BR(l) && u.setShape(l.shape)))), !1 === i.morph ? (c.disableMorphing = !0) : c.disableMorphing && (c.disableMorphing = !1), (zR.normal.cfg = zR.normal.conOpt = zR.emphasis.cfg = zR.emphasis.conOpt = zR.blur.cfg = zR.blur.conOpt = zR.select.cfg = zR.select.conOpt = null), (zR.isLegacy = !1), (function (t, e, n, i, r, o) { if (t.isGroup) return; $R(n, null, o), $R(n, AR, o); var a = o.normal.conOpt, s = o.emphasis.conOpt, l = o.blur.conOpt, u = o.select.conOpt; if (null != a || null != s || null != u || null != l) { var h = t.getTextContent(); if (!1 === a) h && t.removeTextContent(); else { (a = o.normal.conOpt = a || { type: "text" }), h ? h.clearStates() : ((h = WR(a)), t.setTextContent(h)), HR(null, h, e, a, null, i, r); for (var c = a && a.style, p = 0; p < OR.length; p++) { var d = OR[p]; if (d !== kR) { var f = o[d].conOpt; YR(d, h, 0, QR(a, f, d), null); } } c ? h.dirty() : h.markRedraw(); } } })(c, n, i, r, h, zR), (function (t, e, n, i, r) { var o = n.clipPath; if (!1 === o) t && t.getClipPath() && t.removeClipPath(); else if (o) { var a = t.getClipPath(); a && KR(a, o, i) && (a = null), a || ((a = WR(o)), t.setClipPath(a)), HR(null, a, e, o, null, i, r); } })(c, n, i, r, h), HR(t, c, n, i, zR, r, h), _t(i, "info") && (QO(c).info = i.info); for (var p = 0; p < OR.length; p++) { var d = OR[p]; if (d !== kR) { var f = JR(i, d); YR(d, c, 0, QR(i, f, d), zR); } } return ( (function (t, e, n) { if (!t.isGroup) { var i = t, r = n.currentZ, o = n.currentZLevel; (i.z = r), (i.zlevel = o); var a = e.z2; null != a && (i.z2 = a || 0); for (var s = 0; s < OR.length; s++) XR(i, e, OR[s]); } })(c, i, r), "group" === i.type && (function (t, e, n, i, r) { var o = i.children, a = o ? o.length : 0, s = i.$mergeChildren, l = "byName" === s || i.diffChildrenByName, u = !1 === s; if (!a && !l && !u) return; if (l) return ( (h = { api: t, oldChildren: e.children() || [], newChildren: o || [], dataIndex: n, seriesModel: r, group: e, }), void new Gm(h.oldChildren, h.newChildren, eN, eN, h) .add(nN) .update(nN) .remove(iN) .execute() ); var h; u && e.removeAll(); for (var c = 0; c < a; c++) { var p = o[c], d = e.childAt(c); p ? (null == p.ignore && (p.ignore = !1), qR(t, d, n, p, r, e)) : (d.ignore = !0); } for (var f = e.childCount() - 1; f >= c; f--) { var g = e.childAt(f); tN(e, g, r); } })(t, c, n, i, r), a >= 0 ? o.replaceAt(c, a) : o.add(c), c ); } function KR(t, e, n) { var i, r = QO(t), o = e.type, a = e.shape, s = e.style; return ( n.isUniversalTransitionEnabled() || (null != o && o !== r.customGraphicType) || ("path" === o && (i = a) && (_t(i, "pathData") || _t(i, "d")) && rN(a) !== r.customPathData) || ("image" === o && _t(s, "image") && s.image !== r.customImagePath) ); } function $R(t, e, n) { var i = e ? JR(t, e) : t, r = e ? QR(t, i, AR) : t.style, o = t.type, a = i ? i.textConfig : null, s = t.textContent, l = s ? (e ? JR(s, e) : s) : null; if (r && (n.isLegacy || oR(r, o, !!a, !!l))) { n.isLegacy = !0; var u = aR(r, o, !e); !a && u.textConfig && (a = u.textConfig), !l && u.textContent && (l = u.textContent); } if (!e && l) { var h = l; !h.type && (h.type = "text"); } var c = e ? n[e] : n.normal; (c.cfg = a), (c.conOpt = l); } function JR(t, e) { return e ? (t ? t[e] : null) : t; } function QR(t, e, n) { var i = e && e.style; return null == i && n === AR && t && (i = t.styleEmphasis), i; } function tN(t, e, n) { e && vR(e, QO(t).option, n); } function eN(t, e) { var n = t && t.name; return null != n ? n : "e\0\0" + e; } function nN(t, e) { var n = this.context, i = null != t ? n.newChildren[t] : null, r = null != e ? n.oldChildren[e] : null; qR(n.api, r, n.dataIndex, i, n.seriesModel, n.group); } function iN(t) { var e = this.context, n = e.oldChildren[t]; n && vR(n, QO(n).option, e.seriesModel); } function rN(t) { return t && (t.pathData || t.d); } var oN = Vo(), aN = T, sN = W, lN = (function () { function t() { (this._dragging = !1), (this.animationThreshold = 15); } return ( (t.prototype.render = function (t, e, n, i) { var r = e.get("value"), o = e.get("status"); if ( ((this._axisModel = t), (this._axisPointerModel = e), (this._api = n), i || this._lastValue !== r || this._lastStatus !== o) ) { (this._lastValue = r), (this._lastStatus = o); var a = this._group, s = this._handle; if (!o || "hide" === o) return a && a.hide(), void (s && s.hide()); a && a.show(), s && s.show(); var l = {}; this.makeElOption(l, r, t, e, n); var u = l.graphicKey; u !== this._lastGraphicKey && this.clear(n), (this._lastGraphicKey = u); var h = (this._moveAnimation = this.determineAnimation( t, e )); if (a) { var c = H(uN, e, h); this.updatePointerEl(a, l, c), this.updateLabelEl(a, l, c, e); } else (a = this._group = new Br()), this.createPointerEl(a, l, t, e), this.createLabelEl(a, l, t, e), n.getZr().add(a); dN(a, e, !0), this._renderHandle(r); } }), (t.prototype.remove = function (t) { this.clear(t); }), (t.prototype.dispose = function (t) { this.clear(t); }), (t.prototype.determineAnimation = function (t, e) { var n = e.get("animation"), i = t.axis, r = "category" === i.type, o = e.get("snap"); if (!o && !r) return !1; if ("auto" === n || null == n) { var a = this.animationThreshold; if (r && i.getBandWidth() > a) return !0; if (o) { var s = wI(t).seriesDataCount, l = i.getExtent(); return Math.abs(l[0] - l[1]) / s > a; } return !1; } return !0 === n; }), (t.prototype.makeElOption = function (t, e, n, i, r) {}), (t.prototype.createPointerEl = function (t, e, n, i) { var r = e.pointer; if (r) { var o = (oN(t).pointerEl = new Qh[r.type]( aN(e.pointer) )); t.add(o); } }), (t.prototype.createLabelEl = function (t, e, n, i) { if (e.label) { var r = (oN(t).labelEl = new Xs(aN(e.label))); t.add(r), cN(r, i); } }), (t.prototype.updatePointerEl = function (t, e, n) { var i = oN(t).pointerEl; i && e.pointer && (i.setStyle(e.pointer.style), n(i, { shape: e.pointer.shape })); }), (t.prototype.updateLabelEl = function (t, e, n, i) { var r = oN(t).labelEl; r && (r.setStyle(e.label.style), n(r, { x: e.label.x, y: e.label.y }), cN(r, i)); }), (t.prototype._renderHandle = function (t) { if (!this._dragging && this.updateHandleTransform) { var e, n = this._axisPointerModel, i = this._api.getZr(), r = this._handle, o = n.getModel("handle"), a = n.get("status"); if (!o.get("show") || !a || "hide" === a) return r && i.remove(r), void (this._handle = null); this._handle || ((e = !0), (r = this._handle = Uh(o.get("icon"), { cursor: "move", draggable: !0, onmousemove: function (t) { de(t.event); }, onmousedown: sN( this._onHandleDragMove, this, 0, 0 ), drift: sN(this._onHandleDragMove, this), ondragend: sN(this._onHandleDragEnd, this), })), i.add(r)), dN(r, n, !1), r.setStyle( o.getItemStyle(null, [ "color", "borderColor", "borderWidth", "opacity", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY", ]) ); var s = o.get("size"); Y(s) || (s = [s, s]), (r.scaleX = s[0] / 2), (r.scaleY = s[1] / 2), Hg( this, "_doDispatchAxisPointer", o.get("throttle") || 0, "fixRate" ), this._moveHandleToValue(t, e); } }), (t.prototype._moveHandleToValue = function (t, e) { uN( this._axisPointerModel, !e && this._moveAnimation, this._handle, pN( this.getHandleTransform( t, this._axisModel, this._axisPointerModel ) ) ); }), (t.prototype._onHandleDragMove = function (t, e) { var n = this._handle; if (n) { this._dragging = !0; var i = this.updateHandleTransform( pN(n), [t, e], this._axisModel, this._axisPointerModel ); (this._payloadInfo = i), n.stopAnimation(), n.attr(pN(i)), (oN(n).lastProp = null), this._doDispatchAxisPointer(); } }), (t.prototype._doDispatchAxisPointer = function () { if (this._handle) { var t = this._payloadInfo, e = this._axisModel; this._api.dispatchAction({ type: "updateAxisPointer", x: t.cursorPoint[0], y: t.cursorPoint[1], tooltipOption: t.tooltipOption, axesInfo: [ { axisDim: e.axis.dim, axisIndex: e.componentIndex, }, ], }); } }), (t.prototype._onHandleDragEnd = function () { if (((this._dragging = !1), this._handle)) { var t = this._axisPointerModel.get("value"); this._moveHandleToValue(t), this._api.dispatchAction({ type: "hideTip" }); } }), (t.prototype.clear = function (t) { (this._lastValue = null), (this._lastStatus = null); var e = t.getZr(), n = this._group, i = this._handle; e && n && ((this._lastGraphicKey = null), n && e.remove(n), i && e.remove(i), (this._group = null), (this._handle = null), (this._payloadInfo = null)), Yg(this, "_doDispatchAxisPointer"); }), (t.prototype.doClear = function () {}), (t.prototype.buildLabel = function (t, e, n) { return { x: t[(n = n || 0)], y: t[1 - n], width: e[n], height: e[1 - n], }; }), t ); })(); function uN(t, e, n, i) { hN(oN(n).lastProp, i) || ((oN(n).lastProp = i), e ? vh(n, i, t) : (n.stopAnimation(), n.attr(i))); } function hN(t, e) { if (q(t) && q(e)) { var n = !0; return ( E(e, function (e, i) { n = n && hN(t[i], e); }), !!n ); } return t === e; } function cN(t, e) { t[e.get(["label", "show"]) ? "show" : "hide"](); } function pN(t) { return { x: t.x || 0, y: t.y || 0, rotation: t.rotation || 0 }; } function dN(t, e, n) { var i = e.get("z"), r = e.get("zlevel"); t && t.traverse(function (t) { "group" !== t.type && (null != i && (t.z = i), null != r && (t.zlevel = r), (t.silent = n)); }); } function fN(t) { var e, n = t.get("type"), i = t.getModel(n + "Style"); return ( "line" === n ? ((e = i.getLineStyle()).fill = null) : "shadow" === n && ((e = i.getAreaStyle()).stroke = null), e ); } function gN(t, e, n, i, r) { var o = yN( n.get("value"), e.axis, e.ecModel, n.get("seriesDataIndices"), { precision: n.get(["label", "precision"]), formatter: n.get(["label", "formatter"]), } ), a = n.getModel("label"), s = vp(a.get("padding") || 0), l = a.getFont(), u = Sr(o, l), h = r.position, c = u.width + s[1] + s[3], p = u.height + s[0] + s[2], d = r.align; "right" === d && (h[0] -= c), "center" === d && (h[0] -= c / 2); var f = r.verticalAlign; "bottom" === f && (h[1] -= p), "middle" === f && (h[1] -= p / 2), (function (t, e, n, i) { var r = i.getWidth(), o = i.getHeight(); (t[0] = Math.min(t[0] + e, r) - e), (t[1] = Math.min(t[1] + n, o) - n), (t[0] = Math.max(t[0], 0)), (t[1] = Math.max(t[1], 0)); })(h, c, p, i); var g = a.get("backgroundColor"); (g && "auto" !== g) || (g = e.get(["axisLine", "lineStyle", "color"])), (t.label = { x: h[0], y: h[1], style: oc(a, { text: o, font: l, fill: a.getTextColor(), padding: s, backgroundColor: g, }), z2: 10, }); } function yN(t, e, n, i, r) { t = e.scale.parse(t); var o = e.scale.getLabel({ value: t }, { precision: r.precision }), a = r.formatter; if (a) { var s = { value: S_(e, { value: t }), axisDimension: e.dim, axisIndex: e.index, seriesData: [], }; E(i, function (t) { var e = n.getSeriesByIndex(t.seriesIndex), i = t.dataIndexInside, r = e && e.getDataParams(i); r && s.seriesData.push(r); }), U(a) ? (o = a.replace("{value}", o)) : X(a) && (o = a(s)); } return o; } function vN(t, e, n) { var i = [1, 0, 0, 1, 0, 0]; return ( Se(i, i, n.rotation), we(i, i, n.position), Fh( [ t.dataToCoord(e), (n.labelOffset || 0) + (n.labelDirection || 1) * (n.labelMargin || 0), ], i ) ); } function mN(t, e, n, i, r, o) { var a = dI.innerTextLayout(n.rotation, 0, n.labelDirection); (n.labelMargin = r.get(["label", "margin"])), gN(e, i, r, o, { position: vN(i.axis, t, n), align: a.textAlign, verticalAlign: a.textVerticalAlign, }); } function xN(t, e, n) { return { x1: t[(n = n || 0)], y1: t[1 - n], x2: e[n], y2: e[1 - n] }; } function _N(t, e, n) { return { x: t[(n = n || 0)], y: t[1 - n], width: e[n], height: e[1 - n], }; } function bN(t, e, n, i, r, o) { return { cx: t, cy: e, r0: n, r: i, startAngle: r, endAngle: o, clockwise: !0, }; } var wN = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.makeElOption = function (t, e, n, i, r) { var o = n.axis, a = o.grid, s = i.get("type"), l = SN(a, o).getOtherAxis(o).getGlobalExtent(), u = o.toGlobalCoord(o.dataToCoord(e, !0)); if (s && "none" !== s) { var h = fN(i), c = MN[s](o, u, l); (c.style = h), (t.graphicKey = c.type), (t.pointer = c); } mN(e, t, iI(a.model, n), n, i, r); }), (e.prototype.getHandleTransform = function (t, e, n) { var i = iI(e.axis.grid.model, e, { labelInside: !1 }); i.labelMargin = n.get(["handle", "margin"]); var r = vN(e.axis, t, i); return { x: r[0], y: r[1], rotation: i.rotation + (i.labelDirection < 0 ? Math.PI : 0), }; }), (e.prototype.updateHandleTransform = function (t, e, n, i) { var r = n.axis, o = r.grid, a = r.getGlobalExtent(!0), s = SN(o, r).getOtherAxis(r).getGlobalExtent(), l = "x" === r.dim ? 0 : 1, u = [t.x, t.y]; (u[l] += e[l]), (u[l] = Math.min(a[1], u[l])), (u[l] = Math.max(a[0], u[l])); var h = (s[1] + s[0]) / 2, c = [h, h]; c[l] = u[l]; return { x: u[0], y: u[1], rotation: t.rotation, cursorPoint: c, tooltipOption: [ { verticalAlign: "middle" }, { align: "center" }, ][l], }; }), e ); })(lN); function SN(t, e) { var n = {}; return (n[e.dim + "AxisIndex"] = e.index), t.getCartesian(n); } var MN = { line: function (t, e, n) { return { type: "Line", subPixelOptimize: !0, shape: xN([e, n[0]], [e, n[1]], IN(t)), }; }, shadow: function (t, e, n) { var i = Math.max(1, t.getBandWidth()), r = n[1] - n[0]; return { type: "Rect", shape: _N([e - i / 2, n[0]], [i, r], IN(t)), }; }, }; function IN(t) { return "x" === t.dim ? 0 : 1; } var TN = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.type = "axisPointer"), (e.defaultOption = { show: "auto", z: 50, type: "line", snap: !1, triggerTooltip: !0, triggerEmphasis: !0, value: null, status: null, link: [], animation: null, animationDurationUpdate: 200, lineStyle: { color: "#B9BEC9", width: 1, type: "dashed" }, shadowStyle: { color: "rgba(210,219,238,0.2)" }, label: { show: !0, formatter: null, precision: "auto", margin: 3, color: "#fff", padding: [5, 7, 5, 7], backgroundColor: "auto", borderColor: null, borderWidth: 0, borderRadius: 3, }, handle: { show: !1, icon: "M10.7,11.9v-1.3H9.3v1.3c-4.9,0.3-8.8,4.4-8.8,9.4c0,5,3.9,9.1,8.8,9.4h1.3c4.9-0.3,8.8-4.4,8.8-9.4C19.5,16.3,15.6,12.2,10.7,11.9z M13.3,24.4H6.7v-1.2h6.6z M13.3,22H6.7v-1.2h6.6z M13.3,19.6H6.7v-1.2h6.6z", size: 45, margin: 50, color: "#333", shadowBlur: 3, shadowColor: "#aaa", shadowOffsetX: 0, shadowOffsetY: 2, throttle: 40, }, }), e ); })(zp), CN = Vo(), DN = E; function AN(t, e, n) { if (!r.node) { var i = e.getZr(); CN(i).records || (CN(i).records = {}), (function (t, e) { if (CN(t).initialized) return; function n(n, i) { t.on(n, function (n) { var r = (function (t) { var e = { showTip: [], hideTip: [] }, n = function (i) { var r = e[i.type]; r ? r.push(i) : ((i.dispatchAction = n), t.dispatchAction(i)); }; return { dispatchAction: n, pendings: e }; })(e); DN(CN(t).records, function (t) { t && i(t, n, r.dispatchAction); }), (function (t, e) { var n, i = t.showTip.length, r = t.hideTip.length; i ? (n = t.showTip[i - 1]) : r && (n = t.hideTip[r - 1]); n && ((n.dispatchAction = null), e.dispatchAction(n)); })(r.pendings, e); }); } (CN(t).initialized = !0), n("click", H(LN, "click")), n("mousemove", H(LN, "mousemove")), n("globalout", kN); })(i, e), ((CN(i).records[t] || (CN(i).records[t] = {})).handler = n); } } function kN(t, e, n) { t.handler("leave", null, n); } function LN(t, e, n, i) { e.handler(t, n, i); } function PN(t, e) { if (!r.node) { var n = e.getZr(); (CN(n).records || {})[t] && (CN(n).records[t] = null); } } var ON = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = e.getComponent("tooltip"), r = t.get("triggerOn") || (i && i.get("triggerOn")) || "mousemove|click"; AN("axisPointer", n, function (t, e, n) { "none" !== r && ("leave" === t || r.indexOf(t) >= 0) && n({ type: "updateAxisPointer", currTrigger: t, x: e && e.offsetX, y: e && e.offsetY, }); }); }), (e.prototype.remove = function (t, e) { PN("axisPointer", e); }), (e.prototype.dispose = function (t, e) { PN("axisPointer", e); }), (e.type = "axisPointer"), e ); })(Ag); function RN(t, e) { var n, i = [], r = t.seriesIndex; if (null == r || !(n = e.getSeriesByIndex(r))) return { point: [] }; var o = n.getData(), a = zo(o, t); if (null == a || a < 0 || Y(a)) return { point: [] }; var s = o.getItemGraphicEl(a), l = n.coordinateSystem; if (n.getTooltipPosition) i = n.getTooltipPosition(a) || []; else if (l && l.dataToPoint) if (t.isStacked) { var u = l.getBaseAxis(), h = l.getOtherAxis(u).dim, c = u.dim, p = "x" === h || "radius" === h ? 1 : 0, d = o.mapDimension(c), f = []; (f[p] = o.get(d, a)), (f[1 - p] = o.get( o.getCalculationInfo("stackResultDimension"), a )), (i = l.dataToPoint(f) || []); } else i = l.dataToPoint( o.getValues( z(l.dimensions, function (t) { return o.mapDimension(t); }), a ) ) || []; else if (s) { var g = s.getBoundingRect().clone(); g.applyTransform(s.transform), (i = [g.x + g.width / 2, g.y + g.height / 2]); } return { point: i, el: s }; } var NN = Vo(); function EN(t, e, n) { var i = t.currTrigger, r = [t.x, t.y], o = t, a = t.dispatchAction || W(n.dispatchAction, n), s = e.getComponent("axisPointer").coordSysAxesInfo; if (s) { GN(r) && (r = RN( { seriesIndex: o.seriesIndex, dataIndex: o.dataIndex }, e ).point); var l = GN(r), u = o.axesInfo, h = s.axesInfo, c = "leave" === i || GN(r), p = {}, d = {}, f = { list: [], map: {} }, g = { showPointer: H(VN, d), showTooltip: H(BN, f) }; E(s.coordSysMap, function (t, e) { var n = l || t.containPoint(r); E(s.coordSysAxesInfo[e], function (t, e) { var i = t.axis, o = (function (t, e) { for (var n = 0; n < (t || []).length; n++) { var i = t[n]; if ( e.axis.dim === i.axisDim && e.axis.model.componentIndex === i.axisIndex ) return i; } })(u, t); if (!c && n && (!u || o)) { var a = o && o.value; null != a || l || (a = i.pointToData(r)), null != a && zN(t, a, g, !1, p); } }); }); var y = {}; return ( E(h, function (t, e) { var n = t.linkGroup; n && !d[e] && E(n.axesInfo, function (e, i) { var r = d[i]; if (e !== t && r) { var o = r.value; n.mapper && (o = t.axis.scale.parse( n.mapper(o, FN(e), FN(t)) )), (y[t.key] = o); } }); }), E(y, function (t, e) { zN(h[e], t, g, !0, p); }), (function (t, e, n) { var i = (n.axesInfo = []); E(e, function (e, n) { var r = e.axisPointerModel.option, o = t[n]; o ? (!e.useHandle && (r.status = "show"), (r.value = o.value), (r.seriesDataIndices = ( o.payloadBatch || [] ).slice())) : !e.useHandle && (r.status = "hide"), "show" === r.status && i.push({ axisDim: e.axis.dim, axisIndex: e.axis.model.componentIndex, value: r.value, }); }); })(d, h, p), (function (t, e, n, i) { if (GN(e) || !t.list.length) return void i({ type: "hideTip" }); var r = ((t.list[0].dataByAxis[0] || {}).seriesDataIndices || [])[0] || {}; i({ type: "showTip", escapeConnect: !0, x: e[0], y: e[1], tooltipOption: n.tooltipOption, position: n.position, dataIndexInside: r.dataIndexInside, dataIndex: r.dataIndex, seriesIndex: r.seriesIndex, dataByCoordSys: t.list, }); })(f, r, t, a), (function (t, e, n) { var i = n.getZr(), r = "axisPointerLastHighlights", o = NN(i)[r] || {}, a = (NN(i)[r] = {}); E(t, function (t, e) { var n = t.axisPointerModel.option; "show" === n.status && t.triggerEmphasis && E(n.seriesDataIndices, function (t) { var e = t.seriesIndex + " | " + t.dataIndex; a[e] = t; }); }); var s = [], l = []; E(o, function (t, e) { !a[e] && l.push(t); }), E(a, function (t, e) { !o[e] && s.push(t); }), l.length && n.dispatchAction({ type: "downplay", escapeConnect: !0, notBlur: !0, batch: l, }), s.length && n.dispatchAction({ type: "highlight", escapeConnect: !0, notBlur: !0, batch: s, }); })(h, 0, n), p ); } } function zN(t, e, n, i, r) { var o = t.axis; if (!o.scale.isBlank() && o.containData(e)) if (t.involveSeries) { var a = (function (t, e) { var n = e.axis, i = n.dim, r = t, o = [], a = Number.MAX_VALUE, s = -1; return ( E(e.seriesModels, function (e, l) { var u, h, c = e.getData().mapDimensionsAll(i); if (e.getAxisTooltipData) { var p = e.getAxisTooltipData(c, t, n); (h = p.dataIndices), (u = p.nestestValue); } else { if ( !(h = e .getData() .indicesOfNearest( c[0], t, "category" === n.type ? 0.5 : null )).length ) return; u = e.getData().get(c[0], h[0]); } if (null != u && isFinite(u)) { var d = t - u, f = Math.abs(d); f <= a && ((f < a || (d >= 0 && s < 0)) && ((a = f), (s = d), (r = u), (o.length = 0)), E(h, function (t) { o.push({ seriesIndex: e.seriesIndex, dataIndexInside: t, dataIndex: e .getData() .getRawIndex(t), }); })); } }), { payloadBatch: o, snapToValue: r } ); })(e, t), s = a.payloadBatch, l = a.snapToValue; s[0] && null == r.seriesIndex && A(r, s[0]), !i && t.snap && o.containData(l) && null != l && (e = l), n.showPointer(t, e, s), n.showTooltip(t, a, l); } else n.showPointer(t, e); } function VN(t, e, n, i) { t[e.key] = { value: n, payloadBatch: i }; } function BN(t, e, n, i) { var r = n.payloadBatch, o = e.axis, a = o.model, s = e.axisPointerModel; if (e.triggerTooltip && r.length) { var l = e.coordSys.model, u = MI(l), h = t.map[u]; h || ((h = t.map[u] = { coordSysId: l.id, coordSysIndex: l.componentIndex, coordSysType: l.type, coordSysMainType: l.mainType, dataByAxis: [], }), t.list.push(h)), h.dataByAxis.push({ axisDim: o.dim, axisIndex: a.componentIndex, axisType: a.type, axisId: a.id, value: i, valueLabelOpt: { precision: s.get(["label", "precision"]), formatter: s.get(["label", "formatter"]), }, seriesDataIndices: r.slice(), }); } } function FN(t) { var e = t.axis.model, n = {}, i = (n.axisDim = t.axis.dim); return ( (n.axisIndex = n[i + "AxisIndex"] = e.componentIndex), (n.axisName = n[i + "AxisName"] = e.name), (n.axisId = n[i + "AxisId"] = e.id), n ); } function GN(t) { return !t || null == t[0] || isNaN(t[0]) || null == t[1] || isNaN(t[1]); } function WN(t) { TI.registerAxisPointerClass("CartesianAxisPointer", wN), t.registerComponentModel(TN), t.registerComponentView(ON), t.registerPreprocessor(function (t) { if (t) { (!t.axisPointer || 0 === t.axisPointer.length) && (t.axisPointer = {}); var e = t.axisPointer.link; e && !Y(e) && (t.axisPointer.link = [e]); } }), t.registerProcessor( t.PRIORITY.PROCESSOR.STATISTIC, function (t, e) { t.getComponent("axisPointer").coordSysAxesInfo = xI(t, e); } ), t.registerAction( { type: "updateAxisPointer", event: "updateAxisPointer", update: ":updateAxisPointer", }, EN ); } var HN = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.makeElOption = function (t, e, n, i, r) { var o = n.axis; "angle" === o.dim && (this.animationThreshold = Math.PI / 18); var a = o.polar, s = a.getOtherAxis(o).getExtent(), l = o.dataToCoord(e), u = i.get("type"); if (u && "none" !== u) { var h = fN(i), c = YN[u](o, a, l, s); (c.style = h), (t.graphicKey = c.type), (t.pointer = c); } var p = (function (t, e, n, i, r) { var o = e.axis, a = o.dataToCoord(t), s = i.getAngleAxis().getExtent()[0]; s = (s / 180) * Math.PI; var l, u, h, c = i.getRadiusAxis().getExtent(); if ("radius" === o.dim) { var p = [1, 0, 0, 1, 0, 0]; Se(p, p, s), we(p, p, [i.cx, i.cy]), (l = Fh([a, -r], p)); var d = e.getModel("axisLabel").get("rotate") || 0, f = dI.innerTextLayout(s, (d * Math.PI) / 180, -1); (u = f.textAlign), (h = f.textVerticalAlign); } else { var g = c[1]; l = i.coordToPoint([g + r, a]); var y = i.cx, v = i.cy; (u = Math.abs(l[0] - y) / g < 0.3 ? "center" : l[0] > y ? "left" : "right"), (h = Math.abs(l[1] - v) / g < 0.3 ? "middle" : l[1] > v ? "top" : "bottom"); } return { position: l, align: u, verticalAlign: h }; })(e, n, 0, a, i.get(["label", "margin"])); gN(t, n, i, r, p); }), e ); })(lN); var YN = { line: function (t, e, n, i) { return "angle" === t.dim ? { type: "Line", shape: xN( e.coordToPoint([i[0], n]), e.coordToPoint([i[1], n]) ), } : { type: "Circle", shape: { cx: e.cx, cy: e.cy, r: n } }; }, shadow: function (t, e, n, i) { var r = Math.max(1, t.getBandWidth()), o = Math.PI / 180; return "angle" === t.dim ? { type: "Sector", shape: bN( e.cx, e.cy, i[0], i[1], (-n - r / 2) * o, (r / 2 - n) * o ), } : { type: "Sector", shape: bN( e.cx, e.cy, n - r / 2, n + r / 2, 0, 2 * Math.PI ), }; }, }, XN = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.findAxisModel = function (t) { var e; return ( this.ecModel.eachComponent( t, function (t) { t.getCoordSysModel() === this && (e = t); }, this ), e ); }), (e.type = "polar"), (e.dependencies = ["radiusAxis", "angleAxis"]), (e.defaultOption = { z: 0, center: ["50%", "50%"], radius: "80%", }), e ); })(zp), UN = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.getCoordSysModel = function () { return this.getReferringComponents("polar", Wo).models[0]; }), (e.type = "polarAxis"), e ); })(zp); R(UN, D_); var ZN = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "angleAxis"), e; })(UN), jN = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "radiusAxis"), e; })(UN), qN = (function (t) { function e(e, n) { return t.call(this, "radius", e, n) || this; } return ( n(e, t), (e.prototype.pointToData = function (t, e) { return this.polar.pointToData(t, e)[ "radius" === this.dim ? 0 : 1 ]; }), e ); })(ab); (qN.prototype.dataToRadius = ab.prototype.dataToCoord), (qN.prototype.radiusToData = ab.prototype.coordToData); var KN = Vo(), $N = (function (t) { function e(e, n) { return t.call(this, "angle", e, n || [0, 360]) || this; } return ( n(e, t), (e.prototype.pointToData = function (t, e) { return this.polar.pointToData(t, e)[ "radius" === this.dim ? 0 : 1 ]; }), (e.prototype.calculateCategoryInterval = function () { var t = this, e = t.getLabelModel(), n = t.scale, i = n.getExtent(), r = n.count(); if (i[1] - i[0] < 1) return 0; var o = i[0], a = t.dataToCoord(o + 1) - t.dataToCoord(o), s = Math.abs(a), l = Sr( null == o ? "" : o + "", e.getFont(), "center", "top" ), u = Math.max(l.height, 7) / s; isNaN(u) && (u = 1 / 0); var h = Math.max(0, Math.floor(u)), c = KN(t.model), p = c.lastAutoInterval, d = c.lastTickCount; return ( null != p && null != d && Math.abs(p - h) <= 1 && Math.abs(d - r) <= 1 && p > h ? (h = p) : ((c.lastTickCount = r), (c.lastAutoInterval = h)), h ); }), e ); })(ab); ($N.prototype.dataToAngle = ab.prototype.dataToCoord), ($N.prototype.angleToData = ab.prototype.coordToData); var JN = ["radius", "angle"], QN = (function () { function t(t) { (this.dimensions = JN), (this.type = "polar"), (this.cx = 0), (this.cy = 0), (this._radiusAxis = new qN()), (this._angleAxis = new $N()), (this.axisPointerEnabled = !0), (this.name = t || ""), (this._radiusAxis.polar = this._angleAxis.polar = this); } return ( (t.prototype.containPoint = function (t) { var e = this.pointToCoord(t); return ( this._radiusAxis.contain(e[0]) && this._angleAxis.contain(e[1]) ); }), (t.prototype.containData = function (t) { return ( this._radiusAxis.containData(t[0]) && this._angleAxis.containData(t[1]) ); }), (t.prototype.getAxis = function (t) { return this["_" + t + "Axis"]; }), (t.prototype.getAxes = function () { return [this._radiusAxis, this._angleAxis]; }), (t.prototype.getAxesByScale = function (t) { var e = [], n = this._angleAxis, i = this._radiusAxis; return ( n.scale.type === t && e.push(n), i.scale.type === t && e.push(i), e ); }), (t.prototype.getAngleAxis = function () { return this._angleAxis; }), (t.prototype.getRadiusAxis = function () { return this._radiusAxis; }), (t.prototype.getOtherAxis = function (t) { var e = this._angleAxis; return t === e ? this._radiusAxis : e; }), (t.prototype.getBaseAxis = function () { return ( this.getAxesByScale("ordinal")[0] || this.getAxesByScale("time")[0] || this.getAngleAxis() ); }), (t.prototype.getTooltipAxes = function (t) { var e = null != t && "auto" !== t ? this.getAxis(t) : this.getBaseAxis(); return { baseAxes: [e], otherAxes: [this.getOtherAxis(e)] }; }), (t.prototype.dataToPoint = function (t, e) { return this.coordToPoint([ this._radiusAxis.dataToRadius(t[0], e), this._angleAxis.dataToAngle(t[1], e), ]); }), (t.prototype.pointToData = function (t, e) { var n = this.pointToCoord(t); return [ this._radiusAxis.radiusToData(n[0], e), this._angleAxis.angleToData(n[1], e), ]; }), (t.prototype.pointToCoord = function (t) { var e = t[0] - this.cx, n = t[1] - this.cy, i = this.getAngleAxis(), r = i.getExtent(), o = Math.min(r[0], r[1]), a = Math.max(r[0], r[1]); i.inverse ? (o = a - 360) : (a = o + 360); var s = Math.sqrt(e * e + n * n); (e /= s), (n /= s); for ( var l = (Math.atan2(-n, e) / Math.PI) * 180, u = l < o ? 1 : -1; l < o || l > a; ) l += 360 * u; return [s, l]; }), (t.prototype.coordToPoint = function (t) { var e = t[0], n = (t[1] / 180) * Math.PI; return [ Math.cos(n) * e + this.cx, -Math.sin(n) * e + this.cy, ]; }), (t.prototype.getArea = function () { var t = this.getAngleAxis(), e = this.getRadiusAxis().getExtent().slice(); e[0] > e[1] && e.reverse(); var n = t.getExtent(), i = Math.PI / 180, r = 1e-4; return { cx: this.cx, cy: this.cy, r0: e[0], r: e[1], startAngle: -n[0] * i, endAngle: -n[1] * i, clockwise: t.inverse, contain: function (t, e) { var n = t - this.cx, i = e - this.cy, o = n * n + i * i, a = this.r, s = this.r0; return a !== s && o - r <= a * a && o + r >= s * s; }, }; }), (t.prototype.convertToPixel = function (t, e, n) { return tE(e) === this ? this.dataToPoint(n) : null; }), (t.prototype.convertFromPixel = function (t, e, n) { return tE(e) === this ? this.pointToData(n) : null; }), t ); })(); function tE(t) { var e = t.seriesModel, n = t.polarModel; return (n && n.coordinateSystem) || (e && e.coordinateSystem); } function eE(t, e) { var n = this, i = n.getAngleAxis(), r = n.getRadiusAxis(); if ( (i.scale.setExtent(1 / 0, -1 / 0), r.scale.setExtent(1 / 0, -1 / 0), t.eachSeries(function (t) { if (t.coordinateSystem === n) { var e = t.getData(); E(C_(e, "radius"), function (t) { r.scale.unionExtentFromData(e, t); }), E(C_(e, "angle"), function (t) { i.scale.unionExtentFromData(e, t); }); } }), __(i.scale, i.model), __(r.scale, r.model), "category" === i.type && !i.onBand) ) { var o = i.getExtent(), a = 360 / i.scale.count(); i.inverse ? (o[1] += a) : (o[1] -= a), i.setExtent(o[0], o[1]); } } function nE(t, e) { var n; if ( ((t.type = e.get("type")), (t.scale = b_(e)), (t.onBand = e.get("boundaryGap") && "category" === t.type), (t.inverse = e.get("inverse")), (function (t) { return "angleAxis" === t.mainType; })(e)) ) { t.inverse = t.inverse !== e.get("clockwise"); var i = e.get("startAngle"), r = null !== (n = e.get("endAngle")) && void 0 !== n ? n : i + (t.inverse ? -360 : 360); t.setExtent(i, r); } (e.axis = t), (t.model = e); } var iE = { dimensions: JN, create: function (t, e) { var n = []; return ( t.eachComponent("polar", function (t, i) { var r = new QN(i + ""); r.update = eE; var o = r.getRadiusAxis(), a = r.getAngleAxis(), s = t.findAxisModel("radiusAxis"), l = t.findAxisModel("angleAxis"); nE(o, s), nE(a, l), (function (t, e, n) { var i = e.get("center"), r = n.getWidth(), o = n.getHeight(); (t.cx = $r(i[0], r)), (t.cy = $r(i[1], o)); var a = t.getRadiusAxis(), s = Math.min(r, o) / 2, l = e.get("radius"); null == l ? (l = [0, "100%"]) : Y(l) || (l = [0, l]); var u = [$r(l[0], s), $r(l[1], s)]; a.inverse ? a.setExtent(u[1], u[0]) : a.setExtent(u[0], u[1]); })(r, t, e), n.push(r), (t.coordinateSystem = r), (r.model = t); }), t.eachSeries(function (t) { if ("polar" === t.get("coordinateSystem")) { var e = t.getReferringComponents("polar", Wo) .models[0]; 0, (t.coordinateSystem = e.coordinateSystem); } }), n ); }, }, rE = [ "axisLine", "axisLabel", "axisTick", "minorTick", "splitLine", "minorSplitLine", "splitArea", ]; function oE(t, e, n) { e[1] > e[0] && (e = e.slice().reverse()); var i = t.coordToPoint([e[0], n]), r = t.coordToPoint([e[1], n]); return { x1: i[0], y1: i[1], x2: r[0], y2: r[1] }; } function aE(t) { return t.getRadiusAxis().inverse ? 0 : 1; } function sE(t) { var e = t[0], n = t[t.length - 1]; e && n && Math.abs(Math.abs(e.coord - n.coord) - 360) < 1e-4 && t.pop(); } var lE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.axisPointerClass = "PolarAxisPointer"), n ); } return ( n(e, t), (e.prototype.render = function (t, e) { if ((this.group.removeAll(), t.get("show"))) { var n = t.axis, i = n.polar, r = i.getRadiusAxis().getExtent(), o = n.getTicksCoords(), a = n.getMinorTicksCoords(), s = z(n.getViewLabels(), function (t) { t = T(t); var e = n.scale, i = "ordinal" === e.type ? e.getRawOrdinalNumber(t.tickValue) : t.tickValue; return (t.coord = n.dataToCoord(i)), t; }); sE(s), sE(o), E( rE, function (e) { !t.get([e, "show"]) || (n.scale.isBlank() && "axisLine" !== e) || uE[e](this.group, t, i, o, a, r, s); }, this ); } }), (e.type = "angleAxis"), e ); })(TI), uE = { axisLine: function (t, e, n, i, r, o) { var a, s = e.getModel(["axisLine", "lineStyle"]), l = n.getAngleAxis(), u = Math.PI / 180, h = l.getExtent(), c = aE(n), p = c ? 0 : 1, d = 360 === Math.abs(h[1] - h[0]) ? "Circle" : "Arc"; ((a = 0 === o[p] ? new Qh[d]({ shape: { cx: n.cx, cy: n.cy, r: o[c], startAngle: -h[0] * u, endAngle: -h[1] * u, clockwise: l.inverse, }, style: s.getLineStyle(), z2: 1, silent: !0, }) : new Wu({ shape: { cx: n.cx, cy: n.cy, r: o[c], r0: o[p] }, style: s.getLineStyle(), z2: 1, silent: !0, })).style.fill = null), t.add(a); }, axisTick: function (t, e, n, i, r, o) { var a = e.getModel("axisTick"), s = (a.get("inside") ? -1 : 1) * a.get("length"), l = o[aE(n)], u = z(i, function (t) { return new Ku({ shape: oE(n, [l, l + s], t.coord) }); }); t.add( Nh(u, { style: k(a.getModel("lineStyle").getLineStyle(), { stroke: e.get(["axisLine", "lineStyle", "color"]), }), }) ); }, minorTick: function (t, e, n, i, r, o) { if (r.length) { for ( var a = e.getModel("axisTick"), s = e.getModel("minorTick"), l = (a.get("inside") ? -1 : 1) * s.get("length"), u = o[aE(n)], h = [], c = 0; c < r.length; c++ ) for (var p = 0; p < r[c].length; p++) h.push( new Ku({ shape: oE(n, [u, u + l], r[c][p].coord), }) ); t.add( Nh(h, { style: k( s.getModel("lineStyle").getLineStyle(), k(a.getLineStyle(), { stroke: e.get([ "axisLine", "lineStyle", "color", ]), }) ), }) ); } }, axisLabel: function (t, e, n, i, r, o, a) { var s = e.getCategories(!0), l = e.getModel("axisLabel"), u = l.get("margin"), h = e.get("triggerEvent"); E( a, function (i, r) { var a = l, c = i.tickValue, p = o[aE(n)], d = n.coordToPoint([p + u, i.coord]), f = n.cx, g = n.cy, y = Math.abs(d[0] - f) / p < 0.3 ? "center" : d[0] > f ? "left" : "right", v = Math.abs(d[1] - g) / p < 0.3 ? "middle" : d[1] > g ? "top" : "bottom"; if (s && s[c]) { var m = s[c]; q(m) && m.textStyle && (a = new Cc(m.textStyle, l, l.ecModel)); } var x = new Xs({ silent: dI.isLabelSilent(e), style: oc(a, { x: d[0], y: d[1], fill: a.getTextColor() || e.get(["axisLine", "lineStyle", "color"]), text: i.formattedLabel, align: y, verticalAlign: v, }), }); if ((t.add(x), h)) { var _ = dI.makeAxisEventDataBase(e); (_.targetType = "axisLabel"), (_.value = i.rawLabel), (rl(x).eventData = _); } }, this ); }, splitLine: function (t, e, n, i, r, o) { var a = e.getModel("splitLine").getModel("lineStyle"), s = a.get("color"), l = 0; s = s instanceof Array ? s : [s]; for (var u = [], h = 0; h < i.length; h++) { var c = l++ % s.length; (u[c] = u[c] || []), u[c].push(new Ku({ shape: oE(n, o, i[h].coord) })); } for (h = 0; h < u.length; h++) t.add( Nh(u[h], { style: k( { stroke: s[h % s.length] }, a.getLineStyle() ), silent: !0, z: e.get("z"), }) ); }, minorSplitLine: function (t, e, n, i, r, o) { if (r.length) { for ( var a = e .getModel("minorSplitLine") .getModel("lineStyle"), s = [], l = 0; l < r.length; l++ ) for (var u = 0; u < r[l].length; u++) s.push(new Ku({ shape: oE(n, o, r[l][u].coord) })); t.add( Nh(s, { style: a.getLineStyle(), silent: !0, z: e.get("z"), }) ); } }, splitArea: function (t, e, n, i, r, o) { if (i.length) { var a = e.getModel("splitArea").getModel("areaStyle"), s = a.get("color"), l = 0; s = s instanceof Array ? s : [s]; for ( var u = [], h = Math.PI / 180, c = -i[0].coord * h, p = Math.min(o[0], o[1]), d = Math.max(o[0], o[1]), f = e.get("clockwise"), g = 1, y = i.length; g <= y; g++ ) { var v = g === y ? i[0].coord : i[g].coord, m = l++ % s.length; (u[m] = u[m] || []), u[m].push( new Fu({ shape: { cx: n.cx, cy: n.cy, r0: p, r: d, startAngle: c, endAngle: -v * h, clockwise: f, }, silent: !0, }) ), (c = -v * h); } for (g = 0; g < u.length; g++) t.add( Nh(u[g], { style: k( { fill: s[g % s.length] }, a.getAreaStyle() ), silent: !0, }) ); } }, }, hE = ["axisLine", "axisTickLabel", "axisName"], cE = ["splitLine", "splitArea", "minorSplitLine"], pE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.axisPointerClass = "PolarAxisPointer"), n ); } return ( n(e, t), (e.prototype.render = function (t, e) { if ((this.group.removeAll(), t.get("show"))) { var n = this._axisGroup, i = (this._axisGroup = new Br()); this.group.add(i); var r = t.axis, o = r.polar, a = o.getAngleAxis(), s = r.getTicksCoords(), l = r.getMinorTicksCoords(), u = a.getExtent()[0], h = r.getExtent(), c = (function (t, e, n) { return { position: [t.cx, t.cy], rotation: (n / 180) * Math.PI, labelDirection: -1, tickDirection: -1, nameDirection: 1, labelRotate: e .getModel("axisLabel") .get("rotate"), z2: 1, }; })(o, t, u), p = new dI(t, c); E(hE, p.add, p), i.add(p.getGroup()), Hh(n, i, t), E( cE, function (e) { t.get([e, "show"]) && !r.scale.isBlank() && dE[e](this.group, t, o, u, h, s, l); }, this ); } }), (e.type = "radiusAxis"), e ); })(TI), dE = { splitLine: function (t, e, n, i, r, o) { var a = e.getModel("splitLine").getModel("lineStyle"), s = a.get("color"), l = 0, u = n.getAngleAxis(), h = Math.PI / 180, c = u.getExtent(), p = 360 === Math.abs(c[1] - c[0]) ? "Circle" : "Arc"; s = s instanceof Array ? s : [s]; for (var d = [], f = 0; f < o.length; f++) { var g = l++ % s.length; (d[g] = d[g] || []), d[g].push( new Qh[p]({ shape: { cx: n.cx, cy: n.cy, r: Math.max(o[f].coord, 0), startAngle: -c[0] * h, endAngle: -c[1] * h, clockwise: u.inverse, }, }) ); } for (f = 0; f < d.length; f++) t.add( Nh(d[f], { style: k( { stroke: s[f % s.length], fill: null }, a.getLineStyle() ), silent: !0, }) ); }, minorSplitLine: function (t, e, n, i, r, o, a) { if (a.length) { for ( var s = e .getModel("minorSplitLine") .getModel("lineStyle"), l = [], u = 0; u < a.length; u++ ) for (var h = 0; h < a[u].length; h++) l.push( new Su({ shape: { cx: n.cx, cy: n.cy, r: a[u][h].coord, }, }) ); t.add( Nh(l, { style: k({ fill: null }, s.getLineStyle()), silent: !0, }) ); } }, splitArea: function (t, e, n, i, r, o) { if (o.length) { var a = e.getModel("splitArea").getModel("areaStyle"), s = a.get("color"), l = 0; s = s instanceof Array ? s : [s]; for (var u = [], h = o[0].coord, c = 1; c < o.length; c++) { var p = l++ % s.length; (u[p] = u[p] || []), u[p].push( new Fu({ shape: { cx: n.cx, cy: n.cy, r0: h, r: o[c].coord, startAngle: 0, endAngle: 2 * Math.PI, }, silent: !0, }) ), (h = o[c].coord); } for (c = 0; c < u.length; c++) t.add( Nh(u[c], { style: k( { fill: s[c % s.length] }, a.getAreaStyle() ), silent: !0, }) ); } }, }; function fE(t) { return t.get("stack") || "__ec_stack_" + t.seriesIndex; } function gE(t, e) { return e.dim + t.model.componentIndex; } function yE(t, e, n) { var i = {}, r = (function (t) { var e = {}; E(t, function (t, n) { var i = t.getData(), r = t.coordinateSystem, o = r.getBaseAxis(), a = gE(r, o), s = o.getExtent(), l = "category" === o.type ? o.getBandWidth() : Math.abs(s[1] - s[0]) / i.count(), u = e[a] || { bandWidth: l, remainedWidth: l, autoWidthCount: 0, categoryGap: "20%", gap: "30%", stacks: {}, }, h = u.stacks; e[a] = u; var c = fE(t); h[c] || u.autoWidthCount++, (h[c] = h[c] || { width: 0, maxWidth: 0 }); var p = $r(t.get("barWidth"), l), d = $r(t.get("barMaxWidth"), l), f = t.get("barGap"), g = t.get("barCategoryGap"); p && !h[c].width && ((p = Math.min(u.remainedWidth, p)), (h[c].width = p), (u.remainedWidth -= p)), d && (h[c].maxWidth = d), null != f && (u.gap = f), null != g && (u.categoryGap = g); }); var n = {}; return ( E(e, function (t, e) { n[e] = {}; var i = t.stacks, r = t.bandWidth, o = $r(t.categoryGap, r), a = $r(t.gap, 1), s = t.remainedWidth, l = t.autoWidthCount, u = (s - o) / (l + (l - 1) * a); (u = Math.max(u, 0)), E(i, function (t, e) { var n = t.maxWidth; n && n < u && ((n = Math.min(n, s)), t.width && (n = Math.min(n, t.width)), (s -= n), (t.width = n), l--); }), (u = (s - o) / (l + (l - 1) * a)), (u = Math.max(u, 0)); var h, c = 0; E(i, function (t, e) { t.width || (t.width = u), (h = t), (c += t.width * (1 + a)); }), h && (c -= h.width * a); var p = -c / 2; E(i, function (t, i) { (n[e][i] = n[e][i] || { offset: p, width: t.width, }), (p += t.width * (1 + a)); }); }), n ); })( B(e.getSeriesByType(t), function (t) { return ( !e.isSeriesFiltered(t) && t.coordinateSystem && "polar" === t.coordinateSystem.type ); }) ); e.eachSeriesByType(t, function (t) { if ("polar" === t.coordinateSystem.type) { var e = t.getData(), n = t.coordinateSystem, o = n.getBaseAxis(), a = gE(n, o), s = fE(t), l = r[a][s], u = l.offset, h = l.width, c = n.getOtherAxis(o), p = t.coordinateSystem.cx, d = t.coordinateSystem.cy, f = t.get("barMinHeight") || 0, g = t.get("barMinAngle") || 0; i[s] = i[s] || []; for ( var y = e.mapDimension(c.dim), v = e.mapDimension(o.dim), m = mx(e, y), x = "radius" !== o.dim || !t.get("roundCap", !0), _ = c.model.get("startValue"), b = c.dataToCoord(_ || 0), w = 0, S = e.count(); w < S; w++ ) { var M = e.get(y, w), I = e.get(v, w), T = M >= 0 ? "p" : "n", C = b; m && (i[s][I] || (i[s][I] = { p: b, n: b }), (C = i[s][I][T])); var D = void 0, A = void 0, k = void 0, L = void 0; if ("radius" === c.dim) { var P = c.dataToCoord(M) - b, O = o.dataToCoord(I); Math.abs(P) < f && (P = (P < 0 ? -1 : 1) * f), (D = C), (A = C + P), (L = (k = O - u) - h), m && (i[s][I][T] = A); } else { var R = c.dataToCoord(M, x) - b, N = o.dataToCoord(I); Math.abs(R) < g && (R = (R < 0 ? -1 : 1) * g), (A = (D = N + u) + h), (k = C), (L = C + R), m && (i[s][I][T] = L); } e.setItemLayout(w, { cx: p, cy: d, r0: D, r: A, startAngle: (-k * Math.PI) / 180, endAngle: (-L * Math.PI) / 180, clockwise: k >= L, }); } } }); } var vE = { startAngle: 90, clockwise: !0, splitNumber: 12, axisLabel: { rotate: 0 }, }, mE = { splitNumber: 5 }, xE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "polar"), e; })(Ag); function _E(t, e) { e = e || {}; var n = t.coordinateSystem, i = t.axis, r = {}, o = i.position, a = i.orient, s = n.getRect(), l = [s.x, s.x + s.width, s.y, s.y + s.height], u = { horizontal: { top: l[2], bottom: l[3] }, vertical: { left: l[0], right: l[1] }, }; r.position = [ "vertical" === a ? u.vertical[o] : l[0], "horizontal" === a ? u.horizontal[o] : l[3], ]; r.rotation = (Math.PI / 2) * { horizontal: 0, vertical: 1 }[a]; (r.labelDirection = r.tickDirection = r.nameDirection = { top: -1, bottom: 1, right: 1, left: -1 }[o]), t.get(["axisTick", "inside"]) && (r.tickDirection = -r.tickDirection), it(e.labelInside, t.get(["axisLabel", "inside"])) && (r.labelDirection = -r.labelDirection); var h = e.rotate; return ( null == h && (h = t.get(["axisLabel", "rotate"])), (r.labelRotation = "top" === o ? -h : h), (r.z2 = 1), r ); } var bE = ["axisLine", "axisTickLabel", "axisName"], wE = ["splitArea", "splitLine"], SE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.axisPointerClass = "SingleAxisPointer"), n ); } return ( n(e, t), (e.prototype.render = function (e, n, i, r) { var o = this.group; o.removeAll(); var a = this._axisGroup; this._axisGroup = new Br(); var s = _E(e), l = new dI(e, s); E(bE, l.add, l), o.add(this._axisGroup), o.add(l.getGroup()), E( wE, function (t) { e.get([t, "show"]) && ME[t](this, this.group, this._axisGroup, e); }, this ), Hh(a, this._axisGroup, e), t.prototype.render.call(this, e, n, i, r); }), (e.prototype.remove = function () { AI(this); }), (e.type = "singleAxis"), e ); })(TI), ME = { splitLine: function (t, e, n, i) { var r = i.axis; if (!r.scale.isBlank()) { var o = i.getModel("splitLine"), a = o.getModel("lineStyle"), s = a.get("color"); s = s instanceof Array ? s : [s]; for ( var l = a.get("width"), u = i.coordinateSystem.getRect(), h = r.isHorizontal(), c = [], p = 0, d = r.getTicksCoords({ tickModel: o }), f = [], g = [], y = 0; y < d.length; ++y ) { var v = r.toGlobalCoord(d[y].coord); h ? ((f[0] = v), (f[1] = u.y), (g[0] = v), (g[1] = u.y + u.height)) : ((f[0] = u.x), (f[1] = v), (g[0] = u.x + u.width), (g[1] = v)); var m = new Ku({ shape: { x1: f[0], y1: f[1], x2: g[0], y2: g[1] }, silent: !0, }); zh(m.shape, l); var x = p++ % s.length; (c[x] = c[x] || []), c[x].push(m); } var _ = a.getLineStyle(["color"]); for (y = 0; y < c.length; ++y) e.add( Nh(c[y], { style: k({ stroke: s[y % s.length] }, _), silent: !0, }) ); } }, splitArea: function (t, e, n, i) { DI(t, n, i, i); }, }, IE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.getCoordSysModel = function () { return this; }), (e.type = "singleAxis"), (e.layoutMode = "box"), (e.defaultOption = { left: "5%", top: "5%", right: "5%", bottom: "5%", type: "value", position: "bottom", orient: "horizontal", axisLine: { show: !0, lineStyle: { width: 1, type: "solid" }, }, tooltip: { show: !0 }, axisTick: { show: !0, length: 6, lineStyle: { width: 1 } }, axisLabel: { show: !0, interval: "auto" }, splitLine: { show: !0, lineStyle: { type: "dashed", opacity: 0.2 }, }, }), e ); })(zp); R(IE, D_.prototype); var TE = (function (t) { function e(e, n, i, r, o) { var a = t.call(this, e, n, i) || this; return (a.type = r || "value"), (a.position = o || "bottom"), a; } return ( n(e, t), (e.prototype.isHorizontal = function () { var t = this.position; return "top" === t || "bottom" === t; }), (e.prototype.pointToData = function (t, e) { return this.coordinateSystem.pointToData(t)[0]; }), e ); })(ab), CE = ["single"], DE = (function () { function t(t, e, n) { (this.type = "single"), (this.dimension = "single"), (this.dimensions = CE), (this.axisPointerEnabled = !0), (this.model = t), this._init(t, e, n); } return ( (t.prototype._init = function (t, e, n) { var i = this.dimension, r = new TE( i, b_(t), [0, 0], t.get("type"), t.get("position") ), o = "category" === r.type; (r.onBand = o && t.get("boundaryGap")), (r.inverse = t.get("inverse")), (r.orient = t.get("orient")), (t.axis = r), (r.model = t), (r.coordinateSystem = this), (this._axis = r); }), (t.prototype.update = function (t, e) { t.eachSeries(function (t) { if (t.coordinateSystem === this) { var e = t.getData(); E( e.mapDimensionsAll(this.dimension), function (t) { this._axis.scale.unionExtentFromData(e, t); }, this ), __(this._axis.scale, this._axis.model); } }, this); }), (t.prototype.resize = function (t, e) { (this._rect = kp( { left: t.get("left"), top: t.get("top"), right: t.get("right"), bottom: t.get("bottom"), width: t.get("width"), height: t.get("height"), }, { width: e.getWidth(), height: e.getHeight() } )), this._adjustAxis(); }), (t.prototype.getRect = function () { return this._rect; }), (t.prototype._adjustAxis = function () { var t = this._rect, e = this._axis, n = e.isHorizontal(), i = n ? [0, t.width] : [0, t.height], r = e.inverse ? 1 : 0; e.setExtent(i[r], i[1 - r]), this._updateAxisTransform(e, n ? t.x : t.y); }), (t.prototype._updateAxisTransform = function (t, e) { var n = t.getExtent(), i = n[0] + n[1], r = t.isHorizontal(); (t.toGlobalCoord = r ? function (t) { return t + e; } : function (t) { return i - t + e; }), (t.toLocalCoord = r ? function (t) { return t - e; } : function (t) { return i - t + e; }); }), (t.prototype.getAxis = function () { return this._axis; }), (t.prototype.getBaseAxis = function () { return this._axis; }), (t.prototype.getAxes = function () { return [this._axis]; }), (t.prototype.getTooltipAxes = function () { return { baseAxes: [this.getAxis()], otherAxes: [] }; }), (t.prototype.containPoint = function (t) { var e = this.getRect(), n = this.getAxis(); return "horizontal" === n.orient ? n.contain(n.toLocalCoord(t[0])) && t[1] >= e.y && t[1] <= e.y + e.height : n.contain(n.toLocalCoord(t[1])) && t[0] >= e.y && t[0] <= e.y + e.height; }), (t.prototype.pointToData = function (t) { var e = this.getAxis(); return [ e.coordToData( e.toLocalCoord(t["horizontal" === e.orient ? 0 : 1]) ), ]; }), (t.prototype.dataToPoint = function (t) { var e = this.getAxis(), n = this.getRect(), i = [], r = "horizontal" === e.orient ? 0 : 1; return ( t instanceof Array && (t = t[0]), (i[r] = e.toGlobalCoord(e.dataToCoord(+t))), (i[1 - r] = 0 === r ? n.y + n.height / 2 : n.x + n.width / 2), i ); }), (t.prototype.convertToPixel = function (t, e, n) { return AE(e) === this ? this.dataToPoint(n) : null; }), (t.prototype.convertFromPixel = function (t, e, n) { return AE(e) === this ? this.pointToData(n) : null; }), t ); })(); function AE(t) { var e = t.seriesModel, n = t.singleAxisModel; return (n && n.coordinateSystem) || (e && e.coordinateSystem); } var kE = { create: function (t, e) { var n = []; return ( t.eachComponent("singleAxis", function (i, r) { var o = new DE(i, t, e); (o.name = "single_" + r), o.resize(i, e), (i.coordinateSystem = o), n.push(o); }), t.eachSeries(function (t) { if ("singleAxis" === t.get("coordinateSystem")) { var e = t.getReferringComponents("singleAxis", Wo) .models[0]; t.coordinateSystem = e && e.coordinateSystem; } }), n ); }, dimensions: CE, }, LE = ["x", "y"], PE = ["width", "height"], OE = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.makeElOption = function (t, e, n, i, r) { var o = n.axis, a = o.coordinateSystem, s = EE(a, 1 - NE(o)), l = a.dataToPoint(e)[0], u = i.get("type"); if (u && "none" !== u) { var h = fN(i), c = RE[u](o, l, s); (c.style = h), (t.graphicKey = c.type), (t.pointer = c); } mN(e, t, _E(n), n, i, r); }), (e.prototype.getHandleTransform = function (t, e, n) { var i = _E(e, { labelInside: !1 }); i.labelMargin = n.get(["handle", "margin"]); var r = vN(e.axis, t, i); return { x: r[0], y: r[1], rotation: i.rotation + (i.labelDirection < 0 ? Math.PI : 0), }; }), (e.prototype.updateHandleTransform = function (t, e, n, i) { var r = n.axis, o = r.coordinateSystem, a = NE(r), s = EE(o, a), l = [t.x, t.y]; (l[a] += e[a]), (l[a] = Math.min(s[1], l[a])), (l[a] = Math.max(s[0], l[a])); var u = EE(o, 1 - a), h = (u[1] + u[0]) / 2, c = [h, h]; return ( (c[a] = l[a]), { x: l[0], y: l[1], rotation: t.rotation, cursorPoint: c, tooltipOption: { verticalAlign: "middle" }, } ); }), e ); })(lN), RE = { line: function (t, e, n) { return { type: "Line", subPixelOptimize: !0, shape: xN([e, n[0]], [e, n[1]], NE(t)), }; }, shadow: function (t, e, n) { var i = t.getBandWidth(), r = n[1] - n[0]; return { type: "Rect", shape: _N([e - i / 2, n[0]], [i, r], NE(t)), }; }, }; function NE(t) { return t.isHorizontal() ? 0 : 1; } function EE(t, e) { var n = t.getRect(); return [n[LE[e]], n[LE[e]] + n[PE[e]]]; } var zE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "single"), e; })(Ag); var VE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (e, n, i) { var r = Rp(e); t.prototype.init.apply(this, arguments), BE(e, r); }), (e.prototype.mergeOption = function (e) { t.prototype.mergeOption.apply(this, arguments), BE(this.option, e); }), (e.prototype.getCellSize = function () { return this.option.cellSize; }), (e.type = "calendar"), (e.defaultOption = { z: 2, left: 80, top: 60, cellSize: 20, orient: "horizontal", splitLine: { show: !0, lineStyle: { color: "#000", width: 1, type: "solid" }, }, itemStyle: { color: "#fff", borderWidth: 1, borderColor: "#ccc", }, dayLabel: { show: !0, firstDay: 0, position: "start", margin: "50%", color: "#000", }, monthLabel: { show: !0, position: "start", margin: 5, align: "center", formatter: null, color: "#000", }, yearLabel: { show: !0, position: null, margin: 30, formatter: null, color: "#ccc", fontFamily: "sans-serif", fontWeight: "bolder", fontSize: 20, }, }), e ); })(zp); function BE(t, e) { var n, i = t.cellSize; 1 === (n = Y(i) ? i : (t.cellSize = [i, i])).length && (n[1] = n[0]); var r = z([0, 1], function (t) { return ( (function (t, e) { return ( null != t[Cp[e][0]] || (null != t[Cp[e][1]] && null != t[Cp[e][2]]) ); })(e, t) && (n[t] = "auto"), null != n[t] && "auto" !== n[t] ); }); Op(t, e, { type: "box", ignoreSize: r }); } var FE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i = this.group; i.removeAll(); var r = t.coordinateSystem, o = r.getRangeInfo(), a = r.getOrient(), s = e.getLocaleModel(); this._renderDayRect(t, o, i), this._renderLines(t, o, a, i), this._renderYearText(t, o, a, i), this._renderMonthText(t, s, a, i), this._renderWeekText(t, s, o, a, i); }), (e.prototype._renderDayRect = function (t, e, n) { for ( var i = t.coordinateSystem, r = t.getModel("itemStyle").getItemStyle(), o = i.getCellWidth(), a = i.getCellHeight(), s = e.start.time; s <= e.end.time; s = i.getNextNDay(s, 1).time ) { var l = i.dataToRect([s], !1).tl, u = new Ws({ shape: { x: l[0], y: l[1], width: o, height: a, }, cursor: "default", style: r, }); n.add(u); } }), (e.prototype._renderLines = function (t, e, n, i) { var r = this, o = t.coordinateSystem, a = t .getModel(["splitLine", "lineStyle"]) .getLineStyle(), s = t.get(["splitLine", "show"]), l = a.lineWidth; (this._tlpoints = []), (this._blpoints = []), (this._firstDayOfMonth = []), (this._firstDayPoints = []); for (var u = e.start, h = 0; u.time <= e.end.time; h++) { p(u.formatedDate), 0 === h && (u = o.getDateInfo( e.start.y + "-" + e.start.m )); var c = u.date; c.setMonth(c.getMonth() + 1), (u = o.getDateInfo(c)); } function p(e) { r._firstDayOfMonth.push(o.getDateInfo(e)), r._firstDayPoints.push(o.dataToRect([e], !1).tl); var l = r._getLinePointsOfOneWeek(t, e, n); r._tlpoints.push(l[0]), r._blpoints.push(l[l.length - 1]), s && r._drawSplitline(l, a, i); } p(o.getNextNDay(e.end.time, 1).formatedDate), s && this._drawSplitline( r._getEdgesPoints(r._tlpoints, l, n), a, i ), s && this._drawSplitline( r._getEdgesPoints(r._blpoints, l, n), a, i ); }), (e.prototype._getEdgesPoints = function (t, e, n) { var i = [t[0].slice(), t[t.length - 1].slice()], r = "horizontal" === n ? 0 : 1; return ( (i[0][r] = i[0][r] - e / 2), (i[1][r] = i[1][r] + e / 2), i ); }), (e.prototype._drawSplitline = function (t, e, n) { var i = new Zu({ z2: 20, shape: { points: t }, style: e }); n.add(i); }), (e.prototype._getLinePointsOfOneWeek = function (t, e, n) { for ( var i = t.coordinateSystem, r = i.getDateInfo(e), o = [], a = 0; a < 7; a++ ) { var s = i.getNextNDay(r.time, a), l = i.dataToRect([s.time], !1); (o[2 * s.day] = l.tl), (o[2 * s.day + 1] = l["horizontal" === n ? "bl" : "tr"]); } return o; }), (e.prototype._formatterLabel = function (t, e) { return U(t) && t ? ((n = t), E(e, function (t, e) { n = n.replace("{" + e + "}", i ? re(t) : t); }), n) : X(t) ? t(e) : e.nameMap; var n, i; }), (e.prototype._yearTextPositionControl = function ( t, e, n, i, r ) { var o = e[0], a = e[1], s = ["center", "bottom"]; "bottom" === i ? ((a += r), (s = ["center", "top"])) : "left" === i ? (o -= r) : "right" === i ? ((o += r), (s = ["center", "top"])) : (a -= r); var l = 0; return ( ("left" !== i && "right" !== i) || (l = Math.PI / 2), { rotation: l, x: o, y: a, style: { align: s[0], verticalAlign: s[1] }, } ); }), (e.prototype._renderYearText = function (t, e, n, i) { var r = t.getModel("yearLabel"); if (r.get("show")) { var o = r.get("margin"), a = r.get("position"); a || (a = "horizontal" !== n ? "top" : "left"); var s = [ this._tlpoints[this._tlpoints.length - 1], this._blpoints[0], ], l = (s[0][0] + s[1][0]) / 2, u = (s[0][1] + s[1][1]) / 2, h = "horizontal" === n ? 0 : 1, c = { top: [l, s[h][1]], bottom: [l, s[1 - h][1]], left: [s[1 - h][0], u], right: [s[h][0], u], }, p = e.start.y; +e.end.y > +e.start.y && (p = p + "-" + e.end.y); var d = r.get("formatter"), f = { start: e.start.y, end: e.end.y, nameMap: p }, g = this._formatterLabel(d, f), y = new Xs({ z2: 30, style: oc(r, { text: g }), silent: r.get("silent"), }); y.attr(this._yearTextPositionControl(y, c[a], n, a, o)), i.add(y); } }), (e.prototype._monthTextPositionControl = function ( t, e, n, i, r ) { var o = "left", a = "top", s = t[0], l = t[1]; return ( "horizontal" === n ? ((l += r), e && (o = "center"), "start" === i && (a = "bottom")) : ((s += r), e && (a = "middle"), "start" === i && (o = "right")), { x: s, y: l, align: o, verticalAlign: a } ); }), (e.prototype._renderMonthText = function (t, e, n, i) { var r = t.getModel("monthLabel"); if (r.get("show")) { var o = r.get("nameMap"), a = r.get("margin"), s = r.get("position"), l = r.get("align"), u = [this._tlpoints, this._blpoints]; (o && !U(o)) || (o && (e = Vc(o) || e), (o = e.get(["time", "monthAbbr"]) || [])); var h = "start" === s ? 0 : 1, c = "horizontal" === n ? 0 : 1; a = "start" === s ? -a : a; for ( var p = "center" === l, d = r.get("silent"), f = 0; f < u[h].length - 1; f++ ) { var g = u[h][f].slice(), y = this._firstDayOfMonth[f]; if (p) { var v = this._firstDayPoints[f]; g[c] = (v[c] + u[0][f + 1][c]) / 2; } var m = r.get("formatter"), x = o[+y.m - 1], _ = { yyyy: y.y, yy: (y.y + "").slice(2), MM: y.m, M: +y.m, nameMap: x, }, b = this._formatterLabel(m, _), w = new Xs({ z2: 30, style: A( oc(r, { text: b }), this._monthTextPositionControl( g, p, n, s, a ) ), silent: d, }); i.add(w); } } }), (e.prototype._weekTextPositionControl = function ( t, e, n, i, r ) { var o = "center", a = "middle", s = t[0], l = t[1], u = "start" === n; return ( "horizontal" === e ? ((s = s + i + ((u ? 1 : -1) * r[0]) / 2), (o = u ? "right" : "left")) : ((l = l + i + ((u ? 1 : -1) * r[1]) / 2), (a = u ? "bottom" : "top")), { x: s, y: l, align: o, verticalAlign: a } ); }), (e.prototype._renderWeekText = function (t, e, n, i, r) { var o = t.getModel("dayLabel"); if (o.get("show")) { var a = t.coordinateSystem, s = o.get("position"), l = o.get("nameMap"), u = o.get("margin"), h = a.getFirstDayOfWeek(); if (!l || U(l)) l && (e = Vc(l) || e), (l = e.get(["time", "dayOfWeekShort"]) || z( e.get(["time", "dayOfWeekAbbr"]), function (t) { return t[0]; } )); var c = a.getNextNDay(n.end.time, 7 - n.lweek).time, p = [a.getCellWidth(), a.getCellHeight()]; (u = $r(u, Math.min(p[1], p[0]))), "start" === s && ((c = a.getNextNDay( n.start.time, -(7 + n.fweek) ).time), (u = -u)); for (var d = o.get("silent"), f = 0; f < 7; f++) { var g, y = a.getNextNDay(c, f), v = a.dataToRect([y.time], !1).center; g = Math.abs((f + h) % 7); var m = new Xs({ z2: 30, style: A( oc(o, { text: l[g] }), this._weekTextPositionControl(v, i, s, u, p) ), silent: d, }); r.add(m); } } }), (e.type = "calendar"), e ); })(Ag), GE = 864e5, WE = (function () { function t(e, n, i) { (this.type = "calendar"), (this.dimensions = t.dimensions), (this.getDimensionsInfo = t.getDimensionsInfo), (this._model = e); } return ( (t.getDimensionsInfo = function () { return [{ name: "time", type: "time" }, "value"]; }), (t.prototype.getRangeInfo = function () { return this._rangeInfo; }), (t.prototype.getModel = function () { return this._model; }), (t.prototype.getRect = function () { return this._rect; }), (t.prototype.getCellWidth = function () { return this._sw; }), (t.prototype.getCellHeight = function () { return this._sh; }), (t.prototype.getOrient = function () { return this._orient; }), (t.prototype.getFirstDayOfWeek = function () { return this._firstDayOfWeek; }), (t.prototype.getDateInfo = function (t) { var e = (t = uo(t)).getFullYear(), n = t.getMonth() + 1, i = n < 10 ? "0" + n : "" + n, r = t.getDate(), o = r < 10 ? "0" + r : "" + r, a = t.getDay(); return { y: e + "", m: i, d: o, day: (a = Math.abs( (a + 7 - this.getFirstDayOfWeek()) % 7 )), time: t.getTime(), formatedDate: e + "-" + i + "-" + o, date: t, }; }), (t.prototype.getNextNDay = function (t, e) { return ( 0 === (e = e || 0) || (t = new Date(this.getDateInfo(t).time)).setDate( t.getDate() + e ), this.getDateInfo(t) ); }), (t.prototype.update = function (t, e) { (this._firstDayOfWeek = +this._model .getModel("dayLabel") .get("firstDay")), (this._orient = this._model.get("orient")), (this._lineWidth = this._model.getModel("itemStyle").getItemStyle() .lineWidth || 0), (this._rangeInfo = this._getRangeInfo( this._initRangeOption() )); var n = this._rangeInfo.weeks || 1, i = ["width", "height"], r = this._model.getCellSize().slice(), o = this._model.getBoxLayoutParams(), a = "horizontal" === this._orient ? [n, 7] : [7, n]; E([0, 1], function (t) { u(r, t) && (o[i[t]] = r[t] * a[t]); }); var s = { width: e.getWidth(), height: e.getHeight() }, l = (this._rect = kp(o, s)); function u(t, e) { return null != t[e] && "auto" !== t[e]; } E([0, 1], function (t) { u(r, t) || (r[t] = l[i[t]] / a[t]); }), (this._sw = r[0]), (this._sh = r[1]); }), (t.prototype.dataToPoint = function (t, e) { Y(t) && (t = t[0]), null == e && (e = !0); var n = this.getDateInfo(t), i = this._rangeInfo, r = n.formatedDate; if ( e && !(n.time >= i.start.time && n.time < i.end.time + GE) ) return [NaN, NaN]; var o = n.day, a = this._getRangeInfo([i.start.time, r]).nthWeek; return "vertical" === this._orient ? [ this._rect.x + o * this._sw + this._sw / 2, this._rect.y + a * this._sh + this._sh / 2, ] : [ this._rect.x + a * this._sw + this._sw / 2, this._rect.y + o * this._sh + this._sh / 2, ]; }), (t.prototype.pointToData = function (t) { var e = this.pointToDate(t); return e && e.time; }), (t.prototype.dataToRect = function (t, e) { var n = this.dataToPoint(t, e); return { contentShape: { x: n[0] - (this._sw - this._lineWidth) / 2, y: n[1] - (this._sh - this._lineWidth) / 2, width: this._sw - this._lineWidth, height: this._sh - this._lineWidth, }, center: n, tl: [n[0] - this._sw / 2, n[1] - this._sh / 2], tr: [n[0] + this._sw / 2, n[1] - this._sh / 2], br: [n[0] + this._sw / 2, n[1] + this._sh / 2], bl: [n[0] - this._sw / 2, n[1] + this._sh / 2], }; }), (t.prototype.pointToDate = function (t) { var e = Math.floor((t[0] - this._rect.x) / this._sw) + 1, n = Math.floor((t[1] - this._rect.y) / this._sh) + 1, i = this._rangeInfo.range; return "vertical" === this._orient ? this._getDateByWeeksAndDay(n, e - 1, i) : this._getDateByWeeksAndDay(e, n - 1, i); }), (t.prototype.convertToPixel = function (t, e, n) { var i = HE(e); return i === this ? i.dataToPoint(n) : null; }), (t.prototype.convertFromPixel = function (t, e, n) { var i = HE(e); return i === this ? i.pointToData(n) : null; }), (t.prototype.containPoint = function (t) { return console.warn("Not implemented."), !1; }), (t.prototype._initRangeOption = function () { var t, e = this._model.get("range"); if ((Y(e) && 1 === e.length && (e = e[0]), Y(e))) t = e; else { var n = e.toString(); if ( (/^\d{4}$/.test(n) && (t = [n + "-01-01", n + "-12-31"]), /^\d{4}[\/|-]\d{1,2}$/.test(n)) ) { var i = this.getDateInfo(n), r = i.date; r.setMonth(r.getMonth() + 1); var o = this.getNextNDay(r, -1); t = [i.formatedDate, o.formatedDate]; } /^\d{4}[\/|-]\d{1,2}[\/|-]\d{1,2}$/.test(n) && (t = [n, n]); } if (!t) return e; var a = this._getRangeInfo(t); return a.start.time > a.end.time && t.reverse(), t; }), (t.prototype._getRangeInfo = function (t) { var e, n = [this.getDateInfo(t[0]), this.getDateInfo(t[1])]; n[0].time > n[1].time && ((e = !0), n.reverse()); var i = Math.floor(n[1].time / GE) - Math.floor(n[0].time / GE) + 1, r = new Date(n[0].time), o = r.getDate(), a = n[1].date.getDate(); r.setDate(o + i - 1); var s = r.getDate(); if (s !== a) for ( var l = r.getTime() - n[1].time > 0 ? 1 : -1; (s = r.getDate()) !== a && (r.getTime() - n[1].time) * l > 0; ) (i -= l), r.setDate(s - l); var u = Math.floor((i + n[0].day + 6) / 7), h = e ? 1 - u : u - 1; return ( e && n.reverse(), { range: [n[0].formatedDate, n[1].formatedDate], start: n[0], end: n[1], allDay: i, weeks: u, nthWeek: h, fweek: n[0].day, lweek: n[1].day, } ); }), (t.prototype._getDateByWeeksAndDay = function (t, e, n) { var i = this._getRangeInfo(n); if ( t > i.weeks || (0 === t && e < i.fweek) || (t === i.weeks && e > i.lweek) ) return null; var r = 7 * (t - 1) - i.fweek + e, o = new Date(i.start.time); return o.setDate(+i.start.d + r), this.getDateInfo(o); }), (t.create = function (e, n) { var i = []; return ( e.eachComponent("calendar", function (r) { var o = new t(r, e, n); i.push(o), (r.coordinateSystem = o); }), e.eachSeries(function (t) { "calendar" === t.get("coordinateSystem") && (t.coordinateSystem = i[t.get("calendarIndex") || 0]); }), i ); }), (t.dimensions = ["time", "value"]), t ); })(); function HE(t) { var e = t.calendarModel, n = t.seriesModel; return e ? e.coordinateSystem : n ? n.coordinateSystem : null; } function YE(t, e) { var n; return ( E(e, function (e) { null != t[e] && "auto" !== t[e] && (n = !0); }), n ); } var XE = ["transition", "enterFrom", "leaveTo"], UE = XE.concat(["enterAnimation", "updateAnimation", "leaveAnimation"]); function ZE(t, e, n) { if ( (n && (!t[n] && e[n] && (t[n] = {}), (t = t[n]), (e = e[n])), t && e) ) for (var i = n ? XE : UE, r = 0; r < i.length; r++) { var o = i[r]; null == t[o] && null != e[o] && (t[o] = e[o]); } } var jE = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.preventAutoZ = !0), n; } return ( n(e, t), (e.prototype.mergeOption = function (e, n) { var i = this.option.elements; (this.option.elements = null), t.prototype.mergeOption.call(this, e, n), (this.option.elements = i); }), (e.prototype.optionUpdated = function (t, e) { var n = this.option, i = (e ? n : t).elements, r = (n.elements = e ? [] : n.elements), o = []; this._flatten(i, o, null); var a = Lo(r, o, "normalMerge"), s = (this._elOptionsToUpdate = []); E( a, function (t, e) { var n = t.newOption; n && (s.push(n), (function (t, e) { var n = t.existing; if ( ((e.id = t.keyInfo.id), !e.type && n && (e.type = n.type), null == e.parentId) ) { var i = e.parentOption; i ? (e.parentId = i.id) : n && (e.parentId = n.parentId); } e.parentOption = null; })(t, n), (function (t, e, n) { var i = A({}, n), r = t[e], o = n.$action || "merge"; "merge" === o ? r ? (C(r, i, !0), Op(r, i, { ignoreSize: !0 }), Np(n, r), ZE(n, r), ZE(n, r, "shape"), ZE(n, r, "style"), ZE(n, r, "extra"), (n.clipPath = r.clipPath)) : (t[e] = i) : "replace" === o ? (t[e] = i) : "remove" === o && r && (t[e] = null); })(r, e, n), (function (t, e) { if ( t && ((t.hv = e.hv = [ YE(e, ["left", "right"]), YE(e, ["top", "bottom"]), ]), "group" === t.type) ) { var n = t, i = e; null == n.width && (n.width = i.width = 0), null == n.height && (n.height = i.height = 0); } })(r[e], n)); }, this ), (n.elements = B(r, function (t) { return t && delete t.$action, null != t; })); }), (e.prototype._flatten = function (t, e, n) { E( t, function (t) { if (t) { n && (t.parentOption = n), e.push(t); var i = t.children; i && i.length && this._flatten(i, e, t), delete t.children; } }, this ); }), (e.prototype.useElOptionsToUpdate = function () { var t = this._elOptionsToUpdate; return (this._elOptionsToUpdate = null), t; }), (e.type = "graphic"), (e.defaultOption = { elements: [] }), e ); })(zp), qE = { path: null, compoundPath: null, group: Br, image: Ns, text: Xs }, KE = Vo(), $E = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function () { this._elMap = yt(); }), (e.prototype.render = function (t, e, n) { t !== this._lastGraphicModel && this._clear(), (this._lastGraphicModel = t), this._updateElements(t), this._relocate(t, n); }), (e.prototype._updateElements = function (t) { var e = t.useElOptionsToUpdate(); if (e) { var n = this._elMap, i = this.group, r = t.get("z"), o = t.get("zlevel"); E(e, function (e) { var a = Ro(e.id, null), s = null != a ? n.get(a) : null, l = Ro(e.parentId, null), u = null != l ? n.get(l) : i, h = e.type, c = e.style; "text" === h && c && e.hv && e.hv[1] && (c.textVerticalAlign = c.textBaseline = c.verticalAlign = c.align = null); var p = e.textContent, d = e.textConfig; if (c && oR(c, h, !!d, !!p)) { var f = aR(c, h, !0); !d && f.textConfig && (d = e.textConfig = f.textConfig), !p && f.textContent && (p = f.textContent); } var g = (function (t) { return ( (t = A({}, t)), E( [ "id", "parentId", "$action", "hv", "bounding", "textContent", "clipPath", ].concat(Tp), function (e) { delete t[e]; } ), t ); })(e); var y = e.$action || "merge", v = "merge" === y, m = "replace" === y; if (v) { var x = s; (T = !s) ? (x = QE(a, u, e.type, n)) : (x && (KE(x).isNew = !1), CR(x)), x && (gR(x, g, t, { isInit: T }), ez(x, e, r, o)); } else if (m) { tz(s, e, n, t); var _ = QE(a, u, e.type, n); _ && (gR(_, g, t, { isInit: !0 }), ez(_, e, r, o)); } else "remove" === y && (yR(s, e), tz(s, e, n, t)); var b = n.get(a); if (b && p) if (v) { var w = b.getTextContent(); w ? w.attr(p) : b.setTextContent(new Xs(p)); } else m && b.setTextContent(new Xs(p)); if (b) { var S = e.clipPath; if (S) { var M = S.type, I = void 0, T = !1; if (v) { var C = b.getClipPath(); I = (T = !C || KE(C).type !== M) ? JE(M) : C; } else m && ((T = !0), (I = JE(M))); b.setClipPath(I), gR(I, S, t, { isInit: T }), DR(I, S.keyframeAnimation, t); } var D = KE(b); b.setTextConfig(d), (D.option = e), (function (t, e, n) { var i = rl(t).eventData; t.silent || t.ignore || i || (i = rl(t).eventData = { componentType: "graphic", componentIndex: e.componentIndex, name: t.name, }); i && (i.info = n.info); })(b, t, e), Kh({ el: b, componentModel: t, itemName: b.name, itemTooltipOption: e.tooltip, }), DR(b, e.keyframeAnimation, t); } }); } }), (e.prototype._relocate = function (t, e) { for ( var n = t.option.elements, i = this.group, r = this._elMap, o = e.getWidth(), a = e.getHeight(), s = ["x", "y"], l = 0; l < n.length; l++ ) { if ( (f = null != (d = Ro((p = n[l]).id, null)) ? r.get(d) : null) && f.isGroup ) { var u = (g = f.parent) === i, h = KE(f), c = KE(g); (h.width = $r(h.option.width, u ? o : c.width) || 0), (h.height = $r(h.option.height, u ? a : c.height) || 0); } } for (l = n.length - 1; l >= 0; l--) { var p, d, f; if ( (f = null != (d = Ro((p = n[l]).id, null)) ? r.get(d) : null) ) { var g = f.parent, y = ((c = KE(g)), {}), v = Lp( f, p, g === i ? { width: o, height: a } : { width: c.width, height: c.height }, null, { hv: p.hv, boundingMode: p.bounding }, y ); if (!KE(f).isNew && v) { for ( var m = p.transition, x = {}, _ = 0; _ < s.length; _++ ) { var b = s[_], w = y[b]; m && (mR(m) || P(m, b) >= 0) ? (x[b] = w) : (f[b] = w); } vh(f, x, t, 0); } else f.attr(y); } } }), (e.prototype._clear = function () { var t = this, e = this._elMap; e.each(function (n) { tz(n, KE(n).option, e, t._lastGraphicModel); }), (this._elMap = yt()); }), (e.prototype.dispose = function () { this._clear(); }), (e.type = "graphic"), e ); })(Ag); function JE(t) { var e = _t(qE, t) ? qE[t] : Lh(t); var n = new e({}); return (KE(n).type = t), n; } function QE(t, e, n, i) { var r = JE(n); return e.add(r), i.set(t, r), (KE(r).id = t), (KE(r).isNew = !0), r; } function tz(t, e, n, i) { t && t.parent && ("group" === t.type && t.traverse(function (t) { tz(t, e, n, i); }), vR(t, e, i), n.removeKey(KE(t).id)); } function ez(t, e, n, i) { t.isGroup || E( [ ["cursor", Da.prototype.cursor], ["zlevel", i || 0], ["z", n || 0], ["z2", 0], ], function (n) { var i = n[0]; _t(e, i) ? (t[i] = rt(e[i], n[1])) : null == t[i] && (t[i] = n[1]); } ), E(G(e), function (n) { if (0 === n.indexOf("on")) { var i = e[n]; t[n] = X(i) ? i : null; } }), _t(e, "draggable") && (t.draggable = e.draggable), null != e.name && (t.name = e.name), null != e.id && (t.id = e.id); } var nz = ["x", "y", "radius", "angle", "single"], iz = ["cartesian2d", "polar", "singleAxis"]; function rz(t) { return t + "Axis"; } function oz(t, e) { var n, i = yt(), r = [], o = yt(); t.eachComponent({ mainType: "dataZoom", query: e }, function (t) { o.get(t.uid) || s(t); }); do { (n = !1), t.eachComponent("dataZoom", a); } while (n); function a(t) { !o.get(t.uid) && (function (t) { var e = !1; return ( t.eachTargetAxis(function (t, n) { var r = i.get(t); r && r[n] && (e = !0); }), e ); })(t) && (s(t), (n = !0)); } function s(t) { o.set(t.uid, !0), r.push(t), t.eachTargetAxis(function (t, e) { (i.get(t) || i.set(t, []))[e] = !0; }); } return r; } function az(t) { var e = t.ecModel, n = { infoList: [], infoMap: yt() }; return ( t.eachTargetAxis(function (t, i) { var r = e.getComponent(rz(t), i); if (r) { var o = r.getCoordSysModel(); if (o) { var a = o.uid, s = n.infoMap.get(a); s || ((s = { model: o, axisModels: [] }), n.infoList.push(s), n.infoMap.set(a, s)), s.axisModels.push(r); } } }), n ); } var sz = (function () { function t() { (this.indexList = []), (this.indexMap = []); } return ( (t.prototype.add = function (t) { this.indexMap[t] || (this.indexList.push(t), (this.indexMap[t] = !0)); }), t ); })(), lz = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n._autoThrottle = !0), (n._noTarget = !0), (n._rangePropMode = ["percent", "percent"]), n ); } return ( n(e, t), (e.prototype.init = function (t, e, n) { var i = uz(t); (this.settledOption = i), this.mergeDefaultAndTheme(t, n), this._doInit(i); }), (e.prototype.mergeOption = function (t) { var e = uz(t); C(this.option, t, !0), C(this.settledOption, e, !0), this._doInit(e); }), (e.prototype._doInit = function (t) { var e = this.option; this._setDefaultThrottle(t), this._updateRangeUse(t); var n = this.settledOption; E( [ ["start", "startValue"], ["end", "endValue"], ], function (t, i) { "value" === this._rangePropMode[i] && (e[t[0]] = n[t[0]] = null); }, this ), this._resetTarget(); }), (e.prototype._resetTarget = function () { var t = this.get("orient", !0), e = (this._targetAxisInfoMap = yt()); this._fillSpecifiedTargetAxis(e) ? (this._orient = t || this._makeAutoOrientByTargetAxis()) : ((this._orient = t || "horizontal"), this._fillAutoTargetAxisByOrient(e, this._orient)), (this._noTarget = !0), e.each(function (t) { t.indexList.length && (this._noTarget = !1); }, this); }), (e.prototype._fillSpecifiedTargetAxis = function (t) { var e = !1; return ( E( nz, function (n) { var i = this.getReferringComponents(rz(n), Ho); if (i.specified) { e = !0; var r = new sz(); E(i.models, function (t) { r.add(t.componentIndex); }), t.set(n, r); } }, this ), e ); }), (e.prototype._fillAutoTargetAxisByOrient = function (t, e) { var n = this.ecModel, i = !0; if (i) { var r = "vertical" === e ? "y" : "x"; o(n.findComponents({ mainType: r + "Axis" }), r); } i && o( n.findComponents({ mainType: "singleAxis", filter: function (t) { return t.get("orient", !0) === e; }, }), "single" ); function o(e, n) { var r = e[0]; if (r) { var o = new sz(); if ( (o.add(r.componentIndex), t.set(n, o), (i = !1), "x" === n || "y" === n) ) { var a = r.getReferringComponents("grid", Wo) .models[0]; a && E(e, function (t) { r.componentIndex !== t.componentIndex && a === t.getReferringComponents( "grid", Wo ).models[0] && o.add(t.componentIndex); }); } } } i && E( nz, function (e) { if (i) { var r = n.findComponents({ mainType: rz(e), filter: function (t) { return ( "category" === t.get("type", !0) ); }, }); if (r[0]) { var o = new sz(); o.add(r[0].componentIndex), t.set(e, o), (i = !1); } } }, this ); }), (e.prototype._makeAutoOrientByTargetAxis = function () { var t; return ( this.eachTargetAxis(function (e) { !t && (t = e); }, this), "y" === t ? "vertical" : "horizontal" ); }), (e.prototype._setDefaultThrottle = function (t) { if ( (t.hasOwnProperty("throttle") && (this._autoThrottle = !1), this._autoThrottle) ) { var e = this.ecModel.option; this.option.throttle = e.animation && e.animationDurationUpdate > 0 ? 100 : 20; } }), (e.prototype._updateRangeUse = function (t) { var e = this._rangePropMode, n = this.get("rangeMode"); E( [ ["start", "startValue"], ["end", "endValue"], ], function (i, r) { var o = null != t[i[0]], a = null != t[i[1]]; o && !a ? (e[r] = "percent") : !o && a ? (e[r] = "value") : n ? (e[r] = n[r]) : o && (e[r] = "percent"); } ); }), (e.prototype.noTarget = function () { return this._noTarget; }), (e.prototype.getFirstTargetAxisModel = function () { var t; return ( this.eachTargetAxis(function (e, n) { null == t && (t = this.ecModel.getComponent(rz(e), n)); }, this), t ); }), (e.prototype.eachTargetAxis = function (t, e) { this._targetAxisInfoMap.each(function (n, i) { E(n.indexList, function (n) { t.call(e, i, n); }); }); }), (e.prototype.getAxisProxy = function (t, e) { var n = this.getAxisModel(t, e); if (n) return n.__dzAxisProxy; }), (e.prototype.getAxisModel = function (t, e) { var n = this._targetAxisInfoMap.get(t); if (n && n.indexMap[e]) return this.ecModel.getComponent(rz(t), e); }), (e.prototype.setRawRange = function (t) { var e = this.option, n = this.settledOption; E( [ ["start", "startValue"], ["end", "endValue"], ], function (i) { (null == t[i[0]] && null == t[i[1]]) || ((e[i[0]] = n[i[0]] = t[i[0]]), (e[i[1]] = n[i[1]] = t[i[1]])); }, this ), this._updateRangeUse(t); }), (e.prototype.setCalculatedRange = function (t) { var e = this.option; E(["start", "startValue", "end", "endValue"], function (n) { e[n] = t[n]; }); }), (e.prototype.getPercentRange = function () { var t = this.findRepresentativeAxisProxy(); if (t) return t.getDataPercentWindow(); }), (e.prototype.getValueRange = function (t, e) { if (null != t || null != e) return this.getAxisProxy(t, e).getDataValueWindow(); var n = this.findRepresentativeAxisProxy(); return n ? n.getDataValueWindow() : void 0; }), (e.prototype.findRepresentativeAxisProxy = function (t) { if (t) return t.__dzAxisProxy; for ( var e, n = this._targetAxisInfoMap.keys(), i = 0; i < n.length; i++ ) for ( var r = n[i], o = this._targetAxisInfoMap.get(r), a = 0; a < o.indexList.length; a++ ) { var s = this.getAxisProxy(r, o.indexList[a]); if (s.hostedBy(this)) return s; e || (e = s); } return e; }), (e.prototype.getRangePropMode = function () { return this._rangePropMode.slice(); }), (e.prototype.getOrient = function () { return this._orient; }), (e.type = "dataZoom"), (e.dependencies = [ "xAxis", "yAxis", "radiusAxis", "angleAxis", "singleAxis", "series", "toolbox", ]), (e.defaultOption = { z: 4, filterMode: "filter", start: 0, end: 100, }), e ); })(zp); function uz(t) { var e = {}; return ( E( ["start", "end", "startValue", "endValue", "throttle"], function (n) { t.hasOwnProperty(n) && (e[n] = t[n]); } ), e ); } var hz = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "dataZoom.select"), e; })(lz), cz = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { (this.dataZoomModel = t), (this.ecModel = e), (this.api = n); }), (e.type = "dataZoom"), e ); })(Ag), pz = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "dataZoom.select"), e; })(cz), dz = E, fz = Qr, gz = (function () { function t(t, e, n, i) { (this._dimName = t), (this._axisIndex = e), (this.ecModel = i), (this._dataZoomModel = n); } return ( (t.prototype.hostedBy = function (t) { return this._dataZoomModel === t; }), (t.prototype.getDataValueWindow = function () { return this._valueWindow.slice(); }), (t.prototype.getDataPercentWindow = function () { return this._percentWindow.slice(); }), (t.prototype.getTargetSeriesModels = function () { var t = []; return ( this.ecModel.eachSeries(function (e) { if ( (function (t) { var e = t.get("coordinateSystem"); return P(iz, e) >= 0; })(e) ) { var n = rz(this._dimName), i = e.getReferringComponents(n, Wo) .models[0]; i && this._axisIndex === i.componentIndex && t.push(e); } }, this), t ); }), (t.prototype.getAxisModel = function () { return this.ecModel.getComponent( this._dimName + "Axis", this._axisIndex ); }), (t.prototype.getMinMaxSpan = function () { return T(this._minMaxSpan); }), (t.prototype.calculateDataWindow = function (t) { var e, n = this._dataExtent, i = this.getAxisModel().axis.scale, r = this._dataZoomModel.getRangePropMode(), o = [0, 100], a = [], s = []; dz(["start", "end"], function (l, u) { var h = t[l], c = t[l + "Value"]; "percent" === r[u] ? (null == h && (h = o[u]), (c = i.parse(Kr(h, o, n)))) : ((e = !0), (h = Kr( (c = null == c ? n[u] : i.parse(c)), n, o ))), (s[u] = null == c || isNaN(c) ? n[u] : c), (a[u] = null == h || isNaN(h) ? o[u] : h); }), fz(s), fz(a); var l = this._minMaxSpan; function u(t, e, n, r, o) { var a = o ? "Span" : "ValueSpan"; zk(0, t, n, "all", l["min" + a], l["max" + a]); for (var s = 0; s < 2; s++) (e[s] = Kr(t[s], n, r, !0)), o && (e[s] = i.parse(e[s])); } return ( e ? u(s, a, n, o, !1) : u(a, s, o, n, !0), { valueWindow: s, percentWindow: a } ); }), (t.prototype.reset = function (t) { if (t === this._dataZoomModel) { var e = this.getTargetSeriesModels(); (this._dataExtent = (function (t, e, n) { var i = [1 / 0, -1 / 0]; dz(n, function (t) { !(function (t, e, n) { e && E(C_(e, n), function (n) { var i = e.getApproximateExtent(n); i[0] < t[0] && (t[0] = i[0]), i[1] > t[1] && (t[1] = i[1]); }); })(i, t.getData(), e); }); var r = t.getAxisModel(), o = v_(r.axis.scale, r, i).calculate(); return [o.min, o.max]; })(this, this._dimName, e)), this._updateMinMaxSpan(); var n = this.calculateDataWindow(t.settledOption); (this._valueWindow = n.valueWindow), (this._percentWindow = n.percentWindow), this._setAxisModel(); } }), (t.prototype.filterData = function (t, e) { if (t === this._dataZoomModel) { var n = this._dimName, i = this.getTargetSeriesModels(), r = t.get("filterMode"), o = this._valueWindow; "none" !== r && dz(i, function (t) { var e = t.getData(), i = e.mapDimensionsAll(n); if (i.length) { if ("weakFilter" === r) { var a = e.getStore(), s = z( i, function (t) { return e.getDimensionIndex( t ); }, e ); e.filterSelf(function (t) { for ( var e, n, r, l = 0; l < i.length; l++ ) { var u = a.get(s[l], t), h = !isNaN(u), c = u < o[0], p = u > o[1]; if (h && !c && !p) return !0; h && (r = !0), c && (e = !0), p && (n = !0); } return r && e && n; }); } else dz(i, function (n) { if ("empty" === r) t.setData( (e = e.map(n, function (t) { return (function (t) { return ( t >= o[0] && t <= o[1] ); })(t) ? t : NaN; })) ); else { var i = {}; (i[n] = o), e.selectRange(i); } }); dz(i, function (t) { e.setApproximateExtent(o, t); }); } }); } }), (t.prototype._updateMinMaxSpan = function () { var t = (this._minMaxSpan = {}), e = this._dataZoomModel, n = this._dataExtent; dz( ["min", "max"], function (i) { var r = e.get(i + "Span"), o = e.get(i + "ValueSpan"); null != o && (o = this.getAxisModel().axis.scale.parse(o)), null != o ? (r = Kr(n[0] + o, n, [0, 100], !0)) : null != r && (o = Kr(r, [0, 100], n, !0) - n[0]), (t[i + "Span"] = r), (t[i + "ValueSpan"] = o); }, this ); }), (t.prototype._setAxisModel = function () { var t = this.getAxisModel(), e = this._percentWindow, n = this._valueWindow; if (e) { var i = no(n, [0, 500]); i = Math.min(i, 20); var r = t.axis.scale.rawExtentInfo; 0 !== e[0] && r.setDeterminedMinMax("min", +n[0].toFixed(i)), 100 !== e[1] && r.setDeterminedMinMax("max", +n[1].toFixed(i)), r.freeze(); } }), t ); })(); var yz = { getTargetSeries: function (t) { function e(e) { t.eachComponent("dataZoom", function (n) { n.eachTargetAxis(function (i, r) { var o = t.getComponent(rz(i), r); e(i, r, o, n); }); }); } e(function (t, e, n, i) { n.__dzAxisProxy = null; }); var n = []; e(function (e, i, r, o) { r.__dzAxisProxy || ((r.__dzAxisProxy = new gz(e, i, o, t)), n.push(r.__dzAxisProxy)); }); var i = yt(); return ( E(n, function (t) { E(t.getTargetSeriesModels(), function (t) { i.set(t.uid, t); }); }), i ); }, overallReset: function (t, e) { t.eachComponent("dataZoom", function (t) { t.eachTargetAxis(function (e, n) { t.getAxisProxy(e, n).reset(t); }), t.eachTargetAxis(function (n, i) { t.getAxisProxy(n, i).filterData(t, e); }); }), t.eachComponent("dataZoom", function (t) { var e = t.findRepresentativeAxisProxy(); if (e) { var n = e.getDataPercentWindow(), i = e.getDataValueWindow(); t.setCalculatedRange({ start: n[0], end: n[1], startValue: i[0], endValue: i[1], }); } }); }, }; var vz = !1; function mz(t) { vz || ((vz = !0), t.registerProcessor(t.PRIORITY.PROCESSOR.FILTER, yz), (function (t) { t.registerAction("dataZoom", function (t, e) { E(oz(e, t), function (e) { e.setRawRange({ start: t.start, end: t.end, startValue: t.startValue, endValue: t.endValue, }); }); }); })(t), t.registerSubTypeDefaulter("dataZoom", function () { return "slider"; })); } function xz(t) { t.registerComponentModel(hz), t.registerComponentView(pz), mz(t); } var _z = function () {}, bz = {}; function wz(t, e) { bz[t] = e; } function Sz(t) { return bz[t]; } var Mz = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.optionUpdated = function () { t.prototype.optionUpdated.apply(this, arguments); var e = this.ecModel; E(this.option.feature, function (t, n) { var i = Sz(n); i && (i.getDefaultOption && (i.defaultOption = i.getDefaultOption(e)), C(t, i.defaultOption)); }); }), (e.type = "toolbox"), (e.layoutMode = { type: "box", ignoreSize: !0 }), (e.defaultOption = { show: !0, z: 6, orient: "horizontal", left: "right", top: "top", backgroundColor: "transparent", borderColor: "#ccc", borderRadius: 0, borderWidth: 0, padding: 5, itemSize: 15, itemGap: 8, showTitle: !0, iconStyle: { borderColor: "#666", color: "none" }, emphasis: { iconStyle: { borderColor: "#3E98C5" } }, tooltip: { show: !1, position: "bottom" }, }), e ); })(zp); function Iz(t, e) { var n = vp(e.get("padding")), i = e.getItemStyle(["color", "opacity"]); return ( (i.fill = e.get("backgroundColor")), (t = new Ws({ shape: { x: t.x - n[3], y: t.y - n[0], width: t.width + n[1] + n[3], height: t.height + n[0] + n[2], r: e.get("borderRadius"), }, style: i, silent: !0, z2: -1, })) ); } var Tz = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { var r = this.group; if ((r.removeAll(), t.get("show"))) { var o = +t.get("itemSize"), a = "vertical" === t.get("orient"), s = t.get("feature") || {}, l = this._features || (this._features = {}), u = []; E(s, function (t, e) { u.push(e); }), new Gm(this._featureNames || [], u) .add(h) .update(h) .remove(H(h, null)) .execute(), (this._featureNames = u), (function (t, e, n) { var i = e.getBoxLayoutParams(), r = e.get("padding"), o = { width: n.getWidth(), height: n.getHeight(), }, a = kp(i, o, r); Ap( e.get("orient"), t, e.get("itemGap"), a.width, a.height ), Lp(t, i, o, r); })(r, t, n), r.add(Iz(r.getBoundingRect(), t)), a || r.eachChild(function (t) { var e = t.__title, i = t.ensureState("emphasis"), a = i.textConfig || (i.textConfig = {}), s = t.getTextContent(), l = s && s.ensureState("emphasis"); if (l && !X(l) && e) { var u = l.style || (l.style = {}), h = Sr(e, Xs.makeFont(u)), c = t.x + r.x, p = !1; t.y + r.y + o + h.height > n.getHeight() && ((a.position = "top"), (p = !0)); var d = p ? -5 - h.height : o + 10; c + h.width / 2 > n.getWidth() ? ((a.position = ["100%", d]), (u.align = "right")) : c - h.width / 2 < 0 && ((a.position = [0, d]), (u.align = "left")); } }); } function h(h, c) { var p, d = u[h], f = u[c], g = s[d], y = new Cc(g, t, t.ecModel); if ( (i && null != i.newTitle && i.featureName === d && (g.title = i.newTitle), d && !f) ) { if ( (function (t) { return 0 === t.indexOf("my"); })(d) ) p = { onclick: y.option.onclick, featureName: d }; else { var v = Sz(d); if (!v) return; p = new v(); } l[d] = p; } else if (!(p = l[f])) return; (p.uid = Ac("toolbox-feature")), (p.model = y), (p.ecModel = e), (p.api = n); var m = p instanceof _z; d || !f ? !y.get("show") || (m && p.unusable) ? m && p.remove && p.remove(e, n) : (!(function (i, s, l) { var u, h, c = i.getModel("iconStyle"), p = i.getModel(["emphasis", "iconStyle"]), d = s instanceof _z && s.getIcons ? s.getIcons() : i.get("icon"), f = i.get("title") || {}; U(d) ? ((u = {})[l] = d) : (u = d); U(f) ? ((h = {})[l] = f) : (h = f); var g = (i.iconPaths = {}); E(u, function (l, u) { var d = Uh( l, {}, { x: -o / 2, y: -o / 2, width: o, height: o, } ); d.setStyle(c.getItemStyle()), (d.ensureState("emphasis").style = p.getItemStyle()); var f = new Xs({ style: { text: h[u], align: p.get("textAlign"), borderRadius: p.get("textBorderRadius"), padding: p.get("textPadding"), fill: null, font: cc( { fontStyle: p.get( "textFontStyle" ), fontFamily: p.get( "textFontFamily" ), fontSize: p.get("textFontSize"), fontWeight: p.get( "textFontWeight" ), }, e ), }, ignore: !0, }); d.setTextContent(f), Kh({ el: d, componentModel: t, itemName: u, formatterParamsExtra: { title: h[u], }, }), (d.__title = h[u]), d .on("mouseover", function () { var e = p.getItemStyle(), i = a ? null == t.get( "right" ) && "right" !== t.get("left") ? "right" : "left" : null == t.get( "bottom" ) && "bottom" !== t.get("top") ? "bottom" : "top"; f.setStyle({ fill: p.get("textFill") || e.fill || e.stroke || "#000", backgroundColor: p.get( "textBackgroundColor" ), }), d.setTextConfig({ position: p.get( "textPosition" ) || i, }), (f.ignore = !t.get("showTitle")), n.enterEmphasis(this); }) .on("mouseout", function () { "emphasis" !== i.get([ "iconStatus", u, ]) && n.leaveEmphasis(this), f.hide(); }), ("emphasis" === i.get(["iconStatus", u]) ? Ol : Rl)(d), r.add(d), d.on( "click", W(s.onclick, s, e, n, u) ), (g[u] = d); }); })(y, p, d), (y.setIconStatus = function (t, e) { var n = this.option, i = this.iconPaths; (n.iconStatus = n.iconStatus || {}), (n.iconStatus[t] = e), i[t] && ("emphasis" === e ? Ol : Rl)(i[t]); }), p instanceof _z && p.render && p.render(y, e, n, i)) : m && p.dispose && p.dispose(e, n); } }), (e.prototype.updateView = function (t, e, n, i) { E(this._features, function (t) { t instanceof _z && t.updateView && t.updateView(t.model, e, n, i); }); }), (e.prototype.remove = function (t, e) { E(this._features, function (n) { n instanceof _z && n.remove && n.remove(t, e); }), this.group.removeAll(); }), (e.prototype.dispose = function (t, e) { E(this._features, function (n) { n instanceof _z && n.dispose && n.dispose(t, e); }); }), (e.type = "toolbox"), e ); })(Ag); var Cz = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.onclick = function (t, e) { var n = this.model, i = n.get("name") || t.get("title.0.text") || "echarts", o = "svg" === e.getZr().painter.getType(), a = o ? "svg" : n.get("type", !0) || "png", s = e.getConnectedDataURL({ type: a, backgroundColor: n.get("backgroundColor", !0) || t.get("backgroundColor") || "#fff", connectedBackgroundColor: n.get( "connectedBackgroundColor" ), excludeComponents: n.get("excludeComponents"), pixelRatio: n.get("pixelRatio"), }), l = r.browser; if ( "function" != typeof MouseEvent || (!l.newEdge && (l.ie || l.edge)) ) if (window.navigator.msSaveOrOpenBlob || o) { var u = s.split(","), h = u[0].indexOf("base64") > -1, c = o ? decodeURIComponent(u[1]) : u[1]; h && (c = window.atob(c)); var p = i + "." + a; if (window.navigator.msSaveOrOpenBlob) { for ( var d = c.length, f = new Uint8Array(d); d--; ) f[d] = c.charCodeAt(d); var g = new Blob([f]); window.navigator.msSaveOrOpenBlob(g, p); } else { var y = document.createElement("iframe"); document.body.appendChild(y); var v = y.contentWindow, m = v.document; m.open("image/svg+xml", "replace"), m.write(c), m.close(), v.focus(), m.execCommand("SaveAs", !0, p), document.body.removeChild(y); } } else { var x = n.get("lang"), _ = '', b = window.open(); b.document.write(_), (b.document.title = i); } else { var w = document.createElement("a"); (w.download = i + "." + a), (w.target = "_blank"), (w.href = s); var S = new MouseEvent("click", { view: document.defaultView, bubbles: !0, cancelable: !1, }); w.dispatchEvent(S); } }), (e.getDefaultOption = function (t) { return { show: !0, icon: "M4.7,22.9L29.3,45.5L54.7,23.4M4.6,43.6L4.6,58L53.8,58L53.8,43.6M29.2,45.1L29.2,0", title: t .getLocaleModel() .get(["toolbox", "saveAsImage", "title"]), type: "png", connectedBackgroundColor: "#fff", name: "", excludeComponents: ["toolbox"], lang: t .getLocaleModel() .get(["toolbox", "saveAsImage", "lang"]), }; }), e ); })(_z), Dz = "__ec_magicType_stack__", Az = [["line", "bar"], ["stack"]], kz = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.getIcons = function () { var t = this.model, e = t.get("icon"), n = {}; return ( E(t.get("type"), function (t) { e[t] && (n[t] = e[t]); }), n ); }), (e.getDefaultOption = function (t) { return { show: !0, type: [], icon: { line: "M4.1,28.9h7.1l9.3-22l7.4,38l9.7-19.7l3,12.8h14.9M4.1,58h51.4", bar: "M6.7,22.9h10V48h-10V22.9zM24.9,13h10v35h-10V13zM43.2,2h10v46h-10V2zM3.1,58h53.7", stack: "M8.2,38.4l-8.4,4.1l30.6,15.3L60,42.5l-8.1-4.1l-21.5,11L8.2,38.4z M51.9,30l-8.1,4.2l-13.4,6.9l-13.9-6.9L8.2,30l-8.4,4.2l8.4,4.2l22.2,11l21.5-11l8.1-4.2L51.9,30z M51.9,21.7l-8.1,4.2L35.7,30l-5.3,2.8L24.9,30l-8.4-4.1l-8.3-4.2l-8.4,4.2L8.2,30l8.3,4.2l13.9,6.9l13.4-6.9l8.1-4.2l8.1-4.1L51.9,21.7zM30.4,2.2L-0.2,17.5l8.4,4.1l8.3,4.2l8.4,4.2l5.5,2.7l5.3-2.7l8.1-4.2l8.1-4.2l8.1-4.1L30.4,2.2z", }, title: t .getLocaleModel() .get(["toolbox", "magicType", "title"]), option: {}, seriesIndex: {}, }; }), (e.prototype.onclick = function (t, e, n) { var i = this.model, r = i.get(["seriesIndex", n]); if (Lz[n]) { var o, a = { series: [] }; E(Az, function (t) { P(t, n) >= 0 && E(t, function (t) { i.setIconStatus(t, "normal"); }); }), i.setIconStatus(n, "emphasis"), t.eachComponent( { mainType: "series", query: null == r ? null : { seriesIndex: r }, }, function (t) { var e = t.subType, r = t.id, o = Lz[n](e, r, t, i); o && (k(o, t.option), a.series.push(o)); var s = t.coordinateSystem; if ( s && "cartesian2d" === s.type && ("line" === n || "bar" === n) ) { var l = s.getAxesByScale("ordinal")[0]; if (l) { var u = l.dim + "Axis", h = t.getReferringComponents( u, Wo ).models[0].componentIndex; a[u] = a[u] || []; for (var c = 0; c <= h; c++) a[u][h] = a[u][h] || {}; a[u][h].boundaryGap = "bar" === n; } } } ); var s = n; "stack" === n && ((o = C( { stack: i.option.title.tiled, tiled: i.option.title.stack, }, i.option.title )), "emphasis" !== i.get(["iconStatus", n]) && (s = "tiled")), e.dispatchAction({ type: "changeMagicType", currentType: s, newOption: a, newTitle: o, featureName: "magicType", }); } }), e ); })(_z), Lz = { line: function (t, e, n, i) { if ("bar" === t) return C( { id: e, type: "line", data: n.get("data"), stack: n.get("stack"), markPoint: n.get("markPoint"), markLine: n.get("markLine"), }, i.get(["option", "line"]) || {}, !0 ); }, bar: function (t, e, n, i) { if ("line" === t) return C( { id: e, type: "bar", data: n.get("data"), stack: n.get("stack"), markPoint: n.get("markPoint"), markLine: n.get("markLine"), }, i.get(["option", "bar"]) || {}, !0 ); }, stack: function (t, e, n, i) { var r = n.get("stack") === Dz; if ("line" === t || "bar" === t) return ( i.setIconStatus("stack", r ? "normal" : "emphasis"), C( { id: e, stack: r ? "" : Dz }, i.get(["option", "stack"]) || {}, !0 ) ); }, }; Cm( { type: "changeMagicType", event: "magicTypeChanged", update: "prepareAndUpdate", }, function (t, e) { e.mergeOption(t.newOption); } ); var Pz = new Array(60).join("-"), Oz = "\t"; function Rz(t) { return t.replace(/^\s\s*/, "").replace(/\s\s*$/, ""); } var Nz = new RegExp("[\t]+", "g"); function Ez(t, e) { var n = t.split(new RegExp("\n*" + Pz + "\n*", "g")), i = { series: [] }; return ( E(n, function (t, n) { if ( (function (t) { if (t.slice(0, t.indexOf("\n")).indexOf(Oz) >= 0) return !0; })(t) ) { var r = (function (t) { for ( var e = t.split(/\n+/g), n = [], i = z( Rz(e.shift()).split(Nz), function (t) { return { name: t, data: [] }; } ), r = 0; r < e.length; r++ ) { var o = Rz(e[r]).split(Nz); n.push(o.shift()); for (var a = 0; a < o.length; a++) i[a] && (i[a].data[r] = o[a]); } return { series: i, categories: n }; })(t), o = e[n], a = o.axisDim + "Axis"; o && ((i[a] = i[a] || []), (i[a][o.axisIndex] = { data: r.categories }), (i.series = i.series.concat(r.series))); } else { r = (function (t) { for ( var e = t.split(/\n+/g), n = Rz(e.shift()), i = [], r = 0; r < e.length; r++ ) { var o = Rz(e[r]); if (o) { var a = o.split(Nz), s = "", l = void 0, u = !1; isNaN(a[0]) ? ((u = !0), (s = a[0]), (a = a.slice(1)), (i[r] = { name: s, value: [] }), (l = i[r].value)) : (l = i[r] = []); for (var h = 0; h < a.length; h++) l.push(+a[h]); 1 === l.length && (u ? (i[r].value = l[0]) : (i[r] = l[0])); } } return { name: n, data: i }; })(t); i.series.push(r); } }), i ); } var zz = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.onclick = function (t, e) { setTimeout(function () { e.dispatchAction({ type: "hideTip" }); }); var n = e.getDom(), i = this.model; this._dom && n.removeChild(this._dom); var r = document.createElement("div"); (r.style.cssText = "position:absolute;top:0;bottom:0;left:0;right:0;padding:5px"), (r.style.backgroundColor = i.get("backgroundColor") || "#fff"); var o = document.createElement("h4"), a = i.get("lang") || []; (o.innerHTML = a[0] || i.get("title")), (o.style.cssText = "margin:10px 20px"), (o.style.color = i.get("textColor")); var s = document.createElement("div"), l = document.createElement("textarea"); s.style.cssText = "overflow:auto"; var u = i.get("optionToContent"), h = i.get("contentToOption"), c = (function (t) { var e, n, i, r = (function (t) { var e = {}, n = [], i = []; return ( t.eachRawSeries(function (t) { var r = t.coordinateSystem; if ( !r || ("cartesian2d" !== r.type && "polar" !== r.type) ) n.push(t); else { var o = r.getBaseAxis(); if ("category" === o.type) { var a = o.dim + "_" + o.index; e[a] || ((e[a] = { categoryAxis: o, valueAxis: r.getOtherAxis(o), series: [], }), i.push({ axisDim: o.dim, axisIndex: o.index, })), e[a].series.push(t); } else n.push(t); } }), { seriesGroupByCategoryAxis: e, other: n, meta: i, } ); })(t); return { value: B( [ ((n = r.seriesGroupByCategoryAxis), (i = []), E(n, function (t, e) { var n = t.categoryAxis, r = t.valueAxis.dim, o = [" "].concat( z(t.series, function (t) { return t.name; }) ), a = [n.model.getCategories()]; E(t.series, function (t) { var e = t.getRawData(); a.push( t .getRawData() .mapArray( e.mapDimension(r), function (t) { return t; } ) ); }); for ( var s = [o.join(Oz)], l = 0; l < a[0].length; l++ ) { for ( var u = [], h = 0; h < a.length; h++ ) u.push(a[h][l]); s.push(u.join(Oz)); } i.push(s.join("\n")); }), i.join("\n\n" + Pz + "\n\n")), ((e = r.other), z(e, function (t) { var e = t.getRawData(), n = [t.name], i = []; return ( e.each(e.dimensions, function () { for ( var t = arguments.length, r = arguments[t - 1], o = e.getName(r), a = 0; a < t - 1; a++ ) i[a] = arguments[a]; n.push( (o ? o + Oz : "") + i.join(Oz) ); }), n.join("\n") ); }).join("\n\n" + Pz + "\n\n")), ], function (t) { return !!t.replace(/[\n\t\s]/g, ""); } ).join("\n\n" + Pz + "\n\n"), meta: r.meta, }; })(t); if (X(u)) { var p = u(e.getOption()); U(p) ? (s.innerHTML = p) : J(p) && s.appendChild(p); } else { l.readOnly = i.get("readOnly"); var d = l.style; (d.cssText = "display:block;width:100%;height:100%;font-family:monospace;font-size:14px;line-height:1.6rem;resize:none;box-sizing:border-box;outline:none"), (d.color = i.get("textColor")), (d.borderColor = i.get("textareaBorderColor")), (d.backgroundColor = i.get("textareaColor")), (l.value = c.value), s.appendChild(l); } var f = c.meta, g = document.createElement("div"); g.style.cssText = "position:absolute;bottom:5px;left:0;right:0"; var y = "float:right;margin-right:20px;border:none;cursor:pointer;padding:2px 5px;font-size:12px;border-radius:3px", v = document.createElement("div"), m = document.createElement("div"); (y += ";background-color:" + i.get("buttonColor")), (y += ";color:" + i.get("buttonTextColor")); var x = this; function _() { n.removeChild(r), (x._dom = null); } pe(v, "click", _), pe(m, "click", function () { if ( (null == h && null != u) || (null != h && null == u) ) _(); else { var t; try { t = X(h) ? h(s, e.getOption()) : Ez(l.value, f); } catch (t) { throw ( (_(), new Error("Data view format error " + t)) ); } t && e.dispatchAction({ type: "changeDataView", newOption: t, }), _(); } }), (v.innerHTML = a[1]), (m.innerHTML = a[2]), (m.style.cssText = v.style.cssText = y), !i.get("readOnly") && g.appendChild(m), g.appendChild(v), r.appendChild(o), r.appendChild(s), r.appendChild(g), (s.style.height = n.clientHeight - 80 + "px"), n.appendChild(r), (this._dom = r); }), (e.prototype.remove = function (t, e) { this._dom && e.getDom().removeChild(this._dom); }), (e.prototype.dispose = function (t, e) { this.remove(t, e); }), (e.getDefaultOption = function (t) { return { show: !0, readOnly: !1, optionToContent: null, contentToOption: null, icon: "M17.5,17.3H33 M17.5,17.3H33 M45.4,29.5h-28 M11.5,2v56H51V14.8L38.4,2H11.5z M38.4,2.2v12.7H51 M45.4,41.7h-28", title: t .getLocaleModel() .get(["toolbox", "dataView", "title"]), lang: t .getLocaleModel() .get(["toolbox", "dataView", "lang"]), backgroundColor: "#fff", textColor: "#000", textareaColor: "#fff", textareaBorderColor: "#333", buttonColor: "#c23531", buttonTextColor: "#fff", }; }), e ); })(_z); function Vz(t, e) { return z(t, function (t, n) { var i = e && e[n]; if (q(i) && !Y(i)) { (q(t) && !Y(t)) || (t = { value: t }); var r = null != i.name && null == t.name; return (t = k(t, i)), r && delete t.name, t; } return t; }); } Cm( { type: "changeDataView", event: "dataViewChanged", update: "prepareAndUpdate", }, function (t, e) { var n = []; E(t.newOption.series, function (t) { var i = e.getSeriesByName(t.name)[0]; if (i) { var r = i.get("data"); n.push({ name: t.name, data: Vz(t.data, r) }); } else n.push(A({ type: "scatter" }, t)); }), e.mergeOption(k({ series: n }, t.newOption)); } ); var Bz = E, Fz = Vo(); function Gz(t) { var e = Fz(t); return e.snapshots || (e.snapshots = [{}]), e.snapshots; } var Wz = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.onclick = function (t, e) { !(function (t) { Fz(t).snapshots = null; })(t), e.dispatchAction({ type: "restore", from: this.uid }); }), (e.getDefaultOption = function (t) { return { show: !0, icon: "M3.8,33.4 M47,18.9h9.8V8.7 M56.3,20.1 C52.1,9,40.5,0.6,26.8,2.1C12.6,3.7,1.6,16.2,2.1,30.6 M13,41.1H3.1v10.2 M3.7,39.9c4.2,11.1,15.8,19.5,29.5,18 c14.2-1.6,25.2-14.1,24.7-28.5", title: t .getLocaleModel() .get(["toolbox", "restore", "title"]), }; }), e ); })(_z); Cm( { type: "restore", event: "restore", update: "prepareAndUpdate" }, function (t, e) { e.resetOption("recreate"); } ); var Hz = [ "grid", "xAxis", "yAxis", "geo", "graph", "polar", "radiusAxis", "angleAxis", "bmap", ], Yz = (function () { function t(t, e, n) { var i = this; this._targetInfoList = []; var r = Uz(e, t); E(Zz, function (t, e) { (!n || !n.include || P(n.include, e) >= 0) && t(r, i._targetInfoList); }); } return ( (t.prototype.setOutputRanges = function (t, e) { return ( this.matchOutputRanges(t, e, function (t, e, n) { if ( ((t.coordRanges || (t.coordRanges = [])).push( e ), !t.coordRange) ) { t.coordRange = e; var i = Kz[t.brushType](0, n, e); t.__rangeOffset = { offset: Jz[t.brushType]( i.values, t.range, [1, 1] ), xyMinMax: i.xyMinMax, }; } }), t ); }), (t.prototype.matchOutputRanges = function (t, e, n) { E( t, function (t) { var i = this.findTargetInfo(t, e); i && !0 !== i && E(i.coordSyses, function (i) { var r = Kz[t.brushType](1, i, t.range, !0); n(t, r.values, i, e); }); }, this ); }), (t.prototype.setInputRanges = function (t, e) { E( t, function (t) { var n, i, r, o, a, s = this.findTargetInfo(t, e); if (((t.range = t.range || []), s && !0 !== s)) { t.panelId = s.panelId; var l = Kz[t.brushType]( 0, s.coordSys, t.coordRange ), u = t.__rangeOffset; t.range = u ? Jz[t.brushType]( l.values, u.offset, ((n = l.xyMinMax), (i = u.xyMinMax), (r = tV(n)), (o = tV(i)), (a = [r[0] / o[0], r[1] / o[1]]), isNaN(a[0]) && (a[0] = 1), isNaN(a[1]) && (a[1] = 1), a) ) : l.values; } }, this ); }), (t.prototype.makePanelOpts = function (t, e) { return z(this._targetInfoList, function (n) { var i = n.getPanelRect(); return { panelId: n.panelId, defaultBrushType: e ? e(n) : null, clipPath: BL(i), isTargetByCursor: GL(i, t, n.coordSysModel), getLinearBrushOtherExtent: FL(i), }; }); }), (t.prototype.controlSeries = function (t, e, n) { var i = this.findTargetInfo(t, n); return ( !0 === i || (i && P(i.coordSyses, e.coordinateSystem) >= 0) ); }), (t.prototype.findTargetInfo = function (t, e) { for ( var n = this._targetInfoList, i = Uz(e, t), r = 0; r < n.length; r++ ) { var o = n[r], a = t.panelId; if (a) { if (o.panelId === a) return o; } else for (var s = 0; s < jz.length; s++) if (jz[s](i, o)) return o; } return !0; }), t ); })(); function Xz(t) { return t[0] > t[1] && t.reverse(), t; } function Uz(t, e) { return Fo(t, e, { includeMainTypes: Hz }); } var Zz = { grid: function (t, e) { var n = t.xAxisModels, i = t.yAxisModels, r = t.gridModels, o = yt(), a = {}, s = {}; (n || i || r) && (E(n, function (t) { var e = t.axis.grid.model; o.set(e.id, e), (a[e.id] = !0); }), E(i, function (t) { var e = t.axis.grid.model; o.set(e.id, e), (s[e.id] = !0); }), E(r, function (t) { o.set(t.id, t), (a[t.id] = !0), (s[t.id] = !0); }), o.each(function (t) { var r = t.coordinateSystem, o = []; E(r.getCartesians(), function (t, e) { (P(n, t.getAxis("x").model) >= 0 || P(i, t.getAxis("y").model) >= 0) && o.push(t); }), e.push({ panelId: "grid--" + t.id, gridModel: t, coordSysModel: t, coordSys: o[0], coordSyses: o, getPanelRect: qz.grid, xAxisDeclared: a[t.id], yAxisDeclared: s[t.id], }); })); }, geo: function (t, e) { E(t.geoModels, function (t) { var n = t.coordinateSystem; e.push({ panelId: "geo--" + t.id, geoModel: t, coordSysModel: t, coordSys: n, coordSyses: [n], getPanelRect: qz.geo, }); }); }, }, jz = [ function (t, e) { var n = t.xAxisModel, i = t.yAxisModel, r = t.gridModel; return ( !r && n && (r = n.axis.grid.model), !r && i && (r = i.axis.grid.model), r && r === e.gridModel ); }, function (t, e) { var n = t.geoModel; return n && n === e.geoModel; }, ], qz = { grid: function () { return this.coordSys.master.getRect().clone(); }, geo: function () { var t = this.coordSys, e = t.getBoundingRect().clone(); return e.applyTransform(Bh(t)), e; }, }, Kz = { lineX: H($z, 0), lineY: H($z, 1), rect: function (t, e, n, i) { var r = t ? e.pointToData([n[0][0], n[1][0]], i) : e.dataToPoint([n[0][0], n[1][0]], i), o = t ? e.pointToData([n[0][1], n[1][1]], i) : e.dataToPoint([n[0][1], n[1][1]], i), a = [Xz([r[0], o[0]]), Xz([r[1], o[1]])]; return { values: a, xyMinMax: a }; }, polygon: function (t, e, n, i) { var r = [ [1 / 0, -1 / 0], [1 / 0, -1 / 0], ]; return { values: z(n, function (n) { var o = t ? e.pointToData(n, i) : e.dataToPoint(n, i); return ( (r[0][0] = Math.min(r[0][0], o[0])), (r[1][0] = Math.min(r[1][0], o[1])), (r[0][1] = Math.max(r[0][1], o[0])), (r[1][1] = Math.max(r[1][1], o[1])), o ); }), xyMinMax: r, }; }, }; function $z(t, e, n, i) { var r = n.getAxis(["x", "y"][t]), o = Xz( z([0, 1], function (t) { return e ? r.coordToData(r.toLocalCoord(i[t]), !0) : r.toGlobalCoord(r.dataToCoord(i[t])); }) ), a = []; return (a[t] = o), (a[1 - t] = [NaN, NaN]), { values: o, xyMinMax: a }; } var Jz = { lineX: H(Qz, 0), lineY: H(Qz, 1), rect: function (t, e, n) { return [ [t[0][0] - n[0] * e[0][0], t[0][1] - n[0] * e[0][1]], [t[1][0] - n[1] * e[1][0], t[1][1] - n[1] * e[1][1]], ]; }, polygon: function (t, e, n) { return z(t, function (t, i) { return [t[0] - n[0] * e[i][0], t[1] - n[1] * e[i][1]]; }); }, }; function Qz(t, e, n, i) { return [e[0] - i[t] * n[0], e[1] - i[t] * n[1]]; } function tV(t) { return t ? [t[0][1] - t[0][0], t[1][1] - t[1][0]] : [NaN, NaN]; } var eV, nV, iV = E, rV = Io + "toolbox-dataZoom_", oV = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.render = function (t, e, n, i) { this._brushController || ((this._brushController = new lL(n.getZr())), this._brushController .on("brush", W(this._onBrush, this)) .mount()), (function (t, e, n, i, r) { var o = n._isZoomActive; i && "takeGlobalCursor" === i.type && (o = "dataZoomSelect" === i.key && i.dataZoomSelectActive); (n._isZoomActive = o), t.setIconStatus( "zoom", o ? "emphasis" : "normal" ); var a = new Yz(sV(t), e, { include: ["grid"] }), s = a.makePanelOpts(r, function (t) { return t.xAxisDeclared && !t.yAxisDeclared ? "lineX" : !t.xAxisDeclared && t.yAxisDeclared ? "lineY" : "rect"; }); n._brushController .setPanels(s) .enableBrush( !(!o || !s.length) && { brushType: "auto", brushStyle: t .getModel("brushStyle") .getItemStyle(), } ); })(t, e, this, i, n), (function (t, e) { t.setIconStatus( "back", (function (t) { return Gz(t).length; })(e) > 1 ? "emphasis" : "normal" ); })(t, e); }), (e.prototype.onclick = function (t, e, n) { aV[n].call(this); }), (e.prototype.remove = function (t, e) { this._brushController && this._brushController.unmount(); }), (e.prototype.dispose = function (t, e) { this._brushController && this._brushController.dispose(); }), (e.prototype._onBrush = function (t) { var e = t.areas; if (t.isEnd && e.length) { var n = {}, i = this.ecModel; this._brushController.updateCovers([]), new Yz(sV(this.model), i, { include: ["grid"], }).matchOutputRanges(e, i, function (t, e, n) { if ("cartesian2d" === n.type) { var i = t.brushType; "rect" === i ? (r("x", n, e[0]), r("y", n, e[1])) : r( { lineX: "x", lineY: "y" }[i], n, e ); } }), (function (t, e) { var n = Gz(t); Bz(e, function (e, i) { for ( var r = n.length - 1; r >= 0 && !n[r][i]; r-- ); if (r < 0) { var o = t.queryComponents({ mainType: "dataZoom", subType: "select", id: i, })[0]; if (o) { var a = o.getPercentRange(); n[0][i] = { dataZoomId: i, start: a[0], end: a[1], }; } } }), n.push(e); })(i, n), this._dispatchZoomAction(n); } function r(t, e, r) { var o = e.getAxis(t), a = o.model, s = (function (t, e, n) { var i; return ( n.eachComponent( { mainType: "dataZoom", subType: "select", }, function (n) { n.getAxisModel( t, e.componentIndex ) && (i = n); } ), i ); })(t, a, i), l = s .findRepresentativeAxisProxy(a) .getMinMaxSpan(); (null == l.minValueSpan && null == l.maxValueSpan) || (r = zk( 0, r.slice(), o.scale.getExtent(), 0, l.minValueSpan, l.maxValueSpan )), s && (n[s.id] = { dataZoomId: s.id, startValue: r[0], endValue: r[1], }); } }), (e.prototype._dispatchZoomAction = function (t) { var e = []; iV(t, function (t, n) { e.push(T(t)); }), e.length && this.api.dispatchAction({ type: "dataZoom", from: this.uid, batch: e, }); }), (e.getDefaultOption = function (t) { return { show: !0, filterMode: "filter", icon: { zoom: "M0,13.5h26.9 M13.5,26.9V0 M32.1,13.5H58V58H13.5 V32.1", back: "M22,1.4L9.9,13.5l12.3,12.3 M10.3,13.5H54.9v44.6 H10.3v-26", }, title: t .getLocaleModel() .get(["toolbox", "dataZoom", "title"]), brushStyle: { borderWidth: 0, color: "rgba(210,219,238,0.2)", }, }; }), e ); })(_z), aV = { zoom: function () { var t = !this._isZoomActive; this.api.dispatchAction({ type: "takeGlobalCursor", key: "dataZoomSelect", dataZoomSelectActive: t, }); }, back: function () { this._dispatchZoomAction( (function (t) { var e = Gz(t), n = e[e.length - 1]; e.length > 1 && e.pop(); var i = {}; return ( Bz(n, function (t, n) { for (var r = e.length - 1; r >= 0; r--) if ((t = e[r][n])) { i[n] = t; break; } }), i ); })(this.ecModel) ); }, }; function sV(t) { var e = { xAxisIndex: t.get("xAxisIndex", !0), yAxisIndex: t.get("yAxisIndex", !0), xAxisId: t.get("xAxisId", !0), yAxisId: t.get("yAxisId", !0), }; return ( null == e.xAxisIndex && null == e.xAxisId && (e.xAxisIndex = "all"), null == e.yAxisIndex && null == e.yAxisId && (e.yAxisIndex = "all"), e ); } (eV = "dataZoom"), (nV = function (t) { var e = t.getComponent("toolbox", 0), n = ["feature", "dataZoom"]; if (e && null != e.get(n)) { var i = e.getModel(n), r = [], o = Fo(t, sV(i)); return ( iV(o.xAxisModels, function (t) { return a(t, "xAxis", "xAxisIndex"); }), iV(o.yAxisModels, function (t) { return a(t, "yAxis", "yAxisIndex"); }), r ); } function a(t, e, n) { var o = t.componentIndex, a = { type: "select", $fromToolbox: !0, filterMode: i.get("filterMode", !0) || "filter", id: rV + e + o, }; (a[n] = o), r.push(a); } }), lt(null == od.get(eV) && nV), od.set(eV, nV); var lV = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.type = "tooltip"), (e.dependencies = ["axisPointer"]), (e.defaultOption = { z: 60, show: !0, showContent: !0, trigger: "item", triggerOn: "mousemove|click", alwaysShowContent: !1, displayMode: "single", renderMode: "auto", confine: null, showDelay: 0, hideDelay: 100, transitionDuration: 0.4, enterable: !1, backgroundColor: "#fff", shadowBlur: 10, shadowColor: "rgba(0, 0, 0, .2)", shadowOffsetX: 1, shadowOffsetY: 2, borderRadius: 4, borderWidth: 1, padding: null, extraCssText: "", axisPointer: { type: "line", axis: "auto", animation: "auto", animationDurationUpdate: 200, animationEasingUpdate: "exponentialOut", crossStyle: { color: "#999", width: 1, type: "dashed", textStyle: {}, }, }, textStyle: { color: "#666", fontSize: 14 }, }), e ); })(zp); function uV(t) { var e = t.get("confine"); return null != e ? !!e : "richText" === t.get("renderMode"); } function hV(t) { if (r.domSupported) for ( var e = document.documentElement.style, n = 0, i = t.length; n < i; n++ ) if (t[n] in e) return t[n]; } var cV = hV([ "transform", "webkitTransform", "OTransform", "MozTransform", "msTransform", ]); function pV(t, e) { if (!t) return e; e = yp(e, !0); var n = t.indexOf(e); return (t = -1 === n ? e : "-" + t.slice(0, n) + "-" + e).toLowerCase(); } var dV = pV( hV([ "webkitTransition", "transition", "OTransition", "MozTransition", "msTransition", ]), "transition" ), fV = pV(cV, "transform"), gV = "position:absolute;display:block;border-style:solid;white-space:nowrap;z-index:9999999;" + (r.transform3dSupported ? "will-change:transform;" : ""); function yV(t, e, n) { var i = t.toFixed(0) + "px", o = e.toFixed(0) + "px"; if (!r.transformSupported) return n ? "top:" + o + ";left:" + i + ";" : [ ["top", o], ["left", i], ]; var a = r.transform3dSupported, s = "translate" + (a ? "3d" : "") + "(" + i + "," + o + (a ? ",0" : "") + ")"; return n ? "top:0;left:0;" + fV + ":" + s + ";" : [ ["top", 0], ["left", 0], [cV, s], ]; } function vV(t, e, n) { var i = [], o = t.get("transitionDuration"), a = t.get("backgroundColor"), s = t.get("shadowBlur"), l = t.get("shadowColor"), u = t.get("shadowOffsetX"), h = t.get("shadowOffsetY"), c = t.getModel("textStyle"), p = gg(t, "html"), d = u + "px " + h + "px " + s + "px " + l; return ( i.push("box-shadow:" + d), e && o && i.push( (function (t, e) { var n = "cubic-bezier(0.23,1,0.32,1)", i = " " + t / 2 + "s " + n, o = "opacity" + i + ",visibility" + i; return ( e || ((i = " " + t + "s " + n), (o += r.transformSupported ? "," + fV + i : ",left" + i + ",top" + i)), dV + ":" + o ); })(o, n) ), a && i.push("background-color:" + a), E(["width", "color", "radius"], function (e) { var n = "border-" + e, r = yp(n), o = t.get(r); null != o && i.push(n + ":" + o + ("color" === e ? "" : "px")); }), i.push( (function (t) { var e = [], n = t.get("fontSize"), i = t.getTextColor(); i && e.push("color:" + i), e.push("font:" + t.getFont()); var r = rt(t.get("lineHeight"), Math.round((3 * n) / 2)); n && e.push("line-height:" + r + "px"); var o = t.get("textShadowColor"), a = t.get("textShadowBlur") || 0, s = t.get("textShadowOffsetX") || 0, l = t.get("textShadowOffsetY") || 0; return ( o && a && e.push( "text-shadow:" + s + "px " + l + "px " + a + "px " + o ), E(["decoration", "align"], function (n) { var i = t.get(n); i && e.push("text-" + n + ":" + i); }), e.join(";") ); })(c) ), null != p && i.push("padding:" + vp(p).join("px ") + "px"), i.join(";") + ";" ); } function mV(t, e, n, i, r) { var o = e && e.painter; if (n) { var a = o && o.getViewportRoot(); a && (function (t, e, n, i, r) { te(Qt, e, i, r, !0) && te(t, n, Qt[0], Qt[1]); })(t, a, n, i, r); } else { (t[0] = i), (t[1] = r); var s = o && o.getViewportRootOffset(); s && ((t[0] += s.offsetLeft), (t[1] += s.offsetTop)); } (t[2] = t[0] / e.getWidth()), (t[3] = t[1] / e.getHeight()); } var xV = (function () { function t(t, e) { if ( ((this._show = !1), (this._styleCoord = [0, 0, 0, 0]), (this._enterable = !0), (this._alwaysShowContent = !1), (this._firstShow = !0), (this._longHide = !0), r.wxa) ) return null; var n = document.createElement("div"); (n.domBelongToZr = !0), (this.el = n); var i = (this._zr = t.getZr()), o = e.appendTo, a = o && (U(o) ? document.querySelector(o) : J(o) ? o : X(o) && o(t.getDom())); mV(this._styleCoord, i, a, t.getWidth() / 2, t.getHeight() / 2), (a || t.getDom()).appendChild(n), (this._api = t), (this._container = a); var s = this; (n.onmouseenter = function () { s._enterable && (clearTimeout(s._hideTimeout), (s._show = !0)), (s._inContent = !0); }), (n.onmousemove = function (t) { if (((t = t || window.event), !s._enterable)) { var e = i.handler; ce(i.painter.getViewportRoot(), t, !0), e.dispatch("mousemove", t); } }), (n.onmouseleave = function () { (s._inContent = !1), s._enterable && s._show && s.hideLater(s._hideDelay); }); } return ( (t.prototype.update = function (t) { if (!this._container) { var e = this._api.getDom(), n = ((o = "position"), (a = (r = e).currentStyle || (document.defaultView && document.defaultView.getComputedStyle( r ))) ? o ? a[o] : a : null), i = e.style; "absolute" !== i.position && "absolute" !== n && (i.position = "relative"); } var r, o, a, s = t.get("alwaysShowContent"); s && this._moveIfResized(), (this._alwaysShowContent = s), (this.el.className = t.get("className") || ""); }), (t.prototype.show = function (t, e) { clearTimeout(this._hideTimeout), clearTimeout(this._longHideTimeout); var n = this.el, i = n.style, r = this._styleCoord; n.innerHTML ? (i.cssText = gV + vV(t, !this._firstShow, this._longHide) + yV(r[0], r[1], !0) + "border-color:" + Sp(e) + ";" + (t.get("extraCssText") || "") + ";pointer-events:" + (this._enterable ? "auto" : "none")) : (i.display = "none"), (this._show = !0), (this._firstShow = !1), (this._longHide = !1); }), (t.prototype.setContent = function (t, e, n, i, r) { var o = this.el; if (null != t) { var a = ""; if ( (U(r) && "item" === n.get("trigger") && !uV(n) && (a = (function (t, e, n) { if (!U(n) || "inside" === n) return ""; var i = t.get("backgroundColor"), r = t.get("borderWidth"); e = Sp(e); var o, a, s = "left" === (o = n) ? "right" : "right" === o ? "left" : "top" === o ? "bottom" : "top", l = Math.max(1.5 * Math.round(r), 6), u = "", h = fV + ":"; P(["left", "right"], s) > -1 ? ((u += "top:50%"), (h += "translateY(-50%) rotate(" + (a = "left" === s ? -225 : -45) + "deg)")) : ((u += "left:50%"), (h += "translateX(-50%) rotate(" + (a = "top" === s ? 225 : 45) + "deg)")); var c = (a * Math.PI) / 180, p = l + r, d = p * Math.abs(Math.cos(c)) + p * Math.abs(Math.sin(c)), f = e + " solid " + r + "px;"; return ( '
' ); })(n, i, r)), U(t)) ) o.innerHTML = t + a; else if (t) { (o.innerHTML = ""), Y(t) || (t = [t]); for (var s = 0; s < t.length; s++) J(t[s]) && t[s].parentNode !== o && o.appendChild(t[s]); if (a && o.childNodes.length) { var l = document.createElement("div"); (l.innerHTML = a), o.appendChild(l); } } } else o.innerHTML = ""; }), (t.prototype.setEnterable = function (t) { this._enterable = t; }), (t.prototype.getSize = function () { var t = this.el; return t ? [t.offsetWidth, t.offsetHeight] : [0, 0]; }), (t.prototype.moveTo = function (t, e) { if (this.el) { var n = this._styleCoord; if ( (mV(n, this._zr, this._container, t, e), null != n[0] && null != n[1]) ) { var i = this.el.style; E(yV(n[0], n[1]), function (t) { i[t[0]] = t[1]; }); } } }), (t.prototype._moveIfResized = function () { var t = this._styleCoord[2], e = this._styleCoord[3]; this.moveTo( t * this._zr.getWidth(), e * this._zr.getHeight() ); }), (t.prototype.hide = function () { var t = this, e = this.el.style; (e.visibility = "hidden"), (e.opacity = "0"), r.transform3dSupported && (e.willChange = ""), (this._show = !1), (this._longHideTimeout = setTimeout(function () { return (t._longHide = !0); }, 500)); }), (t.prototype.hideLater = function (t) { !this._show || (this._inContent && this._enterable) || this._alwaysShowContent || (t ? ((this._hideDelay = t), (this._show = !1), (this._hideTimeout = setTimeout( W(this.hide, this), t ))) : this.hide()); }), (t.prototype.isShow = function () { return this._show; }), (t.prototype.dispose = function () { clearTimeout(this._hideTimeout), clearTimeout(this._longHideTimeout); var t = this.el.parentNode; t && t.removeChild(this.el), (this.el = this._container = null); }), t ); })(), _V = (function () { function t(t) { (this._show = !1), (this._styleCoord = [0, 0, 0, 0]), (this._alwaysShowContent = !1), (this._enterable = !0), (this._zr = t.getZr()), SV( this._styleCoord, this._zr, t.getWidth() / 2, t.getHeight() / 2 ); } return ( (t.prototype.update = function (t) { var e = t.get("alwaysShowContent"); e && this._moveIfResized(), (this._alwaysShowContent = e); }), (t.prototype.show = function () { this._hideTimeout && clearTimeout(this._hideTimeout), this.el.show(), (this._show = !0); }), (t.prototype.setContent = function (t, e, n, i, r) { var o = this; q(t) && wo(""), this.el && this._zr.remove(this.el); var a = n.getModel("textStyle"); (this.el = new Xs({ style: { rich: e.richTextStyles, text: t, lineHeight: 22, borderWidth: 1, borderColor: i, textShadowColor: a.get("textShadowColor"), fill: n.get(["textStyle", "color"]), padding: gg(n, "richText"), verticalAlign: "top", align: "left", }, z: n.get("z"), })), E( [ "backgroundColor", "borderRadius", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY", ], function (t) { o.el.style[t] = n.get(t); } ), E( [ "textShadowBlur", "textShadowOffsetX", "textShadowOffsetY", ], function (t) { o.el.style[t] = a.get(t) || 0; } ), this._zr.add(this.el); var s = this; this.el.on("mouseover", function () { s._enterable && (clearTimeout(s._hideTimeout), (s._show = !0)), (s._inContent = !0); }), this.el.on("mouseout", function () { s._enterable && s._show && s.hideLater(s._hideDelay), (s._inContent = !1); }); }), (t.prototype.setEnterable = function (t) { this._enterable = t; }), (t.prototype.getSize = function () { var t = this.el, e = this.el.getBoundingRect(), n = wV(t.style); return [ e.width + n.left + n.right, e.height + n.top + n.bottom, ]; }), (t.prototype.moveTo = function (t, e) { var n = this.el; if (n) { var i = this._styleCoord; SV(i, this._zr, t, e), (t = i[0]), (e = i[1]); var r = n.style, o = bV(r.borderWidth || 0), a = wV(r); (n.x = t + o + a.left), (n.y = e + o + a.top), n.markRedraw(); } }), (t.prototype._moveIfResized = function () { var t = this._styleCoord[2], e = this._styleCoord[3]; this.moveTo( t * this._zr.getWidth(), e * this._zr.getHeight() ); }), (t.prototype.hide = function () { this.el && this.el.hide(), (this._show = !1); }), (t.prototype.hideLater = function (t) { !this._show || (this._inContent && this._enterable) || this._alwaysShowContent || (t ? ((this._hideDelay = t), (this._show = !1), (this._hideTimeout = setTimeout( W(this.hide, this), t ))) : this.hide()); }), (t.prototype.isShow = function () { return this._show; }), (t.prototype.dispose = function () { this._zr.remove(this.el); }), t ); })(); function bV(t) { return Math.max(0, t); } function wV(t) { var e = bV(t.shadowBlur || 0), n = bV(t.shadowOffsetX || 0), i = bV(t.shadowOffsetY || 0); return { left: bV(e - n), right: bV(e + n), top: bV(e - i), bottom: bV(e + i), }; } function SV(t, e, n, i) { (t[0] = n), (t[1] = i), (t[2] = t[0] / e.getWidth()), (t[3] = t[1] / e.getHeight()); } var MV = new Ws({ shape: { x: -1, y: -1, width: 2, height: 2 } }), IV = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (t, e) { if (!r.node && e.getDom()) { var n, i = t.getComponent("tooltip"), o = (this._renderMode = "auto" === (n = i.get("renderMode")) ? r.domSupported ? "html" : "richText" : n || "html"); this._tooltipContent = "richText" === o ? new _V(e) : new xV(e, { appendTo: i.get("appendToBody", !0) ? "body" : i.get("appendTo", !0), }); } }), (e.prototype.render = function (t, e, n) { if (!r.node && n.getDom()) { this.group.removeAll(), (this._tooltipModel = t), (this._ecModel = e), (this._api = n); var i = this._tooltipContent; i.update(t), i.setEnterable(t.get("enterable")), this._initGlobalListener(), this._keepShow(), "richText" !== this._renderMode && t.get("transitionDuration") ? Hg(this, "_updatePosition", 50, "fixRate") : Yg(this, "_updatePosition"); } }), (e.prototype._initGlobalListener = function () { var t = this._tooltipModel.get("triggerOn"); AN( "itemTooltip", this._api, W(function (e, n, i) { "none" !== t && (t.indexOf(e) >= 0 ? this._tryShow(n, i) : "leave" === e && this._hide(i)); }, this) ); }), (e.prototype._keepShow = function () { var t = this._tooltipModel, e = this._ecModel, n = this._api, i = t.get("triggerOn"); if ( null != this._lastX && null != this._lastY && "none" !== i && "click" !== i ) { var r = this; clearTimeout(this._refreshUpdateTimeout), (this._refreshUpdateTimeout = setTimeout( function () { !n.isDisposed() && r.manuallyShowTip(t, e, n, { x: r._lastX, y: r._lastY, dataByCoordSys: r._lastDataByCoordSys, }); } )); } }), (e.prototype.manuallyShowTip = function (t, e, n, i) { if (i.from !== this.uid && !r.node && n.getDom()) { var o = CV(i, n); this._ticket = ""; var a = i.dataByCoordSys, s = (function (t, e, n) { var i = Go(t).queryOptionMap, r = i.keys()[0]; if (!r || "series" === r) return; var o = Yo(e, r, i.get(r), { useDefault: !1, enableAll: !1, enableNone: !1, }), a = o.models[0]; if (!a) return; var s, l = n.getViewOfComponentModel(a); if ( (l.group.traverse(function (e) { var n = rl(e).tooltipConfig; if (n && n.name === t.name) return (s = e), !0; }), s) ) return { componentMainType: r, componentIndex: a.componentIndex, el: s, }; })(i, e, n); if (s) { var l = s.el.getBoundingRect().clone(); l.applyTransform(s.el.transform), this._tryShow( { offsetX: l.x + l.width / 2, offsetY: l.y + l.height / 2, target: s.el, position: i.position, positionDefault: "bottom", }, o ); } else if (i.tooltip && null != i.x && null != i.y) { var u = MV; (u.x = i.x), (u.y = i.y), u.update(), (rl(u).tooltipConfig = { name: null, option: i.tooltip, }), this._tryShow( { offsetX: i.x, offsetY: i.y, target: u }, o ); } else if (a) this._tryShow( { offsetX: i.x, offsetY: i.y, position: i.position, dataByCoordSys: a, tooltipOption: i.tooltipOption, }, o ); else if (null != i.seriesIndex) { if (this._manuallyAxisShowTip(t, e, n, i)) return; var h = RN(i, e), c = h.point[0], p = h.point[1]; null != c && null != p && this._tryShow( { offsetX: c, offsetY: p, target: h.el, position: i.position, positionDefault: "bottom", }, o ); } else null != i.x && null != i.y && (n.dispatchAction({ type: "updateAxisPointer", x: i.x, y: i.y, }), this._tryShow( { offsetX: i.x, offsetY: i.y, position: i.position, target: n.getZr().findHover(i.x, i.y) .target, }, o )); } }), (e.prototype.manuallyHideTip = function (t, e, n, i) { var r = this._tooltipContent; this._tooltipModel && r.hideLater(this._tooltipModel.get("hideDelay")), (this._lastX = this._lastY = this._lastDataByCoordSys = null), i.from !== this.uid && this._hide(CV(i, n)); }), (e.prototype._manuallyAxisShowTip = function (t, e, n, i) { var r = i.seriesIndex, o = i.dataIndex, a = e.getComponent("axisPointer").coordSysAxesInfo; if (null != r && null != o && null != a) { var s = e.getSeriesByIndex(r); if (s) if ( "axis" === TV( [ s.getData().getItemModel(o), s, (s.coordinateSystem || {}).model, ], this._tooltipModel ).get("trigger") ) return ( n.dispatchAction({ type: "updateAxisPointer", seriesIndex: r, dataIndex: o, position: i.position, }), !0 ); } }), (e.prototype._tryShow = function (t, e) { var n = t.target; if (this._tooltipModel) { (this._lastX = t.offsetX), (this._lastY = t.offsetY); var i = t.dataByCoordSys; if (i && i.length) this._showAxisTooltip(i, t); else if (n) { var r, o; if ("legend" === rl(n).ssrType) return; (this._lastDataByCoordSys = null), Oy( n, function (t) { return null != rl(t).dataIndex ? ((r = t), !0) : null != rl(t).tooltipConfig ? ((o = t), !0) : void 0; }, !0 ), r ? this._showSeriesItemTooltip(t, r, e) : o ? this._showComponentItemTooltip(t, o, e) : this._hide(e); } else (this._lastDataByCoordSys = null), this._hide(e); } }), (e.prototype._showOrMove = function (t, e) { var n = t.get("showDelay"); (e = W(e, this)), clearTimeout(this._showTimout), n > 0 ? (this._showTimout = setTimeout(e, n)) : e(); }), (e.prototype._showAxisTooltip = function (t, e) { var n = this._ecModel, i = this._tooltipModel, r = [e.offsetX, e.offsetY], o = TV([e.tooltipOption], i), a = this._renderMode, s = [], l = og("section", { blocks: [], noHeader: !0 }), u = [], h = new yg(); E(t, function (t) { E(t.dataByAxis, function (t) { var e = n.getComponent( t.axisDim + "Axis", t.axisIndex ), r = t.value; if (e && null != r) { var o = yN( r, e.axis, n, t.seriesDataIndices, t.valueLabelOpt ), c = og("section", { header: o, noHeader: !ut(o), sortBlocks: !0, blocks: [], }); l.blocks.push(c), E(t.seriesDataIndices, function (l) { var p = n.getSeriesByIndex( l.seriesIndex ), d = l.dataIndexInside, f = p.getDataParams(d); if (!(f.dataIndex < 0)) { (f.axisDim = t.axisDim), (f.axisIndex = t.axisIndex), (f.axisType = t.axisType), (f.axisId = t.axisId), (f.axisValue = S_(e.axis, { value: r, })), (f.axisValueLabel = o), (f.marker = h.makeTooltipMarker( "item", Sp(f.color), a )); var g = bf( p.formatTooltip(d, !0, null) ), y = g.frag; if (y) { var v = TV([p], i).get( "valueFormatter" ); c.blocks.push( v ? A( { valueFormatter: v, }, y ) : y ); } g.text && u.push(g.text), s.push(f); } }); } }); }), l.blocks.reverse(), u.reverse(); var c = e.position, p = o.get("order"), d = cg(l, h, a, p, n.get("useUTC"), o.get("textStyle")); d && u.unshift(d); var f = "richText" === a ? "\n\n" : "
", g = u.join(f); this._showOrMove(o, function () { this._updateContentNotChangedOnAxis(t, s) ? this._updatePosition( o, c, r[0], r[1], this._tooltipContent, s ) : this._showTooltipContent( o, g, s, Math.random() + "", r[0], r[1], c, null, h ); }); }), (e.prototype._showSeriesItemTooltip = function (t, e, n) { var i = this._ecModel, r = rl(e), o = r.seriesIndex, a = i.getSeriesByIndex(o), s = r.dataModel || a, l = r.dataIndex, u = r.dataType, h = s.getData(u), c = this._renderMode, p = t.positionDefault, d = TV( [ h.getItemModel(l), s, a && (a.coordinateSystem || {}).model, ], this._tooltipModel, p ? { position: p } : null ), f = d.get("trigger"); if (null == f || "item" === f) { var g = s.getDataParams(l, u), y = new yg(); g.marker = y.makeTooltipMarker("item", Sp(g.color), c); var v = bf(s.formatTooltip(l, !1, u)), m = d.get("order"), x = d.get("valueFormatter"), _ = v.frag, b = _ ? cg( x ? A({ valueFormatter: x }, _) : _, y, c, m, i.get("useUTC"), d.get("textStyle") ) : v.text, w = "item_" + s.name + "_" + l; this._showOrMove(d, function () { this._showTooltipContent( d, b, g, w, t.offsetX, t.offsetY, t.position, t.target, y ); }), n({ type: "showTip", dataIndexInside: l, dataIndex: h.getRawIndex(l), seriesIndex: o, from: this.uid, }); } }), (e.prototype._showComponentItemTooltip = function (t, e, n) { var i = "html" === this._renderMode, r = rl(e), o = r.tooltipConfig.option || {}, a = o.encodeHTMLContent; if (U(o)) { (o = { content: o, formatter: o }), (a = !0); } a && i && o.content && ((o = T(o)).content = re(o.content)); var s = [o], l = this._ecModel.getComponent( r.componentMainType, r.componentIndex ); l && s.push(l), s.push({ formatter: o.content }); var u = t.positionDefault, h = TV( s, this._tooltipModel, u ? { position: u } : null ), c = h.get("content"), p = Math.random() + "", d = new yg(); this._showOrMove(h, function () { var n = T(h.get("formatterParams") || {}); this._showTooltipContent( h, c, n, p, t.offsetX, t.offsetY, t.position, e, d ); }), n({ type: "showTip", from: this.uid }); }), (e.prototype._showTooltipContent = function ( t, e, n, i, r, o, a, s, l ) { if ( ((this._ticket = ""), t.get("showContent") && t.get("show")) ) { var u = this._tooltipContent; u.setEnterable(t.get("enterable")); var h = t.get("formatter"); a = a || t.get("position"); var c = e, p = this._getNearestPoint( [r, o], n, t.get("trigger"), t.get("borderColor") ).color; if (h) if (U(h)) { var d = t.ecModel.get("useUTC"), f = Y(n) ? n[0] : n; (c = h), f && f.axisType && f.axisType.indexOf("time") >= 0 && (c = Jc(f.axisValue, c, d)), (c = bp(c, n, !0)); } else if (X(h)) { var g = W(function (e, i) { e === this._ticket && (u.setContent(i, l, t, p, a), this._updatePosition( t, a, r, o, u, n, s )); }, this); (this._ticket = i), (c = h(n, i, g)); } else c = h; u.setContent(c, l, t, p, a), u.show(t, p), this._updatePosition(t, a, r, o, u, n, s); } }), (e.prototype._getNearestPoint = function (t, e, n, i) { return "axis" === n || Y(e) ? { color: i || ("html" === this._renderMode ? "#fff" : "none"), } : Y(e) ? void 0 : { color: i || e.color || e.borderColor }; }), (e.prototype._updatePosition = function (t, e, n, i, r, o, a) { var s = this._api.getWidth(), l = this._api.getHeight(); e = e || t.get("position"); var u = r.getSize(), h = t.get("align"), c = t.get("verticalAlign"), p = a && a.getBoundingRect().clone(); if ( (a && p.applyTransform(a.transform), X(e) && (e = e([n, i], o, r.el, p, { viewSize: [s, l], contentSize: u.slice(), })), Y(e)) ) (n = $r(e[0], s)), (i = $r(e[1], l)); else if (q(e)) { var d = e; (d.width = u[0]), (d.height = u[1]); var f = kp(d, { width: s, height: l }); (n = f.x), (i = f.y), (h = null), (c = null); } else if (U(e) && a) { var g = (function (t, e, n, i) { var r = n[0], o = n[1], a = Math.ceil(Math.SQRT2 * i) + 8, s = 0, l = 0, u = e.width, h = e.height; switch (t) { case "inside": (s = e.x + u / 2 - r / 2), (l = e.y + h / 2 - o / 2); break; case "top": (s = e.x + u / 2 - r / 2), (l = e.y - o - a); break; case "bottom": (s = e.x + u / 2 - r / 2), (l = e.y + h + a); break; case "left": (s = e.x - r - a), (l = e.y + h / 2 - o / 2); break; case "right": (s = e.x + u + a), (l = e.y + h / 2 - o / 2); } return [s, l]; })(e, p, u, t.get("borderWidth")); (n = g[0]), (i = g[1]); } else { g = (function (t, e, n, i, r, o, a) { var s = n.getSize(), l = s[0], u = s[1]; null != o && (t + l + o + 2 > i ? (t -= l + o) : (t += o)); null != a && (e + u + a > r ? (e -= u + a) : (e += a)); return [t, e]; })(n, i, r, s, l, h ? null : 20, c ? null : 20); (n = g[0]), (i = g[1]); } if ( (h && (n -= DV(h) ? u[0] / 2 : "right" === h ? u[0] : 0), c && (i -= DV(c) ? u[1] / 2 : "bottom" === c ? u[1] : 0), uV(t)) ) { g = (function (t, e, n, i, r) { var o = n.getSize(), a = o[0], s = o[1]; return ( (t = Math.min(t + a, i) - a), (e = Math.min(e + s, r) - s), (t = Math.max(t, 0)), (e = Math.max(e, 0)), [t, e] ); })(n, i, r, s, l); (n = g[0]), (i = g[1]); } r.moveTo(n, i); }), (e.prototype._updateContentNotChangedOnAxis = function (t, e) { var n = this._lastDataByCoordSys, i = this._cbParamsList, r = !!n && n.length === t.length; return ( r && E(n, function (n, o) { var a = n.dataByAxis || [], s = (t[o] || {}).dataByAxis || []; (r = r && a.length === s.length) && E(a, function (t, n) { var o = s[n] || {}, a = t.seriesDataIndices || [], l = o.seriesDataIndices || []; (r = r && t.value === o.value && t.axisType === o.axisType && t.axisId === o.axisId && a.length === l.length) && E(a, function (t, e) { var n = l[e]; r = r && t.seriesIndex === n.seriesIndex && t.dataIndex === n.dataIndex; }), i && E( t.seriesDataIndices, function (t) { var n = t.seriesIndex, o = e[n], a = i[n]; o && a && a.data !== o.data && (r = !1); } ); }); }), (this._lastDataByCoordSys = t), (this._cbParamsList = e), !!r ); }), (e.prototype._hide = function (t) { (this._lastDataByCoordSys = null), t({ type: "hideTip", from: this.uid }); }), (e.prototype.dispose = function (t, e) { !r.node && e.getDom() && (Yg(this, "_updatePosition"), this._tooltipContent.dispose(), PN("itemTooltip", e)); }), (e.type = "tooltip"), e ); })(Ag); function TV(t, e, n) { var i, r = e.ecModel; n ? ((i = new Cc(n, r, r)), (i = new Cc(e.option, i, r))) : (i = e); for (var o = t.length - 1; o >= 0; o--) { var a = t[o]; a && (a instanceof Cc && (a = a.get("tooltip", !0)), U(a) && (a = { formatter: a }), a && (i = new Cc(a, i, r))); } return i; } function CV(t, e) { return t.dispatchAction || W(e.dispatchAction, e); } function DV(t) { return "center" === t || "middle" === t; } var AV = ["rect", "polygon", "keep", "clear"]; function kV(t, e) { var n = To(t ? t.brush : []); if (n.length) { var i = []; E(n, function (t) { var e = t.hasOwnProperty("toolbox") ? t.toolbox : []; e instanceof Array && (i = i.concat(e)); }); var r = t && t.toolbox; Y(r) && (r = r[0]), r || ((r = { feature: {} }), (t.toolbox = [r])); var o = r.feature || (r.feature = {}), a = o.brush || (o.brush = {}), s = a.type || (a.type = []); s.push.apply(s, i), (function (t) { var e = {}; E(t, function (t) { e[t] = 1; }), (t.length = 0), E(e, function (e, n) { t.push(n); }); })(s), e && !s.length && s.push.apply(s, AV); } } var LV = E; function PV(t) { if (t) for (var e in t) if (t.hasOwnProperty(e)) return !0; } function OV(t, e, n) { var i = {}; return ( LV(e, function (e) { var r, o = (i[e] = (((r = function () {}).prototype.__hidden = r.prototype), new r())); LV(t[e], function (t, i) { if (kD.isValidType(i)) { var r = { type: i, visual: t }; n && n(r, e), (o[i] = new kD(r)), "opacity" === i && (((r = T(r)).type = "colorAlpha"), (o.__hidden.__alphaForOpacity = new kD(r))); } }); }), i ); } function RV(t, e, n) { var i; E(n, function (t) { e.hasOwnProperty(t) && PV(e[t]) && (i = !0); }), i && E(n, function (n) { e.hasOwnProperty(n) && PV(e[n]) ? (t[n] = T(e[n])) : delete t[n]; }); } var NV = { lineX: EV(0), lineY: EV(1), rect: { point: function (t, e, n) { return t && n.boundingRect.contain(t[0], t[1]); }, rect: function (t, e, n) { return t && n.boundingRect.intersect(t); }, }, polygon: { point: function (t, e, n) { return ( t && n.boundingRect.contain(t[0], t[1]) && P_(n.range, t[0], t[1]) ); }, rect: function (t, e, n) { var i = n.range; if (!t || i.length <= 1) return !1; var r = t.x, o = t.y, a = t.width, s = t.height, l = i[0]; return ( !!( P_(i, r, o) || P_(i, r + a, o) || P_(i, r, o + s) || P_(i, r + a, o + s) || ze.create(t).contain(l[0], l[1]) || Zh(r, o, r + a, o, i) || Zh(r, o, r, o + s, i) || Zh(r + a, o, r + a, o + s, i) || Zh(r, o + s, r + a, o + s, i) ) || void 0 ); }, }, }; function EV(t) { var e = ["x", "y"], n = ["width", "height"]; return { point: function (e, n, i) { if (e) { var r = i.range; return zV(e[t], r); } }, rect: function (i, r, o) { if (i) { var a = o.range, s = [i[e[t]], i[e[t]] + i[n[t]]]; return ( s[1] < s[0] && s.reverse(), zV(s[0], a) || zV(s[1], a) || zV(a[0], s) || zV(a[1], s) ); } }, }; } function zV(t, e) { return e[0] <= t && t <= e[1]; } var VV = ["inBrush", "outOfBrush"], BV = "__ecBrushSelect", FV = "__ecInBrushSelectEvent"; function GV(t) { t.eachComponent({ mainType: "brush" }, function (e) { (e.brushTargetManager = new Yz(e.option, t)).setInputRanges( e.areas, t ); }); } function WV(t, e, n) { var i, r, o = []; t.eachComponent({ mainType: "brush" }, function (t) { n && "takeGlobalCursor" === n.type && t.setBrushOption( "brush" === n.key ? n.brushOption : { brushType: !1 } ); }), GV(t), t.eachComponent({ mainType: "brush" }, function (e, n) { var a = { brushId: e.id, brushIndex: n, brushName: e.name, areas: T(e.areas), selected: [], }; o.push(a); var s = e.option, l = s.brushLink, u = [], h = [], c = [], p = !1; n || ((i = s.throttleType), (r = s.throttleDelay)); var d = z(e.areas, function (t) { var e = XV[t.brushType], n = k({ boundingRect: e ? e(t) : void 0 }, t); return ( (n.selectors = (function (t) { var e = t.brushType, n = { point: function (i) { return NV[e].point(i, n, t); }, rect: function (i) { return NV[e].rect(i, n, t); }, }; return n; })(n)), n ); }), f = OV(e.option, VV, function (t) { t.mappingMethod = "fixed"; }); function g(t) { return "all" === l || !!u[t]; } function y(t) { return !!t.length; } Y(l) && E(l, function (t) { u[t] = 1; }), t.eachSeries(function (n, i) { var r = (c[i] = []); "parallel" === n.subType ? (function (t, e) { var n = t.coordinateSystem; (p = p || n.hasAxisBrushed()), g(e) && n.eachActiveState( t.getData(), function (t, e) { "active" === t && (h[e] = 1); } ); })(n, i) : (function (n, i, r) { if ( !n.brushSelector || (function (t, e) { var n = t.option.seriesIndex; return ( null != n && "all" !== n && (Y(n) ? P(n, e) < 0 : e !== n) ); })(e, i) ) return; if ( (E(d, function (i) { e.brushTargetManager.controlSeries( i, n, t ) && r.push(i), (p = p || y(r)); }), g(i) && y(r)) ) { var o = n.getData(); o.each(function (t) { YV(n, r, o, t) && (h[t] = 1); }); } })(n, i, r); }), t.eachSeries(function (t, e) { var n = { seriesId: t.id, seriesIndex: e, seriesName: t.name, dataIndex: [], }; a.selected.push(n); var i = c[e], r = t.getData(), o = g(e) ? function (t) { return h[t] ? (n.dataIndex.push(r.getRawIndex(t)), "inBrush") : "outOfBrush"; } : function (e) { return YV(t, i, r, e) ? (n.dataIndex.push(r.getRawIndex(e)), "inBrush") : "outOfBrush"; }; (g(e) ? p : y(i)) && (function (t, e, n, i, r, o) { var a, s = {}; function l(t) { return Dy(n, a, t); } function u(t, e) { ky(n, a, t, e); } function h(t, h) { a = null == o ? t : h; var c = n.getRawDataItem(a); if (!c || !1 !== c.visualMap) for ( var p = i.call(r, t), d = e[p], f = s[p], g = 0, y = f.length; g < y; g++ ) { var v = f[g]; d[v] && d[v].applyVisual(t, l, u); } } E(t, function (t) { var n = kD.prepareVisualTypes(e[t]); s[t] = n; }), null == o ? n.each(h) : n.each([o], h); })(VV, f, r, o); }); }), (function (t, e, n, i, r) { if (!r) return; var o = t.getZr(); if (o[FV]) return; o[BV] || (o[BV] = HV); var a = Hg(o, BV, n, e); a(t, i); })(e, i, r, o, n); } function HV(t, e) { if (!t.isDisposed()) { var n = t.getZr(); (n[FV] = !0), t.dispatchAction({ type: "brushSelect", batch: e }), (n[FV] = !1); } } function YV(t, e, n, i) { for (var r = 0, o = e.length; r < o; r++) { var a = e[r]; if (t.brushSelector(i, n, a.selectors, a)) return !0; } } var XV = { rect: function (t) { return UV(t.range); }, polygon: function (t) { for (var e, n = t.range, i = 0, r = n.length; i < r; i++) { e = e || [ [1 / 0, -1 / 0], [1 / 0, -1 / 0], ]; var o = n[i]; o[0] < e[0][0] && (e[0][0] = o[0]), o[0] > e[0][1] && (e[0][1] = o[0]), o[1] < e[1][0] && (e[1][0] = o[1]), o[1] > e[1][1] && (e[1][1] = o[1]); } return e && UV(e); }, }; function UV(t) { return new ze(t[0][0], t[1][0], t[0][1] - t[0][0], t[1][1] - t[1][0]); } var ZV = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (t, e) { (this.ecModel = t), (this.api = e), this.model, (this._brushController = new lL(e.getZr())) .on("brush", W(this._onBrush, this)) .mount(); }), (e.prototype.render = function (t, e, n, i) { (this.model = t), this._updateController(t, e, n, i); }), (e.prototype.updateTransform = function (t, e, n, i) { GV(e), this._updateController(t, e, n, i); }), (e.prototype.updateVisual = function (t, e, n, i) { this.updateTransform(t, e, n, i); }), (e.prototype.updateView = function (t, e, n, i) { this._updateController(t, e, n, i); }), (e.prototype._updateController = function (t, e, n, i) { (!i || i.$from !== t.id) && this._brushController .setPanels(t.brushTargetManager.makePanelOpts(n)) .enableBrush(t.brushOption) .updateCovers(t.areas.slice()); }), (e.prototype.dispose = function () { this._brushController.dispose(); }), (e.prototype._onBrush = function (t) { var e = this.model.id, n = this.model.brushTargetManager.setOutputRanges( t.areas, this.ecModel ); (!t.isEnd || t.removeOnClick) && this.api.dispatchAction({ type: "brush", brushId: e, areas: T(n), $from: e, }), t.isEnd && this.api.dispatchAction({ type: "brushEnd", brushId: e, areas: T(n), $from: e, }); }), (e.type = "brush"), e ); })(Ag), jV = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.areas = []), (n.brushOption = {}), n ); } return ( n(e, t), (e.prototype.optionUpdated = function (t, e) { var n = this.option; !e && RV(n, t, ["inBrush", "outOfBrush"]); var i = (n.inBrush = n.inBrush || {}); (n.outOfBrush = n.outOfBrush || { color: "#ddd" }), i.hasOwnProperty("liftZ") || (i.liftZ = 5); }), (e.prototype.setAreas = function (t) { t && (this.areas = z( t, function (t) { return qV(this.option, t); }, this )); }), (e.prototype.setBrushOption = function (t) { (this.brushOption = qV(this.option, t)), (this.brushType = this.brushOption.brushType); }), (e.type = "brush"), (e.dependencies = [ "geo", "grid", "xAxis", "yAxis", "parallel", "series", ]), (e.defaultOption = { seriesIndex: "all", brushType: "rect", brushMode: "single", transformable: !0, brushStyle: { borderWidth: 1, color: "rgba(210,219,238,0.3)", borderColor: "#D2DBEE", }, throttleType: "fixRate", throttleDelay: 0, removeOnClick: !0, z: 1e4, }), e ); })(zp); function qV(t, e) { return C( { brushType: t.brushType, brushMode: t.brushMode, transformable: t.transformable, brushStyle: new Cc(t.brushStyle).getItemStyle(), removeOnClick: t.removeOnClick, z: t.z, }, e, !0 ); } var KV = ["rect", "polygon", "lineX", "lineY", "keep", "clear"], $V = (function (t) { function e() { return (null !== t && t.apply(this, arguments)) || this; } return ( n(e, t), (e.prototype.render = function (t, e, n) { var i, r, o; e.eachComponent({ mainType: "brush" }, function (t) { (i = t.brushType), (r = t.brushOption.brushMode || "single"), (o = o || !!t.areas.length); }), (this._brushType = i), (this._brushMode = r), E(t.get("type", !0), function (e) { t.setIconStatus( e, ( "keep" === e ? "multiple" === r : "clear" === e ? o : e === i ) ? "emphasis" : "normal" ); }); }), (e.prototype.updateView = function (t, e, n) { this.render(t, e, n); }), (e.prototype.getIcons = function () { var t = this.model, e = t.get("icon", !0), n = {}; return ( E(t.get("type", !0), function (t) { e[t] && (n[t] = e[t]); }), n ); }), (e.prototype.onclick = function (t, e, n) { var i = this._brushType, r = this._brushMode; "clear" === n ? (e.dispatchAction({ type: "axisAreaSelect", intervals: [], }), e.dispatchAction({ type: "brush", command: "clear", areas: [], })) : e.dispatchAction({ type: "takeGlobalCursor", key: "brush", brushOption: { brushType: "keep" === n ? i : i !== n && n, brushMode: "keep" === n ? "multiple" === r ? "single" : "multiple" : r, }, }); }), (e.getDefaultOption = function (t) { return { show: !0, type: KV.slice(), icon: { rect: "M7.3,34.7 M0.4,10V-0.2h9.8 M89.6,10V-0.2h-9.8 M0.4,60v10.2h9.8 M89.6,60v10.2h-9.8 M12.3,22.4V10.5h13.1 M33.6,10.5h7.8 M49.1,10.5h7.8 M77.5,22.4V10.5h-13 M12.3,31.1v8.2 M77.7,31.1v8.2 M12.3,47.6v11.9h13.1 M33.6,59.5h7.6 M49.1,59.5 h7.7 M77.5,47.6v11.9h-13", polygon: "M55.2,34.9c1.7,0,3.1,1.4,3.1,3.1s-1.4,3.1-3.1,3.1 s-3.1-1.4-3.1-3.1S53.5,34.9,55.2,34.9z M50.4,51c1.7,0,3.1,1.4,3.1,3.1c0,1.7-1.4,3.1-3.1,3.1c-1.7,0-3.1-1.4-3.1-3.1 C47.3,52.4,48.7,51,50.4,51z M55.6,37.1l1.5-7.8 M60.1,13.5l1.6-8.7l-7.8,4 M59,19l-1,5.3 M24,16.1l6.4,4.9l6.4-3.3 M48.5,11.6 l-5.9,3.1 M19.1,12.8L9.7,5.1l1.1,7.7 M13.4,29.8l1,7.3l6.6,1.6 M11.6,18.4l1,6.1 M32.8,41.9 M26.6,40.4 M27.3,40.2l6.1,1.6 M49.9,52.1l-5.6-7.6l-4.9-1.2", lineX: "M15.2,30 M19.7,15.6V1.9H29 M34.8,1.9H40.4 M55.3,15.6V1.9H45.9 M19.7,44.4V58.1H29 M34.8,58.1H40.4 M55.3,44.4 V58.1H45.9 M12.5,20.3l-9.4,9.6l9.6,9.8 M3.1,29.9h16.5 M62.5,20.3l9.4,9.6L62.3,39.7 M71.9,29.9H55.4", lineY: "M38.8,7.7 M52.7,12h13.2v9 M65.9,26.6V32 M52.7,46.3h13.2v-9 M24.9,12H11.8v9 M11.8,26.6V32 M24.9,46.3H11.8v-9 M48.2,5.1l-9.3-9l-9.4,9.2 M38.9-3.9V12 M48.2,53.3l-9.3,9l-9.4-9.2 M38.9,62.3V46.4", keep: "M4,10.5V1h10.3 M20.7,1h6.1 M33,1h6.1 M55.4,10.5V1H45.2 M4,17.3v6.6 M55.6,17.3v6.6 M4,30.5V40h10.3 M20.7,40 h6.1 M33,40h6.1 M55.4,30.5V40H45.2 M21,18.9h62.9v48.6H21V18.9z", clear: "M22,14.7l30.9,31 M52.9,14.7L22,45.7 M4.7,16.8V4.2h13.1 M26,4.2h7.8 M41.6,4.2h7.8 M70.3,16.8V4.2H57.2 M4.7,25.9v8.6 M70.3,25.9v8.6 M4.7,43.2v12.6h13.1 M26,55.8h7.8 M41.6,55.8h7.8 M70.3,43.2v12.6H57.2", }, title: t .getLocaleModel() .get(["toolbox", "brush", "title"]), }; }), e ); })(_z); var JV = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.layoutMode = { type: "box", ignoreSize: !0 }), n ); } return ( n(e, t), (e.type = "title"), (e.defaultOption = { z: 6, show: !0, text: "", target: "blank", subtext: "", subtarget: "blank", left: 0, top: 0, backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, padding: 5, itemGap: 10, textStyle: { fontSize: 18, fontWeight: "bold", color: "#464646", }, subtextStyle: { fontSize: 12, color: "#6E7079" }, }), e ); })(zp), QV = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.render = function (t, e, n) { if ((this.group.removeAll(), t.get("show"))) { var i = this.group, r = t.getModel("textStyle"), o = t.getModel("subtextStyle"), a = t.get("textAlign"), s = rt( t.get("textBaseline"), t.get("textVerticalAlign") ), l = new Xs({ style: oc( r, { text: t.get("text"), fill: r.getTextColor(), }, { disableBox: !0 } ), z2: 10, }), u = l.getBoundingRect(), h = t.get("subtext"), c = new Xs({ style: oc( o, { text: h, fill: o.getTextColor(), y: u.height + t.get("itemGap"), verticalAlign: "top", }, { disableBox: !0 } ), z2: 10, }), p = t.get("link"), d = t.get("sublink"), f = t.get("triggerEvent", !0); (l.silent = !p && !f), (c.silent = !d && !f), p && l.on("click", function () { Mp(p, "_" + t.get("target")); }), d && c.on("click", function () { Mp(d, "_" + t.get("subtarget")); }), (rl(l).eventData = rl(c).eventData = f ? { componentType: "title", componentIndex: t.componentIndex, } : null), i.add(l), h && i.add(c); var g = i.getBoundingRect(), y = t.getBoxLayoutParams(); (y.width = g.width), (y.height = g.height); var v = kp( y, { width: n.getWidth(), height: n.getHeight() }, t.get("padding") ); a || ("middle" === (a = t.get("left") || t.get("right")) && (a = "center"), "right" === a ? (v.x += v.width) : "center" === a && (v.x += v.width / 2)), s || ("center" === (s = t.get("top") || t.get("bottom")) && (s = "middle"), "bottom" === s ? (v.y += v.height) : "middle" === s && (v.y += v.height / 2), (s = s || "top")), (i.x = v.x), (i.y = v.y), i.markRedraw(); var m = { align: a, verticalAlign: s }; l.setStyle(m), c.setStyle(m), (g = i.getBoundingRect()); var x = v.margin, _ = t.getItemStyle(["color", "opacity"]); _.fill = t.get("backgroundColor"); var b = new Ws({ shape: { x: g.x - x[3], y: g.y - x[0], width: g.width + x[1] + x[3], height: g.height + x[0] + x[2], r: t.get("borderRadius"), }, style: _, subPixelOptimize: !0, silent: !0, }); i.add(b); } }), (e.type = "title"), e ); })(Ag); var tB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.layoutMode = "box"), n; } return ( n(e, t), (e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n), this._initData(); }), (e.prototype.mergeOption = function (e) { t.prototype.mergeOption.apply(this, arguments), this._initData(); }), (e.prototype.setCurrentIndex = function (t) { null == t && (t = this.option.currentIndex); var e = this._data.count(); this.option.loop ? (t = ((t % e) + e) % e) : (t >= e && (t = e - 1), t < 0 && (t = 0)), (this.option.currentIndex = t); }), (e.prototype.getCurrentIndex = function () { return this.option.currentIndex; }), (e.prototype.isIndexMax = function () { return this.getCurrentIndex() >= this._data.count() - 1; }), (e.prototype.setPlayState = function (t) { this.option.autoPlay = !!t; }), (e.prototype.getPlayState = function () { return !!this.option.autoPlay; }), (e.prototype._initData = function () { var t, e = this.option, n = e.data || [], i = e.axisType, r = (this._names = []); "category" === i ? ((t = []), E(n, function (e, n) { var i, o = Ro(Ao(e), ""); q(e) ? ((i = T(e)).value = n) : (i = n), t.push(i), r.push(o); })) : (t = n); var o = { category: "ordinal", time: "time", value: "number" }[ i ] || "number"; (this._data = new cx( [{ name: "value", type: o }], this )).initData(t, r); }), (e.prototype.getData = function () { return this._data; }), (e.prototype.getCategories = function () { if ("category" === this.get("axisType")) return this._names.slice(); }), (e.type = "timeline"), (e.defaultOption = { z: 4, show: !0, axisType: "time", realtime: !0, left: "20%", top: null, right: "20%", bottom: 0, width: null, height: 40, padding: 5, controlPosition: "left", autoPlay: !1, rewind: !1, loop: !0, playInterval: 2e3, currentIndex: 0, itemStyle: {}, label: { color: "#000" }, data: [], }), e ); })(zp), eB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.type = "timeline.slider"), (e.defaultOption = kc(tB.defaultOption, { backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderWidth: 0, orient: "horizontal", inverse: !1, tooltip: { trigger: "item" }, symbol: "circle", symbolSize: 12, lineStyle: { show: !0, width: 2, color: "#DAE1F5" }, label: { position: "auto", show: !0, interval: "auto", rotate: 0, color: "#A4B1D7", }, itemStyle: { color: "#A4B1D7", borderWidth: 1 }, checkpointStyle: { symbol: "circle", symbolSize: 15, color: "#316bf3", borderColor: "#fff", borderWidth: 2, shadowBlur: 2, shadowOffsetX: 1, shadowOffsetY: 1, shadowColor: "rgba(0, 0, 0, 0.3)", animation: !0, animationDuration: 300, animationEasing: "quinticInOut", }, controlStyle: { show: !0, showPlayBtn: !0, showPrevBtn: !0, showNextBtn: !0, itemSize: 24, itemGap: 12, position: "left", playIcon: "path://M31.6,53C17.5,53,6,41.5,6,27.4S17.5,1.8,31.6,1.8C45.7,1.8,57.2,13.3,57.2,27.4S45.7,53,31.6,53z M31.6,3.3 C18.4,3.3,7.5,14.1,7.5,27.4c0,13.3,10.8,24.1,24.1,24.1C44.9,51.5,55.7,40.7,55.7,27.4C55.7,14.1,44.9,3.3,31.6,3.3z M24.9,21.3 c0-2.2,1.6-3.1,3.5-2l10.5,6.1c1.899,1.1,1.899,2.9,0,4l-10.5,6.1c-1.9,1.1-3.5,0.2-3.5-2V21.3z", stopIcon: "path://M30.9,53.2C16.8,53.2,5.3,41.7,5.3,27.6S16.8,2,30.9,2C45,2,56.4,13.5,56.4,27.6S45,53.2,30.9,53.2z M30.9,3.5C17.6,3.5,6.8,14.4,6.8,27.6c0,13.3,10.8,24.1,24.101,24.1C44.2,51.7,55,40.9,55,27.6C54.9,14.4,44.1,3.5,30.9,3.5z M36.9,35.8c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H36c0.5,0,0.9,0.4,0.9,1V35.8z M27.8,35.8 c0,0.601-0.4,1-0.9,1h-1.3c-0.5,0-0.9-0.399-0.9-1V19.5c0-0.6,0.4-1,0.9-1H27c0.5,0,0.9,0.4,0.9,1L27.8,35.8L27.8,35.8z", nextIcon: "M2,18.5A1.52,1.52,0,0,1,.92,18a1.49,1.49,0,0,1,0-2.12L7.81,9.36,1,3.11A1.5,1.5,0,1,1,3,.89l8,7.34a1.48,1.48,0,0,1,.49,1.09,1.51,1.51,0,0,1-.46,1.1L3,18.08A1.5,1.5,0,0,1,2,18.5Z", prevIcon: "M10,.5A1.52,1.52,0,0,1,11.08,1a1.49,1.49,0,0,1,0,2.12L4.19,9.64,11,15.89a1.5,1.5,0,1,1-2,2.22L1,10.77A1.48,1.48,0,0,1,.5,9.68,1.51,1.51,0,0,1,1,8.58L9,.92A1.5,1.5,0,0,1,10,.5Z", prevBtnSize: 18, nextBtnSize: 18, color: "#A4B1D7", borderColor: "#A4B1D7", borderWidth: 1, }, emphasis: { label: { show: !0, color: "#6f778d" }, itemStyle: { color: "#316BF3" }, controlStyle: { color: "#316BF3", borderColor: "#316BF3", borderWidth: 2, }, }, progress: { lineStyle: { color: "#316BF3" }, itemStyle: { color: "#316BF3" }, label: { color: "#6f778d" }, }, data: [], })), e ); })(tB); R(eB, _f.prototype); var nB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return n(e, t), (e.type = "timeline"), e; })(Ag), iB = (function (t) { function e(e, n, i, r) { var o = t.call(this, e, n, i) || this; return (o.type = r || "value"), o; } return ( n(e, t), (e.prototype.getLabelModel = function () { return this.model.getModel("label"); }), (e.prototype.isHorizontal = function () { return "horizontal" === this.model.get("orient"); }), e ); })(ab), rB = Math.PI, oB = Vo(), aB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function (t, e) { this.api = e; }), (e.prototype.render = function (t, e, n) { if ( ((this.model = t), (this.api = n), (this.ecModel = e), this.group.removeAll(), t.get("show", !0)) ) { var i = this._layout(t, n), r = this._createGroup("_mainGroup"), o = this._createGroup("_labelGroup"), a = (this._axis = this._createAxis(i, t)); (t.formatTooltip = function (t) { return og("nameValue", { noName: !0, value: a.scale.getLabel({ value: t }), }); }), E( [ "AxisLine", "AxisTick", "Control", "CurrentPointer", ], function (e) { this["_render" + e](i, r, a, t); }, this ), this._renderAxisLabel(i, o, a, t), this._position(i, t); } this._doPlayStop(), this._updateTicksStatus(); }), (e.prototype.remove = function () { this._clearTimer(), this.group.removeAll(); }), (e.prototype.dispose = function () { this._clearTimer(); }), (e.prototype._layout = function (t, e) { var n, i, r, o, a = t.get(["label", "position"]), s = t.get("orient"), l = (function (t, e) { return kp( t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }, t.get("padding") ); })(t, e), u = { horizontal: "center", vertical: (n = null == a || "auto" === a ? "horizontal" === s ? l.y + l.height / 2 < e.getHeight() / 2 ? "-" : "+" : l.x + l.width / 2 < e.getWidth() / 2 ? "+" : "-" : U(a) ? { horizontal: { top: "-", bottom: "+", }, vertical: { left: "-", right: "+", }, }[s][a] : a) >= 0 || "+" === n ? "left" : "right", }, h = { horizontal: n >= 0 || "+" === n ? "top" : "bottom", vertical: "middle", }, c = { horizontal: 0, vertical: rB / 2 }, p = "vertical" === s ? l.height : l.width, d = t.getModel("controlStyle"), f = d.get("show", !0), g = f ? d.get("itemSize") : 0, y = f ? d.get("itemGap") : 0, v = g + y, m = t.get(["label", "rotate"]) || 0; m = (m * rB) / 180; var x = d.get("position", !0), _ = f && d.get("showPlayBtn", !0), b = f && d.get("showPrevBtn", !0), w = f && d.get("showNextBtn", !0), S = 0, M = p; "left" === x || "bottom" === x ? (_ && ((i = [0, 0]), (S += v)), b && ((r = [S, 0]), (S += v)), w && ((o = [M - g, 0]), (M -= v))) : (_ && ((i = [M - g, 0]), (M -= v)), b && ((r = [0, 0]), (S += v)), w && ((o = [M - g, 0]), (M -= v))); var I = [S, M]; return ( t.get("inverse") && I.reverse(), { viewRect: l, mainLength: p, orient: s, rotation: c[s], labelRotation: m, labelPosOpt: n, labelAlign: t.get(["label", "align"]) || u[s], labelBaseline: t.get(["label", "verticalAlign"]) || t.get(["label", "baseline"]) || h[s], playPosition: i, prevBtnPosition: r, nextBtnPosition: o, axisExtent: I, controlSize: g, controlGap: y, } ); }), (e.prototype._position = function (t, e) { var n = this._mainGroup, i = this._labelGroup, r = t.viewRect; if ("vertical" === t.orient) { var o = [1, 0, 0, 1, 0, 0], a = r.x, s = r.y + r.height; we(o, o, [-a, -s]), Se(o, o, -rB / 2), we(o, o, [a, s]), (r = r.clone()).applyTransform(o); } var l = y(r), u = y(n.getBoundingRect()), h = y(i.getBoundingRect()), c = [n.x, n.y], p = [i.x, i.y]; p[0] = c[0] = l[0][0]; var d, f = t.labelPosOpt; null == f || U(f) ? (v(c, u, l, 1, (d = "+" === f ? 0 : 1)), v(p, h, l, 1, 1 - d)) : (v(c, u, l, 1, (d = f >= 0 ? 0 : 1)), (p[1] = c[1] + f)); function g(t) { (t.originX = l[0][0] - t.x), (t.originY = l[1][0] - t.y); } function y(t) { return [ [t.x, t.x + t.width], [t.y, t.y + t.height], ]; } function v(t, e, n, i, r) { t[i] += n[i][r] - e[i][r]; } n.setPosition(c), i.setPosition(p), (n.rotation = i.rotation = t.rotation), g(n), g(i); }), (e.prototype._createAxis = function (t, e) { var n = e.getData(), i = e.get("axisType"), r = (function (t, e) { if (((e = e || t.get("type")), e)) switch (e) { case "category": return new Rx({ ordinalMeta: t.getCategories(), extent: [1 / 0, -1 / 0], }); case "time": return new Kx({ locale: t.ecModel.getLocaleModel(), useUTC: t.ecModel.get("useUTC"), }); default: return new Ex(); } })(e, i); r.getTicks = function () { return n.mapArray(["value"], function (t) { return { value: t }; }); }; var o = n.getDataExtent("value"); r.setExtent(o[0], o[1]), r.calcNiceTicks(); var a = new iB("value", r, t.axisExtent, i); return (a.model = e), a; }), (e.prototype._createGroup = function (t) { var e = (this[t] = new Br()); return this.group.add(e), e; }), (e.prototype._renderAxisLine = function (t, e, n, i) { var r = n.getExtent(); if (i.get(["lineStyle", "show"])) { var o = new Ku({ shape: { x1: r[0], y1: 0, x2: r[1], y2: 0 }, style: A( { lineCap: "round" }, i.getModel("lineStyle").getLineStyle() ), silent: !0, z2: 1, }); e.add(o); var a = (this._progressLine = new Ku({ shape: { x1: r[0], x2: this._currentPointer ? this._currentPointer.x : r[0], y1: 0, y2: 0, }, style: k( { lineCap: "round", lineWidth: o.style.lineWidth, }, i .getModel(["progress", "lineStyle"]) .getLineStyle() ), silent: !0, z2: 1, })); e.add(a); } }), (e.prototype._renderAxisTick = function (t, e, n, i) { var r = this, o = i.getData(), a = n.scale.getTicks(); (this._tickSymbols = []), E(a, function (t) { var a = n.dataToCoord(t.value), s = o.getItemModel(t.value), l = s.getModel("itemStyle"), u = s.getModel(["emphasis", "itemStyle"]), h = s.getModel(["progress", "itemStyle"]), c = { x: a, y: 0, onclick: W(r._changeTimeline, r, t.value), }, p = sB(s, l, e, c); (p.ensureState("emphasis").style = u.getItemStyle()), (p.ensureState("progress").style = h.getItemStyle()), Ul(p); var d = rl(p); s.get("tooltip") ? ((d.dataIndex = t.value), (d.dataModel = i)) : (d.dataIndex = d.dataModel = null), r._tickSymbols.push(p); }); }), (e.prototype._renderAxisLabel = function (t, e, n, i) { var r = this; if (n.getLabelModel().get("show")) { var o = i.getData(), a = n.getViewLabels(); (this._tickLabels = []), E(a, function (i) { var a = i.tickValue, s = o.getItemModel(a), l = s.getModel("label"), u = s.getModel(["emphasis", "label"]), h = s.getModel(["progress", "label"]), c = n.dataToCoord(i.tickValue), p = new Xs({ x: c, y: 0, rotation: t.labelRotation - t.rotation, onclick: W(r._changeTimeline, r, a), silent: !1, style: oc(l, { text: i.formattedLabel, align: t.labelAlign, verticalAlign: t.labelBaseline, }), }); (p.ensureState("emphasis").style = oc(u)), (p.ensureState("progress").style = oc(h)), e.add(p), Ul(p), (oB(p).dataIndex = a), r._tickLabels.push(p); }); } }), (e.prototype._renderControl = function (t, e, n, i) { var r = t.controlSize, o = t.rotation, a = i.getModel("controlStyle").getItemStyle(), s = i .getModel(["emphasis", "controlStyle"]) .getItemStyle(), l = i.getPlayState(), u = i.get("inverse", !0); function h(t, n, l, u) { if (t) { var h = Cr( rt( i.get(["controlStyle", n + "BtnSize"]), r ), r ), c = (function (t, e, n, i) { var r = i.style, o = Uh( t.get(["controlStyle", e]), i || {}, new ze(n[0], n[1], n[2], n[3]) ); r && o.setStyle(r); return o; })(i, n + "Icon", [0, -h / 2, h, h], { x: t[0], y: t[1], originX: r / 2, originY: 0, rotation: u ? -o : 0, rectHover: !0, style: a, onclick: l, }); (c.ensureState("emphasis").style = s), e.add(c), Ul(c); } } h( t.nextBtnPosition, "next", W(this._changeTimeline, this, u ? "-" : "+") ), h( t.prevBtnPosition, "prev", W(this._changeTimeline, this, u ? "+" : "-") ), h( t.playPosition, l ? "stop" : "play", W(this._handlePlayClick, this, !l), !0 ); }), (e.prototype._renderCurrentPointer = function (t, e, n, i) { var r = i.getData(), o = i.getCurrentIndex(), a = r.getItemModel(o).getModel("checkpointStyle"), s = this, l = { onCreate: function (t) { (t.draggable = !0), (t.drift = W(s._handlePointerDrag, s)), (t.ondragend = W( s._handlePointerDragend, s )), lB(t, s._progressLine, o, n, i, !0); }, onUpdate: function (t) { lB(t, s._progressLine, o, n, i); }, }; this._currentPointer = sB( a, a, this._mainGroup, {}, this._currentPointer, l ); }), (e.prototype._handlePlayClick = function (t) { this._clearTimer(), this.api.dispatchAction({ type: "timelinePlayChange", playState: t, from: this.uid, }); }), (e.prototype._handlePointerDrag = function (t, e, n) { this._clearTimer(), this._pointerChangeTimeline([n.offsetX, n.offsetY]); }), (e.prototype._handlePointerDragend = function (t) { this._pointerChangeTimeline([t.offsetX, t.offsetY], !0); }), (e.prototype._pointerChangeTimeline = function (t, e) { var n = this._toAxisCoord(t)[0], i = Qr(this._axis.getExtent().slice()); n > i[1] && (n = i[1]), n < i[0] && (n = i[0]), (this._currentPointer.x = n), this._currentPointer.markRedraw(); var r = this._progressLine; r && ((r.shape.x2 = n), r.dirty()); var o = this._findNearestTick(n), a = this.model; (e || (o !== a.getCurrentIndex() && a.get("realtime"))) && this._changeTimeline(o); }), (e.prototype._doPlayStop = function () { var t = this; this._clearTimer(), this.model.getPlayState() && (this._timer = setTimeout(function () { var e = t.model; t._changeTimeline( e.getCurrentIndex() + (e.get("rewind", !0) ? -1 : 1) ); }, this.model.get("playInterval"))); }), (e.prototype._toAxisCoord = function (t) { return Fh(t, this._mainGroup.getLocalTransform(), !0); }), (e.prototype._findNearestTick = function (t) { var e, n = this.model.getData(), i = 1 / 0, r = this._axis; return ( n.each(["value"], function (n, o) { var a = r.dataToCoord(n), s = Math.abs(a - t); s < i && ((i = s), (e = o)); }), e ); }), (e.prototype._clearTimer = function () { this._timer && (clearTimeout(this._timer), (this._timer = null)); }), (e.prototype._changeTimeline = function (t) { var e = this.model.getCurrentIndex(); "+" === t ? (t = e + 1) : "-" === t && (t = e - 1), this.api.dispatchAction({ type: "timelineChange", currentIndex: t, from: this.uid, }); }), (e.prototype._updateTicksStatus = function () { var t = this.model.getCurrentIndex(), e = this._tickSymbols, n = this._tickLabels; if (e) for (var i = 0; i < e.length; i++) e && e[i] && e[i].toggleState("progress", i < t); if (n) for (i = 0; i < n.length; i++) n && n[i] && n[i].toggleState( "progress", oB(n[i]).dataIndex <= t ); }), (e.type = "timeline.slider"), e ); })(nB); function sB(t, e, n, i, r, o) { var a = e.get("color"); r ? (r.setColor(a), n.add(r), o && o.onUpdate(r)) : ((r = Xy(t.get("symbol"), -1, -1, 2, 2, a)).setStyle( "strokeNoScale", !0 ), n.add(r), o && o.onCreate(r)); var s = e.getItemStyle(["color"]); r.setStyle(s), (i = C({ rectHover: !0, z2: 100 }, i, !0)); var l = Uy(t.get("symbolSize")); (i.scaleX = l[0] / 2), (i.scaleY = l[1] / 2); var u = Zy(t.get("symbolOffset"), l); u && ((i.x = (i.x || 0) + u[0]), (i.y = (i.y || 0) + u[1])); var h = t.get("symbolRotate"); return ( (i.rotation = ((h || 0) * Math.PI) / 180 || 0), r.attr(i), r.updateTransform(), r ); } function lB(t, e, n, i, r, o) { if (!t.dragging) { var a = r.getModel("checkpointStyle"), s = i.dataToCoord(r.getData().get("value", n)); if (o || !a.get("animation", !0)) t.attr({ x: s, y: 0 }), e && e.attr({ shape: { x2: s } }); else { var l = { duration: a.get("animationDuration", !0), easing: a.get("animationEasing", !0), }; t.stopAnimation(null, !0), t.animateTo({ x: s, y: 0 }, l), e && e.animateTo({ shape: { x2: s } }, l); } } } function uB(t) { var e = t && t.timeline; Y(e) || (e = e ? [e] : []), E(e, function (t) { t && (function (t) { var e = t.type, n = { number: "value", time: "time" }; n[e] && ((t.axisType = n[e]), delete t.type); if ((hB(t), cB(t, "controlPosition"))) { var i = t.controlStyle || (t.controlStyle = {}); cB(i, "position") || (i.position = t.controlPosition), "none" !== i.position || cB(i, "show") || ((i.show = !1), delete i.position), delete t.controlPosition; } E(t.data || [], function (t) { q(t) && !Y(t) && (!cB(t, "value") && cB(t, "name") && (t.value = t.name), hB(t)); }); })(t); }); } function hB(t) { var e = t.itemStyle || (t.itemStyle = {}), n = e.emphasis || (e.emphasis = {}), i = t.label || t.label || {}, r = i.normal || (i.normal = {}), o = { normal: 1, emphasis: 1 }; E(i, function (t, e) { o[e] || cB(r, e) || (r[e] = t); }), n.label && !cB(i, "emphasis") && ((i.emphasis = n.label), delete n.label); } function cB(t, e) { return t.hasOwnProperty(e); } function pB(t, e) { if (!t) return !1; for (var n = Y(t) ? t : [t], i = 0; i < n.length; i++) if (n[i] && n[i][e]) return !0; return !1; } function dB(t) { Co(t, "label", ["show"]); } var fB = Vo(), gB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.createdBySelf = !1), n; } return ( n(e, t), (e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n), this._mergeOption(t, n, !1, !0); }), (e.prototype.isAnimationEnabled = function () { if (r.node) return !1; var t = this.__hostSeries; return ( this.getShallow("animation") && t && t.isAnimationEnabled() ); }), (e.prototype.mergeOption = function (t, e) { this._mergeOption(t, e, !1, !1); }), (e.prototype._mergeOption = function (t, e, n, i) { var r = this.mainType; n || e.eachSeries(function (t) { var n = t.get(this.mainType, !0), o = fB(t)[r]; n && n.data ? (o ? o._mergeOption(n, e, !0) : (i && dB(n), E(n.data, function (t) { t instanceof Array ? (dB(t[0]), dB(t[1])) : dB(t); }), A( (o = this.createMarkerModelFromSeries( n, this, e )), { mainType: this.mainType, seriesIndex: t.seriesIndex, name: t.name, createdBySelf: !0, } ), (o.__hostSeries = t)), (fB(t)[r] = o)) : (fB(t)[r] = null); }, this); }), (e.prototype.formatTooltip = function (t, e, n) { var i = this.getData(), r = this.getRawValue(t), o = i.getName(t); return og("section", { header: this.name, blocks: [ og("nameValue", { name: o, value: r, noName: !o, noValue: null == r, }), ], }); }), (e.prototype.getData = function () { return this._data; }), (e.prototype.setData = function (t) { this._data = t; }), (e.prototype.getDataParams = function (t, e) { var n = _f.prototype.getDataParams.call(this, t, e), i = this.__hostSeries; return ( i && ((n.seriesId = i.id), (n.seriesName = i.name), (n.seriesType = i.subType)), n ); }), (e.getMarkerModelFromSeries = function (t, e) { return fB(t)[e]; }), (e.type = "marker"), (e.dependencies = ["series", "grid", "polar", "geo"]), e ); })(zp); R(gB, _f.prototype); var yB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.createMarkerModelFromSeries = function (t, n, i) { return new e(t, n, i); }), (e.type = "markPoint"), (e.defaultOption = { z: 5, symbol: "pin", symbolSize: 50, tooltip: { trigger: "item" }, label: { show: !0, position: "inside" }, itemStyle: { borderWidth: 2 }, emphasis: { label: { show: !0 } }, }), e ); })(gB); function vB(t) { return !(isNaN(parseFloat(t.x)) && isNaN(parseFloat(t.y))); } function mB(t, e, n, i, r, o) { var a = [], s = mx(e, i) ? e.getCalculationInfo("stackResultDimension") : i, l = MB(e, s, t), u = e.indicesOfNearest(s, l)[0]; (a[r] = e.get(n, u)), (a[o] = e.get(s, u)); var h = e.get(i, u), c = to(e.get(i, u)); return (c = Math.min(c, 20)) >= 0 && (a[o] = +a[o].toFixed(c)), [a, h]; } var xB = { min: H(mB, "min"), max: H(mB, "max"), average: H(mB, "average"), median: H(mB, "median"), }; function _B(t, e) { if (e) { var n = t.getData(), i = t.coordinateSystem, r = i && i.dimensions; if ( !(function (t) { return !isNaN(parseFloat(t.x)) && !isNaN(parseFloat(t.y)); })(e) && !Y(e.coord) && Y(r) ) { var o = bB(e, n, i, t); if ( (e = T(e)).type && xB[e.type] && o.baseAxis && o.valueAxis ) { var a = P(r, o.baseAxis.dim), s = P(r, o.valueAxis.dim), l = xB[e.type](n, o.baseDataDim, o.valueDataDim, a, s); (e.coord = l[0]), (e.value = l[1]); } else e.coord = [ null != e.xAxis ? e.xAxis : e.radiusAxis, null != e.yAxis ? e.yAxis : e.angleAxis, ]; } if (null != e.coord && Y(r)) for (var u = e.coord, h = 0; h < 2; h++) xB[u[h]] && (u[h] = MB(n, n.mapDimension(r[h]), u[h])); else e.coord = []; return e; } } function bB(t, e, n, i) { var r = {}; return ( null != t.valueIndex || null != t.valueDim ? ((r.valueDataDim = null != t.valueIndex ? e.getDimension(t.valueIndex) : t.valueDim), (r.valueAxis = n.getAxis( (function (t, e) { var n = t.getData().getDimensionInfo(e); return n && n.coordDim; })(i, r.valueDataDim) )), (r.baseAxis = n.getOtherAxis(r.valueAxis)), (r.baseDataDim = e.mapDimension(r.baseAxis.dim))) : ((r.baseAxis = i.getBaseAxis()), (r.valueAxis = n.getOtherAxis(r.baseAxis)), (r.baseDataDim = e.mapDimension(r.baseAxis.dim)), (r.valueDataDim = e.mapDimension(r.valueAxis.dim))), r ); } function wB(t, e) { return ( !(t && t.containData && e.coord && !vB(e)) || t.containData(e.coord) ); } function SB(t, e) { return t ? function (t, n, i, r) { return If(r < 2 ? t.coord && t.coord[r] : t.value, e[r]); } : function (t, n, i, r) { return If(t.value, e[r]); }; } function MB(t, e, n) { if ("average" === n) { var i = 0, r = 0; return ( t.each(e, function (t, e) { isNaN(t) || ((i += t), r++); }), i / r ); } return "median" === n ? t.getMedian(e) : t.getDataExtent(e)["max" === n ? 1 : 0]; } var IB = Vo(), TB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.init = function () { this.markerGroupMap = yt(); }), (e.prototype.render = function (t, e, n) { var i = this, r = this.markerGroupMap; r.each(function (t) { IB(t).keep = !1; }), e.eachSeries(function (t) { var r = gB.getMarkerModelFromSeries(t, i.type); r && i.renderSeries(t, r, e, n); }), r.each(function (t) { !IB(t).keep && i.group.remove(t.group); }); }), (e.prototype.markKeep = function (t) { IB(t).keep = !0; }), (e.prototype.toggleBlurSeries = function (t, e) { var n = this; E(t, function (t) { var i = gB.getMarkerModelFromSeries(t, n.type); i && i.getData().eachItemGraphicEl(function (t) { t && (e ? Nl(t) : El(t)); }); }); }), (e.type = "marker"), e ); })(Ag); function CB(t, e, n) { var i = e.coordinateSystem; t.each(function (r) { var o, a = t.getItemModel(r), s = $r(a.get("x"), n.getWidth()), l = $r(a.get("y"), n.getHeight()); if (isNaN(s) || isNaN(l)) { if (e.getMarkerPosition) o = e.getMarkerPosition(t.getValues(t.dimensions, r)); else if (i) { var u = t.get(i.dimensions[0], r), h = t.get(i.dimensions[1], r); o = i.dataToPoint([u, h]); } } else o = [s, l]; isNaN(s) || (o[0] = s), isNaN(l) || (o[1] = l), t.setItemLayout(r, o); }); } var DB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.updateTransform = function (t, e, n) { e.eachSeries(function (t) { var e = gB.getMarkerModelFromSeries(t, "markPoint"); e && (CB(e.getData(), t, n), this.markerGroupMap.get(t.id).updateLayout()); }, this); }), (e.prototype.renderSeries = function (t, e, n, i) { var r = t.coordinateSystem, o = t.id, a = t.getData(), s = this.markerGroupMap, l = s.get(o) || s.set(o, new xS()), u = (function (t, e, n) { var i; i = t ? z(t && t.dimensions, function (t) { return A( A( {}, e .getData() .getDimensionInfo( e.getData().mapDimension(t) ) || {} ), { name: t, ordinalMeta: null } ); }) : [{ name: "value", type: "float" }]; var r = new cx(i, n), o = z(n.get("data"), H(_B, e)); t && (o = B(o, H(wB, t))); var a = SB(!!t, i); return r.initData(o, null, a), r; })(r, t, e); e.setData(u), CB(e.getData(), t, i), u.each(function (t) { var n = u.getItemModel(t), i = n.getShallow("symbol"), r = n.getShallow("symbolSize"), o = n.getShallow("symbolRotate"), s = n.getShallow("symbolOffset"), l = n.getShallow("symbolKeepAspect"); if (X(i) || X(r) || X(o) || X(s)) { var h = e.getRawValue(t), c = e.getDataParams(t); X(i) && (i = i(h, c)), X(r) && (r = r(h, c)), X(o) && (o = o(h, c)), X(s) && (s = s(h, c)); } var p = n.getModel("itemStyle").getItemStyle(), d = Ay(a, "color"); p.fill || (p.fill = d), u.setItemVisual(t, { symbol: i, symbolSize: r, symbolRotate: o, symbolOffset: s, symbolKeepAspect: l, style: p, }); }), l.updateData(u), this.group.add(l.group), u.eachItemGraphicEl(function (t) { t.traverse(function (t) { rl(t).dataModel = e; }); }), this.markKeep(l), (l.group.silent = e.get("silent") || t.get("silent")); }), (e.type = "markPoint"), e ); })(TB); var AB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.createMarkerModelFromSeries = function (t, n, i) { return new e(t, n, i); }), (e.type = "markLine"), (e.defaultOption = { z: 5, symbol: ["circle", "arrow"], symbolSize: [8, 16], symbolOffset: 0, precision: 2, tooltip: { trigger: "item" }, label: { show: !0, position: "end", distance: 5 }, lineStyle: { type: "dashed" }, emphasis: { label: { show: !0 }, lineStyle: { width: 3 } }, animationEasing: "linear", }), e ); })(gB), kB = Vo(), LB = function (t, e, n, i) { var r, o = t.getData(); if (Y(i)) r = i; else { var a = i.type; if ( "min" === a || "max" === a || "average" === a || "median" === a || null != i.xAxis || null != i.yAxis ) { var s = void 0, l = void 0; if (null != i.yAxis || null != i.xAxis) (s = e.getAxis(null != i.yAxis ? "y" : "x")), (l = it(i.yAxis, i.xAxis)); else { var u = bB(i, o, e, t); (s = u.valueAxis), (l = MB(o, xx(o, u.valueDataDim), a)); } var h = "x" === s.dim ? 0 : 1, c = 1 - h, p = T(i), d = { coord: [] }; (p.type = null), (p.coord = []), (p.coord[c] = -1 / 0), (d.coord[c] = 1 / 0); var f = n.get("precision"); f >= 0 && j(l) && (l = +l.toFixed(Math.min(f, 20))), (p.coord[h] = d.coord[h] = l), (r = [ p, d, { type: a, valueIndex: i.valueIndex, value: l }, ]); } else r = []; } var g = [_B(t, r[0]), _B(t, r[1]), A({}, r[2])]; return ( (g[2].type = g[2].type || null), C(g[2], g[0]), C(g[2], g[1]), g ); }; function PB(t) { return !isNaN(t) && !isFinite(t); } function OB(t, e, n, i) { var r = 1 - t, o = i.dimensions[t]; return ( PB(e[r]) && PB(n[r]) && e[t] === n[t] && i.getAxis(o).containData(e[t]) ); } function RB(t, e) { if ("cartesian2d" === t.type) { var n = e[0].coord, i = e[1].coord; if (n && i && (OB(1, n, i, t) || OB(0, n, i, t))) return !0; } return wB(t, e[0]) && wB(t, e[1]); } function NB(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = $r(s.get("x"), r.getWidth()), u = $r(s.get("y"), r.getHeight()); if (isNaN(l) || isNaN(u)) { if (i.getMarkerPosition) o = i.getMarkerPosition(t.getValues(t.dimensions, e)); else { var h = a.dimensions, c = t.get(h[0], e), p = t.get(h[1], e); o = a.dataToPoint([c, p]); } if (OS(a, "cartesian2d")) { var d = a.getAxis("x"), f = a.getAxis("y"); h = a.dimensions; PB(t.get(h[0], e)) ? (o[0] = d.toGlobalCoord(d.getExtent()[n ? 0 : 1])) : PB(t.get(h[1], e)) && (o[1] = f.toGlobalCoord(f.getExtent()[n ? 0 : 1])); } isNaN(l) || (o[0] = l), isNaN(u) || (o[1] = u); } else o = [l, u]; t.setItemLayout(e, o); } var EB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.updateTransform = function (t, e, n) { e.eachSeries(function (t) { var e = gB.getMarkerModelFromSeries(t, "markLine"); if (e) { var i = e.getData(), r = kB(e).from, o = kB(e).to; r.each(function (e) { NB(r, e, !0, t, n), NB(o, e, !1, t, n); }), i.each(function (t) { i.setItemLayout(t, [ r.getItemLayout(t), o.getItemLayout(t), ]); }), this.markerGroupMap.get(t.id).updateLayout(); } }, this); }), (e.prototype.renderSeries = function (t, e, n, i) { var r = t.coordinateSystem, o = t.id, a = t.getData(), s = this.markerGroupMap, l = s.get(o) || s.set(o, new YA()); this.group.add(l.group); var u = (function (t, e, n) { var i; i = t ? z(t && t.dimensions, function (t) { return A( A( {}, e .getData() .getDimensionInfo( e.getData().mapDimension(t) ) || {} ), { name: t, ordinalMeta: null } ); }) : [{ name: "value", type: "float" }]; var r = new cx(i, n), o = new cx(i, n), a = new cx([], n), s = z(n.get("data"), H(LB, e, t, n)); t && (s = B(s, H(RB, t))); var l = SB(!!t, i); return ( r.initData( z(s, function (t) { return t[0]; }), null, l ), o.initData( z(s, function (t) { return t[1]; }), null, l ), a.initData( z(s, function (t) { return t[2]; }) ), (a.hasItemOption = !0), { from: r, to: o, line: a } ); })(r, t, e), h = u.from, c = u.to, p = u.line; (kB(e).from = h), (kB(e).to = c), e.setData(p); var d = e.get("symbol"), f = e.get("symbolSize"), g = e.get("symbolRotate"), y = e.get("symbolOffset"); function v(e, n, r) { var o = e.getItemModel(n); NB(e, n, r, t, i); var s = o.getModel("itemStyle").getItemStyle(); null == s.fill && (s.fill = Ay(a, "color")), e.setItemVisual(n, { symbolKeepAspect: o.get("symbolKeepAspect"), symbolOffset: rt( o.get("symbolOffset", !0), y[r ? 0 : 1] ), symbolRotate: rt( o.get("symbolRotate", !0), g[r ? 0 : 1] ), symbolSize: rt(o.get("symbolSize"), f[r ? 0 : 1]), symbol: rt(o.get("symbol", !0), d[r ? 0 : 1]), style: s, }); } Y(d) || (d = [d, d]), Y(f) || (f = [f, f]), Y(g) || (g = [g, g]), Y(y) || (y = [y, y]), u.from.each(function (t) { v(h, t, !0), v(c, t, !1); }), p.each(function (t) { var e = p .getItemModel(t) .getModel("lineStyle") .getLineStyle(); p.setItemLayout(t, [ h.getItemLayout(t), c.getItemLayout(t), ]), null == e.stroke && (e.stroke = h.getItemVisual(t, "style").fill), p.setItemVisual(t, { fromSymbolKeepAspect: h.getItemVisual( t, "symbolKeepAspect" ), fromSymbolOffset: h.getItemVisual( t, "symbolOffset" ), fromSymbolRotate: h.getItemVisual( t, "symbolRotate" ), fromSymbolSize: h.getItemVisual( t, "symbolSize" ), fromSymbol: h.getItemVisual(t, "symbol"), toSymbolKeepAspect: c.getItemVisual( t, "symbolKeepAspect" ), toSymbolOffset: c.getItemVisual( t, "symbolOffset" ), toSymbolRotate: c.getItemVisual( t, "symbolRotate" ), toSymbolSize: c.getItemVisual(t, "symbolSize"), toSymbol: c.getItemVisual(t, "symbol"), style: e, }); }), l.updateData(p), u.line.eachItemGraphicEl(function (t) { (rl(t).dataModel = e), t.traverse(function (t) { rl(t).dataModel = e; }); }), this.markKeep(l), (l.group.silent = e.get("silent") || t.get("silent")); }), (e.type = "markLine"), e ); })(TB); var zB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.createMarkerModelFromSeries = function (t, n, i) { return new e(t, n, i); }), (e.type = "markArea"), (e.defaultOption = { z: 1, tooltip: { trigger: "item" }, animation: !1, label: { show: !0, position: "top" }, itemStyle: { borderWidth: 0 }, emphasis: { label: { show: !0, position: "top" } }, }), e ); })(gB), VB = Vo(), BB = function (t, e, n, i) { var r = i[0], o = i[1]; if (r && o) { var a = _B(t, r), s = _B(t, o), l = a.coord, u = s.coord; (l[0] = it(l[0], -1 / 0)), (l[1] = it(l[1], -1 / 0)), (u[0] = it(u[0], 1 / 0)), (u[1] = it(u[1], 1 / 0)); var h = D([{}, a, s]); return ( (h.coord = [a.coord, s.coord]), (h.x0 = a.x), (h.y0 = a.y), (h.x1 = s.x), (h.y1 = s.y), h ); } }; function FB(t) { return !isNaN(t) && !isFinite(t); } function GB(t, e, n, i) { var r = 1 - t; return FB(e[r]) && FB(n[r]); } function WB(t, e) { var n = e.coord[0], i = e.coord[1], r = { coord: n, x: e.x0, y: e.y0 }, o = { coord: i, x: e.x1, y: e.y1 }; return OS(t, "cartesian2d") ? !(!n || !i || (!GB(1, n, i) && !GB(0, n, i))) || (function (t, e, n) { return ( !( t && t.containZone && e.coord && n.coord && !vB(e) && !vB(n) ) || t.containZone(e.coord, n.coord) ); })(t, r, o) : wB(t, r) || wB(t, o); } function HB(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = $r(s.get(n[0]), r.getWidth()), u = $r(s.get(n[1]), r.getHeight()); if (isNaN(l) || isNaN(u)) { if (i.getMarkerPosition) { var h = t.getValues(["x0", "y0"], e), c = t.getValues(["x1", "y1"], e), p = a.clampData(h), d = a.clampData(c), f = []; "x0" === n[0] ? (f[0] = p[0] > d[0] ? c[0] : h[0]) : (f[0] = p[0] > d[0] ? h[0] : c[0]), "y0" === n[1] ? (f[1] = p[1] > d[1] ? c[1] : h[1]) : (f[1] = p[1] > d[1] ? h[1] : c[1]), (o = i.getMarkerPosition(f, n, !0)); } else { var g = [(m = t.get(n[0], e)), (x = t.get(n[1], e))]; a.clampData && a.clampData(g, g), (o = a.dataToPoint(g, !0)); } if (OS(a, "cartesian2d")) { var y = a.getAxis("x"), v = a.getAxis("y"), m = t.get(n[0], e), x = t.get(n[1], e); FB(m) ? (o[0] = y.toGlobalCoord( y.getExtent()["x0" === n[0] ? 0 : 1] )) : FB(x) && (o[1] = v.toGlobalCoord( v.getExtent()["y0" === n[1] ? 0 : 1] )); } isNaN(l) || (o[0] = l), isNaN(u) || (o[1] = u); } else o = [l, u]; return o; } var YB = [ ["x0", "y0"], ["x1", "y0"], ["x1", "y1"], ["x0", "y1"], ], XB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.updateTransform = function (t, e, n) { e.eachSeries(function (t) { var e = gB.getMarkerModelFromSeries(t, "markArea"); if (e) { var i = e.getData(); i.each(function (e) { var r = z(YB, function (r) { return HB(i, e, r, t, n); }); i.setItemLayout(e, r), i.getItemGraphicEl(e).setShape("points", r); }); } }, this); }), (e.prototype.renderSeries = function (t, e, n, i) { var r = t.coordinateSystem, o = t.id, a = t.getData(), s = this.markerGroupMap, l = s.get(o) || s.set(o, { group: new Br() }); this.group.add(l.group), this.markKeep(l); var u = (function (t, e, n) { var i, r, o = ["x0", "y0", "x1", "y1"]; if (t) { var a = z(t && t.dimensions, function (t) { var n = e.getData(); return A( A( {}, n.getDimensionInfo(n.mapDimension(t)) || {} ), { name: t, ordinalMeta: null } ); }); (r = z(o, function (t, e) { return { name: t, type: a[e % 2].type }; })), (i = new cx(r, n)); } else i = new cx( (r = [{ name: "value", type: "float" }]), n ); var s = z(n.get("data"), H(BB, e, t, n)); t && (s = B(s, H(WB, t))); var l = t ? function (t, e, n, i) { return If( t.coord[Math.floor(i / 2)][i % 2], r[i] ); } : function (t, e, n, i) { return If(t.value, r[i]); }; return ( i.initData(s, null, l), (i.hasItemOption = !0), i ); })(r, t, e); e.setData(u), u.each(function (e) { var n = z(YB, function (n) { return HB(u, e, n, t, i); }), o = r.getAxis("x").scale, s = r.getAxis("y").scale, l = o.getExtent(), h = s.getExtent(), c = [ o.parse(u.get("x0", e)), o.parse(u.get("x1", e)), ], p = [ s.parse(u.get("y0", e)), s.parse(u.get("y1", e)), ]; Qr(c), Qr(p); var d = !!( l[0] > c[1] || l[1] < c[0] || h[0] > p[1] || h[1] < p[0] ); u.setItemLayout(e, { points: n, allClipped: d }); var f = u .getItemModel(e) .getModel("itemStyle") .getItemStyle(), g = Ay(a, "color"); f.fill || ((f.fill = g), U(f.fill) && (f.fill = ii(f.fill, 0.4))), f.stroke || (f.stroke = g), u.setItemVisual(e, "style", f); }), u .diff(VB(l).data) .add(function (t) { var e = u.getItemLayout(t); if (!e.allClipped) { var n = new Xu({ shape: { points: e.points }, }); u.setItemGraphicEl(t, n), l.group.add(n); } }) .update(function (t, n) { var i = VB(l).data.getItemGraphicEl(n), r = u.getItemLayout(t); r.allClipped ? i && l.group.remove(i) : (i ? vh( i, { shape: { points: r.points } }, e, t ) : (i = new Xu({ shape: { points: r.points }, })), u.setItemGraphicEl(t, i), l.group.add(i)); }) .remove(function (t) { var e = VB(l).data.getItemGraphicEl(t); l.group.remove(e); }) .execute(), u.eachItemGraphicEl(function (t, n) { var i = u.getItemModel(n), r = u.getItemVisual(n, "style"); t.useStyle(u.getItemVisual(n, "style")), ic(t, rc(i), { labelFetcher: e, labelDataIndex: n, defaultText: u.getName(n) || "", inheritColor: U(r.fill) ? ii(r.fill, 1) : "#000", }), $l(t, i), Zl( t, null, null, i.get(["emphasis", "disabled"]) ), (rl(t).dataModel = e); }), (VB(l).data = u), (l.group.silent = e.get("silent") || t.get("silent")); }), (e.type = "markArea"), e ); })(TB); var UB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.layoutMode = { type: "box", ignoreSize: !0 }), n ); } return ( n(e, t), (e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n), (t.selected = t.selected || {}), this._updateSelector(t); }), (e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), this._updateSelector(e); }), (e.prototype._updateSelector = function (t) { var e = t.selector, n = this.ecModel; !0 === e && (e = t.selector = ["all", "inverse"]), Y(e) && E(e, function (t, i) { U(t) && (t = { type: t }), (e[i] = C( t, (function (t, e) { return "all" === e ? { type: "all", title: t .getLocaleModel() .get([ "legend", "selector", "all", ]), } : "inverse" === e ? { type: "inverse", title: t .getLocaleModel() .get([ "legend", "selector", "inverse", ]), } : void 0; })(n, t.type) )); }); }), (e.prototype.optionUpdated = function () { this._updateData(this.ecModel); var t = this._data; if (t[0] && "single" === this.get("selectedMode")) { for (var e = !1, n = 0; n < t.length; n++) { var i = t[n].get("name"); if (this.isSelected(i)) { this.select(i), (e = !0); break; } } !e && this.select(t[0].get("name")); } }), (e.prototype._updateData = function (t) { var e = [], n = []; t.eachRawSeries(function (i) { var r, o = i.name; if ((n.push(o), i.legendVisualProvider)) { var a = i.legendVisualProvider.getAllNames(); t.isSeriesFiltered(i) || (n = n.concat(a)), a.length ? (e = e.concat(a)) : (r = !0); } else r = !0; r && No(i) && e.push(i.name); }), (this._availableNames = n); var i = this.get("data") || e, r = yt(), o = z( i, function (t) { return ( (U(t) || j(t)) && (t = { name: t }), r.get(t.name) ? null : (r.set(t.name, !0), new Cc(t, this, this.ecModel)) ); }, this ); this._data = B(o, function (t) { return !!t; }); }), (e.prototype.getData = function () { return this._data; }), (e.prototype.select = function (t) { var e = this.option.selected; "single" === this.get("selectedMode") && E(this._data, function (t) { e[t.get("name")] = !1; }); e[t] = !0; }), (e.prototype.unSelect = function (t) { "single" !== this.get("selectedMode") && (this.option.selected[t] = !1); }), (e.prototype.toggleSelected = function (t) { var e = this.option.selected; e.hasOwnProperty(t) || (e[t] = !0), this[e[t] ? "unSelect" : "select"](t); }), (e.prototype.allSelect = function () { var t = this._data, e = this.option.selected; E(t, function (t) { e[t.get("name", !0)] = !0; }); }), (e.prototype.inverseSelect = function () { var t = this._data, e = this.option.selected; E(t, function (t) { var n = t.get("name", !0); e.hasOwnProperty(n) || (e[n] = !0), (e[n] = !e[n]); }); }), (e.prototype.isSelected = function (t) { var e = this.option.selected; return ( !(e.hasOwnProperty(t) && !e[t]) && P(this._availableNames, t) >= 0 ); }), (e.prototype.getOrient = function () { return "vertical" === this.get("orient") ? { index: 1, name: "vertical" } : { index: 0, name: "horizontal" }; }), (e.type = "legend.plain"), (e.dependencies = ["series"]), (e.defaultOption = { z: 4, show: !0, orient: "horizontal", left: "center", top: 0, align: "auto", backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", borderRadius: 0, borderWidth: 0, padding: 5, itemGap: 10, itemWidth: 25, itemHeight: 14, symbolRotate: "inherit", symbolKeepAspect: !0, inactiveColor: "#ccc", inactiveBorderColor: "#ccc", inactiveBorderWidth: "auto", itemStyle: { color: "inherit", opacity: "inherit", borderColor: "inherit", borderWidth: "auto", borderCap: "inherit", borderJoin: "inherit", borderDashOffset: "inherit", borderMiterLimit: "inherit", }, lineStyle: { width: "auto", color: "inherit", inactiveColor: "#ccc", inactiveWidth: 2, opacity: "inherit", type: "inherit", cap: "inherit", join: "inherit", dashOffset: "inherit", miterLimit: "inherit", }, textStyle: { color: "#333" }, selectedMode: !0, selector: !1, selectorLabel: { show: !0, borderRadius: 10, padding: [3, 5, 3, 5], fontSize: 12, fontFamily: "sans-serif", color: "#666", borderWidth: 1, borderColor: "#666", }, emphasis: { selectorLabel: { show: !0, color: "#eee", backgroundColor: "#666", }, }, selectorPosition: "auto", selectorItemGap: 7, selectorButtonGap: 10, tooltip: { show: !1 }, }), e ); })(zp), ZB = H, jB = E, qB = Br, KB = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n.newlineDisabled = !1), n; } return ( n(e, t), (e.prototype.init = function () { this.group.add((this._contentGroup = new qB())), this.group.add((this._selectorGroup = new qB())), (this._isFirstRender = !0); }), (e.prototype.getContentGroup = function () { return this._contentGroup; }), (e.prototype.getSelectorGroup = function () { return this._selectorGroup; }), (e.prototype.render = function (t, e, n) { var i = this._isFirstRender; if ( ((this._isFirstRender = !1), this.resetInner(), t.get("show", !0)) ) { var r = t.get("align"), o = t.get("orient"); (r && "auto" !== r) || (r = "right" === t.get("left") && "vertical" === o ? "right" : "left"); var a = t.get("selector", !0), s = t.get("selectorPosition", !0); !a || (s && "auto" !== s) || (s = "horizontal" === o ? "end" : "start"), this.renderInner(r, t, e, n, a, o, s); var l = t.getBoxLayoutParams(), u = { width: n.getWidth(), height: n.getHeight() }, h = t.get("padding"), c = kp(l, u, h), p = this.layoutInner(t, r, c, i, a, s), d = kp( k({ width: p.width, height: p.height }, l), u, h ); (this.group.x = d.x - p.x), (this.group.y = d.y - p.y), this.group.markRedraw(), this.group.add((this._backgroundEl = Iz(p, t))); } }), (e.prototype.resetInner = function () { this.getContentGroup().removeAll(), this._backgroundEl && this.group.remove(this._backgroundEl), this.getSelectorGroup().removeAll(); }), (e.prototype.renderInner = function (t, e, n, i, r, o, a) { var s = this.getContentGroup(), l = yt(), u = e.get("selectedMode"), h = []; n.eachRawSeries(function (t) { !t.get("legendHoverLink") && h.push(t.id); }), jB( e.getData(), function (r, o) { var a = r.get("name"); if ( !this.newlineDisabled && ("" === a || "\n" === a) ) { var c = new qB(); return (c.newline = !0), void s.add(c); } var p = n.getSeriesByName(a)[0]; if (!l.get(a)) { if (p) { var d = p.getData(), f = d.getVisual( "legendLineStyle" ) || {}, g = d.getVisual("legendIcon"), y = d.getVisual("style"), v = this._createItem( p, a, o, r, e, t, f, y, g, u, i ); v .on("click", ZB($B, a, null, i, h)) .on( "mouseover", ZB(QB, p.name, null, i, h) ) .on( "mouseout", ZB(tF, p.name, null, i, h) ), n.ssr && v.eachChild(function (t) { var e = rl(t); (e.seriesIndex = p.seriesIndex), (e.dataIndex = o), (e.ssrType = "legend"); }), l.set(a, !0); } else n.eachRawSeries(function (s) { if ( !l.get(a) && s.legendVisualProvider ) { var c = s.legendVisualProvider; if (!c.containName(a)) return; var p = c.indexOfName(a), d = c.getItemVisual( p, "style" ), f = c.getItemVisual( p, "legendIcon" ), g = qn(d.fill); g && 0 === g[3] && ((g[3] = 0.2), (d = A(A({}, d), { fill: ri(g, "rgba"), }))); var y = this._createItem( s, a, o, r, e, t, {}, d, f, u, i ); y .on( "click", ZB($B, null, a, i, h) ) .on( "mouseover", ZB(QB, null, a, i, h) ) .on( "mouseout", ZB(tF, null, a, i, h) ), n.ssr && y.eachChild(function ( t ) { var e = rl(t); (e.seriesIndex = s.seriesIndex), (e.dataIndex = o), (e.ssrType = "legend"); }), l.set(a, !0); } }, this); 0; } }, this ), r && this._createSelector(r, e, i, o, a); }), (e.prototype._createSelector = function (t, e, n, i, r) { var o = this.getSelectorGroup(); jB(t, function (t) { var i = t.type, r = new Xs({ style: { x: 0, y: 0, align: "center", verticalAlign: "middle", }, onclick: function () { n.dispatchAction({ type: "all" === i ? "legendAllSelect" : "legendInverseSelect", legendId: e.id, }); }, }); o.add(r), ic( r, { normal: e.getModel("selectorLabel"), emphasis: e.getModel([ "emphasis", "selectorLabel", ]), }, { defaultText: t.title } ), Ul(r); }); }), (e.prototype._createItem = function ( t, e, n, i, r, o, a, s, l, u, h ) { var c = t.visualDrawType, p = r.get("itemWidth"), d = r.get("itemHeight"), f = r.isSelected(e), g = i.get("symbolRotate"), y = i.get("symbolKeepAspect"), v = i.get("icon"), m = (function (t, e, n, i, r, o, a) { function s(t, e) { "auto" === t.lineWidth && (t.lineWidth = e.lineWidth > 0 ? 2 : 0), jB(t, function (n, i) { "inherit" === t[i] && (t[i] = e[i]); }); } var l = e.getModel("itemStyle"), u = l.getItemStyle(), h = 0 === t.lastIndexOf("empty", 0) ? "fill" : "stroke", c = l.getShallow("decal"); (u.decal = c && "inherit" !== c ? mv(c, a) : i.decal), "inherit" === u.fill && (u.fill = i[r]); "inherit" === u.stroke && (u.stroke = i[h]); "inherit" === u.opacity && (u.opacity = ("fill" === r ? i : n).opacity); s(u, i); var p = e.getModel("lineStyle"), d = p.getLineStyle(); if ( (s(d, n), "auto" === u.fill && (u.fill = i.fill), "auto" === u.stroke && (u.stroke = i.fill), "auto" === d.stroke && (d.stroke = i.fill), !o) ) { var f = e.get("inactiveBorderWidth"), g = u[h]; (u.lineWidth = "auto" === f ? i.lineWidth > 0 && g ? 2 : 0 : u.lineWidth), (u.fill = e.get("inactiveColor")), (u.stroke = e.get("inactiveBorderColor")), (d.stroke = p.get("inactiveColor")), (d.lineWidth = p.get("inactiveWidth")); } return { itemStyle: u, lineStyle: d }; })((l = v || l || "roundRect"), i, a, s, c, f, h), x = new qB(), _ = i.getModel("textStyle"); if (!X(t.getLegendIcon) || (v && "inherit" !== v)) { var b = "inherit" === v && t.getData().getVisual("symbol") ? "inherit" === g ? t.getData().getVisual("symbolRotate") : g : 0; x.add( (function (t) { var e = t.icon || "roundRect", n = Xy( e, 0, 0, t.itemWidth, t.itemHeight, t.itemStyle.fill, t.symbolKeepAspect ); n.setStyle(t.itemStyle), (n.rotation = ((t.iconRotate || 0) * Math.PI) / 180), n.setOrigin([ t.itemWidth / 2, t.itemHeight / 2, ]), e.indexOf("empty") > -1 && ((n.style.stroke = n.style.fill), (n.style.fill = "#fff"), (n.style.lineWidth = 2)); return n; })({ itemWidth: p, itemHeight: d, icon: l, iconRotate: b, itemStyle: m.itemStyle, lineStyle: m.lineStyle, symbolKeepAspect: y, }) ); } else x.add( t.getLegendIcon({ itemWidth: p, itemHeight: d, icon: l, iconRotate: g, itemStyle: m.itemStyle, lineStyle: m.lineStyle, symbolKeepAspect: y, }) ); var w = "left" === o ? p + 5 : -5, S = o, M = r.get("formatter"), I = e; U(M) && M ? (I = M.replace("{name}", null != e ? e : "")) : X(M) && (I = M(e)); var T = f ? _.getTextColor() : i.get("inactiveColor"); x.add( new Xs({ style: oc( _, { text: I, x: w, y: d / 2, fill: T, align: S, verticalAlign: "middle", }, { inheritColor: T } ), }) ); var C = new Ws({ shape: x.getBoundingRect(), style: { fill: "transparent" }, }), D = i.getModel("tooltip"); return ( D.get("show") && Kh({ el: C, componentModel: r, itemName: e, itemTooltipOption: D.option, }), x.add(C), x.eachChild(function (t) { t.silent = !0; }), (C.silent = !u), this.getContentGroup().add(x), Ul(x), (x.__legendDataIndex = n), x ); }), (e.prototype.layoutInner = function (t, e, n, i, r, o) { var a = this.getContentGroup(), s = this.getSelectorGroup(); Ap(t.get("orient"), a, t.get("itemGap"), n.width, n.height); var l = a.getBoundingRect(), u = [-l.x, -l.y]; if ((s.markRedraw(), a.markRedraw(), r)) { Ap("horizontal", s, t.get("selectorItemGap", !0)); var h = s.getBoundingRect(), c = [-h.x, -h.y], p = t.get("selectorButtonGap", !0), d = t.getOrient().index, f = 0 === d ? "width" : "height", g = 0 === d ? "height" : "width", y = 0 === d ? "y" : "x"; "end" === o ? (c[d] += l[f] + p) : (u[d] += h[f] + p), (c[1 - d] += l[g] / 2 - h[g] / 2), (s.x = c[0]), (s.y = c[1]), (a.x = u[0]), (a.y = u[1]); var v = { x: 0, y: 0 }; return ( (v[f] = l[f] + p + h[f]), (v[g] = Math.max(l[g], h[g])), (v[y] = Math.min(0, h[y] + c[1 - d])), v ); } return ( (a.x = u[0]), (a.y = u[1]), this.group.getBoundingRect() ); }), (e.prototype.remove = function () { this.getContentGroup().removeAll(), (this._isFirstRender = !0); }), (e.type = "legend.plain"), e ); })(Ag); function $B(t, e, n, i) { tF(t, e, n, i), n.dispatchAction({ type: "legendToggleSelect", name: null != t ? t : e, }), QB(t, e, n, i); } function JB(t) { for ( var e, n = t.getZr().storage.getDisplayList(), i = 0, r = n.length; i < r && !(e = n[i].states.emphasis); ) i++; return e && e.hoverLayer; } function QB(t, e, n, i) { JB(n) || n.dispatchAction({ type: "highlight", seriesName: t, name: e, excludeSeriesId: i, }); } function tF(t, e, n, i) { JB(n) || n.dispatchAction({ type: "downplay", seriesName: t, name: e, excludeSeriesId: i, }); } function eF(t) { var e = t.findComponents({ mainType: "legend" }); e && e.length && t.filterSeries(function (t) { for (var n = 0; n < e.length; n++) if (!e[n].isSelected(t.name)) return !1; return !0; }); } function nF(t, e, n) { var i = "allSelect" === t || "inverseSelect" === t, r = {}, o = []; n.eachComponent({ mainType: "legend", query: e }, function (n) { i ? n[t]() : n[t](e.name), iF(n, r), o.push(n.componentIndex); }); var a = {}; return ( n.eachComponent("legend", function (t) { E(r, function (e, n) { t[e ? "select" : "unSelect"](n); }), iF(t, a); }), i ? { selected: a, legendIndex: o } : { name: e.name, selected: a } ); } function iF(t, e) { var n = e || {}; return ( E(t.getData(), function (e) { var i = e.get("name"); if ("\n" !== i && "" !== i) { var r = t.isSelected(i); _t(n, i) ? (n[i] = n[i] && r) : (n[i] = r); } }), n ); } function rF(t) { t.registerComponentModel(UB), t.registerComponentView(KB), t.registerProcessor(t.PRIORITY.PROCESSOR.SERIES_FILTER, eF), t.registerSubTypeDefaulter("legend", function () { return "plain"; }), (function (t) { t.registerAction( "legendToggleSelect", "legendselectchanged", H(nF, "toggleSelected") ), t.registerAction( "legendAllSelect", "legendselectall", H(nF, "allSelect") ), t.registerAction( "legendInverseSelect", "legendinverseselect", H(nF, "inverseSelect") ), t.registerAction( "legendSelect", "legendselected", H(nF, "select") ), t.registerAction( "legendUnSelect", "legendunselected", H(nF, "unSelect") ); })(t); } var oF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.setScrollDataIndex = function (t) { this.option.scrollDataIndex = t; }), (e.prototype.init = function (e, n, i) { var r = Rp(e); t.prototype.init.call(this, e, n, i), aF(this, e, r); }), (e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), aF(this, this.option, e); }), (e.type = "legend.scroll"), (e.defaultOption = kc(UB.defaultOption, { scrollDataIndex: 0, pageButtonItemGap: 5, pageButtonGap: null, pageButtonPosition: "end", pageFormatter: "{current}/{total}", pageIcons: { horizontal: ["M0,0L12,-10L12,10z", "M0,0L-12,-10L-12,10z"], vertical: ["M0,0L20,0L10,-20z", "M0,0L20,0L10,20z"], }, pageIconColor: "#2f4554", pageIconInactiveColor: "#aaa", pageIconSize: 15, pageTextStyle: { color: "#333" }, animationDurationUpdate: 800, })), e ); })(UB); function aF(t, e, n) { var i = [1, 1]; (i[t.getOrient().index] = 0), Op(e, n, { type: "box", ignoreSize: !!i }); } var sF = Br, lF = ["width", "height"], uF = ["x", "y"], hF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.newlineDisabled = !0), (n._currentIndex = 0), n ); } return ( n(e, t), (e.prototype.init = function () { t.prototype.init.call(this), this.group.add((this._containerGroup = new sF())), this._containerGroup.add(this.getContentGroup()), this.group.add((this._controllerGroup = new sF())); }), (e.prototype.resetInner = function () { t.prototype.resetInner.call(this), this._controllerGroup.removeAll(), this._containerGroup.removeClipPath(), (this._containerGroup.__rectSize = null); }), (e.prototype.renderInner = function (e, n, i, r, o, a, s) { var l = this; t.prototype.renderInner.call(this, e, n, i, r, o, a, s); var u = this._controllerGroup, h = n.get("pageIconSize", !0), c = Y(h) ? h : [h, h]; d("pagePrev", 0); var p = n.getModel("pageTextStyle"); function d(t, e) { var i = t + "DataIndex", o = Uh( n.get("pageIcons", !0)[n.getOrient().name][e], { onclick: W(l._pageGo, l, i, n, r) }, { x: -c[0] / 2, y: -c[1] / 2, width: c[0], height: c[1], } ); (o.name = t), u.add(o); } u.add( new Xs({ name: "pageText", style: { text: "xx/xx", fill: p.getTextColor(), font: p.getFont(), verticalAlign: "middle", align: "center", }, silent: !0, }) ), d("pageNext", 1); }), (e.prototype.layoutInner = function (t, e, n, i, r, o) { var a = this.getSelectorGroup(), s = t.getOrient().index, l = lF[s], u = uF[s], h = lF[1 - s], c = uF[1 - s]; r && Ap("horizontal", a, t.get("selectorItemGap", !0)); var p = t.get("selectorButtonGap", !0), d = a.getBoundingRect(), f = [-d.x, -d.y], g = T(n); r && (g[l] = n[l] - d[l] - p); var y = this._layoutContentAndController( t, i, g, s, l, h, c, u ); if (r) { if ("end" === o) f[s] += y[l] + p; else { var v = d[l] + p; (f[s] -= v), (y[u] -= v); } (y[l] += d[l] + p), (f[1 - s] += y[c] + y[h] / 2 - d[h] / 2), (y[h] = Math.max(y[h], d[h])), (y[c] = Math.min(y[c], d[c] + f[1 - s])), (a.x = f[0]), (a.y = f[1]), a.markRedraw(); } return y; }), (e.prototype._layoutContentAndController = function ( t, e, n, i, r, o, a, s ) { var l = this.getContentGroup(), u = this._containerGroup, h = this._controllerGroup; Ap( t.get("orient"), l, t.get("itemGap"), i ? n.width : null, i ? null : n.height ), Ap("horizontal", h, t.get("pageButtonItemGap", !0)); var c = l.getBoundingRect(), p = h.getBoundingRect(), d = (this._showController = c[r] > n[r]), f = [-c.x, -c.y]; e || (f[i] = l[s]); var g = [0, 0], y = [-p.x, -p.y], v = rt( t.get("pageButtonGap", !0), t.get("itemGap", !0) ); d && ("end" === t.get("pageButtonPosition", !0) ? (y[i] += n[r] - p[r]) : (g[i] += p[r] + v)); (y[1 - i] += c[o] / 2 - p[o] / 2), l.setPosition(f), u.setPosition(g), h.setPosition(y); var m = { x: 0, y: 0 }; if ( ((m[r] = d ? n[r] : c[r]), (m[o] = Math.max(c[o], p[o])), (m[a] = Math.min(0, p[a] + y[1 - i])), (u.__rectSize = n[r]), d) ) { var x = { x: 0, y: 0 }; (x[r] = Math.max(n[r] - p[r] - v, 0)), (x[o] = m[o]), u.setClipPath(new Ws({ shape: x })), (u.__rectSize = x[r]); } else h.eachChild(function (t) { t.attr({ invisible: !0, silent: !0 }); }); var _ = this._getPageInfo(t); return ( null != _.pageIndex && vh( l, { x: _.contentPosition[0], y: _.contentPosition[1], }, d ? t : null ), this._updatePageInfoView(t, _), m ); }), (e.prototype._pageGo = function (t, e, n) { var i = this._getPageInfo(e)[t]; null != i && n.dispatchAction({ type: "legendScroll", scrollDataIndex: i, legendId: e.id, }); }), (e.prototype._updatePageInfoView = function (t, e) { var n = this._controllerGroup; E(["pagePrev", "pageNext"], function (i) { var r = null != e[i + "DataIndex"], o = n.childOfName(i); o && (o.setStyle( "fill", r ? t.get("pageIconColor", !0) : t.get("pageIconInactiveColor", !0) ), (o.cursor = r ? "pointer" : "default")); }); var i = n.childOfName("pageText"), r = t.get("pageFormatter"), o = e.pageIndex, a = null != o ? o + 1 : 0, s = e.pageCount; i && r && i.setStyle( "text", U(r) ? r .replace( "{current}", null == a ? "" : a + "" ) .replace( "{total}", null == s ? "" : s + "" ) : r({ current: a, total: s }) ); }), (e.prototype._getPageInfo = function (t) { var e = t.get("scrollDataIndex", !0), n = this.getContentGroup(), i = this._containerGroup.__rectSize, r = t.getOrient().index, o = lF[r], a = uF[r], s = this._findTargetItemIndex(e), l = n.children(), u = l[s], h = l.length, c = h ? 1 : 0, p = { contentPosition: [n.x, n.y], pageCount: c, pageIndex: c - 1, pagePrevDataIndex: null, pageNextDataIndex: null, }; if (!u) return p; var d = m(u); p.contentPosition[r] = -d.s; for (var f = s + 1, g = d, y = d, v = null; f <= h; ++f) ((!(v = m(l[f])) && y.e > g.s + i) || (v && !x(v, g.s))) && (g = y.i > g.i ? y : v) && (null == p.pageNextDataIndex && (p.pageNextDataIndex = g.i), ++p.pageCount), (y = v); for (f = s - 1, g = d, y = d, v = null; f >= -1; --f) ((v = m(l[f])) && x(y, v.s)) || !(g.i < y.i) || ((y = g), null == p.pagePrevDataIndex && (p.pagePrevDataIndex = g.i), ++p.pageCount, ++p.pageIndex), (g = v); return p; function m(t) { if (t) { var e = t.getBoundingRect(), n = e[a] + t[a]; return { s: n, e: n + e[o], i: t.__legendDataIndex, }; } } function x(t, e) { return t.e >= e && t.s <= e + i; } }), (e.prototype._findTargetItemIndex = function (t) { return this._showController ? (this.getContentGroup().eachChild(function (i, r) { var o = i.__legendDataIndex; null == n && null != o && (n = r), o === t && (e = r); }), null != e ? e : n) : 0; var e, n; }), (e.type = "legend.scroll"), e ); })(KB); function cF(t) { Vm(rF), t.registerComponentModel(oF), t.registerComponentView(hF), (function (t) { t.registerAction( "legendScroll", "legendscroll", function (t, e) { var n = t.scrollDataIndex; null != n && e.eachComponent( { mainType: "legend", subType: "scroll", query: t, }, function (t) { t.setScrollDataIndex(n); } ); } ); })(t); } var pF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.type = "dataZoom.inside"), (e.defaultOption = kc(lz.defaultOption, { disabled: !1, zoomLock: !1, zoomOnMouseWheel: !0, moveOnMouseMove: !0, moveOnMouseWheel: !1, preventDefaultMouseMove: !0, })), e ); })(lz), dF = Vo(); function fF(t, e, n) { dF(t).coordSysRecordMap.each(function (t) { var i = t.dataZoomInfoMap.get(e.uid); i && (i.getRange = n); }); } function gF(t, e) { if (e) { t.removeKey(e.model.uid); var n = e.controller; n && n.dispose(); } } function yF(t, e) { t.isDisposed() || t.dispatchAction({ type: "dataZoom", animation: { easing: "cubicOut", duration: 100 }, batch: e, }); } function vF(t, e, n, i) { return t.coordinateSystem.containPoint([n, i]); } function mF(t) { t.registerProcessor(t.PRIORITY.PROCESSOR.FILTER, function (t, e) { var n = dF(e), i = n.coordSysRecordMap || (n.coordSysRecordMap = yt()); i.each(function (t) { t.dataZoomInfoMap = null; }), t.eachComponent( { mainType: "dataZoom", subType: "inside" }, function (t) { E(az(t).infoList, function (n) { var r = n.model.uid, o = i.get(r) || i.set( r, (function (t, e) { var n = { model: e, containsPoint: H(vF, e), dispatchAction: H(yF, t), dataZoomInfoMap: null, controller: null, }, i = (n.controller = new nT( t.getZr() )); return ( E( [ "pan", "zoom", "scrollMove", ], function (t) { i.on(t, function (e) { var i = []; n.dataZoomInfoMap.each( function (r) { if ( e.isAvailableBehavior( r .model .option ) ) { var o = (r.getRange || {})[ t ], a = o && o( r.dzReferCoordSysInfo, n .model .mainType, n.controller, e ); !r.model.get( "disabled", !0 ) && a && i.push( { dataZoomId: r .model .id, start: a[0], end: a[1], } ); } } ), i.length && n.dispatchAction( i ); }); } ), n ); })(e, n.model) ); ( o.dataZoomInfoMap || (o.dataZoomInfoMap = yt()) ).set(t.uid, { dzReferCoordSysInfo: n, model: t, getRange: null, }); }); } ), i.each(function (t) { var e, n = t.controller, r = t.dataZoomInfoMap; if (r) { var o = r.keys()[0]; null != o && (e = r.get(o)); } if (e) { var a = (function (t) { var e, n = "type_", i = { type_true: 2, type_move: 1, type_false: 0, type_undefined: -1, }, r = !0; return ( t.each(function (t) { var o = t.model, a = !o.get("disabled", !0) && (!o.get("zoomLock", !0) || "move"); i[n + a] > i[n + e] && (e = a), (r = r && o.get( "preventDefaultMouseMove", !0 )); }), { controlType: e, opt: { zoomOnMouseWheel: !0, moveOnMouseMove: !0, moveOnMouseWheel: !0, preventDefaultMouseMove: !!r, }, } ); })(r); n.enable(a.controlType, a.opt), n.setPointerChecker(t.containsPoint), Hg( t, "dispatchAction", e.model.get("throttle", !0), "fixRate" ); } else gF(i, t); }); }); } var xF = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.type = "dataZoom.inside"), e; } return ( n(e, t), (e.prototype.render = function (e, n, i) { t.prototype.render.apply(this, arguments), e.noTarget() ? this._clear() : ((this.range = e.getPercentRange()), fF(i, e, { pan: W(_F.pan, this), zoom: W(_F.zoom, this), scrollMove: W(_F.scrollMove, this), })); }), (e.prototype.dispose = function () { this._clear(), t.prototype.dispose.apply(this, arguments); }), (e.prototype._clear = function () { !(function (t, e) { for ( var n = dF(t).coordSysRecordMap, i = n.keys(), r = 0; r < i.length; r++ ) { var o = i[r], a = n.get(o), s = a.dataZoomInfoMap; if (s) { var l = e.uid; s.get(l) && (s.removeKey(l), s.keys().length || gF(n, a)); } } })(this.api, this.dataZoomModel), (this.range = null); }), (e.type = "dataZoom.inside"), e ); })(cz), _F = { zoom: function (t, e, n, i) { var r = this.range, o = r.slice(), a = t.axisModels[0]; if (a) { var s = wF[e](null, [i.originX, i.originY], a, n, t), l = ((s.signal > 0 ? s.pixelStart + s.pixelLength - s.pixel : s.pixel - s.pixelStart) / s.pixelLength) * (o[1] - o[0]) + o[0], u = Math.max(1 / i.scale, 0); (o[0] = (o[0] - l) * u + l), (o[1] = (o[1] - l) * u + l); var h = this.dataZoomModel .findRepresentativeAxisProxy() .getMinMaxSpan(); return ( zk(0, o, [0, 100], 0, h.minSpan, h.maxSpan), (this.range = o), r[0] !== o[0] || r[1] !== o[1] ? o : void 0 ); } }, pan: bF(function (t, e, n, i, r, o) { var a = wF[i]([o.oldX, o.oldY], [o.newX, o.newY], e, r, n); return (a.signal * (t[1] - t[0]) * a.pixel) / a.pixelLength; }), scrollMove: bF(function (t, e, n, i, r, o) { return ( wF[i]([0, 0], [o.scrollDelta, o.scrollDelta], e, r, n) .signal * (t[1] - t[0]) * o.scrollDelta ); }), }; function bF(t) { return function (e, n, i, r) { var o = this.range, a = o.slice(), s = e.axisModels[0]; if (s) return ( zk(t(a, s, e, n, i, r), a, [0, 100], "all"), (this.range = a), o[0] !== a[0] || o[1] !== a[1] ? a : void 0 ); }; } var wF = { grid: function (t, e, n, i, r) { var o = n.axis, a = {}, s = r.model.coordinateSystem.getRect(); return ( (t = t || [0, 0]), "x" === o.dim ? ((a.pixel = e[0] - t[0]), (a.pixelLength = s.width), (a.pixelStart = s.x), (a.signal = o.inverse ? 1 : -1)) : ((a.pixel = e[1] - t[1]), (a.pixelLength = s.height), (a.pixelStart = s.y), (a.signal = o.inverse ? -1 : 1)), a ); }, polar: function (t, e, n, i, r) { var o = n.axis, a = {}, s = r.model.coordinateSystem, l = s.getRadiusAxis().getExtent(), u = s.getAngleAxis().getExtent(); return ( (t = t ? s.pointToCoord(t) : [0, 0]), (e = s.pointToCoord(e)), "radiusAxis" === n.mainType ? ((a.pixel = e[0] - t[0]), (a.pixelLength = l[1] - l[0]), (a.pixelStart = l[0]), (a.signal = o.inverse ? 1 : -1)) : ((a.pixel = e[1] - t[1]), (a.pixelLength = u[1] - u[0]), (a.pixelStart = u[0]), (a.signal = o.inverse ? -1 : 1)), a ); }, singleAxis: function (t, e, n, i, r) { var o = n.axis, a = r.model.coordinateSystem.getRect(), s = {}; return ( (t = t || [0, 0]), "horizontal" === o.orient ? ((s.pixel = e[0] - t[0]), (s.pixelLength = a.width), (s.pixelStart = a.x), (s.signal = o.inverse ? 1 : -1)) : ((s.pixel = e[1] - t[1]), (s.pixelLength = a.height), (s.pixelStart = a.y), (s.signal = o.inverse ? -1 : 1)), s ); }, }; function SF(t) { mz(t), t.registerComponentModel(pF), t.registerComponentView(xF), mF(t); } var MF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.type = "dataZoom.slider"), (e.layoutMode = "box"), (e.defaultOption = kc(lz.defaultOption, { show: !0, right: "ph", top: "ph", width: "ph", height: "ph", left: null, bottom: null, borderColor: "#d2dbee", borderRadius: 3, backgroundColor: "rgba(47,69,84,0)", dataBackground: { lineStyle: { color: "#d2dbee", width: 0.5 }, areaStyle: { color: "#d2dbee", opacity: 0.2 }, }, selectedDataBackground: { lineStyle: { color: "#8fb0f7", width: 0.5 }, areaStyle: { color: "#8fb0f7", opacity: 0.2 }, }, fillerColor: "rgba(135,175,274,0.2)", handleIcon: "path://M-9.35,34.56V42m0-40V9.5m-2,0h4a2,2,0,0,1,2,2v21a2,2,0,0,1-2,2h-4a2,2,0,0,1-2-2v-21A2,2,0,0,1-11.35,9.5Z", handleSize: "100%", handleStyle: { color: "#fff", borderColor: "#ACB8D1" }, moveHandleSize: 7, moveHandleIcon: "path://M-320.9-50L-320.9-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-348-41-339-50-320.9-50z M-212.3-50L-212.3-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-239.4-41-230.4-50-212.3-50z M-103.7-50L-103.7-50c18.1,0,27.1,9,27.1,27.1V85.7c0,18.1-9,27.1-27.1,27.1l0,0c-18.1,0-27.1-9-27.1-27.1V-22.9C-130.9-41-121.8-50-103.7-50z", moveHandleStyle: { color: "#D2DBEE", opacity: 0.7 }, showDetail: !0, showDataShadow: "auto", realtime: !0, zoomLock: !1, textStyle: { color: "#6E7079" }, brushSelect: !0, brushStyle: { color: "rgba(135,175,274,0.15)" }, emphasis: { handleLabel: { show: !0 }, handleStyle: { borderColor: "#8FB0F7" }, moveHandleStyle: { color: "#8FB0F7" }, }, })), e ); })(lz), IF = Ws, TF = "horizontal", CF = "vertical", DF = ["line", "bar", "candlestick", "scatter"], AF = { easing: "cubicOut", duration: 100, delay: 0 }, kF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n._displayables = {}), n; } return ( n(e, t), (e.prototype.init = function (t, e) { (this.api = e), (this._onBrush = W(this._onBrush, this)), (this._onBrushEnd = W(this._onBrushEnd, this)); }), (e.prototype.render = function (e, n, i, r) { if ( (t.prototype.render.apply(this, arguments), Hg( this, "_dispatchZoomAction", e.get("throttle"), "fixRate" ), (this._orient = e.getOrient()), !1 !== e.get("show")) ) { if (e.noTarget()) return this._clear(), void this.group.removeAll(); (r && "dataZoom" === r.type && r.from === this.uid) || this._buildView(), this._updateView(); } else this.group.removeAll(); }), (e.prototype.dispose = function () { this._clear(), t.prototype.dispose.apply(this, arguments); }), (e.prototype._clear = function () { Yg(this, "_dispatchZoomAction"); var t = this.api.getZr(); t.off("mousemove", this._onBrush), t.off("mouseup", this._onBrushEnd); }), (e.prototype._buildView = function () { var t = this.group; t.removeAll(), (this._brushing = !1), (this._displayables.brushRect = null), this._resetLocation(), this._resetInterval(); var e = (this._displayables.sliderGroup = new Br()); this._renderBackground(), this._renderHandle(), this._renderDataShadow(), t.add(e), this._positionGroup(); }), (e.prototype._resetLocation = function () { var t = this.dataZoomModel, e = this.api, n = t.get("brushSelect") ? 7 : 0, i = this._findCoordRect(), r = { width: e.getWidth(), height: e.getHeight() }, o = this._orient === TF ? { right: r.width - i.x - i.width, top: r.height - 30 - 7 - n, width: i.width, height: 30, } : { right: 7, top: i.y, width: 30, height: i.height, }, a = Rp(t.option); E(["right", "top", "width", "height"], function (t) { "ph" === a[t] && (a[t] = o[t]); }); var s = kp(a, r); (this._location = { x: s.x, y: s.y }), (this._size = [s.width, s.height]), this._orient === CF && this._size.reverse(); }), (e.prototype._positionGroup = function () { var t = this.group, e = this._location, n = this._orient, i = this.dataZoomModel.getFirstTargetAxisModel(), r = i && i.get("inverse"), o = this._displayables.sliderGroup, a = (this._dataShadowInfo || {}).otherAxisInverse; o.attr( n !== TF || r ? n === TF && r ? { scaleY: a ? 1 : -1, scaleX: -1 } : n !== CF || r ? { scaleY: a ? -1 : 1, scaleX: -1, rotation: Math.PI / 2, } : { scaleY: a ? -1 : 1, scaleX: 1, rotation: Math.PI / 2, } : { scaleY: a ? 1 : -1, scaleX: 1 } ); var s = t.getBoundingRect([o]); (t.x = e.x - s.x), (t.y = e.y - s.y), t.markRedraw(); }), (e.prototype._getViewExtent = function () { return [0, this._size[0]]; }), (e.prototype._renderBackground = function () { var t = this.dataZoomModel, e = this._size, n = this._displayables.sliderGroup, i = t.get("brushSelect"); n.add( new IF({ silent: !0, shape: { x: 0, y: 0, width: e[0], height: e[1] }, style: { fill: t.get("backgroundColor") }, z2: -40, }) ); var r = new IF({ shape: { x: 0, y: 0, width: e[0], height: e[1] }, style: { fill: "transparent" }, z2: 0, onclick: W(this._onClickPanel, this), }), o = this.api.getZr(); i ? (r.on("mousedown", this._onBrushStart, this), (r.cursor = "crosshair"), o.on("mousemove", this._onBrush), o.on("mouseup", this._onBrushEnd)) : (o.off("mousemove", this._onBrush), o.off("mouseup", this._onBrushEnd)), n.add(r); }), (e.prototype._renderDataShadow = function () { var t = (this._dataShadowInfo = this._prepareDataShadowInfo()); if (((this._displayables.dataShadowSegs = []), t)) { var e = this._size, n = this._shadowSize || [], i = t.series, r = i.getRawData(), o = i.getShadowDim && i.getShadowDim(), a = o && r.getDimensionInfo(o) ? i.getShadowDim() : t.otherDim; if (null != a) { var s = this._shadowPolygonPts, l = this._shadowPolylinePts; if ( r !== this._shadowData || a !== this._shadowDim || e[0] !== n[0] || e[1] !== n[1] ) { var u = r.getDataExtent(a), h = 0.3 * (u[1] - u[0]); u = [u[0] - h, u[1] + h]; var c, p = [0, e[1]], d = [0, e[0]], f = [ [e[0], 0], [0, 0], ], g = [], y = d[1] / (r.count() - 1), v = 0, m = Math.round(r.count() / e[0]); r.each([a], function (t, e) { if (m > 0 && e % m) v += y; else { var n = null == t || isNaN(t) || "" === t, i = n ? 0 : Kr(t, u, p, !0); n && !c && e ? (f.push([f[f.length - 1][0], 0]), g.push([g[g.length - 1][0], 0])) : !n && c && (f.push([v, 0]), g.push([v, 0])), f.push([v, i]), g.push([v, i]), (v += y), (c = n); } }), (s = this._shadowPolygonPts = f), (l = this._shadowPolylinePts = g); } (this._shadowData = r), (this._shadowDim = a), (this._shadowSize = [e[0], e[1]]); for ( var x = this.dataZoomModel, _ = 0; _ < 3; _++ ) { var b = w(1 === _); this._displayables.sliderGroup.add(b), this._displayables.dataShadowSegs.push(b); } } } function w(t) { var e = x.getModel( t ? "selectedDataBackground" : "dataBackground" ), n = new Br(), i = new Xu({ shape: { points: s }, segmentIgnoreThreshold: 1, style: e.getModel("areaStyle").getAreaStyle(), silent: !0, z2: -20, }), r = new Zu({ shape: { points: l }, segmentIgnoreThreshold: 1, style: e.getModel("lineStyle").getLineStyle(), silent: !0, z2: -19, }); return n.add(i), n.add(r), n; } }), (e.prototype._prepareDataShadowInfo = function () { var t = this.dataZoomModel, e = t.get("showDataShadow"); if (!1 !== e) { var n, i = this.ecModel; return ( t.eachTargetAxis(function (r, o) { E( t .getAxisProxy(r, o) .getTargetSeriesModels(), function (t) { if ( !( n || (!0 !== e && P(DF, t.get("type")) < 0) ) ) { var a, s = i.getComponent( rz(r), o ).axis, l = (function (t) { var e = { x: "y", y: "x", radius: "angle", angle: "radius", }; return e[t]; })(r), u = t.coordinateSystem; null != l && u.getOtherAxis && (a = u.getOtherAxis(s).inverse), (l = t .getData() .mapDimension(l)), (n = { thisAxis: s, series: t, thisDim: r, otherDim: l, otherAxisInverse: a, }); } }, this ); }, this), n ); } }), (e.prototype._renderHandle = function () { var t = this.group, e = this._displayables, n = (e.handles = [null, null]), i = (e.handleLabels = [null, null]), r = this._displayables.sliderGroup, o = this._size, a = this.dataZoomModel, s = this.api, l = a.get("borderRadius") || 0, u = a.get("brushSelect"), h = (e.filler = new IF({ silent: u, style: { fill: a.get("fillerColor") }, textConfig: { position: "inside" }, })); r.add(h), r.add( new IF({ silent: !0, subPixelOptimize: !0, shape: { x: 0, y: 0, width: o[0], height: o[1], r: l, }, style: { stroke: a.get("dataBackgroundColor") || a.get("borderColor"), lineWidth: 1, fill: "rgba(0,0,0,0)", }, }) ), E( [0, 1], function (e) { var o = a.get("handleIcon"); !Wy[o] && o.indexOf("path://") < 0 && o.indexOf("image://") < 0 && (o = "path://" + o); var s = Xy(o, -1, 0, 2, 2, null, !0); s.attr({ cursor: LF(this._orient), draggable: !0, drift: W(this._onDragMove, this, e), ondragend: W(this._onDragEnd, this), onmouseover: W( this._showDataInfo, this, !0 ), onmouseout: W(this._showDataInfo, this, !1), z2: 5, }); var l = s.getBoundingRect(), u = a.get("handleSize"); (this._handleHeight = $r(u, this._size[1])), (this._handleWidth = (l.width / l.height) * this._handleHeight), s.setStyle( a.getModel("handleStyle").getItemStyle() ), (s.style.strokeNoScale = !0), (s.rectHover = !0), (s.ensureState("emphasis").style = a .getModel(["emphasis", "handleStyle"]) .getItemStyle()), Ul(s); var h = a.get("handleColor"); null != h && (s.style.fill = h), r.add((n[e] = s)); var c = a.getModel("textStyle"), p = (a.get("handleLabel") || {}).show || !1; t.add( (i[e] = new Xs({ silent: !0, invisible: !p, style: oc(c, { x: 0, y: 0, text: "", verticalAlign: "middle", align: "center", fill: c.getTextColor(), font: c.getFont(), }), z2: 10, })) ); }, this ); var c = h; if (u) { var p = $r(a.get("moveHandleSize"), o[1]), d = (e.moveHandle = new Ws({ style: a .getModel("moveHandleStyle") .getItemStyle(), silent: !0, shape: { r: [0, 0, 2, 2], y: o[1] - 0.5, height: p, }, })), f = 0.8 * p, g = (e.moveHandleIcon = Xy( a.get("moveHandleIcon"), -f / 2, -f / 2, f, f, "#fff", !0 )); (g.silent = !0), (g.y = o[1] + p / 2 - 0.5), (d.ensureState("emphasis").style = a .getModel(["emphasis", "moveHandleStyle"]) .getItemStyle()); var y = Math.min(o[1] / 2, Math.max(p, 10)); (c = e.moveZone = new Ws({ invisible: !0, shape: { y: o[1] - y, height: p + y }, })) .on("mouseover", function () { s.enterEmphasis(d); }) .on("mouseout", function () { s.leaveEmphasis(d); }), r.add(d), r.add(g), r.add(c); } c.attr({ draggable: !0, cursor: LF(this._orient), drift: W(this._onDragMove, this, "all"), ondragstart: W(this._showDataInfo, this, !0), ondragend: W(this._onDragEnd, this), onmouseover: W(this._showDataInfo, this, !0), onmouseout: W(this._showDataInfo, this, !1), }); }), (e.prototype._resetInterval = function () { var t = (this._range = this.dataZoomModel.getPercentRange()), e = this._getViewExtent(); this._handleEnds = [ Kr(t[0], [0, 100], e, !0), Kr(t[1], [0, 100], e, !0), ]; }), (e.prototype._updateInterval = function (t, e) { var n = this.dataZoomModel, i = this._handleEnds, r = this._getViewExtent(), o = n.findRepresentativeAxisProxy().getMinMaxSpan(), a = [0, 100]; zk( e, i, r, n.get("zoomLock") ? "all" : t, null != o.minSpan ? Kr(o.minSpan, a, r, !0) : null, null != o.maxSpan ? Kr(o.maxSpan, a, r, !0) : null ); var s = this._range, l = (this._range = Qr([ Kr(i[0], r, a, !0), Kr(i[1], r, a, !0), ])); return !s || s[0] !== l[0] || s[1] !== l[1]; }), (e.prototype._updateView = function (t) { var e = this._displayables, n = this._handleEnds, i = Qr(n.slice()), r = this._size; E( [0, 1], function (t) { var i = e.handles[t], o = this._handleHeight; i.attr({ scaleX: o / 2, scaleY: o / 2, x: n[t] + (t ? -1 : 1), y: r[1] / 2 - o / 2, }); }, this ), e.filler.setShape({ x: i[0], y: 0, width: i[1] - i[0], height: r[1], }); var o = { x: i[0], width: i[1] - i[0] }; e.moveHandle && (e.moveHandle.setShape(o), e.moveZone.setShape(o), e.moveZone.getBoundingRect(), e.moveHandleIcon && e.moveHandleIcon.attr("x", o.x + o.width / 2)); for ( var a = e.dataShadowSegs, s = [0, i[0], i[1], r[0]], l = 0; l < a.length; l++ ) { var u = a[l], h = u.getClipPath(); h || ((h = new Ws()), u.setClipPath(h)), h.setShape({ x: s[l], y: 0, width: s[l + 1] - s[l], height: r[1], }); } this._updateDataInfo(t); }), (e.prototype._updateDataInfo = function (t) { var e = this.dataZoomModel, n = this._displayables, i = n.handleLabels, r = this._orient, o = ["", ""]; if (e.get("showDetail")) { var a = e.findRepresentativeAxisProxy(); if (a) { var s = a.getAxisModel().axis, l = this._range, u = t ? a.calculateDataWindow({ start: l[0], end: l[1], }).valueWindow : a.getDataValueWindow(); o = [ this._formatLabel(u[0], s), this._formatLabel(u[1], s), ]; } } var h = Qr(this._handleEnds.slice()); function c(t) { var e = Bh(n.handles[t].parent, this.group), a = Gh(0 === t ? "right" : "left", e), s = this._handleWidth / 2 + 5, l = Fh( [h[t] + (0 === t ? -s : s), this._size[1] / 2], e ); i[t].setStyle({ x: l[0], y: l[1], verticalAlign: r === TF ? "middle" : a, align: r === TF ? a : "center", text: o[t], }); } c.call(this, 0), c.call(this, 1); }), (e.prototype._formatLabel = function (t, e) { var n = this.dataZoomModel, i = n.get("labelFormatter"), r = n.get("labelPrecision"); (null != r && "auto" !== r) || (r = e.getPixelPrecision()); var o = null == t || isNaN(t) ? "" : "category" === e.type || "time" === e.type ? e.scale.getLabel({ value: Math.round(t) }) : t.toFixed(Math.min(r, 20)); return X(i) ? i(t, o) : U(i) ? i.replace("{value}", o) : o; }), (e.prototype._showDataInfo = function (t) { var e = (this.dataZoomModel.get("handleLabel") || {}) .show || !1, n = this.dataZoomModel .getModel(["emphasis", "handleLabel"]) .get("show") || !1, i = t || this._dragging ? n : e, r = this._displayables, o = r.handleLabels; o[0].attr("invisible", !i), o[1].attr("invisible", !i), r.moveHandle && this.api[i ? "enterEmphasis" : "leaveEmphasis"]( r.moveHandle, 1 ); }), (e.prototype._onDragMove = function (t, e, n, i) { (this._dragging = !0), de(i.event); var r = Fh( [e, n], this._displayables.sliderGroup.getLocalTransform(), !0 ), o = this._updateInterval(t, r[0]), a = this.dataZoomModel.get("realtime"); this._updateView(!a), o && a && this._dispatchZoomAction(!0); }), (e.prototype._onDragEnd = function () { (this._dragging = !1), this._showDataInfo(!1), !this.dataZoomModel.get("realtime") && this._dispatchZoomAction(!1); }), (e.prototype._onClickPanel = function (t) { var e = this._size, n = this._displayables.sliderGroup.transformCoordToLocal( t.offsetX, t.offsetY ); if (!(n[0] < 0 || n[0] > e[0] || n[1] < 0 || n[1] > e[1])) { var i = this._handleEnds, r = (i[0] + i[1]) / 2, o = this._updateInterval("all", n[0] - r); this._updateView(), o && this._dispatchZoomAction(!1); } }), (e.prototype._onBrushStart = function (t) { var e = t.offsetX, n = t.offsetY; (this._brushStart = new De(e, n)), (this._brushing = !0), (this._brushStartTime = +new Date()); }), (e.prototype._onBrushEnd = function (t) { if (this._brushing) { var e = this._displayables.brushRect; if (((this._brushing = !1), e)) { e.attr("ignore", !0); var n = e.shape; if ( !( +new Date() - this._brushStartTime < 200 && Math.abs(n.width) < 5 ) ) { var i = this._getViewExtent(), r = [0, 100]; (this._range = Qr([ Kr(n.x, i, r, !0), Kr(n.x + n.width, i, r, !0), ])), (this._handleEnds = [n.x, n.x + n.width]), this._updateView(), this._dispatchZoomAction(!1); } } } }), (e.prototype._onBrush = function (t) { this._brushing && (de(t.event), this._updateBrushRect(t.offsetX, t.offsetY)); }), (e.prototype._updateBrushRect = function (t, e) { var n = this._displayables, i = this.dataZoomModel, r = n.brushRect; r || ((r = n.brushRect = new IF({ silent: !0, style: i.getModel("brushStyle").getItemStyle(), })), n.sliderGroup.add(r)), r.attr("ignore", !1); var o = this._brushStart, a = this._displayables.sliderGroup, s = a.transformCoordToLocal(t, e), l = a.transformCoordToLocal(o.x, o.y), u = this._size; (s[0] = Math.max(Math.min(u[0], s[0]), 0)), r.setShape({ x: l[0], y: 0, width: s[0] - l[0], height: u[1], }); }), (e.prototype._dispatchZoomAction = function (t) { var e = this._range; this.api.dispatchAction({ type: "dataZoom", from: this.uid, dataZoomId: this.dataZoomModel.id, animation: t ? AF : null, start: e[0], end: e[1], }); }), (e.prototype._findCoordRect = function () { var t, e = az(this.dataZoomModel).infoList; if (!t && e.length) { var n = e[0].model.coordinateSystem; t = n.getRect && n.getRect(); } if (!t) { var i = this.api.getWidth(), r = this.api.getHeight(); t = { x: 0.2 * i, y: 0.2 * r, width: 0.6 * i, height: 0.6 * r, }; } return t; }), (e.type = "dataZoom.slider"), e ); })(cz); function LF(t) { return "vertical" === t ? "ns-resize" : "ew-resize"; } function PF(t) { t.registerComponentModel(MF), t.registerComponentView(kF), mz(t); } var OF = function (t, e, n) { var i = T((RF[t] || {})[e]); return n && Y(i) ? i[i.length - 1] : i; }, RF = { color: { active: ["#006edd", "#e0ffff"], inactive: ["rgba(0,0,0,0)"], }, colorHue: { active: [0, 360], inactive: [0, 0] }, colorSaturation: { active: [0.3, 1], inactive: [0, 0] }, colorLightness: { active: [0.9, 0.5], inactive: [0, 0] }, colorAlpha: { active: [0.3, 1], inactive: [0, 0] }, opacity: { active: [0.3, 1], inactive: [0, 0] }, symbol: { active: ["circle", "roundRect", "diamond"], inactive: ["none"], }, symbolSize: { active: [10, 50], inactive: [0, 0] }, }, NF = kD.mapVisual, EF = kD.eachVisual, zF = Y, VF = E, BF = Qr, FF = Kr, GF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.stateList = ["inRange", "outOfRange"]), (n.replacableOptionKeys = [ "inRange", "outOfRange", "target", "controller", "color", ]), (n.layoutMode = { type: "box", ignoreSize: !0 }), (n.dataBound = [-1 / 0, 1 / 0]), (n.targetVisuals = {}), (n.controllerVisuals = {}), n ); } return ( n(e, t), (e.prototype.init = function (t, e, n) { this.mergeDefaultAndTheme(t, n); }), (e.prototype.optionUpdated = function (t, e) { var n = this.option; !e && RV(n, t, this.replacableOptionKeys), (this.textStyleModel = this.getModel("textStyle")), this.resetItemSize(), this.completeVisualOption(); }), (e.prototype.resetVisual = function (t) { var e = this.stateList; (t = W(t, this)), (this.controllerVisuals = OV( this.option.controller, e, t )), (this.targetVisuals = OV(this.option.target, e, t)); }), (e.prototype.getItemSymbol = function () { return null; }), (e.prototype.getTargetSeriesIndices = function () { var t = this.option.seriesIndex, e = []; return ( null == t || "all" === t ? this.ecModel.eachSeries(function (t, n) { e.push(n); }) : (e = To(t)), e ); }), (e.prototype.eachTargetSeries = function (t, e) { E( this.getTargetSeriesIndices(), function (n) { var i = this.ecModel.getSeriesByIndex(n); i && t.call(e, i); }, this ); }), (e.prototype.isTargetSeries = function (t) { var e = !1; return ( this.eachTargetSeries(function (n) { n === t && (e = !0); }), e ); }), (e.prototype.formatValueText = function (t, e, n) { var i, r = this.option, o = r.precision, a = this.dataBound, s = r.formatter; (n = n || ["<", ">"]), Y(t) && ((t = t.slice()), (i = !0)); var l = e ? t : i ? [u(t[0]), u(t[1])] : u(t); return U(s) ? s .replace("{value}", i ? l[0] : l) .replace("{value2}", i ? l[1] : l) : X(s) ? i ? s(t[0], t[1]) : s(t) : i ? t[0] === a[0] ? n[0] + " " + l[1] : t[1] === a[1] ? n[1] + " " + l[0] : l[0] + " - " + l[1] : l; function u(t) { return t === a[0] ? "min" : t === a[1] ? "max" : (+t).toFixed(Math.min(o, 20)); } }), (e.prototype.resetExtent = function () { var t = this.option, e = BF([t.min, t.max]); this._dataExtent = e; }), (e.prototype.getDataDimensionIndex = function (t) { var e = this.option.dimension; if (null != e) return t.getDimensionIndex(e); for (var n = t.dimensions, i = n.length - 1; i >= 0; i--) { var r = n[i], o = t.getDimensionInfo(r); if (!o.isCalculationCoord) return o.storeDimIndex; } }), (e.prototype.getExtent = function () { return this._dataExtent.slice(); }), (e.prototype.completeVisualOption = function () { var t = this.ecModel, e = this.option, n = { inRange: e.inRange, outOfRange: e.outOfRange }, i = e.target || (e.target = {}), r = e.controller || (e.controller = {}); C(i, n), C(r, n); var o = this.isCategory(); function a(n) { zF(e.color) && !n.inRange && (n.inRange = { color: e.color.slice().reverse() }), (n.inRange = n.inRange || { color: t.get("gradientColor"), }); } a.call(this, i), a.call(this, r), function (t, e, n) { var i = t[e], r = t[n]; i && !r && ((r = t[n] = {}), VF(i, function (t, e) { if (kD.isValidType(e)) { var n = OF(e, "inactive", o); null != n && ((r[e] = n), "color" !== e || r.hasOwnProperty("opacity") || r.hasOwnProperty( "colorAlpha" ) || (r.opacity = [0, 0])); } })); }.call(this, i, "inRange", "outOfRange"), function (t) { var e = (t.inRange || {}).symbol || (t.outOfRange || {}).symbol, n = (t.inRange || {}).symbolSize || (t.outOfRange || {}).symbolSize, i = this.get("inactiveColor"), r = this.getItemSymbol() || "roundRect"; VF( this.stateList, function (a) { var s = this.itemSize, l = t[a]; l || (l = t[a] = { color: o ? i : [i] }), null == l.symbol && (l.symbol = (e && T(e)) || (o ? r : [r])), null == l.symbolSize && (l.symbolSize = (n && T(n)) || (o ? s[0] : [s[0], s[0]])), (l.symbol = NF(l.symbol, function (t) { return "none" === t ? r : t; })); var u = l.symbolSize; if (null != u) { var h = -1 / 0; EF(u, function (t) { t > h && (h = t); }), (l.symbolSize = NF(u, function (t) { return FF( t, [0, h], [0, s[0]], !0 ); })); } }, this ); }.call(this, r); }), (e.prototype.resetItemSize = function () { this.itemSize = [ parseFloat(this.get("itemWidth")), parseFloat(this.get("itemHeight")), ]; }), (e.prototype.isCategory = function () { return !!this.option.categories; }), (e.prototype.setSelected = function (t) {}), (e.prototype.getSelected = function () { return null; }), (e.prototype.getValueState = function (t) { return null; }), (e.prototype.getVisualMeta = function (t) { return null; }), (e.type = "visualMap"), (e.dependencies = ["series"]), (e.defaultOption = { show: !0, z: 4, seriesIndex: "all", min: 0, max: 200, left: 0, right: null, top: null, bottom: 0, itemWidth: null, itemHeight: null, inverse: !1, orient: "vertical", backgroundColor: "rgba(0,0,0,0)", borderColor: "#ccc", contentColor: "#5793f3", inactiveColor: "#aaa", borderWidth: 0, padding: 5, textGap: 10, precision: 0, textStyle: { color: "#333" }, }), e ); })(zp), WF = [20, 140], HF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.optionUpdated = function (e, n) { t.prototype.optionUpdated.apply(this, arguments), this.resetExtent(), this.resetVisual(function (t) { (t.mappingMethod = "linear"), (t.dataExtent = this.getExtent()); }), this._resetRange(); }), (e.prototype.resetItemSize = function () { t.prototype.resetItemSize.apply(this, arguments); var e = this.itemSize; (null == e[0] || isNaN(e[0])) && (e[0] = WF[0]), (null == e[1] || isNaN(e[1])) && (e[1] = WF[1]); }), (e.prototype._resetRange = function () { var t = this.getExtent(), e = this.option.range; !e || e.auto ? ((t.auto = 1), (this.option.range = t)) : Y(e) && (e[0] > e[1] && e.reverse(), (e[0] = Math.max(e[0], t[0])), (e[1] = Math.min(e[1], t[1]))); }), (e.prototype.completeVisualOption = function () { t.prototype.completeVisualOption.apply(this, arguments), E( this.stateList, function (t) { var e = this.option.controller[t].symbolSize; e && e[0] !== e[1] && (e[0] = e[1] / 3); }, this ); }), (e.prototype.setSelected = function (t) { (this.option.range = t.slice()), this._resetRange(); }), (e.prototype.getSelected = function () { var t = this.getExtent(), e = Qr((this.get("range") || []).slice()); return ( e[0] > t[1] && (e[0] = t[1]), e[1] > t[1] && (e[1] = t[1]), e[0] < t[0] && (e[0] = t[0]), e[1] < t[0] && (e[1] = t[0]), e ); }), (e.prototype.getValueState = function (t) { var e = this.option.range, n = this.getExtent(); return (e[0] <= n[0] || e[0] <= t) && (e[1] >= n[1] || t <= e[1]) ? "inRange" : "outOfRange"; }), (e.prototype.findTargetDataIndices = function (t) { var e = []; return ( this.eachTargetSeries(function (n) { var i = [], r = n.getData(); r.each( this.getDataDimensionIndex(r), function (e, n) { t[0] <= e && e <= t[1] && i.push(n); }, this ), e.push({ seriesId: n.id, dataIndex: i }); }, this), e ); }), (e.prototype.getVisualMeta = function (t) { var e = YF(this, "outOfRange", this.getExtent()), n = YF(this, "inRange", this.option.range.slice()), i = []; function r(e, n) { i.push({ value: e, color: t(e, n) }); } for ( var o = 0, a = 0, s = n.length, l = e.length; a < l && (!n.length || e[a] <= n[0]); a++ ) e[a] < n[o] && r(e[a], "outOfRange"); for (var u = 1; o < s; o++, u = 0) u && i.length && r(n[o], "outOfRange"), r(n[o], "inRange"); for (u = 1; a < l; a++) (!n.length || n[n.length - 1] < e[a]) && (u && (i.length && r(i[i.length - 1].value, "outOfRange"), (u = 0)), r(e[a], "outOfRange")); var h = i.length; return { stops: i, outerColors: [ h ? i[0].color : "transparent", h ? i[h - 1].color : "transparent", ], }; }), (e.type = "visualMap.continuous"), (e.defaultOption = kc(GF.defaultOption, { align: "auto", calculable: !1, hoverLink: !0, realtime: !0, handleIcon: "path://M-11.39,9.77h0a3.5,3.5,0,0,1-3.5,3.5h-22a3.5,3.5,0,0,1-3.5-3.5h0a3.5,3.5,0,0,1,3.5-3.5h22A3.5,3.5,0,0,1-11.39,9.77Z", handleSize: "120%", handleStyle: { borderColor: "#fff", borderWidth: 1 }, indicatorIcon: "circle", indicatorSize: "50%", indicatorStyle: { borderColor: "#fff", borderWidth: 2, shadowBlur: 2, shadowOffsetX: 1, shadowOffsetY: 1, shadowColor: "rgba(0,0,0,0.2)", }, })), e ); })(GF); function YF(t, e, n) { if (n[0] === n[1]) return n.slice(); for ( var i = (n[1] - n[0]) / 200, r = n[0], o = [], a = 0; a <= 200 && r < n[1]; a++ ) o.push(r), (r += i); return o.push(n[1]), o; } var XF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n.autoPositionValues = { left: 1, right: 1, top: 1, bottom: 1, }), n ); } return ( n(e, t), (e.prototype.init = function (t, e) { (this.ecModel = t), (this.api = e); }), (e.prototype.render = function (t, e, n, i) { (this.visualMapModel = t), !1 !== t.get("show") ? this.doRender(t, e, n, i) : this.group.removeAll(); }), (e.prototype.renderBackground = function (t) { var e = this.visualMapModel, n = vp(e.get("padding") || 0), i = t.getBoundingRect(); t.add( new Ws({ z2: -1, silent: !0, shape: { x: i.x - n[3], y: i.y - n[0], width: i.width + n[3] + n[1], height: i.height + n[0] + n[2], }, style: { fill: e.get("backgroundColor"), stroke: e.get("borderColor"), lineWidth: e.get("borderWidth"), }, }) ); }), (e.prototype.getControllerVisual = function (t, e, n) { var i = (n = n || {}).forceState, r = this.visualMapModel, o = {}; if ("color" === e) { var a = r.get("contentColor"); o.color = a; } function s(t) { return o[t]; } function l(t, e) { o[t] = e; } var u = r.controllerVisuals[i || r.getValueState(t)]; return ( E(kD.prepareVisualTypes(u), function (i) { var r = u[i]; n.convertOpacityToAlpha && "opacity" === i && ((i = "colorAlpha"), (r = u.__alphaForOpacity)), kD.dependsOn(i, e) && r && r.applyVisual(t, s, l); }), o[e] ); }), (e.prototype.positionGroup = function (t) { var e = this.visualMapModel, n = this.api; Lp(t, e.getBoxLayoutParams(), { width: n.getWidth(), height: n.getHeight(), }); }), (e.prototype.doRender = function (t, e, n, i) {}), (e.type = "visualMap"), e ); })(Ag), UF = [ ["left", "right", "width"], ["top", "bottom", "height"], ]; function ZF(t, e, n) { var i = t.option, r = i.align; if (null != r && "auto" !== r) return r; for ( var o = { width: e.getWidth(), height: e.getHeight() }, a = "horizontal" === i.orient ? 1 : 0, s = UF[a], l = [0, null, 10], u = {}, h = 0; h < 3; h++ ) (u[UF[1 - a][h]] = l[h]), (u[s[h]] = 2 === h ? n[0] : i[s[h]]); var c = [ ["x", "width", 3], ["y", "height", 0], ][a], p = kp(u, o, i.padding); return s[ (p.margin[c[2]] || 0) + p[c[0]] + 0.5 * p[c[1]] < 0.5 * o[c[1]] ? 0 : 1 ]; } function jF(t, e) { return ( E(t || [], function (t) { null != t.dataIndex && ((t.dataIndexInside = t.dataIndex), (t.dataIndex = null)), (t.highlightKey = "visualMap" + (e ? e.componentIndex : "")); }), t ); } var qF = Kr, KF = E, $F = Math.min, JF = Math.max, QF = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return ( (n.type = e.type), (n._shapes = {}), (n._dataInterval = []), (n._handleEnds = []), (n._hoverLinkDataIndices = []), n ); } return ( n(e, t), (e.prototype.init = function (e, n) { t.prototype.init.call(this, e, n), (this._hoverLinkFromSeriesMouseOver = W( this._hoverLinkFromSeriesMouseOver, this )), (this._hideIndicator = W(this._hideIndicator, this)); }), (e.prototype.doRender = function (t, e, n, i) { (i && "selectDataRange" === i.type && i.from === this.uid) || this._buildView(); }), (e.prototype._buildView = function () { this.group.removeAll(); var t = this.visualMapModel, e = this.group; (this._orient = t.get("orient")), (this._useHandle = t.get("calculable")), this._resetInterval(), this._renderBar(e); var n = t.get("text"); this._renderEndsText(e, n, 0), this._renderEndsText(e, n, 1), this._updateView(!0), this.renderBackground(e), this._updateView(), this._enableHoverLinkToSeries(), this._enableHoverLinkFromSeries(), this.positionGroup(e); }), (e.prototype._renderEndsText = function (t, e, n) { if (e) { var i = e[1 - n]; i = null != i ? i + "" : ""; var r = this.visualMapModel, o = r.get("textGap"), a = r.itemSize, s = this._shapes.mainGroup, l = this._applyTransform( [a[0] / 2, 0 === n ? -o : a[1] + o], s ), u = this._applyTransform( 0 === n ? "bottom" : "top", s ), h = this._orient, c = this.visualMapModel.textStyleModel; this.group.add( new Xs({ style: oc(c, { x: l[0], y: l[1], verticalAlign: "horizontal" === h ? "middle" : u, align: "horizontal" === h ? u : "center", text: i, }), }) ); } }), (e.prototype._renderBar = function (t) { var e = this.visualMapModel, n = this._shapes, i = e.itemSize, r = this._orient, o = this._useHandle, a = ZF(e, this.api, i), s = (n.mainGroup = this._createBarGroup(a)), l = new Br(); s.add(l), l.add((n.outOfRange = tG())), l.add( (n.inRange = tG( null, o ? nG(this._orient) : null, W(this._dragHandle, this, "all", !1), W(this._dragHandle, this, "all", !0) )) ), l.setClipPath( new Ws({ shape: { x: 0, y: 0, width: i[0], height: i[1], r: 3, }, }) ); var u = e.textStyleModel.getTextRect("国"), h = JF(u.width, u.height); o && ((n.handleThumbs = []), (n.handleLabels = []), (n.handleLabelPoints = []), this._createHandle(e, s, 0, i, h, r), this._createHandle(e, s, 1, i, h, r)), this._createIndicator(e, s, i, h, r), t.add(s); }), (e.prototype._createHandle = function (t, e, n, i, r, o) { var a = W(this._dragHandle, this, n, !1), s = W(this._dragHandle, this, n, !0), l = Cr(t.get("handleSize"), i[0]), u = Xy( t.get("handleIcon"), -l / 2, -l / 2, l, l, null, !0 ), h = nG(this._orient); u.attr({ cursor: h, draggable: !0, drift: a, ondragend: s, onmousemove: function (t) { de(t.event); }, }), (u.x = i[0] / 2), u.useStyle(t.getModel("handleStyle").getItemStyle()), u.setStyle({ strokeNoScale: !0, strokeFirst: !0 }), (u.style.lineWidth *= 2), (u.ensureState("emphasis").style = t .getModel(["emphasis", "handleStyle"]) .getItemStyle()), Jl(u, !0), e.add(u); var c = this.visualMapModel.textStyleModel, p = new Xs({ cursor: h, draggable: !0, drift: a, onmousemove: function (t) { de(t.event); }, ondragend: s, style: oc(c, { x: 0, y: 0, text: "" }), }); (p.ensureState("blur").style = { opacity: 0.1 }), (p.stateTransition = { duration: 200 }), this.group.add(p); var d = [l, 0], f = this._shapes; (f.handleThumbs[n] = u), (f.handleLabelPoints[n] = d), (f.handleLabels[n] = p); }), (e.prototype._createIndicator = function (t, e, n, i, r) { var o = Cr(t.get("indicatorSize"), n[0]), a = Xy( t.get("indicatorIcon"), -o / 2, -o / 2, o, o, null, !0 ); a.attr({ cursor: "move", invisible: !0, silent: !0, x: n[0] / 2, }); var s = t.getModel("indicatorStyle").getItemStyle(); if (a instanceof Ns) { var l = a.style; a.useStyle( A( { image: l.image, x: l.x, y: l.y, width: l.width, height: l.height, }, s ) ); } else a.useStyle(s); e.add(a); var u = this.visualMapModel.textStyleModel, h = new Xs({ silent: !0, invisible: !0, style: oc(u, { x: 0, y: 0, text: "" }), }); this.group.add(h); var c = [("horizontal" === r ? i / 2 : 6) + n[0] / 2, 0], p = this._shapes; (p.indicator = a), (p.indicatorLabel = h), (p.indicatorLabelPoint = c), (this._firstShowIndicator = !0); }), (e.prototype._dragHandle = function (t, e, n, i) { if (this._useHandle) { if (((this._dragging = !e), !e)) { var r = this._applyTransform( [n, i], this._shapes.mainGroup, !0 ); this._updateInterval(t, r[1]), this._hideIndicator(), this._updateView(); } e === !this.visualMapModel.get("realtime") && this.api.dispatchAction({ type: "selectDataRange", from: this.uid, visualMapId: this.visualMapModel.id, selected: this._dataInterval.slice(), }), e ? !this._hovering && this._clearHoverLinkToSeries() : eG(this.visualMapModel) && this._doHoverLinkToSeries( this._handleEnds[t], !1 ); } }), (e.prototype._resetInterval = function () { var t = this.visualMapModel, e = (this._dataInterval = t.getSelected()), n = t.getExtent(), i = [0, t.itemSize[1]]; this._handleEnds = [qF(e[0], n, i, !0), qF(e[1], n, i, !0)]; }), (e.prototype._updateInterval = function (t, e) { e = e || 0; var n = this.visualMapModel, i = this._handleEnds, r = [0, n.itemSize[1]]; zk(e, i, r, t, 0); var o = n.getExtent(); this._dataInterval = [ qF(i[0], r, o, !0), qF(i[1], r, o, !0), ]; }), (e.prototype._updateView = function (t) { var e = this.visualMapModel, n = e.getExtent(), i = this._shapes, r = [0, e.itemSize[1]], o = t ? r : this._handleEnds, a = this._createBarVisual( this._dataInterval, n, o, "inRange" ), s = this._createBarVisual(n, n, r, "outOfRange"); i.inRange .setStyle({ fill: a.barColor }) .setShape("points", a.barPoints), i.outOfRange .setStyle({ fill: s.barColor }) .setShape("points", s.barPoints), this._updateHandle(o, a); }), (e.prototype._createBarVisual = function (t, e, n, i) { var r = { forceState: i, convertOpacityToAlpha: !0 }, o = this._makeColorGradient(t, r), a = [ this.getControllerVisual(t[0], "symbolSize", r), this.getControllerVisual(t[1], "symbolSize", r), ], s = this._createBarPoints(n, a); return { barColor: new oh(0, 0, 0, 1, o), barPoints: s, handlesColor: [o[0].color, o[o.length - 1].color], }; }), (e.prototype._makeColorGradient = function (t, e) { var n = [], i = (t[1] - t[0]) / 100; n.push({ color: this.getControllerVisual(t[0], "color", e), offset: 0, }); for (var r = 1; r < 100; r++) { var o = t[0] + i * r; if (o > t[1]) break; n.push({ color: this.getControllerVisual(o, "color", e), offset: r / 100, }); } return ( n.push({ color: this.getControllerVisual(t[1], "color", e), offset: 1, }), n ); }), (e.prototype._createBarPoints = function (t, e) { var n = this.visualMapModel.itemSize; return [ [n[0] - e[0], t[0]], [n[0], t[0]], [n[0], t[1]], [n[0] - e[1], t[1]], ]; }), (e.prototype._createBarGroup = function (t) { var e = this._orient, n = this.visualMapModel.get("inverse"); return new Br( "horizontal" !== e || n ? "horizontal" === e && n ? { scaleX: "bottom" === t ? -1 : 1, rotation: -Math.PI / 2, } : "vertical" !== e || n ? { scaleX: "left" === t ? 1 : -1 } : { scaleX: "left" === t ? 1 : -1, scaleY: -1 } : { scaleX: "bottom" === t ? 1 : -1, rotation: Math.PI / 2, } ); }), (e.prototype._updateHandle = function (t, e) { if (this._useHandle) { var n = this._shapes, i = this.visualMapModel, r = n.handleThumbs, o = n.handleLabels, a = i.itemSize, s = i.getExtent(), l = this._applyTransform("left", n.mainGroup); KF( [0, 1], function (u) { var h = r[u]; h.setStyle("fill", e.handlesColor[u]), (h.y = t[u]); var c = qF(t[u], [0, a[1]], s, !0), p = this.getControllerVisual( c, "symbolSize" ); (h.scaleX = h.scaleY = p / a[0]), (h.x = a[0] - p / 2); var d = Fh( n.handleLabelPoints[u], Bh(h, this.group) ); if ("horizontal" === this._orient) { var f = "left" === l || "top" === l ? (a[0] - p) / 2 : (a[0] - p) / -2; d[1] += f; } o[u].setStyle({ x: d[0], y: d[1], text: i.formatValueText( this._dataInterval[u] ), verticalAlign: "middle", align: "vertical" === this._orient ? this._applyTransform( "left", n.mainGroup ) : "center", }); }, this ); } }), (e.prototype._showIndicator = function (t, e, n, i) { var r = this.visualMapModel, o = r.getExtent(), a = r.itemSize, s = [0, a[1]], l = this._shapes, u = l.indicator; if (u) { u.attr("invisible", !1); var h = this.getControllerVisual(t, "color", { convertOpacityToAlpha: !0, }), c = this.getControllerVisual(t, "symbolSize"), p = qF(t, o, s, !0), d = a[0] - c / 2, f = { x: u.x, y: u.y }; (u.y = p), (u.x = d); var g = Fh(l.indicatorLabelPoint, Bh(u, this.group)), y = l.indicatorLabel; y.attr("invisible", !1); var v = this._applyTransform("left", l.mainGroup), m = "horizontal" === this._orient; y.setStyle({ text: (n || "") + r.formatValueText(e), verticalAlign: m ? v : "middle", align: m ? "center" : v, }); var x = { x: d, y: p, style: { fill: h } }, _ = { style: { x: g[0], y: g[1] } }; if ( r.ecModel.isAnimationEnabled() && !this._firstShowIndicator ) { var b = { duration: 100, easing: "cubicInOut", additive: !0, }; (u.x = f.x), (u.y = f.y), u.animateTo(x, b), y.animateTo(_, b); } else u.attr(x), y.attr(_); this._firstShowIndicator = !1; var w = this._shapes.handleLabels; if (w) for (var S = 0; S < w.length; S++) this.api.enterBlur(w[S]); } }), (e.prototype._enableHoverLinkToSeries = function () { var t = this; this._shapes.mainGroup .on("mousemove", function (e) { if (((t._hovering = !0), !t._dragging)) { var n = t.visualMapModel.itemSize, i = t._applyTransform( [e.offsetX, e.offsetY], t._shapes.mainGroup, !0, !0 ); (i[1] = $F(JF(0, i[1]), n[1])), t._doHoverLinkToSeries( i[1], 0 <= i[0] && i[0] <= n[0] ); } }) .on("mouseout", function () { (t._hovering = !1), !t._dragging && t._clearHoverLinkToSeries(); }); }), (e.prototype._enableHoverLinkFromSeries = function () { var t = this.api.getZr(); this.visualMapModel.option.hoverLink ? (t.on( "mouseover", this._hoverLinkFromSeriesMouseOver, this ), t.on("mouseout", this._hideIndicator, this)) : this._clearHoverLinkFromSeries(); }), (e.prototype._doHoverLinkToSeries = function (t, e) { var n = this.visualMapModel, i = n.itemSize; if (n.option.hoverLink) { var r = [0, i[1]], o = n.getExtent(); t = $F(JF(r[0], t), r[1]); var a = (function (t, e, n) { var i = 6, r = t.get("hoverLinkDataSize"); r && (i = qF(r, e, n, !0) / 2); return i; })(n, o, r), s = [t - a, t + a], l = qF(t, r, o, !0), u = [qF(s[0], r, o, !0), qF(s[1], r, o, !0)]; s[0] < r[0] && (u[0] = -1 / 0), s[1] > r[1] && (u[1] = 1 / 0), e && (u[0] === -1 / 0 ? this._showIndicator(l, u[1], "< ", a) : u[1] === 1 / 0 ? this._showIndicator(l, u[0], "> ", a) : this._showIndicator(l, l, "≈ ", a)); var h = this._hoverLinkDataIndices, c = []; (e || eG(n)) && (c = this._hoverLinkDataIndices = n.findTargetDataIndices(u)); var p = (function (t, e) { var n = {}, i = {}; return ( r(t || [], n), r(e || [], i, n), [o(n), o(i)] ); function r(t, e, n) { for (var i = 0, r = t.length; i < r; i++) { var o = Ro(t[i].seriesId, null); if (null == o) return; for ( var a = To(t[i].dataIndex), s = n && n[o], l = 0, u = a.length; l < u; l++ ) { var h = a[l]; s && s[h] ? (s[h] = null) : ((e[o] || (e[o] = {}))[h] = 1); } } } function o(t, e) { var n = []; for (var i in t) if (t.hasOwnProperty(i) && null != t[i]) if (e) n.push(+i); else { var r = o(t[i], !0); r.length && n.push({ seriesId: i, dataIndex: r, }); } return n; } })(h, c); this._dispatchHighDown("downplay", jF(p[0], n)), this._dispatchHighDown("highlight", jF(p[1], n)); } }), (e.prototype._hoverLinkFromSeriesMouseOver = function (t) { var e; if ( (Oy( t.target, function (t) { var n = rl(t); if (null != n.dataIndex) return (e = n), !0; }, !0 ), e) ) { var n = this.ecModel.getSeriesByIndex(e.seriesIndex), i = this.visualMapModel; if (i.isTargetSeries(n)) { var r = n.getData(e.dataType), o = r .getStore() .get( i.getDataDimensionIndex(r), e.dataIndex ); isNaN(o) || this._showIndicator(o, o); } } }), (e.prototype._hideIndicator = function () { var t = this._shapes; t.indicator && t.indicator.attr("invisible", !0), t.indicatorLabel && t.indicatorLabel.attr("invisible", !0); var e = this._shapes.handleLabels; if (e) for (var n = 0; n < e.length; n++) this.api.leaveBlur(e[n]); }), (e.prototype._clearHoverLinkToSeries = function () { this._hideIndicator(); var t = this._hoverLinkDataIndices; this._dispatchHighDown( "downplay", jF(t, this.visualMapModel) ), (t.length = 0); }), (e.prototype._clearHoverLinkFromSeries = function () { this._hideIndicator(); var t = this.api.getZr(); t.off("mouseover", this._hoverLinkFromSeriesMouseOver), t.off("mouseout", this._hideIndicator); }), (e.prototype._applyTransform = function (t, e, n, i) { var r = Bh(e, i ? null : this.group); return Y(t) ? Fh(t, r, n) : Gh(t, r, n); }), (e.prototype._dispatchHighDown = function (t, e) { e && e.length && this.api.dispatchAction({ type: t, batch: e }); }), (e.prototype.dispose = function () { this._clearHoverLinkFromSeries(), this._clearHoverLinkToSeries(); }), (e.type = "visualMap.continuous"), e ); })(XF); function tG(t, e, n, i) { return new Xu({ shape: { points: t }, draggable: !!n, cursor: e, drift: n, onmousemove: function (t) { de(t.event); }, ondragend: i, }); } function eG(t) { var e = t.get("hoverLinkOnHandle"); return !!(null == e ? t.get("realtime") : e); } function nG(t) { return "vertical" === t ? "ns-resize" : "ew-resize"; } var iG = { type: "selectDataRange", event: "dataRangeSelected", update: "update", }, rG = function (t, e) { e.eachComponent({ mainType: "visualMap", query: t }, function (e) { e.setSelected(t.selected); }); }, oG = [ { createOnAllSeries: !0, reset: function (t, e) { var n = []; return ( e.eachComponent("visualMap", function (e) { var i, r, o, a, s, l = t.pipelineContext; !e.isTargetSeries(t) || (l && l.large) || n.push( ((i = e.stateList), (r = e.targetVisuals), (o = W(e.getValueState, e)), (a = e.getDataDimensionIndex(t.getData())), (s = {}), E(i, function (t) { var e = kD.prepareVisualTypes(r[t]); s[t] = e; }), { progress: function (t, e) { var n, i; function l(t) { return Dy(e, i, t); } function u(t, n) { ky(e, i, t, n); } null != a && (n = e.getDimensionIndex(a)); for ( var h = e.getStore(); null != (i = t.next()); ) { var c = e.getRawDataItem(i); if (!c || !1 !== c.visualMap) for ( var p = null != a ? h.get( n, i ) : i, d = o(p), f = r[d], g = s[d], y = 0, v = g.length; y < v; y++ ) { var m = g[y]; f[m] && f[m].applyVisual( p, l, u ); } } }, }) ); }), n ); }, }, { createOnAllSeries: !0, reset: function (t, e) { var n = t.getData(), i = []; e.eachComponent("visualMap", function (e) { if (e.isTargetSeries(t)) { var r = e.getVisualMeta(W(aG, null, t, e)) || { stops: [], outerColors: [], }, o = e.getDataDimensionIndex(n); o >= 0 && ((r.dimension = o), i.push(r)); } }), t.getData().setVisual("visualMeta", i); }, }, ]; function aG(t, e, n, i) { for ( var r = e.targetVisuals[i], o = kD.prepareVisualTypes(r), a = { color: Ay(t.getData(), "color") }, s = 0, l = o.length; s < l; s++ ) { var u = o[s], h = r["opacity" === u ? "__alphaForOpacity" : u]; h && h.applyVisual(n, c, p); } return a.color; function c(t) { return a[t]; } function p(t, e) { a[t] = e; } } var sG = E; function lG(t) { var e = t && t.visualMap; Y(e) || (e = e ? [e] : []), sG(e, function (t) { if (t) { uG(t, "splitList") && !uG(t, "pieces") && ((t.pieces = t.splitList), delete t.splitList); var e = t.pieces; e && Y(e) && sG(e, function (t) { q(t) && (uG(t, "start") && !uG(t, "min") && (t.min = t.start), uG(t, "end") && !uG(t, "max") && (t.max = t.end)); }); } }); } function uG(t, e) { return t && t.hasOwnProperty && t.hasOwnProperty(e); } var hG = !1; function cG(t) { hG || ((hG = !0), t.registerSubTypeDefaulter("visualMap", function (t) { return t.categories || ((t.pieces ? t.pieces.length > 0 : t.splitNumber > 0) && !t.calculable) ? "piecewise" : "continuous"; }), t.registerAction(iG, rG), E(oG, function (e) { t.registerVisual(t.PRIORITY.VISUAL.COMPONENT, e); }), t.registerPreprocessor(lG)); } function pG(t) { t.registerComponentModel(HF), t.registerComponentView(QF), cG(t); } var dG = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), (n._pieceList = []), n; } return ( n(e, t), (e.prototype.optionUpdated = function (e, n) { t.prototype.optionUpdated.apply(this, arguments), this.resetExtent(); var i = (this._mode = this._determineMode()); (this._pieceList = []), fG[this._mode].call(this, this._pieceList), this._resetSelected(e, n); var r = this.option.categories; this.resetVisual(function (t, e) { "categories" === i ? ((t.mappingMethod = "category"), (t.categories = T(r))) : ((t.dataExtent = this.getExtent()), (t.mappingMethod = "piecewise"), (t.pieceList = z(this._pieceList, function (t) { return ( (t = T(t)), "inRange" !== e && (t.visual = null), t ); }))); }); }), (e.prototype.completeVisualOption = function () { var e = this.option, n = {}, i = kD.listVisualTypes(), r = this.isCategory(); function o(t, e, n) { return t && t[e] && t[e].hasOwnProperty(n); } E(e.pieces, function (t) { E(i, function (e) { t.hasOwnProperty(e) && (n[e] = 1); }); }), E( n, function (t, n) { var i = !1; E( this.stateList, function (t) { i = i || o(e, t, n) || o(e.target, t, n); }, this ), !i && E(this.stateList, function (t) { (e[t] || (e[t] = {}))[n] = OF( n, "inRange" === t ? "active" : "inactive", r ); }); }, this ), t.prototype.completeVisualOption.apply(this, arguments); }), (e.prototype._resetSelected = function (t, e) { var n = this.option, i = this._pieceList, r = (e ? n : t).selected || {}; if ( ((n.selected = r), E( i, function (t, e) { var n = this.getSelectedMapKey(t); r.hasOwnProperty(n) || (r[n] = !0); }, this ), "single" === n.selectedMode) ) { var o = !1; E( i, function (t, e) { var n = this.getSelectedMapKey(t); r[n] && (o ? (r[n] = !1) : (o = !0)); }, this ); } }), (e.prototype.getItemSymbol = function () { return this.get("itemSymbol"); }), (e.prototype.getSelectedMapKey = function (t) { return "categories" === this._mode ? t.value + "" : t.index + ""; }), (e.prototype.getPieceList = function () { return this._pieceList; }), (e.prototype._determineMode = function () { var t = this.option; return t.pieces && t.pieces.length > 0 ? "pieces" : this.option.categories ? "categories" : "splitNumber"; }), (e.prototype.setSelected = function (t) { this.option.selected = T(t); }), (e.prototype.getValueState = function (t) { var e = kD.findPieceIndex(t, this._pieceList); return null != e && this.option.selected[ this.getSelectedMapKey(this._pieceList[e]) ] ? "inRange" : "outOfRange"; }), (e.prototype.findTargetDataIndices = function (t) { var e = [], n = this._pieceList; return ( this.eachTargetSeries(function (i) { var r = [], o = i.getData(); o.each( this.getDataDimensionIndex(o), function (e, i) { kD.findPieceIndex(e, n) === t && r.push(i); }, this ), e.push({ seriesId: i.id, dataIndex: r }); }, this), e ); }), (e.prototype.getRepresentValue = function (t) { var e; if (this.isCategory()) e = t.value; else if (null != t.value) e = t.value; else { var n = t.interval || []; e = n[0] === -1 / 0 && n[1] === 1 / 0 ? 0 : (n[0] + n[1]) / 2; } return e; }), (e.prototype.getVisualMeta = function (t) { if (!this.isCategory()) { var e = [], n = ["", ""], i = this, r = this._pieceList.slice(); if (r.length) { var o = r[0].interval[0]; o !== -1 / 0 && r.unshift({ interval: [-1 / 0, o] }), (o = r[r.length - 1].interval[1]) !== 1 / 0 && r.push({ interval: [o, 1 / 0] }); } else r.push({ interval: [-1 / 0, 1 / 0] }); var a = -1 / 0; return ( E( r, function (t) { var e = t.interval; e && (e[0] > a && s([a, e[0]], "outOfRange"), s(e.slice()), (a = e[1])); }, this ), { stops: e, outerColors: n } ); } function s(r, o) { var a = i.getRepresentValue({ interval: r }); o || (o = i.getValueState(a)); var s = t(a, o); r[0] === -1 / 0 ? (n[0] = s) : r[1] === 1 / 0 ? (n[1] = s) : e.push( { value: r[0], color: s }, { value: r[1], color: s } ); } }), (e.type = "visualMap.piecewise"), (e.defaultOption = kc(GF.defaultOption, { selected: null, minOpen: !1, maxOpen: !1, align: "auto", itemWidth: 20, itemHeight: 14, itemSymbol: "roundRect", pieces: null, categories: null, splitNumber: 5, selectedMode: "multiple", itemGap: 10, hoverLink: !0, })), e ); })(GF), fG = { splitNumber: function (t) { var e = this.option, n = Math.min(e.precision, 20), i = this.getExtent(), r = e.splitNumber; (r = Math.max(parseInt(r, 10), 1)), (e.splitNumber = r); for (var o = (i[1] - i[0]) / r; +o.toFixed(n) !== o && n < 5; ) n++; (e.precision = n), (o = +o.toFixed(n)), e.minOpen && t.push({ interval: [-1 / 0, i[0]], close: [0, 0] }); for (var a = 0, s = i[0]; a < r; s += o, a++) { var l = a === r - 1 ? i[1] : s + o; t.push({ interval: [s, l], close: [1, 1] }); } e.maxOpen && t.push({ interval: [i[1], 1 / 0], close: [0, 0] }), go(t), E( t, function (t, e) { (t.index = e), (t.text = this.formatValueText(t.interval)); }, this ); }, categories: function (t) { var e = this.option; E( e.categories, function (e) { t.push({ text: this.formatValueText(e, !0), value: e }); }, this ), gG(e, t); }, pieces: function (t) { var e = this.option; E( e.pieces, function (e, n) { q(e) || (e = { value: e }); var i = { text: "", index: n }; if ( (null != e.label && (i.text = e.label), e.hasOwnProperty("value")) ) { var r = (i.value = e.value); (i.interval = [r, r]), (i.close = [1, 1]); } else { for ( var o = (i.interval = []), a = (i.close = [0, 0]), s = [1, 0, 1], l = [-1 / 0, 1 / 0], u = [], h = 0; h < 2; h++ ) { for ( var c = [ ["gte", "gt", "min"], ["lte", "lt", "max"], ][h], p = 0; p < 3 && null == o[h]; p++ ) (o[h] = e[c[p]]), (a[h] = s[p]), (u[h] = 2 === p); null == o[h] && (o[h] = l[h]); } u[0] && o[1] === 1 / 0 && (a[0] = 0), u[1] && o[0] === -1 / 0 && (a[1] = 0), o[0] === o[1] && a[0] && a[1] && (i.value = o[0]); } (i.visual = kD.retrieveVisuals(e)), t.push(i); }, this ), gG(e, t), go(t), E( t, function (t) { var e = t.close, n = [["<", "≤"][e[1]], [">", "≥"][e[0]]]; t.text = t.text || this.formatValueText( null != t.value ? t.value : t.interval, !1, n ); }, this ); }, }; function gG(t, e) { var n = t.inverse; ("vertical" === t.orient ? !n : n) && e.reverse(); } var yG = (function (t) { function e() { var n = (null !== t && t.apply(this, arguments)) || this; return (n.type = e.type), n; } return ( n(e, t), (e.prototype.doRender = function () { var t = this.group; t.removeAll(); var e = this.visualMapModel, n = e.get("textGap"), i = e.textStyleModel, r = i.getFont(), o = i.getTextColor(), a = this._getItemAlign(), s = e.itemSize, l = this._getViewData(), u = l.endsText, h = it(e.get("showLabel", !0), !u), c = !e.get("selectedMode"); u && this._renderEndsText(t, u[0], s, h, a), E( l.viewPieceList, function (i) { var l = i.piece, u = new Br(); (u.onclick = W(this._onItemClick, this, l)), this._enableHoverLink( u, i.indexInModelPieceList ); var p = e.getRepresentValue(l); if ( (this._createItemSymbol( u, p, [0, 0, s[0], s[1]], c ), h) ) { var d = this.visualMapModel.getValueState(p); u.add( new Xs({ style: { x: "right" === a ? -n : s[0] + n, y: s[1] / 2, text: l.text, verticalAlign: "middle", align: a, font: r, fill: o, opacity: "outOfRange" === d ? 0.5 : 1, }, silent: c, }) ); } t.add(u); }, this ), u && this._renderEndsText(t, u[1], s, h, a), Ap(e.get("orient"), t, e.get("itemGap")), this.renderBackground(t), this.positionGroup(t); }), (e.prototype._enableHoverLink = function (t, e) { var n = this; t.on("mouseover", function () { return i("highlight"); }).on("mouseout", function () { return i("downplay"); }); var i = function (t) { var i = n.visualMapModel; i.option.hoverLink && n.api.dispatchAction({ type: t, batch: jF(i.findTargetDataIndices(e), i), }); }; }), (e.prototype._getItemAlign = function () { var t = this.visualMapModel, e = t.option; if ("vertical" === e.orient) return ZF(t, this.api, t.itemSize); var n = e.align; return (n && "auto" !== n) || (n = "left"), n; }), (e.prototype._renderEndsText = function (t, e, n, i, r) { if (e) { var o = new Br(), a = this.visualMapModel.textStyleModel; o.add( new Xs({ style: oc(a, { x: i ? ("right" === r ? n[0] : 0) : n[0] / 2, y: n[1] / 2, verticalAlign: "middle", align: i ? r : "center", text: e, }), }) ), t.add(o); } }), (e.prototype._getViewData = function () { var t = this.visualMapModel, e = z(t.getPieceList(), function (t, e) { return { piece: t, indexInModelPieceList: e }; }), n = t.get("text"), i = t.get("orient"), r = t.get("inverse"); return ( ("horizontal" === i ? r : !r) ? e.reverse() : n && (n = n.slice().reverse()), { viewPieceList: e, endsText: n } ); }), (e.prototype._createItemSymbol = function (t, e, n, i) { var r = Xy( this.getControllerVisual(e, "symbol"), n[0], n[1], n[2], n[3], this.getControllerVisual(e, "color") ); (r.silent = i), t.add(r); }), (e.prototype._onItemClick = function (t) { var e = this.visualMapModel, n = e.option, i = n.selectedMode; if (i) { var r = T(n.selected), o = e.getSelectedMapKey(t); "single" === i || !0 === i ? ((r[o] = !0), E(r, function (t, e) { r[e] = e === o; })) : (r[o] = !r[o]), this.api.dispatchAction({ type: "selectDataRange", from: this.uid, visualMapId: this.visualMapModel.id, selected: r, }); } }), (e.type = "visualMap.piecewise"), e ); })(XF); function vG(t) { t.registerComponentModel(dG), t.registerComponentView(yG), cG(t); } var mG = { label: { enabled: !0 }, decal: { show: !1 } }, xG = Vo(), _G = {}; function bG(t, e) { var n = t.getModel("aria"); if (n.get("enabled")) { var i = T(mG); C(i.label, t.getLocaleModel().get("aria"), !1), C(n.option, i, !1), (function () { if (n.getModel("decal").get("show")) { var e = yt(); t.eachSeries(function (t) { if (!t.isColorBySeries()) { var n = e.get(t.type); n || ((n = {}), e.set(t.type, n)), (xG(t).scope = n); } }), t.eachRawSeries(function (e) { if (!t.isSeriesFiltered(e)) if (X(e.enableAriaDecal)) e.enableAriaDecal(); else { var n = e.getData(); if (e.isColorBySeries()) { var i = pd( e.ecModel, e.name, _G, t.getSeriesCount() ), r = n.getVisual("decal"); n.setVisual("decal", u(r, i)); } else { var o = e.getRawData(), a = {}, s = xG(e).scope; n.each(function (t) { var e = n.getRawIndex(t); a[e] = t; }); var l = o.count(); o.each(function (t) { var i = a[t], r = o.getName(t) || t + "", h = pd(e.ecModel, r, s, l), c = n.getItemVisual( i, "decal" ); n.setItemVisual( i, "decal", u(c, h) ); }); } } function u(t, e) { var n = t ? A(A({}, e), t) : e; return (n.dirty = !0), n; } }); } })(), (function () { var i = e.getZr().dom; if (!i) return; var o = t.getLocaleModel().get("aria"), a = n.getModel("label"); if (((a.option = k(a.option, o)), !a.get("enabled"))) return; if ((i.setAttribute("role", "img"), a.get("description"))) return void i.setAttribute( "aria-label", a.get("description") ); var s, l = t.getSeriesCount(), u = a.get(["data", "maxCount"]) || 10, h = a.get(["series", "maxCount"]) || 10, c = Math.min(l, h); if (l < 1) return; var p = (function () { var e = t.get("title"); e && e.length && (e = e[0]); return e && e.text; })(); s = p ? r(a.get(["general", "withTitle"]), { title: p }) : a.get(["general", "withoutTitle"]); var d = []; (s += r( l > 1 ? a.get(["series", "multiple", "prefix"]) : a.get(["series", "single", "prefix"]), { seriesCount: l } )), t.eachSeries(function (e, n) { if (n < c) { var i = void 0, o = e.get("name") ? "withName" : "withoutName"; i = r( (i = l > 1 ? a.get(["series", "multiple", o]) : a.get(["series", "single", o])), { seriesId: e.seriesIndex, seriesName: e.get("name"), seriesType: ((_ = e.subType), (b = t .getLocaleModel() .get(["series", "typeNames"])), b[_] || b.chart), } ); var s = e.getData(); if (s.count() > u) i += r(a.get(["data", "partialData"]), { displayCnt: u, }); else i += a.get(["data", "allData"]); for ( var h = a.get([ "data", "separator", "middle", ]), p = a.get(["data", "separator", "end"]), f = a.get([ "data", "excludeDimensionId", ]), g = [], y = 0; y < s.count(); y++ ) if (y < u) { var v = s.getName(y), m = f ? B( s.getValues(y), function (t, e) { return -1 === P(f, e); } ) : s.getValues(y), x = a.get([ "data", v ? "withName" : "withoutName", ]); g.push( r(x, { name: v, value: m.join(h) }) ); } (i += g.join(h) + p), d.push(i); } var _, b; }); var f = a.getModel(["series", "multiple", "separator"]), g = f.get("middle"), y = f.get("end"); (s += d.join(g) + y), i.setAttribute("aria-label", s); })(); } function r(t, e) { if (!U(t)) return t; var n = t; return ( E(e, function (t, e) { n = n.replace( new RegExp("\\{\\s*" + e + "\\s*\\}", "g"), t ); }), n ); } } function wG(t) { if (t && t.aria) { var e = t.aria; null != e.show && (e.enabled = e.show), (e.label = e.label || {}), E(["description", "general", "series", "data"], function (t) { null != e[t] && (e.label[t] = e[t]); }); } } var SG = { value: "eq", "<": "lt", "<=": "lte", ">": "gt", ">=": "gte", "=": "eq", "!=": "ne", "<>": "ne", }, MG = (function () { function t(t) { if ( null == (this._condVal = U(t) ? new RegExp(t) : et(t) ? t : null) ) { var e = ""; 0, wo(e); } } return ( (t.prototype.evaluate = function (t) { var e = typeof t; return U(e) ? this._condVal.test(t) : !!j(e) && this._condVal.test(t + ""); }), t ); })(), IG = (function () { function t() {} return ( (t.prototype.evaluate = function () { return this.value; }), t ); })(), TG = (function () { function t() {} return ( (t.prototype.evaluate = function () { for (var t = this.children, e = 0; e < t.length; e++) if (!t[e].evaluate()) return !1; return !0; }), t ); })(), CG = (function () { function t() {} return ( (t.prototype.evaluate = function () { for (var t = this.children, e = 0; e < t.length; e++) if (t[e].evaluate()) return !0; return !1; }), t ); })(), DG = (function () { function t() {} return ( (t.prototype.evaluate = function () { return !this.child.evaluate(); }), t ); })(), AG = (function () { function t() {} return ( (t.prototype.evaluate = function () { for ( var t = !!this.valueParser, e = (0, this.getValue)(this.valueGetterParam), n = t ? this.valueParser(e) : null, i = 0; i < this.subCondList.length; i++ ) if (!this.subCondList[i].evaluate(t ? n : e)) return !1; return !0; }), t ); })(); function kG(t, e) { if (!0 === t || !1 === t) { var n = new IG(); return (n.value = t), n; } var i = ""; return ( PG(t) || wo(i), t.and ? LG("and", t, e) : t.or ? LG("or", t, e) : t.not ? (function (t, e) { var n = t.not, i = ""; 0; PG(n) || wo(i); var r = new DG(); (r.child = kG(n, e)), r.child || wo(i); return r; })(t, e) : (function (t, e) { for ( var n = "", i = e.prepareGetValue(t), r = [], o = G(t), a = t.parser, s = a ? Cf(a) : null, l = 0; l < o.length; l++ ) { var u = o[l]; if ("parser" !== u && !e.valueGetterAttrMap.get(u)) { var h = _t(SG, u) ? SG[u] : u, c = t[u], p = s ? s(c) : c, d = Pf(h, p) || ("reg" === h && new MG(p)); d || wo(n), r.push(d); } } r.length || wo(n); var f = new AG(); return ( (f.valueGetterParam = i), (f.valueParser = s), (f.getValue = e.getValue), (f.subCondList = r), f ); })(t, e) ); } function LG(t, e, n) { var i = e[t], r = ""; Y(i) || wo(r), i.length || wo(r); var o = "and" === t ? new TG() : new CG(); return ( (o.children = z(i, function (t) { return kG(t, n); })), o.children.length || wo(r), o ); } function PG(t) { return q(t) && !N(t); } var OG = (function () { function t(t, e) { this._cond = kG(t, e); } return ( (t.prototype.evaluate = function () { return this._cond.evaluate(); }), t ); })(); var RG = { type: "echarts:filter", transform: function (t) { for ( var e, n, i, r = t.upstream, o = ((n = t.config), (i = { valueGetterAttrMap: yt({ dimension: !0 }), prepareGetValue: function (t) { var e = "", n = t.dimension; _t(t, "dimension") || wo(e); var i = r.getDimensionInfo(n); return i || wo(e), { dimIdx: i.index }; }, getValue: function (t) { return r.retrieveValueFromItem(e, t.dimIdx); }, }), new OG(n, i)), a = [], s = 0, l = r.count(); s < l; s++ ) (e = r.getRawDataItem(s)), o.evaluate() && a.push(e); return { data: a }; }, }; var NG = { type: "echarts:sort", transform: function (t) { var e = t.upstream, n = t.config, i = "", r = To(n); r.length || wo(i); var o = []; E(r, function (t) { var n = t.dimension, r = t.order, a = t.parser, s = t.incomparable; if ( (null == n && wo(i), "asc" !== r && "desc" !== r && wo(i), s && "min" !== s && "max" !== s) ) { var l = ""; 0, wo(l); } if ("asc" !== r && "desc" !== r) { var u = ""; 0, wo(u); } var h = e.getDimensionInfo(n); h || wo(i); var c = a ? Cf(a) : null; a && !c && wo(i), o.push({ dimIdx: h.index, parser: c, comparator: new kf(r, s), }); }); var a = e.sourceFormat; a !== Hp && a !== Yp && wo(i); for (var s = [], l = 0, u = e.count(); l < u; l++) s.push(e.getRawDataItem(l)); return ( s.sort(function (t, n) { for (var i = 0; i < o.length; i++) { var r = o[i], a = e.retrieveValueFromItem(t, r.dimIdx), s = e.retrieveValueFromItem(n, r.dimIdx); r.parser && ((a = r.parser(a)), (s = r.parser(s))); var l = r.comparator.evaluate(a, s); if (0 !== l) return l; } return 0; }), { data: s } ); }, }; var EG = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.type = "dataset"), e; } return ( n(e, t), (e.prototype.init = function (e, n, i) { t.prototype.init.call(this, e, n, i), (this._sourceManager = new $f(this)), Jf(this); }), (e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), Jf(this); }), (e.prototype.optionUpdated = function () { this._sourceManager.dirty(); }), (e.prototype.getSourceManager = function () { return this._sourceManager; }), (e.type = "dataset"), (e.defaultOption = { seriesLayoutBy: jp }), e ); })(zp), zG = (function (t) { function e() { var e = (null !== t && t.apply(this, arguments)) || this; return (e.type = "dataset"), e; } return n(e, t), (e.type = "dataset"), e; })(Ag); var VG = hs.CMD; function BG(t, e) { return Math.abs(t - e) < 1e-5; } function FG(t) { var e, n, i, r, o, a = t.data, s = t.len(), l = [], u = 0, h = 0, c = 0, p = 0; function d(t, n) { e && e.length > 2 && l.push(e), (e = [t, n]); } function f(t, n, i, r) { (BG(t, i) && BG(n, r)) || e.push(t, n, i, r, i, r); } function g(t, n, i, r, o, a) { var s = Math.abs(n - t), l = (4 * Math.tan(s / 4)) / 3, u = n < t ? -1 : 1, h = Math.cos(t), c = Math.sin(t), p = Math.cos(n), d = Math.sin(n), f = h * o + i, g = c * a + r, y = p * o + i, v = d * a + r, m = o * l * u, x = a * l * u; e.push(f - m * c, g + x * h, y + m * d, v - x * p, y, v); } for (var y = 0; y < s; ) { var v = a[y++], m = 1 === y; switch ( (m && ((c = u = a[y]), (p = h = a[y + 1]), (v !== VG.L && v !== VG.C && v !== VG.Q) || (e = [c, p])), v) ) { case VG.M: (u = c = a[y++]), (h = p = a[y++]), d(c, p); break; case VG.L: f(u, h, (n = a[y++]), (i = a[y++])), (u = n), (h = i); break; case VG.C: e.push( a[y++], a[y++], a[y++], a[y++], (u = a[y++]), (h = a[y++]) ); break; case VG.Q: (n = a[y++]), (i = a[y++]), (r = a[y++]), (o = a[y++]), e.push( u + (2 / 3) * (n - u), h + (2 / 3) * (i - h), r + (2 / 3) * (n - r), o + (2 / 3) * (i - o), r, o ), (u = r), (h = o); break; case VG.A: var x = a[y++], _ = a[y++], b = a[y++], w = a[y++], S = a[y++], M = a[y++] + S; y += 1; var I = !a[y++]; (n = Math.cos(S) * b + x), (i = Math.sin(S) * w + _), m ? d((c = n), (p = i)) : f(u, h, n, i), (u = Math.cos(M) * b + x), (h = Math.sin(M) * w + _); for ( var T = ((I ? -1 : 1) * Math.PI) / 2, C = S; I ? C > M : C < M; C += T ) { g( C, I ? Math.max(C + T, M) : Math.min(C + T, M), x, _, b, w ); } break; case VG.R: (c = u = a[y++]), (p = h = a[y++]), (n = c + a[y++]), (i = p + a[y++]), d(n, p), f(n, p, n, i), f(n, i, c, i), f(c, i, c, p), f(c, p, n, p); break; case VG.Z: e && f(u, h, c, p), (u = c), (h = p); } } return e && e.length > 2 && l.push(e), l; } function GG(t, e, n, i, r, o, a, s, l, u) { if (BG(t, n) && BG(e, i) && BG(r, a) && BG(o, s)) l.push(a, s); else { var h = 2 / u, c = h * h, p = a - t, d = s - e, f = Math.sqrt(p * p + d * d); (p /= f), (d /= f); var g = n - t, y = i - e, v = r - a, m = o - s, x = g * g + y * y, _ = v * v + m * m; if (x < c && _ < c) l.push(a, s); else { var b = p * g + d * y, w = -p * v - d * m; if (x - b * b < c && b >= 0 && _ - w * w < c && w >= 0) l.push(a, s); else { var S = [], M = []; wn(t, n, r, a, 0.5, S), wn(e, i, o, s, 0.5, M), GG( S[0], M[0], S[1], M[1], S[2], M[2], S[3], M[3], l, u ), GG( S[4], M[4], S[5], M[5], S[6], M[6], S[7], M[7], l, u ); } } } } function WG(t, e, n) { var i = t[e], r = t[1 - e], o = Math.abs(i / r), a = Math.ceil(Math.sqrt(o * n)), s = Math.floor(n / a); 0 === s && ((s = 1), (a = n)); for (var l = [], u = 0; u < a; u++) l.push(s); var h = n - a * s; if (h > 0) for (u = 0; u < h; u++) l[u % a] += 1; return l; } function HG(t, e, n) { for ( var i = t.r0, r = t.r, o = t.startAngle, a = t.endAngle, s = Math.abs(a - o), l = s * r, u = r - i, h = l > Math.abs(u), c = WG([l, u], h ? 0 : 1, e), p = (h ? s : u) / c.length, d = 0; d < c.length; d++ ) for (var f = (h ? u : s) / c[d], g = 0; g < c[d]; g++) { var y = {}; h ? ((y.startAngle = o + p * d), (y.endAngle = o + p * (d + 1)), (y.r0 = i + f * g), (y.r = i + f * (g + 1))) : ((y.startAngle = o + f * g), (y.endAngle = o + f * (g + 1)), (y.r0 = i + p * d), (y.r = i + p * (d + 1))), (y.clockwise = t.clockwise), (y.cx = t.cx), (y.cy = t.cy), n.push(y); } } function YG(t, e, n, i) { return t * i - n * e; } function XG(t, e, n, i, r, o, a, s) { var l = n - t, u = i - e, h = a - r, c = s - o, p = YG(h, c, l, u); if (Math.abs(p) < 1e-6) return null; var d = YG(t - r, e - o, h, c) / p; return d < 0 || d > 1 ? null : new De(d * l + t, d * u + e); } function UG(t, e, n) { var i = new De(); De.sub(i, n, e), i.normalize(); var r = new De(); return De.sub(r, t, e), r.dot(i); } function ZG(t, e) { var n = t[t.length - 1]; (n && n[0] === e[0] && n[1] === e[1]) || t.push(e); } function jG(t) { var e = t.points, n = [], i = []; Ba(e, n, i); var r = new ze(n[0], n[1], i[0] - n[0], i[1] - n[1]), o = r.width, a = r.height, s = r.x, l = r.y, u = new De(), h = new De(); return ( o > a ? ((u.x = h.x = s + o / 2), (u.y = l), (h.y = l + a)) : ((u.y = h.y = l + a / 2), (u.x = s), (h.x = s + o)), (function (t, e, n) { for (var i = t.length, r = [], o = 0; o < i; o++) { var a = t[o], s = t[(o + 1) % i], l = XG(a[0], a[1], s[0], s[1], e.x, e.y, n.x, n.y); l && r.push({ projPt: UG(l, e, n), pt: l, idx: o }); } if (r.length < 2) return [{ points: t }, { points: t }]; r.sort(function (t, e) { return t.projPt - e.projPt; }); var u = r[0], h = r[r.length - 1]; if (h.idx < u.idx) { var c = u; (u = h), (h = c); } var p = [u.pt.x, u.pt.y], d = [h.pt.x, h.pt.y], f = [p], g = [d]; for (o = u.idx + 1; o <= h.idx; o++) ZG(f, t[o].slice()); for (ZG(f, d), ZG(f, p), o = h.idx + 1; o <= u.idx + i; o++) ZG(g, t[o % i].slice()); return ZG(g, p), ZG(g, d), [{ points: f }, { points: g }]; })(e, u, h) ); } function qG(t, e, n, i) { if (1 === n) i.push(e); else { var r = Math.floor(n / 2), o = t(e); qG(t, o[0], r, i), qG(t, o[1], n - r, i); } return i; } function KG(t, e) { e.setStyle(t.style), (e.z = t.z), (e.z2 = t.z2), (e.zlevel = t.zlevel); } function $G(t, e) { var n, i = [], r = t.shape; switch (t.type) { case "rect": !(function (t, e, n) { for ( var i = t.width, r = t.height, o = i > r, a = WG([i, r], o ? 0 : 1, e), s = o ? "width" : "height", l = o ? "height" : "width", u = o ? "x" : "y", h = o ? "y" : "x", c = t[s] / a.length, p = 0; p < a.length; p++ ) for (var d = t[l] / a[p], f = 0; f < a[p]; f++) { var g = {}; (g[u] = p * c), (g[h] = f * d), (g[s] = c), (g[l] = d), (g.x += t.x), (g.y += t.y), n.push(g); } })(r, e, i), (n = Ws); break; case "sector": HG(r, e, i), (n = Fu); break; case "circle": HG( { r0: 0, r: r.r, startAngle: 0, endAngle: 2 * Math.PI, cx: r.cx, cy: r.cy, }, e, i ), (n = Fu); break; default: var o = t.getComputedTransform(), a = o ? Math.sqrt( Math.max( o[0] * o[0] + o[1] * o[1], o[2] * o[2] + o[3] * o[3] ) ) : 1, s = z( (function (t, e) { var n = FG(t), i = []; e = e || 1; for (var r = 0; r < n.length; r++) { var o = n[r], a = [], s = o[0], l = o[1]; a.push(s, l); for (var u = 2; u < o.length; ) { var h = o[u++], c = o[u++], p = o[u++], d = o[u++], f = o[u++], g = o[u++]; GG(s, l, h, c, p, d, f, g, a, e), (s = f), (l = g); } i.push(a); } return i; })(t.getUpdatedPathProxy(), a), function (t) { return (function (t) { for (var e = [], n = 0; n < t.length; ) e.push([t[n++], t[n++]]); return e; })(t); } ), l = s.length; if (0 === l) qG(jG, { points: s[0] }, e, i); else if (l === e) for (var u = 0; u < l; u++) i.push({ points: s[u] }); else { var h = 0, c = z(s, function (t) { var e = [], n = []; Ba(t, e, n); var i = (n[1] - e[1]) * (n[0] - e[0]); return (h += i), { poly: t, area: i }; }); c.sort(function (t, e) { return e.area - t.area; }); var p = e; for (u = 0; u < l; u++) { var d = c[u]; if (p <= 0) break; var f = u === l - 1 ? p : Math.ceil((d.area / h) * e); f < 0 || (qG(jG, { points: d.poly }, f, i), (p -= f)); } } n = Xu; } if (!n) return (function (t, e) { for (var n = [], i = 0; i < e; i++) n.push(bu(t)); return n; })(t, e); var g = []; for (u = 0; u < i.length; u++) { var y = new n(); y.setShape(i[u]), KG(t, y), g.push(y); } return g; } function JG(t, e) { var n = t.length, i = e.length; if (n === i) return [t, e]; for ( var r = [], o = [], a = n < i ? t : e, s = Math.min(n, i), l = Math.abs(i - n) / 6, u = (s - 2) / 6, h = Math.ceil(l / u) + 1, c = [a[0], a[1]], p = l, d = 2; d < s; ) { var f = a[d - 2], g = a[d - 1], y = a[d++], v = a[d++], m = a[d++], x = a[d++], _ = a[d++], b = a[d++]; if (p <= 0) c.push(y, v, m, x, _, b); else { for (var w = Math.min(p, h - 1) + 1, S = 1; S <= w; S++) { var M = S / w; wn(f, y, m, _, M, r), wn(g, v, x, b, M, o), (f = r[3]), (g = o[3]), c.push(r[1], o[1], r[2], o[2], f, g), (y = r[5]), (v = o[5]), (m = r[6]), (x = o[6]); } p -= w - 1; } } return a === t ? [c, e] : [t, c]; } function QG(t, e) { for ( var n = t.length, i = t[n - 2], r = t[n - 1], o = [], a = 0; a < e.length; ) (o[a++] = i), (o[a++] = r); return o; } function tW(t) { for ( var e = 0, n = 0, i = 0, r = t.length, o = 0, a = r - 2; o < r; a = o, o += 2 ) { var s = t[a], l = t[a + 1], u = t[o], h = t[o + 1], c = s * h - u * l; (e += c), (n += (s + u) * c), (i += (l + h) * c); } return 0 === e ? [t[0] || 0, t[1] || 0] : [n / e / 3, i / e / 3, e]; } function eW(t, e, n, i) { for ( var r = (t.length - 2) / 6, o = 1 / 0, a = 0, s = t.length, l = s - 2, u = 0; u < r; u++ ) { for (var h = 6 * u, c = 0, p = 0; p < s; p += 2) { var d = 0 === p ? h : ((h + p - 2) % l) + 2, f = t[d] - n[0], g = t[d + 1] - n[1], y = e[p] - i[0] - f, v = e[p + 1] - i[1] - g; c += y * y + v * v; } c < o && ((o = c), (a = u)); } return a; } function nW(t) { for (var e = [], n = t.length, i = 0; i < n; i += 2) (e[i] = t[n - i - 2]), (e[i + 1] = t[n - i - 1]); return e; } function iW(t) { return t.__isCombineMorphing; } var rW = "__mOriginal_"; function oW(t, e, n) { var i = rW + e, r = t[i] || t[e]; t[i] || (t[i] = t[e]); var o = n.replace, a = n.after, s = n.before; t[e] = function () { var t, e = arguments; return ( s && s.apply(this, e), (t = o ? o.apply(this, e) : r.apply(this, e)), a && a.apply(this, e), t ); }; } function aW(t, e) { var n = rW + e; t[n] && ((t[e] = t[n]), (t[n] = null)); } function sW(t, e) { for (var n = 0; n < t.length; n++) for (var i = t[n], r = 0; r < i.length; ) { var o = i[r], a = i[r + 1]; (i[r++] = e[0] * o + e[2] * a + e[4]), (i[r++] = e[1] * o + e[3] * a + e[5]); } } function lW(t, e) { var n = t.getUpdatedPathProxy(), i = e.getUpdatedPathProxy(), r = (function (t, e) { for ( var n, i, r, o = [], a = [], s = 0; s < Math.max(t.length, e.length); s++ ) { var l = t[s], u = e[s], h = void 0, c = void 0; l ? u ? ((i = h = (n = JG(l, u))[0]), (r = c = n[1])) : ((c = QG(r || l, l)), (h = l)) : ((h = QG(i || u, u)), (c = u)), o.push(h), a.push(c); } return [o, a]; })(FG(n), FG(i)), o = r[0], a = r[1], s = t.getComputedTransform(), l = e.getComputedTransform(); s && sW(o, s), l && sW(a, l), oW(e, "updateTransform", { replace: function () { this.transform = null; }, }), (e.transform = null); var u = (function (t, e, n, i) { for (var r, o = [], a = 0; a < t.length; a++) { var s = t[a], l = e[a], u = tW(s), h = tW(l); null == r && (r = u[2] < 0 != h[2] < 0); var c = [], p = [], d = 0, f = 1 / 0, g = [], y = s.length; r && (s = nW(s)); for ( var v = 6 * eW(s, l, u, h), m = y - 2, x = 0; x < m; x += 2 ) { var _ = ((v + x) % m) + 2; (c[x + 2] = s[_] - u[0]), (c[x + 3] = s[_ + 1] - u[1]); } if (((c[0] = s[v] - u[0]), (c[1] = s[v + 1] - u[1]), n > 0)) for (var b = i / n, w = -i / 2; w <= i / 2; w += b) { var S = Math.sin(w), M = Math.cos(w), I = 0; for (x = 0; x < s.length; x += 2) { var T = c[x], C = c[x + 1], D = l[x] - h[0], A = l[x + 1] - h[1], k = D * M - A * S, L = D * S + A * M; (g[x] = k), (g[x + 1] = L); var P = k - T, O = L - C; I += P * P + O * O; } if (I < f) { (f = I), (d = w); for (var R = 0; R < g.length; R++) p[R] = g[R]; } } else for (var N = 0; N < y; N += 2) (p[N] = l[N] - h[0]), (p[N + 1] = l[N + 1] - h[1]); o.push({ from: c, to: p, fromCp: u, toCp: h, rotation: -d, }); } return o; })(o, a, 10, Math.PI), h = []; oW(e, "buildPath", { replace: function (t) { for ( var n = e.__morphT, i = 1 - n, r = [], o = 0; o < u.length; o++ ) { var a = u[o], s = a.from, l = a.to, c = a.rotation * n, p = a.fromCp, d = a.toCp, f = Math.sin(c), g = Math.cos(c); Gt(r, p, d, n); for (var y = 0; y < s.length; y += 2) { var v = s[y], m = s[y + 1], x = v * i + (S = l[y]) * n, _ = m * i + (M = l[y + 1]) * n; (h[y] = x * g - _ * f + r[0]), (h[y + 1] = x * f + _ * g + r[1]); } var b = h[0], w = h[1]; t.moveTo(b, w); for (y = 2; y < s.length; ) { var S = h[y++], M = h[y++], I = h[y++], T = h[y++], C = h[y++], D = h[y++]; b === S && w === M && I === C && T === D ? t.lineTo(C, D) : t.bezierCurveTo(S, M, I, T, C, D), (b = C), (w = D); } } }, }); } function uW(t, e, n) { if (!t || !e) return e; var i = n.done, r = n.during; return ( lW(t, e), (e.__morphT = 0), e.animateTo( { __morphT: 1 }, k( { during: function (t) { e.dirtyShape(), r && r(t); }, done: function () { aW(e, "buildPath"), aW(e, "updateTransform"), (e.__morphT = -1), e.createPathProxy(), e.dirtyShape(), i && i(); }, }, n ) ), e ); } function hW(t, e, n, i, r, o) { (t = r === n ? 0 : Math.round((32767 * (t - n)) / (r - n))), (e = o === i ? 0 : Math.round((32767 * (e - i)) / (o - i))); for (var a, s = 0, l = 32768; l > 0; l /= 2) { var u = 0, h = 0; (t & l) > 0 && (u = 1), (e & l) > 0 && (h = 1), (s += l * l * ((3 * u) ^ h)), 0 === h && (1 === u && ((t = l - 1 - t), (e = l - 1 - e)), (a = t), (t = e), (e = a)); } return s; } function cW(t) { var e = 1 / 0, n = 1 / 0, i = -1 / 0, r = -1 / 0, o = z(t, function (t) { var o = t.getBoundingRect(), a = t.getComputedTransform(), s = o.x + o.width / 2 + (a ? a[4] : 0), l = o.y + o.height / 2 + (a ? a[5] : 0); return ( (e = Math.min(s, e)), (n = Math.min(l, n)), (i = Math.max(s, i)), (r = Math.max(l, r)), [s, l] ); }); return z(o, function (o, a) { return { cp: o, z: hW(o[0], o[1], e, n, i, r), path: t[a] }; }) .sort(function (t, e) { return t.z - e.z; }) .map(function (t) { return t.path; }); } function pW(t) { return $G(t.path, t.count); } function dW(t) { return Y(t[0]); } function fW(t, e) { for (var n = [], i = t.length, r = 0; r < i; r++) n.push({ one: t[r], many: [] }); for (r = 0; r < e.length; r++) { var o = e[r].length, a = void 0; for (a = 0; a < o; a++) n[a % i].many.push(e[r][a]); } var s = 0; for (r = i - 1; r >= 0; r--) if (!n[r].many.length) { var l = n[s].many; if (l.length <= 1) { if (!s) return n; s = 0; } o = l.length; var u = Math.ceil(o / 2); (n[r].many = l.slice(u, o)), (n[s].many = l.slice(0, u)), s++; } return n; } var gW = { clone: function (t) { for ( var e = [], n = 1 - Math.pow(1 - t.path.style.opacity, 1 / t.count), i = 0; i < t.count; i++ ) { var r = bu(t.path); r.setStyle("opacity", n), e.push(r); } return e; }, split: null, }; function yW(t, e, n, i, r, o) { if (t.length && e.length) { var a = gh("update", i, r); if (a && a.duration > 0) { var s, l, u = i.getModel("universalTransition").get("delay"), h = Object.assign({ setToFinal: !0 }, a); dW(t) && ((s = t), (l = e)), dW(e) && ((s = e), (l = t)); for ( var c = s ? s === t : t.length > e.length, p = s ? fW(l, s) : fW(c ? e : t, [c ? t : e]), d = 0, f = 0; f < p.length; f++ ) d += p[f].many.length; var g = 0; for (f = 0; f < p.length; f++) y(p[f], c, g, d), (g += p[f].many.length); } } function y(t, e, i, r, a) { var s = t.many, l = t.one; if (1 !== s.length || a) for ( var c = k( { dividePath: gW[n], individualDelay: u && function (t, e, n, o) { return u(t + i, r); }, }, h ), p = e ? (function (t, e, n) { var i = []; !(function t(e) { for (var n = 0; n < e.length; n++) { var r = e[n]; iW(r) ? t(r.childrenRef()) : r instanceof ks && i.push(r); } })(t); var r = i.length; if (!r) return { fromIndividuals: [], toIndividuals: [], count: 0, }; var o = (n.dividePath || pW)({ path: e, count: r, }); if (o.length !== r) return ( console.error( "Invalid morphing: unmatched splitted path" ), { fromIndividuals: [], toIndividuals: [], count: 0, } ); (i = cW(i)), (o = cW(o)); for ( var a = n.done, s = n.during, l = n.individualDelay, u = new vr(), h = 0; h < r; h++ ) { var c = i[h], p = o[h]; (p.parent = e), p.copyTransform(u), l || lW(c, p); } function d(t) { for (var e = 0; e < o.length; e++) o[e].addSelfToZr(t); } function f() { (e.__isCombineMorphing = !1), (e.__morphT = -1), (e.childrenRef = null), aW(e, "addSelfToZr"), aW(e, "removeSelfFromZr"); } (e.__isCombineMorphing = !0), (e.childrenRef = function () { return o; }), oW(e, "addSelfToZr", { after: function (t) { d(t); }, }), oW(e, "removeSelfFromZr", { after: function (t) { for (var e = 0; e < o.length; e++) o[e].removeSelfFromZr(t); }, }); var g = o.length; if (l) { var y = g, v = function () { 0 == --y && (f(), a && a()); }; for (h = 0; h < g; h++) { var m = l ? k( { delay: (n.delay || 0) + l(h, g, i[h], o[h]), done: v, }, n ) : n; uW(i[h], o[h], m); } } else (e.__morphT = 0), e.animateTo( { __morphT: 1 }, k( { during: function (t) { for ( var n = 0; n < g; n++ ) { var i = o[n]; (i.__morphT = e.__morphT), i.dirtyShape(); } s && s(t); }, done: function () { f(); for ( var e = 0; e < t.length; e++ ) aW( t[e], "updateTransform" ); a && a(); }, }, n ) ); return ( e.__zr && d(e.__zr), { fromIndividuals: i, toIndividuals: o, count: g, } ); })(s, l, c) : (function (t, e, n) { var i = e.length, r = [], o = n.dividePath || pW; if (iW(t)) { !(function t(e) { for (var n = 0; n < e.length; n++) { var i = e[n]; iW(i) ? t(i.childrenRef()) : i instanceof ks && r.push(i); } })(t.childrenRef()); var a = r.length; if (a < i) for (var s = 0, l = a; l < i; l++) r.push(bu(r[s++ % a])); r.length = i; } else { r = o({ path: t, count: i }); var u = t.getComputedTransform(); for (l = 0; l < r.length; l++) r[l].setLocalTransform(u); if (r.length !== i) return ( console.error( "Invalid morphing: unmatched splitted path" ), { fromIndividuals: [], toIndividuals: [], count: 0, } ); } (r = cW(r)), (e = cW(e)); var h = n.individualDelay; for (l = 0; l < i; l++) { var c = h ? k( { delay: (n.delay || 0) + h(l, i, r[l], e[l]), }, n ) : n; uW(r[l], e[l], c); } return { fromIndividuals: r, toIndividuals: e, count: e.length, }; })(l, s, c), d = p.fromIndividuals, f = p.toIndividuals, g = d.length, v = 0; v < g; v++ ) { m = u ? k({ delay: u(v, g) }, h) : h; o(d[v], f[v], e ? s[v] : t.one, e ? t.one : s[v], m); } else { var m, x = e ? s[0] : l, _ = e ? l : s[0]; if (iW(x)) y({ many: [x], one: _ }, !0, i, r, !0); else uW(x, _, (m = u ? k({ delay: u(i, r) }, h) : h)), o(x, _, x, _, m); } } } function vW(t) { if (!t) return []; if (Y(t)) { for (var e = [], n = 0; n < t.length; n++) e.push(vW(t[n])); return e; } var i = []; return ( t.traverse(function (t) { t instanceof ks && !t.disableMorphing && !t.invisible && !t.ignore && i.push(t); }), i ); } var mW = Vo(); function xW(t, e, n, i) { var r = (function (t, e) { for (var n = t.dimensions, i = 0; i < n.length; i++) { var r = t.getDimensionInfo(n[i]); if (r && 0 === r.otherDims[e]) return n[i]; } })(t, i ? "itemChildGroupId" : "itemGroupId"); if (r) { var o = (function (t, e, n) { var i = t.getDimensionInfo(n), r = i && i.ordinalMeta; if (i) { var o = t.get(i.name, e); return (r && r.categories[o]) || o + ""; } })(t, e, r); return o; } var a = t.getRawDataItem(e), s = i ? "childGroupId" : "groupId"; return a && a[s] ? a[s] + "" : i ? void 0 : n || t.getId(e); } function _W(t) { var e = []; return ( E(t, function (t) { var n = t.data, i = t.dataGroupId; if (!(n.count() > 1e4)) for (var r = n.getIndices(), o = 0; o < r.length; o++) e.push({ data: n, groupId: xW(n, o, i, !1), childGroupId: xW(n, o, i, !0), divide: t.divide, dataIndex: o, }); }), e ); } function bW(t, e, n) { t.traverse(function (t) { t instanceof ks && mh(t, { style: { opacity: 0 } }, e, { dataIndex: n, isFrom: !0, }); }); } function wW(t) { if (t.parent) { var e = t.getComputedTransform(); t.setLocalTransform(e), t.parent.remove(t); } } function SW(t) { t.stopAnimation(), t.isGroup && t.traverse(function (t) { t.stopAnimation(); }); } function MW(t, e, n) { var i = gh("update", n, e); i && t.traverse(function (t) { if (t instanceof Da) { var e = (function (t) { return fh(t).oldStyle; })(t); e && t.animateFrom({ style: e }, i); } }); } function IW(t, e, n) { var i = _W(t), r = _W(e); function o(t, e, n, i, r) { (n || t) && e.animateFrom( { style: n && n !== t ? A(A({}, n.style), t.style) : t.style, }, r ); } var a = !1, s = 0, l = yt(), u = yt(); i.forEach(function (t) { t.groupId && l.set(t.groupId, !0), t.childGroupId && u.set(t.childGroupId, !0); }); for (var h = 0; h < r.length; h++) { var c = r[h].groupId; if (u.get(c)) { s = 1; break; } var p = r[h].childGroupId; if (p && l.get(p)) { s = 2; break; } } function d(t, e) { return function (n) { var i = n.data, r = n.dataIndex; return e ? i.getId(r) : t ? 1 === s ? n.childGroupId : n.groupId : 2 === s ? n.childGroupId : n.groupId; }; } var f = (function (t, e) { var n = t.length; if (n !== e.length) return !1; for (var i = 0; i < n; i++) { var r = t[i], o = e[i]; if (r.data.getId(r.dataIndex) !== o.data.getId(o.dataIndex)) return !1; } return !0; })(i, r), g = {}; if (!f) for (h = 0; h < r.length; h++) { var y = r[h], v = y.data.getItemGraphicEl(y.dataIndex); v && (g[v.id] = !0); } function m(t, e) { var n = i[e], s = r[t], l = s.data.hostModel, u = n.data.getItemGraphicEl(n.dataIndex), h = s.data.getItemGraphicEl(s.dataIndex); u !== h ? (u && g[u.id]) || (h && (SW(h), u ? (SW(u), wW(u), (a = !0), yW(vW(u), vW(h), s.divide, l, t, o)) : bW(h, l, t))) : h && MW(h, s.dataIndex, l); } new Gm(i, r, d(!0, f), d(!1, f), null, "multiple") .update(m) .updateManyToOne(function (t, e) { var n = r[t], s = n.data, l = s.hostModel, u = s.getItemGraphicEl(n.dataIndex), h = B( z(e, function (t) { return i[t].data.getItemGraphicEl(i[t].dataIndex); }), function (t) { return t && t !== u && !g[t.id]; } ); u && (SW(u), h.length ? (E(h, function (t) { SW(t), wW(t); }), (a = !0), yW(vW(h), vW(u), n.divide, l, t, o)) : bW(u, l, n.dataIndex)); }) .updateOneToMany(function (t, e) { var n = i[e], s = n.data.getItemGraphicEl(n.dataIndex); if (!s || !g[s.id]) { var l = B( z(t, function (t) { return r[t].data.getItemGraphicEl( r[t].dataIndex ); }), function (t) { return t && t !== s; } ), u = r[t[0]].data.hostModel; l.length && (E(l, function (t) { return SW(t); }), s ? (SW(s), wW(s), (a = !0), yW(vW(s), vW(l), n.divide, u, t[0], o)) : E(l, function (e) { return bW(e, u, t[0]); })); } }) .updateManyToMany(function (t, e) { new Gm( e, t, function (t) { return i[t].data.getId(i[t].dataIndex); }, function (t) { return r[t].data.getId(r[t].dataIndex); } ) .update(function (n, i) { m(t[n], e[i]); }) .execute(); }) .execute(), a && E(e, function (t) { var e = t.data.hostModel, i = e && n.getViewOfSeriesModel(e), r = gh("update", e, 0); i && e.isAnimationEnabled() && r && r.duration > 0 && i.group.traverse(function (t) { t instanceof ks && !t.animators.length && t.animateFrom({ style: { opacity: 0 } }, r); }); }); } function TW(t) { var e = t.getModel("universalTransition").get("seriesKey"); return e || t.id; } function CW(t) { return Y(t) ? t.sort().join(",") : t; } function DW(t) { if (t.hostModel) return t.hostModel .getModel("universalTransition") .get("divideShape"); } function AW(t, e) { for (var n = 0; n < t.length; n++) { if ( (null != e.seriesIndex && e.seriesIndex === t[n].seriesIndex) || (null != e.seriesId && e.seriesId === t[n].id) ) return n; } } Vm([ function (t) { t.registerPainter("canvas", hS); }, ]), Vm([ function (t) { t.registerPainter("svg", iS); }, ]), Vm([ function (t) { t.registerChartView(YS), t.registerSeriesModel(cS), t.registerLayout(XS("line", !0)), t.registerVisual({ seriesType: "line", reset: function (t) { var e = t.getData(), n = t.getModel("lineStyle").getLineStyle(); n && !n.stroke && (n.stroke = e.getVisual("style").fill), e.setVisual("legendLineStyle", n); }, }), t.registerProcessor( t.PRIORITY.PROCESSOR.STATISTIC, jS("line") ); }, function (t) { t.registerChartView(rM), t.registerSeriesModel(KS), t.registerLayout(t.PRIORITY.VISUAL.LAYOUT, H(Ux, "bar")), t.registerLayout( t.PRIORITY.VISUAL.PROGRESSIVE_LAYOUT, Zx("bar") ), t.registerProcessor( t.PRIORITY.PROCESSOR.STATISTIC, jS("bar") ), t.registerAction( { type: "changeAxisOrder", event: "changeAxisOrder", update: "update", }, function (t, e) { var n = t.componentType || "series"; e.eachComponent( { mainType: n, query: t }, function (e) { t.sortInfo && e.axis.setCategorySortInfo(t.sortInfo); } ); } ); }, function (t) { t.registerChartView(OM), t.registerSeriesModel(zM), Ly("pie", t.registerAction), t.registerLayout(H(MM, "pie")), t.registerProcessor(TM("pie")), t.registerProcessor( (function (t) { return { seriesType: t, reset: function (t, e) { var n = t.getData(); n.filterSelf(function (t) { var e = n.mapDimension("value"), i = n.get(e, t); return !(j(i) && !isNaN(i) && i < 0); }); }, }; })("pie") ); }, function (t) { Vm(VI), t.registerSeriesModel(VM), t.registerChartView(WM), t.registerLayout(XS("scatter")); }, function (t) { Vm(JI), t.registerChartView(HI), t.registerSeriesModel(YI), t.registerLayout(BI), t.registerProcessor(TM("radar")), t.registerPreprocessor(WI); }, function (t) { Vm(CC), t.registerChartView(lC), t.registerSeriesModel(uC), t.registerLayout(cC), t.registerProcessor(t.PRIORITY.PROCESSOR.STATISTIC, hC), Ly("map", t.registerAction); }, function (t) { t.registerChartView(BC), t.registerSeriesModel(sD), t.registerLayout(uD), t.registerVisual(hD), (function (t) { t.registerAction( { type: "treeExpandAndCollapse", event: "treeExpandAndCollapse", update: "update", }, function (t, e) { e.eachComponent( { mainType: "series", subType: "tree", query: t, }, function (e) { var n = t.dataIndex, i = e .getData() .tree.getNodeByDataIndex(n); i.isExpand = !i.isExpand; } ); } ), t.registerAction( { type: "treeRoam", event: "treeRoam", update: "none", }, function (t, e, n) { e.eachComponent( { mainType: "series", subType: "tree", query: t, }, function (e) { var i = MC( e.coordinateSystem, t, void 0, n ); e.setCenter && e.setCenter(i.center), e.setZoom && e.setZoom(i.zoom); } ); } ); })(t); }, function (t) { t.registerSeriesModel(dD), t.registerChartView(TD), t.registerVisual(HD), t.registerLayout(nA), (function (t) { for (var e = 0; e < cD.length; e++) t.registerAction( { type: cD[e], update: "updateView" }, bt ); t.registerAction( { type: "treemapRootToNode", update: "updateView" }, function (t, e) { e.eachComponent( { mainType: "series", subType: "treemap", query: t, }, function (e, n) { var i = iD( t, [ "treemapZoomToNode", "treemapRootToNode", ], e ); if (i) { var r = e.getViewRoot(); r && (t.direction = oD(r, i.node) ? "rollUp" : "drillDown"), e.resetViewRoot(i.node); } } ); } ); })(t); }, function (t) { t.registerChartView(ik), t.registerSeriesModel(hk), t.registerProcessor(lA), t.registerVisual(uA), t.registerVisual(cA), t.registerLayout(bA), t.registerLayout(t.PRIORITY.VISUAL.POST_CHART_LAYOUT, AA), t.registerLayout(LA), t.registerCoordinateSystem("graphView", { dimensions: dC.dimensions, create: PA, }), t.registerAction( { type: "focusNodeAdjacency", event: "focusNodeAdjacency", update: "series:focusNodeAdjacency", }, bt ), t.registerAction( { type: "unfocusNodeAdjacency", event: "unfocusNodeAdjacency", update: "series:unfocusNodeAdjacency", }, bt ), t.registerAction(ck, function (t, e, n) { e.eachComponent( { mainType: "series", query: t }, function (e) { var i = MC(e.coordinateSystem, t, void 0, n); e.setCenter && e.setCenter(i.center), e.setZoom && e.setZoom(i.zoom); } ); }); }, function (t) { t.registerChartView(gk), t.registerSeriesModel(yk); }, function (t) { t.registerChartView(xk), t.registerSeriesModel(_k), t.registerLayout(bk), t.registerProcessor(TM("funnel")); }, function (t) { Vm(ZL), t.registerChartView(wk), t.registerSeriesModel(Ck), t.registerVisual(t.PRIORITY.VISUAL.BRUSH, kk); }, function (t) { t.registerChartView(KL), t.registerSeriesModel(JL), t.registerLayout(QL), t.registerVisual(cP), t.registerAction( { type: "dragNode", event: "dragnode", update: "update", }, function (t, e) { e.eachComponent( { mainType: "series", subType: "sankey", query: t, }, function (e) { e.setNodePosition(t.dataIndex, [ t.localX, t.localY, ]); } ); } ); }, function (t) { t.registerSeriesModel(dP), t.registerChartView(fP), t.registerLayout(bP), t.registerTransform(wP); }, function (t) { t.registerChartView(PP), t.registerSeriesModel(HP), t.registerPreprocessor(YP), t.registerVisual(kP), t.registerLayout(XP); }, function (t) { t.registerChartView(qP), t.registerSeriesModel(KP), t.registerLayout(XS("effectScatter")); }, function (t) { t.registerChartView(rO), t.registerSeriesModel(lO), t.registerLayout(iO), t.registerVisual(hO); }, function (t) { t.registerChartView(dO), t.registerSeriesModel(fO); }, function (t) { t.registerChartView(mO), t.registerSeriesModel(EO), t.registerLayout( t.PRIORITY.VISUAL.LAYOUT, H(Ux, "pictorialBar") ), t.registerLayout( t.PRIORITY.VISUAL.PROGRESSIVE_LAYOUT, Zx("pictorialBar") ); }, function (t) { t.registerChartView(zO), t.registerSeriesModel(VO), t.registerLayout(BO), t.registerProcessor(TM("themeRiver")); }, function (t) { t.registerChartView(YO), t.registerSeriesModel(XO), t.registerLayout(H(jO, "sunburst")), t.registerProcessor(H(TM, "sunburst")), t.registerVisual(KO), (function (t) { t.registerAction( { type: WO, update: "updateView" }, function (t, e) { e.eachComponent( { mainType: "series", subType: "sunburst", query: t, }, function (e, n) { var i = iD(t, [WO], e); if (i) { var r = e.getViewRoot(); r && (t.direction = oD(r, i.node) ? "rollUp" : "drillDown"), e.resetViewRoot(i.node); } } ); } ), t.registerAction( { type: HO, update: "none" }, function (t, e, n) { (t = A({}, t)), e.eachComponent( { mainType: "series", subType: "sunburst", query: t, }, function (e) { var n = iD(t, [HO], e); n && (t.dataIndex = n.node.dataIndex); } ), n.dispatchAction( A(t, { type: "highlight" }) ); } ), t.registerAction( { type: "sunburstUnhighlight", update: "updateView", }, function (t, e, n) { (t = A({}, t)), n.dispatchAction( A(t, { type: "downplay" }) ); } ); })(t); }, function (t) { t.registerChartView(GR), t.registerSeriesModel(tR); }, ]), Vm(function (t) { Vm(VI), Vm(WN); }), Vm(function (t) { Vm(WN), TI.registerAxisPointerClass("PolarAxisPointer", HN), t.registerCoordinateSystem("polar", iE), t.registerComponentModel(XN), t.registerComponentView(xE), KM(t, "angle", ZN, vE), KM(t, "radius", jN, mE), t.registerComponentView(lE), t.registerComponentView(pE), t.registerLayout(H(yE, "bar")); }), Vm(CC), Vm(function (t) { Vm(WN), TI.registerAxisPointerClass("SingleAxisPointer", OE), t.registerComponentView(zE), t.registerComponentView(SE), t.registerComponentModel(IE), KM(t, "single", IE, IE.defaultOption), t.registerCoordinateSystem("single", kE); }), Vm(ZL), Vm(function (t) { t.registerComponentModel(VE), t.registerComponentView(FE), t.registerCoordinateSystem("calendar", WE); }), Vm(function (t) { t.registerComponentModel(jE), t.registerComponentView($E), t.registerPreprocessor(function (t) { var e = t.graphic; Y(e) ? e[0] && e[0].elements ? (t.graphic = [t.graphic[0]]) : (t.graphic = [{ elements: e }]) : e && !e.elements && (t.graphic = [{ elements: [e] }]); }); }), Vm(function (t) { t.registerComponentModel(Mz), t.registerComponentView(Tz), wz("saveAsImage", Cz), wz("magicType", kz), wz("dataView", zz), wz("dataZoom", oV), wz("restore", Wz), Vm(xz); }), Vm(function (t) { Vm(WN), t.registerComponentModel(lV), t.registerComponentView(IV), t.registerAction( { type: "showTip", event: "showTip", update: "tooltip:manuallyShowTip", }, bt ), t.registerAction( { type: "hideTip", event: "hideTip", update: "tooltip:manuallyHideTip", }, bt ); }), Vm(WN), Vm(function (t) { t.registerComponentView(ZV), t.registerComponentModel(jV), t.registerPreprocessor(kV), t.registerVisual(t.PRIORITY.VISUAL.BRUSH, WV), t.registerAction( { type: "brush", event: "brush", update: "updateVisual" }, function (t, e) { e.eachComponent( { mainType: "brush", query: t }, function (e) { e.setAreas(t.areas); } ); } ), t.registerAction( { type: "brushSelect", event: "brushSelected", update: "none", }, bt ), t.registerAction( { type: "brushEnd", event: "brushEnd", update: "none" }, bt ), wz("brush", $V); }), Vm(function (t) { t.registerComponentModel(JV), t.registerComponentView(QV); }), Vm(function (t) { t.registerComponentModel(eB), t.registerComponentView(aB), t.registerSubTypeDefaulter("timeline", function () { return "slider"; }), (function (t) { t.registerAction( { type: "timelineChange", event: "timelineChanged", update: "prepareAndUpdate", }, function (t, e, n) { var i = e.getComponent("timeline"); return ( i && null != t.currentIndex && (i.setCurrentIndex(t.currentIndex), !i.get("loop", !0) && i.isIndexMax() && i.getPlayState() && (i.setPlayState(!1), n.dispatchAction({ type: "timelinePlayChange", playState: !1, from: t.from, }))), e.resetOption("timeline", { replaceMerge: i.get("replaceMerge", !0), }), k({ currentIndex: i.option.currentIndex }, t) ); } ), t.registerAction( { type: "timelinePlayChange", event: "timelinePlayChanged", update: "update", }, function (t, e) { var n = e.getComponent("timeline"); n && null != t.playState && n.setPlayState(t.playState); } ); })(t), t.registerPreprocessor(uB); }), Vm(function (t) { t.registerComponentModel(yB), t.registerComponentView(DB), t.registerPreprocessor(function (t) { pB(t.series, "markPoint") && (t.markPoint = t.markPoint || {}); }); }), Vm(function (t) { t.registerComponentModel(AB), t.registerComponentView(EB), t.registerPreprocessor(function (t) { pB(t.series, "markLine") && (t.markLine = t.markLine || {}); }); }), Vm(function (t) { t.registerComponentModel(zB), t.registerComponentView(XB), t.registerPreprocessor(function (t) { pB(t.series, "markArea") && (t.markArea = t.markArea || {}); }); }), Vm(function (t) { Vm(rF), Vm(cF); }), Vm(function (t) { Vm(SF), Vm(PF); }), Vm(SF), Vm(PF), Vm(function (t) { Vm(pG), Vm(vG); }), Vm(pG), Vm(vG), Vm(function (t) { t.registerPreprocessor(wG), t.registerVisual(t.PRIORITY.VISUAL.ARIA, bG); }), Vm(function (t) { t.registerTransform(RG), t.registerTransform(NG); }), Vm(function (t) { t.registerComponentModel(EG), t.registerComponentView(zG); }), Vm(function (t) { t.registerUpdateLifecycle( "series:beforeupdate", function (t, e, n) { E(To(n.seriesTransition), function (t) { E(To(t.to), function (t) { for ( var e = n.updatedSeries, i = 0; i < e.length; i++ ) ((null != t.seriesIndex && t.seriesIndex === e[i].seriesIndex) || (null != t.seriesId && t.seriesId === e[i].id)) && (e[i][_g] = !0); }); }); } ), t.registerUpdateLifecycle( "series:transition", function (t, e, n) { var i = mW(e); if (i.oldSeries && n.updatedSeries && n.optionChanged) { var r = n.seriesTransition; if (r) E(To(r), function (t) { !(function (t, e, n, i) { var r = [], o = []; E(To(t.from), function (t) { var n = AW(e.oldSeries, t); n >= 0 && r.push({ dataGroupId: e.oldDataGroupIds[n], data: e.oldData[n], divide: DW(e.oldData[n]), groupIdDim: t.dimension, }); }), E(To(t.to), function (t) { var i = AW(n.updatedSeries, t); if (i >= 0) { var r = n.updatedSeries[ i ].getData(); o.push({ dataGroupId: e.oldDataGroupIds[ i ], data: r, divide: DW(r), groupIdDim: t.dimension, }); } }), r.length > 0 && o.length > 0 && IW(r, o, i); })(t, i, n, e); }); else { var o = (function (t, e) { var n = yt(), i = yt(), r = yt(); return ( E(t.oldSeries, function (e, n) { var o = t.oldDataGroupIds[n], a = t.oldData[n], s = TW(e), l = CW(s); i.set(l, { dataGroupId: o, data: a, }), Y(s) && E(s, function (t) { r.set(t, { key: l, dataGroupId: o, data: a, }); }); }), E(e.updatedSeries, function (t) { if ( t.isUniversalTransitionEnabled() && t.isAnimationEnabled() ) { var e = t.get("dataGroupId"), o = t.getData(), a = TW(t), s = CW(a), l = i.get(s); if (l) n.set(s, { oldSeries: [ { dataGroupId: l.dataGroupId, divide: DW( l.data ), data: l.data, }, ], newSeries: [ { dataGroupId: e, divide: DW(o), data: o, }, ], }); else if (Y(a)) { var u = []; E(a, function (t) { var e = i.get(t); e.data && u.push({ dataGroupId: e.dataGroupId, divide: DW( e.data ), data: e.data, }); }), u.length && n.set(s, { oldSeries: u, newSeries: [ { dataGroupId: e, data: o, divide: DW( o ), }, ], }); } else { var h = r.get(a); if (h) { var c = n.get(h.key); c || ((c = { oldSeries: [ { dataGroupId: h.dataGroupId, data: h.data, divide: DW( h.data ), }, ], newSeries: [], }), n.set(h.key, c)), c.newSeries.push({ dataGroupId: e, data: o, divide: DW(o), }); } } } }), n ); })(i, n); E(o.keys(), function (t) { var n = o.get(t); IW(n.oldSeries, n.newSeries, e); }); } E(n.updatedSeries, function (t) { t[_g] && (t[_g] = !1); }); } for ( var a = t.getSeries(), s = (i.oldSeries = []), l = (i.oldDataGroupIds = []), u = (i.oldData = []), h = 0; h < a.length; h++ ) { var c = a[h].getData(); c.count() < 1e4 && (s.push(a[h]), l.push(a[h].get("dataGroupId")), u.push(c)); } } ); }), Vm(function (t) { t.registerUpdateLifecycle( "series:beforeupdate", function (t, e, n) { var i = Xb(e).labelManager; i || (i = Xb(e).labelManager = new Yb()), i.clearLabels(); } ), t.registerUpdateLifecycle( "series:layoutlabels", function (t, e, n) { var i = Xb(e).labelManager; n.updatedSeries.forEach(function (t) { i.addLabelsOfSeries(e.getViewOfSeriesModel(t)); }), i.updateLayoutConfig(e), i.layout(e), i.processLabelsOverall(); } ); }), (t.Axis = ab), (t.ChartView = Og), (t.ComponentModel = zp), (t.ComponentView = Ag), (t.List = cx), (t.Model = Cc), (t.PRIORITY = Cv), (t.SeriesModel = bg), (t.color = li), (t.connect = function (t) { if (Y(t)) { var e = t; (t = null), E(e, function (e) { null != e.group && (t = e.group); }), (t = t || "g_" + ym++), E(e, function (e) { e.group = t; }); } return (fm[t] = !0), t; }), (t.dataTool = {}), (t.dependencies = { zrender: "5.6.1" }), (t.disConnect = xm), (t.disconnect = mm), (t.dispose = function (t) { U(t) ? (t = dm[t]) : t instanceof nm || (t = _m(t)), t instanceof nm && !t.isDisposed() && t.dispose(); }), (t.env = r), (t.extendChartView = function (t) { var e = Og.extend(t); return Og.registerClass(e), e; }), (t.extendComponentModel = function (t) { var e = zp.extend(t); return zp.registerClass(e), e; }), (t.extendComponentView = function (t) { var e = Ag.extend(t); return Ag.registerClass(e), e; }), (t.extendSeriesModel = function (t) { var e = bg.extend(t); return bg.registerClass(e), e; }), (t.format = Z_), (t.getCoordinateSystemDimensions = function (t) { var e = wd.get(t); if (e) return e.getDimensionsInfo ? e.getDimensionsInfo() : e.dimensions.slice(); }), (t.getInstanceByDom = _m), (t.getInstanceById = function (t) { return dm[t]; }), (t.getMap = function (t) { var e = Mv("getMap"); return e && e(t); }), (t.graphic = U_), (t.helper = k_), (t.init = function (t, e, n) { var i = !(n && n.ssr); if (i) { 0; var r = _m(t); if (r) return r; 0; } var o = new nm(t, e, n); return ( (o.id = "ec_" + gm++), (dm[o.id] = o), i && Xo(t, vm, o.id), $v(o), wv.trigger("afterinit", o), o ); }), (t.innerDrawElementOnCanvas = dv), (t.matrix = Ce), (t.number = Y_), (t.parseGeoJSON = H_), (t.parseGeoJson = H_), (t.registerAction = Cm), (t.registerCoordinateSystem = Dm), (t.registerLayout = Am), (t.registerLoading = Om), (t.registerLocale = zc), (t.registerMap = Rm), (t.registerPostInit = Mm), (t.registerPostUpdate = Im), (t.registerPreprocessor = wm), (t.registerProcessor = Sm), (t.registerTheme = bm), (t.registerTransform = Nm), (t.registerUpdateLifecycle = Tm), (t.registerVisual = km), (t.setCanvasCreator = function (t) { c({ createCanvas: t }); }), (t.setPlatformAPI = c), (t.throttle = Wg), (t.time = X_), (t.use = Vm), (t.util = j_), (t.vector = Xt), (t.version = "5.6.0"), (t.zrUtil = St), (t.zrender = jr), Object.defineProperty(t, "__esModule", { value: !0 }); });