!(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 =
'