bg-editor 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/LICENSE +8 -0
  2. package/README.md +51 -0
  3. package/README.zh-CN.md +51 -0
  4. package/dist/_basePickBy-4kmg42pS.js +158 -0
  5. package/dist/_baseUniq-WOvvCHTI.js +621 -0
  6. package/dist/arc-wItjmL5I.js +90 -0
  7. package/dist/architecture-U656AL7Q-FYDwFSxk.js +12 -0
  8. package/dist/architectureDiagram-VXUJARFQ-iG5MkBjx.js +4666 -0
  9. package/dist/blockDiagram-VD42YOAC-i2GlXmWy.js +2268 -0
  10. package/dist/c4Diagram-YG6GDRKO-IufO7T1R.js +1587 -0
  11. package/dist/channel-Dah4F59k.js +12 -0
  12. package/dist/chunk-4BX2VUAB-5_v9rnje.js +15 -0
  13. package/dist/chunk-55IACEB6-BDNtSypP.js +15 -0
  14. package/dist/chunk-B4BG7PRW-DzaYPsfW.js +1382 -0
  15. package/dist/chunk-DI55MBZ5-Buwrprkw.js +1377 -0
  16. package/dist/chunk-FMBD7UC4-BaEPEIWb.js +26 -0
  17. package/dist/chunk-QN33PNHL-DhbA7i5G.js +26 -0
  18. package/dist/chunk-QZHKN3VN-BAb_D1oz.js +22 -0
  19. package/dist/chunk-TZMSLE5B-OU1MJ2do.js +71 -0
  20. package/dist/classDiagram-2ON5EDUG-KStC8v09.js +23 -0
  21. package/dist/classDiagram-v2-WZHVMYZB-KStC8v09.js +23 -0
  22. package/dist/clone-C74UiRbr.js +15 -0
  23. package/dist/cose-bilkent-S5V4N54A-eRXCoix2.js +2612 -0
  24. package/dist/cytoscape.esm-BG3R4uVs.js +18738 -0
  25. package/dist/dagre-6UL2VRFP-Bi83jPQf.js +451 -0
  26. package/dist/defaultLocale-DgmhL6Re.js +178 -0
  27. package/dist/diagram-PSM6KHXK-aW98k2-4.js +539 -0
  28. package/dist/diagram-QEK2KX5R-BR--iNM5.js +224 -0
  29. package/dist/diagram-S2PKOQOG-NTnEy5_O.js +149 -0
  30. package/dist/erDiagram-Q2GNP2WA-C8oZ5c-S.js +848 -0
  31. package/dist/flowDiagram-NV44I4VS-DiKad3Bb.js +1627 -0
  32. package/dist/ganttDiagram-LVOFAZNH-CthzjjJq.js +2506 -0
  33. package/dist/gitGraph-F6HP7TQM-CuXAC0XT.js +12 -0
  34. package/dist/gitGraphDiagram-NY62KEGX-d4KszKqi.js +706 -0
  35. package/dist/graph-CnOTx4E0.js +254 -0
  36. package/dist/index-D6-Wf75-.js +122127 -0
  37. package/dist/info-NVLQJR56-Dhmtdc7O.js +12 -0
  38. package/dist/infoDiagram-ER5ION4S-DedidjTu.js +31 -0
  39. package/dist/init-d639unba.js +23 -0
  40. package/dist/journeyDiagram-XKPGCS4Q-BylvmUWL.js +843 -0
  41. package/dist/kanban-definition-3W4ZIXB7-DGV_aVgU.js +725 -0
  42. package/dist/layout-OXk4OSoz.js +1342 -0
  43. package/dist/linear-CO_vz87n.js +266 -0
  44. package/dist/mermaid-parser.core-CYtF6phW.js +12928 -0
  45. package/dist/mindmap-definition-VGOIOE7T-BU05Y6Vz.js +790 -0
  46. package/dist/ordinal-CofNqUw2.js +68 -0
  47. package/dist/packet-BFZMPI3H-D7H_8Q-U.js +12 -0
  48. package/dist/pie-7BOR55EZ-BNWNcO5Z.js +12 -0
  49. package/dist/pieDiagram-ADFJNKIX-reGTUsiW.js +168 -0
  50. package/dist/quadrantDiagram-AYHSOK5B-NeHOJ0lX.js +1029 -0
  51. package/dist/radar-NHE76QYJ-DrVEcvh1.js +12 -0
  52. package/dist/requirementDiagram-UZGBJVZJ-BE76XNaT.js +857 -0
  53. package/dist/sankeyDiagram-TZEHDZUN-UHfMLEKl.js +817 -0
  54. package/dist/sequenceDiagram-WL72ISMW-62KWnVbh.js +2518 -0
  55. package/dist/stateDiagram-FKZM4ZOC--_CkWvu6.js +270 -0
  56. package/dist/stateDiagram-v2-4FDKWEC3-Dj7ZjAmI.js +23 -0
  57. package/dist/style.css +1 -0
  58. package/dist/timeline-definition-IT6M3QCI-C3Wb0xMN.js +804 -0
  59. package/dist/treemap-KMMF4GRG-Bc8F2dFd.js +12 -0
  60. package/dist/umo-editor.js +16 -0
  61. package/dist/xychartDiagram-PRI3JC2R-D2J307cO.js +1347 -0
  62. package/package.json +200 -0
  63. package/types/index.d.ts +277 -0
  64. package/types/src/components/index.d.ts +9 -0
  65. package/types/src/components/menus/button.vue.d.ts +583 -0
  66. package/types/src/components/modal.vue.d.ts +2 -0
  67. package/types/src/components/tooltip.vue.d.ts +27 -0
