@aidapt/caity-chat 3.0.0

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