@marimo-team/islands 0.12.1-dev7 → 0.12.2-dev0

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