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