Files
gradio-webrtc/backend/fastrtc/templates/component/flowDiagram-4HSFHLVR-DiHdHcaJ.js
Freddy Boulton 1877720231 Add text mode (#321)
* Pretty good spot

* Working draft

* Fix other mode

* Add js to git

* Working

* Add code

* fix

* Fix

* Add code

* Fix submit race condition

* demo

* fix

* Fix

* Fix
2025-06-03 19:24:21 -04:00

1623 lines
84 KiB
JavaScript

import { d as G1, s as Ht, c as qt, n as Xt, g as Qt, b as Jt, o as Zt, _ as m, e as $t, p as te, J as ee, q as se, l as Z, r as st, u as it, j as C1, t as ie, v as re, x as Ot, y as ae, z as ne, A as ue } from "./mermaid.core-C0Blj36u.js";
import { g as le, s as oe } from "./chunk-RZ5BOZE2-BQm8zocb.js";
import { c as ce } from "./channel-BLI8LD7T.js";
var he = "flowchart-", P1, de = (P1 = class {
// cspell:ignore funs
constructor() {
this.vertexCounter = 0, this.config = G1(), this.vertices = /* @__PURE__ */ new Map(), this.edges = [], this.classes = /* @__PURE__ */ new Map(), this.subGraphs = [], this.subGraphLookup = /* @__PURE__ */ new Map(), this.tooltips = /* @__PURE__ */ new Map(), this.subCount = 0, this.firstGraphFlag = !0, this.secCount = -1, this.posCrossRef = [], this.funs = [], this.setAccTitle = Ht, this.setAccDescription = qt, this.setDiagramTitle = Xt, this.getAccTitle = Qt, this.getAccDescription = Jt, this.getDiagramTitle = Zt, this.funs.push(this.setupToolTips.bind(this)), this.addVertex = this.addVertex.bind(this), this.firstGraph = this.firstGraph.bind(this), this.setDirection = this.setDirection.bind(this), this.addSubGraph = this.addSubGraph.bind(this), this.addLink = this.addLink.bind(this), this.setLink = this.setLink.bind(this), this.updateLink = this.updateLink.bind(this), this.addClass = this.addClass.bind(this), this.setClass = this.setClass.bind(this), this.destructLink = this.destructLink.bind(this), this.setClickEvent = this.setClickEvent.bind(this), this.setTooltip = this.setTooltip.bind(this), this.updateLinkInterpolate = this.updateLinkInterpolate.bind(this), this.setClickFun = this.setClickFun.bind(this), this.bindFunctions = this.bindFunctions.bind(this), this.lex = {
firstGraph: this.firstGraph.bind(this)
}, this.clear(), this.setGen("gen-2");
}
sanitizeText(i) {
return $t.sanitizeText(i, this.config);
}
/**
* Function to lookup domId from id in the graph definition.
*
* @param id - id of the node
*/
lookUpDomId(i) {
for (const a of this.vertices.values())
if (a.id === i)
return a.domId;
return i;
}
/**
* Function called by parser when a node definition has been found
*/
addVertex(i, a, n, u, l, f, c = {}, A) {
var U, T;
if (!i || i.trim().length === 0)
return;
let r;
if (A !== void 0) {
let d;
A.includes(`
`) ? d = A + `
` : d = `{
` + A + `
}`, r = te(d, { schema: ee });
}
const b = this.edges.find((d) => d.id === i);
if (b) {
const d = r;
(d == null ? void 0 : d.animate) !== void 0 && (b.animate = d.animate), (d == null ? void 0 : d.animation) !== void 0 && (b.animation = d.animation);
return;
}
let F, k = this.vertices.get(i);
if (k === void 0 && (k = {
id: i,
labelType: "text",
domId: he + i + "-" + this.vertexCounter,
styles: [],
classes: []
}, this.vertices.set(i, k)), this.vertexCounter++, a !== void 0 ? (this.config = G1(), F = this.sanitizeText(a.text.trim()), k.labelType = a.type, F.startsWith('"') && F.endsWith('"') && (F = F.substring(1, F.length - 1)), k.text = F) : k.text === void 0 && (k.text = i), n !== void 0 && (k.type = n), u != null && u.forEach((d) => {
k.styles.push(d);
}), l != null && l.forEach((d) => {
k.classes.push(d);
}), f !== void 0 && (k.dir = f), k.props === void 0 ? k.props = c : c !== void 0 && Object.assign(k.props, c), r !== void 0) {
if (r.shape) {
if (r.shape !== r.shape.toLowerCase() || r.shape.includes("_"))
throw new Error(`No such shape: ${r.shape}. Shape names should be lowercase.`);
if (!se(r.shape))
throw new Error(`No such shape: ${r.shape}.`);
k.type = r == null ? void 0 : r.shape;
}
r != null && r.label && (k.text = r == null ? void 0 : r.label), r != null && r.icon && (k.icon = r == null ? void 0 : r.icon, !((U = r.label) != null && U.trim()) && k.text === i && (k.text = "")), r != null && r.form && (k.form = r == null ? void 0 : r.form), r != null && r.pos && (k.pos = r == null ? void 0 : r.pos), r != null && r.img && (k.img = r == null ? void 0 : r.img, !((T = r.label) != null && T.trim()) && k.text === i && (k.text = "")), r != null && r.constraint && (k.constraint = r.constraint), r.w && (k.assetWidth = Number(r.w)), r.h && (k.assetHeight = Number(r.h));
}
}
/**
* Function called by parser when a link/edge definition has been found
*
*/
addSingleLink(i, a, n, u) {
const c = {
start: i,
end: a,
type: void 0,
text: "",
labelType: "text",
classes: [],
isUserDefinedId: !1,
interpolate: this.edges.defaultInterpolate
};
Z.info("abc78 Got edge...", c);
const A = n.text;
if (A !== void 0 && (c.text = this.sanitizeText(A.text.trim()), c.text.startsWith('"') && c.text.endsWith('"') && (c.text = c.text.substring(1, c.text.length - 1)), c.labelType = A.type), n !== void 0 && (c.type = n.type, c.stroke = n.stroke, c.length = n.length > 10 ? 10 : n.length), u && !this.edges.some((r) => r.id === u))
c.id = u, c.isUserDefinedId = !0;
else {
const r = this.edges.filter((b) => b.start === c.start && b.end === c.end);
r.length === 0 ? c.id = st(c.start, c.end, { counter: 0, prefix: "L" }) : c.id = st(c.start, c.end, {
counter: r.length + 1,
prefix: "L"
});
}
if (this.edges.length < (this.config.maxEdges ?? 500))
Z.info("Pushing edge..."), this.edges.push(c);
else
throw new Error(
`Edge limit exceeded. ${this.edges.length} edges found, but the limit is ${this.config.maxEdges}.
Initialize mermaid with maxEdges set to a higher number to allow more edges.
You cannot set this config via configuration inside the diagram as it is a secure config.
You have to call mermaid.initialize.`
);
}
isLinkData(i) {
return i !== null && typeof i == "object" && "id" in i && typeof i.id == "string";
}
addLink(i, a, n) {
const u = this.isLinkData(n) ? n.id.replace("@", "") : void 0;
Z.info("addLink", i, a, u);
for (const l of i)
for (const f of a) {
const c = l === i[i.length - 1], A = f === a[0];
c && A ? this.addSingleLink(l, f, n, u) : this.addSingleLink(l, f, n, void 0);
}
}
/**
* Updates a link's line interpolation algorithm
*/
updateLinkInterpolate(i, a) {
i.forEach((n) => {
n === "default" ? this.edges.defaultInterpolate = a : this.edges[n].interpolate = a;
});
}
/**
* Updates a link with a style
*
*/
updateLink(i, a) {
i.forEach((n) => {
var u, l, f, c, A, r;
if (typeof n == "number" && n >= this.edges.length)
throw new Error(
`The index ${n} for linkStyle is out of bounds. Valid indices for linkStyle are between 0 and ${this.edges.length - 1}. (Help: Ensure that the index is within the range of existing edges.)`
);
n === "default" ? this.edges.defaultStyle = a : (this.edges[n].style = a, (((l = (u = this.edges[n]) == null ? void 0 : u.style) == null ? void 0 : l.length) ?? 0) > 0 && !((c = (f = this.edges[n]) == null ? void 0 : f.style) != null && c.some((b) => b == null ? void 0 : b.startsWith("fill"))) && ((r = (A = this.edges[n]) == null ? void 0 : A.style) == null || r.push("fill:none")));
});
}
addClass(i, a) {
const n = a.join().replace(/\\,/g, "§§§").replace(/,/g, ";").replace(/§§§/g, ",").split(";");
i.split(",").forEach((u) => {
let l = this.classes.get(u);
l === void 0 && (l = { id: u, styles: [], textStyles: [] }, this.classes.set(u, l)), n != null && n.forEach((f) => {
if (/color/.exec(f)) {
const c = f.replace("fill", "bgFill");
l.textStyles.push(c);
}
l.styles.push(f);
});
});
}
/**
* Called by parser when a graph definition is found, stores the direction of the chart.
*
*/
setDirection(i) {
this.direction = i, /.*</.exec(this.direction) && (this.direction = "RL"), /.*\^/.exec(this.direction) && (this.direction = "BT"), /.*>/.exec(this.direction) && (this.direction = "LR"), /.*v/.exec(this.direction) && (this.direction = "TB"), this.direction === "TD" && (this.direction = "TB");
}
/**
* Called by parser when a special node is found, e.g. a clickable element.
*
* @param ids - Comma separated list of ids
* @param className - Class to add
*/
setClass(i, a) {
for (const n of i.split(",")) {
const u = this.vertices.get(n);
u && u.classes.push(a);
const l = this.edges.find((c) => c.id === n);
l && l.classes.push(a);
const f = this.subGraphLookup.get(n);
f && f.classes.push(a);
}
}
setTooltip(i, a) {
if (a !== void 0) {
a = this.sanitizeText(a);
for (const n of i.split(","))
this.tooltips.set(this.version === "gen-1" ? this.lookUpDomId(n) : n, a);
}
}
setClickFun(i, a, n) {
const u = this.lookUpDomId(i);
if (G1().securityLevel !== "loose" || a === void 0)
return;
let l = [];
if (typeof n == "string") {
l = n.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/);
for (let c = 0; c < l.length; c++) {
let A = l[c].trim();
A.startsWith('"') && A.endsWith('"') && (A = A.substr(1, A.length - 2)), l[c] = A;
}
}
l.length === 0 && l.push(i);
const f = this.vertices.get(i);
f && (f.haveCallback = !0, this.funs.push(() => {
const c = document.querySelector(`[id="${u}"]`);
c !== null && c.addEventListener(
"click",
() => {
it.runFunc(a, ...l);
},
!1
);
}));
}
/**
* Called by parser when a link is found. Adds the URL to the vertex data.
*
* @param ids - Comma separated list of ids
* @param linkStr - URL to create a link for
* @param target - Target attribute for the link
*/
setLink(i, a, n) {
i.split(",").forEach((u) => {
const l = this.vertices.get(u);
l !== void 0 && (l.link = it.formatUrl(a, this.config), l.linkTarget = n);
}), this.setClass(i, "clickable");
}
getTooltip(i) {
return this.tooltips.get(i);
}
/**
* Called by parser when a click definition is found. Registers an event handler.
*
* @param ids - Comma separated list of ids
* @param functionName - Function to be called on click
* @param functionArgs - Arguments to be passed to the function
*/
setClickEvent(i, a, n) {
i.split(",").forEach((u) => {
this.setClickFun(u, a, n);
}), this.setClass(i, "clickable");
}
bindFunctions(i) {
this.funs.forEach((a) => {
a(i);
});
}
getDirection() {
var i;
return (i = this.direction) == null ? void 0 : i.trim();
}
/**
* Retrieval function for fetching the found nodes after parsing has completed.
*
*/
getVertices() {
return this.vertices;
}
/**
* Retrieval function for fetching the found links after parsing has completed.
*
*/
getEdges() {
return this.edges;
}
/**
* Retrieval function for fetching the found class definitions after parsing has completed.
*
*/
getClasses() {
return this.classes;
}
setupToolTips(i) {
let a = C1(".mermaidTooltip");
(a._groups || a)[0][0] === null && (a = C1("body").append("div").attr("class", "mermaidTooltip").style("opacity", 0)), C1(i).select("svg").selectAll("g.node").on("mouseover", (l) => {
var r;
const f = C1(l.currentTarget);
if (f.attr("title") === null)
return;
const A = (r = l.currentTarget) == null ? void 0 : r.getBoundingClientRect();
a.transition().duration(200).style("opacity", ".9"), a.text(f.attr("title")).style("left", window.scrollX + A.left + (A.right - A.left) / 2 + "px").style("top", window.scrollY + A.bottom + "px"), a.html(a.html().replace(/&lt;br\/&gt;/g, "<br/>")), f.classed("hover", !0);
}).on("mouseout", (l) => {
a.transition().duration(500).style("opacity", 0), C1(l.currentTarget).classed("hover", !1);
});
}
/**
* Clears the internal graph db so that a new graph can be parsed.
*
*/
clear(i = "gen-2") {
this.vertices = /* @__PURE__ */ new Map(), this.classes = /* @__PURE__ */ new Map(), this.edges = [], this.funs = [this.setupToolTips.bind(this)], this.subGraphs = [], this.subGraphLookup = /* @__PURE__ */ new Map(), this.subCount = 0, this.tooltips = /* @__PURE__ */ new Map(), this.firstGraphFlag = !0, this.version = i, this.config = G1(), ie();
}
setGen(i) {
this.version = i || "gen-2";
}
defaultStyle() {
return "fill:#ffa;stroke: #f66; stroke-width: 3px; stroke-dasharray: 5, 5;fill:#ffa;stroke: #666;";
}
addSubGraph(i, a, n) {
let u = i.text.trim(), l = n.text;
i === n && /\s/.exec(n.text) && (u = void 0);
const f = /* @__PURE__ */ m((b) => {
const F = { boolean: {}, number: {}, string: {} }, k = [];
let U;
return { nodeList: b.filter(function(d) {
const K = typeof d;
return d.stmt && d.stmt === "dir" ? (U = d.value, !1) : d.trim() === "" ? !1 : K in F ? F[K].hasOwnProperty(d) ? !1 : F[K][d] = !0 : k.includes(d) ? !1 : k.push(d);
}), dir: U };
}, "uniq"), { nodeList: c, dir: A } = f(a.flat());
if (this.version === "gen-1")
for (let b = 0; b < c.length; b++)
c[b] = this.lookUpDomId(c[b]);
u = u ?? "subGraph" + this.subCount, l = l || "", l = this.sanitizeText(l), this.subCount = this.subCount + 1;
const r = {
id: u,
nodes: c,
title: l.trim(),
classes: [],
dir: A,
labelType: n.type
};
return Z.info("Adding", r.id, r.nodes, r.dir), r.nodes = this.makeUniq(r, this.subGraphs).nodes, this.subGraphs.push(r), this.subGraphLookup.set(u, r), u;
}
getPosForId(i) {
for (const [a, n] of this.subGraphs.entries())
if (n.id === i)
return a;
return -1;
}
indexNodes2(i, a) {
const n = this.subGraphs[a].nodes;
if (this.secCount = this.secCount + 1, this.secCount > 2e3)
return {
result: !1,
count: 0
};
if (this.posCrossRef[this.secCount] = a, this.subGraphs[a].id === i)
return {
result: !0,
count: 0
};
let u = 0, l = 1;
for (; u < n.length; ) {
const f = this.getPosForId(n[u]);
if (f >= 0) {
const c = this.indexNodes2(i, f);
if (c.result)
return {
result: !0,
count: l + c.count
};
l = l + c.count;
}
u = u + 1;
}
return {
result: !1,
count: l
};
}
getDepthFirstPos(i) {
return this.posCrossRef[i];
}
indexNodes() {
this.secCount = -1, this.subGraphs.length > 0 && this.indexNodes2("none", this.subGraphs.length - 1);
}
getSubGraphs() {
return this.subGraphs;
}
firstGraph() {
return this.firstGraphFlag ? (this.firstGraphFlag = !1, !0) : !1;
}
destructStartLink(i) {
let a = i.trim(), n = "arrow_open";
switch (a[0]) {
case "<":
n = "arrow_point", a = a.slice(1);
break;
case "x":
n = "arrow_cross", a = a.slice(1);
break;
case "o":
n = "arrow_circle", a = a.slice(1);
break;
}
let u = "normal";
return a.includes("=") && (u = "thick"), a.includes(".") && (u = "dotted"), { type: n, stroke: u };
}
countChar(i, a) {
const n = a.length;
let u = 0;
for (let l = 0; l < n; ++l)
a[l] === i && ++u;
return u;
}
destructEndLink(i) {
const a = i.trim();
let n = a.slice(0, -1), u = "arrow_open";
switch (a.slice(-1)) {
case "x":
u = "arrow_cross", a.startsWith("x") && (u = "double_" + u, n = n.slice(1));
break;
case ">":
u = "arrow_point", a.startsWith("<") && (u = "double_" + u, n = n.slice(1));
break;
case "o":
u = "arrow_circle", a.startsWith("o") && (u = "double_" + u, n = n.slice(1));
break;
}
let l = "normal", f = n.length - 1;
n.startsWith("=") && (l = "thick"), n.startsWith("~") && (l = "invisible");
const c = this.countChar(".", n);
return c && (l = "dotted", f = c), { type: u, stroke: l, length: f };
}
destructLink(i, a) {
const n = this.destructEndLink(i);
let u;
if (a) {
if (u = this.destructStartLink(a), u.stroke !== n.stroke)
return { type: "INVALID", stroke: "INVALID" };
if (u.type === "arrow_open")
u.type = n.type;
else {
if (u.type !== n.type)
return { type: "INVALID", stroke: "INVALID" };
u.type = "double_" + u.type;
}
return u.type === "double_arrow" && (u.type = "double_arrow_point"), u.length = n.length, u;
}
return n;
}
// Todo optimizer this by caching existing nodes
exists(i, a) {
for (const n of i)
if (n.nodes.includes(a))
return !0;
return !1;
}
/**
* Deletes an id from all subgraphs
*
*/
makeUniq(i, a) {
const n = [];
return i.nodes.forEach((u, l) => {
this.exists(a, u) || n.push(i.nodes[l]);
}), { nodes: n };
}
getTypeFromVertex(i) {
if (i.img)
return "imageSquare";
if (i.icon)
return i.form === "circle" ? "iconCircle" : i.form === "square" ? "iconSquare" : i.form === "rounded" ? "iconRounded" : "icon";
switch (i.type) {
case "square":
case void 0:
return "squareRect";
case "round":
return "roundedRect";
case "ellipse":
return "ellipse";
default:
return i.type;
}
}
findNode(i, a) {
return i.find((n) => n.id === a);
}
destructEdgeType(i) {
let a = "none", n = "arrow_point";
switch (i) {
case "arrow_point":
case "arrow_circle":
case "arrow_cross":
n = i;
break;
case "double_arrow_point":
case "double_arrow_circle":
case "double_arrow_cross":
a = i.replace("double_", ""), n = a;
break;
}
return { arrowTypeStart: a, arrowTypeEnd: n };
}
addNodeFromVertex(i, a, n, u, l, f) {
var b;
const c = n.get(i.id), A = u.get(i.id) ?? !1, r = this.findNode(a, i.id);
if (r)
r.cssStyles = i.styles, r.cssCompiledStyles = this.getCompiledStyles(i.classes), r.cssClasses = i.classes.join(" ");
else {
const F = {
id: i.id,
label: i.text,
labelStyle: "",
parentId: c,
padding: ((b = l.flowchart) == null ? void 0 : b.padding) || 8,
cssStyles: i.styles,
cssCompiledStyles: this.getCompiledStyles(["default", "node", ...i.classes]),
cssClasses: "default " + i.classes.join(" "),
dir: i.dir,
domId: i.domId,
look: f,
link: i.link,
linkTarget: i.linkTarget,
tooltip: this.getTooltip(i.id),
icon: i.icon,
pos: i.pos,
img: i.img,
assetWidth: i.assetWidth,
assetHeight: i.assetHeight,
constraint: i.constraint
};
A ? a.push({
...F,
isGroup: !0,
shape: "rect"
}) : a.push({
...F,
isGroup: !1,
shape: this.getTypeFromVertex(i)
});
}
}
getCompiledStyles(i) {
let a = [];
for (const n of i) {
const u = this.classes.get(n);
u != null && u.styles && (a = [...a, ...u.styles ?? []].map((l) => l.trim())), u != null && u.textStyles && (a = [...a, ...u.textStyles ?? []].map((l) => l.trim()));
}
return a;
}
getData() {
const i = G1(), a = [], n = [], u = this.getSubGraphs(), l = /* @__PURE__ */ new Map(), f = /* @__PURE__ */ new Map();
for (let r = u.length - 1; r >= 0; r--) {
const b = u[r];
b.nodes.length > 0 && f.set(b.id, !0);
for (const F of b.nodes)
l.set(F, b.id);
}
for (let r = u.length - 1; r >= 0; r--) {
const b = u[r];
a.push({
id: b.id,
label: b.title,
labelStyle: "",
parentId: l.get(b.id),
padding: 8,
cssCompiledStyles: this.getCompiledStyles(b.classes),
cssClasses: b.classes.join(" "),
shape: "rect",
dir: b.dir,
isGroup: !0,
look: i.look
});
}
this.getVertices().forEach((r) => {
this.addNodeFromVertex(r, a, l, f, i, i.look || "classic");
});
const A = this.getEdges();
return A.forEach((r, b) => {
var d;
const { arrowTypeStart: F, arrowTypeEnd: k } = this.destructEdgeType(r.type), U = [...A.defaultStyle ?? []];
r.style && U.push(...r.style);
const T = {
id: st(r.start, r.end, { counter: b, prefix: "L" }, r.id),
isUserDefinedId: r.isUserDefinedId,
start: r.start,
end: r.end,
type: r.type ?? "normal",
label: r.text,
labelpos: "c",
thickness: r.stroke,
minlen: r.length,
classes: (r == null ? void 0 : r.stroke) === "invisible" ? "" : "edge-thickness-normal edge-pattern-solid flowchart-link",
arrowTypeStart: (r == null ? void 0 : r.stroke) === "invisible" || (r == null ? void 0 : r.type) === "arrow_open" ? "none" : F,
arrowTypeEnd: (r == null ? void 0 : r.stroke) === "invisible" || (r == null ? void 0 : r.type) === "arrow_open" ? "none" : k,
arrowheadStyle: "fill: #333",
cssCompiledStyles: this.getCompiledStyles(r.classes),
labelStyle: U,
style: U,
pattern: r.stroke,
look: i.look,
animate: r.animate,
animation: r.animation,
curve: r.interpolate || this.edges.defaultInterpolate || ((d = i.flowchart) == null ? void 0 : d.curve)
};
n.push(T);
}), { nodes: a, edges: n, other: {}, config: i };
}
defaultConfig() {
return re.flowchart;
}
}, m(P1, "FlowDB"), P1), pe = /* @__PURE__ */ m(function(s, i) {
return i.db.getClasses();
}, "getClasses"), fe = /* @__PURE__ */ m(async function(s, i, a, n) {
var U;
Z.info("REF0:"), Z.info("Drawing state diagram (v2)", i);
const { securityLevel: u, flowchart: l, layout: f } = G1();
let c;
u === "sandbox" && (c = C1("#i" + i));
const A = u === "sandbox" ? c.nodes()[0].contentDocument : document;
Z.debug("Before getData: ");
const r = n.db.getData();
Z.debug("Data: ", r);
const b = le(i, u), F = n.db.getDirection();
r.type = n.type, r.layoutAlgorithm = ae(f), r.layoutAlgorithm === "dagre" && f === "elk" && Z.warn(
"flowchart-elk was moved to an external package in Mermaid v11. Please refer [release notes](https://github.com/mermaid-js/mermaid/releases/tag/v11.0.0) for more details. This diagram will be rendered using `dagre` layout as a fallback."
), r.direction = F, r.nodeSpacing = (l == null ? void 0 : l.nodeSpacing) || 50, r.rankSpacing = (l == null ? void 0 : l.rankSpacing) || 50, r.markers = ["point", "circle", "cross"], r.diagramId = i, Z.debug("REF1:", r), await ne(r, b);
const k = ((U = r.config.flowchart) == null ? void 0 : U.diagramPadding) ?? 8;
it.insertTitle(
b,
"flowchartTitleText",
(l == null ? void 0 : l.titleTopMargin) || 0,
n.db.getDiagramTitle()
), oe(b, k, "flowchart", (l == null ? void 0 : l.useMaxWidth) || !1);
for (const T of r.nodes) {
const d = C1(`#${i} [id="${T.id}"]`);
if (!d || !T.link)
continue;
const K = A.createElementNS("http://www.w3.org/2000/svg", "a");
K.setAttributeNS("http://www.w3.org/2000/svg", "class", T.cssClasses), K.setAttributeNS("http://www.w3.org/2000/svg", "rel", "noopener"), u === "sandbox" ? K.setAttributeNS("http://www.w3.org/2000/svg", "target", "_top") : T.linkTarget && K.setAttributeNS("http://www.w3.org/2000/svg", "target", T.linkTarget);
const f1 = d.insert(function() {
return K;
}, ":first-child"), g1 = d.select(".label-container");
g1 && f1.append(function() {
return g1.node();
});
const b1 = d.select(".label");
b1 && f1.append(function() {
return b1.node();
});
}
}, "draw"), ge = {
getClasses: pe,
draw: fe
}, rt = function() {
var s = /* @__PURE__ */ m(function(p1, h, p, g) {
for (p = p || {}, g = p1.length; g--; p[p1[g]] = h) ;
return p;
}, "o"), i = [1, 4], a = [1, 3], n = [1, 5], u = [1, 8, 9, 10, 11, 27, 34, 36, 38, 44, 60, 84, 85, 86, 87, 88, 89, 102, 105, 106, 109, 111, 114, 115, 116, 121, 122, 123, 124], l = [2, 2], f = [1, 13], c = [1, 14], A = [1, 15], r = [1, 16], b = [1, 23], F = [1, 25], k = [1, 26], U = [1, 27], T = [1, 49], d = [1, 48], K = [1, 29], f1 = [1, 30], g1 = [1, 31], b1 = [1, 32], M1 = [1, 33], V = [1, 44], L = [1, 46], I = [1, 42], w = [1, 47], R = [1, 43], N = [1, 50], G = [1, 45], P = [1, 51], O = [1, 52], U1 = [1, 34], W1 = [1, 35], z1 = [1, 36], j1 = [1, 37], h1 = [1, 57], E = [1, 8, 9, 10, 11, 27, 32, 34, 36, 38, 44, 60, 84, 85, 86, 87, 88, 89, 102, 105, 106, 109, 111, 114, 115, 116, 121, 122, 123, 124], $ = [1, 61], t1 = [1, 60], e1 = [1, 62], S1 = [8, 9, 11, 75, 77, 78], at = [1, 78], D1 = [1, 91], x1 = [1, 96], T1 = [1, 95], E1 = [1, 92], y1 = [1, 88], F1 = [1, 94], _1 = [1, 90], B1 = [1, 97], v1 = [1, 93], V1 = [1, 98], L1 = [1, 89], A1 = [8, 9, 10, 11, 40, 75, 77, 78], W = [8, 9, 10, 11, 40, 46, 75, 77, 78], H = [8, 9, 10, 11, 29, 40, 44, 46, 48, 50, 52, 54, 56, 58, 60, 63, 65, 67, 68, 70, 75, 77, 78, 89, 102, 105, 106, 109, 111, 114, 115, 116], nt = [8, 9, 11, 44, 60, 75, 77, 78, 89, 102, 105, 106, 109, 111, 114, 115, 116], I1 = [44, 60, 89, 102, 105, 106, 109, 111, 114, 115, 116], ut = [1, 121], lt = [1, 122], K1 = [1, 124], Y1 = [1, 123], ot = [44, 60, 62, 74, 89, 102, 105, 106, 109, 111, 114, 115, 116], ct = [1, 133], ht = [1, 147], dt = [1, 148], pt = [1, 149], ft = [1, 150], gt = [1, 135], bt = [1, 137], At = [1, 141], kt = [1, 142], mt = [1, 143], Ct = [1, 144], St = [1, 145], Dt = [1, 146], xt = [1, 151], Tt = [1, 152], Et = [1, 131], yt = [1, 132], Ft = [1, 139], _t = [1, 134], Bt = [1, 138], vt = [1, 136], Q1 = [8, 9, 10, 11, 27, 32, 34, 36, 38, 44, 60, 84, 85, 86, 87, 88, 89, 102, 105, 106, 109, 111, 114, 115, 116, 121, 122, 123, 124], Vt = [1, 154], Lt = [1, 156], B = [8, 9, 11], q = [8, 9, 10, 11, 14, 44, 60, 89, 105, 106, 109, 111, 114, 115, 116], C = [1, 176], z = [1, 172], j = [1, 173], S = [1, 177], D = [1, 174], x = [1, 175], w1 = [77, 116, 119], y = [8, 9, 10, 11, 12, 14, 27, 29, 32, 44, 60, 75, 84, 85, 86, 87, 88, 89, 90, 105, 109, 111, 114, 115, 116], It = [10, 106], d1 = [31, 49, 51, 53, 55, 57, 62, 64, 66, 67, 69, 71, 116, 117, 118], s1 = [1, 247], i1 = [1, 245], r1 = [1, 249], a1 = [1, 243], n1 = [1, 244], u1 = [1, 246], l1 = [1, 248], o1 = [1, 250], R1 = [1, 268], wt = [8, 9, 11, 106], J = [8, 9, 10, 11, 60, 84, 105, 106, 109, 110, 111, 112], J1 = {
trace: /* @__PURE__ */ m(function() {
}, "trace"),
yy: {},
symbols_: { error: 2, start: 3, graphConfig: 4, document: 5, line: 6, statement: 7, SEMI: 8, NEWLINE: 9, SPACE: 10, EOF: 11, GRAPH: 12, NODIR: 13, DIR: 14, FirstStmtSeparator: 15, ending: 16, endToken: 17, spaceList: 18, spaceListNewline: 19, vertexStatement: 20, separator: 21, styleStatement: 22, linkStyleStatement: 23, classDefStatement: 24, classStatement: 25, clickStatement: 26, subgraph: 27, textNoTags: 28, SQS: 29, text: 30, SQE: 31, end: 32, direction: 33, acc_title: 34, acc_title_value: 35, acc_descr: 36, acc_descr_value: 37, acc_descr_multiline_value: 38, shapeData: 39, SHAPE_DATA: 40, link: 41, node: 42, styledVertex: 43, AMP: 44, vertex: 45, STYLE_SEPARATOR: 46, idString: 47, DOUBLECIRCLESTART: 48, DOUBLECIRCLEEND: 49, PS: 50, PE: 51, "(-": 52, "-)": 53, STADIUMSTART: 54, STADIUMEND: 55, SUBROUTINESTART: 56, SUBROUTINEEND: 57, VERTEX_WITH_PROPS_START: 58, "NODE_STRING[field]": 59, COLON: 60, "NODE_STRING[value]": 61, PIPE: 62, CYLINDERSTART: 63, CYLINDEREND: 64, DIAMOND_START: 65, DIAMOND_STOP: 66, TAGEND: 67, TRAPSTART: 68, TRAPEND: 69, INVTRAPSTART: 70, INVTRAPEND: 71, linkStatement: 72, arrowText: 73, TESTSTR: 74, START_LINK: 75, edgeText: 76, LINK: 77, LINK_ID: 78, edgeTextToken: 79, STR: 80, MD_STR: 81, textToken: 82, keywords: 83, STYLE: 84, LINKSTYLE: 85, CLASSDEF: 86, CLASS: 87, CLICK: 88, DOWN: 89, UP: 90, textNoTagsToken: 91, stylesOpt: 92, "idString[vertex]": 93, "idString[class]": 94, CALLBACKNAME: 95, CALLBACKARGS: 96, HREF: 97, LINK_TARGET: 98, "STR[link]": 99, "STR[tooltip]": 100, alphaNum: 101, DEFAULT: 102, numList: 103, INTERPOLATE: 104, NUM: 105, COMMA: 106, style: 107, styleComponent: 108, NODE_STRING: 109, UNIT: 110, BRKT: 111, PCT: 112, idStringToken: 113, MINUS: 114, MULT: 115, UNICODE_TEXT: 116, TEXT: 117, TAGSTART: 118, EDGE_TEXT: 119, alphaNumToken: 120, direction_tb: 121, direction_bt: 122, direction_rl: 123, direction_lr: 124, $accept: 0, $end: 1 },
terminals_: { 2: "error", 8: "SEMI", 9: "NEWLINE", 10: "SPACE", 11: "EOF", 12: "GRAPH", 13: "NODIR", 14: "DIR", 27: "subgraph", 29: "SQS", 31: "SQE", 32: "end", 34: "acc_title", 35: "acc_title_value", 36: "acc_descr", 37: "acc_descr_value", 38: "acc_descr_multiline_value", 40: "SHAPE_DATA", 44: "AMP", 46: "STYLE_SEPARATOR", 48: "DOUBLECIRCLESTART", 49: "DOUBLECIRCLEEND", 50: "PS", 51: "PE", 52: "(-", 53: "-)", 54: "STADIUMSTART", 55: "STADIUMEND", 56: "SUBROUTINESTART", 57: "SUBROUTINEEND", 58: "VERTEX_WITH_PROPS_START", 59: "NODE_STRING[field]", 60: "COLON", 61: "NODE_STRING[value]", 62: "PIPE", 63: "CYLINDERSTART", 64: "CYLINDEREND", 65: "DIAMOND_START", 66: "DIAMOND_STOP", 67: "TAGEND", 68: "TRAPSTART", 69: "TRAPEND", 70: "INVTRAPSTART", 71: "INVTRAPEND", 74: "TESTSTR", 75: "START_LINK", 77: "LINK", 78: "LINK_ID", 80: "STR", 81: "MD_STR", 84: "STYLE", 85: "LINKSTYLE", 86: "CLASSDEF", 87: "CLASS", 88: "CLICK", 89: "DOWN", 90: "UP", 93: "idString[vertex]", 94: "idString[class]", 95: "CALLBACKNAME", 96: "CALLBACKARGS", 97: "HREF", 98: "LINK_TARGET", 99: "STR[link]", 100: "STR[tooltip]", 102: "DEFAULT", 104: "INTERPOLATE", 105: "NUM", 106: "COMMA", 109: "NODE_STRING", 110: "UNIT", 111: "BRKT", 112: "PCT", 114: "MINUS", 115: "MULT", 116: "UNICODE_TEXT", 117: "TEXT", 118: "TAGSTART", 119: "EDGE_TEXT", 121: "direction_tb", 122: "direction_bt", 123: "direction_rl", 124: "direction_lr" },
productions_: [0, [3, 2], [5, 0], [5, 2], [6, 1], [6, 1], [6, 1], [6, 1], [6, 1], [4, 2], [4, 2], [4, 2], [4, 3], [16, 2], [16, 1], [17, 1], [17, 1], [17, 1], [15, 1], [15, 1], [15, 2], [19, 2], [19, 2], [19, 1], [19, 1], [18, 2], [18, 1], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [7, 2], [7, 9], [7, 6], [7, 4], [7, 1], [7, 2], [7, 2], [7, 1], [21, 1], [21, 1], [21, 1], [39, 2], [39, 1], [20, 4], [20, 3], [20, 4], [20, 2], [20, 2], [20, 1], [42, 1], [42, 6], [42, 5], [43, 1], [43, 3], [45, 4], [45, 4], [45, 6], [45, 4], [45, 4], [45, 4], [45, 8], [45, 4], [45, 4], [45, 4], [45, 6], [45, 4], [45, 4], [45, 4], [45, 4], [45, 4], [45, 1], [41, 2], [41, 3], [41, 3], [41, 1], [41, 3], [41, 4], [76, 1], [76, 2], [76, 1], [76, 1], [72, 1], [72, 2], [73, 3], [30, 1], [30, 2], [30, 1], [30, 1], [83, 1], [83, 1], [83, 1], [83, 1], [83, 1], [83, 1], [83, 1], [83, 1], [83, 1], [83, 1], [83, 1], [28, 1], [28, 2], [28, 1], [28, 1], [24, 5], [25, 5], [26, 2], [26, 4], [26, 3], [26, 5], [26, 3], [26, 5], [26, 5], [26, 7], [26, 2], [26, 4], [26, 2], [26, 4], [26, 4], [26, 6], [22, 5], [23, 5], [23, 5], [23, 9], [23, 9], [23, 7], [23, 7], [103, 1], [103, 3], [92, 1], [92, 3], [107, 1], [107, 2], [108, 1], [108, 1], [108, 1], [108, 1], [108, 1], [108, 1], [108, 1], [108, 1], [113, 1], [113, 1], [113, 1], [113, 1], [113, 1], [113, 1], [113, 1], [113, 1], [113, 1], [113, 1], [113, 1], [82, 1], [82, 1], [82, 1], [82, 1], [91, 1], [91, 1], [91, 1], [91, 1], [91, 1], [91, 1], [91, 1], [91, 1], [91, 1], [91, 1], [91, 1], [79, 1], [79, 1], [120, 1], [120, 1], [120, 1], [120, 1], [120, 1], [120, 1], [120, 1], [120, 1], [120, 1], [120, 1], [120, 1], [47, 1], [47, 2], [101, 1], [101, 2], [33, 1], [33, 1], [33, 1], [33, 1]],
performAction: /* @__PURE__ */ m(function(h, p, g, o, _, t, O1) {
var e = t.length - 1;
switch (_) {
case 2:
this.$ = [];
break;
case 3:
(!Array.isArray(t[e]) || t[e].length > 0) && t[e - 1].push(t[e]), this.$ = t[e - 1];
break;
case 4:
case 183:
this.$ = t[e];
break;
case 11:
o.setDirection("TB"), this.$ = "TB";
break;
case 12:
o.setDirection(t[e - 1]), this.$ = t[e - 1];
break;
case 27:
this.$ = t[e - 1].nodes;
break;
case 28:
case 29:
case 30:
case 31:
case 32:
this.$ = [];
break;
case 33:
this.$ = o.addSubGraph(t[e - 6], t[e - 1], t[e - 4]);
break;
case 34:
this.$ = o.addSubGraph(t[e - 3], t[e - 1], t[e - 3]);
break;
case 35:
this.$ = o.addSubGraph(void 0, t[e - 1], void 0);
break;
case 37:
this.$ = t[e].trim(), o.setAccTitle(this.$);
break;
case 38:
case 39:
this.$ = t[e].trim(), o.setAccDescription(this.$);
break;
case 43:
this.$ = t[e - 1] + t[e];
break;
case 44:
this.$ = t[e];
break;
case 45:
o.addVertex(t[e - 1][t[e - 1].length - 1], void 0, void 0, void 0, void 0, void 0, void 0, t[e]), o.addLink(t[e - 3].stmt, t[e - 1], t[e - 2]), this.$ = { stmt: t[e - 1], nodes: t[e - 1].concat(t[e - 3].nodes) };
break;
case 46:
o.addLink(t[e - 2].stmt, t[e], t[e - 1]), this.$ = { stmt: t[e], nodes: t[e].concat(t[e - 2].nodes) };
break;
case 47:
o.addLink(t[e - 3].stmt, t[e - 1], t[e - 2]), this.$ = { stmt: t[e - 1], nodes: t[e - 1].concat(t[e - 3].nodes) };
break;
case 48:
this.$ = { stmt: t[e - 1], nodes: t[e - 1] };
break;
case 49:
o.addVertex(t[e - 1][t[e - 1].length - 1], void 0, void 0, void 0, void 0, void 0, void 0, t[e]), this.$ = { stmt: t[e - 1], nodes: t[e - 1], shapeData: t[e] };
break;
case 50:
this.$ = { stmt: t[e], nodes: t[e] };
break;
case 51:
this.$ = [t[e]];
break;
case 52:
o.addVertex(t[e - 5][t[e - 5].length - 1], void 0, void 0, void 0, void 0, void 0, void 0, t[e - 4]), this.$ = t[e - 5].concat(t[e]);
break;
case 53:
this.$ = t[e - 4].concat(t[e]);
break;
case 54:
this.$ = t[e];
break;
case 55:
this.$ = t[e - 2], o.setClass(t[e - 2], t[e]);
break;
case 56:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "square");
break;
case 57:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "doublecircle");
break;
case 58:
this.$ = t[e - 5], o.addVertex(t[e - 5], t[e - 2], "circle");
break;
case 59:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "ellipse");
break;
case 60:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "stadium");
break;
case 61:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "subroutine");
break;
case 62:
this.$ = t[e - 7], o.addVertex(t[e - 7], t[e - 1], "rect", void 0, void 0, void 0, Object.fromEntries([[t[e - 5], t[e - 3]]]));
break;
case 63:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "cylinder");
break;
case 64:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "round");
break;
case 65:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "diamond");
break;
case 66:
this.$ = t[e - 5], o.addVertex(t[e - 5], t[e - 2], "hexagon");
break;
case 67:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "odd");
break;
case 68:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "trapezoid");
break;
case 69:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "inv_trapezoid");
break;
case 70:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "lean_right");
break;
case 71:
this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "lean_left");
break;
case 72:
this.$ = t[e], o.addVertex(t[e]);
break;
case 73:
t[e - 1].text = t[e], this.$ = t[e - 1];
break;
case 74:
case 75:
t[e - 2].text = t[e - 1], this.$ = t[e - 2];
break;
case 76:
this.$ = t[e];
break;
case 77:
var v = o.destructLink(t[e], t[e - 2]);
this.$ = { type: v.type, stroke: v.stroke, length: v.length, text: t[e - 1] };
break;
case 78:
var v = o.destructLink(t[e], t[e - 2]);
this.$ = { type: v.type, stroke: v.stroke, length: v.length, text: t[e - 1], id: t[e - 3] };
break;
case 79:
this.$ = { text: t[e], type: "text" };
break;
case 80:
this.$ = { text: t[e - 1].text + "" + t[e], type: t[e - 1].type };
break;
case 81:
this.$ = { text: t[e], type: "string" };
break;
case 82:
this.$ = { text: t[e], type: "markdown" };
break;
case 83:
var v = o.destructLink(t[e]);
this.$ = { type: v.type, stroke: v.stroke, length: v.length };
break;
case 84:
var v = o.destructLink(t[e]);
this.$ = { type: v.type, stroke: v.stroke, length: v.length, id: t[e - 1] };
break;
case 85:
this.$ = t[e - 1];
break;
case 86:
this.$ = { text: t[e], type: "text" };
break;
case 87:
this.$ = { text: t[e - 1].text + "" + t[e], type: t[e - 1].type };
break;
case 88:
this.$ = { text: t[e], type: "string" };
break;
case 89:
case 104:
this.$ = { text: t[e], type: "markdown" };
break;
case 101:
this.$ = { text: t[e], type: "text" };
break;
case 102:
this.$ = { text: t[e - 1].text + "" + t[e], type: t[e - 1].type };
break;
case 103:
this.$ = { text: t[e], type: "text" };
break;
case 105:
this.$ = t[e - 4], o.addClass(t[e - 2], t[e]);
break;
case 106:
this.$ = t[e - 4], o.setClass(t[e - 2], t[e]);
break;
case 107:
case 115:
this.$ = t[e - 1], o.setClickEvent(t[e - 1], t[e]);
break;
case 108:
case 116:
this.$ = t[e - 3], o.setClickEvent(t[e - 3], t[e - 2]), o.setTooltip(t[e - 3], t[e]);
break;
case 109:
this.$ = t[e - 2], o.setClickEvent(t[e - 2], t[e - 1], t[e]);
break;
case 110:
this.$ = t[e - 4], o.setClickEvent(t[e - 4], t[e - 3], t[e - 2]), o.setTooltip(t[e - 4], t[e]);
break;
case 111:
this.$ = t[e - 2], o.setLink(t[e - 2], t[e]);
break;
case 112:
this.$ = t[e - 4], o.setLink(t[e - 4], t[e - 2]), o.setTooltip(t[e - 4], t[e]);
break;
case 113:
this.$ = t[e - 4], o.setLink(t[e - 4], t[e - 2], t[e]);
break;
case 114:
this.$ = t[e - 6], o.setLink(t[e - 6], t[e - 4], t[e]), o.setTooltip(t[e - 6], t[e - 2]);
break;
case 117:
this.$ = t[e - 1], o.setLink(t[e - 1], t[e]);
break;
case 118:
this.$ = t[e - 3], o.setLink(t[e - 3], t[e - 2]), o.setTooltip(t[e - 3], t[e]);
break;
case 119:
this.$ = t[e - 3], o.setLink(t[e - 3], t[e - 2], t[e]);
break;
case 120:
this.$ = t[e - 5], o.setLink(t[e - 5], t[e - 4], t[e]), o.setTooltip(t[e - 5], t[e - 2]);
break;
case 121:
this.$ = t[e - 4], o.addVertex(t[e - 2], void 0, void 0, t[e]);
break;
case 122:
this.$ = t[e - 4], o.updateLink([t[e - 2]], t[e]);
break;
case 123:
this.$ = t[e - 4], o.updateLink(t[e - 2], t[e]);
break;
case 124:
this.$ = t[e - 8], o.updateLinkInterpolate([t[e - 6]], t[e - 2]), o.updateLink([t[e - 6]], t[e]);
break;
case 125:
this.$ = t[e - 8], o.updateLinkInterpolate(t[e - 6], t[e - 2]), o.updateLink(t[e - 6], t[e]);
break;
case 126:
this.$ = t[e - 6], o.updateLinkInterpolate([t[e - 4]], t[e]);
break;
case 127:
this.$ = t[e - 6], o.updateLinkInterpolate(t[e - 4], t[e]);
break;
case 128:
case 130:
this.$ = [t[e]];
break;
case 129:
case 131:
t[e - 2].push(t[e]), this.$ = t[e - 2];
break;
case 133:
this.$ = t[e - 1] + t[e];
break;
case 181:
this.$ = t[e];
break;
case 182:
this.$ = t[e - 1] + "" + t[e];
break;
case 184:
this.$ = t[e - 1] + "" + t[e];
break;
case 185:
this.$ = { stmt: "dir", value: "TB" };
break;
case 186:
this.$ = { stmt: "dir", value: "BT" };
break;
case 187:
this.$ = { stmt: "dir", value: "RL" };
break;
case 188:
this.$ = { stmt: "dir", value: "LR" };
break;
}
}, "anonymous"),
table: [{ 3: 1, 4: 2, 9: i, 10: a, 12: n }, { 1: [3] }, s(u, l, { 5: 6 }), { 4: 7, 9: i, 10: a, 12: n }, { 4: 8, 9: i, 10: a, 12: n }, { 13: [1, 9], 14: [1, 10] }, { 1: [2, 1], 6: 11, 7: 12, 8: f, 9: c, 10: A, 11: r, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: b, 33: 24, 34: F, 36: k, 38: U, 42: 28, 43: 38, 44: T, 45: 39, 47: 40, 60: d, 84: K, 85: f1, 86: g1, 87: b1, 88: M1, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O, 121: U1, 122: W1, 123: z1, 124: j1 }, s(u, [2, 9]), s(u, [2, 10]), s(u, [2, 11]), { 8: [1, 54], 9: [1, 55], 10: h1, 15: 53, 18: 56 }, s(E, [2, 3]), s(E, [2, 4]), s(E, [2, 5]), s(E, [2, 6]), s(E, [2, 7]), s(E, [2, 8]), { 8: $, 9: t1, 11: e1, 21: 58, 41: 59, 72: 63, 75: [1, 64], 77: [1, 66], 78: [1, 65] }, { 8: $, 9: t1, 11: e1, 21: 67 }, { 8: $, 9: t1, 11: e1, 21: 68 }, { 8: $, 9: t1, 11: e1, 21: 69 }, { 8: $, 9: t1, 11: e1, 21: 70 }, { 8: $, 9: t1, 11: e1, 21: 71 }, { 8: $, 9: t1, 10: [1, 72], 11: e1, 21: 73 }, s(E, [2, 36]), { 35: [1, 74] }, { 37: [1, 75] }, s(E, [2, 39]), s(S1, [2, 50], { 18: 76, 39: 77, 10: h1, 40: at }), { 10: [1, 79] }, { 10: [1, 80] }, { 10: [1, 81] }, { 10: [1, 82] }, { 14: D1, 44: x1, 60: T1, 80: [1, 86], 89: E1, 95: [1, 83], 97: [1, 84], 101: 85, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: V1, 116: L1, 120: 87 }, s(E, [2, 185]), s(E, [2, 186]), s(E, [2, 187]), s(E, [2, 188]), s(A1, [2, 51]), s(A1, [2, 54], { 46: [1, 99] }), s(W, [2, 72], { 113: 112, 29: [1, 100], 44: T, 48: [1, 101], 50: [1, 102], 52: [1, 103], 54: [1, 104], 56: [1, 105], 58: [1, 106], 60: d, 63: [1, 107], 65: [1, 108], 67: [1, 109], 68: [1, 110], 70: [1, 111], 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 114: G, 115: P, 116: O }), s(H, [2, 181]), s(H, [2, 142]), s(H, [2, 143]), s(H, [2, 144]), s(H, [2, 145]), s(H, [2, 146]), s(H, [2, 147]), s(H, [2, 148]), s(H, [2, 149]), s(H, [2, 150]), s(H, [2, 151]), s(H, [2, 152]), s(u, [2, 12]), s(u, [2, 18]), s(u, [2, 19]), { 9: [1, 113] }, s(nt, [2, 26], { 18: 114, 10: h1 }), s(E, [2, 27]), { 42: 115, 43: 38, 44: T, 45: 39, 47: 40, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, s(E, [2, 40]), s(E, [2, 41]), s(E, [2, 42]), s(I1, [2, 76], { 73: 116, 62: [1, 118], 74: [1, 117] }), { 76: 119, 79: 120, 80: ut, 81: lt, 116: K1, 119: Y1 }, { 75: [1, 125], 77: [1, 126] }, s(ot, [2, 83]), s(E, [2, 28]), s(E, [2, 29]), s(E, [2, 30]), s(E, [2, 31]), s(E, [2, 32]), { 10: ct, 12: ht, 14: dt, 27: pt, 28: 127, 32: ft, 44: gt, 60: bt, 75: At, 80: [1, 129], 81: [1, 130], 83: 140, 84: kt, 85: mt, 86: Ct, 87: St, 88: Dt, 89: xt, 90: Tt, 91: 128, 105: Et, 109: yt, 111: Ft, 114: _t, 115: Bt, 116: vt }, s(Q1, l, { 5: 153 }), s(E, [2, 37]), s(E, [2, 38]), s(S1, [2, 48], { 44: Vt }), s(S1, [2, 49], { 18: 155, 10: h1, 40: Lt }), s(A1, [2, 44]), { 44: T, 47: 157, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, { 102: [1, 158], 103: 159, 105: [1, 160] }, { 44: T, 47: 161, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, { 44: T, 47: 162, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, s(B, [2, 107], { 10: [1, 163], 96: [1, 164] }), { 80: [1, 165] }, s(B, [2, 115], { 120: 167, 10: [1, 166], 14: D1, 44: x1, 60: T1, 89: E1, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: V1, 116: L1 }), s(B, [2, 117], { 10: [1, 168] }), s(q, [2, 183]), s(q, [2, 170]), s(q, [2, 171]), s(q, [2, 172]), s(q, [2, 173]), s(q, [2, 174]), s(q, [2, 175]), s(q, [2, 176]), s(q, [2, 177]), s(q, [2, 178]), s(q, [2, 179]), s(q, [2, 180]), { 44: T, 47: 169, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, { 30: 170, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 178, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 180, 50: [1, 179], 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 181, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 182, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 183, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 109: [1, 184] }, { 30: 185, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 186, 65: [1, 187], 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 188, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 189, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 30: 190, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, s(H, [2, 182]), s(u, [2, 20]), s(nt, [2, 25]), s(S1, [2, 46], { 39: 191, 18: 192, 10: h1, 40: at }), s(I1, [2, 73], { 10: [1, 193] }), { 10: [1, 194] }, { 30: 195, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 77: [1, 196], 79: 197, 116: K1, 119: Y1 }, s(w1, [2, 79]), s(w1, [2, 81]), s(w1, [2, 82]), s(w1, [2, 168]), s(w1, [2, 169]), { 76: 198, 79: 120, 80: ut, 81: lt, 116: K1, 119: Y1 }, s(ot, [2, 84]), { 8: $, 9: t1, 10: ct, 11: e1, 12: ht, 14: dt, 21: 200, 27: pt, 29: [1, 199], 32: ft, 44: gt, 60: bt, 75: At, 83: 140, 84: kt, 85: mt, 86: Ct, 87: St, 88: Dt, 89: xt, 90: Tt, 91: 201, 105: Et, 109: yt, 111: Ft, 114: _t, 115: Bt, 116: vt }, s(y, [2, 101]), s(y, [2, 103]), s(y, [2, 104]), s(y, [2, 157]), s(y, [2, 158]), s(y, [2, 159]), s(y, [2, 160]), s(y, [2, 161]), s(y, [2, 162]), s(y, [2, 163]), s(y, [2, 164]), s(y, [2, 165]), s(y, [2, 166]), s(y, [2, 167]), s(y, [2, 90]), s(y, [2, 91]), s(y, [2, 92]), s(y, [2, 93]), s(y, [2, 94]), s(y, [2, 95]), s(y, [2, 96]), s(y, [2, 97]), s(y, [2, 98]), s(y, [2, 99]), s(y, [2, 100]), { 6: 11, 7: 12, 8: f, 9: c, 10: A, 11: r, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: b, 32: [1, 202], 33: 24, 34: F, 36: k, 38: U, 42: 28, 43: 38, 44: T, 45: 39, 47: 40, 60: d, 84: K, 85: f1, 86: g1, 87: b1, 88: M1, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O, 121: U1, 122: W1, 123: z1, 124: j1 }, { 10: h1, 18: 203 }, { 44: [1, 204] }, s(A1, [2, 43]), { 10: [1, 205], 44: T, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 112, 114: G, 115: P, 116: O }, { 10: [1, 206] }, { 10: [1, 207], 106: [1, 208] }, s(It, [2, 128]), { 10: [1, 209], 44: T, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 112, 114: G, 115: P, 116: O }, { 10: [1, 210], 44: T, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 112, 114: G, 115: P, 116: O }, { 80: [1, 211] }, s(B, [2, 109], { 10: [1, 212] }), s(B, [2, 111], { 10: [1, 213] }), { 80: [1, 214] }, s(q, [2, 184]), { 80: [1, 215], 98: [1, 216] }, s(A1, [2, 55], { 113: 112, 44: T, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 114: G, 115: P, 116: O }), { 31: [1, 217], 67: C, 82: 218, 116: S, 117: D, 118: x }, s(d1, [2, 86]), s(d1, [2, 88]), s(d1, [2, 89]), s(d1, [2, 153]), s(d1, [2, 154]), s(d1, [2, 155]), s(d1, [2, 156]), { 49: [1, 219], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 30: 220, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 51: [1, 221], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 53: [1, 222], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 55: [1, 223], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 57: [1, 224], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 60: [1, 225] }, { 64: [1, 226], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 66: [1, 227], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 30: 228, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, { 31: [1, 229], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 67: C, 69: [1, 230], 71: [1, 231], 82: 218, 116: S, 117: D, 118: x }, { 67: C, 69: [1, 233], 71: [1, 232], 82: 218, 116: S, 117: D, 118: x }, s(S1, [2, 45], { 18: 155, 10: h1, 40: Lt }), s(S1, [2, 47], { 44: Vt }), s(I1, [2, 75]), s(I1, [2, 74]), { 62: [1, 234], 67: C, 82: 218, 116: S, 117: D, 118: x }, s(I1, [2, 77]), s(w1, [2, 80]), { 77: [1, 235], 79: 197, 116: K1, 119: Y1 }, { 30: 236, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, s(Q1, l, { 5: 237 }), s(y, [2, 102]), s(E, [2, 35]), { 43: 238, 44: T, 45: 39, 47: 40, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, { 10: h1, 18: 239 }, { 10: s1, 60: i1, 84: r1, 92: 240, 105: a1, 107: 241, 108: 242, 109: n1, 110: u1, 111: l1, 112: o1 }, { 10: s1, 60: i1, 84: r1, 92: 251, 104: [1, 252], 105: a1, 107: 241, 108: 242, 109: n1, 110: u1, 111: l1, 112: o1 }, { 10: s1, 60: i1, 84: r1, 92: 253, 104: [1, 254], 105: a1, 107: 241, 108: 242, 109: n1, 110: u1, 111: l1, 112: o1 }, { 105: [1, 255] }, { 10: s1, 60: i1, 84: r1, 92: 256, 105: a1, 107: 241, 108: 242, 109: n1, 110: u1, 111: l1, 112: o1 }, { 44: T, 47: 257, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, s(B, [2, 108]), { 80: [1, 258] }, { 80: [1, 259], 98: [1, 260] }, s(B, [2, 116]), s(B, [2, 118], { 10: [1, 261] }), s(B, [2, 119]), s(W, [2, 56]), s(d1, [2, 87]), s(W, [2, 57]), { 51: [1, 262], 67: C, 82: 218, 116: S, 117: D, 118: x }, s(W, [2, 64]), s(W, [2, 59]), s(W, [2, 60]), s(W, [2, 61]), { 109: [1, 263] }, s(W, [2, 63]), s(W, [2, 65]), { 66: [1, 264], 67: C, 82: 218, 116: S, 117: D, 118: x }, s(W, [2, 67]), s(W, [2, 68]), s(W, [2, 70]), s(W, [2, 69]), s(W, [2, 71]), s([10, 44, 60, 89, 102, 105, 106, 109, 111, 114, 115, 116], [2, 85]), s(I1, [2, 78]), { 31: [1, 265], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 6: 11, 7: 12, 8: f, 9: c, 10: A, 11: r, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: b, 32: [1, 266], 33: 24, 34: F, 36: k, 38: U, 42: 28, 43: 38, 44: T, 45: 39, 47: 40, 60: d, 84: K, 85: f1, 86: g1, 87: b1, 88: M1, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O, 121: U1, 122: W1, 123: z1, 124: j1 }, s(A1, [2, 53]), { 43: 267, 44: T, 45: 39, 47: 40, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O }, s(B, [2, 121], { 106: R1 }), s(wt, [2, 130], { 108: 269, 10: s1, 60: i1, 84: r1, 105: a1, 109: n1, 110: u1, 111: l1, 112: o1 }), s(J, [2, 132]), s(J, [2, 134]), s(J, [2, 135]), s(J, [2, 136]), s(J, [2, 137]), s(J, [2, 138]), s(J, [2, 139]), s(J, [2, 140]), s(J, [2, 141]), s(B, [2, 122], { 106: R1 }), { 10: [1, 270] }, s(B, [2, 123], { 106: R1 }), { 10: [1, 271] }, s(It, [2, 129]), s(B, [2, 105], { 106: R1 }), s(B, [2, 106], { 113: 112, 44: T, 60: d, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 114: G, 115: P, 116: O }), s(B, [2, 110]), s(B, [2, 112], { 10: [1, 272] }), s(B, [2, 113]), { 98: [1, 273] }, { 51: [1, 274] }, { 62: [1, 275] }, { 66: [1, 276] }, { 8: $, 9: t1, 11: e1, 21: 277 }, s(E, [2, 34]), s(A1, [2, 52]), { 10: s1, 60: i1, 84: r1, 105: a1, 107: 278, 108: 242, 109: n1, 110: u1, 111: l1, 112: o1 }, s(J, [2, 133]), { 14: D1, 44: x1, 60: T1, 89: E1, 101: 279, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: V1, 116: L1, 120: 87 }, { 14: D1, 44: x1, 60: T1, 89: E1, 101: 280, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: V1, 116: L1, 120: 87 }, { 98: [1, 281] }, s(B, [2, 120]), s(W, [2, 58]), { 30: 282, 67: C, 80: z, 81: j, 82: 171, 116: S, 117: D, 118: x }, s(W, [2, 66]), s(Q1, l, { 5: 283 }), s(wt, [2, 131], { 108: 269, 10: s1, 60: i1, 84: r1, 105: a1, 109: n1, 110: u1, 111: l1, 112: o1 }), s(B, [2, 126], { 120: 167, 10: [1, 284], 14: D1, 44: x1, 60: T1, 89: E1, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: V1, 116: L1 }), s(B, [2, 127], { 120: 167, 10: [1, 285], 14: D1, 44: x1, 60: T1, 89: E1, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: V1, 116: L1 }), s(B, [2, 114]), { 31: [1, 286], 67: C, 82: 218, 116: S, 117: D, 118: x }, { 6: 11, 7: 12, 8: f, 9: c, 10: A, 11: r, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: b, 32: [1, 287], 33: 24, 34: F, 36: k, 38: U, 42: 28, 43: 38, 44: T, 45: 39, 47: 40, 60: d, 84: K, 85: f1, 86: g1, 87: b1, 88: M1, 89: V, 102: L, 105: I, 106: w, 109: R, 111: N, 113: 41, 114: G, 115: P, 116: O, 121: U1, 122: W1, 123: z1, 124: j1 }, { 10: s1, 60: i1, 84: r1, 92: 288, 105: a1, 107: 241, 108: 242, 109: n1, 110: u1, 111: l1, 112: o1 }, { 10: s1, 60: i1, 84: r1, 92: 289, 105: a1, 107: 241, 108: 242, 109: n1, 110: u1, 111: l1, 112: o1 }, s(W, [2, 62]), s(E, [2, 33]), s(B, [2, 124], { 106: R1 }), s(B, [2, 125], { 106: R1 })],
defaultActions: {},
parseError: /* @__PURE__ */ m(function(h, p) {
if (p.recoverable)
this.trace(h);
else {
var g = new Error(h);
throw g.hash = p, g;
}
}, "parseError"),
parse: /* @__PURE__ */ m(function(h) {
var p = this, g = [0], o = [], _ = [null], t = [], O1 = this.table, e = "", v = 0, Rt = 0, zt = 2, Nt = 1, jt = t.slice.call(arguments, 1), M = Object.create(this.lexer), k1 = { yy: {} };
for (var Z1 in this.yy)
Object.prototype.hasOwnProperty.call(this.yy, Z1) && (k1.yy[Z1] = this.yy[Z1]);
M.setInput(h, k1.yy), k1.yy.lexer = M, k1.yy.parser = this, typeof M.yylloc > "u" && (M.yylloc = {});
var $1 = M.yylloc;
t.push($1);
var Kt = M.options && M.options.ranges;
typeof k1.yy.parseError == "function" ? this.parseError = k1.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError;
function Yt(X) {
g.length = g.length - 2 * X, _.length = _.length - X, t.length = t.length - X;
}
m(Yt, "popStack");
function Gt() {
var X;
return X = o.pop() || M.lex() || Nt, typeof X != "number" && (X instanceof Array && (o = X, X = o.pop()), X = p.symbols_[X] || X), X;
}
m(Gt, "lex");
for (var Y, m1, Q, tt, N1 = {}, q1, c1, Pt, X1; ; ) {
if (m1 = g[g.length - 1], this.defaultActions[m1] ? Q = this.defaultActions[m1] : ((Y === null || typeof Y > "u") && (Y = Gt()), Q = O1[m1] && O1[m1][Y]), typeof Q > "u" || !Q.length || !Q[0]) {
var et = "";
X1 = [];
for (q1 in O1[m1])
this.terminals_[q1] && q1 > zt && X1.push("'" + this.terminals_[q1] + "'");
M.showPosition ? et = "Parse error on line " + (v + 1) + `:
` + M.showPosition() + `
Expecting ` + X1.join(", ") + ", got '" + (this.terminals_[Y] || Y) + "'" : et = "Parse error on line " + (v + 1) + ": Unexpected " + (Y == Nt ? "end of input" : "'" + (this.terminals_[Y] || Y) + "'"), this.parseError(et, {
text: M.match,
token: this.terminals_[Y] || Y,
line: M.yylineno,
loc: $1,
expected: X1
});
}
if (Q[0] instanceof Array && Q.length > 1)
throw new Error("Parse Error: multiple actions possible at state: " + m1 + ", token: " + Y);
switch (Q[0]) {
case 1:
g.push(Y), _.push(M.yytext), t.push(M.yylloc), g.push(Q[1]), Y = null, Rt = M.yyleng, e = M.yytext, v = M.yylineno, $1 = M.yylloc;
break;
case 2:
if (c1 = this.productions_[Q[1]][1], N1.$ = _[_.length - c1], N1._$ = {
first_line: t[t.length - (c1 || 1)].first_line,
last_line: t[t.length - 1].last_line,
first_column: t[t.length - (c1 || 1)].first_column,
last_column: t[t.length - 1].last_column
}, Kt && (N1._$.range = [
t[t.length - (c1 || 1)].range[0],
t[t.length - 1].range[1]
]), tt = this.performAction.apply(N1, [
e,
Rt,
v,
k1.yy,
Q[1],
_,
t
].concat(jt)), typeof tt < "u")
return tt;
c1 && (g = g.slice(0, -1 * c1 * 2), _ = _.slice(0, -1 * c1), t = t.slice(0, -1 * c1)), g.push(this.productions_[Q[1]][0]), _.push(N1.$), t.push(N1._$), Pt = O1[g[g.length - 2]][g[g.length - 1]], g.push(Pt);
break;
case 3:
return !0;
}
}
return !0;
}, "parse")
}, Wt = /* @__PURE__ */ function() {
var p1 = {
EOF: 1,
parseError: /* @__PURE__ */ m(function(p, g) {
if (this.yy.parser)
this.yy.parser.parseError(p, g);
else
throw new Error(p);
}, "parseError"),
// resets the lexer, sets new input
setInput: /* @__PURE__ */ m(function(h, p) {
return this.yy = p || this.yy || {}, this._input = h, this._more = this._backtrack = this.done = !1, this.yylineno = this.yyleng = 0, this.yytext = this.matched = this.match = "", this.conditionStack = ["INITIAL"], this.yylloc = {
first_line: 1,
first_column: 0,
last_line: 1,
last_column: 0
}, this.options.ranges && (this.yylloc.range = [0, 0]), this.offset = 0, this;
}, "setInput"),
// consumes and returns one char from the input
input: /* @__PURE__ */ m(function() {
var h = this._input[0];
this.yytext += h, this.yyleng++, this.offset++, this.match += h, this.matched += h;
var p = h.match(/(?:\r\n?|\n).*/g);
return p ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), h;
}, "input"),
// unshifts one char (or a string) into the input
unput: /* @__PURE__ */ m(function(h) {
var p = h.length, g = h.split(/(?:\r\n?|\n)/g);
this._input = h + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - p), this.offset -= p;
var o = this.match.split(/(?:\r\n?|\n)/g);
this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), g.length - 1 && (this.yylineno -= g.length - 1);
var _ = this.yylloc.range;
return this.yylloc = {
first_line: this.yylloc.first_line,
last_line: this.yylineno + 1,
first_column: this.yylloc.first_column,
last_column: g ? (g.length === o.length ? this.yylloc.first_column : 0) + o[o.length - g.length].length - g[0].length : this.yylloc.first_column - p
}, this.options.ranges && (this.yylloc.range = [_[0], _[0] + this.yyleng - p]), this.yyleng = this.yytext.length, this;
}, "unput"),
// When called from action, caches matched text and appends it on next action
more: /* @__PURE__ */ m(function() {
return this._more = !0, this;
}, "more"),
// When called from action, signals the lexer that this rule fails to match the input, so the next matching rule (regex) should be tested instead.
reject: /* @__PURE__ */ m(function() {
if (this.options.backtrack_lexer)
this._backtrack = !0;
else
return this.parseError("Lexical error on line " + (this.yylineno + 1) + `. You can only invoke reject() in the lexer when the lexer is of the backtracking persuasion (options.backtrack_lexer = true).
` + this.showPosition(), {
text: "",
token: null,
line: this.yylineno
});
return this;
}, "reject"),
// retain first n characters of the match
less: /* @__PURE__ */ m(function(h) {
this.unput(this.match.slice(h));
}, "less"),
// displays already matched input, i.e. for error messages
pastInput: /* @__PURE__ */ m(function() {
var h = this.matched.substr(0, this.matched.length - this.match.length);
return (h.length > 20 ? "..." : "") + h.substr(-20).replace(/\n/g, "");
}, "pastInput"),
// displays upcoming input, i.e. for error messages
upcomingInput: /* @__PURE__ */ m(function() {
var h = this.match;
return h.length < 20 && (h += this._input.substr(0, 20 - h.length)), (h.substr(0, 20) + (h.length > 20 ? "..." : "")).replace(/\n/g, "");
}, "upcomingInput"),
// displays the character position where the lexing error occurred, i.e. for error messages
showPosition: /* @__PURE__ */ m(function() {
var h = this.pastInput(), p = new Array(h.length + 1).join("-");
return h + this.upcomingInput() + `
` + p + "^";
}, "showPosition"),
// test the lexed token: return FALSE when not a match, otherwise return token
test_match: /* @__PURE__ */ m(function(h, p) {
var g, o, _;
if (this.options.backtrack_lexer && (_ = {
yylineno: this.yylineno,
yylloc: {
first_line: this.yylloc.first_line,
last_line: this.last_line,
first_column: this.yylloc.first_column,
last_column: this.yylloc.last_column
},
yytext: this.yytext,
match: this.match,
matches: this.matches,
matched: this.matched,
yyleng: this.yyleng,
offset: this.offset,
_more: this._more,
_input: this._input,
yy: this.yy,
conditionStack: this.conditionStack.slice(0),
done: this.done
}, this.options.ranges && (_.yylloc.range = this.yylloc.range.slice(0))), o = h[0].match(/(?:\r\n?|\n).*/g), o && (this.yylineno += o.length), this.yylloc = {
first_line: this.yylloc.last_line,
last_line: this.yylineno + 1,
first_column: this.yylloc.last_column,
last_column: o ? o[o.length - 1].length - o[o.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + h[0].length
}, this.yytext += h[0], this.match += h[0], this.matches = h, this.yyleng = this.yytext.length, this.options.ranges && (this.yylloc.range = [this.offset, this.offset += this.yyleng]), this._more = !1, this._backtrack = !1, this._input = this._input.slice(h[0].length), this.matched += h[0], g = this.performAction.call(this, this.yy, this, p, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), g)
return g;
if (this._backtrack) {
for (var t in _)
this[t] = _[t];
return !1;
}
return !1;
}, "test_match"),
// return next match in input
next: /* @__PURE__ */ m(function() {
if (this.done)
return this.EOF;
this._input || (this.done = !0);
var h, p, g, o;
this._more || (this.yytext = "", this.match = "");
for (var _ = this._currentRules(), t = 0; t < _.length; t++)
if (g = this._input.match(this.rules[_[t]]), g && (!p || g[0].length > p[0].length)) {
if (p = g, o = t, this.options.backtrack_lexer) {
if (h = this.test_match(g, _[t]), h !== !1)
return h;
if (this._backtrack) {
p = !1;
continue;
} else
return !1;
} else if (!this.options.flex)
break;
}
return p ? (h = this.test_match(p, _[o]), h !== !1 ? h : !1) : this._input === "" ? this.EOF : this.parseError("Lexical error on line " + (this.yylineno + 1) + `. Unrecognized text.
` + this.showPosition(), {
text: "",
token: null,
line: this.yylineno
});
}, "next"),
// return next match that has a token
lex: /* @__PURE__ */ m(function() {
var p = this.next();
return p || this.lex();
}, "lex"),
// activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)
begin: /* @__PURE__ */ m(function(p) {
this.conditionStack.push(p);
}, "begin"),
// pop the previously active lexer condition state off the condition stack
popState: /* @__PURE__ */ m(function() {
var p = this.conditionStack.length - 1;
return p > 0 ? this.conditionStack.pop() : this.conditionStack[0];
}, "popState"),
// produce the lexer rule set which is active for the currently active lexer condition state
_currentRules: /* @__PURE__ */ m(function() {
return this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1] ? this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules : this.conditions.INITIAL.rules;
}, "_currentRules"),
// return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available
topState: /* @__PURE__ */ m(function(p) {
return p = this.conditionStack.length - 1 - Math.abs(p || 0), p >= 0 ? this.conditionStack[p] : "INITIAL";
}, "topState"),
// alias for begin(condition)
pushState: /* @__PURE__ */ m(function(p) {
this.begin(p);
}, "pushState"),
// return the number of states currently on the stack
stateStackSize: /* @__PURE__ */ m(function() {
return this.conditionStack.length;
}, "stateStackSize"),
options: {},
performAction: /* @__PURE__ */ m(function(p, g, o, _) {
switch (o) {
case 0:
return this.begin("acc_title"), 34;
case 1:
return this.popState(), "acc_title_value";
case 2:
return this.begin("acc_descr"), 36;
case 3:
return this.popState(), "acc_descr_value";
case 4:
this.begin("acc_descr_multiline");
break;
case 5:
this.popState();
break;
case 6:
return "acc_descr_multiline_value";
case 7:
return this.pushState("shapeData"), g.yytext = "", 40;
case 8:
return this.pushState("shapeDataStr"), 40;
case 9:
return this.popState(), 40;
case 10:
const t = /\n\s*/g;
return g.yytext = g.yytext.replace(t, "<br/>"), 40;
case 11:
return 40;
case 12:
this.popState();
break;
case 13:
this.begin("callbackname");
break;
case 14:
this.popState();
break;
case 15:
this.popState(), this.begin("callbackargs");
break;
case 16:
return 95;
case 17:
this.popState();
break;
case 18:
return 96;
case 19:
return "MD_STR";
case 20:
this.popState();
break;
case 21:
this.begin("md_string");
break;
case 22:
return "STR";
case 23:
this.popState();
break;
case 24:
this.pushState("string");
break;
case 25:
return 84;
case 26:
return 102;
case 27:
return 85;
case 28:
return 104;
case 29:
return 86;
case 30:
return 87;
case 31:
return 97;
case 32:
this.begin("click");
break;
case 33:
this.popState();
break;
case 34:
return 88;
case 35:
return p.lex.firstGraph() && this.begin("dir"), 12;
case 36:
return p.lex.firstGraph() && this.begin("dir"), 12;
case 37:
return p.lex.firstGraph() && this.begin("dir"), 12;
case 38:
return 27;
case 39:
return 32;
case 40:
return 98;
case 41:
return 98;
case 42:
return 98;
case 43:
return 98;
case 44:
return this.popState(), 13;
case 45:
return this.popState(), 14;
case 46:
return this.popState(), 14;
case 47:
return this.popState(), 14;
case 48:
return this.popState(), 14;
case 49:
return this.popState(), 14;
case 50:
return this.popState(), 14;
case 51:
return this.popState(), 14;
case 52:
return this.popState(), 14;
case 53:
return this.popState(), 14;
case 54:
return this.popState(), 14;
case 55:
return 121;
case 56:
return 122;
case 57:
return 123;
case 58:
return 124;
case 59:
return 78;
case 60:
return 105;
case 61:
return 111;
case 62:
return 46;
case 63:
return 60;
case 64:
return 44;
case 65:
return 8;
case 66:
return 106;
case 67:
return 115;
case 68:
return this.popState(), 77;
case 69:
return this.pushState("edgeText"), 75;
case 70:
return 119;
case 71:
return this.popState(), 77;
case 72:
return this.pushState("thickEdgeText"), 75;
case 73:
return 119;
case 74:
return this.popState(), 77;
case 75:
return this.pushState("dottedEdgeText"), 75;
case 76:
return 119;
case 77:
return 77;
case 78:
return this.popState(), 53;
case 79:
return "TEXT";
case 80:
return this.pushState("ellipseText"), 52;
case 81:
return this.popState(), 55;
case 82:
return this.pushState("text"), 54;
case 83:
return this.popState(), 57;
case 84:
return this.pushState("text"), 56;
case 85:
return 58;
case 86:
return this.pushState("text"), 67;
case 87:
return this.popState(), 64;
case 88:
return this.pushState("text"), 63;
case 89:
return this.popState(), 49;
case 90:
return this.pushState("text"), 48;
case 91:
return this.popState(), 69;
case 92:
return this.popState(), 71;
case 93:
return 117;
case 94:
return this.pushState("trapText"), 68;
case 95:
return this.pushState("trapText"), 70;
case 96:
return 118;
case 97:
return 67;
case 98:
return 90;
case 99:
return "SEP";
case 100:
return 89;
case 101:
return 115;
case 102:
return 111;
case 103:
return 44;
case 104:
return 109;
case 105:
return 114;
case 106:
return 116;
case 107:
return this.popState(), 62;
case 108:
return this.pushState("text"), 62;
case 109:
return this.popState(), 51;
case 110:
return this.pushState("text"), 50;
case 111:
return this.popState(), 31;
case 112:
return this.pushState("text"), 29;
case 113:
return this.popState(), 66;
case 114:
return this.pushState("text"), 65;
case 115:
return "TEXT";
case 116:
return "QUOTE";
case 117:
return 9;
case 118:
return 10;
case 119:
return 11;
}
}, "anonymous"),
rules: [/^(?:accTitle\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*:\s*)/, /^(?:(?!\n||)*[^\n]*)/, /^(?:accDescr\s*\{\s*)/, /^(?:[\}])/, /^(?:[^\}]*)/, /^(?:@\{)/, /^(?:["])/, /^(?:["])/, /^(?:[^\"]+)/, /^(?:[^}^"]+)/, /^(?:\})/, /^(?:call[\s]+)/, /^(?:\([\s]*\))/, /^(?:\()/, /^(?:[^(]*)/, /^(?:\))/, /^(?:[^)]*)/, /^(?:[^`"]+)/, /^(?:[`]["])/, /^(?:["][`])/, /^(?:[^"]+)/, /^(?:["])/, /^(?:["])/, /^(?:style\b)/, /^(?:default\b)/, /^(?:linkStyle\b)/, /^(?:interpolate\b)/, /^(?:classDef\b)/, /^(?:class\b)/, /^(?:href[\s])/, /^(?:click[\s]+)/, /^(?:[\s\n])/, /^(?:[^\s\n]*)/, /^(?:flowchart-elk\b)/, /^(?:graph\b)/, /^(?:flowchart\b)/, /^(?:subgraph\b)/, /^(?:end\b\s*)/, /^(?:_self\b)/, /^(?:_blank\b)/, /^(?:_parent\b)/, /^(?:_top\b)/, /^(?:(\r?\n)*\s*\n)/, /^(?:\s*LR\b)/, /^(?:\s*RL\b)/, /^(?:\s*TB\b)/, /^(?:\s*BT\b)/, /^(?:\s*TD\b)/, /^(?:\s*BR\b)/, /^(?:\s*<)/, /^(?:\s*>)/, /^(?:\s*\^)/, /^(?:\s*v\b)/, /^(?:.*direction\s+TB[^\n]*)/, /^(?:.*direction\s+BT[^\n]*)/, /^(?:.*direction\s+RL[^\n]*)/, /^(?:.*direction\s+LR[^\n]*)/, /^(?:[^\s\"]+@(?=[^\{\"]))/, /^(?:[0-9]+)/, /^(?:#)/, /^(?::::)/, /^(?::)/, /^(?:&)/, /^(?:;)/, /^(?:,)/, /^(?:\*)/, /^(?:\s*[xo<]?--+[-xo>]\s*)/, /^(?:\s*[xo<]?--\s*)/, /^(?:[^-]|-(?!-)+)/, /^(?:\s*[xo<]?==+[=xo>]\s*)/, /^(?:\s*[xo<]?==\s*)/, /^(?:[^=]|=(?!))/, /^(?:\s*[xo<]?-?\.+-[xo>]?\s*)/, /^(?:\s*[xo<]?-\.\s*)/, /^(?:[^\.]|\.(?!))/, /^(?:\s*~~[\~]+\s*)/, /^(?:[-/\)][\)])/, /^(?:[^\(\)\[\]\{\}]|!\)+)/, /^(?:\(-)/, /^(?:\]\))/, /^(?:\(\[)/, /^(?:\]\])/, /^(?:\[\[)/, /^(?:\[\|)/, /^(?:>)/, /^(?:\)\])/, /^(?:\[\()/, /^(?:\)\)\))/, /^(?:\(\(\()/, /^(?:[\\(?=\])][\]])/, /^(?:\/(?=\])\])/, /^(?:\/(?!\])|\\(?!\])|[^\\\[\]\(\)\{\}\/]+)/, /^(?:\[\/)/, /^(?:\[\\)/, /^(?:<)/, /^(?:>)/, /^(?:\^)/, /^(?:\\\|)/, /^(?:v\b)/, /^(?:\*)/, /^(?:#)/, /^(?:&)/, /^(?:([A-Za-z0-9!"\#$%&'*+\.`?\\_\/]|-(?=[^\>\-\.])|(?!))+)/, /^(?:-)/, /^(?:[\u00AA\u00B5\u00BA\u00C0-\u00D6\u00D8-\u00F6]|[\u00F8-\u02C1\u02C6-\u02D1\u02E0-\u02E4\u02EC\u02EE\u0370-\u0374\u0376\u0377]|[\u037A-\u037D\u0386\u0388-\u038A\u038C\u038E-\u03A1\u03A3-\u03F5]|[\u03F7-\u0481\u048A-\u0527\u0531-\u0556\u0559\u0561-\u0587\u05D0-\u05EA]|[\u05F0-\u05F2\u0620-\u064A\u066E\u066F\u0671-\u06D3\u06D5\u06E5\u06E6\u06EE]|[\u06EF\u06FA-\u06FC\u06FF\u0710\u0712-\u072F\u074D-\u07A5\u07B1\u07CA-\u07EA]|[\u07F4\u07F5\u07FA\u0800-\u0815\u081A\u0824\u0828\u0840-\u0858\u08A0]|[\u08A2-\u08AC\u0904-\u0939\u093D\u0950\u0958-\u0961\u0971-\u0977]|[\u0979-\u097F\u0985-\u098C\u098F\u0990\u0993-\u09A8\u09AA-\u09B0\u09B2]|[\u09B6-\u09B9\u09BD\u09CE\u09DC\u09DD\u09DF-\u09E1\u09F0\u09F1\u0A05-\u0A0A]|[\u0A0F\u0A10\u0A13-\u0A28\u0A2A-\u0A30\u0A32\u0A33\u0A35\u0A36\u0A38\u0A39]|[\u0A59-\u0A5C\u0A5E\u0A72-\u0A74\u0A85-\u0A8D\u0A8F-\u0A91\u0A93-\u0AA8]|[\u0AAA-\u0AB0\u0AB2\u0AB3\u0AB5-\u0AB9\u0ABD\u0AD0\u0AE0\u0AE1\u0B05-\u0B0C]|[\u0B0F\u0B10\u0B13-\u0B28\u0B2A-\u0B30\u0B32\u0B33\u0B35-\u0B39\u0B3D\u0B5C]|[\u0B5D\u0B5F-\u0B61\u0B71\u0B83\u0B85-\u0B8A\u0B8E-\u0B90\u0B92-\u0B95\u0B99]|[\u0B9A\u0B9C\u0B9E\u0B9F\u0BA3\u0BA4\u0BA8-\u0BAA\u0BAE-\u0BB9\u0BD0]|[\u0C05-\u0C0C\u0C0E-\u0C10\u0C12-\u0C28\u0C2A-\u0C33\u0C35-\u0C39\u0C3D]|[\u0C58\u0C59\u0C60\u0C61\u0C85-\u0C8C\u0C8E-\u0C90\u0C92-\u0CA8\u0CAA-\u0CB3]|[\u0CB5-\u0CB9\u0CBD\u0CDE\u0CE0\u0CE1\u0CF1\u0CF2\u0D05-\u0D0C\u0D0E-\u0D10]|[\u0D12-\u0D3A\u0D3D\u0D4E\u0D60\u0D61\u0D7A-\u0D7F\u0D85-\u0D96\u0D9A-\u0DB1]|[\u0DB3-\u0DBB\u0DBD\u0DC0-\u0DC6\u0E01-\u0E30\u0E32\u0E33\u0E40-\u0E46\u0E81]|[\u0E82\u0E84\u0E87\u0E88\u0E8A\u0E8D\u0E94-\u0E97\u0E99-\u0E9F\u0EA1-\u0EA3]|[\u0EA5\u0EA7\u0EAA\u0EAB\u0EAD-\u0EB0\u0EB2\u0EB3\u0EBD\u0EC0-\u0EC4\u0EC6]|[\u0EDC-\u0EDF\u0F00\u0F40-\u0F47\u0F49-\u0F6C\u0F88-\u0F8C\u1000-\u102A]|[\u103F\u1050-\u1055\u105A-\u105D\u1061\u1065\u1066\u106E-\u1070\u1075-\u1081]|[\u108E\u10A0-\u10C5\u10C7\u10CD\u10D0-\u10FA\u10FC-\u1248\u124A-\u124D]|[\u1250-\u1256\u1258\u125A-\u125D\u1260-\u1288\u128A-\u128D\u1290-\u12B0]|[\u12B2-\u12B5\u12B8-\u12BE\u12C0\u12C2-\u12C5\u12C8-\u12D6\u12D8-\u1310]|[\u1312-\u1315\u1318-\u135A\u1380-\u138F\u13A0-\u13F4\u1401-\u166C]|[\u166F-\u167F\u1681-\u169A\u16A0-\u16EA\u1700-\u170C\u170E-\u1711]|[\u1720-\u1731\u1740-\u1751\u1760-\u176C\u176E-\u1770\u1780-\u17B3\u17D7]|[\u17DC\u1820-\u1877\u1880-\u18A8\u18AA\u18B0-\u18F5\u1900-\u191C]|[\u1950-\u196D\u1970-\u1974\u1980-\u19AB\u19C1-\u19C7\u1A00-\u1A16]|[\u1A20-\u1A54\u1AA7\u1B05-\u1B33\u1B45-\u1B4B\u1B83-\u1BA0\u1BAE\u1BAF]|[\u1BBA-\u1BE5\u1C00-\u1C23\u1C4D-\u1C4F\u1C5A-\u1C7D\u1CE9-\u1CEC]|[\u1CEE-\u1CF1\u1CF5\u1CF6\u1D00-\u1DBF\u1E00-\u1F15\u1F18-\u1F1D]|[\u1F20-\u1F45\u1F48-\u1F4D\u1F50-\u1F57\u1F59\u1F5B\u1F5D\u1F5F-\u1F7D]|[\u1F80-\u1FB4\u1FB6-\u1FBC\u1FBE\u1FC2-\u1FC4\u1FC6-\u1FCC\u1FD0-\u1FD3]|[\u1FD6-\u1FDB\u1FE0-\u1FEC\u1FF2-\u1FF4\u1FF6-\u1FFC\u2071\u207F]|[\u2090-\u209C\u2102\u2107\u210A-\u2113\u2115\u2119-\u211D\u2124\u2126\u2128]|[\u212A-\u212D\u212F-\u2139\u213C-\u213F\u2145-\u2149\u214E\u2183\u2184]|[\u2C00-\u2C2E\u2C30-\u2C5E\u2C60-\u2CE4\u2CEB-\u2CEE\u2CF2\u2CF3]|[\u2D00-\u2D25\u2D27\u2D2D\u2D30-\u2D67\u2D6F\u2D80-\u2D96\u2DA0-\u2DA6]|[\u2DA8-\u2DAE\u2DB0-\u2DB6\u2DB8-\u2DBE\u2DC0-\u2DC6\u2DC8-\u2DCE]|[\u2DD0-\u2DD6\u2DD8-\u2DDE\u2E2F\u3005\u3006\u3031-\u3035\u303B\u303C]|[\u3041-\u3096\u309D-\u309F\u30A1-\u30FA\u30FC-\u30FF\u3105-\u312D]|[\u3131-\u318E\u31A0-\u31BA\u31F0-\u31FF\u3400-\u4DB5\u4E00-\u9FCC]|[\uA000-\uA48C\uA4D0-\uA4FD\uA500-\uA60C\uA610-\uA61F\uA62A\uA62B]|[\uA640-\uA66E\uA67F-\uA697\uA6A0-\uA6E5\uA717-\uA71F\uA722-\uA788]|[\uA78B-\uA78E\uA790-\uA793\uA7A0-\uA7AA\uA7F8-\uA801\uA803-\uA805]|[\uA807-\uA80A\uA80C-\uA822\uA840-\uA873\uA882-\uA8B3\uA8F2-\uA8F7\uA8FB]|[\uA90A-\uA925\uA930-\uA946\uA960-\uA97C\uA984-\uA9B2\uA9CF\uAA00-\uAA28]|[\uAA40-\uAA42\uAA44-\uAA4B\uAA60-\uAA76\uAA7A\uAA80-\uAAAF\uAAB1\uAAB5]|[\uAAB6\uAAB9-\uAABD\uAAC0\uAAC2\uAADB-\uAADD\uAAE0-\uAAEA\uAAF2-\uAAF4]|[\uAB01-\uAB06\uAB09-\uAB0E\uAB11-\uAB16\uAB20-\uAB26\uAB28-\uAB2E]|[\uABC0-\uABE2\uAC00-\uD7A3\uD7B0-\uD7C6\uD7CB-\uD7FB\uF900-\uFA6D]|[\uFA70-\uFAD9\uFB00-\uFB06\uFB13-\uFB17\uFB1D\uFB1F-\uFB28\uFB2A-\uFB36]|[\uFB38-\uFB3C\uFB3E\uFB40\uFB41\uFB43\uFB44\uFB46-\uFBB1\uFBD3-\uFD3D]|[\uFD50-\uFD8F\uFD92-\uFDC7\uFDF0-\uFDFB\uFE70-\uFE74\uFE76-\uFEFC]|[\uFF21-\uFF3A\uFF41-\uFF5A\uFF66-\uFFBE\uFFC2-\uFFC7\uFFCA-\uFFCF]|[\uFFD2-\uFFD7\uFFDA-\uFFDC])/, /^(?:\|)/, /^(?:\|)/, /^(?:\))/, /^(?:\()/, /^(?:\])/, /^(?:\[)/, /^(?:(\}))/, /^(?:\{)/, /^(?:[^\[\]\(\)\{\}\|\"]+)/, /^(?:")/, /^(?:(\r?\n)+)/, /^(?:\s)/, /^(?:$)/],
conditions: { shapeDataEndBracket: { rules: [21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, shapeDataStr: { rules: [9, 10, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, shapeData: { rules: [8, 11, 12, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, callbackargs: { rules: [17, 18, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, callbackname: { rules: [14, 15, 16, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, href: { rules: [21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, click: { rules: [21, 24, 33, 34, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, dottedEdgeText: { rules: [21, 24, 74, 76, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, thickEdgeText: { rules: [21, 24, 71, 73, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, edgeText: { rules: [21, 24, 68, 70, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, trapText: { rules: [21, 24, 77, 80, 82, 84, 88, 90, 91, 92, 93, 94, 95, 108, 110, 112, 114], inclusive: !1 }, ellipseText: { rules: [21, 24, 77, 78, 79, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, text: { rules: [21, 24, 77, 80, 81, 82, 83, 84, 87, 88, 89, 90, 94, 95, 107, 108, 109, 110, 111, 112, 113, 114, 115], inclusive: !1 }, vertex: { rules: [21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, dir: { rules: [21, 24, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, acc_descr_multiline: { rules: [5, 6, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, acc_descr: { rules: [3, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, acc_title: { rules: [1, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, md_string: { rules: [19, 20, 21, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, string: { rules: [21, 22, 23, 24, 77, 80, 82, 84, 88, 90, 94, 95, 108, 110, 112, 114], inclusive: !1 }, INITIAL: { rules: [0, 2, 4, 7, 13, 21, 24, 25, 26, 27, 28, 29, 30, 31, 32, 35, 36, 37, 38, 39, 40, 41, 42, 43, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 71, 72, 74, 75, 77, 80, 82, 84, 85, 86, 88, 90, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 108, 110, 112, 114, 116, 117, 118, 119], inclusive: !0 } }
};
return p1;
}();
J1.lexer = Wt;
function H1() {
this.yy = {};
}
return m(H1, "Parser"), H1.prototype = J1, J1.Parser = H1, new H1();
}();
rt.parser = rt;
var Mt = rt, Ut = Object.assign({}, Mt);
Ut.parse = (s) => {
const i = s.replace(/}\s*\n/g, `}
`);
return Mt.parse(i);
};
var be = Ut, Ae = /* @__PURE__ */ m((s, i) => {
const a = ce, n = a(s, "r"), u = a(s, "g"), l = a(s, "b");
return ue(n, u, l, i);
}, "fade"), ke = /* @__PURE__ */ m((s) => `.label {
font-family: ${s.fontFamily};
color: ${s.nodeTextColor || s.textColor};
}
.cluster-label text {
fill: ${s.titleColor};
}
.cluster-label span {
color: ${s.titleColor};
}
.cluster-label span p {
background-color: transparent;
}
.label text,span {
fill: ${s.nodeTextColor || s.textColor};
color: ${s.nodeTextColor || s.textColor};
}
.node rect,
.node circle,
.node ellipse,
.node polygon,
.node path {
fill: ${s.mainBkg};
stroke: ${s.nodeBorder};
stroke-width: 1px;
}
.rough-node .label text , .node .label text, .image-shape .label, .icon-shape .label {
text-anchor: middle;
}
// .flowchart-label .text-outer-tspan {
// text-anchor: middle;
// }
// .flowchart-label .text-inner-tspan {
// text-anchor: start;
// }
.node .katex path {
fill: #000;
stroke: #000;
stroke-width: 1px;
}
.rough-node .label,.node .label, .image-shape .label, .icon-shape .label {
text-align: center;
}
.node.clickable {
cursor: pointer;
}
.root .anchor path {
fill: ${s.lineColor} !important;
stroke-width: 0;
stroke: ${s.lineColor};
}
.arrowheadPath {
fill: ${s.arrowheadColor};
}
.edgePath .path {
stroke: ${s.lineColor};
stroke-width: 2.0px;
}
.flowchart-link {
stroke: ${s.lineColor};
fill: none;
}
.edgeLabel {
background-color: ${s.edgeLabelBackground};
p {
background-color: ${s.edgeLabelBackground};
}
rect {
opacity: 0.5;
background-color: ${s.edgeLabelBackground};
fill: ${s.edgeLabelBackground};
}
text-align: center;
}
/* For html labels only */
.labelBkg {
background-color: ${Ae(s.edgeLabelBackground, 0.5)};
// background-color:
}
.cluster rect {
fill: ${s.clusterBkg};
stroke: ${s.clusterBorder};
stroke-width: 1px;
}
.cluster text {
fill: ${s.titleColor};
}
.cluster span {
color: ${s.titleColor};
}
/* .cluster div {
color: ${s.titleColor};
} */
div.mermaidTooltip {
position: absolute;
text-align: center;
max-width: 200px;
padding: 2px;
font-family: ${s.fontFamily};
font-size: 12px;
background: ${s.tertiaryColor};
border: 1px solid ${s.border2};
border-radius: 2px;
pointer-events: none;
z-index: 100;
}
.flowchartTitleText {
text-anchor: middle;
font-size: 18px;
fill: ${s.textColor};
}
rect.text {
fill: none;
stroke-width: 0;
}
.icon-shape, .image-shape {
background-color: ${s.edgeLabelBackground};
p {
background-color: ${s.edgeLabelBackground};
padding: 2px;
}
rect {
opacity: 0.5;
background-color: ${s.edgeLabelBackground};
fill: ${s.edgeLabelBackground};
}
text-align: center;
}
`, "getStyles"), me = ke, xe = {
parser: be,
get db() {
return new de();
},
renderer: ge,
styles: me,
init: /* @__PURE__ */ m((s) => {
s.flowchart || (s.flowchart = {}), s.layout && Ot({ layout: s.layout }), s.flowchart.arrowMarkerAbsolute = s.arrowMarkerAbsolute, Ot({ flowchart: { arrowMarkerAbsolute: s.arrowMarkerAbsolute } });
}, "init")
};
export {
xe as diagram
};