@@ -0,0 +1,1627 @@
1
+ import "./style.css";
2
+ import { g as qt } from "./chunk-FMBD7UC4-BaEPEIWb.js";
3
+ import { _ as m, n as Ot, l as $, c as b1, d as E1, o as Ht, r as Xt, u as it, b as Qt, s as Jt, p as Zt, a as $t, g as te, q as ee, k as se, t as ie, J as re, v as ae, x as st, y as ne, z as ue, A as oe } from "./index-D6-Wf75-.js";
4
+ import { g as le } from "./chunk-55IACEB6-BDNtSypP.js";
5
+ import { s as ce } from "./chunk-QN33PNHL-DhbA7i5G.js";
6
+ import { c as he } from "./channel-Dah4F59k.js";
7
+ /**
8
+ * @umoteam/editor 9.0.1
9
+ * @license MIT
10
+ * @author umodoc https://www.umodoc.com
11
+ * @see https://www.umodoc.com
12
+ **/
13
+ var de = "flowchart-", G1, pe = (G1 = class {
14
+ // cspell:ignore funs
15
+ constructor() {
16
+ this.vertexCounter = 0, this.config = b1(), 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 = Qt, this.setAccDescription = Jt, this.setDiagramTitle = Zt, this.getAccTitle = $t, this.getAccDescription = te, this.getDiagramTitle = ee, 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 = {
17
+ firstGraph: this.firstGraph.bind(this)
18
+ }, this.clear(), this.setGen("gen-2");
19
+ }
20
+ sanitizeText(i) {
21
+ return se.sanitizeText(i, this.config);
22
+ }
23
+ /**
24
+ * Function to lookup domId from id in the graph definition.
25
+ *
26
+ * @param id - id of the node
27
+ */
28
+ lookUpDomId(i) {
29
+ for (const r of this.vertices.values())
30
+ if (r.id === i)
31
+ return r.domId;
32
+ return i;
33
+ }
34
+ /**
35
+ * Function called by parser when a node definition has been found
36
+ */
37
+ addVertex(i, r, a, n, l, g, c = {}, b) {
38
+ if (!i || i.trim().length === 0)
39
+ return;
40
+ let u;
41
+ if (b !== void 0) {
42
+ let k;
43
+ b.includes(`
44
+ `) ? k = b + `
45
+ ` : k = `{
46
+ ` + b + `
47
+ }`, u = ie(k, { schema: re });
48
+ }
49
+ const A = this.edges.find((k) => k.id === i);
50
+ if (A) {
51
+ const k = u;
52
+ k?.animate !== void 0 && (A.animate = k.animate), k?.animation !== void 0 && (A.animation = k.animation), k?.curve !== void 0 && (A.interpolate = k.curve);
53
+ return;
54
+ }
55
+ let y, f = this.vertices.get(i);
56
+ if (f === void 0 && (f = {
57
+ id: i,
58
+ labelType: "text",
59
+ domId: de + i + "-" + this.vertexCounter,
60
+ styles: [],
61
+ classes: []
62
+ }, this.vertices.set(i, f)), this.vertexCounter++, r !== void 0 ? (this.config = b1(), y = this.sanitizeText(r.text.trim()), f.labelType = r.type, y.startsWith('"') && y.endsWith('"') && (y = y.substring(1, y.length - 1)), f.text = y) : f.text === void 0 && (f.text = i), a !== void 0 && (f.type = a), n?.forEach((k) => {
63
+ f.styles.push(k);
64
+ }), l?.forEach((k) => {
65
+ f.classes.push(k);
66
+ }), g !== void 0 && (f.dir = g), f.props === void 0 ? f.props = c : c !== void 0 && Object.assign(f.props, c), u !== void 0) {
67
+ if (u.shape) {
68
+ if (u.shape !== u.shape.toLowerCase() || u.shape.includes("_"))
69
+ throw new Error(`No such shape: ${u.shape}. Shape names should be lowercase.`);
70
+ if (!ae(u.shape))
71
+ throw new Error(`No such shape: ${u.shape}.`);
72
+ f.type = u?.shape;
73
+ }
74
+ u?.label && (f.text = u?.label), u?.icon && (f.icon = u?.icon, !u.label?.trim() && f.text === i && (f.text = "")), u?.form && (f.form = u?.form), u?.pos && (f.pos = u?.pos), u?.img && (f.img = u?.img, !u.label?.trim() && f.text === i && (f.text = "")), u?.constraint && (f.constraint = u.constraint), u.w && (f.assetWidth = Number(u.w)), u.h && (f.assetHeight = Number(u.h));
75
+ }
76
+ }
77
+ /**
78
+ * Function called by parser when a link/edge definition has been found
79
+ *
80
+ */
81
+ addSingleLink(i, r, a, n) {
82
+ const c = {
83
+ start: i,
84
+ end: r,
85
+ type: void 0,
86
+ text: "",
87
+ labelType: "text",
88
+ classes: [],
89
+ isUserDefinedId: !1,
90
+ interpolate: this.edges.defaultInterpolate
91
+ };
92
+ $.info("abc78 Got edge...", c);
93
+ const b = a.text;
94
+ if (b !== void 0 && (c.text = this.sanitizeText(b.text.trim()), c.text.startsWith('"') && c.text.endsWith('"') && (c.text = c.text.substring(1, c.text.length - 1)), c.labelType = b.type), a !== void 0 && (c.type = a.type, c.stroke = a.stroke, c.length = a.length > 10 ? 10 : a.length), n && !this.edges.some((u) => u.id === n))
95
+ c.id = n, c.isUserDefinedId = !0;
96
+ else {
97
+ const u = this.edges.filter((A) => A.start === c.start && A.end === c.end);
98
+ u.length === 0 ? c.id = st(c.start, c.end, { counter: 0, prefix: "L" }) : c.id = st(c.start, c.end, {
99
+ counter: u.length + 1,
100
+ prefix: "L"
101
+ });
102
+ }
103
+ if (this.edges.length < (this.config.maxEdges ?? 500))
104
+ $.info("Pushing edge..."), this.edges.push(c);
105
+ else
106
+ throw new Error(
107
+ `Edge limit exceeded. ${this.edges.length} edges found, but the limit is ${this.config.maxEdges}.
108
+
109
+ Initialize mermaid with maxEdges set to a higher number to allow more edges.
110
+ You cannot set this config via configuration inside the diagram as it is a secure config.
111
+ You have to call mermaid.initialize.`
112
+ );
113
+ }
114
+ isLinkData(i) {
115
+ return i !== null && typeof i == "object" && "id" in i && typeof i.id == "string";
116
+ }
117
+ addLink(i, r, a) {
118
+ const n = this.isLinkData(a) ? a.id.replace("@", "") : void 0;
119
+ $.info("addLink", i, r, n);
120
+ for (const l of i)
121
+ for (const g of r) {
122
+ const c = l === i[i.length - 1], b = g === r[0];
123
+ c && b ? this.addSingleLink(l, g, a, n) : this.addSingleLink(l, g, a, void 0);
124
+ }
125
+ }
126
+ /**
127
+ * Updates a link's line interpolation algorithm
128
+ */
129
+ updateLinkInterpolate(i, r) {
130
+ i.forEach((a) => {
131
+ a === "default" ? this.edges.defaultInterpolate = r : this.edges[a].interpolate = r;
132
+ });
133
+ }
134
+ /**
135
+ * Updates a link with a style
136
+ *
137
+ */
138
+ updateLink(i, r) {
139
+ i.forEach((a) => {
140
+ if (typeof a == "number" && a >= this.edges.length)
141
+ throw new Error(
142
+ `The index ${a} 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.)`
143
+ );
144
+ a === "default" ? this.edges.defaultStyle = r : (this.edges[a].style = r, (this.edges[a]?.style?.length ?? 0) > 0 && !this.edges[a]?.style?.some((n) => n?.startsWith("fill")) && this.edges[a]?.style?.push("fill:none"));
145
+ });
146
+ }
147
+ addClass(i, r) {
148
+ const a = r.join().replace(/\\,/g, "§§§").replace(/,/g, ";").replace(/§§§/g, ",").split(";");
149
+ i.split(",").forEach((n) => {
150
+ let l = this.classes.get(n);
151
+ l === void 0 && (l = { id: n, styles: [], textStyles: [] }, this.classes.set(n, l)), a?.forEach((g) => {
152
+ if (/color/.exec(g)) {
153
+ const c = g.replace("fill", "bgFill");
154
+ l.textStyles.push(c);
155
+ }
156
+ l.styles.push(g);
157
+ });
158
+ });
159
+ }
160
+ /**
161
+ * Called by parser when a graph definition is found, stores the direction of the chart.
162
+ *
163
+ */
164
+ setDirection(i) {
165
+ this.direction = i.trim(), /.*</.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");
166
+ }
167
+ /**
168
+ * Called by parser when a special node is found, e.g. a clickable element.
169
+ *
170
+ * @param ids - Comma separated list of ids
171
+ * @param className - Class to add
172
+ */
173
+ setClass(i, r) {
174
+ for (const a of i.split(",")) {
175
+ const n = this.vertices.get(a);
176
+ n && n.classes.push(r);
177
+ const l = this.edges.find((c) => c.id === a);
178
+ l && l.classes.push(r);
179
+ const g = this.subGraphLookup.get(a);
180
+ g && g.classes.push(r);
181
+ }
182
+ }
183
+ setTooltip(i, r) {
184
+ if (r !== void 0) {
185
+ r = this.sanitizeText(r);
186
+ for (const a of i.split(","))
187
+ this.tooltips.set(this.version === "gen-1" ? this.lookUpDomId(a) : a, r);
188
+ }
189
+ }
190
+ setClickFun(i, r, a) {
191
+ const n = this.lookUpDomId(i);
192
+ if (b1().securityLevel !== "loose" || r === void 0)
193
+ return;
194
+ let l = [];
195
+ if (typeof a == "string") {
196
+ l = a.split(/,(?=(?:(?:[^"]*"){2})*[^"]*$)/);
197
+ for (let c = 0; c < l.length; c++) {
198
+ let b = l[c].trim();
199
+ b.startsWith('"') && b.endsWith('"') && (b = b.substr(1, b.length - 2)), l[c] = b;
200
+ }
201
+ }
202
+ l.length === 0 && l.push(i);
203
+ const g = this.vertices.get(i);
204
+ g && (g.haveCallback = !0, this.funs.push(() => {
205
+ const c = document.querySelector(`[id="${n}"]`);
206
+ c !== null && c.addEventListener(
207
+ "click",
208
+ () => {
209
+ it.runFunc(r, ...l);
210
+ },
211
+ !1
212
+ );
213
+ }));
214
+ }
215
+ /**
216
+ * Called by parser when a link is found. Adds the URL to the vertex data.
217
+ *
218
+ * @param ids - Comma separated list of ids
219
+ * @param linkStr - URL to create a link for
220
+ * @param target - Target attribute for the link
221
+ */
222
+ setLink(i, r, a) {
223
+ i.split(",").forEach((n) => {
224
+ const l = this.vertices.get(n);
225
+ l !== void 0 && (l.link = it.formatUrl(r, this.config), l.linkTarget = a);
226
+ }), this.setClass(i, "clickable");
227
+ }
228
+ getTooltip(i) {
229
+ return this.tooltips.get(i);
230
+ }
231
+ /**
232
+ * Called by parser when a click definition is found. Registers an event handler.
233
+ *
234
+ * @param ids - Comma separated list of ids
235
+ * @param functionName - Function to be called on click
236
+ * @param functionArgs - Arguments to be passed to the function
237
+ */
238
+ setClickEvent(i, r, a) {
239
+ i.split(",").forEach((n) => {
240
+ this.setClickFun(n, r, a);
241
+ }), this.setClass(i, "clickable");
242
+ }
243
+ bindFunctions(i) {
244
+ this.funs.forEach((r) => {
245
+ r(i);
246
+ });
247
+ }
248
+ getDirection() {
249
+ return this.direction?.trim();
250
+ }
251
+ /**
252
+ * Retrieval function for fetching the found nodes after parsing has completed.
253
+ *
254
+ */
255
+ getVertices() {
256
+ return this.vertices;
257
+ }
258
+ /**
259
+ * Retrieval function for fetching the found links after parsing has completed.
260
+ *
261
+ */
262
+ getEdges() {
263
+ return this.edges;
264
+ }
265
+ /**
266
+ * Retrieval function for fetching the found class definitions after parsing has completed.
267
+ *
268
+ */
269
+ getClasses() {
270
+ return this.classes;
271
+ }
272
+ setupToolTips(i) {
273
+ let r = E1(".mermaidTooltip");
274
+ (r._groups || r)[0][0] === null && (r = E1("body").append("div").attr("class", "mermaidTooltip").style("opacity", 0)), E1(i).select("svg").selectAll("g.node").on("mouseover", (l) => {
275
+ const g = E1(l.currentTarget);
276
+ if (g.attr("title") === null)
277
+ return;
278
+ const b = l.currentTarget?.getBoundingClientRect();
279
+ r.transition().duration(200).style("opacity", ".9"), r.text(g.attr("title")).style("left", window.scrollX + b.left + (b.right - b.left) / 2 + "px").style("top", window.scrollY + b.bottom + "px"), r.html(r.html().replace(/&lt;br\/&gt;/g, "<br/>")), g.classed("hover", !0);
280
+ }).on("mouseout", (l) => {
281
+ r.transition().duration(500).style("opacity", 0), E1(l.currentTarget).classed("hover", !1);
282
+ });
283
+ }
284
+ /**
285
+ * Clears the internal graph db so that a new graph can be parsed.
286
+ *
287
+ */
288
+ clear(i = "gen-2") {
289
+ 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 = b1(), ne();
290
+ }
291
+ setGen(i) {
292
+ this.version = i || "gen-2";
293
+ }
294
+ defaultStyle() {
295
+ return "fill:#ffa;stroke: #f66; stroke-width: 3px; stroke-dasharray: 5, 5;fill:#ffa;stroke: #666;";
296
+ }
297
+ addSubGraph(i, r, a) {
298
+ let n = i.text.trim(), l = a.text;
299
+ i === a && /\s/.exec(a.text) && (n = void 0);
300
+ const c = (/* @__PURE__ */ m((f) => {
301
+ const k = { boolean: {}, number: {}, string: {} }, x = [];
302
+ let T;
303
+ return { nodeList: f.filter(function(W) {
304
+ const J = typeof W;
305
+ return W.stmt && W.stmt === "dir" ? (T = W.value, !1) : W.trim() === "" ? !1 : J in k ? k[J].hasOwnProperty(W) ? !1 : k[J][W] = !0 : x.includes(W) ? !1 : x.push(W);
306
+ }), dir: T };
307
+ }, "uniq"))(r.flat()), b = c.nodeList;
308
+ let u = c.dir;
309
+ const A = b1().flowchart ?? {};
310
+ if (u = u ?? (A.inheritDir ? this.getDirection() ?? b1().direction ?? void 0 : void 0), this.version === "gen-1")
311
+ for (let f = 0; f < b.length; f++)
312
+ b[f] = this.lookUpDomId(b[f]);
313
+ n = n ?? "subGraph" + this.subCount, l = l || "", l = this.sanitizeText(l), this.subCount = this.subCount + 1;
314
+ const y = {
315
+ id: n,
316
+ nodes: b,
317
+ title: l.trim(),
318
+ classes: [],
319
+ dir: u,
320
+ labelType: a.type
321
+ };
322
+ return $.info("Adding", y.id, y.nodes, y.dir), y.nodes = this.makeUniq(y, this.subGraphs).nodes, this.subGraphs.push(y), this.subGraphLookup.set(n, y), n;
323
+ }
324
+ getPosForId(i) {
325
+ for (const [r, a] of this.subGraphs.entries())
326
+ if (a.id === i)
327
+ return r;
328
+ return -1;
329
+ }
330
+ indexNodes2(i, r) {
331
+ const a = this.subGraphs[r].nodes;
332
+ if (this.secCount = this.secCount + 1, this.secCount > 2e3)
333
+ return {
334
+ result: !1,
335
+ count: 0
336
+ };
337
+ if (this.posCrossRef[this.secCount] = r, this.subGraphs[r].id === i)
338
+ return {
339
+ result: !0,
340
+ count: 0
341
+ };
342
+ let n = 0, l = 1;
343
+ for (; n < a.length; ) {
344
+ const g = this.getPosForId(a[n]);
345
+ if (g >= 0) {
346
+ const c = this.indexNodes2(i, g);
347
+ if (c.result)
348
+ return {
349
+ result: !0,
350
+ count: l + c.count
351
+ };
352
+ l = l + c.count;
353
+ }
354
+ n = n + 1;
355
+ }
356
+ return {
357
+ result: !1,
358
+ count: l
359
+ };
360
+ }
361
+ getDepthFirstPos(i) {
362
+ return this.posCrossRef[i];
363
+ }
364
+ indexNodes() {
365
+ this.secCount = -1, this.subGraphs.length > 0 && this.indexNodes2("none", this.subGraphs.length - 1);
366
+ }
367
+ getSubGraphs() {
368
+ return this.subGraphs;
369
+ }
370
+ firstGraph() {
371
+ return this.firstGraphFlag ? (this.firstGraphFlag = !1, !0) : !1;
372
+ }
373
+ destructStartLink(i) {
374
+ let r = i.trim(), a = "arrow_open";
375
+ switch (r[0]) {
376
+ case "<":
377
+ a = "arrow_point", r = r.slice(1);
378
+ break;
379
+ case "x":
380
+ a = "arrow_cross", r = r.slice(1);
381
+ break;
382
+ case "o":
383
+ a = "arrow_circle", r = r.slice(1);
384
+ break;
385
+ }
386
+ let n = "normal";
387
+ return r.includes("=") && (n = "thick"), r.includes(".") && (n = "dotted"), { type: a, stroke: n };
388
+ }
389
+ countChar(i, r) {
390
+ const a = r.length;
391
+ let n = 0;
392
+ for (let l = 0; l < a; ++l)
393
+ r[l] === i && ++n;
394
+ return n;
395
+ }
396
+ destructEndLink(i) {
397
+ const r = i.trim();
398
+ let a = r.slice(0, -1), n = "arrow_open";
399
+ switch (r.slice(-1)) {
400
+ case "x":
401
+ n = "arrow_cross", r.startsWith("x") && (n = "double_" + n, a = a.slice(1));
402
+ break;
403
+ case ">":
404
+ n = "arrow_point", r.startsWith("<") && (n = "double_" + n, a = a.slice(1));
405
+ break;
406
+ case "o":
407
+ n = "arrow_circle", r.startsWith("o") && (n = "double_" + n, a = a.slice(1));
408
+ break;
409
+ }
410
+ let l = "normal", g = a.length - 1;
411
+ a.startsWith("=") && (l = "thick"), a.startsWith("~") && (l = "invisible");
412
+ const c = this.countChar(".", a);
413
+ return c && (l = "dotted", g = c), { type: n, stroke: l, length: g };
414
+ }
415
+ destructLink(i, r) {
416
+ const a = this.destructEndLink(i);
417
+ let n;
418
+ if (r) {
419
+ if (n = this.destructStartLink(r), n.stroke !== a.stroke)
420
+ return { type: "INVALID", stroke: "INVALID" };
421
+ if (n.type === "arrow_open")
422
+ n.type = a.type;
423
+ else {
424
+ if (n.type !== a.type)
425
+ return { type: "INVALID", stroke: "INVALID" };
426
+ n.type = "double_" + n.type;
427
+ }
428
+ return n.type === "double_arrow" && (n.type = "double_arrow_point"), n.length = a.length, n;
429
+ }
430
+ return a;
431
+ }
432
+ // Todo optimizer this by caching existing nodes
433
+ exists(i, r) {
434
+ for (const a of i)
435
+ if (a.nodes.includes(r))
436
+ return !0;
437
+ return !1;
438
+ }
439
+ /**
440
+ * Deletes an id from all subgraphs
441
+ *
442
+ */
443
+ makeUniq(i, r) {
444
+ const a = [];
445
+ return i.nodes.forEach((n, l) => {
446
+ this.exists(r, n) || a.push(i.nodes[l]);
447
+ }), { nodes: a };
448
+ }
449
+ getTypeFromVertex(i) {
450
+ if (i.img)
451
+ return "imageSquare";
452
+ if (i.icon)
453
+ return i.form === "circle" ? "iconCircle" : i.form === "square" ? "iconSquare" : i.form === "rounded" ? "iconRounded" : "icon";
454
+ switch (i.type) {
455
+ case "square":
456
+ case void 0:
457
+ return "squareRect";
458
+ case "round":
459
+ return "roundedRect";
460
+ case "ellipse":
461
+ return "ellipse";
462
+ default:
463
+ return i.type;
464
+ }
465
+ }
466
+ findNode(i, r) {
467
+ return i.find((a) => a.id === r);
468
+ }
469
+ destructEdgeType(i) {
470
+ let r = "none", a = "arrow_point";
471
+ switch (i) {
472
+ case "arrow_point":
473
+ case "arrow_circle":
474
+ case "arrow_cross":
475
+ a = i;
476
+ break;
477
+ case "double_arrow_point":
478
+ case "double_arrow_circle":
479
+ case "double_arrow_cross":
480
+ r = i.replace("double_", ""), a = r;
481
+ break;
482
+ }
483
+ return { arrowTypeStart: r, arrowTypeEnd: a };
484
+ }
485
+ addNodeFromVertex(i, r, a, n, l, g) {
486
+ const c = a.get(i.id), b = n.get(i.id) ?? !1, u = this.findNode(r, i.id);
487
+ if (u)
488
+ u.cssStyles = i.styles, u.cssCompiledStyles = this.getCompiledStyles(i.classes), u.cssClasses = i.classes.join(" ");
489
+ else {
490
+ const A = {
491
+ id: i.id,
492
+ label: i.text,
493
+ labelStyle: "",
494
+ parentId: c,
495
+ padding: l.flowchart?.padding || 8,
496
+ cssStyles: i.styles,
497
+ cssCompiledStyles: this.getCompiledStyles(["default", "node", ...i.classes]),
498
+ cssClasses: "default " + i.classes.join(" "),
499
+ dir: i.dir,
500
+ domId: i.domId,
501
+ look: g,
502
+ link: i.link,
503
+ linkTarget: i.linkTarget,
504
+ tooltip: this.getTooltip(i.id),
505
+ icon: i.icon,
506
+ pos: i.pos,
507
+ img: i.img,
508
+ assetWidth: i.assetWidth,
509
+ assetHeight: i.assetHeight,
510
+ constraint: i.constraint
511
+ };
512
+ b ? r.push({
513
+ ...A,
514
+ isGroup: !0,
515
+ shape: "rect"
516
+ }) : r.push({
517
+ ...A,
518
+ isGroup: !1,
519
+ shape: this.getTypeFromVertex(i)
520
+ });
521
+ }
522
+ }
523
+ getCompiledStyles(i) {
524
+ let r = [];
525
+ for (const a of i) {
526
+ const n = this.classes.get(a);
527
+ n?.styles && (r = [...r, ...n.styles ?? []].map((l) => l.trim())), n?.textStyles && (r = [...r, ...n.textStyles ?? []].map((l) => l.trim()));
528
+ }
529
+ return r;
530
+ }
531
+ getData() {
532
+ const i = b1(), r = [], a = [], n = this.getSubGraphs(), l = /* @__PURE__ */ new Map(), g = /* @__PURE__ */ new Map();
533
+ for (let u = n.length - 1; u >= 0; u--) {
534
+ const A = n[u];
535
+ A.nodes.length > 0 && g.set(A.id, !0);
536
+ for (const y of A.nodes)
537
+ l.set(y, A.id);
538
+ }
539
+ for (let u = n.length - 1; u >= 0; u--) {
540
+ const A = n[u];
541
+ r.push({
542
+ id: A.id,
543
+ label: A.title,
544
+ labelStyle: "",
545
+ parentId: l.get(A.id),
546
+ padding: 8,
547
+ cssCompiledStyles: this.getCompiledStyles(A.classes),
548
+ cssClasses: A.classes.join(" "),
549
+ shape: "rect",
550
+ dir: A.dir,
551
+ isGroup: !0,
552
+ look: i.look
553
+ });
554
+ }
555
+ this.getVertices().forEach((u) => {
556
+ this.addNodeFromVertex(u, r, l, g, i, i.look || "classic");
557
+ });
558
+ const b = this.getEdges();
559
+ return b.forEach((u, A) => {
560
+ const { arrowTypeStart: y, arrowTypeEnd: f } = this.destructEdgeType(u.type), k = [...b.defaultStyle ?? []];
561
+ u.style && k.push(...u.style);
562
+ const x = {
563
+ id: st(u.start, u.end, { counter: A, prefix: "L" }, u.id),
564
+ isUserDefinedId: u.isUserDefinedId,
565
+ start: u.start,
566
+ end: u.end,
567
+ type: u.type ?? "normal",
568
+ label: u.text,
569
+ labelpos: "c",
570
+ thickness: u.stroke,
571
+ minlen: u.length,
572
+ classes: u?.stroke === "invisible" ? "" : "edge-thickness-normal edge-pattern-solid flowchart-link",
573
+ arrowTypeStart: u?.stroke === "invisible" || u?.type === "arrow_open" ? "none" : y,
574
+ arrowTypeEnd: u?.stroke === "invisible" || u?.type === "arrow_open" ? "none" : f,
575
+ arrowheadStyle: "fill: #333",
576
+ cssCompiledStyles: this.getCompiledStyles(u.classes),
577
+ labelStyle: k,
578
+ style: k,
579
+ pattern: u.stroke,
580
+ look: i.look,
581
+ animate: u.animate,
582
+ animation: u.animation,
583
+ curve: u.interpolate || this.edges.defaultInterpolate || i.flowchart?.curve
584
+ };
585
+ a.push(x);
586
+ }), { nodes: r, edges: a, other: {}, config: i };
587
+ }
588
+ defaultConfig() {
589
+ return ue.flowchart;
590
+ }
591
+ }, m(G1, "FlowDB"), G1), fe = /* @__PURE__ */ m(function(s, i) {
592
+ return i.db.getClasses();
593
+ }, "getClasses"), ge = /* @__PURE__ */ m(async function(s, i, r, a) {
594
+ $.info("REF0:"), $.info("Drawing state diagram (v2)", i);
595
+ const { securityLevel: n, flowchart: l, layout: g } = b1();
596
+ let c;
597
+ n === "sandbox" && (c = E1("#i" + i));
598
+ const b = n === "sandbox" ? c.nodes()[0].contentDocument : document;
599
+ $.debug("Before getData: ");
600
+ const u = a.db.getData();
601
+ $.debug("Data: ", u);
602
+ const A = le(i, n), y = a.db.getDirection();
603
+ u.type = a.type, u.layoutAlgorithm = Ht(g), u.layoutAlgorithm === "dagre" && g === "elk" && $.warn(
604
+ "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."
605
+ ), u.direction = y, u.nodeSpacing = l?.nodeSpacing || 50, u.rankSpacing = l?.rankSpacing || 50, u.markers = ["point", "circle", "cross"], u.diagramId = i, $.debug("REF1:", u), await Xt(u, A);
606
+ const f = u.config.flowchart?.diagramPadding ?? 8;
607
+ it.insertTitle(
608
+ A,
609
+ "flowchartTitleText",
610
+ l?.titleTopMargin || 0,
611
+ a.db.getDiagramTitle()
612
+ ), ce(A, f, "flowchart", l?.useMaxWidth || !1);
613
+ for (const k of u.nodes) {
614
+ const x = E1(`#${i} [id="${k.id}"]`);
615
+ if (!x || !k.link)
616
+ continue;
617
+ const T = b.createElementNS("http://www.w3.org/2000/svg", "a");
618
+ T.setAttributeNS("http://www.w3.org/2000/svg", "class", k.cssClasses), T.setAttributeNS("http://www.w3.org/2000/svg", "rel", "noopener"), n === "sandbox" ? T.setAttributeNS("http://www.w3.org/2000/svg", "target", "_top") : k.linkTarget && T.setAttributeNS("http://www.w3.org/2000/svg", "target", k.linkTarget);
619
+ const d1 = x.insert(function() {
620
+ return T;
621
+ }, ":first-child"), W = x.select(".label-container");
622
+ W && d1.append(function() {
623
+ return W.node();
624
+ });
625
+ const J = x.select(".label");
626
+ J && d1.append(function() {
627
+ return J.node();
628
+ });
629
+ }
630
+ }, "draw"), be = {
631
+ getClasses: fe,
632
+ draw: ge
633
+ }, rt = function() {
634
+ var s = /* @__PURE__ */ m(function(g1, h, d, p) {
635
+ for (d = d || {}, p = g1.length; p--; d[g1[p]] = h) ;
636
+ return d;
637
+ }, "o"), i = [1, 4], r = [1, 3], a = [1, 5], n = [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], g = [1, 13], c = [1, 14], b = [1, 15], u = [1, 16], A = [1, 23], y = [1, 25], f = [1, 26], k = [1, 27], x = [1, 49], T = [1, 48], d1 = [1, 29], W = [1, 30], J = [1, 31], O1 = [1, 32], M1 = [1, 33], V = [1, 44], w = [1, 46], I = [1, 42], R = [1, 47], N = [1, 43], G = [1, 50], P = [1, 45], O = [1, 51], M = [1, 52], U1 = [1, 34], W1 = [1, 35], z1 = [1, 36], j1 = [1, 37], p1 = [1, 57], F = [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], t1 = [1, 61], e1 = [1, 60], s1 = [1, 62], C1 = [8, 9, 11, 75, 77, 78], at = [1, 78], D1 = [1, 91], S1 = [1, 96], x1 = [1, 95], T1 = [1, 92], y1 = [1, 88], F1 = [1, 94], _1 = [1, 90], B1 = [1, 97], v1 = [1, 93], L1 = [1, 98], V1 = [1, 89], A1 = [8, 9, 10, 11, 40, 75, 77, 78], z = [8, 9, 10, 11, 40, 46, 75, 77, 78], q = [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], w1 = [44, 60, 89, 102, 105, 106, 109, 111, 114, 115, 116], ut = [1, 121], ot = [1, 122], K1 = [1, 124], Y1 = [1, 123], lt = [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], Et = [1, 144], Ct = [1, 145], Dt = [1, 146], St = [1, 151], xt = [1, 152], Tt = [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], Lt = [1, 154], Vt = [1, 156], v = [8, 9, 11], H = [8, 9, 10, 11, 14, 44, 60, 89, 105, 106, 109, 111, 114, 115, 116], E = [1, 176], j = [1, 172], K = [1, 173], C = [1, 177], D = [1, 174], S = [1, 175], I1 = [77, 116, 119], _ = [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], wt = [10, 106], f1 = [31, 49, 51, 53, 55, 57, 62, 64, 66, 67, 69, 71, 116, 117, 118], i1 = [1, 247], r1 = [1, 245], a1 = [1, 249], n1 = [1, 243], u1 = [1, 244], o1 = [1, 246], l1 = [1, 248], c1 = [1, 250], R1 = [1, 268], It = [8, 9, 11, 106], Z = [8, 9, 10, 11, 60, 84, 105, 106, 109, 110, 111, 112], J1 = {
638
+ trace: /* @__PURE__ */ m(function() {
639
+ }, "trace"),
640
+ yy: {},
641
+ 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 },
642
+ 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" },
643
+ 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]],
644
+ performAction: /* @__PURE__ */ m(function(h, d, p, o, B, t, P1) {
645
+ var e = t.length - 1;
646
+ switch (B) {
647
+ case 2:
648
+ this.$ = [];
649
+ break;
650
+ case 3:
651
+ (!Array.isArray(t[e]) || t[e].length > 0) && t[e - 1].push(t[e]), this.$ = t[e - 1];
652
+ break;
653
+ case 4:
654
+ case 183:
655
+ this.$ = t[e];
656
+ break;
657
+ case 11:
658
+ o.setDirection("TB"), this.$ = "TB";
659
+ break;
660
+ case 12:
661
+ o.setDirection(t[e - 1]), this.$ = t[e - 1];
662
+ break;
663
+ case 27:
664
+ this.$ = t[e - 1].nodes;
665
+ break;
666
+ case 28:
667
+ case 29:
668
+ case 30:
669
+ case 31:
670
+ case 32:
671
+ this.$ = [];
672
+ break;
673
+ case 33:
674
+ this.$ = o.addSubGraph(t[e - 6], t[e - 1], t[e - 4]);
675
+ break;
676
+ case 34:
677
+ this.$ = o.addSubGraph(t[e - 3], t[e - 1], t[e - 3]);
678
+ break;
679
+ case 35:
680
+ this.$ = o.addSubGraph(void 0, t[e - 1], void 0);
681
+ break;
682
+ case 37:
683
+ this.$ = t[e].trim(), o.setAccTitle(this.$);
684
+ break;
685
+ case 38:
686
+ case 39:
687
+ this.$ = t[e].trim(), o.setAccDescription(this.$);
688
+ break;
689
+ case 43:
690
+ this.$ = t[e - 1] + t[e];
691
+ break;
692
+ case 44:
693
+ this.$ = t[e];
694
+ break;
695
+ case 45:
696
+ 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) };
697
+ break;
698
+ case 46:
699
+ o.addLink(t[e - 2].stmt, t[e], t[e - 1]), this.$ = { stmt: t[e], nodes: t[e].concat(t[e - 2].nodes) };
700
+ break;
701
+ case 47:
702
+ 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) };
703
+ break;
704
+ case 48:
705
+ this.$ = { stmt: t[e - 1], nodes: t[e - 1] };
706
+ break;
707
+ case 49:
708
+ 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] };
709
+ break;
710
+ case 50:
711
+ this.$ = { stmt: t[e], nodes: t[e] };
712
+ break;
713
+ case 51:
714
+ this.$ = [t[e]];
715
+ break;
716
+ case 52:
717
+ 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]);
718
+ break;
719
+ case 53:
720
+ this.$ = t[e - 4].concat(t[e]);
721
+ break;
722
+ case 54:
723
+ this.$ = t[e];
724
+ break;
725
+ case 55:
726
+ this.$ = t[e - 2], o.setClass(t[e - 2], t[e]);
727
+ break;
728
+ case 56:
729
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "square");
730
+ break;
731
+ case 57:
732
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "doublecircle");
733
+ break;
734
+ case 58:
735
+ this.$ = t[e - 5], o.addVertex(t[e - 5], t[e - 2], "circle");
736
+ break;
737
+ case 59:
738
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "ellipse");
739
+ break;
740
+ case 60:
741
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "stadium");
742
+ break;
743
+ case 61:
744
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "subroutine");
745
+ break;
746
+ case 62:
747
+ 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]]]));
748
+ break;
749
+ case 63:
750
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "cylinder");
751
+ break;
752
+ case 64:
753
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "round");
754
+ break;
755
+ case 65:
756
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "diamond");
757
+ break;
758
+ case 66:
759
+ this.$ = t[e - 5], o.addVertex(t[e - 5], t[e - 2], "hexagon");
760
+ break;
761
+ case 67:
762
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "odd");
763
+ break;
764
+ case 68:
765
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "trapezoid");
766
+ break;
767
+ case 69:
768
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "inv_trapezoid");
769
+ break;
770
+ case 70:
771
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "lean_right");
772
+ break;
773
+ case 71:
774
+ this.$ = t[e - 3], o.addVertex(t[e - 3], t[e - 1], "lean_left");
775
+ break;
776
+ case 72:
777
+ this.$ = t[e], o.addVertex(t[e]);
778
+ break;
779
+ case 73:
780
+ t[e - 1].text = t[e], this.$ = t[e - 1];
781
+ break;
782
+ case 74:
783
+ case 75:
784
+ t[e - 2].text = t[e - 1], this.$ = t[e - 2];
785
+ break;
786
+ case 76:
787
+ this.$ = t[e];
788
+ break;
789
+ case 77:
790
+ var L = o.destructLink(t[e], t[e - 2]);
791
+ this.$ = { type: L.type, stroke: L.stroke, length: L.length, text: t[e - 1] };
792
+ break;
793
+ case 78:
794
+ var L = o.destructLink(t[e], t[e - 2]);
795
+ this.$ = { type: L.type, stroke: L.stroke, length: L.length, text: t[e - 1], id: t[e - 3] };
796
+ break;
797
+ case 79:
798
+ this.$ = { text: t[e], type: "text" };
799
+ break;
800
+ case 80:
801
+ this.$ = { text: t[e - 1].text + "" + t[e], type: t[e - 1].type };
802
+ break;
803
+ case 81:
804
+ this.$ = { text: t[e], type: "string" };
805
+ break;
806
+ case 82:
807
+ this.$ = { text: t[e], type: "markdown" };
808
+ break;
809
+ case 83:
810
+ var L = o.destructLink(t[e]);
811
+ this.$ = { type: L.type, stroke: L.stroke, length: L.length };
812
+ break;
813
+ case 84:
814
+ var L = o.destructLink(t[e]);
815
+ this.$ = { type: L.type, stroke: L.stroke, length: L.length, id: t[e - 1] };
816
+ break;
817
+ case 85:
818
+ this.$ = t[e - 1];
819
+ break;
820
+ case 86:
821
+ this.$ = { text: t[e], type: "text" };
822
+ break;
823
+ case 87:
824
+ this.$ = { text: t[e - 1].text + "" + t[e], type: t[e - 1].type };
825
+ break;
826
+ case 88:
827
+ this.$ = { text: t[e], type: "string" };
828
+ break;
829
+ case 89:
830
+ case 104:
831
+ this.$ = { text: t[e], type: "markdown" };
832
+ break;
833
+ case 101:
834
+ this.$ = { text: t[e], type: "text" };
835
+ break;
836
+ case 102:
837
+ this.$ = { text: t[e - 1].text + "" + t[e], type: t[e - 1].type };
838
+ break;
839
+ case 103:
840
+ this.$ = { text: t[e], type: "text" };
841
+ break;
842
+ case 105:
843
+ this.$ = t[e - 4], o.addClass(t[e - 2], t[e]);
844
+ break;
845
+ case 106:
846
+ this.$ = t[e - 4], o.setClass(t[e - 2], t[e]);
847
+ break;
848
+ case 107:
849
+ case 115:
850
+ this.$ = t[e - 1], o.setClickEvent(t[e - 1], t[e]);
851
+ break;
852
+ case 108:
853
+ case 116:
854
+ this.$ = t[e - 3], o.setClickEvent(t[e - 3], t[e - 2]), o.setTooltip(t[e - 3], t[e]);
855
+ break;
856
+ case 109:
857
+ this.$ = t[e - 2], o.setClickEvent(t[e - 2], t[e - 1], t[e]);
858
+ break;
859
+ case 110:
860
+ this.$ = t[e - 4], o.setClickEvent(t[e - 4], t[e - 3], t[e - 2]), o.setTooltip(t[e - 4], t[e]);
861
+ break;
862
+ case 111:
863
+ this.$ = t[e - 2], o.setLink(t[e - 2], t[e]);
864
+ break;
865
+ case 112:
866
+ this.$ = t[e - 4], o.setLink(t[e - 4], t[e - 2]), o.setTooltip(t[e - 4], t[e]);
867
+ break;
868
+ case 113:
869
+ this.$ = t[e - 4], o.setLink(t[e - 4], t[e - 2], t[e]);
870
+ break;
871
+ case 114:
872
+ this.$ = t[e - 6], o.setLink(t[e - 6], t[e - 4], t[e]), o.setTooltip(t[e - 6], t[e - 2]);
873
+ break;
874
+ case 117:
875
+ this.$ = t[e - 1], o.setLink(t[e - 1], t[e]);
876
+ break;
877
+ case 118:
878
+ this.$ = t[e - 3], o.setLink(t[e - 3], t[e - 2]), o.setTooltip(t[e - 3], t[e]);
879
+ break;
880
+ case 119:
881
+ this.$ = t[e - 3], o.setLink(t[e - 3], t[e - 2], t[e]);
882
+ break;
883
+ case 120:
884
+ this.$ = t[e - 5], o.setLink(t[e - 5], t[e - 4], t[e]), o.setTooltip(t[e - 5], t[e - 2]);
885
+ break;
886
+ case 121:
887
+ this.$ = t[e - 4], o.addVertex(t[e - 2], void 0, void 0, t[e]);
888
+ break;
889
+ case 122:
890
+ this.$ = t[e - 4], o.updateLink([t[e - 2]], t[e]);
891
+ break;
892
+ case 123:
893
+ this.$ = t[e - 4], o.updateLink(t[e - 2], t[e]);
894
+ break;
895
+ case 124:
896
+ this.$ = t[e - 8], o.updateLinkInterpolate([t[e - 6]], t[e - 2]), o.updateLink([t[e - 6]], t[e]);
897
+ break;
898
+ case 125:
899
+ this.$ = t[e - 8], o.updateLinkInterpolate(t[e - 6], t[e - 2]), o.updateLink(t[e - 6], t[e]);
900
+ break;
901
+ case 126:
902
+ this.$ = t[e - 6], o.updateLinkInterpolate([t[e - 4]], t[e]);
903
+ break;
904
+ case 127:
905
+ this.$ = t[e - 6], o.updateLinkInterpolate(t[e - 4], t[e]);
906
+ break;
907
+ case 128:
908
+ case 130:
909
+ this.$ = [t[e]];
910
+ break;
911
+ case 129:
912
+ case 131:
913
+ t[e - 2].push(t[e]), this.$ = t[e - 2];
914
+ break;
915
+ case 133:
916
+ this.$ = t[e - 1] + t[e];
917
+ break;
918
+ case 181:
919
+ this.$ = t[e];
920
+ break;
921
+ case 182:
922
+ this.$ = t[e - 1] + "" + t[e];
923
+ break;
924
+ case 184:
925
+ this.$ = t[e - 1] + "" + t[e];
926
+ break;
927
+ case 185:
928
+ this.$ = { stmt: "dir", value: "TB" };
929
+ break;
930
+ case 186:
931
+ this.$ = { stmt: "dir", value: "BT" };
932
+ break;
933
+ case 187:
934
+ this.$ = { stmt: "dir", value: "RL" };
935
+ break;
936
+ case 188:
937
+ this.$ = { stmt: "dir", value: "LR" };
938
+ break;
939
+ }
940
+ }, "anonymous"),
941
+ table: [{ 3: 1, 4: 2, 9: i, 10: r, 12: a }, { 1: [3] }, s(n, l, { 5: 6 }), { 4: 7, 9: i, 10: r, 12: a }, { 4: 8, 9: i, 10: r, 12: a }, { 13: [1, 9], 14: [1, 10] }, { 1: [2, 1], 6: 11, 7: 12, 8: g, 9: c, 10: b, 11: u, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: A, 33: 24, 34: y, 36: f, 38: k, 42: 28, 43: 38, 44: x, 45: 39, 47: 40, 60: T, 84: d1, 85: W, 86: J, 87: O1, 88: M1, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M, 121: U1, 122: W1, 123: z1, 124: j1 }, s(n, [2, 9]), s(n, [2, 10]), s(n, [2, 11]), { 8: [1, 54], 9: [1, 55], 10: p1, 15: 53, 18: 56 }, s(F, [2, 3]), s(F, [2, 4]), s(F, [2, 5]), s(F, [2, 6]), s(F, [2, 7]), s(F, [2, 8]), { 8: t1, 9: e1, 11: s1, 21: 58, 41: 59, 72: 63, 75: [1, 64], 77: [1, 66], 78: [1, 65] }, { 8: t1, 9: e1, 11: s1, 21: 67 }, { 8: t1, 9: e1, 11: s1, 21: 68 }, { 8: t1, 9: e1, 11: s1, 21: 69 }, { 8: t1, 9: e1, 11: s1, 21: 70 }, { 8: t1, 9: e1, 11: s1, 21: 71 }, { 8: t1, 9: e1, 10: [1, 72], 11: s1, 21: 73 }, s(F, [2, 36]), { 35: [1, 74] }, { 37: [1, 75] }, s(F, [2, 39]), s(C1, [2, 50], { 18: 76, 39: 77, 10: p1, 40: at }), { 10: [1, 79] }, { 10: [1, 80] }, { 10: [1, 81] }, { 10: [1, 82] }, { 14: D1, 44: S1, 60: x1, 80: [1, 86], 89: T1, 95: [1, 83], 97: [1, 84], 101: 85, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: L1, 116: V1, 120: 87 }, s(F, [2, 185]), s(F, [2, 186]), s(F, [2, 187]), s(F, [2, 188]), s(A1, [2, 51]), s(A1, [2, 54], { 46: [1, 99] }), s(z, [2, 72], { 113: 112, 29: [1, 100], 44: x, 48: [1, 101], 50: [1, 102], 52: [1, 103], 54: [1, 104], 56: [1, 105], 58: [1, 106], 60: T, 63: [1, 107], 65: [1, 108], 67: [1, 109], 68: [1, 110], 70: [1, 111], 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 114: P, 115: O, 116: M }), s(q, [2, 181]), s(q, [2, 142]), s(q, [2, 143]), s(q, [2, 144]), s(q, [2, 145]), s(q, [2, 146]), s(q, [2, 147]), s(q, [2, 148]), s(q, [2, 149]), s(q, [2, 150]), s(q, [2, 151]), s(q, [2, 152]), s(n, [2, 12]), s(n, [2, 18]), s(n, [2, 19]), { 9: [1, 113] }, s(nt, [2, 26], { 18: 114, 10: p1 }), s(F, [2, 27]), { 42: 115, 43: 38, 44: x, 45: 39, 47: 40, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, s(F, [2, 40]), s(F, [2, 41]), s(F, [2, 42]), s(w1, [2, 76], { 73: 116, 62: [1, 118], 74: [1, 117] }), { 76: 119, 79: 120, 80: ut, 81: ot, 116: K1, 119: Y1 }, { 75: [1, 125], 77: [1, 126] }, s(lt, [2, 83]), s(F, [2, 28]), s(F, [2, 29]), s(F, [2, 30]), s(F, [2, 31]), s(F, [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: Et, 87: Ct, 88: Dt, 89: St, 90: xt, 91: 128, 105: Tt, 109: yt, 111: Ft, 114: _t, 115: Bt, 116: vt }, s(Q1, l, { 5: 153 }), s(F, [2, 37]), s(F, [2, 38]), s(C1, [2, 48], { 44: Lt }), s(C1, [2, 49], { 18: 155, 10: p1, 40: Vt }), s(A1, [2, 44]), { 44: x, 47: 157, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, { 102: [1, 158], 103: 159, 105: [1, 160] }, { 44: x, 47: 161, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, { 44: x, 47: 162, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, s(v, [2, 107], { 10: [1, 163], 96: [1, 164] }), { 80: [1, 165] }, s(v, [2, 115], { 120: 167, 10: [1, 166], 14: D1, 44: S1, 60: x1, 89: T1, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: L1, 116: V1 }), s(v, [2, 117], { 10: [1, 168] }), s(H, [2, 183]), s(H, [2, 170]), s(H, [2, 171]), s(H, [2, 172]), s(H, [2, 173]), s(H, [2, 174]), s(H, [2, 175]), s(H, [2, 176]), s(H, [2, 177]), s(H, [2, 178]), s(H, [2, 179]), s(H, [2, 180]), { 44: x, 47: 169, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, { 30: 170, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 178, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 180, 50: [1, 179], 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 181, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 182, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 183, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 109: [1, 184] }, { 30: 185, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 186, 65: [1, 187], 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 188, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 189, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 30: 190, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, s(q, [2, 182]), s(n, [2, 20]), s(nt, [2, 25]), s(C1, [2, 46], { 39: 191, 18: 192, 10: p1, 40: at }), s(w1, [2, 73], { 10: [1, 193] }), { 10: [1, 194] }, { 30: 195, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 77: [1, 196], 79: 197, 116: K1, 119: Y1 }, s(I1, [2, 79]), s(I1, [2, 81]), s(I1, [2, 82]), s(I1, [2, 168]), s(I1, [2, 169]), { 76: 198, 79: 120, 80: ut, 81: ot, 116: K1, 119: Y1 }, s(lt, [2, 84]), { 8: t1, 9: e1, 10: ct, 11: s1, 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: Et, 87: Ct, 88: Dt, 89: St, 90: xt, 91: 201, 105: Tt, 109: yt, 111: Ft, 114: _t, 115: Bt, 116: vt }, s(_, [2, 101]), s(_, [2, 103]), s(_, [2, 104]), s(_, [2, 157]), s(_, [2, 158]), s(_, [2, 159]), s(_, [2, 160]), s(_, [2, 161]), s(_, [2, 162]), s(_, [2, 163]), s(_, [2, 164]), s(_, [2, 165]), s(_, [2, 166]), s(_, [2, 167]), s(_, [2, 90]), s(_, [2, 91]), s(_, [2, 92]), s(_, [2, 93]), s(_, [2, 94]), s(_, [2, 95]), s(_, [2, 96]), s(_, [2, 97]), s(_, [2, 98]), s(_, [2, 99]), s(_, [2, 100]), { 6: 11, 7: 12, 8: g, 9: c, 10: b, 11: u, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: A, 32: [1, 202], 33: 24, 34: y, 36: f, 38: k, 42: 28, 43: 38, 44: x, 45: 39, 47: 40, 60: T, 84: d1, 85: W, 86: J, 87: O1, 88: M1, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M, 121: U1, 122: W1, 123: z1, 124: j1 }, { 10: p1, 18: 203 }, { 44: [1, 204] }, s(A1, [2, 43]), { 10: [1, 205], 44: x, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 112, 114: P, 115: O, 116: M }, { 10: [1, 206] }, { 10: [1, 207], 106: [1, 208] }, s(wt, [2, 128]), { 10: [1, 209], 44: x, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 112, 114: P, 115: O, 116: M }, { 10: [1, 210], 44: x, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 112, 114: P, 115: O, 116: M }, { 80: [1, 211] }, s(v, [2, 109], { 10: [1, 212] }), s(v, [2, 111], { 10: [1, 213] }), { 80: [1, 214] }, s(H, [2, 184]), { 80: [1, 215], 98: [1, 216] }, s(A1, [2, 55], { 113: 112, 44: x, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 114: P, 115: O, 116: M }), { 31: [1, 217], 67: E, 82: 218, 116: C, 117: D, 118: S }, s(f1, [2, 86]), s(f1, [2, 88]), s(f1, [2, 89]), s(f1, [2, 153]), s(f1, [2, 154]), s(f1, [2, 155]), s(f1, [2, 156]), { 49: [1, 219], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 30: 220, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 51: [1, 221], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 53: [1, 222], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 55: [1, 223], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 57: [1, 224], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 60: [1, 225] }, { 64: [1, 226], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 66: [1, 227], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 30: 228, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, { 31: [1, 229], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 67: E, 69: [1, 230], 71: [1, 231], 82: 218, 116: C, 117: D, 118: S }, { 67: E, 69: [1, 233], 71: [1, 232], 82: 218, 116: C, 117: D, 118: S }, s(C1, [2, 45], { 18: 155, 10: p1, 40: Vt }), s(C1, [2, 47], { 44: Lt }), s(w1, [2, 75]), s(w1, [2, 74]), { 62: [1, 234], 67: E, 82: 218, 116: C, 117: D, 118: S }, s(w1, [2, 77]), s(I1, [2, 80]), { 77: [1, 235], 79: 197, 116: K1, 119: Y1 }, { 30: 236, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, s(Q1, l, { 5: 237 }), s(_, [2, 102]), s(F, [2, 35]), { 43: 238, 44: x, 45: 39, 47: 40, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, { 10: p1, 18: 239 }, { 10: i1, 60: r1, 84: a1, 92: 240, 105: n1, 107: 241, 108: 242, 109: u1, 110: o1, 111: l1, 112: c1 }, { 10: i1, 60: r1, 84: a1, 92: 251, 104: [1, 252], 105: n1, 107: 241, 108: 242, 109: u1, 110: o1, 111: l1, 112: c1 }, { 10: i1, 60: r1, 84: a1, 92: 253, 104: [1, 254], 105: n1, 107: 241, 108: 242, 109: u1, 110: o1, 111: l1, 112: c1 }, { 105: [1, 255] }, { 10: i1, 60: r1, 84: a1, 92: 256, 105: n1, 107: 241, 108: 242, 109: u1, 110: o1, 111: l1, 112: c1 }, { 44: x, 47: 257, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, s(v, [2, 108]), { 80: [1, 258] }, { 80: [1, 259], 98: [1, 260] }, s(v, [2, 116]), s(v, [2, 118], { 10: [1, 261] }), s(v, [2, 119]), s(z, [2, 56]), s(f1, [2, 87]), s(z, [2, 57]), { 51: [1, 262], 67: E, 82: 218, 116: C, 117: D, 118: S }, s(z, [2, 64]), s(z, [2, 59]), s(z, [2, 60]), s(z, [2, 61]), { 109: [1, 263] }, s(z, [2, 63]), s(z, [2, 65]), { 66: [1, 264], 67: E, 82: 218, 116: C, 117: D, 118: S }, s(z, [2, 67]), s(z, [2, 68]), s(z, [2, 70]), s(z, [2, 69]), s(z, [2, 71]), s([10, 44, 60, 89, 102, 105, 106, 109, 111, 114, 115, 116], [2, 85]), s(w1, [2, 78]), { 31: [1, 265], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 6: 11, 7: 12, 8: g, 9: c, 10: b, 11: u, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: A, 32: [1, 266], 33: 24, 34: y, 36: f, 38: k, 42: 28, 43: 38, 44: x, 45: 39, 47: 40, 60: T, 84: d1, 85: W, 86: J, 87: O1, 88: M1, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M, 121: U1, 122: W1, 123: z1, 124: j1 }, s(A1, [2, 53]), { 43: 267, 44: x, 45: 39, 47: 40, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M }, s(v, [2, 121], { 106: R1 }), s(It, [2, 130], { 108: 269, 10: i1, 60: r1, 84: a1, 105: n1, 109: u1, 110: o1, 111: l1, 112: c1 }), s(Z, [2, 132]), s(Z, [2, 134]), s(Z, [2, 135]), s(Z, [2, 136]), s(Z, [2, 137]), s(Z, [2, 138]), s(Z, [2, 139]), s(Z, [2, 140]), s(Z, [2, 141]), s(v, [2, 122], { 106: R1 }), { 10: [1, 270] }, s(v, [2, 123], { 106: R1 }), { 10: [1, 271] }, s(wt, [2, 129]), s(v, [2, 105], { 106: R1 }), s(v, [2, 106], { 113: 112, 44: x, 60: T, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 114: P, 115: O, 116: M }), s(v, [2, 110]), s(v, [2, 112], { 10: [1, 272] }), s(v, [2, 113]), { 98: [1, 273] }, { 51: [1, 274] }, { 62: [1, 275] }, { 66: [1, 276] }, { 8: t1, 9: e1, 11: s1, 21: 277 }, s(F, [2, 34]), s(A1, [2, 52]), { 10: i1, 60: r1, 84: a1, 105: n1, 107: 278, 108: 242, 109: u1, 110: o1, 111: l1, 112: c1 }, s(Z, [2, 133]), { 14: D1, 44: S1, 60: x1, 89: T1, 101: 279, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: L1, 116: V1, 120: 87 }, { 14: D1, 44: S1, 60: x1, 89: T1, 101: 280, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: L1, 116: V1, 120: 87 }, { 98: [1, 281] }, s(v, [2, 120]), s(z, [2, 58]), { 30: 282, 67: E, 80: j, 81: K, 82: 171, 116: C, 117: D, 118: S }, s(z, [2, 66]), s(Q1, l, { 5: 283 }), s(It, [2, 131], { 108: 269, 10: i1, 60: r1, 84: a1, 105: n1, 109: u1, 110: o1, 111: l1, 112: c1 }), s(v, [2, 126], { 120: 167, 10: [1, 284], 14: D1, 44: S1, 60: x1, 89: T1, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: L1, 116: V1 }), s(v, [2, 127], { 120: 167, 10: [1, 285], 14: D1, 44: S1, 60: x1, 89: T1, 105: y1, 106: F1, 109: _1, 111: B1, 114: v1, 115: L1, 116: V1 }), s(v, [2, 114]), { 31: [1, 286], 67: E, 82: 218, 116: C, 117: D, 118: S }, { 6: 11, 7: 12, 8: g, 9: c, 10: b, 11: u, 20: 17, 22: 18, 23: 19, 24: 20, 25: 21, 26: 22, 27: A, 32: [1, 287], 33: 24, 34: y, 36: f, 38: k, 42: 28, 43: 38, 44: x, 45: 39, 47: 40, 60: T, 84: d1, 85: W, 86: J, 87: O1, 88: M1, 89: V, 102: w, 105: I, 106: R, 109: N, 111: G, 113: 41, 114: P, 115: O, 116: M, 121: U1, 122: W1, 123: z1, 124: j1 }, { 10: i1, 60: r1, 84: a1, 92: 288, 105: n1, 107: 241, 108: 242, 109: u1, 110: o1, 111: l1, 112: c1 }, { 10: i1, 60: r1, 84: a1, 92: 289, 105: n1, 107: 241, 108: 242, 109: u1, 110: o1, 111: l1, 112: c1 }, s(z, [2, 62]), s(F, [2, 33]), s(v, [2, 124], { 106: R1 }), s(v, [2, 125], { 106: R1 })],
942
+ defaultActions: {},
943
+ parseError: /* @__PURE__ */ m(function(h, d) {
944
+ if (d.recoverable)
945
+ this.trace(h);
946
+ else {
947
+ var p = new Error(h);
948
+ throw p.hash = d, p;
949
+ }
950
+ }, "parseError"),
951
+ parse: /* @__PURE__ */ m(function(h) {
952
+ var d = this, p = [0], o = [], B = [null], t = [], P1 = this.table, e = "", L = 0, Rt = 0, zt = 2, Nt = 1, jt = t.slice.call(arguments, 1), U = Object.create(this.lexer), k1 = { yy: {} };
953
+ for (var Z1 in this.yy)
954
+ Object.prototype.hasOwnProperty.call(this.yy, Z1) && (k1.yy[Z1] = this.yy[Z1]);
955
+ U.setInput(h, k1.yy), k1.yy.lexer = U, k1.yy.parser = this, typeof U.yylloc > "u" && (U.yylloc = {});
956
+ var $1 = U.yylloc;
957
+ t.push($1);
958
+ var Kt = U.options && U.options.ranges;
959
+ typeof k1.yy.parseError == "function" ? this.parseError = k1.yy.parseError : this.parseError = Object.getPrototypeOf(this).parseError;
960
+ function Yt(X) {
961
+ p.length = p.length - 2 * X, B.length = B.length - X, t.length = t.length - X;
962
+ }
963
+ m(Yt, "popStack");
964
+ function Gt() {
965
+ var X;
966
+ return X = o.pop() || U.lex() || Nt, typeof X != "number" && (X instanceof Array && (o = X, X = o.pop()), X = d.symbols_[X] || X), X;
967
+ }
968
+ m(Gt, "lex");
969
+ for (var Y, m1, Q, tt, N1 = {}, H1, h1, Pt, X1; ; ) {
970
+ if (m1 = p[p.length - 1], this.defaultActions[m1] ? Q = this.defaultActions[m1] : ((Y === null || typeof Y > "u") && (Y = Gt()), Q = P1[m1] && P1[m1][Y]), typeof Q > "u" || !Q.length || !Q[0]) {
971
+ var et = "";
972
+ X1 = [];
973
+ for (H1 in P1[m1])
974
+ this.terminals_[H1] && H1 > zt && X1.push("'" + this.terminals_[H1] + "'");
975
+ U.showPosition ? et = "Parse error on line " + (L + 1) + `:
976
+ ` + U.showPosition() + `
977
+ Expecting ` + X1.join(", ") + ", got '" + (this.terminals_[Y] || Y) + "'" : et = "Parse error on line " + (L + 1) + ": Unexpected " + (Y == Nt ? "end of input" : "'" + (this.terminals_[Y] || Y) + "'"), this.parseError(et, {
978
+ text: U.match,
979
+ token: this.terminals_[Y] || Y,
980
+ line: U.yylineno,
981
+ loc: $1,
982
+ expected: X1
983
+ });
984
+ }
985
+ if (Q[0] instanceof Array && Q.length > 1)
986
+ throw new Error("Parse Error: multiple actions possible at state: " + m1 + ", token: " + Y);
987
+ switch (Q[0]) {
988
+ case 1:
989
+ p.push(Y), B.push(U.yytext), t.push(U.yylloc), p.push(Q[1]), Y = null, Rt = U.yyleng, e = U.yytext, L = U.yylineno, $1 = U.yylloc;
990
+ break;
991
+ case 2:
992
+ if (h1 = this.productions_[Q[1]][1], N1.$ = B[B.length - h1], N1._$ = {
993
+ first_line: t[t.length - (h1 || 1)].first_line,
994
+ last_line: t[t.length - 1].last_line,
995
+ first_column: t[t.length - (h1 || 1)].first_column,
996
+ last_column: t[t.length - 1].last_column
997
+ }, Kt && (N1._$.range = [
998
+ t[t.length - (h1 || 1)].range[0],
999
+ t[t.length - 1].range[1]
1000
+ ]), tt = this.performAction.apply(N1, [
1001
+ e,
1002
+ Rt,
1003
+ L,
1004
+ k1.yy,
1005
+ Q[1],
1006
+ B,
1007
+ t
1008
+ ].concat(jt)), typeof tt < "u")
1009
+ return tt;
1010
+ h1 && (p = p.slice(0, -1 * h1 * 2), B = B.slice(0, -1 * h1), t = t.slice(0, -1 * h1)), p.push(this.productions_[Q[1]][0]), B.push(N1.$), t.push(N1._$), Pt = P1[p[p.length - 2]][p[p.length - 1]], p.push(Pt);
1011
+ break;
1012
+ case 3:
1013
+ return !0;
1014
+ }
1015
+ }
1016
+ return !0;
1017
+ }, "parse")
1018
+ }, Wt = /* @__PURE__ */ function() {
1019
+ var g1 = {
1020
+ EOF: 1,
1021
+ parseError: /* @__PURE__ */ m(function(d, p) {
1022
+ if (this.yy.parser)
1023
+ this.yy.parser.parseError(d, p);
1024
+ else
1025
+ throw new Error(d);
1026
+ }, "parseError"),
1027
+ // resets the lexer, sets new input
1028
+ setInput: /* @__PURE__ */ m(function(h, d) {
1029
+ return this.yy = d || 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 = {
1030
+ first_line: 1,
1031
+ first_column: 0,
1032
+ last_line: 1,
1033
+ last_column: 0
1034
+ }, this.options.ranges && (this.yylloc.range = [0, 0]), this.offset = 0, this;
1035
+ }, "setInput"),
1036
+ // consumes and returns one char from the input
1037
+ input: /* @__PURE__ */ m(function() {
1038
+ var h = this._input[0];
1039
+ this.yytext += h, this.yyleng++, this.offset++, this.match += h, this.matched += h;
1040
+ var d = h.match(/(?:\r\n?|\n).*/g);
1041
+ return d ? (this.yylineno++, this.yylloc.last_line++) : this.yylloc.last_column++, this.options.ranges && this.yylloc.range[1]++, this._input = this._input.slice(1), h;
1042
+ }, "input"),
1043
+ // unshifts one char (or a string) into the input
1044
+ unput: /* @__PURE__ */ m(function(h) {
1045
+ var d = h.length, p = h.split(/(?:\r\n?|\n)/g);
1046
+ this._input = h + this._input, this.yytext = this.yytext.substr(0, this.yytext.length - d), this.offset -= d;
1047
+ var o = this.match.split(/(?:\r\n?|\n)/g);
1048
+ this.match = this.match.substr(0, this.match.length - 1), this.matched = this.matched.substr(0, this.matched.length - 1), p.length - 1 && (this.yylineno -= p.length - 1);
1049
+ var B = this.yylloc.range;
1050
+ return this.yylloc = {
1051
+ first_line: this.yylloc.first_line,
1052
+ last_line: this.yylineno + 1,
1053
+ first_column: this.yylloc.first_column,
1054
+ last_column: p ? (p.length === o.length ? this.yylloc.first_column : 0) + o[o.length - p.length].length - p[0].length : this.yylloc.first_column - d
1055
+ }, this.options.ranges && (this.yylloc.range = [B[0], B[0] + this.yyleng - d]), this.yyleng = this.yytext.length, this;
1056
+ }, "unput"),
1057
+ // When called from action, caches matched text and appends it on next action
1058
+ more: /* @__PURE__ */ m(function() {
1059
+ return this._more = !0, this;
1060
+ }, "more"),
1061
+ // 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.
1062
+ reject: /* @__PURE__ */ m(function() {
1063
+ if (this.options.backtrack_lexer)
1064
+ this._backtrack = !0;
1065
+ else
1066
+ 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).
1067
+ ` + this.showPosition(), {
1068
+ text: "",
1069
+ token: null,
1070
+ line: this.yylineno
1071
+ });
1072
+ return this;
1073
+ }, "reject"),
1074
+ // retain first n characters of the match
1075
+ less: /* @__PURE__ */ m(function(h) {
1076
+ this.unput(this.match.slice(h));
1077
+ }, "less"),
1078
+ // displays already matched input, i.e. for error messages
1079
+ pastInput: /* @__PURE__ */ m(function() {
1080
+ var h = this.matched.substr(0, this.matched.length - this.match.length);
1081
+ return (h.length > 20 ? "..." : "") + h.substr(-20).replace(/\n/g, "");
1082
+ }, "pastInput"),
1083
+ // displays upcoming input, i.e. for error messages
1084
+ upcomingInput: /* @__PURE__ */ m(function() {
1085
+ var h = this.match;
1086
+ return h.length < 20 && (h += this._input.substr(0, 20 - h.length)), (h.substr(0, 20) + (h.length > 20 ? "..." : "")).replace(/\n/g, "");
1087
+ }, "upcomingInput"),
1088
+ // displays the character position where the lexing error occurred, i.e. for error messages
1089
+ showPosition: /* @__PURE__ */ m(function() {
1090
+ var h = this.pastInput(), d = new Array(h.length + 1).join("-");
1091
+ return h + this.upcomingInput() + `
1092
+ ` + d + "^";
1093
+ }, "showPosition"),
1094
+ // test the lexed token: return FALSE when not a match, otherwise return token
1095
+ test_match: /* @__PURE__ */ m(function(h, d) {
1096
+ var p, o, B;
1097
+ if (this.options.backtrack_lexer && (B = {
1098
+ yylineno: this.yylineno,
1099
+ yylloc: {
1100
+ first_line: this.yylloc.first_line,
1101
+ last_line: this.last_line,
1102
+ first_column: this.yylloc.first_column,
1103
+ last_column: this.yylloc.last_column
1104
+ },
1105
+ yytext: this.yytext,
1106
+ match: this.match,
1107
+ matches: this.matches,
1108
+ matched: this.matched,
1109
+ yyleng: this.yyleng,
1110
+ offset: this.offset,
1111
+ _more: this._more,
1112
+ _input: this._input,
1113
+ yy: this.yy,
1114
+ conditionStack: this.conditionStack.slice(0),
1115
+ done: this.done
1116
+ }, this.options.ranges && (B.yylloc.range = this.yylloc.range.slice(0))), o = h[0].match(/(?:\r\n?|\n).*/g), o && (this.yylineno += o.length), this.yylloc = {
1117
+ first_line: this.yylloc.last_line,
1118
+ last_line: this.yylineno + 1,
1119
+ first_column: this.yylloc.last_column,
1120
+ last_column: o ? o[o.length - 1].length - o[o.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + h[0].length
1121
+ }, 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], p = this.performAction.call(this, this.yy, this, d, this.conditionStack[this.conditionStack.length - 1]), this.done && this._input && (this.done = !1), p)
1122
+ return p;
1123
+ if (this._backtrack) {
1124
+ for (var t in B)
1125
+ this[t] = B[t];
1126
+ return !1;
1127
+ }
1128
+ return !1;
1129
+ }, "test_match"),
1130
+ // return next match in input
1131
+ next: /* @__PURE__ */ m(function() {
1132
+ if (this.done)
1133
+ return this.EOF;
1134
+ this._input || (this.done = !0);
1135
+ var h, d, p, o;
1136
+ this._more || (this.yytext = "", this.match = "");
1137
+ for (var B = this._currentRules(), t = 0; t < B.length; t++)
1138
+ if (p = this._input.match(this.rules[B[t]]), p && (!d || p[0].length > d[0].length)) {
1139
+ if (d = p, o = t, this.options.backtrack_lexer) {
1140
+ if (h = this.test_match(p, B[t]), h !== !1)
1141
+ return h;
1142
+ if (this._backtrack) {
1143
+ d = !1;
1144
+ continue;
1145
+ } else
1146
+ return !1;
1147
+ } else if (!this.options.flex)
1148
+ break;
1149
+ }
1150
+ return d ? (h = this.test_match(d, B[o]), h !== !1 ? h : !1) : this._input === "" ? this.EOF : this.parseError("Lexical error on line " + (this.yylineno + 1) + `. Unrecognized text.
1151
+ ` + this.showPosition(), {
1152
+ text: "",
1153
+ token: null,
1154
+ line: this.yylineno
1155
+ });
1156
+ }, "next"),
1157
+ // return next match that has a token
1158
+ lex: /* @__PURE__ */ m(function() {
1159
+ var d = this.next();
1160
+ return d || this.lex();
1161
+ }, "lex"),
1162
+ // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)
1163
+ begin: /* @__PURE__ */ m(function(d) {
1164
+ this.conditionStack.push(d);
1165
+ }, "begin"),
1166
+ // pop the previously active lexer condition state off the condition stack
1167
+ popState: /* @__PURE__ */ m(function() {
1168
+ var d = this.conditionStack.length - 1;
1169
+ return d > 0 ? this.conditionStack.pop() : this.conditionStack[0];
1170
+ }, "popState"),
1171
+ // produce the lexer rule set which is active for the currently active lexer condition state
1172
+ _currentRules: /* @__PURE__ */ m(function() {
1173
+ return this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1] ? this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules : this.conditions.INITIAL.rules;
1174
+ }, "_currentRules"),
1175
+ // return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available
1176
+ topState: /* @__PURE__ */ m(function(d) {
1177
+ return d = this.conditionStack.length - 1 - Math.abs(d || 0), d >= 0 ? this.conditionStack[d] : "INITIAL";
1178
+ }, "topState"),
1179
+ // alias for begin(condition)
1180
+ pushState: /* @__PURE__ */ m(function(d) {
1181
+ this.begin(d);
1182
+ }, "pushState"),
1183
+ // return the number of states currently on the stack
1184
+ stateStackSize: /* @__PURE__ */ m(function() {
1185
+ return this.conditionStack.length;
1186
+ }, "stateStackSize"),
1187
+ options: {},
1188
+ performAction: /* @__PURE__ */ m(function(d, p, o, B) {
1189
+ switch (o) {
1190
+ case 0:
1191
+ return this.begin("acc_title"), 34;
1192
+ case 1:
1193
+ return this.popState(), "acc_title_value";
1194
+ case 2:
1195
+ return this.begin("acc_descr"), 36;
1196
+ case 3:
1197
+ return this.popState(), "acc_descr_value";
1198
+ case 4:
1199
+ this.begin("acc_descr_multiline");
1200
+ break;
1201
+ case 5:
1202
+ this.popState();
1203
+ break;
1204
+ case 6:
1205
+ return "acc_descr_multiline_value";
1206
+ case 7:
1207
+ return this.pushState("shapeData"), p.yytext = "", 40;
1208
+ case 8:
1209
+ return this.pushState("shapeDataStr"), 40;
1210
+ case 9:
1211
+ return this.popState(), 40;
1212
+ case 10:
1213
+ const t = /\n\s*/g;
1214
+ return p.yytext = p.yytext.replace(t, "<br/>"), 40;
1215
+ case 11:
1216
+ return 40;
1217
+ case 12:
1218
+ this.popState();
1219
+ break;
1220
+ case 13:
1221
+ this.begin("callbackname");
1222
+ break;
1223
+ case 14:
1224
+ this.popState();
1225
+ break;
1226
+ case 15:
1227
+ this.popState(), this.begin("callbackargs");
1228
+ break;
1229
+ case 16:
1230
+ return 95;
1231
+ case 17:
1232
+ this.popState();
1233
+ break;
1234
+ case 18:
1235
+ return 96;
1236
+ case 19:
1237
+ return "MD_STR";
1238
+ case 20:
1239
+ this.popState();
1240
+ break;
1241
+ case 21:
1242
+ this.begin("md_string");
1243
+ break;
1244
+ case 22:
1245
+ return "STR";
1246
+ case 23:
1247
+ this.popState();
1248
+ break;
1249
+ case 24:
1250
+ this.pushState("string");
1251
+ break;
1252
+ case 25:
1253
+ return 84;
1254
+ case 26:
1255
+ return 102;
1256
+ case 27:
1257
+ return 85;
1258
+ case 28:
1259
+ return 104;
1260
+ case 29:
1261
+ return 86;
1262
+ case 30:
1263
+ return 87;
1264
+ case 31:
1265
+ return 97;
1266
+ case 32:
1267
+ this.begin("click");
1268
+ break;
1269
+ case 33:
1270
+ this.popState();
1271
+ break;
1272
+ case 34:
1273
+ return 88;
1274
+ case 35:
1275
+ return d.lex.firstGraph() && this.begin("dir"), 12;
1276
+ case 36:
1277
+ return d.lex.firstGraph() && this.begin("dir"), 12;
1278
+ case 37:
1279
+ return d.lex.firstGraph() && this.begin("dir"), 12;
1280
+ case 38:
1281
+ return 27;
1282
+ case 39:
1283
+ return 32;
1284
+ case 40:
1285
+ return 98;
1286
+ case 41:
1287
+ return 98;
1288
+ case 42:
1289
+ return 98;
1290
+ case 43:
1291
+ return 98;
1292
+ case 44:
1293
+ return this.popState(), 13;
1294
+ case 45:
1295
+ return this.popState(), 14;
1296
+ case 46:
1297
+ return this.popState(), 14;
1298
+ case 47:
1299
+ return this.popState(), 14;
1300
+ case 48:
1301
+ return this.popState(), 14;
1302
+ case 49:
1303
+ return this.popState(), 14;
1304
+ case 50:
1305
+ return this.popState(), 14;
1306
+ case 51:
1307
+ return this.popState(), 14;
1308
+ case 52:
1309
+ return this.popState(), 14;
1310
+ case 53:
1311
+ return this.popState(), 14;
1312
+ case 54:
1313
+ return this.popState(), 14;
1314
+ case 55:
1315
+ return 121;
1316
+ case 56:
1317
+ return 122;
1318
+ case 57:
1319
+ return 123;
1320
+ case 58:
1321
+ return 124;
1322
+ case 59:
1323
+ return 78;
1324
+ case 60:
1325
+ return 105;
1326
+ case 61:
1327
+ return 111;
1328
+ case 62:
1329
+ return 46;
1330
+ case 63:
1331
+ return 60;
1332
+ case 64:
1333
+ return 44;
1334
+ case 65:
1335
+ return 8;
1336
+ case 66:
1337
+ return 106;
1338
+ case 67:
1339
+ return 115;
1340
+ case 68:
1341
+ return this.popState(), 77;
1342
+ case 69:
1343
+ return this.pushState("edgeText"), 75;
1344
+ case 70:
1345
+ return 119;
1346
+ case 71:
1347
+ return this.popState(), 77;
1348
+ case 72:
1349
+ return this.pushState("thickEdgeText"), 75;
1350
+ case 73:
1351
+ return 119;
1352
+ case 74:
1353
+ return this.popState(), 77;
1354
+ case 75:
1355
+ return this.pushState("dottedEdgeText"), 75;
1356
+ case 76:
1357
+ return 119;
1358
+ case 77:
1359
+ return 77;
1360
+ case 78:
1361
+ return this.popState(), 53;
1362
+ case 79:
1363
+ return "TEXT";
1364
+ case 80:
1365
+ return this.pushState("ellipseText"), 52;
1366
+ case 81:
1367
+ return this.popState(), 55;
1368
+ case 82:
1369
+ return this.pushState("text"), 54;
1370
+ case 83:
1371
+ return this.popState(), 57;
1372
+ case 84:
1373
+ return this.pushState("text"), 56;
1374
+ case 85:
1375
+ return 58;
1376
+ case 86:
1377
+ return this.pushState("text"), 67;
1378
+ case 87:
1379
+ return this.popState(), 64;
1380
+ case 88:
1381
+ return this.pushState("text"), 63;
1382
+ case 89:
1383
+ return this.popState(), 49;
1384
+ case 90:
1385
+ return this.pushState("text"), 48;
1386
+ case 91:
1387
+ return this.popState(), 69;
1388
+ case 92:
1389
+ return this.popState(), 71;
1390
+ case 93:
1391
+ return 117;
1392
+ case 94:
1393
+ return this.pushState("trapText"), 68;
1394
+ case 95:
1395
+ return this.pushState("trapText"), 70;
1396
+ case 96:
1397
+ return 118;
1398
+ case 97:
1399
+ return 67;
1400
+ case 98:
1401
+ return 90;
1402
+ case 99:
1403
+ return "SEP";
1404
+ case 100:
1405
+ return 89;
1406
+ case 101:
1407
+ return 115;
1408
+ case 102:
1409
+ return 111;
1410
+ case 103:
1411
+ return 44;
1412
+ case 104:
1413
+ return 109;
1414
+ case 105:
1415
+ return 114;
1416
+ case 106:
1417
+ return 116;
1418
+ case 107:
1419
+ return this.popState(), 62;
1420
+ case 108:
1421
+ return this.pushState("text"), 62;
1422
+ case 109:
1423
+ return this.popState(), 51;
1424
+ case 110:
1425
+ return this.pushState("text"), 50;
1426
+ case 111:
1427
+ return this.popState(), 31;
1428
+ case 112:
1429
+ return this.pushState("text"), 29;
1430
+ case 113:
1431
+ return this.popState(), 66;
1432
+ case 114:
1433
+ return this.pushState("text"), 65;
1434
+ case 115:
1435
+ return "TEXT";
1436
+ case 116:
1437
+ return "QUOTE";
1438
+ case 117:
1439
+ return 9;
1440
+ case 118:
1441
+ return 10;
1442
+ case 119:
1443
+ return 11;
1444
+ }
1445
+ }, "anonymous"),
1446
+ 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)/, /^(?:$)/],
1447
+ 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 } }
1448
+ };
1449
+ return g1;
1450
+ }();
1451
+ J1.lexer = Wt;
1452
+ function q1() {
1453
+ this.yy = {};
1454
+ }
1455
+ return m(q1, "Parser"), q1.prototype = J1, J1.Parser = q1, new q1();
1456
+ }();
1457
+ rt.parser = rt;
1458
+ var Mt = rt, Ut = Object.assign({}, Mt);
1459
+ Ut.parse = (s) => {
1460
+ const i = s.replace(/}\s*\n/g, `}
1461
+ `);
1462
+ return Mt.parse(i);
1463
+ };
1464
+ var Ae = Ut, ke = /* @__PURE__ */ m((s, i) => {
1465
+ const r = he, a = r(s, "r"), n = r(s, "g"), l = r(s, "b");
1466
+ return oe(a, n, l, i);
1467
+ }, "fade"), me = /* @__PURE__ */ m((s) => `.label {
1468
+ font-family: ${s.fontFamily};
1469
+ color: ${s.nodeTextColor || s.textColor};
1470
+ }
1471
+ .cluster-label text {
1472
+ fill: ${s.titleColor};
1473
+ }
1474
+ .cluster-label span {
1475
+ color: ${s.titleColor};
1476
+ }
1477
+ .cluster-label span p {
1478
+ background-color: transparent;
1479
+ }
1480
+
1481
+ .label text,span {
1482
+ fill: ${s.nodeTextColor || s.textColor};
1483
+ color: ${s.nodeTextColor || s.textColor};
1484
+ }
1485
+
1486
+ .node rect,
1487
+ .node circle,
1488
+ .node ellipse,
1489
+ .node polygon,
1490
+ .node path {
1491
+ fill: ${s.mainBkg};
1492
+ stroke: ${s.nodeBorder};
1493
+ stroke-width: 1px;
1494
+ }
1495
+ .rough-node .label text , .node .label text, .image-shape .label, .icon-shape .label {
1496
+ text-anchor: middle;
1497
+ }
1498
+ // .flowchart-label .text-outer-tspan {
1499
+ // text-anchor: middle;
1500
+ // }
1501
+ // .flowchart-label .text-inner-tspan {
1502
+ // text-anchor: start;
1503
+ // }
1504
+
1505
+ .node .katex path {
1506
+ fill: #000;
1507
+ stroke: #000;
1508
+ stroke-width: 1px;
1509
+ }
1510
+
1511
+ .rough-node .label,.node .label, .image-shape .label, .icon-shape .label {
1512
+ text-align: center;
1513
+ }
1514
+ .node.clickable {
1515
+ cursor: pointer;
1516
+ }
1517
+
1518
+
1519
+ .root .anchor path {
1520
+ fill: ${s.lineColor} !important;
1521
+ stroke-width: 0;
1522
+ stroke: ${s.lineColor};
1523
+ }
1524
+
1525
+ .arrowheadPath {
1526
+ fill: ${s.arrowheadColor};
1527
+ }
1528
+
1529
+ .edgePath .path {
1530
+ stroke: ${s.lineColor};
1531
+ stroke-width: 2.0px;
1532
+ }
1533
+
1534
+ .flowchart-link {
1535
+ stroke: ${s.lineColor};
1536
+ fill: none;
1537
+ }
1538
+
1539
+ .edgeLabel {
1540
+ background-color: ${s.edgeLabelBackground};
1541
+ p {
1542
+ background-color: ${s.edgeLabelBackground};
1543
+ }
1544
+ rect {
1545
+ opacity: 0.5;
1546
+ background-color: ${s.edgeLabelBackground};
1547
+ fill: ${s.edgeLabelBackground};
1548
+ }
1549
+ text-align: center;
1550
+ }
1551
+
1552
+ /* For html labels only */
1553
+ .labelBkg {
1554
+ background-color: ${ke(s.edgeLabelBackground, 0.5)};
1555
+ // background-color:
1556
+ }
1557
+
1558
+ .cluster rect {
1559
+ fill: ${s.clusterBkg};
1560
+ stroke: ${s.clusterBorder};
1561
+ stroke-width: 1px;
1562
+ }
1563
+
1564
+ .cluster text {
1565
+ fill: ${s.titleColor};
1566
+ }
1567
+
1568
+ .cluster span {
1569
+ color: ${s.titleColor};
1570
+ }
1571
+ /* .cluster div {
1572
+ color: ${s.titleColor};
1573
+ } */
1574
+
1575
+ div.mermaidTooltip {
1576
+ position: absolute;
1577
+ text-align: center;
1578
+ max-width: 200px;
1579
+ padding: 2px;
1580
+ font-family: ${s.fontFamily};
1581
+ font-size: 12px;
1582
+ background: ${s.tertiaryColor};
1583
+ border: 1px solid ${s.border2};
1584
+ border-radius: 2px;
1585
+ pointer-events: none;
1586
+ z-index: 100;
1587
+ }
1588
+
1589
+ .flowchartTitleText {
1590
+ text-anchor: middle;
1591
+ font-size: 18px;
1592
+ fill: ${s.textColor};
1593
+ }
1594
+
1595
+ rect.text {
1596
+ fill: none;
1597
+ stroke-width: 0;
1598
+ }
1599
+
1600
+ .icon-shape, .image-shape {
1601
+ background-color: ${s.edgeLabelBackground};
1602
+ p {
1603
+ background-color: ${s.edgeLabelBackground};
1604
+ padding: 2px;
1605
+ }
1606
+ rect {
1607
+ opacity: 0.5;
1608
+ background-color: ${s.edgeLabelBackground};
1609
+ fill: ${s.edgeLabelBackground};
1610
+ }
1611
+ text-align: center;
1612
+ }
1613
+ ${qt()}
1614
+ `, "getStyles"), Ee = me, Fe = {
1615
+ parser: Ae,
1616
+ get db() {
1617
+ return new pe();
1618
+ },
1619
+ renderer: be,
1620
+ styles: Ee,
1621
+ init: /* @__PURE__ */ m((s) => {
1622
+ s.flowchart || (s.flowchart = {}), s.layout && Ot({ layout: s.layout }), s.flowchart.arrowMarkerAbsolute = s.arrowMarkerAbsolute, Ot({ flowchart: { arrowMarkerAbsolute: s.arrowMarkerAbsolute } });
1623
+ }, "init")
1624
+ };
1625
+ export {
1626
+ Fe as diagram
1627
+ };