/* * 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]) } )(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 : "undefined" == typeof navigator ? (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 sans-serif"; 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 = /^([0-9]*?)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; r < i.length; r++) { var o = i[r]; (n ? null != e[o] : null == t[o]) && (t[o] = e[o]) } 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 && U(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 U(t) { return "function" == typeof t } function X(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(e) { this.data = {}; var n = Y(e); this.data = {}; 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.get = function (t) { return this.data.hasOwnProperty(t) ? this.data[t] : null } , t.prototype.set = function (t, e) { return this.data[t] = e } , t.prototype.each = function (t, e) { for (var n in this.data) this.data.hasOwnProperty(n) && t.call(e, this.data[n], n) } , t.prototype.keys = function () { return G(this.data) } , t.prototype.removeKey = function (t) { delete this.data[t] } , t }(); function ft(t) { return new dt(t) } function gt(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 yt(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 vt(t) { var e = t.style; e.webkitUserSelect = "none", e.userSelect = "none", e.webkitTapHighlightColor = "rgba(0,0,0,0)", e["-webkit-touch-callout"] = "none" } function mt(t, e) { return t.hasOwnProperty(e) } function xt() { } var _t = 180 / Math.PI , bt = 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: U, isString: X, 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: dt, createHashMap: ft, concatArray: gt, createObject: yt, disableUserSelect: vt, hasOwn: mt, noop: xt, RADIAN_TO_DEGREE: _t }); function wt(t, e) { return null == t && (t = 0), null == e && (e = 0), [t, e] } function St(t, e) { return t[0] = e[0], t[1] = e[1], t } function Mt(t) { return [t[0], t[1]] } function It(t, e, n) { return t[0] = e, t[1] = n, t } function Tt(t, e, n) { return t[0] = e[0] + n[0], t[1] = e[1] + n[1], t } function Ct(t, e, n, i) { return t[0] = e[0] + n[0] * i, t[1] = e[1] + n[1] * i, t } function Dt(t, e, n) { return t[0] = e[0] - n[0], t[1] = e[1] - n[1], t } function At(t) { return Math.sqrt(Lt(t)) } var kt = At; function Lt(t) { return t[0] * t[0] + t[1] * t[1] } var Pt = Lt; function Ot(t, e, n) { return t[0] = e[0] * n, t[1] = e[1] * n, t } function Rt(t, e) { var n = At(e); return 0 === n ? (t[0] = 0, t[1] = 0) : (t[0] = e[0] / n, t[1] = e[1] / n), t } function Nt(t, e) { return Math.sqrt((t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1])) } var Et = Nt; function zt(t, e) { return (t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1]) } var Vt = zt; function Bt(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 Ft(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 Gt(t, e, n) { return t[0] = Math.min(e[0], n[0]), t[1] = Math.min(e[1], n[1]), t } function Wt(t, e, n) { return t[0] = Math.max(e[0], n[0]), t[1] = Math.max(e[1], n[1]), t } var Ht = Object.freeze({ __proto__: null, create: wt, copy: St, clone: Mt, set: It, add: Tt, scaleAndAdd: Ct, sub: Dt, len: At, length: kt, lenSquare: Lt, lengthSquare: Pt, 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: Ot, normalize: Rt, distance: Nt, dist: Et, distanceSquare: zt, distSquare: Vt, negate: function (t, e) { return t[0] = -e[0], t[1] = -e[1], t }, lerp: Bt, applyTransform: Ft, min: Gt, max: Wt }) , Yt = function (t, e) { this.target = t, this.topTarget = e && e.topTarget } , Ut = 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 Yt(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 Yt(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 Yt(s, t), "dragleave", t.event), a && a !== s && this.handler.dispatchToElement(new Yt(a, t), "dragenter", t.event)) } } , t.prototype._dragEnd = function (t) { var e = this._draggingTarget; e && (e.dragging = !1), this.handler.dispatchToElement(new Yt(e, t), "dragend", t.event), this._dropTarget && this.handler.dispatchToElement(new Yt(this._dropTarget, t), "drop", t.event), this._draggingTarget = null, this._dropTarget = null } , t }() , Xt = 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 }() , Zt = Math.log(2); function jt(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) / Zt); 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] * jt(t, e - 1, h, u, r | f, o), d++) } return o[a] = c, c } function qt(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 = jt(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) * jt(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 Kt = []; function $t(t, e, n, i, o) { if (e.getBoundingClientRect && r.domSupported && !Jt(e)) { var a = e.___zrEVENTSAVED || (e.___zrEVENTSAVED = {}) , s = 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 ? qt(s, a) : qt(a, 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), a, o); if (s) return s(t, n, i), !0 } return !1 } function Jt(t) { return "CANVAS" === t.nodeName.toUpperCase() } var Qt = /^(?:mouse|pointer|contextmenu|drag|drop)|click/ , te = [] , ee = r.browser.firefox && +r.browser.version.split(".")[0] < 39; function ne(t, e, n, i) { return n = n || {}, i ? ie(t, e, n) : ee && 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) : ie(t, e, n), n } function ie(t, e, n) { if (r.domSupported && t.getBoundingClientRect) { var i = e.clientX , o = e.clientY; if (Jt(t)) { var a = t.getBoundingClientRect(); return n.zrX = i - a.left, void (n.zrY = o - a.top) } if ($t(te, t, i, o)) return n.zrX = te[0], void (n.zrY = te[1]) } n.zrX = n.zrY = 0 } function re(t) { return t || window.event } function oe(t, e, n) { if (null != (e = re(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 && ne(t, r, e, n) } else { ne(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 && Qt.test(e.type) && (e.which = 1 & a ? 1 : 2 & a ? 3 : 4 & a ? 2 : 0), e } function ae(t, e, n, i) { t.addEventListener(e, n, i) } var se = function (t) { t.preventDefault(), t.stopPropagation(), t.cancelBubble = !0 }; function le(t) { return 2 === t.which || 3 === t.which } var ue = 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 = ne(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 ce) if (ce.hasOwnProperty(e)) { var n = ce[e](this._track, t); if (n) return n } } , t }(); function he(t) { var e = t[1][0] - t[0][0] , n = t[1][1] - t[0][1]; return Math.sqrt(e * e + n * n) } var ce = { 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 = he(r) / he(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 } } } } } , pe = "silent"; function de() { se(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 }(Xt) , ge = function (t, e) { this.x = t, this.y = e } , ye = ["click", "dblclick", "mousewheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu"] , ve = function (t) { function e(e, n, i, r) { var o = t.call(this) || this; return o._hovered = new ge(0, 0), o.storage = e, o.painter = n, o.painterRoot = r, i = i || new fe, o.proxy = null, o.setHandlerProxy(i), o._draggingMgr = new Ut(o), o } return n(e, t), e.prototype.setHandlerProxy = function (t) { this.proxy && this.proxy.dispose(), t && (E(ye, (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 = xe(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: de } }(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) { for (var i = this.storage.getDisplayList(), r = new ge(t, e), o = i.length - 1; o >= 0; o--) { var a = void 0; if (i[o] !== n && !i[o].ignore && (a = me(i[o], t, e)) && (!r.topTarget && (r.topTarget = i[o]), a !== pe)) { r.target = i[o]; break } } return r } , e.prototype.processGesture = function (t, e) { this._gestureMgr || (this._gestureMgr = new ue); 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 }(Xt); function me(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 || pe } return !1 } function xe(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) { ve.prototype[t] = function (e) { var n, i, r = e.zrX, o = e.zrY, a = xe(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 || Et(this._downPoint, [e.zrX, e.zrY]) > 4) return; this._downPoint = null } this.dispatchToElement(n, t, e) } } )); function _e(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 be(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 we(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 Se(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 Me(t, e) { var n, i, r = 7, o = 0; t.length; var 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 = Se(t[h], t, l, u, 0, e); l += p, 0 !== (u -= p) && 0 !== (c = we(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 = Se(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 = we(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 - Se(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 - we(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 Ie(t, e, n, i) { n || (n = 0), i || (i = t.length); var r = i - n; if (!(r < 2)) { var o = 0; if (r < 32) be(t, n, i, n + (o = _e(t, n, i, e)), e); else { var a = Me(t, e) , s = function (t) { for (var e = 0; t >= 32;) e |= 1 & t, t >>= 1; return t + e }(r); do { if ((o = _e(t, n, i, e)) < s) { var l = r; l > s && (l = s), be(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 Te = !1; function Ce() { Te || (Te = !0, console.warn("z / z2 / zlevel of displayable is invalid, which may cause unexpected errors")) } function De(t, e) { return t.zlevel === e.zlevel ? t.z === e.z ? t.z2 - e.z2 : t.z - e.z : t.zlevel - e.zlevel } var Ae = function () { function t() { this._roots = [], this._displayList = [], this._displayListLen = 0, this.displayableSortFunc = De } 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, Ie(n, De) } , 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) && (Ce(), u.z = 0), isNaN(u.z2) && (Ce(), u.z2 = 0), isNaN(u.zlevel) && (Ce(), 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 }() , ke = r.hasGlobalWindow && (window.requestAnimationFrame && window.requestAnimationFrame.bind(window) || window.msRequestAnimationFrame && window.msRequestAnimationFrame.bind(window) || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame) || function (t) { return setTimeout(t, 16) } , Le = { 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 ? .5 * t * t : -.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 ? .5 * t * t * t : .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 ? .5 * t * t * t * t : -.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 ? .5 * t * t * t * t * t : .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 .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 ? .5 * Math.pow(1024, t - 1) : .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 ? -.5 * (Math.sqrt(1 - t * t) - 1) : .5 * (Math.sqrt(1 - (t -= 2) * t) + 1) }, elasticIn: function (t) { var e, n = .1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? (n = 1, e = .1) : e = .4 * Math.asin(1 / n) / (2 * Math.PI), -n * Math.pow(2, 10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / .4)) }, elasticOut: function (t) { var e, n = .1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? (n = 1, e = .1) : e = .4 * Math.asin(1 / n) / (2 * Math.PI), n * Math.pow(2, -10 * t) * Math.sin((t - e) * (2 * Math.PI) / .4) + 1) }, elasticInOut: function (t) { var e, n = .1, i = .4; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? (n = 1, e = .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) * -.5 : n * Math.pow(2, -10 * (t -= 1)) * Math.sin((t - e) * (2 * Math.PI) / i) * .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) * .5 : .5 * ((t -= 2) * t * ((e + 1) * t + e) + 2) }, bounceIn: function (t) { return 1 - Le.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 + .75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + .9375 : 7.5625 * (t -= 2.625 / 2.75) * t + .984375 }, bounceInOut: function (t) { return t < .5 ? .5 * Le.bounceIn(2 * t) : .5 * Le.bounceOut(2 * t - 1) + .5 } } , Pe = Math.pow , Oe = Math.sqrt , Re = 1e-8 , Ne = 1e-4 , Ee = Oe(3) , ze = 1 / 3 , Ve = wt() , Be = wt() , Fe = wt(); function Ge(t) { return t > -1e-8 && t < Re } function We(t) { return t > Re || t < -1e-8 } function He(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 Ye(t, e, n, i, r) { var o = 1 - r; return 3 * (((e - t) * o + 2 * (n - e) * r) * o + (i - n) * r * r) } function Ue(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 (Ge(h) && Ge(c)) { if (Ge(s)) o[0] = 0; else (M = -l / s) >= 0 && M <= 1 && (o[d++] = M) } else { var f = c * c - 4 * h * p; if (Ge(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 = Oe(f) , m = h * s + 1.5 * a * (-c + v) , x = h * s + 1.5 * a * (-c - v); (M = (-s - ((m = m < 0 ? -Pe(-m, ze) : Pe(m, ze)) + (x = x < 0 ? -Pe(-x, ze) : Pe(x, ze)))) / (3 * a)) >= 0 && M <= 1 && (o[d++] = M) } else { var _ = (2 * h * s - 3 * a * c) / (2 * Oe(h * h * h)) , b = Math.acos(_) / 3 , w = Oe(h) , S = Math.cos(b) , M = (-s - 2 * w * S) / (3 * a) , I = (y = (-s + w * (S + Ee * Math.sin(b))) / (3 * a), (-s + w * (S - Ee * 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 Xe(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 (Ge(a)) { if (We(o)) (h = -s / o) >= 0 && h <= 1 && (r[l++] = h) } else { var u = o * o - 4 * a * s; if (Ge(u)) r[0] = -o / (2 * a); else if (u > 0) { var h, c = Oe(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 Ze(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 je(t, e, n, i, r, o, a, s, l, u, h) { var c, p, d, f, g, y = .005, v = 1 / 0; Ve[0] = l, Ve[1] = u; for (var m = 0; m < 1; m += .05) Be[0] = He(t, n, r, a, m), Be[1] = He(e, i, o, s, m), (f = Vt(Ve, Be)) < v && (c = m, v = f); v = 1 / 0; for (var x = 0; x < 32 && !(y < Ne); x++) p = c - y, d = c + y, Be[0] = He(t, n, r, a, p), Be[1] = He(e, i, o, s, p), f = Vt(Be, Ve), p >= 0 && f < v ? (c = p, v = f) : (Fe[0] = He(t, n, r, a, d), Fe[1] = He(e, i, o, s, d), g = Vt(Fe, Ve), d <= 1 && g < v ? (c = d, v = g) : y *= .5); return h && (h[0] = He(t, n, r, a, c), h[1] = He(e, i, o, s, c)), Oe(v) } function qe(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 = He(t, n, r, a, f) , y = He(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 Ke(t, e, n, i) { var r = 1 - i; return r * (r * t + 2 * i * e) + i * i * n } function $e(t, e, n, i) { return 2 * ((1 - i) * (e - t) + i * (n - e)) } function Je(t, e, n) { var i = t + n - 2 * e; return 0 === i ? .5 : (t - e) / i } function Qe(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 tn(t, e, n, i, r, o, a, s, l) { var u, h = .005, c = 1 / 0; Ve[0] = a, Ve[1] = s; for (var p = 0; p < 1; p += .05) { Be[0] = Ke(t, n, r, p), Be[1] = Ke(e, i, o, p), (y = Vt(Ve, Be)) < c && (u = p, c = y) } c = 1 / 0; for (var d = 0; d < 32 && !(h < Ne); d++) { var f = u - h , g = u + h; Be[0] = Ke(t, n, r, f), Be[1] = Ke(e, i, o, f); var y = Vt(Be, Ve); if (f >= 0 && y < c) u = f, c = y; else { Fe[0] = Ke(t, n, r, g), Fe[1] = Ke(e, i, o, g); var v = Vt(Fe, Ve); g <= 1 && v < c ? (u = g, c = v) : h *= .5 } } return l && (l[0] = Ke(t, n, r, u), l[1] = Ke(e, i, o, u)), Oe(c) } function en(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 = Ke(t, n, r, p) , f = Ke(e, i, o, p) , g = d - s , y = f - l; u += Math.sqrt(g * g + y * y), s = d, l = f } return u } var nn = /cubic-bezier\(([0-9,\.e ]+)\)/; function rn(t) { var e = t && nn.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 : Ue(0, i, o, 1, t, s) && He(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 || xt, this.ondestroy = t.ondestroy || xt, this.onrestart = t.onrestart || xt, 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 = U(t) ? t : Le[t] || rn(t) } , t }() , an = function (t) { this.value = t } , sn = function () { function t() { this._len = 0 } return t.prototype.insert = function (t) { var e = new an(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 }() , ln = function () { function t(t) { this._list = new sn, 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 an(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 }() , un = { 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 hn(t) { return (t = Math.round(t)) < 0 ? 0 : t > 255 ? 255 : t } function cn(t) { return t < 0 ? 0 : t > 1 ? 1 : t } function pn(t) { var e = t; return e.length && "%" === e.charAt(e.length - 1) ? hn(parseFloat(e) / 100 * 255) : hn(parseInt(e, 10)) } function dn(t) { var e = t; return e.length && "%" === e.charAt(e.length - 1) ? cn(parseFloat(e) / 100) : cn(parseFloat(e)) } function fn(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 gn(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 vn(t, e) { return t[0] = e[0], t[1] = e[1], t[2] = e[2], t[3] = e[3], t } var mn = new ln(20) , xn = null; function _n(t, e) { xn && vn(xn, e), xn = mn.put(t, xn || e.slice()) } function bn(t, e) { if (t) { e = e || []; var n = mn.get(t); if (n) return vn(e, n); var i = (t += "").replace(/ /g, "").toLowerCase(); if (i in un) return vn(e, un[i]), _n(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), _n(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), _n(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 = dn(u.pop()); case "rgb": return 3 !== u.length ? void yn(e, 0, 0, 0, 1) : (yn(e, pn(u[0]), pn(u[1]), pn(u[2]), h), _n(t, e), e); case "hsla": return 4 !== u.length ? void yn(e, 0, 0, 0, 1) : (u[3] = dn(u[3]), wn(u, e), _n(t, e), e); case "hsl": return 3 !== u.length ? void yn(e, 0, 0, 0, 1) : (wn(u, e), _n(t, e), e); default: return } } yn(e, 0, 0, 0, 1) } } function wn(t, e) { var n = (parseFloat(t[0]) % 360 + 360) % 360 / 360 , i = dn(t[1]) , r = dn(t[2]) , o = r <= .5 ? r * (i + 1) : r + i - r * i , a = 2 * r - o; return yn(e = e || [], hn(255 * fn(a, o, n + 1 / 3)), hn(255 * fn(a, o, n)), hn(255 * fn(a, o, n - 1 / 3)), 1), 4 === t.length && (e[3] = t[3]), e } function Sn(t, e) { var n = bn(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 kn(n, 4 === n.length ? "rgba" : "rgb") } } function Mn(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] = hn(gn(a[0], s[0], l)), n[1] = hn(gn(a[1], s[1], l)), n[2] = hn(gn(a[2], s[2], l)), n[3] = cn(gn(a[3], s[3], l)), n } } var In = Mn; function Tn(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 = bn(e[r]) , s = bn(e[o]) , l = i - r , u = kn([hn(gn(a[0], s[0], l)), hn(gn(a[1], s[1], l)), hn(gn(a[2], s[2], l)), cn(gn(a[3], s[3], l))], "rgba"); return n ? { color: u, leftIndex: r, rightIndex: o, value: i } : u } } var Cn = Tn; function Dn(t, e, n, i) { var r = bn(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 < .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] = dn(n)), null != i && (r[2] = dn(i)), kn(wn(r), "rgba") } function An(t, e) { var n = bn(t); if (n && null != e) return n[3] = cn(e), kn(n, "rgba") } function kn(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 Ln(t, e) { var n = bn(t); return n ? (.299 * n[0] + .587 * n[1] + .114 * n[2]) * n[3] / 255 + (1 - n[3]) * e : 0 } var Pn = Object.freeze({ __proto__: null, parse: bn, lift: Sn, toHex: function (t) { var e = bn(t); if (e) return ((1 << 24) + (e[0] << 16) + (e[1] << 8) + +e[2]).toString(16).slice(1) }, fastLerp: Mn, fastMapToColor: In, lerp: Tn, mapToColor: Cn, modifyHSL: Dn, modifyAlpha: An, stringify: kn, lum: Ln, random: function () { return kn([Math.round(255 * Math.random()), Math.round(255 * Math.random()), Math.round(255 * Math.random())], "rgb") } }) , On = Math.round; function Rn(t) { var e; if (t && "transparent" !== t) { if ("string" == typeof t && t.indexOf("rgba") > -1) { var n = bn(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 Nn = 1e-4; function En(t) { return t < Nn && t > -1e-4 } function zn(t) { return On(1e3 * t) / 1e3 } function Vn(t) { return On(1e4 * t) / 1e4 } var Bn = { left: "start", right: "end", center: "middle", middle: "middle" }; function Fn(t) { return t && !!t.image } function Gn(t) { return "linear" === t.type } function Wn(t) { return "radial" === t.type } function Hn(t) { return "url(#" + t + ")" } function Yn(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 Un(t) { var e = t.x || 0 , n = t.y || 0 , i = (t.rotation || 0) * _t , 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(" + On(a * _t) + "deg, " + On(s * _t) + "deg)"), l.join(" ") } var Xn = r.hasGlobalWindow && U(window.btoa) ? function (t) { return window.btoa(unescape(t)) } : "undefined" != typeof Buffer ? function (t) { return Buffer.from(t).toString("base64") } : function (t) { return null } , Zn = Array.prototype.slice; function jn(t, e, n) { return (e - t) * n + t } function qn(t, e, n, i) { for (var r = e.length, o = 0; o < r; o++) t[o] = jn(e[o], n[o], i); return t } function Kn(t, e, n, i) { for (var r = e.length, o = 0; o < r; o++) t[o] = e[o] + n[o] * i; return t } function $n(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 Jn(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 Qn(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] : Zn.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 ti(t) { if (N(t)) { var e = t.length; if (N(t[0])) { for (var n = [], i = 0; i < e; i++) n.push(Zn.call(t[i])); return n } return Zn.call(t) } return t } function ei(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 ni(t) { return 4 === t || 5 === t } function ii(t) { return 1 === t || 2 === t } var ri = [0, 0, 0, 0] , oi = 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 (X(e)) if (isNaN(+e)) { var u = bn(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: bn(t.color) } } )), Gn(e) ? a = 4 : Wn(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 = U(n) ? n : Le[n] || rn(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 = ii(i), l = ni(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 ? Qn(c, p, i) : l && Jn(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 = Kn([], n[u].value, d, -1) : ii(i) && (n[u].additiveValue = 1 === i ? Kn([], n[u].value, d, -1) : $n([], 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 ? ri : t[h]; if (!ii(s) && !c || y || (y = this._additiveValue = []), this.discrete) t[h] = g < 1 ? i.rawValue : r.rawValue; else if (ii(s)) 1 === s ? qn(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] = jn(e[a][s], n[a][s], i) } }(y, i[a], r[a], g); else if (ni(s)) { var v = i[a] , m = r[a] , x = 4 === s; t[h] = { type: x ? "linear" : "radial", x: jn(v.x, m.x, g), y: jn(v.y, m.y, g), colorStops: z(v.colorStops, (function (t, e) { var n = m.colorStops[e]; return { offset: jn(t.offset, n.offset, g), color: ei(qn([], t.color, n.color, g)) } } )), global: m.global }, x ? (t[h].x2 = jn(v.x2, m.x2, g), t[h].y2 = jn(v.y2, m.y2, g)) : t[h].r = jn(v.r, m.r, g) } else if (c) qn(y, i[a], r[a], g), o || (t[h] = ei(y)); else { var _ = jn(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 ? (bn(t[n], ri), Kn(ri, ri, i, 1), t[n] = ei(ri)) : 1 === e ? Kn(t[n], t[n], i, 1) : 2 === e && $n(t[n], t[n], i, 1) } , t }() , ai = 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 oi(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 = ei(l)) } else l = this._target[a]; if (null == l) continue; t > 0 && s.addKeyframe(0, ti(l), i), this._trackKeys.push(a) } s.addKeyframe(t, ti(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] = ti(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 si() { return (new Date).getTime() } var li, ui, hi = 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 = si() - 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, ke((function e() { t._running && (ke(e), !t._paused && t.update()) } )) } , e.prototype.start = function () { this._running || (this._time = si(), this._pausedTime = 0, this._startLoop()) } , e.prototype.stop = function () { this._running = !1 } , e.prototype.pause = function () { this._paused || (this._pauseStart = si(), this._paused = !0) } , e.prototype.resume = function () { this._paused && (this._pausedTime += si() - 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 ai(t, e.loop); return this.addAnimator(n), n } , e }(Xt), ci = r.domSupported, pi = (ui = { pointerdown: 1, pointerup: 1, pointermove: 1, pointerout: 1 }, { mouse: li = ["click", "dblclick", "mousewheel", "wheel", "mouseout", "mouseup", "mousedown", "mousemove", "contextmenu"], touch: ["touchstart", "touchend", "touchmove"], pointer: z(li, (function (t) { var e = t.replace("mouse", "pointer"); return ui.hasOwnProperty(e) ? e : t } )) }), di = ["mousemove", "mouseup"], fi = ["pointermove", "pointerup"], gi = !1; function yi(t) { var e = t.pointerType; return "pen" === e || "touch" === e } function vi(t) { t && (t.zrByTouch = !0) } function mi(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 xi = function (t, e) { this.stopPropagation = xt, this.stopImmediatePropagation = xt, this.preventDefault = xt, this.type = e.type, this.target = this.currentTarget = t.dom, this.pointerType = e.pointerType, this.clientX = e.clientX, this.clientY = e.clientY } , _i = { mousedown: function (t) { t = oe(this.dom, t), this.__mayPointerCapture = [t.zrX, t.zrY], this.trigger("mousedown", t) }, mousemove: function (t) { t = oe(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 = oe(this.dom, t), this.__togglePointerCapture(!1), this.trigger("mouseup", t) }, mouseout: function (t) { mi(this, (t = oe(this.dom, t)).toElement || t.relatedTarget) || (this.__pointerCapturing && (t.zrEventControl = "no_globalout"), this.trigger("mouseout", t)) }, wheel: function (t) { gi = !0, t = oe(this.dom, t), this.trigger("mousewheel", t) }, mousewheel: function (t) { gi || (t = oe(this.dom, t), this.trigger("mousewheel", t)) }, touchstart: function (t) { vi(t = oe(this.dom, t)), this.__lastTouchMoment = new Date, this.handler.processGesture(t, "start"), _i.mousemove.call(this, t), _i.mousedown.call(this, t) }, touchmove: function (t) { vi(t = oe(this.dom, t)), this.handler.processGesture(t, "change"), _i.mousemove.call(this, t) }, touchend: function (t) { vi(t = oe(this.dom, t)), this.handler.processGesture(t, "end"), _i.mouseup.call(this, t), +new Date - +this.__lastTouchMoment < 300 && _i.click.call(this, t) }, pointerdown: function (t) { _i.mousedown.call(this, t) }, pointermove: function (t) { yi(t) || _i.mousemove.call(this, t) }, pointerup: function (t) { _i.mouseup.call(this, t) }, pointerout: function (t) { yi(t) || _i.mouseout.call(this, t) } }; E(["click", "dblclick", "contextmenu"], (function (t) { _i[t] = function (e) { e = oe(this.dom, e), this.trigger(t, e) } } )); var bi = { pointermove: function (t) { yi(t) || bi.mousemove.call(this, t) }, pointerup: function (t) { bi.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 wi(t, e) { var n = e.domHandlers; r.pointerEventsSupported ? E(pi.pointer, (function (i) { Mi(e, i, (function (e) { n[i].call(t, e) } )) } )) : (r.touchEventsSupported && E(pi.touch, (function (i) { Mi(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(pi.mouse, (function (i) { Mi(e, i, (function (r) { r = re(r), e.touching || n[i].call(t, r) } )) } ))) } function Si(t, e) { function n(n) { Mi(e, n, (function (i) { i = re(i), mi(t, i.target) || (i = function (t, e) { return oe(t.dom, new xi(t, e), !0) }(t, i), e.domHandlers[n].call(t, i)) } ), { capture: !0 }) } r.pointerEventsSupported ? E(fi, n) : r.touchEventsSupported || E(di, n) } function Mi(t, e, n, i) { t.mounted[e] = n, t.listenerOpts[e] = i, ae(t.domTarget, e, n, i) } function Ii(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 Ti = function (t, e) { this.mounted = {}, this.listenerOpts = {}, this.touching = !1, this.domTarget = t, this.domHandlers = e } , Ci = 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 Ti(e, _i), ci && (i._globalHandlerScope = new Ti(document, bi)), wi(i, i._localHandlerScope), i } return n(e, t), e.prototype.dispose = function () { Ii(this._localHandlerScope), ci && Ii(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, ci && +this.__pointerCapturing ^ +t) { this.__pointerCapturing = t; var e = this._globalHandlerScope; t ? Si(this, e) : Ii(e) } } , e }(Xt) , Di = 1; r.hasGlobalWindow && (Di = Math.max(window.devicePixelRatio || window.screen && window.screen.deviceXDPI / window.screen.logicalXDPI || 1, 1)); var Ai = Di , ki = "#333" , Li = "#ccc"; function Pi() { return [1, 0, 0, 1, 0, 0] } function Oi(t) { return t[0] = 1, t[1] = 0, t[2] = 0, t[3] = 1, t[4] = 0, t[5] = 0, t } function Ri(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 Ni(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 Ei(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 zi(t, e, n) { var i = e[0] , r = e[2] , o = e[4] , a = e[1] , s = e[3] , l = e[5] , u = Math.sin(n) , h = Math.cos(n); return t[0] = i * h + a * u, t[1] = -i * u + a * h, t[2] = r * h + s * u, t[3] = -r * u + h * s, t[4] = h * o + u * l, t[5] = h * l - u * o, t } function Vi(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 Bi(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 Fi(t) { var e = [1, 0, 0, 1, 0, 0]; return Ri(e, t), e } var Gi = Object.freeze({ __proto__: null, create: Pi, identity: Oi, copy: Ri, mul: Ni, translate: Ei, rotate: zi, scale: Vi, invert: Bi, clone: Fi }) , Wi = Oi , Hi = 5e-5; function Yi(t) { return t > Hi || t < -5e-5 } var Ui = [] , Xi = [] , Zi = [1, 0, 0, 1, 0, 0] , ji = Math.abs , qi = 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 Yi(this.rotation) || Yi(this.x) || Yi(this.y) || Yi(this.scaleX - 1) || Yi(this.scaleY - 1) || Yi(this.skewX) || Yi(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) : Wi(n), t && (e ? Ni(n, t, n) : Ri(n, t)), this.transform = n, this._resolveGlobalScaleRatio(n)) : n && Wi(n) } , t.prototype._resolveGlobalScaleRatio = function (t) { var e = this.globalScaleRatio; if (null != e && 1 !== e) { this.getGlobalScale(Ui); var n = Ui[0] < 0 ? -1 : 1 , i = Ui[1] < 0 ? -1 : 1 , r = ((Ui[0] - n) * e + n) / Ui[0] || 0 , o = ((Ui[1] - i) * e + i) / Ui[1] || 0; t[0] *= r, t[1] *= r, t[2] *= o, t[3] *= o } this.invTransform = this.invTransform || [1, 0, 0, 1, 0, 0], Bi(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 && (Ni(Xi, t.invTransform, e), e = Xi); var n = this.originX , i = this.originY; (n || i) && (Zi[4] = n, Zi[5] = i, Ni(Xi, e, Zi), Xi[4] -= n, Xi[5] -= i, e = Xi), 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 && Ft(n, n, i), n } , t.prototype.transformCoordToGlobal = function (t, e) { var n = [t, e] , i = this.transform; return i && Ft(n, n, i), n } , t.prototype.getLineScale = function () { var t = this.transform; return t && ji(t[0] - 1) > 1e-10 && ji(t[3] - 1) > 1e-10 ? Math.sqrt(ji(t[0] * t[3] - t[2] * t[1])) : 1 } , t.prototype.copyTransform = function (t) { $i(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 && zi(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 }() , Ki = ["x", "y", "originX", "originY", "anchorX", "anchorY", "rotation", "scaleX", "scaleY", "skewX", "skewY"]; function $i(t, e) { for (var n = 0; n < Ki.length; n++) { var i = Ki[n]; t[i] = e[i] } } var Ji = 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 }() , Qi = Math.min , tr = Math.max , er = new Ji , nr = new Ji , ir = new Ji , rr = new Ji , or = new Ji , ar = new Ji , sr = 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 = Qi(t.x, this.x) , n = Qi(t.y, this.y); isFinite(this.x) && isFinite(this.width) ? this.width = tr(t.x + t.width, this.x + this.width) - e : this.width = t.width, isFinite(this.y) && isFinite(this.height) ? this.height = tr(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 Ei(r, r, [-e.x, -e.y]), Vi(r, r, [n, i]), Ei(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 ? Ji.set(ar, -g, 0) : Ji.set(ar, y, 0)) : x < d && (d = x, g < y ? Ji.set(or, g, 0) : Ji.set(or, -y, 0)), s < h || c < a ? _ > f && (f = _, v < m ? Ji.set(ar, 0, -v) : Ji.set(ar, 0, m)) : x < d && (d = x, v < m ? Ji.set(or, 0, v) : Ji.set(or, 0, -m)) } return n && Ji.copy(n, p ? or : ar), 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)) } er.x = ir.x = n.x, er.y = rr.y = n.y, nr.x = rr.x = n.x + n.width, nr.y = ir.y = n.y + n.height, er.transform(i), rr.transform(i), nr.transform(i), ir.transform(i), e.x = Qi(er.x, nr.x, ir.x, rr.x), e.y = Qi(er.y, nr.y, ir.y, rr.y); var l = tr(er.x, nr.x, ir.x, rr.x) , u = tr(er.y, nr.y, ir.y, rr.y); e.width = l - e.x, e.height = u - e.y } else e !== n && t.copy(e, n) } , t }() , lr = {}; function ur(t, e) { var n = lr[e = e || a]; n || (n = lr[e] = new ln(500)); var i = n.get(t); return null == i && (i = h.measureText(t, e).width, n.put(t, i)), i } function hr(t, e, n, i) { var r = ur(t, e) , o = fr(e) , a = pr(0, r, n) , s = dr(0, o, i); return new sr(a, s, r, o) } function cr(t, e, n, i) { var r = ((t || "") + "").split("\n"); if (1 === r.length) return hr(r[0], e, n, i); for (var o = new sr(0, 0, 0, 0), a = 0; a < r.length; a++) { var s = hr(r[a], e, n, i); 0 === a ? o.copy(s) : o.union(s) } return o } function pr(t, e, n) { return "right" === n ? t -= e : "center" === n && (t -= e / 2), t } function dr(t, e, n) { return "middle" === n ? t -= e / 2 : "bottom" === n && (t -= e), t } function fr(t) { return ur("国", t) } function gr(t, e) { return "string" == typeof t ? t.lastIndexOf("%") >= 0 ? parseFloat(t) / 100 * e : parseFloat(t) : t } function yr(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 += gr(i[0], n.width), u += gr(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 vr = "__zr_normal__" , mr = Ki.concat(["ignore"]) , xr = V(Ki, (function (t, e) { return t[e] = !0, t } ), { ignore: !1 }) , _r = {} , br = new sr(0, 0, 0, 0) , wr = 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 = br; n.layoutRect ? u.copy(n.layoutRect) : u.copy(this.getBoundingRect()), i || u.applyTransform(this.transform), this.calculateTextPosition ? this.calculateTextPosition(_r, n, u) : yr(_r, n, u), r.x = _r.x, r.y = _r.y, o = _r.align, a = _r.verticalAlign; var h = n.origin; if (h && null != n.rotation) { var c = void 0 , p = void 0; "center" === h ? (c = .5 * u.width, p = .5 * u.height) : (c = gr(h[0], u.width), p = gr(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() ? Li : ki } , t.prototype.getOutsideStroke = function (t) { var e = this.__zr && this.__zr.getBackgroundColor() , n = "string" == typeof e && bn(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, kn(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 !== vr)) { 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, mr) } , 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(vr, !1, t) } , t.prototype.useState = function (t, e, n, i) { var r = t === vr; 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._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 < mr.length; u++) { var h = mr[u] , c = r && xr[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 qi, 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 ai(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) { Sr(this, t, e, n) } , t.prototype.animateFrom = function (t, e, n) { Sr(this, t, e, n, !0) } , t.prototype._transitionState = function (t, e, n, i) { for (var r = Sr(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 Sr(t, e, n, i, r) { var o = []; Tr(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 Mr(t, e, n) { for (var i = 0; i < n; i++) t[i] = e[i] } function Ir(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), Mr(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] ? Mr(o[l], r[l], s) : o[l] = Array.prototype.slice.call(r[l]); else Mr(o, r, a); o.length = r.length } else t[n] = e[n] } function Tr(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 } Tr(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 || (x = (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 } ))).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[_]] = ti(n[v]), Ir(n, i, v) } } (w = new ai(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(wr, Xt), R(wr, qi); var Cr = 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 sr(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 ? (sr.applyTransform(e, s, l), (r = r || e.clone()).union(e)) : (r = r || s.clone()).union(s) } } return r || e } , e }(wr); Cr.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 Dr = {} , Ar = {}; var kr = 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 Ae , a = n.renderer || "canvas"; Dr[a] || (a = G(Dr)[0]), n.useDirtyRect = null != n.useDirtyRect && n.useDirtyRect; var s = new Dr[a](e, o, n, t) , l = n.ssr || s.ssrOnly; this.storage = o, this.painter = s; var u = r.node || r.worker || l ? null : new Ci(s.getViewportRoot(), s.root); this.handler = new ve(o, s, u, s.root), this.animation = new hi({ stage: { update: l ? null : function () { return i._flush(!0) } } }), l || this.animation.start() } return t.prototype.add = function (t) { t && (this.storage.addRoot(t), t.addSelfToZr(this), this.refresh()) } , t.prototype.remove = function (t) { t && (this.storage.delRoot(t), t.removeSelfFromZr(this), this.refresh()) } , t.prototype.configLayer = function (t, e) { this.painter.configLayer && this.painter.configLayer(t, e), this.refresh() } , t.prototype.setBackgroundColor = function (t) { 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 Ln(t, 1) < .4; if (t.colorStops) { for (var e = t.colorStops, n = 0, i = e.length, r = 0; r < i; r++) n += Ln(e[r].color, 1); return (n /= i) < .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) { t || this.animation.update(!0), this._needsRefresh = !1, this.painter.refresh(), this._needsRefresh = !1 } , t.prototype.refresh = function () { this._needsRefresh = !0, this.animation.start() } , t.prototype.flush = function () { this._flush(!1) } , t.prototype._flush = function (t) { var e, n = si(); this._needsRefresh && (e = !0, this.refreshImmediately(t)), this._needsRefreshHover && (e = !0, this.refreshHoverImmediately()); var i = si(); 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.animation.start(), this._stillFrameAccum = 0 } , t.prototype.refreshHover = function () { this._needsRefreshHover = !0 } , t.prototype.refreshHoverImmediately = function () { this._needsRefreshHover = !1, this.painter.refreshHover && "canvas" === this.painter.getType() && this.painter.refreshHover() } , t.prototype.resize = function (t) { t = t || {}, this.painter.resize(t.width, t.height), this.handler.resize() } , t.prototype.clearAnimation = function () { this.animation.clear() } , t.prototype.getWidth = function () { return this.painter.getWidth() } , t.prototype.getHeight = function () { return this.painter.getHeight() } , t.prototype.setCursorStyle = function (t) { this.handler.setCursorStyle(t) } , t.prototype.findHover = function (t, e) { return this.handler.findHover(t, e) } , t.prototype.on = function (t, e, n) { return this.handler.on(t, e, n), this } , t.prototype.off = function (t, e) { this.handler.off(t, e) } , t.prototype.trigger = function (t, e) { this.handler.trigger(t, e) } , t.prototype.clear = function () { for (var t = this.storage.getRoots(), e = 0; e < t.length; e++) t[e] instanceof Cr && t[e].removeSelfFromZr(this); this.storage.delAllRoots(), this.painter.clear() } , t.prototype.dispose = function () { var t; this.animation.stop(), this.clear(), this.storage.dispose(), this.painter.dispose(), this.handler.dispose(), this.animation = this.storage = this.painter = this.handler = null, t = this.id, delete Ar[t] } , t }(); function Lr(t, e) { var n = new kr(M(), t, e); return Ar[n.id] = n, n } function Pr(t, e) { Dr[t] = e } var Or = Object.freeze({ __proto__: null, init: Lr, dispose: function (t) { t.dispose() }, disposeAll: function () { for (var t in Ar) Ar.hasOwnProperty(t) && Ar[t].dispose(); Ar = {} }, getInstance: function (t) { return Ar[t] }, registerPainter: Pr, version: "5.3.0" }) , Rr = 1e-4; function Nr(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 Er(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 X(t) ? (n = t, n.replace(/^\s+|\s+$/g, "")).match(/%$/) ? parseFloat(t) / 100 * e : parseFloat(t) : null == t ? NaN : +t; var n } function zr(t, e, n) { return null == e && (e = 10), e = Math.min(Math.max(0, e), 20), t = (+t).toFixed(e), n ? t : +t } function Vr(t) { return t.sort((function (t, e) { return t - e } )), t } function Br(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 Fr(t) } function Fr(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 Gr(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 Wr(t, e, n) { if (!t[e]) return 0; var i = V(t, (function (t, e) { return t + (isNaN(e) ? 0 : e) } ), 0); if (0 === i) return 0; for (var r = Math.pow(10, n), o = z(t, (function (t) { return (isNaN(t) ? 0 : t) / i * r * 100 } )), a = 100 * r, s = z(o, (function (t) { return Math.floor(t) } )), l = V(s, (function (t, e) { return t + e } ), 0), u = z(o, (function (t, e) { return t - s[e] } )); l < a;) { for (var h = Number.NEGATIVE_INFINITY, c = null, p = 0, d = u.length; p < d; ++p) u[p] > h && (h = u[p], c = p); ++s[c], u[c] = 0, ++l } return s[e] / r } function Hr(t, e) { var n = Math.max(Br(t), Br(e)) , i = t + e; return n > 20 ? i : zr(i, n) } var Yr = 9007199254740991; function Ur(t) { var e = 2 * Math.PI; return (t % e + e) % e } function Xr(t) { return t > -1e-4 && t < Rr } var Zr = /^(?:(\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 jr(t) { if (t instanceof Date) return t; if (X(t)) { var e = Zr.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 qr(t) { return Math.pow(10, Kr(t)) } function Kr(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 $r(t, e) { var n = Kr(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 Jr(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 Qr(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 to(t) { var e = parseFloat(t); return e == t && (0 !== e || !X(t) || t.indexOf("x") <= 0) ? e : NaN } function eo(t) { return !isNaN(to(t)) } function no() { return Math.round(9 * Math.random()) } function io(t, e) { return 0 === e ? t : io(e, t % e) } function ro(t, e) { return null == t ? e : null == e ? t : t * e / io(t, e) } "undefined" != typeof console && console.warn && console.log; function oo(t) { 0 } function ao(t) { throw new Error(t) } function so(t, e, n) { return (e - t) * n + t } var lo = "series\0" , uo = "\0_ec_\0"; function ho(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 po = ["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 fo(t) { return !q(t) || Y(t) || t instanceof Date ? t : t.value } function go(t) { return q(t) && !(t instanceof Array) } function yo(t, e, n) { var i = "normalMerge" === n , r = "replaceMerge" === n , o = "replaceAll" === n; t = t || [], e = (e || []).slice(); var a = ft(); 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 || bo(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 = mo(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) && !bo(n) && !bo(o) && vo("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 || bo(i.existing) || i.existing && null != e.id && !vo("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 = ft(), 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 ? mo(i.name) : n ? n.name : lo + e, n) r.id = mo(n.id); else if (null != i.id) r.id = mo(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 vo(t, e, n) { var i = xo(e[t], null) , r = xo(n[t], null); return null != i && null != r && i === r } function mo(t) { return xo(t, "") } function xo(t, e) { return null == t ? e : X(t) ? t : j(t) || Z(t) ? t + "" : e } function _o(t) { var e = t.name; return !(!e || !e.indexOf(lo)) } function bo(t) { return t && null != t.id && 0 === mo(t.id).indexOf(uo) } function wo(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 So() { var t = "__ec_inner_" + Mo++; return function (e) { return e[t] || (e[t] = {}) } } var Mo = no(); function Io(t, e, n) { var i = To(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 = Ao(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 To(t, e) { var n; if (X(t)) { var i = {}; i[t + "Index"] = 0, n = i } else n = t; var r = ft() , 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 Co = { useDefault: !0, enableAll: !1, enableNone: !1 } , Do = { useDefault: !1, enableAll: !0, enableNone: !0 }; function Ao(t, e, n, i) { i = i || Co; 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 ko(t, e, n) { t.setAttribute ? t.setAttribute(e, n) : t[e] = n } function Lo(t, e) { var n = ft() , 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 Po(t, e, n, i, r) { var o = null == e || "auto" === e; if (null == i) return i; if (j(i)) return zr(f = so(n || 0, i, r), o ? Math.max(Br(n || 0), Br(i)) : e); if (X(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] = zr(f, o ? Math.max(Br(p), Br(d)) : e) } } return a } var Oo = "___EC__COMPONENT__CONTAINER___" , Ro = "___EC__EXTENDED_CLASS___"; function No(t) { var e = { main: "", sub: "" }; if (t) { var n = t.split("."); e.main = n[0] || "", e.sub = n[1] || "" } return e } function Eo(t, e) { t.$constructor = t, t.extend = function (t) { var e, i, r = this; return U(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) : O(e = function () { (t.$constructor || r).apply(this, arguments) } , this), A(e.prototype, t), e[Ro] = !0, e.extend = this.extend, e.superCall = Bo, e.superApply = Fo, e.superClass = r, e } } function zo(t, e) { t.extend = e.extend } var Vo = Math.round(10 * Math.random()); function Bo(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 Fo(t, e, n) { return this.superClass.prototype[e].apply(t, n) } function Go(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 = No(i); if (r.sub) { if (r.sub !== Oo) { (function (t) { var n = e[t.main]; n && n[Oo] || ((n = e[t.main] = {})[Oo] = !0); return n }(r))[r.sub] = t } } else e[r.main] = t } return t } , t.getClass = function (t, n, i) { var r = e[t]; if (r && r[Oo] && (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 = No(t) , i = [] , r = e[n.main]; return r && r[Oo] ? E(r, (function (t, e) { e !== Oo && i.push(t) } )) : i.push(r), i } , t.hasClass = function (t) { var n = No(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 = No(t) , i = e[n.main]; return i && i[Oo] } } function Wo(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 Ho = Wo([["fill", "color"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["opacity"], ["shadowColor"]]) , Yo = function () { function t() { } return t.prototype.getAreaStyle = function (t, e) { return Ho(this, t, e) } , t }() , Uo = new ln(50); function Xo(t) { if ("string" == typeof t) { var e = Uo.get(t); return e && e.image } return t } function Zo(t, e, n, i, r) { if (t) { if ("string" == typeof t) { if (e && e.__zrImageSrc === t || !n) return e; var o = Uo.get(t) , a = { hostEl: n, cb: i, cbPayload: r }; if (o) !qo(e = o.image) && o.pending.push(a); else { var s = h.loadImage(t, jo, jo); s.__zrImageSrc = t, Uo.put(t, s.__cachedImgObj = { image: s, pending: [a] }) } return e } return t } return e } function jo() { 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 qo(t) { return t && t.width && t.height } var Ko = /\{([a-zA-Z0-9_]+)\|([^}]*)\}/g; function $o(t, e, n, i, r) { if (!e) return ""; var o = (t + "").split("\n"); r = Jo(e, n, i, r); for (var a = 0, s = o.length; a < s; a++) o[a] = Qo(o[a], r); return o.join("\n") } function Jo(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 = ur("国", e); var a = r.ascCharWidth = ur("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 = ur(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 Qo(t, e) { var n = e.containerWidth , i = e.font , r = e.contentWidth; if (!n) return ""; var o = ur(t, i); if (o <= n) return t; for (var a = 0; ; a++) { if (o <= r || a >= e.maxIterations) { t += e.ellipsis; break } var s = 0 === a ? ta(t, r, e.ascCharWidth, e.cnCharWidth) : o > 0 ? Math.floor(t.length * r / o) : 0; o = ur(t = t.substr(0, s), i) } return "" === t && (t = e.placeholder), t } function ta(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 ea = function () { } , na = function (t) { this.tokens = [], t && (this.tokens = t) } , ia = function () { this.width = 0, this.height = 0, this.contentWidth = 0, this.contentHeight = 0, this.outerWidth = 0, this.outerHeight = 0, this.lines = [] }; function ra(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 = gr(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 = sa(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 ea; if (m.styleName = r, m.text = v, m.isLineHolder = !v && !s, "number" == typeof l.width ? m.width = l.width : m.width = a ? a[y] : ur(v, h), y || c) u.push(new na([m])); else { var x = (u[u.length - 1] || (u[0] = new na)).tokens , _ = x.length; 1 === _ && x[0].isLineHolder ? x[0] = m : (v || !_ || s) && x.push(m) } } } var oa = V(",&?/;] ".split(""), (function (t, e) { return t[e] = !0, t } ), {}); function aa(t) { return !function (t) { var e = t.charCodeAt(0); return e >= 33 && e <= 383 }(t) || !!oa[t] } function sa(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 = ur(p, e) , f = !i && !aa(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 la = "__zr_style_" + Math.round(10 * Math.random()) , ua = { shadowBlur: 0, shadowOffsetX: 0, shadowOffsetY: 0, shadowColor: "#000", opacity: 1, blend: "source-over" } , ha = { style: { shadowBlur: !0, shadowOffsetX: !0, shadowOffsetY: !0, shadowColor: !0, opacity: !0 } }; ua[la] = !0; var ca = ["z", "z2", "invisible"] , pa = ["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) { fa.copy(t.getBoundingRect()), t.transform && fa.applyTransform(t.transform); return ga.width = e, ga.height = n, !fa.intersect(ga) }(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 sr(0, 0, 0, 0)), e ? sr.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 sr(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 yt(ua, t) } , e.prototype.useStyle = function (t) { t[la] || (t = this.createStyle(t)), this.__inHover ? this.__hoverStyle = t : this.style = t, this.dirtyStyle() } , e.prototype.isStyleObject = function (t) { return t[la] } , 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, ca) } , 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 ? pa : ca; 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 ha } , 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 }(wr) , fa = new sr(0, 0, 0, 0) , ga = new sr(0, 0, 0, 0); var ya = Math.min , va = Math.max , ma = Math.sin , xa = Math.cos , _a = 2 * Math.PI , ba = wt() , wa = wt() , Sa = wt(); function Ma(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 = ya(r, i[0]), o = va(o, i[0]), a = ya(a, i[1]), s = va(s, i[1]); e[0] = r, e[1] = a, n[0] = o, n[1] = s } } function Ia(t, e, n, i, r, o) { r[0] = ya(t, n), r[1] = ya(e, i), o[0] = va(t, n), o[1] = va(e, i) } var Ta = [] , Ca = []; function Da(t, e, n, i, r, o, a, s, l, u) { var h = Xe , c = He , p = h(t, n, r, a, Ta); 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, Ta[d]); l[0] = ya(f, l[0]), u[0] = va(f, u[0]) } p = h(e, i, o, s, Ca); for (d = 0; d < p; d++) { var g = c(e, i, o, s, Ca[d]); l[1] = ya(g, l[1]), u[1] = va(g, u[1]) } l[0] = ya(t, l[0]), u[0] = va(t, u[0]), l[0] = ya(a, l[0]), u[0] = va(a, u[0]), l[1] = ya(e, l[1]), u[1] = va(e, u[1]), l[1] = ya(s, l[1]), u[1] = va(s, u[1]) } function Aa(t, e, n, i, r, o, a, s) { var l = Je , u = Ke , h = va(ya(l(t, n, r), 1), 0) , c = va(ya(l(e, i, o), 1), 0) , p = u(t, n, r, h) , d = u(e, i, o, c); a[0] = ya(t, r, p), a[1] = ya(e, o, d), s[0] = va(t, r, p), s[1] = va(e, o, d) } function ka(t, e, n, i, r, o, a, s, l) { var u = Gt , h = Wt , c = Math.abs(r - o); if (c % _a < 1e-4 && c > 1e-4) return s[0] = t - n, s[1] = e - i, l[0] = t + n, void (l[1] = e + i); if (ba[0] = xa(r) * n + t, ba[1] = ma(r) * i + e, wa[0] = xa(o) * n + t, wa[1] = ma(o) * i + e, u(s, ba, wa), h(l, ba, wa), (r %= _a) < 0 && (r += _a), (o %= _a) < 0 && (o += _a), r > o && !a ? o += _a : r < o && a && (r += _a), a) { var p = o; o = r, r = p } for (var d = 0; d < o; d += Math.PI / 2) d > r && (Sa[0] = xa(d) * n + t, Sa[1] = ma(d) * i + e, u(s, Sa, s), h(l, Sa, l)) } var La = { M: 1, L: 2, C: 3, Q: 4, A: 5, Z: 6, R: 7 } , Pa = [] , Oa = [] , Ra = [] , Na = [] , Ea = [] , za = [] , Va = Math.min , Ba = Math.max , Fa = Math.cos , Ga = Math.sin , Wa = Math.abs , Ha = Math.PI , Ya = 2 * Ha , Ua = "undefined" != typeof Float32Array , Xa = []; function Za(t) { return Math.round(t / Ha * 1e8) / 1e8 % 2 * Ha } var ja = 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 = Wa(n / Ai / t) || 0, this._uy = Wa(n / Ai / 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(La.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 = Wa(t - this._xi) , i = Wa(e - this._yi) , r = n > this._ux || i > this._uy; if (this.addData(La.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(La.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(La.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(), Xa[0] = i, Xa[1] = r, function (t, e) { var n = Za(t[0]); n < 0 && (n += Ya); var i = n - t[0] , r = t[1]; r += i, !e && r - n >= Ya ? r = n + Ya : e && n - r >= Ya ? r = n - Ya : !e && n > r ? r = n + (Ya - Za(n - r)) : e && n < r && (r = n - (Ya - Za(r - n))), t[0] = n, t[1] = r }(Xa, o), i = Xa[0]; var a = (r = Xa[1]) - i; return this.addData(La.A, t, e, n, n, i, a, 0, o ? 0 : 1), this._ctx && this._ctx.arc(t, e, n, i, r, o), this._xi = Fa(r) * n + t, this._yi = Ga(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(La.R, t, e, n, i), this } , t.prototype.closePath = function () { this._drawPendingPt(), this.addData(La.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 || !Ua || (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(); Ua && 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, Ua && this._len > 11 && (this.data = new Float32Array(t))) } } , t.prototype.getBoundingRect = function () { Ra[0] = Ra[1] = Ea[0] = Ea[1] = Number.MAX_VALUE, Na[0] = Na[1] = za[0] = za[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 La.M: n = r = e[t++], i = o = e[t++], Ea[0] = r, Ea[1] = o, za[0] = r, za[1] = o; break; case La.L: Ia(n, i, e[t], e[t + 1], Ea, za), n = e[t++], i = e[t++]; break; case La.C: Da(n, i, e[t++], e[t++], e[t++], e[t++], e[t], e[t + 1], Ea, za), n = e[t++], i = e[t++]; break; case La.Q: Aa(n, i, e[t++], e[t++], e[t], e[t + 1], Ea, za), n = e[t++], i = e[t++]; break; case La.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 = Fa(p) * h + l, o = Ga(p) * c + u), ka(l, u, h, c, p, d, f, Ea, za), n = Fa(d) * h + l, i = Ga(d) * c + u; break; case La.R: Ia(r = n = e[t++], o = i = e[t++], r + e[t++], o + e[t++], Ea, za); break; case La.Z: n = r, i = o } Gt(Ra, Ra, Ea), Wt(Na, Na, za) } return 0 === t && (Ra[0] = Ra[1] = Na[0] = Na[1] = 0), new sr(Ra[0], Ra[1], Na[0] - Ra[0], Na[1] - Ra[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 La.M: r = a = t[c++], o = s = t[c++]; break; case La.L: var g = t[c++] , y = (x = t[c++]) - o; (Wa(A = g - r) > n || Wa(y) > i || c === e - 1) && (f = Math.sqrt(A * A + y * y), r = g, o = x); break; case La.C: var v = t[c++] , m = t[c++] , x = (g = t[c++], t[c++]) , _ = t[c++] , b = t[c++]; f = qe(r, o, v, m, g, x, _, b, 10), r = _, o = b; break; case La.Q: f = en(r, o, v = t[c++], m = t[c++], g = t[c++], x = t[c++], 10), r = g, o = x; break; case La.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; t[c++]; d && (a = Fa(T) * M + w, s = Ga(T) * I + S), f = Ba(M, I) * Va(Ya, Math.abs(C)), r = Fa(D) * M + w, o = Ga(D) * I + S; break; case La.R: a = r = t[c++], s = o = t[c++], f = 2 * t[c++] + 2 * t[c++]; break; case La.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 !== La.L && x > 0 && (t.lineTo(h, c), x = 0), b) { case La.M: n = r = p[_++], i = o = p[_++], t.moveTo(r, o); break; case La.L: a = p[_++], s = p[_++]; var S = Wa(a - r) , M = Wa(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 La.C: var C = p[_++] , D = p[_++] , A = p[_++] , k = p[_++] , L = p[_++] , P = p[_++]; if (y) { if (v + (j = l[m++]) > u) { Ze(r, C, A, L, I = (u - v) / j, Pa), Ze(o, D, k, P, I, Oa), t.bezierCurveTo(Pa[1], Oa[1], Pa[2], Oa[2], Pa[3], Oa[3]); break t } v += j } t.bezierCurveTo(C, D, A, k, L, P), r = L, o = P; break; case La.Q: C = p[_++], D = p[_++], A = p[_++], k = p[_++]; if (y) { if (v + (j = l[m++]) > u) { Qe(r, C, A, I = (u - v) / j, Pa), Qe(o, D, k, I, Oa), t.quadraticCurveTo(Pa[1], Oa[1], Pa[2], Oa[2]); break t } v += j } t.quadraticCurveTo(C, D, A, k), r = A, o = k; break; case La.A: var O = p[_++] , R = p[_++] , N = p[_++] , E = p[_++] , z = p[_++] , V = p[_++] , B = p[_++] , F = !p[_++] , G = N > E ? N : E , W = Wa(N - E) > .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 = Fa(z) * N + O, i = Ga(z) * E + R), r = Fa(H) * N + O, o = Ga(H) * E + R; break; case La.R: n = r = p[_], i = o = p[_ + 1], a = p[_++], s = p[_++]; var U = p[_++] , X = p[_++]; if (y) { if (v + (j = l[m++]) > u) { var Z = u - v; t.moveTo(a, s), t.lineTo(a + Va(Z, U), s), (Z -= U) > 0 && t.lineTo(a + U, s + Va(Z, X)), (Z -= X) > 0 && t.lineTo(a + Ba(U - Z, 0), s + X), (Z -= U) > 0 && t.lineTo(a, s + Ba(X - Z, 0)); break t } v += j } t.rect(a, s, U, X); break; case La.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 = La, t.initDefaultProps = function () { var e = t.prototype; e._saveData = !0, e._ux = 0, e._uy = 0, e._pendingPtDist = 0, e._version = 0 }(), t }(); function qa(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 Ka(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) && je(t, e, n, i, r, o, a, s, u, h, null) <= c / 2 } function $a(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) && tn(t, e, n, i, r, o, s, l, null) <= u / 2 } var Ja = 2 * Math.PI; function Qa(t) { return (t %= Ja) < 0 && (t += Ja), t } var ts = 2 * Math.PI; function es(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) % ts < 1e-4) return !0; if (o) { var c = i; i = Qa(r), r = Qa(c) } else i = Qa(i), r = Qa(r); i > r && (r += ts); var p = Math.atan2(l, s); return p < 0 && (p += ts), p >= i && p <= r || p + ts >= i && p + ts <= r } function ns(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 ? .5 : -.5); var l = a * (n - t) + t; return l === r ? 1 / 0 : l > r ? s : 0 } var is = ja.CMD , rs = 2 * Math.PI; var os = [-1, -1, -1] , as = [-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 = Ue(e, i, o, s, u, os); if (0 === c) return 0; for (var p = 0, d = -1, f = void 0, g = void 0, y = 0; y < c; y++) { var v = os[y] , m = 0 === v || 1 === v ? .5 : 1; He(t, n, r, a, v) < l || (d < 0 && (d = Xe(e, i, o, s, as), as[1] < as[0] && d > 1 && (h = void 0, h = as[0], as[0] = as[1], as[1] = h), f = He(e, i, o, s, as[0]), d > 1 && (g = He(e, i, o, s, as[1]))), 2 === d ? v < as[0] ? p += f < e ? m : -m : v < as[1] ? p += g < f ? m : -m : p += s < g ? m : -m : v < as[0] ? p += f < e ? m : -m : p += s < f ? m : -m) } return p } function ls(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 (Ge(o)) We(a) && (h = -s / a) >= 0 && h <= 1 && (r[l++] = h); else { var u = a * a - 4 * o * s; if (Ge(u)) (h = -a / (2 * o)) >= 0 && h <= 1 && (r[l++] = h); else if (u > 0) { var h, c = Oe(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, os); if (0 === l) return 0; var u = Je(e, i, o); if (u >= 0 && u <= 1) { for (var h = 0, c = Ke(e, i, o, u), p = 0; p < l; p++) { var d = 0 === os[p] || 1 === os[p] ? .5 : 1; Ke(t, n, r, os[p]) < a || (os[p] < u ? h += c < e ? d : -d : h += o < c ? d : -d) } return h } d = 0 === os[0] || 1 === os[0] ? .5 : 1; return Ke(t, n, r, os[0]) < a ? 0 : o < e ? d : -d } function us(t, e, n, i, r, o, a, s) { if ((s -= e) > n || s < -n) return 0; var l = Math.sqrt(n * n - s * s); os[0] = -l, os[1] = l; var u = Math.abs(i - r); if (u < 1e-4) return 0; if (u >= rs - 1e-4) { i = 0, r = rs; var h = o ? 1 : -1; return a >= os[0] + t && a <= os[1] + t ? h : 0 } if (i > r) { var c = i; i = r, r = c } i < 0 && (i += rs, r += rs); for (var p = 0, d = 0; d < 2; d++) { var f = os[d]; if (f + t > a) { var g = Math.atan2(s, f); h = o ? 1 : -1; g < 0 && (g = rs + g), (g >= i && g <= r || g + rs >= i && g + rs <= r) && (g > Math.PI / 2 && g < 1.5 * Math.PI && (h = -h), p += h) } } return p } function hs(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 === is.M && y > 1 && (n || (c += ns(p, d, f, g, i, r))), m && (f = p = u[y], g = d = u[y + 1]), v) { case is.M: p = f = u[y++], d = g = u[y++]; break; case is.L: if (n) { if (qa(p, d, u[y], u[y + 1], e, i, r)) return !0 } else c += ns(p, d, u[y], u[y + 1], i, r) || 0; p = u[y++], d = u[y++]; break; case is.C: if (n) { if (Ka(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 is.Q: if (n) { if ($a(p, d, u[y++], u[y++], u[y], u[y + 1], e, i, r)) return !0 } else c += ls(p, d, u[y++], u[y++], u[y], u[y + 1], i, r) || 0; p = u[y++], d = u[y++]; break; case is.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 += ns(p, d, o, a, i, r); var T = (i - x) * w / b + x; if (n) { if (es(x, _, w, S, S + M, I, e, T, r)) return !0 } else c += us(x, _, w, S, S + M, I, T, r); p = Math.cos(S + M) * b + x, d = Math.sin(S + M) * w + _; break; case is.R: if (f = p = u[y++], g = d = u[y++], o = f + u[y++], a = g + u[y++], n) { if (qa(f, g, o, g, e, i, r) || qa(o, g, o, a, e, i, r) || qa(o, a, f, a, e, i, r) || qa(f, a, f, g, e, i, r)) return !0 } else c += ns(o, g, o, a, i, r), c += ns(f, a, f, g, i, r); break; case is.Z: if (n) { if (qa(p, d, f, g, e, i, r)) return !0 } else c += ns(p, d, f, g, i, r); p = f, d = g } } return n || (s = d, l = g, Math.abs(s - l) < 1e-4) || (c += ns(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 }, ua) , ps = { style: k({ fill: !0, stroke: !0, strokePercent: !0, fillOpacity: !0, strokeOpacity: !0, lineDashOffset: !0, lineWidth: !0, miterLimit: !0 }, ha.style) } , ds = Ki.concat(["invisible", "culling", "z", "z2", "zlevel", "parent"]) , fs = 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 < ds.length; ++s) r[ds[s]] = this[ds[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 (X(t)) { var e = Ln(t, 0); return e > .5 ? ki : e > .2 ? "#eee" : Li } if (t) return Li } return ki } , e.prototype.getInsideTextStroke = function (t) { var e = this.style.fill; if (X(e)) { var n = this.__zr; if (!(!n || !n.isDarkMode()) === Ln(t, 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 ja(!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 hs(t, e, !0, n, i) }(o, a / s, t, e))) return !0 } if (this.hasFill()) return function (t, e, n) { return hs(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 yt(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 ps } , 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) , gs = k({ strokeFirst: !0, font: a, x: 0, y: 0, textAlign: "left", textBaseline: "top", miterLimit: 2 }, cs) , ys = 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 yt(gs, 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 = cr(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); ys.prototype.type = "tspan"; var vs = k({ x: 0, y: 0 }, ua) , ms = { style: k({ x: !0, y: !0, width: !0, height: !0, sx: !0, sy: !0, sWidth: !0, sHeight: !0 }, ha.style) }; var xs = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.createStyle = function (t) { return yt(vs, 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 ms } , e.prototype.getBoundingRect = function () { var t = this.style; return this._rect || (this._rect = new sr(t.x || 0, t.y || 0, this.getWidth(), this.getHeight())), this._rect } , e }(da); xs.prototype.type = "image"; var _s = Math.round; function bs(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 ? (_s(2 * i) === _s(2 * r) && (t.x1 = t.x2 = Ss(i, s, !0)), _s(2 * o) === _s(2 * a) && (t.y1 = t.y2 = Ss(o, s, !0)), t) : t } } function ws(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 = Ss(i, s, !0), t.y = Ss(r, s, !0), t.width = Math.max(Ss(i + o, s, !1) - t.x, 0 === o ? 0 : 1), t.height = Math.max(Ss(r + a, s, !1) - t.y, 0 === a ? 0 : 1), t) : t } } function Ss(t, e, n) { if (!e) return t; var i = _s(2 * t); return (i + _s(e)) % 2 == 0 ? i / 2 : (i + (n ? 1 : -1)) / 2 } var Ms = function () { this.x = 0, this.y = 0, this.width = 0, this.height = 0 } , Is = {} , Ts = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new Ms } , e.prototype.buildPath = function (t, e) { var n, i, r, o; if (this.subPixelOptimize) { var a = ws(Is, 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 }(fs); Ts.prototype.type = "rect"; var Cs = { fill: "#000" } , Ds = { 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 }, ha.style) } , As = function (t) { function e(e) { var n = t.call(this) || this; return n.type = "text", n._children = [], n._defaultStyle = Cs, 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, Es(t = this.style), E(t.rich, Es), 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 sr(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 || Cs } , 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 Ds } , 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 = fr(o), l = rt(e.lineHeight, s), u = !!e.backgroundColor, h = "truncate" === e.lineOverflow, c = e.width, p = (n = null == c || "break" !== i && "breakAll" !== i ? t ? t.split("\n") : [] : t ? sa(t, e.font, c, "breakAll" === i, 0).lines : []).length * l, d = rt(e.height, p); if (p > d && h) { var f = Math.floor(d / l); n = n.slice(0, f) } if (t && a && null != c) for (var g = Jo(c, o, e.ellipsis, { minChar: e.truncateMinChar, placeholder: e.placeholder }), y = 0; y < n.length; y++) n[y] = Qo(n[y], g); var v = d , m = 0; for (y = 0; y < n.length; y++) m = Math.max(ur(n[y], o), m); null == c && (c = m); var x = m; return r && (v += r[0] + r[2], x += r[1] + r[3], c += r[1] + r[3]), u && (x = c), { lines: n, height: d, outerWidth: x, outerHeight: v, lineHeight: l, calculatedLineHeight: s, contentWidth: m, contentHeight: p, width: c } }(Fs(t), t) , r = Gs(t) , o = !!t.backgroundColor , s = i.outerHeight , l = i.outerWidth , u = i.contentWidth , h = i.lines , c = i.lineHeight , p = this._defaultStyle , d = t.x || 0 , f = t.y || 0 , g = t.align || p.align || "left" , y = t.verticalAlign || p.verticalAlign || "top" , v = d , m = dr(f, i.contentHeight, y); if (r || n) { var x = pr(d, l, g) , _ = dr(f, s, y); r && this._renderBackground(t, t, x, _, l, s) } m += c / 2, n && (v = Bs(d, g, n), "top" === y ? m += n[0] : "bottom" === y && (m -= n[2])); for (var b = 0, w = !1, S = (Vs("fill" in t ? t.fill : (w = !0, p.fill))), M = (zs("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(ys) , 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, Rs(k, t), m += c, T && A.setBoundingRect(new sr(pr(k.x, t.width, k.textAlign), dr(k.y, C, k.textBaseline), u, C)) } } , e.prototype._updateRichTexts = function () { var t = this.style , e = function (t, e) { var n = new ia; 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 = Ko.lastIndex = 0; null != (i = Ko.exec(t));) { var u = i.index; u > l && ra(n, t.substring(l, u), e, s), ra(n, i[2], e, s, i[1]), l = Ko.lastIndex } l < t.length && ra(n, t.substring(l, t.length), e, s); var h = [] , c = 0 , p = 0 , d = e.padding , f = "truncate" === a , g = "truncate" === e.lineOverflow; function y(t, e, n) { t.width = e, t.lineHeight = n, c += n, p = Math.max(p, e) } t: for (var v = 0; v < n.lines.length; v++) { for (var m = n.lines[v], x = 0, _ = 0, b = 0; b < m.tokens.length; b++) { var w = (P = m.tokens[b]).styleName && e.rich[P.styleName] || {} , S = P.textPadding = w.padding , M = S ? S[1] + S[3] : 0 , I = P.font = w.font || e.font; P.contentHeight = fr(I); var T = rt(w.height, P.contentHeight); if (P.innerHeight = T, S && (T += S[0] + S[2]), P.height = T, P.lineHeight = ot(w.lineHeight, e.lineHeight, T), P.align = w && w.align || e.align, P.verticalAlign = w && w.verticalAlign || "middle", g && null != o && c + P.lineHeight > o) { b > 0 ? (m.tokens = m.tokens.slice(0, b), y(m, _, x), n.lines = n.lines.slice(0, v + 1)) : n.lines = n.lines.slice(0, v); break t } var C = w.width , D = null == C || "auto" === C; if ("string" == typeof C && "%" === C.charAt(C.length - 1)) P.percentWidth = C, h.push(P), P.contentWidth = ur(P.text, I); else { if (D) { var A = w.backgroundColor , k = A && A.image; k && qo(k = Xo(k)) && (P.width = Math.max(P.width, k.width * T / k.height)) } var L = f && null != r ? r - _ : null; null != L && L < P.width ? !D || L < M ? (P.text = "", P.width = P.contentWidth = 0) : (P.text = $o(P.text, L - M, I, e.ellipsis, { minChar: e.truncateMinChar }), P.width = P.contentWidth = ur(P.text, I)) : P.contentWidth = ur(P.text, I) } P.width += M, _ += P.width, w && (x = Math.max(x, P.lineHeight)) } y(m, _, x) } 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]), v = 0; v < h.length; v++) { var P, O = (P = h[v]).percentWidth; P.width = parseInt(O, 10) / 100 * n.width } return n }(Fs(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 , c = pr(a, i, u) , p = dr(s, r, h) , d = c , f = p; o && (d += o[3], f += o[0]); var g = d + n; Gs(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 && Gs(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 = Bs(r, o, p), h -= t.height / 2 - p[0] - t.innerHeight / 2); var d = this._getOrCreateChild(ys) , f = d.createStyle(); d.useStyle(f); var g = this._defaultStyle , y = !1 , v = 0 , m = Vs("fill" in l ? l.fill : "fill" in e ? e.fill : (y = !0, g.fill)) , x = zs("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), Rs(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 sr(pr(f.x, b, f.textAlign), dr(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(Ts)).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(xs)).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 Ns(t) && (e = [t.fontStyle, t.fontWeight, Os(t.fontSize), t.fontFamily || "sans-serif"].join(" ")), e && ut(e) || t.textFont || t.font } , e }(da) , ks = { left: !0, right: 1, center: 1 } , Ls = { top: 1, bottom: 1, middle: 1 } , Ps = ["fontStyle", "fontWeight", "fontSize", "fontFamily"]; function Os(t) { return "string" != typeof t || -1 === t.indexOf("px") && -1 === t.indexOf("rem") && -1 === t.indexOf("em") ? isNaN(+t) ? "12px" : t + "px" : t } function Rs(t, e) { for (var n = 0; n < Ps.length; n++) { var i = Ps[n] , r = e[i]; null != r && (t[i] = r) } } function Ns(t) { return null != t.fontSize || t.fontFamily || t.fontWeight } function Es(t) { if (t) { t.font = As.makeFont(t); var e = t.align; "middle" === e && (e = "center"), t.align = null == e || ks[e] ? e : "left"; var n = t.verticalAlign; "center" === n && (n = "middle"), t.verticalAlign = null == n || Ls[n] ? n : "top", t.padding && (t.padding = st(t.padding)) } } function zs(t, e) { return null == t || e <= 0 || "transparent" === t || "none" === t ? null : t.image || t.colorStops ? "#000" : t } function Vs(t) { return null == t || "none" === t ? null : t.image || t.colorStops ? "#000" : t } function Bs(t, e, n) { return "right" === e ? t - n[1] : "center" === e ? t + n[3] / 2 - n[1] / 2 : t + n[3] } function Fs(t) { var e = t.text; return null != e && (e += ""), e } function Gs(t) { return !!(t.backgroundColor || t.lineHeight || t.borderWidth && t.borderColor) } var Ws = So() , Hs = function (t, e, n, i) { if (i) { var r = Ws(i); r.dataIndex = n, r.dataType = e, r.seriesIndex = t, "group" === i.type && i.traverse((function (i) { var r = Ws(i); r.seriesIndex = t, r.dataIndex = n, r.dataType = e } )) } } , Ys = 1 , Us = {} , Xs = So() , Zs = So() , js = ["emphasis", "blur", "select"] , qs = ["normal", "emphasis", "blur", "select"] , Ks = 10 , $s = "highlight" , Js = "downplay" , Qs = "select" , tl = "unselect" , el = "toggleSelect"; function nl(t) { return null != t && "none" !== t } var il = new ln(100); function rl(t) { if (X(t)) { var e = il.get(t); return e || (e = Sn(t, -.1), il.put(t, e)), e } if (Q(t)) { var n = A({}, t); return n.colorStops = z(t.colorStops, (function (t) { return { offset: t.offset, color: Sn(t.color, -.1) } } )), n } return t } function ol(t, e, n) { t.onHoverStateChange && (t.hoverState || 0) !== n && t.onHoverStateChange(e), t.hoverState = n } function al(t) { ol(t, "emphasis", 2) } function sl(t) { 2 === t.hoverState && ol(t, "normal", 0) } function ll(t) { ol(t, "blur", 1) } function ul(t) { 1 === t.hoverState && ol(t, "normal", 0) } function hl(t) { t.selected = !0 } function cl(t) { t.selected = !1 } function pl(t, e, n) { e(t, n) } function dl(t, e, n) { pl(t, e, n), t.isGroup && t.traverse((function (t) { pl(t, e, n) } )) } function fl(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 gl(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 fs) { var a = Xs(t) , s = r && a.selectFill || a.normalFill , l = r && a.selectStroke || a.normalStroke; if (nl(s) || nl(l)) { var u = (i = i || {}).style || {}; "inherit" === u.fill ? (o = !0, i = A({}, i), (u = A({}, u)).fill = s) : !nl(u.fill) && nl(s) ? (o = !0, i = A({}, i), (u = A({}, u)).fill = rl(s)) : !nl(u.stroke) && nl(l) && (o || (i = A({}, i), u = A({}, u)), u.stroke = rl(l)), i.style = u } } if (i && null == i.z2) { o || (i = A({}, i)); var h = t.z2EmphasisLift; i.z2 = t.z2 + (null != h ? h : Ks) } 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 : .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 yl(t) { t.stateProxy = gl; var e = t.getTextContent() , n = t.getTextGuideLine(); e && (e.stateProxy = gl), n && (n.stateProxy = gl) } function vl(t, e) { !Il(t, e) && !t.__highByOuter && dl(t, al) } function ml(t, e) { !Il(t, e) && !t.__highByOuter && dl(t, sl) } function xl(t, e) { t.__highByOuter |= 1 << (e || 0), dl(t, al) } function _l(t, e) { !(t.__highByOuter &= ~(1 << (e || 0))) && dl(t, sl) } function bl(t) { dl(t, ll) } function wl(t) { dl(t, ul) } function Sl(t) { dl(t, hl) } function Ml(t) { dl(t, cl) } function Il(t, e) { return t.__highDownSilentOnTouch && e.zrByTouch } function Tl(t) { t.getModel().eachComponent((function (e, n) { var i = Zs(n); i.isBlured && ("series" === e ? t.getViewOfSeriesModel(n) : t.getViewOfComponentModel(n)).group.traverse((function (t) { ul(t) } )); i.isBlured = !1 } )) } function Cl(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 && wl(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) { ll(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), Zs(t).isBlured = !0 } } )), r.eachComponent((function (t, e) { if ("series" !== t) { var n = i.getViewOfComponentModel(e); n && n.blurSeries && n.blurSeries(l, r) } } )) } } function Dl(t, e, n) { if (null != t && null != e) { var i = n.getModel().getComponent(t, e); if (i) { Zs(i).isBlured = !0; var r = n.getViewOfComponentModel(i); r && r.focusBlurEnabled && r.group.traverse((function (t) { ll(t) } )) } } } function Al(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" === Ws(l[u]).focus) { s = !0; break } return { focusSelf: s, dispatchers: l } } function kl(t) { E(t.getAllData(), (function (e) { var n = e.data , i = e.type; n.eachItemGraphicEl((function (e, n) { t.isSelected(n, i) ? Sl(e) : Ml(e) } )) } )) } function Ll(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 Pl(t, e, n) { Vl(t, !0), dl(t, yl), Rl(t, e, n) } function Ol(t, e, n, i) { i ? function (t) { Vl(t, !1) }(t) : Pl(t, e, n) } function Rl(t, e, n) { var i = Ws(t); null != e ? (i.focus = e, i.blurScope = n) : i.focus && (i.focus = null) } var Nl = ["emphasis", "blur", "select"] , El = { itemStyle: "getItemStyle", lineStyle: "getLineStyle", areaStyle: "getAreaStyle" }; function zl(t, e, n, i) { n = n || "itemStyle"; for (var r = 0; r < Nl.length; r++) { var o = Nl[r] , a = e.getModel([o, n]); t.ensureState(o).style = i ? i(a) : a[El[n]]() } } function Vl(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 Bl(t) { return !(!t || !t.__highDownDispatcher) } function Fl(t) { var e = t.type; return e === Qs || e === tl || e === el } function Gl(t) { var e = t.type; return e === $s || e === Js } var Wl = ja.CMD , Hl = [[], [], []] , Yl = Math.sqrt , Ul = Math.atan2; function Xl(t, e) { if (e) { var n, i, r, o, a, s, l = t.data, u = t.len(), h = Wl.M, c = Wl.C, p = Wl.L, d = Wl.R, f = Wl.A, g = Wl.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 = Yl(e[0] * e[0] + e[1] * e[1]) , x = Yl(e[2] * e[2] + e[3] * e[3]) , _ = Ul(-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++], Ft(s, s, e), l[o++] = s[0], l[o++] = s[1], s[0] += l[r++], s[1] += l[r++], Ft(s, s, e), l[o++] = s[0], l[o++] = s[1] } for (a = 0; a < i; a++) { var b = Hl[a]; b[0] = l[r++], b[1] = l[r++], Ft(b, b, e), l[o++] = b[0], l[o++] = b[1] } } t.increaseVersion() } } var Zl = Math.sqrt , jl = Math.sin , ql = Math.cos , Kl = Math.PI; function $l(t) { return Math.sqrt(t[0] * t[0] + t[1] * t[1]) } function Jl(t, e) { return (t[0] * e[0] + t[1] * e[1]) / ($l(t) * $l(e)) } function Ql(t, e) { return (t[0] * e[1] < t[1] * e[0] ? -1 : 1) * Math.acos(Jl(t, e)) } function tu(t, e, n, i, r, o, a, s, l, u, h) { var c = l * (Kl / 180) , p = ql(c) * (t - n) / 2 + jl(c) * (e - i) / 2 , d = -1 * jl(c) * (t - n) / 2 + ql(c) * (e - i) / 2 , f = p * p / (a * a) + d * d / (s * s); f > 1 && (a *= Zl(f), s *= Zl(f)); var g = (r === o ? -1 : 1) * Zl((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 + ql(c) * y - jl(c) * v , x = (e + i) / 2 + jl(c) * y + ql(c) * v , _ = Ql([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 = Ql(b, w); if (Jl(b, w) <= -1 && (S = Kl), Jl(b, w) >= 1 && (S = 0), S < 0) { var M = Math.round(S / Kl * 1e6) / 1e6; S = 2 * Kl + M % 2 * Kl } h.addData(u, m, x, a, s, _, S, c, o) } var eu = /([mlvhzcqtsa])([^mlvhzcqtsa]*)/gi , nu = /-?([0-9]*\.)?[0-9]+([eE]-?[0-9]+)?/g; var iu = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.applyTransform = function (t) { } , e }(fs); function ru(t) { return null != t.setData } function ou(t, e) { var n = function (t) { var e = new ja; if (!t) return e; var n, i = 0, r = 0, o = i, a = r, s = ja.CMD, l = t.match(eu); 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(nu) || [], 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++], tu(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++], tu(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 (ru(t)) { t.setData(n.data), (e = t.getContext()) && t.rebuildPath(e, 1) } else { var e = t; n.rebuildPath(e, 1) } } , i.applyTransform = function (t) { Xl(n, t), this.dirtyShape() } , i } function au(t, e) { return new iu(ou(t, e)) } function su(t, e) { e = e || {}; var n = new fs; return t.shape && n.setShape(t.shape), n.setStyle(t.style), e.bakeTransform ? Xl(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 lu = function () { this.cx = 0, this.cy = 0, this.r = 0 } , uu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new lu } , 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 }(fs); uu.prototype.type = "circle"; var hu = function () { this.cx = 0, this.cy = 0, this.rx = 0, this.ry = 0 } , cu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new hu } , e.prototype.buildPath = function (t, e) { var n = .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 }(fs); cu.prototype.type = "ellipse"; var pu = Math.PI , du = 2 * pu , fu = Math.sin , gu = Math.cos , yu = Math.acos , vu = Math.atan2 , mu = Math.abs , xu = Math.sqrt , _u = Math.max , bu = Math.min , wu = 1e-4; function Su(t, e, n, i, r, o, a) { var s = t - n , l = e - i , u = (a ? o : -o) / xu(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) * xu(_u(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 Mu(t, e) { var n, i = _u(e.r, 0), r = _u(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 = mu(l - s) , d = p > du && p % du; if (d > wu && (p = d), i > wu) if (p > du - wu) t.moveTo(u + i * gu(s), h + i * fu(s)), t.arc(u, h, i, s, l, !c), r > wu && (t.moveTo(u + r * gu(l), h + r * fu(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 * gu(s) , L = i * fu(s) , P = r * gu(l) , O = r * fu(l) , R = p > wu; if (R) { var N = e.cornerRadius; N && (f = (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))[0], g = n[1], y = n[2], v = n[3]); var E = mu(i - r) / 2; if (m = bu(E, y), x = bu(E, v), _ = bu(E, f), b = bu(E, g), M = w = _u(m, x), I = S = _u(_, b), (w > wu || S > wu) && (T = i * gu(l), C = i * fu(l), D = r * gu(s), A = r * fu(s), p < pu)) { 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 < wu)) 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 / fu(yu((V * F + B * G) / (xu(V * V + B * B) * xu(F * F + G * G))) / 2) , H = xu(z[0] * z[0] + z[1] * z[1]); M = bu(w, (i - H) / (W + 1)), I = bu(S, (r - H) / (W - 1)) } } } if (R) if (M > wu) { var U = bu(y, M) , X = bu(v, M) , Z = Su(D, A, k, L, i, U, c) , j = Su(T, C, P, O, i, X, c); t.moveTo(u + Z.cx + Z.x0, h + Z.cy + Z.y0), M < w && U === X ? t.arc(u + Z.cx, h + Z.cy, M, vu(Z.y0, Z.x0), vu(j.y0, j.x0), !c) : (U > 0 && t.arc(u + Z.cx, h + Z.cy, U, vu(Z.y0, Z.x0), vu(Z.y1, Z.x1), !c), t.arc(u, h, i, vu(Z.cy + Z.y1, Z.cx + Z.x1), vu(j.cy + j.y1, j.cx + j.x1), !c), X > 0 && t.arc(u + j.cx, h + j.cy, X, vu(j.y1, j.x1), vu(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 > wu && R) if (I > wu) { U = bu(f, I), Z = Su(P, O, T, C, r, -(X = bu(g, I)), c), j = Su(k, L, D, A, r, -U, c); t.lineTo(u + Z.cx + Z.x0, h + Z.cy + Z.y0), I < S && U === X ? t.arc(u + Z.cx, h + Z.cy, I, vu(Z.y0, Z.x0), vu(j.y0, j.x0), !c) : (X > 0 && t.arc(u + Z.cx, h + Z.cy, X, vu(Z.y0, Z.x0), vu(Z.y1, Z.x1), !c), t.arc(u, h, r, vu(Z.cy + Z.y1, Z.cx + Z.x1), vu(j.cy + j.y1, j.cx + j.x1), c), U > 0 && t.arc(u + j.cx, h + j.cy, U, vu(j.y1, j.x1), vu(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 Iu = 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 } , Tu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new Iu } , e.prototype.buildPath = function (t, e) { Mu(t, e) } , e.prototype.isZeroArea = function () { return this.shape.startAngle === this.shape.endAngle || this.shape.r === this.shape.r0 } , e }(fs); Tu.prototype.type = "sector"; var Cu = function () { this.cx = 0, this.cy = 0, this.r = 0, this.r0 = 0 } , Du = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new Cu } , 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 }(fs); function Au(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++) Gt(a, a, t[p]), Wt(s, s, t[p]); Gt(a, a, i[0]), Wt(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(Mt(t[p])); continue } r = t[p - 1], o = t[p + 1] } Dt(u, o, r), Ot(u, u, e); var g = Nt(f, r) , y = Nt(f, o) , v = g + y; 0 !== v && (g /= v, y /= v), Ot(h, u, -g), Ot(c, u, y); var m = Tt([], f, h) , x = Tt([], f, c); i && (Wt(m, m, a), Gt(m, m, s), Wt(x, x, a), Gt(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() } } Du.prototype.type = "ring"; var ku = function () { this.points = null, this.smooth = 0, this.smoothConstraint = null } , Lu = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new ku } , e.prototype.buildPath = function (t, e) { Au(t, e, !0) } , e }(fs); Lu.prototype.type = "polygon"; var Pu = function () { this.points = null, this.percent = 1, this.smooth = 0, this.smoothConstraint = null } , Ou = 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 Pu } , e.prototype.buildPath = function (t, e) { Au(t, e, !1) } , e }(fs); Ou.prototype.type = "polyline"; var Ru = {} , Nu = function () { this.x1 = 0, this.y1 = 0, this.x2 = 0, this.y2 = 0, this.percent = 1 } , Eu = 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 Nu } , e.prototype.buildPath = function (t, e) { var n, i, r, o; if (this.subPixelOptimize) { var a = bs(Ru, 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 }(fs); Eu.prototype.type = "line"; var zu = [] , Vu = function () { this.x1 = 0, this.y1 = 0, this.x2 = 0, this.y2 = 0, this.cpx1 = 0, this.cpy1 = 0, this.percent = 1 }; function Bu(t, e, n) { var i = t.cpx2 , r = t.cpy2; return null != i || null != r ? [(n ? Ye : He)(t.x1, t.cpx1, t.cpx2, t.x2, e), (n ? Ye : He)(t.y1, t.cpy1, t.cpy2, t.y2, e)] : [(n ? $e : Ke)(t.x1, t.cpx1, t.x2, e), (n ? $e : Ke)(t.y1, t.cpy1, t.y2, e)] } var Fu = 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 Vu } , 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 && (Qe(n, a, r, h, zu), a = zu[1], r = zu[2], Qe(i, s, o, h, zu), s = zu[1], o = zu[2]), t.quadraticCurveTo(a, s, r, o)) : (h < 1 && (Ze(n, a, l, r, h, zu), a = zu[1], l = zu[2], r = zu[3], Ze(i, s, u, o, h, zu), s = zu[1], u = zu[2], o = zu[3]), t.bezierCurveTo(a, s, l, u, r, o))) } , e.prototype.pointAt = function (t) { return Bu(this.shape, t, !1) } , e.prototype.tangentAt = function (t) { var e = Bu(this.shape, t, !0); return Rt(e, e) } , e }(fs); Fu.prototype.type = "bezier-curve"; var Gu = function () { this.cx = 0, this.cy = 0, this.r = 0, this.startAngle = 0, this.endAngle = 2 * Math.PI, this.clockwise = !0 } , Wu = 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 Gu } , 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 }(fs); Wu.prototype.type = "arc"; var Hu = 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), fs.prototype.getBoundingRect.call(this) } , e }(fs) , Yu = function () { function t(t) { this.colorStops = t || [] } return t.prototype.addColorStop = function (t, e) { this.colorStops.push({ offset: t, color: e }) } , t }() , Uu = 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 }(Yu) , Xu = function (t) { function e(e, n, i, r, o) { var a = t.call(this, r) || this; return a.x = null == e ? .5 : e, a.y = null == n ? .5 : n, a.r = null == i ? .5 : i, a.type = "radial", a.global = o || !1, a } return n(e, t), e }(Yu) , Zu = [0, 0] , ju = [0, 0] , qu = new Ji , Ku = new Ji , $u = function () { function t(t, e) { this._corners = [], this._axes = [], this._origin = [0, 0]; for (var n = 0; n < 4; n++) this._corners[n] = new Ji; for (n = 0; n < 2; n++) this._axes[n] = new Ji; 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); Ji.sub(i[0], n[1], n[0]), Ji.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 qu.set(1 / 0, 1 / 0), Ku.set(0, 0), !this._intersectCheckOneSide(this, t, qu, Ku, i, 1) && (n = !1, i) || !this._intersectCheckOneSide(t, this, qu, Ku, i, -1) && (n = !1, i) || i || Ji.copy(e, n ? qu : Ku), 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, Zu), this._getProjMinMaxOnAxis(s, e._corners, ju), Zu[1] < ju[0] || Zu[0] > ju[1]) { if (a = !1, r) return a; var u = Math.abs(ju[0] - Zu[1]) , h = Math.abs(Zu[0] - ju[1]); Math.min(u, h) > i.len() && (u < h ? Ji.scale(i, l, -u * o) : Ji.scale(i, l, h * o)) } else if (n) { u = Math.abs(ju[0] - Zu[1]), h = Math.abs(Zu[0] - ju[1]); Math.min(u, h) < n.len() && (u < h ? Ji.scale(n, l, u * o) : Ji.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 }() , Ju = [] , Qu = 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 sr(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(Ju)), 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) , th = So(); function eh(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)), U(h) && (h = h(n, r)), U(l) && (l = l(n)), { duration: l || 0, delay: h, easing: u } } return null } function nh(t, e, n, i, r, o, a) { var s, l = !1; U(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 = eh(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 ih(t, e, n, i, r, o) { nh("update", t, e, n, i, r, o) } function rh(t, e, n, i, r, o) { nh("enter", t, e, n, i, r, o) } function oh(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 ah(t, e, n, i, r, o) { oh(t) || nh("leave", t, e, n, i, r, o) } function sh(t, e, n, i) { t.removeTextContent(), t.removeTextGuideLine(), ah(t, { style: { opacity: 0 } }, e, n, i) } function lh(t, e, n) { function i() { t.parent && t.parent.remove(t) } t.isGroup ? t.traverse((function (t) { t.isGroup || sh(t, e, n, i) } )) : sh(t, e, n, i) } function uh(t) { th(t).oldStyle = t.style } var hh = Math.max , ch = Math.min , ph = {}; function dh(t) { return fs.extend(t) } var fh = function (t, e) { var i = ou(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 }(iu) }; function gh(t, e) { return fh(t, e) } function yh(t, e) { ph[t] = e } function vh(t) { if (ph.hasOwnProperty(t)) return ph[t] } function mh(t, e, n, i) { var r = au(t, e); return n && ("center" === i && (n = _h(n, r.getBoundingRect())), wh(r, n)), r } function xh(t, e, n) { var i = new xs({ 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(_h(e, r)) } } }); return i } function _h(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 bh = 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 fs(e); return a.createPathProxy(), a.buildPath = function (t) { if (ru(t)) { t.appendPath(n); var e = t.getContext(); e && t.rebuildPath(e, 1) } } , a }; function wh(t, e) { if (t.applyTransform) { var n = t.getBoundingRect().calculateTransform(e); t.applyTransform(n) } } var Sh = Ss; function Mh(t, e) { for (var n = Oi([]); t && t !== e;) Ni(n, t.getLocalTransform(), n), t = t.parent; return n } function Ih(t, e, n) { return e && !N(e) && (e = qi.getLocalTransform(e)), n && (e = Bi([], e)), Ft([], t, e) } function Th(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 = Ih(o, e, n), Math.abs(o[0]) > Math.abs(o[1]) ? o[0] > 0 ? "right" : "left" : o[1] > 0 ? "bottom" : "top" } function Ch(t) { return !t.isGroup } function Dh(t, e, n) { if (t && e) { var i, r = (i = {}, t.traverse((function (t) { Ch(t) && t.anid && (i[t.anid] = t) } )), i); e.traverse((function (t) { if (Ch(t) && t.anid) { var e = r[t.anid]; if (e) { var i = o(t); t.attr(o(e)), ih(t, i, n, Ws(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 Ah(t, e) { return z(t, (function (t) { var n = t[0]; n = hh(n, e.x), n = ch(n, e.x + e.width); var i = t[1]; return i = hh(i, e.y), [n, i = ch(i, e.y + e.height)] } )) } function kh(t, e) { var n = hh(t.x, e.x) , i = ch(t.x + t.width, e.x + e.width) , r = hh(t.y, e.y) , o = ch(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 Lh(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 xs(i)) : mh(t.replace("path://", ""), i, n, "center") } function Ph(t, e, n, i, r) { for (var o = 0, a = r[r.length - 1]; o < r.length; o++) { var s = r[o]; if (Oh(t, e, n, i, s[0], s[1], a[0], a[1])) return !0; a = s } } function Oh(t, e, n, i, r, o, a, s) { var l, u = n - t, h = i - e, c = a - r, p = s - o, d = Rh(c, p, u, h); if ((l = d) <= 1e-6 && l >= -1e-6) return !1; var f = t - r , g = e - o , y = Rh(f, g, u, h) / d; if (y < 0 || y > 1) return !1; var v = Rh(f, g, c, p) / d; return !(v < 0 || v > 1) } function Rh(t, e, n, i) { return t * i - n * e } function Nh(t) { var e = t.itemTooltipOption , n = t.componentModel , i = t.itemName , r = X(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) { mt(s, t) || (s[t] = l[t], s.$vars.push(t)) } )); var u = Ws(t.el); u.componentMainType = o, u.componentIndex = a, u.tooltipConfig = { name: i, option: k({ content: i, formatterParams: s }, r) } } function Eh(t, e) { var n; t.isGroup && (n = e(t)), n || t.traverse(e) } function zh(t, e) { if (t) if (Y(t)) for (var n = 0; n < t.length; n++) Eh(t[n], e); else Eh(t, e) } yh("circle", uu), yh("ellipse", cu), yh("sector", Tu), yh("ring", Du), yh("polygon", Lu), yh("polyline", Ou), yh("rect", Ts), yh("line", Eu), yh("bezierCurve", Fu), yh("arc", Wu); var Vh = Object.freeze({ __proto__: null, updateProps: ih, initProps: rh, removeElement: ah, removeElementWithFadeOut: lh, isElementRemoved: oh, extendShape: dh, extendPath: gh, registerShape: yh, getShapeClass: vh, makePath: mh, makeImage: xh, mergePath: bh, resizePath: wh, subPixelOptimizeLine: function (t) { return bs(t.shape, t.shape, t.style), t }, subPixelOptimizeRect: function (t) { return ws(t.shape, t.shape, t.style), t }, subPixelOptimize: Sh, getTransform: Mh, applyTransform: Ih, transformDirection: Th, groupTransition: Dh, clipPointsByRect: Ah, clipRectByRect: kh, createIcon: Lh, linePolygonIntersect: Ph, lineLineIntersect: Oh, setTooltipConfig: Nh, traverseElements: zh, Group: Cr, Image: xs, Text: As, Circle: uu, Ellipse: cu, Sector: Tu, Ring: Du, Polygon: Lu, Polyline: Ou, Rect: Ts, Line: Eu, BezierCurve: Fu, Arc: Wu, IncrementalDisplayable: Qu, CompoundPath: Hu, LinearGradient: Uu, RadialGradient: Xu, BoundingRect: sr, OrientedBoundingRect: $u, Point: Ji, Path: fs }) , Bh = {}; function Fh(t, e) { for (var n = 0; n < js.length; n++) { var i = js[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 Gh(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 = U(t.defaultText) ? t.defaultText(o, t, n) : t.defaultText); for (var l = { normal: i }, u = 0; u < js.length; u++) { var h = js[u] , c = e[h]; l[h] = rt(r ? r.getFormattedLabel(o, h, null, a, c && c.get("formatter")) : null, i) } return l } function Wh(t, e, n, i) { n = n || Bh; for (var r = t instanceof As, o = !1, a = 0; a < qs.length; a++) { if ((p = e[qs[a]]) && p.getShallow("show")) { o = !0; break } } var s = r ? t : t.getTextContent(); if (o) { r || (s || (s = new As, t.setTextContent(s)), t.stateProxy && (s.stateProxy = t.stateProxy)); var l = Gh(n, e) , u = e.normal , h = !!u.getShallow("show") , c = Yh(u, i && i.normal, n, !1, !r); c.text = l.normal, r || t.setTextConfig(Uh(u, n, !1)); for (a = 0; a < js.length; a++) { var p, d = js[a]; if (p = e[d]) { var f = s.ensureState(d) , g = !!rt(p.getShallow("show"), h); if (g !== h && (f.ignore = !g), f.style = Yh(p, i && i[d], n, !0, !r), f.style.text = l[d], !r) t.ensureState(d).textConfig = Uh(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 && ($h(s).setLabelText = function (t) { var i = Gh(n, e, t); Fh(s, i) } ) } else s && (s.ignore = !0); t.dirty() } function Hh(t, e) { e = e || "label"; for (var n = { normal: t.getModel(e) }, i = 0; i < js.length; i++) { var r = js[i]; n[r] = t.getModel([r, e]) } return n } function Yh(t, e, n, i, r) { var o = {}; return function (t, e, n, i, r) { n = n || Bh; var o, a = e.ecModel, s = a && a.option.textStyle, l = function (t) { var e; for (; t && t !== t.ecModel;) { var n = (t.option || Bh).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]); qh(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); qh(t, e, s, n, i, r, !0, !1) }(o, t, n, i, r), e && A(o, e), o } function Uh(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 Xh = ["fontStyle", "fontWeight", "fontSize", "fontFamily", "textShadowColor", "textShadowBlur", "textShadowOffsetX", "textShadowOffsetY"] , Zh = ["align", "lineHeight", "width", "height", "tag", "verticalAlign"] , jh = ["padding", "borderWidth", "borderRadius", "borderDashOffset", "backgroundColor", "borderColor", "shadowColor", "shadowBlur", "shadowOffsetX", "shadowOffsetY"]; function qh(t, e, n, i, r, o, a, s) { n = !r && n || Bh; 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 < Xh.length; g++) { var y = Xh[g]; null != (m = rt(e.getShallow(y), n[y])) && (t[y] = m) } for (g = 0; g < Zh.length; g++) { y = Zh[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 < jh.length; g++) { var m; y = jh[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 Kh(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 $h = So(); function Jh(t, e, n, i) { if (t) { var r = $h(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 Qh(t, e, n, i, r) { var o = $h(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 ? rh : ih)(t, { percent: 1 }, i, e, null, (function (i) { var u = Po(n, o.precision, s, l, i); o.interpolatedValue = 1 === i ? null : u; var h = Gh({ labelDataIndex: e, labelFetcher: r, defaultText: a ? a(u) : u + "" }, o.statesModels, u); Fh(t, h) } )) } } var tc, ec, nc = ["textStyle", "color"], ic = ["fontStyle", "fontWeight", "fontSize", "fontFamily", "padding", "lineHeight", "rich", "width", "height", "overflow"], rc = new As, oc = function () { function t() { } return t.prototype.getTextColor = function (t) { var e = this.ecModel; return this.getShallow("color") || (!t && e ? e.get(nc) : null) } , t.prototype.getFont = function () { return Kh({ 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 < ic.length; n++) e[ic[n]] = this.getShallow(ic[n]); return rc.useStyle(e), rc.update(), rc.getBoundingRect() } , t }(), ac = [["lineWidth", "width"], ["stroke", "color"], ["opacity"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"], ["lineDash", "type"], ["lineDashOffset", "dashOffset"], ["lineCap", "cap"], ["lineJoin", "join"], ["miterLimit"]], sc = Wo(ac), lc = function () { function t() { } return t.prototype.getLineStyle = function (t) { return sc(this, t) } , t }(), uc = [["fill", "color"], ["stroke", "borderColor"], ["lineWidth", "borderWidth"], ["opacity"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"], ["lineDash", "borderType"], ["lineDashOffset", "borderDashOffset"], ["lineCap", "borderCap"], ["lineJoin", "borderJoin"], ["miterLimit", "borderMiterLimit"]], hc = Wo(uc), cc = function () { function t() { } return t.prototype.getItemStyle = function (t, e) { return hc(this, t, e) } , t }(), pc = 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 }(); Eo(pc), tc = pc, ec = ["__\0is_clz", Vo++].join("_"), tc.prototype[ec] = !0, tc.isInstance = function (t) { return !(!t || !t[ec]) } , R(pc, lc), R(pc, cc), R(pc, Yo), R(pc, oc); var dc = Math.round(10 * Math.random()); function fc(t) { return [t || "", dc++].join("_") } function gc(t, e) { return C(C({}, t, !0), e, !0) } var yc = "ZH" , vc = "EN" , mc = vc , xc = {} , _c = {} , bc = r.domSupported && (document.documentElement.lang || navigator.language || navigator.browserLanguage).toUpperCase().indexOf(yc) > -1 ? yc : mc; function wc(t, e) { t = t.toUpperCase(), _c[t] = new pc(e), xc[t] = e } function Sc(t) { return _c[t] } wc(vc, { 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" } }, 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: ". " } } } }), wc(yc, { 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: "旭日图" } }, 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 Mc = 1e3 , Ic = 6e4 , Tc = 36e5 , Cc = 864e5 , Dc = 31536e6 , Ac = { 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}" } , kc = "{yyyy}-{MM}-{dd}" , Lc = { year: "{yyyy}", month: "{yyyy}-{MM}", day: kc, hour: "{yyyy}-{MM}-{dd} " + Ac.hour, minute: "{yyyy}-{MM}-{dd} " + Ac.minute, second: "{yyyy}-{MM}-{dd} " + Ac.second, millisecond: Ac.none } , Pc = ["year", "month", "day", "hour", "minute", "second", "millisecond"] , Oc = ["year", "half-year", "quarter", "month", "week", "half-week", "day", "half-day", "quarter-day", "hour", "minute", "second", "millisecond"]; function Rc(t, e) { return "0000".substr(0, e - (t += "").length) + t } function Nc(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 Ec(t) { return t === Nc(t) } function zc(t, e, n, i) { var r = jr(t) , o = r[Fc(n)]() , a = r[Gc(n)]() + 1 , s = Math.floor((a - 1) / 4) + 1 , l = r[Wc(n)]() , u = r["get" + (n ? "UTC" : "") + "Day"]() , h = r[Hc(n)]() , c = (h - 1) % 12 + 1 , p = r[Yc(n)]() , d = r[Uc(n)]() , f = r[Xc(n)]() , g = (i instanceof pc ? i : Sc(i || bc) || _c.EN).getModel("time") , y = g.get("month") , v = g.get("monthAbbr") , m = g.get("dayOfWeek") , x = g.get("dayOfWeekAbbr"); return (e || "").replace(/{yyyy}/g, o + "").replace(/{yy}/g, o % 100 + "").replace(/{Q}/g, s + "").replace(/{MMMM}/g, y[a - 1]).replace(/{MMM}/g, v[a - 1]).replace(/{MM}/g, Rc(a, 2)).replace(/{M}/g, a + "").replace(/{dd}/g, Rc(l, 2)).replace(/{d}/g, l + "").replace(/{eeee}/g, m[u]).replace(/{ee}/g, x[u]).replace(/{e}/g, u + "").replace(/{HH}/g, Rc(h, 2)).replace(/{H}/g, h + "").replace(/{hh}/g, Rc(c + "", 2)).replace(/{h}/g, c + "").replace(/{mm}/g, Rc(p, 2)).replace(/{m}/g, p + "").replace(/{ss}/g, Rc(d, 2)).replace(/{s}/g, d + "").replace(/{SSS}/g, Rc(f, 3)).replace(/{S}/g, f + "") } function Vc(t, e) { var n = jr(t) , i = n[Gc(e)]() + 1 , r = n[Wc(e)]() , o = n[Hc(e)]() , a = n[Yc(e)]() , s = n[Uc(e)]() , l = 0 === n[Xc(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 Bc(t, e, n) { var i = j(t) ? jr(t) : t; switch (e = e || Vc(t, n)) { case "year": return i[Fc(n)](); case "half-year": return i[Gc(n)]() >= 6 ? 1 : 0; case "quarter": return Math.floor((i[Gc(n)]() + 1) / 4); case "month": return i[Gc(n)](); case "day": return i[Wc(n)](); case "half-day": return i[Hc(n)]() / 24; case "hour": return i[Hc(n)](); case "minute": return i[Yc(n)](); case "second": return i[Uc(n)](); case "millisecond": return i[Xc(n)]() } } function Fc(t) { return t ? "getUTCFullYear" : "getFullYear" } function Gc(t) { return t ? "getUTCMonth" : "getMonth" } function Wc(t) { return t ? "getUTCDate" : "getDate" } function Hc(t) { return t ? "getUTCHours" : "getHours" } function Yc(t) { return t ? "getUTCMinutes" : "getMinutes" } function Uc(t) { return t ? "getUTCSeconds" : "getSeconds" } function Xc(t) { return t ? "getUTCMilliseconds" : "getMilliseconds" } function Zc(t) { return t ? "setUTCFullYear" : "setFullYear" } function jc(t) { return t ? "setUTCMonth" : "setMonth" } function qc(t) { return t ? "setUTCDate" : "setDate" } function Kc(t) { return t ? "setUTCHours" : "setHours" } function $c(t) { return t ? "setUTCMinutes" : "setMinutes" } function Jc(t) { return t ? "setUTCSeconds" : "setSeconds" } function Qc(t) { return t ? "setUTCMilliseconds" : "setMilliseconds" } function tp(t) { if (!eo(t)) return X(t) ? t : "-"; var e = (t + "").split("."); return e[0].replace(/(\d{1,3})(?=(?:\d{3})+(?!\d))/g, "$1,") + (e.length > 1 ? "." + e[1] : "") } function ep(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 np = st , ip = /([&<>"'])/g , rp = { "&": "&", "<": "<", ">": ">", '"': """, "'": "'" }; function op(t) { return null == t ? "" : (t + "").replace(ip, (function (t, e) { return rp[e] } )) } function ap(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 ? jr(t) : t; if (!isNaN(+s)) return zc(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 = to(t); return r(l) ? tp(l) : Z(t) ? i(t) : "boolean" == typeof t ? t + "" : "-" } var sp = ["a", "b", "c", "d", "e", "f", "g"] , lp = function (t, e) { return "{" + t + (null == e ? "" : e) + "}" }; function up(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 = sp[o]; t = t.replace(lp(a), lp(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(lp(sp[l], s), n ? op(u) : u) } return t } function hp(t, e) { var n = X(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 cp(t, e) { return e = e || "transparent", X(t) ? t : q(t) && t.colorStops && (t.colorStops[0] || {}).color || e } function pp(t, e) { if ("_blank" === e || "blank" === e) { var n = window.open(); n.opener = null, n.location.href = t } else window.open(t, e) } var dp = E , fp = ["left", "right", "top", "bottom", "width", "height"] , gp = [["width", "left", "right"], ["height", "top", "bottom"]]; function yp(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 vp = yp; H(yp, "vertical"), H(yp, "horizontal"); function mp(t, e, n) { n = np(n || 0); var i = e.width , r = e.height , o = Er(t.left, i) , a = Er(t.top, r) , s = Er(t.right, i) , l = Er(t.bottom, r) , u = Er(t.width, i) , h = Er(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 = .8 * i : h = .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 sr(o + n[3], a + n[0], u, h); return f.margin = n, f } function xp(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 sr(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 = mp(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 _p(t) { var e = t.layoutMode || t.constructor.layoutMode; return q(e) ? e : e ? { type: e } : null } function bp(t, e, n) { var i = n && n.ignoreSize; !Y(i) && (i = [i, i]); var r = a(gp[0], 0) , o = a(gp[1], 1); function a(n, r) { var o = {} , a = 0 , u = {} , h = 0; if (dp(n, (function (e) { u[e] = t[e] } )), dp(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) { dp(t, (function (t) { e[t] = n[t] } )) } u(gp[0], t, r), u(gp[1], t, o) } function wp(t) { return Sp({}, t) } function Sp(t, e) { return e && t && dp(fp, (function (n) { e.hasOwnProperty(n) && (t[n] = e[n]) } )), t } var Mp = So() , Ip = function (t) { function e(e, n, i) { var r = t.call(this, e, n, i) || this; return r.uid = fc("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 = _p(this) , i = n ? wp(t) : {}; C(t, e.getTheme().get(this.mainType)), C(t, this.getDefaultOption()), n && bp(t, i, n) } , e.prototype.mergeOption = function (t, e) { C(this.option, t, !0); var n = _p(this); n && bp(this.option, t, n) } , e.prototype.optionUpdated = function (t, e) { } , e.prototype.getDefaultOption = function () { var t = this.constructor; if (!function (t) { return !(!t || !t[Ro]) }(t)) return t.defaultOption; var e = Mp(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 Ao(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 }(pc); zo(Ip, pc), Go(Ip), function (t) { var e = {}; t.registerSubTypeDefaulter = function (t, n) { var i = No(t); e[i.main] = n } , t.determineSubType = function (n, i) { var r = i.type; if (!r) { var o = No(n).main; t.hasSubTypes(n) && e[o] && (r = e[o](i)) } return r } }(Ip), 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) } } }(Ip, (function (t) { var e = []; E(Ip.getClassesByMainType(t), (function (t) { e = e.concat(t.dependencies || t.prototype.dependencies || []) } )), e = z(e, (function (t) { return No(t).main } )), "dataset" !== t && P(e, "dataset") <= 0 && e.unshift("dataset"); return e } )); var Tp = ""; "undefined" != typeof navigator && (Tp = navigator.platform || ""); var Cp = "rgba(0, 0, 0, 0.2)" , Dp = { darkMode: "auto", colorBy: "series", color: ["#5470c6", "#91cc75", "#fac858", "#ee6666", "#73c0de", "#3ba272", "#fc8452", "#9a60b4", "#ea7ccc"], gradientColor: ["#f6efa6", "#d88273", "#bf444c"], aria: { decal: { decals: [{ color: Cp, dashArrayX: [1, 0], dashArrayY: [2, 5], symbolSize: 1, rotation: Math.PI / 6 }, { color: Cp, symbol: "circle", dashArrayX: [[8, 8], [0, 8, 8, 0]], dashArrayY: [6, 0], symbolSize: .8 }, { color: Cp, dashArrayX: [1, 0], dashArrayY: [4, 3], rotation: -Math.PI / 4 }, { color: Cp, dashArrayX: [[6, 6], [0, 6, 6, 0]], dashArrayY: [6, 0] }, { color: Cp, dashArrayX: [[1, 0], [1, 6]], dashArrayY: [1, 0, 6, 0], rotation: Math.PI / 4 }, { color: Cp, symbol: "triangle", dashArrayX: [[9, 9], [0, 9, 9, 0]], dashArrayY: [7, 2], symbolSize: .75 }] } }, textStyle: { fontFamily: Tp.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 } , Ap = ft(["tooltip", "label", "itemName", "itemId", "itemGroupId", "seriesName"]) , kp = "original" , Lp = "arrayRows" , Pp = "objectRows" , Op = "keyedColumns" , Rp = "typedArray" , Np = "unknown" , Ep = "column" , zp = "row" , Vp = 1 , Bp = 2 , Fp = 3 , Gp = So(); function Wp(t, e, n) { var i = {} , r = Yp(e); if (!r || !t) return i; var o, a, s = [], l = [], u = e.ecModel, h = Gp(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 Hp(t, e, n) { var i = {}; if (!Yp(t)) return i; var r, o = e.sourceFormat, a = e.dimensionsDefine; o !== Pp && o !== Op || 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 = Xp(e.data, o, e.seriesLayoutBy, a, e.startIndex, l); s.push(h); var c = h === Fp; if (c && null == t.v && l !== r && (t.v = l), (null == t.n || t.n === t.v || !c && s[t.n] === Fp) && (t.n = l), p(t) && s[t.n] !== Fp) return t; c || (h === Bp && 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 Yp(t) { if (!t.get("data", !0)) return Ao(t.ecModel, "dataset", { index: t.get("datasetIndex", !0), id: t.get("datasetId", !0) }, Co).models[0] } function Up(t, e) { return Xp(t.data, t.sourceFormat, t.seriesLayoutBy, t.dimensionsDefine, t.startIndex, e) } function Xp(t, e, n, i, r, o) { var a, s, l; if ($(t)) return Fp; if (i) { var u = i[o]; q(u) ? (s = u.name, l = u.type) : X(u) && (s = u) } if (null != l) return "ordinal" === l ? Vp : Fp; if (e === Lp) { var h = t; if (n === zp) { 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 === Pp) { var f = t; if (!s) return Fp; for (p = 0; p < f.length && p < 5; p++) { if ((y = f[p]) && null != (a = m(y[s]))) return a } } else if (e === Op) { if (!s) return Fp; if (!(c = t[s]) || $(c)) return Fp; for (p = 0; p < c.length && p < 5; p++) if (null != (a = m(c[p]))) return a } else if (e === kp) { var g = t; for (p = 0; p < g.length && p < 5; p++) { var y, v = fo(y = g[p]); if (!Y(v)) return Fp; if (null != (a = m(v[o]))) return a } } function m(t) { var e = X(t); return null != t && isFinite(t) && "" !== t ? e ? Bp : Fp : e && "-" !== t ? Vp : void 0 } return Fp } var Zp = ft(); var jp, qp, Kp, $p = So(), Jp = So(), Qp = function () { function t() { } return t.prototype.getColorFromPalette = function (t, e, n) { var i = ho(this.get("color", !0)) , r = this.get("colorLayer", !0); return ed(this, $p, i, r, t, e, n) } , t.prototype.clearColorPalette = function () { !function (t, e) { e(t).paletteIdx = 0, e(t).paletteNameMap = {} }(this, $p) } , t }(); function td(t, e, n, i) { var r = ho(t.get(["aria", "decal", "decals"])); return ed(t, Jp, r, null, e, n, i) } function ed(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 nd = 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 pc(i), this._locale = new pc(r), this._optionManager = o } , e.prototype.setOption = function (t, e, n) { var i = od(e); this._optionManager.setOption(t, n, i), this._resetOption(null, i) } , e.prototype.resetOption = function (t, e) { return this._resetOption(t, od(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)) : Kp(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 = ft() , s = e && e.replaceMergeMainTypeMap; Gp(this).datasetMap = ft(), E(t, (function (t, e) { null != t && (Ip.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) { Ip.hasClass(e) && !a.get(e) && (o.push(e), a.set(e, !0)) } )), Ip.topologicalTravel(o, Ip.getAllClassMainTypes(), (function (e) { var o = function (t, e, n) { var i = Zp.get(e); if (!i) return n; var r = i(t); return r ? n.concat(r) : n }(this, e, ho(t[e])) , a = i.get(e) , l = a ? s && s.get(e) ? "replaceMerge" : "normalMerge" : "replaceAll" , u = yo(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, Ip), 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 = Ip.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 && jp(this) } ), this), this._seriesIndices || jp(this) } , e.prototype.getOption = function () { var t = T(this.option); return E(t, (function (e, n) { if (Ip.hasClass(n)) { for (var i = ho(e), r = i.length, o = !1, a = r - 1; a >= 0; a--) i[a] && !bo(i[a]) ? o = !0 : (i[a] = null, !o && r--); i.length = r, t[n] = i } } )), delete t["\0_ec_inner"], 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(ho(i), (function (t) { a[t] && n.push(a[t]) } ))) : n = null != r ? id("id", r, a) : null != o ? id("name", o, a) : B(a, (function (t) { return !!t } )), rd(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 = rd(u, t), t.filter ? B(o, t.filter) : o } , e.prototype.eachComponent = function (t, e, n) { var i = this._componentsMap; if (U(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 = X(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 = xo(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) { qp(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) { qp(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 qp(this), null == this._seriesIndicesMap.get(t.componentIndex) } , e.prototype.getCurrentSeriesIndices = function () { return (this._seriesIndices || []).slice() } , e.prototype.filterSeries = function (t, e) { qp(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 = ft(n) } , e.prototype.restoreData = function (t) { jp(this); var e = this._componentsMap , n = []; e.each((function (t, e) { Ip.hasClass(e) && n.push(e) } )), Ip.topologicalTravel(n, Ip.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 = (jp = function (t) { var e = t._seriesIndices = []; E(t._componentsMap.get("series"), (function (t) { t && e.push(t.componentIndex) } )), t._seriesIndicesMap = ft(e) } , qp = function (t) { } , void (Kp = function (t, e) { t.option = {}, t.option["\0_ec_inner"] = 1, t._componentsMap = ft({ series: [] }), t._componentsCount = ft(); 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 || Ip.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, Dp, !1), t._mergeOption(e, null) } )), e }(pc); function id(t, e, n) { if (Y(e)) { var i = ft(); return E(e, (function (t) { null != t && (null != xo(t, null) && i.set(t, !0)) } )), B(n, (function (e) { return e && i.get(e[t]) } )) } var r = xo(e, null); return B(n, (function (e) { return e && null != r && e[t] === r } )) } function rd(t, e) { return e.hasOwnProperty("subType") ? B(t, (function (t) { return t && t.subType === e.subType } )) : t } function od(t) { var e = ft(); return t && E(ho(t.replaceMerge), (function (t) { e.set(t, !0) } )), { replaceMergeMainTypeMap: e } } R(nd, Qp); var ad = ["getDom", "getZr", "getWidth", "getHeight", "getDevicePixelRatio", "dispatchAction", "isSSR", "isDisposed", "on", "off", "getDataURL", "getConnectedDataURL", "getOption", "getId", "updateLabelLayout"] , sd = function (t) { E(ad, (function (e) { this[e] = W(t[e], t) } ), this) } , ld = {} , ud = function () { function t() { this._coordinateSystems = [] } return t.prototype.create = function (t, e) { var n = []; E(ld, (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) { ld[t] = e } , t.get = function (t) { return ld[t] } , t }() , hd = /^(min|max)?(.+)$/ , cd = function () { function t(t) { this._timelineOptions = [], this._mediaList = [], this._currentMediaIndices = [], this._api = t } return t.prototype.setOption = function (t, e, n) { t && (E(ho(t.series), (function (t) { t && t.data && $(t.data) && ct(t.data) } )), E(ho(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++) pd(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 pd(t, e, n) { var i = { width: e, height: n, aspectratio: e / n } , r = !0; return E(t, (function (t, e) { var n = e.match(hd); 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 dd = E , fd = q , gd = ["areaStyle", "lineStyle", "nodeStyle", "linkStyle", "chordStyle", "label", "labelLine"]; function yd(t) { var e = t && t.itemStyle; if (e) for (var n = 0, i = gd.length; n < i; n++) { var r = gd[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 vd(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 md(t) { vd(t, "itemStyle"), vd(t, "lineStyle"), vd(t, "areaStyle"), vd(t, "label"), vd(t, "labelLine"), vd(t, "upperLabel"), vd(t, "edgeLabel") } function xd(t, e) { var n = fd(t) && t[e] , i = fd(n) && n.textStyle; if (i) { 0; for (var r = 0, o = po.length; r < o; r++) { var a = po[r]; i.hasOwnProperty(a) && (n[a] = i[a]) } } } function _d(t) { t && (md(t), xd(t, "label"), t.emphasis && xd(t.emphasis, "label")) } function bd(t) { return Y(t) ? t : t ? [t] : [] } function wd(t) { return (Y(t) ? t[0] : t) || {} } function Sd(t, e) { dd(bd(t.series), (function (t) { fd(t) && function (t) { if (fd(t)) { yd(t), md(t), xd(t, "label"), xd(t, "upperLabel"), xd(t, "edgeLabel"), t.emphasis && (xd(t.emphasis, "label"), xd(t.emphasis, "upperLabel"), xd(t.emphasis, "edgeLabel")); var e = t.markPoint; e && (yd(e), _d(e)); var n = t.markLine; n && (yd(n), _d(n)); var i = t.markArea; i && _d(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++) _d(o[a]); E(t.categories, (function (t) { md(t) } )) } if (r && !$(r)) for (a = 0; a < r.length; a++) _d(r[a]); if ((e = t.markPoint) && e.data) { var s = e.data; for (a = 0; a < s.length; a++) _d(s[a]) } if ((n = t.markLine) && n.data) { var l = n.data; for (a = 0; a < l.length; a++) Y(l[a]) ? (_d(l[a][0]), _d(l[a][1])) : _d(l[a]) } "gauge" === t.type ? (xd(t, "axisLabel"), xd(t, "title"), xd(t, "detail")) : "treemap" === t.type ? (vd(t.breadcrumb, "itemStyle"), E(t.levels, (function (t) { md(t) } ))) : "tree" === t.type && md(t.leaves) } }(t) } )); var n = ["xAxis", "yAxis", "radiusAxis", "angleAxis", "singleAxis", "parallelAxis", "radar"]; e && n.push("valueAxis", "categoryAxis", "logAxis", "timeAxis"), dd(n, (function (e) { dd(bd(t[e]), (function (t) { t && (xd(t, "axisLabel"), xd(t.axisPointer, "label")) } )) } )), dd(bd(t.parallel), (function (t) { var e = t && t.parallelAxisDefault; xd(e, "axisLabel"), xd(e && e.axisPointer, "label") } )), dd(bd(t.calendar), (function (t) { vd(t, "itemStyle"), xd(t, "dayLabel"), xd(t, "monthLabel"), xd(t, "yearLabel") } )), dd(bd(t.radar), (function (t) { xd(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) } )), dd(bd(t.geo), (function (t) { fd(t) && (_d(t), dd(bd(t.regions), (function (t) { _d(t) } ))) } )), dd(bd(t.timeline), (function (t) { _d(t), vd(t, "label"), vd(t, "itemStyle"), vd(t, "controlStyle", !0); var e = t.data; Y(e) && E(e, (function (t) { q(t) && (vd(t, "label"), vd(t, "itemStyle")) } )) } )), dd(bd(t.toolbox), (function (t) { vd(t, "iconStyle"), dd(t.feature, (function (t) { vd(t, "iconStyle") } )) } )), xd(wd(t.axisPointer), "label"), xd(wd(t.tooltip).axisPointer, "label") } function Md(t) { t && E(Id, (function (e) { e[0] in t && !(e[1] in t) && (t[e[1]] = t[e[0]]) } )) } var Id = [["x", "left"], ["y", "top"], ["x2", "right"], ["y2", "bottom"]] , Td = ["grid", "geo", "parallel", "legend", "toolbox", "title", "visualMap", "dataZoom", "timeline"] , Cd = [["borderRadius", "barBorderRadius"], ["borderColor", "barBorderColor"], ["borderWidth", "barBorderWidth"]]; function Dd(t) { var e = t && t.itemStyle; if (e) for (var n = 0; n < Cd.length; n++) { var i = Cd[n][1] , r = Cd[n][0]; null != e[i] && (e[r] = e[i]) } } function Ad(t) { t && "edge" === t.alignTo && null != t.margin && null == t.edgeDistance && (t.edgeDistance = t.margin) } function kd(t) { t && t.downplay && !t.blur && (t.blur = t.downplay) } function Ld(t, e) { if (t) for (var n = 0; n < t.length; n++) e(t[n]), t[n] && Ld(t[n].children, e) } function Pd(t, e) { Sd(t, e), t.series = ho(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), Ad(t.label), (r = t.data) && !$(r)) for (var n = 0; n < r.length; n++) Ad(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 (Dd(t), Dd(t.backgroundStyle), Dd(t.emphasis), (r = t.data) && !$(r)) for (n = 0; n < r.length; n++) "object" == typeof r[n] && (Dd(r[n]), Dd(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)), kd(t), Ld(t.data, kd) } 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)), Md(t) } } )), t.dataRange && (t.visualMap = t.dataRange), E(Td, (function (e) { var n = t[e]; n && (Y(n) || (n = [n]), E(n, (function (t) { Md(t) } ))) } )) } function Od(t) { E(t, (function (e, n) { var i = [] , r = [NaN, NaN] , o = [e.stackResultDimension, e.stackedOverDimension] , a = e.data , s = e.isStackedByIndex; a.modify(o, (function (o, l, u) { var h, c, p = a.get(e.stackedDimension, u); if (isNaN(p)) return r; s ? c = a.getRawIndex(u) : h = a.get(e.stackedByDimension, u); for (var d = NaN, f = n - 1; f >= 0; f--) { var g = t[f]; if (s || (c = g.data.rawIndexOf(g.stackedByDimension, h)), c >= 0) { var y = g.data.getByRawIndex(g.stackResultDimension, c); if (p >= 0 && y > 0 || p <= 0 && y < 0) { p = Hr(p, y), d = y; break } } } return i[0] = p, i[1] = d, i } )) } )) } var Rd, Nd, Ed, zd, Vd, Bd = function (t) { this.data = t.data || (t.sourceFormat === Op ? {} : []), this.sourceFormat = t.sourceFormat || Np, this.seriesLayoutBy = t.seriesLayoutBy || Ep, 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 && Up(this, n) === Vp && (i.type = "ordinal") } }; function Fd(t) { return t instanceof Bd } function Gd(t, e, n) { n = n || Hd(t); var i = e.seriesLayoutBy , r = function (t, e, n, i, r) { var o, a; if (!t) return { dimensionsDefine: Yd(r), startIndex: a, dimensionsDetectedCount: o }; if (e === Lp) { var s = t; "auto" === i || null == i ? Ud((function (t) { null != t && "-" !== t && (X(t) ? null == a && (a = 1) : a = 0) } ), n, s, 10) : a = j(i) ? i : i ? 1 : 0, r || 1 !== a || (r = [], Ud((function (t, e) { r[e] = null != t ? t + "" : "" } ), n, s, 1 / 0)), o = r ? r.length : n === zp ? s.length : s[0] ? s[0].length : null } else if (e === Pp) r || (r = function (t) { var e, n = 0; for (; n < t.length && !(e = t[n++]);) ; if (e) { var i = []; return E(e, (function (t, e) { i.push(e) } )), i } }(t)); else if (e === Op) r || (r = [], E(t, (function (t, e) { r.push(e) } ))); else if (e === kp) { var l = fo(t[0]); o = Y(l) && l.length || 1 } return { startIndex: a, dimensionsDefine: Yd(r), dimensionsDetectedCount: o } }(t, n, i, e.sourceHeader, e.dimensions); return new Bd({ data: t, sourceFormat: n, seriesLayoutBy: i, dimensionsDefine: r.dimensionsDefine, startIndex: r.startIndex, dimensionsDetectedCount: r.dimensionsDetectedCount, metaRawOption: T(e) }) } function Wd(t) { return new Bd({ data: t, sourceFormat: $(t) ? Rp : kp }) } function Hd(t) { var e = Np; if ($(t)) e = Rp; else if (Y(t)) { 0 === t.length && (e = Lp); for (var n = 0, i = t.length; n < i; n++) { var r = t[n]; if (null != r) { if (Y(r)) { e = Lp; break } if (q(r)) { e = Pp; break } } } } else if (q(t)) for (var o in t) if (mt(t, o) && N(t[o])) { e = Op; break } return e } function Yd(t) { if (t) { var e = ft(); 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 Ud(t, e, n, i) { if (e === zp) 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 Xd(t) { var e = t.sourceFormat; return e === Pp || e === Op } var Zd = function () { function t(t, e) { var n = Fd(t) ? t : Wd(t); this._source = n; var i = this._data = n.data; n.sourceFormat === Rp && (this._offset = 0, this._dimSize = e, this._data = i), Vd(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; Vd = function (t, r, o) { var a = o.sourceFormat , s = o.seriesLayoutBy , l = o.startIndex , u = o.dimensionsDefine , h = zd[rf(a, s)]; if (A(t, h), a === Rp) t.getItem = e, t.count = i, t.fillStorage = n; else { var c = Kd(a, s); t.getItem = W(c, null, r, l, u); var p = Qd(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 = {}).arrayRows_column = { pure: !0, appendData: r }, t.arrayRows_row = { pure: !0, appendData: function () { throw new Error('Do not support appendData when set seriesLayoutBy: "row".') } }, t.objectRows = { pure: !0, appendData: r }, t.keyedColumns = { 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.original = { appendData: r }, t.typedArray = { persistent: !1, pure: !0, appendData: function (t) { this._data = t }, clean: function () { this._offset += this.count(), this._data = null } }, zd = t }(), t }() , jd = function (t, e, n, i) { return t[i] } , qd = ((Rd = {}).arrayRows_column = function (t, e, n, i) { return t[i + e] } , Rd.arrayRows_row = 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 } , Rd.objectRows = jd, Rd.keyedColumns = 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 } , Rd.original = jd, Rd); function Kd(t, e) { var n = qd[rf(t, e)]; return n } var $d = function (t, e, n) { return t.length } , Jd = ((Nd = {}).arrayRows_column = function (t, e, n) { return Math.max(0, t.length - e) } , Nd.arrayRows_row = function (t, e, n) { var i = t[0]; return i ? Math.max(0, i.length - e) : 0 } , Nd.objectRows = $d, Nd.keyedColumns = function (t, e, n) { var i = n[0].name; var r = t[i]; return r ? r.length : 0 } , Nd.original = $d, Nd); function Qd(t, e) { var n = Jd[rf(t, e)]; return n } var tf = function (t, e, n) { return t[e] } , ef = ((Ed = {}).arrayRows = tf, Ed.objectRows = function (t, e, n) { return t[n] } , Ed.keyedColumns = tf, Ed.original = function (t, e, n) { var i = fo(t); return i instanceof Array ? i[e] : i } , Ed.typedArray = tf, Ed); function nf(t) { var e = ef[t]; return e } function rf(t, e) { return t === Lp ? t + "_" + e : t } function of(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 nf(o)(i, a, s) } var l = i; return o === kp && (l = fo(i)), l } } } var af = /\{@(.+?)\}/g , sf = 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 U(r) ? (s.status = e, s.dimensionIndex = i, r(s)) : X(r) ? up(r, s).replace(af, (function (e, n) { var i = n.length , r = n; "[" === r.charAt(0) && "]" === r.charAt(i - 1) && (r = +r.slice(1, i - 1)); var s = of(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 of(this.getData(e), t) } , t.prototype.formatTooltip = function (t, e, n) { } , t }(); function lf(t) { var e, n; return q(t) ? t.type && (n = t) : e = t, { text: e, frag: n } } function uf(t) { return new hf(t) } var hf = 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) { cf.reset(e, n, i, r), this._callingProgress = t, this._callingProgress({ start: e, end: n, count: n - e, next: cf.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 }() , cf = 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 pf(t, e) { var n = e && e.type; return "ordinal" === n ? t : ("time" !== n || j(t) || null == t || "-" === t || (t = +jr(t)), null == t || "" === t ? NaN : +t) } var df = ft({ number: function (t) { return parseFloat(t) }, time: function (t) { return +jr(t) }, trim: function (t) { return X(t) ? ut(t) : t } }); function ff(t) { return df.get(t) } var gf = { 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 } } , yf = function () { function t(t, e) { if (!j(e)) { var n = ""; 0, ao(n) } this._opFn = gf[t], this._rvalFloat = to(e) } return t.prototype.evaluate = function (t) { return j(t) ? this._opFn(t, this._rvalFloat) : this._opFn(to(t), this._rvalFloat) } , t }() , vf = 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 : to(t) , i = j(e) ? e : to(e) , r = isNaN(n) , o = isNaN(i); if (r && (n = this._incomparable), o && (i = this._incomparable), r && o) { var a = X(t) , s = X(e); a && (n = s ? t : 0), s && (i = a ? e : 0) } return n < i ? this._resultLT : n > i ? -this._resultLT : 0 } , t }() , mf = function () { function t(t, e) { this._rval = e, this._isEQ = t, this._rvalTypeof = typeof e, this._rvalFloat = to(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 = to(t) === this._rvalFloat) } return this._isEQ ? e : !e } , t }(); function xf(t, e) { return "eq" === t || "ne" === t ? new mf("eq" === t, e) : mt(gf, t) ? new yf(t, e) : null } var _f = 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 pf(t, e) } , t }(); function bf(t) { var e = t.sourceFormat; if (!Cf(e)) { var n = ""; 0, ao(n) } return t.data } function wf(t) { var e = t.sourceFormat , n = t.data; if (!Cf(e)) { var i = ""; 0, ao(i) } if (e === Lp) { for (var r = [], o = 0, a = n.length; o < a; o++) r.push(n[o].slice()); return r } if (e === Pp) { for (r = [], o = 0, a = n.length; o < a; o++) r.push(A({}, n[o])); return r } } function Sf(t, e, n) { if (null != n) return j(n) || !isNaN(n) && !mt(e, n) ? t[n] : mt(e, n) ? e[n] : void 0 } function Mf(t) { return T(t) } var If = ft(); function Tf(t, e, n, i) { var r = ""; e.length || ao(r), q(t) || ao(r); var o = t.type , a = If.get(o); a || ao(r); var s = z(e, (function (t) { return function (t, e) { var n = new _f , i = t.data , r = n.sourceFormat = t.sourceFormat , o = t.startIndex , a = ""; t.seriesLayoutBy !== Ep && ao(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 = ""; mt(l, n) && ao(r), l[n] = i } } )); else for (var h = 0; h < t.dimensionsDetectedCount; h++) s.push({ index: h }); var c = Kd(r, Ep); e.__isBuiltIn && (n.getRawDataItem = function (t) { return c(i, o, s, t) } , n.getRawData = W(bf, null, t)), n.cloneRawData = W(wf, null, t); var p = Qd(r, Ep); n.count = W(p, null, i, o, s); var d = nf(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(Sf, null, s, l), n.cloneAllDimensionInfo = W(Mf, null, s), n }(t, a) } )) , l = ho(a.transform({ upstream: s[0], upstreamList: s, config: T(t.config) })); return z(l, (function (t, n) { var i, r = ""; q(t) || ao(r), t.data || ao(r), Cf(Hd(t.data)) || ao(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: Ep, sourceHeader: a, dimensions: o.metaRawOption.dimensions } } else i = { seriesLayoutBy: Ep, sourceHeader: 0, dimensions: t.dimensions }; return Gd(t.data, i, null) } )) } function Cf(t) { return t === Lp || t === Pp } var Df, Af = "undefined", kf = typeof Uint32Array === Af ? Array : Uint32Array, Lf = typeof Uint16Array === Af ? Array : Uint16Array, Pf = typeof Int32Array === Af ? Array : Int32Array, Of = typeof Float64Array === Af ? Array : Float64Array, Rf = { float: Of, int: Pf, ordinal: Array, number: Array, time: Of }; function Nf(t) { return t > 65535 ? kf : Lf } function Ef(t, e, n, i, r) { var o = Rf[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 zf = function () { function t() { this._chunks = [], this._rawExtent = [], this._extent = [], this._count = 0, this._rawCount = 0, this._calcDimNameToIdx = ft() } 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 = Df[i.sourceFormat]; this._dimValueGetter = n || r, this._rawExtent = []; Xd(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 Rf[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]); 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++) { Ef(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 = Df.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]), Ef(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 = Nf(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 (Nf(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 (Nf(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 (Nf(this._rawCount))(Math.ceil(s / u) + 2); 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[S = 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; for (v = x; v < _; v++) { var S; m = a[S = this.getRawIndex(v)]; isNaN(m) || (i = Math.abs((b - g) * (m - w) - (b - v) * (y - w))) > n && (n = i, r = S) } 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.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 (Nf(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 pf(t[i], this._dimensions[i]) } Df = { arrayRows: t, objectRows: function (t, e, n, i) { return pf(t[e], this._dimensions[i]) }, keyedColumns: t, original: function (t, e, n, i) { var r = t && (null == t.value ? t : t.value); return pf(r instanceof Array ? r[i] : r, this._dimensions[i]) }, typedArray: function (t, e, n, i) { return t[i] } } }(), t }() , Vf = 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 (Ff(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)) ? Rp : kp, 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 ? [Gd(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 = [Gd(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 && Gf(o) } var a, s = [], l = []; return E(t, (function (t) { t.prepareSource(); var e = t.getSource(r || 0) , n = ""; null == r || e || Gf(n), s.push(e), l.push(t._getVersionSign()) } )), i ? e = function (t, e, n) { var i = ho(t) , r = i.length , o = ""; r || ao(o); for (var a = 0, s = r; a < s; a++) e = Tf(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 Bd({ 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]; Ff(this._sourceHost) && a ? o = a._innerGetDataStore(t, e, n) : (o = new zf).initData(new Zd(e, t.length), t), r[n] = o } return o } , t.prototype._getUpstreamSourceManagers = function () { var t = this._sourceHost; if (Ff(t)) { var e = Yp(t); return e ? [e.getSourceManager()] : [] } return z(function (t) { return t.get("transform", !0) || t.get("fromTransformResult", !0) ? Ao(t.ecModel, "dataset", { index: t.get("fromDatasetIndex", !0), id: t.get("fromDatasetId", !0) }, Co).models : [] }(t), (function (t) { return t.getSourceManager() } )) } , t.prototype._getSourceMetaRawOption = function () { var t, e, n, i = this._sourceHost; if (Ff(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 Bf(t) { t.option.transform && ct(t.option.transform) } function Ff(t) { return "series" === t.mainType } function Gf(t) { throw new Error(t) } function Wf(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:" + op(i + "") + "px;color:" + op(n) + ";font-weight:" + op(r + ""), valueStyle: "font-size:" + op(a + "") + "px;color:" + op(o) + ";font-weight:" + op(s + "") } : { nameStyle: { fontSize: i, fill: n, fontWeight: r }, valueStyle: { fontSize: a, fill: o, fontWeight: s } } } var Hf = [0, 10, 20, 30] , Yf = ["", "\n", "\n\n", "\n\n\n"]; function Uf(t, e) { return e.type = t, e } function Xf(t) { return "section" === t.type } function Zf(t) { return Xf(t) ? qf : Kf } function jf(t) { if (Xf(t)) { var e = 0 , n = t.blocks.length , i = n > 1 || n > 0 && !t.noHeader; return E(t.blocks, (function (t) { var n = jf(t); n >= e && (e = n + +(i && (!n || Xf(t) && !t.noHeader))) } )), e } return 0 } function qf(t, e, n, i) { var r, o = e.noHeader, a = (r = jf(e), { html: Hf[r], richText: Yf[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 (mt(h, u)) { var c = new vf(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 = Zf(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) : Jf(s.join(""), o ? n : a.html); if (o) return p; var d = ap(e.header, "ordinal", t.useUTC) , f = Wf(i, t.renderMode).nameStyle; return "richText" === t.renderMode ? Qf(t, d, f) + a.richText + p : Jf('
' + op(d) + "
" + p, n) } function Kf(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 ap(t, Y(d) ? d[e] : d, u) } )) } ; if (!o || !a) { var c = s ? "" : t.markupStyleCreator.makeTooltipMarker(e.markerType, e.markerColor || "#333", r) , p = o ? "" : ap(l, "ordinal", u) , d = e.valueType , f = a ? [] : h(e.value) , g = !s || !o , y = !s && o , v = Wf(i, r) , m = v.nameStyle , x = v.valueStyle; return "richText" === r ? (s ? "" : c) + (o ? "" : Qf(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)) : Jf((s ? "" : c) + (o ? "" : function (t, e, n) { return '' + op(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 op(t) } )).join("  ") + "" }(f, g, y, x)), n) } } function $f(t, e, n, i, r, o) { if (t) return Zf(t)({ useUTC: r, renderMode: n, orderMode: i, markupStyleCreator: e, valueFormatter: t.valueFormatter }, t, 0, o) } function Jf(t, e) { return '
' + t + '
' } function Qf(t, e, n) { return t.markupStyleCreator.wrapRichTextStyle(e, n) } function tg(t, e) { return cp(t.getData().getItemVisual(e, "style")[t.visualDrawType]) } function eg(t, e) { var n = t.get("padding"); return null != n ? n : "richText" === e ? [8, 10] : 10 } var ng = function () { function t() { this.richTextStyles = {}, this._nextStyleNameId = no() } 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 = hp({ color: e, type: t, renderMode: n, markerId: i }); return X(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 ig(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 = tg(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(Uf("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(of(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 = of(l, a, u[0]), n = g.type } else r = e = p ? c[0] : c; var y = _o(o) , v = y && o.name || "" , m = l.getName(a) , x = s ? v : m; return Uf("section", { header: v, noHeader: s || !y, sortParam: r, blocks: [Uf("nameValue", { markerType: "item", markerColor: d, name: x, noName: !ut(x), value: e, valueType: n })].concat(i || []) }) } var rg = So(); function og(t, e) { return t.getName(e) || t.getId(e) } var ag = 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 = uf({ count: lg, reset: ug }), this.dataTask.context = { model: this }, this.mergeDefaultAndTheme(t, n), (rg(this).sourceManager = new Vf(this)).prepareSource(); var i = this.getInitialData(t, n); cg(i, this), this.dataTask.context.data = i, rg(this).dataBeforeProcessed = i, sg(this), this._initSelectedMapFromData(i) } , e.prototype.mergeDefaultAndTheme = function (t, e) { var n = _p(this) , i = n ? wp(t) : {} , r = this.subType; Ip.hasClass(r) && (r += "Series"), C(t, e.getTheme().get(this.subType)), C(t, this.getDefaultOption()), co(t, "label", ["show"]), this.fillDataTextStyle(t.data), n && bp(t, i, n) } , e.prototype.mergeOption = function (t, e) { t = C(this.option, t, !0), this.fillDataTextStyle(t.data); var n = _p(this); n && bp(this.option, t, n); var i = rg(this).sourceManager; i.dirty(), i.prepareSource(); var r = this.getInitialData(t, e); cg(r, this), this.dataTask.dirty(), this.dataTask.context.data = r, rg(this).dataBeforeProcessed = r, sg(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 : n.getLinkedData(t) } return rg(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) } rg(this).data = t } , e.prototype.getEncode = function () { var t = this.get("encode", !0); if (t) return ft(t) } , e.prototype.getSourceManager = function () { return rg(this).sourceManager } , e.prototype.getSource = function () { return this.getSourceManager().getSource() } , e.prototype.getRawData = function () { return rg(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 ig({ 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 = Qp.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 = og(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[og(i, t)]) && !i.getItemModel(t).get(["select", "disabled"]) } , e.prototype.isUniversalTransitionEnabled = function () { if (this.__universalTransitionEnabled) 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 = og(t, u)] = !0, this._selectedDataIndicesMap[c] = t.getRawIndex(u) } } else if ("single" === o || !0 === o) { var h = e[a - 1] , c = og(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 Ip.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 }(Ip); function sg(t) { var e = t.name; _o(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 lg(t) { return t.model.getRawData().count() } function ug(t) { var e = t.model; return e.setData(e.getRawData().cloneShallow()), hg } function hg(t, e) { e.outputData && t.end > e.outputData.count() && e.model.getRawData().cloneShallow(e.outputData) } function cg(t, e) { E(gt(t.CHANGABLE_METHODS, t.DOWNSAMPLE_METHODS), (function (n) { t.wrapMethod(n, H(pg, e)) } )) } function pg(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(ag, sf), R(ag, Qp), zo(ag, Ip); var fg = function () { function t() { this.group = new Cr, this.uid = fc("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.blurSeries = function (t, e) { } , t.prototype.eachRendered = function (t) { var e = this.group; e && e.traverse(t) } , t }(); function gg() { var t = So(); 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" } } Eo(fg), Go(fg); var yg = So() , vg = gg() , mg = function () { function t() { this.group = new Cr, this.uid = fc("viewChart"), this.renderTask = uf({ plan: bg, reset: wg }), 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 && _g(r, i, "emphasis") } , t.prototype.downplay = function (t, e, n, i) { var r = t.getData(i && i.dataType); r && _g(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) { zh(this.group, t) } , t.markUpdateMethod = function (t, e) { yg(t).updateMethod = e } , t.protoInitialize = void (t.prototype.type = "chart"), t }(); function xg(t, e, n) { t && Bl(t) && ("emphasis" === e ? xl : _l)(t, n) } function _g(t, e, n) { var i = wo(t, e) , r = e && null != e.highlightKey ? function (t) { var e = Us[t]; return null == e && Ys <= 32 && (e = Us[t] = Ys++), e }(e.highlightKey) : null; null != i ? E(ho(i), (function (e) { xg(t.getItemGraphicEl(e), n, r) } )) : t.eachItemGraphicEl((function (t) { xg(t, n, r) } )) } function bg(t) { return vg(t.model) } function wg(t) { var e = t.model , n = t.ecModel , i = t.api , r = t.payload , o = e.pipelineContext.progressiveRender , a = t.view , s = r && yg(r).updateMethod , l = o ? "incrementalPrepareRender" : s && a[s] ? s : "render"; return "render" !== l && a[l](e, n, i, r), Sg[l] } Eo(mg), Go(mg); var Sg = { 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) } } } , Mg = "\0__throttleOriginMethod" , Ig = "\0__throttleRate" , Tg = "\0__throttleType"; function Cg(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 Dg(t, e, n, i) { var r = t[e]; if (r) { var o = r[Mg] || r , a = r[Tg]; if (r[Ig] !== n || a !== i) { if (null == n || !i) return t[e] = o; (r = t[e] = Cg(o, n, "debounce" === i))[Mg] = o, r[Tg] = i, r[Ig] = n } return r } } function Ag(t, e) { var n = t[e]; n && n[Mg] && (n.clear && n.clear(), t[e] = n[Mg]) } var kg = So() , Lg = { itemStyle: Wo(uc, !0), lineStyle: Wo(ac, !0) } , Pg = { lineStyle: "stroke", itemStyle: "fill" }; function Og(t, e) { var n = t.visualStyleMapper || Lg[e]; return n || (console.warn("Unkown style type '" + e + "'."), Lg.itemStyle) } function Rg(t, e) { var n = t.visualDrawType || Pg[e]; return n || (console.warn("Unkown style type '" + e + "'."), "fill") } var Ng = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { var n = t.getData() , i = t.visualStyleAccessPath || "itemStyle" , r = t.getModel(i) , o = Og(t, i)(r) , a = r.getShallow("decal"); a && (n.setVisual("decal", a), a.dirty = !0); var s = Rg(t, i) , l = o[s] , u = U(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 || U(o.fill) ? c : o.fill, o.stroke = "auto" === o.stroke || U(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) } } } } , Eg = new pc , zg = { createOnAllSeries: !0, performRawSeries: !0, reset: function (t, e) { if (!t.ignoreStyleOnData && !e.isSeriesFiltered(t)) { var n = t.getData() , i = t.visualStyleAccessPath || "itemStyle" , r = Og(t, i) , o = n.getVisual("drawType"); return { dataEach: n.hasItemOption ? function (t, e) { var n = t.getRawDataItem(e); if (n && n[i]) { Eg.option = n[i]; var a = r(Eg); A(t.ensureUniqueItemVisual(e, "style"), a), Eg.option.decal && (t.setItemVisual(e, "decal", Eg.option.decal), Eg.option.decal.dirty = !0), o in a && t.setItemVisual(e, "colorFromPalette", !1) } } : null } } } } , Vg = { performRawSeries: !0, overallReset: function (t) { var e = ft(); 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)), kg(t).scope = r } } )), t.eachSeries((function (e) { if (!e.isColorBySeries() && !t.isSeriesFiltered(e)) { var n = e.getRawData() , i = {} , r = e.getData() , o = kg(e).scope , a = e.visualStyleAccessPath || "itemStyle" , s = Rg(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) } } )) } } )) } } , Bg = Math.PI; var Fg = function () { function t(t, e, n, i) { this._stageTaskMap = ft(), 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 = ft(); 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 = ft() , s = t.seriesType , l = t.getTargetSeries; function u(e) { var s = e.uid , l = a.set(s, o && o.get(s) || uf({ plan: Ug, reset: Xg, count: qg })); 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 || uf({ reset: Gg }); o.context = { ecModel: n, api: i, overallReset: t.overallReset, scheduler: r }; var a = o.agentStubMap , s = o.agentStubMap = ft() , 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, uf({ reset: Wg, onDirty: Yg }))); 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 U(t) && (t = { overallReset: t, seriesType: Kg(t) }), t.uid = fc("stageHandler"), e && (t.visualType = e), t } , t }(); function Gg(t) { t.overallReset(t.ecModel, t.api, t.payload) } function Wg(t) { return t.overallProgress && Hg } function Hg() { this.agent.dirty(), this.getDownstream().dirty() } function Yg() { this.agent && this.agent.dirty() } function Ug(t) { return t.plan ? t.plan(t.model, t.ecModel, t.api, t.payload) : null } function Xg(t) { t.useClearVisual && t.data.clearAllVisual(); var e = t.resetDefines = ho(t.reset(t.model, t.ecModel, t.api, t.payload)); return e.length > 1 ? z(e, (function (t, e) { return jg(e) } )) : Zg } var Zg = jg(0); function jg(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 qg(t) { return t.data.count() } function Kg(t) { $g = null; try { t(Jg, Qg) } catch (t) { } return $g } var $g, Jg = {}, Qg = {}; function ty(t, e) { for (var n in e.prototype) t[n] = xt } ty(Jg, nd), ty(Qg, sd), Jg.eachSeriesByType = Jg.eachRawSeriesByType = function (t) { $g = t } , Jg.eachComponent = function (t) { "series" === t.mainType && t.subType && ($g = t.subType) } ; var ey = ["#37A2DA", "#32C5E9", "#67E0E3", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#E062AE", "#E690D1", "#e7bcf3", "#9d96f5", "#8378EA", "#96BFFF"] , ny = { color: ey, colorLayer: [["#37A2DA", "#ffd85c", "#fd7b5f"], ["#37A2DA", "#67E0E3", "#FFDB5C", "#ff9f7f", "#E062AE", "#9d96f5"], ["#37A2DA", "#32C5E9", "#9FE6B8", "#FFDB5C", "#ff9f7f", "#fb7293", "#e7bcf3", "#8378EA", "#96BFFF"], ey] } , iy = "#B9B8CE" , ry = "#100C2A" , oy = function () { return { axisLine: { lineStyle: { color: iy } }, splitLine: { lineStyle: { color: "#484753" } }, splitArea: { areaStyle: { color: ["rgba(255,255,255,0.02)", "rgba(255,255,255,0.05)"] } }, minorSplitLine: { lineStyle: { color: "#20203B" } } } } , ay = ["#4992ff", "#7cffb2", "#fddd60", "#ff6e76", "#58d9f9", "#05c091", "#ff8a45", "#8d48e3", "#dd79ff"] , sy = { darkMode: !0, color: ay, backgroundColor: ry, axisPointer: { lineStyle: { color: "#817f91" }, crossStyle: { color: "#817f91" }, label: { color: "#fff" } }, legend: { textStyle: { color: iy } }, textStyle: { color: iy }, title: { textStyle: { color: "#EEF1FA" }, subtextStyle: { color: "#B9B8CE" } }, toolbox: { iconStyle: { borderColor: iy } }, dataZoom: { borderColor: "#71708A", textStyle: { color: iy }, brushStyle: { color: "rgba(135,163,206,0.3)" }, handleStyle: { color: "#353450", borderColor: "#C5CBE3" }, moveHandleStyle: { color: "#B0B6C3", opacity: .3 }, fillerColor: "rgba(135,163,206,0.2)", emphasis: { handleStyle: { borderColor: "#91B7F2", color: "#4D587D" }, moveHandleStyle: { color: "#636D9A", opacity: .7 } }, dataBackground: { lineStyle: { color: "#71708A", width: 1 }, areaStyle: { color: "#71708A" } }, selectedDataBackground: { lineStyle: { color: "#87A3CE" }, areaStyle: { color: "#87A3CE" } } }, visualMap: { textStyle: { color: iy } }, timeline: { lineStyle: { color: iy }, label: { color: iy }, controlStyle: { color: iy, borderColor: iy } }, calendar: { itemStyle: { color: ry }, dayLabel: { color: iy }, monthLabel: { color: iy }, yearLabel: { color: iy } }, timeAxis: oy(), logAxis: oy(), valueAxis: oy(), categoryAxis: oy(), line: { symbol: "circle" }, graph: { color: ay }, gauge: { title: { color: iy }, axisLine: { lineStyle: { color: [[1, "rgba(207,212,219,0.2)"]] } }, axisLabel: { color: iy }, detail: { color: "#EEF1FA" } }, candlestick: { itemStyle: { color: "#f64e56", color0: "#54ea92", borderColor: "#f64e56", borderColor0: "#54ea92" } } }; sy.categoryAxis.splitLine.show = !1; var ly = function () { function t() { } return t.prototype.normalizeQuery = function (t) { var e = {} , n = {} , i = {}; if (X(t)) { var r = No(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 }() , uy = ["symbol", "symbolSize", "symbolRotate", "symbolOffset"] , hy = uy.concat(["symbolKeepAspect"]) , cy = { 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 < uy.length; a++) { var s = uy[a] , l = t.get(s); U(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 } } } } } , py = { 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 < hy.length; i++) { var r = hy[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); default: 0 } } function fy(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); default: 0 } } function gy(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); break; default: 0 } } function yy(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 vy(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 = wo(l, r.fromActionPayload); n.trigger(o, { type: o, seriesId: t.id, name: Y(u) ? l.getName(u[0]) : l.getName(u), selected: X(i) ? i : A({}, i) }) } } )) } function my(t, e, n) { for (var i; t && (!e(t) || (i = t, !n));) t = t.__hostTarget || t.parent; return i } var xy = Math.round(9 * Math.random()) , _y = "function" == typeof Object.defineProperty , by = function () { function t() { this._id = "__ec_inner_" + xy++ } return t.prototype.get = function (t) { return this._guard(t)[this._id] } , t.prototype.set = function (t, e) { var n = this._guard(t); return _y ? 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 }() , wy = fs.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() } }) , Sy = fs.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() } }) , My = fs.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 = .6 * a , f = .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() } }) , Iy = fs.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() } }) , Ty = { 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 } } , Cy = {}; E({ line: Eu, rect: Ts, roundRect: Ts, square: Ts, circle: uu, diamond: Sy, pin: My, arrow: Iy, triangle: wy }, (function (t, e) { Cy[e] = new t } )); var Dy = fs.extend({ type: "symbol", shape: { symbolType: "", x: 0, y: 0, width: 0, height: 0 }, calculateTextPosition: function (t, e, n) { var i = yr(t, e, n) , r = this.shape; return r && "pin" === r.symbolType && "inside" === e.position && (i.y = n.y + .4 * n.height), i }, buildPath: function (t, e, n) { var i = e.symbolType; if ("none" !== i) { var r = Cy[i]; r || (r = Cy[i = "rect"]), Ty[i](e.x, e.y, e.width, e.height, r.shape), r.buildPath(t, r.shape, n) } } }); function Ay(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 ky(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://") ? xh(t.slice(8), new sr(e, n, i, r), a ? "center" : "cover") : 0 === t.indexOf("path://") ? mh(t.slice(7), {}, new sr(e, n, i, r), a ? "center" : "cover") : new Dy({ shape: { symbolType: t, x: e, y: n, width: i, height: r } })).__isEmptyBrush = l, s.setColor = Ay, o && s.setColor(o), s } function Ly(t) { return Y(t) || (t = [+t, +t]), [t[0] || 0, t[1] || 0] } function Py(t, e) { if (null != t) return Y(t) || (t = [t, t]), [Er(t[0], e[0]) || 0, Er(rt(t[1], t[0]), e[1]) || 0] } function Oy(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 ? .5 : e.x , s = null == e.y ? .5 : e.y , l = null == e.r ? .5 : e.r; return e.global || (a = a * i + n.x, s = s * r + n.y, l *= o), 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 = isNaN(i) ? 0 : i, r = isNaN(r) ? 1 : r, o = isNaN(o) ? 0 : o, a = isNaN(a) ? 0 : a, 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 Ry(t) { return parseInt(t, 10) } function Ny(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] || Ry(s[i]) || Ry(t.style[i])) - (Ry(s[o]) || 0) - (Ry(s[a]) || 0) | 0 } function Ey(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 zy = new ja(!0); function Vy(t) { var e = t.stroke; return !(null == e || "none" === e || !(t.lineWidth > 0)) } function By(t) { return "string" == typeof t && "none" !== t } function Fy(t) { var e = t.fill; return null != e && "none" !== e } function Gy(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 Wy(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 Hy(t, e, n) { var i = Zo(e.image, e.__image, n); if (qo(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) * _t), o.scaleSelf(e.scaleX || 1, e.scaleY || 1), r.setTransform(o) } return r } } var Yy = ["shadowBlur", "shadowOffsetX", "shadowOffsetY"] , Uy = [["lineCap", "butt"], ["lineJoin", "miter"], ["miterLimit", 10]]; function Xy(t, e, n, i, r) { var o = !1; if (!i && e === (n = n || {})) return !1; if (i || e.opacity !== n.opacity) { qy(t, r), o = !0; var a = Math.max(Math.min(e.opacity, 1), 0); t.globalAlpha = isNaN(a) ? ua.opacity : a } (i || e.blend !== n.blend) && (o || (qy(t, r), o = !0), t.globalCompositeOperation = e.blend || ua.blend); for (var s = 0; s < Yy.length; s++) { var l = Yy[s]; (i || e[l] !== n[l]) && (o || (qy(t, r), o = !0), t[l] = t.dpr * (e[l] || 0)) } return (i || e.shadowColor !== n.shadowColor) && (o || (qy(t, r), o = !0), t.shadowColor = e.shadowColor || ua.shadowColor), o } function Zy(t, e, n, i, r) { var o = Ky(e, r.inHover) , a = i ? null : n && Ky(n, r.inHover) || {}; if (o === a) return !1; var s = Xy(t, o, a, i, r); if ((i || o.fill !== a.fill) && (s || (qy(t, r), s = !0), By(o.fill) && (t.fillStyle = o.fill)), (i || o.stroke !== a.stroke) && (s || (qy(t, r), s = !0), By(o.stroke) && (t.strokeStyle = o.stroke)), (i || o.opacity !== a.opacity) && (s || (qy(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 || (qy(t, r), s = !0), t.lineWidth = l) } for (var u = 0; u < Uy.length; u++) { var h = Uy[u] , c = h[0]; (i || o[c] !== a[c]) && (s || (qy(t, r), s = !0), t[c] = o[c] || h[1]) } return s } function jy(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 qy(t, e) { e.batchFill && t.fill(), e.batchStroke && t.stroke(), e.batchFill = "", e.batchStroke = "" } function Ky(t, e) { return e && t.__hoverStyle || t.style } function $y(t, e) { Jy(t, e, { inHover: !1, viewWidth: 0, viewHeight: 0 }, !0) } function Jy(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 && (qy(t, n), t.restore(), u = l = !0, n.prevElClipPaths = null, n.allClipped = !1, n.prevEl = null), o && o.length && (qy(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(), jy(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 fs && e.autoBatch && function (t) { var e = Fy(t) , n = Vy(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) ? (qy(t, n), jy(t, e)) : d || qy(t, n); var f = Ky(e, n.inHover); e instanceof fs ? (1 !== n.lastDrawType && (u = !0, n.lastDrawType = 1), Zy(t, e, h, u, n), d && (n.batchFill || n.batchStroke) || t.beginPath(), function (t, e, n, i) { var r, o = Vy(n), a = Fy(n), s = n.strokePercent, l = s < 1, u = !e.path; e.silent && !l || !u || e.createPathProxy(); var h = e.path || zy , 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 ? Oy(t, p, w) : e.__canvasFillGradient, e.__canvasFillGradient = m), g && (x = c ? Oy(t, d, w) : e.__canvasStrokeGradient, e.__canvasStrokeGradient = x), y && (_ = c || !e.__canvasFillPattern ? Hy(t, p, e) : e.__canvasFillPattern, e.__canvasFillPattern = _), v && (b = c || !e.__canvasStrokePattern ? Hy(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 = Ey(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 && Wy(t, n), a && Gy(t, n)) : (a && Gy(t, n), o && Wy(t, n))), S && t.setLineDash([]) }(t, e, f, d), d && (n.batchFill = f.fill || "", n.batchStroke = f.stroke || "")) : e instanceof ys ? (3 !== n.lastDrawType && (u = !0, n.lastDrawType = 3), Zy(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 = Ey(e))[0], s = i[1]), o && (t.setLineDash(o), t.lineDashOffset = s), n.strokeFirst ? (Vy(n) && t.strokeText(r, n.x, n.y), Fy(n) && t.fillText(r, n.x, n.y)) : (Fy(n) && t.fillText(r, n.x, n.y), Vy(n) && t.strokeText(r, n.x, n.y)), o && t.setLineDash([]) } }(t, e, f)) : e instanceof xs ? (2 !== n.lastDrawType && (u = !0, n.lastDrawType = 2), function (t, e, n, i, r) { Xy(t, Ky(e, r.inHover), n && Ky(n, r.inHover), i, r) }(t, e, h, u, n), function (t, e, n) { var i = e.__image = Zo(n.image, e.__image, e, e.onload); if (i && qo(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(), Jy(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(), Jy(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 && qy(t, n), e.innerAfterBrush(), e.afterBrush && e.afterBrush(), n.prevEl = e, e.__dirty = 0, e.__isRendered = !0 } } var Qy = new by , tv = new ln(100) , ev = ["symbol", "symbolSize", "symbolKeepAspect", "color", "backgroundColor", "dashArrayX", "dashArrayY", "maxTileWidth", "maxTileHeight"]; function nv(t, e) { if ("none" === t) return null; var n = e.getDevicePixelRatio() , i = e.getZr() , r = "svg" === i.painter.type; t.dirty && Qy.delete(t); var o = Qy.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 < ev.length; ++l) { var u = a[ev[l]]; if (null != u && !Y(u) && !X(u) && !j(u) && "boolean" != typeof u) { s = !1; break } o.push(u) } if (s) { e = o.join(",") + (r ? "-svg" : ""); var c = tv.get(e); c && (r ? t.svgElement = c : t.image = c) } var p, d = rv(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 = iv(a.symbol), y = (b = d, z(b, (function (t) { return ov(t) } ))), v = ov(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 = ro(t, y[e]); var i = 1; for (e = 0, n = g.length; e < n; ++e) i = ro(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 = .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 = ky(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 $y(p, h) } } )(), s && tv.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, Qy.set(t, s), t.dirty = !1, s } function iv(t) { if (!t || 0 === t.length) return [["rect"]]; if (X(t)) return [[t]]; for (var e = !0, n = 0; n < t.length; ++n) if (!X(t[n])) { e = !1; break } if (e) return iv([t]); var i = []; for (n = 0; n < t.length; ++n) X(t[n]) ? i.push([t[n]]) : i.push(t[n]); return i } function rv(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 rv([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 ov(t) { for (var e = 0, n = 0; n < t.length; ++n) e += t[n]; return t.length % 2 == 1 ? 2 * e : e } var av = new Xt , sv = {}; function lv(t) { return sv[t] } var uv = "undefined" != typeof window , hv = 2e3 , cv = 4500 , pv = { PROCESSOR: { FILTER: 1e3, SERIES_FILTER: 800, STATISTIC: 5e3 }, VISUAL: { LAYOUT: 1e3, PROGRESSIVE_LAYOUT: 1100, GLOBAL: hv, CHART: 3e3, POST_CHART_LAYOUT: 4600, COMPONENT: 4e3, BRUSH: 5e3, CHART_ITEM: cv, ARIA: 6e3, DECAL: 7e3 } } , dv = /^[a-zA-Z0-9_]+$/ , fv = "__connectUpdateStatus"; function gv(t) { return function () { for (var e = [], n = 0; n < arguments.length; n++) e[n] = arguments[n]; if (!this.isDisposed()) return vv(this, t, e); Gv(this.id) } } function yv(t) { return function () { for (var e = [], n = 0; n < arguments.length; n++) e[n] = arguments[n]; return vv(this, t, e) } } function vv(t, e, n) { return n[0] = n[0] && n[0].toLowerCase(), Xt.prototype[e].apply(t, n) } var mv, xv, _v, bv, wv, Sv, Mv, Iv, Tv, Cv, Dv, Av, kv, Lv, Pv, Ov, Rv, Nv, Ev = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e }(Xt), zv = Ev.prototype; zv.on = yv("on"), zv.off = yv("off"); var Vv = function (t) { function e(e, n, i) { var r = t.call(this, new ly) || this; r._chartsViews = [], r._chartsMap = {}, r._componentsViews = [], r._componentsMap = {}, r._pendingActions = [], i = i || {}, X(n) && (n = Zv[n]), r._dom = e; var o = "canvas" , a = !1 , s = r._zr = Lr(e, { renderer: i.renderer || o, devicePixelRatio: i.devicePixelRatio, width: i.width, height: i.height, ssr: i.ssr, useDirtyRect: null == i.useDirtyRect ? a : i.useDirtyRect }); r._ssr = i.ssr, r._throttledZrFlush = Cg(W(s.flush, s), 17), (n = T(n)) && Pd(n, !0), r._theme = n, r._locale = function (t) { if (X(t)) { var e = xc[t.toUpperCase()] || {}; return t === yc || t === vc ? T(e) : C(T(e), T(xc.EN), !1) } return C(T(t), T(xc.EN), !1) }(i.locale || bc), r._coordSysMgr = new ud; var l = r._api = Pv(r); function u(t, e) { return t.__prio - e.__prio } return Ie(Xv, u), Ie(Yv, u), r._scheduler = new Fg(r, l, Yv, Xv), r._messageCenter = new Ev, r._initEvents(), r.resize = W(r.resize, r), s.animation.on("frame", r._onframe, r), Cv(s, r), Dv(s, r), ct(r), r } return n(e, t), e.prototype._onframe = function () { if (!this._disposed) { Nv(this); var t = this._scheduler; if (this.__pendingUpdate) { var e = this.__pendingUpdate.silent; this.__flagInMainProcess = !0; try { mv(this), bv.update.call(this, null, this.__pendingUpdate.updateParams) } catch (t) { throw this.__flagInMainProcess = !1, this.__pendingUpdate = null, t } this._zr.flush(), this.__flagInMainProcess = !1, this.__pendingUpdate = null, Iv.call(this, e), Tv.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), Sv(this, i), t.performVisualTasks(i), Lv(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.__flagInMainProcess) if (this._disposed) Gv(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.__flagInMainProcess = !0, !this._model || e) { var a = new cd(this._api) , s = this._theme , l = this._model = new nd; l.scheduler = this._scheduler, l.ssr = this._ssr, l.init(null, null, null, s, this._locale, a) } this._model.setOption(t, { replaceMerge: r }, Uv); var u = { seriesTransition: o, optionChanged: !0 }; if (n) this.__pendingUpdate = { silent: i, updateParams: u }, this.__flagInMainProcess = !1, this.getZr().wakeUp(); else { try { mv(this), bv.update.call(this, null, u) } catch (t) { throw this.__pendingUpdate = null, this.__flagInMainProcess = !1, t } this._ssr || this._zr.flush(), this.__pendingUpdate = null, this.__flagInMainProcess = !1, Iv.call(this, i), Tv.call(this, i) } } } , e.prototype.setTheme = function () { oo() } , 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 || uv && 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 } Gv(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 (Kv[n]) { var a = o , s = o , l = -1 / 0 , u = -1 / 0 , c = [] , p = t && t.pixelRatio || this.getDevicePixelRatio(); E(qv, (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 = Lr(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 Ts({ shape: { x: 0, y: 0, width: d, height: f }, style: { fill: t.connectedBackgroundColor } })), E(c, (function (t) { var e = new xs({ 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) } Gv(this.id) } , e.prototype.convertToPixel = function (t, e) { return wv(this, "convertToPixel", t, e) } , e.prototype.convertFromPixel = function (t, e) { return wv(this, "convertFromPixel", t, e) } , e.prototype.containPixel = function (t, e) { var n; if (!this._disposed) return E(Io(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; Gv(this.id) } , e.prototype.getVisual = function (t, e) { var n = Io(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) : fy(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(Fv, (function (t) { var e = function (e) { var n, r = i.getModel(), o = e.target, a = "globalout" === t; if (a ? n = {} : o && my(o, (function (t) { var e = Ws(t); if (e && null != e.dataIndex) { var i = e.dataModel || r.getSeriesByIndex(e.seriesIndex); return n = i && i.getDataParams(e.dataIndex, e.dataType) || {}, !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(Hv, (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 ? (vy("map", "selectchanged", e, i, t), vy("pie", "selectchanged", e, i, t)) : "select" === t.fromAction ? (vy("map", "selected", e, i, t), vy("pie", "selected", e, i, t)) : "unselect" === t.fromAction && (vy("map", "unselected", e, i, t), vy("pie", "unselected", e, i, t)) } )) } , e.prototype.isDisposed = function () { return this._disposed } , e.prototype.clear = function () { this._disposed ? Gv(this.id) : this.setOption({ series: [] }, !0) } , e.prototype.dispose = function () { if (this._disposed) Gv(this.id); else { this._disposed = !0, this.getDom() && ko(this.getDom(), Qv, ""); 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 qv[t.id] } } , e.prototype.resize = function (t) { if (!this.__flagInMainProcess) if (this._disposed) Gv(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.__pendingUpdate && (null == i && (i = this.__pendingUpdate.silent), n = !0, this.__pendingUpdate = null), this.__flagInMainProcess = !0; try { n && mv(this), bv.update.call(this, { type: "resize", animation: A({ duration: 0 }, t && t.animation) }) } catch (t) { throw this.__flagInMainProcess = !1, t } this.__flagInMainProcess = !1, Iv.call(this, i), Tv.call(this, i) } } } , e.prototype.showLoading = function (t, e) { if (this._disposed) Gv(this.id); else if (q(t) && (e = t, t = ""), t = t || "default", this.hideLoading(), jv[t]) { var n = jv[t](this._api, e) , i = this._zr; this._loadingFX = n, i.add(n) } } , e.prototype.hideLoading = function () { this._disposed ? Gv(this.id) : (this._loadingFX && this._zr.remove(this._loadingFX), this._loadingFX = null) } , e.prototype.makeActionFromEvent = function (t) { var e = A({}, t); return e.type = Hv[t.type], e } , e.prototype.dispatchAction = function (t, e) { if (this._disposed) Gv(this.id); else if (q(e) || (e = { silent: !!e }), Wv[t.type] && this._model) if (this.__flagInMainProcess) this._pendingActions.push(t); else { var n = e.silent; Mv.call(this, t, n); var i = e.flush; i ? this._zr.flush() : !1 !== i && r.browser.weChat && this._throttledZrFlush(), Iv.call(this, n), Tv.call(this, n) } } , e.prototype.updateLabelLayout = function () { av.trigger("series:layoutlabels", this._model, this._api, { updatedSeries: [] }) } , e.prototype.appendData = function (t) { if (this._disposed) Gv(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 (!oh(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 (oh(t)) return; if (t instanceof fs && function (t) { var e = Xs(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) } } )) } mv = function (t) { var e = t._scheduler; e.restorePipelines(t._model), e.prepareStageTasks(), xv(t, !0), xv(t, !1), e.plan() } , xv = 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 = No(t.type) , p = e ? fg.getClass(c.main, c.sub) : mg.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) } } , _v = 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 = ft(), E(ho(u), (function (t) { var e = xo(t, null); null != e && l.set(e, !0) } ))), o && o.eachComponent(s, (function (e) { if (!(l && null !== l.get(e.id))) if (Gl(n)) if (e instanceof ag) n.type !== $s || n.notBlur || e.get(["emphasis", "disabled"]) || function (t, e, n) { var i = t.seriesIndex , r = t.getData(e.dataType); if (r) { var o = wo(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 = Ws(a); Cl(i, u.focus, u.blurScope, n) } else { var h = t.get(["emphasis", "focus"]) , c = t.get(["emphasis", "blurScope"]); null != h && Cl(i, h, c, n) } } }(e, n, t._api); else { var i = Al(e.mainType, e.componentIndex, n.name, t._api) , r = i.focusSelf , o = i.dispatchers; n.type === $s && r && !n.notBlur && Dl(e.mainType, e.componentIndex, t._api), o && E(o, (function (t) { n.type === $s ? xl(t) : _l(t) } )) } else Fl(n) && e instanceof ag && (!function (t, e, n) { if (Fl(e)) { var i = e.dataType , r = wo(t.getData(i), e); Y(r) || (r = [r]), t[e.type === el ? "toggleSelect" : e.type === Qs ? "select" : "unselect"](r, i) } }(e, n, t._api), kl(e), Rv(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) { mv(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), Sv(this, i), a.update(i, r), t(i), s.performVisualTasks(i, e), Av(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), av.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 = ft(); 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 }), Lv(this, i, r, e, {}, a), av.trigger("afterupdate", i, r) } }, updateView: function (e) { var n = this._model; n && (n.setUpdatePayload(e), mg.markUpdateMethod(e, "updateView"), t(n), this._scheduler.performVisualTasks(n, e, { setDirty: !0 }), Av(this, n, this._api, e, {}), av.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() } )), mg.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) } )), av.trigger("afterupdate", i, this._api)) }, updateLayout: function (t) { bv.update.call(this, t) } }, wv = function (t, e, n, i) { if (t._disposed) Gv(t.id); else { for (var r, o = t._model, a = t._coordSysMgr.getCoordinateSystems(), s = Io(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 } } , Sv = function (t, e) { var n = t._chartsMap , i = t._scheduler; e.eachSeries((function (t) { i.updateStreamModes(t, n[t.__viewId]) } )) } , Mv = function (t, e) { var n = this , i = this.getModel() , r = t.type , o = t.escapeConnect , a = Wv[r] , s = a.actionInfo , l = (s.update || "update").split(":") , u = l.pop() , h = null != l[0] && No(l[0]); this.__flagInMainProcess = !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 = Fl(t), y = Gl(t); if (y && Tl(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 = To(t) , r = i.queryOptionMap , o = i.mainTypeSpecified ? r.keys()[0] : "series"; _v(n, u, e, o), Rv(n) } else g ? (_v(n, u, e, "series"), Rv(n)) : h && _v(n, u, e, h.main, h.sub) } )), "none" !== u && !y && !g && !h) try { this.__pendingUpdate ? (mv(this), bv.update.call(this, t), this.__pendingUpdate = null) : bv[u].call(this, t) } catch (t) { throw this.__flagInMainProcess = !1, t } if (d = p ? { type: s.event || r, escapeConnect: o, batch: f } : f[0], this.__flagInMainProcess = !1, !e) { var v = this._messageCenter; if (v.trigger(d.type, d), g) { var m = { type: "selectchanged", escapeConnect: o, selected: Ll(i), isFromClick: t.isFromClick || !1, fromAction: t.type, fromActionPayload: t }; v.trigger(m.type, m) } } } , Iv = function (t) { for (var e = this._pendingActions; e.length;) { var n = e.shift(); Mv.call(this, n, t) } } , Tv = function (t) { !t && this.trigger("updated") } , Cv = function (t, e) { t.on("rendered", (function (n) { e.trigger("rendered", n), !t.animation.isFinished() || e.__pendingUpdate || e._scheduler.unfinished || e._pendingActions.length || e.trigger("finished") } )) } , Dv = function (t, e) { t.on("mouseover", (function (t) { var n = my(t.target, Bl); n && (!function (t, e, n) { var i = Ws(t) , r = Al(i.componentMainType, i.componentIndex, i.componentHighDownName, n) , o = r.dispatchers , a = r.focusSelf; o ? (a && Dl(i.componentMainType, i.componentIndex, n), E(o, (function (t) { return vl(t, e) } ))) : (Cl(i.seriesIndex, i.focus, i.blurScope, n), "self" === i.focus && Dl(i.componentMainType, i.componentIndex, n), vl(t, e)) }(n, t, e._api), Rv(e)) } )).on("mouseout", (function (t) { var n = my(t.target, Bl); n && (!function (t, e, n) { Tl(n); var i = Ws(t) , r = Al(i.componentMainType, i.componentIndex, i.componentHighDownName, n).dispatchers; r ? E(r, (function (t) { return ml(t, e) } )) : ml(t, e) }(n, t, e._api), Rv(e)) } )).on("click", (function (t) { var n = my(t.target, (function (t) { return null != Ws(t).dataIndex } ), !0); if (n) { var i = n.selected ? "unselect" : "select" , r = Ws(n); e._api.dispatchAction({ type: i, dataType: r.dataType, dataIndexInside: r.dataIndex, seriesIndex: r.seriesIndex, isFromClick: !0 }) } } )) } , Av = 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); Ie(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), kv(t, e, n, i, r), E(t._chartsViews, (function (t) { t.__alive = !1 } )), Lv(t, e, n, i, r), E(t._chartsViews, (function (t) { t.__alive || t.remove(e, n) } )) } , kv = 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) } )) } , Lv = function (t, e, n, o, l, u) { var h = t._scheduler; l = A(l || {}, { updatedSeries: e.getSeries() }), av.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), kl(e) } )), h.unfinished = c || h.unfinished, av.trigger("series:layoutlabels", e, n, l), av.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.storage , i = 0; n.traverse((function (t) { t.isGroup || i++ } )), i > 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), av.trigger("series:afterupdate", e, n, l) } , Rv = function (t) { t.__needsUpdateStatus = !0, t.getZr().wakeUp() } , Nv = function (t) { t.__needsUpdateStatus && (t.getZr().storage.traverse((function (t) { oh(t) || e(t) } )), t.__needsUpdateStatus = !1) } , Pv = 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) { xl(e, n), Rv(t) } , i.prototype.leaveEmphasis = function (e, n) { _l(e, n), Rv(t) } , i.prototype.enterBlur = function (e) { bl(e), Rv(t) } , i.prototype.leaveBlur = function (e) { wl(e), Rv(t) } , i.prototype.enterSelect = function (e) { Sl(e), Rv(t) } , i.prototype.leaveSelect = function (e) { Ml(e), Rv(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 }(sd))(t) } , Ov = function (t) { function e(t, e) { for (var n = 0; n < t.length; n++) { t[n][fv] = e } } E(Hv, (function (n, i) { t._messageCenter.on(i, (function (n) { if (Kv[t.group] && 0 !== t[fv]) { if (n && n.escapeConnect) return; var i = t.makeActionFromEvent(n) , r = []; E(qv, (function (e) { e !== t && e.group === t.group && r.push(e) } )), e(r, 0), E(r, (function (t) { 1 !== t[fv] && t.dispatchAction(i) } )), e(r, 2) } } )) } )) } }(), e }(Xt) , Bv = Vv.prototype; Bv.on = gv("on"), Bv.off = gv("off"), Bv.one = function (t, e, n) { var i = this; oo(), 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 Fv = ["click", "dblclick", "mouseover", "mouseout", "mousemove", "mousedown", "mouseup", "globalout", "contextmenu"]; function Gv(t) { 0 } var Wv = {} , Hv = {} , Yv = [] , Uv = [] , Xv = [] , Zv = {} , jv = {} , qv = {} , Kv = {} , $v = +new Date - 0 , Jv = +new Date - 0 , Qv = "_echarts_instance_"; function tm(t) { Kv[t] = !1 } var em = tm; function nm(t) { return qv[function (t, e) { return t.getAttribute ? t.getAttribute(e) : t[e] }(t, Qv)] } function im(t, e) { Zv[t] = e } function rm(t) { P(Uv, t) < 0 && Uv.push(t) } function om(t, e) { fm(Yv, t, e, 2e3) } function am(t) { lm("afterinit", t) } function sm(t) { lm("afterupdate", t) } function lm(t, e) { av.on(t, e) } function um(t, e, n) { U(e) && (n = e, e = ""); var i = q(t) ? t.type : [t, t = { event: e }][0]; t.event = (t.event || i).toLowerCase(), e = t.event, Hv[e] || (lt(dv.test(i) && dv.test(e)), Wv[i] || (Wv[i] = { action: n, actionInfo: t }), Hv[e] = i) } function hm(t, e) { ud.register(t, e) } function cm(t, e) { fm(Xv, t, e, 1e3, "layout") } function pm(t, e) { fm(Xv, t, e, 3e3, "visual") } var dm = []; function fm(t, e, n, i, r) { if ((U(e) || q(e)) && (n = e, e = i), !(P(dm, n) >= 0)) { dm.push(n); var o = Fg.wrapStageHandler(n, r); o.__prio = e, o.__raw = n, t.push(o) } } function gm(t, e) { jv[t] = e } function ym(t, e, n) { var i = lv("registerMap"); i && i(t, e, n) } var vm = function (t) { var e = (t = T(t)).type , n = ""; e || ao(n); var i = e.split(":"); 2 !== i.length && ao(n); var r = !1; "echarts" === i[0] && (e = i[1], r = !0), t.__isBuiltIn = r, If.set(e, t) }; pm(hv, Ng), pm(cv, zg), pm(cv, Vg), pm(hv, cy), pm(cv, py), pm(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 = nv(n, e)) } )); var r = i.getVisual("decal"); if (r) i.getVisual("style").decal = nv(r, e) } } )) } )), rm(Pd), om(900, (function (t) { var e = ft(); 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(Od) } )), gm("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 Cr , i = new Ts({ style: { fill: e.maskColor }, zlevel: e.zlevel, z: 1e4 }); n.add(i); var r, o = new As({ 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 Ts({ style: { fill: "none" }, textContent: o, textConfig: { position: "right", distance: 10 }, zlevel: e.zlevel, z: 10001 }); return n.add(a), e.showSpinner && ((r = new Wu({ shape: { startAngle: -Bg / 2, endAngle: -Bg / 2 + .1, r: e.spinnerRadius }, style: { stroke: e.color, lineCap: "round", lineWidth: e.lineWidth }, zlevel: e.zlevel, z: 10001 })).animateShape(!0).when(1e3, { endAngle: 3 * Bg / 2 }).start("circularInOut"), r.animateShape(!0).when(1e3, { startAngle: 3 * Bg / 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 } )), um({ type: $s, event: $s, update: $s }, xt), um({ type: Js, event: Js, update: Js }, xt), um({ type: Qs, event: Qs, update: Qs }, xt), um({ type: tl, event: tl, update: tl }, xt), um({ type: el, event: el, update: el }, xt), im("light", ny), im("dark", sy); var mm = [] , xm = { registerPreprocessor: rm, registerProcessor: om, registerPostInit: am, registerPostUpdate: sm, registerUpdateLifecycle: lm, registerAction: um, registerCoordinateSystem: hm, registerLayout: cm, registerVisual: pm, registerTransform: vm, registerLoading: gm, registerMap: ym, registerImpl: function (t, e) { sv[t] = e }, PRIORITY: pv, ComponentModel: Ip, ComponentView: fg, SeriesModel: ag, ChartView: mg, registerComponentModel: function (t) { Ip.registerClass(t) }, registerComponentView: function (t) { fg.registerClass(t) }, registerSeriesModel: function (t) { ag.registerClass(t) }, registerChartView: function (t) { mg.registerClass(t) }, registerSubTypeDefaulter: function (t, e) { Ip.registerSubTypeDefaulter(t, e) }, registerPainter: function (t, e) { Pr(t, e) } }; function _m(t) { Y(t) ? E(t, (function (t) { _m(t) } )) : P(mm, t) >= 0 || (mm.push(t), U(t) && (t = { install: t }), t.install(xm)) } function bm(t) { return null == t ? 0 : t.length || 1 } function wm(t) { return t } var Sm = function () { function t(t, e, n, i, r, o) { this._old = t, this._new = e, this._oldKeyGetter = n || wm, this._newKeyGetter = i || wm, 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 }() , Mm = 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 Im(t, e) { return t.hasOwnProperty(e) || (t[e] = []), t[e] } function Tm(t) { return "category" === t ? "ordinal" : "time" === t ? "time" : "float" } var Cm = function (t) { this.otherDims = {}, null != t && A(this, t) } , Dm = So() , Am = { float: "f", int: "i", ordinal: "o", number: "n", time: "t" } , km = 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 = Om(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 = Xd(this.source), n = !Rm(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 += Am[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 Lm(t) { return t instanceof km } function Pm(t) { for (var e = ft(), 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 Om(t) { var e = Dm(t); return e.dimNameMap || (e.dimNameMap = Pm(t.dimensionsDefine)) } function Rm(t) { return t > 30 } var Nm, Em, zm, Vm, Bm, Fm, Gm, Wm = q, Hm = z, Ym = "undefined" == typeof Int32Array ? Array : Int32Array, Um = ["hasItemOption", "_nameList", "_idList", "_invertedIndicesMap", "_dimSummary", "userOutput", "_rawData", "_dimValueGetter", "_nameDimIdx", "_idDimIdx", "_nameRepeatCount"], Xm = ["_approximateExtent"], Zm = 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", "lttbDownSample", "map"], this.CHANGABLE_METHODS = ["filterSelf", "selectRange"], this.DOWNSAMPLE_METHODS = ["downSample", "lttbDownSample"]; var i = !1; Lm(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 = X(h) ? new Cm({ name: h }) : h instanceof Cm ? h : new Cm(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 = ft(); 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 zf && (i = t), !i) { var o = this.dimensions , a = Fd(t) || N(t) ? new Zd(t, o.length) : t; i = new zf; var s = Hm(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 = ft() , o = [] , a = [] , s = {}; E(t.dimensions, (function (e) { var n, l = t.getDimensionInfo(e), u = l.coordDim; if (u) { var h = l.coordDimIndex; Im(i, u)[h] = e, l.isExtraCoord || (r.set(u, 1), "ordinal" !== (n = l.type) && "time" !== n && (o[0] = e), Im(s, u)[h] = t.getDimensionIndex(l.name)), l.defaultTooltip && a.push(e) } Ap.each((function (t, e) { var n = Im(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 Mm(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.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 && Gm(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 !== Rp && !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 === kp && !n.pure) for (var o = [], a = t; a < e; a++) { var s = n.getItem(a, o); if (!this.hasItemOption && go(s) && (this.hasItemOption = !0), s) { var l = s.name; null == i[a] && null != l && (i[a] = xo(l, null)); var u = s.id; null == r[a] && null != u && (r[a] = xo(u, null)) } } if (this._shouldMakeIdFromName()) for (a = t; a < e; a++) Gm(this, a); Nm(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) { Wm(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 = zm(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 Em(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(Hm(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[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) { U(t) && (n = e, e = t, t = []); var i = n || this , r = Hm(Vm(t), this._getStoreDimIndex, this); this._store.each(r, i ? W(e, i) : e) } , t.prototype.filterSelf = function (t, e, n) { U(t) && (n = e, e = t, t = []); var i = n || this , r = Hm(Vm(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) { U(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 = Hm(Vm(t), this._getStoreDimIndex, this) , a = Fm(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 = Hm(Vm(t), this._getStoreDimIndex, this); this._store.modify(o, r ? W(e, r) : e) } , t.prototype.downSample = function (t, e, n, i) { var r = Fm(this); return r._store = this._store.downSample(this._getStoreDimIndex(t), e, n, i), r } , t.prototype.lttbDownSample = function (t, e) { var n = Fm(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 pc(n, e, e && e.ecModel) } , t.prototype.diff = function (t) { var e = this; return new Sm(t ? t.getStore().getIndices() : [], this.getStore().getIndices(), (function (e) { return Em(t, e) } ), (function (t) { return Em(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 || {}, Wm(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() : Wm(r) && (r = A({}, r)), i[e] = r), r } , t.prototype.setItemVisual = function (t, e, n) { var i = this._itemVisuals[t] || {}; this._itemVisuals[t] = i, Wm(e) ? A(i, e) : i[e] = n } , t.prototype.clearAllVisual = function () { this._visual = {}, this._itemVisuals = [] } , t.prototype.setLayout = function (t, e) { Wm(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; Hs(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 : Hm(this.dimensions, this._getDimInfo, this), this.hostModel)), Bm(e, this), e._store = this._store, e } , t.prototype.wrapMethod = function (t, e) { var n = this[t]; U(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 = (Nm = 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 Ym(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 } } )) } , zm = function (t, e, n) { return xo(t._getCategory(e, n), null) } , Em = function (t, e) { var n = t._idList[e]; return null == n && null != t._idDimIdx && (n = zm(t, t._idDimIdx, e)), null == n && (n = "e\0\0" + e), n } , Vm = function (t) { return Y(t) || (t = null != t ? [t] : []), t } , Fm = function (e) { var n = new t(e._schema ? e._schema : Hm(e.dimensions, e._getDimInfo, e), e.hostModel); return Bm(n, e), n } , Bm = function (t, e) { E(Um.concat(e.__wrappedMethods || []), (function (n) { e.hasOwnProperty(n) && (t[n] = e[n]) } )), t.__wrappedMethods = e.__wrappedMethods, E(Xm, (function (n) { t[n] = T(e[n]) } )), t._calculationInfo = A({}, e._calculationInfo) } , void (Gm = 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 = zm(t, r, e)), null == s && null != o && (i[e] = s = zm(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 jm(t, e) { Fd(t) || (t = Wd(t)); var n = (e = e || {}).coordDimensions || [] , i = e.dimensionsDefine || t.dimensionsDefine || [] , r = ft() , 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 && Rm(a) , l = i === t.dimensionsDefine , u = l ? Om(t) : Pm(i) , h = e.encodeDefine; !h && e.encodeDefaulter && (h = e.encodeDefaulter(t, a)); for (var c = ft(h), p = new Pf(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 Cm , 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 = ho(t).slice(); if (1 === n.length && !X(n[0]) && n[0] < 0) c.set(e, !1); else { var i = c.set(e, []); E(n, (function (t, n) { var r = X(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 != Ap.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 (X(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 = ho(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 = qm(_, r, x), S.coordDimIndex = 0, (!v || m <= 0) && (S.isExtraCoord = !0), m--), b(S), null != S.type || Up(t, w) !== Vp && (!S.isExtraCoord || null == S.otherDims.itemName && null == S.otherDims.seriesName) || (S.type = "ordinal") } return function (t) { for (var e = ft(), 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 km({ source: t, dimensions: o, fullDimensionCount: a, dimensionOmitted: s }) } function qm(t, e, n) { var i = e.data; if (n || i.hasOwnProperty(t)) { for (var r = 0; i.hasOwnProperty(t + r);) r++; t += r } return e.set(t, !0), t } var Km = function (t) { this.coordSysDims = [], this.axisMap = ft(), this.categoryAxisMap = ft(), this.coordSysName = t }; var $m = { cartesian2d: function (t, e, n, i) { var r = t.getReferringComponents("xAxis", Co).models[0] , o = t.getReferringComponents("yAxis", Co).models[0]; e.coordSysDims = ["x", "y"], n.set("x", r), n.set("y", o), Jm(r) && (i.set("x", r), e.firstCategoryDimIndex = 0), Jm(o) && (i.set("y", o), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = 1)) }, singleAxis: function (t, e, n, i) { var r = t.getReferringComponents("singleAxis", Co).models[0]; e.coordSysDims = ["single"], n.set("single", r), Jm(r) && (i.set("single", r), e.firstCategoryDimIndex = 0) }, polar: function (t, e, n, i) { var r = t.getReferringComponents("polar", Co).models[0] , o = r.findAxisModel("radiusAxis") , a = r.findAxisModel("angleAxis"); e.coordSysDims = ["radius", "angle"], n.set("radius", o), n.set("angle", a), Jm(o) && (i.set("radius", o), e.firstCategoryDimIndex = 0), Jm(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), Jm(s) && (i.set(l, s), null == e.firstCategoryDimIndex && (e.firstCategoryDimIndex = o)) } )) } }; function Jm(t) { return "category" === t.get("type") } function Qm(t, e, n) { var i, r, o, a = (n = n || {}).byIndex, s = n.stackedCoordDimension; !function (t) { return !Lm(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) { X(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 tx(t, e) { return !!e && e === t.getCalculationInfo("stackedDimension") } function ex(t, e) { return tx(t, e) ? t.getCalculationInfo("stackResultDimension") : e } function nx(t, e, n) { n = n || {}; var i, r = e.getSourceManager(), o = !1; t ? (o = !0, i = Wd(t)) : o = (i = r.getSource()).sourceFormat === kp; var a = function (t) { var e = t.get("coordinateSystem") , n = new Km(e) , i = $m[e]; if (i) return i(t, n, n.axisMap, n.categoryAxisMap), n }(e) , s = function (t, e) { var n, i = t.get("coordinateSystem"), r = ud.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 = Tm(r) } return n } ))), n || (n = r && (r.getDimensionsInfo ? r.getDimensionsInfo() : r.dimensions.slice()) || ["x", "y"]), n }(e, a) , l = n.useEncodeDefaulter , u = U(l) ? l : l ? H(Wp, s, e) : null , h = jm(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 = Qm(e, { schema: h, store: p }) , f = new Zm(h, e); f.setCalculationInfo(d); var g = null != c && function (t) { if (t.sourceFormat === kp) { return !Y(fo(function (t) { var e = 0; for (; e < t.length && null == t[e];) e++; return t[e] }(t.data || []))) } }(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 ix = 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 }(); Go(ix); var rx = 0 , ox = function () { function t(t) { this.categories = t.categories || [], this._needCollect = t.needCollect, this._deduplication = t.deduplication, this.uid = ++rx } return t.createByAxisModel = function (e) { var n = e.option , i = n.data , r = i && z(i, ax); 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 (!X(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 = ft(this.categories)) } , t }(); function ax(t) { return q(t) && null != t.value ? t.value : t + "" } function sx(t) { return "interval" === t.type || "log" === t.type } function lx(t, e, n, i) { var r = {} , o = t[1] - t[0] , a = r.interval = $r(o / e, !0); null != n && a < n && (a = r.interval = n), null != i && a > i && (a = r.interval = i); var s = r.intervalPrecision = hx(a); return function (t, e) { !isFinite(t[0]) && (t[0] = e[0]), !isFinite(t[1]) && (t[1] = e[1]), cx(t, 0, e), cx(t, 1, e), t[0] > t[1] && (t[0] = t[1]) }(r.niceTickExtent = [zr(Math.ceil(t[0] / a) * a, s), zr(Math.floor(t[1] / a) * a, s)], t), r } function ux(t) { var e = Math.pow(10, Kr(t)) , n = t / e; return n ? 2 === n ? n = 3 : 3 === n ? n = 5 : n *= 2 : n = 1, zr(n * e) } function hx(t) { return Br(t) + 2 } function cx(t, e, n) { t[e] = Math.max(Math.min(t[e], n[1]), n[0]) } function px(t, e) { return t >= e[0] && t <= e[1] } function dx(t, e) { return e[1] === e[0] ? .5 : (t - e[0]) / (e[1] - e[0]) } function fx(t, e) { return t * (e[1] - e[0]) + e[0] } var gx = function (t) { function e(e) { var n = t.call(this, e) || this; n.type = "ordinal"; var i = n.getSetting("ordinalMeta"); return i || (i = new ox({})), Y(i) && (i = new ox({ 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 X(t) ? this._ordinalMeta.getOrdinal(t) : Math.round(t) } , e.prototype.contain = function (t) { return px(t = this.parse(t), this._extent) && null != this._ordinalMeta.categories[t] } , e.prototype.normalize = function (t) { return dx(t = this._getTickNumber(this.parse(t)), this._extent) } , e.prototype.scale = function (t) { return t = Math.round(fx(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 }(ix); ix.registerClass(gx); var yx = zr , vx = 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 px(t, this._extent) } , e.prototype.normalize = function (t) { return dx(t, this._extent) } , e.prototype.scale = function (t) { return fx(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 = hx(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: yx(i[0] - e, r) }) : o.push({ value: n[0] })); for (var a = i[0]; a <= i[1] && (o.push({ value: a }), (a = yx(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: yx(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 = yx(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 = Br(t.value) || 0 : "auto" === n && (n = this._intervalPrecision), tp(yx(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 = lx(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 = 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] = yx(Math.floor(e[0] / r) * r)), t.fixMax || (e[1] = yx(Math.ceil(e[1] / r) * r)) } , e.prototype.setNiceExtent = function (t, e) { this._niceExtent = [t, e] } , e.type = "interval", e }(ix); ix.registerClass(vx); var mx = "undefined" != typeof Float32Array , xx = mx ? Float32Array : Array; function _x(t) { return Y(t) ? mx ? new Float32Array(t) : t : new xx(t) } var bx = "__ec_stack_"; function Sx(t) { return t.get("stack") || bx + t.seriesIndex } function Mx(t) { return t.dim + t.index } function Ix(t, e) { var n = []; return e.eachSeriesByType(t, (function (t) { kx(t) && n.push(t) } )), n } function Tx(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 = Er(t.get("barWidth"), i) , d = Er(t.get("barMaxWidth"), i) , f = Er(t.get("barMinWidth") || (Lx(t) ? .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: Mx(r), stackId: Sx(t) }) } )), Cx(n) } function Cx(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 = Er(o, r) , l = Er(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 Dx(t, e) { var n = Ix(t, e) , i = Tx(n); E(n, (function (t) { var e = t.getData() , n = t.coordinateSystem.getBaseAxis() , r = Sx(t) , o = i[Mx(n)][r] , a = o.offset , s = o.width; e.setLayout({ bandWidth: o.bandWidth, offset: a, size: s }) } )) } function Ax(t) { return { seriesType: t, plan: gg(), reset: function (t) { if (kx(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 = tx(e, l) && !!e.getCalculationInfo("stackedOnSeries") , c = r.isHorizontal() , p = function (t, e) { return e.toGlobalCoord(e.dataToCoord("log" === e.type ? 1 : 0)) }(0, r) , d = Lx(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 && _x(3 * r), u = d && s && _x(3 * r), m = d && _x(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 kx(t) { return t.coordinateSystem && "cartesian2d" === t.coordinateSystem.type } function Lx(t) { return t.pipelineContext && t.pipelineContext.large } var Px = 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 zc(t.value, Lc[function (t) { switch (t) { case "year": case "month": return "day"; case "millisecond": return "millisecond"; default: return "second" } }(Nc(this._minLevelUnit))] || Lc.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 (X(n)) o = n; else if (U(n)) o = n(t.value, e, { level: t.level }); else { var a = A({}, Ac); if (t.level > 0) for (var s = 0; s < Pc.length; ++s) a[Pc[s]] = "{primary|" + a[Pc[s]] + "}"; var l = n ? !1 === n.inherit ? n : k(n, a) : a , u = Vc(t.value, r); if (l[u]) o = l[u]; else if (l.inherit) { for (s = Oc.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 zc(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 = Oc , 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 = jr(e) , o = jr(n) , a = function (t) { return Bc(r, t, i) === Bc(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() } }(Nc(t), i[0], i[1], n)) { l && (r = [{ value: Bx(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 / Cc / 365)), d = Fc(n), f = Zc(n); break; case "half-year": case "quarter": case "month": p = Nx(e), d = Gc(n), f = jc(n); break; case "week": case "half-week": case "day": p = Rx(e), d = Wc(n), f = qc(n), g = !0; break; case "half-day": case "quarter-day": case "hour": p = Ex(e), d = Hc(n), f = Kc(n); break; case "minute": p = zx(e, !0), d = Yc(n), f = $c(n); break; case "second": p = zx(e, !1), d = Uc(n), f = Jc(n); break; case "millisecond": p = Vx(e), d = Xc(n), f = Qc(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 = Nc(o[d]); if (Ec(o[d])) if (l(o[d], u[u.length - 1] || [], h), f !== (o[d + 1] ? Nc(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] -= Cc, e[1] += Cc), 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] - Cc } 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 = Ox.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 }(Ox, this._approxInterval, 0, o), o - 1); this._interval = Ox[a][1], this._minLevelUnit = Ox[Math.max(a - 1, 0)][0] } , e.prototype.parse = function (t) { return j(t) ? t : +jr(t) } , e.prototype.contain = function (t) { return px(this.parse(t), this._extent) } , e.prototype.normalize = function (t) { return dx(this.parse(t), this._extent) } , e.prototype.scale = function (t) { return fx(t, this._extent) } , e.type = "time", e }(vx) , Ox = [["second", Mc], ["minute", Ic], ["hour", Tc], ["quarter-day", 216e5], ["half-day", 432e5], ["day", 10368e4], ["half-week", 3024e5], ["week", 6048e5], ["month", 26784e5], ["quarter", 8208e6], ["half-year", Dc / 2], ["year", Dc]]; function Rx(t, e) { return (t /= Cc) > 16 ? 16 : t > 7.5 ? 7 : t > 3.5 ? 4 : t > 1.5 ? 2 : 1 } function Nx(t) { return (t /= 2592e6) > 6 ? 6 : t > 3 ? 3 : t > 2 ? 2 : 1 } function Ex(t) { return (t /= Tc) > 12 ? 12 : t > 6 ? 6 : t > 3.5 ? 4 : t > 2 ? 2 : 1 } function zx(t, e) { return (t /= e ? Ic : Mc) > 30 ? 30 : t > 20 ? 20 : t > 15 ? 15 : t > 10 ? 10 : t > 5 ? 5 : t > 2 ? 2 : 1 } function Vx(t) { return $r(t, !0) } function Bx(t, e, n) { var i = new Date(t); switch (Nc(e)) { case "year": case "month": i[jc(n)](0); case "day": i[qc(n)](1); case "hour": i[Kc(n)](0); case "minute": i[$c(n)](0); case "second": i[Jc(n)](0), i[Qc(n)](0) } return i.getTime() } ix.registerClass(Px); var Fx = ix.prototype , Gx = vx.prototype , Wx = zr , Hx = Math.floor , Yx = Math.ceil , Ux = Math.pow , Xx = Math.log , Zx = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "log", e.base = 10, e._originalScale = new vx, 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(Gx.getTicks.call(this, t), (function (t) { var e = t.value , r = zr(Ux(this.base, e)); return r = e === n[0] && this._fixMin ? qx(r, i[0]) : r, { value: r = e === n[1] && this._fixMax ? qx(r, i[1]) : r } } ), this) } , e.prototype.setExtent = function (t, e) { var n = this.base; t = Xx(t) / Xx(n), e = Xx(e) / Xx(n), Gx.setExtent.call(this, t, e) } , e.prototype.getExtent = function () { var t = this.base , e = Fx.getExtent.call(this); e[0] = Ux(t, e[0]), e[1] = Ux(t, e[1]); var n = this._originalScale.getExtent(); return this._fixMin && (e[0] = qx(e[0], n[0])), this._fixMax && (e[1] = qx(e[1], n[1])), e } , e.prototype.unionExtent = function (t) { this._originalScale.unionExtent(t); var e = this.base; t[0] = Xx(t[0]) / Xx(e), t[1] = Xx(t[1]) / Xx(e), Fx.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 = qr(n); for (t / n * i <= .5 && (i *= 10); !isNaN(i) && Math.abs(i) < 1 && Math.abs(i) > 0;) i *= 10; var r = [zr(Yx(e[0] / i) * i), zr(Hx(e[1] / i) * i)]; this._interval = i, this._niceExtent = r } } , e.prototype.calcNiceExtent = function (t) { Gx.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 px(t = Xx(t) / Xx(this.base), this._extent) } , e.prototype.normalize = function (t) { return dx(t = Xx(t) / Xx(this.base), this._extent) } , e.prototype.scale = function (t) { return t = fx(t, this._extent), Ux(this.base, t) } , e.type = "log", e }(ix) , jx = Zx.prototype; function qx(t, e) { return Wx(t, Br(e)) } jx.getMinorTicks = Gx.getMinorTicks, jx.getLabel = Gx.getLabel, ix.registerClass(Zx); var Kx = 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 = this._modelMinRaw = e.get("min", !0); U(r) ? this._modelMinNum = t_(t, r({ min: n[0], max: n[1] })) : "dataMin" !== r && (this._modelMinNum = t_(t, r)); var o = this._modelMaxRaw = e.get("max", !0); if (U(o) ? this._modelMaxNum = t_(t, o({ min: n[0], max: n[1] })) : "dataMax" !== o && (this._modelMaxNum = t_(t, o)), i) this._axisDataLen = e.getCategories().length; else { var a = e.get("boundaryGap") , s = Y(a) ? a : [a || 0, a || 0]; "boolean" == typeof s[0] || "boolean" == typeof s[1] ? this._boundaryGapInner = [0, 0] : this._boundaryGapInner = [gr(s[0], 1), gr(s[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[Jx[t]] = e } , t.prototype.setDeterminedMinMax = function (t, e) { var n = $x[t]; this[n] = e } , t.prototype.freeze = function () { this.frozen = !0 } , t }() , $x = { min: "_determinedMin", max: "_determinedMax" } , Jx = { min: "_dataMin", max: "_dataMax" }; function Qx(t, e, n) { var i = t.rawExtentInfo; return i || (i = new Kx(t, e, n), t.rawExtentInfo = i, i) } function t_(t, e) { return null == e ? null : nt(e) ? NaN : t.parse(e) } function e_(t, e) { var n = t.type , i = Qx(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 = Ix("bar", a) , l = !1; if (E(s, (function (t) { l = l || t.getBaseAxis() === e.axis } )), l) { var u = Tx(s) , h = function (t, e, n, i) { var r = n.axis.getExtent() , o = r[1] - r[0] , a = function (t, e, n) { if (t && e) { var i = t[Mx(e)]; return null != i && null != n ? i[Sx(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 { min: t -= c * (s / u), max: e += c * (l / u) } }(r, o, e, u); r = h.min, o = h.max } } return { extent: [r, o], fixMin: i.minFixed, fixMax: i.maxFixed } } function n_(t, e) { var n = e , i = e_(t, n) , r = i.extent , o = n.get("splitNumber"); t instanceof Zx && (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 i_(t, e) { if (e = e || t.get("type")) switch (e) { case "category": return new gx({ ordinalMeta: t.getOrdinalMeta ? t.getOrdinalMeta() : t.getCategories(), extent: [1 / 0, -1 / 0] }); case "time": return new Px({ locale: t.ecModel.getLocaleModel(), useUTC: t.ecModel.get("useUTC") }); default: return new (ix.getClass(e) || vx) } } function r_(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) } ) : X(i) ? function (e) { return function (n) { var i = t.scale.getLabel(n); return e.replace("{value}", null != i ? i : "") } }(i) : U(i) ? (e = i, function (n, i) { return null != r && (i = n.value - r), e(o_(t, n), i, null != n.level ? { level: n.level } : null) } ) : function (e) { return t.scale.getLabel(e) } } function o_(t, e) { return "category" === t.type ? t.scale.getLabel(e) : e.value } function a_(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 sr(t.x, t.y, o, a) } function s_(t) { var e = t.get("interval"); return null == e ? "auto" : e } function l_(t) { return "category" === t.type && 0 === s_(t.getLabelModel()) } function u_(t, e) { var n = {}; return E(t.mapDimensionsAll(e), (function (e) { n[ex(t, e)] = !0 } )), G(n) } var h_ = function () { function t() { } return t.prototype.getNeedCrossZero = function () { return !this.option.scale } , t.prototype.getCoordSysModel = function () { } , t }(); var c_ = { isDimensionStacked: tx, enableDataStack: Qm, getStackedDimension: ex }; var p_ = Object.freeze({ __proto__: null, createList: function (t) { return nx(null, t) }, getLayoutRect: mp, dataStack: c_, createScale: function (t, e) { var n = e; e instanceof pc || (n = new pc(e)); var i = i_(n); return i.setExtent(t[0], t[1]), n_(i, n), i }, mixinAxisModelCommonMethods: function (t) { R(t, h_) }, getECData: Ws, createTextStyle: function (t, e) { return Yh(t, null, null, "normal" !== (e = e || {}).state) }, createDimensions: function (t, e) { return jm(t, e).dimensions }, createSymbol: ky, enableHoverEmphasis: Pl }); function d_(t, e) { return Math.abs(t - e) < 1e-8 } function f_(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 += ns(r[0], r[1], a[0], a[1], e, n), r = a } var s = t[0]; return d_(r[0], s[0]) && d_(r[1], s[1]) || (i += ns(r[0], r[1], s[0], s[1], e, n)), 0 !== i } var g_ = []; function y_(t, e) { for (var n = 0; n < t.length; n++) Ft(t[n], t[n], e) } function v_(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]) && (Gt(e, e, o), Wt(n, n, o)) } } var m_ = 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 }() , x_ = function (t, e) { this.type = "polygon", this.exterior = t, this.interiors = e } , __ = 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 ? v_(e.exterior, n, i, t) : E(e.points, (function (e) { v_(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 sr(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 (f_(a, t[0], t[1])) { for (var l = 0; l < (s ? s.length : 0); l++) if (f_(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 sr(t, e, n, i), s = r.calculateTransform(a), l = this.geometries, u = 0; u < l.length; u++) { var h = l[u]; "polygon" === h.type ? (y_(h.exterior, s), E(h.interiors, (function (t) { y_(t, s) } ))) : E(h.points, (function (t) { y_(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 }(m_) , w_ = 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 = Oi(g_), r = t; r && !r.isGeoSVGGraphicRoot;) Ni(i, r.getLocalTransform(), i), r = r.parent; return Bi(i, i), Ft(n, n, i), n } , e }(m_); function S_(t, e, n) { for (var i = 0; i < t.length; i++) t[i] = M_(t[i], e[i], n) } function M_(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 I_(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 = M_(r, i, n); break; case "Polygon": case "MultiLineString": S_(r, i, n); break; case "MultiPolygon": E(r, (function (t, e) { return S_(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 x_(o[0], o.slice(1))); break; case "MultiPolygon": E(i.coordinates, (function (t) { t[0] && r.push(new x_(t[0], t.slice(1))) } )); break; case "LineString": r.push(new __([i.coordinates])); break; case "MultiLineString": r.push(new __(i.coordinates)) } var a = new b_(n[e || "name"], r, n.cp); return a.properties = n, a } )) } var T_ = Object.freeze({ __proto__: null, linearMap: Nr, round: zr, asc: Vr, getPrecision: Br, getPrecisionSafe: Fr, getPixelPrecision: Gr, getPercentWithPrecision: Wr, MAX_SAFE_INTEGER: Yr, remRadian: Ur, isRadianAroundZero: Xr, parseDate: jr, quantity: qr, quantityExponent: Kr, nice: $r, quantile: Jr, reformIntervals: Qr, isNumeric: eo, numericToNumber: to }) , C_ = Object.freeze({ __proto__: null, parse: jr, format: zc }) , D_ = Object.freeze({ __proto__: null, extendShape: dh, extendPath: gh, makePath: mh, makeImage: xh, mergePath: bh, resizePath: wh, createIcon: Lh, updateProps: ih, initProps: rh, getTransform: Mh, clipPointsByRect: Ah, clipRectByRect: kh, registerShape: yh, getShapeClass: vh, Group: Cr, Image: xs, Text: As, Circle: uu, Ellipse: cu, Sector: Tu, Ring: Du, Polygon: Lu, Polyline: Ou, Rect: Ts, Line: Eu, BezierCurve: Fu, Arc: Wu, IncrementalDisplayable: Qu, CompoundPath: Hu, LinearGradient: Uu, RadialGradient: Xu, BoundingRect: sr }) , A_ = Object.freeze({ __proto__: null, addCommas: tp, toCamelCase: ep, normalizeCssArray: np, encodeHTML: op, formatTpl: up, getTooltipMarker: hp, formatTime: function (t, e, n) { "week" !== t && "month" !== t && "quarter" !== t && "half-year" !== t && "year" !== t || (t = "MM-dd\nyyyy"); var i = jr(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", Rc(a, 2)).replace("M", a).replace("yyyy", o).replace("yy", o % 100 + "").replace("dd", Rc(s, 2)).replace("d", s).replace("hh", Rc(l, 2)).replace("h", l).replace("mm", Rc(u, 2)).replace("m", u).replace("ss", Rc(h, 2)).replace("s", h).replace("SSS", Rc(c, 3)) }, capitalFirst: function (t) { return t ? t.charAt(0).toUpperCase() + t.substr(1) : t }, truncateText: $o, getTextRect: function (t, e, n, i, r, o, a, s) { return new As({ style: { text: t, font: e, align: n, verticalAlign: i, padding: r, rich: o, overflow: a ? "truncate" : null, lineHeight: s } }).getBoundingRect() } }) , k_ = Object.freeze({ __proto__: null, map: z, each: E, indexOf: P, inherits: O, reduce: V, filter: B, bind: W, curry: H, isArray: Y, isString: X, isObject: q, isFunction: U, extend: A, defaults: k, clone: T, merge: C }) , L_ = So(); function P_(t) { return "category" === t.type ? function (t) { var e = t.getLabelModel() , n = R_(t, e); return !e.get("show") || t.scale.isBlank() ? { labels: [], labelCategoryInterval: n.labelCategoryInterval } : n }(t) : function (t) { var e = t.scale.getTicks() , n = r_(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 O_(t, e) { return "category" === t.type ? function (t, e) { var n, i, r = N_(t, "ticks"), o = s_(e), a = E_(r, o); if (a) return a; e.get("show") && !t.scale.isBlank() || (n = []); if (U(o)) n = B_(t, o, !0); else if ("auto" === o) { var s = R_(t, t.getLabelModel()); i = s.labelCategoryInterval, n = z(s.labels, (function (t) { return t.tickValue } )) } else n = V_(t, i = o, !0); return z_(r, o, { ticks: n, tickCategoryInterval: i }) }(t, e) : { ticks: z(t.scale.getTicks(), (function (t) { return t.value } )) } } function R_(t, e) { var n, i, r = N_(t, "labels"), o = s_(e), a = E_(r, o); return a || (U(o) ? n = B_(t, o) : (i = "auto" === o ? function (t) { var e = L_(t).autoInterval; return null != e ? e : L_(t).autoInterval = t.calculateCategoryInterval() }(t) : o, n = V_(t, i)), z_(r, o, { labels: n, labelCategoryInterval: i })) } function N_(t, e) { return L_(t)[e] || (L_(t)[e] = []) } function E_(t, e) { for (var n = 0; n < t.length; n++) if (t[n].key === e) return t[n].value } function z_(t, e, n) { return t.push({ key: e, value: n }), n } function V_(t, e, n) { var i = r_(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 = l_(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 B_(t, e, n) { var i = t.scale , r = r_(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 F_ = [0, 1] , G_ = 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 Gr(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 && W_(n = n.slice(), i.count()), Nr(t, F_, n, e) } , t.prototype.coordToData = function (t, e) { var n = this._extent , i = this.scale; this.onBand && "ordinal" === i.type && W_(n = n.slice(), i.count()); var r = Nr(t, n, F_, 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(O_(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[0] }; 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 } )), a = 1 + t.scale.getExtent()[1] - e[r - 1].tickValue, o = { coord: e[r - 1].coord + u * a }, e.push(o) } var h = s[0] > s[1]; c(e[0].coord, s[0]) && (i ? e[0].coord = s[0] : e.shift()); i && c(s[0], e[0].coord) && e.unshift({ coord: s[0] }); c(s[1], o.coord) && (i ? o.coord = s[1] : e.pop()); i && c(o.coord, s[1]) && e.push({ coord: s[1] }); function c(t, e) { return t = zr(t), e = zr(e), h ? 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 P_(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 = r_(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 = cr(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))) , _ = L_(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 W_(t, e) { var n = (t[1] - t[0]) / e / 2; t[0] += n, t[1] -= n } var H_ = 2 * Math.PI , Y_ = ja.CMD , U_ = ["top", "right", "bottom", "left"]; function X_(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 Z_(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) % H_ < 1e-4) return l[0] = h, l[1] = c, u - n; if (o) { var p = i; i = Qa(r), r = Qa(p) } else i = Qa(i), r = Qa(r); i > r && (r += H_); var d = Math.atan2(s, a); if (d < 0 && (d += H_), d >= i && d <= r || d + H_ >= i && d + H_ <= 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 j_(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 q_(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 K_ = []; function $_(t, e, n) { var i = q_(e.x, e.y, e.width, e.height, t.x, t.y, K_); return n.set(K_[0], K_[1]), i } function J_(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 Y_.M: o = s = h[d++], a = l = h[d++]; break; case Y_.L: g = j_(o, a, h[d], h[d + 1], c, p, K_, !0), o = h[d++], a = h[d++]; break; case Y_.C: g = je(o, a, h[d++], h[d++], h[d++], h[d++], h[d], h[d + 1], c, p, K_), o = h[d++], a = h[d++]; break; case Y_.Q: g = tn(o, a, h[d++], h[d++], h[d], h[d + 1], c, p, K_), o = h[d++], a = h[d++]; break; case Y_.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 = Z_(y, v, x, _, _ + b, w, (c - y) * x / m + y, p, K_), o = Math.cos(_ + b) * m + y, a = Math.sin(_ + b) * x + v; break; case Y_.R: g = q_(s = o = h[d++], l = a = h[d++], h[d++], h[d++], c, p, K_); break; case Y_.Z: g = j_(o, a, s, l, c, p, K_, !0), o = s, a = l } g < u && (u = g, n.set(K_[0], K_[1])) } return u } var Q_ = new Ji , tb = new Ji , eb = new Ji , nb = new Ji , ib = new Ji; function rb(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 || U_ , s = i.getBoundingRect().clone(); s.applyTransform(i.getComputedTransform()); var l = 1 / 0 , u = r.anchor , h = t.getComputedTransform() , c = h && Bi([], h) , p = e.get("length2") || 0; u && eb.copy(u); for (var d = 0; d < a.length; d++) { X_(a[d], 0, s, Q_, nb), Ji.scaleAndAdd(tb, Q_, nb, p), tb.transform(c); var f = t.getBoundingRect() , g = u ? u.distance(tb) : t instanceof fs ? J_(tb, t.path, eb) : $_(tb, f, eb); g < l && (l = g, tb.transform(h), eb.transform(h), eb.toArray(o[0]), tb.toArray(o[1]), Q_.toArray(o[2])) } sb(o, e.get("minTurnAngle")), n.setShape({ points: o }) } } } var ob = [] , ab = new Ji; function sb(t, e) { if (e <= 180 && e > 0) { e = e / 180 * Math.PI, Q_.fromArray(t[0]), tb.fromArray(t[1]), eb.fromArray(t[2]), Ji.sub(nb, Q_, tb), Ji.sub(ib, eb, tb); var n = nb.len() , i = ib.len(); if (!(n < .001 || i < .001)) { nb.scale(1 / n), ib.scale(1 / i); var r = nb.dot(ib); if (Math.cos(e) < r) { var o = j_(tb.x, tb.y, eb.x, eb.y, Q_.x, Q_.y, ob, !1); ab.fromArray(ob), ab.scaleAndAdd(ib, o / Math.tan(Math.PI - e)); var a = eb.x !== tb.x ? (ab.x - tb.x) / (eb.x - tb.x) : (ab.y - tb.y) / (eb.y - tb.y); if (isNaN(a)) return; a < 0 ? Ji.copy(ab, tb) : a > 1 && Ji.copy(ab, eb), ab.toArray(t[1]) } } } } function lb(t, e, n) { if (n <= 180 && n > 0) { n = n / 180 * Math.PI, Q_.fromArray(t[0]), tb.fromArray(t[1]), eb.fromArray(t[2]), Ji.sub(nb, tb, Q_), Ji.sub(ib, eb, tb); var i = nb.len() , r = ib.len(); if (!(i < .001 || r < .001)) if (nb.scale(1 / i), ib.scale(1 / r), nb.dot(e) < Math.cos(n)) { var o = j_(tb.x, tb.y, eb.x, eb.y, Q_.x, Q_.y, ob, !1); ab.fromArray(ob); var a = Math.PI / 2 , s = a + Math.acos(ib.dot(e)) - n; if (s >= a) Ji.copy(ab, eb); else { ab.scaleAndAdd(ib, o / Math.tan(Math.PI / 2 - s)); var l = eb.x !== tb.x ? (ab.x - tb.x) / (eb.x - tb.x) : (ab.y - tb.y) / (eb.y - tb.y); if (isNaN(l)) return; l < 0 ? Ji.copy(ab, tb) : l > 1 && Ji.copy(ab, eb) } ab.toArray(t[1]) } } } function ub(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 = .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 hb(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 = Et(i[0], i[1]) , o = Et(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 = Bt([], i[1], i[0], a / r) , l = Bt([], i[1], i[2], a / o) , u = Bt([], s, l, .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 cb(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 < qs.length; l++) { var u = qs[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.normal; d && (d.ignore = !0); continue } i || (i = new Ou, t.setTextGuideLine(i), c || !s && a || ub(i, !0, "normal", e.normal), t.stateProxy && (i.stateProxy = t.stateProxy)), ub(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 = hb } } else i && t.removeTextGuideLine() } function pb(t, e) { e = e || "labelLine"; for (var n = { normal: t.getModel(e) }, i = 0; i < js.length; i++) { var r = js[i]; n[r] = t.getModel([r, e]) } return n } function db(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 $u(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 fb(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, .8), g < 0 && b(g, .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 gb(t, e, n, i) { return fb(t, "y", "height", e, n, i) } function yb(t) { var e = []; t.sort((function (t, e) { return e.priority - t.priority } )); var n = new sr(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 -= .1, n.height -= .1, n.x += .05, n.y += .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 $u(f.localRect, f.transform)), c || (c = new $u(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 vb(t) { if (t) { for (var e = [], n = 0; n < t.length; n++) e.push(t[n].slice()); return e } } function mb(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: vb(i && i.shape.points) } } var xb = ["align", "verticalAlign", "width", "height", "fontSize"] , _b = new qi , bb = So() , wb = So(); function Sb(t, e, n) { for (var i = 0; i < n.length; i++) { var r = n[i]; null != e[r] && (t[r] = e[r]) } } var Mb = ["x", "y", "rotation"] , Ib = 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(); sr.applyTransform(l, l, s), s ? _b.setLocalTransform(s) : (_b.x = _b.y = _b.rotation = _b.originX = _b.originY = 0, _b.scaleX = _b.scaleY = 1); var u, h = i.__hostTarget; if (h) { u = h.getBoundingRect().plain(); var c = h.getComputedTransform(); sr.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: _b.x, y: _b.y, scaleX: _b.scaleX, scaleY: _b.scaleY, rotation: _b.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"); (U(i) || G(i).length) && t.group.traverse((function (t) { if (t.ignore) return !0; var r = t.getTextContent() , o = Ws(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 () { rb(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 = U(o.layoutOption) ? o.layoutOption(mb(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 = Er(u.x, e), a.setStyle("x", 0), c = !0) : (a.x = l.x, a.setStyle("x", l.style.x)), null != u.y ? (a.y = Er(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) } bb(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 < xb.length; d++) { var f = xb[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 = db(this._labelList), o = B(r, (function (t) { return "shiftX" === t.layoutOption.moveOverlap } )), a = B(r, (function (t) { return "shiftY" === t.layoutOption.moveOverlap } )); fb(o, "x", "width", 0, n, e), gb(a, 0, i), yb(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 = bb(a).needsUpdateLabelLine), o && t._updateLabelLine(e, n), r && t._animateLabels(e, n) } )) } )) } , t.prototype._updateLabelLine = function (t, e) { var n = t.getTextContent() , i = Ws(t) , r = i.dataIndex; if (n && null != r) { var o = e.getData(i.dataType) , a = o.getItemModel(r) , s = {} , l = o.getItemVisual(r, "style") , u = o.getVisual("drawType"); s.stroke = l[u]; var h = a.getModel("labelLine"); cb(t, pb(a), s), rb(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 && !oh(t))) { var r = (d = bb(n)).oldLayout , o = Ws(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)), ih(n, s, e, a) } else if (n.attr(s), !$h(n).valueAnimation) { var h = rt(n.style.opacity, 1); n.style.opacity = 0, rh(n, { style: { opacity: h } }, e, a) } if (d.oldLayout = s, n.states.select) { var c = d.oldLayoutSelect = {}; Sb(c, s, Mb), Sb(c, n.states.select, Mb) } if (n.states.emphasis) { var p = d.oldLayoutEmphasis = {}; Sb(p, s, Mb), Sb(p, n.states.emphasis, Mb) } Qh(n, a, l, e, e) } if (i && !i.ignore && !i.invisible) { r = (d = wb(i)).oldLayout; var d, f = { points: i.shape.points }; r ? (i.attr({ shape: r }), ih(i, { shape: f }, e)) : (i.setShape(f), i.style.strokePercent = 0, rh(i, { style: { strokePercent: 1 } }, e)), d.oldLayout = f } } , t }() , Tb = So(); var Cb = Math.sin , Db = Math.cos , Ab = Math.PI , kb = 2 * Math.PI , Lb = 180 / Ab , Pb = 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 = En(h - kb) || (u ? l >= kb : -l >= kb) , p = l > 0 ? l % kb : l % kb + kb , d = !1; d = !!c || !En(h) && p >= Ab == !!u; var f = t + n * Db(o) , g = e + i * Cb(o); this._start && this._add("M", f, g); var y = Math.round(r * Lb); if (c) { var v = 1 / this._p , m = (u ? 1 : -1) * (kb - v); this._add("A", n, i, y, 1, +u, t + n * Db(o + m), e + i * Cb(o + m)), v > .01 && this._add("A", n, i, y, 0, +u, f, g) } else { var x = t + n * Db(a) , _ = e + i * Cb(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 }() , Ob = "none" , Rb = Math.round; var Nb = ["lineCap", "miterLimit", "lineJoin"] , Eb = z(Nb, (function (t) { return "stroke-" + t.toLowerCase() } )); function zb(t, e, n, i) { var r = null == e.opacity ? 1 : e.opacity; if (n instanceof xs) t("opacity", r); else { if (function (t) { var e = t.fill; return null != e && e !== Ob }(e)) { var o = Rn(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", Ob); if (function (t) { var e = t.stroke; return null != e && e !== Ob }(e)) { var s = Rn(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 = Ey(n) , d = p[0] , f = p[1]; d && (f = Rb(f || 0), t("stroke-dasharray", d.join(",")), (f || i) && t("stroke-dashoffset", f)) } else i && t("stroke-dasharray", Ob); for (var g = 0; g < Nb.length; g++) { var y = Nb[g]; if (i || e[y] !== cs[y]) { var v = e[y] || cs[y]; v && t(Eb[g], v) } } } else i && t("stroke", Ob) } } var Vb = "http://www.w3.org/2000/svg" , Bb = "http://www.w3.org/1999/xlink"; function Fb(t) { return document.createElementNS(Vb, t) } function Gb(t, e, n, i, r) { return { tag: t, attrs: n || {}, children: i, text: r, key: e } } function Wb(t, e) { var n = (e = e || {}).newline ? "\n" : ""; return function t(e) { var i = e.children , r = e.tag; 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, e.attrs) + (e.text || "") + (i ? "" + n + z(i, (function (e) { return t(e) } )).join(n) + n : "") + ("") }(t) } function Hb(t) { return { zrId: t, shadowCache: {}, patternCache: {}, gradientCache: {}, clipPathCache: {}, defs: {}, cssNodes: {}, cssAnims: {}, cssClassIdx: 0, cssAnimIdx: 0, shadowIdx: 0, gradientIdx: 0, patternIdx: 0, clipPathIdx: 0 } } function Yb(t, e, n, i) { return Gb("svg", "root", { width: t, height: e, xmlns: Vb, "xmlns:xlink": Bb, version: "1.1", baseProfile: "full", viewBox: !!i && "0 0 " + t + " " + e }, n) } var Ub = { 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" } , Xb = "transform-origin"; function Zb(t, e, n) { var i = A({}, t.shape); A(i, e), t.buildPath(n, i); var r = new Pb; return r.reset(Yn(t)), n.rebuildPath(r, 1), r.generateStr(), r.getStr() } function jb(t, e) { var n = e.originX , i = e.originY; (n || i) && (t[Xb] = n + "px " + i + "px") } var qb = { fill: "fill", opacity: "opacity", lineWidth: "stroke-width", lineDashOffset: "stroke-dashoffset" }; function Kb(t, e) { var n = e.zrId + "-ani-" + e.cssAnimIdx++; return e.cssAnims[n] = t, n } function $b(t) { return X(t) ? Ub[t] ? "cubic-bezier(" + Ub[t] + ")" : rn(t) ? t : "" : "" } function Jb(t, e, n, i) { var r = t.animators , o = r.length , a = []; if (t instanceof Hu) { if (y = function (t, e, n) { var i, r, o = t.shape.paths, a = {}; if (E(o, (function (t) { var e = Hb(n.zrId); e.animation = !0, Jb(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 = Kb(a, n); return i.replace(r, s) } }(t, e, n)) a.push(y); else if (!o) return } else if (!o) return; for (var s = {}, l = 0; l < o; l++) { var u = r[l] , h = [u.getMaxTime() / 1e3 + "s"] , c = $b(u.getClip().easing) , p = u.getDelay(); c ? h.push(c) : h.push("linear"), p && h.push(p / 1e3 + "s"), u.getLoop() && h.push("infinite"); var d = h.join(" "); s[d] = s[d] || [d, []], s[d][1].push(u) } function f(r) { var o, a = r[1], s = a.length, l = {}, u = {}, h = {}; function c(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] , c = Math.round(h.time / r * 100) + "%" , p = $b(h.easing) , d = h.rawValue; (X(d) || j(d)) && (e[c] = e[c] || {}, e[c][l] = h.rawValue, p && (e[c]["animation-timing-function"] = p)) } } } } for (var p = 0; p < s; p++) { (w = (b = a[p]).targetName) ? "shape" === w && c(b, u) : !i && c(b, l) } for (var d in l) { var f = {}; $i(f, t), A(f, l[d]); var g = Un(f) , y = l[d]["animation-timing-function"]; h[d] = g ? { transform: g } : {}, jb(h[d], f), y && (h[d]["animation-timing-function"] = y) } var v = !0; for (var d in u) { h[d] = h[d] || {}; var m = !o; y = u[d]["animation-timing-function"]; m && (o = new ja); var x = o.len(); o.reset(), h[d].d = Zb(t, u[d], o); var _ = o.len(); if (!m && x !== _) { v = !1; break } y && (h[d]["animation-timing-function"] = y) } if (!v) for (var d in h) delete h[d].d; if (!i) for (p = 0; p < s; p++) { var b, w; "style" === (w = (b = a[p]).targetName) && c(b, h, (function (t) { return qb[t] } )) } var S, M = G(h), I = !0; for (p = 1; p < M.length; p++) { var T = M[p - 1] , C = M[p]; if (h[T][Xb] !== h[C][Xb]) { I = !1; break } S = h[T][Xb] } if (I && S) { for (var d in h) h[d][Xb] && delete h[d][Xb]; e[Xb] = S } if (B(M, (function (t) { return G(h[t]).length > 0 } )).length) return Kb(h, n) + " " + r[0] + " both" } for (var g in s) { var y; (y = f(s[g])) && a.push(y) } if (a.length) { var v = n.zrId + "-cls-" + n.cssClassIdx++; n.cssNodes["." + v] = { animation: a.join(",") }, e.class = v } } var Qb = Math.round; function tw(t) { return t && X(t.src) } function ew(t) { return t && U(t.toDataURL) } function nw(t, e, n, i) { zb((function (r, o) { var a = "fill" === r || "stroke" === r; a && function (t) { return t && ("linear" === t.type || "radial" === t.type) }(o) ? function (t, e, n, i) { var r, o = t[n], a = { gradientUnits: o.global ? "userSpaceOnUse" : "objectBoundingBox" }; if (Gn(o)) r = "linearGradient", a.x1 = o.x, a.y1 = o.y, a.x2 = o.x2, a.y2 = o.y2; else { if (!Wn(o)) return void 0; r = "radialGradient", a.cx = rt(o.x, .5), a.cy = rt(o.y, .5), a.r = rt(o.r, .5) } for (var s = o.colorStops, l = [], u = 0, h = s.length; u < h; ++u) { var c = 100 * Vn(s[u].offset) + "%" , p = Rn(s[u].color) , d = p.color , f = p.opacity , g = { offset: c }; g["stop-color"] = d, f < 1 && (g["stop-opacity"] = f), l.push(Gb("stop", u + "", g)) } var y = Wb(Gb(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] = Gb(r, m, a, l)); e[n] = Hn(m) }(e, t, r, i) : a && function (t) { return Fn(t) || function (t) { return t && !!t.svgElement }(t) }(o) ? function (t, e, n, i) { var r, o = t.style[n], a = { patternUnits: "userSpaceOnUse" }; if (Fn(o)) { var s = o.imageWidth , l = o.imageHeight , u = void 0 , h = o.image; if (X(h) ? u = h : tw(h) ? u = h.src : ew(h) && (u = h.toDataURL()), "undefined" == typeof Image) { var c = "Image width/height must been given explictly in svg-ssr renderer."; lt(s, c), lt(l, c) } else if (null == s || null == l) { var p = function (t, e) { if (t) { var n = t.elm , i = t.attrs.width = s || e.width , r = t.attrs.height = l || e.height; n && (n.setAttribute("width", i), n.setAttribute("height", r)) } } , d = Zo(u, null, t, (function (t) { p(f, t), p(r, t) } )); d && d.width && d.height && (s = s || d.width, l = l || d.height) } r = Gb("image", "img", { href: u, width: s, height: l }), a.width = s, a.height = l } else o.svgElement && (r = o.svgElement, a.width = o.svgWidth, a.height = o.svgHeight); if (!r) return; a.patternTransform = Un(o); var f = Gb("pattern", "", a, [r]) , g = Wb(f) , y = i.patternCache , v = y[g]; v || (v = i.zrId + "-p" + i.patternIdx++, y[g] = v, a.id = v, f = i.defs[v] = Gb("pattern", v, a, [r])); e[n] = Hn(v) }(n, t, r, i) : t[r] = o } ), 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 = Rn(i.shadowColor) , f = d.opacity , g = d.color , y = p / 2 / l + " " + p / 2 / u; a = n.zrId + "-s" + n.shadowIdx++, n.defs[a] = Gb("filter", a, { id: a, x: "-100%", y: "-100%", width: "300%", height: "300%" }, [Gb("feDropShadow", "", { dx: h / l, dy: c / u, stdDeviation: y, "flood-color": g, "flood-opacity": f })]), o[r] = a } e.filter = Hn(a) } }(n, t, i) } function iw(t) { return En(t[0] - 1) && En(t[1]) && En(t[2]) && En(t[3] - 1) } function rw(t, e, n) { if (e && (!function (t) { return En(t[4]) && En(t[5]) }(e) || !iw(e))) { var i = n ? 10 : 1e4; t.transform = iw(e) ? "translate(" + Qb(e[4] * i) / i + " " + Qb(e[5] * i) / i + ")" : function (t) { return "matrix(" + zn(t[0]) + "," + zn(t[1]) + "," + zn(t[2]) + "," + zn(t[3]) + "," + Vn(t[4]) + "," + Vn(t[5]) + ")" }(e) } } function ow(t, e, n) { for (var i = t.points, r = [], o = 0; o < i.length; o++) r.push(Qb(i[o][0] * n) / n), r.push(Qb(i[o][1] * n) / n); e.points = r.join(" ") } function aw(t) { return !t.smooth } var sw, lw, uw = { circle: [(sw = ["cx", "cy", "r"], lw = z(sw, (function (t) { return "string" == typeof t ? [t, t] : t } )), function (t, e, n) { for (var i = 0; i < lw.length; i++) { var r = lw[i] , o = t[r[0]]; null != o && (e[r[1]] = Qb(o * n) / n) } } )], polyline: [ow, aw], polygon: [ow, aw] }; function hw(t, e) { var n = t.style , i = t.shape , r = uw[t.type] , o = {} , a = e.animation , s = "path" , l = t.style.strokePercent , u = e.compress && Yn(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) { t.path || t.createPathProxy(); var h = t.path; t.shapeChanged() && (h.beginPath(), t.buildPath(h, t.shape), t.pathUpdated()); var c = h.getVersion() , p = t , d = p.__svgPathBuilder; p.__svgPathVersion === c && d && l === p.__svgPathStrokePercent || (d || (d = p.__svgPathBuilder = new Pb), d.reset(u), h.rebuildPath(d, l), d.generateStr(), p.__svgPathVersion = c, p.__svgPathStrokePercent = l), o.d = d.getStr() } else { s = t.type; var f = Math.pow(10, u); r[0](i, o, f) } return rw(o, t.transform), nw(o, n, t, e), e.animation && Jb(t, o, e), Gb(s, t.id + "", o) } function cw(t, e) { return t instanceof fs ? hw(t, e) : t instanceof xs ? function (t, e) { var n = t.style , i = n.image; if (i && !X(i) && (tw(i) ? i = i.src : ew(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), rw(a, t.transform), nw(a, n, t, e), e.animation && Jb(t, a, e), Gb("image", t.id + "", a) } }(t, e) : t instanceof ys ? 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, fr(r), n.textBaseline) , u = { "dominant-baseline": "central", "text-anchor": Bn[n.textAlign] || n.textAlign }; if (Ns(n)) { var h = "" , c = n.fontStyle , p = Os(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), rw(u, t.transform), nw(u, n, t, e), e.animation && Jb(t, u, e), Gb("text", t.id + "", u, void 0, i) } }(t, e) : void 0 } function pw(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] = Gb("clipPath", o, a, [hw(t, n)]) } e["clip-path"] = Hn(o) } function dw(t) { return document.createTextNode(t) } function fw(t, e, n) { t.insertBefore(e, n) } function gw(t, e) { t.removeChild(e) } function yw(t, e) { t.appendChild(e) } function vw(t) { return t.parentNode } function mw(t) { return t.nextSibling } function xw(t, e) { t.textContent = e } var _w = Gb("", ""); function bw(t) { return void 0 === t } function ww(t) { return void 0 !== t } function Sw(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 Mw(t, e) { var n = t.key === e.key; return t.tag === e.tag && n } function Iw(t) { var e, n = t.children, i = t.tag; if (ww(i)) { var r = t.elm = Fb(i); if (Dw(_w, t), Y(n)) for (e = 0; e < n.length; ++e) { var o = n[e]; null != o && yw(r, Iw(o)) } else ww(t.text) && !q(t.text) && yw(r, dw(t.text)) } else t.elm = dw(t.text); return t.elm } function Tw(t, e, n, i, r) { for (; i <= r; ++i) { var o = n[i]; null != o && fw(t, Iw(o), e) } } function Cw(t, e, n, i) { for (; n <= i; ++n) { var r = e[n]; if (null != r) if (ww(r.tag)) gw(vw(r.elm), r.elm); else gw(t, r.elm) } } function Dw(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) : 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(Bb, n, a) : i.setAttribute(n, a)) } for (n in r) n in o || i.removeAttribute(n) } } function Aw(t, e) { var n = e.elm = t.elm , i = t.children , r = e.children; t !== e && (Dw(t, e), bw(e.text) ? ww(i) && ww(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] : Mw(u, p) ? (Aw(u, p), u = e[++a], p = n[++s]) : Mw(h, d) ? (Aw(h, d), h = e[--l], d = n[--c]) : Mw(u, d) ? (Aw(u, d), fw(t, u.elm, mw(h.elm)), u = e[++a], d = n[--c]) : Mw(h, p) ? (Aw(h, p), fw(t, h.elm, u.elm), h = e[--l], p = n[++s]) : (bw(i) && (i = Sw(e, a, l)), bw(r = i[p.key]) || (o = e[r]).tag !== p.tag ? fw(t, Iw(p), u.elm) : (Aw(o, p), e[r] = void 0, fw(t, o.elm, u.elm)), p = n[++s]); (a <= l || s <= c) && (a > l ? Tw(t, null == n[c + 1] ? null : n[c + 1].elm, n, s, c) : Cw(t, e, a, l)) }(n, i, r) : ww(r) ? (ww(t.text) && xw(n, ""), Tw(n, null, r, 0, r.length - 1)) : ww(i) ? Cw(n, i, 0, i.length - 1) : ww(t.text) && xw(n, "") : t.text !== e.text && (ww(i) && Cw(n, i, 0, i.length - 1), xw(n, e.text))) } var kw = 0 , Lw = function () { function t(t, e, n) { if (this.type = "svg", this.refreshHover = Pw("refreshHover"), this.configLayer = Pw("configLayer"), this.storage = e, this._opts = n = A({}, n), this.root = t, this._id = "zr" + kw++, this._oldVNode = Yb(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 = Fb("svg"); Dw(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 (Mw(t, e)) Aw(t, e); else { var n = t.elm , i = vw(n); Iw(e), null !== i && (fw(i, e.elm, mw(n)), Cw(i, [t], 0, 0)) } }(this._oldVNode, t), this._oldVNode = t } } , t.prototype.renderOneToVNode = function (t) { return cw(t, Hb(this._id)) } , t.prototype.renderToVNode = function (t) { t = t || {}; var e = this.storage.getDisplayList(!0) , n = this._backgroundColor , i = this._width , r = this._height , o = Hb(this._id); o.animation = t.animation, o.willUpdate = t.willUpdate, o.compress = t.compress; var a = []; if (n && "none" !== n) { var s = Rn(n) , l = s.color , u = s.opacity; this._bgVNode = Gb("rect", "bg", { width: i, height: r, x: "0", y: "0", id: "0", fill: l, "fill-opacity": u }), a.push(this._bgVNode) } else this._bgVNode = null; var h = t.compress ? null : this._mainVNode = Gb("g", "main", {}, []); this._paintList(e, o, h ? h.children : a), h && a.push(h); var c = z(G(o.defs), (function (t) { return o.defs[t] } )); if (c.length && a.push(Gb("defs", "defs", {}, c)), t.animation) { var p = 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) : "" }(o.cssNodes, o.cssAnims, { newline: !0 }); if (p) { var d = Gb("style", "stl", {}, [], p); a.push(d) } } return Yb(i, r, a, t.useViewBox) } , t.prototype.renderToString = function (t) { return t = t || {}, Wb(this.renderToVNode({ animation: rt(t.cssAnimation, !0), willUpdate: !1, compress: !0, useViewBox: rt(t.useViewBox, !0) }), { newline: !0 }) } , t.prototype.setBackgroundColor = function (t) { this._backgroundColor = t; var e = this._bgVNode; if (e && e.elm) { var n = Rn(t) , i = n.color , r = n.opacity; e.elm.setAttribute("fill", i), r < 1 && e.elm.setAttribute("fill-opacity", r) } } , 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 = {}; pw(c[y], v, e); var m = Gb("g", "clip-g-" + l++, v, []); (i ? i.children : n).push(m), a[s++] = m, i = m } r = c; var x = cw(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 = Ny(i, 0, n), e = Ny(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" } var a = this._svgDom; a && (a.setAttribute("width", t), a.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 = encodeURIComponent(this.renderToString()) , n = "data:image/svg+xml;"; return t ? (e = Xn(e)) && n + "base64," + e : n + "charset=UTF-8," + e } , t }(); function Pw(t) { return function () { 0 } } function Ow(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 Rw = function (t) { function e(e, n, i) { var r, o = t.call(this) || this; o.motionBlur = !1, o.lastFrameAlpha = .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 || Ai, "string" == typeof e ? r = Ow(e, n, i) : q(e) && (e = (r = e).id), o.id = e, o.dom = r; var a = r.style; return a && (vt(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 = Ow("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 sr(0, 0, 0, 0); function u(t) { if (t.isFinite() && !t.isZero()) if (0 === o.length) { (e = new sr(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 sr(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 sr(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]).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; Q(e) ? (a = e.__canvasGradient || Oy(r, e, { x: 0, y: 0, width: i, height: o }), e.__canvasGradient = a) : tt(e) && (a = Hy(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 }(Xt) , Nw = 1e5 , Ew = 314159 , zw = .01; var Vw = 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 || Ai, this._singleCanvas = r, this.root = t, t.style && (vt(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 Rw(s, this, this.dpr); h.__builtin__ = !0, h.initContext(), a[314159] = h, h.zlevel = Ew, o.push(Ew), this._domRoot = t } else { this._width = Ny(t, 0, n), this._height = Ny(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(Nw)), i || (i = n.ctx).save(), Jy(i, a, r, o === e - 1)) } i && i.restore() } } , t.prototype.getHoverLayer = function () { return this.getLayer(Nw) } , t.prototype.paintOne = function (t, e) { $y(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; ke((function () { s._paintList(t, e, n, i) } )) } } } , t.prototype._compositeManually = function () { var t = this.getLayer(Ew).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)) && (Jy(a, t, r, o), t.setPrevPaintRect(s)) } else Jy(a, t, r, o) } , t.prototype.getLayer = function (t, e) { this._singleCanvas && !this._needsManuallyCompositing && (t = Ew); var n = this._layers[t]; return n || ((n = new Rw("zr_" + t, this, this.dpr)).zlevel = t, n.__builtin__ = !0, this._layerConfig[t] ? C(n, this._layerConfig[t], !0) : this._layerConfig[t - zw] && C(n, this._layerConfig[t - zw], !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 = 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 + .001, this._needsManuallyCompositing)).incremental = !0, a = 1) : u = this.getLayer(l + (a > 0 ? zw : 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 + zw) 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 = Ny(r, 0, i), e = Ny(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(Ew).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 Rw("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]; Jy(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 Bw = 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 nx(null, this, { useEncodeDefaulter: !0 }) } , e.prototype.getLegendIcon = function (t) { var e = new Cr , n = ky("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 = .8 * t.itemHeight , s = ky(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 }(ag); function Fw(t, e) { var n = t.mapDimensionsAll("defaultedLabel") , i = n.length; if (1 === i) { var r = of(t, e, n[0]); return null != r ? r + "" : null } if (i) { for (var o = [], a = 0; a < n.length; a++) o.push(of(t, e, n[a])); return o.join(" ") } } function Gw(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 Ww = 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 = ky(t, -1, -1, 2, 2, null, r); o.attr({ z2: 100, culling: !0, scaleX: i[0] / 2, scaleY: i[1] / 2 }), o.drift = Hw, 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 () { xl(this.childAt(0)) } , e.prototype.downplay = function () { _l(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) { var e = this.childAt(0); e.draggable = t, e.cursor = t ? "move" : e.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) : ih(p, c, a, n), uh(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, rh(p, c, a, n) } } u && this.childAt(0).stopAnimation("leave"), this._seriesModel = a } , 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 = Hh(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 = Py(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 xs) { 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; Wh(f, c, { labelFetcher: g, labelDataIndex: e, defaultText: function (e) { return I ? t.getName(e) : Fw(t, e) }, inheritColor: b, defaultOpacity: _.opacity }), this._sizeX = n[0] / 2, this._sizeY = n[1] / 2; var T = f.ensureState("emphasis"); if (T.style = o, f.ensureState("select").style = s, f.ensureState("blur").style = a, p) { var C = Math.max(1.1, 3 / this._sizeY); T.scaleX = this._sizeX * C, T.scaleY = this._sizeY * C } this.setSymbolScale(1), Ol(this, l, u, h) } , e.prototype.setSymbolScale = function (t) { this.scaleX = this.scaleY = t } , e.prototype.fadeOut = function (t, e) { var n = this.childAt(0) , i = this._seriesModel , r = Ws(this).dataIndex , o = e && e.animation; if (this.silent = n.silent = !0, e && e.fadeLabel) { var a = n.getTextContent(); a && ah(a, { style: { opacity: 0 } }, i, { dataIndex: r, removeOpt: o, cb: function () { n.removeTextContent() } }) } else n.removeTextContent(); ah(n, { style: { opacity: 0 }, scaleX: 0, scaleY: 0 }, i, { dataIndex: r, cb: t, removeOpt: o }) } , e.getSymbolSize = function (t, e) { return Ly(t.getItemVisual(e, "symbolSize")) } , e }(Cr); function Hw(t, e) { this.parent.drift(t, e) } function Yw(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 Uw(t) { return null == t || q(t) || (t = { isIgnore: t }), t || {} } function Xw(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: Hh(e), cursorStyle: e.get("cursor") } } var Zw = function () { function t(t) { this.group = new Cr, this._SymbolCtor = t || Ww } return t.prototype.updateData = function (t, e) { this._progressiveEls = null, e = Uw(e); var n = this.group , i = t.hostModel , r = this._data , o = this._SymbolCtor , a = e.disableAnimation , s = Xw(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 (Yw(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 (Yw(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) : ih(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) } )) } )).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 = Xw(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 = Uw(n); for (var r = t.start; r < t.end; r++) { var o = e.getItemLayout(r); if (Yw(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) { zh(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) } )) } )) : e.removeAll() } , t }(); function jw(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] : 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 tx(e, c[0]) && (p = !0, c[0] = d), tx(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 qw(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 Kw = Math.min , $w = Math.max; function Jw(t, e) { return isNaN(t) || isNaN(e) } function Qw(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 (Jw(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 + _ * _ < .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 (; Jw(w, S) && M < i;) M++, w = e[2 * (b += o)], S = e[2 * b + 1]; var I = .5 , T = 0 , C = 0 , D = void 0 , A = void 0; if (M >= i || Jw(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 = Kw(D = v + T * a * I, $w(w, v)), A = Kw(A, $w(S, m)), D = $w(D, Kw(w, v)), f = m - (C = (A = $w(A, Kw(S, m))) - m) * R / N, d = Kw(d = v - (T = D - v) * R / N, $w(u, v)), f = Kw(f, $w(h, m)), D = v + (T = v - (d = $w(d, Kw(u, v)))) * N / R, A = m + (C = m - (f = $w(f, Kw(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 } , eS = 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 && Jw(n[2 * r - 2], n[2 * r - 1]); r--) ; for (; i < r && Jw(n[2 * i], n[2 * i + 1]); i++) ; } for (; i < r;) i += Qw(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 = ja.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 ? Ue(n, u, c, d, t, s) : Ue(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 ? He(i, h, p, f, x) : He(n, u, c, d, x); return a ? [t, y] : [y, t] } } n = d, i = f } } } , e }(fs) , nS = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e }(tS) , iS = 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 nS } , 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 && Jw(n[2 * o - 2], n[2 * o - 1]); o--) ; for (; r < o && Jw(n[2 * r], n[2 * r + 1]); r++) ; } for (; r < o;) { var s = Qw(t, n, r, o, o, 1, e.smooth, a, e.connectNulls); Qw(t, i, r + s - 1, s, o, -1, e.stackedOnSmooth, a, e.connectNulls), r += s + 1, t.closePath() } } , e }(fs); function rS(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"]) || 2; a -= h / 2, s -= h / 2, l += h, u += h, a = Math.floor(a), l = Math.round(l); var c = new Ts({ 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 = U(r) ? function (t) { r(t, c) } : null; rh(c, { shape: { width: l, height: u, x: a, y: s } }, n, null, i, g) } return c } function oS(t, e, n) { var i = t.getArea() , r = zr(i.r0, 1) , o = zr(i.r, 1) , a = new Tu({ shape: { cx: zr(t.cx, 1), cy: zr(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, rh(a, { shape: { endAngle: i.endAngle, r: o } }, n)); return a } function aS(t, e, n, i, r) { return t ? "polar" === t.type ? oS(t, e, n) : "cartesian2d" === t.type ? rS(t, e, n, i, r) : null : null } function sS(t, e) { return t.type === e } function lS(t, e) { if (t.length === e.length) { for (var n = 0; n < t.length; n++) if (t[n] !== e[n]) return; return !0 } } function uS(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 hS(t, e) { var n = uS(t) , i = n[0] , r = n[1] , o = uS(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 cS(t) { return j(t) ? t : t ? .5 : 0 } function pS(t, e, n) { for (var i = e.getBaseAxis(), r = "x" === i.dim || "radius" === i.dim ? 0 : 1, o = [], a = 0, s = [], l = [], u = []; a < t.length - 2; a += 2) switch (u[0] = t[a + 2], u[1] = t[a + 3], l[0] = t[a], l[1] = t[a + 1], o.push(l[0], l[1]), n) { case "end": s[r] = u[r], s[1 - r] = l[1 - r], o.push(s[0], s[1]); break; case "middle": var h = (l[r] + u[r]) / 2 , c = []; s[r] = c[r] = h, s[1 - r] = l[1 - r], c[1 - r] = u[1 - r], o.push(s[0], s[1]), o.push(c[0], c[1]); break; default: s[r] = l[r], s[1 - r] = u[1 - r], o.push(s[0], s[1]) } return o.push(t[a++], t[a++]), o } function dS(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: Tn((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 < .001) return "transparent"; E(p, (function (t) { t.offset = (t.coord - f) / y } )), p.push({ offset: d ? p[d - 1].offset : .5, color: c[1] || "transparent" }), p.unshift({ offset: d ? p[0].offset : .5, color: c[0] || "transparent" }); var v = new Uu(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 * Ww.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 yS(t) { if (t.get(["endLabel", "show"])) return !0; for (var e = 0; e < js.length; e++) if (t.get([js[e], "endLabel", "show"])) return !0; return !1 } function vS(t, e, n, i) { if (sS(e, "cartesian2d")) { var r = i.getModel("endLabel") , o = r.get("valueAnimation") , a = i.getData() , s = { lastFrameIndex: 0 } , l = yS(i) ? function (n, i) { t._endLabelOnDuring(n, i, a, s, o, r, e) } : null , u = e.getBaseAxis().isHorizontal() , h = rS(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 oS(e, n, i) } var mS = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.init = function () { var t = new Cr , e = new Zw; this.group.add(e.group), this._symbolDraw = e, this._lineGroup = t } , e.prototype.render = function (t, e, n) { var i = this , r = t.coordinateSystem , o = this.group , a = t.getData() , s = t.getModel("lineStyle") , l = t.getModel("areaStyle") , u = a.getLayout("points") || [] , h = "polar" === r.type , c = this._coordSys , p = this._symbolDraw , d = this._polyline , f = this._polygon , g = this._lineGroup , y = t.get("animation") , v = !l.isEmpty() , m = l.get("origin") , x = jw(r, a, m) , _ = v && function (t, e, n) { if (!n.valueDim) return []; for (var i = e.count(), r = _x(2 * i), o = 0; o < i; o++) { var a = qw(n, t, e, o); r[2 * o] = a[0], r[2 * o + 1] = a[1] } return r }(r, a, x) , b = t.get("showSymbol") , w = b && !h && fS(t, a, r) , S = this._data; S && S.eachItemGraphicEl((function (t, e) { t.__temp && (o.remove(t), S.setItemGraphicEl(e, null)) } )), b || p.remove(), o.add(g); var M, I = !h && t.get("step"); r && r.getArea && t.get("clip", !0) && (null != (M = r.getArea()).width ? (M.x -= .1, M.y -= .1, M.width += .2, M.height += .2) : M.r0 && (M.r0 -= .5, M.r += .5)), this._clipShapeForSymbol = M; var T = dS(a, r, n) || a.getVisual("style")[a.getVisual("drawType")]; if (d && c.type === r.type && I === this._step) { v && !f ? f = this._newPolygon(u, _) : f && !v && (g.remove(f), f = this._polygon = null), h || this._initOrUpdateEndLabel(t, r, cp(T)); var C = g.getClipPath(); if (C) rh(C, { shape: vS(this, r, !1, t).shape }, t); else g.setClipPath(vS(this, r, !0, t)); b && p.updateData(a, { isIgnore: w, clipShape: M, disableAnimation: !0, getSymbolPoint: function (t) { return [u[2 * t], u[2 * t + 1]] } }), lS(this._stackedOnPoints, _) && lS(this._points, u) || (y ? this._doUpdateAnimation(a, _, r, n, I, m) : (I && (u = pS(u, r, I), _ && (_ = pS(_, r, I))), d.setShape({ points: u }), f && f.setShape({ points: u, stackedOnPoints: _ }))) } else b && p.updateData(a, { isIgnore: w, clipShape: M, disableAnimation: !0, getSymbolPoint: function (t) { return [u[2 * t], u[2 * t + 1]] } }), y && this._initSymbolLabelAnimation(a, r, M), I && (u = pS(u, r, I), _ && (_ = pS(_, r, I))), d = this._newPolyline(u), v && (f = this._newPolygon(u, _)), h || this._initOrUpdateEndLabel(t, r, cp(T)), g.setClipPath(vS(this, r, !0, t)); var D = t.getModel("emphasis") , A = D.get("focus") , L = D.get("blurScope") , P = D.get("disabled"); (d.useStyle(k(s.getLineStyle(), { fill: "none", stroke: T, lineJoin: "bevel" })), zl(d, t, "lineStyle"), d.style.lineWidth > 0 && "bolder" === t.get(["emphasis", "lineStyle", "width"])) && (d.getState("emphasis").style.lineWidth = +d.style.lineWidth + 1); Ws(d).seriesIndex = t.seriesIndex, Ol(d, A, L, P); var O = cS(t.get("smooth")) , R = t.get("smoothMonotone") , N = t.get("connectNulls"); if (d.setShape({ smooth: O, smoothMonotone: R, connectNulls: N }), f) { var E = a.getCalculationInfo("stackedOnSeries") , z = 0; f.useStyle(k(l.getAreaStyle(), { fill: T, opacity: .7, lineJoin: "bevel", decal: a.getVisual("style").decal })), E && (z = cS(E.get("smooth"))), f.setShape({ smooth: O, stackedOnSmooth: z, smoothMonotone: R, connectNulls: N }), zl(f, t, "areaStyle"), Ws(f).seriesIndex = t.seriesIndex, Ol(f, A, L, P) } var V = function (t) { i._changePolyState(t) }; a.eachItemGraphicEl((function (t) { t && (t.onHoverStateChange = V) } )), this._polyline.onHoverStateChange = V, this._data = a, this._coordSys = r, this._stackedOnPoints = _, this._points = u, this._step = I, this._valueOrigin = m, t.get("triggerLineEvent") && (this.packEventData(t, d), f && this.packEventData(t, f)) } , e.prototype.packEventData = function (t, e) { Ws(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 = wo(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") , c = t.get("z"); (s = new Ww(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 mg.prototype.highlight.call(this, t, e, n, i) } , e.prototype.downplay = function (t, e, n, i) { var r = t.getData() , o = wo(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 mg.prototype.downplay.call(this, t, e, n, i) } , e.prototype._changePolyState = function (t) { var e = this._polygon; fl(this._polyline, t), e && fl(e, t) } , e.prototype._newPolyline = function (t) { var e = this._polyline; return e && this._lineGroup.remove(e), e = new eS({ 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 iS({ 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"); U(l) && (l = l(null)); var u = s.get("animationDelay") || 0 , h = U(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 = U(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 (yS(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 As({ 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 && (Wh(o, Hh(t, "endLabel"), { inheritColor: n, labelFetcher: t, labelDataIndex: l, defaultText: function (t, e, n) { return null != n ? Gw(r, n) : Fw(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 = Po(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] + _ }) } r && $h(s).setLabelText(I) } } , e.prototype._doUpdateAnimation = function (t, e, n, i, r, o) { var a = this._polyline , s = this._polygon , l = t.hostModel , u = 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 = jw(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 = qw(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 = _x(P) , R = _x(P) , N = _x(P) , E = _x(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) , h = u.current , c = u.stackedOnCurrent , p = u.next , d = u.stackedOnNext; if (r && (h = pS(u.current, n, r), c = pS(u.stackedOnCurrent, n, r), p = pS(u.next, n, r), d = pS(u.stackedOnNext, n, r)), hS(h, p) > 3e3 || s && hS(c, d) > 3e3) return a.stopAnimation(), a.setShape({ points: p }), void (s && (s.stopAnimation(), s.setShape({ points: p, stackedOnPoints: d }))); a.shape.__points = u.current, a.shape.points = h; var f = { shape: { points: p } }; u.current !== h && (f.shape.__points = u.next), a.stopAnimation(), ih(a, f, l), s && (s.setShape({ points: h, stackedOnPoints: c }), s.stopAnimation(), ih(s, { shape: { stackedOnPoints: d } }, l), a.shape.points !== s.shape.points && (s.shape.points = a.shape.points)); for (var g = [], y = u.status, v = 0; v < y.length; v++) { if ("=" === y[v].cmd) { var m = t.getItemGraphicEl(y[v].idx1); m && g.push({ el: m, ptIdx: v }) } } a.animators && a.animators.length && a.animators[0].during((function () { s && s.dirtyShape(); for (var t = a.shape.__points, e = 0; e < g.length; e++) { var n = g[e].el , i = 2 * g[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 }(mg); function xS(t, e) { return { seriesType: t, plan: gg(), 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"); tx(n, a[0]) && (a[0] = l), tx(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 && _x(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 _S = { 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] } } , bS = function (t) { return Math.round(t.length / 2) }; function wS(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 (p > 1) { "lttb" === r && t.setData(i.lttbDownSample(i.mapDimension(l.dim), 1 / p)); var d = void 0; X(r) ? d = _S[r] : U(r) && (d = r), d && t.setData(i.downSample(i.mapDimension(l.dim), 1 / p, d, bS)) } } } } } var SS = 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 nx(null, this, { useEncodeDefaulter: !0 }) } , e.prototype.getMarkerPosition = function (t) { var e = this.coordinateSystem; if (e && e.clampData) { var n = e.dataToPoint(e.clampData(t)) , i = this.getData() , r = i.getLayout("offset") , o = i.getLayout("size"); return n[e.getBaseAxis().isHorizontal() ? 0 : 1] += r + o / 2, n } 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 }(ag); ag.registerClass(SS); var MS = 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 nx(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 = gc(SS.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 }(SS) , IS = function () { this.cx = 0, this.cy = 0, this.r0 = 0, this.r = 0, this.startAngle = 0, this.endAngle = 2 * Math.PI, this.clockwise = !0 } , TS = 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 IS } , 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 = .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 }(fs); function CS(t, e, n) { return e * Math.sin(t) * (n ? -1 : 1) } function DS(t, e, n) { return e * Math.cos(t) * (n ? 1 : -1) } var AS = Math.max , kS = Math.min; var LS = 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) { zh(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 (sS(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 = BS[l.type](a, t) , n = function (t, e, n) { return new ("polar" === t.type ? Tu : Ts)({ shape: XS(e, n, t), silent: !0, z2: 0 }) }(l, r, e); return n.useStyle(y.getItemStyle()), "cartesian2d" === l.type && n.setShape("r", v), m[t] = n, n } a.diff(s).add((function (e) { var n = a.getItemModel(e) , i = BS[l.type](a, e, n); if (g && w(e), a.hasValue(e) && VS[l.type](i)) { var s = !1; p && (s = PS[l.type](d, i)); var y = OS[l.type](t, a, e, i, r, h, u.model, !1, f); c && (y.forceLabelAnimation = !0), GS(y, a, e, n, i, t, r, "polar" === l.type), _ ? y.attr({ shape: i }) : c ? RS(c, h, y, i, e, r, !1, !1) : rh(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 = BS[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[e] = M); var I = BS[l.type](a, e); ih(M, { shape: XS(r, I, l) }, h, e) } var T = s.getItemGraphicEl(n); if (a.hasValue(e) && VS[l.type](S)) { var C = !1; if (p && (C = PS[l.type](d, S)) && o.remove(T), T ? uh(T) : T = OS[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 = $h(D); null != A.prevValue && (A.prevValue = A.value) } } else GS(T, a, e, i, S, t, r, "polar" === l.type); _ ? T.attr({ shape: S }) : c ? RS(c, h, T, S, e, r, !0, b) : ih(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 && lh(n, t, e) } )).execute(); var S = this._backgroundGroup || (this._backgroundGroup = new Cr); 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(), YS(t, this.group), this._updateLargeClip(t) } , e.prototype._incrementalRenderLarge = function (t, e) { this._removeBackground(), YS(e, this.group, this._progressiveEls, !0) } , e.prototype._updateLargeClip = function (t) { var e = t.get("clip", !0) && aS(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) { lh(e, t, Ws(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 }(mg) , PS = { 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 = AS(e.x, t.x) , s = kS(e.x + e.width, r) , l = AS(e.y, t.y) , u = kS(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 = kS(e.r, t.r) , o = AS(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 } } , OS = { cartesian2d: function (t, e, n, i, r, o, a, s, l) { var u = new Ts({ 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 ? TS : Tu , h = new u({ shape: i, z2: 1 }); h.name = "item"; var c, p, d = FS(r); if (h.calculateTextPosition = (c = d, p = ({ isRoundCap: u === TS } || {}).isRoundCap, function (t, e, n) { var i = e.position; if (!i || i instanceof Array) return yr(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) + CS(f, o + v, !1), b = l + d * x(f) + DS(f, o + v, !1), w = "right", S = "middle"; break; case "insideStartAngle": _ = s + d * m(f) + CS(f, -o + v, !1), b = l + d * x(f) + DS(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) + CS(g, o + v, !0), b = l + d * x(g) + DS(g, o + v, !0), w = "left", S = "middle"; break; case "insideEndAngle": _ = s + d * m(g) + CS(g, -o + v, !0), b = l + d * x(g) + DS(g, -o + v, !0), w = "right", S = "middle"; break; default: return yr(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 ? 0 : i.startAngle, g[f] = i[f], (s ? ih : rh)(h, { shape: g }, o) } return h } }; function RS(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 ? ih : rh)(n, { shape: l }, e, r, null), (a ? ih : rh)(n, { shape: u }, e ? t.baseAxis.model : null, r) } function NS(t, e) { for (var n = 0; n < e.length; n++) if (!isFinite(t[e[n]])) return !0; return !1 } var ES = ["x", "y", "width", "height"] , zS = ["cx", "cy", "r", "startAngle", "endAngle"] , VS = { cartesian2d: function (t) { return !NS(t, ES) }, polar: function (t) { return !NS(t, zS) } } , BS = { 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 FS(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 GS(t, e, n, i, r, o, a, s) { var l = e.getItemVisual(n, "style"); s || t.setShape("r", i.get(["itemStyle", "borderRadius"]) || 0), t.useStyle(l); var u = i.getShallow("cursor"); u && t.attr("cursor", u); var h = 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" , c = Hh(i); Wh(t, c, { labelFetcher: o, labelDataIndex: n, defaultText: Fw(o.getData(), n), inheritColor: l.fill, defaultOpacity: l.opacity, defaultOutsidePosition: h }); var p = t.getTextContent(); if (s && p) { var d = i.get(["label", "position"]); t.textConfig.inside = "middle" === d || 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" === d ? h : d, FS(a), i.get(["label", "rotate"])) } Jh(p, c, o.getRawValue(n), (function (t) { return Gw(e, t) } )); var f = i.getModel(["emphasis"]); Ol(t, f.get("focus"), f.get("blurScope"), f.get("disabled")), zl(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 WS = function () { } , HS = 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 WS } , 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 }(fs); function YS(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 HS({ 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 HS({ shape: { points: r.getLayout("largePoints") }, incremental: !!i, z2: 1 }); c.baseDimIdx = o, c.largeDataIndices = a, c.barWidth = s, e.add(c), c.useStyle(r.getVisual("style")), Ws(c).seriesIndex = t.seriesIndex, t.get("silent") || (c.on("mousedown", US), c.on("mousemove", US)), n && n.push(c) } var US = Cg((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); Ws(this).dataIndex = e >= 0 ? e : null } ), 30, !1); function XS(t, e, n) { if (sS(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 ZS = 2 * Math.PI , jS = Math.PI / 180; function qS(t, e) { return mp(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight() }) } function KS(t, e) { var n = qS(t, e) , i = t.get("center") , r = t.get("radius"); Y(r) || (r = [0, r]), Y(i) || (i = [i, i]); var o = Er(n.width, e.getWidth()) , a = Er(n.height, e.getHeight()) , s = Math.min(o, a); return { cx: Er(i[0], o) + n.x, cy: Er(i[1], a) + n.y, r0: Er(r[0], s / 2), r: Er(r[1], s / 2) } } function $S(t, e, n) { e.eachSeriesByType(t, (function (t) { var e = t.getData() , i = e.mapDimension("value") , r = qS(t, n) , o = KS(t, n) , a = o.cx , s = o.cy , l = o.r , u = o.r0 , h = -t.get("startAngle") * jS , c = t.get("minAngle") * jS , p = 0; e.each(i, (function (t) { !isNaN(t) && p++ } )); var d = e.getSum(i) , f = Math.PI / (d || p) * 2 , g = t.get("clockwise") , y = t.get("roseType") , v = t.get("stillShowZeroSum") , m = e.getDataExtent(i); m[0] = 0; var x = ZS , _ = 0 , b = h , w = g ? 1 : -1; 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: g, cx: a, cy: s, r0: u, r: y ? NaN : l }); else { (i = "area" !== y ? 0 === d && v ? f : t * f : ZS / p) < c ? (i = c, x -= c) : _ += t; var r = b + w * i; e.setItemLayout(n, { angle: i, startAngle: b, endAngle: r, clockwise: g, cx: a, cy: s, r0: u, r: y ? Nr(t, m, [u, l]) : l }), b = r } } )), x < ZS && p) if (x <= .001) { var S = ZS / p; e.each(i, (function (t, n) { if (!isNaN(t)) { var i = e.getItemLayout(n); i.angle = S, i.startAngle = h + w * n * S, i.endAngle = h + w * (n + 1) * S } } )) } else f = x / _, b = h, e.each(i, (function (t, n) { if (!isNaN(t)) { var i = e.getItemLayout(n) , r = i.angle === c ? c : t * f; i.startAngle = b, i.endAngle = b + w * r, b += w * r } } )) } )) } function JS(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 QS = Math.PI / 180; function tM(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 } gb(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((1 - Math.abs(u * u / a)) * c) , d = e + (p + l.len2) * r , f = d - l.label.x; eM(l, l.targetTextWidth - f * r, !0), l.label.x = d } } } function eM(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 nM(t) { return "center" === t.position } function iM(t) { var e, n, i = t.getData(), r = [], o = !1, a = (t.get("minShowLabelAngle") || 0) * QS, 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") , _ = Er(y.get("edgeDistance"), u) , b = y.get("bleedMargin") , w = g.getModel("labelLine") , S = w.get("length"); S = Er(S, u); var M = w.get("length2"); if (M = Er(M, u), Math.abs(c.endAngle - c.startAngle) < a) return E(p.states, d), void (p.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 U = (p.style.margin || 0) + 2.1; Y.y -= U / 2, Y.height += U, r.push({ label: p, labelLine: f, position: v, len: S, len2: M, minTurnAngle: w.get("minTurnAngle"), maxSurfaceAngle: w.get("maxSurfaceAngle"), surfaceNormal: new Ji(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; nM(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 (!nM(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, eM(y, g) } for (tM(u, e, n, i, 1, 0, o, 0, s, c), tM(l, e, n, i, -1, 0, o, 0, s, h), p = 0; p < t.length; p++) { var y; if (!nM(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) : (sb(_, g.minTurnAngle), lb(_, g.surfaceNormal, g.maxSurfaceAngle), v.setShape({ points: _ }), y.__hostTarget.textGuideLineConfig = { anchor: new Ji(_[0][0], _[0][1]) }) } } } function rM(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 gr(t, r) } )) } } var oM = function (t) { function e(e, n, i) { var r = t.call(this) || this; r.z2 = 2; var o = new As; 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(rM(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 ? (rh(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, rh(r, { shape: { r: l.r } }, o, e)) : null != n ? (r.setShape({ startAngle: n, endAngle: n }), rh(r, { shape: { startAngle: l.startAngle, endAngle: l.endAngle } }, o, e)) : (r.shape.endAngle = l.startAngle, ih(r, { shape: { endAngle: l.endAngle } }, o, e)) } else uh(r), ih(r, { shape: u }, o, e); r.useStyle(t.getItemVisual(e, "style")), zl(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) }, rM(s.getModel("itemStyle"), l)), A(r.ensureState("select"), { x: d, y: f, shape: rM(a.getModel(["select", "itemStyle"]), l) }), A(r.ensureState("blur"), { shape: rM(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 }), Ol(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; Wh(i, Hh(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 Ou, this.setTextGuideLine(c)), cb(this, pb(r), { stroke: s, opacity: ot(o.get(["lineStyle", "opacity"]), l, 1) }) } } , e }(Tu) , aM = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.ignoreLabelLineUpdate = !0, e } return n(e, t), e.prototype.init = function () { var t = new Cr; this._sectorGroup = 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 = new Tu({ shape: KS(t, n) }); h.useStyle(t.getModel("emptyCircleStyle").getItemStyle()), this._emptyCircleSector = h, s.add(h) } o.diff(a).add((function (t) { var e = new oM(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) { lh(a.getItemGraphicEl(e), t, e) } )).execute(), iM(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 }(mg); function sM(t, e, n) { e = Y(e) && { coordDimensions: e } || A({ encodeDefine: t.getEncode() }, e); var i = t.getSource() , r = jm(i, e).dimensions , o = new Zm(r, t); return o.initData(i, n), o } var lM = 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 }() , uM = 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 lM(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 sM(this, { coordDimensions: ["value"], encodeDefaulter: H(Hp, this) }) } , e.prototype.getDataParams = function (e) { var n = this.getData() , i = t.prototype.getDataParams.call(this, e) , r = []; return n.each(n.mapDimension("value"), (function (t) { r.push(t) } )), i.percent = Wr(r, e, n.hostModel.get("percentPrecision")), i.$vars.push("percent"), i } , 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, 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 }(ag); var hM = 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 nx(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: .8 }, emphasis: { scale: !0 }, clip: !0, select: { itemStyle: { borderColor: "#212121" } }, universalTransition: { divideShape: "clone" } }, e }(ag) , cM = function () { } , pM = 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 cM } , 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 sr(a - r / 2, s - o / 2, l - a + r, u - s + o) } return t } , e }(fs) , dM = function () { function t() { this.group = new Cr } 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 pM({ cursor: "default" }); return 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 = ky(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 = Ws(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 }() , fM = 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) { var e = t.coordinateSystem , n = e && e.getArea && e.getArea(); return t.get("clip", !0) ? n : null } , 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 dM : new Zw, 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 }(mg) , gM = 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 }(Ip) , 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", Co).models[0] } , e.type = "cartesian2dAxis", e }(Ip); R(yM, h_); var vM = { 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, lineStyle: { color: ["#E0E6F1"], width: 1, type: "solid" } }, splitArea: { show: !1, areaStyle: { color: ["rgba(250,250,250,0.2)", "rgba(210,219,238,0.2)"] } } } , mM = C({ boundaryGap: !0, deduplication: null, splitLine: { show: !1 }, axisTick: { alignWithLabel: !1, interval: "auto" }, axisLabel: { interval: "auto" } }, vM) , xM = 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 } } }, vM) , _M = { category: mM, value: xM, time: C({ splitNumber: 6, axisLabel: { showMinLabel: !1, showMaxLabel: !1, rich: { primary: { fontWeight: "bold" } } }, splitLine: { show: !1 } }, xM), log: k({ logBase: 10 }, xM) } , bM = { value: 1, category: 1, time: 1, log: 1 }; function wM(t, e, i, r) { E(bM, (function (o, a) { var s = C(C({}, _M[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 = _p(this) , i = n ? wp(t) : {}; C(t, e.getTheme().get(a + "Axis")), C(t, this.getDefaultOption()), t.type = SM(t), n && bp(t, i, n) } , i.prototype.optionUpdated = function () { "category" === this.option.type && (this.__ordinalMeta = ox.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", SM) } function SM(t) { return t.type || (t.data ? "category" : "value") } var MM = 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 }() , IM = ["x", "y"]; function TM(t) { return "interval" === t.type || "time" === t.type } var CM = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = "cartesian2d", e.dimensions = IM, 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 (TM(t) && TM(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 = Bi([], 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.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 Ft(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 Ft(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 () { var t = this.getAxis("x").getGlobalExtent() , e = this.getAxis("y").getGlobalExtent() , n = Math.min(t[0], t[1]) , i = Math.min(e[0], e[1]) , r = Math.max(t[0], t[1]) - n , o = Math.max(e[0], e[1]) - i; return new sr(n, i, r, o) } , e }(MM) , DM = 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 }(G_); function AM(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 kM(t) { return "cartesian2d" === t.get("coordinateSystem") } function LM(t) { var e = { xAxisModel: null, yAxisModel: null }; return E(e, (function (n, i) { var r = i.replace(/Model$/, "") , o = t.getReferringComponents(r, Co).models[0]; e[i] = o } )), e } var PM = Math.log; function OM(t, e, n) { var i = vx.prototype , r = i.getTicks.call(n) , o = i.getTicks.call(n, !0) , a = r.length - 1 , s = i.getInterval.call(n) , l = e_(t, e) , u = l.extent , h = l.fixMin , c = l.fixMax; if ("log" === t.type) { var p = PM(t.base); u = [PM(u[0]) / p, PM(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 = ux(f), y = u[0] + f * a; else if (c) for (g = u[1] - f * a; g > u[0] && isFinite(g) && isFinite(u[0]);) f = ux(f), g = u[1] - f * a; else { t.getTicks().length - 1 > a && (f = ux(f)); var v = f * a; (g = zr((y = Math.ceil(u[1] / f) * f) - v)) < 0 && u[0] >= 0 ? (g = 0, y = zr(v)) : y > 0 && u[1] <= 0 && (y = 0, g = -zr(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 RM = function () { function t(t, e, n) { this.type = "grid", this._coordsMap = {}, this._coordsList = [], this._axesMap = {}, this._axesList = [], this.axisPointerEnabled = !0, this.dimensions = IM, 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; sx(l) && s.get("alignTicks") && null == s.get("interval") ? r.push(a) : (n_(l, s), sx(l) && (e = a)) } r.length && (e || n_((e = r.pop()).scale, e.model), E(r, (function (t) { OM(t.scale, t.model, e.scale) } ))) } } this._updateScale(t, this.model), i(n.x), i(n.y); var r = {}; E(n.x, (function (t) { EM(n, "y", t, r) } )), E(n.y, (function (t) { EM(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 = mp(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 gx ? n.count() : (i = n.getTicks()).length; var a, s = t.getLabelModel(), l = r_(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 = a_(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", Co).models[0], o = t.yAxisModel || i && i.getReferringComponents("yAxis", Co).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 (NM(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 DM(e, i_(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 CM(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(u_(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 (kM(t)) { var i = LM(t) , r = i.xAxisModel , o = i.yAxisModel; if (!NM(r, e) || !NM(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 (kM(t)) { var e = LM(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 = IM, t }(); function NM(t, e) { return t.getCoordSysModel() === e } function EM(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) zM(o[l]) && (r = o[l]); else for (var u in o) if (o.hasOwnProperty(u) && zM(o[u]) && !i[h(o[u])]) { r = o[u]; break } r && (i[h(r)] = !0) } function h(t) { return t.dim + "_" + t.index } } function zM(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 VM = Math.PI , BM = function () { function t(t, e) { this.group = new Cr, 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 Cr({ x: e.position[0], y: e.position[1], rotation: e.rotation }); n.updateTransform(), this._transformGroup = n } return t.prototype.hasBuilder = function (t) { return !!FM[t] } , t.prototype.add = function (t) { FM[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 = Ur(e - t); return Xr(o) ? (r = n > 0 ? "top" : "bottom", i = "center") : Xr(o - VM) ? (r = n > 0 ? "bottom" : "top", i = "center") : (r = "middle", i = o > 0 && o < VM ? 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 }() , FM = { 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]; a && (Ft(s, s, a), Ft(l, l, a)); var u = A({ lineCap: "round" }, e.getModel(["axisLine", "lineStyle"]).getLineStyle()) , h = new Eu({ subPixelOptimize: !0, shape: { x1: s[0], y1: s[1], x2: l[0], y2: l[1] }, style: u, strokeContainThreshold: t.strokeContainThreshold || 5, silent: !0, z2: 1 }); h.anid = "line", n.add(h); var c = e.get(["axisLine", "symbol"]); if (null != c) { var p = e.get(["axisLine", "symbolSize"]); X(c) && (c = [c, c]), (X(p) || j(p)) && (p = [p, p]); var d = Py(e.get(["axisLine", "symbolOffset"]) || 0, p) , f = p[0] , g = p[1]; E([{ rotate: t.rotation + Math.PI / 2, offset: d[0], r: 0 }, { rotate: t.rotation - Math.PI / 2, offset: d[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" !== c[i] && null != c[i]) { var r = ky(c[i], -f / 2, -g / 2, f, g, u.stroke, !0) , o = e.r + e.offset; r.attr({ rotation: e.rotate, x: s[0] + o * Math.cos(t.rotation), y: s[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 = YM(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; if (!it(i.axisLabelShow, n.get(["axisLabel", "show"])) || r.scale.isBlank()) return; var o = n.getModel("axisLabel") , a = o.get("margin") , s = r.getViewLabels() , l = (it(i.labelRotate, o.get("rotate")) || 0) * VM / 180 , u = BM.innerTextLayout(i.rotation, l, i.labelDirection) , h = n.getCategories && n.getCategories(!0) , c = [] , p = BM.isLabelSilent(n) , d = n.get("triggerEvent"); return E(s, (function (s, l) { var f = "ordinal" === r.scale.type ? r.scale.getRawOrdinalNumber(s.tickValue) : s.tickValue , g = s.formattedLabel , y = s.rawLabel , v = o; if (h && h[f]) { var m = h[f]; q(m) && m.textStyle && (v = new pc(m.textStyle, o, n.ecModel)) } var x = v.getTextColor() || n.get(["axisLine", "lineStyle", "color"]) , _ = r.dataToCoord(f) , b = new As({ x: _, y: i.labelOffset + i.labelDirection * a, rotation: u.rotation, silent: p, z2: 10 + (s.level || 0), style: Yh(v, { text: g, align: v.getShallow("align", !0) || u.textAlign, verticalAlign: v.getShallow("verticalAlign", !0) || v.getShallow("baseline", !0) || u.textVerticalAlign, fill: U(x) ? x("category" === r.type ? y : "value" === r.type ? f + "" : f, l) : x }) }); if (b.anid = "label_" + f, d) { var w = BM.makeAxisEventDataBase(n); w.targetType = "axisLabel", w.value = y, Ws(b).eventData = w } e.add(b), b.updateTransform(), c.push(b), t.add(b), b.decomposeTransform() } )), c }(n, i, e, t); (function (t, e, n) { if (l_(t.axis)) return; var i = t.get(["axisLabel", "showMinLabel"]) , r = t.get(["axisLabel", "showMaxLabel"]); n = n || []; var o = (e = 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 ? (GM(o), GM(u)) : WM(o, a) && (i ? (GM(a), GM(h)) : (GM(o), GM(u))); !1 === r ? (GM(s), GM(c)) : WM(l, s) && (r ? (GM(l), GM(p)) : (GM(s), GM(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 = YM(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"])) && yb(db(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, HM(s) ? t.labelOffset + l * h : 0], f = e.get("nameRotate"); null != f && (f = f * VM / 180), HM(s) ? o = BM.innerTextLayout(t.rotation, null != f ? f : t.rotation, l) : (o = function (t, e, n, i) { var r, o, a = Ur(n - t), s = i[0] > i[1], l = "start" === e && !s || "start" !== e && s; Xr(a - VM / 2) ? (o = l ? "bottom" : "top", r = "center") : Xr(a - 1.5 * VM) ? (o = l ? "top" : "bottom", r = "center") : (o = "middle", r = a < 1.5 * VM && a > VM / 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 As({ x: d[0], y: d[1], rotation: o.rotation, silent: BM.isLabelSilent(e), style: Yh(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 (Nh({ el: x, componentModel: e, itemName: r }), x.__fullText = r, x.anid = "name", e.get("triggerEvent")) { var _ = BM.makeAxisEventDataBase(e); _.targetType = "axisName", _.name = r, Ws(x).eventData = _ } i.add(x), x.updateTransform(), n.add(x), x.decomposeTransform() } } }; function GM(t) { t && (t.ignore = !0) } function WM(t, e) { var n = t && t.getBoundingRect().clone() , i = e && e.getBoundingRect().clone(); if (n && i) { var r = Oi([]); return zi(r, r, -t.rotation), n.applyTransform(Ni([], r, t.getLocalTransform())), i.applyTransform(Ni([], r, e.getLocalTransform())), n.intersect(i) } } function HM(t) { return "middle" === t || "center" === t } function YM(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 && (Ft(a, a, e), Ft(s, s, e)); var h = new Eu({ subPixelOptimize: !0, shape: { x1: a[0], y1: a[1], x2: s[0], y2: s[1] }, style: i, z2: 2, autoBatch: !0, silent: !0 }); h.anid = r + "_" + t[l].tickValue, o.push(h) } return o } function UM(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 = KM(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 || qM(c))) { null == s && (s = c.get("triggerTooltip")); var d = (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 pc(s, n, i)) }(h, u, r, e, i, s) : c).get("snap") , f = KM(h.model) , g = s || d || "category" === h.type , y = t.axesInfo[f] = { key: f, axis: h, coordSys: n, axisPointerModel: c, triggerTooltip: s, involveSeries: g, snap: d, useHandle: qM(c), seriesModels: [], linkGroup: null }; l[f] = y, t.seriesInvolved = t.seriesInvolved || g; var v = function (t, e) { for (var n = e.model, i = e.dim, r = 0; r < t.length; r++) { var o = t[r] || {}; if (XM(o[i + "AxisId"], n.id) || XM(o[i + "AxisIndex"], n.componentIndex) || XM(o[i + "AxisName"], n.name)) return r } }(o, h); if (null != v) { var m = a[v] || (a[v] = { axesInfo: {} }); m.axesInfo[f] = y, m.mapper = o[v].mapper, y.linkGroup = m } } } } )) }(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[KM(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 XM(t, e) { return "all" === t || Y(t) && P(t, e) >= 0 || t === e } function ZM(t) { var e = jM(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 = qM(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 jM(t) { var e = (t.ecModel.getComponent("axisPointer") || {}).coordSysAxesInfo; return e && e.axesInfo[KM(t)] } function qM(t) { return !!t.get(["handle", "show"]) } function KM(t) { return t.type + "||" + t.id } var $M = {} , JM = 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 && ZM(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 = jM(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) { $M[t] = e } , e.getAxisPointerClass = function (t) { return t && $M[t] } , e.type = "axis", e }(fg) , QM = So(); function tI(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 = QM(t).splitAreaColors , p = ft() , 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 Ts({ 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 } QM(t).splitAreaColors = p } } } function eI(t) { QM(t).splitAreaColors = null } var nI = ["axisLine", "axisTickLabel", "axisName"] , iI = ["splitArea", "splitLine", "minorSplitLine"] , rI = 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 Cr, this.group.add(this._axisGroup), e.get("show")) { var a = e.getCoordSysModel() , s = AM(a, e) , l = new BM(e, A({ handleAutoShown: function (t) { for (var n = a.coordinateSystem.getCartesians(), i = 0; i < n.length; i++) if (sx(n[i].getOtherAxis(e.axis).scale)) return !0; return !1 } }, s)); E(nI, l.add, l), this._axisGroup.add(l.getGroup()), E(iI, (function (t) { e.get([t, "show"]) && oI[t](this, this._axisGroup, e, a) } ), this), r && "changeAxisOrder" === r.type && r.isInitSort || Dh(o, this._axisGroup, e), t.prototype.render.call(this, e, n, i, r) } } , e.prototype.remove = function () { eI(this) } , e.type = "cartesianAxis", e }(JM) , 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"); s = Y(s) ? s : [s]; for (var l = i.coordinateSystem.getRect(), u = r.isHorizontal(), h = 0, c = r.getTicksCoords({ tickModel: o }), p = [], d = [], f = a.getLineStyle(), g = 0; g < c.length; g++) { var y = r.toGlobalCoord(c[g].coord); u ? (p[0] = y, p[1] = l.y, d[0] = y, d[1] = l.y + l.height) : (p[0] = l.x, p[1] = y, d[0] = l.x + l.width, d[1] = y); var v = h++ % s.length , m = c[g].tickValue; e.add(new Eu({ anid: null != m ? "line_" + c[g].tickValue : null, subPixelOptimize: !0, autoBatch: !0, shape: { x1: p[0], y1: p[1], x2: d[0], y2: d[1] }, style: k({ stroke: s[v] }, f), silent: !0 })) } } }, 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), e.add(new Eu({ anid: "minor_line_" + l[p][d].tickValue, subPixelOptimize: !0, autoBatch: !0, shape: { x1: u[0], y1: u[1], x2: h[0], y2: h[1] }, style: c, silent: !0 })) } }, splitArea: function (t, e, n, i) { tI(t, e, n, i) } } , aI = 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 }(rI) , sI = function (t) { function e() { var e = null !== t && t.apply(this, arguments) || this; return e.type = aI.type, e } return n(e, t), e.type = "yAxis", e }(rI) , lI = 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 Ts({ shape: t.coordinateSystem.getRect(), style: k({ fill: t.get("backgroundColor") }, t.getItemStyle()), silent: !0, z2: -1 })) } , e.type = "grid", e }(fg) , uI = { offset: 0 }; function hI(t) { t.registerComponentView(lI), t.registerComponentModel(gM), t.registerCoordinateSystem("cartesian2d", RM), wM(t, "x", yM, uI), wM(t, "y", yM, uI), t.registerComponentView(aI), t.registerComponentView(sI), t.registerPreprocessor((function (t) { t.xAxis && t.yAxis && !t.grid && (t.grid = {}) } )) } function cI(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] = pI(r) ? r : dI(i) } )) } )), e.each((function (t) { var r = F(n[t], (function (t) { return pI(t) } )) || dI(i); n[t].push(r.slice()), e.setItemLayout(t, n[t]) } )) } } )) } function pI(t) { return !isNaN(t[0]) && !isNaN(t[1]) } function dI(t) { return [t.cx, t.cy] } function fI(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 gI = 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 = Ly(t.getItemVisual(e, "symbolSize")) , r = ky(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]), Vh[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 Lu , r = new Ou , a = { shape: { points: n } }; i.shape.points = u(n), r.shape.points = u(n), rh(i, a, t, e), rh(r, a, t, e); var s = new Cr , h = new Cr; 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), uh(s), uh(r), ih(r, h, t), ih(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 })), zl(i, n, "lineStyle"), zl(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: .7, decal: l.decal })); var p = n.getModel("emphasis") , d = p.getModel("itemStyle").getItemStyle(); s.eachChild((function (t) { if (t instanceof xs) { 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 = ""), Wh(t, Hh(n), { labelFetcher: o.hostModel, labelDataIndex: e, labelDimIndex: t.__dimIdx, defaultText: r, inheritColor: u, defaultOpacity: l.opacity }) } )), Ol(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 }(mg) , 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 lM(W(this.getData, this), W(this.getRawData, this)) } , e.prototype.getInitialData = function (t, e) { return sM(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 = tg(this, t); return Uf("section", { header: a, sortBlocks: !0, blocks: z(r, (function (e) { var n = i.get(i.mapDimension(e.dim), t); return Uf("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 }(ag) , vI = _M.value; function mI(t, e) { return k({ show: e }, t) } var xI = 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 (s || (d.name = ""), X(l)) { var f = d.name; d.name = l.replace("{value}", null != f ? f : "") } else U(l) && (d.name = l(d.name, d)); var g = new pc(d, null, this.ecModel); return R(g, h_.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" } }, vI.axisLine), axisLabel: mI(vI.axisLabel, !1), axisTick: mI(vI.axisTick, !1), splitLine: mI(vI.splitLine, !0), splitArea: mI(vI.splitArea, !0), indicator: [] }, e }(Ip) , _I = ["axisLine", "axisTickLabel", "axisName"] , bI = 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 BM(t.model, { axisName: n, position: [e.cx, e.cy], rotation: t.angle, labelDirection: -1, tickDirection: -1, nameDirection: 1 }) } )), (function (t) { E(_I, 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 uu({ shape: { cx: v, cy: m, r: y[x].coord } })); if (u && x < y.length - 1) g[C(g, d, x)].push(new Du({ 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 Ou({ shape: { points: S } })); if (u && w) g[C(g, d, x - 1)].push(new Lu({ shape: { points: S.concat(w) } })); w = S.slice().reverse() } } var I = a.getLineStyle() , T = s.getAreaStyle(); E(g, (function (t, e) { this.group.add(bh(t, { style: k({ stroke: "none", fill: d[e % d.length] }, T), silent: !0 })) } ), this), E(f, (function (t, e) { this.group.add(bh(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 }(fg) , wI = 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 }(G_) , SI = 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 wI(n, new vx); 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 = Er(n[0], i), this.cy = Er(n[1], r), this.startAngle = t.get("startAngle") * Math.PI / 180; var a = t.get("radius"); (X(a) || j(a)) && (a = [0, a]), this.r0 = Er(a[0], o), this.r = Er(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 vx; o.setExtent(0, r), o.setInterval(1), E(n, (function (t, e) { OM(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 MI(t) { t.registerCoordinateSystem("radar", SI), t.registerComponentModel(xI), t.registerComponentView(bI), 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 II = "\0_ec_interaction_mutex"; function TI(t, e) { return !!CI(t)[e] } function CI(t) { return t[II] || (t[II] = {}) } um({ type: "takeGlobalCursor", event: "globalCursorTaken", update: "update" }, xt); var DI = 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 (!(le(t) || t.target && t.target.draggable)) { var e = t.offsetX , n = t.offsetY; this.pointerChecker && this.pointerChecker(t, e, n) && (this._x = e, this._y = n, this._dragging = !0) } } , e.prototype._mousemoveHandler = function (t) { if (this._dragging && LI("moveOnMouseMove", t, this._opt) && "pinch" !== t.gestureEvent && !TI(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 && se(t.event), kI(this, "pan", "moveOnMouseMove", t, { dx: o, dy: a, oldX: i, oldY: r, newX: e, newY: n, isAvailableBehavior: null }) } } , e.prototype._mouseupHandler = function (t) { le(t) || (this._dragging = !1) } , e.prototype._mousewheelHandler = function (t) { var e = LI("zoomOnMouseWheel", t, this._opt) , n = LI("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; AI(this, "zoom", "zoomOnMouseWheel", t, { scale: i > 0 ? s : 1 / s, originX: o, originY: a, isAvailableBehavior: null }) } if (n) { var l = Math.abs(i); AI(this, "scrollMove", "moveOnMouseWheel", t, { scrollDelta: (i > 0 ? 1 : -1) * (l > 3 ? .4 : l > 1 ? .15 : .05), originX: o, originY: a, isAvailableBehavior: null }) } } } , e.prototype._pinchHandler = function (t) { TI(this._zr, "globalPan") || AI(this, "zoom", null, t, { scale: t.pinchScale > 1 ? 1.1 : 1 / 1.1, originX: t.pinchX, originY: t.pinchY, isAvailableBehavior: null }) } , e }(Xt); function AI(t, e, n, i, r) { t.pointerChecker && t.pointerChecker(i, r.originX, r.originY) && (se(i.event), kI(t, e, n, i, r)) } function kI(t, e, n, i, r) { r.isAvailableBehavior = W(LI, null, n, i), t.trigger(e, r) } function LI(t, e, n) { var i = n[t]; return !t || i && (!X(i) || e.event[i + "Key"]) } function PI(t, e, n) { var i = t.target; i.x += e, i.y += n, i.dirty() } function OI(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 RI, NI = { axisPointer: 1, tooltip: 1, brush: 1 }; function EI(t, e, n) { var i = e.getComponentByElement(t.topTarget) , r = i && i.coordinateSystem; return i && i !== n && !NI.hasOwnProperty(i.mainType) && r && r.model !== n } function zI(t) { X(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 VI = { 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" } , BI = G(VI) , FI = { "alignment-baseline": "textBaseline", "stop-color": "stopColor" } , GI = G(FI) , WI = function () { function t() { this._defs = {}, this._root = null } return t.prototype.parse = function (t, e) { e = e || {}; var n = zI(t); this._defsUsePending = []; var i = new Cr; 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), jI(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 = JI(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 = iT(l, { x: 0, y: 0, width: a, height: s }), !e.ignoreViewBox)) { var p = i; (i = new Cr).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 Ts({ 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 = RI[s]; if (u && mt(RI, 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 = HI[s]; if (p && mt(HI, 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 ys({ style: { text: t.textContent }, silent: !0, x: this._textX || 0, y: this._textY || 0 }); XI(e, n), jI(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 (RI = { g: function (t, e) { var n = new Cr; return XI(e, n), jI(t, n, this._defsUsePending, !1, !1), n }, rect: function (t, e) { var n = new Ts; return XI(e, n), jI(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 uu; return XI(e, n), jI(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 Eu; return XI(e, n), jI(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 cu; return XI(e, n), jI(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 = ZI(i)); var r = new Lu({ shape: { points: n || [] }, silent: !0 }); return XI(e, r), jI(t, r, this._defsUsePending, !1, !1), r }, polyline: function (t, e) { var n, i = t.getAttribute("points"); i && (n = ZI(i)); var r = new Ou({ shape: { points: n || [] }, silent: !0 }); return XI(e, r), jI(t, r, this._defsUsePending, !1, !1), r }, image: function (t, e) { var n = new xs; return XI(e, n), jI(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 Cr; return XI(e, a), jI(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 Cr; return XI(e, a), jI(t, a, this._defsUsePending, !1, !0), this._textX += parseFloat(r), this._textY += parseFloat(o), a }, path: function (t, e) { var n = au(t.getAttribute("d") || ""); return XI(e, n), jI(t, n, this._defsUsePending, !1, !1), n.silent = !0, n } }), t }() , HI = { 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 Uu(e, n, i, r); return YI(t, o), UI(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 Xu(e, n, i); return YI(t, r), UI(t, r), r } }; function YI(t, e) { "userSpaceOnUse" === t.getAttribute("gradientUnits") && (e.global = !0) } function UI(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 = {}; nT(n, o, o); var a = o.stopColor || n.getAttribute("stop-color") || "#000000"; e.colorStops.push({ offset: r, color: a }) } n = n.nextSibling } } function XI(t, e) { t && t.__inheritedStyle && (e.__inheritedStyle || (e.__inheritedStyle = {}), k(e.__inheritedStyle, t.__inheritedStyle)) } function ZI(t) { for (var e = JI(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 jI(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(QI, (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 = JI(a); switch (r = r || [1, 0, 0, 1, 0, 0], s) { case "translate": Ei(r, r, [parseFloat(l[0]), parseFloat(l[1] || "0")]); break; case "scale": Vi(r, r, [parseFloat(l[0]), parseFloat(l[1] || l[0])]); break; case "rotate": zi(r, r, -parseFloat(l[0]) * tT); break; case "skewX": Ni(r, [1, 0, Math.tan(parseFloat(l[0]) * tT), 1, 0, 0], r); break; case "skewY": Ni(r, [1, Math.tan(parseFloat(l[0]) * tT), 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), nT(t, a, s), i || function (t, e, n) { for (var i = 0; i < BI.length; i++) { var r = BI[i]; null != (o = t.getAttribute(r)) && (e[VI[r]] = o) } for (i = 0; i < GI.length; i++) { var o; r = GI[i]; null != (o = t.getAttribute(r)) && (n[FI[r]] = o) } }(t, a, s)), o.style = o.style || {}, null != a.fill && (o.style.fill = KI(o, "fill", a.fill, n)), null != a.stroke && (o.style.stroke = KI(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(JI(a.lineDash), (function (t) { return parseFloat(t) } ))), "hidden" !== a.visibility && "collapse" !== a.visibility || (o.invisible = !0), "none" === a.display && (o.ignore = !0) } var qI = /^url\(\s*#(.*?)\)/; function KI(t, e, n, i) { var r = n && n.match(qI); if (!r) return "none" === n && (n = null), n; var o = ut(r[1]); i.push([t, e, o]) } var $I = /-?([0-9]*\.)?[0-9]+([eE]-?[0-9]+)?/g; function JI(t) { return t.match($I) || [] } var QI = /(translate|scale|rotate|skewX|skewY|matrix)\(([\-\s0-9\.eE,]*)\)/g , tT = Math.PI / 180; var eT = /([^\s:;]+)\s*:\s*([^:;]+)/g; function nT(t, e, n) { var i, r = t.getAttribute("style"); if (r) for (eT.lastIndex = 0; null != (i = eT.exec(r));) { var o = i[1] , a = mt(VI, o) ? VI[o] : null; a && (e[a] = i[2]); var s = mt(FI, o) ? FI[o] : null; s && (n[s] = i[2]) } } function iT(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 rT = ft(["rect", "circle", "line", "ellipse", "polygon", "polyline", "path", "text", "tspan", "g"]) , oT = function () { function t(t, e) { this.type = "geoSVG", this._usedGraphicMap = ft(), this._freedGraphics = [], this._mapName = t, this._parsedXML = zI(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 = ft(); return E(t, (function (t) { if (null == t.namedFrom) { var i = new w_(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 WI).parse(i, r)) || {}).root)) } catch (t) { throw new Error("Invalid svg format\n" + t.message) } var o = new Cr; 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 sr(h, c, p, d) } if (l) { var g = iT(l, u); n.scaleX = n.scaleY = g.scale, n.x = g.x, n.y = g.y } o.setClipPath(new Ts({ shape: u.plain() })); var y = []; return E(e.named, (function (t) { var e; null != rT.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 aT = [126, 25], sT = "南海诸岛", lT = [[[0, 3.5], [7, 11.2], [15, 11.9], [30, 7], [42, .7], [52, .7], [56, 7.7], [59, .7], [64, .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]]], uT = 0; uT < lT.length; uT++) for (var hT = 0; hT < lT[uT].length; hT++) lT[uT][hT][0] /= 10.5, lT[uT][hT][1] /= -14, lT[uT][hT][0] += aT[0], lT[uT][hT][1] += aT[1]; var cT = { "南海诸岛": [32, 80], "广东": [0, -10], "香港": [10, 5], "澳门": [-10, 10], "天津": [5, 5] }; var pT = [[[123.45165252685547, 25.73527164402261], [123.49731445312499, 25.73527164402261], [123.49731445312499, 25.750734064600884], [123.45165252685547, 25.750734064600884], [123.45165252685547, 25.73527164402261]]]; var dT = function () { function t(t, e, n) { var i; this.type = "geoJSON", this._parsedMap = ft(), this._mapName = t, this._specialAreas = n, this._geoJSON = X(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: fT(i) }) } var r = ft() , o = []; return E(n.regions, (function (e) { var n = e.name; t && mt(t, n) && (e = e.cloneShallow(n = t[n])), o.push(e), r.set(n, e) } )), { regions: o, boundingRect: n.boundingRect || new sr(0, 0, 0, 0), regionsMap: r } } , t.prototype._parseToRegions = function (t) { var e, n = this._mapName, i = this._geoJSON; try { e = i ? I_(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 === sT) return; e.push(new b_(sT, z(lT, (function (t) { return { type: "polygon", exterior: t } } )), aT)) } }(n, e), E(e, (function (t) { var e = t.name; !function (t, e) { if ("china" === t) { var n = cT[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: pT[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 fT(t) { for (var e, n = 0; n < t.length; n++) { var i = t[n].getBoundingRect(); (e = e || i.clone()).union(i) } return e } var gT = ft() , yT = function (t, e, n) { if (e.svg) { var i = new oT(t, e.svg); gT.set(t, i) } else { var r = e.geoJson || e.geoJSON; r && !e.features ? n = e.specialAreas : r = e; i = new dT(t, r, n); gT.set(t, i) } } , vT = function (t) { return gT.get(t) } , mT = function (t) { var e = gT.get(t); return e && "geoJSON" === e.type && e.getMapForUser() } , xT = function (t, e, n) { var i = gT.get(t); if (i) return i.load(e, n) } , _T = ["rect", "circle", "line", "ellipse", "polygon", "polyline", "path"] , bT = ft(_T) , wT = ft(_T.concat(["g"])) , ST = ft(_T.concat(["g"])) , MT = So(); function IT(t) { var e = t.getItemStyle() , n = t.get("areaColor"); return null != n && (e.fill = n), e } function TT(t) { var e = t.style; e && (e.stroke = e.stroke || e.fill, e.fill = null) } var CT = function () { function t(t) { var e = new Cr; this.uid = fc("ec_map_draw"), this._controller = new DI(t.getZr()), this._controllerHost = { target: e }, this.group = e, e.add(this._regionsGroup = new Cr), e.add(this._svgGroup = new Cr) } 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()) : ih(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 = ft() , n = ft() , 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; p || (p = e.set(h, new Cr), i.add(p), f = a ? a.indexOfName(h) : null, g = t.isGeo ? o.getRegionModel(h) : a ? a.getItemModel(f) : null, n.set(h, { dataIdx: f, regionModel: g })); var y = [] , v = []; E(r.geometries, (function (t) { if ("polygon" === t.type) { var e = [t.exterior].concat(t.interiors || []); l && (e = OT(e, l)), E(e, (function (t) { y.push(new Lu(c(t))) } )) } else { var n = t.points; l && (n = OT(n, l, !0)), E(n, (function (t) { v.push(new Ou(c(t))) } )) } } )); var m = u(r.getCenter(), s && s.project); function x(e, n) { if (e.length) { var i = new Hu({ culling: !0, segmentIgnoreThreshold: 1, shape: { paths: e } }); p.add(i), DT(t, i, f, g), AT(t, i, h, g, o, f, m), n && (TT(i), E(i.states, TT)) } } x(y), x(v, !0) } )), e.each((function (e, i) { var r = n.get(i) , a = r.dataIdx , s = r.regionModel; kT(t, e, i, s, o, a), LT(t, e, i, s, o), PT(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 = ft() , 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 != bT.get(s) && l instanceof da && DT(t, l, u, h), l instanceof da && (l.culling = !0), l.z2EmphasisLift = 0, e.namedFrom) || (null != ST.get(s) && AT(t, l, n, h, o, u, null), kT(t, l, n, h, o, u), LT(t, l, n, h, o), null != wT.get(s) && ("self" === PT(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) { yl(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 = vT(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 = vT(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, PI(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, OI(o, t.scale, t.originX, t.originY), n.dispatchAction(A(s(), { zoom: t.scale, originX: t.originX, originY: t.originY, animation: { duration: 0 } })) } ), this), r.setPointerChecker((function (e, r, o) { return i.containPoint([r, o]) && !EI(e, n, t) } )) } , t.prototype.resetForLabelLayout = function () { this.group.traverse((function (t) { var e = t.getTextContent(); e && (e.ignore = MT(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 DT(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 = IT(r) , u = IT(o) , h = IT(s) , c = IT(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 = nv(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, yl(e) } function AT(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; Wh(e, Hh(i), { labelFetcher: p, labelDataIndex: c, defaultText: n }, d); var f = e.getTextContent(); if (f && (MT(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 kT(t, e, n, i, r, o) { t.data ? t.data.setItemGraphicEl(o, e) : Ws(e).eventData = { componentType: "geo", componentIndex: r.componentIndex, geoIndex: r.componentIndex, name: n, region: i && i.option || {} } } function LT(t, e, n, i, r) { t.data || Nh({ el: e, componentModel: r, itemName: n, itemTooltipOption: i.get("tooltip") }) } function PT(t, e, n, i, r) { e.highDownSilentOnTouch = !!r.get("selectedMode"); var o = i.getModel("emphasis") , a = o.get("focus"); return Ol(e, a, o.get("blurScope"), o.get("disabled")), t.isGeo && function (t, e, n) { var i = Ws(t); i.componentMainType = e.mainType, i.componentIndex = e.componentIndex, i.componentHighDownName = n }(e, r, n), a } function OT(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 RT = 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 CT(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 uu({ 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); Wh(l, Hh(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) { fl(l, t) } } r.add(l) } } } )) } , e.type = "map", e }(mg) , NT = 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 = sM(this, { coordDimensions: ["value"], encodeDefaulter: H(Hp, this) }), n = ft(), i = [], r = 0, o = e.count(); r < o; r++) { var a = e.getName(r); n.set(a, !0) } return E(xT(this.getMapType(), this.option.nameMap, this.option.nameProperty).regions, (function (t) { var e = t.name; n.get(e) || i.push(e) } )), e.appendValues([], 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 Uf("section", { header: s.join(", "), noHeader: !s.length, blocks: [Uf("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 = ky(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: .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 }(ag); function ET(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 zT(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 VT = Ft , BT = function (t) { function e(e) { var n = t.call(this) || this; return n.type = "view", n.dimensions = ["x", "y"], n._roamTransformable = new qi, n._rawTransformable = new qi, n.name = e, n } return n(e, t), e.prototype.setBoundingRect = function (t, e, n, i) { return this._rect = new sr(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 sr(t, e, n, i) } , e.prototype._transformTo = function (t, e, n, i) { var r = this.getBoundingRect() , o = this._rawTransformable; o.transform = r.calculateTransform(new sr(t, e, n, i)); var a = o.parent; o.parent = null, o.decomposeTransform(), o.parent = a, this._updateTransform() } , e.prototype.setCenter = function (t) { t && (this._center = t, 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 = Ft([], i, t), n = Ft([], 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(), Ri(this.transform || (this.transform = []), e.transform || [1, 0, 0, 1, 0, 0]), this._rawTransform = e.getLocalTransform(), this.invTransform = this.invTransform || [], Bi(this.invTransform, this.transform), this.decomposeTransform() } , e.prototype.getTransformInfo = function () { var t = this._rawTransformable , e = this._roamTransformable , n = new qi; 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 ? VT(n, t, i) : St(n, t) } , e.prototype.pointToData = function (t) { var e = this.invTransform; return e ? VT([], t, e) : [t[0], t[1]] } , e.prototype.convertToPixel = function (t, e, n) { var i = FT(e); return i === this ? i.dataToPoint(n) : null } , e.prototype.convertFromPixel = function (t, e, n) { var i = FT(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 }(qi); function FT(t) { var e = t.seriesModel; return e ? e.coordinateSystem : null } var GT = { geoJSON: { aspectScale: .75, invertLongitute: !0 }, geoSVG: { aspectScale: 1, invertLongitute: !1 } } , WT = ["lng", "lat"] , HT = function (t) { function e(e, n, i) { var r = t.call(this, e) || this; r.dimensions = WT, r.type = "geo", r._nameCoordMap = ft(), r.map = n; var o, a = i.projection, s = xT(n, i.nameMap, i.nameProperty), l = vT(n), u = (r.resourceType = l ? l.type : null, r.regions = s.regions), h = GT[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 sr(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 (X(t) && (t = this.getGeoCoord(t)), t) { var i = this.projection; return i && (t = i.project(t)), t && this.projectedToPoint(t) } } , 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 = YT(e); return i === this ? i.dataToPoint(n) : null } , e.prototype.convertFromPixel = function (t, e, n) { var i = YT(e); return i === this ? i.pointToData(n) : null } , e }(BT); function YT(t) { var e = t.geoModel , n = t.seriesModel; return e ? e.coordinateSystem : n ? n.coordinateSystem || (n.getReferringComponents("geo", Co).models[0] || {}).coordinateSystem : null } function UT(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]); Gt(i, i, c), Wt(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 = [Er(g[0], v), Er(g[1], m)], p = Er(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 = mp(b, { width: v, height: m }) } this.setViewRect(d.x, d.y, d.width, d.height), this.setCenter(t.get("center")), this.setZoom(t.get("zoom")) } R(HT, BT); var XT = new (function () { function t() { this.dimensions = WT } 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 HT(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 = UT, 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 HT(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 = UT, 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 = ft(), a = 0; a < r.length; a++) o.set(r[a].name, r[a]); return E(xT(e, n, i).regions, (function (t) { var e = t.name; !o.get(e) && r.push({ name: e }) } )), r } , t }()) , ZT = 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 = vT(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 = XT.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 pc(i, t, t.ecModel)), i.selected && (n[r] = !0)), e } ), ft()), e.selectedMap || (e.selectedMap = n) } , e.prototype.getRegionModel = function (t) { return this._optionModelMap.get(t) || new pc(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 U(i) ? (r.status = e, i(r)) : X(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: .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 }(Ip); function jT(t, e) { return t.pointToProjected ? t.pointToProjected(e) : t.pointToData(e) } function qT(t, e, n) { var i = t.getZoom() , r = t.getCenter() , o = e.zoom , a = t.projectedToPoint ? t.projectedToPoint(r) : t.dataToPoint(r); if (null != e.dx && null != e.dy && (a[0] -= e.dx, a[1] -= e.dy, t.setCenter(jT(t, a))), null != o) { if (n) { var s = n.min || 0 , l = n.max || 1 / 0; o = Math.max(Math.min(i * o, l), s) / i } t.scaleX *= o, t.scaleY *= o; var u = (e.originX - t.x) * (o - 1) , h = (e.originY - t.y) * (o - 1); t.x -= u, t.y -= h, t.updateTransform(), t.setCenter(jT(t, a)), t.setZoom(o * i) } return { center: t.getCenter(), zoom: t.getZoom() } } var KT = 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 CT(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; my(t.target, (function (t) { return null != (e = Ws(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 = Ws(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 }(fg); function $T(t, e, n) { yT(t, e, n) } function JT(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", XT), t.registerComponentModel(ZT), t.registerComponentView(KT), t.registerImpl("registerMap", $T), t.registerImpl("getMap", (function (t) { return mT(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) { var n = t.componentType || "series"; e.eachComponent({ mainType: n, query: t }, (function (e) { var i = e.coordinateSystem; if ("geo" === i.type) { var r = qT(i, t, e.get("scaleLimit")); e.setCenter && e.setCenter(r.center), e.setZoom && e.setZoom(r.zoom), "series" === n && E(e.seriesGroup, (function (t) { t.setCenter(r.center), t.setZoom(r.zoom) } )) } } )) } )) } function QT(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 = iC(s), o = rC(o), s && o;) { r = iC(r), a = rC(a), r.hierNode.ancestor = t; var p = s.hierNode.prelim + c - o.hierNode.prelim - u + i(s, o); p > 0 && (aC(oC(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 && !iC(r) && (r.hierNode.thread = s, r.hierNode.modifier += c - l), o && !rC(a) && (a.hierNode.thread = o, a.hierNode.modifier += u - h, n = t) } return n }(t, r, t.parentNode.hierNode.defaultAncestor || i[0], e) } function tC(t) { var e = t.hierNode.prelim + t.parentNode.hierNode.modifier; t.setLayout({ x: e }, !0), t.hierNode.modifier += t.parentNode.hierNode.modifier } function eC(t) { return arguments.length ? t : sC } function nC(t, e) { return t -= Math.PI / 2, { x: e * Math.cos(t), y: e * Math.sin(t) } } function iC(t) { var e = t.children; return e.length && t.isExpand ? e[e.length - 1] : t.hierNode.thread } function rC(t) { var e = t.children; return e.length && t.isExpand ? e[0] : t.hierNode.thread } function oC(t, e, n) { return t.hierNode.ancestor.parentNode === e.parentNode ? t.hierNode.ancestor : n } function aC(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 sC(t, e) { return t.parentNode === e.parentNode ? 1 : 2 } var lC = function () { this.parentPoint = [], this.childPoints = [] } , uC = 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 lC } , 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 = Er(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 }(fs) , hC = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._mainGroup = new Cr, n } return n(e, t), e.prototype.init = function (t, e) { this._controller = new DI(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), this._updateController(t, e, n); var a = this._data; i.diff(a).add((function (e) { cC(i, e) && pC(i, e, null, o, t) } )).update((function (e, n) { var r = a.getItemGraphicEl(n); cC(i, e) ? pC(i, e, r, o, t) : r && gC(a, n, r, o, t) } )).remove((function (e) { var n = a.getItemGraphicEl(e); n && gC(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) { var e = t.getData() , n = []; e.each((function (t) { var i = e.getItemLayout(t); !i || isNaN(i.x) || isNaN(i.y) || n.push([+i.x, +i.y]) } )); var i = [] , r = []; Ma(n, i, r); var o = this._min , a = this._max; r[0] - i[0] == 0 && (i[0] = o ? o[0] : i[0] - 1, r[0] = a ? a[0] : r[0] + 1), r[1] - i[1] == 0 && (i[1] = o ? o[1] : i[1] - 1, r[1] = a ? a[1] : r[1] + 1); var s = t.coordinateSystem = new BT; s.zoomLimit = t.get("scaleLimit"), s.setBoundingRect(i[0], i[1], r[0] - i[0], r[1] - i[1]), s.setCenter(t.get("center")), s.setZoom(t.get("zoom")), this.group.attr({ x: s.x, y: s.y, scaleX: s.scaleX, scaleY: s.scaleY }), this._min = i, this._max = r } , 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) && !EI(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) { PI(o, e.dx, e.dy), n.dispatchAction({ seriesId: t.id, type: "treeRoam", dx: e.dx, dy: e.dy }) } )).on("zoom", (function (e) { OI(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 }(mg); function cC(t, e) { var n = t.getItemLayout(e); return n && !isNaN(n.x) && !isNaN(n.y) } function pC(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 Ww(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, ih(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) { 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 = "ancestor" === D ? a.getAncestorsIndices() : "descendant" === D ? a.getDescendantIndices() : null; A && (Ws(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 Fu({ shape: yC(h, c, p, r, r) })), ih(g, { shape: yC(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 uC({ shape: { parentPoint: [a.x, a.y], childPoints: [[a.x, a.y]], orient: c, forkPosition: d } })), ih(g, { shape: { parentPoint: [a.x, a.y], childPoints: v } }, t) } } else 0; g && (g.useStyle(k({ strokeNoScale: !0, fill: null }, f)), zl(g, l, "lineStyle"), yl(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 || fl(n.__edge, e) } } ) } function dC(t, e, n, i, r) { var o = fC(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 ? ah(h, { shape: yC(p, d, f, s, s), style: { opacity: 0 } }, i, { cb: function () { n.remove(h) }, removeOpt: r }) : "polyline" === c && "orthogonal" === i.get("layout") && ah(h, { shape: { parentPoint: [s.x, s.y], childPoints: [[s.x, s.y]] }, style: { opacity: 0 } }, i, { cb: function () { n.remove(h) }, removeOpt: r })) } } function fC(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 gC(t, e, n, i, r) { var o = t.tree.getNodeByDataIndex(e) , a = fC(t.tree.root, o).sourceLayout , s = { duration: r.get("animationDurationUpdate"), easing: r.get("animationEasingUpdate") }; ah(n, { x: a.x + 1, y: a.y + 1 }, r, { cb: function () { i.remove(n), t.setItemGraphicEl(e, null) }, removeOpt: s }), n.fadeOut(null, { fadeLabel: !0, animation: s }), o.children.forEach((function (e) { dC(e, t, i, r, s) } )), dC(o, t, i, r, s) } function yC(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 = nC(u, c) , f = nC(u, c + (p - c) * n) , g = nC(h, p + (c - p) * n) , y = nC(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 vC = So(); function mC(t) { var e = t.mainData , n = t.datas; n || (n = { main: e }, t.datasAttr = { main: "data" }), t.datas = t.mainData = null, MC(e, n, t), E(n, (function (n) { E(e.TRANSFERABLE_METHODS, (function (e) { n.wrapMethod(e, H(xC, t)) } )) } )), e.wrapMethod("cloneShallow", H(bC, t)), E(e.CHANGABLE_METHODS, (function (n) { e.wrapMethod(n, H(_C, t)) } )), lt(n[e.dataType] === e) } function xC(t, e) { if (vC(i = this).mainData === i) { var n = A({}, vC(this).datas); n[this.dataType] = e, MC(e, n, t) } else IC(e, this.dataType, vC(this).mainData, t); var i; return e } function _C(t, e) { return t.struct && t.struct.update(), e } function bC(t, e) { return E(vC(e).datas, (function (n, i) { n !== e && IC(n.cloneShallow(), i, e, t) } )), e } function wC(t) { var e = vC(this).mainData; return null == t || null == e ? e : vC(e).datas[t] } function SC() { var t = vC(this).mainData; return null == t ? [{ data: t }] : z(G(vC(t).datas), (function (e) { return { type: e, data: vC(t).datas[e] } } )) } function MC(t, e, n) { vC(t).datas = {}, E(e, (function (e, i) { IC(e, i, t, n) } )) } function IC(t, e, n, i) { vC(n).datas[e] = t, vC(t).mainData = n, t.dataType = e, i.struct && (t[i.structAttr] = i.struct, i.struct[i.datasAttr[e]] = t), t.getLinkedData = wC, t.getLinkedDataAll = SC } var TC = 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) { U(t) && (n = e, e = t, t = null), X(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 }() , CC = 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 TC(xo(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 = jm(o, { coordDimensions: ["value"], dimensionsCount: a }).dimensions , l = new Zm(s, n); return l.initData(o), i && i(l), mC({ mainData: l, struct: r, structAttr: "tree" }), r.update(), r } , t }(); function DC(t, e, n) { if (t && P(e, t.type) >= 0) { var i = n.getData().tree.root , r = t.targetNode; if (X(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 AC(t) { for (var e = []; t;) (t = t.parentNode) && e.push(t); return e.reverse() } function kC(t, e) { return P(AC(t), e) >= 0 } function LC(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 PC = 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 pc(n, this, this.ecModel) , r = CC.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 Uf("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 = LC(i, this), 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: .4, center: null, zoom: 1, orient: "LR", symbol: "emptyCircle", symbolSize: 7, expandAndCollapse: !0, initialTreeDepth: 2, lineStyle: { color: "#ccc", width: 1.5, curveness: .5 }, itemStyle: { color: "lightsteelblue", borderWidth: 1.5 }, label: { show: !0 }, animationEasing: "linear", animationDuration: 700, animationDurationUpdate: 500 }, e }(ag); function OC(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 RC(t, e) { t.eachSeriesByType("tree", (function (t) { !function (t, e) { var n = function (t, e) { return mp(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 = eC((function (t, e) { return (t.parentNode === e.parentNode ? 1 : 2) / t.depth } ))) : (r = n.width, o = n.height, a = eC()); 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, QT, a), s.hierNode.modifier = -l.hierNode.prelim, OC(l, tC); var u = l , h = l , c = l; OC(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), OC(l, (function (t) { y = (t.getLayout().x + d) * f, v = (t.depth - 1) * g; var e = nC(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), OC(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), OC(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 NC(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 EC = ["treemapZoomToNode", "treemapRender", "treemapMove"]; function zC(t) { var e = t.getData().tree , n = {}; e.eachNode((function (e) { for (var i = e; i && i.depth > 1;) i = i.parentNode; var r = td(t.ecModel, i.name || i.dataIndex + "", n); e.setVisual("decal", r) } )) } var VC = 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 }; BC(n); var i = t.levels || [] , r = this.designatedVisualItemStyle = {} , o = new pc({ itemStyle: r }, this, e) , a = z((i = t.levels = function (t, e) { var n, i, r = ho(e.get("color")), o = ho(e.get(["aria", "decal", "decals"])); if (!r) return; E(t = t || [], (function (t) { var e = new pc(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)) || [], (function (t) { return new pc(t, o, e) } ), this) , s = CC.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 Uf("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 = LC(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 = ft(), 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 () { zC(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: .5 * (1 + Math.sqrt(5)), leafDepth: null, drillDownIcon: "▶", zoomToNodeRatio: .1024, 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" } } }, 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 }(ag); function BC(t) { var e = 0; E(t.children, (function (t) { BC(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 FC = function () { function t(t) { this.group = new Cr, 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 = a.getModel("textStyle") , l = { 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, l, s), this._renderContent(t, l, a, s, i), xp(o, l.pos, l.box) } } , t.prototype._prepare = function (t, e, n) { for (var i = t; i; i = i.parentNode) { var r = xo(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) { for (var o, a, s, l, u, h, c, p, d, f = 0, g = e.emptyItemWidth, y = t.get(["breadcrumb", "height"]), v = (o = e.pos, a = e.box, l = a.width, u = a.height, h = Er(o.left, l), c = Er(o.top, u), p = Er(o.right, l), d = Er(o.bottom, u), (isNaN(h) || isNaN(parseFloat(o.left))) && (h = 0), (isNaN(p) || isNaN(parseFloat(o.right))) && (p = l), (isNaN(c) || isNaN(parseFloat(o.top))) && (c = 0), (isNaN(d) || isNaN(parseFloat(o.bottom))) && (d = u), s = np(s || 0), { width: Math.max(p - h - s[1] - s[3], 0), height: Math.max(d - c - s[0] - s[2], 0) }), m = e.totalWidth, x = e.renderList, _ = x.length - 1; _ >= 0; _--) { var b = x[_] , w = b.node , S = b.width , M = b.text; m > v.width && (m -= S - g, S = g, M = null); var I = new Lu({ shape: { points: GC(f, 0, S, y, _ === x.length - 1, 0 === _) }, style: k(n.getItemStyle(), { lineJoin: "bevel" }), textContent: new As({ style: { text: M, fill: i.getTextColor(), font: i.getFont() } }), textConfig: { position: "inside" }, z2: 1e5, onclick: H(r, w) }); I.disableLabelAnimation = !0, this.group.add(I), WC(I, t, w), f += S + 8 } } , t.prototype.remove = function () { this.group.removeAll() } , t }(); function GC(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 WC(t, e, n) { Ws(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 && LC(n, e) } } var HC = 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 YC = Cr , UC = Ts , XC = "label" , ZC = "upperLabel" , jC = Wo([["fill", "color"], ["stroke", "strokeColor"], ["lineWidth", "strokeWidth"], ["shadowBlur"], ["shadowOffsetX"], ["shadowOffsetY"], ["shadowColor"]]) , qC = function (t) { var e = jC(t); return e.stroke = e.fill = e.lineWidth = null, e } , KC = So() , $C = 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 = DC(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 YC, 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 = G("nodeGroup", YC); if (!C) return; if (l.add(C), C.x = h.x || 0, C.y = h.y || 0, C.markRedraw(), KC(C).nodeWidth = d, KC(C).nodeHeight = f, h.isAboveViewRoot) return C; var D = G("background", UC, u, 20); D && E(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) Bl(C) && Vl(C, !1), D && (Vl(D, !O), c.setItemGraphicEl(a.dataIndex, D), Rl(D, R, P)); else { var N = G("content", UC, u, 30); N && z(C, N), D.disableMorphing = !0, D && Bl(D) && Vl(D, !1), Vl(C, !O), c.setItemGraphicEl(a.dataIndex, C), Rl(C, R, P) } return C; function E(e, n, i) { var r = Ws(n); if (r.dataIndex = a.dataIndex, r.seriesIndex = t.seriesIndex, n.setShape({ x: 0, y: 0, width: d, height: f, r: T }), y) V(n); else { n.invisible = !1; var o = a.getVisual("style") , s = o.stroke , l = qC(w); l.fill = s; var u = jC(S); u.fill = S.get("borderColor"); var h = jC(M); h.fill = M.get("borderColor"); var c = jC(I); if (c.fill = I.get("borderColor"), i) { var p = d - 2 * g; B(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, yl(n) } e.add(n) } function z(e, n) { var i = Ws(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) V(n); else { n.invisible = !1; var s = a.getVisual("style") , l = s.fill , u = qC(w); u.fill = l, u.decal = s.decal; var h = jC(S) , c = jC(M) , p = jC(I); B(n, l, s.opacity, null), n.setStyle(u), n.ensureState("emphasis").style = h, n.ensureState("blur").style = c, n.ensureState("select").style = p, yl(n) } e.add(n) } function V(t) { !t.invisible && o.push(t) } function B(e, n, i, r) { var o = p.getModel(r ? ZC : XC) , s = xo(p.get("name"), null) , l = o.getShallow("show"); Wh(e, Hh(p, r ? ZC : XC), { 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", F(c, r, h); var f = u.getState("emphasis"); F(f ? f.style : null, r, h) } } function F(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 G(t, i, o, a) { var s = null != m && n[t][m] , l = r[t]; return s ? (n[t][m] = null, W(l, s)) : y || ((s = new i) instanceof da && (s.z2 = function (t, e) { return 100 * t + e }(o, a)), H(l, s)), e[t][v] = s } function W(t, e) { var n = t[v] = {}; e instanceof YC ? (n.oldX = e.x, n.oldY = e.y) : n.oldShape = A({}, e.shape) } function H(t, e) { var n = t[v] = {} , o = a.parentNode , s = e instanceof Cr; 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 Sm(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), KC(t).willDelete = !0) } )) } )), e }(s); return this._oldTree = i, this._storage = a, { 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 = (U(r) ? 0 : r) || 0 , s = (U(o) ? null : o) || "cubicOut" , l = new HC; E(e.willDeleteEls, (function (t, e) { E(t, (function (t, n) { if (!t.invisible) { var r, o = t.parent, u = KC(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 Cr ? 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; e || ((e = this._controller = new DI(t.getZr())).enable(this.seriesModel.get("roam")), e.on("pan", W(this._onPan, this)), e.on("zoom", W(this._onZoom, this))); var n = new sr(0, 0, t.getWidth(), t.getHeight()); e.setPointerChecker((function (t, e, i) { return n.contain(e, i) } )) } , e.prototype._clearController = function () { var t = this._controller; 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; if ("animating" !== this._state) { var i = this.seriesModel.getData().tree.root; if (!i) return; var r = i.getLayout(); if (!r) return; var o = new sr(r.x, r.y, r.width, r.height) , a = this.seriesModel.layoutInfo , s = [1, 0, 0, 1, 0, 0]; Ei(s, s, [-(e -= a.x), -(n -= a.y)]), Vi(s, s, [t.scale, t.scale]), Ei(s, s, [e, n]), o.applyTransform(s), this.api.dispatchAction({ type: "treemapRender", from: this.uid, seriesId: this.seriesModel.id, rootRect: { x: o.x, y: o.y, width: o.width, height: o.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 && pp(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 FC(this.group))).render(t, e, n.node, (function (e) { "animating" !== i._state && (kC(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 }(mg); var JC = E , QC = q , tD = -1 , eD = function () { function t(e) { var n = e.mappingMethod , i = e.type , r = this.option = T(e); this.type = i, this.mappingMethod = n, this._normalizeData = cD[n]; var o = t.visualHandlers[i]; this.applyVisual = o.applyVisual, this.getColorMapper = o.getColorMapper, this._normalizedToVisual = o._normalizedToVisual[n], "piecewise" === n ? (nD(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 (JC(e, (function (t, e) { n[t] = e } )), !Y(i)) { var r = []; q(i) ? JC(i, (function (t, e) { var i = n[e]; r[null != i ? i : tD] = t } )) : r[-1] = i, i = hD(t, r) } for (var o = e.length - 1; o >= 0; o--) null == i[o] && (delete n[e[o]], e.pop()) }(r) : nD(r, !0) : (lt("linear" !== n || r.dataExtent), nD(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 && JC(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 (!QC(t)) return []; var e = []; JC(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 || X(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 (pD(h[1], t, u[1])) return o } else if (u[1] === 1 / 0) { if (pD(h[0], u[0], t)) return o } else if (pD(h[0], u[0], t) && pD(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: oD("color"), getColorMapper: function () { var t = this.option; return W("category" === t.mappingMethod ? function (t, e) { return !e && (t = this._normalizeData(t)), aD.call(this, t) } : function (e, n, i) { var r = !!i; return !n && (e = this._normalizeData(e)), i = Mn(e, t.parsedVisual, i), r ? i : kn(i, "rgba") } , this) }, _normalizedToVisual: { linear: function (t) { return kn(Mn(t, this.option.parsedVisual), "rgba") }, category: aD, piecewise: function (t, e) { var n = uD.call(this, e); return null == n && (n = kn(Mn(t, this.option.parsedVisual), "rgba")), n }, fixed: sD } }, colorHue: iD((function (t, e) { return Dn(t, e) } )), colorSaturation: iD((function (t, e) { return Dn(t, null, e) } )), colorLightness: iD((function (t, e) { return Dn(t, null, null, e) } )), colorAlpha: iD((function (t, e) { return An(t, e) } )), decal: { applyVisual: oD("decal"), _normalizedToVisual: { linear: null, category: aD, piecewise: null, fixed: null } }, opacity: { applyVisual: oD("opacity"), _normalizedToVisual: lD([0, 1]) }, liftZ: { applyVisual: oD("liftZ"), _normalizedToVisual: { linear: sD, category: sD, piecewise: sD, fixed: sD } }, symbol: { applyVisual: function (t, e, n) { n("symbol", this.mapValueToVisual(t)) }, _normalizedToVisual: { linear: rD, category: aD, piecewise: function (t, e) { var n = uD.call(this, e); return null == n && (n = rD.call(this, t)), n }, fixed: sD } }, symbolSize: { applyVisual: oD("symbolSize"), _normalizedToVisual: lD([0, 1]) } }, t }(); function nD(t, e) { var n = t.visual , i = []; q(n) ? JC(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]), hD(t, i) } function iD(t) { return { applyVisual: function (e, n, i) { var r = this.mapValueToVisual(e); i("color", t(n("color"), r)) }, _normalizedToVisual: lD([0, 1]) } } function rD(t) { var e = this.option.visual; return e[Math.round(Nr(t, [0, 1], [0, e.length - 1], !0))] || {} } function oD(t) { return function (e, n, i) { i(t, this.mapValueToVisual(e)) } } function aD(t) { var e = this.option.visual; return e[this.option.loop && t !== tD ? t % e.length : t] } function sD() { return this.option.visual[0] } function lD(t) { return { linear: function (e) { return Nr(e, t, this.option.visual, !0) }, category: aD, piecewise: function (e, n) { var i = uD.call(this, n); return null == i && (i = Nr(e, t, this.option.visual, !0)), i }, fixed: sD } } function uD(t) { var e = this.option , n = e.pieceList; if (e.hasSpecialVisual) { var i = n[eD.findPieceIndex(t, n)]; if (i && i.visual) return i.visual[this.type] } } function hD(t, e) { return t.visual = e, "color" === t.type && (t.parsedVisual = z(e, (function (t) { return bn(t) } ))), e } var cD = { linear: function (t) { return Nr(t, this.option.dataExtent, [0, 1], !0) }, piecewise: function (t) { var e = this.option.pieceList , n = eD.findPieceIndex(t, e, !0); if (null != n) return Nr(n, [0, e.length - 1], [0, 1], !0) }, category: function (t) { var e = this.option.categories ? this.option.categoryMap[t] : t; return null == e ? tD : e }, fixed: xt }; function pD(t, e, n) { return t ? e <= n : e < n } var dD = So() , fD = { seriesType: "treemap", reset: function (t) { var e = t.getData().tree.root; e.isRemoved() || gD(e, {}, t.getViewRoot().getAncestors(), t) } }; function gD(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 ? Dn(e, null, null, t) : null }(p, s = yD(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 = mD(e, "color") || null != r.color && "none" !== r.color && (mD(e, "colorAlpha") || mD(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 eD(c); return dD(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 && dD(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); gD(t, o, n, i) } } )) } else s = yD(u), h.fill = s } } function yD(t) { var e = vD(t, "color"); if (e) { var n = vD(t, "colorAlpha") , i = vD(t, "colorSaturation"); return i && (e = Dn(e, null, null, i)), n && (e = An(e, n)), e } } function vD(t, e) { var n = t[e]; if (null != n && "none" !== n) return n } function mD(t, e) { var n = t.get(e); return Y(n) && n.length ? { name: e, range: n } : null } var xD = Math.max , _D = Math.min , bD = it , wD = E , SD = ["itemStyle", "borderWidth"] , MD = ["itemStyle", "gapWidth"] , ID = ["upperLabel", "show"] , TD = ["upperLabel", "height"] , CD = { seriesType: "treemap", reset: function (t, e, n, i) { var r = n.getWidth() , o = n.getHeight() , a = t.option , s = mp(t.getBoxLayoutParams(), { width: n.getWidth(), height: n.getHeight() }) , l = a.size || [] , u = Er(bD(s.width, l[0]), r) , h = Er(bD(s.height, l[1]), o) , c = i && i.type , p = DC(i, ["treemapZoomToNode", "treemapRootToNode"], t) , d = "treemapRender" === c || "treemapMove" === c ? i.rootRect : null , f = t.getViewRoot() , g = AC(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(SD); (u += 4 * y * y + (3 * y + Math.max(y, PD(g))) * Math.pow(u, .5)) > Yr && (u = Yr), a = o } u < l && (u = l); var v = Math.pow(u / l, .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), DD(f, m, !1, 0), x = f.getLayout(), wD(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), LD(_, new sr(-s.x, -s.y, r, o), g, f, 0) } }; function DD(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(SD) , u = s.get(MD) / 2 , h = PD(s) , c = Math.max(l, h) , p = l - u , d = c - u; t.setLayout({ borderWidth: l, upperHeight: c, upperLabelHeight: h }, !0); var f = (r = xD(r - 2 * p, 0)) * (o = xD(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 = []; !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 = B(a, (function (t) { return !t.isRemoved() } )), 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], wD(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 = _D(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 = AD(x, v, e.squareRatio); S <= m ? (_++, m = S) : (x.area -= x.pop().getLayout().area, kD(x, v, y, u, !1), v = _D(y.width, y.height), x.length = x.area = 0, m = 1 / 0) } if (x.length && kD(x, v, y, u, !0), !n) { var M = s.get("childrenVisibleMin"); null != M && f < M && (n = !0) } for (_ = 0, b = g.length; _ < b; _++) DD(g[_], e, n, i + 1) } } } function AD(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 ? xD(u * i / l, l / (u * r)) : 1 / 0 } function kD(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]] = xD(h - 2 * i, 0) , v = n[s[o]] + n[l[o]] - u , m = c === p - 1 || v < g ? v : g , x = f[l[o]] = xD(m - 2 * i, 0); f[s[a]] = n[s[a]] + _D(i, y / 2), f[s[o]] = u + _D(i, x / 2), u += m, d.setLayout(f, !0) } n[s[a]] += h, n[l[a]] -= h } function LD(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 sr(e.x - o.x, e.y - o.y, e.width, e.height); wD(t.viewChildren || [], (function (t) { LD(t, l, n, i, r + 1) } )) } } function PD(t) { return t.get(ID) ? t.get(TD) : 0 } function OD(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 RD(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) { X(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 ND(t) { return t instanceof Array || (t = [t, t]), t } function ED(t) { t.eachSeriesByType("graph", (function (t) { var e = t.getGraph() , n = t.getEdgeData() , i = ND(t.get("edgeSymbol")) , r = ND(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 = ND(i.getShallow("symbol", !0)) , a = ND(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 zD = "--\x3e" , VD = function (t) { return t.get("autoCurveness") || null } , BD = function (t, e) { var n = VD(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 } , FD = function (t, e, n) { var i = [t.id, t.dataIndex].join(".") , r = [e.id, e.dataIndex].join("."); return [n.uid, i, r].join(zD) } , GD = function (t) { var e = t.split(zD); return [e[0], e[2], e[1]].join(zD) } , WD = function (t, e) { var n = e.__edgeMap; return n[t] ? n[t].length : 0 }; function HD(t, e, n, i) { var r = VD(e) , o = Y(r); if (!r) return null; var a = function (t, e) { var n = FD(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 WD(FD(t.node1, t.node2, e), e) + WD(FD(t.node2, t.node1, e), e) }(t, e); BD(e, u), t.lineStyle = t.lineStyle || {}; var h = FD(t.node1, t.node2, e) , c = e.__curvenessList , p = o || u % 2 ? 0 : 1; if (a.isForward) return c[p + s]; var d = GD(h) , f = WD(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 YD(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")]) } )), UD(n, t) } } function UD(t, e) { t.eachEdge((function (t, n) { var i = ot(t.getModel().get(["lineStyle", "curveness"]), -HD(t, e, n, !0), 0) , r = Mt(t.node1.getLayout()) , o = Mt(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 XD(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]) } UD(i.graph, t) } else e && "none" !== e || YD(t) } )) } function ZD(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 jD(t) { var e = t.getVisual("symbolSize"); return e instanceof Array && (e = (e[0] + e[1]) / 2), +e } var qD = Math.PI , KD = []; function $D(t, e) { var n = t.coordinateSystem; if (!n || "view" === n.type) { var i = n.getBoundingRect() , r = t.getData() , o = r.graph , a = i.width / 2 + i.x , s = i.height / 2 + i.y , l = Math.min(i.width, i.height) / 2 , u = r.count(); r.setLayout({ cx: a, cy: s }), u && (JD[e](t, o, r, l, a, s, u), o.eachEdge((function (e, n) { var i, r = ot(e.getModel().get(["lineStyle", "curveness"]), HD(e, t, n), 0), o = Mt(e.node1.getLayout()), l = Mt(e.node2.getLayout()), u = (o[0] + l[0]) / 2, h = (o[1] + l[1]) / 2; +r && (i = [a * (r *= 3) + u * (1 - r), s * r + h * (1 - r)]), e.setLayout([o, l, i]) } ))) } } var JD = { 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; KD.length = a; var l = ZD(t); e.eachNode((function (t) { var e = jD(t); isNaN(e) && (e = 2), e < 0 && (e = 0), e *= l; var n = Math.asin(e / 2 / i); isNaN(n) && (n = qD / 2), KD[t.dataIndex] = n, s += 2 * n } )); var u = (2 * qD - s) / a / 2 , h = 0; e.eachNode((function (t) { var e = u + KD[t.dataIndex]; h += e, t.setLayout([i * Math.cos(h) + r, i * Math.sin(h) + o]), h += e } )) } }; function QD(t) { t.eachSeriesByType("graph", (function (t) { "circular" === t.get("layout") && $D(t, "symbolSize") } )) } var tA = Ct; function eA(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 && $D(t, "value") : YD(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 = Nr(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 = Nr(e, u, d); isNaN(o) && (o = (d[0] + d[1]) / 2); var a = r.getModel() , s = ot(r.getModel().get(["lineStyle", "curveness"]), -HD(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 ? .1 : n.gravity, h = 0; h < i.length; h++) { var c = i[h]; c.p || (c.p = wt(a * (Math.random() - .5) + l[0], s * (Math.random() - .5) + l[1])), c.pp = Mt(c.p), c.edges = null } var p, d, f = null == n.friction ? .6 : n.friction, g = f; return { warmUp: function () { g = .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; Dt(e, (y = a.n2).p, s.p); var h = At(e) - a.d , c = y.w / (s.w + y.w); isNaN(c) && (c = 0), Rt(e, e), !s.fixed && tA(s.p, s.p, e, c * h * g), !y.fixed && tA(y.p, y.p, e, -(1 - c) * h * g) } } for (o = 0; o < n; o++) (x = i[o]).fixed || (Dt(e, l, x.p), tA(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; Dt(e, (y = i[f]).p, s.p), 0 === (h = At(e)) && (It(e, Math.random() - .5, Math.random() - .5), h = 1); var v = (s.rep + y.rep) / h / h; !s.fixed && tA(s.pp, s.pp, e, v), !y.fixed && tA(y.pp, y.pp, e, -v) } } var m = []; for (o = 0; o < n; o++) { var x; (x = i[o]).fixed || (Dt(m, x.p, x.pp), tA(x.p, x.p, m, g), St(x.pp, x.p)) } var _ = (g *= .992) < .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 && St(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] || [], St(p[0], h), St(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 nA(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 = []; Ma(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 mp(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 BT; 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")), d.setZoom(t.get("zoom")), n.push(d) } } )), n } var iA = Eu.prototype , rA = Fu.prototype , oA = 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) }(oA); function aA(t) { return isNaN(+t.cpx1) || isNaN(+t.cpy1) } var sA = 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 oA } , e.prototype.buildPath = function (t, e) { aA(e) ? iA.buildPath.call(this, t, e) : rA.buildPath.call(this, t, e) } , e.prototype.pointAt = function (t) { return aA(this.shape) ? iA.pointAt.call(this, t) : rA.pointAt.call(this, t) } , e.prototype.tangentAt = function (t) { var e = this.shape , n = aA(e) ? [e.x2 - e.x1, e.y2 - e.y1] : rA.tangentAt.call(this, t); return Rt(n, n) } , e }(fs) , lA = ["fromSymbol", "toSymbol"]; function uA(t) { return "_" + t + "Type" } function hA(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 = Ly(r) , u = Py(a || 0, l) , h = ky(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 cA(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 pA = 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 sA({ name: "line", subPixelOptimize: !0 }); return cA(e.shape, t), e }(t.getItemLayout(e)); r.shape.percent = 0, rh(r, { shape: { percent: 1 } }, i, e), this.add(r), E(lA, (function (n) { var i = hA(n, t, e); this.add(i), this[uA(n)] = t.getItemVisual(e, n) } ), 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: {} }; cA(a.shape, o), ih(r, a, i, e), E(lA, (function (n) { var i = t.getItemVisual(e, n) , r = uA(n); if (this[r] !== i) { this.remove(this.childOfName(n)); var o = hA(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 = Hh(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(lA, (function (t) { var e = this.childOfName(t); if (e) { e.setColor(g), e.style.opacity = f.opacity; for (var n = 0; n < js.length; n++) { var i = js[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); Wh(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) ? zr(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 }), Ol(this, h, c, u) } , e.prototype.highlight = function () { xl(this) } , e.prototype.downplay = function () { _l(this) } , e.prototype.updateLayout = function (t, e) { this.setLinePoints(t.getItemLayout(e)) } , e.prototype.setLinePoints = function (t) { var e = this.childOfName("line"); cA(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 = Dt([], u, l); if (Rt(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] > .8 ? "left" : h[0] < -.8 ? "right" : "center", p = h[1] > .8 ? "top" : h[1] < -.8 ? "bottom" : "middle"; break; case "start": i.x = -h[0] * f + l[0], i.y = -h[1] * g + l[1], c = h[0] > .8 ? "right" : h[0] < -.8 ? "left" : "center", p = h[1] > .8 ? "bottom" : h[1] < -.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 }(Cr) , dA = function () { function t(t) { this.group = new Cr, this._LineCtor = t || pA } 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 = fA(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 = fA(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 (yA(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) { zh(this._progressiveEls || this.group, t) } , t.prototype._doAdd = function (t, e, n) { if (yA(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); yA(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 fA(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: Hh(e) } } function gA(t) { return isNaN(t[0]) || isNaN(t[1]) } function yA(t) { return t && !gA(t[0]) && !gA(t[1]) } var vA = [] , mA = [] , xA = [] , _A = Ke , bA = Vt , wA = Math.abs; function SA(t, e, n) { for (var i, r = t[0], o = t[1], a = t[2], s = 1 / 0, l = n * n, u = .1, h = .1; h <= .9; h += .1) { vA[0] = _A(r[0], o[0], a[0], h), vA[1] = _A(r[1], o[1], a[1], h), (d = wA(bA(vA, e) - l)) < s && (s = d, i = h) } for (var c = 0; c < 32; c++) { var p = i + u; mA[0] = _A(r[0], o[0], a[0], i), mA[1] = _A(r[1], o[1], a[1], i), xA[0] = _A(r[0], o[0], a[0], p), xA[1] = _A(r[1], o[1], a[1], p); var d = bA(mA, e) - l; if (wA(d) < .01) break; var f = bA(xA, e) - l; u /= 2, d < 0 ? f >= 0 ? i += u : i -= u : f >= 0 ? i -= u : i += u } return i } function MA(t, e) { var n = [] , i = Qe , 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 = [Mt(l[0]), Mt(l[1])], l[2] && l.__original.push(Mt(l[2]))); var c = l.__original; if (null != l[2]) { if (St(r[0], c[0]), St(r[1], c[2]), St(r[2], c[1]), u && "none" !== u) { var p = jD(t.node1) , d = SA(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 = jD(t.node2), d = SA(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] } St(l[0], r[0]), St(l[1], r[2]), St(l[2], r[1]) } else { if (St(o[0], c[0]), St(o[1], c[1]), Dt(a, o[1], o[0]), Rt(a, a), u && "none" !== u) { p = jD(t.node1); Ct(o[0], o[0], a, p * e) } if (h && "none" !== h) { p = jD(t.node2); Ct(o[1], o[1], a, -p * e) } St(l[0], o[0]), St(l[1], o[1]) } } )) } function IA(t) { return "view" === t.type } var TA = 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 Zw , i = new dA , r = this.group; this._controller = new DI(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 (IA(r)) { var l = { x: r.x, y: r.y, scaleX: r.scaleX, scaleY: r.scaleY }; this._firstRender ? s.attr(l) : ih(s, l, t) } MA(t.getGraph(), ZD(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), u.graph.eachNode((function (t) { var e = t.dataIndex , n = t.getGraphicEl() , r = t.getModel(); if (n) { n.off("drag").off("dragend"); var o = r.get("draggable"); o && n.on("drag", (function () { c && (c.warmUp(), !i._layouting && i._startForceLayoutIteration(c, p), c.setFixed(e), u.setItemLayout(e, [n.x, n.y])) } )).on("dragend", (function () { c && c.setUnfixed(e) } )), n.setDraggable(o && !!c), "adjacency" === r.get(["emphasis", "focus"]) && (Ws(n).focus = t.getAdjacentDataIndices()) } } )), u.graph.eachEdge((function (t) { var e = t.getGraphicEl() , n = t.getModel().get(["emphasis", "focus"]); e && "adjacency" === n && (Ws(e).focus = { edge: [t.dataIndex], node: [t.node1.dataIndex, t.node2.dataIndex] }) } )); var d = "circular" === t.get("layout") && t.get(["circular", "rotateLabel"]) , f = u.getLayout("cx") , g = u.getLayout("cy"); u.eachItemGraphicEl((function (t, e) { var n = u.getItemModel(e).get(["label", "rotate"]) || 0 , i = t.getSymbolPath(); if (d) { var r = u.getItemLayout(e) , o = Math.atan2(r[1] - g, r[0] - f); o < 0 && (o = 2 * Math.PI + o); var a = r[0] < f; a && (o -= Math.PI); var s = a ? "left" : "right"; i.setTextConfig({ rotation: -o, position: s, origin: "center" }); var l = i.ensureState("emphasis"); A(l.textConfig || (l.textConfig = {}), { position: s }) } else i.setTextConfig({ rotation: n *= Math.PI / 180 }) } )), this._firstRender = !1 } , e.prototype.dispose = function () { 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) && !EI(e, n, t) } )), IA(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) { PI(o, e.dx, e.dy), n.dispatchAction({ seriesId: t.id, type: "graphRoam", dx: e.dx, dy: e.dy }) } )).on("zoom", (function (e) { OI(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(), MA(t.getGraph(), ZD(t)), i._lineDraw.updateLayout(), n.updateLabelLayout() } ))) : r.disable() } , e.prototype._updateNodeAndLinkScale = function () { var t = this._model , e = t.getData() , n = ZD(t); e.eachItemGraphicEl((function (t, e) { t && t.setSymbolScale(n) } )) } , e.prototype.updateLayout = function (t) { MA(t.getGraph(), ZD(t)), this._symbolDraw.updateLayout(), this._lineDraw.updateLayout() } , e.prototype.remove = function (t, e) { this._symbolDraw && this._symbolDraw.remove(), this._lineDraw && this._lineDraw.remove() } , e.type = "graph", e }(mg); function CA(t) { return "_EC_" + t } var DA = 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[CA(t)]) { var i = new AA(t, e); return i.hostGraph = this, this.nodes.push(i), n[CA(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[CA(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 AA || (t = i[CA(t)]), e instanceof AA || (e = i[CA(e)]), t && e) { var o = t.id + "-" + e.id , a = new kA(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 AA && (t = t.id), e instanceof AA && (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 AA || (e = this._nodesMap[CA(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 }() , AA = 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 }() , kA = 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 }(); function LA(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 PA(t, e, n, i, r) { for (var o = new DA(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(xo(h.id, null), c + " > " + p)), u++) } var d, f = n.get("coordinateSystem"); if ("cartesian2d" === f || "polar" === f) d = nx(t, n); else { var g = ud.get(f) , y = g && g.dimensions || []; P(y, "value") < 0 && y.concat(["value"]); var v = jm(t, { coordDimensions: y, encodeDefine: n.getEncode() }).dimensions; (d = new Zm(v, n)).initData(t) } var m = new Zm(["value"], n); return m.initData(l, s), r && r(d, m), mC({ mainData: d, struct: o, structAttr: "graph", datas: { node: d, edge: m }, datasAttr: { node: "data", edge: "edgeData" } }), o.update(), o } R(AA, LA("hostGraph", "data")), R(kA, LA("hostGraph", "edgeData")); var OA = 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 lM(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) { VD(n = this) && (n.__curvenessList = [], n.__edgeMap = {}, BD(n)); var a = PA(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 = pc.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 (VD(n)) { var r = FD(t, e, n) , o = n.__edgeMap , a = o[GD(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), Uf("nameValue", { name: l.join(" > "), value: r.value, noValue: null == r.value }) } return ig({ 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 Zm(["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: .1, friction: .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: .6, label: { show: !1, formatter: "{b}" }, itemStyle: {}, lineStyle: { color: "#aaa", width: 1, opacity: .5 }, emphasis: { scale: !0, label: { show: !0 } }, select: { itemStyle: { borderColor: "#212121" } } }, e }(ag) , RA = { type: "graphRoam", event: "graphRoam", update: "none" }; var NA = function () { this.angle = 0, this.width = 10, this.r = 10, this.x = 0, this.y = 0 } , EA = 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 NA } , 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 }(fs); function zA(t, e) { var n = null == t ? "" : t + ""; return e && (X(e) ? n = e.replace("{value}", n) : U(e) && (n = e(t))), n } var VA = 2 * Math.PI , BA = 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: Er(n[0], e.getWidth()), cy: Er(n[1], e.getHeight()), r: Er(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) { for (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") ? TS : Tu, c = u.get("show"), p = u.getModel("lineStyle"), d = p.get("width"), f = (l - s) % VA || l === s ? (l - s) % VA : VA, g = s, y = 0; c && y < i.length; y++) { var v = new h({ shape: { startAngle: g, endAngle: l = s + f * Math.min(Math.max(i[y][0], 0), 1), cx: r.cx, cy: r.cy, clockwise: a, r0: r.r - d, r: r.r }, silent: !0 }); v.setStyle({ fill: i[y][1] }), v.setStyle(p.getLineStyle(["color", "width"])), o.add(v), g = l } var m = 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] }; if (!a) { var x = s; s = l, l = x } this._renderTicks(t, e, n, m, r, s, l, a, d), this._renderTitleAndDetail(t, e, n, m, r), this._renderAnchor(t, r), this._renderPointer(t, e, n, m, 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 = Er(v.get("length"), f), S = Er(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 Eu({ 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 = zA(zr(k / _ * (y - g) + g), x.get("formatter")) , R = i(k / _); c.add(new As({ style: Yh(x, { text: O, x: u * (f - w - P) + p, y: h * (f - w - P) + d, verticalAlign: h < -.8 ? "top" : h > .8 ? "bottom" : "middle", align: u < -.4 ? "left" : u > .4 ? "right" : "center" }, { inheritColor: R }), silent: !0 })) } if (m.get("show") && k !== _) { P = (P = m.get("distance")) ? P + l : l; for (var N = 0; N <= b; N++) { u = Math.cos(M), h = Math.sin(M); var E = new Eu({ 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 && E.setStyle({ stroke: i((k + N / b) / _) }), c.add(E), 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 = Er(o.get("width"), r.r), s = Er(o.get("length"), r.r), l = t.get(["pointer", "icon"]), u = o.get("offsetCenter"), h = Er(u[0], r.r), c = Er(u[1], r.r), p = o.get("keepAspect"); return (i = l ? ky(l, h - a / 2, c - s, a, s, null, p) : new EA({ 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") ? TS : Tu , 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 = x - y.get(v, t) % x), c } (g || d) && (y.diff(h).add((function (e) { var n = y.get(v, e); if (d) { var i = w(e, o); rh(i, { rotation: -((isNaN(+n) ? b[0] : Nr(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"); rh(r, { shape: { endAngle: Nr(n, _, b, a) } }, t), u.add(r), Hs(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, ih(s, { rotation: -((isNaN(+i) ? b[0] : Nr(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"); ih(m, { shape: { endAngle: Nr(i, _, b, x) } }, t), u.add(m), Hs(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 xs) { 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(Nr(y.get(v, t), _, [0, 1], !0))), s.z2EmphasisLift = 0, zl(s, e), Ol(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, zl(c, e), Ol(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 = ky(r, e.cx - i / 2 + Er(o[0], e.r), e.cy - i / 2 + Er(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 Cr , c = [] , p = [] , d = t.isAnimationEnabled() , f = t.get(["pointer", "showAbove"]); a.diff(this._data).add((function (t) { c[t] = new As({ silent: !0 }), p[t] = new As({ 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 Cr , y = i(Nr(o, [l, u], [0, 1], !0)) , v = n.getModel("title"); if (v.get("show")) { var m = v.get("offsetCenter") , x = r.cx + Er(m[0], r.r) , _ = r.cy + Er(m[1], r.r); (D = c[e]).attr({ z2: f ? 0 : 2, style: Yh(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 + Er(w[0], r.r) , M = r.cy + Er(w[1], r.r) , I = Er(b.get("width"), r.r) , T = Er(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: Yh(b, { x: S, y: M, text: zA(o, A), width: isNaN(I) ? null : I, height: isNaN(T) ? null : T, align: "center", verticalAlign: "middle" }, { inheritColor: C }) }), Jh(D, { normal: b }, o, (function (t) { return zA(t, A) } )), d && Qh(D, e, a, t, { getFormattedLabel: function (t, e, n, i, r, a) { return zA(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 }(mg) , FA = 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 sM(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 }, 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 }(ag); var GA = ["itemStyle", "opacity"] , WA = function (t) { function e(e, n) { var i = t.call(this) || this , r = i , o = new Ou , a = new As; 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(GA); l = null == l ? 1 : l, n || uh(i), i.useStyle(t.getItemVisual(e, "style")), i.style.lineJoin = "round", n ? (i.setShape({ points: a.points }), i.style.opacity = 0, rh(i, { style: { opacity: l } }, r, e)) : ih(i, { style: { opacity: l }, shape: { points: a.points } }, r, e), zl(i, o), this._updateLabel(t, e), Ol(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; Wh(r, Hh(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 Ji(h[0][0], h[0][1]) : null }, ih(r, { style: { x: s.x, y: s.y } }, o, e), r.attr({ rotation: s.rotation, originX: s.x, originY: s.y, z2: 10 }), cb(n, pb(a), { stroke: u }) } , e }(Lu) , HA = 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 WA(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) { lh(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 }(mg) , YA = 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 lM(W(this.getData, this), W(this.getRawData, this)), this._defaultLabelLine(e) } , e.prototype.getInitialData = function (t, e) { return sM(this, { coordDimensions: ["value"], encodeDefaulter: H(Hp, 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 }(ag); function UA(t, e) { t.eachSeriesByType("funnel", (function (t) { var n = t.getData() , i = n.mapDimension("value") , r = t.get("sort") , o = function (t, e) { return mp(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 U(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 ? [Er(t.get("minSize"), l), Er(t.get("maxSize"), l)] : [Er(t.get("minSize"), s), Er(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 = Nr(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 = Nr(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 = Er(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 = Er(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 XA = function (t) { function e() { var n = null !== t && t.apply(this, arguments) || this; return n.type = e.type, n._dataGroup = new Cr, 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 = qA(t); if (o.diff(a).add((function (t) { KA(jA(o, r, t, l, s), o, t, u) } )).update((function (e, n) { var i = a.getItemGraphicEl(n) , r = ZA(o, e, l, s); o.setItemGraphicEl(e, i), ih(i, { shape: { points: r } }, t, e), uh(i), KA(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 Ts({ 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), rh(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 = qA(e), s = this._progressiveEls = [], l = t.start; l < t.end; l++) { var u = jA(i, this._dataGroup, l, o, r); u.incremental = !0, KA(u, i, l, a), s.push(u) } } , e.prototype.remove = function () { this._dataGroup && this._dataGroup.removeAll(), this._data = null } , e.type = "parallel", e }(mg); function ZA(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 jA(t, e, n, i, r) { var o = ZA(t, n, i, r) , a = new Ou({ shape: { points: o }, z2: 10 }); return e.add(a), t.setItemGraphicEl(n, a), a } function qA(t) { var e = t.get("smooth", !0); return !0 === e && (e = .3), nt(e = to(e)) && (e = 0), { smooth: e } } function KA(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"); zl(t, r, "lineStyle"), Ol(t, o.get("focus"), o.get("blurScope"), o.get("disabled")) } var $A = 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 nx(null, this, { useEncodeDefaulter: W(JA, 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: .05, activeOpacity: 1, lineStyle: { width: 1, opacity: .45, type: "solid" }, emphasis: { label: { show: !1 } }, progressive: 500, smooth: !1, animationEasing: "linear" }, e }(ag); function JA(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 QA = ["lineStyle", "opacity"] , tk = { 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(QA, !0); null != o && (r = o) } e.ensureUniqueItemVisual(n, "style").opacity = r } ), t.start, t.end) } } } }; function ek(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) { E(ho(t.parallelAxis), (function (e) { if (q(e)) { var n = e.parallelIndex || 0 , i = ho(t.parallel)[n]; i && i.parallelAxisDefault && C(e, i.parallelAxisDefault, !1) } } )) }(t) } 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.render = function (t, e, n) { this._model = t, this._api = n, this._handlers || (this._handlers = {}, E(ik, (function (t, e) { n.getZr().on(e, this._handlers[e] = W(t, this)) } ), this)), Dg(this, "_throttledDispatchExpand", t.get("axisExpandRate"), "fixRate") } , e.prototype.dispose = function (t, e) { Ag(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 }(fg) , ik = { 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 ok = 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: [-.15, .05, .4], axisExpandTriggerOn: "click", parallelAxisDefault: null }, e }(Ip) , ak = 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 }(G_); function sk(t, e, n, i, r, o) { t = t || 0; var a = n[1] - n[0]; if (null != r && (r = uk(r, [0, a])), null != o && (o = Math.max(o, null != r ? r : 0)), "all" === i) { var s = Math.abs(e[1] - e[0]); s = uk(s, [0, a]), r = o = uk(s, [r, o]), i = 0 } e[0] = uk(e[0], n), e[1] = uk(e[1], n); var l = lk(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] = uk(e[i], c), u = lk(e, i), null != r && (u.sign !== l.sign || u.span < r) && (e[1 - i] = e[i] + l.sign * r), u = lk(e, i), null != o && u.span > o && (e[1 - i] = e[i] + u.sign * o), e } function lk(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 uk(t, e) { return Math.min(null != e[1] ? e[1] : 1 / 0, Math.max(null != e[0] ? e[0] : -1 / 0, t)) } var hk = E , ck = Math.min , pk = Math.max , dk = Math.floor , fk = Math.ceil , gk = zr , yk = Math.PI , vk = function () { function t(t, e, n) { this.type = "parallel", this._axesMap = ft(), 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; hk(i, (function (t, n) { var i = r[n] , o = e.getComponent("parallelAxis", i) , a = this._axesMap.set(t, new ak(t, i_(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(); hk(this.dimensions, (function (t) { var e = this._axesMap.get(t); e.scale.unionExtentFromData(i, i.mapDimension(t)), n_(e.scale, e.model) } ), this) } } ), this) } , t.prototype.resize = function (t, e) { this._rect = mp(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 = mk(e.get("axisExpandWidth"), l), c = mk(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 = mk(d[1] - d[0], l), d[1] = d[0] + t) : (t = mk(h * (c - 1), l), (d = [h * (e.get("axisExpandCenter") || dk(u / 2)) - t / 2])[1] = d[0] + t); var f = (s - t) / (u - c); f < 3 && (f = 0); var g = [dk(gk(d[0] / h, 1)) + 1, fk(gk(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]) } )), hk(n, (function (e, n) { var o = (i.axisExpandable ? _k : xk)(n, i) , a = { horizontal: { x: o.position, y: i.axisLength }, vertical: { x: 0, y: o.position } } , s = { horizontal: yk / 2, vertical: 0 } , l = [a[r].x + t.x, a[r].y + t.y] , u = s[r] , h = [1, 0, 0, 1, 0, 0]; zi(h, h, u), Ei(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 Ih([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) ? sk(a, i, o, "all") : l = "none"; else { var p = i[1] - i[0]; (i = [pk(0, o[1] * s / p - p / 2)])[1] = ck(o[1], i[0] + p), i[0] = i[1] - p } return { axisExpandWindow: i, behavior: l } } , t }(); function mk(t, e) { return ck(pk(t, e[0]), e[1]) } function xk(t, e) { var n = e.layoutLength / (e.axisCount - 1); return { position: n * t, axisNameAvailableWidth: n, axisLabelShow: !0 } } function _k(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 bk = { create: function (t, e) { var n = []; return t.eachComponent("parallel", (function (i, r) { var o = new vk(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", Co).models[0]; t.coordinateSystem = e.coordinateSystem } } )), n } } , wk = 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 Wo([["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--) Vr(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 }(Ip); R(wk, h_); var Sk = !0 , Mk = Math.min , Ik = Math.max , Tk = Math.pow , Ck = "globalPan" , Dk = { w: [0, 0], e: [0, 1], n: [1, 0], s: [1, 1] } , Ak = { w: "ew", e: "ew", n: "ns", s: "ns", ne: "nesw", sw: "nesw", nw: "nwse", se: "nwse" } , kk = { brushStyle: { lineWidth: 2, stroke: "rgba(210,219,238,0.3)", fill: "#D2DBEE" }, transformable: !0, brushMode: "single", removeOnClick: !1 } , Lk = 0 , Pk = function (t) { function e(e) { var n = t.call(this) || this; return n._track = [], n._covers = [], n._handlers = {}, n._zr = e, n.group = new Cr, n._uid = "brushController_" + Lk++, E(oL, (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) { CI(t)[e] = n }(e, Ck, this._uid), E(this._handlers, (function (t, n) { e.on(n, t) } )), this._brushType = t.brushType, this._brushOption = C(T(kk), t, !0) } , e.prototype._doDisableBrush = function () { var t = this._zr; !function (t, e, n) { var i = CI(t); i[e] === n && (i[e] = null) }(t, Ck, 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(kk), t, !0) } )); var e = this._covers , n = this._covers = [] , i = this , r = this._creatingCover; return new Sm(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]) : Rk(i, Ok(i, s)); zk(i, l) } } } , e.prototype.unmount = function () { return this.enableBrush(!1), Gk(this), this._zr.remove(this.group), this } , e.prototype.dispose = function () { this.unmount(), this.off() } , e }(Xt); function Ok(t, e) { var n = sL[e.brushType].createCover(t, e); return n.__brushOption = e, Ek(n, e), t.group.add(n), n } function Rk(t, e) { var n = Vk(e); return n.endCreating && (n.endCreating(t, e), Ek(e, e.__brushOption)), e } function Nk(t, e) { var n = e.__brushOption; Vk(e).updateCoverShape(t, e, n.range, n) } function Ek(t, e) { var n = e.z; null == n && (n = 1e4), t.traverse((function (t) { t.z = n, t.z2 = n } )) } function zk(t, e) { Vk(e).updateCommon(t, e), Nk(t, e) } function Vk(t) { return sL[t.__brushOption.brushType] } function Bk(t, e, n) { var i, r = t._panels; if (!r) return Sk; var o = t._transform; return E(r, (function (t) { t.isTargetByCursor(e, n, o) && (i = t) } )), i } function Fk(t, e) { var n = t._panels; if (!n) return Sk; var i = e.__brushOption.panelId; return null != i ? n[i] : Sk } function Gk(t) { var e = t._covers , n = e.length; return E(e, (function (e) { t.group.remove(e) } ), t), e.length = 0, !!n } function Wk(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 Hk(t) { var e = t.length - 1; return e < 0 && (e = 0), [t[0], t[e]] } function Yk(t, e, n, i) { var r = new Cr; return r.add(new Ts({ name: "main", style: jk(n), silent: !0, draggable: !0, cursor: "move", drift: H($k, t, e, r, ["n", "s", "w", "e"]), ondragend: H(Wk, e, { isEnd: !0 }) })), E(i, (function (n) { r.add(new Ts({ name: n.join(""), style: { opacity: 0 }, draggable: !0, silent: !0, invisible: !0, drift: H($k, t, e, r, n), ondragend: H(Wk, e, { isEnd: !0 }) })) } )), r } function Uk(t, e, n, i) { var r = i.brushStyle.lineWidth || 0 , o = Ik(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; Zk(t, e, "main", a, s, f, g), i.transformable && (Zk(t, e, "w", l, u, o, v), Zk(t, e, "e", p, u, o, v), Zk(t, e, "n", l, u, y, o), Zk(t, e, "s", l, d, y, o), Zk(t, e, "nw", l, u, o, o), Zk(t, e, "ne", p, u, o, o), Zk(t, e, "sw", l, d, o, o), Zk(t, e, "se", p, d, o, o)) } function Xk(t, e) { var n = e.__brushOption , i = n.transformable , r = e.childAt(0); r.useStyle(jk(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 ? Kk(t, n[0]) : function (t, e) { var n = [Kk(t, e[0]), Kk(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 ? Ak[o] + "-resize" : null }) } )) } function Zk(t, e, n, i, r, o, a) { var s = e.childOfName(n); s && s.setShape(function (t) { var e = Mk(t[0][0], t[1][0]) , n = Mk(t[0][1], t[1][1]) , i = Ik(t[0][0], t[1][0]) , r = Ik(t[0][1], t[1][1]); return { x: e, y: n, width: i - e, height: r - n } }(tL(t, e, [[i, r], [i + o, r + a]]))) } function jk(t) { return k({ strokeNoScale: !0 }, t.brushStyle) } function qk(t, e, n, i) { var r = [Mk(t, n), Mk(e, i)] , o = [Ik(t, n), Ik(e, i)]; return [[r[0], o[0]], [r[1], o[1]]] } function Kk(t, e) { return { left: "w", right: "e", top: "n", bottom: "s" }[Th({ w: "left", e: "right", n: "top", s: "bottom" }[e], function (t) { return Mh(t.group) }(t))] } function $k(t, e, n, i, r, o) { var a = n.__brushOption , s = t.toRectRange(a.range) , l = Qk(e, r, o); E(i, (function (t) { var e = Dk[t]; s[e[0]][e[1]] += l[e[0]] } )), a.range = t.fromRectRange(qk(s[0][0], s[1][0], s[0][1], s[1][1])), zk(e, n), Wk(e, { isEnd: !1 }) } function Jk(t, e, n, i) { var r = e.__brushOption.range , o = Qk(t, n, i); E(r, (function (t) { t[0] += o[0], t[1] += o[1] } )), zk(t, e), Wk(t, { isEnd: !1 }) } function Qk(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 tL(t, e, n) { var i = Fk(t, e); return i && i !== Sk ? i.clipPath(n, t._transform) : T(n) } function eL(t) { var e = t.event; e.preventDefault && e.preventDefault() } function nL(t, e, n) { return t.childOfName("main").contain(e, n) } function iL(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 Tk(r * r + o * o, .5) > 6 }(t) || o) { if (a && !o) { "single" === s.brushMode && Gk(t); var l = T(s); l.brushType = rL(l.brushType, a), l.panelId = a === Sk ? null : a.panelId, o = t._creatingCover = Ok(t, l), t._covers.push(o) } if (o) { var u = sL[rL(t._brushType, a)]; o.__brushOption.range = u.getCreatingRange(tL(t, o, t._track)), i && (Rk(t, o), u.updateCommon(t, o)), Nk(t, o), r = { isEnd: i } } } else i && "single" === s.brushMode && s.removeOnClick && Bk(t, e, n) && Gk(t) && (r = { isEnd: i, removeOnClick: !0 }); return r } function rL(t, e) { return "auto" === t ? e.defaultBrushType : t } var oL = { mousedown: function (t) { if (this._dragging) aL(this, t); else if (!t.target || !t.target.draggable) { eL(t); var e = this.group.transformCoordToLocal(t.offsetX, t.offsetY); this._creatingCover = null, (this._creatingPanel = Bk(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 = Bk(t, e, n); if (!t._dragging) for (var a = 0; a < r.length; a++) { var s = r[a].__brushOption; if (o && (o === Sk || s.panelId === o.panelId) && sL[s.brushType].contain(r[a], n[0], n[1])) return } o && i.setCursorStyle("crosshair") } }(this, t, i), this._dragging) { eL(t); var r = iL(this, t, i, !1); r && Wk(this, r) } }, mouseup: function (t) { aL(this, t) } }; function aL(t, e) { if (t._dragging) { eL(e); var n = e.offsetX , i = e.offsetY , r = t.group.transformCoordToLocal(n, i) , o = iL(t, e, r, !0); t._dragging = !1, t._track = [], t._creatingCover = null, o && Wk(t, o) } } var sL = { lineX: lL(0), lineY: lL(1), rect: { createCover: function (t, e) { function n(t) { return t } return Yk({ toRectRange: n, fromRectRange: n }, t, e, [["w"], ["e"], ["n"], ["s"], ["s", "e"], ["s", "w"], ["n", "e"], ["n", "w"]]) }, getCreatingRange: function (t) { var e = Hk(t); return qk(e[1][0], e[1][1], e[0][0], e[0][1]) }, updateCoverShape: function (t, e, n, i) { Uk(t, e, n, i) }, updateCommon: Xk, contain: nL }, polygon: { createCover: function (t, e) { var n = new Cr; return n.add(new Ou({ name: "main", style: jk(e), silent: !0 })), n }, getCreatingRange: function (t) { return t }, endCreating: function (t, e) { e.remove(e.childAt(0)), e.add(new Lu({ name: "main", draggable: !0, drift: H(Jk, t, e), ondragend: H(Wk, t, { isEnd: !0 }) })) }, updateCoverShape: function (t, e, n, i) { e.childAt(0).setShape({ points: tL(t, e, n) }) }, updateCommon: Xk, contain: nL } }; function lL(t) { return { createCover: function (e, n) { return Yk({ 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 = Hk(e); return [Mk(n[0][t], n[1][t]), Ik(n[0][t], n[1][t])] }, updateCoverShape: function (e, n, i, r) { var o, a = Fk(e, n); if (a !== Sk && 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(), Uk(e, n, l, r) }, updateCommon: Xk, contain: nL } } function uL(t) { return t = pL(t), function (e) { return Ah(e, t) } } function hL(t, e) { return t = pL(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 cL(t, e, n) { var i = pL(t); return function (t, r) { return i.contain(r[0], r[1]) && !EI(t, e, n) } } function pL(t) { return sr.create(t) } var dL = ["axisLine", "axisTickLabel", "axisName"] , fL = 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 Pk(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 Cr, 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 BM(t, h); E(dL, c.add, c), this._axisGroup.add(c.getGroup()), this._refreshBrushController(h, s, t, o, l, n), Dh(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, .1 * Math.abs(s)) , u = sr.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: uL(u), isTargetByCursor: cL(u, o, i), getLinearBrushOtherExtent: hL(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 }(fg); var gL = { type: "axisAreaSelect", event: "axisAreaSelected" }; var yL = { type: "value", areaSelectStyle: { width: 20, borderWidth: 1, borderColor: "rgba(160,197,232)", color: "rgba(160,197,232)", opacity: .3 }, realtime: !0, z: 10 }; function vL(t) { t.registerComponentView(nk), t.registerComponentModel(ok), t.registerCoordinateSystem("parallel", bk), t.registerPreprocessor(ek), t.registerComponentModel(wk), t.registerComponentView(fL), wM(t, "parallel", wk, yL), function (t) { t.registerAction(gL, (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 mL = 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 } , xL = function (t) { function e(e) { return t.call(this, e) || this } return n(e, t), e.prototype.getDefaultShape = function () { return new mL } , 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 () { xl(this) } , e.prototype.downplay = function () { _l(this) } , e }(fs) , _L = 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 xL , i = Ws(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(); switch (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()), n.style.fill) { case "source": n.style.fill = e.node1.getVisual("color"), n.style.decal = e.node1.getVisual("style").decal; break; case "target": n.style.fill = e.node2.getVisual("color"), n.style.decal = e.node2.getVisual("style").decal; break; case "gradient": var A = e.node1.getVisual("color") , k = e.node2.getVisual("color"); X(A) && X(k) && (n.style.fill = new Uu(0, 0, +("horizontal" === c), +("vertical" === c), [{ color: A, offset: 0 }, { color: k, offset: 1 }])) } var L = v.getModel("emphasis"); zl(n, v, "lineStyle", (function (t) { return t.getItemStyle() } )), o.add(n), h.setItemGraphicEl(e.dataIndex, n); var P = L.get("focus"); Ol(n, "adjacency" === P ? e.getAdjacentDataIndices() : P, L.get("blurScope"), L.get("disabled")), Ws(n).dataType = "edge" } )), r.eachNode((function (e) { var n = e.getLayout() , i = e.getModel() , r = i.get("localX") , a = i.get("localY") , h = i.getModel("emphasis") , c = new Ts({ shape: { x: null != r ? r * s : n.x, y: null != a ? a * l : n.y, width: n.dx, height: n.dy }, style: i.getModel("itemStyle").getItemStyle(), z2: 10 }); Wh(c, Hh(i), { labelFetcher: t, labelDataIndex: e.dataIndex, defaultText: e.id }), c.disableLabelAnimation = !0, c.setStyle("fill", e.getVisual("color")), c.setStyle("decal", e.getVisual("style").decal), zl(c, i), o.add(c), u.setItemGraphicEl(e.dataIndex, c), Ws(c).dataType = "node"; var p = h.get("focus"); Ol(c, "adjacency" === p ? e.getAdjacentDataIndices() : p, 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 Ts({ shape: { x: t.x - 10, y: t.y - 10, width: 0, height: t.height + 20 } }); return rh(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 }(mg); var bL = 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 pc(r[a], this, e)); if (i && n) return PA(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 } )) } )).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 Uf("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 Uf("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 }, levels: [], nodeAlign: "justify", lineStyle: { color: "#314656", opacity: .2, curveness: .5 }, emphasis: { label: { show: !0 }, lineStyle: { opacity: .5 } }, select: { itemStyle: { borderColor: "#212121" } }, animationEasing: "linear", animationDuration: 1e3 }, e }(ag); function wL(t, e) { t.eachSeriesByType("sankey", (function (t) { var n = t.get("nodeWidth") , i = t.get("nodeGap") , r = function (t, e) { return mp(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 = PL(t.outEdges, LL) , n = PL(t.inEdges, LL) , 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) { SL(t) || t.setLayout({ depth: Math.max(0, i - t.getLayout().skNodeHeight) }, !0) } )) } else "justify" === e && function (t, e) { E(t, (function (t) { SL(t) || t.outEdges.length || t.setLayout({ depth: e }, !0) } )) }(t, i) }(t, a, 0, 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, "vertical" === o ? (r - n) / b : (i - n) / b, 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 = Lo(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), ML(s, r, n, i, a); for (var l = 1; o > 0; o--) IL(s, l *= .99, a), ML(s, r, n, i, a), OL(s, l, a), ML(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 SL(t) { var e = t.hostGraph.data.getRawDataItem(t.dataIndex); return null != e.depth && e.depth >= 0 } function ML(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 IL(t, e, n) { E(t.slice().reverse(), (function (t) { E(t, (function (t) { if (t.outEdges.length) { var i = PL(t.outEdges, TL, n) / PL(t.outEdges, LL); if (isNaN(i)) { var r = t.outEdges.length; i = r ? PL(t.outEdges, CL, n) / r : 0 } if ("vertical" === n) { var o = t.getLayout().x + (i - kL(t, n)) * e; t.setLayout({ x: o }, !0) } else { var a = t.getLayout().y + (i - kL(t, n)) * e; t.setLayout({ y: a }, !0) } } } )) } )) } function TL(t, e) { return kL(t.node2, e) * t.getValue() } function CL(t, e) { return kL(t.node2, e) } function DL(t, e) { return kL(t.node1, e) * t.getValue() } function AL(t, e) { return kL(t.node1, e) } function kL(t, e) { return "vertical" === e ? t.getLayout().x + t.getLayout().dx / 2 : t.getLayout().y + t.getLayout().dy / 2 } function LL(t) { return t.getValue() } function PL(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 OL(t, e, n) { E(t, (function (t) { E(t, (function (t) { if (t.inEdges.length) { var i = PL(t.inEdges, DL, n) / PL(t.inEdges, LL); if (isNaN(i)) { var r = t.inEdges.length; i = r ? PL(t.inEdges, AL, n) / r : 0 } if ("vertical" === n) { var o = t.getLayout().x + (i - kL(t, n)) * e; t.setLayout({ x: o }, !0) } else { var a = t.getLayout().y + (i - kL(t, n)) * e; t.setLayout({ y: a }, !0) } } } )) } )) } function RL(t) { t.eachSeriesByType("sankey", (function (t) { var e = t.getGraph().nodes; if (e.length) { var n = 1 / 0 , i = -1 / 0; E(e, (function (t) { var e = t.getLayout().value; e < n && (n = e), e > i && (i = e) } )), E(e, (function (e) { var r = new eD({ type: "color", mappingMethod: "linear", dataExtent: [n, i], visual: t.get("color") }).mapValueToVisual(e.getLayout().value) , o = e.getModel().get(["itemStyle", "color"]); null != o ? (e.setVisual("color", o), e.setVisual("style", { fill: o })) : (e.setVisual("color", r), e.setVisual("style", { fill: r })) } )) } } )) } var NL = function () { function t() { } return 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 = !0) : "category" === s ? (t.layout = "vertical", n = o.getOrdinalMeta(), i = !0) : 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: Tm(d), ordinalMeta: n, otherDims: { tooltip: !1, itemName: 0 }, dimsDef: ["base"] }, { name: c, type: Tm(f), dimsDef: v.slice() }]; return sM(this, { coordDimensions: m, dimensionsCount: v.length + 1, encodeDefaulter: H(Wp, m, this) }) } , t.prototype.getBaseAxis = function () { var t = this._baseAxisDim; return this.ecModel.getComponent(t + "Axis", this.get(t + "AxisIndex")).axis } , t }() , EL = 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 }(ag); R(EL, NL, !0); var zL = 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 = FL(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 ? (uh(n), GL(s, n, i, t)) : n = FL(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 }(mg) , VL = function () { } , BL = 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 VL } , 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 }(fs); function FL(t, e, n, i, r) { var o = t.ends , a = new BL({ shape: { points: r ? WL(o, i, t) : o } }); return GL(t, a, e, n, r), a } function GL(t, e, n, i, r) { var o = n.hostModel; (0, Vh[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"); zl(e, a), Ol(e, s.get("focus"), s.get("blurScope"), s.get("disabled")) } function WL(t, e, n) { return z(t, (function (t) { return (t = t.slice())[e] = n.initBaseline, t } )) } function HL(t, e) { } var YL = E; function UL(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); YL(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; YL(i, (function (t) { l = Math.max(l, t.getData().count()) } )); var u = n.getExtent(); e = Math.abs(u[1] - u[0]) / l } YL(i, (function (t) { var n = t.get("boxWidth"); Y(n) || (n = [n, n]), s.push([Er(n[0], e) || 0, Er(n[1], e) || 0]) } )); var h = .8 * e - 2 , c = h / r * .3 , p = (h - c * (r - 1)) / r , d = p / 2 - h / 2; YL(i, (function (t, e) { a.push(d), d += c + p, o.push(Math.min(Math.max(p, s[e][0]), s[e][1])) } )) }(t), YL(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 XL = { type: "echarts:boxplot", transform: function (t) { var e = t.upstream; if (e.sourceFormat !== Lp) { var n = ""; 0, ao(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 = Vr(t[a].slice()) , l = Jr(s, .25) , u = Jr(s, .5) , h = Jr(s, .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 = U(y) ? y({ value: a }) : X(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 ZL = ["color", "borderColor"] , 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.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) { zh(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 && JL(s, a)) return; var l = $L(a, n, !0); rh(l, { shape: { points: a.ends } }, t, n), QL(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 && JL(s, h) ? i.remove(u) : (u ? (ih(u, { shape: { points: h.ends } }, t, a), uh(u)) : u = $L(h), QL(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(), iP(t, this.group); var e = t.get("clip", !0) ? aS(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 = $L(i.getItemLayout(n)); QL(o, i, n, r), o.incremental = !0, this.group.add(o), this._progressiveEls.push(o) } } , e.prototype._incrementalRenderLarge = function (t, e) { iP(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 }(mg) , qL = function () { } , KL = 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 qL } , 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 }(fs); function $L(t, e, n) { var i = t.ends; return new KL({ shape: { points: n ? tP(i, t) : i }, z2: 100 }) } function JL(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 QL(t, e, n, i) { var r = e.getItemModel(n); t.useStyle(e.getItemVisual(n, "style")), t.style.strokeNoScale = !0, t.__simpleBox = i, zl(t, r) } function tP(t, e) { return z(t, (function (t) { return (t = t.slice())[1] = e.initBaseline, t } )) } var eP = function () { } , nP = 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 eP } , 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 }(fs); function iP(t, e, n, i) { var r = t.getData().getLayout("largePoints") , o = new nP({ shape: { points: r }, __sign: 1 }); e.add(o); var a = new nP({ shape: { points: r }, __sign: -1 }); e.add(a), rP(1, o, t), rP(-1, a, t), i && (o.incremental = !0, a.incremental = !0), n && n.push(o, a) } function rP(t, e, n, i) { var r = n.get(["itemStyle", t > 0 ? "borderColor" : "borderColor0"]) || n.get(["itemStyle", t > 0 ? "color" : "color0"]) , o = n.getModel("itemStyle").getItemStyle(ZL); e.useStyle(o), e.style.fill = null, e.style.stroke = r } var oP = 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", borderWidth: 1 }, emphasis: { scale: !0, itemStyle: { borderWidth: 2 } }, barMaxWidth: null, barMinWidth: null, barWidth: null, large: !0, largeThreshold: 600, progressive: 3e3, progressiveThreshold: 1e4, progressiveChunkMode: "mod", animationEasing: "linear", animationDuration: 300 }, e }(ag); function aP(t) { t && Y(t.series) && E(t.series, (function (t) { q(t) && "k" === t.type && (t.type = "candlestick") } )) } R(oP, NL, !0); var sP = ["itemStyle", "borderColor"] , lP = ["itemStyle", "borderColor0"] , uP = ["itemStyle", "color"] , hP = ["itemStyle", "color0"] , cP = { seriesType: "candlestick", plan: gg(), performRawSeries: !0, reset: function (t, e) { function n(t, e) { return e.get(t > 0 ? uP : hP) } function i(t, e) { return e.get(t > 0 ? sP : lP) } if (!e.isSeriesFiltered(t)) return !t.pipelineContext.large && { progress: function (t, e) { for (var r; null != (r = t.next());) { var o = e.getItemModel(r) , a = e.getItemLayout(r).sign , s = o.getItemStyle(); s.fill = n(a, o), s.stroke = i(a, o) || s.fill, A(e.ensureUniqueItemVisual(r, "style"), s) } } } } } , pP = { seriesType: "candlestick", plan: gg(), 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 = Er(rt(t.get("barMaxWidth"), r), r), a = Er(rt(t.get("barMinWidth"), 1), r), s = t.get("barWidth"); return null != s ? Er(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 (t, n) { var i, r, a = _x(4 * t.count), c = 0, p = [], d = [], f = n.getStore(); for (; null != (r = t.next());) { var g = f.get(o, r) , y = f.get(s, r) , v = f.get(l, r) , m = f.get(u, r) , x = f.get(h, r); isNaN(g) || isNaN(m) || isNaN(x) ? (a[c++] = NaN, c += 3) : (a[c++] = dP(f, r, y, v, l), p[0] = g, p[1] = m, i = e.dataToPoint(p, null, d), a[c++] = i ? i[0] : NaN, a[c++] = i ? i[1] : NaN, p[1] = x, i = e.dataToPoint(p, null, d), a[c++] = i ? i[1] : NaN) } n.setLayout("largePoints", a) } : 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 = S(y, c) , x = S(v, c) , _ = S(f, c) , b = S(g, c) , w = []; M(w, x, 0), M(w, m, 1), w.push(T(b), T(x), T(_), T(m)), n.setItemLayout(r, { sign: dP(a, r, p, d, l), initBaseline: p > d ? x[1] : m[1], ends: w, brushRect: I(f, g, c) }) } function S(t, n) { var i = []; return i[0] = n, i[1] = t, isNaN(n) || isNaN(t) ? [NaN, NaN] : e.dataToPoint(i) } function M(t, e, n) { var r = e.slice() , o = e.slice(); r[0] = Sh(r[0] + i / 2, 1, !1), o[0] = Sh(o[0] - i / 2, 1, !0), n ? t.push(r, o) : t.push(o, r) } function I(t, e, n) { var r = S(t, n) , o = S(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 T(t) { return t[0] = Sh(t[0], 1), t } } } } }; function dP(t, e, n, i, r) { return n > i ? -1 : n < i ? 1 : e > 0 ? t.get(r, e - 1) <= i ? 1 : -1 : 1 } function fP(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 gP = function (t) { function e(e, n) { var i = t.call(this) || this , r = new Ww(e, n) , o = new Cr; 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 = ky(e, -1, -1, 2, 2, n); a.attr({ style: { strokeNoScale: !0 }, z2: 99, silent: !0, scaleX: .5, scaleY: .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) } fP(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) } fP(n, t) } , e.prototype.highlight = function () { xl(this) } , e.prototype.downplay = function () { _l(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 = Ly(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 = Py(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, Ol(this, h.get("focus"), h.get("blurScope"), h.get("disabled")) } , e.prototype.fadeOut = function (t) { t && t() } , e }(Cr) , yP = 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 Zw(gP) } , 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 = Fi(e.getRoamTransform()), this.group.decomposeTransform()) } , e.prototype.remove = function (t, e) { this._symbolDraw && this._symbolDraw.remove(!0) } , e.type = "effectScatter", e }(mg) , vP = 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 nx(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 }(ag); var mP = 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 pA(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 = ky(r, -.5, -.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 = this , o = t.getItemLayout(n) , a = 1e3 * e.get("period") , s = e.get("loop") , l = e.get("constantSpeed") , u = it(e.get("delay"), (function (e) { return e / t.count() * a / 3 } )); if (i.ignore = !0, this._updateAnimationPoints(i, o), l > 0 && (a = this._getLineLength(i) / l * 1e3), (a !== this._period || s !== this._loop) && (i.stopAnimation(), a > 0)) { var h = void 0; h = U(u) ? u(n) : u, i.__t > 0 && (h = -a * i.__t), i.__t = 0; var c = i.animate("", s).when(a, { __t: 1 }).delay(h).during((function () { r._updateSymbolPosition(i) } )); s || c.done((function () { r.remove(i) } )), c.start() } this._period = a, this._loop = s } } , e.prototype._getLineLength = function (t) { return Et(t.__p1, t.__cp1) + Et(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 , o = [t.x, t.y] , a = o.slice() , s = Ke , l = $e; o[0] = s(e[0], i[0], n[0], r), o[1] = s(e[1], i[1], n[1], r); var u = l(e[0], i[0], n[0], r) , h = l(e[1], i[1], n[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 * Et(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 * Et(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 }(Cr) , xP = 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 Ou({ shape: { points: i } }); this.add(r), this._updateCommonStl(t, e, n) } , e.prototype.updateData = function (t, e, n) { var i = t.hostModel; ih(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, Ol(this, a, s, l) } , e.prototype.updateLayout = function (t, e) { this.childAt(0).setShape("points", t.getItemLayout(e)) } , e }(Cr) , _P = 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 xP(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 += Et(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 , 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 = u[0] - l[0] , c = u[1] - l[1]; t.rotation = -Math.atan2(c, h) - Math.PI / 2, this._lastFrame = o, this._lastFramePercent = e, t.ignore = !1 } } , e }(mP) , bP = function () { this.polyline = !1, this.curveness = 0, this.segs = [] } , wP = 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 bP } , 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 (qa(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 ($a(u, h, (u + p) / 2 - (h - d) * r, (h + d) / 2 - (p - u) * r, p, d, o, t, e)) return a } else if (qa(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 sr(n, i, r, o) } return t } , e }(fs) , SP = function () { function t() { this.group = new Cr } 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 wP({ cursor: "default" }); 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 = Ws(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 }() , MP = { seriesType: "lines", plan: gg(), 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) } } } } } } , IP = 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 + .9, 1), 0) })), r.updateData(i); var u = t.get("clip", !0) && aS(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 = MP.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 SP : new dA(r ? i ? _P : xP : i ? mP : pA), 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 }(mg) , TP = "undefined" == typeof Uint32Array ? Array : Uint32Array , CP = "undefined" == typeof Float64Array ? Array : Float64Array; function DP(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 AP = 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 || [], DP(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 (DP(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 = gt(this._flatCoords, e.flatCoords), this._flatCoordsOffset = gt(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 TP(n), r = new CP(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 Zm(["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), Uf("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: .2 }, large: !1, largeThreshold: 2e3, polyline: !1, clip: !0, label: { show: !1, position: "end" }, lineStyle: { opacity: .5 } }, e }(ag); function kP(t) { return t instanceof Array || (t = [t, t]), t } var LP = { seriesType: "lines", reset: function (t) { var e = kP(t.get("symbol")) , n = kP(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 = kP(n.getShallow("symbol", !0)) , r = kP(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 PP = 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 OP(t) { var e = t.dimensions; return "lng" === e[0] && "lat" === e[1] } var RP = 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()) : OP(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 && (OP(r) ? this.render(e, n, i) : (this._progressiveEls = [], this._renderOnCartesianAndCalendar(e, i, t.start, t.end, !0))) } , e.prototype.eachRendered = function (t) { zh(this._progressiveEls || this.group, t) } , e.prototype._renderOnCartesianAndCalendar = function (t, e, n, i, r) { var o, a, s, l, u = t.coordinateSystem; if (sS(u, "cartesian2d")) { var h = u.getAxis("x") , c = u.getAxis("y"); 0, o = h.getBandWidth(), a = c.getBandWidth(), s = h.scale.getExtent(), l = c.scale.getExtent() } for (var p = this.group, d = t.getData(), f = t.getModel(["emphasis", "itemStyle"]).getItemStyle(), g = t.getModel(["blur", "itemStyle"]).getItemStyle(), y = t.getModel(["select", "itemStyle"]).getItemStyle(), v = Hh(t), m = t.getModel("emphasis"), x = m.get("focus"), _ = m.get("blurScope"), b = m.get("disabled"), w = sS(u, "cartesian2d") ? [d.mapDimension("x"), d.mapDimension("y"), d.mapDimension("value")] : [d.mapDimension("time"), d.mapDimension("value")], S = n; S < i; S++) { var M = void 0 , I = d.getItemVisual(S, "style"); if (sS(u, "cartesian2d")) { var T = d.get(w[0], S) , C = d.get(w[1], S); if (isNaN(d.get(w[2], S)) || T < s[0] || T > s[1] || C < l[0] || C > l[1]) continue; var D = u.dataToPoint([T, C]); M = new Ts({ shape: { x: Math.floor(Math.round(D[0]) - o / 2), y: Math.floor(Math.round(D[1]) - a / 2), width: Math.ceil(o), height: Math.ceil(a) }, style: I }) } else { if (isNaN(d.get(w[1], S))) continue; M = new Ts({ z2: 1, shape: u.dataToRect([d.get(w[0], S)]).contentShape, style: I }) } var A = d.getItemModel(S); if (d.hasItemOption) { var k = A.getModel("emphasis"); f = k.getModel("itemStyle").getItemStyle(), g = A.getModel(["blur", "itemStyle"]).getItemStyle(), y = A.getModel(["select", "itemStyle"]).getItemStyle(), x = k.get("focus"), _ = k.get("blurScope"), b = k.get("disabled"), v = Hh(A) } var L = t.getRawValue(S) , P = "-"; L && null != L[2] && (P = L[2] + ""), Wh(M, v, { labelFetcher: t, labelDataIndex: S, defaultOpacity: I.opacity, defaultText: P }), M.ensureState("emphasis").style = f, M.ensureState("blur").style = g, M.ensureState("select").style = y, Ol(M, x, _, b), M.incremental = r, r && (M.states.emphasis.hoverLayer = !0), p.add(M), d.setItemGraphicEl(S, M), this._progressiveEls && this._progressiveEls.push(M) } } , 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 PP; 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 xs({ style: { width: f, height: g, x: h, y: c, image: s.canvas }, silent: !0 }); this.group.add(_) } , e.type = "heatmap", e }(mg) , NP = 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 nx(null, this, { generateCoord: "value" }) } , e.prototype.preventIncremental = function () { var t = ud.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 }(ag); var EP = ["itemStyle", "borderWidth"] , zP = [{ xy: "x", wh: "width", index: 0, posDesc: ["left", "right"] }, { xy: "y", wh: "height", index: 1, posDesc: ["top", "bottom"] }] , VP = new uu , BP = 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: zP[+s], categoryDim: zP[1 - +s] }; return r.diff(o).add((function (t) { if (r.hasValue(t)) { var e = ZP(r, t) , n = FP(r, t, e, u) , o = KP(r, u, n); r.setItemGraphicEl(t, o), i.add(o), eO(o, u, n) } } )).update((function (t, e) { var n = o.getItemGraphicEl(e); if (r.hasValue(t)) { var a = ZP(r, t) , s = FP(r, t, a, u) , l = JP(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; ih(t.__pictorialBundle, { x: n.bundlePosition[0], y: n.bundlePosition[1] }, i, r), n.symbolRepeat ? HP(t, e, n, !0) : YP(t, e, n, !0); UP(t, n, !0), XP(t, e, n, !0) }(n, u, s) : n = KP(r, u, s, !0), r.setItemGraphicEl(t, n), n.__pictorialSymbolMeta = s, i.add(n), eO(n, u, s) } else i.remove(n) } )).remove((function (t) { var e = o.getItemGraphicEl(t); e && $P(o, t, e.__pictorialSymbolMeta.animationModel, e) } )).execute(), 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) { $P(i, Ws(e).dataIndex, t, e) } )) : n.removeAll() } , e.type = "pictorialBar", e }(mg); function FP(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 = [GP(l, s[0]) - u, GP(l, s[1]) - u]; c[1] < c[0] && c.reverse(), o = c[h] } else o = null != s ? GP(l, s) - u : e ? i.coordSysExtent[a.index][h] - u : n[a.wh]; r.boundingLength = o, e && (r.repeatCutLength = n[a.wh]); r.pxSign = 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] = Er(h[p.index], d), h[c.index] = Er(h[c.index], i ? d : Math.abs(o)), u.symbolSize = h, (u.symbolScale = [h[0] / s, h[1] / s])[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(EP) || 0; o && (VP.attr({ scaleX: e[0], scaleY: e[1], rotation: n }), VP.updateTransform(), o /= VP.getLineScale(), o *= e[i.valueDim.index]); r.valueLineWidth = o }(n, c.symbolScale, l, i, c); var p = c.symbolSize , d = Py(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 _ = Er(m, e[d.index]) , b = Math.max(g + 2 * _, 0) , w = x ? 0 : 2 * _ , S = eo(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 GP(t, e) { return t.toGlobalCoord(t.dataToCoord(t.scale.parse(e))) } function WP(t) { var e = t.symbolPatternSize , n = ky(t.symbolType, -e / 2, -e / 2, e, e); return n.attr({ culling: !0 }), "image" !== n.type && n.setStyle({ strokeNoScale: !0 }), n } function HP(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 (QP(t, (function (t) { t.__pictorialAnimationIndex = h, t.__pictorialRepeatTimes = u, h < u ? tO(t, null, f(h), n, i) : tO(t, null, { scaleX: 0, scaleY: 0 }, n, i, (function () { r.remove(t) } )), h++ } )); h < u; h++) { var p = WP(n); p.__pictorialAnimationIndex = h, p.__pictorialRepeatTimes = u, r.add(p); var d = f(h); tO(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 + .5) + s[l.index], { x: e[0], y: e[1], scaleX: n.symbolScale[0], scaleY: n.symbolScale[1], rotation: n.rotation } } } function YP(t, e, n, i) { var r = t.__pictorialBundle , o = t.__pictorialMainPath; o ? tO(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 = WP(n), r.add(o), tO(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 UP(t, e, n) { var i = A({}, e.barRectShape) , r = t.__pictorialBarRect; r ? tO(r, null, { shape: i }, e, n) : ((r = t.__pictorialBarRect = new Ts({ z2: 2, shape: i, silent: !0, style: { stroke: "transparent", fill: "transparent", lineWidth: 0 } })).disableMorphing = !0, t.add(r)) } function XP(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) ih(r, { shape: o }, s, l); else { o[a.wh] = 0, r = new Ts({ shape: o }), t.__pictorialBundle.setClipPath(r), t.__pictorialClipPath = r; var u = {}; u[a.wh] = n.clipShape[a.wh], Vh[i ? "updateProps" : "initProps"](r, { shape: u }, s, l) } } } function ZP(t, e) { var n = t.getItemModel(e); return n.getAnimationDelayParams = jP, n.isAnimationEnabled = qP, n } function jP(t) { return { index: t.__pictorialAnimationIndex, count: t.__pictorialRepeatTimes } } function qP() { return this.parentModel.isAnimationEnabled() && !!this.getShallow("animation") } function KP(t, e, n, i) { var r = new Cr , o = new Cr; return r.add(o), r.__pictorialBundle = o, o.x = n.bundlePosition[0], o.y = n.bundlePosition[1], n.symbolRepeat ? HP(r, e, n) : YP(r, 0, n), UP(r, n, i), XP(r, e, n, i), r.__pictorialShapeStr = JP(t, n), r.__pictorialSymbolMeta = n, r } function $P(t, e, n, i) { var r = i.__pictorialBarRect; r && r.removeTextContent(); var o = []; QP(i, (function (t) { o.push(t) } )), i.__pictorialMainPath && o.push(i.__pictorialMainPath), i.__pictorialClipPath && (n = null), E(o, (function (t) { ah(t, { scaleX: 0, scaleY: 0 }, n, e, (function () { i.parent && i.parent.remove(i) } )) } )), t.setItemGraphicEl(e, null) } function JP(t, e) { return [t.getItemVisual(e.dataIndex, "symbol") || "none", !!e.symbolRepeat, !!e.symbolClip].join(":") } function QP(t, e, n) { E(t.__pictorialBundle.children(), (function (i) { i !== t.__pictorialBarRect && e.call(n, i) } )) } function tO(t, e, n, i, r, o) { e && t.attr(e), i.symbolClip && !r ? n && t.attr(n) : n && Vh[r ? "updateProps" : "initProps"](t, n, i.animationModel, i.dataIndex, o) } function eO(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"); QP(t, (function (t) { if (t instanceof xs) { 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)]; Wh(t.__pictorialBarRect, Hh(r), { labelFetcher: e.seriesModel, labelDataIndex: i, defaultText: Fw(e.seriesModel.getData(), i), inheritColor: n.style.fill, defaultOpacity: n.style.opacity, defaultOutsidePosition: d }), Ol(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 iO = 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 = gc(SS.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%", progressive: 0, emphasis: { scale: !1 }, select: { itemStyle: { borderColor: "#212121" } } }), e }(SS); var rO = 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 Sm(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 Cr; h = new iS({ shape: { points: c, stackedOnPoints: d, smooth: .4, stackedOnSmooth: .4, smoothConstraint: !1 }, z2: 0 }), S.add(h), o.add(S), t.isAnimationEnabled() && h.setClipPath(function (t, e, n) { var i = new Ts({ shape: { x: t.x - 10, y: t.y - 10, width: 0, height: t.height + 20 } }); return rh(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, ih(h, { shape: { points: c, stackedOnPoints: d } }, t), uh(h) } Wh(h, Hh(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), zl(h, t), Ol(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 }(mg); var oO = 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 lM(W(this.getData, this), W(this.getRawData, this)) } , e.prototype.fixData = function (t) { var e = t.length , n = {} , i = Lo(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", Co).models[0].get("type"), i = B(t.data, (function (t) { return void 0 !== t[2] } )), r = this.fixData(i || []), o = [], a = this.nameMap = ft(), 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 = jm(r, { coordDimensions: ["single"], dimensionsDefine: [{ name: "time", type: Tm(n) }, { name: "value", type: "float" }, { name: "name", type: "ordinal" }], encodeDefine: { single: 0, value: 1, itemName: 2 } }).dimensions , h = new Zm(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 = Lo(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 Uf("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 }(ag); function aO(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] = Er(o[0], r.height), o[1] = Er(o[1], r.height), sO(e, t, r.height - o[0] - o[1])) : (o[0] = Er(o[0], r.width), o[1] = Er(o[1], r.width), sO(e, t, r.width - o[0] - o[1])); e.setLayout("layoutInfo", i) } )) } function sO(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 lO = function (t) { function e(e, n, i, r) { var o = t.call(this) || this; o.z2 = 2, o.textConfig = { inside: !0 }, Ws(o).seriesIndex = n.seriesIndex; var a = new As({ 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; Ws(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 = nv(c, r)); var p = rM(a.getModel("itemStyle"), u, !0); A(u, p), E(js, (function (t) { var e = o.ensureState(t) , n = a.getModel([t, "itemStyle"]); e.style = n.getItemStyle(); var i = rM(n, u); i && (e.shape = i) } )), t ? (o.setShape(u), o.shape.r = l.r0, ih(o, { shape: { r: l.r } }, n, e.dataIndex)) : (ih(o, { shape: u }, n), uh(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"); Ol(this, "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(qs, (function (i) { var o = "normal" === i ? n.getModel("label") : n.getModel([i, "label"]) , p = "normal" === i , d = p ? h : h.ensureState(i) , g = t.getFormattedLabel(c, i); p && (g = g || e.node.name), d.style = Yh(o, {}, null, "normal" !== i, !0), g && (d.style.text = g); var y = o.get("show"); null == y || p || (d.ignore = !y); var v, m = f(o, "position"), x = p ? u : u.states[i], _ = x.style.fill; x.textConfig = { outsideFill: "inherit" === o.get("color") ? _ : null, inside: "outside" !== m }; var b = f(o, "distance") || 0 , w = f(o, "align"); "outside" === m ? (v = r.r + b, w = a > Math.PI / 2 ? "right" : "left") : w && "center" !== w ? "left" === w ? (v = r.r0 + b, a > Math.PI / 2 && (w = "right")) : "right" === w && (v = r.r - b, a > Math.PI / 2 && (w = "left")) : (v = (r.r + r.r0) / 2, w = "center"), d.style.align = w, d.style.verticalAlign = f(o, "verticalAlign") || "middle", d.x = v * s + r.cx, d.y = v * l + r.cy; var S = f(o, "rotate") , M = 0; "radial" === S ? (M = -a) < -Math.PI / 2 && (M += Math.PI) : "tangential" === S ? (M = Math.PI / 2 - a) > Math.PI / 2 ? M -= Math.PI : M < -Math.PI / 2 && (M += Math.PI) : j(S) && (M = S * Math.PI / 180), d.rotation = M } )), h.dirtyStyle() } , e }(Tu) , uO = "sunburstRootToNode" , hO = "sunburstHighlight"; var cO = 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 lO(i, t, e, n); l.add(s), o.setItemGraphicEl(i.dataIndex, s) } }(null == s ? null : i[s], null == h ? null : r[h]) } new Sm(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 lO(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) pp(a, o.get("target", !0) || "_blank") } n = !0 } } )) } )) } , e.prototype._rootToNode = function (t) { t !== this.seriesModel.getViewRoot() && this.api.dispatchAction({ type: uO, 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 }(mg) , pO = 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 }; dO(n); var i = this._levelModels = z(t.levels || [], (function (t) { return new pc(t, this, e) } ), this) , r = CC.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 = LC(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 () { zC(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: .2 }, label: { opacity: .1 } }, animationType: "expansion", animationDuration: 1e3, animationDurationUpdate: 500, data: [], sort: "desc" }, e }(ag); function dO(t) { var e = 0; E(t.children, (function (t) { dO(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 fO = Math.PI / 180; function gO(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 = Er(e[0], r) , l = Er(e[1], o) , u = Er(i[0], a / 2) , h = Er(i[1], a / 2) , c = -t.get("startAngle") * fO , p = t.get("minAngle") * fO , d = t.getData().tree.root , f = t.getViewRoot() , g = f.depth , y = t.get("sort"); null != y && yO(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 = Er(v, a / 2)), null != b && (f = Er(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 yO(t, e) { var n = t.children || []; t.children = function (t, e) { if (U(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) { yO(t, e) } )) } function vO(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 && X(o) && (o = Sn(o, (t.depth - 1) / (i - 1) * .5)), o }(r, t, i.root.height)), A(n.ensureUniqueItemVisual(r.dataIndex, "style"), o) } )) } )) } var mO = { color: "fill", borderColor: "stroke" } , xO = { symbol: 1, symbolSize: 1, symbolKeepAspect: 1, legendIcon: 1, visualMeta: 1, liftZ: 1, decal: 1 } , _O = So() , bO = 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 nx(null, this) } , e.prototype.getDataParams = function (e, n, i) { var r = t.prototype.getDataParams.call(this, e, n); return i && (r.info = _O(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 }(ag); function wO(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 SO(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 MO(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 IO(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 TO(t, e, n, i) { return t && (t.legacy || !1 !== t.legacy && !n && !i && "tspan" !== e && ("text" === e || mt(t, "text"))) } function CO(t, e, n) { var i, r, o, a = t; if ("text" === e) o = a; else { o = {}, mt(a, "text") && (o.text = a.text), mt(a, "rich") && (o.rich = a.rich), mt(a, "textFill") && (o.fill = a.textFill), mt(a, "textStroke") && (o.stroke = a.textStroke), mt(a, "fontFamily") && (o.fontFamily = a.fontFamily), mt(a, "fontSize") && (o.fontSize = a.fontSize), mt(a, "fontStyle") && (o.fontStyle = a.fontStyle), mt(a, "fontWeight") && (o.fontWeight = a.fontWeight), r = { type: "text", style: o, silent: !0 }, i = {}; var s = mt(a, "textPosition"); n ? i.position = s ? a.textPosition : "inside" : s && (i.position = a.textPosition), mt(a, "textPosition") && (i.position = a.textPosition), mt(a, "textOffset") && (i.offset = a.textOffset), mt(a, "textRotation") && (i.rotation = a.textRotation), mt(a, "textDistance") && (i.distance = a.textDistance) } return DO(o, t), E(o.rich, (function (t) { DO(t, t) } )), { textConfig: i, textContent: r } } function DO(t, e) { e && (e.font = e.textFont || e.font, mt(e, "textStrokeWidth") && (t.lineWidth = e.textStrokeWidth), mt(e, "textAlign") && (t.align = e.textAlign), mt(e, "textVerticalAlign") && (t.verticalAlign = e.textVerticalAlign), mt(e, "textLineHeight") && (t.lineHeight = e.textLineHeight), mt(e, "textWidth") && (t.width = e.textWidth), mt(e, "textHeight") && (t.height = e.textHeight), mt(e, "textBackgroundColor") && (t.backgroundColor = e.textBackgroundColor), mt(e, "textPadding") && (t.padding = e.textPadding), mt(e, "textBorderColor") && (t.borderColor = e.textBorderColor), mt(e, "textBorderWidth") && (t.borderWidth = e.textBorderWidth), mt(e, "textBorderRadius") && (t.borderRadius = e.textBorderRadius), mt(e, "textBoxShadowColor") && (t.shadowColor = e.textBoxShadowColor), mt(e, "textBoxShadowBlur") && (t.shadowBlur = e.textBoxShadowBlur), mt(e, "textBoxShadowOffsetX") && (t.shadowOffsetX = e.textBoxShadowOffsetX), mt(e, "textBoxShadowOffsetY") && (t.shadowOffsetY = e.textBoxShadowOffsetY)) } function AO(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"; kO(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) { kO(t, t) } )), i } function kO(t, e) { e && (mt(e, "fill") && (t.textFill = e.fill), mt(e, "stroke") && (t.textStroke = e.fill), mt(e, "lineWidth") && (t.textStrokeWidth = e.lineWidth), mt(e, "font") && (t.font = e.font), mt(e, "fontStyle") && (t.fontStyle = e.fontStyle), mt(e, "fontWeight") && (t.fontWeight = e.fontWeight), mt(e, "fontSize") && (t.fontSize = e.fontSize), mt(e, "fontFamily") && (t.fontFamily = e.fontFamily), mt(e, "align") && (t.textAlign = e.align), mt(e, "verticalAlign") && (t.textVerticalAlign = e.verticalAlign), mt(e, "lineHeight") && (t.textLineHeight = e.lineHeight), mt(e, "width") && (t.textWidth = e.width), mt(e, "height") && (t.textHeight = e.height), mt(e, "backgroundColor") && (t.textBackgroundColor = e.backgroundColor), mt(e, "padding") && (t.textPadding = e.padding), mt(e, "borderColor") && (t.textBorderColor = e.borderColor), mt(e, "borderWidth") && (t.textBorderWidth = e.borderWidth), mt(e, "borderRadius") && (t.textBorderRadius = e.borderRadius), mt(e, "shadowColor") && (t.textBoxShadowColor = e.shadowColor), mt(e, "shadowBlur") && (t.textBoxShadowBlur = e.shadowBlur), mt(e, "shadowOffsetX") && (t.textBoxShadowOffsetX = e.shadowOffsetX), mt(e, "shadowOffsetY") && (t.textBoxShadowOffsetY = e.shadowOffsetY), mt(e, "textShadowColor") && (t.textShadowColor = e.textShadowColor), mt(e, "textShadowBlur") && (t.textShadowBlur = e.textShadowBlur), mt(e, "textShadowOffsetX") && (t.textShadowOffsetX = e.textShadowOffsetX), mt(e, "textShadowOffsetY") && (t.textShadowOffsetY = e.textShadowOffsetY)) } var LO = { position: ["x", "y"], scale: ["scaleX", "scaleY"], origin: ["originX", "originY"] } , PO = G(LO) , OO = (V(Ki, (function (t, e) { return t[e] = 1, t } ), {}), Ki.join(", "), ["", "style", "shape", "extra"]) , RO = So(); function NO(t, e, n, i, r) { var o = t + "Animation" , a = eh(t, i, r) || {} , s = RO(e).userDuring; return a.duration > 0 && (a.during = s ? W(WO, { el: e, userDuring: s }) : null, a.setToFinal = !0, a.scope = t), A(a, n[o]), a } function EO(t, e, n, i) { var r = (i = i || {}).dataIndex , o = i.isInit , a = i.clearStyle , s = n.isAnimationEnabled() , l = RO(t) , u = e.style; l.userDuring = e.during; var h = {} , c = {}; if (function (t, e, n) { for (var i = 0; i < PO.length; i++) { var r = PO[i] , o = LO[r] , a = e[r]; a && (n[o[0]] = a[0], n[o[1]] = a[1]) } for (i = 0; i < Ki.length; i++) { var s = Ki[i]; null != e[s] && (n[s] = e[s]) } }(0, e, c), YO("shape", e, c), YO("extra", e, c), !o && s && (function (t, e, n) { for (var i = e.transition, r = BO(i) ? Ki : ho(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), HO("shape", t, e, h), HO("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 && !BO(a)) { var l = ho(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 && (BO(s) || BO(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) { mt(e, "silent") && (t.silent = e.silent), mt(e, "ignore") && (t.ignore = e.ignore), t instanceof da && mt(e, "invisible") && (t.invisible = e.invisible); t instanceof fs && mt(e, "autoBatch") && (t.autoBatch = e.autoBatch) }(t, e), s) if (o) { var p = {}; E(OO, (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 = NO("enter", t, e, n, r); d.duration > 0 && t.animateFrom(p, d) } else !function (t, e, n, i, r) { if (r) { var o = NO("update", t, e, i, n); o.duration > 0 && t.animateFrom(r, o) } }(t, e, r || 0, n, h); zO(t, e), u ? t.dirty() : t.markRedraw() } function zO(t, e) { for (var n = RO(t).leaveToProps, i = 0; i < OO.length; i++) { var r = OO[i] , o = r ? e[r] : e; o && o.leaveTo && (n || (n = RO(t).leaveToProps = {}), r && (n[r] = n[r] || {}), A(r ? n[r] : n, o.leaveTo)) } } function VO(t, e, n, i) { if (t) { var r = t.parent , o = RO(t).leaveToProps; if (o) { var a = NO("update", t, e, n, 0); a.done = function () { r.remove(t), i && i() } , t.animateTo(o, a) } else r.remove(t), i && i() } } function BO(t) { return "all" === t } var FO = {} , GO = { setTransform: function (t, e) { return FO.el[t] = e, this }, getTransform: function (t) { return FO.el[t] }, setShape: function (t, e) { var n = FO.el; return (n.shape || (n.shape = {}))[t] = e, n.dirtyShape && n.dirtyShape(), this }, getShape: function (t) { var e = FO.el.shape; if (e) return e[t] }, setStyle: function (t, e) { var n = FO.el , i = n.style; return i && (i[t] = e, n.dirtyStyle && n.dirtyStyle()), this }, getStyle: function (t) { var e = FO.el.style; if (e) return e[t] }, setExtra: function (t, e) { return (FO.el.extra || (FO.el.extra = {}))[t] = e, this }, getExtra: function (t) { var e = FO.el.extra; if (e) return e[t] } }; function WO() { var t = this , e = t.el; if (e) { var n = RO(e).userDuring , i = t.userDuring; n === i ? (FO.el = e, i(GO)) : t.el = t.userDuring = null } } function HO(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] = {}), BO(l)) A(o, a); else for (var u = ho(l), h = 0; h < u.length; h++) { var c = a[d = u[h]]; o[d] = c } else if (BO(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]]; UO(r[d], c) && (o[d] = c) } } } } } function YO(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] = ti(i[s]) } } function UO(t, e) { return N(t) ? t !== e : null != t && isFinite(t) } var XO = So() , ZO = ["percent", "easing", "shape", "style", "extra"]; function jO(t) { t.stopAnimation("keyframe"), t.attr(XO(t)) } function qO(t, e, n) { if (n.isAnimationEnabled() && e) if (Y(e)) E(e, (function (e) { qO(t, e, n) } )); else { var i = e.keyframes , r = e.duration; if (n && null == r) { var o = eh("enter", n, 0); r = o && o.duration } if (i && r) { var a = XO(t); E(OO, (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(ZO, 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 KO = "emphasis" , $O = "normal" , JO = "blur" , QO = "select" , tR = [$O, KO, JO, QO] , eR = { normal: ["itemStyle"], emphasis: [KO, "itemStyle"], blur: [JO, "itemStyle"], select: [QO, "itemStyle"] } , nR = { normal: ["label"], emphasis: [KO, "label"], blur: [JO, "label"], select: [QO, "label"] } , iR = ["x", "y"] , rR = { normal: {}, emphasis: {}, blur: {}, select: {} } , oR = { 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(wO, 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(SO, t) } } }, singleAxis: 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(MO, 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(IO, 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 aR(t) { return t instanceof fs } function sR(t) { return t instanceof da } var lR = 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 = dR(t, o, e, n); r || a.removeAll(), o.diff(r).add((function (e) { gR(n, null, e, s(e, i), t, a, o) } )).remove((function (e) { var n = r.getItemGraphicEl(e); VO(n, _O(n).option, t) } )).update((function (e, l) { var u = r.getItemGraphicEl(l); gR(n, u, e, s(e, i), t, a, o) } )).execute(); var l = t.get("clip", !0) ? aS(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 = dR(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 = gR(null, null, u, a(u, r), e, this.group, o); h && (h.traverse(l), s.push(h)) } } , e.prototype.eachRendered = function (t) { zh(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 }(mg); function uR(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 = MR(i); e = mh(o, null, r, i.layout || "center"), _O(e).customPathData = o } else if ("image" === n) e = new xs({}), _O(e).customImagePath = t.style.image; else if ("text" === n) e = new As({}); else if ("group" === n) e = new Cr; else { if ("compoundPath" === n) throw new Error('"compoundPath" is not supported yet.'); var a = vh(n); if (!a) { var s = ""; 0, ao(s) } e = new a } return _O(e).customGraphicType = n, e.name = t.name, e.z2EmphasisLift = 1, e.z2SelectLift = 1, e } function hR(t, e, n, i, r, o, a) { jO(e); var s = r && r.normal.cfg; s && e.setTextConfig(s), i && null == i.transition && (i.transition = iR); var l = i && i.style; if (l) { if ("text" === e.type) { var u = l; mt(u, "textFill") && (u.fill = u.textFill), mt(u, "textStroke") && (u.stroke = u.textStroke) } var h = void 0 , c = aR(e) ? l.decal : null; t && c && (c.dirty = !0, h = nv(c, t)), l.__decalPattern = h } sR(e) && (l && (h = l.__decalPattern) && (l.decal = h)); EO(e, i, o, { dataIndex: n, isInit: a, clearStyle: !0 }), qO(e, i.keyframeAnimation, o) } function cR(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), yl(o) } } function pR(t, e, n) { var i = n === $O , r = i ? e : xR(e, n) , o = r ? r.z2 : null; null != o && ((i ? t : t.ensureState(n)).z2 = o || 0) } function dR(t, e, n, i) { var r = t.get("renderItem") , o = t.coordinateSystem , a = {}; o && (a = o.prepareCustoms ? o.prepareCustoms(o) : oR[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, $O).getItemStyle(); null != o && (l.fill = o), null != a && (l.opacity = a); var u = { inheritColor: X(o) ? o : "#000" } , h = x(i, $O) , c = Yh(h, null, u, !1, !0); c.text = h.getShallow("show") ? rt(t.getFormattedLabel(i, $O), Fw(e, i)) : null; var p = Uh(h, u, !1); return b(n, l), l = AO(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, KO).getItemStyle() , o = x(i, KO) , a = Yh(o, null, null, !0, !0); a.text = o.getShallow("show") ? ot(t.getFormattedLabel(i, KO), t.getFormattedLabel(i, $O), Fw(e, i)) : null; var l = Uh(o, null, !0); return b(n, r), r = AO(r, a, l), n && _(r, n), r.legacy = !0, r }, visual: function (t, n) { if (null == n && (n = s), mt(mO, t)) { var i = e.getItemVisual(n, "style"); return i ? i[mO[t]] : null } if (mt(xO, 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: bx + o }, t)); var a = Cx(e) , s = []; for (o = 0; o < t.count; o++) { var l = a.axis0[bx + 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 Kh(t, n) } }, a.api || {}), h = { context: {}, seriesId: t.id, seriesName: t.name, seriesIndex: t.seriesIndex, coordSys: a.coordSys, dataInsideLength: e.count(), encode: fR(t.getData()) }, c = {}, p = {}, d = {}, f = {}, g = 0; g < tR.length; g++) { var y = tR[g]; d[y] = t.getModel(eR[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(eR[n])) : v(t).getModel(eR[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) mt(e, n) && (t[n] = e[n]) } function b(t, e) { t && (t.textFill && (e.textFill = t.textFill), t.textPosition && (e.textPosition = t.textPosition)) } } function fR(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 gR(t, e, n, i, r, o, a) { if (i) { var s = yR(t, e, n, i, r, o); return s && a.setItemGraphicEl(n, s), s && Ol(s, i.focus, i.blurScope, i.emphasisDisabled), s } o.remove(e) } function yR(t, e, n, i, r, o) { var a = -1 , s = e; e && vR(e, i, r) && (a = P(o.childrenRef(), e), e = null); var l, u, h = !e, c = e; c ? c.clearStates() : (c = uR(i), s && (l = s, (u = c).copyTransform(l), sR(u) && sR(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, aR(u) && aR(l) && u.setShape(l.shape)))), !1 === i.morph ? c.disableMorphing = !0 : c.disableMorphing && (c.disableMorphing = !1), rR.normal.cfg = rR.normal.conOpt = rR.emphasis.cfg = rR.emphasis.conOpt = rR.blur.cfg = rR.blur.conOpt = rR.select.cfg = rR.select.conOpt = null, rR.isLegacy = !1, function (t, e, n, i, r, o) { if (t.isGroup) return; mR(n, null, o), mR(n, KO, 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 = uR(a), t.setTextContent(h)), hR(null, h, e, a, null, i, r); for (var c = a && a.style, p = 0; p < tR.length; p++) { var d = tR[p]; if (d !== $O) { var f = o[d].conOpt; cR(d, h, 0, _R(a, f, d), null) } } c ? h.dirty() : h.markRedraw() } } }(c, n, i, r, h, rR), 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 && vR(a, o, i) && (a = null), a || (a = uR(o), t.setClipPath(a)), hR(null, a, e, o, null, i, r) } }(c, n, i, r, h), hR(t, c, n, i, rR, r, h), mt(i, "info") && (_O(c).info = i.info); for (var p = 0; p < tR.length; p++) { var d = tR[p]; if (d !== $O) { var f = xR(i, d); cR(d, c, 0, _R(i, f, d), rR) } } 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 < tR.length; s++) pR(i, e, tR[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 Sm(h.oldChildren, h.newChildren, bR, bR, h).add(wR).update(wR).remove(SR).execute(); var h; u && e.removeAll(); for (var c = 0; c < a; c++) o[c] && yR(t, e.childAt(c), n, o[c], r, e); for (var p = e.childCount() - 1; p >= c; p--) { VO(e.childAt(p), _O(e).option, r) } }(t, c, n, i, r), a >= 0 ? o.replaceAt(c, a) : o.add(c), c } function vR(t, e, n) { var i, r = _O(t), o = e.type, a = e.shape, s = e.style; return n.isUniversalTransitionEnabled() || null != o && o !== r.customGraphicType || "path" === o && ((i = a) && (mt(i, "pathData") || mt(i, "d"))) && MR(a) !== r.customPathData || "image" === o && mt(s, "image") && s.image !== r.customImagePath } function mR(t, e, n) { var i = e ? xR(t, e) : t , r = e ? _R(t, i, KO) : t.style , o = t.type , a = i ? i.textConfig : null , s = t.textContent , l = s ? e ? xR(s, e) : s : null; if (r && (n.isLegacy || TO(r, o, !!a, !!l))) { n.isLegacy = !0; var u = CO(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 xR(t, e) { return e ? t ? t[e] : null : t } function _R(t, e, n) { var i = e && e.style; return null == i && n === KO && t && (i = t.styleEmphasis), i } function bR(t, e) { var n = t && t.name; return null != n ? n : "e\0\0" + e } function wR(t, e) { var n = this.context , i = null != t ? n.newChildren[t] : null , r = null != e ? n.oldChildren[e] : null; yR(n.api, r, n.dataIndex, i, n.seriesModel, n.group) } function SR(t) { var e = this.context , n = e.oldChildren[t]; VO(n, _O(n).option, e.seriesModel) } function MR(t) { return t && (t.pathData || t.d) } var IR = So() , TR = T , CR = W , DR = 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(AR, e, h); this.updatePointerEl(a, l, c), this.updateLabelEl(a, l, c, e) } else a = this._group = new Cr, this.createPointerEl(a, l, t, e), this.createLabelEl(a, l, t, e), n.getZr().add(a); OR(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 = jM(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 = IR(t).pointerEl = new Vh[r.type](TR(e.pointer)); t.add(o) } } , t.prototype.createLabelEl = function (t, e, n, i) { if (e.label) { var r = IR(t).labelEl = new As(TR(e.label)); t.add(r), LR(r, i) } } , t.prototype.updatePointerEl = function (t, e, n) { var i = IR(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 = IR(t).labelEl; r && (r.setStyle(e.label.style), n(r, { x: e.label.x, y: e.label.y }), LR(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 = Lh(o.get("icon"), { cursor: "move", draggable: !0, onmousemove: function (t) { se(t.event) }, onmousedown: CR(this._onHandleDragMove, this, 0, 0), drift: CR(this._onHandleDragMove, this), ondragend: CR(this._onHandleDragEnd, this) }), i.add(r)), OR(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, Dg(this, "_doDispatchAxisPointer", o.get("throttle") || 0, "fixRate"), this._moveHandleToValue(t, e) } } , t.prototype._moveHandleToValue = function (t, e) { AR(this._axisPointerModel, !e && this._moveAnimation, this._handle, PR(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(PR(n), [t, e], this._axisModel, this._axisPointerModel); this._payloadInfo = i, n.stopAnimation(), n.attr(PR(i)), IR(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), Ag(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 AR(t, e, n, i) { kR(IR(n).lastProp, i) || (IR(n).lastProp = i, e ? ih(n, i, t) : (n.stopAnimation(), n.attr(i))) } function kR(t, e) { if (q(t) && q(e)) { var n = !0; return E(e, (function (e, i) { n = n && kR(t[i], e) } )), !!n } return t === e } function LR(t, e) { t[e.get(["label", "show"]) ? "show" : "hide"]() } function PR(t) { return { x: t.x || 0, y: t.y || 0, rotation: t.rotation || 0 } } function OR(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 RR(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 NR(t, e, n, i, r) { var o = ER(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 = np(a.get("padding") || 0) , l = a.getFont() , u = cr(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: Yh(a, { text: o, font: l, fill: a.getTextColor(), padding: s, backgroundColor: g }), z2: 10 } } function ER(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: o_(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) } )), X(a) ? o = a.replace("{value}", o) : U(a) && (o = a(s)) } return o } function zR(t, e, n) { var i = [1, 0, 0, 1, 0, 0]; return zi(i, i, n.rotation), Ei(i, i, n.position), Ih([t.dataToCoord(e), (n.labelOffset || 0) + (n.labelDirection || 1) * (n.labelMargin || 0)], i) } function VR(t, e, n, i, r, o) { var a = BM.innerTextLayout(n.rotation, 0, n.labelDirection); n.labelMargin = r.get(["label", "margin"]), NR(e, i, r, o, { position: zR(i.axis, t, n), align: a.textAlign, verticalAlign: a.textVerticalAlign }) } function BR(t, e, n) { return { x1: t[n = n || 0], y1: t[1 - n], x2: e[n], y2: e[1 - n] } } function FR(t, e, n) { return { x: t[n = n || 0], y: t[1 - n], width: e[n], height: e[1 - n] } } function GR(t, e, n, i, r, o) { return { cx: t, cy: e, r0: n, r: i, startAngle: r, endAngle: o, clockwise: !0 } } var WR = 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 = HR(a, o).getOtherAxis(o).getGlobalExtent() , u = o.toGlobalCoord(o.dataToCoord(e, !0)); if (s && "none" !== s) { var h = RR(i) , c = YR[s](o, u, l); c.style = h, t.graphicKey = c.type, t.pointer = c } VR(e, t, AM(a.model, n), n, i, r) } , e.prototype.getHandleTransform = function (t, e, n) { var i = AM(e.axis.grid.model, e, { labelInside: !1 }); i.labelMargin = n.get(["handle", "margin"]); var r = zR(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 = HR(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 }(DR); function HR(t, e) { var n = {}; return n[e.dim + "AxisIndex"] = e.index, t.getCartesian(n) } var YR = { line: function (t, e, n) { return { type: "Line", subPixelOptimize: !0, shape: BR([e, n[0]], [e, n[1]], UR(t)) } }, shadow: function (t, e, n) { var i = Math.max(1, t.getBandWidth()) , r = n[1] - n[0]; return { type: "Rect", shape: FR([e - i / 2, n[0]], [i, r], UR(t)) } } }; function UR(t) { return "x" === t.dim ? 0 : 1 } var XR = 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, 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 }(Ip) , ZR = So() , jR = E; function qR(t, e, n) { if (!r.node) { var i = e.getZr(); ZR(i).records || (ZR(i).records = {}), function (t, e) { if (ZR(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); jR(ZR(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) } )) } ZR(t).initialized = !0, n("click", H($R, "click")), n("mousemove", H($R, "mousemove")), n("globalout", KR) }(i, e), (ZR(i).records[t] || (ZR(i).records[t] = {})).handler = n } } function KR(t, e, n) { t.handler("leave", null, n) } function $R(t, e, n, i) { e.handler(t, n, i) } function JR(t, e) { if (!r.node) { var n = e.getZr(); (ZR(n).records || {})[t] && (ZR(n).records[t] = null) } } var QR = 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"; qR("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) { JR("axisPointer", e) } , e.prototype.dispose = function (t, e) { JR("axisPointer", e) } , e.type = "axisPointer", e }(fg); function tN(t, e) { var n, i = [], r = t.seriesIndex; if (null == r || !(n = e.getSeriesByIndex(r))) return { point: [] }; var o = n.getData() , a = wo(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 eN = So(); function nN(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) { sN(r) && (r = tN({ seriesIndex: o.seriesIndex, dataIndex: o.dataIndex }, e).point); var l = sN(r) , u = o.axesInfo , h = s.axesInfo , c = "leave" === i || sN(r) , p = {} , d = {} , f = { list: [], map: {} } , g = { showPointer: H(rN, d), showTooltip: H(oN, 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 && iN(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, aN(e), aN(t)))), y[t.key] = o } } )) } )), E(y, (function (t, e) { iN(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 (sN(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 = eN(i)[r] || {} , a = eN(i)[r] = {}; E(t, (function (t, e) { var n = t.axisPointerModel.option; "show" === n.status && 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 iN(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 ? .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 rN(t, e, n, i) { t[e.key] = { value: n, payloadBatch: i } } function oN(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 = KM(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 aN(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 sN(t) { return !t || null == t[0] || isNaN(t[0]) || null == t[1] || isNaN(t[1]) } function lN(t) { JM.registerAxisPointerClass("CartesianAxisPointer", WR), t.registerComponentModel(XR), t.registerComponentView(QR), 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 = UM(t, e) } )), t.registerAction({ type: "updateAxisPointer", event: "updateAxisPointer", update: ":updateAxisPointer" }, nN) } var uN = 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 = RR(i) , c = hN[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]; zi(p, p, s), Ei(p, p, [i.cx, i.cy]), l = Ih([a, -r], p); var d = e.getModel("axisLabel").get("rotate") || 0 , f = BM.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 < .3 ? "center" : l[0] > y ? "left" : "right", h = Math.abs(l[1] - v) / g < .3 ? "middle" : l[1] > v ? "top" : "bottom" } return { position: l, align: u, verticalAlign: h } }(e, n, 0, a, i.get(["label", "margin"])); NR(t, n, i, r, p) } , e }(DR); var hN = { line: function (t, e, n, i) { return "angle" === t.dim ? { type: "Line", shape: BR(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: GR(e.cx, e.cy, i[0], i[1], (-n - r / 2) * o, (r / 2 - n) * o) } : { type: "Sector", shape: GR(e.cx, e.cy, n - r / 2, n + r / 2, 0, 2 * Math.PI) } } } , cN = 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 }(Ip) , pN = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.getCoordSysModel = function () { return this.getReferringComponents("polar", Co).models[0] } , e.type = "polarAxis", e }(Ip); R(pN, h_); var dN = 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 }(pN) , fN = 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 }(pN) , gN = 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 }(G_); gN.prototype.dataToRadius = G_.prototype.dataToCoord, gN.prototype.radiusToData = G_.prototype.coordToData; var yN = So() , vN = 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 = cr(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 = yN(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 }(G_); vN.prototype.dataToAngle = G_.prototype.dataToCoord, vN.prototype.angleToData = G_.prototype.coordToData; var mN = ["radius", "angle"] , xN = function () { function t(t) { this.dimensions = mN, this.type = "polar", this.cx = 0, this.cy = 0, this._radiusAxis = new gN, this._angleAxis = new vN, 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; 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 , r = n * n + i * i - 1e-4 , o = this.r , a = this.r0; return r <= o * o && r >= a * a } } } , t.prototype.convertToPixel = function (t, e, n) { return _N(e) === this ? this.dataToPoint(n) : null } , t.prototype.convertFromPixel = function (t, e, n) { return _N(e) === this ? this.pointToData(n) : null } , t }(); function _N(t) { var e = t.seriesModel , n = t.polarModel; return n && n.coordinateSystem || e && e.coordinateSystem } function bN(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(u_(e, "radius"), (function (t) { r.scale.unionExtentFromData(e, t) } )), E(u_(e, "angle"), (function (t) { i.scale.unionExtentFromData(e, t) } )) } } )), n_(i.scale, i.model), n_(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 wN(t, e) { if (t.type = e.get("type"), t.scale = i_(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 n = e.get("startAngle"); t.setExtent(n, n + (t.inverse ? -360 : 360)) } e.axis = t, t.model = e } var SN = { dimensions: mN, create: function (t, e) { var n = []; return t.eachComponent("polar", (function (t, i) { var r = new xN(i + ""); r.update = bN; var o = r.getRadiusAxis() , a = r.getAngleAxis() , s = t.findAxisModel("radiusAxis") , l = t.findAxisModel("angleAxis"); wN(o, s), wN(a, l), function (t, e, n) { var i = e.get("center") , r = n.getWidth() , o = n.getHeight(); t.cx = Er(i[0], r), t.cy = Er(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 = [Er(l[0], s), Er(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", Co).models[0]; 0, t.coordinateSystem = e.coordinateSystem } } )), n } } , MN = ["axisLine", "axisLabel", "axisTick", "minorTick", "splitLine", "minorSplitLine", "splitArea"]; function IN(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 TN(t) { return t.getRadiusAxis().inverse ? 0 : 1 } function CN(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 DN = 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 } )); CN(s), CN(o), E(MN, (function (e) { !t.get([e, "show"]) || n.scale.isBlank() && "axisLine" !== e || AN[e](this.group, t, i, o, a, r, s) } ), this) } } , e.type = "angleAxis", e }(JM) , AN = { axisLine: function (t, e, n, i, r, o) { var a, s = e.getModel(["axisLine", "lineStyle"]), l = TN(n), u = l ? 0 : 1; (a = 0 === o[u] ? new uu({ shape: { cx: n.cx, cy: n.cy, r: o[l] }, style: s.getLineStyle(), z2: 1, silent: !0 }) : new Du({ shape: { cx: n.cx, cy: n.cy, r: o[l], r0: o[u] }, 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[TN(n)] , u = z(i, (function (t) { return new Eu({ shape: IN(n, [l, l + s], t.coord) }) } )); t.add(bh(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[TN(n)], h = [], c = 0; c < r.length; c++) for (var p = 0; p < r[c].length; p++) h.push(new Eu({ shape: IN(n, [u, u + l], r[c][p].coord) })); t.add(bh(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[TN(n)] , d = n.coordToPoint([p + u, i.coord]) , f = n.cx , g = n.cy , y = Math.abs(d[0] - f) / p < .3 ? "center" : d[0] > f ? "left" : "right" , v = Math.abs(d[1] - g) / p < .3 ? "middle" : d[1] > g ? "top" : "bottom"; if (s && s[c]) { var m = s[c]; q(m) && m.textStyle && (a = new pc(m.textStyle, l, l.ecModel)) } var x = new As({ silent: BM.isLabelSilent(e), style: Yh(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 _ = BM.makeAxisEventDataBase(e); _.targetType = "axisLabel", _.value = i.rawLabel, Ws(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 Eu({ shape: IN(n, o, i[h].coord) })) } for (h = 0; h < u.length; h++) t.add(bh(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 Eu({ shape: IN(n, o, r[l][u].coord) })); t.add(bh(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 Tu({ 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(bh(u[g], { style: k({ fill: s[g % s.length] }, a.getAreaStyle()), silent: !0 })) } } } , kN = ["axisLine", "axisTickLabel", "axisName"] , LN = ["splitLine", "splitArea", "minorSplitLine"] , PN = 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 Cr; 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 BM(t, c); E(kN, p.add, p), i.add(p.getGroup()), Dh(n, i, t), E(LN, (function (e) { t.get([e, "show"]) && !r.scale.isBlank() && ON[e](this.group, t, o, u, h, s, l) } ), this) } } , e.type = "radiusAxis", e }(JM) , ON = { 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 < o.length; h++) { var c = l++ % s.length; u[c] = u[c] || [], u[c].push(new uu({ shape: { cx: n.cx, cy: n.cy, r: o[h].coord } })) } for (h = 0; h < u.length; h++) t.add(bh(u[h], { style: k({ stroke: s[h % 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 uu({ shape: { cx: n.cx, cy: n.cy, r: a[u][h].coord } })); t.add(bh(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 Tu({ 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(bh(u[c], { style: k({ fill: s[c % s.length] }, a.getAreaStyle()), silent: !0 })) } } }; function RN(t) { return t.get("stack") || "__ec_stack_" + t.seriesIndex } function NN(t, e) { return e.dim + t.model.componentIndex } function EN(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 = NN(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 = RN(t); h[c] || u.autoWidthCount++, h[c] = h[c] || { width: 0, maxWidth: 0 }; var p = Er(t.get("barWidth"), l) , d = Er(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 = Er(t.categoryGap, r) , a = Er(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 = NN(n, o) , s = RN(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 = tx(e, y), x = "radius" !== o.dim || !t.get("roundCap", !0), _ = c.dataToCoord(0), b = 0, w = e.count(); b < w; b++) { var S = e.get(y, b) , M = e.get(v, b) , I = S >= 0 ? "p" : "n" , T = _; m && (i[s][M] || (i[s][M] = { p: _, n: _ }), T = i[s][M][I]); var C = void 0 , D = void 0 , A = void 0 , k = void 0; if ("radius" === c.dim) { var L = c.dataToCoord(S) - _ , P = o.dataToCoord(M); Math.abs(L) < f && (L = (L < 0 ? -1 : 1) * f), C = T, D = T + L, k = (A = P - u) - h, m && (i[s][M][I] = D) } else { var O = c.dataToCoord(S, x) - _ , R = o.dataToCoord(M); Math.abs(O) < g && (O = (O < 0 ? -1 : 1) * g), D = (C = R + u) + h, A = T, k = T + O, m && (i[s][M][I] = k) } e.setItemLayout(b, { cx: p, cy: d, r0: C, r: D, startAngle: -A * Math.PI / 180, endAngle: -k * Math.PI / 180, clockwise: A >= k }) } } } )) } var zN = { startAngle: 90, clockwise: !0, splitNumber: 12, axisLabel: { rotate: 0 } } , VN = { splitNumber: 5 } , BN = 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 }(fg); function FN(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 GN = ["axisLine", "axisTickLabel", "axisName"] , WN = ["splitArea", "splitLine"] , HN = 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 Cr; var s = FN(e) , l = new BM(e, s); E(GN, l.add, l), o.add(this._axisGroup), o.add(l.getGroup()), E(WN, (function (t) { e.get([t, "show"]) && YN[t](this, this.group, this._axisGroup, e) } ), this), Dh(a, this._axisGroup, e), t.prototype.render.call(this, e, n, i, r) } , e.prototype.remove = function () { eI(this) } , e.type = "singleAxis", e }(JM) , YN = { 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 = i.coordinateSystem.getRect(), u = r.isHorizontal(), h = [], c = 0, p = r.getTicksCoords({ tickModel: o }), d = [], f = [], g = 0; g < p.length; ++g) { var y = r.toGlobalCoord(p[g].coord); u ? (d[0] = y, d[1] = l.y, f[0] = y, f[1] = l.y + l.height) : (d[0] = l.x, d[1] = y, f[0] = l.x + l.width, f[1] = y); var v = c++ % s.length; h[v] = h[v] || [], h[v].push(new Eu({ subPixelOptimize: !0, shape: { x1: d[0], y1: d[1], x2: f[0], y2: f[1] }, silent: !0 })) } var m = a.getLineStyle(["color"]); for (g = 0; g < h.length; ++g) e.add(bh(h[g], { style: k({ stroke: s[g % s.length] }, m), silent: !0 })) } }, splitArea: function (t, e, n, i) { tI(t, n, i, i) } } , UN = 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: .2 } } }, e }(Ip); R(UN, h_.prototype); var XN = 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 }(G_) , ZN = ["single"] , jN = function () { function t(t, e, n) { this.type = "single", this.dimension = "single", this.dimensions = ZN, 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 XN(i, i_(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), n_(this._axis.scale, this._axis.model) } } ), this) } , t.prototype.resize = function (t, e) { this._rect = mp({ 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.reverse ? 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 qN(e) === this ? this.dataToPoint(n) : null } , t.prototype.convertFromPixel = function (t, e, n) { return qN(e) === this ? this.pointToData(n) : null } , t }(); function qN(t) { var e = t.seriesModel , n = t.singleAxisModel; return n && n.coordinateSystem || e && e.coordinateSystem } var KN = { create: function (t, e) { var n = []; return t.eachComponent("singleAxis", (function (i, r) { var o = new jN(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", Co).models[0]; t.coordinateSystem = e && e.coordinateSystem } } )), n }, dimensions: ZN } , $N = ["x", "y"] , JN = ["width", "height"] , QN = 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 = nE(a, 1 - eE(o)) , l = a.dataToPoint(e)[0] , u = i.get("type"); if (u && "none" !== u) { var h = RR(i) , c = tE[u](o, l, s); c.style = h, t.graphicKey = c.type, t.pointer = c } VR(e, t, FN(n), n, i, r) } , e.prototype.getHandleTransform = function (t, e, n) { var i = FN(e, { labelInside: !1 }); i.labelMargin = n.get(["handle", "margin"]); var r = zR(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 = eE(r) , s = nE(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 = nE(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 }(DR) , tE = { line: function (t, e, n) { return { type: "Line", subPixelOptimize: !0, shape: BR([e, n[0]], [e, n[1]], eE(t)) } }, shadow: function (t, e, n) { var i = t.getBandWidth() , r = n[1] - n[0]; return { type: "Rect", shape: FR([e - i / 2, n[0]], [i, r], eE(t)) } } }; function eE(t) { return t.isHorizontal() ? 0 : 1 } function nE(t, e) { var n = t.getRect(); return [n[$N[e]], n[$N[e]] + n[JN[e]]] } var 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.type = "single", e }(fg); var rE = 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 = wp(e); t.prototype.init.apply(this, arguments), oE(e, r) } , e.prototype.mergeOption = function (e) { t.prototype.mergeOption.apply(this, arguments), oE(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 }(Ip); function oE(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[gp[e][0]] || null != t[gp[e][1]] && null != t[gp[e][2]] }(e, t) && (n[t] = "auto"), null != n[t] && "auto" !== n[t] } )); bp(t, e, { type: "box", ignoreSize: r }) } var aE = 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 Ts({ 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 Ou({ 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 X(t) && t ? (n = t, E(e, (function (t, e) { n = n.replace("{" + e + "}", i ? op(t) : t) } )), n) : U(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 As({ z2: 30, style: Yh(r, { text: g }) }); 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 && !X(o) || (o && (e = Sc(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 = 0; d < u[h].length - 1; d++) { var f = u[h][d].slice() , g = this._firstDayOfMonth[d]; if (p) { var y = this._firstDayPoints[d]; f[c] = (y[c] + u[0][d + 1][c]) / 2 } var v = r.get("formatter") , m = o[+g.m - 1] , x = { yyyy: g.y, yy: (g.y + "").slice(2), MM: g.m, M: +g.m, nameMap: m } , _ = this._formatterLabel(v, x) , b = new As({ z2: 30, style: A(Yh(r, { text: _ }), this._monthTextPositionControl(f, p, n, s, a)) }); i.add(b) } } } , 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 || X(l)) l && (e = Sc(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 = Er(u, Math.min(p[1], p[0])), "start" === s && (c = a.getNextNDay(n.start.time, -(7 + n.fweek)).time, u = -u); for (var d = 0; d < 7; d++) { var f, g = a.getNextNDay(c, d), y = a.dataToRect([g.time], !1).center; f = Math.abs((d + h) % 7); var v = new As({ z2: 30, style: A(Yh(o, { text: l[f] }), this._weekTextPositionControl(y, i, s, u, p)) }); r.add(v) } } } , e.type = "calendar", e }(fg) , sE = 864e5 , lE = 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 = jr(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 = mp(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 + sE)) 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 = uE(e); return i === this ? i.dataToPoint(n) : null } , t.prototype.convertFromPixel = function (t, e, n) { var i = uE(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 / sE) - Math.floor(n[0].time / sE) + 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 uE(t) { var e = t.calendarModel , n = t.seriesModel; return e ? e.coordinateSystem : n ? n.coordinateSystem : null } function hE(t, e) { var n; return E(e, (function (e) { null != t[e] && "auto" !== t[e] && (n = !0) } )), n } var cE = ["transition", "enterFrom", "leaveTo"] , pE = cE.concat(["enterAnimation", "updateAnimation", "leaveAnimation"]); function dE(t, e, n) { if (n && (!t[n] && e[n] && (t[n] = {}), t = t[n], e = e[n]), t && e) for (var i = n ? cE : pE, r = 0; r < i.length; r++) { var o = i[r]; null == t[o] && null != e[o] && (t[o] = e[o]) } } var fE = 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 = yo(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), bp(r, i, { ignoreSize: !0 }), Sp(n, r), dE(n, r), dE(n, r, "shape"), dE(n, r, "style"), dE(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 = [hE(e, ["left", "right"]), hE(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; "group" === t.type && i && 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 }(Ip) , gE = { path: null, compoundPath: null, group: Cr, image: xs, text: As } , yE = So() , 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 () { this._elMap = ft() } , 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 = xo(e.id, null) , s = null != a ? n.get(a) : null , l = xo(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 && TO(c, h, !!d, !!p)) { var f = CO(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(fp), (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 = xE(a, u, e.type, n) : (x && (yE(x).isNew = !1), jO(x)), x && (EO(x, g, t, { isInit: T }), bE(x, e, r, o)) } else if (m) { _E(s, e, n, t); var _ = xE(a, u, e.type, n); _ && (EO(_, g, t, { isInit: !0 }), bE(_, e, r, o)) } else "remove" === y && (zO(s, e), _E(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 As(p)) } else m && b.setTextContent(new As(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 || yE(C).type !== M) ? mE(M) : C } else m && (T = !0, I = mE(M)); b.setClipPath(I), EO(I, S, t, { isInit: T }), qO(I, S.keyframeAnimation, t) } var D = yE(b); b.setTextConfig(d), D.option = e, function (t, e, n) { var i = Ws(t).eventData; t.silent || t.ignore || i || (i = Ws(t).eventData = { componentType: "graphic", componentIndex: e.componentIndex, name: t.name }); i && (i.info = n.info) }(b, t, e), Nh({ el: b, componentModel: t, itemName: b.name, itemTooltipOption: e.tooltip }), qO(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 = xo((p = n[l]).id, null)) ? r.get(d) : null) && f.isGroup) { var u = (g = f.parent) === i , h = yE(f) , c = yE(g); h.width = Er(h.option.width, u ? o : c.width) || 0, h.height = Er(h.option.height, u ? a : c.height) || 0 } } for (l = n.length - 1; l >= 0; l--) { var p, d, f; if (f = null != (d = xo((p = n[l]).id, null)) ? r.get(d) : null) { var g = f.parent , y = (c = yE(g), {}) , v = xp(f, p, g === i ? { width: o, height: a } : { width: c.width, height: c.height }, null, { hv: p.hv, boundingMode: p.bounding }, y); if (!yE(f).isNew && v) { for (var m = p.transition, x = {}, _ = 0; _ < s.length; _++) { var b = s[_] , w = y[b]; m && (BO(m) || P(m, b) >= 0) ? x[b] = w : f[b] = w } ih(f, x, t, 0) } else f.attr(y) } } } , e.prototype._clear = function () { var t = this , e = this._elMap; e.each((function (n) { _E(n, yE(n).option, e, t._lastGraphicModel) } )), this._elMap = ft() } , e.prototype.dispose = function () { this._clear() } , e.type = "graphic", e }(fg); function mE(t) { var e = mt(gE, t) ? gE[t] : vh(t); var n = new e({}); return yE(n).type = t, n } function xE(t, e, n, i) { var r = mE(n); return e.add(r), i.set(t, r), yE(r).id = t, yE(r).isNew = !0, r } function _E(t, e, n, i) { t && t.parent && ("group" === t.type && t.traverse((function (t) { _E(t, e, n, i) } )), VO(t, e, i), n.removeKey(yE(t).id)) } function bE(t, e, n, i) { if (!t.isGroup) { var r = t; r.z = rt(e.z, n || 0), r.zlevel = rt(e.zlevel, i || 0); var o = e.z2; null != o && (r.z2 = o || 0) } E(G(e), (function (n) { var i = e[n]; 0 === n.indexOf("on") && U(i) && (t[n] = i) } )), t.draggable = e.draggable, null != e.name && (t.name = e.name), null != e.id && (t.id = e.id) } var wE = ["x", "y", "radius", "angle", "single"] , SE = ["cartesian2d", "polar", "singleAxis"]; function ME(t) { return t + "Axis" } function IE(t, e) { var n, i = ft(), r = [], o = ft(); 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 TE(t) { var e = t.ecModel , n = { infoList: [], infoMap: ft() }; return t.eachTargetAxis((function (t, i) { var r = e.getComponent(ME(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 CE = 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 }() , DE = 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 = AE(t); this.settledOption = i, this.mergeDefaultAndTheme(t, n), this._doInit(i) } , e.prototype.mergeOption = function (t) { var e = AE(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 = ft(); 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(wE, (function (n) { var i = this.getReferringComponents(ME(n), Do); if (i.specified) { e = !0; var r = new CE; 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 CE; if (o.add(r.componentIndex), t.set(n, o), i = !1, "x" === n || "y" === n) { var a = r.getReferringComponents("grid", Co).models[0]; a && E(e, (function (t) { r.componentIndex !== t.componentIndex && a === t.getReferringComponents("grid", Co).models[0] && o.add(t.componentIndex) } )) } } } i && E(wE, (function (e) { if (i) { var r = n.findComponents({ mainType: ME(e), filter: function (t) { return "category" === t.get("type", !0) } }); if (r[0]) { var o = new CE; 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(ME(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(ME(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 }(Ip); function AE(t) { var e = {}; return E(["start", "end", "startValue", "endValue", "throttle"], (function (n) { t.hasOwnProperty(n) && (e[n] = t[n]) } )), e } var kE = 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 }(DE) , LE = 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 }(fg) , PE = 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 }(LE) , OE = E , RE = Vr , NE = 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(SE, e) >= 0 }(e)) { var n = ME(this._dimName) , i = e.getReferringComponents(n, Co).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 = []; OE(["start", "end"], (function (l, u) { var h = t[l] , c = t[l + "Value"]; "percent" === r[u] ? (null == h && (h = o[u]), c = i.parse(Nr(h, o, n))) : (e = !0, h = Nr(c = null == c ? n[u] : i.parse(c), n, o)), s[u] = c, a[u] = h } )), RE(s), RE(a); var l = this._minMaxSpan; function u(t, e, n, r, o) { var a = o ? "Span" : "ValueSpan"; sk(0, t, n, "all", l["min" + a], l["max" + a]); for (var s = 0; s < 2; s++) e[s] = Nr(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]; OE(n, (function (t) { !function (t, e, n) { e && E(u_(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 = Qx(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 && OE(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 OE(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) } } )); OE(i, (function (t) { e.setApproximateExtent(o, t) } )) } } )) } } , t.prototype._updateMinMaxSpan = function () { var t = this._minMaxSpan = {} , e = this._dataZoomModel , n = this._dataExtent; OE(["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 = Nr(n[0] + o, n, [0, 100], !0) : null != r && (o = Nr(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 = Gr(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 EE = { getTargetSeries: function (t) { function e(e) { t.eachComponent("dataZoom", (function (n) { n.eachTargetAxis((function (i, r) { var o = t.getComponent(ME(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 NE(e, i, o, t), n.push(r.__dzAxisProxy)) } )); var i = ft(); 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 zE = !1; function VE(t) { zE || (zE = !0, t.registerProcessor(t.PRIORITY.PROCESSOR.FILTER, EE), function (t) { t.registerAction("dataZoom", (function (t, e) { E(IE(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 BE(t) { t.registerComponentModel(kE), t.registerComponentView(PE), VE(t) } var FE = function () { } , GE = {}; function WE(t, e) { GE[t] = e } function HE(t) { return GE[t] } var YE = 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 = HE(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 }(Ip); function UE(t, e) { var n = np(e.get("padding")) , i = e.getItemStyle(["color", "opacity"]); return i.fill = e.get("backgroundColor"), t = new Ts({ 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 XE = 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 = t.get("feature") || {} , s = this._features || (this._features = {}) , l = []; E(a, (function (t, e) { l.push(e) } )), new Sm(this._featureNames || [], l).add(u).update(u).remove(H(u, null)).execute(), this._featureNames = l, function (t, e, n) { var i = e.getBoxLayoutParams() , r = e.get("padding") , o = { width: n.getWidth(), height: n.getHeight() } , a = mp(i, o, r); vp(e.get("orient"), t, e.get("itemGap"), a.width, a.height), xp(t, i, o, r) }(r, t, n), r.add(UE(r.getBoundingRect(), t)), r.eachChild((function (t) { var e = t.__title , i = t.ensureState("emphasis") , a = i.textConfig || (i.textConfig = {}) , s = t.getTextContent() , l = s && s.states.emphasis; if (l && !U(l) && e) { var u = l.style || (l.style = {}) , h = cr(e, As.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 + 8; 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 u(u, h) { var c, p = l[u], d = l[h], f = a[p], g = new pc(f, t, t.ecModel); if (i && null != i.newTitle && i.featureName === p && (f.title = i.newTitle), p && !d) { if (function (t) { return 0 === t.indexOf("my") }(p)) c = { onclick: g.option.onclick, featureName: p }; else { var y = HE(p); if (!y) return; c = new y } s[p] = c } else if (!(c = s[d])) return; c.uid = fc("toolbox-feature"), c.model = g, c.ecModel = e, c.api = n; var v = c instanceof FE; p || !d ? !g.get("show") || v && c.unusable ? v && c.remove && c.remove(e, n) : (!function (i, a, s) { var l, u, h = i.getModel("iconStyle"), c = i.getModel(["emphasis", "iconStyle"]), p = a instanceof FE && a.getIcons ? a.getIcons() : i.get("icon"), d = i.get("title") || {}; X(p) ? (l = {})[s] = p : l = p; X(d) ? (u = {})[s] = d : u = d; var f = i.iconPaths = {}; E(l, (function (s, l) { var p = Lh(s, {}, { x: -o / 2, y: -o / 2, width: o, height: o }); p.setStyle(h.getItemStyle()), p.ensureState("emphasis").style = c.getItemStyle(); var d = new As({ style: { text: u[l], align: c.get("textAlign"), borderRadius: c.get("textBorderRadius"), padding: c.get("textPadding"), fill: null }, ignore: !0 }); p.setTextContent(d), Nh({ el: p, componentModel: t, itemName: l, formatterParamsExtra: { title: u[l] } }), p.__title = u[l], p.on("mouseover", (function () { var e = c.getItemStyle() , n = "vertical" === t.get("orient") ? null == t.get("right") ? "right" : "left" : null == t.get("bottom") ? "bottom" : "top"; d.setStyle({ fill: c.get("textFill") || e.fill || e.stroke || "#000", backgroundColor: c.get("textBackgroundColor") }), p.setTextConfig({ position: c.get("textPosition") || n }), d.ignore = !t.get("showTitle"), xl(this) } )).on("mouseout", (function () { "emphasis" !== i.get(["iconStatus", l]) && _l(this), d.hide() } )), ("emphasis" === i.get(["iconStatus", l]) ? xl : _l)(p), r.add(p), p.on("click", W(a.onclick, a, e, n, l)), f[l] = p } )) }(g, c, p), g.setIconStatus = function (t, e) { var n = this.option , i = this.iconPaths; n.iconStatus = n.iconStatus || {}, n.iconStatus[t] = e, i[t] && ("emphasis" === e ? xl : _l)(i[t]) } , c instanceof FE && c.render && c.render(g, e, n, i)) : v && c.dispose && c.dispose(e, n) } } , e.prototype.updateView = function (t, e, n, i) { E(this._features, (function (t) { t instanceof FE && t.updateView && t.updateView(t.model, e, n, i) } )) } , e.prototype.remove = function (t, e) { E(this._features, (function (n) { n instanceof FE && n.remove && n.remove(t, e) } )), this.group.removeAll() } , e.prototype.dispose = function (t, e) { E(this._features, (function (n) { n instanceof FE && n.dispose && n.dispose(t, e) } )) } , e.type = "toolbox", e }(fg); var ZE = 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 (U(MouseEvent) && (l.newEdge || !l.ie && !l.edge)) { var u = document.createElement("a"); u.download = i + "." + a, u.target = "_blank", u.href = s; var h = new MouseEvent("click", { view: document.defaultView, bubbles: !0, cancelable: !1 }); u.dispatchEvent(h) } else if (window.navigator.msSaveOrOpenBlob || o) { var c = s.split(",") , p = c[0].indexOf("base64") > -1 , d = o ? decodeURIComponent(c[1]) : c[1]; p && (d = window.atob(d)); var f = i + "." + a; if (window.navigator.msSaveOrOpenBlob) { for (var g = d.length, y = new Uint8Array(g); g--;) y[g] = d.charCodeAt(g); var v = new Blob([y]); window.navigator.msSaveOrOpenBlob(v, f) } else { var m = document.createElement("iframe"); document.body.appendChild(m); var x = m.contentWindow , _ = x.document; _.open("image/svg+xml", "replace"), _.write(d), _.close(), x.focus(), _.execCommand("SaveAs", !0, f), document.body.removeChild(m) } } else { var b = n.get("lang") , w = '' , S = window.open(); S.document.write(w), S.document.title = i } } , 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 }(FE) , jE = "__ec_magicType_stack__" , qE = [["line", "bar"], ["stack"]] , KE = 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 ($E[n]) { var o, a = { series: [] }; E(qE, (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 = $E[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, Co).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 }(FE) , $E = { 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") === jE; if ("line" === t || "bar" === t) return i.setIconStatus("stack", r ? "normal" : "emphasis"), C({ id: e, stack: r ? "" : jE }, i.get(["option", "stack"]) || {}, !0) } }; um({ type: "changeMagicType", event: "magicTypeChanged", update: "prepareAndUpdate" }, (function (t, e) { e.mergeOption(t.newOption) } )); var JE = new Array(60).join("-") , QE = "\t"; function tz(t) { return t.replace(/^\s\s*/, "").replace(/\s\s*$/, "") } var ez = new RegExp("[\t]+", "g"); function nz(t, e) { var n = t.split(new RegExp("\n*" + JE + "\n*", "g")) , i = { series: [] }; return E(n, (function (t, n) { if (function (t) { if (t.slice(0, t.indexOf("\n")).indexOf(QE) >= 0) return !0 }(t)) { var r = function (t) { for (var e = t.split(/\n+/g), n = [], i = z(tz(e.shift()).split(ez), (function (t) { return { name: t, data: [] } } )), r = 0; r < e.length; r++) { var o = tz(e[r]).split(ez); 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 = tz(e.shift()), i = [], r = 0; r < e.length; r++) { var o = tz(e[r]); if (o) { var a = o.split(ez) , 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 iz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.onclick = function (t, e) { var n = e.getDom() , i = this.model; this._dom && n.removeChild(this._dom); var r = document.createElement("div"); r.style.cssText = "position:absolute;left:5px;top:5px;bottom:5px;right: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 = "display:block;width:100%;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(QE)], 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(QE)) } i.push(s.join("\n")) } )), i.join("\n\n" + JE + "\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 + QE : "") + i.join(QE)) } )), n.join("\n") } )).join("\n\n" + JE + "\n\n"))], (function (t) { return !!t.replace(/[\n\t\s]/g, "") } )).join("\n\n" + JE + "\n\n"), meta: r.meta } }(t); if (U(u)) { var p = u(e.getOption()); X(p) ? s.innerHTML = p : J(p) && s.appendChild(p) } else s.appendChild(l), l.readOnly = i.get("readOnly"), l.style.cssText = "width:100%;height:100%;font-family:monospace;font-size:14px;line-height:1.6rem;", l.style.color = i.get("textColor"), l.style.borderColor = i.get("textareaBorderColor"), l.style.backgroundColor = i.get("textareaColor"), l.value = c.value; var d = c.meta , f = document.createElement("div"); f.style.cssText = "position:absolute;bottom:0;left:0;right:0;"; var g = "float:right;margin-right:20px;border:none;cursor:pointer;padding:2px 5px;font-size:12px;border-radius:3px" , y = document.createElement("div") , v = document.createElement("div"); g += ";background-color:" + i.get("buttonColor"), g += ";color:" + i.get("buttonTextColor"); var m = this; function x() { n.removeChild(r), m._dom = null } ae(y, "click", x), ae(v, "click", (function () { if (null == h && null != u || null != h && null == u) x(); else { var t; try { t = U(h) ? h(s, e.getOption()) : nz(l.value, d) } catch (t) { throw x(), new Error("Data view format error " + t) } t && e.dispatchAction({ type: "changeDataView", newOption: t }), x() } } )), y.innerHTML = a[1], v.innerHTML = a[2], v.style.cssText = g, y.style.cssText = g, !i.get("readOnly") && f.appendChild(v), f.appendChild(y), r.appendChild(o), r.appendChild(s), r.appendChild(f), 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 }(FE); function rz(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 } )) } um({ 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: rz(t.data, r) }) } else n.push(A({ type: "scatter" }, t)) } )), e.mergeOption(k({ series: n }, t.newOption)) } )); var oz = E , az = So(); function sz(t) { var e = az(t); return e.snapshots || (e.snapshots = [{}]), e.snapshots } var lz = function (t) { function e() { return null !== t && t.apply(this, arguments) || this } return n(e, t), e.prototype.onclick = function (t, e) { !function (t) { az(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 }(FE); um({ type: "restore", event: "restore", update: "prepareAndUpdate" }, (function (t, e) { e.resetOption("recreate") } )); var uz = ["grid", "xAxis", "yAxis", "geo", "graph", "polar", "radiusAxis", "angleAxis", "bmap"] , hz = function () { function t(t, e, n) { var i = this; this._targetInfoList = []; var r = pz(e, t); E(dz, (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 = yz[t.brushType](0, n, e); t.__rangeOffset = { offset: mz[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 = yz[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 = yz[t.brushType](0, s.coordSys, t.coordRange) , u = t.__rangeOffset; t.range = u ? mz[t.brushType](l.values, u.offset, (n = l.xyMinMax, i = u.xyMinMax, r = _z(n), o = _z(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: uL(i), isTargetByCursor: cL(i, t, n.coordSysModel), getLinearBrushOtherExtent: hL(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 = pz(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 < fz.length; s++) if (fz[s](i, o)) return o } return !0 } , t }(); function cz(t) { return t[0] > t[1] && t.reverse(), t } function pz(t, e) { return Io(t, e, { includeMainTypes: uz }) } var dz = { grid: function (t, e) { var n = t.xAxisModels , i = t.yAxisModels , r = t.gridModels , o = ft() , 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: gz.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: gz.geo }) } )) } } , fz = [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 } ] , gz = { grid: function () { return this.coordSys.master.getRect().clone() }, geo: function () { var t = this.coordSys , e = t.getBoundingRect().clone(); return e.applyTransform(Mh(t)), e } } , yz = { lineX: H(vz, 0), lineY: H(vz, 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 = [cz([r[0], o[0]]), cz([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 vz(t, e, n, i) { var r = n.getAxis(["x", "y"][t]) , o = cz(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 mz = { lineX: H(xz, 0), lineY: H(xz, 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 xz(t, e, n, i) { return [e[0] - i[t] * n[0], e[1] - i[t] * n[1]] } function _z(t) { return t ? [t[0][1] - t[0][0], t[1][1] - t[1][0]] : [NaN, NaN] } var bz, wz, Sz = E, Mz = uo + "toolbox-dataZoom_", Iz = 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 Pk(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 hz(Cz(t), e, { include: ["grid"] }).makePanelOpts(r, (function (t) { return t.xAxisDeclared && !t.yAxisDeclared ? "lineX" : !t.xAxisDeclared && t.yAxisDeclared ? "lineY" : "rect" } )); n._brushController.setPanels(a).enableBrush(!(!o || !a.length) && { brushType: "auto", brushStyle: t.getModel("brushStyle").getItemStyle() }) }(t, e, this, i, n), function (t, e) { t.setIconStatus("back", function (t) { return sz(t).length }(e) > 1 ? "emphasis" : "normal") }(t, e) } , e.prototype.onclick = function (t, e, n) { Tz[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 hz(Cz(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 = sz(t); oz(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 = sk(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 = []; Sz(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 }(FE), Tz = { zoom: function () { var t = !this._isZoomActive; this.api.dispatchAction({ type: "takeGlobalCursor", key: "dataZoomSelect", dataZoomSelectActive: t }) }, back: function () { this._dispatchZoomAction(function (t) { var e = sz(t) , n = e[e.length - 1]; e.length > 1 && e.pop(); var i = {}; return oz(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 Cz(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 } bz = "dataZoom", wz = function (t) { var e = t.getComponent("toolbox", 0) , n = ["feature", "dataZoom"]; if (e && null != e.get(n)) { var i = e.getModel(n) , r = [] , o = Io(t, Cz(i)); return Sz(o.xAxisModels, (function (t) { return a(t, "xAxis", "xAxisIndex") } )), Sz(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: Mz + e + o }; a[n] = o, r.push(a) } } , lt(null == Zp.get(bz) && wz), Zp.set(bz, wz); var Dz = 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: .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 }(Ip); function Az(t) { var e = t.get("confine"); return null != e ? !!e : "richText" === t.get("renderMode") } function kz(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 Lz = kz(["transform", "webkitTransform", "OTransform", "MozTransform", "msTransform"]); function Pz(t, e) { if (!t) return e; e = ep(e, !0); var n = t.indexOf(e); return (t = -1 === n ? e : "-" + t.slice(0, n) + "-" + e).toLowerCase() } var Oz = Pz(kz(["webkitTransition", "transition", "OTransition", "MozTransition", "msTransition"]), "transition") , Rz = Pz(Lz, "transform") , Nz = "position:absolute;display:block;border-style:solid;white-space:nowrap;z-index:9999999;" + (r.transform3dSupported ? "will-change:transform;" : ""); function Ez(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;" + Rz + ":" + s + ";" : [["top", 0], ["left", 0], [Lz, s]] } function zz(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 = eg(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 ? "," + Rz + i : ",left" + i + ",top" + i), Oz + ":" + o }(o, n)), a && i.push("background-color:" + a), E(["width", "color", "radius"], (function (e) { var n = "border-" + e , r = ep(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()), n && e.push("line-height:" + Math.round(3 * n / 2) + "px"); var r = t.get("textShadowColor") , o = t.get("textShadowBlur") || 0 , a = t.get("textShadowOffsetX") || 0 , s = t.get("textShadowOffsetY") || 0; return r && o && e.push("text-shadow:" + a + "px " + s + "px " + o + "px " + r), E(["decoration", "align"], (function (n) { var i = t.get(n); i && e.push("text-" + n + ":" + i) } )), e.join(";") }(c)), null != p && i.push("padding:" + np(p).join("px ") + "px"), i.join(";") + ";" } function Vz(t, e, n, i, r) { var o = e && e.painter; if (n) { var a = o && o.getViewportRoot(); a && function (t, e, n, i, r) { $t(Kt, e, i, r, !0) && $t(t, n, Kt[0], Kt[1]) }(t, a, document.body, 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 Bz = function () { function t(t, e, n) { if (this._show = !1, this._styleCoord = [0, 0, 0, 0], this._enterable = !0, this._firstShow = !0, this._longHide = !0, r.wxa) return null; var i = document.createElement("div"); i.domBelongToZr = !0, this.el = i; var o = this._zr = e.getZr() , a = this._appendToBody = n && n.appendToBody; Vz(this._styleCoord, o, a, e.getWidth() / 2, e.getHeight() / 2), a ? document.body.appendChild(i) : t.appendChild(i), this._container = t; var s = this; i.onmouseenter = function () { s._enterable && (clearTimeout(s._hideTimeout), s._show = !0), s._inContent = !0 } , i.onmousemove = function (t) { if (t = t || window.event, !s._enterable) { var e = o.handler; oe(o.painter.getViewportRoot(), t, !0), e.dispatch("mousemove", t) } } , i.onmouseleave = function () { s._inContent = !1, s._enterable && s._show && s.hideLater(s._hideDelay) } } return t.prototype.update = function (t) { var e, n, i, r = this._container, o = (n = "position", (i = (e = r).currentStyle || document.defaultView && document.defaultView.getComputedStyle(e)) ? n ? i[n] : i : null), a = r.style; "absolute" !== a.position && "absolute" !== o && (a.position = "relative"), t.get("alwaysShowContent") && this._moveIfResized(), 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 = Nz + zz(t, !this._firstShow, this._longHide) + Ez(r[0], r[1], !0) + "border-color:" + cp(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 (X(r) && "item" === n.get("trigger") && !Az(n) && (a = function (t, e, n) { if (!X(n) || "inside" === n) return ""; var i = t.get("backgroundColor") , r = t.get("borderWidth"); e = cp(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 = Rz + ":"; 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)), X(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.offsetWidth, t.offsetHeight] } , t.prototype.moveTo = function (t, e) { var n = this._styleCoord; if (Vz(n, this._zr, this._appendToBody, t, e), null != n[0] && null != n[1]) { var i = this.el.style; E(Ez(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 || (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.el.parentNode.removeChild(this.el) } , t }() , Fz = function () { function t(t) { this._show = !1, this._styleCoord = [0, 0, 0, 0], this._enterable = !0, this._zr = t.getZr(), Hz(this._styleCoord, this._zr, t.getWidth() / 2, t.getHeight() / 2) } return t.prototype.update = function (t) { t.get("alwaysShowContent") && this._moveIfResized() } , 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) && ao(""), this.el && this._zr.remove(this.el); var a = n.getModel("textStyle"); this.el = new As({ style: { rich: e.richTextStyles, text: t, lineHeight: 22, borderWidth: 1, borderColor: i, textShadowColor: a.get("textShadowColor"), fill: n.get(["textStyle", "color"]), padding: eg(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 = Wz(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; Hz(i, this._zr, t, e), t = i[0], e = i[1]; var r = n.style , o = Gz(r.borderWidth || 0) , a = Wz(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 || (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 Gz(t) { return Math.max(0, t) } function Wz(t) { var e = Gz(t.shadowBlur || 0) , n = Gz(t.shadowOffsetX || 0) , i = Gz(t.shadowOffsetY || 0); return { left: Gz(e - n), right: Gz(e + n), top: Gz(e - i), bottom: Gz(e + i) } } function Hz(t, e, n, i) { t[0] = n, t[1] = i, t[2] = t[0] / e.getWidth(), t[3] = t[1] / e.getHeight() } var Yz = new Ts({ shape: { x: -1, y: -1, width: 2, height: 2 } }) , Uz = 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 Fz(e) : new Bz(e.getDom(), e, { appendToBody: i.get("appendToBody", !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, this._alwaysShowContent = t.get("alwaysShowContent"); var i = this._tooltipContent; i.update(t), i.setEnterable(t.get("enterable")), this._initGlobalListener(), this._keepShow(), "richText" !== this._renderMode && t.get("transitionDuration") ? Dg(this, "_updatePosition", 50, "fixRate") : Ag(this, "_updatePosition") } } , e.prototype._initGlobalListener = function () { var t = this._tooltipModel.get("triggerOn"); qR("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; if (null != this._lastX && null != this._lastY && "none" !== t.get("triggerOn")) { var i = this; clearTimeout(this._refreshUpdateTimeout), this._refreshUpdateTimeout = setTimeout((function () { !n.isDisposed() && i.manuallyShowTip(t, e, n, { x: i._lastX, y: i._lastY, dataByCoordSys: i._lastDataByCoordSys }) } )) } } , e.prototype.manuallyShowTip = function (t, e, n, i) { if (i.from !== this.uid && !r.node && n.getDom()) { var o = Zz(i, n); this._ticket = ""; var a = i.dataByCoordSys , s = function (t, e, n) { var i = To(t).queryOptionMap , r = i.keys()[0]; if (!r || "series" === r) return; var o, a = Ao(e, r, i.get(r), { useDefault: !1, enableAll: !1, enableNone: !1 }).models[0]; if (!a) return; if (n.getViewOfComponentModel(a).group.traverse((function (e) { var n = Ws(e).tooltipConfig; if (n && n.name === t.name) return o = e, !0 } )), o) return { componentMainType: r, componentIndex: a.componentIndex, el: o } }(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 = Yz; u.x = i.x, u.y = i.y, u.update(), Ws(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 = tN(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._alwaysShowContent && this._tooltipModel && r.hideLater(this._tooltipModel.get("hideDelay")), this._lastX = this._lastY = this._lastDataByCoordSys = null, i.from !== this.uid && this._hide(Zz(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" === Xz([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; this._lastDataByCoordSys = null, my(n, (function (t) { return null != Ws(t).dataIndex ? (r = t, !0) : null != Ws(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 = Xz([e.tooltipOption], i) , a = this._renderMode , s = [] , l = Uf("section", { blocks: [], noHeader: !0 }) , u = [] , h = new ng; 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 = ER(r, e.axis, n, t.seriesDataIndices, t.valueLabelOpt) , c = Uf("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 = o_(e.axis, { value: r }), f.axisValueLabel = o, f.marker = h.makeTooltipMarker("item", cp(f.color), a); var g = lf(p.formatTooltip(d, !0, null)) , y = g.frag; if (y) { var v = Xz([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 = $f(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 = Ws(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 = Xz([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 ng; g.marker = y.makeTooltipMarker("item", cp(g.color), c); var v = lf(s.formatTooltip(l, !1, u)) , m = d.get("order") , x = d.get("valueFormatter") , _ = v.frag , b = _ ? $f(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 = Ws(e) , r = i.tooltipConfig.option || {}; if (X(r)) { r = { content: r, formatter: r } } var o = [r] , a = this._ecModel.getComponent(i.componentMainType, i.componentIndex); a && o.push(a), o.push({ formatter: r.content }); var s = t.positionDefault , l = Xz(o, this._tooltipModel, s ? { position: s } : null) , u = l.get("content") , h = Math.random() + "" , c = new ng; this._showOrMove(l, (function () { var n = T(l.get("formatterParams") || {}); this._showTooltipContent(l, u, n, h, t.offsetX, t.offsetY, t.position, e, c) } )), 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 , 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 (X(h)) { var d = t.ecModel.get("useUTC") , f = Y(n) ? n[0] : n; c = h, f && f.axisType && f.axisType.indexOf("time") >= 0 && (c = zc(f.axisValue, c, d)), c = up(c, n, !0) } else if (U(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), U(e) && (e = e([n, i], o, r.el, p, { viewSize: [s, l], contentSize: u.slice() })), Y(e)) n = Er(e[0], s), i = Er(e[1], l); else if (q(e)) { var d = e; d.width = u[0], d.height = u[1]; var f = mp(d, { width: s, height: l }); n = f.x, i = f.y, h = null, c = null } else if (X(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 -= jz(h) ? u[0] / 2 : "right" === h ? u[0] : 0), c && (i -= jz(c) ? u[1] / 2 : "bottom" === c ? u[1] : 0), Az(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() && (Ag(this, "_updatePosition"), this._tooltipContent.dispose(), JR("itemTooltip", e)) } , e.type = "tooltip", e }(fg); function Xz(t, e, n) { var i, r = e.ecModel; n ? (i = new pc(n, r, r), i = new pc(e.option, i, r)) : i = e; for (var o = t.length - 1; o >= 0; o--) { var a = t[o]; a && (a instanceof pc && (a = a.get("tooltip", !0)), X(a) && (a = { formatter: a }), a && (i = new pc(a, i, r))) } return i } function Zz(t, e) { return t.dispatchAction || W(e.dispatchAction, e) } function jz(t) { return "center" === t || "middle" === t } var qz = ["rect", "polygon", "keep", "clear"]; function Kz(t, e) { var n = ho(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, qz) } } var $z = E; function Jz(t) { if (t) for (var e in t) if (t.hasOwnProperty(e)) return !0 } function Qz(t, e, n) { var i = {}; return $z(e, (function (e) { var r, o = i[e] = ((r = function () { } ).prototype.__hidden = r.prototype, new r); $z(t[e], (function (t, i) { if (eD.isValidType(i)) { var r = { type: i, visual: t }; n && n(r, e), o[i] = new eD(r), "opacity" === i && ((r = T(r)).type = "colorAlpha", o.__hidden.__alphaForOpacity = new eD(r)) } } )) } )), i } function tV(t, e, n) { var i; E(n, (function (t) { e.hasOwnProperty(t) && Jz(e[t]) && (i = !0) } )), i && E(n, (function (n) { e.hasOwnProperty(n) && Jz(e[n]) ? t[n] = T(e[n]) : delete t[n] } )) } var eV = { lineX: nV(0), lineY: nV(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]) && f_(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 !!(f_(i, r, o) || f_(i, r + a, o) || f_(i, r, o + s) || f_(i, r + a, o + s) || sr.create(t).contain(l[0], l[1]) || Ph(r, o, r + a, o, i) || Ph(r, o, r, o + s, i) || Ph(r + a, o, r + a, o + s, i) || Ph(r, o + s, r + a, o + s, i)) || void 0 } } }; function nV(t) { var e = ["x", "y"] , n = ["width", "height"]; return { point: function (e, n, i) { if (e) { var r = i.range; return iV(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(), iV(s[0], a) || iV(s[1], a) || iV(a[0], s) || iV(a[1], s) } } } } function iV(t, e) { return e[0] <= t && t <= e[1] } var rV = ["inBrush", "outOfBrush"] , oV = "__ecBrushSelect" , aV = "__ecInBrushSelectEvent"; function sV(t) { t.eachComponent({ mainType: "brush" }, (function (e) { (e.brushTargetManager = new hz(e.option, t)).setInputRanges(e.areas, t) } )) } function lV(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 }) } )), sV(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 = cV[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 eV[e].point(i, n, t) }, rect: function (i) { return eV[e].rect(i, n, t) } }; return n }(n), n } )) , f = Qz(e.option, rV, (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) { hV(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 hV(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) { gy(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 = eD.prepareVisualTypes(e[t]); s[t] = n } )), null == o ? n.each(h) : n.each([o], h) }(rV, f, r, o) } )) } )), function (t, e, n, i, r) { if (!r) return; var o = t.getZr(); if (o[aV]) return; o.__ecBrushSelect || (o.__ecBrushSelect = uV); Dg(o, oV, n, e)(t, i) }(e, i, r, o, n) } function uV(t, e) { if (!t.isDisposed()) { var n = t.getZr(); n[aV] = !0, t.dispatchAction({ type: "brushSelect", batch: e }), n[aV] = !1 } } function hV(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 cV = { rect: function (t) { return pV(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 && pV(e) } }; function pV(t) { return new sr(t[0][0], t[1][0], t[0][1] - t[0][0], t[1][1] - t[1][0]) } var dV = 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 Pk(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) { sV(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 }(fg) , fV = 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 && tV(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 gV(this.option, t) } ), this)) } , e.prototype.setBrushOption = function (t) { this.brushOption = gV(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 }(Ip); function gV(t, e) { return C({ brushType: t.brushType, brushMode: t.brushMode, transformable: t.transformable, brushStyle: new pc(t.brushStyle).getItemStyle(), removeOnClick: t.removeOnClick, z: t.z }, e, !0) } var yV = ["rect", "polygon", "lineX", "lineY", "keep", "clear"] , vV = 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: yV.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 }(FE); var mV = 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 }(Ip) , xV = 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 As({ style: Yh(r, { text: t.get("text"), fill: r.getTextColor() }, { disableBox: !0 }), z2: 10 }) , u = l.getBoundingRect() , h = t.get("subtext") , c = new As({ style: Yh(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 () { pp(p, "_" + t.get("target")) } )), d && c.on("click", (function () { pp(d, "_" + t.get("subtarget")) } )), Ws(l).eventData = Ws(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 = mp(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 Ts({ 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 }(fg); var _V = 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 = xo(fo(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 Zm([{ 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 }(Ip) , bV = 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 = gc(_V.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 }(_V); R(bV, sf.prototype); var wV = 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 }(fg) , SV = 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 }(G_) , MV = Math.PI , IV = So() , TV = 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 Uf("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 mp(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 ? "+" : "-" : X(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: MV / 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 * MV / 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; Ei(o, o, [-a, -s]), zi(o, o, -MV / 2), Ei(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 || X(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")) switch (e) { case "category": return new gx({ ordinalMeta: t.getCategories(), extent: [1 / 0, -1 / 0] }); case "time": return new Px({ locale: t.ecModel.getLocaleModel(), useUTC: t.ecModel.get("useUTC") }); default: return new vx } }(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 SV("value", r, t.axisExtent, i); return a.model = e, a } , e.prototype._createGroup = function (t) { var e = this[t] = new Cr; 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 Eu({ 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 Eu({ 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 = CV(s, l, e, c); p.ensureState("emphasis").style = u.getItemStyle(), p.ensureState("progress").style = h.getItemStyle(), Pl(p); var d = Ws(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 As({ x: c, y: 0, rotation: t.labelRotation - t.rotation, onclick: W(r._changeTimeline, r, a), silent: !1, style: Yh(l, { text: i.formattedLabel, align: t.labelAlign, verticalAlign: t.labelBaseline }) }); p.ensureState("emphasis").style = Yh(u), p.ensureState("progress").style = Yh(h), e.add(p), Pl(p), IV(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 = gr(rt(i.get(["controlStyle", n + "BtnSize"]), r), r) , c = function (t, e, n, i) { var r = i.style , o = Lh(t.get(["controlStyle", e]), i || {}, new sr(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), Pl(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), DV(t, s._progressLine, o, n, i, !0) }, onUpdate: function (t) { DV(t, s._progressLine, o, n, i) } }; this._currentPointer = CV(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 = Vr(this._axis.getExtent().slice()); n > i[1] && (n = i[1]), n < i[0] && (n = i[0]), this._currentPointer.x = n, this._currentPointer.markRedraw(), this._progressLine.shape.x2 = n, this._progressLine.dirty(); var r = this._findNearestTick(n) , o = this.model; (e || r !== o.getCurrentIndex() && o.get("realtime")) && this._changeTimeline(r) } , 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 Ih(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", IV(n[i]).dataIndex <= t) } , e.type = "timeline.slider", e }(wV); function CV(t, e, n, i, r, o) { var a = e.get("color"); r ? (r.setColor(a), n.add(r), o && o.onUpdate(r)) : ((r = ky(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 = Ly(t.get("symbolSize")); i.scaleX = l[0] / 2, i.scaleY = l[1] / 2; var u = Py(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 DV(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 AV(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 (kV(t), LV(t, "controlPosition")) { var i = t.controlStyle || (t.controlStyle = {}); LV(i, "position") || (i.position = t.controlPosition), "none" !== i.position || LV(i, "show") || (i.show = !1, delete i.position), delete t.controlPosition } E(t.data || [], (function (t) { q(t) && !Y(t) && (!LV(t, "value") && LV(t, "name") && (t.value = t.name), kV(t)) } )) }(t) } )) } function kV(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] || LV(r, e) || (r[e] = t) } )), n.label && !LV(i, "emphasis") && (i.emphasis = n.label, delete n.label) } function LV(t, e) { return t.hasOwnProperty(e) } function PV(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 OV(t) { co(t, "label", ["show"]) } var RV = So() , NV = 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 = RV(t)[r]; n && n.data ? (o ? o._mergeOption(n, e, !0) : (i && OV(n), E(n.data, (function (t) { t instanceof Array ? (OV(t[0]), OV(t[1])) : OV(t) } )), A(o = this.createMarkerModelFromSeries(n, this, e), { mainType: this.mainType, seriesIndex: t.seriesIndex, name: t.name, createdBySelf: !0 }), o.__hostSeries = t), RV(t)[r] = o) : RV(t)[r] = null } ), this) } , e.prototype.formatTooltip = function (t, e, n) { var i = this.getData() , r = this.getRawValue(t) , o = i.getName(t); return Uf("section", { header: this.name, blocks: [Uf("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.getMarkerModelFromSeries = function (t, e) { return RV(t)[e] } , e.type = "marker", e.dependencies = ["series", "grid", "polar", "geo"], e }(Ip); R(NV, sf.prototype); var EV = 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 }(NV); function zV(t, e, n, i, r, o) { var a = [] , s = tx(e, i) ? e.getCalculationInfo("stackResultDimension") : i , l = HV(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 = Br(e.get(i, u)); return (c = Math.min(c, 20)) >= 0 && (a[o] = +a[o].toFixed(c)), [a, h] } var VV = { min: H(zV, "min"), max: H(zV, "max"), average: H(zV, "average"), median: H(zV, "median") }; function BV(t, e) { var n = t.getData() , i = t.coordinateSystem; if (e && !function (t) { return !isNaN(parseFloat(t.x)) && !isNaN(parseFloat(t.y)) }(e) && !Y(e.coord) && i) { var r = i.dimensions , o = FV(e, n, i, t); if ((e = T(e)).type && VV[e.type] && o.baseAxis && o.valueAxis) { var a = P(r, o.baseAxis.dim) , s = P(r, o.valueAxis.dim) , l = VV[e.type](n, o.baseDataDim, o.valueDataDim, a, s); e.coord = l[0], e.value = l[1] } else { for (var u = [null != e.xAxis ? e.xAxis : e.radiusAxis, null != e.yAxis ? e.yAxis : e.angleAxis], h = 0; h < 2; h++) VV[u[h]] && (u[h] = HV(n, n.mapDimension(r[h]), u[h])); e.coord = u } } return e } function FV(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 GV(t, e) { return !(t && t.containData && e.coord && !function (t) { return !(isNaN(parseFloat(t.x)) && isNaN(parseFloat(t.y))) }(e)) || t.containData(e.coord) } function WV(t, e) { return t ? function (t, n, i, r) { return pf(r < 2 ? t.coord && t.coord[r] : t.value, e[r]) } : function (t, n, i, r) { return pf(t.value, e[r]) } } function HV(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 YV = So() , UV = 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 = ft() } , e.prototype.render = function (t, e, n) { var i = this , r = this.markerGroupMap; r.each((function (t) { YV(t).keep = !1 } )), e.eachSeries((function (t) { var r = NV.getMarkerModelFromSeries(t, i.type); r && i.renderSeries(t, r, e, n) } )), r.each((function (t) { !YV(t).keep && i.group.remove(t.group) } )) } , e.prototype.markKeep = function (t) { YV(t).keep = !0 } , e.prototype.blurSeries = function (t) { var e = this; E(t, (function (t) { var n = NV.getMarkerModelFromSeries(t, e.type); n && n.getData().eachItemGraphicEl((function (t) { t && bl(t) } )) } )) } , e.type = "marker", e }(fg); function XV(t, e, n) { var i = e.coordinateSystem; t.each((function (r) { var o, a = t.getItemModel(r), s = Er(a.get("x"), n.getWidth()), l = Er(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 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.updateTransform = function (t, e, n) { e.eachSeries((function (t) { var e = NV.getMarkerModelFromSeries(t, "markPoint"); e && (XV(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 Zw) , 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 Zm(i, n) , o = z(n.get("data"), H(BV, e)); t && (o = B(o, H(GV, t))); var a = WV(!!t, i); return r.initData(o, null, a), r }(r, t, e); e.setData(u), XV(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 (U(i) || U(r) || U(o) || U(s)) { var h = e.getRawValue(t) , c = e.getDataParams(t); U(i) && (i = i(h, c)), U(r) && (r = r(h, c)), U(o) && (o = o(h, c)), U(s) && (s = s(h, c)) } var p = n.getModel("itemStyle").getItemStyle() , d = fy(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) { Ws(t).dataModel = e } )) } )), this.markKeep(l), l.group.silent = e.get("silent") || t.get("silent") } , e.type = "markPoint", e }(UV); var jV = 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 }(NV) , qV = So() , KV = 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 = FV(i, o, e, t); s = u.valueAxis, l = HV(o, ex(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 = [BV(t, r[0]), BV(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 $V(t) { return !isNaN(t) && !isFinite(t) } function JV(t, e, n, i) { var r = 1 - t , o = i.dimensions[t]; return $V(e[r]) && $V(n[r]) && e[t] === n[t] && i.getAxis(o).containData(e[t]) } function QV(t, e) { if ("cartesian2d" === t.type) { var n = e[0].coord , i = e[1].coord; if (n && i && (JV(1, n, i, t) || JV(0, n, i, t))) return !0 } return GV(t, e[0]) && GV(t, e[1]) } function tB(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = Er(s.get("x"), r.getWidth()), u = Er(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 (sS(a, "cartesian2d")) { var d = a.getAxis("x") , f = a.getAxis("y"); h = a.dimensions; $V(t.get(h[0], e)) ? o[0] = d.toGlobalCoord(d.getExtent()[n ? 0 : 1]) : $V(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 = NV.getMarkerModelFromSeries(t, "markLine"); if (e) { var i = e.getData() , r = qV(e).from , o = qV(e).to; r.each((function (e) { tB(r, e, !0, t, n), tB(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 dA); 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 Zm(i, n) , o = new Zm(i, n) , a = new Zm([], n) , s = z(n.get("data"), H(KV, e, t, n)); t && (s = B(s, H(QV, t))); var l = WV(!!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; qV(e).from = h, qV(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); tB(e, n, r, t, i); var s = o.getModel("itemStyle").getItemStyle(); null == s.fill && (s.fill = fy(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, n) { t.traverse((function (t) { Ws(t).dataModel = e } )) } )), this.markKeep(l), l.group.silent = e.get("silent") || t.get("silent") } , e.type = "markLine", e }(UV); 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.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 }(NV) , iB = So() , rB = function (t, e, n, i) { var r = BV(t, i[0]) , o = BV(t, i[1]) , a = r.coord , s = o.coord; a[0] = it(a[0], -1 / 0), a[1] = it(a[1], -1 / 0), s[0] = it(s[0], 1 / 0), s[1] = it(s[1], 1 / 0); var l = D([{}, r, o]); return l.coord = [r.coord, o.coord], l.x0 = r.x, l.y0 = r.y, l.x1 = o.x, l.y1 = o.y, l }; function oB(t) { return !isNaN(t) && !isFinite(t) } function aB(t, e, n, i) { var r = 1 - t; return oB(e[r]) && oB(n[r]) } function sB(t, e) { var n = e.coord[0] , i = e.coord[1]; return !!(sS(t, "cartesian2d") && n && i && (aB(1, n, i) || aB(0, n, i))) || (GV(t, { coord: n, x: e.x0, y: e.y0 }) || GV(t, { coord: i, x: e.x1, y: e.y1 })) } function lB(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = Er(s.get(n[0]), r.getWidth()), u = Er(s.get(n[1]), r.getHeight()); if (isNaN(l) || isNaN(u)) { if (i.getMarkerPosition) o = i.getMarkerPosition(t.getValues(n, e)); else { var h = [d = t.get(n[0], e), f = t.get(n[1], e)]; a.clampData && a.clampData(h, h), o = a.dataToPoint(h, !0) } if (sS(a, "cartesian2d")) { var c = a.getAxis("x") , p = a.getAxis("y") , d = t.get(n[0], e) , f = t.get(n[1], e); oB(d) ? o[0] = c.toGlobalCoord(c.getExtent()["x0" === n[0] ? 0 : 1]) : oB(f) && (o[1] = p.toGlobalCoord(p.getExtent()["y0" === n[1] ? 0 : 1])) } isNaN(l) || (o[0] = l), isNaN(u) || (o[1] = u) } else o = [l, u]; return o } var uB = [["x0", "y0"], ["x1", "y0"], ["x1", "y1"], ["x0", "y1"]] , hB = 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 = NV.getMarkerModelFromSeries(t, "markArea"); if (e) { var i = e.getData(); i.each((function (e) { var r = z(uB, (function (r) { return lB(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 Cr }); 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 Zm(r, n) } else i = new Zm(r = [{ name: "value", type: "float" }], n); var s = z(n.get("data"), H(rB, e, t, n)); t && (s = B(s, H(sB, t))); var l = t ? function (t, e, n, i) { return pf(t.coord[Math.floor(i / 2)][i % 2], r[i]) } : function (t, e, n, i) { return pf(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(uB, (function (n) { return lB(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))]; Vr(c), Vr(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 = fy(a, "color"); f.fill || (f.fill = g, X(f.fill) && (f.fill = An(f.fill, .4))), f.stroke || (f.stroke = g), u.setItemVisual(e, "style", f) } )), u.diff(iB(l).data).add((function (t) { var e = u.getItemLayout(t); if (!e.allClipped) { var n = new Lu({ shape: { points: e.points } }); u.setItemGraphicEl(t, n), l.group.add(n) } } )).update((function (t, n) { var i = iB(l).data.getItemGraphicEl(n) , r = u.getItemLayout(t); r.allClipped ? i && l.group.remove(i) : (i ? ih(i, { shape: { points: r.points } }, e, t) : i = new Lu({ shape: { points: r.points } }), u.setItemGraphicEl(t, i), l.group.add(i)) } )).remove((function (t) { var e = iB(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")), Wh(t, Hh(i), { labelFetcher: e, labelDataIndex: n, defaultText: u.getName(n) || "", inheritColor: X(r.fill) ? An(r.fill, 1) : "#000" }), zl(t, i), Ol(t, null, null, i.get(["emphasis", "disabled"])), Ws(t).dataModel = e } )), iB(l).data = u, l.group.silent = e.get("silent") || t.get("silent") } , e.type = "markArea", e }(UV); var cB = 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) { X(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 && _o(i) && e.push(i.name) } )), this._availableNames = n; var i = z(this.get("data") || e, (function (t) { return (X(t) || j(t)) && (t = { name: t }), new pc(t, this, this.ecModel) } ), this); this._data = i } , 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 }(Ip) , pB = H , dB = E , fB = Cr , gB = 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 fB), this.group.add(this._selectorGroup = new fB), 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 = mp(l, u, h) , p = this.layoutInner(t, r, c, i, a, s) , d = mp(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 = UE(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 = ft() , u = e.get("selectedMode") , h = []; n.eachRawSeries((function (t) { !t.get("legendHoverLink") && h.push(t.id) } )), dB(e.getData(), (function (r, o) { var a = r.get("name"); if (!this.newlineDisabled && ("" === a || "\n" === a)) { var c = new fB; 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"); this._createItem(p, a, o, r, e, t, f, y, g, u).on("click", pB(yB, a, null, i, h)).on("mouseover", pB(mB, p.name, null, i, h)).on("mouseout", pB(xB, p.name, null, i, h)), l.set(a, !0) } else n.eachRawSeries((function (n) { if (!l.get(a) && n.legendVisualProvider) { var s = n.legendVisualProvider; if (!s.containName(a)) return; var c = s.indexOfName(a) , p = s.getItemVisual(c, "style") , d = s.getItemVisual(c, "legendIcon") , f = bn(p.fill); f && 0 === f[3] && (f[3] = .2, p = A(A({}, p), { fill: kn(f, "rgba") })), this._createItem(n, a, o, r, e, t, {}, p, d, u).on("click", pB(yB, null, a, i, h)).on("mouseover", pB(mB, null, a, i, h)).on("mouseout", pB(xB, null, a, i, h)), 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(); dB(t, (function (t) { var i = t.type , r = new As({ style: { x: 0, y: 0, align: "center", verticalAlign: "middle" }, onclick: function () { n.dispatchAction({ type: "all" === i ? "legendAllSelect" : "legendInverseSelect" }) } }); o.add(r), Wh(r, { normal: e.getModel("selectorLabel"), emphasis: e.getModel(["emphasis", "selectorLabel"]) }, { defaultText: t.title }), Pl(r) } )) } , e.prototype._createItem = function (t, e, n, i, r, o, a, s, l, u) { var h = t.visualDrawType , c = r.get("itemWidth") , p = r.get("itemHeight") , d = r.isSelected(e) , f = i.get("symbolRotate") , g = i.get("symbolKeepAspect") , y = i.get("icon") , v = function (t, e, n, i, r, o) { function a(t, e) { "auto" === t.lineWidth && (t.lineWidth = e.lineWidth > 0 ? 2 : 0), dB(t, (function (n, i) { "inherit" === t[i] && (t[i] = e[i]) } )) } var s = e.getModel("itemStyle").getItemStyle() , l = 0 === t.lastIndexOf("empty", 0) ? "fill" : "stroke"; s.decal = i.decal, "inherit" === s.fill && (s.fill = i[r]); "inherit" === s.stroke && (s.stroke = i[l]); "inherit" === s.opacity && (s.opacity = ("fill" === r ? i : n).opacity); a(s, i); var u = e.getModel("lineStyle") , h = u.getLineStyle(); if (a(h, n), "auto" === s.fill && (s.fill = i.fill), "auto" === s.stroke && (s.stroke = i.fill), "auto" === h.stroke && (h.stroke = i.fill), !o) { var c = e.get("inactiveBorderWidth") , p = s[l]; s.lineWidth = "auto" === c ? i.lineWidth > 0 && p ? 2 : 0 : s.lineWidth, s.fill = e.get("inactiveColor"), s.stroke = e.get("inactiveBorderColor"), h.stroke = u.get("inactiveColor"), h.lineWidth = u.get("inactiveWidth") } return { itemStyle: s, lineStyle: h } }(l = y || l || "roundRect", i, a, s, h, d) , m = new fB , x = i.getModel("textStyle"); if (!U(t.getLegendIcon) || y && "inherit" !== y) { var _ = "inherit" === y && t.getData().getVisual("symbol") ? "inherit" === f ? t.getData().getVisual("symbolRotate") : f : 0; m.add(function (t) { var e = t.icon || "roundRect" , n = ky(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: c, itemHeight: p, icon: l, iconRotate: _, itemStyle: v.itemStyle, lineStyle: v.lineStyle, symbolKeepAspect: g })) } else m.add(t.getLegendIcon({ itemWidth: c, itemHeight: p, icon: l, iconRotate: f, itemStyle: v.itemStyle, lineStyle: v.lineStyle, symbolKeepAspect: g })); var b = "left" === o ? c + 5 : -5 , w = o , S = r.get("formatter") , M = e; X(S) && S ? M = S.replace("{name}", null != e ? e : "") : U(S) && (M = S(e)); var I = i.get("inactiveColor"); m.add(new As({ style: Yh(x, { text: M, x: b, y: p / 2, fill: d ? x.getTextColor() : I, align: w, verticalAlign: "middle" }) })); var T = new Ts({ shape: m.getBoundingRect(), invisible: !0 }) , C = i.getModel("tooltip"); return C.get("show") && Nh({ el: T, componentModel: r, itemName: e, itemTooltipOption: C.option }), m.add(T), m.eachChild((function (t) { t.silent = !0 } )), T.silent = !u, this.getContentGroup().add(m), Pl(m), m.__legendDataIndex = n, m } , e.prototype.layoutInner = function (t, e, n, i, r, o) { var a = this.getContentGroup() , s = this.getSelectorGroup(); vp(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) { vp("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 }(fg); function yB(t, e, n, i) { xB(t, e, n, i), n.dispatchAction({ type: "legendToggleSelect", name: null != t ? t : e }), mB(t, e, n, i) } function vB(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 mB(t, e, n, i) { vB(n) || n.dispatchAction({ type: "highlight", seriesName: t, name: e, excludeSeriesId: i }) } function xB(t, e, n, i) { vB(n) || n.dispatchAction({ type: "downplay", seriesName: t, name: e, excludeSeriesId: i }) } function _B(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 bB(t, e, n) { var i, r = {}, o = "toggleSelected" === t; return n.eachComponent("legend", (function (n) { o && null != i ? n[i ? "select" : "unSelect"](e.name) : "allSelect" === t || "inverseSelect" === t ? n[t]() : (n[t](e.name), i = n.isSelected(e.name)), E(n.getData(), (function (t) { var e = t.get("name"); if ("\n" !== e && "" !== e) { var i = n.isSelected(e); r.hasOwnProperty(e) ? r[e] = r[e] && i : r[e] = i } } )) } )), "allSelect" === t || "inverseSelect" === t ? { selected: r } : { name: e.name, selected: r } } function wB(t) { t.registerComponentModel(cB), t.registerComponentView(gB), t.registerProcessor(t.PRIORITY.PROCESSOR.SERIES_FILTER, _B), t.registerSubTypeDefaulter("legend", (function () { return "plain" } )), function (t) { t.registerAction("legendToggleSelect", "legendselectchanged", H(bB, "toggleSelected")), t.registerAction("legendAllSelect", "legendselectall", H(bB, "allSelect")), t.registerAction("legendInverseSelect", "legendinverseselect", H(bB, "inverseSelect")), t.registerAction("legendSelect", "legendselected", H(bB, "select")), t.registerAction("legendUnSelect", "legendunselected", H(bB, "unSelect")) }(t) } var SB = 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 = wp(e); t.prototype.init.call(this, e, n, i), MB(this, e, r) } , e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), MB(this, this.option, e) } , e.type = "legend.scroll", e.defaultOption = gc(cB.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 }(cB); function MB(t, e, n) { var i = [1, 1]; i[t.getOrient().index] = 0, bp(e, n, { type: "box", ignoreSize: !!i }) } var IB = Cr , TB = ["width", "height"] , CB = ["x", "y"] , DB = 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 IB), this._containerGroup.add(this.getContentGroup()), this.group.add(this._controllerGroup = new IB) } , 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 = Lh(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 As({ 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 = TB[s] , u = CB[s] , h = TB[1 - s] , c = CB[1 - s]; r && vp("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; vp(t.get("orient"), l, t.get("itemGap"), i ? n.width : null, i ? null : n.height), vp("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 Ts({ shape: x })), u.__rectSize = x[r] } else h.eachChild((function (t) { t.attr({ invisible: !0, silent: !0 }) } )); var _ = this._getPageInfo(t); return null != _.pageIndex && ih(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", X(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 = TB[r] , a = CB[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 }(gB); function AB(t) { _m(wB), t.registerComponentModel(SB), t.registerComponentView(DB), 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 kB = 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 = gc(DE.defaultOption, { disabled: !1, zoomLock: !1, zoomOnMouseWheel: !0, moveOnMouseMove: !0, moveOnMouseWheel: !1, preventDefaultMouseMove: !0 }), e }(DE) , LB = So(); function PB(t, e, n) { LB(t).coordSysRecordMap.each((function (t) { var i = t.dataZoomInfoMap.get(e.uid); i && (i.getRange = n) } )) } function OB(t, e) { if (e) { t.removeKey(e.model.uid); var n = e.controller; n && n.dispose() } } function RB(t, e) { t.isDisposed() || t.dispatchAction({ type: "dataZoom", animation: { easing: "cubicOut", duration: 100 }, batch: e }) } function NB(t, e, n, i) { return t.coordinateSystem.containPoint([n, i]) } function EB(t) { t.registerProcessor(t.PRIORITY.PROCESSOR.FILTER, (function (t, e) { var n = LB(e) , i = n.coordSysRecordMap || (n.coordSysRecordMap = ft()); i.each((function (t) { t.dataZoomInfoMap = null } )), t.eachComponent({ mainType: "dataZoom", subType: "inside" }, (function (t) { E(TE(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(NB, e), dispatchAction: H(RB, t), dataZoomInfoMap: null, controller: null } , i = n.controller = new DI(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 = ft())).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), Dg(t, "dispatchAction", e.model.get("throttle", !0), "fixRate") } else OB(i, t) } )) } )) } var zB = 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(), PB(i, e, { pan: W(VB.pan, this), zoom: W(VB.zoom, this), scrollMove: W(VB.scrollMove, this) })) } , e.prototype.dispose = function () { this._clear(), t.prototype.dispose.apply(this, arguments) } , e.prototype._clear = function () { !function (t, e) { for (var n = LB(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 || OB(n, a)) } } }(this.api, this.dataZoomModel), this.range = null } , e.type = "dataZoom.inside", e }(LE) , VB = { zoom: function (t, e, n, i) { var r = this.range , o = r.slice() , a = t.axisModels[0]; if (a) { var s = FB[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 sk(0, o, [0, 100], 0, h.minSpan, h.maxSpan), this.range = o, r[0] !== o[0] || r[1] !== o[1] ? o : void 0 } }, pan: BB((function (t, e, n, i, r, o) { var a = FB[i]([o.oldX, o.oldY], [o.newX, o.newY], e, r, n); return a.signal * (t[1] - t[0]) * a.pixel / a.pixelLength } )), scrollMove: BB((function (t, e, n, i, r, o) { return FB[i]([0, 0], [o.scrollDelta, o.scrollDelta], e, r, n).signal * (t[1] - t[0]) * o.scrollDelta } )) }; function BB(t) { return function (e, n, i, r) { var o = this.range , a = o.slice() , s = e.axisModels[0]; if (s) return sk(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 FB = { 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 GB(t) { VE(t), t.registerComponentModel(kB), t.registerComponentView(zB), EB(t) } var WB = 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 = gc(DE.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: .5 }, areaStyle: { color: "#d2dbee", opacity: .2 } }, selectedDataBackground: { lineStyle: { color: "#8fb0f7", width: .5 }, areaStyle: { color: "#8fb0f7", opacity: .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: .7 }, showDetail: !0, showDataShadow: "auto", realtime: !0, zoomLock: !1, textStyle: { color: "#6E7079" }, brushSelect: !0, brushStyle: { color: "rgba(135,175,274,0.15)" }, emphasis: { handleStyle: { borderColor: "#8FB0F7" }, moveHandleStyle: { color: "#8FB0F7" } } }), e }(DE) , HB = Ts , YB = "horizontal" , UB = "vertical" , XB = ["line", "bar", "candlestick", "scatter"] , ZB = { easing: "cubicOut", duration: 100, delay: 0 } , jB = 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), Dg(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 () { Ag(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 Cr; 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 === YB ? { 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 = wp(t.option); E(["right", "top", "width", "height"], (function (t) { "ph" === a[t] && (a[t] = o[t]) } )); var s = mp(a, r); this._location = { x: s.x, y: s.y }, this._size = [s.width, s.height], this._orient === UB && 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 !== YB || r ? n === YB && r ? { scaleY: a ? 1 : -1, scaleX: -1 } : n !== UB || 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 HB({ silent: !0, shape: { x: 0, y: 0, width: e[0], height: e[1] }, style: { fill: t.get("backgroundColor") }, z2: -40 })); var r = new HB({ 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() : t.otherDim; if (null != o) { var a = this._shadowPolygonPts , s = this._shadowPolylinePts; if (r !== this._shadowData || o !== this._shadowDim || e[0] !== n[0] || e[1] !== n[1]) { var l = r.getDataExtent(o) , u = .3 * (l[1] - l[0]); l = [l[0] - u, l[1] + u]; var h, c = [0, e[1]], p = [0, e[0]], d = [[e[0], 0], [0, 0]], f = [], g = p[1] / (r.count() - 1), y = 0, v = Math.round(r.count() / e[0]); r.each([o], (function (t, e) { if (v > 0 && e % v) y += g; else { var n = null == t || isNaN(t) || "" === t , i = n ? 0 : Nr(t, l, c, !0); n && !h && e ? (d.push([d[d.length - 1][0], 0]), f.push([f[f.length - 1][0], 0])) : !n && h && (d.push([y, 0]), f.push([y, 0])), d.push([y, i]), f.push([y, i]), y += g, h = n } } )), a = this._shadowPolygonPts = d, s = this._shadowPolylinePts = f } this._shadowData = r, this._shadowDim = o, this._shadowSize = [e[0], e[1]]; for (var m = this.dataZoomModel, x = 0; x < 3; x++) { var _ = b(1 === x); this._displayables.sliderGroup.add(_), this._displayables.dataShadowSegs.push(_) } } } function b(t) { var e = m.getModel(t ? "selectedDataBackground" : "dataBackground") , n = new Cr , i = new Lu({ shape: { points: a }, segmentIgnoreThreshold: 1, style: e.getModel("areaStyle").getAreaStyle(), silent: !0, z2: -20 }) , r = new Ou({ shape: { points: s }, 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(XB, t.get("type")) < 0)) { var a, s = i.getComponent(ME(r), o).axis, l = { x: "y", y: "x", radius: "angle", angle: "radius" }[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 HB({ silent: u, style: { fill: a.get("fillerColor") }, textConfig: { position: "inside" } }); r.add(h), r.add(new HB({ 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"); !Cy[o] && o.indexOf("path://") < 0 && o.indexOf("image://") < 0 && (o = "path://" + o); var s = ky(o, -1, 0, 2, 2, null, !0); s.attr({ cursor: qB(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 = Er(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(), Pl(s); var h = a.get("handleColor"); null != h && (s.style.fill = h), r.add(n[e] = s); var c = a.getModel("textStyle"); t.add(i[e] = new As({ silent: !0, invisible: !0, style: Yh(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 = Er(a.get("moveHandleSize"), o[1]) , d = e.moveHandle = new Ts({ style: a.getModel("moveHandleStyle").getItemStyle(), silent: !0, shape: { r: [0, 0, 2, 2], y: o[1] - .5, height: p } }) , f = .8 * p , g = e.moveHandleIcon = ky(a.get("moveHandleIcon"), -f / 2, -f / 2, f, f, "#fff", !0); g.silent = !0, g.y = o[1] + p / 2 - .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 Ts({ 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: qB(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 = [Nr(t[0], [0, 100], e, !0), Nr(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]; sk(e, i, r, n.get("zoomLock") ? "all" : t, null != o.minSpan ? Nr(o.minSpan, a, r, !0) : null, null != o.maxSpan ? Nr(o.maxSpan, a, r, !0) : null); var s = this._range , l = this._range = Vr([Nr(i[0], r, a, !0), Nr(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 = Vr(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 Ts, 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 = Vr(this._handleEnds.slice()); function c(t) { var e = Mh(n.handles[t].parent, this.group) , a = Th(0 === t ? "right" : "left", e) , s = this._handleWidth / 2 + 5 , l = Ih([h[t] + (0 === t ? -s : s), this._size[1] / 2], e); i[t].setStyle({ x: l[0], y: l[1], verticalAlign: r === YB ? "middle" : a, align: r === YB ? 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 U(i) ? i(t, o) : X(i) ? i.replace("{value}", o) : o } , e.prototype._showDataInfo = function (t) { t = this._dragging || t; var e = this._displayables , n = e.handleLabels; n[0].attr("invisible", !t), n[1].attr("invisible", !t), e.moveHandle && this.api[t ? "enterEmphasis" : "leaveEmphasis"](e.moveHandle, 1) } , e.prototype._onDragMove = function (t, e, n, i) { this._dragging = !0, se(i.event); var r = Ih([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 Ji(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 = Vr([Nr(n.x, i, r, !0), Nr(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 && (se(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 HB({ 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 ? ZB : null, start: e[0], end: e[1] }) } , e.prototype._findCoordRect = function () { var t, e = TE(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: .2 * i, y: .2 * r, width: .6 * i, height: .6 * r } } return t } , e.type = "dataZoom.slider", e }(LE); function qB(t) { return "vertical" === t ? "ns-resize" : "ew-resize" } function KB(t) { t.registerComponentModel(WB), t.registerComponentView(jB), VE(t) } var $B = function (t, e, n) { var i = T((JB[t] || {})[e]); return n && Y(i) ? i[i.length - 1] : i } , JB = { color: { active: ["#006edd", "#e0ffff"], inactive: ["rgba(0,0,0,0)"] }, colorHue: { active: [0, 360], inactive: [0, 0] }, colorSaturation: { active: [.3, 1], inactive: [0, 0] }, colorLightness: { active: [.9, .5], inactive: [0, 0] }, colorAlpha: { active: [.3, 1], inactive: [0, 0] }, opacity: { active: [.3, 1], inactive: [0, 0] }, symbol: { active: ["circle", "roundRect", "diamond"], inactive: ["none"] }, symbolSize: { active: [10, 50], inactive: [0, 0] } } , QB = eD.mapVisual , tF = eD.eachVisual , eF = Y , nF = E , iF = Vr , rF = Nr , oF = 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 && tV(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 = Qz(this.option.controller, e, t), this.targetVisuals = Qz(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 = ho(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 X(s) ? s.replace("{value}", i ? l[0] : l).replace("{value2}", i ? l[1] : l) : U(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 = iF([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) { eF(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] = {}, nF(i, (function (t, e) { if (eD.isValidType(e)) { var n = $B(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"; nF(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 = QB(l.symbol, (function (t) { return "none" === t ? r : t } )); var u = l.symbolSize; if (null != u) { var h = -1 / 0; tF(u, (function (t) { t > h && (h = t) } )), l.symbolSize = QB(u, (function (t) { return rF(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 }(Ip) , aF = [20, 140] , sF = 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] = aF[0]), (null == e[1] || isNaN(e[1])) && (e[1] = aF[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 = Vr((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 = lF(this, "outOfRange", this.getExtent()) , n = lF(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 = gc(oF.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 }(oF); function lF(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 uF = 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 = np(e.get("padding") || 0) , i = t.getBoundingRect(); t.add(new Ts({ 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(eD.prepareVisualTypes(u), (function (i) { var r = u[i]; n.convertOpacityToAlpha && "opacity" === i && (i = "colorAlpha", r = u.__alphaForOpacity), eD.dependsOn(i, e) && r && r.applyVisual(t, s, l) } )), o[e] } , e.prototype.positionGroup = function (t) { var e = this.visualMapModel , n = this.api; xp(t, e.getBoxLayoutParams(), { width: n.getWidth(), height: n.getHeight() }) } , e.prototype.doRender = function (t, e, n, i) { } , e.type = "visualMap", e }(fg) , hF = [["left", "right", "width"], ["top", "bottom", "height"]]; function cF(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 = hF[a], l = [0, null, 10], u = {}, h = 0; h < 3; h++) u[hF[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 = mp(u, o, i.padding); return s[(p.margin[c[2]] || 0) + p[c[0]] + .5 * p[c[1]] < .5 * o[c[1]] ? 0 : 1] } function pF(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 dF = Nr , fF = E , gF = Math.min , yF = Math.max , vF = 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.doRender = function (t, e, n, i) { this._api = n, 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 As({ style: { x: l[0], y: l[1], verticalAlign: "horizontal" === h ? "middle" : u, align: "horizontal" === h ? u : "center", text: i, font: c.getFont(), fill: c.getTextColor() } })) } } , e.prototype._renderBar = function (t) { var e = this.visualMapModel , n = this._shapes , i = e.itemSize , r = this._orient , o = this._useHandle , a = cF(e, this.api, i) , s = n.mainGroup = this._createBarGroup(a) , l = new Cr; s.add(l), l.add(n.outOfRange = mF()), l.add(n.inRange = mF(null, o ? _F(this._orient) : null, W(this._dragHandle, this, "all", !1), W(this._dragHandle, this, "all", !0))), l.setClipPath(new Ts({ shape: { x: 0, y: 0, width: i[0], height: i[1], r: 3 } })); var u = e.textStyleModel.getTextRect("国") , h = yF(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 = gr(t.get("handleSize"), i[0]) , u = ky(t.get("handleIcon"), -l / 2, -l / 2, l, l, null, !0) , h = _F(this._orient); u.attr({ cursor: h, draggable: !0, drift: a, ondragend: s, onmousemove: function (t) { se(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(), Vl(u, !0), e.add(u); var c = this.visualMapModel.textStyleModel , p = new As({ cursor: h, draggable: !0, drift: a, onmousemove: function (t) { se(t.event) }, ondragend: s, style: { x: 0, y: 0, text: "", font: c.getFont(), fill: c.getTextColor() } }); p.ensureState("blur").style = { opacity: .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 = gr(t.get("indicatorSize"), n[0]) , a = ky(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 xs) { 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 As({ silent: !0, invisible: !0, style: { x: 0, y: 0, text: "", font: u.getFont(), fill: u.getTextColor() } }); 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() : xF(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 = [dF(e[0], n, i, !0), dF(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]]; sk(e, i, r, t, 0); var o = n.getExtent(); this._dataInterval = [dF(i[0], r, o, !0), dF(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 Uu(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 Cr("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(); fF([0, 1], (function (l) { var u = r[l]; u.setStyle("fill", e.handlesColor[l]), u.y = t[l]; var h = dF(t[l], [0, a[1]], s, !0) , c = this.getControllerVisual(h, "symbolSize"); u.scaleX = u.scaleY = c / a[0], u.x = a[0] - c / 2; var p = Ih(n.handleLabelPoints[l], Mh(u, this.group)); o[l].setStyle({ x: p[0], y: p[1], text: i.formatValueText(this._dataInterval[l]), 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 = dF(t, o, s, !0) , d = a[0] - c / 2 , f = { x: u.x, y: u.y }; u.y = p, u.x = d; var g = Ih(l.indicatorLabelPoint, Mh(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] = gF(yF(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 = gF(yF(r[0], t), r[1]); var a = function (t, e, n) { var i = 6 , r = t.get("hoverLinkDataSize"); r && (i = dF(r, e, n, !0) / 2); return i }(n, o, r) , s = [t - a, t + a] , l = dF(t, r, o, !0) , u = [dF(s[0], r, o, !0), dF(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 || xF(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 = xo(t[i].seriesId, null); if (null == o) return; for (var a = ho(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", pF(p[0], n)), this._dispatchHighDown("highlight", pF(p[1], n)) } } , e.prototype._hoverLinkFromSeriesMouseOver = function (t) { var e = t.target , n = this.visualMapModel; if (e && null != Ws(e).dataIndex) { var i = Ws(e) , r = this.ecModel.getSeriesByIndex(i.seriesIndex); if (n.isTargetSeries(r)) { var o = r.getData(i.dataType) , a = o.getStore().get(n.getDataDimensionIndex(o), i.dataIndex); isNaN(a) || this._showIndicator(a, a) } } } , 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", pF(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 = Mh(e, i ? null : this.group); return Y(t) ? Ih(t, r, n) : Th(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.prototype.remove = function () { this._clearHoverLinkFromSeries(), this._clearHoverLinkToSeries() } , e.type = "visualMap.continuous", e }(uF); function mF(t, e, n, i) { return new Lu({ shape: { points: t }, draggable: !!n, cursor: e, drift: n, onmousemove: function (t) { se(t.event) }, ondragend: i }) } function xF(t) { var e = t.get("hoverLinkOnHandle"); return !!(null == e ? t.get("realtime") : e) } function _F(t) { return "vertical" === t ? "ns-resize" : "ew-resize" } var bF = { type: "selectDataRange", event: "dataRangeSelected", update: "update" } , wF = function (t, e) { e.eachComponent({ mainType: "visualMap", query: t }, (function (e) { e.setSelected(t.selected) } )) } , SF = [{ 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 = eD.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) { gy(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(MF, null, t, e)) || { stops: [], outerColors: [] } , o = e.getDataDimensionIndex(n); o >= 0 && (r.dimension = o, i.push(r)) } } )), t.getData().setVisual("visualMeta", i) } }]; function MF(t, e, n, i) { for (var r = e.targetVisuals[i], o = eD.prepareVisualTypes(r), a = { color: fy(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 IF = E; function TF(t) { var e = t && t.visualMap; Y(e) || (e = e ? [e] : []), IF(e, (function (t) { if (t) { CF(t, "splitList") && !CF(t, "pieces") && (t.pieces = t.splitList, delete t.splitList); var e = t.pieces; e && Y(e) && IF(e, (function (t) { q(t) && (CF(t, "start") && !CF(t, "min") && (t.min = t.start), CF(t, "end") && !CF(t, "max") && (t.max = t.end)) } )) } } )) } function CF(t, e) { return t && t.hasOwnProperty && t.hasOwnProperty(e) } var DF = !1; function AF(t) { DF || (DF = !0, t.registerSubTypeDefaulter("visualMap", (function (t) { return t.categories || (t.pieces ? t.pieces.length > 0 : t.splitNumber > 0) && !t.calculable ? "piecewise" : "continuous" } )), t.registerAction(bF, wF), E(SF, (function (e) { t.registerVisual(t.PRIORITY.VISUAL.COMPONENT, e) } )), t.registerPreprocessor(TF)) } function kF(t) { t.registerComponentModel(sF), t.registerComponentView(vF), AF(t) } var LF = 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 = [], PF[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 = eD.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] = $B(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 = eD.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) { eD.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 = gc(oF.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 }(oF) , PF = { 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] }), Qr(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), OF(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 = eD.retrieveVisuals(e), t.push(i) } ), this), OF(e, t), Qr(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 OF(t, e) { var n = t.inverse; ("vertical" === t.orient ? !n : n) && e.reverse() } var RF = 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); u && this._renderEndsText(t, u[0], s, h, a), E(l.viewPieceList, (function (i) { var l = i.piece , u = new Cr; u.onclick = W(this._onItemClick, this, l), this._enableHoverLink(u, i.indexInModelPieceList); var c = e.getRepresentValue(l); if (this._createItemSymbol(u, c, [0, 0, s[0], s[1]]), h) { var p = this.visualMapModel.getValueState(c); u.add(new As({ 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" === p ? .5 : 1 } })) } t.add(u) } ), this), u && this._renderEndsText(t, u[1], s, h, a), vp(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: pF(i.findTargetDataIndices(e), i) }) } } , e.prototype._getItemAlign = function () { var t = this.visualMapModel , e = t.option; if ("vertical" === e.orient) return cF(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 Cr , a = this.visualMapModel.textStyleModel; o.add(new As({ style: { x: i ? "right" === r ? n[0] : 0 : n[0] / 2, y: n[1] / 2, verticalAlign: "middle", align: i ? r : "center", text: e, font: a.getFont(), fill: a.getTextColor() } })), 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) { t.add(ky(this.getControllerVisual(e, "symbol"), n[0], n[1], n[2], n[3], this.getControllerVisual(e, "color"))) } , e.prototype._onItemClick = function (t) { var e = this.visualMapModel , n = e.option , i = T(n.selected) , r = e.getSelectedMapKey(t); "single" === n.selectedMode ? (i[r] = !0, E(i, (function (t, e) { i[e] = e === r } ))) : i[r] = !i[r], this.api.dispatchAction({ type: "selectDataRange", from: this.uid, visualMapId: this.visualMapModel.id, selected: i }) } , e.type = "visualMap.piecewise", e }(uF); function NF(t) { t.registerComponentModel(LF), t.registerComponentView(RF), AF(t) } var EF = { label: { enabled: !0 }, decal: { show: !1 } } , zF = So() , VF = {}; function BF(t, e) { var n = t.getModel("aria"); if (n.get("enabled")) { var i = T(EF); C(i.label, t.getLocaleModel().get("aria"), !1), C(n.option, i, !1), function () { if (n.getModel("decal").get("show")) { var e = ft(); t.eachSeries((function (t) { if (!t.isColorBySeries()) { var n = e.get(t.type); n || (n = {}, e.set(t.type, n)), zF(t).scope = n } } )), t.eachRawSeries((function (e) { if (!t.isSeriesFiltered(e)) if (U(e.enableAriaDecal)) e.enableAriaDecal(); else { var n = e.getData(); if (e.isColorBySeries()) { var i = td(e.ecModel, e.name, VF, t.getSeriesCount()) , r = n.getVisual("decal"); n.setVisual("decal", u(r, i)) } else { var o = e.getRawData() , a = {} , s = zF(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 = td(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 = t.getLocaleModel().get("aria") , o = n.getModel("label"); if (o.option = k(o.option, i), !o.get("enabled")) return; var a = e.getZr().dom; if (o.get("description")) return void a.setAttribute("aria-label", o.get("description")); var s, l = t.getSeriesCount(), u = o.get(["data", "maxCount"]) || 10, h = o.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 }(); if (p) { var d = o.get(["general", "withTitle"]); s = r(d, { title: p }) } else s = o.get(["general", "withoutTitle"]); var f = [] , g = l > 1 ? o.get(["series", "multiple", "prefix"]) : o.get(["series", "single", "prefix"]); s += r(g, { seriesCount: l }), t.eachSeries((function (e, n) { if (n < c) { var i = void 0 , a = e.get("name") ? "withName" : "withoutName"; i = r(i = l > 1 ? o.get(["series", "multiple", a]) : o.get(["series", "single", a]), { seriesId: e.seriesIndex, seriesName: e.get("name"), seriesType: (x = e.subType, t.getLocaleModel().get(["series", "typeNames"])[x] || "自定义图") }); var s = e.getData(); if (s.count() > u) i += r(o.get(["data", "partialData"]), { displayCnt: u }); else i += o.get(["data", "allData"]); for (var h = o.get(["data", "separator", "middle"]), p = o.get(["data", "separator", "end"]), d = [], g = 0; g < s.count(); g++) if (g < u) { var y = s.getName(g) , v = s.getValues(g) , m = o.get(["data", y ? "withName" : "withoutName"]); d.push(r(m, { name: y, value: v.join(h) })) } i += d.join(h) + p, f.push(i) } var x } )); var y = o.getModel(["series", "multiple", "separator"]) , v = y.get("middle") , m = y.get("end"); s += f.join(v) + m, a.setAttribute("aria-label", s) }() } function r(t, e) { if (!X(t)) return t; var n = t; return E(e, (function (t, e) { n = n.replace(new RegExp("\\{\\s*" + e + "\\s*\\}", "g"), t) } )), n } } function FF(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 GF = { value: "eq", "<": "lt", "<=": "lte", ">": "gt", ">=": "gte", "=": "eq", "!=": "ne", "<>": "ne" } , WF = function () { function t(t) { if (null == (this._condVal = X(t) ? new RegExp(t) : et(t) ? t : null)) { var e = ""; 0, ao(e) } } return t.prototype.evaluate = function (t) { var e = typeof t; return X(e) ? this._condVal.test(t) : !!j(e) && this._condVal.test(t + "") } , t }() , HF = function () { function t() { } return t.prototype.evaluate = function () { return this.value } , t }() , YF = 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 }() , UF = 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 }() , XF = function () { function t() { } return t.prototype.evaluate = function () { return !this.child.evaluate() } , t }() , ZF = 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 jF(t, e) { if (!0 === t || !1 === t) { var n = new HF; return n.value = t, n } var i = ""; return KF(t) || ao(i), t.and ? qF("and", t, e) : t.or ? qF("or", t, e) : t.not ? function (t, e) { var n = t.not , i = ""; 0; KF(n) || ao(i); var r = new XF; r.child = jF(n, e), r.child || ao(i); return r }(t, e) : function (t, e) { for (var n = "", i = e.prepareGetValue(t), r = [], o = G(t), a = t.parser, s = a ? ff(a) : null, l = 0; l < o.length; l++) { var u = o[l]; if ("parser" !== u && !e.valueGetterAttrMap.get(u)) { var h = mt(GF, u) ? GF[u] : u , c = t[u] , p = s ? s(c) : c , d = xf(h, p) || "reg" === h && new WF(p); d || ao(n), r.push(d) } } r.length || ao(n); var f = new ZF; return f.valueGetterParam = i, f.valueParser = s, f.getValue = e.getValue, f.subCondList = r, f }(t, e) } function qF(t, e, n) { var i = e[t] , r = ""; Y(i) || ao(r), i.length || ao(r); var o = "and" === t ? new YF : new UF; return o.children = z(i, (function (t) { return jF(t, n) } )), o.children.length || ao(r), o } function KF(t) { return q(t) && !N(t) } var $F = function () { function t(t, e) { this._cond = jF(t, e) } return t.prototype.evaluate = function () { return this._cond.evaluate() } , t }(); var JF = { type: "echarts:filter", transform: function (t) { for (var e, n, i, r = t.upstream, o = (n = t.config, i = { valueGetterAttrMap: ft({ dimension: !0 }), prepareGetValue: function (t) { var e = "" , n = t.dimension; mt(t, "dimension") || ao(e); var i = r.getDimensionInfo(n); return i || ao(e), { dimIdx: i.index } }, getValue: function (t) { return r.retrieveValueFromItem(e, t.dimIdx) } }, new $F(n, i)), a = [], s = 0, l = r.count(); s < l; s++) e = r.getRawDataItem(s), o.evaluate() && a.push(e); return { data: a } } }; var QF = { type: "echarts:sort", transform: function (t) { var e = t.upstream , n = t.config , i = "" , r = ho(n); r.length || ao(i); var o = []; E(r, (function (t) { var n = t.dimension , r = t.order , a = t.parser , s = t.incomparable; if (null == n && ao(i), "asc" !== r && "desc" !== r && ao(i), s && "min" !== s && "max" !== s) { var l = ""; 0, ao(l) } if ("asc" !== r && "desc" !== r) { var u = ""; 0, ao(u) } var h = e.getDimensionInfo(n); h || ao(i); var c = a ? ff(a) : null; a && !c && ao(i), o.push({ dimIdx: h.index, parser: c, comparator: new vf(r, s) }) } )); var a = e.sourceFormat; a !== Lp && a !== Pp && ao(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 tG = 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 Vf(this), Bf(this) } , e.prototype.mergeOption = function (e, n) { t.prototype.mergeOption.call(this, e, n), Bf(this) } , e.prototype.optionUpdated = function () { this._sourceManager.dirty() } , e.prototype.getSourceManager = function () { return this._sourceManager } , e.type = "dataset", e.defaultOption = { seriesLayoutBy: Ep }, e }(Ip) , eG = 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 }(fg); var nG = ja.CMD; function iG(t, e) { return Math.abs(t - e) < 1e-5 } function rG(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) { iG(t, i) && iG(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 !== nG.L && v !== nG.C && v !== nG.Q || (e = [c, p])), v) { case nG.M: u = c = a[y++], h = p = a[y++], d(c, p); break; case nG.L: f(u, h, n = a[y++], i = a[y++]), u = n, h = i; break; case nG.C: e.push(a[y++], a[y++], a[y++], a[y++], u = a[y++], h = a[y++]); break; case nG.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 nG.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 nG.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 nG.Z: e && f(u, h, c, p), u = c, h = p } } return e && e.length > 2 && l.push(e), l } function oG(t, e, n, i, r, o, a, s, l, u) { if (iG(t, n) && iG(e, i) && iG(r, a) && iG(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 = []; Ze(t, n, r, a, .5, S), Ze(e, i, o, s, .5, M), oG(S[0], M[0], S[1], M[1], S[2], M[2], S[3], M[3], l, u), oG(S[4], M[4], S[5], M[5], S[6], M[6], S[7], M[7], l, u) } } } } function aG(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 sG(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 = aG([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 lG(t, e, n, i) { return t * i - n * e } function uG(t, e, n, i, r, o, a, s) { var l = n - t , u = i - e , h = a - r , c = s - o , p = lG(h, c, l, u); if (Math.abs(p) < 1e-6) return null; var d = lG(t - r, e - o, h, c) / p; return d < 0 || d > 1 ? null : new Ji(d * l + t, d * u + e) } function hG(t, e, n) { var i = new Ji; Ji.sub(i, n, e), i.normalize(); var r = new Ji; return Ji.sub(r, t, e), r.dot(i) } function cG(t, e) { var n = t[t.length - 1]; n && n[0] === e[0] && n[1] === e[1] || t.push(e) } function pG(t) { var e = t.points , n = [] , i = []; Ma(e, n, i); var r = new sr(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 Ji , h = new Ji; 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 = uG(a[0], a[1], s[0], s[1], e.x, e.y, n.x, n.y); l && r.push({ projPt: hG(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++) cG(f, t[o].slice()); for (cG(f, d), cG(f, p), o = h.idx + 1; o <= u.idx + i; o++) cG(g, t[o % i].slice()); return cG(g, p), cG(g, d), [{ points: f }, { points: g }] }(e, u, h) } function dG(t, e, n, i) { if (1 === n) i.push(e); else { var r = Math.floor(n / 2) , o = t(e); dG(t, o[0], r, i), dG(t, o[1], n - r, i) } return i } function fG(t, e) { e.setStyle(t.style), e.z = t.z, e.z2 = t.z2, e.zlevel = t.zlevel } function gG(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 = aG([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 = Ts; break; case "sector": sG(r, e, i), n = Tu; break; case "circle": sG({ r0: 0, r: r.r, startAngle: 0, endAngle: 2 * Math.PI, cx: r.cx, cy: r.cy }, e, i), n = Tu; 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 = rG(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++]; oG(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) dG(pG, { 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 = []; Ma(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 || (dG(pG, { points: d.poly }, f, i), p -= f) } } n = Lu } if (!n) return function (t, e) { for (var n = [], i = 0; i < e; i++) n.push(su(t)); return n }(t, e); var g = []; for (u = 0; u < i.length; u++) { var y = new n; y.setShape(i[u]), fG(t, y), g.push(y) } return g } function yG(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; Ze(f, y, m, _, M, r), Ze(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 vG(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 mG(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 xG(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 _G(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 bG(t) { return t.__isCombineMorphing } var wG = "__mOriginal_"; function SG(t, e, n) { var i = wG + 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 MG(t, e) { var n = wG + e; t[n] && (t[e] = t[n], t[n] = null) } function IG(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 TG(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 = yG(l, u))[0], r = c = n[1]) : (c = vG(r || l, l), h = l) : (h = vG(i || u, u), c = u), o.push(h), a.push(c) } return [o, a] }(rG(n), rG(i)) , o = r[0] , a = r[1] , s = t.getComputedTransform() , l = e.getComputedTransform(); s && IG(o, s), l && IG(a, l), SG(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 = mG(s) , h = mG(l); null == r && (r = u[2] < 0 != h[2] < 0); var c = [] , p = [] , d = 0 , f = 1 / 0 , g = [] , y = s.length; r && (s = _G(s)); for (var v = 6 * xG(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 = []; SG(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); Bt(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 CG(t, e, n) { if (!t || !e) return e; var i = n.done , r = n.during; return TG(t, e), e.__morphT = 0, e.animateTo({ __morphT: 1 }, k({ during: function (t) { e.dirtyShape(), r && r(t) }, done: function () { MG(e, "buildPath"), MG(e, "updateTransform"), e.__morphT = -1, e.createPathProxy(), e.dirtyShape(), i && i() } }, n)), e } function DG(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 AG(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: DG(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 kG(t) { return gG(t.path, t.count) } function LG(t) { return Y(t[0]) } function PG(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 OG = { 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 = su(t.path); r.setStyle("opacity", n), e.push(r) } return e }, split: null }; function RG(t, e, n, i, r, o) { if (t.length && e.length) { var a = eh("update", i, r); if (a && a.duration > 0) { var s, l, u = i.getModel("universalTransition").get("delay"), h = Object.assign({ setToFinal: !0 }, a); LG(t) && (s = t, l = e), LG(e) && (s = e, l = t); for (var c = s ? s === t : t.length > e.length, p = s ? PG(l, s) : PG(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: OG[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]; bG(r) ? t(r.childrenRef()) : r instanceof fs && i.push(r) } }(t); var r = i.length; if (!r) return { fromIndividuals: [], toIndividuals: [], count: 0 }; var o = (n.dividePath || kG)({ path: e, count: r }); if (o.length !== r) return console.error("Invalid morphing: unmatched splitted path"), { fromIndividuals: [], toIndividuals: [], count: 0 }; i = AG(i), o = AG(o); for (var a = n.done, s = n.during, l = n.individualDelay, u = new qi, h = 0; h < r; h++) { var c = i[h] , p = o[h]; p.parent = e, p.copyTransform(u), l || TG(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, MG(e, "addSelfToZr"), MG(e, "removeSelfFromZr") } e.__isCombineMorphing = !0, e.childrenRef = function () { return o } , SG(e, "addSelfToZr", { after: function (t) { d(t) } }), SG(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; CG(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++) MG(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 || kG; if (bG(t)) { !function t(e) { for (var n = 0; n < e.length; n++) { var i = e[n]; bG(i) ? t(i.childrenRef()) : i instanceof fs && r.push(i) } }(t.childrenRef()); var a = r.length; if (a < i) for (var s = 0, l = a; l < i; l++) r.push(su(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 = AG(r), e = AG(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; CG(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 (bG(x)) y({ many: [x], one: _ }, !0, i, r, !0); else CG(x, _, m = u ? k({ delay: u(i, r) }, h) : h), o(x, _, x, _, m) } } } function NG(t) { if (!t) return []; if (Y(t)) { for (var e = [], n = 0; n < t.length; n++) e.push(NG(t[n])); return e } var i = []; return t.traverse((function (t) { t instanceof fs && !t.disableMorphing && !t.invisible && !t.ignore && i.push(t) } )), i } var EG = So(); function zG(t) { var e = []; return E(t, (function (t) { var n = t.data; if (!(n.count() > 1e4)) for (var i = n.getIndices(), r = function (t) { for (var e = t.dimensions, n = 0; n < e.length; n++) { var i = t.getDimensionInfo(e[n]); if (i && 0 === i.otherDims.itemGroupId) return e[n] } }(n), o = 0; o < i.length; o++) e.push({ data: n, dim: t.dim || r, divide: t.divide, dataIndex: o }) } )), e } function VG(t, e, n) { t.traverse((function (t) { t instanceof fs && rh(t, { style: { opacity: 0 } }, e, { dataIndex: n, isFrom: !0 }) } )) } function BG(t) { if (t.parent) { var e = t.getComputedTransform(); t.setLocalTransform(e), t.parent.remove(t) } } function FG(t) { t.stopAnimation(), t.isGroup && t.traverse((function (t) { t.stopAnimation() } )) } function GG(t, e, n) { var i = eh("update", n, e); i && t.traverse((function (t) { if (t instanceof da) { var e = function (t) { return th(t).oldStyle }(t); e && t.animateFrom({ style: e }, i) } } )) } function WG(t, e, n) { var i = zG(t) , r = zG(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) } function a(t) { for (var e = 0; e < t.length; e++) if (t[e].dim) return t[e].dim } var s = a(i) , l = a(r) , u = !1; function h(t, e) { return function (n) { var i = n.data , r = n.dataIndex; if (e) return i.getId(r); var o = i.hostModel && i.hostModel.get("dataGroupId") , a = t ? s || l : l || s , u = a && i.getDimensionInfo(a) , h = u && u.ordinalMeta; if (u) { var c = i.get(u.name, r); return h && h.categories[c] || c + "" } var p = i.getRawDataItem(r); return p && p.groupId ? p.groupId + "" : o || i.getId(r) } } var c = 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) , p = {}; if (!c) for (var d = 0; d < r.length; d++) { var f = r[d] , g = f.data.getItemGraphicEl(f.dataIndex); g && (p[g.id] = !0) } function y(t, e) { var n = i[e] , a = r[t] , s = a.data.hostModel , l = n.data.getItemGraphicEl(n.dataIndex) , h = a.data.getItemGraphicEl(a.dataIndex); l !== h ? l && p[l.id] || h && (FG(h), l ? (FG(l), BG(l), u = !0, RG(NG(l), NG(h), a.divide, s, t, o)) : VG(h, s, t)) : h && GG(h, a.dataIndex, s) } new Sm(i, r, h(!0, c), h(!1, c), null, "multiple").update(y).updateManyToOne((function (t, e) { var n = r[t] , a = n.data , s = a.hostModel , l = a.getItemGraphicEl(n.dataIndex) , h = B(z(e, (function (t) { return i[t].data.getItemGraphicEl(i[t].dataIndex) } )), (function (t) { return t && t !== l && !p[t.id] } )); l && (FG(l), h.length ? (E(h, (function (t) { FG(t), BG(t) } )), u = !0, RG(NG(h), NG(l), n.divide, s, t, o)) : VG(l, s, n.dataIndex)) } )).updateOneToMany((function (t, e) { var n = i[e] , a = n.data.getItemGraphicEl(n.dataIndex); if (!a || !p[a.id]) { var s = B(z(t, (function (t) { return r[t].data.getItemGraphicEl(r[t].dataIndex) } )), (function (t) { return t && t !== a } )) , l = r[t[0]].data.hostModel; s.length && (E(s, (function (t) { return FG(t) } )), a ? (FG(a), BG(a), u = !0, RG(NG(a), NG(s), n.divide, l, t[0], o)) : E(s, (function (e) { return VG(e, l, t[0]) } ))) } } )).updateManyToMany((function (t, e) { new Sm(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) { y(t[n], e[i]) } )).execute() } )).execute(), u && E(e, (function (t) { var e = t.data.hostModel , i = e && n.getViewOfSeriesModel(e) , r = eh("update", e, 0); i && e.isAnimationEnabled() && r && r.duration > 0 && i.group.traverse((function (t) { t instanceof fs && !t.animators.length && t.animateFrom({ style: { opacity: 0 } }, r) } )) } )) } function HG(t) { var e = t.getModel("universalTransition").get("seriesKey"); return e || t.id } function YG(t) { return Y(t) ? t.sort().join(",") : t } function UG(t) { if (t.hostModel) return t.hostModel.getModel("universalTransition").get("divideShape") } function XG(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 } } _m([function (t) { t.registerPainter("canvas", Vw) } ]), _m([function (t) { t.registerPainter("svg", Lw) } ]), _m([function (t) { t.registerChartView(mS), t.registerSeriesModel(Bw), 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, wS("line")) } , function (t) { t.registerChartView(LS), t.registerSeriesModel(MS), t.registerLayout(t.PRIORITY.VISUAL.LAYOUT, H(Dx, "bar")), t.registerLayout(t.PRIORITY.VISUAL.PROGRESSIVE_LAYOUT, Ax("bar")), t.registerProcessor(t.PRIORITY.PROCESSOR.STATISTIC, wS("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(aM), t.registerSeriesModel(uM), yy("pie", t.registerAction), t.registerLayout(H($S, "pie")), t.registerProcessor(JS("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) { _m(hI), t.registerSeriesModel(hM), t.registerChartView(fM), t.registerLayout(xS("scatter")) } , function (t) { _m(MI), t.registerChartView(gI), t.registerSeriesModel(yI), t.registerLayout(cI), t.registerProcessor(JS("radar")), t.registerPreprocessor(fI) } , function (t) { _m(JT), t.registerChartView(RT), t.registerSeriesModel(NT), t.registerLayout(zT), t.registerProcessor(t.PRIORITY.PROCESSOR.STATISTIC, ET), yy("map", t.registerAction) } , function (t) { t.registerChartView(hC), t.registerSeriesModel(PC), t.registerLayout(RC), t.registerVisual(NC), 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) { e.eachComponent({ mainType: "series", subType: "tree", query: t }, (function (e) { var n = qT(e.coordinateSystem, t); e.setCenter && e.setCenter(n.center), e.setZoom && e.setZoom(n.zoom) } )) } )) }(t) } , function (t) { t.registerSeriesModel(VC), t.registerChartView($C), t.registerVisual(fD), t.registerLayout(CD), function (t) { for (var e = 0; e < EC.length; e++) t.registerAction({ type: EC[e], update: "updateView" }, xt); t.registerAction({ type: "treemapRootToNode", update: "updateView" }, (function (t, e) { e.eachComponent({ mainType: "series", subType: "treemap", query: t }, (function (e, n) { var i = DC(t, ["treemapZoomToNode", "treemapRootToNode"], e); if (i) { var r = e.getViewRoot(); r && (t.direction = kC(r, i.node) ? "rollUp" : "drillDown"), e.resetViewRoot(i.node) } } )) } )) }(t) } , function (t) { t.registerChartView(TA), t.registerSeriesModel(OA), t.registerProcessor(OD), t.registerVisual(RD), t.registerVisual(ED), t.registerLayout(XD), t.registerLayout(t.PRIORITY.VISUAL.POST_CHART_LAYOUT, QD), t.registerLayout(eA), t.registerCoordinateSystem("graphView", { dimensions: BT.dimensions, create: nA }), t.registerAction({ type: "focusNodeAdjacency", event: "focusNodeAdjacency", update: "series:focusNodeAdjacency" }, xt), t.registerAction({ type: "unfocusNodeAdjacency", event: "unfocusNodeAdjacency", update: "series:unfocusNodeAdjacency" }, xt), t.registerAction(RA, (function (t, e) { e.eachComponent({ mainType: "series", query: t }, (function (e) { var n = qT(e.coordinateSystem, t); e.setCenter && e.setCenter(n.center), e.setZoom && e.setZoom(n.zoom) } )) } )) } , function (t) { t.registerChartView(BA), t.registerSeriesModel(FA) } , function (t) { t.registerChartView(HA), t.registerSeriesModel(YA), t.registerLayout(UA), t.registerProcessor(JS("funnel")) } , function (t) { _m(vL), t.registerChartView(XA), t.registerSeriesModel($A), t.registerVisual(t.PRIORITY.VISUAL.BRUSH, tk) } , function (t) { t.registerChartView(_L), t.registerSeriesModel(bL), t.registerLayout(wL), t.registerVisual(RL), 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(EL), t.registerChartView(zL), t.registerVisual(HL), t.registerLayout(UL), t.registerTransform(XL) } , function (t) { t.registerChartView(jL), t.registerSeriesModel(oP), t.registerPreprocessor(aP), t.registerVisual(cP), t.registerLayout(pP) } , function (t) { t.registerChartView(yP), t.registerSeriesModel(vP), t.registerLayout(xS("effectScatter")) } , function (t) { t.registerChartView(IP), t.registerSeriesModel(AP), t.registerLayout(MP), t.registerVisual(LP) } , function (t) { t.registerChartView(RP), t.registerSeriesModel(NP) } , function (t) { t.registerChartView(BP), t.registerSeriesModel(iO), t.registerLayout(t.PRIORITY.VISUAL.LAYOUT, H(Dx, "pictorialBar")), t.registerLayout(t.PRIORITY.VISUAL.PROGRESSIVE_LAYOUT, Ax("pictorialBar")) } , function (t) { t.registerChartView(rO), t.registerSeriesModel(oO), t.registerLayout(aO), t.registerProcessor(JS("themeRiver")) } , function (t) { t.registerChartView(cO), t.registerSeriesModel(pO), t.registerLayout(H(gO, "sunburst")), t.registerProcessor(H(JS, "sunburst")), t.registerVisual(vO), function (t) { t.registerAction({ type: uO, update: "updateView" }, (function (t, e) { e.eachComponent({ mainType: "series", subType: "sunburst", query: t }, (function (e, n) { var i = DC(t, [uO], e); if (i) { var r = e.getViewRoot(); r && (t.direction = kC(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 = DC(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(lR), t.registerSeriesModel(bO) } ]), _m((function (t) { _m(hI), _m(lN) } )), _m((function (t) { _m(lN), JM.registerAxisPointerClass("PolarAxisPointer", uN), t.registerCoordinateSystem("polar", SN), t.registerComponentModel(cN), t.registerComponentView(BN), wM(t, "angle", dN, zN), wM(t, "radius", fN, VN), t.registerComponentView(DN), t.registerComponentView(PN), t.registerLayout(H(EN, "bar")) } )), _m(JT), _m((function (t) { _m(lN), JM.registerAxisPointerClass("SingleAxisPointer", QN), t.registerComponentView(iE), t.registerComponentView(HN), t.registerComponentModel(UN), wM(t, "single", UN, UN.defaultOption), t.registerCoordinateSystem("single", KN) } )), _m(vL), _m((function (t) { t.registerComponentModel(rE), t.registerComponentView(aE), t.registerCoordinateSystem("calendar", lE) } )), _m((function (t) { t.registerComponentModel(fE), t.registerComponentView(vE), 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] }]) } )) } )), _m((function (t) { t.registerComponentModel(YE), t.registerComponentView(XE), WE("saveAsImage", ZE), WE("magicType", KE), WE("dataView", iz), WE("dataZoom", Iz), WE("restore", lz), _m(BE) } )), _m((function (t) { _m(lN), t.registerComponentModel(Dz), t.registerComponentView(Uz), t.registerAction({ type: "showTip", event: "showTip", update: "tooltip:manuallyShowTip" }, xt), t.registerAction({ type: "hideTip", event: "hideTip", update: "tooltip:manuallyHideTip" }, xt) } )), _m(lN), _m((function (t) { t.registerComponentView(dV), t.registerComponentModel(fV), t.registerPreprocessor(Kz), t.registerVisual(t.PRIORITY.VISUAL.BRUSH, lV), 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" }, xt), t.registerAction({ type: "brushEnd", event: "brushEnd", update: "none" }, xt), WE("brush", vV) } )), _m((function (t) { t.registerComponentModel(mV), t.registerComponentView(xV) } )), _m((function (t) { t.registerComponentModel(bV), t.registerComponentView(TV), 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(AV) } )), _m((function (t) { t.registerComponentModel(EV), t.registerComponentView(ZV), t.registerPreprocessor((function (t) { PV(t.series, "markPoint") && (t.markPoint = t.markPoint || {}) } )) } )), _m((function (t) { t.registerComponentModel(jV), t.registerComponentView(eB), t.registerPreprocessor((function (t) { PV(t.series, "markLine") && (t.markLine = t.markLine || {}) } )) } )), _m((function (t) { t.registerComponentModel(nB), t.registerComponentView(hB), t.registerPreprocessor((function (t) { PV(t.series, "markArea") && (t.markArea = t.markArea || {}) } )) } )), _m((function (t) { _m(wB), _m(AB) } )), _m((function (t) { _m(GB), _m(KB) } )), _m(GB), _m(KB), _m((function (t) { _m(kF), _m(NF) } )), _m(kF), _m(NF), _m((function (t) { t.registerPreprocessor(FF), t.registerVisual(t.PRIORITY.VISUAL.ARIA, BF) } )), _m((function (t) { t.registerTransform(JF), t.registerTransform(QF) } )), _m((function (t) { t.registerComponentModel(tG), t.registerComponentView(eG) } )), _m((function (t) { t.registerUpdateLifecycle("series:beforeupdate", (function (t, e, n) { E(ho(n.seriesTransition), (function (t) { E(ho(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].__universalTransitionEnabled = !0) } )) } )) } )), t.registerUpdateLifecycle("series:transition", (function (t, e, n) { var i = EG(e); if (i.oldSeries && n.updatedSeries && n.optionChanged) { var r = n.seriesTransition; if (r) E(ho(r), (function (t) { !function (t, e, n, i) { var r = [] , o = []; E(ho(t.from), (function (t) { var n = XG(e.oldSeries, t); n >= 0 && r.push({ data: e.oldData[n], divide: UG(e.oldData[n]), dim: t.dimension }) } )), E(ho(t.to), (function (t) { var e = XG(n.updatedSeries, t); if (e >= 0) { var i = n.updatedSeries[e].getData(); o.push({ data: i, divide: UG(i), dim: t.dimension }) } } )), r.length > 0 && o.length > 0 && WG(r, o, i) }(t, i, n, e) } )); else { var o = function (t, e) { var n = ft() , i = ft() , r = ft(); return E(t.oldSeries, (function (e, n) { var o = t.oldData[n] , a = HG(e) , s = YG(a); i.set(s, o), Y(a) && E(a, (function (t) { r.set(t, { data: o, key: s }) } )) } )), E(e.updatedSeries, (function (t) { if (t.isUniversalTransitionEnabled() && t.isAnimationEnabled()) { var e = t.getData() , o = HG(t) , a = YG(o) , s = i.get(a); if (s) n.set(a, { oldSeries: [{ divide: UG(s), data: s }], newSeries: [{ divide: UG(e), data: e }] }); else if (Y(o)) { var l = []; E(o, (function (t) { var e = i.get(t); e && l.push({ divide: UG(e), data: e }) } )), l.length && n.set(a, { oldSeries: l, newSeries: [{ data: e, divide: UG(e) }] }) } else { var u = r.get(o); if (u) { var h = n.get(u.key); h || (h = { oldSeries: [{ data: u.data, divide: UG(u.data) }], newSeries: [] }, n.set(u.key, h)), h.newSeries.push({ data: e, divide: UG(e) }) } } } } )), n }(i, n); E(o.keys(), (function (t) { var n = o.get(t); WG(n.oldSeries, n.newSeries, e) } )) } E(n.updatedSeries, (function (t) { t.__universalTransitionEnabled && (t.__universalTransitionEnabled = !1) } )) } for (var a = t.getSeries(), s = i.oldSeries = [], l = i.oldData = [], u = 0; u < a.length; u++) { var h = a[u].getData(); h.count() < 1e4 && (s.push(a[u]), l.push(h)) } } )) } )), _m((function (t) { t.registerUpdateLifecycle("series:beforeupdate", (function (t, e, n) { var i = Tb(e).labelManager; i || (i = Tb(e).labelManager = new Ib), i.clearLabels() } )), t.registerUpdateLifecycle("series:layoutlabels", (function (t, e, n) { var i = Tb(e).labelManager; n.updatedSeries.forEach((function (t) { i.addLabelsOfSeries(e.getViewOfSeriesModel(t)) } )), i.updateLayoutConfig(e), i.layout(e), i.processLabelsOverall() } )) } )), t.Axis = G_, t.ChartView = mg, t.ComponentModel = Ip, t.ComponentView = fg, t.List = Zm, t.Model = pc, t.PRIORITY = pv, t.SeriesModel = ag, t.color = Pn, 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_" + Jv++, E(e, (function (e) { e.group = t } )) } return Kv[t] = !0, t } , t.dataTool = {}, t.dependencies = { zrender: "5.3.0" }, t.disConnect = tm, t.disconnect = em, t.dispose = function (t) { X(t) ? t = qv[t] : t instanceof Vv || (t = nm(t)), t instanceof Vv && !t.isDisposed() && t.dispose() } , t.env = r, t.extendChartView = function (t) { var e = mg.extend(t); return mg.registerClass(e), e } , t.extendComponentModel = function (t) { var e = Ip.extend(t); return Ip.registerClass(e), e } , t.extendComponentView = function (t) { var e = fg.extend(t); return fg.registerClass(e), e } , t.extendSeriesModel = function (t) { var e = ag.extend(t); return ag.registerClass(e), e } , t.format = A_, t.getCoordinateSystemDimensions = function (t) { var e = ud.get(t); if (e) return e.getDimensionsInfo ? e.getDimensionsInfo() : e.dimensions.slice() } , t.getInstanceByDom = nm, t.getInstanceById = function (t) { return qv[t] } , t.getMap = function (t) { var e = lv("getMap"); return e && e(t) } , t.graphic = D_, t.helper = p_, t.init = function (t, e, n) { var i = !(n && n.ssr); if (i) { 0; var r = nm(t); if (r) return r; 0 } var o = new Vv(t, e, n); return o.id = "ec_" + $v++, qv[o.id] = o, i && ko(t, Qv, o.id), Ov(o), av.trigger("afterinit", o), o } , t.innerDrawElementOnCanvas = $y, t.matrix = Gi, t.number = T_, t.parseGeoJSON = I_, t.parseGeoJson = I_, t.registerAction = um, t.registerCoordinateSystem = hm, t.registerLayout = cm, t.registerLoading = gm, t.registerLocale = wc, t.registerMap = ym, t.registerPostInit = am, t.registerPostUpdate = sm, t.registerPreprocessor = rm, t.registerProcessor = om, t.registerTheme = im, t.registerTransform = vm, t.registerUpdateLifecycle = lm, t.registerVisual = pm, t.setCanvasCreator = function (t) { c({ createCanvas: t }) } , t.setPlatformAPI = c, t.throttle = Cg, t.time = C_, t.use = _m, t.util = k_, t.vector = Ht, t.version = "5.3.0", t.zrUtil = bt, t.zrender = Or, Object.defineProperty(t, "__esModule", { value: !0 }) } ));