86 lines
4.8 KiB
JavaScript
86 lines
4.8 KiB
JavaScript
import { w as ln, c as H } from "./path-428ebac9.js";
|
|
import { aw as an, ax as V, ay as D, az as rn, aA as y, V as on, aB as K, aC as _, aD as un, aE as t, aF as sn, aG as tn, aH as fn } from "./mermaid-00886c59.js";
|
|
function cn(l) {
|
|
return l.innerRadius;
|
|
}
|
|
function yn(l) {
|
|
return l.outerRadius;
|
|
}
|
|
function gn(l) {
|
|
return l.startAngle;
|
|
}
|
|
function mn(l) {
|
|
return l.endAngle;
|
|
}
|
|
function pn(l) {
|
|
return l && l.padAngle;
|
|
}
|
|
function dn(l, h, z, E, v, A, I, a) {
|
|
var B = z - l, i = E - h, n = I - v, m = a - A, r = m * B - n * i;
|
|
if (!(r * r < y))
|
|
return r = (n * (h - A) - m * (l - v)) / r, [l + r * B, h + r * i];
|
|
}
|
|
function W(l, h, z, E, v, A, I) {
|
|
var a = l - z, B = h - E, i = (I ? A : -A) / K(a * a + B * B), n = i * B, m = -i * a, r = l + n, s = h + m, f = z + n, c = E + m, O = (r + f) / 2, o = (s + c) / 2, p = f - r, g = c - s, R = p * p + g * g, T = v - A, w = r * c - f * s, C = (g < 0 ? -1 : 1) * K(fn(0, T * T * R - w * w)), F = (w * g - p * C) / R, G = (-w * p - g * C) / R, P = (w * g + p * C) / R, d = (-w * p + g * C) / R, x = F - O, e = G - o, u = P - O, S = d - o;
|
|
return x * x + e * e > u * u + S * S && (F = P, G = d), {
|
|
cx: F,
|
|
cy: G,
|
|
x01: -n,
|
|
y01: -m,
|
|
x11: F * (v / T - 1),
|
|
y11: G * (v / T - 1)
|
|
};
|
|
}
|
|
function vn() {
|
|
var l = cn, h = yn, z = H(0), E = null, v = gn, A = mn, I = pn, a = null, B = ln(i);
|
|
function i() {
|
|
var n, m, r = +l.apply(this, arguments), s = +h.apply(this, arguments), f = v.apply(this, arguments) - rn, c = A.apply(this, arguments) - rn, O = un(c - f), o = c > f;
|
|
if (a || (a = n = B()), s < r && (m = s, s = r, r = m), !(s > y))
|
|
a.moveTo(0, 0);
|
|
else if (O > on - y)
|
|
a.moveTo(s * V(f), s * D(f)), a.arc(0, 0, s, f, c, !o), r > y && (a.moveTo(r * V(c), r * D(c)), a.arc(0, 0, r, c, f, o));
|
|
else {
|
|
var p = f, g = c, R = f, T = c, w = O, C = O, F = I.apply(this, arguments) / 2, G = F > y && (E ? +E.apply(this, arguments) : K(r * r + s * s)), P = _(un(s - r) / 2, +z.apply(this, arguments)), d = P, x = P, e, u;
|
|
if (G > y) {
|
|
var S = sn(G / r * D(F)), L = sn(G / s * D(F));
|
|
(w -= S * 2) > y ? (S *= o ? 1 : -1, R += S, T -= S) : (w = 0, R = T = (f + c) / 2), (C -= L * 2) > y ? (L *= o ? 1 : -1, p += L, g -= L) : (C = 0, p = g = (f + c) / 2);
|
|
}
|
|
var j = s * V(p), J = s * D(p), M = r * V(T), N = r * D(T);
|
|
if (P > y) {
|
|
var Q = s * V(g), U = s * D(g), X = r * V(R), Y = r * D(R), q;
|
|
if (O < an)
|
|
if (q = dn(j, J, X, Y, Q, U, M, N)) {
|
|
var Z = j - q[0], $ = J - q[1], k = Q - q[0], b = U - q[1], nn = 1 / D(tn((Z * k + $ * b) / (K(Z * Z + $ * $) * K(k * k + b * b))) / 2), en = K(q[0] * q[0] + q[1] * q[1]);
|
|
d = _(P, (r - en) / (nn - 1)), x = _(P, (s - en) / (nn + 1));
|
|
} else
|
|
d = x = 0;
|
|
}
|
|
C > y ? x > y ? (e = W(X, Y, j, J, s, x, o), u = W(Q, U, M, N, s, x, o), a.moveTo(e.cx + e.x01, e.cy + e.y01), x < P ? a.arc(e.cx, e.cy, x, t(e.y01, e.x01), t(u.y01, u.x01), !o) : (a.arc(e.cx, e.cy, x, t(e.y01, e.x01), t(e.y11, e.x11), !o), a.arc(0, 0, s, t(e.cy + e.y11, e.cx + e.x11), t(u.cy + u.y11, u.cx + u.x11), !o), a.arc(u.cx, u.cy, x, t(u.y11, u.x11), t(u.y01, u.x01), !o))) : (a.moveTo(j, J), a.arc(0, 0, s, p, g, !o)) : a.moveTo(j, J), !(r > y) || !(w > y) ? a.lineTo(M, N) : d > y ? (e = W(M, N, Q, U, r, -d, o), u = W(j, J, X, Y, r, -d, o), a.lineTo(e.cx + e.x01, e.cy + e.y01), d < P ? a.arc(e.cx, e.cy, d, t(e.y01, e.x01), t(u.y01, u.x01), !o) : (a.arc(e.cx, e.cy, d, t(e.y01, e.x01), t(e.y11, e.x11), !o), a.arc(0, 0, r, t(e.cy + e.y11, e.cx + e.x11), t(u.cy + u.y11, u.cx + u.x11), o), a.arc(u.cx, u.cy, d, t(u.y11, u.x11), t(u.y01, u.x01), !o))) : a.arc(0, 0, r, T, R, o);
|
|
}
|
|
if (a.closePath(), n)
|
|
return a = null, n + "" || null;
|
|
}
|
|
return i.centroid = function() {
|
|
var n = (+l.apply(this, arguments) + +h.apply(this, arguments)) / 2, m = (+v.apply(this, arguments) + +A.apply(this, arguments)) / 2 - an / 2;
|
|
return [V(m) * n, D(m) * n];
|
|
}, i.innerRadius = function(n) {
|
|
return arguments.length ? (l = typeof n == "function" ? n : H(+n), i) : l;
|
|
}, i.outerRadius = function(n) {
|
|
return arguments.length ? (h = typeof n == "function" ? n : H(+n), i) : h;
|
|
}, i.cornerRadius = function(n) {
|
|
return arguments.length ? (z = typeof n == "function" ? n : H(+n), i) : z;
|
|
}, i.padRadius = function(n) {
|
|
return arguments.length ? (E = n == null ? null : typeof n == "function" ? n : H(+n), i) : E;
|
|
}, i.startAngle = function(n) {
|
|
return arguments.length ? (v = typeof n == "function" ? n : H(+n), i) : v;
|
|
}, i.endAngle = function(n) {
|
|
return arguments.length ? (A = typeof n == "function" ? n : H(+n), i) : A;
|
|
}, i.padAngle = function(n) {
|
|
return arguments.length ? (I = typeof n == "function" ? n : H(+n), i) : I;
|
|
}, i.context = function(n) {
|
|
return arguments.length ? (a = n ?? null, i) : a;
|
|
}, i;
|
|
}
|
|
export {
|
|
vn as d
|
|
};
|