markdown-flow-ui
Version:
A React UI library for rendering markdown with interactive flow components, typewriter effects, and plugin support
1,326 lines (1,325 loc) • 37.6 kB
JavaScript
import { G as g } from "./graph-CTpbA7wW.mjs";
import { b as Te, p as ce, q as le, g as z, e as ee, l as j, o as Ie, s as Me, c as Se, u as Fe, d as f, i as m, f as _, v as x, r as M } from "./_baseUniq-l1t_n-IG.mjs";
import { f as O, b as he, a as je, c as Ve, d as Ae, t as V, m as w, e as P, h as ve, g as X, l as T, i as Be } from "./_basePickBy-ChFwRGMQ.mjs";
import { b7 as Ge, b8 as Ye, b9 as De, aS as qe, ba as We, aW as pe, aV as we, bb as $e, aR as q, aA as ze, aY as Xe, aC as Ue, bc as W } from "./index-pooOtYuy.mjs";
function He(e) {
return Ge(Ye(e, void 0, O), e + "");
}
var Je = 1, Ze = 4;
function Ke(e) {
return Te(e, Je | Ze);
}
function Qe(e, n) {
return e == null ? e : De(e, ce(n), qe);
}
function en(e, n) {
return e && le(e, ce(n));
}
function nn(e, n) {
return e > n;
}
function S(e, n) {
var r = {};
return n = z(n), le(e, function(t, a, i) {
We(r, a, n(t, a, i));
}), r;
}
function y(e) {
return e && e.length ? he(e, pe, nn) : void 0;
}
function U(e, n) {
return e && e.length ? he(e, z(n), je) : void 0;
}
function rn(e, n) {
var r = e.length;
for (e.sort(n); r--; )
e[r] = e[r].value;
return e;
}
function tn(e, n) {
if (e !== n) {
var r = e !== void 0, t = e === null, a = e === e, i = ee(e), o = n !== void 0, u = n === null, d = n === n, s = ee(n);
if (!u && !s && !i && e > n || i && o && d && !u && !s || t && o && d || !r && d || !a)
return 1;
if (!t && !i && !s && e < n || s && r && a && !t && !i || u && r && a || !o && a || !d)
return -1;
}
return 0;
}
function an(e, n, r) {
for (var t = -1, a = e.criteria, i = n.criteria, o = a.length, u = r.length; ++t < o; ) {
var d = tn(a[t], i[t]);
if (d) {
if (t >= u)
return d;
var s = r[t];
return d * (s == "desc" ? -1 : 1);
}
}
return e.index - n.index;
}
function on(e, n, r) {
n.length ? n = j(n, function(i) {
return we(i) ? function(o) {
return Ie(o, i.length === 1 ? i[0] : i);
} : i;
}) : n = [pe];
var t = -1;
n = j(n, $e(z));
var a = Ve(e, function(i, o, u) {
var d = j(n, function(s) {
return s(i);
});
return { criteria: d, index: ++t, value: i };
});
return rn(a, function(i, o) {
return an(i, o, r);
});
}
function un(e, n) {
return Ae(e, n, function(r, t) {
return Me(e, t);
});
}
var I = He(function(e, n) {
return e == null ? {} : un(e, n);
}), dn = Math.ceil, sn = Math.max;
function fn(e, n, r, t) {
for (var a = -1, i = sn(dn((n - e) / (r || 1)), 0), o = Array(i); i--; )
o[++a] = e, e += r;
return o;
}
function cn(e) {
return function(n, r, t) {
return t && typeof t != "number" && q(n, r, t) && (r = t = void 0), n = V(n), r === void 0 ? (r = n, n = 0) : r = V(r), t = t === void 0 ? n < r ? 1 : -1 : V(t), fn(n, r, t);
};
}
var E = cn(), R = ze(function(e, n) {
if (e == null)
return [];
var r = n.length;
return r > 1 && q(e, n[0], n[1]) ? n = [] : r > 2 && q(n[0], n[1], n[2]) && (n = [n[0]]), on(e, Se(n), []);
}), ln = 0;
function H(e) {
var n = ++ln;
return Fe(e) + n;
}
function hn(e, n, r) {
for (var t = -1, a = e.length, i = n.length, o = {}; ++t < a; ) {
var u = t < i ? n[t] : void 0;
r(o, e[t], u);
}
return o;
}
function vn(e, n) {
return hn(e || [], n || [], Xe);
}
class pn {
constructor() {
var n = {};
n._next = n._prev = n, this._sentinel = n;
}
dequeue() {
var n = this._sentinel, r = n._prev;
if (r !== n)
return ne(r), r;
}
enqueue(n) {
var r = this._sentinel;
n._prev && n._next && ne(n), n._next = r._next, r._next._prev = n, r._next = n, n._prev = r;
}
toString() {
for (var n = [], r = this._sentinel, t = r._prev; t !== r; )
n.push(JSON.stringify(t, wn)), t = t._prev;
return "[" + n.join(", ") + "]";
}
}
function ne(e) {
e._prev._next = e._next, e._next._prev = e._prev, delete e._next, delete e._prev;
}
function wn(e, n) {
if (e !== "_next" && e !== "_prev")
return n;
}
var bn = Ue(1);
function mn(e, n) {
if (e.nodeCount() <= 1)
return [];
var r = yn(e, n || bn), t = gn(r.graph, r.buckets, r.zeroIdx);
return O(
w(t, function(a) {
return e.outEdges(a.v, a.w);
})
);
}
function gn(e, n, r) {
for (var t = [], a = n[n.length - 1], i = n[0], o; e.nodeCount(); ) {
for (; o = i.dequeue(); )
A(e, n, r, o);
for (; o = a.dequeue(); )
A(e, n, r, o);
if (e.nodeCount()) {
for (var u = n.length - 2; u > 0; --u)
if (o = n[u].dequeue(), o) {
t = t.concat(A(e, n, r, o, !0));
break;
}
}
}
return t;
}
function A(e, n, r, t, a) {
var i = a ? [] : void 0;
return f(e.inEdges(t.v), function(o) {
var u = e.edge(o), d = e.node(o.v);
a && i.push({ v: o.v, w: o.w }), d.out -= u, $(n, r, d);
}), f(e.outEdges(t.v), function(o) {
var u = e.edge(o), d = o.w, s = e.node(d);
s.in -= u, $(n, r, s);
}), e.removeNode(t.v), i;
}
function yn(e, n) {
var r = new g(), t = 0, a = 0;
f(e.nodes(), function(u) {
r.setNode(u, { v: u, in: 0, out: 0 });
}), f(e.edges(), function(u) {
var d = r.edge(u.v, u.w) || 0, s = n(u), c = d + s;
r.setEdge(u.v, u.w, c), a = Math.max(a, r.node(u.v).out += s), t = Math.max(t, r.node(u.w).in += s);
});
var i = E(a + t + 3).map(function() {
return new pn();
}), o = t + 1;
return f(r.nodes(), function(u) {
$(i, o, r.node(u));
}), { graph: r, buckets: i, zeroIdx: o };
}
function $(e, n, r) {
r.out ? r.in ? e[r.out - r.in + n].enqueue(r) : e[e.length - 1].enqueue(r) : e[0].enqueue(r);
}
function kn(e) {
var n = e.graph().acyclicer === "greedy" ? mn(e, r(e)) : xn(e);
f(n, function(t) {
var a = e.edge(t);
e.removeEdge(t), a.forwardName = t.name, a.reversed = !0, e.setEdge(t.w, t.v, a, H("rev"));
});
function r(t) {
return function(a) {
return t.edge(a).weight;
};
}
}
function xn(e) {
var n = [], r = {}, t = {};
function a(i) {
Object.prototype.hasOwnProperty.call(t, i) || (t[i] = !0, r[i] = !0, f(e.outEdges(i), function(o) {
Object.prototype.hasOwnProperty.call(r, o.w) ? n.push(o) : a(o.w);
}), delete r[i]);
}
return f(e.nodes(), a), n;
}
function En(e) {
f(e.edges(), function(n) {
var r = e.edge(n);
if (r.reversed) {
e.removeEdge(n);
var t = r.forwardName;
delete r.reversed, delete r.forwardName, e.setEdge(n.w, n.v, r, t);
}
});
}
function L(e, n, r, t) {
var a;
do
a = H(t);
while (e.hasNode(a));
return r.dummy = n, e.setNode(a, r), a;
}
function On(e) {
var n = new g().setGraph(e.graph());
return f(e.nodes(), function(r) {
n.setNode(r, e.node(r));
}), f(e.edges(), function(r) {
var t = n.edge(r.v, r.w) || { weight: 0, minlen: 1 }, a = e.edge(r);
n.setEdge(r.v, r.w, {
weight: t.weight + a.weight,
minlen: Math.max(t.minlen, a.minlen)
});
}), n;
}
function be(e) {
var n = new g({ multigraph: e.isMultigraph() }).setGraph(e.graph());
return f(e.nodes(), function(r) {
e.children(r).length || n.setNode(r, e.node(r));
}), f(e.edges(), function(r) {
n.setEdge(r, e.edge(r));
}), n;
}
function re(e, n) {
var r = e.x, t = e.y, a = n.x - r, i = n.y - t, o = e.width / 2, u = e.height / 2;
if (!a && !i)
throw new Error("Not possible to find intersection inside of the rectangle");
var d, s;
return Math.abs(i) * o > Math.abs(a) * u ? (i < 0 && (u = -u), d = u * a / i, s = u) : (a < 0 && (o = -o), d = o, s = o * i / a), { x: r + d, y: t + s };
}
function F(e) {
var n = w(E(me(e) + 1), function() {
return [];
});
return f(e.nodes(), function(r) {
var t = e.node(r), a = t.rank;
m(a) || (n[a][t.order] = r);
}), n;
}
function Ln(e) {
var n = P(
w(e.nodes(), function(r) {
return e.node(r).rank;
})
);
f(e.nodes(), function(r) {
var t = e.node(r);
ve(t, "rank") && (t.rank -= n);
});
}
function Nn(e) {
var n = P(
w(e.nodes(), function(i) {
return e.node(i).rank;
})
), r = [];
f(e.nodes(), function(i) {
var o = e.node(i).rank - n;
r[o] || (r[o] = []), r[o].push(i);
});
var t = 0, a = e.graph().nodeRankFactor;
f(r, function(i, o) {
m(i) && o % a !== 0 ? --t : t && f(i, function(u) {
e.node(u).rank += t;
});
});
}
function te(e, n, r, t) {
var a = {
width: 0,
height: 0
};
return arguments.length >= 4 && (a.rank = r, a.order = t), L(e, "border", a, n);
}
function me(e) {
return y(
w(e.nodes(), function(n) {
var r = e.node(n).rank;
if (!m(r))
return r;
})
);
}
function Pn(e, n) {
var r = { lhs: [], rhs: [] };
return f(e, function(t) {
n(t) ? r.lhs.push(t) : r.rhs.push(t);
}), r;
}
function Cn(e, n) {
return n();
}
function _n(e) {
function n(r) {
var t = e.children(r), a = e.node(r);
if (t.length && f(t, n), Object.prototype.hasOwnProperty.call(a, "minRank")) {
a.borderLeft = [], a.borderRight = [];
for (var i = a.minRank, o = a.maxRank + 1; i < o; ++i)
ae(e, "borderLeft", "_bl", r, a, i), ae(e, "borderRight", "_br", r, a, i);
}
}
f(e.children(), n);
}
function ae(e, n, r, t, a, i) {
var o = { width: 0, height: 0, rank: i, borderType: n }, u = a[n][i - 1], d = L(e, "border", o, r);
a[n][i] = d, e.setParent(d, t), u && e.setEdge(u, d, { weight: 1 });
}
function Rn(e) {
var n = e.graph().rankdir.toLowerCase();
(n === "lr" || n === "rl") && ge(e);
}
function Tn(e) {
var n = e.graph().rankdir.toLowerCase();
(n === "bt" || n === "rl") && In(e), (n === "lr" || n === "rl") && (Mn(e), ge(e));
}
function ge(e) {
f(e.nodes(), function(n) {
ie(e.node(n));
}), f(e.edges(), function(n) {
ie(e.edge(n));
});
}
function ie(e) {
var n = e.width;
e.width = e.height, e.height = n;
}
function In(e) {
f(e.nodes(), function(n) {
B(e.node(n));
}), f(e.edges(), function(n) {
var r = e.edge(n);
f(r.points, B), Object.prototype.hasOwnProperty.call(r, "y") && B(r);
});
}
function B(e) {
e.y = -e.y;
}
function Mn(e) {
f(e.nodes(), function(n) {
G(e.node(n));
}), f(e.edges(), function(n) {
var r = e.edge(n);
f(r.points, G), Object.prototype.hasOwnProperty.call(r, "x") && G(r);
});
}
function G(e) {
var n = e.x;
e.x = e.y, e.y = n;
}
function Sn(e) {
e.graph().dummyChains = [], f(e.edges(), function(n) {
Fn(e, n);
});
}
function Fn(e, n) {
var r = n.v, t = e.node(r).rank, a = n.w, i = e.node(a).rank, o = n.name, u = e.edge(n), d = u.labelRank;
if (i !== t + 1) {
e.removeEdge(n);
var s = void 0, c, l;
for (l = 0, ++t; t < i; ++l, ++t)
u.points = [], s = {
width: 0,
height: 0,
edgeLabel: u,
edgeObj: n,
rank: t
}, c = L(e, "edge", s, "_d"), t === d && (s.width = u.width, s.height = u.height, s.dummy = "edge-label", s.labelpos = u.labelpos), e.setEdge(r, c, { weight: u.weight }, o), l === 0 && e.graph().dummyChains.push(c), r = c;
e.setEdge(r, a, { weight: u.weight }, o);
}
}
function jn(e) {
f(e.graph().dummyChains, function(n) {
var r = e.node(n), t = r.edgeLabel, a;
for (e.setEdge(r.edgeObj, t); r.dummy; )
a = e.successors(n)[0], e.removeNode(n), t.points.push({ x: r.x, y: r.y }), r.dummy === "edge-label" && (t.x = r.x, t.y = r.y, t.width = r.width, t.height = r.height), n = a, r = e.node(n);
});
}
function J(e) {
var n = {};
function r(t) {
var a = e.node(t);
if (Object.prototype.hasOwnProperty.call(n, t))
return a.rank;
n[t] = !0;
var i = P(
w(e.outEdges(t), function(o) {
return r(o.w) - e.edge(o).minlen;
})
);
return (i === Number.POSITIVE_INFINITY || // return value of _.map([]) for Lodash 3
i === void 0 || // return value of _.map([]) for Lodash 4
i === null) && (i = 0), a.rank = i;
}
f(e.sources(), r);
}
function C(e, n) {
return e.node(n.w).rank - e.node(n.v).rank - e.edge(n).minlen;
}
function ye(e) {
var n = new g({ directed: !1 }), r = e.nodes()[0], t = e.nodeCount();
n.setNode(r, {});
for (var a, i; Vn(n, e) < t; )
a = An(n, e), i = n.hasNode(a.v) ? C(e, a) : -C(e, a), Bn(n, e, i);
return n;
}
function Vn(e, n) {
function r(t) {
f(n.nodeEdges(t), function(a) {
var i = a.v, o = t === i ? a.w : i;
!e.hasNode(o) && !C(n, a) && (e.setNode(o, {}), e.setEdge(t, o, {}), r(o));
});
}
return f(e.nodes(), r), e.nodeCount();
}
function An(e, n) {
return U(n.edges(), function(r) {
if (e.hasNode(r.v) !== e.hasNode(r.w))
return C(n, r);
});
}
function Bn(e, n, r) {
f(e.nodes(), function(t) {
n.node(t).rank += r;
});
}
function Gn() {
}
Gn.prototype = new Error();
function ke(e, n, r) {
we(n) || (n = [n]);
var t = (e.isDirected() ? e.successors : e.neighbors).bind(e), a = [], i = {};
return f(n, function(o) {
if (!e.hasNode(o))
throw new Error("Graph does not have node: " + o);
xe(e, o, r === "post", i, t, a);
}), a;
}
function xe(e, n, r, t, a, i) {
Object.prototype.hasOwnProperty.call(t, n) || (t[n] = !0, r || i.push(n), f(a(n), function(o) {
xe(e, o, r, t, a, i);
}), r && i.push(n));
}
function Yn(e, n) {
return ke(e, n, "post");
}
function Dn(e, n) {
return ke(e, n, "pre");
}
k.initLowLimValues = K;
k.initCutValues = Z;
k.calcCutValue = Ee;
k.leaveEdge = Le;
k.enterEdge = Ne;
k.exchangeEdges = Pe;
function k(e) {
e = On(e), J(e);
var n = ye(e);
K(n), Z(n, e);
for (var r, t; r = Le(n); )
t = Ne(n, e, r), Pe(n, e, r, t);
}
function Z(e, n) {
var r = Yn(e, e.nodes());
r = r.slice(0, r.length - 1), f(r, function(t) {
qn(e, n, t);
});
}
function qn(e, n, r) {
var t = e.node(r), a = t.parent;
e.edge(r, a).cutvalue = Ee(e, n, r);
}
function Ee(e, n, r) {
var t = e.node(r), a = t.parent, i = !0, o = n.edge(r, a), u = 0;
return o || (i = !1, o = n.edge(a, r)), u = o.weight, f(n.nodeEdges(r), function(d) {
var s = d.v === r, c = s ? d.w : d.v;
if (c !== a) {
var l = s === i, h = n.edge(d).weight;
if (u += l ? h : -h, $n(e, r, c)) {
var v = e.edge(r, c).cutvalue;
u += l ? -v : v;
}
}
}), u;
}
function K(e, n) {
arguments.length < 2 && (n = e.nodes()[0]), Oe(e, {}, 1, n);
}
function Oe(e, n, r, t, a) {
var i = r, o = e.node(t);
return n[t] = !0, f(e.neighbors(t), function(u) {
Object.prototype.hasOwnProperty.call(n, u) || (r = Oe(e, n, r, u, t));
}), o.low = i, o.lim = r++, a ? o.parent = a : delete o.parent, r;
}
function Le(e) {
return X(e.edges(), function(n) {
return e.edge(n).cutvalue < 0;
});
}
function Ne(e, n, r) {
var t = r.v, a = r.w;
n.hasEdge(t, a) || (t = r.w, a = r.v);
var i = e.node(t), o = e.node(a), u = i, d = !1;
i.lim > o.lim && (u = o, d = !0);
var s = _(n.edges(), function(c) {
return d === oe(e, e.node(c.v), u) && d !== oe(e, e.node(c.w), u);
});
return U(s, function(c) {
return C(n, c);
});
}
function Pe(e, n, r, t) {
var a = r.v, i = r.w;
e.removeEdge(a, i), e.setEdge(t.v, t.w, {}), K(e), Z(e, n), Wn(e, n);
}
function Wn(e, n) {
var r = X(e.nodes(), function(a) {
return !n.node(a).parent;
}), t = Dn(e, r);
t = t.slice(1), f(t, function(a) {
var i = e.node(a).parent, o = n.edge(a, i), u = !1;
o || (o = n.edge(i, a), u = !0), n.node(a).rank = n.node(i).rank + (u ? o.minlen : -o.minlen);
});
}
function $n(e, n, r) {
return e.hasEdge(n, r);
}
function oe(e, n, r) {
return r.low <= n.lim && n.lim <= r.lim;
}
function zn(e) {
switch (e.graph().ranker) {
case "network-simplex":
ue(e);
break;
case "tight-tree":
Un(e);
break;
case "longest-path":
Xn(e);
break;
default:
ue(e);
}
}
var Xn = J;
function Un(e) {
J(e), ye(e);
}
function ue(e) {
k(e);
}
function Hn(e) {
var n = L(e, "root", {}, "_root"), r = Jn(e), t = y(x(r)) - 1, a = 2 * t + 1;
e.graph().nestingRoot = n, f(e.edges(), function(o) {
e.edge(o).minlen *= a;
});
var i = Zn(e) + 1;
f(e.children(), function(o) {
Ce(e, n, a, i, t, r, o);
}), e.graph().nodeRankFactor = a;
}
function Ce(e, n, r, t, a, i, o) {
var u = e.children(o);
if (!u.length) {
o !== n && e.setEdge(n, o, { weight: 0, minlen: r });
return;
}
var d = te(e, "_bt"), s = te(e, "_bb"), c = e.node(o);
e.setParent(d, o), c.borderTop = d, e.setParent(s, o), c.borderBottom = s, f(u, function(l) {
Ce(e, n, r, t, a, i, l);
var h = e.node(l), v = h.borderTop ? h.borderTop : l, p = h.borderBottom ? h.borderBottom : l, b = h.borderTop ? t : 2 * t, N = v !== p ? 1 : a - i[o] + 1;
e.setEdge(d, v, {
weight: b,
minlen: N,
nestingEdge: !0
}), e.setEdge(p, s, {
weight: b,
minlen: N,
nestingEdge: !0
});
}), e.parent(o) || e.setEdge(n, d, { weight: 0, minlen: a + i[o] });
}
function Jn(e) {
var n = {};
function r(t, a) {
var i = e.children(t);
i && i.length && f(i, function(o) {
r(o, a + 1);
}), n[t] = a;
}
return f(e.children(), function(t) {
r(t, 1);
}), n;
}
function Zn(e) {
return M(
e.edges(),
function(n, r) {
return n + e.edge(r).weight;
},
0
);
}
function Kn(e) {
var n = e.graph();
e.removeNode(n.nestingRoot), delete n.nestingRoot, f(e.edges(), function(r) {
var t = e.edge(r);
t.nestingEdge && e.removeEdge(r);
});
}
function Qn(e, n, r) {
var t = {}, a;
f(r, function(i) {
for (var o = e.parent(i), u, d; o; ) {
if (u = e.parent(o), u ? (d = t[u], t[u] = o) : (d = a, a = o), d && d !== o) {
n.setEdge(d, o);
return;
}
o = u;
}
});
}
function er(e, n, r) {
var t = nr(e), a = new g({ compound: !0 }).setGraph({ root: t }).setDefaultNodeLabel(function(i) {
return e.node(i);
});
return f(e.nodes(), function(i) {
var o = e.node(i), u = e.parent(i);
(o.rank === n || o.minRank <= n && n <= o.maxRank) && (a.setNode(i), a.setParent(i, u || t), f(e[r](i), function(d) {
var s = d.v === i ? d.w : d.v, c = a.edge(s, i), l = m(c) ? 0 : c.weight;
a.setEdge(s, i, { weight: e.edge(d).weight + l });
}), Object.prototype.hasOwnProperty.call(o, "minRank") && a.setNode(i, {
borderLeft: o.borderLeft[n],
borderRight: o.borderRight[n]
}));
}), a;
}
function nr(e) {
for (var n; e.hasNode(n = H("_root")); ) ;
return n;
}
function rr(e, n) {
for (var r = 0, t = 1; t < n.length; ++t)
r += tr(e, n[t - 1], n[t]);
return r;
}
function tr(e, n, r) {
for (var t = vn(
r,
w(r, function(s, c) {
return c;
})
), a = O(
w(n, function(s) {
return R(
w(e.outEdges(s), function(c) {
return { pos: t[c.w], weight: e.edge(c).weight };
}),
"pos"
);
})
), i = 1; i < r.length; ) i <<= 1;
var o = 2 * i - 1;
i -= 1;
var u = w(new Array(o), function() {
return 0;
}), d = 0;
return f(
// @ts-expect-error
a.forEach(function(s) {
var c = s.pos + i;
u[c] += s.weight;
for (var l = 0; c > 0; )
c % 2 && (l += u[c + 1]), c = c - 1 >> 1, u[c] += s.weight;
d += s.weight * l;
})
), d;
}
function ar(e) {
var n = {}, r = _(e.nodes(), function(u) {
return !e.children(u).length;
}), t = y(
w(r, function(u) {
return e.node(u).rank;
})
), a = w(E(t + 1), function() {
return [];
});
function i(u) {
if (!ve(n, u)) {
n[u] = !0;
var d = e.node(u);
a[d.rank].push(u), f(e.successors(u), i);
}
}
var o = R(r, function(u) {
return e.node(u).rank;
});
return f(o, i), a;
}
function ir(e, n) {
return w(n, function(r) {
var t = e.inEdges(r);
if (t.length) {
var a = M(
t,
function(i, o) {
var u = e.edge(o), d = e.node(o.v);
return {
sum: i.sum + u.weight * d.order,
weight: i.weight + u.weight
};
},
{ sum: 0, weight: 0 }
);
return {
v: r,
barycenter: a.sum / a.weight,
weight: a.weight
};
} else
return { v: r };
});
}
function or(e, n) {
var r = {};
f(e, function(a, i) {
var o = r[a.v] = {
indegree: 0,
in: [],
out: [],
vs: [a.v],
i
};
m(a.barycenter) || (o.barycenter = a.barycenter, o.weight = a.weight);
}), f(n.edges(), function(a) {
var i = r[a.v], o = r[a.w];
!m(i) && !m(o) && (o.indegree++, i.out.push(r[a.w]));
});
var t = _(r, function(a) {
return !a.indegree;
});
return ur(t);
}
function ur(e) {
var n = [];
function r(i) {
return function(o) {
o.merged || (m(o.barycenter) || m(i.barycenter) || o.barycenter >= i.barycenter) && dr(i, o);
};
}
function t(i) {
return function(o) {
o.in.push(i), --o.indegree === 0 && e.push(o);
};
}
for (; e.length; ) {
var a = e.pop();
n.push(a), f(a.in.reverse(), r(a)), f(a.out, t(a));
}
return w(
_(n, function(i) {
return !i.merged;
}),
function(i) {
return I(i, ["vs", "i", "barycenter", "weight"]);
}
);
}
function dr(e, n) {
var r = 0, t = 0;
e.weight && (r += e.barycenter * e.weight, t += e.weight), n.weight && (r += n.barycenter * n.weight, t += n.weight), e.vs = n.vs.concat(e.vs), e.barycenter = r / t, e.weight = t, e.i = Math.min(n.i, e.i), n.merged = !0;
}
function sr(e, n) {
var r = Pn(e, function(c) {
return Object.prototype.hasOwnProperty.call(c, "barycenter");
}), t = r.lhs, a = R(r.rhs, function(c) {
return -c.i;
}), i = [], o = 0, u = 0, d = 0;
t.sort(fr(!!n)), d = de(i, a, d), f(t, function(c) {
d += c.vs.length, i.push(c.vs), o += c.barycenter * c.weight, u += c.weight, d = de(i, a, d);
});
var s = { vs: O(i) };
return u && (s.barycenter = o / u, s.weight = u), s;
}
function de(e, n, r) {
for (var t; n.length && (t = T(n)).i <= r; )
n.pop(), e.push(t.vs), r++;
return r;
}
function fr(e) {
return function(n, r) {
return n.barycenter < r.barycenter ? -1 : n.barycenter > r.barycenter ? 1 : e ? r.i - n.i : n.i - r.i;
};
}
function _e(e, n, r, t) {
var a = e.children(n), i = e.node(n), o = i ? i.borderLeft : void 0, u = i ? i.borderRight : void 0, d = {};
o && (a = _(a, function(p) {
return p !== o && p !== u;
}));
var s = ir(e, a);
f(s, function(p) {
if (e.children(p.v).length) {
var b = _e(e, p.v, r, t);
d[p.v] = b, Object.prototype.hasOwnProperty.call(b, "barycenter") && lr(p, b);
}
});
var c = or(s, r);
cr(c, d);
var l = sr(c, t);
if (o && (l.vs = O([o, l.vs, u]), e.predecessors(o).length)) {
var h = e.node(e.predecessors(o)[0]), v = e.node(e.predecessors(u)[0]);
Object.prototype.hasOwnProperty.call(l, "barycenter") || (l.barycenter = 0, l.weight = 0), l.barycenter = (l.barycenter * l.weight + h.order + v.order) / (l.weight + 2), l.weight += 2;
}
return l;
}
function cr(e, n) {
f(e, function(r) {
r.vs = O(
r.vs.map(function(t) {
return n[t] ? n[t].vs : t;
})
);
});
}
function lr(e, n) {
m(e.barycenter) ? (e.barycenter = n.barycenter, e.weight = n.weight) : (e.barycenter = (e.barycenter * e.weight + n.barycenter * n.weight) / (e.weight + n.weight), e.weight += n.weight);
}
function hr(e) {
var n = me(e), r = se(e, E(1, n + 1), "inEdges"), t = se(e, E(n - 1, -1, -1), "outEdges"), a = ar(e);
fe(e, a);
for (var i = Number.POSITIVE_INFINITY, o, u = 0, d = 0; d < 4; ++u, ++d) {
vr(u % 2 ? r : t, u % 4 >= 2), a = F(e);
var s = rr(e, a);
s < i && (d = 0, o = Ke(a), i = s);
}
fe(e, o);
}
function se(e, n, r) {
return w(n, function(t) {
return er(e, t, r);
});
}
function vr(e, n) {
var r = new g();
f(e, function(t) {
var a = t.graph().root, i = _e(t, a, r, n);
f(i.vs, function(o, u) {
t.node(o).order = u;
}), Qn(t, r, i.vs);
});
}
function fe(e, n) {
f(n, function(r) {
f(r, function(t, a) {
e.node(t).order = a;
});
});
}
function pr(e) {
var n = br(e);
f(e.graph().dummyChains, function(r) {
for (var t = e.node(r), a = t.edgeObj, i = wr(e, n, a.v, a.w), o = i.path, u = i.lca, d = 0, s = o[d], c = !0; r !== a.w; ) {
if (t = e.node(r), c) {
for (; (s = o[d]) !== u && e.node(s).maxRank < t.rank; )
d++;
s === u && (c = !1);
}
if (!c) {
for (; d < o.length - 1 && e.node(s = o[d + 1]).minRank <= t.rank; )
d++;
s = o[d];
}
e.setParent(r, s), r = e.successors(r)[0];
}
});
}
function wr(e, n, r, t) {
var a = [], i = [], o = Math.min(n[r].low, n[t].low), u = Math.max(n[r].lim, n[t].lim), d, s;
d = r;
do
d = e.parent(d), a.push(d);
while (d && (n[d].low > o || u > n[d].lim));
for (s = d, d = t; (d = e.parent(d)) !== s; )
i.push(d);
return { path: a.concat(i.reverse()), lca: s };
}
function br(e) {
var n = {}, r = 0;
function t(a) {
var i = r;
f(e.children(a), t), n[a] = { low: i, lim: r++ };
}
return f(e.children(), t), n;
}
function mr(e, n) {
var r = {};
function t(a, i) {
var o = 0, u = 0, d = a.length, s = T(i);
return f(i, function(c, l) {
var h = yr(e, c), v = h ? e.node(h).order : d;
(h || c === s) && (f(i.slice(u, l + 1), function(p) {
f(e.predecessors(p), function(b) {
var N = e.node(b), Q = N.order;
(Q < o || v < Q) && !(N.dummy && e.node(p).dummy) && Re(r, b, p);
});
}), u = l + 1, o = v);
}), i;
}
return M(n, t), r;
}
function gr(e, n) {
var r = {};
function t(i, o, u, d, s) {
var c;
f(E(o, u), function(l) {
c = i[l], e.node(c).dummy && f(e.predecessors(c), function(h) {
var v = e.node(h);
v.dummy && (v.order < d || v.order > s) && Re(r, h, c);
});
});
}
function a(i, o) {
var u = -1, d, s = 0;
return f(o, function(c, l) {
if (e.node(c).dummy === "border") {
var h = e.predecessors(c);
h.length && (d = e.node(h[0]).order, t(o, s, l, u, d), s = l, u = d);
}
t(o, s, o.length, d, i.length);
}), o;
}
return M(n, a), r;
}
function yr(e, n) {
if (e.node(n).dummy)
return X(e.predecessors(n), function(r) {
return e.node(r).dummy;
});
}
function Re(e, n, r) {
if (n > r) {
var t = n;
n = r, r = t;
}
var a = e[n];
a || (e[n] = a = {}), a[r] = !0;
}
function kr(e, n, r) {
if (n > r) {
var t = n;
n = r, r = t;
}
return !!e[n] && Object.prototype.hasOwnProperty.call(e[n], r);
}
function xr(e, n, r, t) {
var a = {}, i = {}, o = {};
return f(n, function(u) {
f(u, function(d, s) {
a[d] = d, i[d] = d, o[d] = s;
});
}), f(n, function(u) {
var d = -1;
f(u, function(s) {
var c = t(s);
if (c.length) {
c = R(c, function(b) {
return o[b];
});
for (var l = (c.length - 1) / 2, h = Math.floor(l), v = Math.ceil(l); h <= v; ++h) {
var p = c[h];
i[s] === s && d < o[p] && !kr(r, s, p) && (i[p] = s, i[s] = a[s] = a[p], d = o[p]);
}
}
});
}), { root: a, align: i };
}
function Er(e, n, r, t, a) {
var i = {}, o = Or(e, n, r, a), u = a ? "borderLeft" : "borderRight";
function d(l, h) {
for (var v = o.nodes(), p = v.pop(), b = {}; p; )
b[p] ? l(p) : (b[p] = !0, v.push(p), v = v.concat(h(p))), p = v.pop();
}
function s(l) {
i[l] = o.inEdges(l).reduce(function(h, v) {
return Math.max(h, i[v.v] + o.edge(v));
}, 0);
}
function c(l) {
var h = o.outEdges(l).reduce(function(p, b) {
return Math.min(p, i[b.w] - o.edge(b));
}, Number.POSITIVE_INFINITY), v = e.node(l);
h !== Number.POSITIVE_INFINITY && v.borderType !== u && (i[l] = Math.max(i[l], h));
}
return d(s, o.predecessors.bind(o)), d(c, o.successors.bind(o)), f(t, function(l) {
i[l] = i[r[l]];
}), i;
}
function Or(e, n, r, t) {
var a = new g(), i = e.graph(), o = _r(i.nodesep, i.edgesep, t);
return f(n, function(u) {
var d;
f(u, function(s) {
var c = r[s];
if (a.setNode(c), d) {
var l = r[d], h = a.edge(l, c);
a.setEdge(l, c, Math.max(o(e, s, d), h || 0));
}
d = s;
});
}), a;
}
function Lr(e, n) {
return U(x(n), function(r) {
var t = Number.NEGATIVE_INFINITY, a = Number.POSITIVE_INFINITY;
return Qe(r, function(i, o) {
var u = Rr(e, o) / 2;
t = Math.max(i + u, t), a = Math.min(i - u, a);
}), t - a;
});
}
function Nr(e, n) {
var r = x(n), t = P(r), a = y(r);
f(["u", "d"], function(i) {
f(["l", "r"], function(o) {
var u = i + o, d = e[u], s;
if (d !== n) {
var c = x(d);
s = o === "l" ? t - P(c) : a - y(c), s && (e[u] = S(d, function(l) {
return l + s;
}));
}
});
});
}
function Pr(e, n) {
return S(e.ul, function(r, t) {
if (n)
return e[n.toLowerCase()][t];
var a = R(w(e, t));
return (a[1] + a[2]) / 2;
});
}
function Cr(e) {
var n = F(e), r = W(mr(e, n), gr(e, n)), t = {}, a;
f(["u", "d"], function(o) {
a = o === "u" ? n : x(n).reverse(), f(["l", "r"], function(u) {
u === "r" && (a = w(a, function(l) {
return x(l).reverse();
}));
var d = (o === "u" ? e.predecessors : e.successors).bind(e), s = xr(e, a, r, d), c = Er(e, a, s.root, s.align, u === "r");
u === "r" && (c = S(c, function(l) {
return -l;
})), t[o + u] = c;
});
});
var i = Lr(e, t);
return Nr(t, i), Pr(t, e.graph().align);
}
function _r(e, n, r) {
return function(t, a, i) {
var o = t.node(a), u = t.node(i), d = 0, s;
if (d += o.width / 2, Object.prototype.hasOwnProperty.call(o, "labelpos"))
switch (o.labelpos.toLowerCase()) {
case "l":
s = -o.width / 2;
break;
case "r":
s = o.width / 2;
break;
}
if (s && (d += r ? s : -s), s = 0, d += (o.dummy ? n : e) / 2, d += (u.dummy ? n : e) / 2, d += u.width / 2, Object.prototype.hasOwnProperty.call(u, "labelpos"))
switch (u.labelpos.toLowerCase()) {
case "l":
s = u.width / 2;
break;
case "r":
s = -u.width / 2;
break;
}
return s && (d += r ? s : -s), s = 0, d;
};
}
function Rr(e, n) {
return e.node(n).width;
}
function Tr(e) {
e = be(e), Ir(e), en(Cr(e), function(n, r) {
e.node(r).x = n;
});
}
function Ir(e) {
var n = F(e), r = e.graph().ranksep, t = 0;
f(n, function(a) {
var i = y(
w(a, function(o) {
return e.node(o).height;
})
);
f(a, function(o) {
e.node(o).y = t + i / 2;
}), t += i + r;
});
}
function ot(e, n) {
var r = Cn;
r("layout", () => {
var t = r(" buildLayoutGraph", () => qr(e));
r(" runLayout", () => Mr(t, r)), r(" updateInputGraph", () => Sr(e, t));
});
}
function Mr(e, n) {
n(" makeSpaceForEdgeLabels", () => Wr(e)), n(" removeSelfEdges", () => Qr(e)), n(" acyclic", () => kn(e)), n(" nestingGraph.run", () => Hn(e)), n(" rank", () => zn(be(e))), n(" injectEdgeLabelProxies", () => $r(e)), n(" removeEmptyRanks", () => Nn(e)), n(" nestingGraph.cleanup", () => Kn(e)), n(" normalizeRanks", () => Ln(e)), n(" assignRankMinMax", () => zr(e)), n(" removeEdgeLabelProxies", () => Xr(e)), n(" normalize.run", () => Sn(e)), n(" parentDummyChains", () => pr(e)), n(" addBorderSegments", () => _n(e)), n(" order", () => hr(e)), n(" insertSelfEdges", () => et(e)), n(" adjustCoordinateSystem", () => Rn(e)), n(" position", () => Tr(e)), n(" positionSelfEdges", () => nt(e)), n(" removeBorderNodes", () => Kr(e)), n(" normalize.undo", () => jn(e)), n(" fixupEdgeLabelCoords", () => Jr(e)), n(" undoCoordinateSystem", () => Tn(e)), n(" translateGraph", () => Ur(e)), n(" assignNodeIntersects", () => Hr(e)), n(" reversePoints", () => Zr(e)), n(" acyclic.undo", () => En(e));
}
function Sr(e, n) {
f(e.nodes(), function(r) {
var t = e.node(r), a = n.node(r);
t && (t.x = a.x, t.y = a.y, n.children(r).length && (t.width = a.width, t.height = a.height));
}), f(e.edges(), function(r) {
var t = e.edge(r), a = n.edge(r);
t.points = a.points, Object.prototype.hasOwnProperty.call(a, "x") && (t.x = a.x, t.y = a.y);
}), e.graph().width = n.graph().width, e.graph().height = n.graph().height;
}
var Fr = ["nodesep", "edgesep", "ranksep", "marginx", "marginy"], jr = { ranksep: 50, edgesep: 20, nodesep: 50, rankdir: "tb" }, Vr = ["acyclicer", "ranker", "rankdir", "align"], Ar = ["width", "height"], Br = { width: 0, height: 0 }, Gr = ["minlen", "weight", "width", "height", "labeloffset"], Yr = {
minlen: 1,
weight: 1,
width: 0,
height: 0,
labeloffset: 10,
labelpos: "r"
}, Dr = ["labelpos"];
function qr(e) {
var n = new g({ multigraph: !0, compound: !0 }), r = D(e.graph());
return n.setGraph(
W({}, jr, Y(r, Fr), I(r, Vr))
), f(e.nodes(), function(t) {
var a = D(e.node(t));
n.setNode(t, Be(Y(a, Ar), Br)), n.setParent(t, e.parent(t));
}), f(e.edges(), function(t) {
var a = D(e.edge(t));
n.setEdge(
t,
W({}, Yr, Y(a, Gr), I(a, Dr))
);
}), n;
}
function Wr(e) {
var n = e.graph();
n.ranksep /= 2, f(e.edges(), function(r) {
var t = e.edge(r);
t.minlen *= 2, t.labelpos.toLowerCase() !== "c" && (n.rankdir === "TB" || n.rankdir === "BT" ? t.width += t.labeloffset : t.height += t.labeloffset);
});
}
function $r(e) {
f(e.edges(), function(n) {
var r = e.edge(n);
if (r.width && r.height) {
var t = e.node(n.v), a = e.node(n.w), i = { rank: (a.rank - t.rank) / 2 + t.rank, e: n };
L(e, "edge-proxy", i, "_ep");
}
});
}
function zr(e) {
var n = 0;
f(e.nodes(), function(r) {
var t = e.node(r);
t.borderTop && (t.minRank = e.node(t.borderTop).rank, t.maxRank = e.node(t.borderBottom).rank, n = y(n, t.maxRank));
}), e.graph().maxRank = n;
}
function Xr(e) {
f(e.nodes(), function(n) {
var r = e.node(n);
r.dummy === "edge-proxy" && (e.edge(r.e).labelRank = r.rank, e.removeNode(n));
});
}
function Ur(e) {
var n = Number.POSITIVE_INFINITY, r = 0, t = Number.POSITIVE_INFINITY, a = 0, i = e.graph(), o = i.marginx || 0, u = i.marginy || 0;
function d(s) {
var c = s.x, l = s.y, h = s.width, v = s.height;
n = Math.min(n, c - h / 2), r = Math.max(r, c + h / 2), t = Math.min(t, l - v / 2), a = Math.max(a, l + v / 2);
}
f(e.nodes(), function(s) {
d(e.node(s));
}), f(e.edges(), function(s) {
var c = e.edge(s);
Object.prototype.hasOwnProperty.call(c, "x") && d(c);
}), n -= o, t -= u, f(e.nodes(), function(s) {
var c = e.node(s);
c.x -= n, c.y -= t;
}), f(e.edges(), function(s) {
var c = e.edge(s);
f(c.points, function(l) {
l.x -= n, l.y -= t;
}), Object.prototype.hasOwnProperty.call(c, "x") && (c.x -= n), Object.prototype.hasOwnProperty.call(c, "y") && (c.y -= t);
}), i.width = r - n + o, i.height = a - t + u;
}
function Hr(e) {
f(e.edges(), function(n) {
var r = e.edge(n), t = e.node(n.v), a = e.node(n.w), i, o;
r.points ? (i = r.points[0], o = r.points[r.points.length - 1]) : (r.points = [], i = a, o = t), r.points.unshift(re(t, i)), r.points.push(re(a, o));
});
}
function Jr(e) {
f(e.edges(), function(n) {
var r = e.edge(n);
if (Object.prototype.hasOwnProperty.call(r, "x"))
switch ((r.labelpos === "l" || r.labelpos === "r") && (r.width -= r.labeloffset), r.labelpos) {
case "l":
r.x -= r.width / 2 + r.labeloffset;
break;
case "r":
r.x += r.width / 2 + r.labeloffset;
break;
}
});
}
function Zr(e) {
f(e.edges(), function(n) {
var r = e.edge(n);
r.reversed && r.points.reverse();
});
}
function Kr(e) {
f(e.nodes(), function(n) {
if (e.children(n).length) {
var r = e.node(n), t = e.node(r.borderTop), a = e.node(r.borderBottom), i = e.node(T(r.borderLeft)), o = e.node(T(r.borderRight));
r.width = Math.abs(o.x - i.x), r.height = Math.abs(a.y - t.y), r.x = i.x + r.width / 2, r.y = t.y + r.height / 2;
}
}), f(e.nodes(), function(n) {
e.node(n).dummy === "border" && e.removeNode(n);
});
}
function Qr(e) {
f(e.edges(), function(n) {
if (n.v === n.w) {
var r = e.node(n.v);
r.selfEdges || (r.selfEdges = []), r.selfEdges.push({ e: n, label: e.edge(n) }), e.removeEdge(n);
}
});
}
function et(e) {
var n = F(e);
f(n, function(r) {
var t = 0;
f(r, function(a, i) {
var o = e.node(a);
o.order = i + t, f(o.selfEdges, function(u) {
L(
e,
"selfedge",
{
width: u.label.width,
height: u.label.height,
rank: o.rank,
order: i + ++t,
e: u.e,
label: u.label
},
"_se"
);
}), delete o.selfEdges;
});
});
}
function nt(e) {
f(e.nodes(), function(n) {
var r = e.node(n);
if (r.dummy === "selfedge") {
var t = e.node(r.e.v), a = t.x + t.width / 2, i = t.y, o = r.x - a, u = t.height / 2;
e.setEdge(r.e, r.label), e.removeNode(n), r.label.points = [
{ x: a + 2 * o / 3, y: i - u },
{ x: a + 5 * o / 6, y: i - u },
{ x: a + o, y: i },
{ x: a + 5 * o / 6, y: i + u },
{ x: a + 2 * o / 3, y: i + u }
], r.label.x = r.x, r.label.y = r.y;
}
});
}
function Y(e, n) {
return S(I(e, n), Number);
}
function D(e) {
var n = {};
return f(e, function(r, t) {
n[t.toLowerCase()] = r;
}), n;
}
export {
ot as l
};
//# sourceMappingURL=layout-VtjyAaGP.mjs.map