!(function (t, e) { 'object' == typeof exports && 'undefined' != typeof module ? e(exports) : 'function' == typeof define && define.amd ? define(['exports'], e) : e((t.echarts = {})); })(this, function (t) { 'use strict'; function e(t, e) { Od[t] = e; } function n(t) { if (null == t || 'object' != typeof t) return t; var e = t, i = Td.call(t); if ('[object Array]' === i) { e = []; for (var r = 0, o = t.length; r < o; r++) e[r] = n(t[r]); } else if (Id[i]) { var a = t.constructor; if (t.constructor.from) e = a.from(t); else { e = new a(t.length); for (var r = 0, o = t.length; r < o; r++) e[r] = n(t[r]); } } else if (!Sd[i] && !L(t) && !M(t)) { e = {}; for (var s in t) t.hasOwnProperty(s) && (e[s] = n(t[s])); } return e; } function i(t, e, r) { if (!w(e) || !w(t)) return r ? n(e) : t; for (var o in e) if (e.hasOwnProperty(o)) { var a = t[o], s = e[o]; !w(s) || !w(a) || y(s) || y(a) || M(s) || M(a) || b(s) || b(a) || L(s) || L(a) ? (!r && o in t) || (t[o] = n(e[o], !0)) : i(a, s, r); } return t; } function r(t, e) { for (var n = t[0], r = 1, o = t.length; r < o; r++) n = i(n, t[r], e); return n; } function o(t, e) { for (var n in e) e.hasOwnProperty(n) && (t[n] = e[n]); return t; } function a(t, e, n) { for (var i in e) e.hasOwnProperty(i) && (n ? null != e[i] : null == t[i]) && (t[i] = e[i]); return t; } function s() { return Ed || (Ed = zd().getContext('2d')), Ed; } function l(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 h(t, e) { function n() {} var i = t.prototype; (n.prototype = e.prototype), (t.prototype = new n()); for (var r in i) t.prototype[r] = i[r]; (t.prototype.constructor = t), (t.superClass = e); } function u(t, e, n) { a( (t = 'prototype' in t ? t.prototype : t), (e = 'prototype' in e ? e.prototype : e), n ); } function c(t) { if (t) return 'string' != typeof t && 'number' == typeof t.length; } function d(t, e, n) { if (t && e) if (t.forEach && t.forEach === Cd) 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 f(t, e, n) { if (t && e) { if (t.map && t.map === Pd) 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 p(t, e, n, i) { if (t && e) { if (t.reduce && t.reduce === Ld) return t.reduce(e, n, i); for (var r = 0, o = t.length; r < o; r++) n = e.call(i, n, t[r], r, t); return n; } } function g(t, e, n) { if (t && e) { if (t.filter && t.filter === kd) 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 v(t, e) { var n = Dd.call(arguments, 2); return function () { return t.apply(e, n.concat(Dd.call(arguments))); }; } function m(t) { var e = Dd.call(arguments, 1); return function () { return t.apply(this, e.concat(Dd.call(arguments))); }; } function y(t) { return '[object Array]' === Td.call(t); } function x(t) { return 'function' == typeof t; } function _(t) { return '[object String]' === Td.call(t); } function w(t) { var e = typeof t; return 'function' === e || (!!t && 'object' == e); } function b(t) { return !!Sd[Td.call(t)]; } function M(t) { return ( 'object' == typeof t && 'number' == typeof t.nodeType && 'object' == typeof t.ownerDocument ); } function S(t) { return t !== t; } function I(t) { for (var e = 0, n = arguments.length; e < n; e++) if (null != arguments[e]) return arguments[e]; } function T(t, e) { return null != t ? t : e; } function A(t, e, n) { return null != t ? t : null != e ? e : n; } function C() { return Function.call.apply(Dd, arguments); } function k(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 D(t, e) { if (!t) throw new Error(e); } function P(t) { t[Nd] = !0; } function L(t) { return t[Nd]; } function O(t) { t && d( t, function (t, e) { this.set(e, t); }, this ); } function z(t) { return new O(t); } function E() {} function N(t, e) { var n = new Rd(2); return ( null == t && (t = 0), null == e && (e = 0), (n[0] = t), (n[1] = e), n ); } function B(t, e) { return (t[0] = e[0]), (t[1] = e[1]), t; } function R(t) { var e = new Rd(2); return (e[0] = t[0]), (e[1] = t[1]), e; } function V(t, e, n) { return (t[0] = e[0] + n[0]), (t[1] = e[1] + n[1]), t; } function G(t, e, n, i) { return (t[0] = e[0] + n[0] * i), (t[1] = e[1] + n[1] * i), t; } function W(t, e, n) { return (t[0] = e[0] - n[0]), (t[1] = e[1] - n[1]), t; } function H(t) { return Math.sqrt(F(t)); } function F(t) { return t[0] * t[0] + t[1] * t[1]; } function Z(t, e, n) { return (t[0] = e[0] * n), (t[1] = e[1] * n), t; } function U(t, e) { var n = H(e); return ( 0 === n ? ((t[0] = 0), (t[1] = 0)) : ((t[0] = e[0] / n), (t[1] = e[1] / n)), t ); } function X(t, e) { return Math.sqrt( (t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1]) ); } function j(t, e) { return (t[0] - e[0]) * (t[0] - e[0]) + (t[1] - e[1]) * (t[1] - e[1]); } function q(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 Y(t, e, n) { return (t[0] = Math.min(e[0], n[0])), (t[1] = Math.min(e[1], n[1])), t; } function $(t, e, n) { return (t[0] = Math.max(e[0], n[0])), (t[1] = Math.max(e[1], n[1])), t; } function K() { this.on('mousedown', this._dragStart, this), this.on('mousemove', this._drag, this), this.on('mouseup', this._dragEnd, this), this.on('globalout', this._dragEnd, this); } function Q(t, e) { return { target: t, topTarget: e && e.topTarget }; } function J(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, }; } function tt() {} function et(t, e, n) { if (t[t.rectHover ? 'rectContain' : 'contain'](e, n)) { for (var i, r = t; r; ) { if (r.clipPath && !r.clipPath.contain(e, n)) return !1; r.silent && (i = !0), (r = r.parent); } return !i || Xd; } return !1; } function nt() { var t = new Yd(6); return it(t), t; } function it(t) { return ( (t[0] = 1), (t[1] = 0), (t[2] = 0), (t[3] = 1), (t[4] = 0), (t[5] = 0), t ); } function rt(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 ot(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 at(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 st(t, e, n) { var i = e[0], r = e[2], o = e[4], a = e[1], s = e[3], l = e[5], h = Math.sin(n), u = Math.cos(n); return ( (t[0] = i * u + a * h), (t[1] = -i * h + a * u), (t[2] = r * u + s * h), (t[3] = -r * h + u * s), (t[4] = u * o + h * l), (t[5] = u * l - h * o), t ); } function lt(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 ht(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 ut(t) { return t > Qd || t < -Qd; } function ct(t) { (this._target = t.target), (this._life = t.life || 1e3), (this._delay = t.delay || 0), (this._initialized = !1), (this.loop = null != t.loop && t.loop), (this.gap = t.gap || 0), (this.easing = t.easing || 'Linear'), (this.onframe = t.onframe), (this.ondestroy = t.ondestroy), (this.onrestart = t.onrestart), (this._pausedTime = 0), (this._paused = !1); } function dt(t) { return (t = Math.round(t)) < 0 ? 0 : t > 255 ? 255 : t; } function ft(t) { return (t = Math.round(t)) < 0 ? 0 : t > 360 ? 360 : t; } function pt(t) { return t < 0 ? 0 : t > 1 ? 1 : t; } function gt(t) { return dt( t.length && '%' === t.charAt(t.length - 1) ? (parseFloat(t) / 100) * 255 : parseInt(t, 10) ); } function vt(t) { return pt( t.length && '%' === t.charAt(t.length - 1) ? parseFloat(t) / 100 : parseFloat(t) ); } function mt(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 yt(t, e, n) { return t + (e - t) * n; } function xt(t, e, n, i, r) { return (t[0] = e), (t[1] = n), (t[2] = i), (t[3] = r), t; } function _t(t, e) { return (t[0] = e[0]), (t[1] = e[1]), (t[2] = e[2]), (t[3] = e[3]), t; } function wt(t, e) { cf && _t(cf, e), (cf = uf.put(t, cf || e.slice())); } function bt(t, e) { if (t) { e = e || []; var n = uf.get(t); if (n) return _t(e, n); var i = (t += '').replace(/ /g, '').toLowerCase(); if (i in hf) return _t(e, hf[i]), wt(t, e), e; if ('#' !== i.charAt(0)) { var r = i.indexOf('('), o = i.indexOf(')'); if (-1 !== r && o + 1 === i.length) { var a = i.substr(0, r), s = i.substr(r + 1, o - (r + 1)).split(','), l = 1; switch (a) { case 'rgba': if (4 !== s.length) return void xt(e, 0, 0, 0, 1); l = vt(s.pop()); case 'rgb': return 3 !== s.length ? void xt(e, 0, 0, 0, 1) : (xt(e, gt(s[0]), gt(s[1]), gt(s[2]), l), wt(t, e), e); case 'hsla': return 4 !== s.length ? void xt(e, 0, 0, 0, 1) : ((s[3] = vt(s[3])), Mt(s, e), wt(t, e), e); case 'hsl': return 3 !== s.length ? void xt(e, 0, 0, 0, 1) : (Mt(s, e), wt(t, e), e); default: return; } } xt(e, 0, 0, 0, 1); } else { if (4 === i.length) return (h = parseInt(i.substr(1), 16)) >= 0 && h <= 4095 ? (xt( e, ((3840 & h) >> 4) | ((3840 & h) >> 8), (240 & h) | ((240 & h) >> 4), (15 & h) | ((15 & h) << 4), 1 ), wt(t, e), e) : void xt(e, 0, 0, 0, 1); if (7 === i.length) { var h = parseInt(i.substr(1), 16); return h >= 0 && h <= 16777215 ? (xt(e, (16711680 & h) >> 16, (65280 & h) >> 8, 255 & h, 1), wt(t, e), e) : void xt(e, 0, 0, 0, 1); } } } } function Mt(t, e) { var n = (((parseFloat(t[0]) % 360) + 360) % 360) / 360, i = vt(t[1]), r = vt(t[2]), o = r <= 0.5 ? r * (i + 1) : r + i - r * i, a = 2 * r - o; return ( (e = e || []), xt( e, dt(255 * mt(a, o, n + 1 / 3)), dt(255 * mt(a, o, n)), dt(255 * mt(a, o, n - 1 / 3)), 1 ), 4 === t.length && (e[3] = t[3]), e ); } function St(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, h = (s + a) / 2; if (0 === l) (e = 0), (n = 0); else { n = h < 0.5 ? l / (s + a) : l / (2 - s - a); var u = ((s - i) / 6 + l / 2) / l, c = ((s - r) / 6 + l / 2) / l, d = ((s - o) / 6 + l / 2) / l; i === s ? (e = d - c) : r === s ? (e = 1 / 3 + u - d) : o === s && (e = 2 / 3 + c - u), e < 0 && (e += 1), e > 1 && (e -= 1); } var f = [360 * e, n, h]; return null != t[3] && f.push(t[3]), f; } } function It(t, e) { var n = bt(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; return Dt(n, 4 === n.length ? 'rgba' : 'rgb'); } } function Tt(t) { var e = bt(t); if (e) return ((1 << 24) + (e[0] << 16) + (e[1] << 8) + +e[2]) .toString(16) .slice(1); } function At(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] = dt(yt(a[0], s[0], l))), (n[1] = dt(yt(a[1], s[1], l))), (n[2] = dt(yt(a[2], s[2], l))), (n[3] = pt(yt(a[3], s[3], l))), n ); } } function Ct(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 = bt(e[r]), s = bt(e[o]), l = i - r, h = Dt( [ dt(yt(a[0], s[0], l)), dt(yt(a[1], s[1], l)), dt(yt(a[2], s[2], l)), pt(yt(a[3], s[3], l)), ], 'rgba' ); return n ? { color: h, leftIndex: r, rightIndex: o, value: i } : h; } } function kt(t, e) { if ((t = bt(t)) && null != e) return (t[3] = pt(e)), Dt(t, 'rgba'); } function Dt(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 Pt(t, e) { return t[e]; } function Lt(t, e, n) { t[e] = n; } function Ot(t, e, n) { return (e - t) * n + t; } function zt(t, e, n) { return n > 0.5 ? e : t; } function Et(t, e, n, i, r) { var o = t.length; if (1 == r) for (s = 0; s < o; s++) i[s] = Ot(t[s], e[s], n); else for (var a = o && t[0].length, s = 0; s < o; s++) for (var l = 0; l < a; l++) i[s][l] = Ot(t[s][l], e[s][l], n); } function Nt(t, e, n) { var i = t.length, r = e.length; if (i !== r) if (i > r) t.length = r; else for (a = i; a < r; a++) t.push(1 === n ? e[a] : gf.call(e[a])); for (var o = t[0] && t[0].length, a = 0; a < t.length; a++) if (1 === n) isNaN(t[a]) && (t[a] = e[a]); else for (var s = 0; s < o; s++) isNaN(t[a][s]) && (t[a][s] = e[a][s]); } function Bt(t, e, n) { if (t === e) return !0; var i = t.length; if (i !== e.length) return !1; if (1 === n) { for (o = 0; o < i; o++) if (t[o] !== e[o]) return !1; } else for (var r = t[0].length, o = 0; o < i; o++) for (var a = 0; a < r; a++) if (t[o][a] !== e[o][a]) return !1; return !0; } function Rt(t, e, n, i, r, o, a, s, l) { var h = t.length; if (1 == l) for (c = 0; c < h; c++) s[c] = Vt(t[c], e[c], n[c], i[c], r, o, a); else for (var u = t[0].length, c = 0; c < h; c++) for (var d = 0; d < u; d++) s[c][d] = Vt(t[c][d], e[c][d], n[c][d], i[c][d], r, o, a); } function Vt(t, e, n, i, r, o, a) { var s = 0.5 * (n - t), l = 0.5 * (i - e); return ( (2 * (e - n) + s + l) * a + (-3 * (e - n) - 2 * s - l) * o + s * r + e ); } function Gt(t) { if (c(t)) { var e = t.length; if (c(t[0])) { for (var n = [], i = 0; i < e; i++) n.push(gf.call(t[i])); return n; } return gf.call(t); } return t; } function Wt(t) { return ( (t[0] = Math.floor(t[0])), (t[1] = Math.floor(t[1])), (t[2] = Math.floor(t[2])), 'rgba(' + t.join(',') + ')' ); } function Ht(t) { var e = t[t.length - 1].value; return c(e && e[0]) ? 2 : 1; } function Ft(t, e, n, i, r, o) { var a = t._getter, s = t._setter, l = 'spline' === e, h = i.length; if (h) { var u, d = c(i[0].value), f = !1, p = !1, g = d ? Ht(i) : 0; i.sort(function (t, e) { return t.time - e.time; }), (u = i[h - 1].time); for (var v = [], m = [], y = i[0].value, x = !0, _ = 0; _ < h; _++) { v.push(i[_].time / u); var w = i[_].value; if ( ((d && Bt(w, y, g)) || (!d && w === y) || (x = !1), (y = w), 'string' == typeof w) ) { var b = bt(w); b ? ((w = b), (f = !0)) : (p = !0); } m.push(w); } if (o || !x) { for (var M = m[h - 1], _ = 0; _ < h - 1; _++) d ? Nt(m[_], M, g) : !isNaN(m[_]) || isNaN(M) || p || f || (m[_] = M); d && Nt(a(t._target, r), M, g); var S, I, T, A, C, k, D = 0, P = 0; if (f) var L = [0, 0, 0, 0]; var O = new ct({ target: t._target, life: u, loop: t._loop, delay: t._delay, onframe: function (t, e) { var n; if (e < 0) n = 0; else if (e < P) { for (n = S = Math.min(D + 1, h - 1); n >= 0 && !(v[n] <= e); n--); n = Math.min(n, h - 2); } else { for (n = D; n < h && !(v[n] > e); n++); n = Math.min(n - 1, h - 2); } (D = n), (P = e); var i = v[n + 1] - v[n]; if (0 !== i) if (((I = (e - v[n]) / i), l)) if ( ((A = m[n]), (T = m[0 === n ? n : n - 1]), (C = m[n > h - 2 ? h - 1 : n + 1]), (k = m[n > h - 3 ? h - 1 : n + 2]), d) ) Rt(T, A, C, k, I, I * I, I * I * I, a(t, r), g); else { if (f) (o = Rt(T, A, C, k, I, I * I, I * I * I, L, 1)), (o = Wt(L)); else { if (p) return zt(A, C, I); o = Vt(T, A, C, k, I, I * I, I * I * I); } s(t, r, o); } else if (d) Et(m[n], m[n + 1], I, a(t, r), g); else { var o; if (f) Et(m[n], m[n + 1], I, L, 1), (o = Wt(L)); else { if (p) return zt(m[n], m[n + 1], I); o = Ot(m[n], m[n + 1], I); } s(t, r, o); } }, ondestroy: n, }); return e && 'spline' !== e && (O.easing = e), O; } } } function Zt(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); } function Ut(t) { for (var e = 0; t >= Af; ) (e |= 1 & t), (t >>= 1); return t + e; } function Xt(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++; jt(t, e, r); } else for (; r < n && i(t[r], t[r - 1]) >= 0; ) r++; return r - e; } function jt(t, e, n) { for (n--; e < n; ) { var i = t[e]; (t[e++] = t[n]), (t[n--] = i); } } function qt(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 h = i - s; switch (h) { 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 (; h > 0; ) (t[s + h] = t[s + h - 1]), h--; } t[s] = a; } } function Yt(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 h = a; (a = r - l), (l = r - h); } for (a++; a < l; ) { var u = a + ((l - a) >>> 1); o(t, e[n + u]) > 0 ? (a = u + 1) : (l = u); } return l; } function $t(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 h = a; (a = r - l), (l = r - h); } 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 u = a + ((l - a) >>> 1); o(t, e[n + u]) < 0 ? (l = u) : (a = u + 1); } return l; } function Kt(t, e) { function n(n) { var s = o[n], h = a[n], u = o[n + 1], c = a[n + 1]; (a[n] = h + c), n === l - 3 && ((o[n + 1] = o[n + 2]), (a[n + 1] = a[n + 2])), l--; var d = $t(t[u], t, s, h, 0, e); (s += d), 0 !== (h -= d) && 0 !== (c = Yt(t[s + h - 1], t, u, c, c - 1, e)) && (h <= c ? i(s, h, u, c) : r(s, h, u, c)); } function i(n, i, r, o) { var a = 0; for (a = 0; a < i; a++) h[a] = t[n + a]; var l = 0, u = r, c = n; if (((t[c++] = t[u++]), 0 != --o)) if (1 !== i) { for (var d, f, p, g = s; ; ) { (d = 0), (f = 0), (p = !1); do { if (e(t[u], h[l]) < 0) { if (((t[c++] = t[u++]), f++, (d = 0), 0 == --o)) { p = !0; break; } } else if (((t[c++] = h[l++]), d++, (f = 0), 1 == --i)) { p = !0; break; } } while ((d | f) < g); if (p) break; do { if (0 !== (d = $t(t[u], h, l, i, 0, e))) { for (a = 0; a < d; a++) t[c + a] = h[l + a]; if (((c += d), (l += d), (i -= d) <= 1)) { p = !0; break; } } if (((t[c++] = t[u++]), 0 == --o)) { p = !0; break; } if (0 !== (f = Yt(h[l], t, u, o, 0, e))) { for (a = 0; a < f; a++) t[c + a] = t[u + a]; if (((c += f), (u += f), 0 === (o -= f))) { p = !0; break; } } if (((t[c++] = h[l++]), 1 == --i)) { p = !0; break; } g--; } while (d >= Cf || f >= Cf); if (p) break; g < 0 && (g = 0), (g += 2); } if (((s = g) < 1 && (s = 1), 1 === i)) { for (a = 0; a < o; a++) t[c + a] = t[u + a]; t[c + o] = h[l]; } else { if (0 === i) throw new Error(); for (a = 0; a < i; a++) t[c + a] = h[l + a]; } } else { for (a = 0; a < o; a++) t[c + a] = t[u + a]; t[c + o] = h[l]; } else for (a = 0; a < i; a++) t[c + a] = h[l + a]; } function r(n, i, r, o) { var a = 0; for (a = 0; a < o; a++) h[a] = t[r + a]; var l = n + i - 1, u = o - 1, c = r + o - 1, d = 0, f = 0; if (((t[c--] = t[l--]), 0 != --i)) if (1 !== o) { for (var p = s; ; ) { var g = 0, v = 0, m = !1; do { if (e(h[u], t[l]) < 0) { if (((t[c--] = t[l--]), g++, (v = 0), 0 == --i)) { m = !0; break; } } else if (((t[c--] = h[u--]), v++, (g = 0), 1 == --o)) { m = !0; break; } } while ((g | v) < p); if (m) break; do { if (0 != (g = i - $t(h[u], t, n, i, i - 1, e))) { for ( i -= g, f = (c -= g) + 1, d = (l -= g) + 1, a = g - 1; a >= 0; a-- ) t[f + a] = t[d + a]; if (0 === i) { m = !0; break; } } if (((t[c--] = h[u--]), 1 == --o)) { m = !0; break; } if (0 != (v = o - Yt(t[l], h, 0, o, o - 1, e))) { for ( o -= v, f = (c -= v) + 1, d = (u -= v) + 1, a = 0; a < v; a++ ) t[f + a] = h[d + a]; if (o <= 1) { m = !0; break; } } if (((t[c--] = t[l--]), 0 == --i)) { m = !0; break; } p--; } while (g >= Cf || v >= Cf); if (m) break; p < 0 && (p = 0), (p += 2); } if (((s = p) < 1 && (s = 1), 1 === o)) { for (f = (c -= i) + 1, d = (l -= i) + 1, a = i - 1; a >= 0; a--) t[f + a] = t[d + a]; t[c] = h[u]; } else { if (0 === o) throw new Error(); for (d = c - (o - 1), a = 0; a < o; a++) t[d + a] = h[a]; } } else { for (f = (c -= i) + 1, d = (l -= i) + 1, a = i - 1; a >= 0; a--) t[f + a] = t[d + a]; t[c] = h[u]; } else for (d = c - (o - 1), a = 0; a < o; a++) t[d + a] = h[a]; } var o, a, s = Cf, l = 0, h = []; (o = []), (a = []), (this.mergeRuns = function () { for (; l > 1; ) { var t = l - 2; if ( (t >= 1 && a[t - 1] <= a[t] + a[t + 1]) || (t >= 2 && a[t - 2] <= a[t] + a[t - 1]) ) a[t - 1] < a[t + 1] && t--; else if (a[t] > a[t + 1]) break; n(t); } }), (this.forceMergeRuns = function () { for (; l > 1; ) { var t = l - 2; t > 0 && a[t - 1] < a[t + 1] && t--, n(t); } }), (this.pushRun = function (t, e) { (o[l] = t), (a[l] = e), (l += 1); }); } function Qt(t, e, n, i) { n || (n = 0), i || (i = t.length); var r = i - n; if (!(r < 2)) { var o = 0; if (r < Af) return (o = Xt(t, n, i, e)), void qt(t, n, i, n + o, e); var a = new Kt(t, e), s = Ut(r); do { if ((o = Xt(t, n, i, e)) < s) { var l = r; l > s && (l = s), qt(t, n, n + l, n + o, e), (o = l); } a.pushRun(n, o), a.mergeRuns(), (r -= o), (n += o); } while (0 !== r); a.forceMergeRuns(); } } function Jt(t, e) { return t.zlevel === e.zlevel ? t.z === e.z ? t.z2 - e.z2 : t.z - e.z : t.zlevel - e.zlevel; } function te(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)), t.createLinearGradient(i, o, r, a) ); } function ee(t, e, n) { var i = n.width, r = n.height, o = Math.min(i, r), a = null == e.x ? 0.5 : e.x, s = null == e.y ? 0.5 : e.y, l = null == e.r ? 0.5 : e.r; return ( e.global || ((a = a * i + n.x), (s = s * r + n.y), (l *= o)), t.createRadialGradient(a, s, 0, a, s, l) ); } function ne() { return !1; } function ie(t, e, n) { var i = zd(), r = e.getWidth(), o = e.getHeight(), a = i.style; return ( (a.position = 'absolute'), (a.left = 0), (a.top = 0), (a.width = r + 'px'), (a.height = o + 'px'), (i.width = r * n), (i.height = o * n), i.setAttribute('data-zr-dom-id', t), i ); } function re(t) { if ('string' == typeof t) { var e = Rf.get(t); return e && e.image; } return t; } function oe(t, e, n, i, r) { if (t) { if ('string' == typeof t) { if ((e && e.__zrImageSrc === t) || !n) return e; var o = Rf.get(t), a = { hostEl: n, cb: i, cbPayload: r }; return ( o ? !se((e = o.image)) && o.pending.push(a) : (!e && (e = new Image()), (e.onload = ae), Rf.put(t, (e.__cachedImgObj = { image: e, pending: [a] })), (e.src = e.__zrImageSrc = t)), e ); } return t; } return e; } function ae() { var t = this.__cachedImgObj; this.onload = 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 se(t) { return t && t.width && t.height; } function le(t, e) { var n = t + ':' + (e = e || Ff); if (Vf[n]) return Vf[n]; for (var i = (t + '').split('\n'), r = 0, o = 0, a = i.length; o < a; o++) r = Math.max(_e(i[o], e).width, r); return Gf > Wf && ((Gf = 0), (Vf = {})), Gf++, (Vf[n] = r), r; } function he(t, e, n, i, r, o, a) { return o ? ce(t, e, n, i, r, o, a) : ue(t, e, n, i, r, a); } function ue(t, e, n, i, r, o) { var a = we(t, e, r, o), s = le(t, e); r && (s += r[1] + r[3]); var l = a.outerHeight, h = new Zt(de(0, s, n), fe(0, l, i), s, l); return (h.lineHeight = a.lineHeight), h; } function ce(t, e, n, i, r, o, a) { var s = be(t, { rich: o, truncate: a, font: e, textAlign: n, textPadding: r, }), l = s.outerWidth, h = s.outerHeight; return new Zt(de(0, l, n), fe(0, h, i), l, h); } function de(t, e, n) { return 'right' === n ? (t -= e) : 'center' === n && (t -= e / 2), t; } function fe(t, e, n) { return 'middle' === n ? (t -= e / 2) : 'bottom' === n && (t -= e), t; } function pe(t, e, n) { var i = e.x, r = e.y, o = e.height, a = e.width, s = o / 2, l = 'left', h = 'top'; switch (t) { case 'left': (i -= n), (r += s), (l = 'right'), (h = 'middle'); break; case 'right': (i += n + a), (r += s), (h = 'middle'); break; case 'top': (i += a / 2), (r -= n), (l = 'center'), (h = 'bottom'); break; case 'bottom': (i += a / 2), (r += o + n), (l = 'center'); break; case 'inside': (i += a / 2), (r += s), (l = 'center'), (h = 'middle'); break; case 'insideLeft': (i += n), (r += s), (h = 'middle'); break; case 'insideRight': (i += a - n), (r += s), (l = 'right'), (h = 'middle'); break; case 'insideTop': (i += a / 2), (r += n), (l = 'center'); break; case 'insideBottom': (i += a / 2), (r += o - n), (l = 'center'), (h = 'bottom'); break; case 'insideTopLeft': (i += n), (r += n); break; case 'insideTopRight': (i += a - n), (r += n), (l = 'right'); break; case 'insideBottomLeft': (i += n), (r += o - n), (h = 'bottom'); break; case 'insideBottomRight': (i += a - n), (r += o - n), (l = 'right'), (h = 'bottom'); } return { x: i, y: r, textAlign: l, textVerticalAlign: h }; } function ge(t, e, n, i, r) { if (!e) return ''; var o = (t + '').split('\n'); r = ve(e, n, i, r); for (var a = 0, s = o.length; a < s; a++) o[a] = me(o[a], r); return o.join('\n'); } function ve(t, e, n, i) { (i = o({}, i)).font = e; var n = T(n, '...'); i.maxIterations = T(i.maxIterations, 2); var r = (i.minChar = T(i.minChar, 0)); i.cnCharWidth = le('国', e); var a = (i.ascCharWidth = le('a', e)); i.placeholder = T(i.placeholder, ''); for (var s = (t = Math.max(0, t - 1)), l = 0; l < r && s >= a; l++) s -= a; var h = le(n); return ( h > s && ((n = ''), (h = 0)), (s = t - h), (i.ellipsis = n), (i.ellipsisWidth = h), (i.contentWidth = s), (i.containerWidth = t), i ); } function me(t, e) { var n = e.containerWidth, i = e.font, r = e.contentWidth; if (!n) return ''; var o = le(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 ? ye(t, r, e.ascCharWidth, e.cnCharWidth) : o > 0 ? Math.floor((t.length * r) / o) : 0; o = le((t = t.substr(0, s)), i); } return '' === t && (t = e.placeholder), t; } function ye(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; } function xe(t) { return le('国', t); } function _e(t, e) { return Zf.measureText(t, e); } function we(t, e, n, i) { null != t && (t += ''); var r = xe(e), o = t ? t.split('\n') : [], a = o.length * r, s = a; if ((n && (s += n[0] + n[2]), t && i)) { var l = i.outerHeight, h = i.outerWidth; if (null != l && s > l) (t = ''), (o = []); else if (null != h) for ( var u = ve(h - (n ? n[1] + n[3] : 0), e, i.ellipsis, { minChar: i.minChar, placeholder: i.placeholder, }), c = 0, d = o.length; c < d; c++ ) o[c] = me(o[c], u); } return { lines: o, height: a, outerHeight: s, lineHeight: r }; } function be(t, e) { var n = { lines: [], width: 0, height: 0 }; if ((null != t && (t += ''), !t)) return n; for (var i, r = (Hf.lastIndex = 0); null != (i = Hf.exec(t)); ) { var o = i.index; o > r && Me(n, t.substring(r, o)), Me(n, i[2], i[1]), (r = Hf.lastIndex); } r < t.length && Me(n, t.substring(r, t.length)); var a = n.lines, s = 0, l = 0, h = [], u = e.textPadding, c = e.truncate, d = c && c.outerWidth, f = c && c.outerHeight; u && (null != d && (d -= u[1] + u[3]), null != f && (f -= u[0] + u[2])); for (D = 0; D < a.length; D++) { for (var p = a[D], g = 0, v = 0, m = 0; m < p.tokens.length; m++) { var y = ((P = p.tokens[m]).styleName && e.rich[P.styleName]) || {}, x = (P.textPadding = y.textPadding), _ = (P.font = y.font || e.font), w = (P.textHeight = T(y.textHeight, xe(_))); if ( (x && (w += x[0] + x[2]), (P.height = w), (P.lineHeight = A(y.textLineHeight, e.textLineHeight, w)), (P.textAlign = (y && y.textAlign) || e.textAlign), (P.textVerticalAlign = (y && y.textVerticalAlign) || 'middle'), null != f && s + P.lineHeight > f) ) return { lines: [], width: 0, height: 0 }; P.textWidth = le(P.text, _); var b = y.textWidth, M = null == b || 'auto' === b; if ('string' == typeof b && '%' === b.charAt(b.length - 1)) (P.percentWidth = b), h.push(P), (b = 0); else { if (M) { b = P.textWidth; var S = y.textBackgroundColor, I = S && S.image; I && se((I = re(I))) && (b = Math.max(b, (I.width * w) / I.height)); } var C = x ? x[1] + x[3] : 0; b += C; var k = null != d ? d - v : null; null != k && k < b && (!M || k < C ? ((P.text = ''), (P.textWidth = b = 0)) : ((P.text = ge(P.text, k - C, _, c.ellipsis, { minChar: c.minChar, })), (P.textWidth = le(P.text, _)), (b = P.textWidth + C))); } (v += P.width = b), y && (g = Math.max(g, P.lineHeight)); } (p.width = v), (p.lineHeight = g), (s += g), (l = Math.max(l, v)); } (n.outerWidth = n.width = T(e.textWidth, l)), (n.outerHeight = n.height = T(e.textHeight, s)), u && ((n.outerWidth += u[1] + u[3]), (n.outerHeight += u[0] + u[2])); for (var D = 0; D < h.length; D++) { var P = h[D], L = P.percentWidth; P.width = (parseInt(L, 10) / 100) * l; } return n; } function Me(t, e, n) { for ( var i = '' === e, r = e.split('\n'), o = t.lines, a = 0; a < r.length; a++ ) { var s = r[a], l = { styleName: n, text: s, isLineHolder: !s && !i }; if (a) o.push({ tokens: [l] }); else { var h = (o[o.length - 1] || (o[0] = { tokens: [] })).tokens, u = h.length; 1 === u && h[0].isLineHolder ? (h[0] = l) : (s || !u || i) && h.push(l); } } } function Se(t) { return ( ((t.fontSize || t.fontFamily) && [ t.fontStyle, t.fontWeight, (t.fontSize || 12) + 'px', t.fontFamily || 'sans-serif', ].join(' ')) || t.textFont || t.font ); } function Ie(t, e) { var n, i, r, o, a = e.x, s = e.y, l = e.width, h = e.height, u = e.r; l < 0 && ((a += l), (l = -l)), h < 0 && ((s += h), (h = -h)), 'number' == typeof u ? (n = i = r = o = u) : u instanceof Array ? 1 === u.length ? (n = i = r = o = u[0]) : 2 === u.length ? ((n = r = u[0]), (i = o = u[1])) : 3 === u.length ? ((n = u[0]), (i = o = u[1]), (r = u[2])) : ((n = u[0]), (i = u[1]), (r = u[2]), (o = u[3])) : (n = i = r = o = 0); var c; n + i > l && ((n *= l / (c = n + i)), (i *= l / c)), r + o > l && ((r *= l / (c = r + o)), (o *= l / c)), i + r > h && ((i *= h / (c = i + r)), (r *= h / c)), n + o > h && ((n *= h / (c = n + o)), (o *= h / c)), t.moveTo(a + n, s), t.lineTo(a + l - i, s), 0 !== i && t.quadraticCurveTo(a + l, s, a + l, s + i), t.lineTo(a + l, s + h - r), 0 !== r && t.quadraticCurveTo(a + l, s + h, a + l - r, s + h), t.lineTo(a + o, s + h), 0 !== o && t.quadraticCurveTo(a, s + h, a, s + h - o), t.lineTo(a, s + n), 0 !== n && t.quadraticCurveTo(a, s, a + n, s); } function Te(t) { return Ae(t), d(t.rich, Ae), t; } function Ae(t) { if (t) { t.font = Se(t); var e = t.textAlign; 'middle' === e && (e = 'center'), (t.textAlign = null == e || Uf[e] ? e : 'left'); var n = t.textVerticalAlign || t.textBaseline; 'center' === n && (n = 'middle'), (t.textVerticalAlign = null == n || Xf[n] ? n : 'top'), t.textPadding && (t.textPadding = k(t.textPadding)); } } function Ce(t, e, n, i, r) { i.rich ? De(t, e, n, i, r) : ke(t, e, n, i, r); } function ke(t, e, n, i, r) { var o = Re(e, 'font', i.font || Ff), a = i.textPadding, s = t.__textCotentBlock; (s && !t.__dirty) || (s = t.__textCotentBlock = we(n, o, a, i.truncate)); var l = s.outerHeight, h = s.lines, u = s.lineHeight, c = Be(l, i, r), d = c.baseX, f = c.baseY, p = c.textAlign, g = c.textVerticalAlign; Le(e, i, r, d, f); var v = fe(f, l, g), m = d, y = v, x = ze(i); if (x || a) { var _ = le(n, o); a && (_ += a[1] + a[3]); var w = de(d, _, p); x && Ee(t, e, i, w, v, _, l), a && ((m = He(d, p, a)), (y += a[0])); } Re(e, 'textAlign', p || 'left'), Re(e, 'textBaseline', 'middle'), Re(e, 'shadowBlur', i.textShadowBlur || 0), Re(e, 'shadowColor', i.textShadowColor || 'transparent'), Re(e, 'shadowOffsetX', i.textShadowOffsetX || 0), Re(e, 'shadowOffsetY', i.textShadowOffsetY || 0), (y += u / 2); var b = i.textStrokeWidth, M = Ve(i.textStroke, b), S = Ge(i.textFill); M && (Re(e, 'lineWidth', b), Re(e, 'strokeStyle', M)), S && Re(e, 'fillStyle', S); for (var I = 0; I < h.length; I++) M && e.strokeText(h[I], m, y), S && e.fillText(h[I], m, y), (y += u); } function De(t, e, n, i, r) { var o = t.__textCotentBlock; (o && !t.__dirty) || (o = t.__textCotentBlock = be(n, i)), Pe(t, e, o, i, r); } function Pe(t, e, n, i, r) { var o = n.width, a = n.outerWidth, s = n.outerHeight, l = i.textPadding, h = Be(s, i, r), u = h.baseX, c = h.baseY, d = h.textAlign, f = h.textVerticalAlign; Le(e, i, r, u, c); var p = de(u, a, d), g = fe(c, s, f), v = p, m = g; l && ((v += l[3]), (m += l[0])); var y = v + o; ze(i) && Ee(t, e, i, p, g, a, s); for (var x = 0; x < n.lines.length; x++) { for ( var _, w = n.lines[x], b = w.tokens, M = b.length, S = w.lineHeight, I = w.width, T = 0, A = v, C = y, k = M - 1; T < M && (!(_ = b[T]).textAlign || 'left' === _.textAlign); ) Oe(t, e, _, i, S, m, A, 'left'), (I -= _.width), (A += _.width), T++; for (; k >= 0 && 'right' === (_ = b[k]).textAlign; ) Oe(t, e, _, i, S, m, C, 'right'), (I -= _.width), (C -= _.width), k--; for (A += (o - (A - v) - (y - C) - I) / 2; T <= k; ) Oe(t, e, (_ = b[T]), i, S, m, A + _.width / 2, 'center'), (A += _.width), T++; m += S; } } function Le(t, e, n, i, r) { if (n && e.textRotation) { var o = e.textOrigin; 'center' === o ? ((i = n.width / 2 + n.x), (r = n.height / 2 + n.y)) : o && ((i = o[0] + n.x), (r = o[1] + n.y)), t.translate(i, r), t.rotate(-e.textRotation), t.translate(-i, -r); } } function Oe(t, e, n, i, r, o, a, s) { var l = i.rich[n.styleName] || {}, h = n.textVerticalAlign, u = o + r / 2; 'top' === h ? (u = o + n.height / 2) : 'bottom' === h && (u = o + r - n.height / 2), !n.isLineHolder && ze(l) && Ee( t, e, l, 'right' === s ? a - n.width : 'center' === s ? a - n.width / 2 : a, u - n.height / 2, n.width, n.height ); var c = n.textPadding; c && ((a = He(a, s, c)), (u -= n.height / 2 - c[2] - n.textHeight / 2)), Re(e, 'shadowBlur', A(l.textShadowBlur, i.textShadowBlur, 0)), Re( e, 'shadowColor', l.textShadowColor || i.textShadowColor || 'transparent' ), Re(e, 'shadowOffsetX', A(l.textShadowOffsetX, i.textShadowOffsetX, 0)), Re(e, 'shadowOffsetY', A(l.textShadowOffsetY, i.textShadowOffsetY, 0)), Re(e, 'textAlign', s), Re(e, 'textBaseline', 'middle'), Re(e, 'font', n.font || Ff); var d = Ve(l.textStroke || i.textStroke, p), f = Ge(l.textFill || i.textFill), p = T(l.textStrokeWidth, i.textStrokeWidth); d && (Re(e, 'lineWidth', p), Re(e, 'strokeStyle', d), e.strokeText(n.text, a, u)), f && (Re(e, 'fillStyle', f), e.fillText(n.text, a, u)); } function ze(t) { return t.textBackgroundColor || (t.textBorderWidth && t.textBorderColor); } function Ee(t, e, n, i, r, o, a) { var s = n.textBackgroundColor, l = n.textBorderWidth, h = n.textBorderColor, u = _(s); if ( (Re(e, 'shadowBlur', n.textBoxShadowBlur || 0), Re(e, 'shadowColor', n.textBoxShadowColor || 'transparent'), Re(e, 'shadowOffsetX', n.textBoxShadowOffsetX || 0), Re(e, 'shadowOffsetY', n.textBoxShadowOffsetY || 0), u || (l && h)) ) { e.beginPath(); var c = n.textBorderRadius; c ? Ie(e, { x: i, y: r, width: o, height: a, r: c }) : e.rect(i, r, o, a), e.closePath(); } if (u) Re(e, 'fillStyle', s), e.fill(); else if (w(s)) { var d = s.image; (d = oe(d, null, t, Ne, s)) && se(d) && e.drawImage(d, i, r, o, a); } l && h && (Re(e, 'lineWidth', l), Re(e, 'strokeStyle', h), e.stroke()); } function Ne(t, e) { e.image = t; } function Be(t, e, n) { var i = e.x || 0, r = e.y || 0, o = e.textAlign, a = e.textVerticalAlign; if (n) { var s = e.textPosition; if (s instanceof Array) (i = n.x + We(s[0], n.width)), (r = n.y + We(s[1], n.height)); else { var l = pe(s, n, e.textDistance); (i = l.x), (r = l.y), (o = o || l.textAlign), (a = a || l.textVerticalAlign); } var h = e.textOffset; h && ((i += h[0]), (r += h[1])); } return { baseX: i, baseY: r, textAlign: o, textVerticalAlign: a }; } function Re(t, e, n) { return (t[e] = n), t[e]; } function Ve(t, e) { return null == t || e <= 0 || 'transparent' === t || 'none' === t ? null : t.image || t.colorStops ? '#000' : t; } function Ge(t) { return null == t || 'none' === t ? null : t.image || t.colorStops ? '#000' : t; } function We(t, e) { return 'string' == typeof t ? t.lastIndexOf('%') >= 0 ? (parseFloat(t) / 100) * e : parseFloat(t) : t; } function He(t, e, n) { return 'right' === e ? t - n[1] : 'center' === e ? t + n[3] / 2 - n[1] / 2 : t + n[3]; } function Fe(t, e) { return ( null != t && (t || e.textBackgroundColor || (e.textBorderWidth && e.textBorderColor) || e.textPadding) ); } function Ze(t) { (t = t || {}), bf.call(this, t); for (var e in t) t.hasOwnProperty(e) && 'style' !== e && (this[e] = t[e]); (this.style = new Pf(t.style, this)), (this._rect = null), (this.__clipPaths = []); } function Ue(t) { Ze.call(this, t); } function Xe(t) { return parseInt(t, 10); } function je(t) { return ( !!t && (!!t.__builtin__ || ('function' == typeof t.resize && 'function' == typeof t.refresh)) ); } function qe(t) { t.__unusedCount++; } function Ye(t) { 1 == t.__unusedCount && t.clear(); } function $e(t, e, n) { return ( Yf.copy(t.getBoundingRect()), t.transform && Yf.applyTransform(t.transform), ($f.width = e), ($f.height = n), !Yf.intersect($f) ); } function Ke(t, e) { if (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; } function Qe(t, e) { for (var n = 0; n < t.length; n++) { var i = t[n]; i.setTransform(e), e.beginPath(), i.buildPath(e, i.shape), e.clip(), i.restoreTransform(e); } } function Je(t, e) { var n = document.createElement('div'); return ( (n.style.cssText = [ 'position:relative', 'overflow:hidden', 'width:' + t + 'px', 'height:' + e + 'px', 'padding:0', 'margin:0', 'border-width:0', ].join(';') + ';'), n ); } function tn(t) { return t.getBoundingClientRect ? t.getBoundingClientRect() : { left: 0, top: 0 }; } function en(t, e, n, i) { return ( (n = n || {}), i || !Md.canvasSupported ? nn(t, e, n) : Md.browser.firefox && 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)) : nn(t, e, n), n ); } function nn(t, e, n) { var i = tn(t); (n.zrX = e.clientX - i.left), (n.zrY = e.clientY - i.top); } function rn(t, e, n) { if (null != (e = e || window.event).zrX) return e; var i = e.type; if (i && i.indexOf('touch') >= 0) { var r = 'touchend' != i ? e.targetTouches[0] : e.changedTouches[0]; r && en(t, r, e, n); } else en(t, e, e, n), (e.zrDelta = e.wheelDelta ? e.wheelDelta / 120 : -(e.detail || 0) / 3); var o = e.button; return ( null == e.which && void 0 !== o && Jf.test(e.type) && (e.which = 1 & o ? 1 : 2 & o ? 3 : 4 & o ? 2 : 0), e ); } function on(t, e, n) { Qf ? t.addEventListener(e, n) : t.attachEvent('on' + e, n); } function an(t, e, n) { Qf ? t.removeEventListener(e, n) : t.detachEvent('on' + e, n); } function sn(t) { return t.which > 1; } function ln(t) { var e = t[1][0] - t[0][0], n = t[1][1] - t[0][1]; return Math.sqrt(e * e + n * n); } function hn(t) { return [(t[0][0] + t[1][0]) / 2, (t[0][1] + t[1][1]) / 2]; } function un(t) { return 'mousewheel' === t && Md.browser.firefox ? 'DOMMouseScroll' : t; } function cn(t, e, n) { var i = t._gestureMgr; 'start' === n && i.clear(); var r = i.recognize( e, t.handler.findHover(e.zrX, e.zrY, null).target, t.dom ); if (('end' === n && i.clear(), r)) { var o = r.type; (e.gestureEvent = o), t.handler.dispatchToElement({ target: r.target }, o, r.event); } } function dn(t) { (t._touching = !0), clearTimeout(t._touchTimer), (t._touchTimer = setTimeout(function () { t._touching = !1; }, 700)); } function fn(t) { var e = t.pointerType; return 'pen' === e || 'touch' === e; } function pn(t) { function e(t, e) { return function () { if (!e._touching) return t.apply(e, arguments); }; } d(op, function (e) { t._handlers[e] = v(lp[e], t); }), d(sp, function (e) { t._handlers[e] = v(lp[e], t); }), d(rp, function (n) { t._handlers[n] = e(lp[n], t); }); } function gn(t) { function e(e, n) { d( e, function (e) { on(t, un(e), n._handlers[e]); }, n ); } Ud.call(this), (this.dom = t), (this._touching = !1), this._touchTimer, (this._gestureMgr = new np()), (this._handlers = {}), pn(this), Md.pointerEventsSupported ? e(sp, this) : (Md.touchEventsSupported && e(op, this), e(rp, this)); } function vn(t, e) { var n = new fp(wd(), t, e); return (dp[n.id] = n), n; } function mn(t, e) { cp[t] = e; } function yn(t) { delete dp[t]; } function xn(t) { return t.replace(/^\s+/, '').replace(/\s+$/, ''); } function _n(t, e, n, i) { var r = e[1] - e[0], o = n[1] - n[0]; if (0 === r) return 0 === o ? n[0] : (n[0] + n[1]) / 2; if (i) if (r > 0) { if (t <= e[0]) return n[0]; if (t >= e[1]) return n[1]; } else { if (t >= e[0]) return n[0]; if (t <= e[1]) return n[1]; } else { if (t === e[0]) return n[0]; if (t === e[1]) return n[1]; } return ((t - e[0]) / r) * o + n[0]; } function wn(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 'string' == typeof t ? xn(t).match(/%$/) ? (parseFloat(t) / 100) * e : parseFloat(t) : null == t ? NaN : +t; } function bn(t, e, n) { return ( null == e && (e = 10), (e = Math.min(Math.max(0, e), 20)), (t = (+t).toFixed(e)), n ? t : +t ); } function Mn(t) { return ( t.sort(function (t, e) { return t - e; }), t ); } function Sn(t) { if (((t = +t), isNaN(t))) return 0; for (var e = 1, n = 0; Math.round(t * e) / e !== t; ) (e *= 10), n++; return n; } function In(t) { var e = t.toString(), n = e.indexOf('e'); if (n > 0) { var i = +e.slice(n + 1); return i < 0 ? -i : 0; } var r = e.indexOf('.'); return r < 0 ? 0 : e.length - 1 - r; } function Tn(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 An(t, e, n) { if (!t[e]) return 0; var i = p( t, function (t, e) { return t + (isNaN(e) ? 0 : e); }, 0 ); if (0 === i) return 0; for ( var r = Math.pow(10, n), o = f(t, function (t) { return ((isNaN(t) ? 0 : t) / i) * r * 100; }), a = 100 * r, s = f(o, function (t) { return Math.floor(t); }), l = p( s, function (t, e) { return t + e; }, 0 ), h = f(o, function (t, e) { return t - s[e]; }); l < a; ) { for ( var u = Number.NEGATIVE_INFINITY, c = null, d = 0, g = h.length; d < g; ++d ) h[d] > u && ((u = h[d]), (c = d)); ++s[c], (h[c] = 0), ++l; } return s[e] / r; } function Cn(t) { var e = 2 * Math.PI; return ((t % e) + e) % e; } function kn(t) { return t > -gp && t < gp; } function Dn(t) { if (t instanceof Date) return t; if ('string' == typeof t) { var e = vp.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] || 0 ) ) ); } return new Date( +e[1], +(e[2] || 1) - 1, +e[3] || 1, +e[4] || 0, +(e[5] || 0), +e[6] || 0, +e[7] || 0 ); } return null == t ? new Date(NaN) : new Date(Math.round(t)); } function Pn(t) { return Math.pow(10, Ln(t)); } function Ln(t) { return Math.floor(Math.log(t) / Math.LN10); } function On(t, e) { var n, i = Ln(t), r = Math.pow(10, i), o = t / r; return ( (n = e ? o < 1.5 ? 1 : o < 2.5 ? 2 : o < 4 ? 3 : o < 7 ? 5 : 10 : o < 1 ? 1 : o < 2 ? 2 : o < 3 ? 3 : o < 5 ? 5 : 10), (t = n * r), i >= -20 ? +t.toFixed(i < 0 ? -i : 0) : t ); } function zn(t) { return isNaN(t) ? '-' : (t = (t + '').split('.'))[0].replace( /(\d{1,3})(?=(?:\d{3})+(?!\d))/g, '$1,' ) + (t.length > 1 ? '.' + t[1] : ''); } function En(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 ); } function Nn(t) { return String(t) .replace(/&/g, '&') .replace(//g, '>') .replace(/"/g, '"') .replace(/'/g, '''); } function Bn(t, e, n) { y(e) || (e = [e]); var i = e.length; if (!i) return ''; for (var r = e[0].$vars || [], o = 0; o < r.length; o++) { var a = xp[o], s = _p(a, 0); t = t.replace(_p(a), n ? Nn(s) : s); } for (var l = 0; l < i; l++) for (var h = 0; h < r.length; h++) { s = e[l][r[h]]; t = t.replace(_p(xp[h], l), n ? Nn(s) : s); } return t; } function Rn(t, e) { return t ? '' : ''; } function Vn(t, e, n) { ('week' !== t && 'month' !== t && 'quarter' !== t && 'half-year' !== t && 'year' !== t) || (t = 'MM-dd\nyyyy'); var i = Dn(e), r = n ? 'UTC' : '', o = i['get' + r + 'FullYear'](), a = i['get' + r + 'Month']() + 1, s = i['get' + r + 'Date'](), l = i['get' + r + 'Hours'](), h = i['get' + r + 'Minutes'](), u = i['get' + r + 'Seconds'](); return (t = t .replace('MM', wp(a)) .replace('M', a) .replace('yyyy', o) .replace('yy', o % 100) .replace('dd', wp(s)) .replace('d', s) .replace('hh', wp(l)) .replace('h', l) .replace('mm', wp(h)) .replace('m', h) .replace('ss', wp(u)) .replace('s', u)); } function Gn(t) { return t ? t.charAt(0).toUpperCase() + t.substr(1) : t; } function Wn(t, e, n) { return (t[Ap + e] = n); } function Hn(t, e) { return t[Ap + e]; } function Fn(t, e) { return t.hasOwnProperty(Ap + e); } function Zn(t) { var e = { main: '', sub: '' }; return ( t && ((t = t.split(Ip)), (e.main = t[0] || ''), (e.sub = t[1] || '')), e ); } function Un(t) { D( /^[a-zA-Z0-9_]+([.][a-zA-Z0-9_]+)?$/.test(t), 'componentType "' + t + '" illegal' ); } function Xn(t, e) { (t.$constructor = t), (t.extend = function (t) { var e = this, n = function () { t.$constructor ? t.$constructor.apply(this, arguments) : e.apply(this, arguments); }; return ( o(n.prototype, t), (n.extend = this.extend), (n.superCall = jn), (n.superApply = qn), h(n, this), (n.superClass = e), n ); }); } function jn(t, e) { var n = C(arguments, 2); return this.superClass.prototype[e].apply(t, n); } function qn(t, e, n) { return this.superClass.prototype[e].apply(t, n); } function Yn(t, e) { function n(t) { var e = i[t.main]; return (e && e[Tp]) || ((e = i[t.main] = {})[Tp] = !0), e; } e = e || {}; var i = {}; if ( ((t.registerClass = function (t, e) { return ( e && (Un(e), (e = Zn(e)).sub ? e.sub !== Tp && (n(e)[e.sub] = t) : (i[e.main] = t)), t ); }), (t.getClass = function (t, e, n) { var r = i[t]; if ((r && r[Tp] && (r = e ? r[e] : null), n && !r)) throw new Error( e ? 'Component ' + t + '.' + (e || '') + ' not exists. Load it first.' : t + '.type should be specified.' ); return r; }), (t.getClassesByMainType = function (t) { t = Zn(t); var e = [], n = i[t.main]; return ( n && n[Tp] ? d(n, function (t, n) { n !== Tp && e.push(t); }) : e.push(n), e ); }), (t.hasClass = function (t) { return (t = Zn(t)), !!i[t.main]; }), (t.getAllClassMainTypes = function () { var t = []; return ( d(i, function (e, n) { t.push(n); }), t ); }), (t.hasSubTypes = function (t) { t = Zn(t); var e = i[t.main]; return e && e[Tp]; }), (t.parseClassType = Zn), e.registerWhenExtend) ) { var r = t.extend; r && (t.extend = function (e) { var n = r.call(this, e); return t.registerClass(n, e.type); }); } return t; } function $n(t) { return t > -Ep && t < Ep; } function Kn(t) { return t > Ep || t < -Ep; } function Qn(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 Jn(t, e, n, i, r) { var o = 1 - r; return 3 * (((e - t) * o + 2 * (n - e) * r) * o + (i - n) * r * r); } function ti(t, e, n, i, r, o) { var a = i + 3 * (e - n) - t, s = 3 * (n - 2 * e + t), l = 3 * (e - t), h = t - r, u = s * s - 3 * a * l, c = s * l - 9 * a * h, d = l * l - 3 * s * h, f = 0; if ($n(u) && $n(c)) $n(s) ? (o[0] = 0) : (S = -l / s) >= 0 && S <= 1 && (o[f++] = S); else { var p = c * c - 4 * u * d; if ($n(p)) { var g = c / u, v = -g / 2; (S = -s / a + g) >= 0 && S <= 1 && (o[f++] = S), v >= 0 && v <= 1 && (o[f++] = v); } else if (p > 0) { var m = zp(p), y = u * s + 1.5 * a * (-c + m), x = u * s + 1.5 * a * (-c - m); (S = (-s - ((y = y < 0 ? -Op(-y, Rp) : Op(y, Rp)) + (x = x < 0 ? -Op(-x, Rp) : Op(x, Rp)))) / (3 * a)) >= 0 && S <= 1 && (o[f++] = S); } else { var _ = (2 * u * s - 3 * a * c) / (2 * zp(u * u * u)), w = Math.acos(_) / 3, b = zp(u), M = Math.cos(w), S = (-s - 2 * b * M) / (3 * a), v = (-s + b * (M + Bp * Math.sin(w))) / (3 * a), I = (-s + b * (M - Bp * Math.sin(w))) / (3 * a); S >= 0 && S <= 1 && (o[f++] = S), v >= 0 && v <= 1 && (o[f++] = v), I >= 0 && I <= 1 && (o[f++] = I); } } return f; } function ei(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 ($n(a)) Kn(o) && (c = -s / o) >= 0 && c <= 1 && (r[l++] = c); else { var h = o * o - 4 * a * s; if ($n(h)) r[0] = -o / (2 * a); else if (h > 0) { var u = zp(h), c = (-o + u) / (2 * a), d = (-o - u) / (2 * a); c >= 0 && c <= 1 && (r[l++] = c), d >= 0 && d <= 1 && (r[l++] = d); } } return l; } function ni(t, e, n, i, r, o) { var a = (e - t) * r + t, s = (n - e) * r + e, l = (i - n) * r + n, h = (s - a) * r + a, u = (l - s) * r + s, c = (u - h) * r + h; (o[0] = t), (o[1] = a), (o[2] = h), (o[3] = c), (o[4] = c), (o[5] = u), (o[6] = l), (o[7] = i); } function ii(t, e, n, i, r, o, a, s, l, h, u) { var c, d, f, p, g, v = 0.005, m = 1 / 0; (Vp[0] = l), (Vp[1] = h); for (var y = 0; y < 1; y += 0.05) (Gp[0] = Qn(t, n, r, a, y)), (Gp[1] = Qn(e, i, o, s, y)), (p = Hd(Vp, Gp)) < m && ((c = y), (m = p)); m = 1 / 0; for (var x = 0; x < 32 && !(v < Np); x++) (d = c - v), (f = c + v), (Gp[0] = Qn(t, n, r, a, d)), (Gp[1] = Qn(e, i, o, s, d)), (p = Hd(Gp, Vp)), d >= 0 && p < m ? ((c = d), (m = p)) : ((Wp[0] = Qn(t, n, r, a, f)), (Wp[1] = Qn(e, i, o, s, f)), (g = Hd(Wp, Vp)), f <= 1 && g < m ? ((c = f), (m = g)) : (v *= 0.5)); return u && ((u[0] = Qn(t, n, r, a, c)), (u[1] = Qn(e, i, o, s, c))), zp(m); } function ri(t, e, n, i) { var r = 1 - i; return r * (r * t + 2 * i * e) + i * i * n; } function oi(t, e, n, i) { return 2 * ((1 - i) * (e - t) + i * (n - e)); } function ai(t, e, n, i, r) { var o = t - 2 * e + n, a = 2 * (e - t), s = t - i, l = 0; if ($n(o)) Kn(a) && (c = -s / a) >= 0 && c <= 1 && (r[l++] = c); else { var h = a * a - 4 * o * s; if ($n(h)) (c = -a / (2 * o)) >= 0 && c <= 1 && (r[l++] = c); else if (h > 0) { var u = zp(h), c = (-a + u) / (2 * o), d = (-a - u) / (2 * o); c >= 0 && c <= 1 && (r[l++] = c), d >= 0 && d <= 1 && (r[l++] = d); } } return l; } function si(t, e, n) { var i = t + n - 2 * e; return 0 === i ? 0.5 : (t - e) / i; } function li(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 hi(t, e, n, i, r, o, a, s, l) { var h, u = 0.005, c = 1 / 0; (Vp[0] = a), (Vp[1] = s); for (var d = 0; d < 1; d += 0.05) (Gp[0] = ri(t, n, r, d)), (Gp[1] = ri(e, i, o, d)), (v = Hd(Vp, Gp)) < c && ((h = d), (c = v)); c = 1 / 0; for (var f = 0; f < 32 && !(u < Np); f++) { var p = h - u, g = h + u; (Gp[0] = ri(t, n, r, p)), (Gp[1] = ri(e, i, o, p)); var v = Hd(Gp, Vp); if (p >= 0 && v < c) (h = p), (c = v); else { (Wp[0] = ri(t, n, r, g)), (Wp[1] = ri(e, i, o, g)); var m = Hd(Wp, Vp); g <= 1 && m < c ? ((h = g), (c = m)) : (u *= 0.5); } } return l && ((l[0] = ri(t, n, r, h)), (l[1] = ri(e, i, o, h))), zp(c); } function ui(t, e, n) { if (0 !== t.length) { var i, r = t[0], o = r[0], a = r[0], s = r[1], l = r[1]; for (i = 1; i < t.length; i++) (r = t[i]), (o = Hp(o, r[0])), (a = Fp(a, r[0])), (s = Hp(s, r[1])), (l = Fp(l, r[1])); (e[0] = o), (e[1] = s), (n[0] = a), (n[1] = l); } } function ci(t, e, n, i, r, o) { (r[0] = Hp(t, n)), (r[1] = Hp(e, i)), (o[0] = Fp(t, n)), (o[1] = Fp(e, i)); } function di(t, e, n, i, r, o, a, s, l, h) { var u, c = ei, d = Qn, f = c(t, n, r, a, $p); for ( l[0] = 1 / 0, l[1] = 1 / 0, h[0] = -1 / 0, h[1] = -1 / 0, u = 0; u < f; u++ ) { var p = d(t, n, r, a, $p[u]); (l[0] = Hp(p, l[0])), (h[0] = Fp(p, h[0])); } for (f = c(e, i, o, s, Kp), u = 0; u < f; u++) { var g = d(e, i, o, s, Kp[u]); (l[1] = Hp(g, l[1])), (h[1] = Fp(g, h[1])); } (l[0] = Hp(t, l[0])), (h[0] = Fp(t, h[0])), (l[0] = Hp(a, l[0])), (h[0] = Fp(a, h[0])), (l[1] = Hp(e, l[1])), (h[1] = Fp(e, h[1])), (l[1] = Hp(s, l[1])), (h[1] = Fp(s, h[1])); } function fi(t, e, n, i, r, o, a, s) { var l = si, h = ri, u = Fp(Hp(l(t, n, r), 1), 0), c = Fp(Hp(l(e, i, o), 1), 0), d = h(t, n, r, u), f = h(e, i, o, c); (a[0] = Hp(t, r, d)), (a[1] = Hp(e, o, f)), (s[0] = Fp(t, r, d)), (s[1] = Fp(e, o, f)); } function pi(t, e, n, i, r, o, a, s, l) { var h = Y, u = $, c = Math.abs(r - o); if (c % Xp < 1e-4 && c > 1e-4) return ( (s[0] = t - n), (s[1] = e - i), (l[0] = t + n), void (l[1] = e + i) ); if ( ((jp[0] = Up(r) * n + t), (jp[1] = Zp(r) * i + e), (qp[0] = Up(o) * n + t), (qp[1] = Zp(o) * i + e), h(s, jp, qp), u(l, jp, qp), (r %= Xp) < 0 && (r += Xp), (o %= Xp) < 0 && (o += Xp), r > o && !a ? (o += Xp) : r < o && a && (r += Xp), a) ) { var d = o; (o = r), (r = d); } for (var f = 0; f < o; f += Math.PI / 2) f > r && ((Yp[0] = Up(f) * n + t), (Yp[1] = Zp(f) * i + e), h(s, Yp, s), u(l, Yp, l)); } function gi(t, e, n, i, r, o, a) { if (0 === r) return !1; var s = r, l = 0, h = t; 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 + (h = (t * i - n * e) / (t - n)); return (u * u) / (l * l + 1) <= ((s / 2) * s) / 2; } function vi(t, e, n, i, r, o, a, s, l, h, u) { if (0 === l) return !1; var c = l; return ( !( (u > e + c && u > i + c && u > o + c && u > s + c) || (u < e - c && u < i - c && u < o - c && u < s - c) || (h > t + c && h > n + c && h > r + c && h > a + c) || (h < t - c && h < n - c && h < r - c && h < a - c) ) && ii(t, e, n, i, r, o, a, s, h, u, null) <= c / 2 ); } function mi(t, e, n, i, r, o, a, s, l) { if (0 === a) return !1; var h = a; return ( !( (l > e + h && l > i + h && l > o + h) || (l < e - h && l < i - h && l < o - h) || (s > t + h && s > n + h && s > r + h) || (s < t - h && s < n - h && s < r - h) ) && hi(t, e, n, i, r, o, s, l, null) <= h / 2 ); } function yi(t) { return (t %= cg) < 0 && (t += cg), t; } function xi(t, e, n, i, r, o, a, s, l) { if (0 === a) return !1; var h = a; (s -= t), (l -= e); var u = Math.sqrt(s * s + l * l); if (u - h > n || u + h < n) return !1; if (Math.abs(i - r) % dg < 1e-4) return !0; if (o) { var c = i; (i = yi(r)), (r = yi(c)); } else (i = yi(i)), (r = yi(r)); i > r && (r += dg); var d = Math.atan2(l, s); return ( d < 0 && (d += dg), (d >= i && d <= r) || (d + dg >= i && d + dg <= r) ); } function _i(t, e, n, i, r, o) { if ((o > e && o > i) || (o < e && o < i)) return 0; if (i === e) return 0; var a = i < e ? 1 : -1, s = (o - e) / (i - e); return ( (1 !== s && 0 !== s) || (a = i < e ? 0.5 : -0.5), s * (n - t) + t > r ? a : 0 ); } function wi(t, e) { return Math.abs(t - e) < gg; } function bi() { var t = mg[0]; (mg[0] = mg[1]), (mg[1] = t); } function Mi(t, e, n, i, r, o, a, s, l, h) { if ( (h > e && h > i && h > o && h > s) || (h < e && h < i && h < o && h < s) ) return 0; var u = ti(e, i, o, s, h, vg); if (0 === u) return 0; for (var c, d, f = 0, p = -1, g = 0; g < u; g++) { var v = vg[g], m = 0 === v || 1 === v ? 0.5 : 1; Qn(t, n, r, a, v) < l || (p < 0 && ((p = ei(e, i, o, s, mg)), mg[1] < mg[0] && p > 1 && bi(), (c = Qn(e, i, o, s, mg[0])), p > 1 && (d = Qn(e, i, o, s, mg[1]))), 2 == p ? v < mg[0] ? (f += c < e ? m : -m) : v < mg[1] ? (f += d < c ? m : -m) : (f += s < d ? m : -m) : v < mg[0] ? (f += c < e ? m : -m) : (f += s < c ? m : -m)); } return f; } function Si(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 = ai(e, i, o, s, vg); if (0 === l) return 0; var h = si(e, i, o); if (h >= 0 && h <= 1) { for (var u = 0, c = ri(e, i, o, h), d = 0; d < l; d++) { f = 0 === vg[d] || 1 === vg[d] ? 0.5 : 1; (p = ri(t, n, r, vg[d])) < a || (vg[d] < h ? (u += c < e ? f : -f) : (u += o < c ? f : -f)); } return u; } var f = 0 === vg[0] || 1 === vg[0] ? 0.5 : 1, p = ri(t, n, r, vg[0]); return p < a ? 0 : o < e ? f : -f; } function Ii(t, e, n, i, r, o, a, s) { if ((s -= e) > n || s < -n) return 0; h = Math.sqrt(n * n - s * s); (vg[0] = -h), (vg[1] = h); var l = Math.abs(i - r); if (l < 1e-4) return 0; if (l % pg < 1e-4) { (i = 0), (r = pg); p = o ? 1 : -1; return a >= vg[0] + t && a <= vg[1] + t ? p : 0; } if (o) { var h = i; (i = yi(r)), (r = yi(h)); } else (i = yi(i)), (r = yi(r)); i > r && (r += pg); for (var u = 0, c = 0; c < 2; c++) { var d = vg[c]; if (d + t > a) { var f = Math.atan2(s, d), p = o ? 1 : -1; f < 0 && (f = pg + f), ((f >= i && f <= r) || (f + pg >= i && f + pg <= r)) && (f > Math.PI / 2 && f < 1.5 * Math.PI && (p = -p), (u += p)); } } return u; } function Ti(t, e, n, i, r) { for (var o = 0, a = 0, s = 0, l = 0, h = 0, u = 0; u < t.length; ) { var c = t[u++]; switch ( (c === fg.M && u > 1 && (n || (o += _i(a, s, l, h, i, r))), 1 == u && ((l = a = t[u]), (h = s = t[u + 1])), c) ) { case fg.M: (a = l = t[u++]), (s = h = t[u++]); break; case fg.L: if (n) { if (gi(a, s, t[u], t[u + 1], e, i, r)) return !0; } else o += _i(a, s, t[u], t[u + 1], i, r) || 0; (a = t[u++]), (s = t[u++]); break; case fg.C: if (n) { if ( vi(a, s, t[u++], t[u++], t[u++], t[u++], t[u], t[u + 1], e, i, r) ) return !0; } else o += Mi(a, s, t[u++], t[u++], t[u++], t[u++], t[u], t[u + 1], i, r) || 0; (a = t[u++]), (s = t[u++]); break; case fg.Q: if (n) { if (mi(a, s, t[u++], t[u++], t[u], t[u + 1], e, i, r)) return !0; } else o += Si(a, s, t[u++], t[u++], t[u], t[u + 1], i, r) || 0; (a = t[u++]), (s = t[u++]); break; case fg.A: var d = t[u++], f = t[u++], p = t[u++], g = t[u++], v = t[u++], m = t[u++], y = (t[u++], 1 - t[u++]), x = Math.cos(v) * p + d, _ = Math.sin(v) * g + f; u > 1 ? (o += _i(a, s, x, _, i, r)) : ((l = x), (h = _)); var w = ((i - d) * g) / p + d; if (n) { if (xi(d, f, g, v, v + m, y, e, w, r)) return !0; } else o += Ii(d, f, g, v, v + m, y, w, r); (a = Math.cos(v + m) * p + d), (s = Math.sin(v + m) * g + f); break; case fg.R: (l = a = t[u++]), (h = s = t[u++]); var x = l + t[u++], _ = h + t[u++]; if (n) { if ( gi(l, h, x, h, e, i, r) || gi(x, h, x, _, e, i, r) || gi(x, _, l, _, e, i, r) || gi(l, _, l, h, e, i, r) ) return !0; } else (o += _i(x, h, x, _, i, r)), (o += _i(l, _, l, h, i, r)); break; case fg.Z: if (n) { if (gi(a, s, l, h, e, i, r)) return !0; } else o += _i(a, s, l, h, i, r); (a = l), (s = h); } } return n || wi(s, h) || (o += _i(a, s, l, h, i, r) || 0), 0 !== o; } function Ai(t, e, n) { return Ti(t, 0, !1, e, n); } function Ci(t, e, n, i) { return Ti(t, e, !0, n, i); } function ki(t) { Ze.call(this, t), (this.path = null); } function Di(t, e, n, i, r, o, a, s, l, h, u) { var c = l * (Dg / 180), d = (kg(c) * (t - n)) / 2 + (Cg(c) * (e - i)) / 2, f = (-1 * Cg(c) * (t - n)) / 2 + (kg(c) * (e - i)) / 2, p = (d * d) / (a * a) + (f * f) / (s * s); p > 1 && ((a *= Ag(p)), (s *= Ag(p))); var g = (r === o ? -1 : 1) * Ag( (a * a * (s * s) - a * a * (f * f) - s * s * (d * d)) / (a * a * (f * f) + s * s * (d * d)) ) || 0, v = (g * a * f) / s, m = (g * -s * d) / a, y = (t + n) / 2 + kg(c) * v - Cg(c) * m, x = (e + i) / 2 + Cg(c) * v + kg(c) * m, _ = Og([1, 0], [(d - v) / a, (f - m) / s]), w = [(d - v) / a, (f - m) / s], b = [(-1 * d - v) / a, (-1 * f - m) / s], M = Og(w, b); Lg(w, b) <= -1 && (M = Dg), Lg(w, b) >= 1 && (M = 0), 0 === o && M > 0 && (M -= 2 * Dg), 1 === o && M < 0 && (M += 2 * Dg), u.addData(h, y, x, a, s, _, M, c, o); } function Pi(t) { if (!t) return []; var e, n = t .replace(/-/g, ' -') .replace(/ /g, ' ') .replace(/ /g, ',') .replace(/,,/g, ','); for (e = 0; e < Tg.length; e++) n = n.replace(new RegExp(Tg[e], 'g'), '|' + Tg[e]); var i, r = n.split('|'), o = 0, a = 0, s = new ug(), l = ug.CMD; for (e = 1; e < r.length; e++) { var h, u = r[e], c = u.charAt(0), d = 0, f = u.slice(1).replace(/e,-/g, 'e-').split(','); f.length > 0 && '' === f[0] && f.shift(); for (var p = 0; p < f.length; p++) f[p] = parseFloat(f[p]); for (; d < f.length && !isNaN(f[d]) && !isNaN(f[0]); ) { var g, v, m, y, x, _, w, b = o, M = a; switch (c) { case 'l': (o += f[d++]), (a += f[d++]), (h = l.L), s.addData(h, o, a); break; case 'L': (o = f[d++]), (a = f[d++]), (h = l.L), s.addData(h, o, a); break; case 'm': (o += f[d++]), (a += f[d++]), (h = l.M), s.addData(h, o, a), (c = 'l'); break; case 'M': (o = f[d++]), (a = f[d++]), (h = l.M), s.addData(h, o, a), (c = 'L'); break; case 'h': (o += f[d++]), (h = l.L), s.addData(h, o, a); break; case 'H': (o = f[d++]), (h = l.L), s.addData(h, o, a); break; case 'v': (a += f[d++]), (h = l.L), s.addData(h, o, a); break; case 'V': (a = f[d++]), (h = l.L), s.addData(h, o, a); break; case 'C': (h = l.C), s.addData(h, f[d++], f[d++], f[d++], f[d++], f[d++], f[d++]), (o = f[d - 2]), (a = f[d - 1]); break; case 'c': (h = l.C), s.addData( h, f[d++] + o, f[d++] + a, f[d++] + o, f[d++] + a, f[d++] + o, f[d++] + a ), (o += f[d - 2]), (a += f[d - 1]); break; case 'S': (g = o), (v = a); var S = s.len(), I = s.data; i === l.C && ((g += o - I[S - 4]), (v += a - I[S - 3])), (h = l.C), (b = f[d++]), (M = f[d++]), (o = f[d++]), (a = f[d++]), s.addData(h, g, v, b, M, o, a); break; case 's': (g = o), (v = a); var S = s.len(), I = s.data; i === l.C && ((g += o - I[S - 4]), (v += a - I[S - 3])), (h = l.C), (b = o + f[d++]), (M = a + f[d++]), (o += f[d++]), (a += f[d++]), s.addData(h, g, v, b, M, o, a); break; case 'Q': (b = f[d++]), (M = f[d++]), (o = f[d++]), (a = f[d++]), (h = l.Q), s.addData(h, b, M, o, a); break; case 'q': (b = f[d++] + o), (M = f[d++] + a), (o += f[d++]), (a += f[d++]), (h = l.Q), s.addData(h, b, M, o, a); break; case 'T': (g = o), (v = a); var S = s.len(), I = s.data; i === l.Q && ((g += o - I[S - 4]), (v += a - I[S - 3])), (o = f[d++]), (a = f[d++]), (h = l.Q), s.addData(h, g, v, o, a); break; case 't': (g = o), (v = a); var S = s.len(), I = s.data; i === l.Q && ((g += o - I[S - 4]), (v += a - I[S - 3])), (o += f[d++]), (a += f[d++]), (h = l.Q), s.addData(h, g, v, o, a); break; case 'A': (m = f[d++]), (y = f[d++]), (x = f[d++]), (_ = f[d++]), (w = f[d++]), Di( (b = o), (M = a), (o = f[d++]), (a = f[d++]), _, w, m, y, x, (h = l.A), s ); break; case 'a': (m = f[d++]), (y = f[d++]), (x = f[d++]), (_ = f[d++]), (w = f[d++]), Di( (b = o), (M = a), (o += f[d++]), (a += f[d++]), _, w, m, y, x, (h = l.A), s ); } } ('z' !== c && 'Z' !== c) || ((h = l.Z), s.addData(h)), (i = h); } return s.toStatic(), s; } function Li(t, e) { var n = Pi(t); return ( (e = e || {}), (e.buildPath = function (t) { if (t.setData) t.setData(n.data), (e = t.getContext()) && t.rebuildPath(e); else { var e = t; n.rebuildPath(e); } }), (e.applyTransform = function (t) { Ig(n, t), this.dirty(!0); }), e ); } function Oi(t, e) { return new ki(Li(t, e)); } function zi(t, e) { return ki.extend(Li(t, e)); } function Ei(t, e, n, i, r, o, a) { var s = 0.5 * (n - t), l = 0.5 * (i - e); return ( (2 * (e - n) + s + l) * a + (-3 * (e - n) - 2 * s - l) * o + s * r + e ); } function Ni(t, e, n) { var i = e.points, r = e.smooth; if (i && i.length >= 2) { if (r && 'spline' !== r) { var o = Wg(i, r, n, e.smoothConstraint); t.moveTo(i[0][0], i[0][1]); for (var a = i.length, s = 0; s < (n ? a : a - 1); s++) { var l = o[2 * s], h = o[2 * s + 1], u = i[(s + 1) % a]; t.bezierCurveTo(l[0], l[1], h[0], h[1], u[0], u[1]); } } else { 'spline' === r && (i = Gg(i, n)), t.moveTo(i[0][0], i[0][1]); for (var s = 1, c = i.length; s < c; s++) t.lineTo(i[s][0], i[s][1]); } n && t.closePath(); } } function Bi(t, e, n) { var i = t.cpx2, r = t.cpy2; return null === i || null === r ? [ (n ? Jn : Qn)(t.x1, t.cpx1, t.cpx2, t.x2, e), (n ? Jn : Qn)(t.y1, t.cpy1, t.cpy2, t.y2, e), ] : [ (n ? oi : ri)(t.x1, t.cpx1, t.x2, e), (n ? oi : ri)(t.y1, t.cpy1, t.y2, e), ]; } function Ri(t) { return ki.extend(t); } function Vi(t, e, n, i) { var r = Oi(t, e), o = r.getBoundingRect(); return n && ('center' === i && (n = Wi(n, o)), Hi(r, n)), r; } function Gi(t, e, n) { var i = new Ue({ 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(Wi(e, r)); } }, }); return i; } function Wi(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, } ); } function Hi(t, e) { if (t.applyTransform) { var n = t.getBoundingRect().calculateTransform(e); t.applyTransform(n); } } function Fi(t) { var e = t.shape, n = t.style.lineWidth; return ( Jg(2 * e.x1) === Jg(2 * e.x2) && (e.x1 = e.x2 = Ui(e.x1, n, !0)), Jg(2 * e.y1) === Jg(2 * e.y2) && (e.y1 = e.y2 = Ui(e.y1, n, !0)), t ); } function Zi(t) { var e = t.shape, n = t.style.lineWidth, i = e.x, r = e.y, o = e.width, a = e.height; return ( (e.x = Ui(e.x, n, !0)), (e.y = Ui(e.y, n, !0)), (e.width = Math.max(Ui(i + o, n, !1) - e.x, 0 === o ? 0 : 1)), (e.height = Math.max(Ui(r + a, n, !1) - e.y, 0 === a ? 0 : 1)), t ); } function Ui(t, e, n) { var i = Jg(2 * t); return (i + Jg(e)) % 2 == 0 ? i / 2 : (i + (n ? 1 : -1)) / 2; } function Xi(t) { return null != t && 'none' != t; } function ji(t) { return 'string' == typeof t ? It(t, -0.1) : t; } function qi(t) { if (t.__hoverStlDirty) { var e = t.style.stroke, n = t.style.fill, i = t.__hoverStl; (i.fill = i.fill || (Xi(n) ? ji(n) : null)), (i.stroke = i.stroke || (Xi(e) ? ji(e) : null)); var r = {}; for (var o in i) null != i[o] && (r[o] = t.style[o]); (t.__normalStl = r), (t.__hoverStlDirty = !1); } } function Yi(t) { if (!t.__isHover) { if ((qi(t), t.useHoverLayer)) t.__zr && t.__zr.addHover(t, t.__hoverStl); else { var e = t.style, n = e.insideRollbackOpt; n && dr(e), e.extendFrom(t.__hoverStl), n && (cr(e, e.insideOriginalTextPosition, n), null == e.textFill && (e.textFill = n.autoColor)), t.dirty(!1), (t.z2 += 1); } t.__isHover = !0; } } function $i(t) { if (t.__isHover) { var e = t.__normalStl; t.useHoverLayer ? t.__zr && t.__zr.removeHover(t) : (e && t.setStyle(e), (t.z2 -= 1)), (t.__isHover = !1); } } function Ki(t) { 'group' === t.type ? t.traverse(function (t) { 'group' !== t.type && Yi(t); }) : Yi(t); } function Qi(t) { 'group' === t.type ? t.traverse(function (t) { 'group' !== t.type && $i(t); }) : $i(t); } function Ji(t, e) { (t.__hoverStl = t.hoverStyle || e || {}), (t.__hoverStlDirty = !0), t.__isHover && qi(t); } function tr(t) { (this.__hoverSilentOnTouch && t.zrByTouch) || (!this.__isEmphasis && Ki(this)); } function er(t) { (this.__hoverSilentOnTouch && t.zrByTouch) || (!this.__isEmphasis && Qi(this)); } function nr() { (this.__isEmphasis = !0), Ki(this); } function ir() { (this.__isEmphasis = !1), Qi(this); } function rr(t, e, n) { (t.__hoverSilentOnTouch = n && n.hoverSilentOnTouch), 'group' === t.type ? t.traverse(function (t) { 'group' !== t.type && Ji(t, e); }) : Ji(t, e), t.on('mouseover', tr).on('mouseout', er), t.on('emphasis', nr).on('normal', ir); } function or(t, e, n, i, r, o, a) { var s = (r = r || nv).labelFetcher, l = r.labelDataIndex, h = r.labelDimIndex, u = n.getShallow('show'), c = i.getShallow('show'), d = u || c ? T( s ? s.getFormattedLabel(l, 'normal', null, h) : null, r.defaultText ) : null, f = u ? d : null, p = c ? T(s ? s.getFormattedLabel(l, 'emphasis', null, h) : null, d) : null; (null == f && null == p) || (ar(t, n, o, r), ar(e, i, a, r, !0)), (t.text = f), (e.text = p); } function ar(t, e, n, i, r) { return ( sr(t, e, i, r), n && o(t, n), t.host && t.host.dirty && t.host.dirty(!1), t ); } function sr(t, e, n, i) { if ((n = n || nv).isRectText) { var r = e.getShallow('position') || (i ? null : 'inside'); 'outside' === r && (r = 'top'), (t.textPosition = r), (t.textOffset = e.getShallow('offset')); var o = e.getShallow('rotate'); null != o && (o *= Math.PI / 180), (t.textRotation = o), (t.textDistance = T(e.getShallow('distance'), i ? null : 5)); } var a, s = e.ecModel, l = s && s.option.textStyle, h = lr(e); if (h) { a = {}; for (var u in h) if (h.hasOwnProperty(u)) { var c = e.getModel(['rich', u]); hr((a[u] = {}), c, l, n, i); } } return ( (t.rich = a), hr(t, e, l, n, i, !0), n.forceRich && !n.textStyle && (n.textStyle = {}), t ); } function lr(t) { for (var e; t && t !== t.ecModel; ) { var n = (t.option || nv).rich; if (n) { e = e || {}; for (var i in n) n.hasOwnProperty(i) && (e[i] = 1); } t = t.parentModel; } return e; } function hr(t, e, n, i, r, o) { if ( ((n = (!r && n) || nv), (t.textFill = ur(e.getShallow('color'), i) || n.color), (t.textStroke = ur(e.getShallow('textBorderColor'), i) || n.textBorderColor), (t.textStrokeWidth = T( e.getShallow('textBorderWidth'), n.textBorderWidth )), !r) ) { if (o) { var a = t.textPosition; (t.insideRollback = cr(t, a, i)), (t.insideOriginalTextPosition = a), (t.insideRollbackOpt = i); } null == t.textFill && (t.textFill = i.autoColor); } (t.fontStyle = e.getShallow('fontStyle') || n.fontStyle), (t.fontWeight = e.getShallow('fontWeight') || n.fontWeight), (t.fontSize = e.getShallow('fontSize') || n.fontSize), (t.fontFamily = e.getShallow('fontFamily') || n.fontFamily), (t.textAlign = e.getShallow('align')), (t.textVerticalAlign = e.getShallow('verticalAlign') || e.getShallow('baseline')), (t.textLineHeight = e.getShallow('lineHeight')), (t.textWidth = e.getShallow('width')), (t.textHeight = e.getShallow('height')), (t.textTag = e.getShallow('tag')), (o && i.disableBox) || ((t.textBackgroundColor = ur(e.getShallow('backgroundColor'), i)), (t.textPadding = e.getShallow('padding')), (t.textBorderColor = ur(e.getShallow('borderColor'), i)), (t.textBorderWidth = e.getShallow('borderWidth')), (t.textBorderRadius = e.getShallow('borderRadius')), (t.textBoxShadowColor = e.getShallow('shadowColor')), (t.textBoxShadowBlur = e.getShallow('shadowBlur')), (t.textBoxShadowOffsetX = e.getShallow('shadowOffsetX')), (t.textBoxShadowOffsetY = e.getShallow('shadowOffsetY'))), (t.textShadowColor = e.getShallow('textShadowColor') || n.textShadowColor), (t.textShadowBlur = e.getShallow('textShadowBlur') || n.textShadowBlur), (t.textShadowOffsetX = e.getShallow('textShadowOffsetX') || n.textShadowOffsetX), (t.textShadowOffsetY = e.getShallow('textShadowOffsetY') || n.textShadowOffsetY); } function ur(t, e) { return 'auto' !== t ? t : e && e.autoColor ? e.autoColor : null; } function cr(t, e, n) { var i, r = n.useInsideStyle; return ( null == t.textFill && !1 !== r && (!0 === r || (n.isRectText && e && 'string' == typeof e && e.indexOf('inside') >= 0)) && ((i = { textFill: null, textStroke: t.textStroke, textStrokeWidth: t.textStrokeWidth, }), (t.textFill = '#fff'), null == t.textStroke && ((t.textStroke = n.autoColor), null == t.textStrokeWidth && (t.textStrokeWidth = 2))), i ); } function dr(t) { var e = t.insideRollback; e && ((t.textFill = e.textFill), (t.textStroke = e.textStroke), (t.textStrokeWidth = e.textStrokeWidth)); } function fr(t, e) { var n = e || e.getModel('textStyle'); return [ 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(' '); } function pr(t, e, n, i, r, o) { if ( ('function' == typeof r && ((o = r), (r = null)), i && i.isAnimationEnabled()) ) { var a = t ? 'Update' : '', s = i.getShallow('animationDuration' + a), l = i.getShallow('animationEasing' + a), h = i.getShallow('animationDelay' + a); 'function' == typeof h && (h = h( r, i.getAnimationDelayParams ? i.getAnimationDelayParams(e, r) : null )), 'function' == typeof s && (s = s(r)), s > 0 ? e.animateTo(n, s, h || 0, l, o, !!o) : (e.stopAnimation(), e.attr(n), o && o()); } else e.stopAnimation(), e.attr(n), o && o(); } function gr(t, e, n, i, r) { pr(!0, t, e, n, i, r); } function vr(t, e, n, i, r) { pr(!1, t, e, n, i, r); } function mr(t, e) { for (var n = it([]); t && t !== e; ) ot(n, t.getLocalTransform(), n), (t = t.parent); return n; } function yr(t, e, n) { return ( e && !c(e) && (e = Jd.getLocalTransform(e)), n && (e = ht([], e)), q([], t, e) ); } function xr(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 = yr(o, e, n)), Math.abs(o[0]) > Math.abs(o[1]) ? o[0] > 0 ? 'right' : 'left' : o[1] > 0 ? 'bottom' : 'top' ); } function _r(t, e, n, i) { function r(t) { var e = { position: R(t.position), rotation: t.rotation }; return t.shape && (e.shape = o({}, t.shape)), e; } if (t && e) { var a = (function (t) { var e = {}; return ( t.traverse(function (t) { !t.isGroup && t.anid && (e[t.anid] = t); }), e ); })(t); e.traverse(function (t) { if (!t.isGroup && t.anid) { var e = a[t.anid]; if (e) { var i = r(t); t.attr(r(e)), gr(t, i, n, t.dataIndex); } } }); } } function wr(t, e) { return f(t, function (t) { var n = t[0]; (n = tv(n, e.x)), (n = ev(n, e.x + e.width)); var i = t[1]; return (i = tv(i, e.y)), (i = ev(i, e.y + e.height)), [n, i]; }); } function br(t, e, n) { var i = ((e = o({ rectHover: !0 }, e)).style = { strokeNoScale: !0 }); if (((n = n || { x: -1, y: -1, width: 2, height: 2 }), t)) return 0 === t.indexOf('image://') ? ((i.image = t.slice(8)), a(i, n), new Ue(e)) : Vi(t.replace('path://', ''), e, n, 'center'); } function Mr(t, e, n) { (this.parentModel = e), (this.ecModel = n), (this.option = t); } function Sr(t, e, n) { for ( var i = 0; i < e.length && (!e[i] || null != (t = t && 'object' == typeof t ? t[e[i]] : null)); i++ ); return null == t && n && (t = n.get(e)), t; } function Ir(t, e) { var n = Hn(t, 'getParent'); return n ? n.call(t, e) : t.parentModel; } function Tr(t) { return t instanceof Array ? t : null == t ? [] : [t]; } function Ar(t, e) { if (t) for ( var n = (t.emphasis = t.emphasis || {}), i = (t.normal = t.normal || {}), r = 0, o = e.length; r < o; r++ ) { var a = e[r]; !n.hasOwnProperty(a) && i.hasOwnProperty(a) && (n[a] = i[a]); } } function Cr(t) { return t && (null == t.value ? t : t.value); } function kr(t) { return uv(t) && !(t instanceof Array); } function Dr(t, e) { var n = e && e.type; return 'ordinal' === n ? t : ('time' === n && 'number' != typeof t && null != t && '-' !== t && (t = +Dn(t)), null == t || '' === t ? NaN : +t); } function Pr(t, e) { e = (e || []).slice(); var n = f(t || [], function (t, e) { return { exist: t }; }); return ( hv(e, function (t, i) { if (uv(t)) { for (r = 0; r < n.length; r++) if (!n[r].option && null != t.id && n[r].exist.id === t.id + '') return (n[r].option = t), void (e[i] = null); for (var r = 0; r < n.length; r++) { var o = n[r].exist; if ( !( n[r].option || (null != o.id && null != t.id) || null == t.name || Or(t) || Or(o) || o.name !== t.name + '' ) ) return (n[r].option = t), void (e[i] = null); } } }), hv(e, function (t, e) { if (uv(t)) { for (var i = 0; i < n.length; i++) { var r = n[i].exist; if (!n[i].option && !Or(r) && null == t.id) { n[i].option = t; break; } } i >= n.length && n.push({ option: t }); } }), n ); } function Lr(t) { var e = z(); hv(t, function (t, n) { var i = t.exist; i && e.set(i.id, t); }), hv(t, function (t, n) { var i = t.option; D( !i || null == i.id || !e.get(i.id) || e.get(i.id) === t, 'id duplicates: ' + (i && i.id) ), i && null != i.id && e.set(i.id, t), !t.keyInfo && (t.keyInfo = {}); }), hv(t, function (t, n) { var i = t.exist, r = t.option, o = t.keyInfo; if (uv(r)) { if (((o.name = null != r.name ? r.name + '' : i ? i.name : '\0-'), i)) o.id = i.id; else if (null != r.id) o.id = r.id + ''; else { var a = 0; do { o.id = '\0' + o.name + '\0' + a++; } while (e.get(o.id)); } e.set(o.id, t); } }); } function Or(t) { return uv(t) && t.id && 0 === (t.id + '').indexOf('\0_ec_\0'); } function zr(t, e) { return null != e.dataIndexInside ? e.dataIndexInside : null != e.dataIndex ? y(e.dataIndex) ? f(e.dataIndex, function (e) { return t.indexOfRawIndex(e); }) : t.indexOfRawIndex(e.dataIndex) : null != e.name ? y(e.name) ? f(e.name, function (e) { return t.indexOfName(e); }) : t.indexOfName(e.name) : void 0; } function Er(t, e, n) { if (_(e)) { var i = {}; (i[e + 'Index'] = 0), (e = i); } var r = n && n.defaultMainType; !r || Vr(e, r + 'Index') || Vr(e, r + 'Id') || Vr(e, r + 'Name') || (e[r + 'Index'] = 0); var o = {}; return ( hv(e, function (i, r) { var i = e[r]; if ('dataIndex' !== r && 'dataIndexInside' !== r) { var a = r.match(/^(\w+)(Index|Id|Name)$/) || [], s = a[1], h = (a[2] || '').toLowerCase(); if ( !( !s || !h || null == i || ('index' === h && 'none' === i) || (n && n.includeMainTypes && l(n.includeMainTypes, s) < 0) ) ) { var u = { mainType: s }; ('index' === h && 'all' === i) || (u[h] = i); var c = t.queryComponents(u); (o[s + 'Models'] = c), (o[s + 'Model'] = c[0]); } } else o[r] = i; }), o ); } function Nr(t, e) { var n = t.dimensions; e = t.getDimension(e); for (var i = 0; i < n.length; i++) { var r = t.getDimensionInfo(n[i]); if (r.name === e) return r.coordDim; } } function Br(t, e) { var n = []; return ( hv(t.dimensions, function (i) { var r = t.getDimensionInfo(i); r.coordDim === e && (n[r.coordDimIndex] = r.name); }), n ); } function Rr(t, e) { var n = []; return ( hv(t.dimensions, function (i) { var r = t.getDimensionInfo(i), o = r.otherDims[e]; null != o && !1 !== o && (n[o] = r.name); }), n ); } function Vr(t, e) { return t && t.hasOwnProperty(e); } function Gr(t) { return [t || '', pv++, Math.random()].join(gv); } function Wr(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, h) { var u, c, d = l.position, f = l.getBoundingRect(), p = e.childAt(h + 1), g = p && p.getBoundingRect(); if ('horizontal' === t) { var v = f.width + (g ? -g.x + f.x : 0); (u = o + v) > i || l.newline ? ((o = 0), (u = v), (a += s + n), (s = f.height)) : (s = Math.max(s, f.height)); } else { var m = f.height + (g ? -g.y + f.y : 0); (c = a + m) > r || l.newline ? ((o += s + n), (a = 0), (c = m), (s = f.width)) : (s = Math.max(s, f.width)); } l.newline || ((d[0] = o), (d[1] = a), 'horizontal' === t ? (o = u + n) : (a = c + n)); }); } function Hr(t, e, n) { n = yp(n || 0); var i = e.width, r = e.height, o = wn(t.left, i), a = wn(t.top, r), s = wn(t.right, i), l = wn(t.bottom, r), h = wn(t.width, i), u = wn(t.height, r), c = n[2] + n[0], d = n[1] + n[3], f = t.aspect; switch ( (isNaN(h) && (h = i - s - d - o), isNaN(u) && (u = r - l - c - a), null != f && (isNaN(h) && isNaN(u) && (f > i / r ? (h = 0.8 * i) : (u = 0.8 * r)), isNaN(h) && (h = f * u), isNaN(u) && (u = h / f)), isNaN(o) && (o = i - s - h - d), isNaN(a) && (a = r - l - u - c), t.left || t.right) ) { case 'center': o = i / 2 - h / 2 - n[3]; break; case 'right': o = i - h - d; } switch (t.top || t.bottom) { case 'middle': case 'center': a = r / 2 - u / 2 - n[0]; break; case 'bottom': a = r - u - c; } (o = o || 0), (a = a || 0), isNaN(h) && (h = i - d - o - (s || 0)), isNaN(u) && (u = r - c - a - (l || 0)); var p = new Zt(o + n[3], a + n[0], h, u); return (p.margin = n), p; } function Fr(t, e, n, i, r) { var o = !r || !r.hv || r.hv[0], s = !r || !r.hv || r.hv[1], l = (r && r.boundingMode) || 'all'; if (o || s) { var h; if ('raw' === l) h = 'group' === t.type ? new Zt(0, 0, +e.width || 0, +e.height || 0) : t.getBoundingRect(); else if (((h = t.getBoundingRect()), t.needLocalTransform())) { var u = t.getLocalTransform(); (h = h.clone()).applyTransform(u); } e = Hr(a({ width: h.width, height: h.height }, e), n, i); var c = t.position, d = o ? e.x - h.x : 0, f = s ? e.y - h.y : 0; t.attr('position', 'raw' === l ? [d, f] : [c[0] + d, c[1] + f]); } } function Zr(t, e, n) { function i(n, i) { var a = {}, l = 0, h = {}, u = 0; if ( (vv(n, function (e) { h[e] = t[e]; }), vv(n, function (t) { r(e, t) && (a[t] = h[t] = e[t]), o(a, t) && l++, o(h, t) && u++; }), s[i]) ) return ( o(e, n[1]) ? (h[n[2]] = null) : o(e, n[2]) && (h[n[1]] = null), h ); if (2 !== u && l) { if (l >= 2) return a; for (var c = 0; c < n.length; c++) { var d = n[c]; if (!r(a, d) && r(t, d)) { a[d] = t[d]; break; } } return a; } return h; } function r(t, e) { return t.hasOwnProperty(e); } function o(t, e) { return null != t[e] && 'auto' !== t[e]; } function a(t, e, n) { vv(t, function (t) { e[t] = n[t]; }); } !w(n) && (n = {}); var s = n.ignoreSize; !y(s) && (s = [s, s]); var l = i(yv[0], 0), h = i(yv[1], 1); a(yv[0], t, l), a(yv[1], t, h); } function Ur(t) { return Xr({}, t); } function Xr(t, e) { return ( e && t && vv(mv, function (n) { e.hasOwnProperty(n) && (t[n] = e[n]); }), t ); } function jr(t, e) { d(e, function (e, r) { bv.hasClass(r) || ('object' == typeof e ? (t[r] = t[r] ? i(t[r], e, !1) : n(e)) : null == t[r] && (t[r] = e)); }); } function qr(t) { (t = t), (this.option = {}), (this.option[Lv] = 1), (this._componentsMap = z({ series: [] })), (this._seriesIndices = null), jr(t, this._theme.option), i(t, Sv, !1), this.mergeOption(t); } function Yr(t, e) { y(e) || (e = e ? [e] : []); var n = {}; return ( Tv(e, function (e) { n[e] = (t.get(e) || []).slice(); }), n ); } function $r(t, e, n) { return e.type ? e.type : n ? n.subType : bv.determineSubType(t, e); } function Kr(t) { return ( Cv(t, function (t) { return t.componentIndex; }) || [] ); } function Qr(t, e) { return e.hasOwnProperty('subType') ? Av(t, function (t) { return t.subType === e.subType; }) : t; } function Jr(t) { d( zv, function (e) { this[e] = v(t[e], t); }, this ); } function to() { this._coordinateSystems = []; } function eo(t) { (this._api = t), (this._timelineOptions = []), (this._mediaList = []), this._mediaDefault, (this._currentMediaIndices = []), this._optionBackup, this._newBaseOption; } function no(t, e, n) { var i, r, o = [], a = [], s = t.timeline; if ( (t.baseOption && (r = t.baseOption), (s || t.options) && ((r = r || {}), (o = (t.options || []).slice())), t.media) ) { r = r || {}; var l = t.media; Nv(l, function (t) { t && t.option && (t.query ? a.push(t) : i || (i = t)); }); } return ( r || (r = t), r.timeline || (r.timeline = s), Nv( [r].concat(o).concat( f(a, function (t) { return t.option; }) ), function (t) { Nv(e, function (e) { e(t, n); }); } ), { baseOption: r, timelineOptions: o, mediaDefault: i, mediaList: a } ); } function io(t, e, n) { var i = { width: e, height: n, aspectratio: e / n }, r = !0; return ( d(t, function (t, e) { var n = e.match(Gv); if (n && n[1] && n[2]) { var o = n[1], a = n[2].toLowerCase(); ro(i[a], t, o) || (r = !1); } }), r ); } function ro(t, e, n) { return 'min' === n ? t >= e : 'max' === n ? t <= e : t === e; } function oo(t, e) { return t.join(',') === e.join(','); } function ao(t, e) { Nv((e = e || {}), function (e, n) { if (null != e) { var i = t[n]; if (bv.hasClass(n)) { e = Tr(e); var r = Pr((i = Tr(i)), e); t[n] = Rv(r, function (t) { return t.option && t.exist ? Vv(t.exist, t.option, !0) : t.exist || t.option; }); } else t[n] = Vv(i, e, !0); } }); } function so(t) { var e = t && t.itemStyle; if (e) for (var n = 0, r = Fv.length; n < r; n++) { var o = Fv[n], a = e.normal, s = e.emphasis; a && a[o] && ((t[o] = t[o] || {}), t[o].normal ? i(t[o].normal, a[o]) : (t[o].normal = a[o]), (a[o] = null)), s && s[o] && ((t[o] = t[o] || {}), t[o].emphasis ? i(t[o].emphasis, s[o]) : (t[o].emphasis = s[o]), (s[o] = null)); } } function lo(t, e) { var n = Hv(t) && t[e], i = Hv(n) && n.textStyle; if (i) for (var r = 0, o = cv.length; r < o; r++) { var e = cv[r]; i.hasOwnProperty(e) && (n[e] = i[e]); } } function ho(t) { Hv(t) && (lo(t, 'normal'), lo(t, 'emphasis')); } function uo(t) { if (Hv(t)) { so(t), ho(t.label), ho(t.upperLabel), ho(t.edgeLabel); var e = t.markPoint; so(e), ho(e && e.label); var n = t.markLine; so(t.markLine), ho(n && n.label); var i = t.markArea; ho(i && i.label), lo(t, 'axisLabel'), lo(t, 'title'), lo(t, 'detail'); var r = t.data; if (r) for (a = 0; a < r.length; a++) so(r[a]), ho(r[a] && r[a].label); if ((e = t.markPoint) && e.data) for (var o = e.data, a = 0; a < o.length; a++) so(o[a]), ho(o[a] && o[a].label); if ((n = t.markLine) && n.data) for (var s = n.data, a = 0; a < s.length; a++) y(s[a]) ? (so(s[a][0]), ho(s[a][0] && s[a][0].label), so(s[a][1]), ho(s[a][1] && s[a][1].label)) : (so(s[a]), ho(s[a] && s[a].label)); } } function co(t) { return y(t) ? t : t ? [t] : []; } function fo(t) { return (y(t) ? t[0] : t) || {}; } function po(t, e) { e = e.split(','); for (var n = t, i = 0; i < e.length && null != (n = n && n[e[i]]); i++); return n; } function go(t, e, n, i) { e = e.split(','); for (var r, o = t, a = 0; a < e.length - 1; a++) null == o[(r = e[a])] && (o[r] = {}), (o = o[r]); (i || null == o[e[a]]) && (o[e[a]] = n); } function vo(t) { d(Uv, function (e) { e[0] in t && !(e[1] in t) && (t[e[1]] = t[e[0]]); }); } function mo() { (this.group = new Tf()), (this.uid = Gr('viewChart')); } function yo(t, e) { if (t && (t.trigger(e), 'group' === t.type)) for (var n = 0; n < t.childCount(); n++) yo(t.childAt(n), e); } function xo(t, e, n) { var i = zr(t, e); null != i ? d(Tr(i), function (e) { yo(t.getItemGraphicEl(e), n); }) : t.eachItemGraphicEl(function (t) { yo(t, n); }); } function _o(t, e, n) { function i() { (u = new Date().getTime()), (c = null), t.apply(a, s || []); } var r, o, a, s, l, h = 0, u = 0, c = null; e = e || 0; var d = function () { (r = new Date().getTime()), (a = this), (s = arguments); var t = l || e, d = l || n; (l = null), (o = r - (d ? h : u) - t), clearTimeout(c), d ? (c = setTimeout(i, t)) : o >= 0 ? i() : (c = setTimeout(i, -o)), (h = r); }; return ( (d.clear = function () { c && (clearTimeout(c), (c = null)); }), (d.debounceNextCall = function (t) { l = t; }), d ); } function wo(t, e, n, i) { var r = t[e]; if (r) { var o = r[Jv] || r, a = r[em]; if (r[tm] !== n || a !== i) { if (null == n || !i) return (t[e] = o); ((r = t[e] = _o(o, n, 'debounce' === i))[Jv] = o), (r[em] = i), (r[tm] = n); } return r; } } function bo(t, e) { var n = t[e]; n && n[Jv] && (t[e] = n[Jv]); } function Mo(t) { return function (e, n, i) { (e = e && e.toLowerCase()), Ud.prototype[t].call(this, e, n, i); }; } function So() { Ud.call(this); } function Io(t, e, i) { function r(t, e) { return t.prio - e.prio; } (i = i || {}), 'string' == typeof e && (e = bm[e]), this.id, this.group, (this._dom = t); var o = (this._zr = vn(t, { renderer: i.renderer || 'canvas', devicePixelRatio: i.devicePixelRatio, width: i.width, height: i.height, })); (this._throttledZrFlush = _o(v(o.flush, o), 17)), (e = n(e)) && qv(e, !0), (this._theme = e), (this._chartsViews = []), (this._chartsMap = {}), (this._componentsViews = []), (this._componentsMap = {}), (this._coordSysMgr = new to()), (this._api = Wo(this)), Ud.call(this), (this._messageCenter = new So()), this._initEvents(), (this.resize = v(this.resize, this)), (this._pendingActions = []), Qt(wm, r), Qt(ym, r), o.animation.on('frame', this._onframe, this), P(this); } function To(t, e, n) { var i, r = this._model, o = this._coordSysMgr.getCoordinateSystems(); e = Er(r, e); for (var a = 0; a < o.length; a++) { var s = o[a]; if (s[t] && null != (i = s[t](r, e, n))) return i; } } function Ao(t, e, n, i, r) { function o(i) { i && i.__alive && i[e] && i[e](i.__model, a, t._api, n); } var a = t._model; if (i) { var s = {}; (s[i + 'Id'] = n[i + 'Id']), (s[i + 'Index'] = n[i + 'Index']), (s[i + 'Name'] = n[i + 'Name']); var l = { mainType: i, query: s }; r && (l.subType = r), a && a.eachComponent( l, function (e, n) { o( t['series' === i ? '_chartsMap' : '_componentsMap'][e.__viewId] ); }, t ); } else im(t._componentsViews.concat(t._chartsViews), o); } function Co(t, e) { var n = t.type, i = t.escapeConnect, r = vm[n], s = r.actionInfo, l = (s.update || 'update').split(':'), h = l.pop(); (l = null != l[0] && rm(l[0])), (this[um] = !0); var u = [t], c = !1; t.batch && ((c = !0), (u = f(t.batch, function (e) { return (e = a(o({}, e), t)), (e.batch = null), e; }))); var d, p = [], g = 'highlight' === n || 'downplay' === n; im( u, function (t) { (d = r.action(t, this._model, this._api)), ((d = d || o({}, t)).type = s.event || d.type), p.push(d), g ? Ao(this, h, t, 'series') : l && Ao(this, h, t, l.main, l.sub); }, this ), 'none' === h || g || l || (this[cm] ? (pm.prepareAndUpdate.call(this, t), (this[cm] = !1)) : pm[h].call(this, t)), (d = c ? { type: s.event || n, escapeConnect: i, batch: p } : p[0]), (this[um] = !1), !e && this._messageCenter.trigger(d.type, d); } function ko(t) { for (var e = this._pendingActions; e.length; ) { var n = e.shift(); Co.call(this, n, t); } } function Do(t) { !t && this.trigger('updated'); } function Po(t, e, n) { var i = this._api; im( this._componentsViews, function (r) { var o = r.__model; r[t](o, e, i, n), Go(o, r); }, this ), e.eachSeries(function (r, o) { var a = this._chartsMap[r.__viewId]; a[t](r, e, i, n), Go(r, a), Vo(r, a); }, this), Ro(this._zr, e), im(_m, function (t) { t(e, i); }); } function Lo(t, e) { for ( var n = 'component' === t, i = n ? this._componentsViews : this._chartsViews, r = n ? this._componentsMap : this._chartsMap, o = this._zr, a = 0; a < i.length; a++ ) i[a].__alive = !1; e[n ? 'eachComponent' : 'eachSeries'](function (t, a) { if (n) { if ('series' === t) return; } else a = t; var s = '_ec_' + a.id + '_' + a.type, l = r[s]; if (!l) { var h = rm(a.type), u = n ? $v.getClass(h.main, h.sub) : mo.getClass(h.sub); if (!u) return; (l = new u()).init(e, this._api), (r[s] = l), i.push(l), o.add(l.group); } (a.__viewId = l.__id = s), (l.__alive = !0), (l.__model = a), (l.group.__ecComponentInfo = { mainType: a.mainType, index: a.componentIndex, }); }, this); for (a = 0; a < i.length; ) { var s = i[a]; s.__alive ? a++ : (o.remove(s.group), s.dispose(e, this._api), i.splice(a, 1), delete r[s.__id], (s.__id = s.group.__ecComponentInfo = null)); } } function Oo(t, e) { im(ym, function (n) { n.func(t, e); }); } function zo(t) { var e = {}; t.eachSeries(function (t) { var n = t.get('stack'), i = t.getData(); if (n && 'list' === i.type) { var r = e[n]; e.hasOwnProperty(n) && r && (i.stackedOn = r), (e[n] = i); } }); } function Eo(t, e) { var n = this._api; im(wm, function (i) { i.isLayout && i.func(t, n, e); }); } function No(t, e, n) { var i = this._api; t.clearColorPalette(), t.eachSeries(function (t) { t.clearColorPalette(); }), im(wm, function (r) { (!n || !r.isLayout) && r.func(t, i, e); }); } function Bo(t, e) { var n = this._api; im( this._componentsViews, function (i) { var r = i.__model; i.render(r, t, n, e), Go(r, i); }, this ), im( this._chartsViews, function (t) { t.__alive = !1; }, this ), t.eachSeries(function (i, r) { var o = this._chartsMap[i.__viewId]; (o.__alive = !0), o.render(i, t, n, e), (o.group.silent = !!i.get('silent')), Go(i, o), Vo(i, o); }, this), Ro(this._zr, t), im( this._chartsViews, function (e) { e.__alive || e.remove(t, n); }, this ); } function Ro(t, e) { var n = t.storage, i = 0; n.traverse(function (t) { t.isGroup || i++; }), i > e.get('hoverLayerThreshold') && !Md.node && n.traverse(function (t) { t.isGroup || (t.useHoverLayer = !0); }); } function Vo(t, e) { var n = 0; e.group.traverse(function (t) { 'group' === t.type || t.ignore || n++; }); var i = +t.get('progressive'), r = n > t.get('progressiveThreshold') && i && !Md.node; r && e.group.traverse(function (t) { t.isGroup || ((t.progressive = r ? Math.floor(n++ / i) : -1), r && t.stopAnimation(!0)); }); var o = t.get('blendMode') || null; e.group.traverse(function (t) { t.isGroup || t.setStyle('blend', o); }); } function Go(t, e) { var n = t.get('z'), i = t.get('zlevel'); e.group.traverse(function (t) { 'group' !== t.type && (null != n && (t.z = n), null != i && (t.zlevel = i)); }); } function Wo(t) { var e = t._coordSysMgr; return o(new Jr(t), { getCoordinateSystems: v(e.getCoordinateSystems, e), getComponentByElement: function (e) { for (; e; ) { var n = e.__ecComponentInfo; if (null != n) return t._model.getComponent(n.mainType, n.index); e = e.parent; } }, }); } function Ho(t) { function e(t, e) { for (var i = 0; i < t.length; i++) t[i][n] = e; } var n = '__connectUpdateStatus'; d(mm, function (i, r) { t._messageCenter.on(r, function (i) { if (Im[t.group] && 0 !== t[n]) { if (i && i.escapeConnect) return; var r = t.makeActionFromEvent(i), o = []; d(Sm, function (e) { e !== t && e.group === t.group && o.push(e); }), e(o, 0), im(o, function (t) { 1 !== t[n] && t.dispatchAction(r); }), e(o, 2); } }); }); } function Fo(t) { Im[t] = !1; } function Zo(t) { var e; return (e = t.getAttribute ? t.getAttribute(Cm) : t[Cm]), Sm[e]; } function Uo(t) { xm.push(t); } function Xo(t, e) { 'function' == typeof t && ((e = t), (t = am)), ym.push({ prio: t, func: e }); } function jo(t, e, n) { 'function' == typeof e && ((n = e), (e = '')); var i = w(t) ? t.type : [t, (t = { event: e })][0]; (t.event = (t.event || i).toLowerCase()), (e = t.event), D(dm.test(i) && dm.test(e)), vm[i] || (vm[i] = { action: n, actionInfo: t }), (mm[e] = i); } function qo(t, e) { 'function' == typeof t && ((e = t), (t = sm)), wm.push({ prio: t, func: e, isLayout: !0 }); } function Yo(t, e) { 'function' == typeof t && ((e = t), (t = lm)), wm.push({ prio: t, func: e }); } function $o(t, e) { Mm[t] = e; } function Ko(t) { return bv.extend(t); } function Qo(t) { return $v.extend(t); } function Jo(t) { return Yv.extend(t); } function ta(t) { return mo.extend(t); } function ea(t) { return t; } function na(t, e, n, i, r) { (this._old = t), (this._new = e), (this._oldKeyGetter = n || ea), (this._newKeyGetter = i || ea), (this.context = r); } function ia(t, e, n, i, r) { for (var o = 0; o < t.length; o++) { var a = '_ec_' + r[i](t[o], o), s = e[a]; null == s ? (n.push(a), (e[a] = o)) : (s.length || (e[a] = s = [s]), s.push(o)); } } function ra(t, e) { d(Em.concat(e.__wrappedMethods || []), function (n) { e.hasOwnProperty(n) && (t[n] = e[n]); }), (t.__wrappedMethods = e.__wrappedMethods); } function oa(t) { this._array = t || []; } function aa(t) { return y(t) || (t = [t]), t; } function sa(t, e) { var n = t.dimensions, i = new Nm(f(n, t.getDimensionInfo, t), t.hostModel); ra(i, t); for (var r = (i._storage = {}), o = t._storage, a = 0; a < n.length; a++) { var s = n[a], h = o[s]; l(e, s) >= 0 ? (r[s] = new h.constructor(o[s].length)) : (r[s] = o[s]); } return i; } function la(t, e, i) { function r(t, e, n) { Hm[e] ? (t.otherDims[e] = n) : ((t.coordDim = e), (t.coordDimIndex = n), h.set(e, !0)); } function o(t, e, n) { if (n || null != e.get(t)) { for (var i = 0; null != e.get(t + i); ) i++; t += i; } return e.set(t, !0), t; } (e = e || []), (i = i || {}), (t = (t || []).slice()); var a = (i.dimsDef || []).slice(), s = z(i.encodeDef), l = z(), h = z(), u = [], c = i.dimCount; if (null == c) { var d = ha(e[0]); (c = Math.max((y(d) && d.length) || 1, t.length, a.length)), Vm(t, function (t) { var e = t.dimsDef; e && (c = Math.max(c, e.length)); }); } for (var f = 0; f < c; f++) { var p = Gm(a[f]) ? { name: a[f] } : a[f] || {}, g = p.name, v = (u[f] = { otherDims: {} }); null != g && null == l.get(g) && ((v.name = v.tooltipName = g), l.set(g, f)), null != p.type && (v.type = p.type); } s.each(function (t, e) { (t = s.set(e, Tr(t).slice())), Vm(t, function (n, i) { Gm(n) && (n = l.get(n)), null != n && n < c && ((t[i] = n), r(u[n], e, i)); }); }); var m = 0; Vm(t, function (t, e) { var i, t, o, a; Gm(t) ? ((i = t), (t = {})) : ((i = t.name), (t = n(t)), (o = t.dimsDef), (a = t.otherDims), (t.name = t.coordDim = t.coordDimIndex = t.dimsDef = t.otherDims = null)); var l = Tr(s.get(i)); if (!l.length) for (var h = 0; h < ((o && o.length) || 1); h++) { for (; m < u.length && null != u[m].coordDim; ) m++; m < u.length && l.push(m++); } Vm(l, function (e, n) { var s = u[e]; r(Wm(s, t), i, n), null == s.name && o && (s.name = s.tooltipName = o[n]), a && Wm(s.otherDims, a); }); }); for (var x = i.extraPrefix || 'value', _ = 0; _ < c; _++) null == (v = u[_] = u[_] || {}).coordDim && ((v.coordDim = o(x, h, i.extraFromZero)), (v.coordDimIndex = 0), (v.isExtraCoord = !0)), null == v.name && (v.name = o(v.coordDim, l)), null == v.type && Fm(e, _) && (v.type = 'ordinal'); return u; } function ha(t) { return y(t) ? t : w(t) ? t.value : t; } function ua(t) { for (var e = 0; e < t.length && null == t[e]; ) e++; return t[e]; } function ca(t) { var e = ua(t); return null != e && !y(Cr(e)); } function da(t, e, n) { t = t || []; var i = e.get('coordinateSystem'), r = Zm[i], o = to.get(i), a = { encodeDef: e.get('encode'), dimsDef: e.get('dimensions') }, s = r && r(t, e, n, a), h = s && s.dimensions; h || ((h = (o && (o.getDimensionsInfo ? o.getDimensionsInfo() : o.dimensions.slice())) || ['x', 'y']), (h = la(h, t, a))); var u = s ? s.categoryIndex : -1, c = new Nm(h, e), d = ga(s, t), f = {}, p = u >= 0 && ca(t) ? function (t, e, n, i) { return ( kr(t) && (c.hasItemOption = !0), i === u ? n : Dr(Cr(t), h[i]) ); } : function (t, e, n, i) { var r = Cr(t), o = Dr(r && r[i], h[i]); kr(t) && (c.hasItemOption = !0); var a = s && s.categoryAxesModels; return ( a && a[e] && 'string' == typeof o && ((f[e] = f[e] || a[e].getCategories()), (o = l(f[e], o)) < 0 && !isNaN(o) && (o = +o)), o ); }; return (c.hasItemOption = !1), c.initData(t, d, p), c; } function fa(t) { return 'category' !== t && 'time' !== t; } function pa(t) { return 'category' === t ? 'ordinal' : 'time' === t ? 'time' : 'float'; } function ga(t, e) { var n, i = [], r = t && t.dimensions[t.categoryIndex]; if ((r && (n = t.categoryAxesModels[r.name]), n)) { var o = n.getCategories(); if (o) { var a = e.length; if (y(e[0]) && e[0].length > 1) { i = []; for (var s = 0; s < a; s++) i[s] = o[e[s][t.categoryIndex || 0]]; } else i = o.slice(0); } } return i; } function va(t) { (this._setting = t || {}), (this._extent = [1 / 0, -1 / 0]), (this._interval = 0), this.init && this.init.apply(this, arguments); } function ma(t, e, n, i) { var r = {}, o = t[1] - t[0], a = (r.interval = On(o / e, !0)); null != n && a < n && (a = r.interval = n), null != i && a > i && (a = r.interval = i); var s = (r.intervalPrecision = ya(a)); return ( _a( (r.niceTickExtent = [ jm(Math.ceil(t[0] / a) * a, s), jm(Math.floor(t[1] / a) * a, s), ]), t ), r ); } function ya(t) { return In(t) + 2; } function xa(t, e, n) { t[e] = Math.max(Math.min(t[e], n[1]), n[0]); } function _a(t, e) { !isFinite(t[0]) && (t[0] = e[0]), !isFinite(t[1]) && (t[1] = e[1]), xa(t, 0, e), xa(t, 1, e), t[0] > t[1] && (t[0] = t[1]); } function wa(t, e, n, i) { var r = []; if (!t) return r; e[0] < n[0] && r.push(e[0]); for ( var o = n[0]; o <= n[1] && (r.push(o), (o = jm(o + t, i)) !== r[r.length - 1]); ) if (r.length > 1e4) return []; return e[1] > (r.length ? r[r.length - 1] : n[1]) && r.push(e[1]), r; } function ba(t, e) { return oy(t, ry(e)); } function Ma(t, e) { var n, i, r, o = t.type, a = e.getMin(), s = e.getMax(), l = null != a, h = null != s, u = t.getExtent(); return ( 'ordinal' === o ? (n = (e.get('data') || []).length) : (y((i = e.get('boundaryGap'))) || (i = [i || 0, i || 0]), 'boolean' == typeof i[0] && (i = [0, 0]), (i[0] = wn(i[0], 1)), (i[1] = wn(i[1], 1)), (r = u[1] - u[0] || Math.abs(u[0]))), null == a && (a = 'ordinal' === o ? (n ? 0 : NaN) : u[0] - i[0] * r), null == s && (s = 'ordinal' === o ? (n ? n - 1 : NaN) : u[1] + i[1] * r), 'dataMin' === a ? (a = u[0]) : 'function' == typeof a && (a = a({ min: u[0], max: u[1] })), 'dataMax' === s ? (s = u[1]) : 'function' == typeof s && (s = s({ min: u[0], max: u[1] })), (null == a || !isFinite(a)) && (a = NaN), (null == s || !isFinite(s)) && (s = NaN), t.setBlank(S(a) || S(s)), e.getNeedCrossZero() && (a > 0 && s > 0 && !l && (a = 0), a < 0 && s < 0 && !h && (s = 0)), [a, s] ); } function Sa(t, e) { var n = Ma(t, e), i = null != e.getMin(), r = null != e.getMax(), o = e.get('splitNumber'); 'log' === t.type && (t.base = e.get('logBase')); var a = t.type; t.setExtent(n[0], n[1]), t.niceExtent({ splitNumber: o, fixMin: i, fixMax: r, minInterval: 'interval' === a || 'time' === a ? e.get('minInterval') : null, maxInterval: 'interval' === a || 'time' === a ? e.get('maxInterval') : null, }); var s = e.get('interval'); null != s && t.setInterval && t.setInterval(s); } function Ia(t, e) { if ((e = e || t.get('type'))) switch (e) { case 'category': return new Xm(t.getCategories(), [1 / 0, -1 / 0]); case 'value': return new Ym(); default: return (va.getClass(e) || Ym).create(t); } } function Ta(t, e, n, i, r) { var o, a = 0, s = 0, l = ((i - r) / 180) * Math.PI, h = 1; e.length > 40 && (h = Math.floor(e.length / 40)); for (var u = 0; u < t.length; u += h) { var c = t[u], d = he(e[u], n, 'center', 'top'); (d.x += c * Math.cos(l)), (d.y += c * Math.sin(l)), (d.width *= 1.3), (d.height *= 1.3), o ? o.intersect(d) ? (s++, (a = Math.max(a, s))) : (o.union(d), (s = 0)) : (o = d.clone()); } return 0 === a && h > 1 ? h : (a + 1) * h - 1; } function Aa(t, e) { var n = t.scale, i = n.getTicksLabels(), r = n.getTicks(); return 'string' == typeof e ? ((e = (function (t) { return function (e) { return t.replace('{value}', null != e ? e : ''); }; })(e)), f(i, e)) : 'function' == typeof e ? f( r, function (n, i) { return e(Ca(t, n), i); }, this ) : i; } function Ca(t, e) { return 'category' === t.type ? t.scale.getLabel(e) : e; } function ka(t) { return w(t) && null != t.value ? t.value : t + ''; } function Da(t, e) { if ('image' !== this.type) { var n = this.style, i = this.shape; i && 'line' === i.symbolType ? (n.stroke = t) : this.__isEmptyBrush ? ((n.stroke = t), (n.fill = e || '#fff')) : (n.fill && (n.fill = t), n.stroke && (n.stroke = t)), this.dirty(!1); } } function Pa(t, e, n, i, r, o, a) { var s = 0 === t.indexOf('empty'); s && (t = t.substr(5, 1).toLowerCase() + t.substr(6)); var l; return ( (l = 0 === t.indexOf('image://') ? Gi(t.slice(8), new Zt(e, n, i, r), a ? 'center' : 'cover') : 0 === t.indexOf('path://') ? Vi(t.slice(7), {}, new Zt(e, n, i, r), a ? 'center' : 'cover') : new yy({ shape: { symbolType: t, x: e, y: n, width: i, height: r }, })), (l.__isEmptyBrush = s), (l.setColor = Da), l.setColor(o), l ); } function La(t, e) { var n = (t[1] - t[0]) / e / 2; (t[0] += n), (t[1] -= n); } function Oa(t, e) { return Math.abs(t - e) < My; } function za(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 += _i(r[0], r[1], a[0], a[1], e, n)), (r = a); } var s = t[0]; return ( (Oa(r[0], s[0]) && Oa(r[1], s[1])) || (i += _i(r[0], r[1], s[0], s[1], e, n)), 0 !== i ); } function Ea(t, e, n) { if (((this.name = t), (this.geometries = e), n)) n = [n[0], n[1]]; else { var i = this.getBoundingRect(); n = [i.x + i.width / 2, i.y + i.height / 2]; } this.center = n; } function Na(t) { if (!t.UTF8Encoding) return t; var e = t.UTF8Scale; null == e && (e = 1024); for (var n = t.features, i = 0; i < n.length; i++) for ( var r = n[i].geometry, o = r.coordinates, a = r.encodeOffsets, s = 0; s < o.length; s++ ) { var l = o[s]; if ('Polygon' === r.type) o[s] = Ba(l, a[s], e); else if ('MultiPolygon' === r.type) for (var h = 0; h < l.length; h++) { var u = l[h]; l[h] = Ba(u, a[s][h], e); } } return (t.UTF8Encoding = !1), t; } function Ba(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 Ra(t) { var e, n = Rr(t, 'label'); if (n.length) e = n[0]; else for ( var i, r = t.dimensions.slice(); r.length && ((e = r.pop()), 'ordinal' === (i = t.getDimensionInfo(e).type) || 'time' === i); ); return e; } function Va(t, e) { var n = t.getItemVisual(e, 'symbolSize'); return n instanceof Array ? n.slice() : [+n, +n]; } function Ga(t) { return [t[0] / 2, t[1] / 2]; } function Wa(t, e, n) { Tf.call(this), this.updateData(t, e, n); } function Ha(t, e) { this.parent.drift(t, e); } function Fa(t) { (this.group = new Tf()), (this._symbolCtor = t || Wa); } function Za(t, e, n) { var i = t.getItemLayout(e); return ( i && !isNaN(i[0]) && !isNaN(i[1]) && !(n && n(e)) && 'none' !== t.getItemVisual(e, 'symbol') ); } function Ua(t) { return t >= 0 ? 1 : -1; } function Xa(t, e, n) { for ( var i, r = t.getBaseAxis(), o = t.getOtherAxis(r), a = r.onZero ? 0 : o.scale.getExtent()[0], s = o.dim, l = 'x' === s || 'radius' === s ? 1 : 0, h = e.stackedOn, u = e.get(s, n); h && Ua(h.get(s, n)) === Ua(u); ) { i = h; break; } var c = []; return ( (c[l] = e.get(r.dim, n)), (c[1 - l] = i ? i.get(s, n, !0) : a), t.dataToPoint(c) ); } function ja(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 ); } function qa(t) { return isNaN(t[0]) || isNaN(t[1]); } function Ya(t, e, n, i, r, o, a, s, l, h, u) { for (var c = 0, d = n, f = 0; f < i; f++) { var p = e[d]; if (d >= r || d < 0) break; if (qa(p)) { if (u) { d += o; continue; } break; } if (d === n) t[o > 0 ? 'moveTo' : 'lineTo'](p[0], p[1]), Ey(By, p); else if (l > 0) { var g = d + o, v = e[g]; if (u) for (; v && qa(e[g]); ) v = e[(g += o)]; var m = 0.5, y = e[c]; if (!(v = e[g]) || qa(v)) Ey(Ry, p); else { qa(v) && !u && (v = p), W(Ny, v, y); var x, _; if ('x' === h || 'y' === h) { var w = 'x' === h ? 0 : 1; (x = Math.abs(p[w] - y[w])), (_ = Math.abs(p[w] - v[w])); } else (x = Wd(p, y)), (_ = Wd(p, v)); zy(Ry, p, Ny, -l * (1 - (m = _ / (_ + x)))); } Ly(By, By, s), Oy(By, By, a), Ly(Ry, Ry, s), Oy(Ry, Ry, a), t.bezierCurveTo(By[0], By[1], Ry[0], Ry[1], p[0], p[1]), zy(By, p, Ny, l * m); } else t.lineTo(p[0], p[1]); (c = d), (d += o); } return f; } function $a(t, e) { var n = [1 / 0, 1 / 0], i = [-1 / 0, -1 / 0]; if (e) for (var r = 0; r < t.length; r++) { var o = t[r]; o[0] < n[0] && (n[0] = o[0]), o[1] < n[1] && (n[1] = o[1]), o[0] > i[0] && (i[0] = o[0]), o[1] > i[1] && (i[1] = o[1]); } return { min: e ? n : i, max: e ? i : n }; } function Ka(t, e) { if (t.length === e.length) { for (var n = 0; n < t.length; n++) { var i = t[n], r = e[n]; if (i[0] !== r[0] || i[1] !== r[1]) return; } return !0; } } function Qa(t) { return 'number' == typeof t ? t : t ? 0.3 : 0; } function Ja(t) { var e = t.getGlobalExtent(); if (t.onBand) { var n = t.getBandWidth() / 2 - 1, i = e[1] > e[0] ? 1 : -1; (e[0] += i * n), (e[1] -= i * n); } return e; } function ts(t) { return t >= 0 ? 1 : -1; } function es(t, e) { var n = t.getBaseAxis(), i = t.getOtherAxis(n), r = 0; if (!n.onZero) { var o = i.scale.getExtent(); o[0] > 0 ? (r = o[0]) : o[1] < 0 && (r = o[1]); } var a = i.dim, s = 'x' === a || 'radius' === a ? 1 : 0; return e.mapArray( [a], function (i, o) { for (var l, h = e.stackedOn; h && ts(h.get(a, o)) === ts(i); ) { l = h; break; } var u = []; return ( (u[s] = e.get(n.dim, o)), (u[1 - s] = l ? l.get(a, o, !0) : r), t.dataToPoint(u) ); }, !0 ); } function ns(t, e, n) { var i = Ja(t.getAxis('x')), r = Ja(t.getAxis('y')), o = t.getBaseAxis().isHorizontal(), a = Math.min(i[0], i[1]), s = Math.min(r[0], r[1]), l = Math.max(i[0], i[1]) - a, h = Math.max(r[0], r[1]) - s, u = n.get('lineStyle.normal.width') || 2, c = n.get('clipOverflow') ? u / 2 : Math.max(l, h); o ? ((s -= c), (h += 2 * c)) : ((a -= c), (l += 2 * c)); var d = new Zg({ shape: { x: a, y: s, width: l, height: h } }); return ( e && ((d.shape[o ? 'width' : 'height'] = 0), vr(d, { shape: { width: l, height: h } }, n)), d ); } function is(t, e, n) { var i = t.getAngleAxis(), r = t.getRadiusAxis().getExtent(), o = i.getExtent(), a = Math.PI / 180, s = new Rg({ shape: { cx: t.cx, cy: t.cy, r0: r[0], r: r[1], startAngle: -o[0] * a, endAngle: -o[1] * a, clockwise: i.inverse, }, }); return ( e && ((s.shape.endAngle = -o[0] * a), vr(s, { shape: { endAngle: -o[1] * a } }, n)), s ); } function rs(t, e, n) { return 'polar' === t.type ? is(t, e, n) : ns(t, e, n); } function os(t, e, n) { for ( var i = e.getBaseAxis(), r = 'x' === i.dim || 'radius' === i.dim ? 0 : 1, o = [], a = 0; a < t.length - 1; a++ ) { var s = t[a + 1], l = t[a]; o.push(l); var h = []; switch (n) { case 'end': (h[r] = s[r]), (h[1 - r] = l[1 - r]), o.push(h); break; case 'middle': var u = (l[r] + s[r]) / 2, c = []; (h[r] = c[r] = u), (h[1 - r] = l[1 - r]), (c[1 - r] = s[1 - r]), o.push(h), o.push(c); break; default: (h[r] = l[r]), (h[1 - r] = s[1 - r]), o.push(h); } } return t[a] && o.push(t[a]), o; } function as(t, e) { var n = t.getVisual('visualMeta'); if (n && n.length && t.count()) { for (var i, r = n.length - 1; r >= 0; r--) if (n[r].dimension < 2) { i = n[r]; break; } if (i && 'cartesian2d' === e.type) { var o = i.dimension, a = t.dimensions[o], s = e.getAxis(a), l = f(i.stops, function (t) { return { coord: s.toGlobalCoord(s.dataToCoord(t.value)), color: t.color, }; }), h = l.length, u = i.outerColors.slice(); h && l[0].coord > l[h - 1].coord && (l.reverse(), u.reverse()); var c = l[0].coord - 10, p = l[h - 1].coord + 10, g = p - c; if (g < 0.001) return 'transparent'; d(l, function (t) { t.offset = (t.coord - c) / g; }), l.push({ offset: h ? l[h - 1].offset : 0.5, color: u[1] || 'transparent', }), l.unshift({ offset: h ? l[0].offset : 0.5, color: u[0] || 'transparent', }); var v = new Kg(0, 0, 0, 0, l, !0); return (v[a] = c), (v[a + '2'] = p), v; } } } function ss(t) { return this._axes[t]; } function ls(t) { Uy.call(this, t); } function hs(t, e) { return e.type || (e.data ? 'category' : 'value'); } function us(t, e, n) { return t.getCoordSysModel() === e; } function cs(t, e) { var n = (e * Math.PI) / 180, i = t.plain(), r = i.width, o = i.height, a = r * Math.cos(n) + o * Math.sin(n), s = r * Math.sin(n) + o * Math.cos(n); return new Zt(i.x, i.y, a, s); } function ds(t) { var e, n = t.model, i = n.getFormattedLabels(), r = n.getModel('axisLabel'), o = 1, a = i.length; a > 40 && (o = Math.ceil(a / 40)); for (var s = 0; s < a; s += o) if (!t.isLabelIgnored(s)) { var l = cs(r.getTextRect(i[s]), r.get('rotate') || 0); e ? e.union(l) : (e = l); } return e; } function fs(t, e, n) { (this._coordsMap = {}), (this._coordsList = []), (this._axesMap = {}), (this._axesList = []), this._initCartesian(t, e, n), (this.model = t); } function ps(t, e, n) { var i = t[e]; if (n.onZero) { var r = n.onZeroAxisIndex; if (null == r) { for (var o in i) if (i.hasOwnProperty(o)) { var a = i[o]; if (a && !gs(a)) { r = +o; break; } } null == r && (n.onZero = !1), (n.onZeroAxisIndex = r); } else (a = i[r]) && gs(a) && (n.onZero = !1); } } function gs(t) { return 'category' === t.type || 'time' === t.type || !tx(t); } function vs(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; }); } function ms(t, e) { return f(ix, function (e) { return t.getReferringComponents(e)[0]; }); } function ys(t) { return 'cartesian2d' === t.get('coordinateSystem'); } function xs(t) { var e = { componentType: t.mainType }; return (e[t.mainType + 'Index'] = t.componentIndex), e; } function _s(t, e, n, i) { var r, o, a = Cn(n - t.rotation), s = i[0] > i[1], l = ('start' === e && !s) || ('start' !== e && s); return ( kn(a - rx / 2) ? ((o = l ? 'bottom' : 'top'), (r = 'center')) : kn(a - 1.5 * rx) ? ((o = l ? 'top' : 'bottom'), (r = 'center')) : ((o = 'middle'), (r = a < 1.5 * rx && a > rx / 2 ? l ? 'left' : 'right' : l ? 'right' : 'left')), { rotation: a, textAlign: r, textVerticalAlign: o } ); } function ws(t) { var e = t.get('tooltip'); return t.get('silent') || !(t.get('triggerEvent') || (e && e.show)); } function bs(t, e, n) { var i = t.get('axisLabel.showMinLabel'), r = t.get('axisLabel.showMaxLabel'); (e = e || []), (n = n || []); var o = e[0], a = e[1], s = e[e.length - 1], l = e[e.length - 2], h = n[0], u = n[1], c = n[n.length - 1], d = n[n.length - 2]; !1 === i ? (Ms(o), Ms(h)) : Ss(o, a) && (i ? (Ms(a), Ms(u)) : (Ms(o), Ms(h))), !1 === r ? (Ms(s), Ms(c)) : Ss(l, s) && (r ? (Ms(l), Ms(d)) : (Ms(s), Ms(c))); } function Ms(t) { t && (t.ignore = !0); } function Ss(t, e, n) { var i = t && t.getBoundingRect().clone(), r = e && e.getBoundingRect().clone(); if (i && r) { var o = it([]); return ( st(o, o, -t.rotation), i.applyTransform(ot([], o, t.getLocalTransform())), r.applyTransform(ot([], o, e.getLocalTransform())), i.intersect(r) ); } } function Is(t) { return 'middle' === t || 'center' === t; } function Ts(t, e, n) { var i = e.axis; if (e.get('axisTick.show') && !i.scale.isBlank()) { for ( var r = e.getModel('axisTick'), o = r.getModel('lineStyle'), s = r.get('length'), l = hx(r, n.labelInterval), h = i.getTicksCoords(r.get('alignWithLabel')), u = i.scale.getTicks(), c = e.get('axisLabel.showMinLabel'), d = e.get('axisLabel.showMaxLabel'), f = [], p = [], g = t._transform, v = [], m = h.length, y = 0; y < m; y++ ) if (!lx(i, y, l, m, c, d)) { var x = h[y]; (f[0] = x), (f[1] = 0), (p[0] = x), (p[1] = n.tickDirection * s), g && (q(f, f, g), q(p, p, g)); var _ = new Ug( Fi({ anid: 'tick_' + u[y], shape: { x1: f[0], y1: f[1], x2: p[0], y2: p[1] }, style: a(o.getLineStyle(), { stroke: e.get('axisLine.lineStyle.color'), }), z2: 2, silent: !0, }) ); t.group.add(_), v.push(_); } return v; } } function As(t, e, n) { var i = e.axis; if (I(n.axisLabelShow, e.get('axisLabel.show')) && !i.scale.isBlank()) { var r = e.getModel('axisLabel'), o = r.get('margin'), a = i.scale.getTicks(), s = e.getFormattedLabels(), l = ((I(n.labelRotate, r.get('rotate')) || 0) * rx) / 180, h = sx(n.rotation, l, n.labelDirection), u = e.get('data'), c = [], f = ws(e), p = e.get('triggerEvent'), g = e.get('axisLabel.showMinLabel'), v = e.get('axisLabel.showMaxLabel'); return ( d(a, function (l, d) { if (!lx(i, d, n.labelInterval, a.length, g, v)) { var m = r; u && u[l] && u[l].textStyle && (m = new Mr(u[l].textStyle, r, e.ecModel)); var y = m.getTextColor() || e.get('axisLine.lineStyle.color'), x = [i.dataToCoord(l), n.labelOffset + n.labelDirection * o], _ = i.scale.getLabel(l), w = new zg({ anid: 'label_' + l, position: x, rotation: h.rotation, silent: f, z2: 10, }); ar(w.style, m, { text: s[d], textAlign: m.getShallow('align', !0) || h.textAlign, textVerticalAlign: m.getShallow('verticalAlign', !0) || m.getShallow('baseline', !0) || h.textVerticalAlign, textFill: 'function' == typeof y ? y( 'category' === i.type ? _ : 'value' === i.type ? l + '' : l, d ) : y, }), p && ((w.eventData = xs(e)), (w.eventData.targetType = 'axisLabel'), (w.eventData.value = _)), t._dumbGroup.add(w), w.updateTransform(), c.push(w), t.group.add(w), w.decomposeTransform(); } }), c ); } } function Cs(t, e) { var n = { axesInfo: {}, seriesInvolved: !1, coordSysAxesInfo: {}, coordSysMap: {}, }; return ks(n, t, e), n.seriesInvolved && Ps(n, t), n; } function ks(t, e, n) { var i = e.getComponent('tooltip'), r = e.getComponent('axisPointer'), o = r.get('link', !0) || [], a = []; ux(n.getCoordinateSystems(), function (n) { function s(i, s, l) { var c = l.model.getModel('axisPointer', r), d = c.get('show'); if (d && ('auto' !== d || i || Bs(c))) { null == s && (s = c.get('triggerTooltip')); var f = (c = i ? Ds(l, u, r, e, i, s) : c).get('snap'), p = Rs(l.model), g = s || f || 'category' === l.type, v = (t.axesInfo[p] = { key: p, axis: l, coordSys: n, axisPointerModel: c, triggerTooltip: s, involveSeries: g, snap: f, useHandle: Bs(c), seriesModels: [], }); (h[p] = v), (t.seriesInvolved |= g); var m = Ls(o, l); if (null != m) { var y = a[m] || (a[m] = { axesInfo: {} }); (y.axesInfo[p] = v), (y.mapper = o[m].mapper), (v.linkGroup = y); } } } if (n.axisPointerEnabled) { var l = Rs(n.model), h = (t.coordSysAxesInfo[l] = {}); t.coordSysMap[l] = n; var u = n.model.getModel('tooltip', i); if ( (ux(n.getAxes(), cx(s, !1, null)), n.getTooltipAxes && i && u.get('show')) ) { var c = 'axis' === u.get('trigger'), d = 'cross' === u.get('axisPointer.type'), f = n.getTooltipAxes(u.get('axisPointer.axis')); (c || d) && ux(f.baseAxes, cx(s, !d || 'cross', c)), d && ux(f.otherAxes, cx(s, 'cross', !1)); } } }); } function Ds(t, e, i, r, o, s) { var l = e.getModel('axisPointer'), h = {}; ux( [ 'type', 'snap', 'lineStyle', 'shadowStyle', 'label', 'animation', 'animationDurationUpdate', 'animationEasingUpdate', 'z', ], function (t) { h[t] = n(l.get(t)); } ), (h.snap = 'category' !== t.type && !!s), 'cross' === l.get('type') && (h.type = 'line'); var u = h.label || (h.label = {}); if ( (null == u.show && (u.show = !1), 'cross' === o && ((u.show = !0), !s)) ) { var c = (h.lineStyle = l.get('crossStyle')); c && a(u, c.textStyle); } return t.model.getModel('axisPointer', new Mr(h, i, r)); } function Ps(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) && ux(t.coordSysAxesInfo[Rs(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())); }); }, this); } function Ls(t, e) { for (var n = e.model, i = e.dim, r = 0; r < t.length; r++) { var o = t[r] || {}; if ( Os(o[i + 'AxisId'], n.id) || Os(o[i + 'AxisIndex'], n.componentIndex) || Os(o[i + 'AxisName'], n.name) ) return r; } } function Os(t, e) { return 'all' === t || (y(t) && l(t, e) >= 0) || t === e; } function zs(t) { var e = Es(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 = Bs(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 Es(t) { var e = (t.ecModel.getComponent('axisPointer') || {}).coordSysAxesInfo; return e && e.axesInfo[Rs(t)]; } function Ns(t) { var e = Es(t); return e && e.axisPointerModel; } function Bs(t) { return !!t.get('handle.show'); } function Rs(t) { return t.type + '||' + t.id; } function Vs(t, e, n, i, r, o) { var a = dx.getAxisPointerClass(t.axisPointerClass); if (a) { var s = Ns(e); s ? (t._axisPointer || (t._axisPointer = new a())).render(e, s, i, o) : Gs(t, i); } } function Gs(t, e, n) { var i = t._axisPointer; i && i.dispose(e, n), (t._axisPointer = null); } function Ws(t, e, n) { n = n || {}; var i = t.coordinateSystem, r = e.axis, o = {}, a = r.position, s = r.onZero ? 'onZero' : a, l = r.dim, h = i.getRect(), u = [h.x, h.x + h.width, h.y, h.y + h.height], c = { left: 0, right: 1, top: 0, bottom: 1, onZero: 2 }, d = e.get('offset') || 0, f = 'x' === l ? [u[2] - d, u[3] + d] : [u[0] - d, u[1] + d]; if (r.onZero) { var p = i.getAxis('x' === l ? 'y' : 'x', r.onZeroAxisIndex), g = p.toGlobalCoord(p.dataToCoord(0)); f[c.onZero] = Math.max(Math.min(g, f[1]), f[0]); } (o.position = ['y' === l ? f[c[s]] : u[0], 'x' === l ? f[c[s]] : u[3]]), (o.rotation = (Math.PI / 2) * ('x' === l ? 0 : 1)); var v = { top: -1, bottom: 1, left: -1, right: 1 }; (o.labelDirection = o.tickDirection = o.nameDirection = v[a]), (o.labelOffset = r.onZero ? f[c[a]] - f[c.onZero] : 0), e.get('axisTick.inside') && (o.tickDirection = -o.tickDirection), I(n.labelInside, e.get('axisLabel.inside')) && (o.labelDirection = -o.labelDirection); var m = e.get('axisLabel.rotate'); return ( (o.labelRotate = 'top' === s ? -m : m), (o.labelInterval = r.getLabelInterval()), (o.z2 = 1), o ); } function Hs(t) { return t.get('stack') || xx + t.seriesIndex; } function Fs(t) { return t.dim + t.index; } function Zs(t, e) { return Us( f(t, function (t) { var e = t.getData(), n = t.coordinateSystem.getBaseAxis(), i = n.getExtent(), r = 'category' === n.type ? n.getBandWidth() : Math.abs(i[1] - i[0]) / e.count(); return { bandWidth: r, barWidth: wn(t.get('barWidth'), r), barMaxWidth: wn(t.get('barMaxWidth'), r), barGap: t.get('barGap'), barCategoryGap: t.get('barCategoryGap'), axisKey: Fs(n), stackId: Hs(t), }; }), e ); } function Us(t, e) { var n = {}; d(t, function (t, e) { var i = t.axisKey, r = t.bandWidth, o = n[i] || { bandWidth: r, remainedWidth: r, autoWidthCount: 0, categoryGap: '20%', gap: '30%', stacks: {}, }, a = o.stacks; n[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 h = t.barMaxWidth; h && (a[s].maxWidth = h); var u = t.barGap; null != u && (o.gap = u); var c = t.barCategoryGap; null != c && (o.categoryGap = c); }); var i = {}; return ( d(n, function (t, e) { i[e] = {}; var n = t.stacks, r = t.bandWidth, o = wn(t.categoryGap, r), a = wn(t.gap, 1), s = t.remainedWidth, l = t.autoWidthCount, h = (s - o) / (l + (l - 1) * a); (h = Math.max(h, 0)), d(n, function (t, e) { var n = t.maxWidth; n && n < h && ((n = Math.min(n, s)), t.width && (n = Math.min(n, t.width)), (s -= n), (t.width = n), l--); }), (h = (s - o) / (l + (l - 1) * a)), (h = Math.max(h, 0)); var u, c = 0; d(n, function (t, e) { t.width || (t.width = h), (u = t), (c += t.width * (1 + a)); }), u && (c -= u.width * a); var f = -c / 2; d(n, function (t, n) { (i[e][n] = i[e][n] || { offset: f, width: t.width }), (f += t.width * (1 + a)); }); }), i ); } function Xs(t, e, n) { var i = Zs( g(e.getSeriesByType(t), function (t) { return ( !e.isSeriesFiltered(t) && t.coordinateSystem && 'cartesian2d' === t.coordinateSystem.type ); }) ), r = {}, o = {}; e.eachSeriesByType( t, function (t) { if ('cartesian2d' === t.coordinateSystem.type) { var e = t.getData(), n = t.coordinateSystem, a = n.getBaseAxis(), s = Hs(t), l = i[Fs(a)][s], h = l.offset, u = l.width, c = n.getOtherAxis(a), d = t.get('barMinHeight') || 0, f = a.onZero ? c.toGlobalCoord(c.dataToCoord(0)) : c.getGlobalExtent()[0], p = [t.coordDimToDataDim('x')[0], t.coordDimToDataDim('y')[0]], g = e.mapArray( p, function (t, e) { return n.dataToPoint([t, e]); }, !0 ); (r[s] = r[s] || []), (o[s] = o[s] || []), e.setLayout({ offset: h, size: u }), e.each( t.coordDimToDataDim(c.dim)[0], function (t, n) { if (!isNaN(t)) { r[s][n] || ((r[s][n] = { p: f, n: f }), (o[s][n] = { p: f, n: f })); var i, a, l, p, v = t >= 0 ? 'p' : 'n', m = g[n], y = r[s][n][v], x = o[s][n][v]; c.isHorizontal() ? ((i = y), (a = m[1] + h), (l = m[0] - x), (p = u), (o[s][n][v] += l), Math.abs(l) < d && (l = (l < 0 ? -1 : 1) * d), (r[s][n][v] += l)) : ((i = m[0] + h), (a = y), (l = u), (p = m[1] - x), (o[s][n][v] += p), Math.abs(p) < d && (p = (p <= 0 ? -1 : 1) * d), (r[s][n][v] += p)), e.setItemLayout(n, { x: i, y: a, width: l, height: p }); } }, !0 ); } }, this ); } function js(t, e, n, i, r, o, a) { or(t, e, n.getModel('label.normal'), n.getModel('label.emphasis'), { labelFetcher: r, labelDataIndex: o, defaultText: r.getRawValue(o), isRectText: !0, autoColor: i, }), qs(t), qs(e); } function qs(t, e) { 'outside' === t.textPosition && (t.textPosition = e); } function Ys(t, e, n) { (n.style.text = null), gr(n, { shape: { width: 0 } }, e, t, function () { n.parent && n.parent.remove(n); }); } function $s(t, e, n) { (n.style.text = null), gr(n, { shape: { r: n.shape.r0 } }, e, t, function () { n.parent && n.parent.remove(n); }); } function Ks(t, e, n, i, r, o, s, l) { var h = e.getItemVisual(n, 'color'), u = e.getItemVisual(n, 'opacity'), c = i.getModel('itemStyle.normal'), d = i.getModel('itemStyle.emphasis').getBarItemStyle(); l || t.setShape('r', c.get('barBorderRadius') || 0), t.useStyle(a({ fill: h, opacity: u }, c.getBarItemStyle())); var f = i.getShallow('cursor'); f && t.attr('cursor', f); var p = s ? r.height > 0 ? 'bottom' : 'top' : r.width > 0 ? 'left' : 'right'; l || js(t.style, d, i, h, o, n, p), rr(t, d); } function Qs(t, e) { var n = t.get(bx) || 0; return Math.min(n, Math.abs(e.width), Math.abs(e.height)); } function Js(t, e, n, i) { var r = e.getData(), o = this.dataIndex, a = r.getName(o), s = e.get('selectedOffset'); i.dispatchAction({ type: 'pieToggleSelect', from: t, name: a, seriesId: e.id, }), r.each(function (t) { tl( r.getItemGraphicEl(t), r.getItemLayout(t), e.isSelected(r.getName(t)), s, n ); }); } function tl(t, e, n, i, r) { var o = (e.startAngle + e.endAngle) / 2, a = Math.cos(o), s = Math.sin(o), l = n ? i : 0, h = [a * l, s * l]; r ? t.animate().when(200, { position: h }).start('bounceOut') : t.attr('position', h); } function el(t, e) { function n() { (o.ignore = o.hoverIgnore), (a.ignore = a.hoverIgnore); } function i() { (o.ignore = o.normalIgnore), (a.ignore = a.normalIgnore); } Tf.call(this); var r = new Rg({ z2: 2 }), o = new Fg(), a = new zg(); this.add(r), this.add(o), this.add(a), this.updateData(t, e, !0), this.on('emphasis', n) .on('normal', i) .on('mouseover', n) .on('mouseout', i); } function nl(t, e, n, i, r, o, a) { function s(e, n) { for ( var i = e; i >= 0 && ((t[i].y -= n), !(i > 0 && t[i].y > t[i - 1].y + t[i - 1].height)); i-- ); } function l(t, e, n, i, r, o) { for (var a = e ? Number.MAX_VALUE : 0, s = 0, l = t.length; s < l; s++) if ('center' !== t[s].position) { var h = Math.abs(t[s].y - i), u = t[s].len, c = t[s].len2, d = h < r + u ? Math.sqrt((r + u + c) * (r + u + c) - h * h) : Math.abs(t[s].x - n); e && d >= a && (d = a - 10), !e && d <= a && (d = a + 10), (t[s].x = n + d * o), (a = d); } } t.sort(function (t, e) { return t.y - e.y; }); for (var h, u = 0, c = t.length, d = [], f = [], p = 0; p < c; p++) (h = t[p].y - u) < 0 && (function (e, n, i, r) { for (var o = e; o < n; o++) if ( ((t[o].y += i), o > e && o + 1 < n && t[o + 1].y > t[o].y + t[o].height) ) return void s(o, i / 2); s(n - 1, i / 2); })(p, c, -h), (u = t[p].y + t[p].height); a - u < 0 && s(c - 1, u - a); for (p = 0; p < c; p++) t[p].y >= n ? f.push(t[p]) : d.push(t[p]); l(d, !1, e, n, i, r), l(f, !0, e, n, i, r); } function il(t, e, n, i, r, o) { for (var a = [], s = [], l = 0; l < t.length; l++) t[l].x < e ? a.push(t[l]) : s.push(t[l]); nl(s, e, n, i, 1, r, o), nl(a, e, n, i, -1, r, o); for (l = 0; l < t.length; l++) { var h = t[l].linePoints; if (h) { var u = h[1][0] - h[2][0]; t[l].x < e ? (h[2][0] = t[l].x + 3) : (h[2][0] = t[l].x - 3), (h[1][1] = h[2][1] = t[l].y), (h[1][0] = h[2][0] + u); } } } function rl() { (this.group = new Tf()), (this._symbolEl = new Px({})); } function ol(t, e, n, i) { var r = n.type, o = new (0, iv[r.charAt(0).toUpperCase() + r.slice(1)])(n); e.add(o), i.set(t, o), (o.__ecGraphicId = t); } function al(t, e) { var n = t && t.parent; n && ('group' === t.type && t.traverse(function (t) { al(t, e); }), e.removeKey(t.__ecGraphicId), n.remove(t)); } function sl(t) { return ( (t = o({}, t)), d( ['id', 'parentId', '$action', 'hv', 'bounding'].concat(mv), function (e) { delete t[e]; } ), t ); } function ll(t, e) { var n; return ( d(e, function (e) { null != t[e] && 'auto' !== t[e] && (n = !0); }), n ); } function hl(t, e) { var n = t.exist; 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; } function ul(t, e, n) { var r = o({}, n), a = t[e], s = n.$action || 'merge'; 'merge' === s ? a ? (i(a, r, !0), Zr(a, r, { ignoreSize: !0 }), Xr(n, a)) : (t[e] = r) : 'replace' === s ? (t[e] = r) : 'remove' === s && a && (t[e] = null); } function cl(t, e) { t && ((t.hv = e.hv = [ll(e, ['left', 'right']), ll(e, ['top', 'bottom'])]), 'group' === t.type && (null == t.width && (t.width = e.width = 0), null == t.height && (t.height = e.height = 0))); } function dl(t, e, n, i, r) { var a = t.axis; if (!a.scale.isBlank() && a.containData(e)) if (t.involveSeries) { var s = fl(e, t), l = s.payloadBatch, h = s.snapToValue; l[0] && null == r.seriesIndex && o(r, l[0]), !i && t.snap && a.containData(h) && null != h && (e = h), n.showPointer(t, e, l, r), n.showTooltip(t, s, h); } else n.showPointer(t, e); } function fl(t, e) { var n = e.axis, i = n.dim, r = t, o = [], a = Number.MAX_VALUE, s = -1; return ( Ex(e.seriesModels, function (e, l) { var h, u, c = e.coordDimToDataDim(i); if (e.getAxisTooltipData) { var d = e.getAxisTooltipData(c, t, n); (u = d.dataIndices), (h = d.nestestValue); } else { if ( !(u = e .getData() .indicesOfNearest( c[0], t, !1, 'category' === n.type ? 0.5 : null )).length ) return; h = e.getData().get(c[0], u[0]); } if (null != h && isFinite(h)) { var f = t - h, p = Math.abs(f); p <= a && ((p < a || (f >= 0 && s < 0)) && ((a = p), (s = f), (r = h), (o.length = 0)), Ex(u, function (t) { o.push({ seriesIndex: e.seriesIndex, dataIndexInside: t, dataIndex: e.getData().getRawIndex(t), }); })); } }), { payloadBatch: o, snapToValue: r } ); } function pl(t, e, n, i) { t[e.key] = { value: n, payloadBatch: i }; } function gl(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, h = Rs(l), u = t.map[h]; u || ((u = t.map[h] = { coordSysId: l.id, coordSysIndex: l.componentIndex, coordSysType: l.type, coordSysMainType: l.mainType, dataByAxis: [], }), t.list.push(u)), u.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 vl(t, e, n) { var i = (n.axesInfo = []); Ex(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, }); }); } function ml(t, e, n, i) { if (!wl(e) && t.list.length) { 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, }); } else i({ type: 'hideTip' }); } function yl(t, e, n) { var i = n.getZr(), r = Bx(i).axisPointerLastHighlights || {}, o = (Bx(i).axisPointerLastHighlights = {}); Ex(t, function (t, e) { var n = t.axisPointerModel.option; 'show' === n.status && Ex(n.seriesDataIndices, function (t) { var e = t.seriesIndex + ' | ' + t.dataIndex; o[e] = t; }); }); var a = [], s = []; d(r, function (t, e) { !o[e] && s.push(t); }), d(o, function (t, e) { !r[e] && a.push(t); }), s.length && n.dispatchAction({ type: 'downplay', escapeConnect: !0, batch: s }), a.length && n.dispatchAction({ type: 'highlight', escapeConnect: !0, batch: a }); } function xl(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; } } function _l(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 wl(t) { return !t || null == t[0] || isNaN(t[0]) || null == t[1] || isNaN(t[1]); } function bl(t, e, n) { if (!Md.node) { var i = e.getZr(); Rx(i).records || (Rx(i).records = {}), Ml(i, e), ((Rx(i).records[t] || (Rx(i).records[t] = {})).handler = n); } } function Ml(t, e) { function n(n, i) { t.on(n, function (n) { var r = Al(e); Vx(Rx(t).records, function (t) { t && i(t, n, r.dispatchAction); }), Sl(r.pendings, e); }); } Rx(t).initialized || ((Rx(t).initialized = !0), n('click', m(Tl, 'click')), n('mousemove', m(Tl, 'mousemove')), n('globalout', Il)); } function Sl(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)); } function Il(t, e, n) { t.handler('leave', null, n); } function Tl(t, e, n, i) { e.handler(t, n, i); } function Al(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 }; } function Cl(t, e) { if (!Md.node) { var n = e.getZr(); (Rx(n).records || {})[t] && (Rx(n).records[t] = null); } } function kl() {} function Dl(t, e, n, i) { Pl(Wx(n).lastProp, i) || ((Wx(n).lastProp = i), e ? gr(n, i, t) : (n.stopAnimation(), n.attr(i))); } function Pl(t, e) { if (w(t) && w(e)) { var n = !0; return ( d(e, function (e, i) { n = n && Pl(t[i], e); }), !!n ); } return t === e; } function Ll(t, e) { t[e.get('label.show') ? 'show' : 'hide'](); } function Ol(t) { return { position: t.position.slice(), rotation: t.rotation || 0 }; } function zl(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 El(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 Nl(t, e, n, i, r) { var o = Rl(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 = yp(a.get('padding') || 0), l = a.getFont(), h = he(o, l), u = r.position, c = h.width + s[1] + s[3], d = h.height + s[0] + s[2], f = r.align; 'right' === f && (u[0] -= c), 'center' === f && (u[0] -= c / 2); var p = r.verticalAlign; 'bottom' === p && (u[1] -= d), 'middle' === p && (u[1] -= d / 2), Bl(u, c, d, i); var g = a.get('backgroundColor'); (g && 'auto' !== g) || (g = e.get('axisLine.lineStyle.color')), (t.label = { shape: { x: 0, y: 0, width: c, height: d, r: a.get('borderRadius') }, position: u.slice(), style: { text: o, textFont: l, textFill: a.getTextColor(), textPosition: 'inside', fill: g, stroke: a.get('borderColor') || 'transparent', lineWidth: a.get('borderWidth') || 0, shadowBlur: a.get('shadowBlur'), shadowColor: a.get('shadowColor'), shadowOffsetX: a.get('shadowOffsetX'), shadowOffsetY: a.get('shadowOffsetY'), }, z2: 10, }); } function Bl(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)); } function Rl(t, e, n, i, r) { var o = e.scale.getLabel(t, { precision: r.precision }), a = r.formatter; if (a) { var s = { value: Ca(e, t), seriesData: [] }; d(i, function (t) { var e = n.getSeriesByIndex(t.seriesIndex), i = t.dataIndexInside, r = e && e.getDataParams(i); r && s.seriesData.push(r); }), _(a) ? (o = a.replace('{value}', o)) : x(a) && (o = a(s)); } return o; } function Vl(t, e, n) { var i = nt(); return ( st(i, i, n.rotation), at(i, i, n.position), yr( [ t.dataToCoord(e), (n.labelOffset || 0) + (n.labelDirection || 1) * (n.labelMargin || 0), ], i ) ); } function Gl(t, e, n, i, r, o) { var a = ox.innerTextLayout(n.rotation, 0, n.labelDirection); (n.labelMargin = r.get('label.margin')), Nl(e, i, r, o, { position: Vl(i.axis, t, n), align: a.textAlign, verticalAlign: a.textVerticalAlign, }); } function Wl(t, e, n) { return (n = n || 0), { x1: t[n], y1: t[1 - n], x2: e[n], y2: e[1 - n] }; } function Hl(t, e, n) { return ( (n = n || 0), { x: t[n], y: t[1 - n], width: e[n], height: e[1 - n] } ); } function Fl(t, e) { var n = {}; return (n[e.dim + 'AxisIndex'] = e.index), t.getCartesian(n); } function Zl(t) { return 'x' === t.dim ? 0 : 1; } function Ul(t) { var e = 'left ' + t + 's cubic-bezier(0.23, 1, 0.32, 1),top ' + t + 's cubic-bezier(0.23, 1, 0.32, 1)'; return f(qx, function (t) { return t + 'transition:' + e; }).join(';'); } function Xl(t) { var e = [], n = t.get('fontSize'), i = t.getTextColor(); return ( i && e.push('color:' + i), e.push('font:' + t.getFont()), n && e.push('line-height:' + Math.round((3 * n) / 2) + 'px'), Xx(['decoration', 'align'], function (n) { var i = t.get(n); i && e.push('text-' + n + ':' + i); }), e.join(';') ); } function jl(t) { var e = [], n = t.get('transitionDuration'), i = t.get('backgroundColor'), r = t.getModel('textStyle'), o = t.get('padding'); return ( n && e.push(Ul(n)), i && (Md.canvasSupported ? e.push('background-Color:' + i) : (e.push('background-Color:#' + Tt(i)), e.push('filter:alpha(opacity=70)'))), Xx(['width', 'color', 'radius'], function (n) { var i = 'border-' + n, r = jx(i), o = t.get(r); null != o && e.push(i + ':' + o + ('color' === n ? '' : 'px')); }), e.push(Xl(r)), null != o && e.push('padding:' + yp(o).join('px ') + 'px'), e.join(';') + ';' ); } function ql(t, e) { var n = document.createElement('div'), i = (this._zr = e.getZr()); (this.el = n), (this._x = e.getWidth() / 2), (this._y = e.getHeight() / 2), t.appendChild(n), (this._container = t), (this._show = !1), this._hideTimeout; var r = this; (n.onmouseenter = function () { r._enterable && (clearTimeout(r._hideTimeout), (r._show = !0)), (r._inContent = !0); }), (n.onmousemove = function (e) { if (((e = e || window.event), !r._enterable)) { var n = i.handler; rn(t, e, !0), n.dispatch('mousemove', e); } }), (n.onmouseleave = function () { r._enterable && r._show && r.hideLater(r._hideDelay), (r._inContent = !1); }); } function Yl(t) { for (var e = t.pop(); t.length; ) { var n = t.pop(); n && (n instanceof Mr && (n = n.get('tooltip', !0)), 'string' == typeof n && (n = { formatter: n }), (e = new Mr(n, e, e.ecModel))); } return e; } function $l(t, e) { return t.dispatchAction || v(e.dispatchAction, e); } function Kl(t, e, n, i, r, o, a) { var s = Jl(n), l = s.width, h = s.height; return ( null != o && (t + l + o > i ? (t -= l + o) : (t += o)), null != a && (e + h + a > r ? (e -= h + a) : (e += a)), [t, e] ); } function Ql(t, e, n, i, r) { var o = Jl(n), a = o.width, s = o.height; 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] ); } function Jl(t) { var e = t.clientWidth, n = t.clientHeight; if (document.defaultView && document.defaultView.getComputedStyle) { var i = document.defaultView.getComputedStyle(t); i && ((e += parseInt(i.paddingLeft, 10) + parseInt(i.paddingRight, 10) + parseInt(i.borderLeftWidth, 10) + parseInt(i.borderRightWidth, 10)), (n += parseInt(i.paddingTop, 10) + parseInt(i.paddingBottom, 10) + parseInt(i.borderTopWidth, 10) + parseInt(i.borderBottomWidth, 10))); } return { width: e, height: n }; } function th(t, e, n) { var i = n[0], r = n[1], o = 0, a = 0, s = e.width, l = e.height; switch (t) { case 'inside': (o = e.x + s / 2 - i / 2), (a = e.y + l / 2 - r / 2); break; case 'top': (o = e.x + s / 2 - i / 2), (a = e.y - r - 5); break; case 'bottom': (o = e.x + s / 2 - i / 2), (a = e.y + l + 5); break; case 'left': (o = e.x - i - 5), (a = e.y + l / 2 - r / 2); break; case 'right': (o = e.x + s + 5), (a = e.y + l / 2 - r / 2); } return [o, a]; } function eh(t) { return 'center' === t || 'middle' === t; } function nh(t, e, n) { var i, r = {}, o = 'toggleSelected' === t; return ( n.eachComponent('legend', function (n) { o && null != i ? n[i ? 'select' : 'unSelect'](e.name) : (n[t](e.name), (i = n.isSelected(e.name))), d(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); } }); }), { name: e.name, selected: r } ); } function ih(t, e, n) { var i = e.getBoxLayoutParams(), r = e.get('padding'), o = { width: n.getWidth(), height: n.getHeight() }, a = Hr(i, o, r); xv(e.get('orient'), t, e.get('itemGap'), a.width, a.height), Fr(t, i, o, r); } function rh(t, e) { var n = yp(e.get('padding')), i = e.getItemStyle(['color', 'opacity']); return ( (i.fill = e.get('backgroundColor')), (t = new Zg({ 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, })) ); } function oh(t, e) { e.dispatchAction({ type: 'legendToggleSelect', name: t }); } function ah(t, e, n) { var i = n.getZr().storage.getDisplayList()[0]; (i && i.useHoverLayer) || (t.get('legendHoverLink') && n.dispatchAction({ type: 'highlight', seriesName: t.name, name: e })); } function sh(t, e, n) { var i = n.getZr().storage.getDisplayList()[0]; (i && i.useHoverLayer) || (t.get('legendHoverLink') && n.dispatchAction({ type: 'downplay', seriesName: t.name, name: e })); } function lh(t, e, n) { var i = [1, 1]; (i[t.getOrient().index] = 0), Zr(e, n, { type: 'box', ignoreSize: i }); } function hh(t) { Ar(t.label, ['show']); } function uh(t) { return !(isNaN(parseFloat(t.x)) && isNaN(parseFloat(t.y))); } function ch(t) { return !isNaN(parseFloat(t.x)) && !isNaN(parseFloat(t.y)); } function dh(t, e, n) { var i = -1; do { (i = Math.max(Sn(t.get(e, n)), i)), (t = t.stackedOn); } while (t); return i; } function fh(t, e, n, i, r, o) { var a = [], s = yh(e, i, t), l = e.indicesOfNearest(i, s, !0)[0]; (a[r] = e.get(n, l, !0)), (a[o] = e.get(i, l, !0)); var h = dh(e, i, l); return (h = Math.min(h, 20)) >= 0 && (a[o] = +a[o].toFixed(h)), a; } function ph(t, e) { var i = t.getData(), r = t.coordinateSystem; if (e && !ch(e) && !y(e.coord) && r) { var o = r.dimensions, a = gh(e, i, r, t); if ((e = n(e)).type && p_[e.type] && a.baseAxis && a.valueAxis) { var s = d_(o, a.baseAxis.dim), l = d_(o, a.valueAxis.dim); (e.coord = p_[e.type](i, a.baseDataDim, a.valueDataDim, s, l)), (e.value = e.coord[l]); } else { for ( var h = [ null != e.xAxis ? e.xAxis : e.radiusAxis, null != e.yAxis ? e.yAxis : e.angleAxis, ], u = 0; u < 2; u++ ) if (p_[h[u]]) { var c = t.coordDimToDataDim(o[u])[0]; h[u] = yh(i, c, h[u]); } e.coord = h; } } return e; } function gh(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(i.dataDimToCoordDim(r.valueDataDim))), (r.baseAxis = n.getOtherAxis(r.valueAxis)), (r.baseDataDim = i.coordDimToDataDim(r.baseAxis.dim)[0])) : ((r.baseAxis = i.getBaseAxis()), (r.valueAxis = n.getOtherAxis(r.baseAxis)), (r.baseDataDim = i.coordDimToDataDim(r.baseAxis.dim)[0]), (r.valueDataDim = i.coordDimToDataDim(r.valueAxis.dim)[0])), r ); } function vh(t, e) { return !(t && t.containData && e.coord && !uh(e)) || t.containData(e.coord); } function mh(t, e, n, i) { return i < 2 ? t.coord && t.coord[i] : t.value; } function yh(t, e, n) { if ('average' === n) { var i = 0, r = 0; return ( t.each( e, function (t, e) { isNaN(t) || ((i += t), r++); }, !0 ), i / r ); } return t.getDataExtent(e, !0)['max' === n ? 1 : 0]; } function xh(t, e, n) { var i = e.coordinateSystem; t.each(function (r) { var o, a = t.getItemModel(r), s = wn(a.get('x'), n.getWidth()), l = wn(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 h = t.get(i.dimensions[0], r), u = t.get(i.dimensions[1], r); o = i.dataToPoint([h, u]); } } else o = [s, l]; isNaN(s) || (o[0] = s), isNaN(l) || (o[1] = l), t.setItemLayout(r, o); }); } function _h(t, e, n) { var i; i = t ? f(t && t.dimensions, function (t) { var n = e.getData().getDimensionInfo(e.coordDimToDataDim(t)[0]) || {}; return (n.name = t), n; }) : [{ name: 'value', type: 'float' }]; var r = new Nm(i, n), o = f(n.get('data'), m(ph, e)); return ( t && (o = g(o, m(vh, t))), r.initData( o, null, t ? mh : function (t) { return t.value; } ), r ); } function wh(t) { return isNaN(+t.cpx1) || isNaN(+t.cpy1); } function bh(t) { return '_' + t + 'Type'; } function Mh(t, e, n) { var i = e.getItemVisual(n, 'color'), r = e.getItemVisual(n, t), o = e.getItemVisual(n, t + 'Size'); if (r && 'none' !== r) { y(o) || (o = [o, o]); var a = Pa(r, -o[0] / 2, -o[1] / 2, o[0], o[1], i); return (a.name = t), a; } } function Sh(t) { var e = new y_({ name: 'line' }); return Ih(e.shape, t), e; } function Ih(t, e) { var n = e[0], i = e[1], r = e[2]; (t.x1 = n[0]), (t.y1 = n[1]), (t.x2 = i[0]), (t.y2 = i[1]), (t.percent = 1), r ? ((t.cpx1 = r[0]), (t.cpy1 = r[1])) : ((t.cpx1 = NaN), (t.cpy1 = NaN)); } function Th(t, e, n) { Tf.call(this), this._createLine(t, e, n); } function Ah(t) { return isNaN(t[0]) || isNaN(t[1]); } function Ch(t) { return !Ah(t[0]) && !Ah(t[1]); } function kh(t) { (this._ctor = t || Th), (this.group = new Tf()); } function Dh(t) { return !isNaN(t) && !isFinite(t); } function Ph(t, e, n, i) { var r = 1 - t, o = i.dimensions[t]; return ( Dh(e[r]) && Dh(n[r]) && e[t] === n[t] && i.getAxis(o).containData(e[t]) ); } function Lh(t, e) { if ('cartesian2d' === t.type) { var n = e[0].coord, i = e[1].coord; if (n && i && (Ph(1, n, i, t) || Ph(0, n, i, t))) return !0; } return vh(t, e[0]) && vh(t, e[1]); } function Oh(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = wn(s.get('x'), r.getWidth()), h = wn(s.get('y'), r.getHeight()); if (isNaN(l) || isNaN(h)) { if (i.getMarkerPosition) o = i.getMarkerPosition(t.getValues(t.dimensions, e)); else { var u = a.dimensions, c = t.get(u[0], e), d = t.get(u[1], e); o = a.dataToPoint([c, d]); } if ('cartesian2d' === a.type) { var f = a.getAxis('x'), p = a.getAxis('y'), u = a.dimensions; Dh(t.get(u[0], e)) ? (o[0] = f.toGlobalCoord(f.getExtent()[n ? 0 : 1])) : Dh(t.get(u[1], e)) && (o[1] = p.toGlobalCoord(p.getExtent()[n ? 0 : 1])); } isNaN(l) || (o[0] = l), isNaN(h) || (o[1] = h); } else o = [l, h]; t.setItemLayout(e, o); } function zh(t, e, n) { var i; i = t ? f(t && t.dimensions, function (t) { var n = e.getData().getDimensionInfo(e.coordDimToDataDim(t)[0]) || {}; return (n.name = t), n; }) : [{ name: 'value', type: 'float' }]; var r = new Nm(i, n), o = new Nm(i, n), a = new Nm([], n), s = f(n.get('data'), m(b_, e, t, n)); t && (s = g(s, m(Lh, t))); var l = t ? mh : function (t) { return t.value; }; return ( r.initData( f(s, function (t) { return t[0]; }), null, l ), o.initData( f(s, function (t) { return t[1]; }), null, l ), a.initData( f(s, function (t) { return t[2]; }) ), (a.hasItemOption = !0), { from: r, to: o, line: a } ); } function Eh(t) { return !isNaN(t) && !isFinite(t); } function Nh(t, e, n, i) { var r = 1 - t; return Eh(e[r]) && Eh(n[r]); } function Bh(t, e) { var n = e.coord[0], i = e.coord[1]; return ( !( 'cartesian2d' !== t.type || !n || !i || (!Nh(1, n, i, t) && !Nh(0, n, i, t)) ) || vh(t, { coord: n, x: e.x0, y: e.y0 }) || vh(t, { coord: i, x: e.x1, y: e.y1 }) ); } function Rh(t, e, n, i, r) { var o, a = i.coordinateSystem, s = t.getItemModel(e), l = wn(s.get(n[0]), r.getWidth()), h = wn(s.get(n[1]), r.getHeight()); if (isNaN(l) || isNaN(h)) { if (i.getMarkerPosition) o = i.getMarkerPosition(t.getValues(n, e)); else { var u = t.get(n[0], e), c = t.get(n[1], e); o = a.dataToPoint([u, c], !0); } if ('cartesian2d' === a.type) { var d = a.getAxis('x'), f = a.getAxis('y'), u = t.get(n[0], e), c = t.get(n[1], e); Eh(u) ? (o[0] = d.toGlobalCoord(d.getExtent()['x0' === n[0] ? 0 : 1])) : Eh(c) && (o[1] = f.toGlobalCoord(f.getExtent()['y0' === n[1] ? 0 : 1])); } isNaN(l) || (o[0] = l), isNaN(h) || (o[1] = h); } else o = [l, h]; return o; } function Vh(t, e, n) { var i, r, o = ['x0', 'y0', 'x1', 'y1']; t ? ((i = f(t && t.dimensions, function (t) { var n = e.getData().getDimensionInfo(e.coordDimToDataDim(t)[0]) || {}; return (n.name = t), n; })), (r = new Nm( f(o, function (t, e) { return { name: t, type: i[e % 2].type }; }), n ))) : (r = new Nm((i = [{ name: 'value', type: 'float' }]), n)); var a = f(n.get('data'), m(M_, e, t, n)); t && (a = g(a, m(Bh, t))); var s = t ? function (t, e, n, i) { return t.coord[Math.floor(i / 2)][i % 2]; } : function (t) { return t.value; }; return r.initData(a, null, s), (r.hasItemOption = !0), r; } function Gh(t) { return l(I_, t) >= 0; } function Wh(t, e, n) { function i(t, e) { return l(e.nodes, t) >= 0; } function r(t, i) { var r = !1; return ( e(function (e) { d(n(t, e) || [], function (t) { i.records[e.name][t] && (r = !0); }); }), r ); } function o(t, i) { i.nodes.push(t), e(function (e) { d(n(t, e) || [], function (t) { i.records[e.name][t] = !0; }); }); } return function (n) { var a = { nodes: [], records: {} }; if ( (e(function (t) { a.records[t.name] = {}; }), !n) ) return a; o(n, a); var s; do { (s = !1), t(function (t) { !i(t, a) && r(t, a) && (o(t, a), (s = !0)); }); } while (s); return a; }; } function Hh(t, e, n) { var i = [1 / 0, -1 / 0]; return ( A_(n, function (t) { var n = t.getData(); n && A_(t.coordDimToDataDim(e), function (t) { var e = n.getDataExtent(t); e[0] < i[0] && (i[0] = e[0]), e[1] > i[1] && (i[1] = e[1]); }); }), i[1] < i[0] && (i = [NaN, NaN]), Fh(t, i), i ); } function Fh(t, e) { var n = t.getAxisModel(), i = n.getMin(!0), r = 'category' === n.get('type'), o = r && (n.get('data') || []).length; null != i && 'dataMin' !== i && 'function' != typeof i ? (e[0] = i) : r && (e[0] = o > 0 ? 0 : NaN); var a = n.getMax(!0); return ( null != a && 'dataMax' !== a && 'function' != typeof a ? (e[1] = a) : r && (e[1] = o > 0 ? o - 1 : NaN), n.get('scale', !0) || (e[0] > 0 && (e[0] = 0), e[1] < 0 && (e[1] = 0)), e ); } function Zh(t, e) { var n = t.getAxisModel(), i = t._percentWindow, r = t._valueWindow; if (i) { var o = Tn(r, [0, 500]); o = Math.min(o, 20); var a = e || (0 === i[0] && 100 === i[1]); n.setRange(a ? null : +r[0].toFixed(o), a ? null : +r[1].toFixed(o)); } } function Uh(t) { var e = (t._minMaxSpan = {}), n = t._dataZoomModel; A_(['min', 'max'], function (i) { e[i + 'Span'] = n.get(i + 'Span'); var r = n.get(i + 'ValueSpan'); if ( null != r && ((e[i + 'ValueSpan'] = r), null != (r = t.getAxisModel().axis.scale.parse(r))) ) { var o = t._dataExtent; e[i + 'Span'] = _n(o[0] + r, o, [0, 100], !0); } }); } function Xh(t) { var e = {}; return ( D_(['start', 'end', 'startValue', 'endValue', 'throttle'], function (n) { t.hasOwnProperty(n) && (e[n] = t[n]); }), e ); } function jh(t, e) { var n = t._rangePropMode, i = t.get('rangeMode'); D_( [ ['start', 'startValue'], ['end', 'endValue'], ], function (t, r) { var o = null != e[t[0]], a = null != e[t[1]]; o && !a ? (n[r] = 'percent') : !o && a ? (n[r] = 'value') : i ? (n[r] = i[r]) : o && (n[r] = 'percent'); } ); } function qh(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 Yh(t, e) { return Math.min(e[1], Math.max(e[0], t)); } function $h(t) { return { x: 'y', y: 'x', radius: 'angle', angle: 'radius' }[t]; } function Kh(t) { return 'vertical' === t ? 'ns-resize' : 'ew-resize'; } function Qh(t, e, n) { eu(t)[e] = n; } function Jh(t, e, n) { var i = eu(t); i[e] === n && (i[e] = null); } function tu(t, e) { return !!eu(t)[e]; } function eu(t) { return t[Z_] || (t[Z_] = {}); } function nu(t) { this.pointerChecker, (this._zr = t), (this._opt = {}); var e = v, i = e(iu, this), r = e(ru, this), o = e(ou, this), s = e(au, this), l = e(su, this); Ud.call(this), (this.setPointerChecker = function (t) { this.pointerChecker = t; }), (this.enable = function (e, h) { this.disable(), (this._opt = a(n(h) || {}, { zoomOnMouseWheel: !0, moveOnMouseMove: !0, preventDefaultMouseMove: !0, })), null == e && (e = !0), (!0 !== e && 'move' !== e && 'pan' !== e) || (t.on('mousedown', i), t.on('mousemove', r), t.on('mouseup', o)), (!0 !== e && 'scale' !== e && 'zoom' !== e) || (t.on('mousewheel', s), t.on('pinch', l)); }), (this.disable = function () { t.off('mousedown', i), t.off('mousemove', r), t.off('mouseup', o), t.off('mousewheel', s), t.off('pinch', l); }), (this.dispose = this.disable), (this.isDragging = function () { return this._dragging; }), (this.isPinching = function () { return this._pinching; }); } function iu(t) { if (!(sn(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)); } } function ru(t) { if ( !sn(t) && hu(this, 'moveOnMouseMove', t) && this._dragging && 'pinch' !== t.gestureEvent && !tu(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 && tp(t.event), this.trigger('pan', o, a, i, r, e, n); } } function ou(t) { sn(t) || (this._dragging = !1); } function au(t) { if (hu(this, 'zoomOnMouseWheel', t) && 0 !== t.wheelDelta) { var e = t.wheelDelta > 0 ? 1.1 : 1 / 1.1; lu.call(this, t, e, t.offsetX, t.offsetY); } } function su(t) { if (!tu(this._zr, 'globalPan')) { var e = t.pinchScale > 1 ? 1.1 : 1 / 1.1; lu.call(this, t, e, t.pinchX, t.pinchY); } } function lu(t, e, n, i) { this.pointerChecker && this.pointerChecker(t, n, i) && (tp(t.event), this.trigger('zoom', e, n, i)); } function hu(t, e, n) { var i = t._opt[e]; return i && (!_(i) || n.event[i + 'Key']); } function uu(t, e) { var n = pu(t), i = e.dataZoomId, r = e.coordId; d(n, function (t, n) { var o = t.dataZoomInfos; o[i] && l(e.allCoordIds, r) < 0 && (delete o[i], t.count--); }), vu(n); var o = n[r]; o || (((o = n[r] = { coordId: r, dataZoomInfos: {}, count: 0 }).controller = gu(t, o)), (o.dispatchAction = m(_u, t))), !o.dataZoomInfos[i] && o.count++, (o.dataZoomInfos[i] = e); var a = wu(o.dataZoomInfos); o.controller.enable(a.controlType, a.opt), o.controller.setPointerChecker(e.containsPoint), wo(o, 'dispatchAction', e.throttleRate, 'fixRate'); } function cu(t, e) { var n = pu(t); d(n, function (t) { t.controller.dispose(); var n = t.dataZoomInfos; n[e] && (delete n[e], t.count--); }), vu(n); } function du(t, e) { if (t && 'dataZoom' === t.type && t.batch) for (var n = 0, i = t.batch.length; n < i; n++) if (t.batch[n].dataZoomId === e) return !1; return !0; } function fu(t) { return t.type + '\0_' + t.id; } function pu(t) { var e = t.getZr(); return e[X_] || (e[X_] = {}); } function gu(t, e) { var n = new nu(t.getZr()); return n.on('pan', U_(mu, e)), n.on('zoom', U_(yu, e)), n; } function vu(t) { d(t, function (e, n) { e.count || (e.controller.dispose(), delete t[n]); }); } function mu(t, e, n, i, r, o, a) { xu(t, function (s) { return s.panGetRange(t.controller, e, n, i, r, o, a); }); } function yu(t, e, n, i) { xu(t, function (r) { return r.zoomGetRange(t.controller, e, n, i); }); } function xu(t, e) { var n = []; d(t.dataZoomInfos, function (t) { var i = e(t); !t.disabled && i && n.push({ dataZoomId: t.dataZoomId, start: i[0], end: i[1] }); }), t.dispatchAction(n); } function _u(t, e) { t.dispatchAction({ type: 'dataZoom', batch: e }); } function wu(t) { var e, n = {}, i = { true: 2, move: 1, false: 0, undefined: -1 }; return ( d(t, function (t) { var r = !t.disabled && (!t.zoomLock || 'move'); i[r] > i[e] && (e = r), o(n, t.roamControllerOpt); }), { controlType: e, opt: n } ); } function bu(t, e, n) { n.getAxisProxy(t.name, e).reset(n); } function Mu(t, e, n) { n.getAxisProxy(t.name, e).filterData(n); } function Su(t, e) { $_[t] = e; } function Iu(t) { return $_[t]; } function Tu(t) { return 0 === t.indexOf('my'); } function Au(t) { this.model = t; } function Cu(t) { this.model = t; } function ku(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 } ); } function Du(t) { var e = []; return ( d(t, function (t, n) { var i = t.categoryAxis, r = t.valueAxis.dim, o = [' '].concat( f(t.series, function (t) { return t.name; }) ), a = [i.model.getCategories()]; d(t.series, function (t) { a.push( t.getRawData().mapArray(r, function (t) { return t; }) ); }); for (var s = [o.join(aw)], l = 0; l < a[0].length; l++) { for (var h = [], u = 0; u < a.length; u++) h.push(a[u][l]); s.push(h.join(aw)); } e.push(s.join('\n')); }), e.join('\n\n' + ow + '\n\n') ); } function Pu(t) { return f(t, 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 + aw : '') + i.join(aw)); }), n.join('\n') ); }).join('\n\n' + ow + '\n\n'); } function Lu(t) { var e = ku(t); return { value: g([Du(e.seriesGroupByCategoryAxis), Pu(e.other)], function (t) { return t.replace(/[\n\t\s]/g, ''); }).join('\n\n' + ow + '\n\n'), meta: e.meta, }; } function Ou(t) { return t.replace(/^\s\s*/, '').replace(/\s\s*$/, ''); } function zu(t) { if (t.slice(0, t.indexOf('\n')).indexOf(aw) >= 0) return !0; } function Eu(t) { for ( var e = t.split(/\n+/g), n = [], i = f(Ou(e.shift()).split(sw), function (t) { return { name: t, data: [] }; }), r = 0; r < e.length; r++ ) { var o = Ou(e[r]).split(sw); 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 }; } function Nu(t) { for ( var e = t.split(/\n+/g), n = Ou(e.shift()), i = [], r = 0; r < e.length; r++ ) { var o, a = Ou(e[r]).split(sw), s = '', l = !1; isNaN(a[0]) ? ((l = !0), (s = a[0]), (a = a.slice(1)), (i[r] = { name: s, value: [] }), (o = i[r].value)) : (o = i[r] = []); for (var h = 0; h < a.length; h++) o.push(+a[h]); 1 === o.length && (l ? (i[r].value = o[0]) : (i[r] = o[0])); } return { name: n, data: i }; } function Bu(t, e) { var n = { series: [] }; return ( d(t.split(new RegExp('\n*' + ow + '\n*', 'g')), function (t, i) { if (zu(t)) { var r = Eu(t), o = e[i], a = o.axisDim + 'Axis'; o && ((n[a] = n[a] || []), (n[a][o.axisIndex] = { data: r.categories }), (n.series = n.series.concat(r.series))); } else { r = Nu(t); n.series.push(r); } }), n ); } function Ru(t) { (this._dom = null), (this.model = t); } function Vu(t, e) { return f(t, function (t, n) { var i = e && e[n]; return w(i) && !y(i) ? (w(t) && !y(t) && (t = t.value), a({ value: t }, i)) : t; }); } function Gu(t) { Ud.call(this), (this._zr = t), (this.group = new Tf()), this._brushType, this._brushOption, this._panels, (this._track = []), this._dragging, (this._covers = []), this._creatingCover, this._creatingPanel, this._enableGlobalPan, (this._uid = 'brushController_' + ww++), (this._handlers = {}), hw( bw, function (t, e) { this._handlers[e] = v(t, this); }, this ); } function Wu(t, e) { var r = t._zr; t._enableGlobalPan || Qh(r, mw, t._uid), hw(t._handlers, function (t, e) { r.on(e, t); }), (t._brushType = e.brushType), (t._brushOption = i(n(_w), e, !0)); } function Hu(t) { var e = t._zr; Jh(e, mw, t._uid), hw(t._handlers, function (t, n) { e.off(n, t); }), (t._brushType = t._brushOption = null); } function Fu(t, e) { var n = Mw[e.brushType].createCover(t, e); return (n.__brushOption = e), Xu(n, e), t.group.add(n), n; } function Zu(t, e) { var n = qu(e); return n.endCreating && (n.endCreating(t, e), Xu(e, e.__brushOption)), e; } function Uu(t, e) { var n = e.__brushOption; qu(e).updateCoverShape(t, e, n.range, n); } function Xu(t, e) { var n = e.z; null == n && (n = pw), t.traverse(function (t) { (t.z = n), (t.z2 = n); }); } function ju(t, e) { qu(e).updateCommon(t, e), Uu(t, e); } function qu(t) { return Mw[t.__brushOption.brushType]; } function Yu(t, e, n) { var i = t._panels; if (!i) return !0; var r, o = t._transform; return ( hw(i, function (t) { t.isTargetByCursor(e, n, o) && (r = t); }), r ); } function $u(t, e) { var n = t._panels; if (!n) return !0; var i = e.__brushOption.panelId; return null == i || n[i]; } function Ku(t) { var e = t._covers, n = e.length; return ( hw( e, function (e) { t.group.remove(e); }, t ), (e.length = 0), !!n ); } function Qu(t, e) { var i = uw(t._covers, function (t) { var e = t.__brushOption, i = n(e.range); return { brushType: e.brushType, panelId: e.panelId, range: i }; }); t.trigger('brush', i, { isEnd: !!e.isEnd, removeOnClick: !!e.removeOnClick, }); } function Ju(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 fw(r * r + o * o, 0.5) > gw; } function tc(t) { var e = t.length - 1; return e < 0 && (e = 0), [t[0], t[e]]; } function ec(t, e, n, i) { var r = new Tf(); return ( r.add( new Zg({ name: 'main', style: oc(n), silent: !0, draggable: !0, cursor: 'move', drift: lw(t, e, r, 'nswe'), ondragend: lw(Qu, e, { isEnd: !0 }), }) ), hw(i, function (n) { r.add( new Zg({ name: n, style: { opacity: 0 }, draggable: !0, silent: !0, invisible: !0, drift: lw(t, e, r, n), ondragend: lw(Qu, e, { isEnd: !0 }), }) ); }), r ); } function nc(t, e, n, i) { var r = i.brushStyle.lineWidth || 0, o = dw(r, vw), a = n[0][0], s = n[1][0], l = a - r / 2, h = s - r / 2, u = n[0][1], c = n[1][1], d = u - o + r / 2, f = c - o + r / 2, p = u - a, g = c - s, v = p + r, m = g + r; rc(t, e, 'main', a, s, p, g), i.transformable && (rc(t, e, 'w', l, h, o, m), rc(t, e, 'e', d, h, o, m), rc(t, e, 'n', l, h, v, o), rc(t, e, 's', l, f, v, o), rc(t, e, 'nw', l, h, o, o), rc(t, e, 'ne', d, h, o, o), rc(t, e, 'sw', l, f, o, o), rc(t, e, 'se', d, f, o, o)); } function ic(t, e) { var n = e.__brushOption, i = n.transformable, r = e.childAt(0); r.useStyle(oc(n)), r.attr({ silent: !i, cursor: i ? 'move' : 'default' }), hw(['w', 'e', 'n', 's', 'se', 'sw', 'ne', 'nw'], function (n) { var r = e.childOfName(n), o = lc(t, n); r && r.attr({ silent: !i, invisible: !i, cursor: i ? xw[o] + '-resize' : null, }); }); } function rc(t, e, n, i, r, o, a) { var s = e.childOfName(n); s && s.setShape( fc( dc(t, e, [ [i, r], [i + o, r + a], ]) ) ); } function oc(t) { return a({ strokeNoScale: !0 }, t.brushStyle); } function ac(t, e, n, i) { var r = [cw(t, n), cw(e, i)], o = [dw(t, n), dw(e, i)]; return [ [r[0], o[0]], [r[1], o[1]], ]; } function sc(t) { return mr(t.group); } function lc(t, e) { if (e.length > 1) return ( ('e' === (i = [lc(t, (e = e.split(''))[0]), lc(t, e[1])])[0] || 'w' === i[0]) && i.reverse(), i.join('') ); var n = { left: 'w', right: 'e', top: 'n', bottom: 's' }, i = xr({ w: 'left', e: 'right', n: 'top', s: 'bottom' }[e], sc(t)); return n[i]; } function hc(t, e, n, i, r, o, a, s) { var l = i.__brushOption, h = t(l.range), u = cc(n, o, a); hw(r.split(''), function (t) { var e = yw[t]; h[e[0]][e[1]] += u[e[0]]; }), (l.range = e(ac(h[0][0], h[1][0], h[0][1], h[1][1]))), ju(n, i), Qu(n, { isEnd: !1 }); } function uc(t, e, n, i, r) { var o = e.__brushOption.range, a = cc(t, n, i); hw(o, function (t) { (t[0] += a[0]), (t[1] += a[1]); }), ju(t, e), Qu(t, { isEnd: !1 }); } function cc(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 dc(t, e, i) { var r = $u(t, e); return r && !0 !== r ? r.clipPath(i, t._transform) : n(i); } function fc(t) { var e = cw(t[0][0], t[1][0]), n = cw(t[0][1], t[1][1]); return { x: e, y: n, width: dw(t[0][0], t[1][0]) - e, height: dw(t[0][1], t[1][1]) - n, }; } function pc(t, e, n) { if (t._brushType) { var i = t._zr, r = t._covers, o = Yu(t, e, n); if (!t._dragging) for (var a = 0; a < r.length; a++) { var s = r[a].__brushOption; if ( o && (!0 === o || s.panelId === o.panelId) && Mw[s.brushType].contain(r[a], n[0], n[1]) ) return; } o && i.setCursorStyle('crosshair'); } } function gc(t) { var e = t.event; e.preventDefault && e.preventDefault(); } function vc(t, e, n) { return t.childOfName('main').contain(e, n); } function mc(t, e, i, r) { var o, a = t._creatingCover, s = t._creatingPanel, l = t._brushOption; if ((t._track.push(i.slice()), Ju(t) || a)) { if (s && !a) { 'single' === l.brushMode && Ku(t); var h = n(l); (h.brushType = yc(h.brushType, s)), (h.panelId = !0 === s ? null : s.panelId), (a = t._creatingCover = Fu(t, h)), t._covers.push(a); } if (a) { var u = Mw[yc(t._brushType, s)]; (a.__brushOption.range = u.getCreatingRange(dc(t, a, t._track))), r && (Zu(t, a), u.updateCommon(t, a)), Uu(t, a), (o = { isEnd: r }); } } else r && 'single' === l.brushMode && l.removeOnClick && Yu(t, e, i) && Ku(t) && (o = { isEnd: r, removeOnClick: !0 }); return o; } function yc(t, e) { return 'auto' === t ? e.defaultBrushType : t; } function xc(t) { if (this._dragging) { gc(t); var e = mc( this, t, this.group.transformCoordToLocal(t.offsetX, t.offsetY), !0 ); (this._dragging = !1), (this._track = []), (this._creatingCover = null), e && Qu(this, e); } } function _c(t) { return { createCover: function (e, n) { return ec( lw( hc, function (e) { var n = [e, [0, 100]]; return t && n.reverse(), n; }, function (e) { return e[t]; } ), e, n, [ ['w', 'e'], ['n', 's'], ][t] ); }, getCreatingRange: function (e) { var n = tc(e); return [cw(n[0][t], n[1][t]), dw(n[0][t], n[1][t])]; }, updateCoverShape: function (e, n, i, r) { var o, a = $u(e, n); if (!0 !== a && a.getLinearBrushOtherExtent) o = a.getLinearBrushOtherExtent(t, e._transform); else { var s = e._zr; o = [0, [s.getWidth(), s.getHeight()][1 - t]]; } var l = [i, o]; t && l.reverse(), nc(e, n, l, r); }, updateCommon: ic, contain: vc, }; } function wc(t, e, n) { var i = e.getComponentByElement(t.topTarget), r = i && i.coordinateSystem; return i && i !== n && !Sw[i.mainType] && r && r.model !== n; } function bc(t) { return ( (t = Ic(t)), function (e, n) { return wr(e, t); } ); } function Mc(t, e) { return ( (t = Ic(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 Sc(t, e, n) { return ( (t = Ic(t)), function (i, r, o) { return t.contain(r[0], r[1]) && !wc(i, e, n); } ); } function Ic(t) { return Zt.create(t); } function Tc(t, e, n) { var i = (this._targetInfoList = []), r = {}, o = Cc(e, t); Iw(Pw, function (t, e) { (!n || !n.include || Tw(n.include, e) >= 0) && t(o, i, r); }); } function Ac(t) { return t[0] > t[1] && t.reverse(), t; } function Cc(t, e) { return Er(t, e, { includeMainTypes: kw }); } function kc(t, e, n, i) { var r = n.getAxis(['x', 'y'][t]), o = Ac( f([0, 1], function (t) { return e ? r.coordToData(r.toLocalCoord(i[t])) : r.toGlobalCoord(r.dataToCoord(i[t])); }) ), a = []; return (a[t] = o), (a[1 - t] = [NaN, NaN]), { values: o, xyMinMax: a }; } function Dc(t, e, n, i) { return [e[0] - i[t] * n[0], e[1] - i[t] * n[1]]; } function Pc(t, e) { var n = Lc(t), i = Lc(e), r = [n[0] / i[0], n[1] / i[1]]; return isNaN(r[0]) && (r[0] = 1), isNaN(r[1]) && (r[1] = 1), r; } function Lc(t) { return t ? [t[0][1] - t[0][0], t[1][1] - t[1][0]] : [NaN, NaN]; } function Oc(t, e) { var n = Bc(t); Nw(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); } function zc(t) { var e = Bc(t), n = e[e.length - 1]; e.length > 1 && e.pop(); var i = {}; return ( Nw(n, function (t, n) { for (var r = e.length - 1; r >= 0; r--) if ((t = e[r][n])) { i[n] = t; break; } }), i ); } function Ec(t) { t[Bw] = null; } function Nc(t) { return Bc(t).length; } function Bc(t) { var e = t[Bw]; return e || (e = t[Bw] = [{}]), e; } function Rc(t, e, n) { (this._brushController = new Gu(n.getZr())) .on('brush', v(this._onBrush, this)) .mount(), this._isZoomActive; } function Vc(t) { var e = {}; return ( d(['xAxisIndex', 'yAxisIndex'], function (n) { (e[n] = t[n]), null == e[n] && (e[n] = 'all'), (!1 === e[n] || 'none' === e[n]) && (e[n] = []); }), e ); } function Gc(t, e) { t.setIconStatus('back', Nc(e) > 1 ? 'emphasis' : 'normal'); } function Wc(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 Tc(Vc(t.option), e, { include: ['grid'] }); n._brushController .setPanels( a.makePanelOpts(r, function (t) { return t.xAxisDeclared && !t.yAxisDeclared ? 'lineX' : !t.xAxisDeclared && t.yAxisDeclared ? 'lineY' : 'rect'; }) ) .enableBrush( !!o && { brushType: 'auto', brushStyle: { lineWidth: 0, fill: 'rgba(0,0,0,0.2)' }, } ); } function Hc(t) { this.model = t; } function Fc(t) { return Zw(t); } function Zc() { if (!jw && qw) { jw = !0; var t = qw.styleSheets; t.length < 31 ? qw.createStyleSheet().addRule('.zrvml', 'behavior:url(#default#VML)') : t[0].addRule('.zrvml', 'behavior:url(#default#VML)'); } } function Uc(t) { return parseInt(t, 10); } function Xc(t, e) { Zc(), (this.root = t), (this.storage = e); var n = document.createElement('div'), i = document.createElement('div'); (n.style.cssText = 'display:inline-block;overflow:hidden;position:relative;width:300px;height:150px;'), (i.style.cssText = 'position:absolute;left:0;top:0;'), t.appendChild(n), (this._vmlRoot = i), (this._vmlViewport = n), this.resize(); var r = e.delFromStorage, o = e.addToStorage; (e.delFromStorage = function (t) { r.call(e, t), t && t.onRemove && t.onRemove(i); }), (e.addToStorage = function (t) { t.onAdd && t.onAdd(i), o.call(e, t); }), (this._firstPaint = !0); } function jc(t) { return function () { _f('In IE8.0 VML mode painter not support method "' + t + '"'); }; } function qc(t) { return document.createElementNS(Cb, t); } function Yc(t) { return Lb(1e4 * t) / 1e4; } function $c(t) { return t < Rb && t > -Rb; } function Kc(t, e) { var n = e ? t.textFill : t.fill; return null != n && n !== Pb; } function Qc(t, e) { var n = e ? t.textStroke : t.stroke; return null != n && n !== Pb; } function Jc(t, e) { e && td(t, 'transform', 'matrix(' + Db.call(e, ',') + ')'); } function td(t, e, n) { (!n || ('linear' !== n.type && 'radial' !== n.type)) && t.setAttribute(e, n); } function ed(t, e, n) { t.setAttributeNS('http://www.w3.org/1999/xlink', e, n); } function nd(t, e, n) { if (Kc(e, n)) { var i = n ? e.textFill : e.fill; (i = 'transparent' === i ? Pb : i), 'none' !== t.getAttribute('clip-path') && i === Pb && (i = 'rgba(0, 0, 0, 0.002)'), td(t, 'fill', i), td(t, 'fill-opacity', e.opacity); } else td(t, 'fill', Pb); if (Qc(e, n)) { var r = n ? e.textStroke : e.stroke; td(t, 'stroke', (r = 'transparent' === r ? Pb : r)), td( t, 'stroke-width', (n ? e.textStrokeWidth : e.lineWidth) / (e.strokeNoScale ? e.host.getLineScale() : 1) ), td(t, 'paint-order', 'stroke'), td(t, 'stroke-opacity', e.opacity), e.lineDash ? (td(t, 'stroke-dasharray', e.lineDash.join(',')), td(t, 'stroke-dashoffset', Lb(e.lineDashOffset || 0))) : td(t, 'stroke-dasharray', ''), e.lineCap && td(t, 'stroke-linecap', e.lineCap), e.lineJoin && td(t, 'stroke-linejoin', e.lineJoin), e.miterLimit && td(t, 'stroke-miterlimit', e.miterLimit); } else td(t, 'stroke', Pb); } function id(t) { for (var e = [], n = t.data, i = t.len(), r = 0; r < i; ) { var o = '', a = 0; switch (n[r++]) { case kb.M: (o = 'M'), (a = 2); break; case kb.L: (o = 'L'), (a = 2); break; case kb.Q: (o = 'Q'), (a = 4); break; case kb.C: (o = 'C'), (a = 6); break; case kb.A: var s = n[r++], l = n[r++], h = n[r++], u = n[r++], c = n[r++], d = n[r++], f = n[r++], p = n[r++], g = Math.abs(d), v = $c(g % Nb) && !$c(g), m = !1; m = g >= Nb || (!$c(g) && ((d > -Eb && d < 0) || d > Eb) == !!p); var y = Yc(s + h * zb(c)), x = Yc(l + u * Ob(c)); v && ((d = p ? Nb - 1e-4 : 1e-4 - Nb), (m = !0), 9 === r && e.push('M', y, x)); var _ = Yc(s + h * zb(c + d)), w = Yc(l + u * Ob(c + d)); e.push('A', Yc(h), Yc(u), Lb(f * Bb), +m, +p, _, w); break; case kb.Z: o = 'Z'; break; case kb.R: var _ = Yc(n[r++]), w = Yc(n[r++]), b = Yc(n[r++]), M = Yc(n[r++]); e.push( 'M', _, w, 'L', _ + b, w, 'L', _ + b, w + M, 'L', _, w + M, 'L', _, w ); } o && e.push(o); for (var S = 0; S < a; S++) e.push(Yc(n[r++])); } return e.join(' '); } function rd(t) { return 'middle' === t ? 'middle' : 'bottom' === t ? 'baseline' : 'hanging'; } function od() {} function ad(t, e, n, i) { for (var r = 0, o = e.length, a = 0, s = 0; r < o; r++) { var l = e[r]; if (l.removed) { for (var h = [], u = s; u < s + l.count; u++) h.push(u); (l.indices = h), (s += l.count); } else { for (var h = [], u = a; u < a + l.count; u++) h.push(u); (l.indices = h), (a += l.count), l.added || (s += l.count); } } return e; } function sd(t) { return { newPos: t.newPos, components: t.components.slice(0) }; } function ld(t, e, n) { (this._svgRoot = t), (this._tagNames = 'string' == typeof e ? [e] : e), (this._markLabel = n), (this.nextId = 0); } function hd(t) { ld.call( this, t, ['linearGradient', 'radialGradient'], '__gradient_in_use__' ); } function ud(t) { ld.call(this, t, 'clipPath', '__clippath_in_use__'); } function cd(t) { return parseInt(t, 10); } function dd(t) { return t instanceof ki ? Vb : t instanceof Ue ? Gb : t instanceof zg ? Wb : Vb; } function fd(t, e) { return e && t && e.parentNode !== t; } function pd(t, e, n) { if (fd(t, e) && n) { var i = n.nextSibling; i ? t.insertBefore(e, i) : t.appendChild(e); } } function gd(t, e) { if (fd(t, e)) { var n = t.firstChild; n ? t.insertBefore(e, n) : t.appendChild(e); } } function vd(t, e) { e && t && e.parentNode === t && t.removeChild(e); } function md(t) { return t.__textSvgEl; } function yd(t) { return t.__svgEl; } function xd(t) { return function () { _f('In SVG mode painter not support method "' + t + '"'); }; } var _d = 2311, wd = function () { return _d++; }, bd = {}, Md = (bd = 'undefined' == typeof navigator ? { browser: {}, os: {}, node: !0, canvasSupported: !0, svgSupported: !0, } : (function (t) { var e = {}, n = {}, 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); return ( i && ((n.firefox = !0), (n.version = i[1])), r && ((n.ie = !0), (n.version = r[1])), o && ((n.edge = !0), (n.version = o[1])), a && (n.weChat = !0), { browser: n, os: e, node: !1, canvasSupported: !!document.createElement('canvas').getContext, svgSupported: 'undefined' != typeof SVGRect, touchEventsSupported: 'ontouchstart' in window && !n.ie && !n.edge, pointerEventsSupported: 'onpointerdown' in window && (n.edge || (n.ie && n.version >= 11)), } ); })(navigator.userAgent)), Sd = { '[object Function]': 1, '[object RegExp]': 1, '[object Date]': 1, '[object Error]': 1, '[object CanvasGradient]': 1, '[object CanvasPattern]': 1, '[object Image]': 1, '[object Canvas]': 1, }, Id = { '[object Int8Array]': 1, '[object Uint8Array]': 1, '[object Uint8ClampedArray]': 1, '[object Int16Array]': 1, '[object Uint16Array]': 1, '[object Int32Array]': 1, '[object Uint32Array]': 1, '[object Float32Array]': 1, '[object Float64Array]': 1, }, Td = Object.prototype.toString, Ad = Array.prototype, Cd = Ad.forEach, kd = Ad.filter, Dd = Ad.slice, Pd = Ad.map, Ld = Ad.reduce, Od = {}, zd = function () { return Od.createCanvas(); }; Od.createCanvas = function () { return document.createElement('canvas'); }; var Ed, Nd = '__ec_primitive__'; O.prototype = { constructor: O, get: function (t) { return this['_ec_' + t]; }, set: function (t, e) { return (this['_ec_' + t] = e), e; }, each: function (t, e) { void 0 !== e && (t = v(t, e)); for (var n in this) this.hasOwnProperty(n) && t(this[n], n.slice(4)); }, removeKey: function (t) { delete this['_ec_' + t]; }, }; var Bd = (Object.freeze || Object)({ $override: e, clone: n, merge: i, mergeAll: r, extend: o, defaults: a, createCanvas: zd, getContext: s, indexOf: l, inherits: h, mixin: u, isArrayLike: c, each: d, map: f, reduce: p, filter: g, find: function (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]; }, bind: v, curry: m, isArray: y, isFunction: x, isString: _, isObject: w, isBuiltInObject: b, isDom: M, eqNaN: S, retrieve: I, retrieve2: T, retrieve3: A, slice: C, normalizeCssArray: k, assert: D, setAsPrimitive: P, isPrimitive: L, createHashMap: z, noop: E, }), Rd = 'undefined' == typeof Float32Array ? Array : Float32Array, Vd = H, Gd = F, Wd = X, Hd = j, Fd = (Object.freeze || Object)({ create: N, copy: B, clone: R, set: function (t, e, n) { return (t[0] = e), (t[1] = n), t; }, add: V, scaleAndAdd: G, sub: W, len: H, length: Vd, lenSquare: F, lengthSquare: Gd, 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: Z, normalize: U, distance: X, dist: Wd, distanceSquare: j, distSquare: Hd, negate: function (t, e) { return (t[0] = -e[0]), (t[1] = -e[1]), t; }, lerp: function (t, e, n, i) { return ( (t[0] = e[0] + i * (n[0] - e[0])), (t[1] = e[1] + i * (n[1] - e[1])), t ); }, applyTransform: q, min: Y, max: $, }); K.prototype = { constructor: K, _dragStart: function (t) { var e = t.target; e && e.draggable && ((this._draggingTarget = e), (e.dragging = !0), (this._x = t.offsetX), (this._y = t.offsetY), this.dispatchToElement(Q(e, t), 'dragstart', t.event)); }, _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.dispatchToElement(Q(e, t), 'drag', t.event); var a = this.findHover(n, i, e).target, s = this._dropTarget; (this._dropTarget = a), e !== a && (s && a !== s && this.dispatchToElement(Q(s, t), 'dragleave', t.event), a && a !== s && this.dispatchToElement(Q(a, t), 'dragenter', t.event)); } }, _dragEnd: function (t) { var e = this._draggingTarget; e && (e.dragging = !1), this.dispatchToElement(Q(e, t), 'dragend', t.event), this._dropTarget && this.dispatchToElement(Q(this._dropTarget, t), 'drop', t.event), (this._draggingTarget = null), (this._dropTarget = null); }, }; var Zd = Array.prototype.slice, Ud = function () { this._$handlers = {}; }; Ud.prototype = { constructor: Ud, one: function (t, e, n) { var i = this._$handlers; if (!e || !t) return this; i[t] || (i[t] = []); for (var r = 0; r < i[t].length; r++) if (i[t][r].h === e) return this; return i[t].push({ h: e, one: !0, ctx: n || this }), this; }, on: function (t, e, n) { var i = this._$handlers; if (!e || !t) return this; i[t] || (i[t] = []); for (var r = 0; r < i[t].length; r++) if (i[t][r].h === e) return this; return i[t].push({ h: e, one: !1, ctx: n || this }), this; }, isSilent: function (t) { var e = this._$handlers; return e[t] && e[t].length; }, off: function (t, e) { var n = this._$handlers; 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; }, trigger: function (t) { if (this._$handlers[t]) { var e = arguments, n = e.length; n > 3 && (e = Zd.call(e, 1)); for (var i = this._$handlers[t], r = i.length, o = 0; o < r; ) { switch (n) { case 1: i[o].h.call(i[o].ctx); break; case 2: i[o].h.call(i[o].ctx, e[1]); break; case 3: i[o].h.call(i[o].ctx, e[1], e[2]); break; default: i[o].h.apply(i[o].ctx, e); } i[o].one ? (i.splice(o, 1), r--) : o++; } } return this; }, triggerWithContext: function (t) { if (this._$handlers[t]) { var e = arguments, n = e.length; n > 4 && (e = Zd.call(e, 1, e.length - 1)); for ( var i = e[e.length - 1], r = this._$handlers[t], o = r.length, a = 0; a < o; ) { switch (n) { case 1: r[a].h.call(i); break; case 2: r[a].h.call(i, e[1]); break; case 3: r[a].h.call(i, e[1], e[2]); break; default: r[a].h.apply(i, e); } r[a].one ? (r.splice(a, 1), o--) : a++; } } return this; }, }; var Xd = 'silent'; tt.prototype.dispose = function () {}; var jd = [ 'click', 'dblclick', 'mousewheel', 'mouseout', 'mouseup', 'mousedown', 'mousemove', 'contextmenu', ], qd = function (t, e, n, i) { Ud.call(this), (this.storage = t), (this.painter = e), (this.painterRoot = i), (n = n || new tt()), (this.proxy = n), (n.handler = this), (this._hovered = {}), this._lastTouchMoment, this._lastX, this._lastY, K.call(this), d( jd, function (t) { n.on && n.on(t, this[t], this); }, this ); }; (qd.prototype = { constructor: qd, mousemove: function (t) { var e = t.zrX, n = t.zrY, i = this._hovered, r = i.target; r && !r.__zr && (r = (i = this.findHover(i.x, i.y)).target); var o = (this._hovered = this.findHover(e, n)), a = o.target, s = this.proxy; s.setCursor && s.setCursor(a ? a.cursor : 'default'), r && a !== r && this.dispatchToElement(i, 'mouseout', t), this.dispatchToElement(o, 'mousemove', t), a && a !== r && this.dispatchToElement(o, 'mouseover', t); }, mouseout: function (t) { this.dispatchToElement(this._hovered, 'mouseout', t); var e, n = t.toElement || t.relatedTarget; do { n = n && n.parentNode; } while (n && 9 != n.nodeType && !(e = n === this.painterRoot)); !e && this.trigger('globalout', { event: t }); }, resize: function (t) { this._hovered = {}; }, dispatch: function (t, e) { var n = this[t]; n && n.call(this, e); }, dispose: function () { this.proxy.dispose(), (this.storage = this.proxy = this.painter = null); }, setCursorStyle: function (t) { var e = this.proxy; e.setCursor && e.setCursor(t); }, dispatchToElement: function (t, e, n) { var i = (t = t || {}).target; if (!i || !i.silent) { for ( var r = 'on' + e, o = J(e, t, n); i && (i[r] && (o.cancelBubble = i[r].call(i, o)), i.trigger(e, o), (i = i.parent), !o.cancelBubble); ); o.cancelBubble || (this.trigger(e, o), this.painter && this.painter.eachOtherLayer(function (t) { 'function' == typeof t[r] && t[r].call(t, o), t.trigger && t.trigger(e, o); })); } }, findHover: function (t, e, n) { for ( var i = this.storage.getDisplayList(), r = { x: t, y: e }, o = i.length - 1; o >= 0; o-- ) { var a; if ( i[o] !== n && !i[o].ignore && (a = et(i[o], t, e)) && (!r.topTarget && (r.topTarget = i[o]), a !== Xd) ) { r.target = i[o]; break; } } return r; }, }), d( [ 'click', 'mousedown', 'mouseup', 'mousewheel', 'dblclick', 'contextmenu', ], function (t) { qd.prototype[t] = function (e) { var n = this.findHover(e.zrX, e.zrY), i = n.target; if ('mousedown' === t) (this._downEl = i), (this._downPoint = [e.zrX, e.zrY]), (this._upEl = i); else if ('mosueup' === t) this._upEl = i; else if ('click' === t) { if ( this._downEl !== this._upEl || !this._downPoint || Wd(this._downPoint, [e.zrX, e.zrY]) > 4 ) return; this._downPoint = null; } this.dispatchToElement(n, t, e); }; } ), u(qd, Ud), u(qd, K); var Yd = 'undefined' == typeof Float32Array ? Array : Float32Array, $d = (Object.freeze || Object)({ create: nt, identity: it, copy: rt, mul: ot, translate: at, rotate: st, scale: lt, invert: ht, }), Kd = it, Qd = 5e-5, Jd = function (t) { (t = t || {}).position || (this.position = [0, 0]), null == t.rotation && (this.rotation = 0), t.scale || (this.scale = [1, 1]), (this.origin = this.origin || null); }, tf = Jd.prototype; (tf.transform = null), (tf.needLocalTransform = function () { return ( ut(this.rotation) || ut(this.position[0]) || ut(this.position[1]) || ut(this.scale[0] - 1) || ut(this.scale[1] - 1) ); }), (tf.updateTransform = function () { var t = this.parent, e = t && t.transform, n = this.needLocalTransform(), i = this.transform; n || e ? ((i = i || nt()), n ? this.getLocalTransform(i) : Kd(i), e && (n ? ot(i, t.transform, i) : rt(i, t.transform)), (this.transform = i), (this.invTransform = this.invTransform || nt()), ht(this.invTransform, i)) : i && Kd(i); }), (tf.getLocalTransform = function (t) { return Jd.getLocalTransform(this, t); }), (tf.setTransform = function (t) { var e = this.transform, n = t.dpr || 1; e ? t.setTransform( n * e[0], n * e[1], n * e[2], n * e[3], n * e[4], n * e[5] ) : t.setTransform(n, 0, 0, n, 0, 0); }), (tf.restoreTransform = function (t) { var e = t.dpr || 1; t.setTransform(e, 0, 0, e, 0, 0); }); var ef = []; (tf.decomposeTransform = function () { if (this.transform) { var t = this.parent, e = this.transform; t && t.transform && (ot(ef, t.invTransform, e), (e = ef)); var n = e[0] * e[0] + e[1] * e[1], i = e[2] * e[2] + e[3] * e[3], r = this.position, o = this.scale; ut(n - 1) && (n = Math.sqrt(n)), ut(i - 1) && (i = Math.sqrt(i)), e[0] < 0 && (n = -n), e[3] < 0 && (i = -i), (r[0] = e[4]), (r[1] = e[5]), (o[0] = n), (o[1] = i), (this.rotation = Math.atan2(-e[1] / i, e[0] / n)); } }), (tf.getGlobalScale = function () { var t = this.transform; if (!t) return [1, 1]; var e = Math.sqrt(t[0] * t[0] + t[1] * t[1]), n = Math.sqrt(t[2] * t[2] + t[3] * t[3]); return t[0] < 0 && (e = -e), t[3] < 0 && (n = -n), [e, n]; }), (tf.transformCoordToLocal = function (t, e) { var n = [t, e], i = this.invTransform; return i && q(n, n, i), n; }), (tf.transformCoordToGlobal = function (t, e) { var n = [t, e], i = this.transform; return i && q(n, n, i), n; }), (Jd.getLocalTransform = function (t, e) { Kd((e = e || [])); var n = t.origin, i = t.scale || [1, 1], r = t.rotation || 0, o = t.position || [0, 0]; return ( n && ((e[4] -= n[0]), (e[5] -= n[1])), lt(e, e, i), r && st(e, e, r), n && ((e[4] += n[0]), (e[5] += n[1])), (e[4] += o[0]), (e[5] += o[1]), e ); }); var nf = { linear: function (t) { return t; }, quadraticIn: function (t) { return t * t; }, quadraticOut: function (t) { return t * (2 - t); }, quadraticInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t : -0.5 * (--t * (t - 2) - 1); }, cubicIn: function (t) { return t * t * t; }, cubicOut: function (t) { return --t * t * t + 1; }, cubicInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t * t : 0.5 * ((t -= 2) * t * t + 2); }, quarticIn: function (t) { return t * t * t * t; }, quarticOut: function (t) { return 1 - --t * t * t * t; }, quarticInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t * t * t : -0.5 * ((t -= 2) * t * t * t - 2); }, quinticIn: function (t) { return t * t * t * t * t; }, quinticOut: function (t) { return --t * t * t * t * t + 1; }, quinticInOut: function (t) { return (t *= 2) < 1 ? 0.5 * t * t * t * t * t : 0.5 * ((t -= 2) * t * t * t * t + 2); }, sinusoidalIn: function (t) { return 1 - Math.cos((t * Math.PI) / 2); }, sinusoidalOut: function (t) { return Math.sin((t * Math.PI) / 2); }, sinusoidalInOut: function (t) { return 0.5 * (1 - Math.cos(Math.PI * t)); }, exponentialIn: function (t) { return 0 === t ? 0 : Math.pow(1024, t - 1); }, exponentialOut: function (t) { return 1 === t ? 1 : 1 - Math.pow(2, -10 * t); }, exponentialInOut: function (t) { return 0 === t ? 0 : 1 === t ? 1 : (t *= 2) < 1 ? 0.5 * Math.pow(1024, t - 1) : 0.5 * (2 - Math.pow(2, -10 * (t - 1))); }, circularIn: function (t) { return 1 - Math.sqrt(1 - t * t); }, circularOut: function (t) { return Math.sqrt(1 - --t * t); }, circularInOut: function (t) { return (t *= 2) < 1 ? -0.5 * (Math.sqrt(1 - t * t) - 1) : 0.5 * (Math.sqrt(1 - (t -= 2) * t) + 1); }, elasticIn: function (t) { var e, n = 0.1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? ((n = 1), (e = 0.1)) : (e = (0.4 * Math.asin(1 / n)) / (2 * Math.PI)), -n * Math.pow(2, 10 * (t -= 1)) * Math.sin(((t - e) * (2 * Math.PI)) / 0.4)); }, elasticOut: function (t) { var e, n = 0.1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? ((n = 1), (e = 0.1)) : (e = (0.4 * Math.asin(1 / n)) / (2 * Math.PI)), n * Math.pow(2, -10 * t) * Math.sin(((t - e) * (2 * Math.PI)) / 0.4) + 1); }, elasticInOut: function (t) { var e, n = 0.1; return 0 === t ? 0 : 1 === t ? 1 : (!n || n < 1 ? ((n = 1), (e = 0.1)) : (e = (0.4 * Math.asin(1 / n)) / (2 * Math.PI)), (t *= 2) < 1 ? n * Math.pow(2, 10 * (t -= 1)) * Math.sin(((t - e) * (2 * Math.PI)) / 0.4) * -0.5 : n * Math.pow(2, -10 * (t -= 1)) * Math.sin(((t - e) * (2 * Math.PI)) / 0.4) * 0.5 + 1); }, backIn: function (t) { var e = 1.70158; return t * t * ((e + 1) * t - e); }, backOut: function (t) { var e = 1.70158; return --t * t * ((e + 1) * t + e) + 1; }, backInOut: function (t) { var e = 2.5949095; return (t *= 2) < 1 ? t * t * ((e + 1) * t - e) * 0.5 : 0.5 * ((t -= 2) * t * ((e + 1) * t + e) + 2); }, bounceIn: function (t) { return 1 - nf.bounceOut(1 - t); }, bounceOut: function (t) { return t < 1 / 2.75 ? 7.5625 * t * t : t < 2 / 2.75 ? 7.5625 * (t -= 1.5 / 2.75) * t + 0.75 : t < 2.5 / 2.75 ? 7.5625 * (t -= 2.25 / 2.75) * t + 0.9375 : 7.5625 * (t -= 2.625 / 2.75) * t + 0.984375; }, bounceInOut: function (t) { return t < 0.5 ? 0.5 * nf.bounceIn(2 * t) : 0.5 * nf.bounceOut(2 * t - 1) + 0.5; }, }; ct.prototype = { constructor: ct, step: function (t, e) { if ( (this._initialized || ((this._startTime = t + this._delay), (this._initialized = !0)), this._paused) ) this._pausedTime += e; else { var n = (t - this._startTime - this._pausedTime) / this._life; if (!(n < 0)) { n = Math.min(n, 1); var i = this.easing, r = 'string' == typeof i ? nf[i] : i, o = 'function' == typeof r ? r(n) : n; return ( this.fire('frame', o), 1 == n ? this.loop ? (this.restart(t), 'restart') : ((this._needsRemove = !0), 'destroy') : null ); } } }, restart: function (t) { var e = (t - this._startTime - this._pausedTime) % this._life; (this._startTime = t - e + this.gap), (this._pausedTime = 0), (this._needsRemove = !1); }, fire: function (t, e) { this[(t = 'on' + t)] && this[t](this._target, e); }, pause: function () { this._paused = !0; }, resume: function () { this._paused = !1; }, }; var rf = function () { (this.head = null), (this.tail = null), (this._len = 0); }, of = rf.prototype; (of.insert = function (t) { var e = new af(t); return this.insertEntry(e), e; }), (of.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++; }), (of.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--; }), (of.len = function () { return this._len; }), (of.clear = function () { (this.head = this.tail = null), (this._len = 0); }); var af = function (t) { (this.value = t), this.next, this.prev; }, sf = function (t) { (this._list = new rf()), (this._map = {}), (this._maxSize = t || 10), (this._lastRemovedEntry = null); }, lf = sf.prototype; (lf.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 af(e)), (a.key = t), n.insertEntry(a), (i[t] = a); } return r; }), (lf.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; }), (lf.clear = function () { this._list.clear(), (this._map = {}); }); var hf = { 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], }, uf = new sf(20), cf = null, df = At, ff = Ct, pf = (Object.freeze || Object)({ parse: bt, lift: It, toHex: Tt, fastLerp: At, fastMapToColor: df, lerp: Ct, mapToColor: ff, modifyHSL: function (t, e, n, i) { if ((t = bt(t))) return ( (t = St(t)), null != e && (t[0] = ft(e)), null != n && (t[1] = vt(n)), null != i && (t[2] = vt(i)), Dt(Mt(t), 'rgba') ); }, modifyAlpha: kt, stringify: Dt, }), gf = Array.prototype.slice, vf = function (t, e, n, i) { (this._tracks = {}), (this._target = t), (this._loop = e || !1), (this._getter = n || Pt), (this._setter = i || Lt), (this._clipCount = 0), (this._delay = 0), (this._doneList = []), (this._onframeList = []), (this._clipList = []); }; vf.prototype = { when: function (t, e) { var n = this._tracks; for (var i in e) if (e.hasOwnProperty(i)) { if (!n[i]) { n[i] = []; var r = this._getter(this._target, i); if (null == r) continue; 0 !== t && n[i].push({ time: 0, value: Gt(r) }); } n[i].push({ time: t, value: e[i] }); } return this; }, during: function (t) { return this._onframeList.push(t), this; }, pause: function () { for (var t = 0; t < this._clipList.length; t++) this._clipList[t].pause(); this._paused = !0; }, resume: function () { for (var t = 0; t < this._clipList.length; t++) this._clipList[t].resume(); this._paused = !1; }, isPaused: function () { return !!this._paused; }, _doneCallback: function () { (this._tracks = {}), (this._clipList.length = 0); for (var t = this._doneList, e = t.length, n = 0; n < e; n++) t[n].call(this); }, start: function (t, e) { var n, i = this, r = 0; for (var o in this._tracks) if (this._tracks.hasOwnProperty(o)) { var a = Ft( this, t, function () { --r || i._doneCallback(); }, this._tracks[o], o, e ); a && (this._clipList.push(a), r++, this.animation && this.animation.addClip(a), (n = a)); } if (n) { var s = n.onframe; n.onframe = function (t, e) { s(t, e); for (var n = 0; n < i._onframeList.length; n++) i._onframeList[n](t, e); }; } return r || this._doneCallback(), this; }, stop: function (t) { for ( var e = this._clipList, n = this.animation, i = 0; i < e.length; i++ ) { var r = e[i]; t && r.onframe(this._target, 1), n && n.removeClip(r); } e.length = 0; }, delay: function (t) { return (this._delay = t), this; }, done: function (t) { return t && this._doneList.push(t), this; }, getClips: function () { return this._clipList; }, }; var mf = 1; 'undefined' != typeof window && (mf = Math.max(window.devicePixelRatio || 1, 1)); var yf = mf, xf = function () {}, _f = xf, wf = function () { this.animators = []; }; wf.prototype = { constructor: wf, animate: function (t, e) { var n, i = !1, r = this, o = this.__zr; if (t) { var a = t.split('.'), s = r; i = 'shape' === a[0]; for (var h = 0, u = a.length; h < u; h++) s && (s = s[a[h]]); s && (n = s); } else n = r; if (n) { var c = r.animators, d = new vf(n, e); return ( d .during(function (t) { r.dirty(i); }) .done(function () { c.splice(l(c, d), 1); }), c.push(d), o && o.animation.addAnimator(d), d ); } _f('Property "' + t + '" is not existed in element ' + r.id); }, stopAnimation: function (t) { for (var e = this.animators, n = e.length, i = 0; i < n; i++) e[i].stop(t); return (e.length = 0), this; }, animateTo: function (t, e, n, i, r, o) { _(n) ? ((r = i), (i = n), (n = 0)) : x(i) ? ((r = i), (i = 'linear'), (n = 0)) : x(n) ? ((r = n), (n = 0)) : x(e) ? ((r = e), (e = 500)) : e || (e = 500), this.stopAnimation(), this._animateToShallow('', this, t, e, n); var a = this.animators.slice(), s = a.length; s || (r && r()); for (var l = 0; l < a.length; l++) a[l] .done(function () { --s || (r && r()); }) .start(i, o); }, _animateToShallow: function (t, e, n, i, r) { var o = {}, a = 0; for (var s in n) if (n.hasOwnProperty(s)) if (null != e[s]) w(n[s]) && !c(n[s]) ? this._animateToShallow(t ? t + '.' + s : s, e[s], n[s], i, r) : ((o[s] = n[s]), a++); else if (null != n[s]) if (t) { var l = {}; (l[t] = {}), (l[t][s] = n[s]), this.attr(l); } else this.attr(s, n[s]); return ( a > 0 && this.animate(t, !1) .when(null == i ? 500 : i, o) .delay(r || 0), this ); }, }; var bf = function (t) { Jd.call(this, t), Ud.call(this, t), wf.call(this, t), (this.id = t.id || wd()); }; (bf.prototype = { type: 'element', name: '', __zr: null, ignore: !1, clipPath: null, drift: function (t, e) { switch (this.draggable) { case 'horizontal': e = 0; break; case 'vertical': t = 0; } var n = this.transform; n || (n = this.transform = [1, 0, 0, 1, 0, 0]), (n[4] += t), (n[5] += e), this.decomposeTransform(), this.dirty(!1); }, beforeUpdate: function () {}, afterUpdate: function () {}, update: function () { this.updateTransform(); }, traverse: function (t, e) {}, attrKV: function (t, e) { if ('position' === t || 'scale' === t || 'origin' === t) { if (e) { var n = this[t]; n || (n = this[t] = []), (n[0] = e[0]), (n[1] = e[1]); } } else this[t] = e; }, hide: function () { (this.ignore = !0), this.__zr && this.__zr.refresh(); }, show: function () { (this.ignore = !1), this.__zr && this.__zr.refresh(); }, attr: function (t, e) { if ('string' == typeof t) this.attrKV(t, e); else if (w(t)) for (var n in t) t.hasOwnProperty(n) && this.attrKV(n, t[n]); return this.dirty(!1), this; }, setClipPath: function (t) { var e = this.__zr; e && t.addSelfToZr(e), this.clipPath && this.clipPath !== t && this.removeClipPath(), (this.clipPath = t), (t.__zr = e), (t.__clipTarget = this), this.dirty(!1); }, removeClipPath: function () { var t = this.clipPath; t && (t.__zr && t.removeSelfFromZr(t.__zr), (t.__zr = null), (t.__clipTarget = null), (this.clipPath = null), this.dirty(!1)); }, addSelfToZr: function (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); }, removeSelfFromZr: function (t) { 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); }, }), u(bf, wf), u(bf, Jd), u(bf, Ud); var Mf = q, Sf = Math.min, If = Math.max; (Zt.prototype = { constructor: Zt, union: function (t) { var e = Sf(t.x, this.x), n = Sf(t.y, this.y); (this.width = If(t.x + t.width, this.x + this.width) - e), (this.height = If(t.y + t.height, this.y + this.height) - n), (this.x = e), (this.y = n); }, applyTransform: (function () { var t = [], e = [], n = [], i = []; return function (r) { if (r) { (t[0] = n[0] = this.x), (t[1] = i[1] = this.y), (e[0] = i[0] = this.x + this.width), (e[1] = n[1] = this.y + this.height), Mf(t, t, r), Mf(e, e, r), Mf(n, n, r), Mf(i, i, r), (this.x = Sf(t[0], e[0], n[0], i[0])), (this.y = Sf(t[1], e[1], n[1], i[1])); var o = If(t[0], e[0], n[0], i[0]), a = If(t[1], e[1], n[1], i[1]); (this.width = o - this.x), (this.height = a - this.y); } }; })(), calculateTransform: function (t) { var e = this, n = t.width / e.width, i = t.height / e.height, r = nt(); return at(r, r, [-e.x, -e.y]), lt(r, r, [n, i]), at(r, r, [t.x, t.y]), r; }, intersect: function (t) { if (!t) return !1; t instanceof Zt || (t = Zt.create(t)); var e = this, n = e.x, i = e.x + e.width, r = e.y, o = e.y + e.height, a = t.x, s = t.x + t.width, l = t.y, h = t.y + t.height; return !(i < a || s < n || o < l || h < r); }, contain: function (t, e) { var n = this; return t >= n.x && t <= n.x + n.width && e >= n.y && e <= n.y + n.height; }, clone: function () { return new Zt(this.x, this.y, this.width, this.height); }, copy: function (t) { (this.x = t.x), (this.y = t.y), (this.width = t.width), (this.height = t.height); }, plain: function () { return { x: this.x, y: this.y, width: this.width, height: this.height }; }, }), (Zt.create = function (t) { return new Zt(t.x, t.y, t.width, t.height); }); var Tf = function (t) { (t = t || {}), bf.call(this, t); for (var e in t) t.hasOwnProperty(e) && (this[e] = t[e]); (this._children = []), (this.__storage = null), (this.__dirty = !0); }; (Tf.prototype = { constructor: Tf, isGroup: !0, type: 'group', silent: !1, children: function () { return this._children.slice(); }, childAt: function (t) { return this._children[t]; }, childOfName: function (t) { for (var e = this._children, n = 0; n < e.length; n++) if (e[n].name === t) return e[n]; }, childCount: function () { return this._children.length; }, add: function (t) { return ( t && t !== this && t.parent !== this && (this._children.push(t), this._doAdd(t)), this ); }, 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; }, _doAdd: function (t) { t.parent && t.parent.remove(t), (t.parent = this); var e = this.__storage, n = this.__zr; e && e !== t.__storage && (e.addToStorage(t), t instanceof Tf && t.addChildrenToStorage(e)), n && n.refresh(); }, remove: function (t) { var e = this.__zr, n = this.__storage, i = this._children, r = l(i, t); return r < 0 ? this : (i.splice(r, 1), (t.parent = null), n && (n.delFromStorage(t), t instanceof Tf && t.delChildrenFromStorage(n)), e && e.refresh(), this); }, removeAll: function () { var t, e, n = this._children, i = this.__storage; for (e = 0; e < n.length; e++) (t = n[e]), i && (i.delFromStorage(t), t instanceof Tf && t.delChildrenFromStorage(i)), (t.parent = null); return (n.length = 0), this; }, 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; }, traverse: function (t, e) { for (var n = 0; n < this._children.length; n++) { var i = this._children[n]; t.call(e, i), 'group' === i.type && i.traverse(t, e); } return this; }, addChildrenToStorage: function (t) { for (var e = 0; e < this._children.length; e++) { var n = this._children[e]; t.addToStorage(n), n instanceof Tf && n.addChildrenToStorage(t); } }, delChildrenFromStorage: function (t) { for (var e = 0; e < this._children.length; e++) { var n = this._children[e]; t.delFromStorage(n), n instanceof Tf && n.delChildrenFromStorage(t); } }, dirty: function () { return (this.__dirty = !0), this.__zr && this.__zr.refresh(), this; }, getBoundingRect: function (t) { for ( var e = null, n = new Zt(0, 0, 0, 0), i = t || this._children, r = [], o = 0; o < i.length; o++ ) { var a = i[o]; if (!a.ignore && !a.invisible) { var s = a.getBoundingRect(), l = a.getLocalTransform(r); l ? (n.copy(s), n.applyTransform(l), (e = e || n.clone()).union(n)) : (e = e || s.clone()).union(s); } } return e || n; }, }), h(Tf, bf); var Af = 32, Cf = 7, kf = function () { (this._roots = []), (this._displayList = []), (this._displayListLen = 0); }; kf.prototype = { constructor: kf, traverse: function (t, e) { for (var n = 0; n < this._roots.length; n++) this._roots[n].traverse(t, e); }, getDisplayList: function (t, e) { return (e = e || !1), t && this.updateDisplayList(e), this._displayList; }, 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), Md.canvasSupported && Qt(n, Jt); }, _updateAndAddDisplayable: function (t, e, n) { if (!t.ignore || n) { t.beforeUpdate(), t.__dirty && t.update(), t.afterUpdate(); var i = t.clipPath; 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.clipPath); } if (t.isGroup) { for (var a = t._children, s = 0; s < a.length; s++) { var l = a[s]; t.__dirty && (l.__dirty = !0), this._updateAndAddDisplayable(l, e, n); } t.__dirty = !1; } else (t.__clipPaths = e), (this._displayList[this._displayListLen++] = t); } }, addRoot: function (t) { t.__storage !== this && (t instanceof Tf && t.addChildrenToStorage(this), this.addToStorage(t), this._roots.push(t)); }, delRoot: function (t) { if (null == t) { for (n = 0; n < this._roots.length; n++) { var e = this._roots[n]; e instanceof Tf && e.delChildrenFromStorage(this); } return ( (this._roots = []), (this._displayList = []), void (this._displayListLen = 0) ); } if (t instanceof Array) for (var n = 0, i = t.length; n < i; n++) this.delRoot(t[n]); else { var r = l(this._roots, t); r >= 0 && (this.delFromStorage(t), this._roots.splice(r, 1), t instanceof Tf && t.delChildrenFromStorage(this)); } }, addToStorage: function (t) { return (t.__storage = this), t.dirty(!1), this; }, delFromStorage: function (t) { return t && (t.__storage = null), this; }, dispose: function () { this._renderList = this._roots = null; }, displayableSortFunc: Jt, }; var Df = [ ['shadowBlur', 0], ['shadowOffsetX', 0], ['shadowOffsetY', 0], ['shadowColor', '#000'], ['lineCap', 'butt'], ['lineJoin', 'miter'], ['miterLimit', 10], ], Pf = function (t, e) { this.extendFrom(t, !1), (this.host = e); }; Pf.prototype = { constructor: Pf, host: null, fill: '#000', stroke: null, opacity: 1, lineDash: null, lineDashOffset: 0, shadowBlur: 0, shadowOffsetX: 0, shadowOffsetY: 0, lineWidth: 1, strokeNoScale: !1, text: null, font: null, textFont: null, fontStyle: null, fontWeight: null, fontSize: null, fontFamily: null, textTag: null, textFill: '#000', textStroke: null, textWidth: null, textHeight: null, textStrokeWidth: 0, textLineHeight: null, textPosition: 'inside', textRect: null, textOffset: null, textAlign: null, textVerticalAlign: null, textDistance: 5, textShadowColor: 'transparent', textShadowBlur: 0, textShadowOffsetX: 0, textShadowOffsetY: 0, textBoxShadowColor: 'transparent', textBoxShadowBlur: 0, textBoxShadowOffsetX: 0, textBoxShadowOffsetY: 0, transformText: !1, textRotation: 0, textOrigin: null, textBackgroundColor: null, textBorderColor: null, textBorderWidth: 0, textBorderRadius: 0, textPadding: null, rich: null, truncate: null, blend: null, bind: function (t, e, n) { for (var i = this, r = n && n.style, o = !r, a = 0; a < Df.length; a++) { var s = Df[a], l = s[0]; (o || i[l] !== r[l]) && (t[l] = i[l] || s[1]); } if ( ((o || i.fill !== r.fill) && (t.fillStyle = i.fill), (o || i.stroke !== r.stroke) && (t.strokeStyle = i.stroke), (o || i.opacity !== r.opacity) && (t.globalAlpha = null == i.opacity ? 1 : i.opacity), (o || i.blend !== r.blend) && (t.globalCompositeOperation = i.blend || 'source-over'), this.hasStroke()) ) { var h = i.lineWidth; t.lineWidth = h / (this.strokeNoScale && e && e.getLineScale ? e.getLineScale() : 1); } }, hasFill: function () { var t = this.fill; return null != t && 'none' !== t; }, hasStroke: function () { var t = this.stroke; return null != t && 'none' !== t && this.lineWidth > 0; }, extendFrom: function (t, e) { if (t) for (var n in t) !t.hasOwnProperty(n) || (!0 !== e && (!1 === e ? this.hasOwnProperty(n) : null == t[n])) || (this[n] = t[n]); }, set: function (t, e) { 'string' == typeof t ? (this[t] = e) : this.extendFrom(t, !0); }, clone: function () { var t = new this.constructor(); return t.extendFrom(this, !0), t; }, getGradient: function (t, e, n) { for ( var i = ('radial' === e.type ? ee : te)(t, e, n), r = e.colorStops, o = 0; o < r.length; o++ ) i.addColorStop(r[o].offset, r[o].color); return i; }, }; for (var Lf = Pf.prototype, Of = 0; Of < Df.length; Of++) { var zf = Df[Of]; zf[0] in Lf || (Lf[zf[0]] = zf[1]); } Pf.getGradient = Lf.getGradient; var Ef = function (t, e) { (this.image = t), (this.repeat = e), (this.type = 'pattern'); }; Ef.prototype.getCanvasPattern = function (t) { return t.createPattern(this.image, this.repeat || 'repeat'); }; var Nf = function (t, e, n) { var i; (n = n || yf), 'string' == typeof t ? (i = ie(t, e, n)) : w(t) && (t = (i = t).id), (this.id = t), (this.dom = i); var r = i.style; r && ((i.onselectstart = ne), (r['-webkit-user-select'] = 'none'), (r['user-select'] = 'none'), (r['-webkit-touch-callout'] = 'none'), (r['-webkit-tap-highlight-color'] = 'rgba(0,0,0,0)'), (r.padding = 0), (r.margin = 0), (r['border-width'] = 0)), (this.domBack = null), (this.ctxBack = null), (this.painter = e), (this.config = null), (this.clearColor = 0), (this.motionBlur = !1), (this.lastFrameAlpha = 0.7), (this.dpr = n); }; Nf.prototype = { constructor: Nf, elCount: 0, __dirty: !0, initContext: function () { (this.ctx = this.dom.getContext('2d')), (this.ctx.__currentValues = {}), (this.ctx.dpr = this.dpr); }, createBackBuffer: function () { var t = this.dpr; (this.domBack = ie('back-' + this.id, this.painter, t)), (this.ctxBack = this.domBack.getContext('2d')), (this.ctxBack.__currentValues = {}), 1 != t && this.ctxBack.scale(t, t); }, resize: function (t, e) { var n = this.dpr, i = this.dom, r = i.style, o = this.domBack; (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)); }, clear: function (t) { var e = this.dom, n = this.ctx, i = e.width, r = e.height, o = this.clearColor, a = this.motionBlur && !t, s = this.lastFrameAlpha, l = this.dpr; if ( (a && (this.domBack || this.createBackBuffer(), (this.ctxBack.globalCompositeOperation = 'copy'), this.ctxBack.drawImage(e, 0, 0, i / l, r / l)), n.clearRect(0, 0, i, r), o) ) { var h; o.colorStops ? ((h = o.__canvasGradient || Pf.getGradient(n, o, { x: 0, y: 0, width: i, height: r })), (o.__canvasGradient = h)) : o.image && (h = Ef.prototype.getCanvasPattern.call(o, n)), n.save(), (n.fillStyle = h || o), n.fillRect(0, 0, i, r), n.restore(); } if (a) { var u = this.domBack; n.save(), (n.globalAlpha = s), n.drawImage(u, 0, 0, i, r), n.restore(); } }, }; var Bf = ('undefined' != typeof window && ((window.requestAnimationFrame && window.requestAnimationFrame.bind(window)) || (window.msRequestAnimationFrame && window.msRequestAnimationFrame.bind(window)) || window.mozRequestAnimationFrame || window.webkitRequestAnimationFrame)) || function (t) { setTimeout(t, 16); }, Rf = new sf(50), Vf = {}, Gf = 0, Wf = 5e3, Hf = /\{([a-zA-Z0-9_]+)\|([^}]*)\}/g, Ff = '12px sans-serif', Zf = {}; Zf.measureText = function (t, e) { var n = s(); return (n.font = e || Ff), n.measureText(t); }; var Uf = { left: 1, right: 1, center: 1 }, Xf = { top: 1, bottom: 1, middle: 1 }, jf = new Zt(), qf = function () {}; (qf.prototype = { constructor: qf, drawRectText: function (t, e) { var n = this.style; (e = n.textRect || e), this.__dirty && Te(n); var i = n.text; if ((null != i && (i += ''), Fe(i, n))) { t.save(); var r = this.transform; n.transformText ? this.setTransform(t) : r && (jf.copy(e), jf.applyTransform(r), (e = jf)), Ce(this, t, i, n, e), t.restore(); } }, }), (Ze.prototype = { constructor: Ze, type: 'displayable', __dirty: !0, invisible: !1, z: 0, z2: 0, zlevel: 0, draggable: !1, dragging: !1, silent: !1, culling: !1, cursor: 'pointer', rectHover: !1, progressive: -1, beforeBrush: function (t) {}, afterBrush: function (t) {}, brush: function (t, e) {}, getBoundingRect: function () {}, contain: function (t, e) { return this.rectContain(t, e); }, traverse: function (t, e) { t.call(e, this); }, rectContain: function (t, e) { var n = this.transformCoordToLocal(t, e); return this.getBoundingRect().contain(n[0], n[1]); }, dirty: function () { (this.__dirty = !0), (this._rect = null), this.__zr && this.__zr.refresh(); }, animateStyle: function (t) { return this.animate('style', t); }, attrKV: function (t, e) { 'style' !== t ? bf.prototype.attrKV.call(this, t, e) : this.style.set(e); }, setStyle: function (t, e) { return this.style.set(t, e), this.dirty(!1), this; }, useStyle: function (t) { return (this.style = new Pf(t, this)), this.dirty(!1), this; }, }), h(Ze, bf), u(Ze, qf), (Ue.prototype = { constructor: Ue, type: 'image', brush: function (t, e) { var n = this.style, i = n.image; n.bind(t, this, e); var r = (this._image = oe(i, this._image, this, this.onload)); if (r && se(r)) { var o = n.x || 0, a = n.y || 0, s = n.width, l = n.height, h = r.width / r.height; if ( (null == s && null != l ? (s = l * h) : null == l && null != s ? (l = s / h) : null == s && null == l && ((s = r.width), (l = r.height)), this.setTransform(t), n.sWidth && n.sHeight) ) { var u = n.sx || 0, c = n.sy || 0; t.drawImage(r, u, c, n.sWidth, n.sHeight, o, a, s, l); } else if (n.sx && n.sy) { var d = s - (u = n.sx), f = l - (c = n.sy); t.drawImage(r, u, c, d, f, o, a, s, l); } else t.drawImage(r, o, a, s, l); this.restoreTransform(t), null != n.text && this.drawRectText(t, this.getBoundingRect()); } }, getBoundingRect: function () { var t = this.style; return ( this._rect || (this._rect = new Zt( t.x || 0, t.y || 0, t.width || 0, t.height || 0 )), this._rect ); }, }), h(Ue, Ze); var Yf = new Zt(0, 0, 0, 0), $f = new Zt(0, 0, 0, 0), Kf = function (t, e, n) { this.type = 'canvas'; var i = !t.nodeName || 'CANVAS' === t.nodeName.toUpperCase(); (this._opts = n = o({}, n || {})), (this.dpr = n.devicePixelRatio || yf), (this._singleCanvas = i), (this.root = t); var r = t.style; r && ((r['-webkit-tap-highlight-color'] = 'transparent'), (r['-webkit-user-select'] = r['user-select'] = r['-webkit-touch-callout'] = 'none'), (t.innerHTML = '')), (this.storage = e); var a = (this._zlevelList = []), s = (this._layers = {}); if (((this._layerConfig = {}), i)) { null != n.width && (t.width = n.width), null != n.height && (t.height = n.height); var l = t.width, h = t.height; (this._width = l), (this._height = h); var u = new Nf(t, this, 1); u.initContext(), (s[0] = u), a.push(0), (this._domRoot = t); } else { (this._width = this._getSize(0)), (this._height = this._getSize(1)); var c = (this._domRoot = Je(this._width, this._height)); t.appendChild(c); } (this._progressiveLayers = []), this._hoverlayer, (this._hoverElements = []); }; Kf.prototype = { constructor: Kf, getType: function () { return 'canvas'; }, isSingleCanvas: function () { return this._singleCanvas; }, getViewportRoot: function () { return this._domRoot; }, getViewportRootOffset: function () { var t = this.getViewportRoot(); if (t) return { offsetLeft: t.offsetLeft || 0, offsetTop: t.offsetTop || 0 }; }, refresh: function (t) { var e = this.storage.getDisplayList(!0), n = this._zlevelList; this._paintList(e, t); for (var i = 0; i < n.length; i++) { var r = n[i], o = this._layers[r]; !o.__builtin__ && o.refresh && o.refresh(); } return ( this.refreshHover(), this._progressiveLayers.length && this._startProgessive(), this ); }, addHover: function (t, e) { if (!t.__hoverMir) { var n = new t.constructor({ style: t.style, shape: t.shape }); (n.__from = t), (t.__hoverMir = n), n.setStyle(e), this._hoverElements.push(n); } }, removeHover: function (t) { var e = t.__hoverMir, n = this._hoverElements, i = l(n, e); i >= 0 && n.splice(i, 1), (t.__hoverMir = null); }, clearHover: function (t) { for (var e = this._hoverElements, n = 0; n < e.length; n++) { var i = e[n].__from; i && (i.__hoverMir = null); } e.length = 0; }, refreshHover: function () { var t = this._hoverElements, e = t.length, n = this._hoverlayer; if ((n && n.clear(), e)) { Qt(t, this.storage.displayableSortFunc), n || (n = this._hoverlayer = this.getLayer(1e5)); var i = {}; n.ctx.save(); for (var r = 0; r < e; ) { var o = t[r], a = o.__from; a && a.__zr ? (r++, a.invisible || ((o.transform = a.transform), (o.invTransform = a.invTransform), (o.__clipPaths = a.__clipPaths), this._doPaintEl(o, n, !0, i))) : (t.splice(r, 1), (a.__hoverMir = null), e--); } n.ctx.restore(); } }, _startProgessive: function () { function t() { n === e._progressiveToken && e.storage && (e._doPaintList(e.storage.getDisplayList()), e._furtherProgressive ? (e._progress++, Bf(t)) : (e._progressiveToken = -1)); } var e = this; if (e._furtherProgressive) { var n = (e._progressiveToken = +new Date()); e._progress++, Bf(t); } }, _clearProgressive: function () { (this._progressiveToken = -1), (this._progress = 0), d(this._progressiveLayers, function (t) { t.__dirty && t.clear(); }); }, _paintList: function (t, e) { null == e && (e = !1), this._updateLayerStatus(t), this._clearProgressive(), this.eachBuiltinLayer(qe), this._doPaintList(t, e), this.eachBuiltinLayer(Ye); }, _doPaintList: function (t, e) { function n(t) { var e = o.dpr || 1; o.save(), (o.globalAlpha = 1), (o.shadowBlur = 0), (i.__dirty = !0), o.setTransform(1, 0, 0, 1, 0, 0), o.drawImage(t.dom, 0, 0, u * e, c * e), o.restore(); } for ( var i, r, o, a, s, l, h = 0, u = this._width, c = this._height, f = this._progress, p = 0, g = t.length; p < g; p++ ) { var v = t[p], m = this._singleCanvas ? 0 : v.zlevel, y = v.__frame; if ( (y < 0 && s && (n(s), (s = null)), r !== m && (o && o.restore(), (a = {}), (r = m), (i = this.getLayer(r)).__builtin__ || _f('ZLevel ' + r + ' has been used by unkown layer ' + i.id), (o = i.ctx).save(), (i.__unusedCount = 0), (i.__dirty || e) && i.clear()), i.__dirty || e) ) { if (y >= 0) { if (!s) { if ( ((s = this._progressiveLayers[Math.min(h++, 4)]).ctx.save(), (s.renderScope = {}), s && s.__progress > s.__maxProgress) ) { p = s.__nextIdxNotProg - 1; continue; } (l = s.__progress), s.__dirty || (f = l), (s.__progress = f + 1); } y === f && this._doPaintEl(v, s, !0, s.renderScope); } else this._doPaintEl(v, i, e, a); v.__dirty = !1; } } s && n(s), o && o.restore(), (this._furtherProgressive = !1), d( this._progressiveLayers, function (t) { t.__maxProgress >= t.__progress && (this._furtherProgressive = !0); }, this ); }, _doPaintEl: function (t, e, n, i) { var r = e.ctx, o = t.transform; if ( (e.__dirty || n) && !t.invisible && 0 !== t.style.opacity && (!o || o[0] || o[3]) && (!t.culling || !$e(t, this._width, this._height)) ) { var a = t.__clipPaths; (i.prevClipLayer !== e || Ke(a, i.prevElClipPaths)) && (i.prevElClipPaths && (i.prevClipLayer.ctx.restore(), (i.prevClipLayer = i.prevElClipPaths = null), (i.prevEl = null)), a && (r.save(), Qe(a, r), (i.prevClipLayer = e), (i.prevElClipPaths = a))), t.beforeBrush && t.beforeBrush(r), t.brush(r, i.prevEl || null), (i.prevEl = t), t.afterBrush && t.afterBrush(r); } }, getLayer: function (t) { if (this._singleCanvas) return this._layers[0]; var e = this._layers[t]; return ( e || (((e = new Nf('zr_' + t, this, this.dpr)).__builtin__ = !0), this._layerConfig[t] && i(e, this._layerConfig[t], !0), this.insertLayer(t, e), e.initContext()), e ); }, insertLayer: function (t, e) { var n = this._layers, i = this._zlevelList, r = i.length, o = null, a = -1, s = this._domRoot; if (n[t]) _f('ZLevel ' + t + ' has been used already'); else if (je(e)) { if (r > 0 && t > i[0]) { for (a = 0; a < r - 1 && !(i[a] < t && i[a + 1] > t); a++); o = n[i[a]]; } if ((i.splice(a + 1, 0, t), (n[t] = e), !e.virtual)) if (o) { var l = o.dom; l.nextSibling ? s.insertBefore(e.dom, l.nextSibling) : s.appendChild(e.dom); } else s.firstChild ? s.insertBefore(e.dom, s.firstChild) : s.appendChild(e.dom); } else _f('Layer of zlevel ' + t + ' is not valid'); }, eachLayer: function (t, e) { var n, i, r = this._zlevelList; for (i = 0; i < r.length; i++) (n = r[i]), t.call(e, this._layers[n], n); }, eachBuiltinLayer: function (t, e) { var n, i, r, o = this._zlevelList; for (r = 0; r < o.length; r++) (i = o[r]), (n = this._layers[i]).__builtin__ && t.call(e, n, i); }, eachOtherLayer: function (t, e) { var n, i, r, o = this._zlevelList; for (r = 0; r < o.length; r++) (i = o[r]), (n = this._layers[i]).__builtin__ || t.call(e, n, i); }, getLayers: function () { return this._layers; }, _updateLayerStatus: function (t) { var e = this._layers, n = this._progressiveLayers, i = {}, r = {}; this.eachBuiltinLayer(function (t, e) { (i[e] = t.elCount), (t.elCount = 0), (t.__dirty = !1); }), d(n, function (t, e) { (r[e] = t.elCount), (t.elCount = 0), (t.__dirty = !1); }); for (var o, a, s = 0, l = 0, h = 0, u = t.length; h < u; h++) { var c = t[h], f = e[this._singleCanvas ? 0 : c.zlevel], p = c.progressive; if ( (f && (f.elCount++, (f.__dirty = f.__dirty || c.__dirty)), p >= 0) ) { a !== p && ((a = p), l++); var g = (c.__frame = l - 1); if (!o) { var v = Math.min(s, 4); (o = n[v]) || (o = n[v] = new Nf('progressive', this, this.dpr)).initContext(), (o.__maxProgress = 0); } (o.__dirty = o.__dirty || c.__dirty), o.elCount++, (o.__maxProgress = Math.max(o.__maxProgress, g)), o.__maxProgress >= o.__progress && (f.__dirty = !0); } else (c.__frame = -1), o && ((o.__nextIdxNotProg = h), s++, (o = null)); } o && (s++, (o.__nextIdxNotProg = h)), this.eachBuiltinLayer(function (t, e) { i[e] !== t.elCount && (t.__dirty = !0); }), (n.length = Math.min(s, 5)), d(n, function (t, e) { r[e] !== t.elCount && (c.__dirty = !0), t.__dirty && (t.__progress = 0); }); }, clear: function () { return this.eachBuiltinLayer(this._clearLayer), this; }, _clearLayer: function (t) { t.clear(); }, configLayer: function (t, e) { if (e) { var n = this._layerConfig; n[t] ? i(n[t], e, !0) : (n[t] = e); var r = this._layers[t]; r && i(r, n[t], !0); } }, 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(l(n, t), 1)); }, resize: function (t, e) { var n = this._domRoot; n.style.display = 'none'; var i = this._opts; if ( (null != t && (i.width = t), null != e && (i.height = e), (t = this._getSize(0)), (e = this._getSize(1)), (n.style.display = ''), this._width != t || e != this._height) ) { (n.style.width = t + 'px'), (n.style.height = e + 'px'); for (var r in this._layers) this._layers.hasOwnProperty(r) && this._layers[r].resize(t, e); d(this._progressiveLayers, function (n) { n.resize(t, e); }), this.refresh(!0); } return (this._width = t), (this._height = e), this; }, clearLayer: function (t) { var e = this._layers[t]; e && e.clear(); }, dispose: function () { (this.root.innerHTML = ''), (this.root = this.storage = this._domRoot = this._layers = null); }, getRenderedCanvas: function (t) { function e(t, e) { var i = a._zlevelList; null == t && (t = -1 / 0); for (var r, o = 0; o < i.length; o++) { var s = i[o], l = a._layers[s]; if (!l.__builtin__ && s > t && s < e) { r = l; break; } } r && r.renderToCanvas && (n.ctx.save(), r.renderToCanvas(n.ctx), n.ctx.restore()); } if (((t = t || {}), this._singleCanvas)) return this._layers[0].dom; var n = new Nf('image', this, t.pixelRatio || this.dpr); n.initContext(), (n.clearColor = t.backgroundColor), n.clear(); for ( var i, r = this.storage.getDisplayList(!0), o = {}, a = this, s = 0; s < r.length; s++ ) { var l = r[s]; l.zlevel !== i && (e(i, l.zlevel), (i = l.zlevel)), this._doPaintEl(l, n, !0, o); } return e(i, 1 / 0), n.dom; }, getWidth: function () { return this._width; }, getHeight: function () { return this._height; }, _getSize: function (t) { var e = this._opts, n = ['width', 'height'][t], i = ['clientWidth', 'clientHeight'][t], r = ['paddingLeft', 'paddingTop'][t], o = ['paddingRight', 'paddingBottom'][t]; if (null != e[n] && 'auto' !== e[n]) return parseFloat(e[n]); var a = this.root, s = document.defaultView.getComputedStyle(a); return ( ((a[i] || Xe(s[n]) || Xe(a.style[n])) - (Xe(s[r]) || 0) - (Xe(s[o]) || 0)) | 0 ); }, pathToImage: function (t, e) { e = e || this.dpr; var n = document.createElement('canvas'), i = n.getContext('2d'), r = t.getBoundingRect(), o = t.style, a = o.shadowBlur, s = o.shadowOffsetX, l = o.shadowOffsetY, h = o.hasStroke() ? o.lineWidth : 0, u = Math.max(h / 2, -s + a), c = Math.max(h / 2, s + a), d = Math.max(h / 2, -l + a), f = Math.max(h / 2, l + a), p = r.width + u + c, g = r.height + d + f; (n.width = p * e), (n.height = g * e), i.scale(e, e), i.clearRect(0, 0, p, g), (i.dpr = e); var v = { position: t.position, rotation: t.rotation, scale: t.scale }; (t.position = [u - r.x, d - r.y]), (t.rotation = 0), (t.scale = [1, 1]), t.updateTransform(), t && t.brush(i); var m = new Ue({ style: { x: 0, y: 0, image: n } }); return ( null != v.position && (m.position = t.position = v.position), null != v.rotation && (m.rotation = t.rotation = v.rotation), null != v.scale && (m.scale = t.scale = v.scale), m ); }, }; var Qf = 'undefined' != typeof window && !!window.addEventListener, Jf = /^(?:mouse|pointer|contextmenu|drag|drop)|click/, tp = Qf ? function (t) { t.preventDefault(), t.stopPropagation(), (t.cancelBubble = !0); } : function (t) { (t.returnValue = !1), (t.cancelBubble = !0); }, ep = function (t) { (t = t || {}), (this.stage = t.stage || {}), (this.onframe = t.onframe || function () {}), (this._clips = []), (this._running = !1), this._time, this._pausedTime, this._pauseStart, (this._paused = !1), Ud.call(this); }; (ep.prototype = { constructor: ep, addClip: function (t) { this._clips.push(t); }, addAnimator: function (t) { t.animation = this; for (var e = t.getClips(), n = 0; n < e.length; n++) this.addClip(e[n]); }, removeClip: function (t) { var e = l(this._clips, t); e >= 0 && this._clips.splice(e, 1); }, removeAnimator: function (t) { for (var e = t.getClips(), n = 0; n < e.length; n++) this.removeClip(e[n]); t.animation = null; }, _update: function () { for ( var t = new Date().getTime() - this._pausedTime, e = t - this._time, n = this._clips, i = n.length, r = [], o = [], a = 0; a < i; a++ ) { var s = n[a], l = s.step(t, e); l && (r.push(l), o.push(s)); } for (a = 0; a < i; ) n[a]._needsRemove ? ((n[a] = n[i - 1]), n.pop(), i--) : a++; i = r.length; for (a = 0; a < i; a++) o[a].fire(r[a]); (this._time = t), this.onframe(e), this.trigger('frame', e), this.stage.update && this.stage.update(); }, _startLoop: function () { function t() { e._running && (Bf(t), !e._paused && e._update()); } var e = this; (this._running = !0), Bf(t); }, start: function () { (this._time = new Date().getTime()), (this._pausedTime = 0), this._startLoop(); }, stop: function () { this._running = !1; }, pause: function () { this._paused || ((this._pauseStart = new Date().getTime()), (this._paused = !0)); }, resume: function () { this._paused && ((this._pausedTime += new Date().getTime() - this._pauseStart), (this._paused = !1)); }, clear: function () { this._clips = []; }, animate: function (t, e) { var n = new vf(t, (e = e || {}).loop, e.getter, e.setter); return this.addAnimator(n), n; }, }), u(ep, Ud); var np = function () { this._track = []; }; np.prototype = { constructor: np, recognize: function (t, e, n) { return this._doTrack(t, e, n), this._recognize(t); }, clear: function () { return (this._track.length = 0), this; }, _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 = en(n, s, {}); r.points.push([l.zrX, l.zrY]), r.touches.push(s); } this._track.push(r); } }, _recognize: function (t) { for (var e in ip) if (ip.hasOwnProperty(e)) { var n = ip[e](this._track, t); if (n) return n; } }, }; var ip = { pinch: function (t, e) { var n = t.length; if (n) { var i = (t[n - 1] || {}).points, r = (t[n - 2] || {}).points || i; if (r && r.length > 1 && i && i.length > 1) { var o = ln(i) / ln(r); !isFinite(o) && (o = 1), (e.pinchScale = o); var a = hn(i); return ( (e.pinchX = a[0]), (e.pinchY = a[1]), { type: 'pinch', target: t[0].target, event: e } ); } } }, }, rp = [ 'click', 'dblclick', 'mousewheel', 'mouseout', 'mouseup', 'mousedown', 'mousemove', 'contextmenu', ], op = ['touchstart', 'touchend', 'touchmove'], ap = { pointerdown: 1, pointerup: 1, pointermove: 1, pointerout: 1 }, sp = f(rp, function (t) { var e = t.replace('mouse', 'pointer'); return ap[e] ? e : t; }), lp = { mousemove: function (t) { (t = rn(this.dom, t)), this.trigger('mousemove', t); }, mouseout: function (t) { var e = (t = rn(this.dom, t)).toElement || t.relatedTarget; if (e != this.dom) for (; e && 9 != e.nodeType; ) { if (e === this.dom) return; e = e.parentNode; } this.trigger('mouseout', t); }, touchstart: function (t) { ((t = rn(this.dom, t)).zrByTouch = !0), (this._lastTouchMoment = new Date()), cn(this, t, 'start'), lp.mousemove.call(this, t), lp.mousedown.call(this, t), dn(this); }, touchmove: function (t) { ((t = rn(this.dom, t)).zrByTouch = !0), cn(this, t, 'change'), lp.mousemove.call(this, t), dn(this); }, touchend: function (t) { ((t = rn(this.dom, t)).zrByTouch = !0), cn(this, t, 'end'), lp.mouseup.call(this, t), +new Date() - this._lastTouchMoment < 300 && lp.click.call(this, t), dn(this); }, pointerdown: function (t) { lp.mousedown.call(this, t); }, pointermove: function (t) { fn(t) || lp.mousemove.call(this, t); }, pointerup: function (t) { lp.mouseup.call(this, t); }, pointerout: function (t) { fn(t) || lp.mouseout.call(this, t); }, }; d( ['click', 'mousedown', 'mouseup', 'mousewheel', 'dblclick', 'contextmenu'], function (t) { lp[t] = function (e) { (e = rn(this.dom, e)), this.trigger(t, e); }; } ); var hp = gn.prototype; (hp.dispose = function () { for (var t = rp.concat(op), e = 0; e < t.length; e++) { var n = t[e]; an(this.dom, un(n), this._handlers[n]); } }), (hp.setCursor = function (t) { this.dom.style.cursor = t || 'default'; }), u(gn, Ud); var up = !Md.canvasSupported, cp = { canvas: Kf }, dp = {}, fp = function (t, e, n) { (n = n || {}), (this.dom = e), (this.id = t); var i = this, r = new kf(), o = n.renderer; if (up) { if (!cp.vml) throw new Error( "You need to require 'zrender/vml/vml' to support IE8" ); o = 'vml'; } else (o && cp[o]) || (o = 'canvas'); var a = new cp[o](e, r, n); (this.storage = r), (this.painter = a); var s = Md.node ? null : new gn(a.getViewportRoot()); (this.handler = new qd(r, a, s, a.root)), (this.animation = new ep({ stage: { update: v(this.flush, this) } })), this.animation.start(), this._needsRefresh; var l = r.delFromStorage, h = r.addToStorage; (r.delFromStorage = function (t) { l.call(r, t), t && t.removeSelfFromZr(i); }), (r.addToStorage = function (t) { h.call(r, t), t.addSelfToZr(i); }); }; fp.prototype = { constructor: fp, getId: function () { return this.id; }, add: function (t) { this.storage.addRoot(t), (this._needsRefresh = !0); }, remove: function (t) { this.storage.delRoot(t), (this._needsRefresh = !0); }, configLayer: function (t, e) { this.painter.configLayer(t, e), (this._needsRefresh = !0); }, refreshImmediately: function () { (this._needsRefresh = !1), this.painter.refresh(), (this._needsRefresh = !1); }, refresh: function () { this._needsRefresh = !0; }, flush: function () { this._needsRefresh && this.refreshImmediately(), this._needsRefreshHover && this.refreshHoverImmediately(); }, addHover: function (t, e) { this.painter.addHover && (this.painter.addHover(t, e), this.refreshHover()); }, removeHover: function (t) { this.painter.removeHover && (this.painter.removeHover(t), this.refreshHover()); }, clearHover: function () { this.painter.clearHover && (this.painter.clearHover(), this.refreshHover()); }, refreshHover: function () { this._needsRefreshHover = !0; }, refreshHoverImmediately: function () { (this._needsRefreshHover = !1), this.painter.refreshHover && this.painter.refreshHover(); }, resize: function (t) { (t = t || {}), this.painter.resize(t.width, t.height), this.handler.resize(); }, clearAnimation: function () { this.animation.clear(); }, getWidth: function () { return this.painter.getWidth(); }, getHeight: function () { return this.painter.getHeight(); }, pathToImage: function (t, e) { return this.painter.pathToImage(t, e); }, setCursorStyle: function (t) { this.handler.setCursorStyle(t); }, findHover: function (t, e) { return this.handler.findHover(t, e); }, on: function (t, e, n) { this.handler.on(t, e, n); }, off: function (t, e) { this.handler.off(t, e); }, trigger: function (t, e) { this.handler.trigger(t, e); }, clear: function () { this.storage.delRoot(), this.painter.clear(); }, dispose: function () { this.animation.stop(), this.clear(), this.storage.dispose(), this.painter.dispose(), this.handler.dispose(), (this.animation = this.storage = this.painter = this.handler = null), yn(this.id); }, }; var pp = (Object.freeze || Object)({ version: '3.7.4', init: vn, dispose: function (t) { if (t) t.dispose(); else { for (var e in dp) dp.hasOwnProperty(e) && dp[e].dispose(); dp = {}; } return this; }, getInstance: function (t) { return dp[t]; }, registerPainter: mn, }), gp = 1e-4, vp = /^(?:(\d{4})(?:[-\/](\d{1,2})(?:[-\/](\d{1,2})(?:[T ](\d{1,2})(?::(\d\d)(?::(\d\d)(?:[.,](\d+))?)?)?(Z|[\+\-]\d\d:?\d\d)?)?)?)?)?$/, mp = (Object.freeze || Object)({ linearMap: _n, parsePercent: wn, round: bn, asc: Mn, getPrecision: Sn, getPrecisionSafe: In, getPixelPrecision: Tn, getPercentWithPrecision: An, MAX_SAFE_INTEGER: 9007199254740991, remRadian: Cn, isRadianAroundZero: kn, parseDate: Dn, quantity: Pn, nice: On, reformIntervals: function (t) { function e(t, n, i) { return ( t.interval[i] < n.interval[i] || (t.interval[i] === n.interval[i] && (t.close[i] - n.close[i] == (i ? -1 : 1) || (!i && e(t, n, 1)))) ); } t.sort(function (t, n) { return e(t, n, 0) ? -1 : 1; }); for (var n = -1 / 0, i = 1, r = 0; r < t.length; ) { for (var o = t[r].interval, a = t[r].close, s = 0; s < 2; s++) o[s] <= n && ((o[s] = n), (a[s] = s ? 1 : 1 - i)), (n = o[s]), (i = a[s]); o[0] === o[1] && a[0] * a[1] != 1 ? t.splice(r, 1) : r++; } return t; }, isNumeric: function (t) { return t - parseFloat(t) >= 0; }, }), yp = k, xp = ['a', 'b', 'c', 'd', 'e', 'f', 'g'], _p = function (t, e) { return '{' + t + (null == e ? '' : e) + '}'; }, wp = function (t) { return t < 10 ? '0' + t : t; }, bp = ge, Mp = he, Sp = (Object.freeze || Object)({ addCommas: zn, toCamelCase: En, normalizeCssArray: yp, encodeHTML: Nn, formatTpl: Bn, formatTplSimple: function (t, e, n) { return ( d(e, function (e, i) { t = t.replace('{' + i + '}', n ? Nn(e) : e); }), t ); }, getTooltipMarker: Rn, formatTime: Vn, capitalFirst: Gn, truncateText: bp, getTextRect: Mp, }), Ip = '.', Tp = '___EC__COMPONENT__CONTAINER___', Ap = '\0ec_\0', Cp = function (t) { for (var e = 0; e < t.length; e++) t[e][1] || (t[e][1] = t[e][0]); return function (e, n, i) { for (var r = {}, o = 0; o < t.length; o++) { var a = t[o][1]; if (!((n && l(n, a) >= 0) || (i && l(i, a) < 0))) { var s = e.getShallow(a); null != s && (r[t[o][0]] = s); } } return r; }; }, kp = Cp([ ['lineWidth', 'width'], ['stroke', 'color'], ['opacity'], ['shadowBlur'], ['shadowOffsetX'], ['shadowOffsetY'], ['shadowColor'], ]), Dp = { getLineStyle: function (t) { var e = kp(this, t), n = this.getLineDash(e.lineWidth); return n && (e.lineDash = n), e; }, getLineDash: function (t) { null == t && (t = 1); var e = this.get('type'), n = Math.max(t, 2), i = 4 * t; return 'solid' === e || null == e ? null : 'dashed' === e ? [i, i] : [n, n]; }, }, Pp = Cp([ ['fill', 'color'], ['shadowBlur'], ['shadowOffsetX'], ['shadowOffsetY'], ['opacity'], ['shadowColor'], ]), Lp = { getAreaStyle: function (t, e) { return Pp(this, t, e); }, }, Op = Math.pow, zp = Math.sqrt, Ep = 1e-8, Np = 1e-4, Bp = zp(3), Rp = 1 / 3, Vp = N(), Gp = N(), Wp = N(), Hp = Math.min, Fp = Math.max, Zp = Math.sin, Up = Math.cos, Xp = 2 * Math.PI, jp = N(), qp = N(), Yp = N(), $p = [], Kp = [], Qp = { M: 1, L: 2, C: 3, Q: 4, A: 5, Z: 6, R: 7 }, Jp = [], tg = [], eg = [], ng = [], ig = Math.min, rg = Math.max, og = Math.cos, ag = Math.sin, sg = Math.sqrt, lg = Math.abs, hg = 'undefined' != typeof Float32Array, ug = function (t) { (this._saveData = !t), this._saveData && (this.data = []), (this._ctx = null); }; (ug.prototype = { constructor: ug, _xi: 0, _yi: 0, _x0: 0, _y0: 0, _ux: 0, _uy: 0, _len: 0, _lineDash: null, _dashOffset: 0, _dashIdx: 0, _dashSum: 0, setScale: function (t, e) { (this._ux = lg(1 / yf / t) || 0), (this._uy = lg(1 / yf / e) || 0); }, getContext: function () { return this._ctx; }, beginPath: function (t) { return ( (this._ctx = t), t && t.beginPath(), t && (this.dpr = t.dpr), this._saveData && (this._len = 0), this._lineDash && ((this._lineDash = null), (this._dashOffset = 0)), this ); }, moveTo: function (t, e) { return ( this.addData(Qp.M, t, e), this._ctx && this._ctx.moveTo(t, e), (this._x0 = t), (this._y0 = e), (this._xi = t), (this._yi = e), this ); }, lineTo: function (t, e) { var n = lg(t - this._xi) > this._ux || lg(e - this._yi) > this._uy || this._len < 5; return ( this.addData(Qp.L, t, e), this._ctx && n && (this._needsDash() ? this._dashedLineTo(t, e) : this._ctx.lineTo(t, e)), n && ((this._xi = t), (this._yi = e)), this ); }, bezierCurveTo: function (t, e, n, i, r, o) { return ( this.addData(Qp.C, t, e, n, i, r, o), this._ctx && (this._needsDash() ? this._dashedBezierTo(t, e, n, i, r, o) : this._ctx.bezierCurveTo(t, e, n, i, r, o)), (this._xi = r), (this._yi = o), this ); }, quadraticCurveTo: function (t, e, n, i) { return ( this.addData(Qp.Q, t, e, n, i), this._ctx && (this._needsDash() ? this._dashedQuadraticTo(t, e, n, i) : this._ctx.quadraticCurveTo(t, e, n, i)), (this._xi = n), (this._yi = i), this ); }, arc: function (t, e, n, i, r, o) { return ( this.addData(Qp.A, t, e, n, n, i, r - i, 0, o ? 0 : 1), this._ctx && this._ctx.arc(t, e, n, i, r, o), (this._xi = og(r) * n + t), (this._yi = ag(r) * n + t), this ); }, arcTo: function (t, e, n, i, r) { return this._ctx && this._ctx.arcTo(t, e, n, i, r), this; }, rect: function (t, e, n, i) { return ( this._ctx && this._ctx.rect(t, e, n, i), this.addData(Qp.R, t, e, n, i), this ); }, closePath: function () { this.addData(Qp.Z); var t = this._ctx, e = this._x0, n = this._y0; return ( t && (this._needsDash() && this._dashedLineTo(e, n), t.closePath()), (this._xi = e), (this._yi = n), this ); }, fill: function (t) { t && t.fill(), this.toStatic(); }, stroke: function (t) { t && t.stroke(), this.toStatic(); }, setLineDash: function (t) { if (t instanceof Array) { (this._lineDash = t), (this._dashIdx = 0); for (var e = 0, n = 0; n < t.length; n++) e += t[n]; this._dashSum = e; } return this; }, setLineDashOffset: function (t) { return (this._dashOffset = t), this; }, len: function () { return this._len; }, setData: function (t) { var e = t.length; (this.data && this.data.length == e) || !hg || (this.data = new Float32Array(e)); for (var n = 0; n < e; n++) this.data[n] = t[n]; this._len = e; }, 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(); hg && 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; }, addData: function (t) { if (this._saveData) { var e = this.data; this._len + arguments.length > e.length && (this._expandData(), (e = this.data)); for (var n = 0; n < arguments.length; n++) e[this._len++] = arguments[n]; this._prevCmd = t; } }, _expandData: function () { if (!(this.data instanceof Array)) { for (var t = [], e = 0; e < this._len; e++) t[e] = this.data[e]; this.data = t; } }, _needsDash: function () { return this._lineDash; }, _dashedLineTo: function (t, e) { var n, i, r = this._dashSum, o = this._dashOffset, a = this._lineDash, s = this._ctx, l = this._xi, h = this._yi, u = t - l, c = e - h, d = sg(u * u + c * c), f = l, p = h, g = a.length; for ( u /= d, c /= d, o < 0 && (o = r + o), f -= (o %= r) * u, p -= o * c; (u > 0 && f <= t) || (u < 0 && f >= t) || (0 == u && ((c > 0 && p <= e) || (c < 0 && p >= e))); ) (f += u * (n = a[(i = this._dashIdx)])), (p += c * n), (this._dashIdx = (i + 1) % g), (u > 0 && f < l) || (u < 0 && f > l) || (c > 0 && p < h) || (c < 0 && p > h) || s[i % 2 ? 'moveTo' : 'lineTo']( u >= 0 ? ig(f, t) : rg(f, t), c >= 0 ? ig(p, e) : rg(p, e) ); (u = f - t), (c = p - e), (this._dashOffset = -sg(u * u + c * c)); }, _dashedBezierTo: function (t, e, n, i, r, o) { var a, s, l, h, u, c = this._dashSum, d = this._dashOffset, f = this._lineDash, p = this._ctx, g = this._xi, v = this._yi, m = Qn, y = 0, x = this._dashIdx, _ = f.length, w = 0; for (d < 0 && (d = c + d), d %= c, a = 0; a < 1; a += 0.1) (s = m(g, t, n, r, a + 0.1) - m(g, t, n, r, a)), (l = m(v, e, i, o, a + 0.1) - m(v, e, i, o, a)), (y += sg(s * s + l * l)); for (; x < _ && !((w += f[x]) > d); x++); for (a = (w - d) / y; a <= 1; ) (h = m(g, t, n, r, a)), (u = m(v, e, i, o, a)), x % 2 ? p.moveTo(h, u) : p.lineTo(h, u), (a += f[x] / y), (x = (x + 1) % _); x % 2 != 0 && p.lineTo(r, o), (s = r - h), (l = o - u), (this._dashOffset = -sg(s * s + l * l)); }, _dashedQuadraticTo: function (t, e, n, i) { var r = n, o = i; (n = (n + 2 * t) / 3), (i = (i + 2 * e) / 3), (t = (this._xi + 2 * t) / 3), (e = (this._yi + 2 * e) / 3), this._dashedBezierTo(t, e, n, i, r, o); }, toStatic: function () { var t = this.data; t instanceof Array && ((t.length = this._len), hg && (this.data = new Float32Array(t))); }, getBoundingRect: function () { (Jp[0] = Jp[1] = eg[0] = eg[1] = Number.MAX_VALUE), (tg[0] = tg[1] = ng[0] = ng[1] = -Number.MAX_VALUE); for ( var t = this.data, e = 0, n = 0, i = 0, r = 0, o = 0; o < t.length; ) { var a = t[o++]; switch ((1 == o && ((i = e = t[o]), (r = n = t[o + 1])), a)) { case Qp.M: (e = i = t[o++]), (n = r = t[o++]), (eg[0] = i), (eg[1] = r), (ng[0] = i), (ng[1] = r); break; case Qp.L: ci(e, n, t[o], t[o + 1], eg, ng), (e = t[o++]), (n = t[o++]); break; case Qp.C: di(e, n, t[o++], t[o++], t[o++], t[o++], t[o], t[o + 1], eg, ng), (e = t[o++]), (n = t[o++]); break; case Qp.Q: fi(e, n, t[o++], t[o++], t[o], t[o + 1], eg, ng), (e = t[o++]), (n = t[o++]); break; case Qp.A: var s = t[o++], l = t[o++], h = t[o++], u = t[o++], c = t[o++], d = t[o++] + c, f = (t[o++], 1 - t[o++]); 1 == o && ((i = og(c) * h + s), (r = ag(c) * u + l)), pi(s, l, h, u, c, d, f, eg, ng), (e = og(d) * h + s), (n = ag(d) * u + l); break; case Qp.R: ci( (i = e = t[o++]), (r = n = t[o++]), i + t[o++], r + t[o++], eg, ng ); break; case Qp.Z: (e = i), (n = r); } Y(Jp, Jp, eg), $(tg, tg, ng); } return ( 0 === o && (Jp[0] = Jp[1] = tg[0] = tg[1] = 0), new Zt(Jp[0], Jp[1], tg[0] - Jp[0], tg[1] - Jp[1]) ); }, rebuildPath: function (t) { for ( var e, n, i, r, o, a, s = this.data, l = this._ux, h = this._uy, u = this._len, c = 0; c < u; ) { var d = s[c++]; switch ((1 == c && ((e = i = s[c]), (n = r = s[c + 1])), d)) { case Qp.M: (e = i = s[c++]), (n = r = s[c++]), t.moveTo(i, r); break; case Qp.L: (o = s[c++]), (a = s[c++]), (lg(o - i) > l || lg(a - r) > h || c === u - 1) && (t.lineTo(o, a), (i = o), (r = a)); break; case Qp.C: t.bezierCurveTo(s[c++], s[c++], s[c++], s[c++], s[c++], s[c++]), (i = s[c - 2]), (r = s[c - 1]); break; case Qp.Q: t.quadraticCurveTo(s[c++], s[c++], s[c++], s[c++]), (i = s[c - 2]), (r = s[c - 1]); break; case Qp.A: var f = s[c++], p = s[c++], g = s[c++], v = s[c++], m = s[c++], y = s[c++], x = s[c++], _ = s[c++], w = g > v ? g : v, b = g > v ? 1 : g / v, M = g > v ? v / g : 1, S = m + y; Math.abs(g - v) > 0.001 ? (t.translate(f, p), t.rotate(x), t.scale(b, M), t.arc(0, 0, w, m, S, 1 - _), t.scale(1 / b, 1 / M), t.rotate(-x), t.translate(-f, -p)) : t.arc(f, p, w, m, S, 1 - _), 1 == c && ((e = og(m) * g + f), (n = ag(m) * v + p)), (i = og(S) * g + f), (r = ag(S) * v + p); break; case Qp.R: (e = i = s[c]), (n = r = s[c + 1]), t.rect(s[c++], s[c++], s[c++], s[c++]); break; case Qp.Z: t.closePath(), (i = e), (r = n); } } }, }), (ug.CMD = Qp); var cg = 2 * Math.PI, dg = 2 * Math.PI, fg = ug.CMD, pg = 2 * Math.PI, gg = 1e-4, vg = [-1, -1, -1], mg = [-1, -1], yg = Ef.prototype.getCanvasPattern, xg = Math.abs, _g = new ug(!0); (ki.prototype = { constructor: ki, type: 'path', __dirtyPath: !0, strokeContainThreshold: 5, brush: function (t, e) { var n = this.style, i = this.path || _g, r = n.hasStroke(), o = n.hasFill(), a = n.fill, s = n.stroke, l = o && !!a.colorStops, h = r && !!s.colorStops, u = o && !!a.image, c = r && !!s.image; if ((n.bind(t, this, e), this.setTransform(t), this.__dirty)) { var d; l && ((d = d || this.getBoundingRect()), (this._fillGradient = n.getGradient(t, a, d))), h && ((d = d || this.getBoundingRect()), (this._strokeGradient = n.getGradient(t, s, d))); } l ? (t.fillStyle = this._fillGradient) : u && (t.fillStyle = yg.call(a, t)), h ? (t.strokeStyle = this._strokeGradient) : c && (t.strokeStyle = yg.call(s, t)); var f = n.lineDash, p = n.lineDashOffset, g = !!t.setLineDash, v = this.getGlobalScale(); i.setScale(v[0], v[1]), this.__dirtyPath || (f && !g && r) ? (i.beginPath(t), f && !g && (i.setLineDash(f), i.setLineDashOffset(p)), this.buildPath(i, this.shape, !1), this.path && (this.__dirtyPath = !1)) : (t.beginPath(), this.path.rebuildPath(t)), o && i.fill(t), f && g && (t.setLineDash(f), (t.lineDashOffset = p)), r && i.stroke(t), f && g && t.setLineDash([]), this.restoreTransform(t), null != n.text && this.drawRectText(t, this.getBoundingRect()); }, buildPath: function (t, e, n) {}, createPathProxy: function () { this.path = new ug(); }, getBoundingRect: function () { var t = this._rect, e = this.style, n = !t; if (n) { var i = this.path; i || (i = this.path = new ug()), this.__dirtyPath && (i.beginPath(), this.buildPath(i, this.shape, !1)), (t = i.getBoundingRect()); } if (((this._rect = t), e.hasStroke())) { var r = this._rectWithStroke || (this._rectWithStroke = t.clone()); if (this.__dirty || n) { r.copy(t); var o = e.lineWidth, a = e.strokeNoScale ? this.getLineScale() : 1; e.hasFill() || (o = Math.max(o, this.strokeContainThreshold || 4)), a > 1e-10 && ((r.width += o / a), (r.height += o / a), (r.x -= o / a / 2), (r.y -= o / a / 2)); } return r; } return t; }, 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.data; if (r.hasStroke()) { var a = r.lineWidth, s = r.strokeNoScale ? this.getLineScale() : 1; if ( s > 1e-10 && (r.hasFill() || (a = Math.max(a, this.strokeContainThreshold)), Ci(o, a / s, t, e)) ) return !0; } if (r.hasFill()) return Ai(o, t, e); } return !1; }, dirty: function (t) { null == t && (t = !0), t && ((this.__dirtyPath = t), (this._rect = null)), (this.__dirty = !0), this.__zr && this.__zr.refresh(), this.__clipTarget && this.__clipTarget.dirty(); }, animateShape: function (t) { return this.animate('shape', t); }, attrKV: function (t, e) { 'shape' === t ? (this.setShape(e), (this.__dirtyPath = !0), (this._rect = null)) : Ze.prototype.attrKV.call(this, t, e); }, setShape: function (t, e) { var n = this.shape; if (n) { if (w(t)) for (var i in t) t.hasOwnProperty(i) && (n[i] = t[i]); else n[t] = e; this.dirty(!0); } return this; }, getLineScale: function () { var t = this.transform; return t && xg(t[0] - 1) > 1e-10 && xg(t[3] - 1) > 1e-10 ? Math.sqrt(xg(t[0] * t[3] - t[2] * t[1])) : 1; }, }), (ki.extend = function (t) { var e = function (e) { ki.call(this, e), t.style && this.style.extendFrom(t.style, !1); var n = t.shape; if (n) { this.shape = this.shape || {}; var i = this.shape; for (var r in n) !i.hasOwnProperty(r) && n.hasOwnProperty(r) && (i[r] = n[r]); } t.init && t.init.call(this, e); }; h(e, ki); for (var n in t) 'style' !== n && 'shape' !== n && (e.prototype[n] = t[n]); return e; }), h(ki, Ze); var wg = ug.CMD, bg = [[], [], []], Mg = Math.sqrt, Sg = Math.atan2, Ig = function (t, e) { var n, i, r, o, a, s, l = t.data, h = wg.M, u = wg.C, c = wg.L, d = wg.R, f = wg.A, p = wg.Q; for (r = 0, o = 0; r < l.length; ) { switch (((n = l[r++]), (o = r), (i = 0), n)) { case h: case c: i = 1; break; case u: i = 3; break; case p: i = 2; break; case f: var g = e[4], v = e[5], m = Mg(e[0] * e[0] + e[1] * e[1]), y = Mg(e[2] * e[2] + e[3] * e[3]), x = Sg(-e[1] / y, e[0] / m); (l[r] *= m), (l[r++] += g), (l[r] *= y), (l[r++] += v), (l[r++] *= m), (l[r++] *= y), (l[r++] += x), (l[r++] += x), (o = r += 2); break; case d: (s[0] = l[r++]), (s[1] = l[r++]), q(s, s, e), (l[o++] = s[0]), (l[o++] = s[1]), (s[0] += l[r++]), (s[1] += l[r++]), q(s, s, e), (l[o++] = s[0]), (l[o++] = s[1]); } for (a = 0; a < i; a++) ((s = bg[a])[0] = l[r++]), (s[1] = l[r++]), q(s, s, e), (l[o++] = s[0]), (l[o++] = s[1]); } }, Tg = [ 'm', 'M', 'l', 'L', 'v', 'V', 'h', 'H', 'z', 'Z', 'c', 'C', 'q', 'Q', 't', 'T', 's', 'S', 'a', 'A', ], Ag = Math.sqrt, Cg = Math.sin, kg = Math.cos, Dg = Math.PI, Pg = function (t) { return Math.sqrt(t[0] * t[0] + t[1] * t[1]); }, Lg = function (t, e) { return (t[0] * e[0] + t[1] * e[1]) / (Pg(t) * Pg(e)); }, Og = function (t, e) { return (t[0] * e[1] < t[1] * e[0] ? -1 : 1) * Math.acos(Lg(t, e)); }, zg = function (t) { Ze.call(this, t); }; (zg.prototype = { constructor: zg, type: 'text', brush: function (t, e) { var n = this.style; this.__dirty && Te(n), (n.fill = n.stroke = n.shadowBlur = n.shadowColor = n.shadowOffsetX = n.shadowOffsetY = null); var i = n.text; null != i && (i += ''), n.bind(t, this, e), Fe(i, n) && (this.setTransform(t), Ce(this, t, i, n), this.restoreTransform(t)); }, getBoundingRect: function () { var t = this.style; if ((this.__dirty && Te(t), !this._rect)) { var e = t.text; null != e ? (e += '') : (e = ''); var n = he( t.text + '', t.font, t.textAlign, t.textVerticalAlign, t.textPadding, t.rich ); if ( ((n.x += t.x || 0), (n.y += t.y || 0), Ve(t.textStroke, t.textStrokeWidth)) ) { var i = t.textStrokeWidth; (n.x -= i / 2), (n.y -= i / 2), (n.width += i), (n.height += i); } this._rect = n; } return this._rect; }, }), h(zg, Ze); var Eg = ki.extend({ type: 'circle', shape: { cx: 0, cy: 0, r: 0 }, buildPath: function (t, e, n) { n && t.moveTo(e.cx + e.r, e.cy), t.arc(e.cx, e.cy, e.r, 0, 2 * Math.PI, !0); }, }), Ng = [ ['shadowBlur', 0], ['shadowColor', '#000'], ['shadowOffsetX', 0], ['shadowOffsetY', 0], ], Bg = function (t) { return Md.browser.ie && Md.browser.version >= 11 ? function () { var e, n = this.__clipPaths, i = this.style; if (n) for (var r = 0; r < n.length; r++) { var o = n[r], a = o && o.shape, s = o && o.type; if ( a && (('sector' === s && a.startAngle === a.endAngle) || ('rect' === s && (!a.width || !a.height))) ) { for (l = 0; l < Ng.length; l++) (Ng[l][2] = i[Ng[l][0]]), (i[Ng[l][0]] = Ng[l][1]); e = !0; break; } } if ((t.apply(this, arguments), e)) for (var l = 0; l < Ng.length; l++) i[Ng[l][0]] = Ng[l][2]; } : t; }, Rg = ki.extend({ type: 'sector', shape: { cx: 0, cy: 0, r0: 0, r: 0, startAngle: 0, endAngle: 2 * Math.PI, clockwise: !0, }, brush: Bg(ki.prototype.brush), 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 = e.startAngle, s = e.endAngle, l = e.clockwise, h = Math.cos(a), u = Math.sin(a); t.moveTo(h * r + n, u * r + i), t.lineTo(h * o + n, u * o + i), t.arc(n, i, o, a, s, !l), t.lineTo(Math.cos(s) * r + n, Math.sin(s) * r + i), 0 !== r && t.arc(n, i, r, s, a, l), t.closePath(); }, }), Vg = ki.extend({ type: 'ring', shape: { cx: 0, cy: 0, r: 0, r0: 0 }, 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); }, }), Gg = function (t, e) { for (var n = t.length, i = [], r = 0, o = 1; o < n; o++) r += X(t[o - 1], t[o]); var a = r / 2; a = a < n ? n : a; for (o = 0; o < a; o++) { var s, l, h, u = (o / (a - 1)) * (e ? n : n - 1), c = Math.floor(u), d = u - c, f = t[c % n]; e ? ((s = t[(c - 1 + n) % n]), (l = t[(c + 1) % n]), (h = t[(c + 2) % n])) : ((s = t[0 === c ? c : c - 1]), (l = t[c > n - 2 ? n - 1 : c + 1]), (h = t[c > n - 3 ? n - 1 : c + 2])); var p = d * d, g = d * p; i.push([ Ei(s[0], f[0], l[0], h[0], d, p, g), Ei(s[1], f[1], l[1], h[1], d, p, g), ]); } return i; }, Wg = function (t, e, n, i) { var r, o, a, s, l = [], h = [], u = [], c = []; if (i) { (a = [1 / 0, 1 / 0]), (s = [-1 / 0, -1 / 0]); for (var d = 0, f = t.length; d < f; d++) Y(a, a, t[d]), $(s, s, t[d]); Y(a, a, i[0]), $(s, s, i[1]); } for (var d = 0, f = t.length; d < f; d++) { var p = t[d]; if (n) (r = t[d ? d - 1 : f - 1]), (o = t[(d + 1) % f]); else { if (0 === d || d === f - 1) { l.push(R(t[d])); continue; } (r = t[d - 1]), (o = t[d + 1]); } W(h, o, r), Z(h, h, e); var g = X(p, r), v = X(p, o), m = g + v; 0 !== m && ((g /= m), (v /= m)), Z(u, h, -g), Z(c, h, v); var y = V([], p, u), x = V([], p, c); i && ($(y, y, a), Y(y, y, s), $(x, x, a), Y(x, x, s)), l.push(y), l.push(x); } return n && l.push(l.shift()), l; }, Hg = ki.extend({ type: 'polygon', shape: { points: null, smooth: !1, smoothConstraint: null }, buildPath: function (t, e) { Ni(t, e, !0); }, }), Fg = ki.extend({ type: 'polyline', shape: { points: null, smooth: !1, smoothConstraint: null }, style: { stroke: '#000', fill: null }, buildPath: function (t, e) { Ni(t, e, !1); }, }), Zg = ki.extend({ type: 'rect', shape: { r: 0, x: 0, y: 0, width: 0, height: 0 }, buildPath: function (t, e) { var n = e.x, i = e.y, r = e.width, o = e.height; e.r ? Ie(t, e) : t.rect(n, i, r, o), t.closePath(); }, }), Ug = ki.extend({ type: 'line', shape: { x1: 0, y1: 0, x2: 0, y2: 0, percent: 1 }, style: { stroke: '#000', fill: null }, buildPath: function (t, e) { var n = e.x1, i = e.y1, r = e.x2, o = e.y2, a = e.percent; 0 !== a && (t.moveTo(n, i), a < 1 && ((r = n * (1 - a) + r * a), (o = i * (1 - a) + o * a)), t.lineTo(r, o)); }, pointAt: function (t) { var e = this.shape; return [e.x1 * (1 - t) + e.x2 * t, e.y1 * (1 - t) + e.y2 * t]; }, }), Xg = [], jg = ki.extend({ type: 'bezier-curve', shape: { x1: 0, y1: 0, x2: 0, y2: 0, cpx1: 0, cpy1: 0, percent: 1 }, style: { stroke: '#000', fill: null }, 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, h = e.cpy2, u = e.percent; 0 !== u && (t.moveTo(n, i), null == l || null == h ? (u < 1 && (li(n, a, r, u, Xg), (a = Xg[1]), (r = Xg[2]), li(i, s, o, u, Xg), (s = Xg[1]), (o = Xg[2])), t.quadraticCurveTo(a, s, r, o)) : (u < 1 && (ni(n, a, l, r, u, Xg), (a = Xg[1]), (l = Xg[2]), (r = Xg[3]), ni(i, s, h, o, u, Xg), (s = Xg[1]), (h = Xg[2]), (o = Xg[3])), t.bezierCurveTo(a, s, l, h, r, o))); }, pointAt: function (t) { return Bi(this.shape, t, !1); }, tangentAt: function (t) { var e = Bi(this.shape, t, !0); return U(e, e); }, }), qg = ki.extend({ type: 'arc', shape: { cx: 0, cy: 0, r: 0, startAngle: 0, endAngle: 2 * Math.PI, clockwise: !0, }, style: { stroke: '#000', fill: null }, 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), h = Math.sin(o); t.moveTo(l * r + n, h * r + i), t.arc(n, i, r, o, a, !s); }, }), Yg = ki.extend({ type: 'compound', shape: { paths: null }, _updatePathDirty: function () { for ( var t = this.__dirtyPath, e = this.shape.paths, n = 0; n < e.length; n++ ) t = t || e[n].__dirtyPath; (this.__dirtyPath = t), (this.__dirty = this.__dirty || t); }, 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]); }, buildPath: function (t, e) { for (var n = e.paths || [], i = 0; i < n.length; i++) n[i].buildPath(t, n[i].shape, !0); }, afterBrush: function () { for (var t = this.shape.paths || [], e = 0; e < t.length; e++) t[e].__dirtyPath = !1; }, getBoundingRect: function () { return this._updatePathDirty(), ki.prototype.getBoundingRect.call(this); }, }), $g = function (t) { this.colorStops = t || []; }; $g.prototype = { constructor: $g, addColorStop: function (t, e) { this.colorStops.push({ offset: t, color: e }); }, }; var Kg = function (t, e, n, i, r, o) { (this.x = null == t ? 0 : t), (this.y = null == e ? 0 : e), (this.x2 = null == n ? 1 : n), (this.y2 = null == i ? 0 : i), (this.type = 'linear'), (this.global = o || !1), $g.call(this, r); }; (Kg.prototype = { constructor: Kg }), h(Kg, $g); var Qg = function (t, e, n, i, r) { (this.x = null == t ? 0.5 : t), (this.y = null == e ? 0.5 : e), (this.r = null == n ? 0.5 : n), (this.type = 'radial'), (this.global = r || !1), $g.call(this, i); }; (Qg.prototype = { constructor: Qg }), h(Qg, $g); var Jg = Math.round, tv = Math.max, ev = Math.min, nv = {}, iv = (Object.freeze || Object)({ extendShape: Ri, extendPath: function (t, e) { return zi(t, e); }, makePath: Vi, makeImage: Gi, mergePath: function (t, e) { for (var n = [], i = t.length, r = 0; r < i; r++) { var o = t[r]; o.path || o.createPathProxy(), o.__dirtyPath && o.buildPath(o.path, o.shape, !0), n.push(o.path); } var a = new ki(e); return ( a.createPathProxy(), (a.buildPath = function (t) { t.appendPath(n); var e = t.getContext(); e && t.rebuildPath(e); }), a ); }, resizePath: Hi, subPixelOptimizeLine: Fi, subPixelOptimizeRect: Zi, subPixelOptimize: Ui, setHoverStyle: rr, setLabelStyle: or, setTextStyle: ar, setText: function (t, e, n) { var i, r = { isRectText: !0 }; !1 === n ? (i = !0) : (r.autoColor = n), sr(t, e, r, i), t.host && t.host.dirty && t.host.dirty(!1); }, getFont: fr, updateProps: gr, initProps: vr, getTransform: mr, applyTransform: yr, transformDirection: xr, groupTransition: _r, clipPointsByRect: wr, clipRectByRect: function (t, e) { var n = tv(t.x, e.x), i = ev(t.x + t.width, e.x + e.width), r = tv(t.y, e.y), o = ev(t.y + t.height, e.y + e.height); if (i >= n && o >= r) return { x: n, y: r, width: i - n, height: o - r }; }, createIcon: br, Group: Tf, Image: Ue, Text: zg, Circle: Eg, Sector: Rg, Ring: Vg, Polygon: Hg, Polyline: Fg, Rect: Zg, Line: Ug, BezierCurve: jg, Arc: qg, CompoundPath: Yg, LinearGradient: Kg, RadialGradient: Qg, BoundingRect: Zt, }), rv = ['textStyle', 'color'], ov = { getTextColor: function (t) { var e = this.ecModel; return this.getShallow('color') || (!t && e ? e.get(rv) : null); }, getFont: function () { return fr( { fontStyle: this.getShallow('fontStyle'), fontWeight: this.getShallow('fontWeight'), fontSize: this.getShallow('fontSize'), fontFamily: this.getShallow('fontFamily'), }, this.ecModel ); }, getTextRect: function (t) { return he( t, this.getFont(), this.getShallow('align'), this.getShallow('verticalAlign') || this.getShallow('baseline'), this.getShallow('padding'), this.getShallow('rich'), this.getShallow('truncateText') ); }, }, av = Cp([ ['fill', 'color'], ['stroke', 'borderColor'], ['lineWidth', 'borderWidth'], ['opacity'], ['shadowBlur'], ['shadowOffsetX'], ['shadowOffsetY'], ['shadowColor'], ['textPosition'], ['textAlign'], ]), sv = { getItemStyle: function (t, e) { var n = av(this, t, e), i = this.getBorderLineDash(); return i && (n.lineDash = i), n; }, getBorderLineDash: function () { var t = this.get('borderType'); return 'solid' === t || null == t ? null : 'dashed' === t ? [5, 5] : [1, 1]; }, }, lv = u; (Mr.prototype = { constructor: Mr, init: null, mergeOption: function (t) { i(this.option, t, !0); }, get: function (t, e) { return null == t ? this.option : Sr(this.option, this.parsePath(t), !e && Ir(this, t)); }, getShallow: function (t, e) { var n = this.option, i = null == n ? n : n[t], r = !e && Ir(this, t); return null == i && r && (i = r.getShallow(t)), i; }, getModel: function (t, e) { var n, i = null == t ? this.option : Sr(this.option, (t = this.parsePath(t))); return ( (e = e || ((n = Ir(this, t)) && n.getModel(t))), new Mr(i, e, this.ecModel) ); }, isEmpty: function () { return null == this.option; }, restoreData: function () {}, clone: function () { return new (0, this.constructor)(n(this.option)); }, setReadOnly: function (t) {}, parsePath: function (t) { return 'string' == typeof t && (t = t.split('.')), t; }, customizeGetParent: function (t) { Wn(this, 'getParent', t); }, isAnimationEnabled: function () { if (!Md.node) { if (null != this.option.animation) return !!this.option.animation; if (this.parentModel) return this.parentModel.isAnimationEnabled(); } }, }), Xn(Mr), lv(Mr, Dp), lv(Mr, Lp), lv(Mr, ov), lv(Mr, sv); var hv = d, uv = w, cv = [ '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', ], dv = { getDataParams: function (t, e) { var n = this.getData(e), i = this.getRawValue(t, e), r = n.getRawIndex(t), o = n.getName(t, !0), a = n.getRawDataItem(t), s = n.getItemVisual(t, 'color'); return { componentType: this.mainType, componentSubType: this.subType, seriesType: 'series' === this.mainType ? this.subType : null, seriesIndex: this.seriesIndex, seriesId: this.id, seriesName: this.name, name: o, dataIndex: r, data: a, dataType: e, value: i, color: s, marker: Rn(s), $vars: ['seriesName', 'name', 'value'], }; }, getFormattedLabel: function (t, e, n, i, r) { e = e || 'normal'; var o = this.getData(n).getItemModel(t), a = this.getDataParams(t, n); null != i && a.value instanceof Array && (a.value = a.value[i]); var s = o.get([r || 'label', e, 'formatter']); return 'function' == typeof s ? ((a.status = e), s(a)) : 'string' == typeof s ? Bn(s, a) : void 0; }, getRawValue: function (t, e) { var n = this.getData(e).getRawDataItem(t); if (null != n) return !uv(n) || n instanceof Array ? n : n.value; }, formatTooltip: E, }, fv = (function () { var t = 0; return function () { var e = '\0__ec_prop_getter_' + t++; return function (t) { return t[e] || (t[e] = {}); }; }; })(), pv = 0, gv = '_', vv = d, mv = ['left', 'right', 'top', 'bottom', 'width', 'height'], yv = [ ['width', 'left', 'right'], ['height', 'top', 'bottom'], ], xv = Wr, _v = (m(Wr, 'vertical'), m(Wr, 'horizontal'), { getBoxLayoutParams: function () { return { left: this.get('left'), top: this.get('top'), right: this.get('right'), bottom: this.get('bottom'), width: this.get('width'), height: this.get('height'), }; }, }), wv = Array.prototype.push, bv = Mr.extend({ type: 'component', id: '', name: '', mainType: '', subType: '', componentIndex: 0, defaultOption: null, ecModel: null, dependentModels: [], uid: null, layoutMode: null, $constructor: function (t, e, n, i) { Mr.call(this, t, e, n, i), (this.uid = Gr('componentModel')); }, init: function (t, e, n, i) { this.mergeDefaultAndTheme(t, n); }, mergeDefaultAndTheme: function (t, e) { var n = this.layoutMode, r = n ? Ur(t) : {}; i(t, e.getTheme().get(this.mainType)), i(t, this.getDefaultOption()), n && Zr(t, r, n); }, mergeOption: function (t, e) { i(this.option, t, !0); var n = this.layoutMode; n && Zr(this.option, t, n); }, optionUpdated: function (t, e) {}, getDefaultOption: function () { if (!Fn(this, '__defaultOption')) { for (var t = [], e = this.constructor; e; ) { var n = e.prototype.defaultOption; n && t.push(n), (e = e.superClass); } for (var r = {}, o = t.length - 1; o >= 0; o--) r = i(r, t[o], !0); Wn(this, '__defaultOption', r); } return Hn(this, '__defaultOption'); }, getReferringComponents: function (t) { return this.ecModel.queryComponents({ mainType: t, index: this.get(t + 'Index', !0), id: this.get(t + 'Id', !0), }); }, }); Yn(bv, { registerWhenExtend: !0 }), (function (t) { var e = {}; (t.registerSubTypeDefaulter = function (t, n) { (t = Zn(t)), (e[t.main] = n); }), (t.determineSubType = function (n, i) { var r = i.type; if (!r) { var o = Zn(n).main; t.hasSubTypes(n) && e[o] && (r = e[o](i)); } return r; }); })(bv), (function (t, e) { function n(t) { var n = {}, o = []; return ( d(t, function (a) { var s = i(n, a), h = r((s.originalDeps = e(a)), t); (s.entryCount = h.length), 0 === s.entryCount && o.push(a), d(h, function (t) { l(s.predecessor, t) < 0 && s.predecessor.push(t); var e = i(n, t); l(e.successor, t) < 0 && e.successor.push(a); }); }), { graph: n, noEntryList: o } ); } function i(t, e) { return t[e] || (t[e] = { predecessor: [], successor: [] }), t[e]; } function r(t, e) { var n = []; return ( d(t, function (t) { l(e, t) >= 0 && n.push(t); }), n ); } t.topologicalTravel = function (t, e, i, r) { function o(t) { s[t].entryCount--, 0 === s[t].entryCount && l.push(t); } if (t.length) { var a = n(e), s = a.graph, l = a.noEntryList, h = {}; for ( d(t, function (t) { h[t] = !0; }); l.length; ) { var u = l.pop(), c = s[u], f = !!h[u]; f && (i.call(r, u, c.originalDeps.slice()), delete h[u]), d( c.successor, f ? function (t) { (h[t] = !0), o(t); } : o ); } d(h, function () { throw new Error('Circle dependency may exists'); }); } }; })(bv, function (t) { var e = []; return ( d(bv.getClassesByMainType(t), function (t) { wv.apply(e, t.prototype.dependencies || []); }), f(e, function (t) { return Zn(t).main; }) ); }), u(bv, _v); var Mv = ''; 'undefined' != typeof navigator && (Mv = navigator.platform || ''); var Sv = { color: [ '#c23531', '#2f4554', '#61a0a8', '#d48265', '#91c7ae', '#749f83', '#ca8622', '#bda29a', '#6e7074', '#546570', '#c4ccd3', ], textStyle: { fontFamily: Mv.match(/^Win/) ? 'Microsoft YaHei' : 'sans-serif', fontSize: 12, fontStyle: 'normal', fontWeight: 'normal', }, blendMode: null, animation: 'auto', animationDuration: 1e3, animationDurationUpdate: 300, animationEasing: 'exponentialOut', animationEasingUpdate: 'cubicOut', animationThreshold: 2e3, progressiveThreshold: 3e3, progressive: 400, hoverLayerThreshold: 3e3, useUTC: !1, }, Iv = { clearColorPalette: function () { Wn(this, 'colorIdx', 0), Wn(this, 'colorNameMap', {}); }, getColorFromPalette: function (t, e) { var n = Hn((e = e || this), 'colorIdx') || 0, i = Hn(e, 'colorNameMap') || Wn(e, 'colorNameMap', {}); if (i.hasOwnProperty(t)) return i[t]; var r = this.get('color', !0) || []; if (r.length) { var o = r[n]; return t && (i[t] = o), Wn(e, 'colorIdx', (n + 1) % r.length), o; } }, }, Tv = d, Av = g, Cv = f, kv = y, Dv = l, Pv = w, Lv = '\0_ec_inner', Ov = Mr.extend({ constructor: Ov, init: function (t, e, n, i) { (n = n || {}), (this.option = null), (this._theme = new Mr(n)), (this._optionManager = i); }, setOption: function (t, e) { D(!(Lv in t), 'please use chart.getOption()'), this._optionManager.setOption(t, e), this.resetOption(null); }, resetOption: function (t) { var e = !1, n = this._optionManager; if (!t || 'recreate' === t) { var i = n.mountOption('recreate' === t); this.option && 'recreate' !== t ? (this.restoreData(), this.mergeOption(i)) : qr.call(this, i), (e = !0); } if ( (('timeline' !== t && 'media' !== t) || this.restoreData(), !t || 'recreate' === t || 'timeline' === t) ) { var r = n.getTimelineOption(this); r && (this.mergeOption(r), (e = !0)); } if (!t || 'recreate' === t || 'media' === t) { var o = n.getMediaOption(this, this._api); o.length && Tv( o, function (t) { this.mergeOption(t, (e = !0)); }, this ); } return e; }, mergeOption: function (t) { var e = this.option, r = this._componentsMap, a = []; Tv(t, function (t, r) { null != t && (bv.hasClass(r) ? a.push(r) : (e[r] = null == e[r] ? n(t) : i(e[r], t, !0))); }), bv.topologicalTravel( a, bv.getAllClassMainTypes(), function (n, i) { var a = Tr(t[n]), s = Pr(r.get(n), a); Lr(s), Tv(s, function (t, e) { var i = t.option; Pv(i) && ((t.keyInfo.mainType = n), (t.keyInfo.subType = $r(n, i, t.exist))); }); var l = Yr(r, i); (e[n] = []), r.set(n, []), Tv( s, function (t, i) { var a = t.exist, s = t.option; if ((D(Pv(s) || a, 'Empty component definition'), s)) { var h = bv.getClass(n, t.keyInfo.subType, !0); if (a && a instanceof h) (a.name = t.keyInfo.name), a.mergeOption(s, this), a.optionUpdated(s, !1); else { var u = o( { dependentModels: l, componentIndex: i }, t.keyInfo ); o((a = new h(s, this, this, u)), u), a.init(s, this, this, u), a.optionUpdated(null, !0); } } else a.mergeOption({}, this), a.optionUpdated({}, !1); (r.get(n)[i] = a), (e[n][i] = a.option); }, this ), 'series' === n && (this._seriesIndices = Kr(r.get('series'))); }, this ), (this._seriesIndices = this._seriesIndices || []); }, getOption: function () { var t = n(this.option); return ( Tv(t, function (e, n) { if (bv.hasClass(n)) { for (var i = (e = Tr(e)).length - 1; i >= 0; i--) Or(e[i]) && e.splice(i, 1); t[n] = e; } }), delete t[Lv], t ); }, getTheme: function () { return this._theme; }, getComponent: function (t, e) { var n = this._componentsMap.get(t); if (n) return n[e || 0]; }, queryComponents: function (t) { var e = t.mainType; if (!e) return []; var n = t.index, i = t.id, r = t.name, o = this._componentsMap.get(e); if (!o || !o.length) return []; var a; if (null != n) kv(n) || (n = [n]), (a = Av( Cv(n, function (t) { return o[t]; }), function (t) { return !!t; } )); else if (null != i) { var s = kv(i); a = Av(o, function (t) { return (s && Dv(i, t.id) >= 0) || (!s && t.id === i); }); } else if (null != r) { var l = kv(r); a = Av(o, function (t) { return (l && Dv(r, t.name) >= 0) || (!l && t.name === r); }); } else a = o.slice(); return Qr(a, t); }, findComponents: function (t) { var e = t.query, n = t.mainType, i = (function (t) { var e = n + 'Index', i = n + 'Id', r = n + 'Name'; return !t || (null == t[e] && null == t[i] && null == t[r]) ? null : { mainType: n, index: t[e], id: t[i], name: t[r] }; })(e); return (function (e) { return t.filter ? Av(e, t.filter) : e; })(Qr(i ? this.queryComponents(i) : this._componentsMap.get(n), t)); }, eachComponent: function (t, e, n) { var i = this._componentsMap; if ('function' == typeof t) (n = e), (e = t), i.each(function (t, i) { Tv(t, function (t, r) { e.call(n, i, t, r); }); }); else if (_(t)) Tv(i.get(t), e, n); else if (Pv(t)) { var r = this.findComponents(t); Tv(r, e, n); } }, getSeriesByName: function (t) { var e = this._componentsMap.get('series'); return Av(e, function (e) { return e.name === t; }); }, getSeriesByIndex: function (t) { return this._componentsMap.get('series')[t]; }, getSeriesByType: function (t) { var e = this._componentsMap.get('series'); return Av(e, function (e) { return e.subType === t; }); }, getSeries: function () { return this._componentsMap.get('series').slice(); }, eachSeries: function (t, e) { Tv( this._seriesIndices, function (n) { var i = this._componentsMap.get('series')[n]; t.call(e, i, n); }, this ); }, eachRawSeries: function (t, e) { Tv(this._componentsMap.get('series'), t, e); }, eachSeriesByType: function (t, e, n) { Tv( this._seriesIndices, function (i) { var r = this._componentsMap.get('series')[i]; r.subType === t && e.call(n, r, i); }, this ); }, eachRawSeriesByType: function (t, e, n) { return Tv(this.getSeriesByType(t), e, n); }, isSeriesFiltered: function (t) { return l(this._seriesIndices, t.componentIndex) < 0; }, getCurrentSeriesIndices: function () { return (this._seriesIndices || []).slice(); }, filterSeries: function (t, e) { var n = Av(this._componentsMap.get('series'), t, e); this._seriesIndices = Kr(n); }, restoreData: function () { var t = this._componentsMap; this._seriesIndices = Kr(t.get('series')); var e = []; t.each(function (t, n) { e.push(n); }), bv.topologicalTravel(e, bv.getAllClassMainTypes(), function (e, n) { Tv(t.get(e), function (t) { t.restoreData(); }); }); }, }); u(Ov, Iv); var zv = [ 'getDom', 'getZr', 'getWidth', 'getHeight', 'getDevicePixelRatio', 'dispatchAction', 'isDisposed', 'on', 'off', 'getDataURL', 'getConnectedDataURL', 'getModel', 'getOption', 'getViewOfComponentModel', 'getViewOfSeriesModel', ], Ev = {}; (to.prototype = { constructor: to, create: function (t, e) { var n = []; d(Ev, function (i, r) { var o = i.create(t, e); n = n.concat(o || []); }), (this._coordinateSystems = n); }, update: function (t, e) { d(this._coordinateSystems, function (n) { n.update && n.update(t, e); }); }, getCoordinateSystems: function () { return this._coordinateSystems.slice(); }, }), (to.register = function (t, e) { Ev[t] = e; }), (to.get = function (t) { return Ev[t]; }); var Nv = d, Bv = n, Rv = f, Vv = i, Gv = /^(min|max)?(.+)$/; eo.prototype = { constructor: eo, setOption: function (t, e) { t = Bv(t, !0); var n = this._optionBackup, i = no.call(this, t, e, !n); (this._newBaseOption = i.baseOption), n ? (ao(n.baseOption, i.baseOption), i.timelineOptions.length && (n.timelineOptions = i.timelineOptions), i.mediaList.length && (n.mediaList = i.mediaList), i.mediaDefault && (n.mediaDefault = i.mediaDefault)) : (this._optionBackup = i); }, mountOption: function (t) { var e = this._optionBackup; return ( (this._timelineOptions = Rv(e.timelineOptions, Bv)), (this._mediaList = Rv(e.mediaList, Bv)), (this._mediaDefault = Bv(e.mediaDefault)), (this._currentMediaIndices = []), Bv(t ? e.baseOption : this._newBaseOption) ); }, getTimelineOption: function (t) { var e, n = this._timelineOptions; if (n.length) { var i = t.getComponent('timeline'); i && (e = Bv(n[i.getCurrentIndex()], !0)); } return e; }, getMediaOption: function (t) { var e = this._api.getWidth(), n = this._api.getHeight(), i = this._mediaList, r = this._mediaDefault, o = [], a = []; if (!i.length && !r) return a; for (var s = 0, l = i.length; s < l; s++) io(i[s].query, e, n) && o.push(s); return ( !o.length && r && (o = [-1]), o.length && !oo(o, this._currentMediaIndices) && (a = Rv(o, function (t) { return Bv(-1 === t ? r.option : i[t].option); })), (this._currentMediaIndices = o), a ); }, }; var Wv = d, Hv = w, Fv = [ 'areaStyle', 'lineStyle', 'nodeStyle', 'linkStyle', 'chordStyle', 'label', 'labelLine', ], Zv = function (t, e) { Wv(co(t.series), function (t) { Hv(t) && uo(t); }); var n = [ 'xAxis', 'yAxis', 'radiusAxis', 'angleAxis', 'singleAxis', 'parallelAxis', 'radar', ]; e && n.push('valueAxis', 'categoryAxis', 'logAxis', 'timeAxis'), Wv(n, function (e) { Wv(co(t[e]), function (t) { t && (lo(t, 'axisLabel'), lo(t.axisPointer, 'label')); }); }), Wv(co(t.parallel), function (t) { var e = t && t.parallelAxisDefault; lo(e, 'axisLabel'), lo(e && e.axisPointer, 'label'); }), Wv(co(t.calendar), function (t) { lo(t, 'dayLabel'), lo(t, 'monthLabel'), lo(t, 'yearLabel'); }), Wv(co(t.radar), function (t) { lo(t, 'name'); }), Wv(co(t.geo), function (t) { Hv(t) && (ho(t.label), Wv(co(t.regions), function (t) { ho(t.label); })); }), ho(fo(t.timeline).label), lo(fo(t.axisPointer), 'label'), lo(fo(t.tooltip).axisPointer, 'label'); }, Uv = [ ['x', 'left'], ['y', 'top'], ['x2', 'right'], ['y2', 'bottom'], ], Xv = [ 'grid', 'geo', 'parallel', 'legend', 'toolbox', 'title', 'visualMap', 'dataZoom', 'timeline', ], jv = [ 'bar', 'boxplot', 'candlestick', 'chord', 'effectScatter', 'funnel', 'gauge', 'lines', 'graph', 'heatmap', 'line', 'map', 'parallel', 'pie', 'radar', 'sankey', 'scatter', 'treemap', ], qv = function (t, e) { Zv(t, e), (t.series = Tr(t.series)), d(t.series, function (t) { if (w(t)) { var e = t.type; if ( (('pie' !== e && 'gauge' !== e) || (null != t.clockWise && (t.clockwise = t.clockWise)), 'gauge' === e) ) { var n = po(t, 'pointer.color'); null != n && go(t, 'itemStyle.normal.color', n); } for (var i = 0; i < jv.length; i++) if (jv[i] === t.type) { vo(t); break; } } }), t.dataRange && (t.visualMap = t.dataRange), d(Xv, function (e) { var n = t[e]; n && (y(n) || (n = [n]), d(n, function (t) { vo(t); })); }); }, Yv = bv.extend({ type: 'series.__base__', seriesIndex: 0, coordinateSystem: null, defaultOption: null, legendDataProvider: null, visualColorAccessPath: 'itemStyle.normal.color', layoutMode: null, init: function (t, e, n, i) { (this.seriesIndex = this.componentIndex), this.mergeDefaultAndTheme(t, n), Wn(this, 'dataBeforeProcessed', this.getInitialData(t, n)), this.restoreData(); }, mergeDefaultAndTheme: function (t, e) { var n = this.layoutMode, r = n ? Ur(t) : {}, o = this.subType; bv.hasClass(o) && (o += 'Series'), i(t, e.getTheme().get(this.subType)), i(t, this.getDefaultOption()), Ar(t.label, ['show']), this.fillDataTextStyle(t.data), n && Zr(t, r, n); }, mergeOption: function (t, e) { (t = i(this.option, t, !0)), this.fillDataTextStyle(t.data); var n = this.layoutMode; n && Zr(this.option, t, n); var r = this.getInitialData(t, e); r && (Wn(this, 'data', r), Wn(this, 'dataBeforeProcessed', r.cloneShallow())); }, fillDataTextStyle: function (t) { if (t) for (var e = ['show'], n = 0; n < t.length; n++) t[n] && t[n].label && Ar(t[n].label, e); }, getInitialData: function () {}, getData: function (t) { var e = Hn(this, 'data'); return null == t ? e : e.getLinkedData(t); }, setData: function (t) { Wn(this, 'data', t); }, getRawData: function () { return Hn(this, 'dataBeforeProcessed'); }, coordDimToDataDim: function (t) { return Br(this.getData(), t); }, dataDimToCoordDim: function (t) { return Nr(this.getData(), t); }, getBaseAxis: function () { var t = this.coordinateSystem; return t && t.getBaseAxis && t.getBaseAxis(); }, formatTooltip: function (t, e, n) { var i = Hn(this, 'data'), r = this.getRawValue(t), o = y(r) ? (function (n) { function r(t, n) { var r = i.getDimensionInfo(n); if (r && !1 !== r.otherDims.tooltip) { var s = r.type, l = (o ? '- ' + (r.tooltipName || r.name) + ': ' : '') + ('ordinal' === s ? t + '' : 'time' === s ? e ? '' : Vn('yyyy/MM/dd hh:mm:ss', t) : zn(t)); l && a.push(Nn(l)); } } var o = p( n, function (t, e, n) { var r = i.getDimensionInfo(n); return (t |= r && !1 !== r.tooltip && null != r.tooltipName); }, 0 ), a = [], s = Rr(i, 'tooltip'); return ( s.length ? d(s, function (e) { r(i.get(e, t), e); }) : d(n, r), (o ? '
' : '') + a.join(o ? '
' : ', ') ); })(r) : Nn(zn(r)), a = i.getName(t), s = i.getItemVisual(t, 'color'); w(s) && s.colorStops && (s = (s.colorStops[0] || {}).color); var l = Rn((s = s || 'transparent')), h = this.name; return ( '\0-' === h && (h = ''), (h = h ? Nn(h) + (e ? ': ' : '
') : ''), e ? l + h + o : h + l + (a ? Nn(a) + ': ' + o : o) ); }, isAnimationEnabled: function () { if (Md.node) return !1; var t = this.getShallow('animation'); return ( t && this.getData().count() > this.getShallow('animationThreshold') && (t = !1), t ); }, restoreData: function () { Wn(this, 'data', Hn(this, 'dataBeforeProcessed').cloneShallow()); }, getColorFromPalette: function (t, e) { var n = this.ecModel, i = Iv.getColorFromPalette.call(this, t, e); return i || (i = n.getColorFromPalette(t, e)), i; }, getAxisTooltipData: null, getTooltipPosition: null, }); u(Yv, dv), u(Yv, Iv); var $v = function () { (this.group = new Tf()), (this.uid = Gr('viewComponent')); }; $v.prototype = { constructor: $v, init: function (t, e) {}, render: function (t, e, n, i) {}, dispose: function () {}, }; var Kv = $v.prototype; (Kv.updateView = Kv.updateLayout = Kv.updateVisual = function (t, e, n, i) {}), Xn($v), Yn($v, { registerWhenExtend: !0 }), (mo.prototype = { type: 'chart', init: function (t, e) {}, render: function (t, e, n, i) {}, highlight: function (t, e, n, i) { xo(t.getData(), i, 'emphasis'); }, downplay: function (t, e, n, i) { xo(t.getData(), i, 'normal'); }, remove: function (t, e) { this.group.removeAll(); }, dispose: function () {}, }); var Qv = mo.prototype; (Qv.updateView = Qv.updateLayout = Qv.updateVisual = function (t, e, n, i) { this.render(t, e, n, i); }), Xn(mo), Yn(mo, { registerWhenExtend: !0 }); var Jv = '\0__throttleOriginMethod', tm = '\0__throttleRate', em = '\0__throttleType', nm = Math.PI, im = d, rm = bv.parseClassType, om = { zrender: '3.7.4' }, am = 1e3, sm = 1e3, lm = 3e3, hm = { PROCESSOR: { FILTER: am, STATISTIC: 5e3 }, VISUAL: { LAYOUT: sm, GLOBAL: 2e3, CHART: lm, COMPONENT: 4e3, BRUSH: 5e3, }, }, um = '__flagInMainProcess', cm = '__optionUpdated', dm = /^[a-zA-Z0-9_]+$/; (So.prototype.on = Mo('on')), (So.prototype.off = Mo('off')), (So.prototype.one = Mo('one')), u(So, Ud); var fm = Io.prototype; (fm._onframe = function () { if (this[cm]) { var t = this[cm].silent; (this[um] = !0), pm.prepareAndUpdate.call(this), (this[um] = !1), (this[cm] = !1), ko.call(this, t), Do.call(this, t); } }), (fm.getDom = function () { return this._dom; }), (fm.getZr = function () { return this._zr; }), (fm.setOption = function (t, e, n) { var i; if ( (w(e) && ((n = e.lazyUpdate), (i = e.silent), (e = e.notMerge)), (this[um] = !0), !this._model || e) ) { var r = new eo(this._api), o = this._theme; (this._model = new Ov(null, null, o, r)).init(null, null, o, r); } this._model.setOption(t, xm), n ? ((this[cm] = { silent: i }), (this[um] = !1)) : (pm.prepareAndUpdate.call(this), this._zr.flush(), (this[cm] = !1), (this[um] = !1), ko.call(this, i), Do.call(this, i)); }), (fm.setTheme = function () { console.log('ECharts#setTheme() is DEPRECATED in ECharts 3.0'); }), (fm.getModel = function () { return this._model; }), (fm.getOption = function () { return this._model && this._model.getOption(); }), (fm.getWidth = function () { return this._zr.getWidth(); }), (fm.getHeight = function () { return this._zr.getHeight(); }), (fm.getDevicePixelRatio = function () { return this._zr.painter.dpr || window.devicePixelRatio || 1; }), (fm.getRenderedCanvas = function (t) { if (Md.canvasSupported) { ((t = t || {}).pixelRatio = t.pixelRatio || 1), (t.backgroundColor = t.backgroundColor || this._model.get('backgroundColor')); var e = this._zr; return ( d(e.storage.getDisplayList(), function (t) { t.stopAnimation(!0); }), e.painter.getRenderedCanvas(t) ); } }), (fm.getSvgDataUrl = function () { if (Md.svgSupported) { var t = this._zr; return ( d(t.storage.getDisplayList(), function (t) { t.stopAnimation(!0); }), t.painter.pathToSvg() ); } }), (fm.getDataURL = function (t) { var e = (t = t || {}).excludeComponents, n = this._model, i = [], r = this; im(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.getRenderedCanvas(t).toDataURL( 'image/' + ((t && t.type) || 'png') ); return ( im(i, function (t) { t.group.ignore = !1; }), o ); }), (fm.getConnectedDataURL = function (t) { if (Md.canvasSupported) { var e = this.group, i = Math.min, r = Math.max; if (Im[e]) { var o = 1 / 0, a = 1 / 0, s = -1 / 0, l = -1 / 0, h = [], u = (t && t.pixelRatio) || 1; d(Sm, function (u, c) { if (u.group === e) { var d = u.getRenderedCanvas(n(t)), f = u.getDom().getBoundingClientRect(); (o = i(f.left, o)), (a = i(f.top, a)), (s = r(f.right, s)), (l = r(f.bottom, l)), h.push({ dom: d, left: f.left, top: f.top }); } }); var c = (s *= u) - (o *= u), f = (l *= u) - (a *= u), p = zd(); (p.width = c), (p.height = f); var g = vn(p); return ( im(h, function (t) { var e = new Ue({ style: { x: t.left * u - o, y: t.top * u - a, image: t.dom }, }); g.add(e); }), g.refreshImmediately(), p.toDataURL('image/' + ((t && t.type) || 'png')) ); } return this.getDataURL(t); } }), (fm.convertToPixel = m(To, 'convertToPixel')), (fm.convertFromPixel = m(To, 'convertFromPixel')), (fm.containPixel = function (t, e) { var n; return ( (t = Er(this._model, t)), d( t, function (t, i) { i.indexOf('Models') >= 0 && d( t, function (t) { var r = t.coordinateSystem; if (r && r.containPoint) n |= !!r.containPoint(e); else if ('seriesModels' === i) { var o = this._chartsMap[t.__viewId]; o && o.containPoint && (n |= o.containPoint(e, t)); } }, this ); }, this ), !!n ); }), (fm.getVisual = function (t, e) { var n = (t = Er(this._model, t, { defaultMainType: 'series', })).seriesModel.getData(), i = t.hasOwnProperty('dataIndexInside') ? t.dataIndexInside : t.hasOwnProperty('dataIndex') ? n.indexOfRawIndex(t.dataIndex) : null; return null != i ? n.getItemVisual(i, e) : n.getVisual(e); }), (fm.getViewOfComponentModel = function (t) { return this._componentsMap[t.__viewId]; }), (fm.getViewOfSeriesModel = function (t) { return this._chartsMap[t.__viewId]; }); var pm = { update: function (t) { var e = this._model, n = this._api, i = this._coordSysMgr, r = this._zr; if (e) { e.restoreData(), i.create(this._model, this._api), Oo.call(this, e, n), zo.call(this, e), i.update(e, n), No.call(this, e, t), Bo.call(this, e, t); var o = e.get('backgroundColor') || 'transparent', a = r.painter; if (a.isSingleCanvas && a.isSingleCanvas()) r.configLayer(0, { clearColor: o }); else { if (!Md.canvasSupported) { var s = bt(o); (o = Dt(s, 'rgb')), 0 === s[3] && (o = 'transparent'); } o.colorStops || o.image ? (r.configLayer(0, { clearColor: o }), (this.__hasGradientOrPatternBg = !0), (this._dom.style.background = 'transparent')) : (this.__hasGradientOrPatternBg && r.configLayer(0, { clearColor: null }), (this.__hasGradientOrPatternBg = !1), (this._dom.style.background = o)); } im(_m, function (t) { t(e, n); }); } }, updateView: function (t) { var e = this._model; e && (e.eachSeries(function (t) { t.getData().clearAllVisual(); }), No.call(this, e, t), Po.call(this, 'updateView', e, t)); }, updateVisual: function (t) { var e = this._model; e && (e.eachSeries(function (t) { t.getData().clearAllVisual(); }), No.call(this, e, t, !0), Po.call(this, 'updateVisual', e, t)); }, updateLayout: function (t) { var e = this._model; e && (Eo.call(this, e, t), Po.call(this, 'updateLayout', e, t)); }, prepareAndUpdate: function (t) { var e = this._model; Lo.call(this, 'component', e), Lo.call(this, 'chart', e), pm.update.call(this, t); }, }; (fm.resize = function (t) { (this[um] = !0), this._zr.resize(t); var e = this._model && this._model.resetOption('media'); pm[e ? 'prepareAndUpdate' : 'update'].call(this), this._loadingFX && this._loadingFX.resize(), (this[um] = !1); var n = t && t.silent; ko.call(this, n), Do.call(this, n); }), (fm.showLoading = function (t, e) { if ( (w(t) && ((e = t), (t = '')), (t = t || 'default'), this.hideLoading(), Mm[t]) ) { var n = Mm[t](this._api, e), i = this._zr; (this._loadingFX = n), i.add(n); } }), (fm.hideLoading = function () { this._loadingFX && this._zr.remove(this._loadingFX), (this._loadingFX = null); }), (fm.makeActionFromEvent = function (t) { var e = o({}, t); return (e.type = mm[t.type]), e; }), (fm.dispatchAction = function (t, e) { w(e) || (e = { silent: !!e }), vm[t.type] && this._model && (this[um] ? this._pendingActions.push(t) : (Co.call(this, t, e.silent), e.flush ? this._zr.flush(!0) : !1 !== e.flush && Md.browser.weChat && this._throttledZrFlush(), ko.call(this, e.silent), Do.call(this, e.silent))); }), (fm.on = Mo('on')), (fm.off = Mo('off')), (fm.one = Mo('one')); var gm = [ 'click', 'dblclick', 'mouseover', 'mouseout', 'mousemove', 'mousedown', 'mouseup', 'globalout', 'contextmenu', ]; (fm._initEvents = function () { im( gm, function (t) { this._zr.on( t, function (e) { var n, i = this.getModel(), r = e.target; if ('globalout' === t) n = {}; else if (r && null != r.dataIndex) { var a = r.dataModel || i.getSeriesByIndex(r.seriesIndex); n = (a && a.getDataParams(r.dataIndex, r.dataType)) || {}; } else r && r.eventData && (n = o({}, r.eventData)); n && ((n.event = e), (n.type = t), this.trigger(t, n)); }, this ); }, this ), im( mm, function (t, e) { this._messageCenter.on( e, function (t) { this.trigger(e, t); }, this ); }, this ); }), (fm.isDisposed = function () { return this._disposed; }), (fm.clear = function () { this.setOption({ series: [] }, !0); }), (fm.dispose = function () { if (!this._disposed) { this._disposed = !0; var t = this._api, e = this._model; im(this._componentsViews, function (n) { n.dispose(e, t); }), im(this._chartsViews, function (n) { n.dispose(e, t); }), this._zr.dispose(), delete Sm[this.id]; } }), u(Io, Ud); var vm = {}, mm = {}, ym = [], xm = [], _m = [], wm = [], bm = {}, Mm = {}, Sm = {}, Im = {}, Tm = new Date() - 0, Am = new Date() - 0, Cm = '_echarts_instance_', km = {}, Dm = Fo; Yo(2e3, function (t) { t.eachRawSeries(function (e) { var n = (e.visualColorAccessPath || 'itemStyle.normal.color').split('.'), i = e.getData(), r = e.get(n) || e.getColorFromPalette(e.get('name')); i.setVisual('color', r), t.isSeriesFiltered(e) || ('function' != typeof r || r instanceof $g || i.each(function (t) { i.setItemVisual(t, 'color', r(e.getDataParams(t))); }), i.each(function (t) { var e = i.getItemModel(t).get(n, !0); null != e && i.setItemVisual(t, 'color', e); })); }); }), Uo(qv), $o('default', function (t, e) { a((e = e || {}), { text: 'loading', color: '#c23531', textColor: '#000', maskColor: 'rgba(255, 255, 255, 0.8)', zlevel: 0, }); var n = new Zg({ style: { fill: e.maskColor }, zlevel: e.zlevel, z: 1e4, }), i = new qg({ shape: { startAngle: -nm / 2, endAngle: -nm / 2 + 0.1, r: 10 }, style: { stroke: e.color, lineCap: 'round', lineWidth: 5 }, zlevel: e.zlevel, z: 10001, }), r = new Zg({ style: { fill: 'none', text: e.text, textPosition: 'right', textDistance: 10, textFill: e.textColor, }, zlevel: e.zlevel, z: 10001, }); i .animateShape(!0) .when(1e3, { endAngle: (3 * nm) / 2 }) .start('circularInOut'), i .animateShape(!0) .when(1e3, { startAngle: (3 * nm) / 2 }) .delay(300) .start('circularInOut'); var o = new Tf(); return ( o.add(i), o.add(r), o.add(n), (o.resize = function () { var e = t.getWidth() / 2, o = t.getHeight() / 2; i.setShape({ cx: e, cy: o }); var a = i.shape.r; r.setShape({ x: e - a, y: o - a, width: 2 * a, height: 2 * a }), n.setShape({ x: 0, y: 0, width: t.getWidth(), height: t.getHeight(), }); }), o.resize(), o ); }), jo({ type: 'highlight', event: 'highlight', update: 'highlight' }, E), jo({ type: 'downplay', event: 'downplay', update: 'downplay' }, E); var Pm = {}; na.prototype = { constructor: na, add: function (t) { return (this._add = t), this; }, update: function (t) { return (this._update = t), this; }, remove: function (t) { return (this._remove = t), this; }, execute: function () { var t = this._old, e = this._new, n = {}, i = [], r = []; for ( ia(t, {}, i, '_oldKeyGetter', this), ia(e, n, r, '_newKeyGetter', this), o = 0; o < t.length; o++ ) null != (s = n[(a = i[o])]) ? ((h = s.length) ? (1 === h && (n[a] = null), (s = s.unshift())) : (n[a] = null), this._update && this._update(s, o)) : this._remove && this._remove(o); for (var o = 0; o < r.length; o++) { var a = r[o]; if (n.hasOwnProperty(a)) { var s = n[a]; if (null == s) continue; if (s.length) for (var l = 0, h = s.length; l < h; l++) this._add && this._add(s[l]); else this._add && this._add(s); } } }, }; var Lm = w, Om = 'undefined' == typeof window ? global : window, zm = { float: void 0 === Om.Float64Array ? Array : Om.Float64Array, int: void 0 === Om.Int32Array ? Array : Om.Int32Array, ordinal: Array, number: Array, time: Array, }, Em = ['stackedOn', 'hasItemOption', '_nameList', '_idList', '_rawData']; (oa.prototype.pure = !1), (oa.prototype.count = function () { return this._array.length; }), (oa.prototype.getItem = function (t) { return this._array[t]; }); var Nm = function (t, e) { t = t || ['x', 'y']; for (var n = {}, i = [], r = 0; r < t.length; r++) { var o, a = {}; 'string' == typeof t[r] ? (a = { name: (o = t[r]), coordDim: o, coordDimIndex: 0, stackable: !1, type: 'number', }) : ((o = (a = t[r]).name), (a.type = a.type || 'number'), a.coordDim || ((a.coordDim = o), (a.coordDimIndex = 0))), (a.otherDims = a.otherDims || {}), i.push(o), (n[o] = a); } (this.dimensions = i), (this._dimensionInfos = n), (this.hostModel = e), this.dataType, (this.indices = []), (this._storage = {}), (this._nameList = []), (this._idList = []), (this._optionModels = []), (this.stackedOn = null), (this._visual = {}), (this._layout = {}), (this._itemVisuals = []), (this._itemLayouts = []), (this._graphicEls = []), this._rawData, this._extent; }, Bm = Nm.prototype; (Bm.type = 'list'), (Bm.hasItemOption = !0), (Bm.getDimension = function (t) { return isNaN(t) || (t = this.dimensions[t] || t), t; }), (Bm.getDimensionInfo = function (t) { return n(this._dimensionInfos[this.getDimension(t)]); }), (Bm.initData = function (t, e, n) { y((t = t || [])) && (t = new oa(t)), (this._rawData = t); var i, r = (this._storage = {}), o = (this.indices = []), a = this.dimensions, s = this._dimensionInfos, l = t.count(), h = [], u = {}; e = e || []; for (m = 0; m < a.length; m++) { var c = s[a[m]]; 0 === c.otherDims.itemName && (i = m); var d = zm[c.type]; r[a[m]] = new d(l); } var f = this; n || (f.hasItemOption = !1), (n = n || function (t, e, n, i) { var r = Cr(t); return ( kr(t) && (f.hasItemOption = !0), Dr(r instanceof Array ? r[i] : r, s[e]) ); }); for (m = 0; m < l; m++) { for (var p = t.getItem(m), g = 0; g < a.length; g++) { var v = a[g]; r[v][m] = n(p, v, m, g); } o.push(m); } for (var m = 0; m < l; m++) { p = t.getItem(m); !e[m] && p && (null != p.name ? (e[m] = p.name) : null != i && (e[m] = r[a[i]][m])); var x = e[m] || '', _ = p && p.id; !_ && x && ((u[x] = u[x] || 0), (_ = x), u[x] > 0 && (_ += '__ec__' + u[x]), u[x]++), _ && (h[m] = _); } (this._nameList = e), (this._idList = h); }), (Bm.count = function () { return this.indices.length; }), (Bm.get = function (t, e, n) { var i = this._storage, r = this.indices[e]; if (null == r || !i[t]) return NaN; var o = i[t][r]; if (n) { var a = this._dimensionInfos[t]; if (a && a.stackable) for (var s = this.stackedOn; s; ) { var l = s.get(t, e); ((o >= 0 && l > 0) || (o <= 0 && l < 0)) && (o += l), (s = s.stackedOn); } } return o; }), (Bm.getValues = function (t, e, n) { var i = []; y(t) || ((n = e), (e = t), (t = this.dimensions)); for (var r = 0, o = t.length; r < o; r++) i.push(this.get(t[r], e, n)); return i; }), (Bm.hasValue = function (t) { for ( var e = this.dimensions, n = this._dimensionInfos, i = 0, r = e.length; i < r; i++ ) if ('ordinal' !== n[e[i]].type && isNaN(this.get(e[i], t))) return !1; return !0; }), (Bm.getDataExtent = function (t, e, n) { t = this.getDimension(t); var i = this._storage[t], r = this.getDimensionInfo(t); e = r && r.stackable && e; var o, a = (this._extent || (this._extent = {}))[t + !!e]; if (a) return a; if (i) { for (var s = 1 / 0, l = -1 / 0, h = 0, u = this.count(); h < u; h++) (o = this.get(t, h, e)), (n && !n(o, t, h)) || (o < s && (s = o), o > l && (l = o)); return (this._extent[t + !!e] = [s, l]); } return [1 / 0, -1 / 0]; }), (Bm.getSum = function (t, e) { var n = 0; if (this._storage[t]) for (var i = 0, r = this.count(); i < r; i++) { var o = this.get(t, i, e); isNaN(o) || (n += o); } return n; }), (Bm.indexOf = function (t, e) { var n = this._storage[t], i = this.indices; if (n) for (var r = 0, o = i.length; r < o; r++) if (n[i[r]] === e) return r; return -1; }), (Bm.indexOfName = function (t) { for ( var e = this.indices, n = this._nameList, i = 0, r = e.length; i < r; i++ ) if (n[e[i]] === t) return i; return -1; }), (Bm.indexOfRawIndex = function (t) { var e = this.indices, n = e[t]; if (null != n && n === t) return t; for (var i = 0, r = e.length - 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; }), (Bm.indicesOfNearest = function (t, e, n, i) { var r = []; if (!this._storage[t]) return r; null == i && (i = 1 / 0); for ( var o = Number.MAX_VALUE, a = -1, s = 0, l = this.count(); s < l; s++ ) { var h = e - this.get(t, s, n), u = Math.abs(h); h <= i && u <= o && ((u < o || (h >= 0 && a < 0)) && ((o = u), (a = h), (r.length = 0)), r.push(s)); } return r; }), (Bm.getRawIndex = function (t) { var e = this.indices[t]; return null == e ? -1 : e; }), (Bm.getRawDataItem = function (t) { return this._rawData.getItem(this.getRawIndex(t)); }), (Bm.getName = function (t) { return this._nameList[this.indices[t]] || ''; }), (Bm.getId = function (t) { return this._idList[this.indices[t]] || this.getRawIndex(t) + ''; }), (Bm.each = function (t, e, n, i) { 'function' == typeof t && ((i = n), (n = e), (e = t), (t = [])); var r = [], o = (t = f(aa(t), this.getDimension, this)).length, a = this.indices; i = i || this; for (var s = 0; s < a.length; s++) switch (o) { case 0: e.call(i, s); break; case 1: e.call(i, this.get(t[0], s, n), s); break; case 2: e.call(i, this.get(t[0], s, n), this.get(t[1], s, n), s); break; default: for (var l = 0; l < o; l++) r[l] = this.get(t[l], s, n); (r[l] = s), e.apply(i, r); } }), (Bm.filterSelf = function (t, e, n, i) { 'function' == typeof t && ((i = n), (n = e), (e = t), (t = [])); var r = [], o = [], a = (t = f(aa(t), this.getDimension, this)).length, s = this.indices; i = i || this; for (var l = 0; l < s.length; l++) { var h; if (a) if (1 === a) h = e.call(i, this.get(t[0], l, n), l); else { for (var u = 0; u < a; u++) o[u] = this.get(t[u], l, n); (o[u] = l), (h = e.apply(i, o)); } else h = e.call(i, l); h && r.push(s[l]); } return (this.indices = r), (this._extent = {}), this; }), (Bm.mapArray = function (t, e, n, i) { 'function' == typeof t && ((i = n), (n = e), (e = t), (t = [])); var r = []; return ( this.each( t, function () { r.push(e && e.apply(this, arguments)); }, n, i ), r ); }), (Bm.map = function (t, e, n, i) { var r = sa(this, (t = f(aa(t), this.getDimension, this))), o = (r.indices = this.indices), a = r._storage, s = []; return ( this.each( t, function () { var n = arguments[arguments.length - 1], i = e && e.apply(this, arguments); if (null != i) { 'number' == typeof i && ((s[0] = i), (i = s)); for (var r = 0; r < i.length; r++) { var l = t[r], h = a[l], u = o[n]; h && (h[u] = i[r]); } } }, n, i ), r ); }), (Bm.downSample = function (t, e, n, i) { for ( var r = sa(this, [t]), o = this._storage, a = r._storage, s = this.indices, l = (r.indices = []), h = [], u = [], c = Math.floor(1 / e), d = a[t], f = this.count(), p = 0; p < o[t].length; p++ ) a[t][p] = o[t][p]; for (p = 0; p < f; p += c) { c > f - p && ((c = f - p), (h.length = c)); for (var g = 0; g < c; g++) { var v = s[p + g]; (h[g] = d[v]), (u[g] = v); } var m = n(h); (d[(v = u[i(h, m) || 0])] = m), l.push(v); } return r; }), (Bm.getItemModel = function (t) { var e = this.hostModel; return ( (t = this.indices[t]), new Mr(this._rawData.getItem(t), e, e && e.ecModel) ); }), (Bm.diff = function (t) { var e, n = this._idList, i = t && t._idList; return new na( t ? t.indices : [], this.indices, function (t) { return null != (e = i[t]) ? e : 'e\0\0' + t; }, function (t) { return null != (e = n[t]) ? e : 'e\0\0' + t; } ); }), (Bm.getVisual = function (t) { var e = this._visual; return e && e[t]; }), (Bm.setVisual = function (t, e) { if (Lm(t)) for (var n in t) t.hasOwnProperty(n) && this.setVisual(n, t[n]); else (this._visual = this._visual || {}), (this._visual[t] = e); }), (Bm.setLayout = function (t, e) { if (Lm(t)) for (var n in t) t.hasOwnProperty(n) && this.setLayout(n, t[n]); else this._layout[t] = e; }), (Bm.getLayout = function (t) { return this._layout[t]; }), (Bm.getItemLayout = function (t) { return this._itemLayouts[t]; }), (Bm.setItemLayout = function (t, e, n) { this._itemLayouts[t] = n ? o(this._itemLayouts[t] || {}, e) : e; }), (Bm.clearItemLayouts = function () { this._itemLayouts.length = 0; }), (Bm.getItemVisual = function (t, e, n) { var i = this._itemVisuals[t], r = i && i[e]; return null != r || n ? r : this.getVisual(e); }), (Bm.setItemVisual = function (t, e, n) { var i = this._itemVisuals[t] || {}; if (((this._itemVisuals[t] = i), Lm(e))) for (var r in e) e.hasOwnProperty(r) && (i[r] = e[r]); else i[e] = n; }), (Bm.clearAllVisual = function () { (this._visual = {}), (this._itemVisuals = []); }); var Rm = function (t) { (t.seriesIndex = this.seriesIndex), (t.dataIndex = this.dataIndex), (t.dataType = this.dataType); }; (Bm.setItemGraphicEl = function (t, e) { var n = this.hostModel; e && ((e.dataIndex = t), (e.dataType = this.dataType), (e.seriesIndex = n && n.seriesIndex), 'group' === e.type && e.traverse(Rm, e)), (this._graphicEls[t] = e); }), (Bm.getItemGraphicEl = function (t) { return this._graphicEls[t]; }), (Bm.eachItemGraphicEl = function (t, e) { d(this._graphicEls, function (n, i) { n && t && t.call(e, n, i); }); }), (Bm.cloneShallow = function () { var t = f(this.dimensions, this.getDimensionInfo, this), e = new Nm(t, this.hostModel); return ( (e._storage = this._storage), ra(e, this), (e.indices = this.indices.slice()), this._extent && (e._extent = o({}, this._extent)), e ); }), (Bm.wrapMethod = function (t, e) { var n = this[t]; 'function' == typeof n && ((this.__wrappedMethods = this.__wrappedMethods || []), this.__wrappedMethods.push(t), (this[t] = function () { var t = n.apply(this, arguments); return e.apply(this, [t].concat(C(arguments))); })); }), (Bm.TRANSFERABLE_METHODS = ['cloneShallow', 'downSample', 'map']), (Bm.CHANGABLE_METHODS = ['filterSelf']); var Vm = d, Gm = _, Wm = a, Hm = { tooltip: 1, label: 1, itemName: 1 }, Fm = (la.guessOrdinal = function (t, e) { for (var n = 0, i = t.length; n < i; n++) { var r = ha(t[n]); if (!y(r)) return !1; if (null != (r = r[e]) && isFinite(r) && '' !== r) return !1; if (Gm(r) && '-' !== r) return !0; } return !1; }), Zm = { cartesian2d: function (t, e, n, i) { var r = f(['xAxis', 'yAxis'], function (t) { return n.queryComponents({ mainType: t, index: e.get(t + 'Index'), id: e.get(t + 'Id'), })[0]; }), o = r[0], a = r[1], s = o.get('type'), l = a.get('type'), h = [ { name: 'x', type: pa(s), stackable: fa(s) }, { name: 'y', type: pa(l), stackable: fa(l) }, ], u = 'category' === s, c = 'category' === l; h = la(h, t, i); var d = {}; return ( u && (d.x = o), c && (d.y = a), { dimensions: h, categoryIndex: u ? 0 : c ? 1 : -1, categoryAxesModels: d, } ); }, singleAxis: function (t, e, n, i) { var r = n.queryComponents({ mainType: 'singleAxis', index: e.get('singleAxisIndex'), id: e.get('singleAxisId'), })[0], o = r.get('type'), a = 'category' === o, s = [{ name: 'single', type: pa(o), stackable: fa(o) }]; s = la(s, t, i); var l = {}; return ( a && (l.single = r), { dimensions: s, categoryIndex: a ? 0 : -1, categoryAxesModels: l } ); }, polar: function (t, e, n, i) { var r = n.queryComponents({ mainType: 'polar', index: e.get('polarIndex'), id: e.get('polarId'), })[0], o = r.findAxisModel('angleAxis'), a = r.findAxisModel('radiusAxis'), s = a.get('type'), l = o.get('type'), h = [ { name: 'radius', type: pa(s), stackable: fa(s) }, { name: 'angle', type: pa(l), stackable: fa(l) }, ], u = 'category' === l, c = 'category' === s; h = la(h, t, i); var d = {}; return ( c && (d.radius = a), u && (d.angle = o), { dimensions: h, categoryIndex: u ? 1 : c ? 0 : -1, categoryAxesModels: d, } ); }, geo: function (t, e, n, i) { return { dimensions: la([{ name: 'lng' }, { name: 'lat' }], t, i) }; }, }; (va.prototype.parse = function (t) { return t; }), (va.prototype.getSetting = function (t) { return this._setting[t]; }), (va.prototype.contain = function (t) { var e = this._extent; return t >= e[0] && t <= e[1]; }), (va.prototype.normalize = function (t) { var e = this._extent; return e[1] === e[0] ? 0.5 : (t - e[0]) / (e[1] - e[0]); }), (va.prototype.scale = function (t) { var e = this._extent; return t * (e[1] - e[0]) + e[0]; }), (va.prototype.unionExtent = function (t) { var e = this._extent; t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1]); }), (va.prototype.unionExtentFromData = function (t, e) { this.unionExtent(t.getDataExtent(e, !0)); }), (va.prototype.getExtent = function () { return this._extent.slice(); }), (va.prototype.setExtent = function (t, e) { var n = this._extent; isNaN(t) || (n[0] = t), isNaN(e) || (n[1] = e); }), (va.prototype.getTicksLabels = function () { for (var t = [], e = this.getTicks(), n = 0; n < e.length; n++) t.push(this.getLabel(e[n])); return t; }), (va.prototype.isBlank = function () { return this._isBlank; }), (va.prototype.setBlank = function (t) { this._isBlank = t; }), Xn(va), Yn(va, { registerWhenExtend: !0 }); var Um = va.prototype, Xm = va.extend({ type: 'ordinal', init: function (t, e) { (this._data = t), (this._extent = e || [0, t.length - 1]); }, parse: function (t) { return 'string' == typeof t ? l(this._data, t) : Math.round(t); }, contain: function (t) { return ( (t = this.parse(t)), Um.contain.call(this, t) && null != this._data[t] ); }, normalize: function (t) { return Um.normalize.call(this, this.parse(t)); }, scale: function (t) { return Math.round(Um.scale.call(this, t)); }, getTicks: function () { for (var t = [], e = this._extent, n = e[0]; n <= e[1]; ) t.push(n), n++; return t; }, getLabel: function (t) { return this._data[t]; }, count: function () { return this._extent[1] - this._extent[0] + 1; }, unionExtentFromData: function (t, e) { this.unionExtent(t.getDataExtent(e, !1)); }, niceTicks: E, niceExtent: E, }); Xm.create = function () { return new Xm(); }; var jm = bn, qm = bn, Ym = va.extend({ type: 'interval', _interval: 0, _intervalPrecision: 2, setExtent: function (t, e) { var n = this._extent; isNaN(t) || (n[0] = parseFloat(t)), isNaN(e) || (n[1] = parseFloat(e)); }, unionExtent: function (t) { var e = this._extent; t[0] < e[0] && (e[0] = t[0]), t[1] > e[1] && (e[1] = t[1]), Ym.prototype.setExtent.call(this, e[0], e[1]); }, getInterval: function () { return this._interval; }, setInterval: function (t) { (this._interval = t), (this._niceExtent = this._extent.slice()), (this._intervalPrecision = ya(t)); }, getTicks: function () { return wa( this._interval, this._extent, this._niceExtent, this._intervalPrecision ); }, getTicksLabels: function () { for (var t = [], e = this.getTicks(), n = 0; n < e.length; n++) t.push(this.getLabel(e[n])); return t; }, getLabel: function (t, e) { if (null == t) return ''; var n = e && e.precision; return ( null == n ? (n = In(t) || 0) : 'auto' === n && (n = this._intervalPrecision), (t = qm(t, n, !0)), zn(t) ); }, niceTicks: 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 = ma(i, t, e, n); (this._intervalPrecision = o.intervalPrecision), (this._interval = o.interval), (this._niceExtent = o.niceTickExtent); } }, niceExtent: function (t) { var e = this._extent; if (e[0] === e[1]) if (0 !== e[0]) { var n = e[0]; t.fixMax ? (e[0] -= n / 2) : ((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.niceTicks(t.splitNumber, t.minInterval, t.maxInterval); var r = this._interval; t.fixMin || (e[0] = qm(Math.floor(e[0] / r) * r)), t.fixMax || (e[1] = qm(Math.ceil(e[1] / r) * r)); }, }); Ym.create = function () { return new Ym(); }; var $m = Ym.prototype, Km = Math.ceil, Qm = Math.floor, Jm = function (t, e, n, i) { for (; n < i; ) { var r = (n + i) >>> 1; t[r][1] < e ? (n = r + 1) : (i = r); } return n; }, ty = Ym.extend({ type: 'time', getLabel: function (t) { var e = this._stepLvl, n = new Date(t); return Vn(e[0], n, this.getSetting('useUTC')); }, niceExtent: function (t) { var e = this._extent; if ( (e[0] === e[1] && ((e[0] -= 864e5), (e[1] += 864e5)), 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] - 864e5); } this.niceTicks(t.splitNumber, t.minInterval, t.maxInterval); var i = this._interval; t.fixMin || (e[0] = bn(Qm(e[0] / i) * i)), t.fixMax || (e[1] = bn(Km(e[1] / i) * i)); }, niceTicks: function (t, e, n) { t = t || 10; var i = this._extent, r = i[1] - i[0], o = r / t; null != e && o < e && (o = e), null != n && o > n && (o = n); var a = ey.length, s = Jm(ey, o, 0, a), l = ey[Math.min(s, a - 1)], h = l[1]; 'year' === l[0] && (h *= On(r / h / t, !0)); var u = this.getSetting('useUTC') ? 0 : 60 * new Date(+i[0] || +i[1]).getTimezoneOffset() * 1e3, c = [ Math.round(Km((i[0] - u) / h) * h + u), Math.round(Qm((i[1] - u) / h) * h + u), ]; _a(c, i), (this._stepLvl = l), (this._interval = h), (this._niceExtent = c); }, parse: function (t) { return +Dn(t); }, }); d(['contain', 'normalize'], function (t) { ty.prototype[t] = function (e) { return $m[t].call(this, this.parse(e)); }; }); var ey = [ ['hh:mm:ss', 1e3], ['hh:mm:ss', 5e3], ['hh:mm:ss', 1e4], ['hh:mm:ss', 15e3], ['hh:mm:ss', 3e4], ['hh:mm\nMM-dd', 6e4], ['hh:mm\nMM-dd', 3e5], ['hh:mm\nMM-dd', 6e5], ['hh:mm\nMM-dd', 9e5], ['hh:mm\nMM-dd', 18e5], ['hh:mm\nMM-dd', 36e5], ['hh:mm\nMM-dd', 72e5], ['hh:mm\nMM-dd', 216e5], ['hh:mm\nMM-dd', 432e5], ['MM-dd\nyyyy', 864e5], ['MM-dd\nyyyy', 1728e5], ['MM-dd\nyyyy', 2592e5], ['MM-dd\nyyyy', 3456e5], ['MM-dd\nyyyy', 432e6], ['MM-dd\nyyyy', 5184e5], ['week', 6048e5], ['MM-dd\nyyyy', 864e6], ['week', 12096e5], ['week', 18144e5], ['month', 26784e5], ['week', 36288e5], ['month', 53568e5], ['week', 36288e5], ['quarter', 8208e6], ['month', 107136e5], ['month', 13392e6], ['half-year', 16416e6], ['month', 214272e5], ['month', 26784e6], ['year', 32832e6], ]; ty.create = function (t) { return new ty({ useUTC: t.ecModel.get('useUTC') }); }; var ny = va.prototype, iy = Ym.prototype, ry = In, oy = bn, ay = Math.floor, sy = Math.ceil, ly = Math.pow, hy = Math.log, uy = va.extend({ type: 'log', base: 10, $constructor: function () { va.apply(this, arguments), (this._originalScale = new Ym()); }, getTicks: function () { var t = this._originalScale, e = this._extent, n = t.getExtent(); return f( iy.getTicks.call(this), function (i) { var r = bn(ly(this.base, i)); return ( (r = i === e[0] && t.__fixMin ? ba(r, n[0]) : r), (r = i === e[1] && t.__fixMax ? ba(r, n[1]) : r) ); }, this ); }, getLabel: iy.getLabel, scale: function (t) { return (t = ny.scale.call(this, t)), ly(this.base, t); }, setExtent: function (t, e) { var n = this.base; (t = hy(t) / hy(n)), (e = hy(e) / hy(n)), iy.setExtent.call(this, t, e); }, getExtent: function () { var t = this.base, e = ny.getExtent.call(this); (e[0] = ly(t, e[0])), (e[1] = ly(t, e[1])); var n = this._originalScale, i = n.getExtent(); return ( n.__fixMin && (e[0] = ba(e[0], i[0])), n.__fixMax && (e[1] = ba(e[1], i[1])), e ); }, unionExtent: function (t) { this._originalScale.unionExtent(t); var e = this.base; (t[0] = hy(t[0]) / hy(e)), (t[1] = hy(t[1]) / hy(e)), ny.unionExtent.call(this, t); }, unionExtentFromData: function (t, e) { this.unionExtent( t.getDataExtent(e, !0, function (t) { return t > 0; }) ); }, niceTicks: function (t) { t = t || 10; var e = this._extent, n = e[1] - e[0]; if (!(n === 1 / 0 || n <= 0)) { var i = Pn(n); for ( (t / n) * i <= 0.5 && (i *= 10); !isNaN(i) && Math.abs(i) < 1 && Math.abs(i) > 0; ) i *= 10; var r = [bn(sy(e[0] / i) * i), bn(ay(e[1] / i) * i)]; (this._interval = i), (this._niceExtent = r); } }, niceExtent: function (t) { iy.niceExtent.call(this, t); var e = this._originalScale; (e.__fixMin = t.fixMin), (e.__fixMax = t.fixMax); }, }); d(['contain', 'normalize'], function (t) { uy.prototype[t] = function (e) { return (e = hy(e) / hy(this.base)), ny[t].call(this, e); }; }), (uy.create = function () { return new uy(); }); var cy = { getFormattedLabels: function () { return Aa(this.axis, this.get('axisLabel.formatter')); }, getCategories: function () { return 'category' === this.get('type') && f(this.get('data'), ka); }, getMin: function (t) { var e = this.option, n = t || null == e.rangeStart ? e.min : e.rangeStart; return ( this.axis && null != n && 'dataMin' !== n && 'function' != typeof n && !S(n) && (n = this.axis.scale.parse(n)), n ); }, getMax: function (t) { var e = this.option, n = t || null == e.rangeEnd ? e.max : e.rangeEnd; return ( this.axis && null != n && 'dataMax' !== n && 'function' != typeof n && !S(n) && (n = this.axis.scale.parse(n)), n ); }, getNeedCrossZero: function () { var t = this.option; return null == t.rangeStart && null == t.rangeEnd && !t.scale; }, getCoordSysModel: E, setRange: function (t, e) { (this.option.rangeStart = t), (this.option.rangeEnd = e); }, resetRange: function () { this.option.rangeStart = this.option.rangeEnd = null; }, }, dy = Ri({ 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(); }, }), fy = Ri({ 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(); }, }), py = Ri({ 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, h = Math.asin(s / a), u = Math.cos(h) * a, c = Math.sin(h), d = Math.cos(h), f = 0.6 * a, p = 0.7 * a; t.moveTo(n - u, l + s), t.arc(n, l, a, Math.PI - h, 2 * Math.PI + h), t.bezierCurveTo(n + u - c * f, l + s + d * f, n, i - p, n, i), t.bezierCurveTo(n, i - p, n - u + c * f, l + s + d * f, n - u, l + s), t.closePath(); }, }), gy = Ri({ 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(); }, }), vy = { 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); }, }, my = {}; d( { line: Ug, rect: Zg, roundRect: Zg, square: Zg, circle: Eg, diamond: fy, pin: py, arrow: gy, triangle: dy, }, function (t, e) { my[e] = new t(); } ); var yy = Ri({ type: 'symbol', shape: { symbolType: '', x: 0, y: 0, width: 0, height: 0 }, beforeBrush: function () { var t = this.style; 'pin' === this.shape.symbolType && 'inside' === t.textPosition && ((t.textPosition = ['50%', '40%']), (t.textAlign = 'center'), (t.textVerticalAlign = 'middle')); }, buildPath: function (t, e, n) { var i = e.symbolType, r = my[i]; 'none' !== e.symbolType && (r || (r = my[(i = 'rect')]), vy[i](e.x, e.y, e.width, e.height, r.shape), r.buildPath(t, r.shape, n)); }, }), xy = (Object.freeze || Object)({ createList: function (t) { return da(t.get('data'), t, t.ecModel); }, createScale: function (t, e) { var n = e; e instanceof Mr || u((n = new Mr(e)), cy); var i = Ia(n); return i.setExtent(t[0], t[1]), Sa(i, n), i; }, mixinAxisModelCommonMethods: function (t) { u(t, cy); }, completeDimensions: la, createSymbol: Pa, }), _y = _n, wy = [0, 1], by = function (t, e, n) { (this.dim = t), (this.scale = e), (this._extent = n || [0, 0]), (this.inverse = !1), (this.onBand = !1), this._labelInterval; }; by.prototype = { constructor: by, 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; }, containData: function (t) { return this.contain(this.dataToCoord(t)); }, getExtent: function () { return this._extent.slice(); }, getPixelPrecision: function (t) { return Tn(t || this.scale.getExtent(), this._extent); }, setExtent: function (t, e) { var n = this._extent; (n[0] = t), (n[1] = e); }, dataToCoord: function (t, e) { var n = this._extent, i = this.scale; return ( (t = i.normalize(t)), this.onBand && 'ordinal' === i.type && La((n = n.slice()), i.count()), _y(t, wy, n, e) ); }, coordToData: function (t, e) { var n = this._extent, i = this.scale; this.onBand && 'ordinal' === i.type && La((n = n.slice()), i.count()); var r = _y(t, n, wy, e); return this.scale.scale(r); }, pointToData: function (t, e) {}, getTicksCoords: function (t) { if (this.onBand && !t) { for (var e = this.getBands(), n = [], i = 0; i < e.length; i++) n.push(e[i][0]); return e[i - 1] && n.push(e[i - 1][1]), n; } return f(this.scale.getTicks(), this.dataToCoord, this); }, getLabelsCoords: function () { return f(this.scale.getTicks(), this.dataToCoord, this); }, getBands: function () { for ( var t = this.getExtent(), e = [], n = this.scale.count(), i = t[0], r = t[1] - i, o = 0; o < n; o++ ) e.push([(r * o) / n + i, (r * (o + 1)) / n + i]); return e; }, 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; }, isHorizontal: null, getRotate: null, getLabelInterval: function () { var t = this._labelInterval; if (!t) { var e = this.model, n = e.getModel('axisLabel'); (t = n.get('interval')), 'category' !== this.type || (null != t && 'auto' !== t) || (t = Ta( f(this.scale.getTicks(), this.dataToCoord, this), e.getFormattedLabels(), n.getFont(), this.getRotate ? this.getRotate() : this.isHorizontal && !this.isHorizontal() ? 90 : 0, n.get('rotate') )), (this._labelInterval = t); } return t; }, }; var My = 1e-8; Ea.prototype = { constructor: Ea, properties: null, getBoundingRect: function () { var t = this._rect; if (t) return t; for ( var e = Number.MAX_VALUE, n = [e, e], i = [-e, -e], r = [], o = [], a = this.geometries, s = 0; s < a.length; s++ ) 'polygon' === a[s].type && (ui(a[s].exterior, r, o), Y(n, n, r), $(i, i, o)); return ( 0 === s && (n[0] = n[1] = i[0] = i[1] = 0), (this._rect = new Zt(n[0], n[1], i[0] - n[0], i[1] - n[1])) ); }, 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++) if ('polygon' === n[i].type) { var o = n[i].exterior, a = n[i].interiors; if (za(o, t[0], t[1])) { for (var s = 0; s < (a ? a.length : 0); s++) if (za(a[s])) continue t; return !0; } } return !1; }, 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 Zt(t, e, n, i), s = r.calculateTransform(a), l = this.geometries, h = 0; h < l.length; h++ ) if ('polygon' === l[h].type) { for ( var u = l[h].exterior, c = l[h].interiors, d = 0; d < u.length; d++ ) q(u[d], u[d], s); for (var f = 0; f < (c ? c.length : 0); f++) for (d = 0; d < c[f].length; d++) q(c[f][d], c[f][d], s); } (r = this._rect).copy(a), (this.center = [r.x + r.width / 2, r.y + r.height / 2]); }, }; var Sy = {}; d( [ 'map', 'each', 'filter', 'indexOf', 'inherits', 'reduce', 'filter', 'bind', 'curry', 'isArray', 'isString', 'isObject', 'isFunction', 'extend', 'defaults', 'clone', 'merge', ], function (t) { Sy[t] = Bd[t]; } ), Yv.extend({ type: 'series.line', dependencies: ['grid', 'polar'], getInitialData: function (t, e) { return da(t.data, this, e); }, defaultOption: { zlevel: 0, z: 2, coordinateSystem: 'cartesian2d', legendHoverLink: !0, hoverAnimation: !0, clipOverflow: !0, label: { normal: { position: 'top' } }, lineStyle: { normal: { width: 2, type: 'solid' } }, step: !1, smooth: !1, smoothMonotone: null, symbol: 'emptyCircle', symbolSize: 4, symbolRotate: null, showSymbol: !0, showAllSymbol: !1, connectNulls: !1, sampling: 'none', animationEasing: 'linear', progressive: 0, hoverLayerThreshold: 1 / 0, }, }); var Iy = Wa.prototype; (Iy._createSymbol = function (t, e, n, i) { this.removeAll(); var r = Pa(t, -1, -1, 2, 2, e.getItemVisual(n, 'color')); r.attr({ z2: 100, culling: !0, scale: Ga(i) }), (r.drift = Ha), (this._symbolType = t), this.add(r); }), (Iy.stopSymbolAnimation = function (t) { this.childAt(0).stopAnimation(t); }), (Iy.getSymbolPath = function () { return this.childAt(0); }), (Iy.getScale = function () { return this.childAt(0).scale; }), (Iy.highlight = function () { this.childAt(0).trigger('emphasis'); }), (Iy.downplay = function () { this.childAt(0).trigger('normal'); }), (Iy.setZ = function (t, e) { var n = this.childAt(0); (n.zlevel = t), (n.z = e); }), (Iy.setDraggable = function (t) { var e = this.childAt(0); (e.draggable = t), (e.cursor = t ? 'move' : 'pointer'); }), (Iy.updateData = function (t, e, n) { this.silent = !1; var i = t.getItemVisual(e, 'symbol') || 'circle', r = t.hostModel, o = Va(t, e), a = i !== this._symbolType; if ( (a ? this._createSymbol(i, t, e, o) : (((s = this.childAt(0)).silent = !1), gr(s, { scale: Ga(o) }, r, e)), this._updateCommon(t, e, o, n), a) ) { var s = this.childAt(0), l = n && n.fadeIn, h = { scale: s.scale.slice() }; l && (h.style = { opacity: s.style.opacity }), (s.scale = [0, 0]), l && (s.style.opacity = 0), vr(s, h, r, e); } this._seriesModel = r; }); var Ty = ['itemStyle', 'normal'], Ay = ['itemStyle', 'emphasis'], Cy = ['label', 'normal'], ky = ['label', 'emphasis']; (Iy._updateCommon = function (t, e, n, i) { var r = this.childAt(0), a = t.hostModel, s = t.getItemVisual(e, 'color'); 'image' !== r.type && r.useStyle({ strokeNoScale: !0 }); var l = i && i.itemStyle, h = i && i.hoverItemStyle, u = i && i.symbolRotate, c = i && i.symbolOffset, d = i && i.labelModel, f = i && i.hoverLabelModel, p = i && i.hoverAnimation, g = i && i.cursorStyle; if (!i || t.hasItemOption) { var v = i && i.itemModel ? i.itemModel : t.getItemModel(e); (l = v.getModel(Ty).getItemStyle(['color'])), (h = v.getModel(Ay).getItemStyle()), (u = v.getShallow('symbolRotate')), (c = v.getShallow('symbolOffset')), (d = v.getModel(Cy)), (f = v.getModel(ky)), (p = v.getShallow('hoverAnimation')), (g = v.getShallow('cursor')); } else h = o({}, h); var m = r.style; r.attr('rotation', ((u || 0) * Math.PI) / 180 || 0), c && r.attr('position', [wn(c[0], n[0]), wn(c[1], n[1])]), g && r.attr('cursor', g), r.setColor(s, i && i.symbolInnerColor), r.setStyle(l); var y = t.getItemVisual(e, 'opacity'); null != y && (m.opacity = y); var x = i && i.useNameLabel, _ = !x && Ra(t); (x || null != _) && or(m, h, d, f, { labelFetcher: a, labelDataIndex: e, defaultText: x ? t.getName(e) : t.get(_, e), isRectText: !0, autoColor: s, }), r.off('mouseover').off('mouseout').off('emphasis').off('normal'), (r.hoverStyle = h), rr(r); var w = Ga(n); if (p && a.isAnimationEnabled()) { var b = function () { var t = w[1] / w[0]; this.animateTo( { scale: [ Math.max(1.1 * w[0], w[0] + 3), Math.max(1.1 * w[1], w[1] + 3 * t), ], }, 400, 'elasticOut' ); }, M = function () { this.animateTo({ scale: w }, 400, 'elasticOut'); }; r.on('mouseover', b).on('mouseout', M).on('emphasis', b).on('normal', M); } }), (Iy.fadeOut = function (t, e) { var n = this.childAt(0); (this.silent = n.silent = !0), !(e && e.keepLabel) && (n.style.text = null), gr( n, { style: { opacity: 0 }, scale: [0, 0] }, this._seriesModel, this.dataIndex, t ); }), h(Wa, Tf); var Dy = Fa.prototype; (Dy.updateData = function (t, e) { var n = this.group, i = t.hostModel, r = this._data, o = this._symbolCtor, a = { itemStyle: i.getModel('itemStyle.normal').getItemStyle(['color']), hoverItemStyle: i.getModel('itemStyle.emphasis').getItemStyle(), symbolRotate: i.get('symbolRotate'), symbolOffset: i.get('symbolOffset'), hoverAnimation: i.get('hoverAnimation'), labelModel: i.getModel('label.normal'), hoverLabelModel: i.getModel('label.emphasis'), cursorStyle: i.get('cursor'), }; t .diff(r) .add(function (i) { var r = t.getItemLayout(i); if (Za(t, i, e)) { var s = new o(t, i, a); s.attr('position', r), t.setItemGraphicEl(i, s), n.add(s); } }) .update(function (s, l) { var h = r.getItemGraphicEl(l), u = t.getItemLayout(s); Za(t, s, e) ? (h ? (h.updateData(t, s, a), gr(h, { position: u }, i)) : (h = new o(t, s)).attr('position', u), n.add(h), t.setItemGraphicEl(s, h)) : n.remove(h); }) .remove(function (t) { var e = r.getItemGraphicEl(t); e && e.fadeOut(function () { n.remove(e); }); }) .execute(), (this._data = t); }), (Dy.updateLayout = function () { var t = this._data; t && t.eachItemGraphicEl(function (e, n) { var i = t.getItemLayout(n); e.attr('position', i); }); }), (Dy.remove = function (t) { var e = this.group, n = this._data; n && (t ? n.eachItemGraphicEl(function (t) { t.fadeOut(function () { e.remove(t); }); }) : e.removeAll()); }); var Py = function (t, e, n, i, r, o) { for ( var a = ja(t, e), s = [], l = [], h = [], u = [], c = [], d = [], f = [], p = o.dimensions, g = 0; g < a.length; g++ ) { var v = a[g], m = !0; switch (v.cmd) { case '=': var y = t.getItemLayout(v.idx), x = e.getItemLayout(v.idx1); (isNaN(y[0]) || isNaN(y[1])) && (y = x.slice()), s.push(y), l.push(x), h.push(n[v.idx]), u.push(i[v.idx1]), f.push(e.getRawIndex(v.idx1)); break; case '+': _ = v.idx; s.push(r.dataToPoint([e.get(p[0], _, !0), e.get(p[1], _, !0)])), l.push(e.getItemLayout(_).slice()), h.push(Xa(r, e, _)), u.push(i[_]), f.push(e.getRawIndex(_)); break; case '-': var _ = v.idx, w = t.getRawIndex(_); w !== _ ? (s.push(t.getItemLayout(_)), l.push(o.dataToPoint([t.get(p[0], _, !0), t.get(p[1], _, !0)])), h.push(n[_]), u.push(Xa(o, t, _)), f.push(w)) : (m = !1); } m && (c.push(v), d.push(d.length)); } d.sort(function (t, e) { return f[t] - f[e]; }); for ( var b = [], M = [], S = [], I = [], T = [], g = 0; g < d.length; g++ ) { _ = d[g]; (b[g] = s[_]), (M[g] = l[_]), (S[g] = h[_]), (I[g] = u[_]), (T[g] = c[_]); } return { current: b, next: M, stackedOnCurrent: S, stackedOnNext: I, status: T, }; }, Ly = Y, Oy = $, zy = G, Ey = B, Ny = [], By = [], Ry = [], Vy = ki.extend({ type: 'ec-polyline', shape: { points: [], smooth: 0, smoothConstraint: !0, smoothMonotone: null, connectNulls: !1, }, style: { fill: null, stroke: '#000' }, brush: Bg(ki.prototype.brush), buildPath: function (t, e) { var n = e.points, i = 0, r = n.length, o = $a(n, e.smoothConstraint); if (e.connectNulls) { for (; r > 0 && qa(n[r - 1]); r--); for (; i < r && qa(n[i]); i++); } for (; i < r; ) i += Ya( t, n, i, r, r, 1, o.min, o.max, e.smooth, e.smoothMonotone, e.connectNulls ) + 1; }, }), Gy = ki.extend({ type: 'ec-polygon', shape: { points: [], stackedOnPoints: [], smooth: 0, stackedOnSmooth: 0, smoothConstraint: !0, smoothMonotone: null, connectNulls: !1, }, brush: Bg(ki.prototype.brush), buildPath: function (t, e) { var n = e.points, i = e.stackedOnPoints, r = 0, o = n.length, a = e.smoothMonotone, s = $a(n, e.smoothConstraint), l = $a(i, e.smoothConstraint); if (e.connectNulls) { for (; o > 0 && qa(n[o - 1]); o--); for (; r < o && qa(n[r]); r++); } for (; r < o; ) { var h = Ya( t, n, r, o, o, 1, s.min, s.max, e.smooth, a, e.connectNulls ); Ya( t, i, r + h - 1, h, o, -1, l.min, l.max, e.stackedOnSmooth, a, e.connectNulls ), (r += h + 1), t.closePath(); } }, }); mo.extend({ type: 'line', init: function () { var t = new Tf(), e = new Fa(); this.group.add(e.group), (this._symbolDraw = e), (this._lineGroup = t); }, render: function (t, e, n) { var i = t.coordinateSystem, r = this.group, o = t.getData(), s = t.getModel('lineStyle.normal'), l = t.getModel('areaStyle.normal'), h = o.mapArray(o.getItemLayout, !0), u = 'polar' === i.type, c = this._coordSys, d = this._symbolDraw, f = this._polyline, p = this._polygon, g = this._lineGroup, v = t.get('animation'), m = !l.isEmpty(), y = es(i, o), x = t.get('showSymbol'), _ = x && !u && !t.get('showAllSymbol') && this._getSymbolIgnoreFunc(o, i), w = this._data; w && w.eachItemGraphicEl(function (t, e) { t.__temp && (r.remove(t), w.setItemGraphicEl(e, null)); }), x || d.remove(), r.add(g); var b = !u && t.get('step'); f && c.type === i.type && b === this._step ? (m && !p ? (p = this._newPolygon(h, y, i, v)) : p && !m && (g.remove(p), (p = this._polygon = null)), g.setClipPath(rs(i, !1, t)), x && d.updateData(o, _), o.eachItemGraphicEl(function (t) { t.stopAnimation(!0); }), (Ka(this._stackedOnPoints, y) && Ka(this._points, h)) || (v ? this._updateAnimation(o, y, i, n, b) : (b && ((h = os(h, i, b)), (y = os(y, i, b))), f.setShape({ points: h }), p && p.setShape({ points: h, stackedOnPoints: y })))) : (x && d.updateData(o, _), b && ((h = os(h, i, b)), (y = os(y, i, b))), (f = this._newPolyline(h, i, v)), m && (p = this._newPolygon(h, y, i, v)), g.setClipPath(rs(i, !0, t))); var M = as(o, i) || o.getVisual('color'); f.useStyle( a(s.getLineStyle(), { fill: 'none', stroke: M, lineJoin: 'bevel' }) ); var S = t.get('smooth'); if ( ((S = Qa(t.get('smooth'))), f.setShape({ smooth: S, smoothMonotone: t.get('smoothMonotone'), connectNulls: t.get('connectNulls'), }), p) ) { var I = o.stackedOn, T = 0; p.useStyle( a(l.getAreaStyle(), { fill: M, opacity: 0.7, lineJoin: 'bevel' }) ), I && (T = Qa(I.hostModel.get('smooth'))), p.setShape({ smooth: S, stackedOnSmooth: T, smoothMonotone: t.get('smoothMonotone'), connectNulls: t.get('connectNulls'), }); } (this._data = o), (this._coordSys = i), (this._stackedOnPoints = y), (this._points = h), (this._step = b); }, dispose: function () {}, highlight: function (t, e, n, i) { var r = t.getData(), o = zr(r, i); if (!(o instanceof Array) && null != o && o >= 0) { var a = r.getItemGraphicEl(o); if (!a) { var s = r.getItemLayout(o); if (!s) return; ((a = new Wa(r, o)).position = s), a.setZ(t.get('zlevel'), t.get('z')), (a.ignore = isNaN(s[0]) || isNaN(s[1])), (a.__temp = !0), r.setItemGraphicEl(o, a), a.stopSymbolAnimation(!0), this.group.add(a); } a.highlight(); } else mo.prototype.highlight.call(this, t, e, n, i); }, downplay: function (t, e, n, i) { var r = t.getData(), o = zr(r, i); if (null != o && o >= 0) { var a = r.getItemGraphicEl(o); a && (a.__temp ? (r.setItemGraphicEl(o, null), this.group.remove(a)) : a.downplay()); } else mo.prototype.downplay.call(this, t, e, n, i); }, _newPolyline: function (t) { var e = this._polyline; return ( e && this._lineGroup.remove(e), (e = new Vy({ shape: { points: t }, silent: !0, z2: 10 })), this._lineGroup.add(e), (this._polyline = e), e ); }, _newPolygon: function (t, e) { var n = this._polygon; return ( n && this._lineGroup.remove(n), (n = new Gy({ shape: { points: t, stackedOnPoints: e }, silent: !0 })), this._lineGroup.add(n), (this._polygon = n), n ); }, _getSymbolIgnoreFunc: function (t, e) { var n = e.getAxesByScale('ordinal')[0]; if (n && n.isLabelIgnored) return v(n.isLabelIgnored, n); }, _updateAnimation: function (t, e, n, i, r) { var o = this._polyline, a = this._polygon, s = t.hostModel, l = Py(this._data, t, this._stackedOnPoints, e, this._coordSys, n), h = l.current, u = l.stackedOnCurrent, c = l.next, d = l.stackedOnNext; r && ((h = os(l.current, n, r)), (u = os(l.stackedOnCurrent, n, r)), (c = os(l.next, n, r)), (d = os(l.stackedOnNext, n, r))), (o.shape.__points = l.current), (o.shape.points = h), gr(o, { shape: { points: c } }, s), a && (a.setShape({ points: h, stackedOnPoints: u }), gr(a, { shape: { points: c, stackedOnPoints: d } }, s)); for (var f = [], p = l.status, g = 0; g < p.length; g++) if ('=' === p[g].cmd) { var v = t.getItemGraphicEl(p[g].idx1); v && f.push({ el: v, ptIdx: g }); } o.animators && o.animators.length && o.animators[0].during(function () { for (var t = 0; t < f.length; t++) f[t].el.attr('position', o.shape.__points[f[t].ptIdx]); }); }, 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._data = null); }, }); var Wy = function (t, e, n, i, r) { i.eachRawSeriesByType(t, function (t) { var r = t.getData(), o = t.get('symbol') || e, a = t.get('symbolSize'); r.setVisual({ legendSymbol: n || o, symbol: o, symbolSize: a }), i.isSeriesFiltered(t) || ('function' == typeof a && r.each(function (e) { var n = t.getRawValue(e), i = t.getDataParams(e); r.setItemVisual(e, 'symbolSize', a(n, i)); }), r.each(function (t) { var e = r.getItemModel(t), n = e.getShallow('symbol', !0), i = e.getShallow('symbolSize', !0); null != n && r.setItemVisual(t, 'symbol', n), null != i && r.setItemVisual(t, 'symbolSize', i); })); }); }, Hy = function (t, e) { e.eachSeriesByType(t, function (t) { var e = t.getData(), n = t.coordinateSystem; if (n) { for (var i = [], r = n.dimensions, o = 0; o < r.length; o++) i.push(t.coordDimToDataDim(n.dimensions[o])[0]); 1 === i.length ? e.each(i[0], function (t, i) { e.setItemLayout(i, isNaN(t) ? [NaN, NaN] : n.dataToPoint(t)); }) : 2 === i.length && e.each( i, function (t, i, r) { e.setItemLayout( r, isNaN(t) || isNaN(i) ? [NaN, NaN] : n.dataToPoint([t, i]) ); }, !0 ); } }); }, Fy = { 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 e; }, min: function (t) { for (var e = 1 / 0, n = 0; n < t.length; n++) t[n] < e && (e = t[n]); return e; }, nearest: function (t) { return t[0]; }, }, Zy = function (t, e) { return Math.round(t.length / 2); }, Uy = function (t) { (this._axes = {}), (this._dimList = []), (this.name = t || ''); }; (Uy.prototype = { constructor: Uy, type: 'cartesian', getAxis: function (t) { return this._axes[t]; }, getAxes: function () { return f(this._dimList, ss, this); }, getAxesByScale: function (t) { return ( (t = t.toLowerCase()), g(this.getAxes(), function (e) { return e.scale.type === t; }) ); }, addAxis: function (t) { var e = t.dim; (this._axes[e] = t), this._dimList.push(e); }, dataToCoord: function (t) { return this._dataCoordConvert(t, 'dataToCoord'); }, coordToData: function (t) { return this._dataCoordConvert(t, 'coordToData'); }, _dataCoordConvert: function (t, e) { for ( var n = this._dimList, i = t instanceof Array ? [] : {}, r = 0; r < n.length; r++ ) { var o = n[r], a = this._axes[o]; i[o] = a[e](t[o]); } return i; }, }), (ls.prototype = { constructor: ls, type: 'cartesian2d', dimensions: ['x', 'y'], getBaseAxis: function () { return ( this.getAxesByScale('ordinal')[0] || this.getAxesByScale('time')[0] || this.getAxis('x') ); }, 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])) ); }, containData: function (t) { return ( this.getAxis('x').containData(t[0]) && this.getAxis('y').containData(t[1]) ); }, dataToPoint: function (t, e) { var n = this.getAxis('x'), i = this.getAxis('y'); return [ n.toGlobalCoord(n.dataToCoord(t[0], e)), i.toGlobalCoord(i.dataToCoord(t[1], e)), ]; }, pointToData: function (t, e) { var n = this.getAxis('x'), i = this.getAxis('y'); return [ n.coordToData(n.toLocalCoord(t[0]), e), i.coordToData(i.toLocalCoord(t[1]), e), ]; }, getOtherAxis: function (t) { return this.getAxis('x' === t.dim ? 'y' : 'x'); }, }), h(ls, Uy); var Xy = function (t, e, n, i, r) { by.call(this, t, e, n), (this.type = i || 'value'), (this.position = r || 'bottom'); }; (Xy.prototype = { constructor: Xy, index: 0, onZero: !1, model: null, isHorizontal: function () { var t = this.position; return 'top' === t || 'bottom' === t; }, 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 ); }, getOtherAxis: function () { this.grid.getOtherAxis(); }, isLabelIgnored: function (t) { if ('category' === this.type) { var e = this.getLabelInterval(); return ( ('function' == typeof e && !e(t, this.scale.getLabel(t))) || t % (e + 1) ); } }, pointToData: function (t, e) { return this.coordToData( this.toLocalCoord(t['x' === this.dim ? 0 : 1]), e ); }, toLocalCoord: null, toGlobalCoord: null, }), h(Xy, by); var jy = { show: !0, zlevel: 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: '#333', 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: ['#ccc'], width: 1, type: 'solid' }, }, splitArea: { show: !1, areaStyle: { color: ['rgba(250,250,250,0.3)', 'rgba(200,200,200,0.3)'], }, }, }, qy = {}; (qy.categoryAxis = i( { boundaryGap: !0, splitLine: { show: !1 }, axisTick: { alignWithLabel: !1, interval: 'auto' }, axisLabel: { interval: 'auto' }, }, jy )), (qy.valueAxis = i({ boundaryGap: [0, 0], splitNumber: 5 }, jy)), (qy.timeAxis = a( { scale: !0, min: 'dataMin', max: 'dataMax' }, qy.valueAxis )), (qy.logAxis = a({ scale: !0, logBase: 10 }, qy.valueAxis)); var Yy = ['value', 'category', 'time', 'log'], $y = function (t, e, n, o) { d(Yy, function (a) { e.extend({ type: t + 'Axis.' + a, mergeDefaultAndTheme: function (e, r) { var o = this.layoutMode, s = o ? Ur(e) : {}; i(e, r.getTheme().get(a + 'Axis')), i(e, this.getDefaultOption()), (e.type = n(t, e)), o && Zr(e, s, o); }, defaultOption: r([{}, qy[a + 'Axis'], o], !0), }); }), bv.registerSubTypeDefaulter(t + 'Axis', m(n, t)); }, Ky = bv.extend({ type: 'cartesian2dAxis', axis: null, init: function () { Ky.superApply(this, 'init', arguments), this.resetRange(); }, mergeOption: function () { Ky.superApply(this, 'mergeOption', arguments), this.resetRange(); }, restoreData: function () { Ky.superApply(this, 'restoreData', arguments), this.resetRange(); }, getCoordSysModel: function () { return this.ecModel.queryComponents({ mainType: 'grid', index: this.option.gridIndex, id: this.option.gridId, })[0]; }, }); i(Ky.prototype, cy); var Qy = { offset: 0 }; $y('x', Ky, hs, Qy), $y('y', Ky, hs, Qy), bv.extend({ type: 'grid', dependencies: ['xAxis', 'yAxis'], layoutMode: 'box', coordinateSystem: null, defaultOption: { show: !1, zlevel: 0, z: 0, left: '10%', top: 60, right: '10%', bottom: 60, containLabel: !1, backgroundColor: 'rgba(0,0,0,0)', borderWidth: 1, borderColor: '#ccc', }, }); var Jy = d, tx = function (t) { var e = t.scale.getExtent(), n = e[0], i = e[1]; return !((n > 0 && i > 0) || (n < 0 && i < 0)); }, ex = Sa, nx = fs.prototype; (nx.type = 'grid'), (nx.axisPointerEnabled = !0), (nx.getRect = function () { return this._rect; }), (nx.update = function (t, e) { var n = this._axesMap; this._updateScale(t, this.model), Jy(n.x, function (t) { ex(t.scale, t.model); }), Jy(n.y, function (t) { ex(t.scale, t.model); }), Jy(n.x, function (t) { ps(n, 'y', t); }), Jy(n.y, function (t) { ps(n, 'x', t); }), this.resize(this.model, e); }), (nx.resize = function (t, e, n) { function i() { Jy(o, function (t) { var e = t.isHorizontal(), n = e ? [0, r.width] : [0, r.height], i = t.inverse ? 1 : 0; t.setExtent(n[i], n[1 - i]), vs(t, e ? r.x : r.y); }); } var r = Hr(t.getBoxLayoutParams(), { width: e.getWidth(), height: e.getHeight(), }); this._rect = r; var o = this._axesList; i(), !n && t.get('containLabel') && (Jy(o, function (t) { if (!t.model.get('axisLabel.inside')) { var e = ds(t); if (e) { var n = t.isHorizontal() ? 'height' : 'width', i = t.model.get('axisLabel.margin'); (r[n] -= e[n] + i), 'top' === t.position ? (r.y += e.height + i) : 'left' === t.position && (r.x += e.width + i); } } }), i()); }), (nx.getAxis = function (t, e) { var n = this._axesMap[t]; if (null != n) { if (null == e) for (var i in n) if (n.hasOwnProperty(i)) return n[i]; return n[e]; } }), (nx.getAxes = function () { return this._axesList.slice(); }), (nx.getCartesian = function (t, e) { if (null != t && null != e) { var n = 'x' + t + 'y' + e; return this._coordsMap[n]; } w(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]; }), (nx.getCartesians = function () { return this._coordsList.slice(); }), (nx.convertToPixel = function (t, e, n) { var i = this._findConvertTarget(t, e); return i.cartesian ? i.cartesian.dataToPoint(n) : i.axis ? i.axis.toGlobalCoord(i.axis.dataToCoord(n)) : null; }), (nx.convertFromPixel = function (t, e, n) { var i = this._findConvertTarget(t, e); return i.cartesian ? i.cartesian.pointToData(n) : i.axis ? i.axis.coordToData(i.axis.toLocalCoord(n)) : null; }), (nx._findConvertTarget = function (t, e) { var n, i, r = e.seriesModel, o = e.xAxisModel || (r && r.getReferringComponents('xAxis')[0]), a = e.yAxisModel || (r && r.getReferringComponents('yAxis')[0]), s = e.gridModel, h = this._coordsList; return ( r ? l(h, (n = r.coordinateSystem)) < 0 && (n = null) : o && a ? (n = this.getCartesian(o.componentIndex, a.componentIndex)) : o ? (i = this.getAxis('x', o.componentIndex)) : a ? (i = this.getAxis('y', a.componentIndex)) : s && s.coordinateSystem === this && (n = this._coordsList[0]), { cartesian: n, axis: i } ); }), (nx.containPoint = function (t) { var e = this._coordsList[0]; if (e) return e.containPoint(t); }), (nx._initCartesian = function (t, e, n) { function i(n) { return function (i, s) { if (us(i, t, e)) { var l = i.get('position'); 'x' === n ? 'top' !== l && 'bottom' !== l && r[(l = 'bottom')] && (l = 'top' === l ? 'bottom' : 'top') : 'left' !== l && 'right' !== l && r[(l = 'left')] && (l = 'left' === l ? 'right' : 'left'), (r[l] = !0); var h = new Xy(n, Ia(i), [0, 0], i.get('type'), l), u = 'category' === h.type; (h.onBand = u && i.get('boundaryGap')), (h.inverse = i.get('inverse')), (h.onZero = i.get('axisLine.onZero')), (h.onZeroAxisIndex = i.get('axisLine.onZeroAxisIndex')), (i.axis = h), (h.model = i), (h.grid = this), (h.index = s), this._axesList.push(h), (o[n][s] = h), a[n]++; } }; } var r = { left: !1, right: !1, top: !1, bottom: !1 }, o = { x: {}, y: {} }, a = { x: 0, y: 0 }; if ( (e.eachComponent('xAxis', i('x'), this), e.eachComponent('yAxis', i('y'), this), !a.x || !a.y) ) return (this._axesMap = {}), void (this._axesList = []); (this._axesMap = o), Jy( o.x, function (e, n) { Jy( o.y, function (i, r) { var o = 'x' + n + 'y' + r, a = new ls(o); (a.grid = this), (a.model = t), (this._coordsMap[o] = a), this._coordsList.push(a), a.addAxis(e), a.addAxis(i); }, this ); }, this ); }), (nx._updateScale = function (t, e) { function n(t, e, n) { Jy(n.coordDimToDataDim(e.dim), function (n) { e.scale.unionExtentFromData(t, n); }); } d(this._axesList, function (t) { t.scale.setExtent(1 / 0, -1 / 0); }), t.eachSeries(function (i) { if (ys(i)) { var r = ms(i), o = r[0], a = r[1]; if (!us(o, e, t) || !us(a, e, t)) return; var s = this.getCartesian(o.componentIndex, a.componentIndex), l = i.getData(), h = s.getAxis('x'), u = s.getAxis('y'); 'list' === l.type && (n(l, h, i), n(l, u, i)); } }, this); }), (nx.getTooltipAxes = function (t) { var e = [], n = []; return ( Jy(this.getCartesians(), function (i) { var r = null != t && 'auto' !== t ? i.getAxis(t) : i.getBaseAxis(), o = i.getOtherAxis(r); l(e, r) < 0 && e.push(r), l(n, o) < 0 && n.push(o); }), { baseAxes: e, otherAxes: n } ); }); var ix = ['xAxis', 'yAxis']; (fs.create = function (t, e) { var n = []; return ( t.eachComponent('grid', function (i, r) { var o = new fs(i, t, e); (o.name = 'grid_' + r), o.resize(i, e, !0), (i.coordinateSystem = o), n.push(o); }), t.eachSeries(function (t) { if (ys(t)) { var e = ms(t), n = e[0], i = e[1], r = n.getCoordSysModel().coordinateSystem; t.coordinateSystem = r.getCartesian( n.componentIndex, i.componentIndex ); } }), n ); }), (fs.dimensions = fs.prototype.dimensions = ls.prototype.dimensions), to.register('cartesian2d', fs); var rx = Math.PI, ox = function (t, e) { (this.opt = e), (this.axisModel = t), a(e, { labelOffset: 0, nameDirection: 1, tickDirection: 1, labelDirection: 1, silent: !0, }), (this.group = new Tf()); var n = new Tf({ position: e.position.slice(), rotation: e.rotation }); n.updateTransform(), (this._transform = n.transform), (this._dumbGroup = n); }; ox.prototype = { constructor: ox, hasBuilder: function (t) { return !!ax[t]; }, add: function (t) { ax[t].call(this); }, getGroup: function () { return this.group; }, }; var ax = { axisLine: function () { var t = this.opt, e = this.axisModel; if (e.get('axisLine.show')) { var n = this.axisModel.axis.getExtent(), i = this._transform, r = [n[0], 0], a = [n[1], 0]; i && (q(r, r, i), q(a, a, i)); var s = o( { lineCap: 'round' }, e.getModel('axisLine.lineStyle').getLineStyle() ); this.group.add( new Ug( Fi({ anid: 'line', shape: { x1: r[0], y1: r[1], x2: a[0], y2: a[1] }, style: s, strokeContainThreshold: t.strokeContainThreshold || 5, silent: !0, z2: 1, }) ) ); var l = e.get('axisLine.symbol'), h = e.get('axisLine.symbolSize'); if (null != l) { 'string' == typeof l && (l = [l, l]), ('string' != typeof h && 'number' != typeof h) || (h = [h, h]); var u = h[0], c = h[1]; d( [ [t.rotation + Math.PI / 2, r], [t.rotation - Math.PI / 2, a], ], function (t, e) { if ('none' !== l[e] && null != l[e]) { var n = Pa(l[e], -u / 2, -c / 2, u, c, s.stroke, !0); n.attr({ rotation: t[0], position: t[1], silent: !0 }), this.group.add(n); } }, this ); } } }, axisTickLabel: function () { var t = this.axisModel, e = this.opt, n = Ts(this, t, e); bs(t, As(this, t, e), n); }, axisName: function () { var t = this.opt, e = this.axisModel, n = I(t.axisName, e.get('name')); if (n) { var i, r = e.get('nameLocation'), a = t.nameDirection, s = e.getModel('nameTextStyle'), l = e.get('nameGap') || 0, h = this.axisModel.axis.getExtent(), u = h[0] > h[1] ? -1 : 1, c = [ 'start' === r ? h[0] - u * l : 'end' === r ? h[1] + u * l : (h[0] + h[1]) / 2, Is(r) ? t.labelOffset + a * l : 0, ], d = e.get('nameRotate'); null != d && (d = (d * rx) / 180); var f; Is(r) ? (i = sx(t.rotation, null != d ? d : t.rotation, a)) : ((i = _s(t, r, d || 0, h)), null != (f = t.axisNameAvailableWidth) && ((f = Math.abs(f / Math.sin(i.rotation))), !isFinite(f) && (f = null))); var p = s.getFont(), g = e.get('nameTruncate', !0) || {}, v = g.ellipsis, m = I(t.nameTruncateMaxWidth, g.maxWidth, f), y = null != v && null != m ? bp(n, m, p, v, { minChar: 2, placeholder: g.placeholder }) : n, x = e.get('tooltip', !0), _ = e.mainType, w = { componentType: _, name: n, $vars: ['name'] }; w[_ + 'Index'] = e.componentIndex; var b = new zg({ anid: 'name', __fullText: n, __truncatedText: y, position: c, rotation: i.rotation, silent: ws(e), z2: 1, tooltip: x && x.show ? o( { content: n, formatter: function () { return n; }, formatterParams: w, }, x ) : null, }); ar(b.style, s, { text: y, textFont: p, textFill: s.getTextColor() || e.get('axisLine.lineStyle.color'), textAlign: i.textAlign, textVerticalAlign: i.textVerticalAlign, }), e.get('triggerEvent') && ((b.eventData = xs(e)), (b.eventData.targetType = 'axisName'), (b.eventData.name = n)), this._dumbGroup.add(b), b.updateTransform(), this.group.add(b), b.decomposeTransform(); } }, }, sx = (ox.innerTextLayout = function (t, e, n) { var i, r, o = Cn(e - t); return ( kn(o) ? ((r = n > 0 ? 'top' : 'bottom'), (i = 'center')) : kn(o - rx) ? ((r = n > 0 ? 'bottom' : 'top'), (i = 'center')) : ((r = 'middle'), (i = o > 0 && o < rx ? n > 0 ? 'right' : 'left' : n > 0 ? 'left' : 'right')), { rotation: o, textAlign: i, textVerticalAlign: r } ); }), lx = (ox.ifIgnoreOnTick = function (t, e, n, i, r, o) { if ((0 === e && r) || (e === i - 1 && o)) return !1; var a, s = t.scale; return ( 'ordinal' === s.type && ('function' == typeof n ? ((a = s.getTicks()[e]), !n(a, s.getLabel(a))) : e % (n + 1)) ); }), hx = (ox.getInterval = function (t, e) { var n = t.get('interval'); return (null != n && 'auto' != n) || (n = e), n; }), ux = d, cx = m, dx = Qo({ type: 'axis', _axisPointer: null, axisPointerClass: null, render: function (t, e, n, i) { this.axisPointerClass && zs(t), dx.superApply(this, 'render', arguments), Vs(this, t, 0, n, 0, !0); }, updateAxisPointer: function (t, e, n, i, r) { Vs(this, t, 0, n, 0, !1); }, remove: function (t, e) { var n = this._axisPointer; n && n.remove(e), dx.superApply(this, 'remove', arguments); }, dispose: function (t, e) { Gs(this, e), dx.superApply(this, 'dispose', arguments); }, }), fx = []; (dx.registerAxisPointerClass = function (t, e) { fx[t] = e; }), (dx.getAxisPointerClass = function (t) { return t && fx[t]; }); var px = ox.ifIgnoreOnTick, gx = ox.getInterval, vx = ['axisLine', 'axisTickLabel', 'axisName'], mx = ['splitArea', 'splitLine'], yx = dx.extend({ type: 'cartesianAxis', axisPointerClass: 'CartesianAxisPointer', render: function (t, e, n, i) { this.group.removeAll(); var r = this._axisGroup; if ( ((this._axisGroup = new Tf()), this.group.add(this._axisGroup), t.get('show')) ) { var o = t.getCoordSysModel(), a = Ws(o, t), s = new ox(t, a); d(vx, s.add, s), this._axisGroup.add(s.getGroup()), d( mx, function (e) { t.get(e + '.show') && this['_' + e](t, o, a.labelInterval); }, this ), _r(r, this._axisGroup, t), yx.superCall(this, 'render', t, e, n, i); } }, _splitLine: function (t, e, n) { var i = t.axis; if (!i.scale.isBlank()) { var r = t.getModel('splitLine'), o = r.getModel('lineStyle'), s = o.get('color'), l = gx(r, n); s = y(s) ? s : [s]; for ( var h = e.coordinateSystem.getRect(), u = i.isHorizontal(), c = 0, d = i.getTicksCoords(), f = i.scale.getTicks(), p = t.get('axisLabel.showMinLabel'), g = t.get('axisLabel.showMaxLabel'), v = [], m = [], x = o.getLineStyle(), _ = 0; _ < d.length; _++ ) if (!px(i, _, l, d.length, p, g)) { var w = i.toGlobalCoord(d[_]); u ? ((v[0] = w), (v[1] = h.y), (m[0] = w), (m[1] = h.y + h.height)) : ((v[0] = h.x), (v[1] = w), (m[0] = h.x + h.width), (m[1] = w)); var b = c++ % s.length; this._axisGroup.add( new Ug( Fi({ anid: 'line_' + f[_], shape: { x1: v[0], y1: v[1], x2: m[0], y2: m[1] }, style: a({ stroke: s[b] }, x), silent: !0, }) ) ); } } }, _splitArea: function (t, e, n) { var i = t.axis; if (!i.scale.isBlank()) { var r = t.getModel('splitArea'), o = r.getModel('areaStyle'), s = o.get('color'), l = e.coordinateSystem.getRect(), h = i.getTicksCoords(), u = i.scale.getTicks(), c = i.toGlobalCoord(h[0]), d = i.toGlobalCoord(h[0]), f = 0, p = gx(r, n), g = o.getAreaStyle(); s = y(s) ? s : [s]; for ( var v = t.get('axisLabel.showMinLabel'), m = t.get('axisLabel.showMaxLabel'), x = 1; x < h.length; x++ ) if (!px(i, x, p, h.length, v, m)) { var _, w, b, M, S = i.toGlobalCoord(h[x]); i.isHorizontal() ? ((_ = c), (w = l.y), (b = S - _), (M = l.height)) : ((_ = l.x), (w = d), (b = l.width), (M = S - w)); var I = f++ % s.length; this._axisGroup.add( new Zg({ anid: 'area_' + u[x], shape: { x: _, y: w, width: b, height: M }, style: a({ fill: s[I] }, g), silent: !0, }) ), (c = _ + b), (d = w + M); } } }, }); yx.extend({ type: 'xAxis' }), yx.extend({ type: 'yAxis' }), Qo({ type: 'grid', render: function (t, e) { this.group.removeAll(), t.get('show') && this.group.add( new Zg({ shape: t.coordinateSystem.getRect(), style: a({ fill: t.get('backgroundColor') }, t.getItemStyle()), silent: !0, z2: -1, }) ); }, }), Uo(function (t) { t.xAxis && t.yAxis && !t.grid && (t.grid = {}); }), Yo(m(Wy, 'line', 'circle', 'line')), qo(m(Hy, 'line')), Xo( hm.PROCESSOR.STATISTIC, m(function (t, e, n) { e.eachSeriesByType( t, function (t) { var e = t.getData(), n = t.get('sampling'), i = t.coordinateSystem; if ('cartesian2d' === i.type && n) { var r = i.getBaseAxis(), o = i.getOtherAxis(r), a = r.getExtent(), s = a[1] - a[0], l = Math.round(e.count() / s); if (l > 1) { var h; 'string' == typeof n ? (h = Fy[n]) : 'function' == typeof n && (h = n), h && ((e = e.downSample(o.dim, 1 / l, h, Zy)), t.setData(e)); } } }, this ); }, 'line') ); var xx = '__ec_stack_'; (Xs.getLayoutOnAxis = function (t, e) { var n = [], i = t.axis; if ('category' === i.type) { for (var r = i.getBandWidth(), o = 0; o < t.count; o++) n.push(a({ bandWidth: r, axisKey: 'axis0', stackId: xx + o }, t)); for (var s = Us(n), l = [], o = 0; o < t.count; o++) { var h = s.axis0[xx + o]; (h.offsetCenter = h.offset + h.width / 2), l.push(h); } return l; } }), Yv.extend({ type: 'series.__base_bar__', getInitialData: function (t, e) { return da(t.data, this, e); }, getMarkerPosition: function (t) { var e = this.coordinateSystem; if (e) { var n = e.dataToPoint(t, !0), 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]; }, defaultOption: { zlevel: 0, z: 2, coordinateSystem: 'cartesian2d', legendHoverLink: !0, barMinHeight: 0, barMinAngle: 0, itemStyle: {}, }, }).extend({ type: 'series.bar', dependencies: ['grid', 'polar'], brushSelector: 'rect', }); var _x = Cp([ ['fill', 'color'], ['stroke', 'borderColor'], ['lineWidth', 'borderWidth'], ['stroke', 'barBorderColor'], ['lineWidth', 'barBorderWidth'], ['opacity'], ['shadowBlur'], ['shadowOffsetX'], ['shadowOffsetY'], ['shadowColor'], ]), wx = { getBarItemStyle: function (t) { var e = _x(this, t); if (this.getBorderLineDash) { var n = this.getBorderLineDash(); n && (e.lineDash = n); } return e; }, }, bx = ['itemStyle', 'normal', 'barBorderWidth']; o(Mr.prototype, wx), ta({ type: 'bar', render: function (t, e, n) { var i = t.get('coordinateSystem'); return ( ('cartesian2d' !== i && 'polar' !== i) || this._render(t, e, n), this.group ); }, dispose: E, _render: function (t, e, n) { var i, r = this.group, o = t.getData(), a = this._data, s = t.coordinateSystem, l = s.getBaseAxis(); 'cartesian2d' === s.type ? (i = l.isHorizontal()) : 'polar' === s.type && (i = 'angle' === l.dim); var h = t.isAnimationEnabled() ? t : null; o .diff(a) .add(function (e) { if (o.hasValue(e)) { var n = o.getItemModel(e), a = Sx[s.type](o, e, n), l = Mx[s.type](o, e, n, a, i, h); o.setItemGraphicEl(e, l), r.add(l), Ks(l, o, e, n, a, t, i, 'polar' === s.type); } }) .update(function (e, n) { var l = a.getItemGraphicEl(n); if (o.hasValue(e)) { var u = o.getItemModel(e), c = Sx[s.type](o, e, u); l ? gr(l, { shape: c }, h, e) : (l = Mx[s.type](o, e, u, c, i, h, !0)), o.setItemGraphicEl(e, l), r.add(l), Ks(l, o, e, u, c, t, i, 'polar' === s.type); } else r.remove(l); }) .remove(function (t) { var e = a.getItemGraphicEl(t); 'cartesian2d' === s.type ? e && Ys(t, h, e) : e && $s(t, h, e); }) .execute(), (this._data = o); }, remove: function (t, e) { var n = this.group, i = this._data; t.get('animation') ? i && i.eachItemGraphicEl(function (e) { 'sector' === e.type ? $s(e.dataIndex, t, e) : Ys(e.dataIndex, t, e); }) : n.removeAll(); }, }); var Mx = { cartesian2d: function (t, e, n, i, r, a, s) { var l = new Zg({ shape: o({}, i) }); if (a) { var h = l.shape, u = r ? 'height' : 'width', c = {}; (h[u] = 0), (c[u] = i[u]), iv[s ? 'updateProps' : 'initProps'](l, { shape: c }, a, e); } return l; }, polar: function (t, e, n, i, r, a, s) { var l = new Rg({ shape: o({}, i) }); if (a) { var h = l.shape, u = r ? 'r' : 'endAngle', c = {}; (h[u] = r ? 0 : i.startAngle), (c[u] = i[u]), iv[s ? 'updateProps' : 'initProps'](l, { shape: c }, a, e); } return l; }, }, Sx = { cartesian2d: function (t, e, n) { var i = t.getItemLayout(e), r = Qs(n, i), 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, }; }, }; qo(m(Xs, 'bar')), Yo(function (t) { t.eachSeriesByType('bar', function (t) { t.getData().setVisual('legendSymbol', 'roundRect'); }); }); var Ix = { updateSelectedMap: function (t) { (this._targetList = t.slice()), (this._selectTargetMap = p( t || [], function (t, e) { return t.set(e.name, e), t; }, z() )); }, select: function (t, e) { var n = null != e ? this._targetList[e] : this._selectTargetMap.get(t); 'single' === this.get('selectedMode') && this._selectTargetMap.each(function (t) { t.selected = !1; }), n && (n.selected = !0); }, unSelect: function (t, e) { var n = null != e ? this._targetList[e] : this._selectTargetMap.get(t); n && (n.selected = !1); }, toggleSelected: function (t, e) { var n = null != e ? this._targetList[e] : this._selectTargetMap.get(t); if (null != n) return this[n.selected ? 'unSelect' : 'select'](t, e), n.selected; }, isSelected: function (t, e) { var n = null != e ? this._targetList[e] : this._selectTargetMap.get(t); return n && n.selected; }, }, Tx = Jo({ type: 'series.pie', init: function (t) { Tx.superApply(this, 'init', arguments), (this.legendDataProvider = function () { return this.getRawData(); }), this.updateSelectedMap(t.data), this._defaultLabelLine(t); }, mergeOption: function (t) { Tx.superCall(this, 'mergeOption', t), this.updateSelectedMap(this.option.data); }, getInitialData: function (t, e) { var n = la(['value'], t.data), i = new Nm(n, this); return i.initData(t.data), i; }, getDataParams: function (t) { var e = this.getData(), n = Tx.superCall(this, 'getDataParams', t), i = []; return ( e.each('value', function (t) { i.push(t); }), (n.percent = An(i, t, e.hostModel.get('percentPrecision'))), n.$vars.push('percent'), n ); }, _defaultLabelLine: function (t) { Ar(t.labelLine, ['show']); var e = t.labelLine.normal, n = t.labelLine.emphasis; (e.show = e.show && t.label.normal.show), (n.show = n.show && t.label.emphasis.show); }, defaultOption: { zlevel: 0, z: 2, legendHoverLink: !0, hoverAnimation: !0, center: ['50%', '50%'], radius: [0, '75%'], clockwise: !0, startAngle: 90, minAngle: 0, selectedOffset: 10, hoverOffset: 10, avoidLabelOverlap: !0, percentPrecision: 2, stillShowZeroSum: !0, label: { normal: { rotate: !1, show: !0, position: 'outer' }, emphasis: {}, }, labelLine: { normal: { show: !0, length: 15, length2: 15, smooth: !1, lineStyle: { width: 1, type: 'solid' }, }, }, itemStyle: { normal: { borderWidth: 1 }, emphasis: {} }, animationType: 'expansion', animationEasing: 'cubicOut', data: [], }, }); u(Tx, Ix); var Ax = el.prototype; (Ax.updateData = function (t, e, n) { function i() { s.stopAnimation(!0), s.animateTo( { shape: { r: u.r + l.get('hoverOffset') } }, 300, 'elasticOut' ); } function r() { s.stopAnimation(!0), s.animateTo({ shape: { r: u.r } }, 300, 'elasticOut'); } var s = this.childAt(0), l = t.hostModel, h = t.getItemModel(e), u = t.getItemLayout(e), c = o({}, u); (c.label = null), n ? (s.setShape(c), 'scale' === l.getShallow('animationType') ? ((s.shape.r = u.r0), vr(s, { shape: { r: u.r } }, l, e)) : ((s.shape.endAngle = u.startAngle), gr(s, { shape: { endAngle: u.endAngle } }, l, e))) : gr(s, { shape: c }, l, e); var d = h.getModel('itemStyle'), f = t.getItemVisual(e, 'color'); s.useStyle( a({ lineJoin: 'bevel', fill: f }, d.getModel('normal').getItemStyle()) ), (s.hoverStyle = d.getModel('emphasis').getItemStyle()); var p = h.getShallow('cursor'); p && s.attr('cursor', p), tl( this, t.getItemLayout(e), h.get('selected'), l.get('selectedOffset'), l.get('animation') ), s.off('mouseover').off('mouseout').off('emphasis').off('normal'), h.get('hoverAnimation') && l.isAnimationEnabled() && s .on('mouseover', i) .on('mouseout', r) .on('emphasis', i) .on('normal', r), this._updateLabel(t, e), rr(this); }), (Ax._updateLabel = function (t, e) { var n = this.childAt(1), i = this.childAt(2), r = t.hostModel, o = t.getItemModel(e), a = t.getItemLayout(e).label, s = t.getItemVisual(e, 'color'); gr( n, { shape: { points: a.linePoints || [ [a.x, a.y], [a.x, a.y], [a.x, a.y], ], }, }, r, e ), gr(i, { style: { x: a.x, y: a.y } }, r, e), i.attr({ rotation: a.rotation, origin: [a.x, a.y], z2: 10 }); var l = o.getModel('label.normal'), h = o.getModel('label.emphasis'), u = o.getModel('labelLine.normal'), c = o.getModel('labelLine.emphasis'), s = t.getItemVisual(e, 'color'); or( i.style, (i.hoverStyle = {}), l, h, { labelFetcher: t.hostModel, labelDataIndex: e, defaultText: t.getName(e), autoColor: s, useInsideStyle: !!a.inside, }, { textAlign: a.textAlign, textVerticalAlign: a.verticalAlign, opacity: t.getItemVisual(e, 'opacity'), } ), (i.ignore = i.normalIgnore = !l.get('show')), (i.hoverIgnore = !h.get('show')), (n.ignore = n.normalIgnore = !u.get('show')), (n.hoverIgnore = !c.get('show')), n.setStyle({ stroke: s, opacity: t.getItemVisual(e, 'opacity') }), n.setStyle(u.getModel('lineStyle').getLineStyle()), (n.hoverStyle = c.getModel('lineStyle').getLineStyle()); var d = u.get('smooth'); d && !0 === d && (d = 0.4), n.setShape({ smooth: d }); }), h(el, Tf); mo.extend({ type: 'pie', init: function () { var t = new Tf(); this._sectorGroup = t; }, render: function (t, e, n, i) { if (!i || i.from !== this.uid) { var r = t.getData(), o = this._data, a = this.group, s = e.get('animation'), l = !o, h = t.get('animationType'), u = m(Js, this.uid, t, s, n), c = t.get('selectedMode'); if ( (r .diff(o) .add(function (t) { var e = new el(r, t); l && 'scale' !== h && e.eachChild(function (t) { t.stopAnimation(!0); }), c && e.on('click', u), r.setItemGraphicEl(t, e), a.add(e); }) .update(function (t, e) { var n = o.getItemGraphicEl(e); n.updateData(r, t), n.off('click'), c && n.on('click', u), a.add(n), r.setItemGraphicEl(t, n); }) .remove(function (t) { var e = o.getItemGraphicEl(t); a.remove(e); }) .execute(), s && l && r.count() > 0 && 'scale' !== h) ) { var d = r.getItemLayout(0), f = Math.max(n.getWidth(), n.getHeight()) / 2, p = v(a.removeClipPath, a); a.setClipPath( this._createClipPath(d.cx, d.cy, f, d.startAngle, d.clockwise, p, t) ); } this._data = r; } }, dispose: function () {}, _createClipPath: function (t, e, n, i, r, o, a) { var s = new Rg({ shape: { cx: t, cy: e, r0: 0, r: n, startAngle: i, endAngle: i, clockwise: r, }, }); return ( vr(s, { shape: { endAngle: i + (r ? 1 : -1) * Math.PI * 2 } }, a, o), s ); }, 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; } }, }); var Cx = function (t, e, n, i) { var r, o, a = t.getData(), s = [], l = !1; a.each(function (n) { var i, h, u, c, d = a.getItemLayout(n), f = a.getItemModel(n), p = f.getModel('label.normal'), g = p.get('position') || f.get('label.emphasis.position'), v = f.getModel('labelLine.normal'), m = v.get('length'), y = v.get('length2'), x = (d.startAngle + d.endAngle) / 2, _ = Math.cos(x), w = Math.sin(x); (r = d.cx), (o = d.cy); var b = 'inside' === g || 'inner' === g; if ('center' === g) (i = d.cx), (h = d.cy), (c = 'center'); else { var M = (b ? ((d.r + d.r0) / 2) * _ : d.r * _) + r, S = (b ? ((d.r + d.r0) / 2) * w : d.r * w) + o; if (((i = M + 3 * _), (h = S + 3 * w), !b)) { var I = M + _ * (m + e - d.r), T = S + w * (m + e - d.r), A = I + (_ < 0 ? -1 : 1) * y, C = T; (i = A + (_ < 0 ? -5 : 5)), (h = C), (u = [ [M, S], [I, T], [A, C], ]); } c = b ? 'center' : _ > 0 ? 'left' : 'right'; } var k = p.getFont(), D = p.get('rotate') ? (_ < 0 ? -x + Math.PI : -x) : 0, P = he(t.getFormattedLabel(n, 'normal') || a.getName(n), k, c, 'top'); (l = !!D), (d.label = { x: i, y: h, position: g, height: P.height, len: m, len2: y, linePoints: u, textAlign: c, verticalAlign: 'middle', rotation: D, inside: b, }), b || s.push(d.label); }), !l && t.get('avoidLabelOverlap') && il(s, r, o, e, n, i); }, kx = 2 * Math.PI, Dx = Math.PI / 180; !(function (t, e) { d(e, function (e) { (e.update = 'updateView'), jo(e, function (n, i) { var r = {}; return ( i.eachComponent( { mainType: 'series', subType: t, query: n }, function (t) { t[e.method] && t[e.method](n.name, n.dataIndex); var i = t.getData(); i.each(function (e) { var n = i.getName(e); r[n] = t.isSelected(n) || !1; }); } ), { name: n.name, selected: r } ); }); }); })('pie', [ { type: 'pieToggleSelect', event: 'pieselectchanged', method: 'toggleSelected', }, { type: 'pieSelect', event: 'pieselected', method: 'select' }, { type: 'pieUnSelect', event: 'pieunselected', method: 'unSelect' }, ]), Yo( m(function (t, e) { var n = {}; e.eachRawSeriesByType(t, function (t) { var i = t.getRawData(), r = {}; if (!e.isSeriesFiltered(t)) { var o = t.getData(); o.each(function (t) { var e = o.getRawIndex(t); r[e] = t; }), i.each(function (e) { var a = r[e], s = null != a && o.getItemVisual(a, 'color', !0); if (s) i.setItemVisual(e, 'color', s); else { var l = i.getItemModel(e).get('itemStyle.normal.color') || t.getColorFromPalette(i.getName(e), n); i.setItemVisual(e, 'color', l), null != a && o.setItemVisual(a, 'color', l); } }); } }); }, 'pie') ), qo( m(function (t, e, n, i) { 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 = wn(e[0], r), l = wn(e[1], o), h = wn(i[0], a / 2), u = wn(i[1], a / 2), c = t.getData(), d = -t.get('startAngle') * Dx, f = t.get('minAngle') * Dx, p = 0; c.each('value', function (t) { !isNaN(t) && p++; }); var g = c.getSum('value'), v = (Math.PI / (g || p)) * 2, m = t.get('clockwise'), x = t.get('roseType'), _ = t.get('stillShowZeroSum'), w = c.getDataExtent('value'); w[0] = 0; var b = kx, M = 0, S = d, I = m ? 1 : -1; if ( (c.each( 'value', function (t, e) { var n; if (isNaN(t)) c.setItemLayout(e, { angle: NaN, startAngle: NaN, endAngle: NaN, clockwise: m, cx: s, cy: l, r0: h, r: x ? NaN : u, }); else { (n = 'area' !== x ? (0 === g && _ ? v : t * v) : kx / p) < f ? ((n = f), (b -= f)) : (M += t); var i = S + I * n; c.setItemLayout(e, { angle: n, startAngle: S, endAngle: i, clockwise: m, cx: s, cy: l, r0: h, r: x ? _n(t, w, [h, u]) : u, }), (S = i); } }, !0 ), b < kx && p) ) if (b <= 0.001) { var T = kx / p; c.each('value', function (t, e) { if (!isNaN(t)) { var n = c.getItemLayout(e); (n.angle = T), (n.startAngle = d + I * e * T), (n.endAngle = d + I * (e + 1) * T); } }); } else (v = b / M), (S = d), c.each('value', function (t, e) { if (!isNaN(t)) { var n = c.getItemLayout(e), i = n.angle === f ? f : t * v; (n.startAngle = S), (n.endAngle = S + I * i), (S += I * i); } }); Cx(t, u, r, o); }); }, 'pie') ), Xo( m(function (t, e) { var n = e.findComponents({ mainType: 'legend' }); n && n.length && e.eachSeriesByType( t, function (t) { var e = t.getData(); e.filterSelf(function (t) { for (var i = e.getName(t), r = 0; r < n.length; r++) if (!n[r].isSelected(i)) return !1; return !0; }, this); }, this ); }, 'pie') ), Yv.extend({ type: 'series.scatter', dependencies: ['grid', 'polar', 'geo', 'singleAxis', 'calendar'], getInitialData: function (t, e) { return da(t.data, this, e); }, brushSelector: 'point', defaultOption: { coordinateSystem: 'cartesian2d', zlevel: 0, z: 2, legendHoverLink: !0, hoverAnimation: !0, symbolSize: 10, large: !1, largeThreshold: 2e3, itemStyle: { normal: { opacity: 0.8 } }, }, }); var Px = Ri({ shape: { points: null, sizes: null }, symbolProxy: null, buildPath: function (t, e) { for ( var n = e.points, i = e.sizes, r = this.symbolProxy, o = r.shape, a = 0; a < n.length; a++ ) { var s = n[a]; if (!isNaN(s[0]) && !isNaN(s[1])) { var l = i[a]; l[0] < 4 ? t.rect(s[0] - l[0] / 2, s[1] - l[1] / 2, l[0], l[1]) : ((o.x = s[0] - l[0] / 2), (o.y = s[1] - l[1] / 2), (o.width = l[0]), (o.height = l[1]), r.buildPath(t, o, !0)); } } }, findDataIndex: function (t, e) { for ( var n = this.shape, i = n.points, r = n.sizes, o = i.length - 1; o >= 0; o-- ) { var a = i[o], s = r[o], l = a[0] - s[0] / 2, h = a[1] - s[1] / 2; if (t >= l && e >= h && t <= l + s[0] && e <= h + s[1]) return o; } return -1; }, }), Lx = rl.prototype; (Lx.updateData = function (t) { this.group.removeAll(); var e = this._symbolEl, n = t.hostModel; e.setShape({ points: t.mapArray(t.getItemLayout), sizes: t.mapArray(function (e) { var n = t.getItemVisual(e, 'symbolSize'); return n instanceof Array || (n = [n, n]), n; }), }), (e.symbolProxy = Pa(t.getVisual('symbol'), 0, 0, 0, 0)), (e.setColor = e.symbolProxy.setColor), e.useStyle(n.getModel('itemStyle.normal').getItemStyle(['color'])); var i = t.getVisual('color'); i && e.setColor(i), (e.seriesIndex = n.seriesIndex), e.on('mousemove', function (t) { e.dataIndex = null; var n = e.findDataIndex(t.offsetX, t.offsetY); n >= 0 && (e.dataIndex = n); }), this.group.add(e); }), (Lx.updateLayout = function (t) { var e = t.getData(); this._symbolEl.setShape({ points: e.mapArray(e.getItemLayout) }); }), (Lx.remove = function () { this.group.removeAll(); }), ta({ type: 'scatter', init: function () { (this._normalSymbolDraw = new Fa()), (this._largeSymbolDraw = new rl()); }, render: function (t, e, n) { var i = t.getData(), r = this._largeSymbolDraw, o = this._normalSymbolDraw, a = this.group, s = t.get('large') && i.count() > t.get('largeThreshold') ? r : o; (this._symbolDraw = s), s.updateData(i), a.add(s.group), a.remove(s === r ? o.group : r.group); }, updateLayout: function (t) { this._symbolDraw.updateLayout(t); }, remove: function (t, e) { this._symbolDraw && this._symbolDraw.remove(e, !0); }, dispose: function () {}, }), Yo(m(Wy, 'scatter', 'circle', null)), qo(m(Hy, 'scatter')), Uo(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] }]); }); var Ox = Ko({ type: 'graphic', defaultOption: { elements: [], parentId: null }, _elOptionsToUpdate: null, mergeOption: function (t) { var e = this.option.elements; (this.option.elements = null), Ox.superApply(this, 'mergeOption', arguments), (this.option.elements = e); }, optionUpdated: function (t, e) { var n = this.option, i = (e ? n : t).elements, r = (n.elements = e ? [] : n.elements), o = []; this._flatten(i, o); var a = Pr(r, o); Lr(a); var s = (this._elOptionsToUpdate = []); d( a, function (t, e) { var n = t.option; n && (s.push(n), hl(t, n), ul(r, e, n), cl(r[e], n)); }, this ); for (var l = r.length - 1; l >= 0; l--) null == r[l] ? r.splice(l, 1) : delete r[l].$action; }, _flatten: function (t, e, n) { d( 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 ); }, useElOptionsToUpdate: function () { var t = this._elOptionsToUpdate; return (this._elOptionsToUpdate = null), t; }, }); Qo({ type: 'graphic', init: function (t, e) { (this._elMap = z()), this._lastGraphicModel; }, render: function (t, e, n) { t !== this._lastGraphicModel && this._clear(), (this._lastGraphicModel = t), this._updateElements(t, n), this._relocate(t, n); }, _updateElements: function (t, e) { var n = t.useElOptionsToUpdate(); if (n) { var i = this._elMap, r = this.group; d(n, function (t) { var e = t.$action, n = t.id, o = i.get(n), a = t.parentId, s = null != a ? i.get(a) : r; if ('text' === t.type) { var l = t.style; t.hv && t.hv[1] && (l.textVerticalAlign = l.textBaseline = null), !l.hasOwnProperty('textFill') && l.fill && (l.textFill = l.fill), !l.hasOwnProperty('textStroke') && l.stroke && (l.textStroke = l.stroke); } var h = sl(t); e && 'merge' !== e ? 'replace' === e ? (al(o, i), ol(n, s, h, i)) : 'remove' === e && al(o, i) : o ? o.attr(h) : ol(n, s, h, i); var u = i.get(n); u && ((u.__ecGraphicWidth = t.width), (u.__ecGraphicHeight = t.height)); }); } }, _relocate: function (t, e) { for ( var n = t.option.elements, i = this.group, r = this._elMap, o = n.length - 1; o >= 0; o-- ) { var a = n[o], s = r.get(a.id); if (s) { var l = s.parent; Fr( s, a, l === i ? { width: e.getWidth(), height: e.getHeight() } : { width: l.__ecGraphicWidth || 0, height: l.__ecGraphicHeight || 0, }, null, { hv: a.hv, boundingMode: a.bounding } ); } } }, _clear: function () { var t = this._elMap; t.each(function (e) { al(e, t); }), (this._elMap = z()); }, dispose: function () { this._clear(); }, }); var zx = function (t, e) { var n, i = [], r = t.seriesIndex; if (null == r || !(n = e.getSeriesByIndex(r))) return { point: [] }; var o = n.getData(), a = zr(o, t); if (null == a || y(a)) return { point: [] }; var s = o.getItemGraphicEl(a), l = n.coordinateSystem; if (n.getTooltipPosition) i = n.getTooltipPosition(a) || []; else if (l && l.dataToPoint) i = l.dataToPoint( o.getValues( f(l.dimensions, function (t) { return n.coordDimToDataDim(t)[0]; }), a, !0 ) ) || []; else if (s) { var h = s.getBoundingRect().clone(); h.applyTransform(s.transform), (i = [h.x + h.width / 2, h.y + h.height / 2]); } return { point: i, el: s }; }, Ex = d, Nx = m, Bx = fv(), Rx = (Ko({ type: 'axisPointer', coordSysAxesInfo: null, defaultOption: { show: 'auto', triggerOn: null, zlevel: 0, z: 50, type: 'line', snap: !1, triggerTooltip: !0, value: null, status: null, link: [], animation: null, animationDurationUpdate: 200, lineStyle: { color: '#aaa', width: 1, type: 'solid' }, shadowStyle: { color: 'rgba(150,150,150,0.3)' }, label: { show: !0, formatter: null, precision: 'auto', margin: 3, color: '#fff', padding: [5, 7, 5, 7], backgroundColor: 'auto', borderColor: null, borderWidth: 0, shadowBlur: 3, shadowColor: '#aaa', }, 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, }, }, }), fv()), Vx = d, Gx = Qo({ type: 'axisPointer', render: function (t, e, n) { var i = e.getComponent('tooltip'), r = t.get('triggerOn') || (i && i.get('triggerOn')) || 'mousemove|click'; bl('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, }); }); }, remove: function (t, e) { Cl(e.getZr(), 'axisPointer'), Gx.superApply(this._model, 'remove', arguments); }, dispose: function (t, e) { Cl('axisPointer', e), Gx.superApply(this._model, 'dispose', arguments); }, }), Wx = fv(), Hx = n, Fx = v; ((kl.prototype = { _group: null, _lastGraphicKey: null, _handle: null, _dragging: !1, _lastValue: null, _lastStatus: null, _payloadInfo: null, animationThreshold: 15, 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 h = l.graphicKey; h !== this._lastGraphicKey && this.clear(n), (this._lastGraphicKey = h); var u = (this._moveAnimation = this.determineAnimation(t, e)); if (a) { var c = m(Dl, e, u); this.updatePointerEl(a, l, c, e), this.updateLabelEl(a, l, c, e); } else (a = this._group = new Tf()), this.createPointerEl(a, l, t, e), this.createLabelEl(a, l, t, e), n.getZr().add(a); zl(a, e, !0), this._renderHandle(r); } }, remove: function (t) { this.clear(t); }, dispose: function (t) { this.clear(t); }, 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 = Es(t).seriesDataCount, l = i.getExtent(); return Math.abs(l[0] - l[1]) / s > a; } return !1; } return !0 === n; }, makeElOption: function (t, e, n, i, r) {}, createPointerEl: function (t, e, n, i) { var r = e.pointer; if (r) { var o = (Wx(t).pointerEl = new iv[r.type](Hx(e.pointer))); t.add(o); } }, createLabelEl: function (t, e, n, i) { if (e.label) { var r = (Wx(t).labelEl = new Zg(Hx(e.label))); t.add(r), Ll(r, i); } }, updatePointerEl: function (t, e, n) { var i = Wx(t).pointerEl; i && (i.setStyle(e.pointer.style), n(i, { shape: e.pointer.shape })); }, updateLabelEl: function (t, e, n, i) { var r = Wx(t).labelEl; r && (r.setStyle(e.label.style), n(r, { shape: e.label.shape, position: e.label.position }), Ll(r, i)); }, _renderHandle: function (t) { if (!this._dragging && this.updateHandleTransform) { var e = this._axisPointerModel, n = this._api.getZr(), i = this._handle, r = e.getModel('handle'), o = e.get('status'); if (!r.get('show') || !o || 'hide' === o) return i && n.remove(i), void (this._handle = null); var a; this._handle || ((a = !0), (i = this._handle = br(r.get('icon'), { cursor: 'move', draggable: !0, onmousemove: function (t) { tp(t.event); }, onmousedown: Fx(this._onHandleDragMove, this, 0, 0), drift: Fx(this._onHandleDragMove, this), ondragend: Fx(this._onHandleDragEnd, this), })), n.add(i)), zl(i, e, !1); var s = [ 'color', 'borderColor', 'borderWidth', 'opacity', 'shadowColor', 'shadowBlur', 'shadowOffsetX', 'shadowOffsetY', ]; i.setStyle(r.getItemStyle(null, s)); var l = r.get('size'); y(l) || (l = [l, l]), i.attr('scale', [l[0] / 2, l[1] / 2]), wo(this, '_doDispatchAxisPointer', r.get('throttle') || 0, 'fixRate'), this._moveHandleToValue(t, a); } }, _moveHandleToValue: function (t, e) { Dl( this._axisPointerModel, !e && this._moveAnimation, this._handle, Ol(this.getHandleTransform(t, this._axisModel, this._axisPointerModel)) ); }, _onHandleDragMove: function (t, e) { var n = this._handle; if (n) { this._dragging = !0; var i = this.updateHandleTransform( Ol(n), [t, e], this._axisModel, this._axisPointerModel ); (this._payloadInfo = i), n.stopAnimation(), n.attr(Ol(i)), (Wx(n).lastProp = null), this._doDispatchAxisPointer(); } }, _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 }], }); } }, _onHandleDragEnd: function (t) { if (((this._dragging = !1), this._handle)) { var e = this._axisPointerModel.get('value'); this._moveHandleToValue(e), this._api.dispatchAction({ type: 'hideTip' }); } }, getHandleTransform: null, updateHandleTransform: null, 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)); }, doClear: function () {}, buildLabel: function (t, e, n) { return ( (n = n || 0), { x: t[n], y: t[1 - n], width: e[n], height: e[1 - n] } ); }, }).constructor = kl), Xn(kl); var Zx = kl.extend({ makeElOption: function (t, e, n, i, r) { var o = n.axis, a = o.grid, s = i.get('type'), l = Fl(a, o).getOtherAxis(o).getGlobalExtent(), h = o.toGlobalCoord(o.dataToCoord(e, !0)); if (s && 'none' !== s) { var u = El(i), c = Ux[s](o, h, l, u); (c.style = u), (t.graphicKey = c.type), (t.pointer = c); } Gl(e, t, Ws(a.model, n), n, i, r); }, getHandleTransform: function (t, e, n) { var i = Ws(e.axis.grid.model, e, { labelInside: !1 }); return ( (i.labelMargin = n.get('handle.margin')), { position: Vl(e.axis, t, i), rotation: i.rotation + (i.labelDirection < 0 ? Math.PI : 0), } ); }, updateHandleTransform: function (t, e, n, i) { var r = n.axis, o = r.grid, a = r.getGlobalExtent(!0), s = Fl(o, r).getOtherAxis(r).getGlobalExtent(), l = 'x' === r.dim ? 0 : 1, h = t.position; (h[l] += e[l]), (h[l] = Math.min(a[1], h[l])), (h[l] = Math.max(a[0], h[l])); var u = (s[1] + s[0]) / 2, c = [u, u]; c[l] = h[l]; var d = [{ verticalAlign: 'middle' }, { align: 'center' }]; return { position: h, rotation: t.rotation, cursorPoint: c, tooltipOption: d[l], }; }, }), Ux = { line: function (t, e, n, i) { var r = Wl([e, n[0]], [e, n[1]], Zl(t)); return Fi({ shape: r, style: i }), { type: 'Line', shape: r }; }, shadow: function (t, e, n, i) { var r = t.getBandWidth(), o = n[1] - n[0]; return { type: 'Rect', shape: Hl([e - r / 2, n[0]], [r, o], Zl(t)) }; }, }; dx.registerAxisPointerClass('CartesianAxisPointer', Zx), Uo(function (t) { if (t) { (!t.axisPointer || 0 === t.axisPointer.length) && (t.axisPointer = {}); var e = t.axisPointer.link; e && !y(e) && (t.axisPointer.link = [e]); } }), Xo(hm.PROCESSOR.STATISTIC, function (t, e) { t.getComponent('axisPointer').coordSysAxesInfo = Cs(t, e); }), jo( { type: 'updateAxisPointer', event: 'updateAxisPointer', update: ':updateAxisPointer', }, function (t, e, n) { var i = t.currTrigger, r = [t.x, t.y], o = t, a = t.dispatchAction || v(n.dispatchAction, n), s = e.getComponent('axisPointer').coordSysAxesInfo; if (s) { wl(r) && (r = zx( { seriesIndex: o.seriesIndex, dataIndex: o.dataIndex }, e ).point); var l = wl(r), h = o.axesInfo, u = s.axesInfo, c = 'leave' === i || wl(r), d = {}, f = {}, p = { list: [], map: {} }, g = { showPointer: Nx(pl, f), showTooltip: Nx(gl, p) }; Ex(s.coordSysMap, function (t, e) { var n = l || t.containPoint(r); Ex(s.coordSysAxesInfo[e], function (t, e) { var i = t.axis, o = xl(h, t); if (!c && n && (!h || o)) { var a = o && o.value; null != a || l || (a = i.pointToData(r)), null != a && dl(t, a, g, !1, d); } }); }); var m = {}; return ( Ex(u, function (t, e) { var n = t.linkGroup; n && !f[e] && Ex(n.axesInfo, function (e, i) { var r = f[i]; if (e !== t && r) { var o = r.value; n.mapper && (o = t.axis.scale.parse(n.mapper(o, _l(e), _l(t)))), (m[t.key] = o); } }); }), Ex(m, function (t, e) { dl(u[e], t, g, !0, d); }), vl(f, u, d), ml(p, r, t, a), yl(u, 0, n), d ); } } ), Ko({ type: 'tooltip', dependencies: ['axisPointer'], defaultOption: { zlevel: 0, z: 8, show: !0, showContent: !0, trigger: 'item', triggerOn: 'mousemove|click', alwaysShowContent: !1, displayMode: 'single', confine: !1, showDelay: 0, hideDelay: 100, transitionDuration: 0.4, enterable: !1, backgroundColor: 'rgba(50,50,50,0.7)', borderColor: '#333', borderRadius: 4, borderWidth: 0, padding: 5, extraCssText: '', axisPointer: { type: 'line', axis: 'auto', animation: 'auto', animationDurationUpdate: 200, animationEasingUpdate: 'exponentialOut', crossStyle: { color: '#999', width: 1, type: 'dashed', textStyle: {}, }, }, textStyle: { color: '#fff', fontSize: 14 }, }, }); var Xx = d, jx = En, qx = ['', '-webkit-', '-moz-', '-o-']; ql.prototype = { constructor: ql, _enterable: !0, update: function () { var t = this._container, e = t.currentStyle || document.defaultView.getComputedStyle(t), n = t.style; 'absolute' !== n.position && 'absolute' !== e.position && (n.position = 'relative'); }, show: function (t) { clearTimeout(this._hideTimeout); var e = this.el; (e.style.cssText = 'position:absolute;display:block;border-style:solid;white-space:nowrap;z-index:9999999;' + jl(t) + ';left:' + this._x + 'px;top:' + this._y + 'px;' + (t.get('extraCssText') || '')), (e.style.display = e.innerHTML ? 'block' : 'none'), (this._show = !0); }, setContent: function (t) { this.el.innerHTML = null == t ? '' : t; }, setEnterable: function (t) { this._enterable = t; }, getSize: function () { var t = this.el; return [t.clientWidth, t.clientHeight]; }, moveTo: function (t, e) { var n, i = this._zr; i && i.painter && (n = i.painter.getViewportRootOffset()) && ((t += n.offsetLeft), (e += n.offsetTop)); var r = this.el.style; (r.left = t + 'px'), (r.top = e + 'px'), (this._x = t), (this._y = e); }, hide: function () { (this.el.style.display = 'none'), (this._show = !1); }, hideLater: function (t) { !this._show || (this._inContent && this._enterable) || (t ? ((this._hideDelay = t), (this._show = !1), (this._hideTimeout = setTimeout(v(this.hide, this), t))) : this.hide()); }, isShow: function () { return this._show; }, }; var Yx = v, $x = d, Kx = wn, Qx = new Zg({ shape: { x: -1, y: -1, width: 2, height: 2 } }); Qo({ type: 'tooltip', init: function (t, e) { if (!Md.node) { var n = new ql(e.getDom(), e); this._tooltipContent = n; } }, render: function (t, e, n) { if (!Md.node) { this.group.removeAll(), (this._tooltipModel = t), (this._ecModel = e), (this._api = n), (this._lastDataByCoordSys = null), (this._alwaysShowContent = t.get('alwaysShowContent')); var i = this._tooltipContent; i.update(), i.setEnterable(t.get('enterable')), this._initGlobalListener(), this._keepShow(); } }, _initGlobalListener: function () { var t = this._tooltipModel.get('triggerOn'); bl( 'itemTooltip', this._api, Yx(function (e, n, i) { 'none' !== t && (t.indexOf(e) >= 0 ? this._tryShow(n, i) : 'leave' === e && this._hide(i)); }, this) ); }, _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 () { i.manuallyShowTip(t, e, n, { x: i._lastX, y: i._lastY }); })); } }, manuallyShowTip: function (t, e, n, i) { if (i.from !== this.uid && !Md.node) { var r = $l(i, n); this._ticket = ''; var o = i.dataByCoordSys; if (i.tooltip && null != i.x && null != i.y) { var a = Qx; (a.position = [i.x, i.y]), a.update(), (a.tooltip = i.tooltip), this._tryShow({ offsetX: i.x, offsetY: i.y, target: a }, r); } else if (o) this._tryShow( { offsetX: i.x, offsetY: i.y, position: i.position, event: {}, dataByCoordSys: i.dataByCoordSys, tooltipOption: i.tooltipOption, }, r ); else if (null != i.seriesIndex) { if (this._manuallyAxisShowTip(t, e, n, i)) return; var s = zx(i, e), l = s.point[0], h = s.point[1]; null != l && null != h && this._tryShow( { offsetX: l, offsetY: h, position: i.position, target: s.el, event: {}, }, r ); } 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, event: {}, }, r )); } }, manuallyHideTip: function (t, e, n, i) { var r = this._tooltipContent; this._alwaysShowContent || r.hideLater(this._tooltipModel.get('hideDelay')), (this._lastX = this._lastY = null), i.from !== this.uid && this._hide($l(i, n)); }, _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 && 'axis' === (t = Yl([ s.getData().getItemModel(o), s, (s.coordinateSystem || {}).model, t, ])).get('trigger') ) return ( n.dispatchAction({ type: 'updateAxisPointer', seriesIndex: r, dataIndex: o, position: i.position, }), !0 ); } }, _tryShow: function (t, e) { var n = t.target; if (this._tooltipModel) { (this._lastX = t.offsetX), (this._lastY = t.offsetY); var i = t.dataByCoordSys; i && i.length ? this._showAxisTooltip(i, t) : n && null != n.dataIndex ? ((this._lastDataByCoordSys = null), this._showSeriesItemTooltip(t, n, e)) : n && n.tooltip ? ((this._lastDataByCoordSys = null), this._showComponentItemTooltip(t, n, e)) : ((this._lastDataByCoordSys = null), this._hide(e)); } }, _showOrMove: function (t, e) { var n = t.get('showDelay'); (e = v(e, this)), clearTimeout(this._showTimout), n > 0 ? (this._showTimout = setTimeout(e, n)) : e(); }, _showAxisTooltip: function (t, e) { var n = this._ecModel, i = this._tooltipModel, r = [e.offsetX, e.offsetY], o = [], a = [], s = Yl([e.tooltipOption, i]); $x( t, function (t) { $x(t.dataByAxis, function (t) { var e = n.getComponent(t.axisDim + 'Axis', t.axisIndex), i = t.value, r = []; if (e && null != i) { var s = Rl(i, e.axis, n, t.seriesDataIndices, t.valueLabelOpt); d(t.seriesDataIndices, function (o) { var l = n.getSeriesByIndex(o.seriesIndex), h = o.dataIndexInside, u = l && l.getDataParams(h); (u.axisDim = t.axisDim), (u.axisIndex = t.axisIndex), (u.axisType = t.axisType), (u.axisId = t.axisId), (u.axisValue = Ca(e.axis, i)), (u.axisValueLabel = s), u && (a.push(u), r.push(l.formatTooltip(h, !0))); }); var l = s; o.push((l ? Nn(l) + '
' : '') + r.join('
')); } }); }, this ), o.reverse(), (o = o.join('

')); var l = e.position; this._showOrMove(s, function () { this._updateContentNotChangedOnAxis(t) ? this._updatePosition(s, l, r[0], r[1], this._tooltipContent, a) : this._showTooltipContent(s, o, a, Math.random(), r[0], r[1], l); }); }, _showSeriesItemTooltip: function (t, e, n) { var i = this._ecModel, r = e.seriesIndex, o = i.getSeriesByIndex(r), a = e.dataModel || o, s = e.dataIndex, l = e.dataType, h = a.getData(), u = Yl([ h.getItemModel(s), a, o && (o.coordinateSystem || {}).model, this._tooltipModel, ]), c = u.get('trigger'); if (null == c || 'item' === c) { var d = a.getDataParams(s, l), f = a.formatTooltip(s, !1, l), p = 'item_' + a.name + '_' + s; this._showOrMove(u, function () { this._showTooltipContent( u, f, d, p, t.offsetX, t.offsetY, t.position, t.target ); }), n({ type: 'showTip', dataIndexInside: s, dataIndex: h.getRawIndex(s), seriesIndex: r, from: this.uid, }); } }, _showComponentItemTooltip: function (t, e, n) { var i = e.tooltip; if ('string' == typeof i) { var r = i; i = { content: r, formatter: r }; } var o = new Mr(i, this._tooltipModel, this._ecModel), a = o.get('content'), s = Math.random(); this._showOrMove(o, function () { this._showTooltipContent( o, a, o.get('formatterParams') || {}, s, t.offsetX, t.offsetY, t.position, e ); }), n({ type: 'showTip', from: this.uid }); }, _showTooltipContent: function (t, e, n, i, r, o, a, s) { if (((this._ticket = ''), t.get('showContent') && t.get('show'))) { var l = this._tooltipContent, h = t.get('formatter'); a = a || t.get('position'); var u = e; if (h && 'string' == typeof h) u = Bn(h, n, !0); else if ('function' == typeof h) { var c = Yx(function (e, i) { e === this._ticket && (l.setContent(i), this._updatePosition(t, a, r, o, l, n, s)); }, this); (this._ticket = i), (u = h(n, i, c)); } l.setContent(u), l.show(t), this._updatePosition(t, a, r, o, l, n, s); } }, _updatePosition: function (t, e, n, i, r, o, a) { var s = this._api.getWidth(), l = this._api.getHeight(); e = e || t.get('position'); var h = r.getSize(), u = t.get('align'), c = t.get('verticalAlign'), d = a && a.getBoundingRect().clone(); if ( (a && d.applyTransform(a.transform), 'function' == typeof e && (e = e([n, i], o, r.el, d, { viewSize: [s, l], contentSize: h.slice(), })), y(e)) ) (n = Kx(e[0], s)), (i = Kx(e[1], l)); else if (w(e)) { (e.width = h[0]), (e.height = h[1]); var f = Hr(e, { width: s, height: l }); (n = f.x), (i = f.y), (u = null), (c = null); } else 'string' == typeof e && a ? ((n = (p = th(e, d, h))[0]), (i = p[1])) : ((n = (p = Kl(n, i, r.el, s, l, u ? null : 20, c ? null : 20))[0]), (i = p[1])); if ( (u && (n -= eh(u) ? h[0] / 2 : 'right' === u ? h[0] : 0), c && (i -= eh(c) ? h[1] / 2 : 'bottom' === c ? h[1] : 0), t.get('confine')) ) { var p = Ql(n, i, r.el, s, l); (n = p[0]), (i = p[1]); } r.moveTo(n, i); }, _updateContentNotChangedOnAxis: function (t) { var e = this._lastDataByCoordSys, n = !!e && e.length === t.length; return ( n && $x(e, function (e, i) { var r = e.dataByAxis || {}, o = (t[i] || {}).dataByAxis || []; (n &= r.length === o.length) && $x(r, function (t, e) { var i = o[e] || {}, r = t.seriesDataIndices || [], a = i.seriesDataIndices || []; (n &= t.value === i.value && t.axisType === i.axisType && t.axisId === i.axisId && r.length === a.length) && $x(r, function (t, e) { var i = a[e]; n &= t.seriesIndex === i.seriesIndex && t.dataIndex === i.dataIndex; }); }); }), (this._lastDataByCoordSys = t), !!n ); }, _hide: function (t) { (this._lastDataByCoordSys = null), t({ type: 'hideTip', from: this.uid }); }, dispose: function (t, e) { Md.node || (this._tooltipContent.hide(), Cl('itemTooltip', e)); }, }), jo( { type: 'showTip', event: 'showTip', update: 'tooltip:manuallyShowTip' }, function () {} ), jo( { type: 'hideTip', event: 'hideTip', update: 'tooltip:manuallyHideTip' }, function () {} ); var Jx = Ko({ type: 'legend.plain', dependencies: ['series'], layoutMode: { type: 'box', ignoreSize: !0 }, init: function (t, e, n) { this.mergeDefaultAndTheme(t, n), (t.selected = t.selected || {}); }, mergeOption: function (t) { Jx.superCall(this, 'mergeOption', t); }, 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')); } }, _updateData: function (t) { var e = f( this.get('data') || [], function (t) { return ( ('string' != typeof t && 'number' != typeof t) || (t = { name: t }), new Mr(t, this, this.ecModel) ); }, this ); this._data = e; var n = f(t.getSeries(), function (t) { return t.name; }); t.eachSeries(function (t) { if (t.legendDataProvider) { var e = t.legendDataProvider(); n = n.concat(e.mapArray(e.getName)); } }), (this._availableNames = n); }, getData: function () { return this._data; }, select: function (t) { var e = this.option.selected; 'single' === this.get('selectedMode') && d(this._data, function (t) { e[t.get('name')] = !1; }), (e[t] = !0); }, unSelect: function (t) { 'single' !== this.get('selectedMode') && (this.option.selected[t] = !1); }, toggleSelected: function (t) { var e = this.option.selected; e.hasOwnProperty(t) || (e[t] = !0), this[e[t] ? 'unSelect' : 'select'](t); }, isSelected: function (t) { var e = this.option.selected; return !(e.hasOwnProperty(t) && !e[t]) && l(this._availableNames, t) >= 0; }, defaultOption: { zlevel: 0, 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, inactiveColor: '#ccc', textStyle: { color: '#333' }, selectedMode: !0, tooltip: { show: !1 }, }, }); jo('legendToggleSelect', 'legendselectchanged', m(nh, 'toggleSelected')), jo('legendSelect', 'legendselected', m(nh, 'select')), jo('legendUnSelect', 'legendunselected', m(nh, 'unSelect')); var t_ = m, e_ = d, n_ = Tf, i_ = Qo({ type: 'legend.plain', newlineDisabled: !1, init: function () { this.group.add((this._contentGroup = new n_())), this._backgroundEl; }, getContentGroup: function () { return this._contentGroup; }, render: function (t, e, n) { if ((this.resetInner(), t.get('show', !0))) { var i = t.get('align'); (i && 'auto' !== i) || (i = 'right' === t.get('left') && 'vertical' === t.get('orient') ? 'right' : 'left'), this.renderInner(i, t, e, n); var r = t.getBoxLayoutParams(), o = { width: n.getWidth(), height: n.getHeight() }, s = t.get('padding'), l = Hr(r, o, s), h = this.layoutInner(t, i, l), u = Hr(a({ width: h.width, height: h.height }, r), o, s); this.group.attr('position', [u.x - h.x, u.y - h.y]), this.group.add((this._backgroundEl = rh(h, t))); } }, resetInner: function () { this.getContentGroup().removeAll(), this._backgroundEl && this.group.remove(this._backgroundEl); }, renderInner: function (t, e, n, i) { var r = this.getContentGroup(), o = z(), a = e.get('selectedMode'); e_( e.getData(), function (s, l) { var h = s.get('name'); if (this.newlineDisabled || ('' !== h && '\n' !== h)) { var u = n.getSeriesByName(h)[0]; if (!o.get(h)) if (u) { var c = u.getData(), d = c.getVisual('color'); 'function' == typeof d && (d = d(u.getDataParams(0))); var f = c.getVisual('legendSymbol') || 'roundRect', p = c.getVisual('symbol'); this._createItem(h, l, s, e, f, p, t, d, a) .on('click', t_(oh, h, i)) .on('mouseover', t_(ah, u, null, i)) .on('mouseout', t_(sh, u, null, i)), o.set(h, !0); } else n.eachRawSeries(function (n) { if (!o.get(h) && n.legendDataProvider) { var r = n.legendDataProvider(), u = r.indexOfName(h); if (u < 0) return; var c = r.getItemVisual(u, 'color'); this._createItem(h, l, s, e, 'roundRect', null, t, c, a) .on('click', t_(oh, h, i)) .on('mouseover', t_(ah, n, h, i)) .on('mouseout', t_(sh, n, h, i)), o.set(h, !0); } }, this); } else r.add(new n_({ newline: !0 })); }, this ); }, _createItem: function (t, e, n, i, r, a, s, l, h) { var u = i.get('itemWidth'), c = i.get('itemHeight'), d = i.get('inactiveColor'), f = i.isSelected(t), p = new n_(), g = n.getModel('textStyle'), v = n.get('icon'), m = n.getModel('tooltip'), y = m.parentModel; if ( ((r = v || r), p.add(Pa(r, 0, 0, u, c, f ? l : d, !0)), !v && a && (a !== r || 'none' == a)) ) { var x = 0.8 * c; 'none' === a && (a = 'circle'), p.add(Pa(a, (u - x) / 2, (c - x) / 2, x, x, f ? l : d)); } var _ = 'left' === s ? u + 5 : -5, w = s, b = i.get('formatter'), M = t; 'string' == typeof b && b ? (M = b.replace('{name}', null != t ? t : '')) : 'function' == typeof b && (M = b(t)), p.add( new zg({ style: ar({}, g, { text: M, x: _, y: c / 2, textFill: f ? g.getTextColor() : d, textAlign: w, textVerticalAlign: 'middle', }), }) ); var S = new Zg({ shape: p.getBoundingRect(), invisible: !0, tooltip: m.get('show') ? o( { content: t, formatter: y.get('formatter', !0) || function () { return t; }, formatterParams: { componentType: 'legend', legendIndex: i.componentIndex, name: t, $vars: ['name'], }, }, m.option ) : null, }); return ( p.add(S), p.eachChild(function (t) { t.silent = !0; }), (S.silent = !h), this.getContentGroup().add(p), rr(p), (p.__legendDataIndex = e), p ); }, layoutInner: function (t, e, n) { var i = this.getContentGroup(); xv(t.get('orient'), i, t.get('itemGap'), n.width, n.height); var r = i.getBoundingRect(); return i.attr('position', [-r.x, -r.y]), this.group.getBoundingRect(); }, }); Xo(function (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; }); }), bv.registerSubTypeDefaulter('legend', function () { return 'plain'; }); var r_ = Jx.extend({ type: 'legend.scroll', setScrollDataIndex: function (t) { this.option.scrollDataIndex = t; }, 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, }, init: function (t, e, n, i) { var r = Ur(t); r_.superCall(this, 'init', t, e, n, i), lh(this, t, r); }, mergeOption: function (t, e) { r_.superCall(this, 'mergeOption', t, e), lh(this, this.option, t); }, getOrient: function () { return 'vertical' === this.get('orient') ? { index: 1, name: 'vertical' } : { index: 0, name: 'horizontal' }; }, }), o_ = Tf, a_ = ['width', 'height'], s_ = ['x', 'y'], l_ = i_.extend({ type: 'legend.scroll', newlineDisabled: !0, init: function () { l_.superCall(this, 'init'), (this._currentIndex = 0), this.group.add((this._containerGroup = new o_())), this._containerGroup.add(this.getContentGroup()), this.group.add((this._controllerGroup = new o_())), this._showController; }, resetInner: function () { l_.superCall(this, 'resetInner'), this._controllerGroup.removeAll(), this._containerGroup.removeClipPath(), (this._containerGroup.__rectSize = null); }, renderInner: function (t, e, n, i) { function r(t, n) { var r = t + 'DataIndex', l = br( e.get('pageIcons', !0)[e.getOrient().name][n], { onclick: v(o._pageGo, o, r, e, i) }, { x: -s[0] / 2, y: -s[1] / 2, width: s[0], height: s[1] } ); (l.name = t), a.add(l); } var o = this; l_.superCall(this, 'renderInner', t, e, n, i); var a = this._controllerGroup, s = e.get('pageIconSize', !0); y(s) || (s = [s, s]), r('pagePrev', 0); var l = e.getModel('pageTextStyle'); a.add( new zg({ name: 'pageText', style: { textFill: l.getTextColor(), font: l.getFont(), textVerticalAlign: 'middle', textAlign: 'center', }, silent: !0, }) ), r('pageNext', 1); }, layoutInner: function (t, e, n) { var i = this.getContentGroup(), r = this._containerGroup, o = this._controllerGroup, a = t.getOrient().index, s = a_[a], l = a_[1 - a], h = s_[1 - a]; xv( t.get('orient'), i, t.get('itemGap'), a ? n.width : null, a ? null : n.height ), xv('horizontal', o, t.get('pageButtonItemGap', !0)); var u = i.getBoundingRect(), c = o.getBoundingRect(), d = (this._showController = u[s] > n[s]), f = [-u.x, -u.y]; f[a] = i.position[a]; var p = [0, 0], g = [-c.x, -c.y], v = T(t.get('pageButtonGap', !0), t.get('itemGap', !0)); d && ('end' === t.get('pageButtonPosition', !0) ? (g[a] += n[s] - c[s]) : (p[a] += c[s] + v)), (g[1 - a] += u[l] / 2 - c[l] / 2), i.attr('position', f), r.attr('position', p), o.attr('position', g); var m = this.group.getBoundingRect(); if ( (((m = { x: 0, y: 0 })[s] = d ? n[s] : u[s]), (m[l] = Math.max(u[l], c[l])), (m[h] = Math.min(0, c[h] + g[1 - a])), (r.__rectSize = n[s]), d) ) { var y = { x: 0, y: 0 }; (y[s] = Math.max(n[s] - c[s] - v, 0)), (y[l] = m[l]), r.setClipPath(new Zg({ shape: y })), (r.__rectSize = y[s]); } else o.eachChild(function (t) { t.attr({ invisible: !0, silent: !0 }); }); var x = this._getPageInfo(t); return ( null != x.pageIndex && gr(i, { position: x.contentPosition }, !!d && t), this._updatePageInfoView(t, x), m ); }, _pageGo: function (t, e, n) { var i = this._getPageInfo(e)[t]; null != i && n.dispatchAction({ type: 'legendScroll', scrollDataIndex: i, legendId: e.id, }); }, _updatePageInfoView: function (t, e) { var n = this._controllerGroup; d(['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', _(r) ? r.replace('{current}', a).replace('{total}', s) : r({ current: a, total: s }) ); }, _getPageInfo: function (t) { function e(t) { var e = t.getBoundingRect().clone(); return (e[f] += t.position[u]), e; } var n, i, r, o, a = t.get('scrollDataIndex', !0), s = this.getContentGroup(), l = s.getBoundingRect(), h = this._containerGroup.__rectSize, u = t.getOrient().index, c = a_[u], d = a_[1 - u], f = s_[u], p = s.position.slice(); this._showController ? s.eachChild(function (t) { t.__legendDataIndex === a && (o = t); }) : (o = s.childAt(0)); var g = h ? Math.ceil(l[c] / h) : 0; if (o) { var v = o.getBoundingRect(), m = o.position[u] + v[f]; (p[u] = -m - l[f]), (n = Math.floor((g * (m + v[f] + h / 2)) / l[c])), (n = l[c] && g ? Math.max(0, Math.min(g - 1, n)) : -1); var y = { x: 0, y: 0 }; (y[c] = h), (y[d] = l[d]), (y[f] = -p[u] - l[f]); var x, _ = s.children(); if ( (s.eachChild(function (t, n) { var i = e(t); i.intersect(y) && (null == x && (x = n), (r = t.__legendDataIndex)), n === _.length - 1 && i[f] + i[c] <= y[f] + y[c] && (r = null); }), null != x) ) { var w = e(_[x]); if (((y[f] = w[f] + w[c] - y[c]), x <= 0 && w[f] >= y[f])) i = null; else { for (; x > 0 && e(_[x - 1]).intersect(y); ) x--; i = _[x].__legendDataIndex; } } } return { contentPosition: p, pageIndex: n, pageCount: g, pagePrevDataIndex: i, pageNextDataIndex: r, }; }, }); jo('legendScroll', 'legendscroll', function (t, e) { var n = t.scrollDataIndex; null != n && e.eachComponent( { mainType: 'legend', subType: 'scroll', query: t }, function (t) { t.setScrollDataIndex(n); } ); }), Ko({ type: 'title', layoutMode: { type: 'box', ignoreSize: !0 }, defaultOption: { zlevel: 0, 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: 'bolder', color: '#333' }, subtextStyle: { color: '#aaa' }, }, }), Qo({ type: 'title', 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 = t.get('textBaseline'), l = new zg({ style: ar( {}, r, { text: t.get('text'), textFill: r.getTextColor() }, { disableBox: !0 } ), z2: 10, }), h = l.getBoundingRect(), u = t.get('subtext'), c = new zg({ style: ar( {}, o, { text: u, textFill: o.getTextColor(), y: h.height + t.get('itemGap'), textVerticalAlign: 'top', }, { disableBox: !0 } ), z2: 10, }), d = t.get('link'), f = t.get('sublink'); (l.silent = !d), (c.silent = !f), d && l.on('click', function () { window.open(d, '_' + t.get('target')); }), f && c.on('click', function () { window.open(f, '_' + t.get('subtarget')); }), i.add(l), u && i.add(c); var p = i.getBoundingRect(), g = t.getBoxLayoutParams(); (g.width = p.width), (g.height = p.height); var v = Hr( g, { 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.attr('position', [v.x, v.y]); var m = { textAlign: a, textVerticalAlign: s }; l.setStyle(m), c.setStyle(m), (p = i.getBoundingRect()); var y = v.margin, x = t.getItemStyle(['color', 'opacity']); x.fill = t.get('backgroundColor'); var _ = new Zg({ shape: { x: p.x - y[3], y: p.y - y[0], width: p.width + y[1] + y[3], height: p.height + y[0] + y[2], r: t.get('borderRadius'), }, style: x, silent: !0, }); Zi(_), i.add(_); } }, }); var h_ = zn, u_ = Nn, c_ = Ko({ type: 'marker', dependencies: ['series', 'grid', 'polar', 'geo'], init: function (t, e, n, i) { this.mergeDefaultAndTheme(t, n), this.mergeOption(t, n, i.createdBySelf, !0); }, isAnimationEnabled: function () { if (Md.node) return !1; var t = this.__hostSeries; return this.getShallow('animation') && t && t.isAnimationEnabled(); }, mergeOption: function (t, e, n, i) { var r = this.constructor, a = this.mainType + 'Model'; n || e.eachSeries(function (t) { var n = t.get(this.mainType), s = t[a]; n && n.data ? (s ? s.mergeOption(n, e, !0) : (i && hh(n), d(n.data, function (t) { t instanceof Array ? (hh(t[0]), hh(t[1])) : hh(t); }), o((s = new r(n, this, e)), { mainType: this.mainType, seriesIndex: t.seriesIndex, name: t.name, createdBySelf: !0, }), (s.__hostSeries = t)), (t[a] = s)) : (t[a] = null); }, this); }, formatTooltip: function (t) { var e = this.getData(), n = this.getRawValue(t), i = y(n) ? f(n, h_).join(', ') : h_(n), r = e.getName(t), o = u_(this.name); return ( (null != n || r) && (o += '
'), r && ((o += u_(r)), null != n && (o += ' : ')), null != n && (o += u_(i)), o ); }, getData: function () { return this._data; }, setData: function (t) { this._data = t; }, }); u(c_, dv), c_.extend({ type: 'markPoint', defaultOption: { zlevel: 0, z: 5, symbol: 'pin', symbolSize: 50, tooltip: { trigger: 'item' }, label: { normal: { show: !0, position: 'inside' }, emphasis: { show: !0 }, }, itemStyle: { normal: { borderWidth: 2 } }, }, }); var d_ = l, f_ = m, p_ = { min: f_(fh, 'min'), max: f_(fh, 'max'), average: f_(fh, 'average') }, g_ = Qo({ type: 'marker', init: function () { this.markerGroupMap = z(); }, render: function (t, e, n) { var i = this.markerGroupMap; i.each(function (t) { t.__keep = !1; }); var r = this.type + 'Model'; e.eachSeries(function (t) { var i = t[r]; i && this.renderSeries(t, i, e, n); }, this), i.each(function (t) { !t.__keep && this.group.remove(t.group); }, this); }, renderSeries: function () {}, }); g_.extend({ type: 'markPoint', updateLayout: function (t, e, n) { e.eachSeries(function (t) { var e = t.markPointModel; e && (xh(e.getData(), t, n), this.markerGroupMap.get(t.id).updateLayout(e)); }, this); }, 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 Fa()), h = _h(r, t, e); e.setData(h), xh(e.getData(), t, i), h.each(function (t) { var n = h.getItemModel(t), i = n.getShallow('symbolSize'); 'function' == typeof i && (i = i(e.getRawValue(t), e.getDataParams(t))), h.setItemVisual(t, { symbolSize: i, color: n.get('itemStyle.normal.color') || a.getVisual('color'), symbol: n.getShallow('symbol'), }); }), l.updateData(h), this.group.add(l.group), h.eachItemGraphicEl(function (t) { t.traverse(function (t) { t.dataModel = e; }); }), (l.__keep = !0), (l.group.silent = e.get('silent') || t.get('silent')); }, }), Uo(function (t) { t.markPoint = t.markPoint || {}; }), c_.extend({ type: 'markLine', defaultOption: { zlevel: 0, z: 5, symbol: ['circle', 'arrow'], symbolSize: [8, 16], precision: 2, tooltip: { trigger: 'item' }, label: { normal: { show: !0, position: 'end' }, emphasis: { show: !0 }, }, lineStyle: { normal: { type: 'dashed' }, emphasis: { width: 3 } }, animationEasing: 'linear', }, }); var v_ = Ug.prototype, m_ = jg.prototype, y_ = Ri({ type: 'ec-line', style: { stroke: '#000', fill: null }, shape: { x1: 0, y1: 0, x2: 0, y2: 0, percent: 1, cpx1: null, cpy1: null }, buildPath: function (t, e) { (wh(e) ? v_ : m_).buildPath(t, e); }, pointAt: function (t) { return wh(this.shape) ? v_.pointAt.call(this, t) : m_.pointAt.call(this, t); }, tangentAt: function (t) { var e = this.shape, n = wh(e) ? [e.x2 - e.x1, e.y2 - e.y1] : m_.tangentAt.call(this, t); return U(n, n); }, }), x_ = ['fromSymbol', 'toSymbol'], __ = Th.prototype; (__.beforeUpdate = function () { var t = this, e = t.childOfName('fromSymbol'), n = t.childOfName('toSymbol'), i = t.childOfName('label'); if (e || n || !i.ignore) { for (var r = 1, o = this.parent; o; ) o.scale && (r /= o.scale[0]), (o = o.parent); var a = t.childOfName('line'); if (this.__dirty || a.__dirty) { var s = a.shape.percent, l = a.pointAt(0), h = a.pointAt(s), u = W([], h, l); if ( (U(u, u), e && (e.attr('position', l), (c = a.tangentAt(0)), e.attr('rotation', Math.PI / 2 - Math.atan2(c[1], c[0])), e.attr('scale', [r * s, r * s])), n) ) { n.attr('position', h); var c = a.tangentAt(1); n.attr('rotation', -Math.PI / 2 - Math.atan2(c[1], c[0])), n.attr('scale', [r * s, r * s]); } if (!i.ignore) { i.attr('position', h); var d, f, p, g = 5 * r; if ('end' === i.__position) (d = [u[0] * g + h[0], u[1] * g + h[1]]), (f = u[0] > 0.8 ? 'left' : u[0] < -0.8 ? 'right' : 'center'), (p = u[1] > 0.8 ? 'top' : u[1] < -0.8 ? 'bottom' : 'middle'); else if ('middle' === i.__position) { var v = s / 2, m = [(c = a.tangentAt(v))[1], -c[0]], y = a.pointAt(v); m[1] > 0 && ((m[0] = -m[0]), (m[1] = -m[1])), (d = [y[0] + m[0] * g, y[1] + m[1] * g]), (f = 'center'), (p = 'bottom'); var x = -Math.atan2(c[1], c[0]); h[0] < l[0] && (x = Math.PI + x), i.attr('rotation', x); } else (d = [-u[0] * g + l[0], -u[1] * g + l[1]]), (f = u[0] > 0.8 ? 'right' : u[0] < -0.8 ? 'left' : 'center'), (p = u[1] > 0.8 ? 'bottom' : u[1] < -0.8 ? 'top' : 'middle'); i.attr({ style: { textVerticalAlign: i.__verticalAlign || p, textAlign: i.__textAlign || f, }, position: d, scale: [r, r], }); } } } }), (__._createLine = function (t, e, n) { var i = t.hostModel, r = Sh(t.getItemLayout(e)); (r.shape.percent = 0), vr(r, { shape: { percent: 1 } }, i, e), this.add(r); var o = new zg({ name: 'label' }); this.add(o), d( x_, function (n) { var i = Mh(n, t, e); this.add(i), (this[bh(n)] = t.getItemVisual(e, n)); }, this ), this._updateCommonStl(t, e, n); }), (__.updateData = function (t, e, n) { var i = t.hostModel, r = this.childOfName('line'), o = t.getItemLayout(e), a = { shape: {} }; Ih(a.shape, o), gr(r, a, i, e), d( x_, function (n) { var i = t.getItemVisual(e, n), r = bh(n); if (this[r] !== i) { this.remove(this.childOfName(n)); var o = Mh(n, t, e); this.add(o); } this[r] = i; }, this ), this._updateCommonStl(t, e, n); }), (__._updateCommonStl = function (t, e, n) { var i = t.hostModel, r = this.childOfName('line'), o = n && n.lineStyle, s = n && n.hoverLineStyle, l = n && n.labelModel, h = n && n.hoverLabelModel; if (!n || t.hasItemOption) { var u = t.getItemModel(e); (o = u.getModel('lineStyle.normal').getLineStyle()), (s = u.getModel('lineStyle.emphasis').getLineStyle()), (l = u.getModel('label.normal')), (h = u.getModel('label.emphasis')); } var c = t.getItemVisual(e, 'color'), f = A(t.getItemVisual(e, 'opacity'), o.opacity, 1); r.useStyle( a({ strokeNoScale: !0, fill: 'none', stroke: c, opacity: f }, o) ), (r.hoverStyle = s), d( x_, function (t) { var e = this.childOfName(t); e && (e.setColor(c), e.setStyle({ opacity: f })); }, this ); var p, g, v, m, y = l.getShallow('show'), x = h.getShallow('show'), _ = this.childOfName('label'); if (y || x) { var w = i.getRawValue(e); (g = null == w ? (g = t.getName(e)) : isFinite(w) ? bn(w) : w), (p = c || '#000'), (v = T(i.getFormattedLabel(e, 'normal', t.dataType), g)), (m = T(i.getFormattedLabel(e, 'emphasis', t.dataType), v)); } if (y) { var b = ar(_.style, l, { text: v }, { autoColor: p }); (_.__textAlign = b.textAlign), (_.__verticalAlign = b.textVerticalAlign), (_.__position = l.get('position') || 'middle'); } else _.setStyle('text', null); (_.hoverStyle = x ? { text: m, textFill: h.getTextColor(!0), fontStyle: h.getShallow('fontStyle'), fontWeight: h.getShallow('fontWeight'), fontSize: h.getShallow('fontSize'), fontFamily: h.getShallow('fontFamily'), } : { text: null }), (_.ignore = !y && !x), rr(this); }), (__.highlight = function () { this.trigger('emphasis'); }), (__.downplay = function () { this.trigger('normal'); }), (__.updateLayout = function (t, e) { this.setLinePoints(t.getItemLayout(e)); }), (__.setLinePoints = function (t) { var e = this.childOfName('line'); Ih(e.shape, t), e.dirty(); }), h(Th, Tf); var w_ = kh.prototype; (w_.updateData = function (t) { var e = this._lineData, n = this.group, i = this._ctor, r = t.hostModel, o = { lineStyle: r.getModel('lineStyle.normal').getLineStyle(), hoverLineStyle: r.getModel('lineStyle.emphasis').getLineStyle(), labelModel: r.getModel('label.normal'), hoverLabelModel: r.getModel('label.emphasis'), }; t .diff(e) .add(function (e) { if (Ch(t.getItemLayout(e))) { var r = new i(t, e, o); t.setItemGraphicEl(e, r), n.add(r); } }) .update(function (r, a) { var s = e.getItemGraphicEl(a); Ch(t.getItemLayout(r)) ? (s ? s.updateData(t, r, o) : (s = new i(t, r, o)), t.setItemGraphicEl(r, s), n.add(s)) : n.remove(s); }) .remove(function (t) { n.remove(e.getItemGraphicEl(t)); }) .execute(), (this._lineData = t); }), (w_.updateLayout = function () { var t = this._lineData; t.eachItemGraphicEl(function (e, n) { e.updateLayout(t, n); }, this); }), (w_.remove = function () { this.group.removeAll(); }); var b_ = function (t, e, r, a) { var s = t.getData(), l = a.type; if ( !y(a) && ('min' === l || 'max' === l || 'average' === l || null != a.xAxis || null != a.yAxis) ) { var h, u; if (null != a.yAxis || null != a.xAxis) (h = null != a.yAxis ? 'y' : 'x'), e.getAxis(h), (u = I(a.yAxis, a.xAxis)); else { var c = gh(a, s, e, t); (h = c.valueDataDim), c.valueAxis, (u = yh(s, h, l)); } var d = 'x' === h ? 0 : 1, f = 1 - d, p = n(a), g = {}; (p.type = null), (p.coord = []), (g.coord = []), (p.coord[f] = -1 / 0), (g.coord[f] = 1 / 0); var v = r.get('precision'); v >= 0 && 'number' == typeof u && (u = +u.toFixed(Math.min(v, 20))), (p.coord[d] = g.coord[d] = u), (a = [p, g, { type: l, valueIndex: a.valueIndex, value: u }]); } return ( (a = [ph(t, a[0]), ph(t, a[1]), o({}, a[2])]), (a[2].type = a[2].type || ''), i(a[2], a[0]), i(a[2], a[1]), a ); }; g_.extend({ type: 'markLine', updateLayout: function (t, e, n) { e.eachSeries(function (t) { var e = t.markLineModel; if (e) { var i = e.getData(), r = e.__from, o = e.__to; r.each(function (e) { Oh(r, e, !0, t, n), Oh(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); }, renderSeries: function (t, e, n, i) { function r(e, n, r) { var o = e.getItemModel(n); Oh(e, n, r, t, i), e.setItemVisual(n, { symbolSize: o.get('symbolSize') || g[r ? 0 : 1], symbol: o.get('symbol', !0) || p[r ? 0 : 1], color: o.get('itemStyle.normal.color') || s.getVisual('color'), }); } var o = t.coordinateSystem, a = t.id, s = t.getData(), l = this.markerGroupMap, h = l.get(a) || l.set(a, new kh()); this.group.add(h.group); var u = zh(o, t, e), c = u.from, d = u.to, f = u.line; (e.__from = c), (e.__to = d), e.setData(f); var p = e.get('symbol'), g = e.get('symbolSize'); y(p) || (p = [p, p]), 'number' == typeof g && (g = [g, g]), u.from.each(function (t) { r(c, t, !0), r(d, t, !1); }), f.each(function (t) { var e = f.getItemModel(t).get('lineStyle.normal.color'); f.setItemVisual(t, { color: e || c.getItemVisual(t, 'color') }), f.setItemLayout(t, [c.getItemLayout(t), d.getItemLayout(t)]), f.setItemVisual(t, { fromSymbolSize: c.getItemVisual(t, 'symbolSize'), fromSymbol: c.getItemVisual(t, 'symbol'), toSymbolSize: d.getItemVisual(t, 'symbolSize'), toSymbol: d.getItemVisual(t, 'symbol'), }); }), h.updateData(f), u.line.eachItemGraphicEl(function (t, n) { t.traverse(function (t) { t.dataModel = e; }); }), (h.__keep = !0), (h.group.silent = e.get('silent') || t.get('silent')); }, }), Uo(function (t) { t.markLine = t.markLine || {}; }), c_.extend({ type: 'markArea', defaultOption: { zlevel: 0, z: 1, tooltip: { trigger: 'item' }, animation: !1, label: { normal: { show: !0, position: 'top' }, emphasis: { show: !0, position: 'top' }, }, itemStyle: { normal: { borderWidth: 0 } }, }, }); var M_ = function (t, e, n, i) { var o = ph(t, i[0]), a = ph(t, i[1]), s = I, l = o.coord, h = a.coord; (l[0] = s(l[0], -1 / 0)), (l[1] = s(l[1], -1 / 0)), (h[0] = s(h[0], 1 / 0)), (h[1] = s(h[1], 1 / 0)); var u = r([{}, o, a]); return ( (u.coord = [o.coord, a.coord]), (u.x0 = o.x), (u.y0 = o.y), (u.x1 = a.x), (u.y1 = a.y), u ); }, S_ = [ ['x0', 'y0'], ['x1', 'y0'], ['x1', 'y1'], ['x0', 'y1'], ]; g_.extend({ type: 'markArea', updateLayout: function (t, e, n) { e.eachSeries(function (t) { var e = t.markAreaModel; if (e) { var i = e.getData(); i.each(function (e) { var r = f(S_, function (r) { return Rh(i, e, r, t, n); }); i.setItemLayout(e, r), i.getItemGraphicEl(e).setShape('points', r); }); } }, this); }, renderSeries: function (t, e, n, i) { var r = t.coordinateSystem, o = t.name, s = t.getData(), l = this.markerGroupMap, h = l.get(o) || l.set(o, { group: new Tf() }); this.group.add(h.group), (h.__keep = !0); var u = Vh(r, t, e); e.setData(u), u.each(function (e) { u.setItemLayout( e, f(S_, function (n) { return Rh(u, e, n, t, i); }) ), u.setItemVisual(e, { color: s.getVisual('color') }); }), u .diff(h.__data) .add(function (t) { var e = new Hg({ shape: { points: u.getItemLayout(t) } }); u.setItemGraphicEl(t, e), h.group.add(e); }) .update(function (t, n) { var i = h.__data.getItemGraphicEl(n); gr(i, { shape: { points: u.getItemLayout(t) } }, e, t), h.group.add(i), u.setItemGraphicEl(t, i); }) .remove(function (t) { var e = h.__data.getItemGraphicEl(t); h.group.remove(e); }) .execute(), u.eachItemGraphicEl(function (t, n) { var i = u.getItemModel(n), r = i.getModel('label.normal'), o = i.getModel('label.emphasis'), s = u.getItemVisual(n, 'color'); t.useStyle( a(i.getModel('itemStyle.normal').getItemStyle(), { fill: kt(s, 0.4), stroke: s, }) ), (t.hoverStyle = i.getModel('itemStyle.emphasis').getItemStyle()), or(t.style, t.hoverStyle, r, o, { labelFetcher: e, labelDataIndex: n, defaultText: u.getName(n) || '', isRectText: !0, autoColor: s, }), rr(t, {}), (t.dataModel = e); }), (h.__data = u), (h.group.silent = e.get('silent') || t.get('silent')); }, }), Uo(function (t) { t.markArea = t.markArea || {}; }), bv.registerSubTypeDefaulter('dataZoom', function () { return 'slider'; }); var I_ = ['cartesian2d', 'polar', 'singleAxis'], T_ = (function (t, e) { var n = f((t = t.slice()), Gn), i = f((e = (e || []).slice()), Gn); return function (r, o) { d(t, function (t, a) { for (var s = { name: t, capital: n[a] }, l = 0; l < e.length; l++) s[e[l]] = t + i[l]; r.call(o, s); }); }; })( ['x', 'y', 'z', 'radius', 'angle', 'single'], ['axisIndex', 'axis', 'index', 'id'] ), A_ = d, C_ = Mn, k_ = function (t, e, n, i) { (this._dimName = t), (this._axisIndex = e), this._valueWindow, this._percentWindow, this._dataExtent, this._minMaxSpan, (this.ecModel = i), (this._dataZoomModel = n); }; k_.prototype = { constructor: k_, hostedBy: function (t) { return this._dataZoomModel === t; }, getDataValueWindow: function () { return this._valueWindow.slice(); }, getDataPercentWindow: function () { return this._percentWindow.slice(); }, getTargetSeriesModels: function () { var t = [], e = this.ecModel; return ( e.eachSeries(function (n) { if (Gh(n.get('coordinateSystem'))) { var i = this._dimName, r = e.queryComponents({ mainType: i + 'Axis', index: n.get(i + 'AxisIndex'), id: n.get(i + 'AxisId'), })[0]; this._axisIndex === (r && r.componentIndex) && t.push(n); } }, this), t ); }, getAxisModel: function () { return this.ecModel.getComponent(this._dimName + 'Axis', this._axisIndex); }, getOtherAxisModel: function () { var t, e, n = this._dimName, i = this.ecModel, r = this.getAxisModel(); 'x' === n || 'y' === n ? ((e = 'gridIndex'), (t = 'x' === n ? 'y' : 'x')) : ((e = 'polarIndex'), (t = 'angle' === n ? 'radius' : 'angle')); var o; return ( i.eachComponent(t + 'Axis', function (t) { (t.get(e) || 0) === (r.get(e) || 0) && (o = t); }), o ); }, getMinMaxSpan: function () { return n(this._minMaxSpan); }, calculateDataWindow: function (t) { var e = this._dataExtent, n = this.getAxisModel().axis.scale, i = this._dataZoomModel.getRangePropMode(), r = [0, 100], o = [t.start, t.end], a = []; return ( A_(['startValue', 'endValue'], function (e) { a.push(null != t[e] ? n.parse(t[e]) : null); }), A_([0, 1], function (t) { var s = a[t], l = o[t]; 'percent' === i[t] ? (null == l && (l = r[t]), (s = n.parse(_n(l, r, e, !0)))) : (l = _n(s, e, r, !0)), (a[t] = s), (o[t] = l); }), { valueWindow: C_(a), percentWindow: C_(o) } ); }, reset: function (t) { if (t === this._dataZoomModel) { this._dataExtent = Hh( this, this._dimName, this.getTargetSeriesModels() ); var e = this.calculateDataWindow(t.option); (this._valueWindow = e.valueWindow), (this._percentWindow = e.percentWindow), Uh(this), Zh(this); } }, restore: function (t) { t === this._dataZoomModel && ((this._valueWindow = this._percentWindow = null), Zh(this, !0)); }, filterData: function (t) { function e(t) { return t >= o[0] && t <= o[1]; } if (t === this._dataZoomModel) { var n = this._dimName, i = this.getTargetSeriesModels(), r = t.get('filterMode'), o = this._valueWindow; if ('none' !== r) { var a = this.getOtherAxisModel(); t.get('$fromToolbox') && a && 'category' === a.get('type') && (r = 'empty'), A_(i, function (t) { var i = t.getData(), a = t.coordDimToDataDim(n); 'weakFilter' === r ? i && i.filterSelf(function (t) { for (var e, n, r, s = 0; s < a.length; s++) { var l = i.get(a[s], t), h = !isNaN(l), u = l < o[0], c = l > o[1]; if (h && !u && !c) return !0; h && (r = !0), u && (e = !0), c && (n = !0); } return r && e && n; }) : i && A_(a, function (n) { 'empty' === r ? t.setData( i.map(n, function (t) { return e(t) ? t : NaN; }) ) : i.filterSelf(n, e); }); }); } } }, }; var D_ = d, P_ = T_, L_ = Ko({ type: 'dataZoom', dependencies: [ 'xAxis', 'yAxis', 'zAxis', 'radiusAxis', 'angleAxis', 'singleAxis', 'series', ], defaultOption: { zlevel: 0, z: 4, orient: null, xAxisIndex: null, yAxisIndex: null, filterMode: 'filter', throttle: null, start: 0, end: 100, startValue: null, endValue: null, minSpan: null, maxSpan: null, minValueSpan: null, maxValueSpan: null, rangeMode: null, }, init: function (t, e, n) { (this._dataIntervalByAxis = {}), (this._dataInfo = {}), (this._axisProxies = {}), this.textStyleModel, (this._autoThrottle = !0), (this._rangePropMode = ['percent', 'percent']); var i = Xh(t); this.mergeDefaultAndTheme(t, n), this.doInit(i); }, mergeOption: function (t) { var e = Xh(t); i(this.option, t, !0), this.doInit(e); }, doInit: function (t) { var e = this.option; Md.canvasSupported || (e.realtime = !1), this._setDefaultThrottle(t), jh(this, t), D_( [ ['start', 'startValue'], ['end', 'endValue'], ], function (t, n) { 'value' === this._rangePropMode[n] && (e[t[0]] = null); }, this ), (this.textStyleModel = this.getModel('textStyle')), this._resetTarget(), this._giveAxisProxies(); }, _giveAxisProxies: function () { var t = this._axisProxies; this.eachTargetAxis(function (e, n, i, r) { var o = this.dependentModels[e.axis][n], a = o.__dzAxisProxy || (o.__dzAxisProxy = new k_(e.name, n, this, r)); t[e.name + '_' + n] = a; }, this); }, _resetTarget: function () { var t = this.option, e = this._judgeAutoMode(); P_(function (e) { var n = e.axisIndex; t[n] = Tr(t[n]); }, this), 'axisIndex' === e ? this._autoSetAxisIndex() : 'orient' === e && this._autoSetOrient(); }, _judgeAutoMode: function () { var t = this.option, e = !1; P_(function (n) { null != t[n.axisIndex] && (e = !0); }, this); var n = t.orient; return null == n && e ? 'orient' : e ? void 0 : (null == n && (t.orient = 'horizontal'), 'axisIndex'); }, _autoSetAxisIndex: function () { var t = !0, e = this.get('orient', !0), n = this.option, i = this.dependentModels; if (t) { var r = 'vertical' === e ? 'y' : 'x'; i[r + 'Axis'].length ? ((n[r + 'AxisIndex'] = [0]), (t = !1)) : D_(i.singleAxis, function (i) { t && i.get('orient', !0) === e && ((n.singleAxisIndex = [i.componentIndex]), (t = !1)); }); } t && P_(function (e) { if (t) { var i = [], r = this.dependentModels[e.axis]; if (r.length && !i.length) for (var o = 0, a = r.length; o < a; o++) 'category' === r[o].get('type') && i.push(o); (n[e.axisIndex] = i), i.length && (t = !1); } }, this), t && this.ecModel.eachSeries(function (t) { this._isSeriesHasAllAxesTypeOf(t, 'value') && P_(function (e) { var i = n[e.axisIndex], r = t.get(e.axisIndex), o = t.get(e.axisId); l( i, (r = t.ecModel.queryComponents({ mainType: e.axis, index: r, id: o, })[0].componentIndex) ) < 0 && i.push(r); }); }, this); }, _autoSetOrient: function () { var t; this.eachTargetAxis(function (e) { !t && (t = e.name); }, this), (this.option.orient = 'y' === t ? 'vertical' : 'horizontal'); }, _isSeriesHasAllAxesTypeOf: function (t, e) { var n = !0; return ( P_(function (i) { var r = t.get(i.axisIndex), o = this.dependentModels[i.axis][r]; (o && o.get('type') === e) || (n = !1); }, this), n ); }, _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; } }, getFirstTargetAxisModel: function () { var t; return ( P_(function (e) { if (null == t) { var n = this.get(e.axisIndex); n.length && (t = this.dependentModels[e.axis][n[0]]); } }, this), t ); }, eachTargetAxis: function (t, e) { var n = this.ecModel; P_(function (i) { D_( this.get(i.axisIndex), function (r) { t.call(e, i, r, this, n); }, this ); }, this); }, getAxisProxy: function (t, e) { return this._axisProxies[t + '_' + e]; }, getAxisModel: function (t, e) { var n = this.getAxisProxy(t, e); return n && n.getAxisModel(); }, setRawRange: function (t, e) { var n = this.option; D_( [ ['start', 'startValue'], ['end', 'endValue'], ], function (e) { (null == t[e[0]] && null == t[e[1]]) || ((n[e[0]] = t[e[0]]), (n[e[1]] = t[e[1]])); }, this ), !e && jh(this, t); }, getPercentRange: function () { var t = this.findRepresentativeAxisProxy(); if (t) return t.getDataPercentWindow(); }, 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; }, findRepresentativeAxisProxy: function (t) { if (t) return t.__dzAxisProxy; var e = this._axisProxies; for (var n in e) if (e.hasOwnProperty(n) && e[n].hostedBy(this)) return e[n]; for (var n in e) if (e.hasOwnProperty(n) && !e[n].hostedBy(this)) return e[n]; }, getRangePropMode: function () { return this._rangePropMode.slice(); }, }), O_ = $v.extend({ type: 'dataZoom', render: function (t, e, n, i) { (this.dataZoomModel = t), (this.ecModel = e), (this.api = n); }, getTargetCoordInfo: function () { function t(t, e, n, i) { for (var r, o = 0; o < n.length; o++) if (n[o].model === t) { r = n[o]; break; } r || n.push((r = { model: t, axisModels: [], coordIndex: i })), r.axisModels.push(e); } var e = this.dataZoomModel, n = this.ecModel, i = {}; return ( e.eachTargetAxis(function (e, r) { var o = n.getComponent(e.axis, r); if (o) { var a = o.getCoordSysModel(); a && t( a, o, i[a.mainType] || (i[a.mainType] = []), a.componentIndex ); } }, this), i ); }, }), z_ = (L_.extend({ type: 'dataZoom.slider', layoutMode: 'box', defaultOption: { show: !0, right: 'ph', top: 'ph', width: 'ph', height: 'ph', left: null, bottom: null, backgroundColor: 'rgba(47,69,84,0)', dataBackground: { lineStyle: { color: '#2f4554', width: 0.5, opacity: 0.3 }, areaStyle: { color: 'rgba(47,69,84,0.3)', opacity: 0.3 }, }, borderColor: '#ddd', fillerColor: 'rgba(167,183,204,0.4)', handleIcon: 'M8.2,13.6V3.9H6.3v9.7H3.1v14.9h3.3v9.7h1.8v-9.7h3.3V13.6H8.2z M9.7,24.4H4.8v-1.4h4.9V24.4z M9.7,19.1H4.8v-1.4h4.9V19.1z', handleSize: '100%', handleStyle: { color: '#a7b7cc' }, labelPrecision: null, labelFormatter: null, showDetail: !0, showDataShadow: 'auto', realtime: !0, zoomLock: !1, textStyle: { color: '#333' }, }, }), function (t, e, n, i, r, o) { (e[0] = Yh(e[0], n)), (e[1] = Yh(e[1], n)), (t = t || 0); var a = n[1] - n[0]; null != r && (r = Yh(r, [0, a])), null != o && (o = Math.max(o, null != r ? r : 0)), 'all' === i && ((r = o = Math.abs(e[1] - e[0])), (i = 0)); var s = qh(e, i); e[i] += t; var l = r || 0, h = n.slice(); s.sign < 0 ? (h[0] += l) : (h[1] -= l), (e[i] = Yh(e[i], h)); u = qh(e, i); null != r && (u.sign !== s.sign || u.span < r) && (e[1 - i] = e[i] + s.sign * r); var u = qh(e, i); return null != o && u.span > o && (e[1 - i] = e[i] + u.sign * o), e; }), E_ = Zg, N_ = _n, B_ = Mn, R_ = v, V_ = d, G_ = 'horizontal', W_ = 5, H_ = ['line', 'bar', 'candlestick', 'scatter'], F_ = O_.extend({ type: 'dataZoom.slider', init: function (t, e) { (this._displayables = {}), this._orient, this._range, this._handleEnds, this._size, this._handleWidth, this._handleHeight, this._location, this._dragging, this._dataShadowInfo, (this.api = e); }, render: function (t, e, n, i) { F_.superApply(this, 'render', arguments), wo( this, '_dispatchZoomAction', this.dataZoomModel.get('throttle'), 'fixRate' ), (this._orient = t.get('orient')), !1 !== this.dataZoomModel.get('show') ? ((i && 'dataZoom' === i.type && i.from === this.uid) || this._buildView(), this._updateView()) : this.group.removeAll(); }, remove: function () { F_.superApply(this, 'remove', arguments), bo(this, '_dispatchZoomAction'); }, dispose: function () { F_.superApply(this, 'dispose', arguments), bo(this, '_dispatchZoomAction'); }, _buildView: function () { var t = this.group; t.removeAll(), this._resetLocation(), this._resetInterval(); var e = (this._displayables.barGroup = new Tf()); this._renderBackground(), this._renderHandle(), this._renderDataShadow(), t.add(e), this._positionGroup(); }, _resetLocation: function () { var t = this.dataZoomModel, e = this.api, n = this._findCoordRect(), i = { width: e.getWidth(), height: e.getHeight() }, r = this._orient === G_ ? { right: i.width - n.x - n.width, top: i.height - 30 - 7, width: n.width, height: 30, } : { right: 7, top: n.y, width: 30, height: n.height }, o = Ur(t.option); d(['right', 'top', 'width', 'height'], function (t) { 'ph' === o[t] && (o[t] = r[t]); }); var a = Hr(o, i, t.padding); (this._location = { x: a.x, y: a.y }), (this._size = [a.width, a.height]), 'vertical' === this._orient && this._size.reverse(); }, _positionGroup: function () { var t = this.group, e = this._location, n = this._orient, i = this.dataZoomModel.getFirstTargetAxisModel(), r = i && i.get('inverse'), o = this._displayables.barGroup, a = (this._dataShadowInfo || {}).otherAxisInverse; o.attr( n !== G_ || r ? n === G_ && r ? { scale: a ? [-1, 1] : [-1, -1] } : 'vertical' !== n || r ? { scale: a ? [-1, -1] : [-1, 1], rotation: Math.PI / 2 } : { scale: a ? [1, -1] : [1, 1], rotation: Math.PI / 2 } : { scale: a ? [1, 1] : [1, -1] } ); var s = t.getBoundingRect([o]); t.attr('position', [e.x - s.x, e.y - s.y]); }, _getViewExtent: function () { return [0, this._size[0]]; }, _renderBackground: function () { var t = this.dataZoomModel, e = this._size, n = this._displayables.barGroup; n.add( new E_({ silent: !0, shape: { x: 0, y: 0, width: e[0], height: e[1] }, style: { fill: t.get('backgroundColor') }, z2: -40, }) ), n.add( new E_({ shape: { x: 0, y: 0, width: e[0], height: e[1] }, style: { fill: 'transparent' }, z2: 0, onclick: v(this._onClickPanelClick, this), }) ); }, _renderDataShadow: function () { var t = (this._dataShadowInfo = this._prepareDataShadowInfo()); if (t) { var e = this._size, n = t.series, i = n.getRawData(), r = n.getShadowDim ? n.getShadowDim() : t.otherDim; if (null != r) { var o = i.getDataExtent(r), s = 0.3 * (o[1] - o[0]); o = [o[0] - s, o[1] + s]; var l, h = [0, e[1]], u = [0, e[0]], c = [ [e[0], 0], [0, 0], ], d = [], f = u[1] / (i.count() - 1), p = 0, g = Math.round(i.count() / e[0]); i.each([r], function (t, e) { if (g > 0 && e % g) p += f; else { var n = null == t || isNaN(t) || '' === t, i = n ? 0 : N_(t, o, h, !0); n && !l && e ? (c.push([c[c.length - 1][0], 0]), d.push([d[d.length - 1][0], 0])) : !n && l && (c.push([p, 0]), d.push([p, 0])), c.push([p, i]), d.push([p, i]), (p += f), (l = n); } }); var v = this.dataZoomModel; this._displayables.barGroup.add( new Hg({ shape: { points: c }, style: a( { fill: v.get('dataBackgroundColor') }, v.getModel('dataBackground.areaStyle').getAreaStyle() ), silent: !0, z2: -20, }) ), this._displayables.barGroup.add( new Fg({ shape: { points: d }, style: v.getModel('dataBackground.lineStyle').getLineStyle(), silent: !0, z2: -19, }) ); } } }, _prepareDataShadowInfo: function () { var t = this.dataZoomModel, e = t.get('showDataShadow'); if (!1 !== e) { var n, i = this.ecModel; return ( t.eachTargetAxis(function (r, o) { d( t.getAxisProxy(r.name, o).getTargetSeriesModels(), function (t) { if (!(n || (!0 !== e && l(H_, t.get('type')) < 0))) { var a, s = i.getComponent(r.axis, o).axis, h = $h(r.name), u = t.coordinateSystem; null != h && u.getOtherAxis && (a = u.getOtherAxis(s).inverse), (n = { thisAxis: s, series: t, thisDim: r.name, otherDim: h, otherAxisInverse: a, }); } }, this ); }, this), n ); } }, _renderHandle: function () { var t = this._displayables, e = (t.handles = []), n = (t.handleLabels = []), i = this._displayables.barGroup, r = this._size, o = this.dataZoomModel; i.add( (t.filler = new E_({ draggable: !0, cursor: Kh(this._orient), drift: R_(this._onDragMove, this, 'all'), onmousemove: function (t) { tp(t.event); }, ondragstart: R_(this._showDataInfo, this, !0), ondragend: R_(this._onDragEnd, this), onmouseover: R_(this._showDataInfo, this, !0), onmouseout: R_(this._showDataInfo, this, !1), style: { fill: o.get('fillerColor'), textPosition: 'inside' }, })) ), i.add( new E_( Zi({ silent: !0, shape: { x: 0, y: 0, width: r[0], height: r[1] }, style: { stroke: o.get('dataBackgroundColor') || o.get('borderColor'), lineWidth: 1, fill: 'rgba(0,0,0,0)', }, }) ) ), V_( [0, 1], function (t) { var r = br( o.get('handleIcon'), { cursor: Kh(this._orient), draggable: !0, drift: R_(this._onDragMove, this, t), onmousemove: function (t) { tp(t.event); }, ondragend: R_(this._onDragEnd, this), onmouseover: R_(this._showDataInfo, this, !0), onmouseout: R_(this._showDataInfo, this, !1), }, { x: -1, y: 0, width: 2, height: 2 } ), a = r.getBoundingRect(); (this._handleHeight = wn(o.get('handleSize'), this._size[1])), (this._handleWidth = (a.width / a.height) * this._handleHeight), r.setStyle(o.getModel('handleStyle').getItemStyle()); var s = o.get('handleColor'); null != s && (r.style.fill = s), i.add((e[t] = r)); var l = o.textStyleModel; this.group.add( (n[t] = new zg({ silent: !0, invisible: !0, style: { x: 0, y: 0, text: '', textVerticalAlign: 'middle', textAlign: 'center', textFill: l.getTextColor(), textFont: l.getFont(), }, z2: 10, })) ); }, this ); }, _resetInterval: function () { var t = (this._range = this.dataZoomModel.getPercentRange()), e = this._getViewExtent(); this._handleEnds = [ N_(t[0], [0, 100], e, !0), N_(t[1], [0, 100], e, !0), ]; }, _updateInterval: function (t, e) { var n = this.dataZoomModel, i = this._handleEnds, r = this._getViewExtent(), o = n.findRepresentativeAxisProxy().getMinMaxSpan(), a = [0, 100]; z_( e, i, r, n.get('zoomLock') ? 'all' : t, null != o.minSpan ? N_(o.minSpan, a, r, !0) : null, null != o.maxSpan ? N_(o.maxSpan, a, r, !0) : null ), (this._range = B_([N_(i[0], r, a, !0), N_(i[1], r, a, !0)])); }, _updateView: function (t) { var e = this._displayables, n = this._handleEnds, i = B_(n.slice()), r = this._size; V_( [0, 1], function (t) { var i = e.handles[t], o = this._handleHeight; i.attr({ scale: [o / 2, o / 2], position: [n[t], r[1] / 2 - o / 2], }); }, this ), e.filler.setShape({ x: i[0], y: 0, width: i[1] - i[0], height: r[1], }), this._updateDataInfo(t); }, _updateDataInfo: function (t) { function e(t) { var e = mr(i.handles[t].parent, this.group), n = xr(0 === t ? 'right' : 'left', e), s = this._handleWidth / 2 + W_, l = yr([c[t] + (0 === t ? -s : s), this._size[1] / 2], e); r[t].setStyle({ x: l[0], y: l[1], textVerticalAlign: o === G_ ? 'middle' : n, textAlign: o === G_ ? n : 'center', text: a[t], }); } var n = this.dataZoomModel, i = this._displayables, r = i.handleLabels, o = this._orient, a = ['', '']; if (n.get('showDetail')) { var s = n.findRepresentativeAxisProxy(); if (s) { var l = s.getAxisModel().axis, h = this._range, u = t ? s.calculateDataWindow({ start: h[0], end: h[1] }).valueWindow : s.getDataValueWindow(); a = [this._formatLabel(u[0], l), this._formatLabel(u[1], l)]; } } var c = B_(this._handleEnds.slice()); e.call(this, 0), e.call(this, 1); }, _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(Math.round(t)) : t.toFixed(Math.min(r, 20)); return x(i) ? i(t, o) : _(i) ? i.replace('{value}', o) : o; }, _showDataInfo: function (t) { t = this._dragging || t; var e = this._displayables.handleLabels; e[0].attr('invisible', !t), e[1].attr('invisible', !t); }, _onDragMove: function (t, e, n) { this._dragging = !0; var i = yr([e, n], this._displayables.barGroup.getLocalTransform(), !0); this._updateInterval(t, i[0]); var r = this.dataZoomModel.get('realtime'); this._updateView(!r), r && r && this._dispatchZoomAction(); }, _onDragEnd: function () { (this._dragging = !1), this._showDataInfo(!1), this._dispatchZoomAction(); }, _onClickPanelClick: function (t) { var e = this._size, n = this._displayables.barGroup.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; this._updateInterval('all', n[0] - r), this._updateView(), this._dispatchZoomAction(); } }, _dispatchZoomAction: function () { var t = this._range; this.api.dispatchAction({ type: 'dataZoom', from: this.uid, dataZoomId: this.dataZoomModel.id, start: t[0], end: t[1], }); }, _findCoordRect: function () { var t; if ( (V_(this.getTargetCoordInfo(), function (e) { if (!t && e.length) { var n = e[0].model.coordinateSystem; t = n.getRect && n.getRect(); } }), !t) ) { var e = this.api.getWidth(), n = this.api.getHeight(); t = { x: 0.2 * e, y: 0.2 * n, width: 0.6 * e, height: 0.6 * n }; } return t; }, }); L_.extend({ type: 'dataZoom.inside', defaultOption: { disabled: !1, zoomLock: !1, zoomOnMouseWheel: !0, moveOnMouseMove: !0, preventDefaultMouseMove: !0, }, }); var Z_ = '\0_ec_interaction_mutex'; jo( { type: 'takeGlobalCursor', event: 'globalCursorTaken', update: 'update' }, function () {} ), u(nu, Ud); var U_ = m, X_ = '\0_ec_dataZoom_roams', j_ = v, q_ = O_.extend({ type: 'dataZoom.inside', init: function (t, e) { this._range; }, render: function (t, e, n, i) { q_.superApply(this, 'render', arguments), du(i, t.id) && (this._range = t.getPercentRange()), d( this.getTargetCoordInfo(), function (e, i) { var r = f(e, function (t) { return fu(t.model); }); d( e, function (e) { var o = e.model, a = t.option; uu(n, { coordId: fu(o), allCoordIds: r, containsPoint: function (t, e, n) { return o.coordinateSystem.containPoint([e, n]); }, dataZoomId: t.id, throttleRate: t.get('throttle', !0), panGetRange: j_(this._onPan, this, e, i), zoomGetRange: j_(this._onZoom, this, e, i), zoomLock: a.zoomLock, disabled: a.disabled, roamControllerOpt: { zoomOnMouseWheel: a.zoomOnMouseWheel, moveOnMouseMove: a.moveOnMouseMove, preventDefaultMouseMove: a.preventDefaultMouseMove, }, }); }, this ); }, this ); }, dispose: function () { cu(this.api, this.dataZoomModel.id), q_.superApply(this, 'dispose', arguments), (this._range = null); }, _onPan: function (t, e, n, i, r, o, a, s, l) { var h = this._range.slice(), u = t.axisModels[0]; if (u) { var c = Y_[e]([o, a], [s, l], u, n, t), d = (c.signal * (h[1] - h[0]) * c.pixel) / c.pixelLength; return z_(d, h, [0, 100], 'all'), (this._range = h); } }, _onZoom: function (t, e, n, i, r, o) { var a = this._range.slice(), s = t.axisModels[0]; if (s) { var l = Y_[e](null, [r, o], s, n, t), h = ((l.signal > 0 ? l.pixelStart + l.pixelLength - l.pixel : l.pixel - l.pixelStart) / l.pixelLength) * (a[1] - a[0]) + a[0]; (i = Math.max(1 / i, 0)), (a[0] = (a[0] - h) * i + h), (a[1] = (a[1] - h) * i + h); var u = this.dataZoomModel .findRepresentativeAxisProxy() .getMinMaxSpan(); return z_(0, a, [0, 100], 0, u.minSpan, u.maxSpan), (this._range = a); } }, }), Y_ = { 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(), h = 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 = h[1] - h[0]), (a.pixelStart = h[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 ); }, }; Xo(function (t, e) { t.eachComponent('dataZoom', function (t) { t.eachTargetAxis(bu), t.eachTargetAxis(Mu); }), t.eachComponent('dataZoom', function (t) { var e = t.findRepresentativeAxisProxy(), n = e.getDataPercentWindow(), i = e.getDataValueWindow(); t.setRawRange( { start: n[0], end: n[1], startValue: i[0], endValue: i[1] }, !0 ); }); }), jo('dataZoom', function (t, e) { var n = Wh(v(e.eachComponent, e, 'dataZoom'), T_, function (t, e) { return t.get(e.axisIndex); }), i = []; e.eachComponent({ mainType: 'dataZoom', query: t }, function (t, e) { i.push.apply(i, n(t).nodes); }), d(i, function (e, n) { e.setRawRange({ start: t.start, end: t.end, startValue: t.startValue, endValue: t.endValue, }); }); }); var $_ = {}, K_ = Ko({ type: 'toolbox', layoutMode: { type: 'box', ignoreSize: !0 }, mergeDefaultAndTheme: function (t) { K_.superApply(this, 'mergeDefaultAndTheme', arguments), d(this.option.feature, function (t, e) { var n = Iu(e); n && i(t, n.defaultOption); }); }, defaultOption: { show: !0, z: 6, zlevel: 0, orient: 'horizontal', left: 'right', top: 'top', backgroundColor: 'transparent', borderColor: '#ccc', borderRadius: 0, borderWidth: 0, padding: 5, itemSize: 15, itemGap: 8, showTitle: !0, iconStyle: { normal: { borderColor: '#666', color: 'none' }, emphasis: { borderColor: '#3E98C5' }, }, }, }); Qo({ type: 'toolbox', render: function (t, e, n, i) { function r(r, a) { var s, c = u[r], d = u[a], f = new Mr(l[c], t, t.ecModel); if (c && !d) { if (Tu(c)) s = { model: f, onclick: f.option.onclick, featureName: c }; else { var p = Iu(c); if (!p) return; s = new p(f, e, n); } h[c] = s; } else { if (!(s = h[d])) return; (s.model = f), (s.ecModel = e), (s.api = n); } c || !d ? f.get('show') && !s.unusable ? (o(f, s, c), (f.setIconStatus = function (t, e) { var n = this.option, i = this.iconPaths; (n.iconStatus = n.iconStatus || {}), (n.iconStatus[t] = e), i[t] && i[t].trigger(e); }), s.render && s.render(f, e, n, i)) : s.remove && s.remove(e, n) : s.dispose && s.dispose(e, n); } function o(i, r, o) { var l = i.getModel('iconStyle'), h = r.getIcons ? r.getIcons() : i.get('icon'), u = i.get('title') || {}; if ('string' == typeof h) { var c = h, f = u; (u = {}), ((h = {})[o] = c), (u[o] = f); } var p = (i.iconPaths = {}); d(h, function (o, h) { var c = br(o, {}, { x: -s / 2, y: -s / 2, width: s, height: s }); c.setStyle(l.getModel('normal').getItemStyle()), (c.hoverStyle = l.getModel('emphasis').getItemStyle()), rr(c), t.get('showTitle') && ((c.__title = u[h]), c .on('mouseover', function () { var t = l.getModel('emphasis').getItemStyle(); c.setStyle({ text: u[h], textPosition: t.textPosition || 'bottom', textFill: t.fill || t.stroke || '#000', textAlign: t.textAlign || 'center', }); }) .on('mouseout', function () { c.setStyle({ textFill: null }); })), c.trigger(i.get('iconStatus.' + h) || 'normal'), a.add(c), c.on('click', v(r.onclick, r, e, n, h)), (p[h] = c); }); } var a = this.group; if ((a.removeAll(), t.get('show'))) { var s = +t.get('itemSize'), l = t.get('feature') || {}, h = this._features || (this._features = {}), u = []; d(l, function (t, e) { u.push(e); }), new na(this._featureNames || [], u) .add(r) .update(r) .remove(m(r, null)) .execute(), (this._featureNames = u), ih(a, t, n), a.add(rh(a.getBoundingRect(), t)), a.eachChild(function (t) { var e = t.__title, i = t.hoverStyle; if (i && e) { var r = he(e, Se(i)), o = t.position[0] + a.position[0], l = !1; t.position[1] + a.position[1] + s + r.height > n.getHeight() && ((i.textPosition = 'top'), (l = !0)); var h = l ? -5 - r.height : s + 8; o + r.width / 2 > n.getWidth() ? ((i.textPosition = ['100%', h]), (i.textAlign = 'right')) : o - r.width / 2 < 0 && ((i.textPosition = [0, h]), (i.textAlign = 'left')); } }); } }, updateView: function (t, e, n, i) { d(this._features, function (t) { t.updateView && t.updateView(t.model, e, n, i); }); }, updateLayout: function (t, e, n, i) { d(this._features, function (t) { t.updateLayout && t.updateLayout(t.model, e, n, i); }); }, remove: function (t, e) { d(this._features, function (n) { n.remove && n.remove(t, e); }), this.group.removeAll(); }, dispose: function (t, e) { d(this._features, function (n) { n.dispose && n.dispose(t, e); }); }, }); var Q_ = { 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: ['右键另存为图片'] }, }, }, J_ = Q_.toolbox.saveAsImage; (Au.defaultOption = { 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: J_.title, type: 'png', name: '', excludeComponents: ['toolbox'], pixelRatio: 1, lang: J_.lang.slice(), }), (Au.prototype.unusable = !Md.canvasSupported), (Au.prototype.onclick = function (t, e) { var n = this.model, i = n.get('name') || t.get('title.0.text') || 'echarts', r = document.createElement('a'), o = n.get('type', !0) || 'png'; (r.download = i + '.' + o), (r.target = '_blank'); var a = e.getConnectedDataURL({ type: o, backgroundColor: n.get('backgroundColor', !0) || t.get('backgroundColor') || '#fff', excludeComponents: n.get('excludeComponents'), pixelRatio: n.get('pixelRatio'), }); if ( ((r.href = a), 'function' != typeof MouseEvent || Md.browser.ie || Md.browser.edge) ) if (window.navigator.msSaveOrOpenBlob) { for ( var s = atob(a.split(',')[1]), l = s.length, h = new Uint8Array(l); l--; ) h[l] = s.charCodeAt(l); var u = new Blob([h]); window.navigator.msSaveOrOpenBlob(u, i + '.' + o); } else { var c = n.get('lang'), d = ''; window.open().document.write(d); } else { var f = new MouseEvent('click', { view: window, bubbles: !0, cancelable: !1, }); r.dispatchEvent(f); } }), Su('saveAsImage', Au); var tw = Q_.toolbox.magicType; Cu.defaultOption = { 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', tiled: 'M2.3,2.2h22.8V25H2.3V2.2z M35,2.2h22.8V25H35V2.2zM2.3,35h22.8v22.8H2.3V35z M35,35h22.8v22.8H35V35z', }, title: n(tw.title), option: {}, seriesIndex: {}, }; var ew = Cu.prototype; ew.getIcons = function () { var t = this.model, e = t.get('icon'), n = {}; return ( d(t.get('type'), function (t) { e[t] && (n[t] = e[t]); }), n ); }; var nw = { line: function (t, e, n, r) { if ('bar' === t) return i( { id: e, type: 'line', data: n.get('data'), stack: n.get('stack'), markPoint: n.get('markPoint'), markLine: n.get('markLine'), }, r.get('option.line') || {}, !0 ); }, bar: function (t, e, n, r) { if ('line' === t) return i( { id: e, type: 'bar', data: n.get('data'), stack: n.get('stack'), markPoint: n.get('markPoint'), markLine: n.get('markLine'), }, r.get('option.bar') || {}, !0 ); }, stack: function (t, e, n, r) { if ('line' === t || 'bar' === t) return i( { id: e, stack: '__ec_magicType_stack__' }, r.get('option.stack') || {}, !0 ); }, tiled: function (t, e, n, r) { if ('line' === t || 'bar' === t) return i({ id: e, stack: '' }, r.get('option.tiled') || {}, !0); }, }, iw = [ ['line', 'bar'], ['stack', 'tiled'], ]; (ew.onclick = function (t, e, n) { var i = this.model, r = i.get('seriesIndex.' + n); if (nw[n]) { var o = { series: [] }; d(iw, function (t) { l(t, n) >= 0 && d(t, function (t) { i.setIconStatus(t, 'normal'); }); }), i.setIconStatus(n, 'emphasis'), t.eachComponent( { mainType: 'series', query: null == r ? null : { seriesIndex: r } }, function (e) { var r = e.subType, s = e.id, l = nw[n](r, s, e, i); l && (a(l, e.option), o.series.push(l)); var h = e.coordinateSystem; if ( h && 'cartesian2d' === h.type && ('line' === n || 'bar' === n) ) { var u = h.getAxesByScale('ordinal')[0]; if (u) { var c = u.dim + 'Axis', d = t.queryComponents({ mainType: c, index: e.get(name + 'Index'), id: e.get(name + 'Id'), })[0].componentIndex; o[c] = o[c] || []; for (var f = 0; f <= d; f++) o[c][d] = o[c][d] || {}; o[c][d].boundaryGap = 'bar' === n; } } } ), e.dispatchAction({ type: 'changeMagicType', currentType: n, newOption: o, }); } }), jo( { type: 'changeMagicType', event: 'magicTypeChanged', update: 'prepareAndUpdate', }, function (t, e) { e.mergeOption(t.newOption); } ), Su('magicType', Cu); var rw = Q_.toolbox.dataView, ow = new Array(60).join('-'), aw = '\t', sw = new RegExp('[' + aw + ']+', 'g'); (Ru.defaultOption = { 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: n(rw.title), lang: n(rw.lang), backgroundColor: '#fff', textColor: '#000', textareaColor: '#fff', textareaBorderColor: '#333', buttonColor: '#c23531', buttonTextColor: '#fff', }), (Ru.prototype.onclick = function (t, e) { function n() { i.removeChild(o), (x._dom = null); } var i = e.getDom(), r = this.model; this._dom && i.removeChild(this._dom); var o = document.createElement('div'); (o.style.cssText = 'position:absolute;left:5px;top:5px;bottom:5px;right:5px;'), (o.style.backgroundColor = r.get('backgroundColor') || '#fff'); var a = document.createElement('h4'), s = r.get('lang') || []; (a.innerHTML = s[0] || r.get('title')), (a.style.cssText = 'margin: 10px 20px;'), (a.style.color = r.get('textColor')); var l = document.createElement('div'), h = document.createElement('textarea'); l.style.cssText = 'display:block;width:100%;overflow:auto;'; var u = r.get('optionToContent'), c = r.get('contentToOption'), d = Lu(t); if ('function' == typeof u) { var f = u(e.getOption()); 'string' == typeof f ? (l.innerHTML = f) : M(f) && l.appendChild(f); } else l.appendChild(h), (h.readOnly = r.get('readOnly')), (h.style.cssText = 'width:100%;height:100%;font-family:monospace;font-size:14px;line-height:1.6rem;'), (h.style.color = r.get('textColor')), (h.style.borderColor = r.get('textareaBorderColor')), (h.style.backgroundColor = r.get('textareaColor')), (h.value = d.value); var p = d.meta, g = document.createElement('div'); g.style.cssText = 'position:absolute;bottom:0;left:0;right:0;'; var v = 'float:right;margin-right:20px;border:none;cursor:pointer;padding:2px 5px;font-size:12px;border-radius:3px', m = document.createElement('div'), y = document.createElement('div'); (v += ';background-color:' + r.get('buttonColor')), (v += ';color:' + r.get('buttonTextColor')); var x = this; on(m, 'click', n), on(y, 'click', function () { var t; try { t = 'function' == typeof c ? c(l, e.getOption()) : Bu(h.value, p); } catch (t) { throw (n(), new Error('Data view format error ' + t)); } t && e.dispatchAction({ type: 'changeDataView', newOption: t }), n(); }), (m.innerHTML = s[1]), (y.innerHTML = s[2]), (y.style.cssText = v), (m.style.cssText = v), !r.get('readOnly') && g.appendChild(y), g.appendChild(m), on(h, 'keydown', function (t) { if (9 === (t.keyCode || t.which)) { var e = this.value, n = this.selectionStart, i = this.selectionEnd; (this.value = e.substring(0, n) + aw + e.substring(i)), (this.selectionStart = this.selectionEnd = n + 1), tp(t); } }), o.appendChild(a), o.appendChild(l), o.appendChild(g), (l.style.height = i.clientHeight - 80 + 'px'), i.appendChild(o), (this._dom = o); }), (Ru.prototype.remove = function (t, e) { this._dom && e.getDom().removeChild(this._dom); }), (Ru.prototype.dispose = function (t, e) { this.remove(t, e); }), Su('dataView', Ru), jo( { type: 'changeDataView', event: 'dataViewChanged', update: 'prepareAndUpdate', }, function (t, e) { var n = []; d(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: Vu(t.data, r) }); } else n.push(o({ type: 'scatter' }, t)); }), e.mergeOption(a({ series: n }, t.newOption)); } ); var lw = m, hw = d, uw = f, cw = Math.min, dw = Math.max, fw = Math.pow, pw = 1e4, gw = 6, vw = 6, mw = 'globalPan', yw = { w: [0, 0], e: [0, 1], n: [1, 0], s: [1, 1] }, xw = { w: 'ew', e: 'ew', n: 'ns', s: 'ns', ne: 'nesw', sw: 'nesw', nw: 'nwse', se: 'nwse', }, _w = { brushStyle: { lineWidth: 2, stroke: 'rgba(0,0,0,0.3)', fill: 'rgba(0,0,0,0.1)', }, transformable: !0, brushMode: 'single', removeOnClick: !1, }, ww = 0; (Gu.prototype = { constructor: Gu, enableBrush: function (t) { return this._brushType && Hu(this), t.brushType && Wu(this, t), this; }, setPanels: function (t) { if (t && t.length) { var e = (this._panels = {}); d(t, function (t) { e[t.panelId] = n(t); }); } else this._panels = null; return this; }, mount: function (t) { (t = t || {}), (this._enableGlobalPan = t.enableGlobalPan); var e = this.group; return ( this._zr.add(e), e.attr({ position: t.position || [0, 0], rotation: t.rotation || 0, scale: t.scale || [1, 1], }), (this._transform = e.getLocalTransform()), this ); }, eachCover: function (t, e) { hw(this._covers, t, e); }, updateCovers: function (t) { function e(t, e) { return (null != t.id ? t.id : o + e) + '-' + t.brushType; } function r(e, n) { var i = t[e]; if (null != n && a[n] === h) s[e] = a[n]; else { var r = (s[e] = null != n ? ((a[n].__brushOption = i), a[n]) : Zu(l, Fu(l, i))); ju(l, r); } } t = f(t, function (t) { return i(n(_w), t, !0); }); var o = '\0-brush-index-', a = this._covers, s = (this._covers = []), l = this, h = this._creatingCover; return ( new na( a, t, function (t, n) { return e(t.__brushOption, n); }, e ) .add(r) .update(r) .remove(function (t) { a[t] !== h && l.group.remove(a[t]); }) .execute(), this ); }, unmount: function () { return this.enableBrush(!1), Ku(this), this._zr.remove(this.group), this; }, dispose: function () { this.unmount(), this.off(); }, }), u(Gu, Ud); var bw = { mousedown: function (t) { if (this._dragging) xc.call(this, t); else if (!t.target || !t.target.draggable) { gc(t); var e = this.group.transformCoordToLocal(t.offsetX, t.offsetY); (this._creatingCover = null), (this._creatingPanel = Yu(this, t, e)) && ((this._dragging = !0), (this._track = [e.slice()])); } }, mousemove: function (t) { var e = this.group.transformCoordToLocal(t.offsetX, t.offsetY); if ((pc(this, t, e), this._dragging)) { gc(t); var n = mc(this, t, e, !1); n && Qu(this, n); } }, mouseup: xc, }, Mw = { lineX: _c(0), lineY: _c(1), rect: { createCover: function (t, e) { return ec( lw( hc, function (t) { return t; }, function (t) { return t; } ), t, e, ['w', 'e', 'n', 's', 'se', 'sw', 'ne', 'nw'] ); }, getCreatingRange: function (t) { var e = tc(t); return ac(e[1][0], e[1][1], e[0][0], e[0][1]); }, updateCoverShape: function (t, e, n, i) { nc(t, e, n, i); }, updateCommon: ic, contain: vc, }, polygon: { createCover: function (t, e) { var n = new Tf(); return n.add(new Fg({ name: 'main', style: oc(e), silent: !0 })), n; }, getCreatingRange: function (t) { return t; }, endCreating: function (t, e) { e.remove(e.childAt(0)), e.add( new Hg({ name: 'main', draggable: !0, drift: lw(uc, t, e), ondragend: lw(Qu, t, { isEnd: !0 }), }) ); }, updateCoverShape: function (t, e, n, i) { e.childAt(0).setShape({ points: dc(t, e, n) }); }, updateCommon: ic, contain: vc, }, }, Sw = { axisPointer: 1, tooltip: 1, brush: 1 }, Iw = d, Tw = l, Aw = m, Cw = ['dataToPoint', 'pointToData'], kw = [ 'grid', 'xAxis', 'yAxis', 'geo', 'graph', 'polar', 'radiusAxis', 'angleAxis', 'bmap', ], Dw = Tc.prototype; (Dw.setOutputRanges = function (t, e) { this.matchOutputRanges(t, e, function (t, e, n) { if (((t.coordRanges || (t.coordRanges = [])).push(e), !t.coordRange)) { t.coordRange = e; var i = zw[t.brushType](0, n, e); t.__rangeOffset = { offset: Ew[t.brushType](i.values, t.range, [1, 1]), xyMinMax: i.xyMinMax, }; } }); }), (Dw.matchOutputRanges = function (t, e, n) { Iw( t, function (t) { var i = this.findTargetInfo(t, e); i && !0 !== i && d(i.coordSyses, function (i) { var r = zw[t.brushType](1, i, t.range); n(t, r.values, i, e); }); }, this ); }), (Dw.setInputRanges = function (t, e) { Iw( t, function (t) { var n = this.findTargetInfo(t, e); if (((t.range = t.range || []), n && !0 !== n)) { t.panelId = n.panelId; var i = zw[t.brushType](0, n.coordSys, t.coordRange), r = t.__rangeOffset; t.range = r ? Ew[t.brushType](i.values, r.offset, Pc(i.xyMinMax, r.xyMinMax)) : i.values; } }, this ); }), (Dw.makePanelOpts = function (t, e) { return f(this._targetInfoList, function (n) { var i = n.getPanelRect(); return { panelId: n.panelId, defaultBrushType: e && e(n), clipPath: bc(i), isTargetByCursor: Sc(i, t, n.coordSysModel), getLinearBrushOtherExtent: Mc(i), }; }); }), (Dw.controlSeries = function (t, e, n) { var i = this.findTargetInfo(t, n); return !0 === i || (i && Tw(i.coordSyses, e.coordinateSystem) >= 0); }), (Dw.findTargetInfo = function (t, e) { for ( var n = this._targetInfoList, i = Cc(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 (r = 0; r < Lw.length; r++) if (Lw[r](i, o)) return o; } return !0; }); var Pw = { grid: function (t, e) { var n = t.xAxisModels, i = t.yAxisModels, r = t.gridModels, o = z(), a = {}, s = {}; (n || i || r) && (Iw(n, function (t) { var e = t.axis.grid.model; o.set(e.id, e), (a[e.id] = !0); }), Iw(i, function (t) { var e = t.axis.grid.model; o.set(e.id, e), (s[e.id] = !0); }), Iw(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 = []; Iw(r.getCartesians(), function (t, e) { (Tw(n, t.getAxis('x').model) >= 0 || Tw(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: Ow.grid, xAxisDeclared: a[t.id], yAxisDeclared: s[t.id], }); })); }, geo: function (t, e) { Iw(t.geoModels, function (t) { var n = t.coordinateSystem; e.push({ panelId: 'geo--' + t.id, geoModel: t, coordSysModel: t, coordSys: n, coordSyses: [n], getPanelRect: Ow.geo, }); }); }, }, Lw = [ 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; }, ], Ow = { grid: function () { return this.coordSys.grid.getRect().clone(); }, geo: function () { var t = this.coordSys, e = t.getBoundingRect().clone(); return e.applyTransform(mr(t)), e; }, }, zw = { lineX: Aw(kc, 0), lineY: Aw(kc, 1), rect: function (t, e, n) { var i = e[Cw[t]]([n[0][0], n[1][0]]), r = e[Cw[t]]([n[0][1], n[1][1]]), o = [Ac([i[0], r[0]]), Ac([i[1], r[1]])]; return { values: o, xyMinMax: o }; }, polygon: function (t, e, n) { var i = [ [1 / 0, -1 / 0], [1 / 0, -1 / 0], ]; return { values: f(n, function (n) { var r = e[Cw[t]](n); return ( (i[0][0] = Math.min(i[0][0], r[0])), (i[1][0] = Math.min(i[1][0], r[1])), (i[0][1] = Math.max(i[0][1], r[0])), (i[1][1] = Math.max(i[1][1], r[1])), r ); }), xyMinMax: i, }; }, }, Ew = { lineX: Aw(Dc, 0), lineY: Aw(Dc, 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 f(t, function (t, i) { return [t[0] - n[0] * e[i][0], t[1] - n[1] * e[i][1]]; }); }, }, Nw = d, Bw = '\0_ec_hist_store'; L_.extend({ type: 'dataZoom.select' }), O_.extend({ type: 'dataZoom.select' }); var Rw = Q_.toolbox.dataZoom, Vw = d, Gw = '\0_ec_\0toolbox-dataZoom_'; Rc.defaultOption = { show: !0, 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: n(Rw.title), }; var Ww = Rc.prototype; (Ww.render = function (t, e, n, i) { (this.model = t), (this.ecModel = e), (this.api = n), Wc(t, e, this, i, n), Gc(t, e); }), (Ww.onclick = function (t, e, n) { Hw[n].call(this); }), (Ww.remove = function (t, e) { this._brushController.unmount(); }), (Ww.dispose = function (t, e) { this._brushController.dispose(); }); var Hw = { zoom: function () { var t = !this._isZoomActive; this.api.dispatchAction({ type: 'takeGlobalCursor', key: 'dataZoomSelect', dataZoomSelectActive: t, }); }, back: function () { this._dispatchZoomAction(zc(this.ecModel)); }, }; (Ww._onBrush = function (t, e) { function n(t, e, n) { var a = e.getAxis(t), s = a.model, l = i(t, s, o), h = l.findRepresentativeAxisProxy(s).getMinMaxSpan(); (null == h.minValueSpan && null == h.maxValueSpan) || (n = z_( 0, n.slice(), a.scale.getExtent(), 0, h.minValueSpan, h.maxValueSpan )), l && (r[l.id] = { dataZoomId: l.id, startValue: n[0], endValue: n[1] }); } function i(t, e, n) { var i; return ( n.eachComponent( { mainType: 'dataZoom', subType: 'select' }, function (n) { n.getAxisModel(t, e.componentIndex) && (i = n); } ), i ); } if (e.isEnd && t.length) { var r = {}, o = this.ecModel; this._brushController.updateCovers([]), new Tc(Vc(this.model.option), o, { include: ['grid'], }).matchOutputRanges(t, o, function (t, e, i) { if ('cartesian2d' === i.type) { var r = t.brushType; 'rect' === r ? (n('x', i, e[0]), n('y', i, e[1])) : n({ lineX: 'x', lineY: 'y' }[r], i, e); } }), Oc(o, r), this._dispatchZoomAction(r); } }), (Ww._dispatchZoomAction = function (t) { var e = []; Vw(t, function (t, i) { e.push(n(t)); }), e.length && this.api.dispatchAction({ type: 'dataZoom', from: this.uid, batch: e, }); }), Su('dataZoom', Rc), Uo(function (t) { function e(t, e) { if (e) { var r = t + 'Index', o = e[r]; null == o || 'all' == o || y(o) || (o = !1 === o || 'none' === o ? [] : [o]), n(t, function (e, n) { if (null == o || 'all' == o || -1 !== l(o, n)) { var a = { type: 'select', $fromToolbox: !0, id: Gw + t + n }; (a[r] = n), i.push(a); } }); } } function n(e, n) { var i = t[e]; y(i) || (i = i ? [i] : []), Vw(i, n); } if (t) { var i = t.dataZoom || (t.dataZoom = []); y(i) || (t.dataZoom = i = [i]); var r = t.toolbox; if (r && (y(r) && (r = r[0]), r && r.feature)) { var o = r.feature.dataZoom; e('xAxis', o), e('yAxis', o); } } }); var Fw = Q_.toolbox.restore; (Hc.defaultOption = { 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: Fw.title, }), (Hc.prototype.onclick = function (t, e, n) { Ec(t), e.dispatchAction({ type: 'restore', from: this.uid }); }), Su('restore', Hc), jo( { type: 'restore', event: 'restore', update: 'prepareAndUpdate' }, function (t, e) { e.resetOption('recreate'); } ); var Zw, Uw = 'urn:schemas-microsoft-com:vml', Xw = 'undefined' == typeof window ? null : window, jw = !1, qw = Xw && Xw.document; if (qw && !Md.canvasSupported) try { !qw.namespaces.zrvml && qw.namespaces.add('zrvml', Uw), (Zw = function (t) { return qw.createElement(''); }); } catch (t) { Zw = function (t) { return qw.createElement('<' + t + ' xmlns="' + Uw + '" class="zrvml">'); }; } var Yw = ug.CMD, $w = Math.round, Kw = Math.sqrt, Qw = Math.abs, Jw = Math.cos, tb = Math.sin, eb = Math.max; if (!Md.canvasSupported) { var nb = 21600, ib = nb / 2, rb = function (t) { (t.style.cssText = 'position:absolute;left:0;top:0;width:1px;height:1px;'), (t.coordsize = nb + ',' + nb), (t.coordorigin = '0,0'); }, ob = function (t) { return String(t).replace(/&/g, '&').replace(/"/g, '"'); }, ab = function (t, e, n) { return 'rgb(' + [t, e, n].join(',') + ')'; }, sb = function (t, e) { e && t && e.parentNode !== t && t.appendChild(e); }, lb = function (t, e) { e && t && e.parentNode === t && t.removeChild(e); }, hb = function (t, e, n) { return 1e5 * (parseFloat(t) || 0) + 1e3 * (parseFloat(e) || 0) + n; }, ub = function (t, e) { return 'string' == typeof t ? t.lastIndexOf('%') >= 0 ? (parseFloat(t) / 100) * e : parseFloat(t) : t; }, cb = function (t, e, n) { var i = bt(e); (n = +n), isNaN(n) && (n = 1), i && ((t.color = ab(i[0], i[1], i[2])), (t.opacity = n * i[3])); }, db = function (t) { var e = bt(t); return [ab(e[0], e[1], e[2]), e[3]]; }, fb = function (t, e, n) { var i = e.fill; if (null != i) if (i instanceof $g) { var r, o = 0, a = [0, 0], s = 0, l = 1, h = n.getBoundingRect(), u = h.width, c = h.height; if ('linear' === i.type) { r = 'gradient'; var d = n.transform, f = [i.x * u, i.y * c], p = [i.x2 * u, i.y2 * c]; d && (q(f, f, d), q(p, p, d)); var g = p[0] - f[0], v = p[1] - f[1]; (o = (180 * Math.atan2(g, v)) / Math.PI) < 0 && (o += 360), o < 1e-6 && (o = 0); } else { r = 'gradientradial'; var f = [i.x * u, i.y * c], d = n.transform, m = n.scale, y = u, x = c; (a = [(f[0] - h.x) / y, (f[1] - h.y) / x]), d && q(f, f, d), (y /= m[0] * nb), (x /= m[1] * nb); var _ = eb(y, x); (s = 0 / _), (l = (2 * i.r) / _ - s); } var w = i.colorStops.slice(); w.sort(function (t, e) { return t.offset - e.offset; }); for (var b = w.length, M = [], S = [], I = 0; I < b; I++) { var T = w[I], A = db(T.color); S.push(T.offset * l + s + ' ' + A[0]), (0 !== I && I !== b - 1) || M.push(A); } if (b >= 2) { var C = M[0][0], k = M[1][0], D = M[0][1] * e.opacity, P = M[1][1] * e.opacity; (t.type = r), (t.method = 'none'), (t.focus = '100%'), (t.angle = o), (t.color = C), (t.color2 = k), (t.colors = S.join(',')), (t.opacity = P), (t.opacity2 = D); } 'radial' === r && (t.focusposition = a.join(',')); } else cb(t, i, e.opacity); }, pb = function (t, e) { null != e.lineDash && (t.dashstyle = e.lineDash.join(' ')), null == e.stroke || e.stroke instanceof $g || cb(t, e.stroke, e.opacity); }, gb = function (t, e, n, i) { var r = 'fill' == e, o = t.getElementsByTagName(e)[0]; null != n[e] && 'none' !== n[e] && (r || (!r && n.lineWidth)) ? ((t[r ? 'filled' : 'stroked'] = 'true'), n[e] instanceof $g && lb(t, o), o || (o = Fc(e)), r ? fb(o, n, i) : pb(o, n), sb(t, o)) : ((t[r ? 'filled' : 'stroked'] = 'false'), lb(t, o)); }, vb = [[], [], []], mb = function (t, e) { var n, i, r, o, a, s, l = Yw.M, h = Yw.C, u = Yw.L, c = Yw.A, d = Yw.Q, f = [], p = t.data, g = t.len(); for (o = 0; o < g; ) { switch (((r = p[o++]), (i = ''), (n = 0), r)) { case l: (i = ' m '), (n = 1), (a = p[o++]), (s = p[o++]), (vb[0][0] = a), (vb[0][1] = s); break; case u: (i = ' l '), (n = 1), (a = p[o++]), (s = p[o++]), (vb[0][0] = a), (vb[0][1] = s); break; case d: case h: (i = ' c '), (n = 3); var v, m, y = p[o++], x = p[o++], _ = p[o++], w = p[o++]; r === d ? ((v = _), (m = w), (_ = (_ + 2 * y) / 3), (w = (w + 2 * x) / 3), (y = (a + 2 * y) / 3), (x = (s + 2 * x) / 3)) : ((v = p[o++]), (m = p[o++])), (vb[0][0] = y), (vb[0][1] = x), (vb[1][0] = _), (vb[1][1] = w), (vb[2][0] = v), (vb[2][1] = m), (a = v), (s = m); break; case c: var b = 0, M = 0, S = 1, I = 1, T = 0; e && ((b = e[4]), (M = e[5]), (S = Kw(e[0] * e[0] + e[1] * e[1])), (I = Kw(e[2] * e[2] + e[3] * e[3])), (T = Math.atan2(-e[1] / I, e[0] / S))); var A = p[o++], C = p[o++], k = p[o++], D = p[o++], P = p[o++] + T, L = p[o++] + P + T; o++; var O = p[o++], z = A + Jw(P) * k, E = C + tb(P) * D, y = A + Jw(L) * k, x = C + tb(L) * D, N = O ? ' wa ' : ' at '; Math.abs(z - y) < 1e-4 && (Math.abs(L - P) > 0.01 ? O && (z += 0.0125) : Math.abs(E - C) < 1e-4 ? (O && z < A) || (!O && z > A) ? (x -= 0.0125) : (x += 0.0125) : (O && E < C) || (!O && E > C) ? (y += 0.0125) : (y -= 0.0125)), f.push( N, $w(((A - k) * S + b) * nb - ib), ',', $w(((C - D) * I + M) * nb - ib), ',', $w(((A + k) * S + b) * nb - ib), ',', $w(((C + D) * I + M) * nb - ib), ',', $w((z * S + b) * nb - ib), ',', $w((E * I + M) * nb - ib), ',', $w((y * S + b) * nb - ib), ',', $w((x * I + M) * nb - ib) ), (a = y), (s = x); break; case Yw.R: var B = vb[0], R = vb[1]; (B[0] = p[o++]), (B[1] = p[o++]), (R[0] = B[0] + p[o++]), (R[1] = B[1] + p[o++]), e && (q(B, B, e), q(R, R, e)), (B[0] = $w(B[0] * nb - ib)), (R[0] = $w(R[0] * nb - ib)), (B[1] = $w(B[1] * nb - ib)), (R[1] = $w(R[1] * nb - ib)), f.push( ' m ', B[0], ',', B[1], ' l ', R[0], ',', B[1], ' l ', R[0], ',', R[1], ' l ', B[0], ',', R[1] ); break; case Yw.Z: f.push(' x '); } if (n > 0) { f.push(i); for (var V = 0; V < n; V++) { var G = vb[V]; e && q(G, G, e), f.push( $w(G[0] * nb - ib), ',', $w(G[1] * nb - ib), V < n - 1 ? ',' : '' ); } } } return f.join(''); }; (ki.prototype.brushVML = function (t) { var e = this.style, n = this._vmlEl; n || ((n = Fc('shape')), rb(n), (this._vmlEl = n)), gb(n, 'fill', e, this), gb(n, 'stroke', e, this); var i = this.transform, r = null != i, o = n.getElementsByTagName('stroke')[0]; if (o) { var a = e.lineWidth; if (r && !e.strokeNoScale) { var s = i[0] * i[3] - i[1] * i[2]; a *= Kw(Qw(s)); } o.weight = a + 'px'; } var l = this.path || (this.path = new ug()); this.__dirtyPath && (l.beginPath(), this.buildPath(l, this.shape), l.toStatic(), (this.__dirtyPath = !1)), (n.path = mb(l, this.transform)), (n.style.zIndex = hb(this.zlevel, this.z, this.z2)), sb(t, n), null != e.text ? this.drawRectText(t, this.getBoundingRect()) : this.removeRectText(t); }), (ki.prototype.onRemove = function (t) { lb(t, this._vmlEl), this.removeRectText(t); }), (ki.prototype.onAdd = function (t) { sb(t, this._vmlEl), this.appendRectText(t); }); var yb = function (t) { return ( 'object' == typeof t && t.tagName && 'IMG' === t.tagName.toUpperCase() ); }; (Ue.prototype.brushVML = function (t) { var e, n, i = this.style, r = i.image; if (yb(r)) { var o = r.src; if (o === this._imageSrc) (e = this._imageWidth), (n = this._imageHeight); else { var a = r.runtimeStyle, s = a.width, l = a.height; (a.width = 'auto'), (a.height = 'auto'), (e = r.width), (n = r.height), (a.width = s), (a.height = l), (this._imageSrc = o), (this._imageWidth = e), (this._imageHeight = n); } r = o; } else r === this._imageSrc && ((e = this._imageWidth), (n = this._imageHeight)); if (r) { var h = i.x || 0, u = i.y || 0, c = i.width, d = i.height, f = i.sWidth, p = i.sHeight, g = i.sx || 0, v = i.sy || 0, m = f && p, y = this._vmlEl; y || ((y = qw.createElement('div')), rb(y), (this._vmlEl = y)); var x, _ = y.style, w = !1, b = 1, M = 1; if ( (this.transform && ((x = this.transform), (b = Kw(x[0] * x[0] + x[1] * x[1])), (M = Kw(x[2] * x[2] + x[3] * x[3])), (w = x[1] || x[2])), w) ) { var S = [h, u], I = [h + c, u], T = [h, u + d], A = [h + c, u + d]; q(S, S, x), q(I, I, x), q(T, T, x), q(A, A, x); var C = eb(S[0], I[0], T[0], A[0]), k = eb(S[1], I[1], T[1], A[1]), D = []; D.push( 'M11=', x[0] / b, ',', 'M12=', x[2] / M, ',', 'M21=', x[1] / b, ',', 'M22=', x[3] / M, ',', 'Dx=', $w(h * b + x[4]), ',', 'Dy=', $w(u * M + x[5]) ), (_.padding = '0 ' + $w(C) + 'px ' + $w(k) + 'px 0'), (_.filter = 'progid:DXImageTransform.Microsoft.Matrix(' + D.join('') + ', SizingMethod=clip)'); } else x && ((h = h * b + x[4]), (u = u * M + x[5])), (_.filter = ''), (_.left = $w(h) + 'px'), (_.top = $w(u) + 'px'); var P = this._imageEl, L = this._cropEl; P || ((P = qw.createElement('div')), (this._imageEl = P)); var O = P.style; if (m) { if (e && n) (O.width = $w((b * e * c) / f) + 'px'), (O.height = $w((M * n * d) / p) + 'px'); else { var z = new Image(), E = this; (z.onload = function () { (z.onload = null), (e = z.width), (n = z.height), (O.width = $w((b * e * c) / f) + 'px'), (O.height = $w((M * n * d) / p) + 'px'), (E._imageWidth = e), (E._imageHeight = n), (E._imageSrc = r); }), (z.src = r); } L || (((L = qw.createElement('div')).style.overflow = 'hidden'), (this._cropEl = L)); var N = L.style; (N.width = $w((c + (g * c) / f) * b)), (N.height = $w((d + (v * d) / p) * M)), (N.filter = 'progid:DXImageTransform.Microsoft.Matrix(Dx=' + ((-g * c) / f) * b + ',Dy=' + ((-v * d) / p) * M + ')'), L.parentNode || y.appendChild(L), P.parentNode != L && L.appendChild(P); } else (O.width = $w(b * c) + 'px'), (O.height = $w(M * d) + 'px'), y.appendChild(P), L && L.parentNode && (y.removeChild(L), (this._cropEl = null)); var B = '', R = i.opacity; R < 1 && (B += '.Alpha(opacity=' + $w(100 * R) + ') '), (B += 'progid:DXImageTransform.Microsoft.AlphaImageLoader(src=' + r + ', SizingMethod=scale)'), (O.filter = B), (y.style.zIndex = hb(this.zlevel, this.z, this.z2)), sb(t, y), null != i.text && this.drawRectText(t, this.getBoundingRect()); } }), (Ue.prototype.onRemove = function (t) { lb(t, this._vmlEl), (this._vmlEl = null), (this._cropEl = null), (this._imageEl = null), this.removeRectText(t); }), (Ue.prototype.onAdd = function (t) { sb(t, this._vmlEl), this.appendRectText(t); }); var xb, _b = {}, wb = 0, bb = document.createElement('div'), Mb = function (t) { var e = _b[t]; if (!e) { wb > 100 && ((wb = 0), (_b = {})); var n, i = bb.style; try { (i.font = t), (n = i.fontFamily.split(',')[0]); } catch (t) {} (e = { style: i.fontStyle || 'normal', variant: i.fontVariant || 'normal', weight: i.fontWeight || 'normal', size: 0 | parseFloat(i.fontSize || 12), family: n || 'Microsoft YaHei', }), (_b[t] = e), wb++; } return e; }; !(function (t, e) { Zf[t] = e; })('measureText', function (t, e) { var n = qw; xb || (((xb = n.createElement('div')).style.cssText = 'position:absolute;top:-20000px;left:0;padding:0;margin:0;border:none;white-space:pre;'), qw.body.appendChild(xb)); try { xb.style.font = e; } catch (t) {} return ( (xb.innerHTML = ''), xb.appendChild(n.createTextNode(t)), { width: xb.offsetWidth } ); }); for ( var Sb = new Zt(), Ib = [qf, Ze, Ue, ki, zg], Tb = 0; Tb < Ib.length; Tb++ ) { var Ab = Ib[Tb].prototype; (Ab.drawRectText = function (t, e, n, i) { var r = this.style; this.__dirty && Te(r); var o = r.text; if ((null != o && (o += ''), o)) { if (r.rich) { var a = be(o, r); o = []; for (var s = 0; s < a.lines.length; s++) { for (var l = a.lines[s].tokens, h = [], u = 0; u < l.length; u++) h.push(l[u].text); o.push(h.join('')); } o = o.join('\n'); } var c, d, f = r.textAlign, p = r.textVerticalAlign, g = Mb(r.font), v = g.style + ' ' + g.variant + ' ' + g.weight + ' ' + g.size + 'px "' + g.family + '"'; n = n || he(o, v, f, p); var m = this.transform; if ((m && !i && (Sb.copy(e), Sb.applyTransform(m), (e = Sb)), i)) (c = e.x), (d = e.y); else { var y = r.textPosition, x = r.textDistance; if (y instanceof Array) (c = e.x + ub(y[0], e.width)), (d = e.y + ub(y[1], e.height)), (f = f || 'left'); else { var _ = pe(y, e, x); (c = _.x), (d = _.y), (f = f || _.textAlign), (p = p || _.textVerticalAlign); } } (c = de(c, n.width, f)), (d = fe(d, n.height, p)), (d += n.height / 2); var w, b, M, S = Fc, I = this._textVmlEl; I ? (b = (w = (M = I.firstChild).nextSibling).nextSibling) : ((I = S('line')), (w = S('path')), (b = S('textpath')), (M = S('skew')), (b.style['v-text-align'] = 'left'), rb(I), (w.textpathok = !0), (b.on = !0), (I.from = '0 0'), (I.to = '1000 0.05'), sb(I, M), sb(I, w), sb(I, b), (this._textVmlEl = I)); var T = [c, d], A = I.style; m && i ? (q(T, T, m), (M.on = !0), (M.matrix = m[0].toFixed(3) + ',' + m[2].toFixed(3) + ',' + m[1].toFixed(3) + ',' + m[3].toFixed(3) + ',0,0'), (M.offset = ($w(T[0]) || 0) + ',' + ($w(T[1]) || 0)), (M.origin = '0 0'), (A.left = '0px'), (A.top = '0px')) : ((M.on = !1), (A.left = $w(c) + 'px'), (A.top = $w(d) + 'px')), (b.string = ob(o)); try { b.style.font = v; } catch (t) {} gb(I, 'fill', { fill: r.textFill, opacity: r.opacity }, this), gb( I, 'stroke', { stroke: r.textStroke, opacity: r.opacity, lineDash: r.lineDash, }, this ), (I.style.zIndex = hb(this.zlevel, this.z, this.z2)), sb(t, I); } }), (Ab.removeRectText = function (t) { lb(t, this._textVmlEl), (this._textVmlEl = null); }), (Ab.appendRectText = function (t) { sb(t, this._textVmlEl); }); } (zg.prototype.brushVML = function (t) { var e = this.style; null != e.text ? this.drawRectText( t, { x: e.x || 0, y: e.y || 0, width: 0, height: 0 }, this.getBoundingRect(), !0 ) : this.removeRectText(t); }), (zg.prototype.onRemove = function (t) { this.removeRectText(t); }), (zg.prototype.onAdd = function (t) { this.appendRectText(t); }); } (Xc.prototype = { constructor: Xc, getType: function () { return 'vml'; }, getViewportRoot: function () { return this._vmlViewport; }, getViewportRootOffset: function () { var t = this.getViewportRoot(); if (t) return { offsetLeft: t.offsetLeft || 0, offsetTop: t.offsetTop || 0 }; }, refresh: function () { var t = this.storage.getDisplayList(!0, !0); this._paintList(t); }, _paintList: function (t) { for (var e = this._vmlRoot, n = 0; n < t.length; n++) { var i = t[n]; i.invisible || i.ignore ? (i.__alreadyNotVisible || i.onRemove(e), (i.__alreadyNotVisible = !0)) : (i.__alreadyNotVisible && i.onAdd(e), (i.__alreadyNotVisible = !1), i.__dirty && (i.beforeBrush && i.beforeBrush(), (i.brushVML || i.brush).call(i, e), i.afterBrush && i.afterBrush())), (i.__dirty = !1); } this._firstPaint && (this._vmlViewport.appendChild(e), (this._firstPaint = !1)); }, resize: function (t, e) { var t = null == t ? this._getWidth() : t, e = null == e ? this._getHeight() : e; if (this._width != t || this._height != e) { (this._width = t), (this._height = e); var n = this._vmlViewport.style; (n.width = t + 'px'), (n.height = e + 'px'); } }, dispose: function () { (this.root.innerHTML = ''), (this._vmlRoot = this._vmlViewport = this.storage = null); }, getWidth: function () { return this._width; }, getHeight: function () { return this._height; }, clear: function () { this._vmlViewport && this.root.removeChild(this._vmlViewport); }, _getWidth: function () { var t = this.root, e = t.currentStyle; return ( ((t.clientWidth || Uc(e.width)) - Uc(e.paddingLeft) - Uc(e.paddingRight)) | 0 ); }, _getHeight: function () { var t = this.root, e = t.currentStyle; return ( ((t.clientHeight || Uc(e.height)) - Uc(e.paddingTop) - Uc(e.paddingBottom)) | 0 ); }, }), d( [ 'getLayer', 'insertLayer', 'eachLayer', 'eachBuiltinLayer', 'eachOtherLayer', 'getLayers', 'modLayer', 'delLayer', 'clearLayer', 'toDataURL', 'pathToImage', ], function (t) { Xc.prototype[t] = jc(t); } ), mn('vml', Xc); var Cb = 'http://www.w3.org/2000/svg', kb = ug.CMD, Db = Array.prototype.join, Pb = 'none', Lb = Math.round, Ob = Math.sin, zb = Math.cos, Eb = Math.PI, Nb = 2 * Math.PI, Bb = 180 / Eb, Rb = 1e-4, Vb = {}; Vb.brush = function (t) { var e = t.style, n = t.__svgEl; n || ((n = qc('path')), (t.__svgEl = n)), t.path || t.createPathProxy(); var i = t.path; if (t.__dirtyPath) { i.beginPath(), t.buildPath(i, t.shape), (t.__dirtyPath = !1); var r = id(i); r.indexOf('NaN') < 0 && td(n, 'd', r); } nd(n, e), Jc(n, t.transform), null != e.text && Fb(t, t.getBoundingRect()); }; var Gb = {}; Gb.brush = function (t) { var e = t.style, n = e.image; if ((n instanceof HTMLImageElement && (n = n.src), n)) { var i = e.x || 0, r = e.y || 0, o = e.width, a = e.height, s = t.__svgEl; s || ((s = qc('image')), (t.__svgEl = s)), n !== t.__imageSrc && (ed(s, 'href', n), (t.__imageSrc = n)), td(s, 'width', o), td(s, 'height', a), td(s, 'x', i), td(s, 'y', r), Jc(s, t.transform), null != e.text && Fb(t, t.getBoundingRect()); } }; var Wb = {}, Hb = new Zt(), Fb = function (t, e, n) { var i = t.style; t.__dirty && Te(i); var r = i.text; if (null != r) { r += ''; var o = t.__textSvgEl; if ( (o || ((o = qc('text')), (t.__textSvgEl = o)), nd(o, i, !0), t instanceof zg || t.style.transformText) ) Jc(o, t.transform); else if (t.transform) Hb.copy(e), Hb.applyTransform(t.transform), (e = Hb); else { var a = t.transformCoordToGlobal(e.x, e.y); (e.x = a[0]), (e.y = a[1]); } var s, l, h = i.textPosition, u = i.textDistance, c = i.textAlign || 'left'; 'number' == typeof i.fontSize && (i.fontSize += 'px'); var d = i.font || [ i.fontStyle || '', i.fontWeight || '', i.fontSize || '', i.fontFamily || '', ].join(' ') || Ff, f = rd(i.textVerticalAlign), p = (n = he(r, d, c, f)).lineHeight; if (h instanceof Array) (s = e.x + h[0]), (l = e.y + h[1]); else { var g = pe(h, e, u); (s = g.x), (l = g.y), (f = rd(g.textVerticalAlign)), (c = g.textAlign); } td(o, 'alignment-baseline', f), d && (o.style.font = d); var v = i.textPadding; td(o, 'x', s), td(o, 'y', l); var m = r.split('\n'), y = m.length, x = c; 'left' === x ? ((x = 'start'), v && (s += v[3])) : 'right' === x ? ((x = 'end'), v && (s -= v[1])) : 'center' === x && ((x = 'middle'), v && (s += (v[3] - v[1]) / 2)); var _ = 0; if ( ('baseline' === f ? ((_ = -n.height + p), v && (_ -= v[2])) : 'middle' === f ? ((_ = (-n.height + p) / 2), v && (l += (v[0] - v[2]) / 2)) : v && (_ += v[0]), t.__text !== r || t.__textFont !== d) ) { var w = t.__tspanList || []; t.__tspanList = w; for (M = 0; M < y; M++) (S = w[M]) ? (S.innerHTML = '') : ((S = w[M] = qc('tspan')), o.appendChild(S), td(S, 'alignment-baseline', f), td(S, 'text-anchor', x)), td(S, 'x', s), td(S, 'y', l + M * p + _), S.appendChild(document.createTextNode(m[M])); for (; M < w.length; M++) o.removeChild(w[M]); (w.length = y), (t.__text = r), (t.__textFont = d); } else if (t.__tspanList.length) for (var b = t.__tspanList.length, M = 0; M < b; ++M) { var S = t.__tspanList[M]; S && (td(S, 'x', s), td(S, 'y', l + M * p + _)); } } }; (Wb.drawRectText = Fb), (Wb.brush = function (t) { var e = t.style; null != e.text && ((e.textPosition = [0, 0]), Fb( t, { x: e.x || 0, y: e.y || 0, width: 0, height: 0 }, t.getBoundingRect() )); }), (od.prototype = { diff: function (t, e, n) { n || (n = function (t, e) { return t === e; }), (this.equals = n); var i = this; t = t.slice(); var r = (e = e.slice()).length, o = t.length, a = 1, s = r + o, l = [{ newPos: -1, components: [] }], h = this.extractCommon(l[0], e, t, 0); if (l[0].newPos + 1 >= r && h + 1 >= o) { for (var u = [], c = 0; c < e.length; c++) u.push(c); return [{ indices: u, count: e.length }]; } for (; a <= s; ) { var d = (function () { for (var n = -1 * a; n <= a; n += 2) { var s, h = l[n - 1], u = l[n + 1], c = (u ? u.newPos : 0) - n; h && (l[n - 1] = void 0); var d = h && h.newPos + 1 < r, f = u && 0 <= c && c < o; if (d || f) { if ( (!d || (f && h.newPos < u.newPos) ? ((s = sd(u)), i.pushComponent(s.components, void 0, !0)) : ((s = h).newPos++, i.pushComponent(s.components, !0, void 0)), (c = i.extractCommon(s, e, t, n)), s.newPos + 1 >= r && c + 1 >= o) ) return ad(0, s.components); l[n] = s; } else l[n] = void 0; } a++; })(); if (d) return d; } }, pushComponent: function (t, e, n) { var i = t[t.length - 1]; i && i.added === e && i.removed === n ? (t[t.length - 1] = { count: i.count + 1, added: e, removed: n }) : t.push({ count: 1, added: e, removed: n }); }, extractCommon: function (t, e, n, i) { for ( var r = e.length, o = n.length, a = t.newPos, s = a - i, l = 0; a + 1 < r && s + 1 < o && this.equals(e[a + 1], n[s + 1]); ) a++, s++, l++; return l && t.components.push({ count: l }), (t.newPos = a), s; }, tokenize: function (t) { return t.slice(); }, join: function (t) { return t.slice(); }, }); var Zb = new od(), Ub = function (t, e, n) { return Zb.diff(t, e, n); }; (ld.prototype.createElement = qc), (ld.prototype.getDefs = function (t) { var e = this._svgRoot, n = this._svgRoot.getElementsByTagName('defs'); return 0 === n.length ? t ? ((n = e.insertBefore(this.createElement('defs'), e.firstChild)) .contains || (n.contains = function (t) { var e = n.children; if (!e) return !1; for (var i = e.length - 1; i >= 0; --i) if (e[i] === t) return !0; return !1; }), n) : null : n[0]; }), (ld.prototype.update = function (t, e) { if (t) { var n = this.getDefs(!1); if (t._dom && n.contains(t._dom)) 'function' == typeof e && e(); else { var i = this.add(t); i && (t._dom = i); } } }), (ld.prototype.addDom = function (t) { this.getDefs(!0).appendChild(t); }), (ld.prototype.removeDom = function (t) { this.getDefs(!1).removeChild(t._dom); }), (ld.prototype.getDoms = function () { var t = this.getDefs(!1); if (!t) return []; var e = []; return ( d(this._tagNames, function (n) { var i = t.getElementsByTagName(n); e = e.concat([].slice.call(i)); }), e ); }), (ld.prototype.markAllUnused = function () { var t = this; d(this.getDoms(), function (e) { e[t._markLabel] = '0'; }); }), (ld.prototype.markUsed = function (t) { t && (t[this._markLabel] = '1'); }), (ld.prototype.removeUnused = function () { var t = this.getDefs(!1); if (t) { var e = this; d(this.getDoms(), function (n) { '1' !== n[e._markLabel] && t.removeChild(n); }); } }), (ld.prototype.getSvgProxy = function (t) { return t instanceof ki ? Vb : t instanceof Ue ? Gb : t instanceof zg ? Wb : Vb; }), (ld.prototype.getTextSvgElement = function (t) { return t.__textSvgEl; }), (ld.prototype.getSvgElement = function (t) { return t.__svgEl; }), h(hd, ld), (hd.prototype.addWithoutUpdate = function (t, e) { if (e && e.style) { var n = this; d(['fill', 'stroke'], function (i) { if ( e.style[i] && ('linear' === e.style[i].type || 'radial' === e.style[i].type) ) { var r, o = e.style[i], a = n.getDefs(!0); o._dom ? ((r = o._dom), a.contains(o._dom) || n.addDom(r)) : (r = n.add(o)), n.markUsed(e); var s = r.getAttribute('id'); t.setAttribute(i, 'url(#' + s + ')'); } }); } }), (hd.prototype.add = function (t) { var e; if ('linear' === t.type) e = this.createElement('linearGradient'); else { if ('radial' !== t.type) return _f('Illegal gradient type.'), null; e = this.createElement('radialGradient'); } return ( (t.id = t.id || this.nextId++), e.setAttribute('id', 'zr-gradient-' + t.id), this.updateDom(t, e), this.addDom(e), e ); }), (hd.prototype.update = function (t) { var e = this; ld.prototype.update.call(this, t, function () { var n = t.type, i = t._dom.tagName; ('linear' === n && 'linearGradient' === i) || ('radial' === n && 'radialGradient' === i) ? e.updateDom(t, t._dom) : (e.removeDom(t), e.add(t)); }); }), (hd.prototype.updateDom = function (t, e) { if ('linear' === t.type) e.setAttribute('x1', t.x), e.setAttribute('y1', t.y), e.setAttribute('x2', t.x2), e.setAttribute('y2', t.y2); else { if ('radial' !== t.type) return void _f('Illegal gradient type.'); e.setAttribute('cx', t.x), e.setAttribute('cy', t.y), e.setAttribute('r', t.r); } t.global ? e.setAttribute('gradientUnits', 'userSpaceOnUse') : e.setAttribute('gradientUnits', 'objectBoundingBox'), (e.innerHTML = ''); for (var n = t.colorStops, i = 0, r = n.length; i < r; ++i) { var o = this.createElement('stop'); o.setAttribute('offset', 100 * n[i].offset + '%'), o.setAttribute('stop-color', n[i].color), e.appendChild(o); } t._dom = e; }), (hd.prototype.markUsed = function (t) { if (t.style) { var e = t.style.fill; e && e._dom && ld.prototype.markUsed.call(this, e._dom), (e = t.style.stroke) && e._dom && ld.prototype.markUsed.call(this, e._dom); } }), h(ud, ld), (ud.prototype.update = function (t) { var e = this.getSvgElement(t); e && this.updateDom(e, t.__clipPaths, !1); var n = this.getTextSvgElement(t); n && this.updateDom(n, t.__clipPaths, !0), this.markUsed(t); }), (ud.prototype.updateDom = function (t, e, n) { if (e && e.length > 0) { var i, r, o = this.getDefs(!0), a = e[0], s = n ? '_textDom' : '_dom'; a[s] ? ((r = a[s].getAttribute('id')), (i = a[s]), o.contains(i) || o.appendChild(i)) : ((r = 'zr-clip-' + this.nextId), ++this.nextId, (i = this.createElement('clipPath')).setAttribute('id', r), o.appendChild(i), (a[s] = i)); var l = this.getSvgProxy(a); if (a.transform && a.parent.invTransform && !n) { var h = Array.prototype.slice.call(a.transform); ot(a.transform, a.parent.invTransform, a.transform), l.brush(a), (a.transform = h); } else l.brush(a); var u = this.getSvgElement(a); i.appendChild(u.cloneNode()), t.setAttribute('clip-path', 'url(#' + r + ')'), e.length > 1 && this.updateDom(i, e.slice(1), n); } else t && t.setAttribute('clip-path', 'none'); }), (ud.prototype.markUsed = function (t) { var e = this; t.__clipPaths && t.__clipPaths.length > 0 && d(t.__clipPaths, function (t) { t._dom && ld.prototype.markUsed.call(e, t._dom), t._textDom && ld.prototype.markUsed.call(e, t._textDom); }); }); var Xb = function (t, e, n) { (this.root = t), (this.storage = e), (this._opts = n = o({}, n || {})); var i = qc('svg'); i.setAttribute('xmlns', 'http://www.w3.org/2000/svg'), i.setAttribute('version', '1.1'), i.setAttribute('baseProfile', 'full'), (i.style['user-select'] = 'none'), (i.style.cssText = 'position:absolute;left:0;top:0;'), (this.gradientManager = new hd(i)), (this.clipPathManager = new ud(i)); var r = document.createElement('div'); (r.style.cssText = 'overflow:hidden;position:relative'), (this._svgRoot = i), (this._viewport = r), t.appendChild(r), r.appendChild(i), this.resize(n.width, n.height), (this._visibleList = []); }; (Xb.prototype = { constructor: Xb, getType: function () { return 'svg'; }, getViewportRoot: function () { return this._viewport; }, getViewportRootOffset: function () { var t = this.getViewportRoot(); if (t) return { offsetLeft: t.offsetLeft || 0, offsetTop: t.offsetTop || 0 }; }, refresh: function () { var t = this.storage.getDisplayList(!0); this._paintList(t); }, _paintList: function (t) { this.gradientManager.markAllUnused(), this.clipPathManager.markAllUnused(); var e, n = this._svgRoot, i = this._visibleList, r = t.length, o = []; for (e = 0; e < r; e++) { var a = dd((f = t[e])); f.invisible || (f.__dirty && (a && a.brush(f), this.clipPathManager.update(f), f.style && (this.gradientManager.update(f.style.fill), this.gradientManager.update(f.style.stroke)), (f.__dirty = !1)), o.push(f)); } var s, l = Ub(i, o); for (e = 0; e < l.length; e++) if ((c = l[e]).removed) for (d = 0; d < c.count; d++) { var h = yd((f = i[c.indices[d]])), u = md(f); vd(n, h), vd(n, u); } for (e = 0; e < l.length; e++) { var c = l[e]; if (c.added) for (d = 0; d < c.count; d++) { var h = yd((f = o[c.indices[d]])), u = md(f); s ? pd(n, h, s) : gd(n, h), h ? pd(n, u, h) : s ? pd(n, u, s) : gd(n, u), pd(n, u, h), (s = u || h || s), this.gradientManager.addWithoutUpdate(h, f), this.clipPathManager.markUsed(f); } else if (!c.removed) for (var d = 0; d < c.count; d++) { var f = o[c.indices[d]]; (s = h = md(f) || yd(f) || s), this.gradientManager.markUsed(f), this.gradientManager.addWithoutUpdate(h, f), this.clipPathManager.markUsed(f); } } this.gradientManager.removeUnused(), this.clipPathManager.removeUnused(), (this._visibleList = o); }, _getDefs: function (t) { var e = this._svgRoot, n = this._svgRoot.getElementsByTagName('defs'); return 0 === n.length ? t ? ((n = e.insertBefore(qc('defs'), e.firstChild)).contains || (n.contains = function (t) { var e = n.children; if (!e) return !1; for (var i = e.length - 1; i >= 0; --i) if (e[i] === t) return !0; return !1; }), n) : null : n[0]; }, resize: function (t, e) { var n = this._viewport; n.style.display = 'none'; var i = this._opts; if ( (null != t && (i.width = t), null != e && (i.height = e), (t = this._getSize(0)), (e = this._getSize(1)), (n.style.display = ''), this._width !== t && this._height !== e) ) { (this._width = t), (this._height = e); var r = n.style; (r.width = t + 'px'), (r.height = e + 'px'); var o = this._svgRoot; o.setAttribute('width', t), o.setAttribute('height', e); } }, getWidth: function () { return this._width; }, getHeight: function () { return this._height; }, _getSize: function (t) { var e = this._opts, n = ['width', 'height'][t], i = ['clientWidth', 'clientHeight'][t], r = ['paddingLeft', 'paddingTop'][t], o = ['paddingRight', 'paddingBottom'][t]; if (null != e[n] && 'auto' !== e[n]) return parseFloat(e[n]); var a = this.root, s = document.defaultView.getComputedStyle(a); return ( ((a[i] || cd(s[n]) || cd(a.style[n])) - (cd(s[r]) || 0) - (cd(s[o]) || 0)) | 0 ); }, dispose: function () { (this.root.innerHTML = ''), (this._svgRoot = this._viewport = this.storage = null); }, clear: function () { this._viewport && this.root.removeChild(this._viewport); }, pathToSvg: function () { this.refresh(); var t = this._svgRoot.outerHTML; return 'data:img/svg+xml;utf-8,' + unescape(t); }, }), d( [ 'getLayer', 'insertLayer', 'eachLayer', 'eachBuiltinLayer', 'eachOtherLayer', 'getLayers', 'modLayer', 'delLayer', 'clearLayer', 'toDataURL', 'pathToImage', ], function (t) { Xb.prototype[t] = xd(t); } ), mn('svg', Xb), (t.version = '3.8.5'), (t.dependencies = om), (t.PRIORITY = hm), (t.init = function (t, e, n) { var i = Zo(t); if (i) return i; var r = new Io(t, e, n); return ( (r.id = 'ec_' + Tm++), (Sm[r.id] = r), t.setAttribute ? t.setAttribute(Cm, r.id) : (t[Cm] = r.id), Ho(r), r ); }), (t.connect = function (t) { if (y(t)) { var e = t; (t = null), d(e, function (e) { null != e.group && (t = e.group); }), (t = t || 'g_' + Am++), d(e, function (e) { e.group = t; }); } return (Im[t] = !0), t; }), (t.disConnect = Fo), (t.disconnect = Dm), (t.dispose = function (t) { 'string' == typeof t ? (t = Sm[t]) : t instanceof Io || (t = Zo(t)), t instanceof Io && !t.isDisposed() && t.dispose(); }), (t.getInstanceByDom = Zo), (t.getInstanceById = function (t) { return Sm[t]; }), (t.registerTheme = function (t, e) { bm[t] = e; }), (t.registerPreprocessor = Uo), (t.registerProcessor = Xo), (t.registerPostUpdate = function (t) { _m.push(t); }), (t.registerAction = jo), (t.registerCoordinateSystem = function (t, e) { to.register(t, e); }), (t.getCoordinateSystemDimensions = function (t) { var e = to.get(t); if (e) return e.getDimensionsInfo ? e.getDimensionsInfo() : e.dimensions.slice(); }), (t.registerLayout = qo), (t.registerVisual = Yo), (t.registerLoading = $o), (t.extendComponentModel = Ko), (t.extendComponentView = Qo), (t.extendSeriesModel = Jo), (t.extendChartView = ta), (t.setCanvasCreator = function (t) { e('createCanvas', t); }), (t.registerMap = function (t, e, n) { e.geoJson && !e.features && ((n = e.specialAreas), (e = e.geoJson)), 'string' == typeof e && (e = 'undefined' != typeof JSON && JSON.parse ? JSON.parse(e) : new Function('return (' + e + ');')()), (km[t] = { geoJson: e, specialAreas: n }); }), (t.getMap = function (t) { return km[t]; }), (t.dataTool = Pm), (t.zrender = pp), (t.graphic = iv), (t.number = mp), (t.format = Sp), (t.throttle = _o), (t.helper = xy), (t.matrix = $d), (t.vector = Fd), (t.color = pf), (t.util = Sy), (t.List = Nm), (t.Model = Mr), (t.Axis = by), (t.env = Md), (t.parseGeoJson = function (t) { return ( Na(t), f( g(t.features, function (t) { return ( t.geometry && t.properties && t.geometry.coordinates.length > 0 ); }), function (t) { var e = t.properties, n = t.geometry, i = n.coordinates, r = []; 'Polygon' === n.type && r.push({ type: 'polygon', exterior: i[0], interiors: i.slice(1), }), 'MultiPolygon' === n.type && d(i, function (t) { t[0] && r.push({ type: 'polygon', exterior: t[0], interiors: t.slice(1), }); }); var o = new Ea(e.name, r, e.cp); return (o.properties = e), o; } ) ); }); });