@bytechain.cn/colamd 1.5.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 (157) hide show
  1. package/.github/workflows/release.yml +66 -0
  2. package/.trae/documents/fix-mermaid-colors-and-sankey.md +50 -0
  3. package/CLAUDE.md +87 -0
  4. package/LICENSE +21 -0
  5. package/README.md +540 -0
  6. package/README_CN.md +543 -0
  7. package/demo.md +486 -0
  8. package/dist/main/index.js +735 -0
  9. package/dist/preload/index.js +71 -0
  10. package/dist/renderer/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2 +0 -0
  11. package/dist/renderer/assets/KaTeX_AMS-Regular-DMm9YOAa.woff +0 -0
  12. package/dist/renderer/assets/KaTeX_AMS-Regular-DRggAlZN.ttf +0 -0
  13. package/dist/renderer/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf +0 -0
  14. package/dist/renderer/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff +0 -0
  15. package/dist/renderer/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2 +0 -0
  16. package/dist/renderer/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff +0 -0
  17. package/dist/renderer/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2 +0 -0
  18. package/dist/renderer/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf +0 -0
  19. package/dist/renderer/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf +0 -0
  20. package/dist/renderer/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff +0 -0
  21. package/dist/renderer/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2 +0 -0
  22. package/dist/renderer/assets/KaTeX_Fraktur-Regular-CB_wures.ttf +0 -0
  23. package/dist/renderer/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2 +0 -0
  24. package/dist/renderer/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff +0 -0
  25. package/dist/renderer/assets/KaTeX_Main-Bold-Cx986IdX.woff2 +0 -0
  26. package/dist/renderer/assets/KaTeX_Main-Bold-Jm3AIy58.woff +0 -0
  27. package/dist/renderer/assets/KaTeX_Main-Bold-waoOVXN0.ttf +0 -0
  28. package/dist/renderer/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2 +0 -0
  29. package/dist/renderer/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf +0 -0
  30. package/dist/renderer/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff +0 -0
  31. package/dist/renderer/assets/KaTeX_Main-Italic-3WenGoN9.ttf +0 -0
  32. package/dist/renderer/assets/KaTeX_Main-Italic-BMLOBm91.woff +0 -0
  33. package/dist/renderer/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2 +0 -0
  34. package/dist/renderer/assets/KaTeX_Main-Regular-B22Nviop.woff2 +0 -0
  35. package/dist/renderer/assets/KaTeX_Main-Regular-Dr94JaBh.woff +0 -0
  36. package/dist/renderer/assets/KaTeX_Main-Regular-ypZvNtVU.ttf +0 -0
  37. package/dist/renderer/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf +0 -0
  38. package/dist/renderer/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2 +0 -0
  39. package/dist/renderer/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff +0 -0
  40. package/dist/renderer/assets/KaTeX_Math-Italic-DA0__PXp.woff +0 -0
  41. package/dist/renderer/assets/KaTeX_Math-Italic-flOr_0UB.ttf +0 -0
  42. package/dist/renderer/assets/KaTeX_Math-Italic-t53AETM-.woff2 +0 -0
  43. package/dist/renderer/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf +0 -0
  44. package/dist/renderer/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2 +0 -0
  45. package/dist/renderer/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff +0 -0
  46. package/dist/renderer/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2 +0 -0
  47. package/dist/renderer/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff +0 -0
  48. package/dist/renderer/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf +0 -0
  49. package/dist/renderer/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf +0 -0
  50. package/dist/renderer/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff +0 -0
  51. package/dist/renderer/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2 +0 -0
  52. package/dist/renderer/assets/KaTeX_Script-Regular-C5JkGWo-.ttf +0 -0
  53. package/dist/renderer/assets/KaTeX_Script-Regular-D3wIWfF6.woff2 +0 -0
  54. package/dist/renderer/assets/KaTeX_Script-Regular-D5yQViql.woff +0 -0
  55. package/dist/renderer/assets/KaTeX_Size1-Regular-C195tn64.woff +0 -0
  56. package/dist/renderer/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf +0 -0
  57. package/dist/renderer/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2 +0 -0
  58. package/dist/renderer/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf +0 -0
  59. package/dist/renderer/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2 +0 -0
  60. package/dist/renderer/assets/KaTeX_Size2-Regular-oD1tc_U0.woff +0 -0
  61. package/dist/renderer/assets/KaTeX_Size3-Regular-CTq5MqoE.woff +0 -0
  62. package/dist/renderer/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf +0 -0
  63. package/dist/renderer/assets/KaTeX_Size4-Regular-BF-4gkZK.woff +0 -0
  64. package/dist/renderer/assets/KaTeX_Size4-Regular-DWFBv043.ttf +0 -0
  65. package/dist/renderer/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2 +0 -0
  66. package/dist/renderer/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff +0 -0
  67. package/dist/renderer/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2 +0 -0
  68. package/dist/renderer/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf +0 -0
  69. package/dist/renderer/assets/arc-tTbbM8LO.js +131 -0
  70. package/dist/renderer/assets/architectureDiagram-3BPJPVTR-CEgYow6c.js +8720 -0
  71. package/dist/renderer/assets/blockDiagram-GPEHLZMM-LHyVtPwW.js +3825 -0
  72. package/dist/renderer/assets/c4Diagram-AAUBKEIU-C1P1eJrf.js +2482 -0
  73. package/dist/renderer/assets/channel-upve91Tq.js +7 -0
  74. package/dist/renderer/assets/chunk-2J33WTMH-lag2vhq9.js +24 -0
  75. package/dist/renderer/assets/chunk-4BX2VUAB-BXJ8Ggh-.js +16 -0
  76. package/dist/renderer/assets/chunk-55IACEB6-CiBpxRa1.js +13 -0
  77. package/dist/renderer/assets/chunk-727SXJPM-ODeKQFXC.js +2016 -0
  78. package/dist/renderer/assets/chunk-AQP2D5EJ-BK7xJolB.js +1953 -0
  79. package/dist/renderer/assets/chunk-FMBD7UC4-BxpCZPtz.js +19 -0
  80. package/dist/renderer/assets/chunk-ND2GUHAM-CqqaU9Ue.js +116 -0
  81. package/dist/renderer/assets/chunk-QZHKN3VN-Biq_K124.js +19 -0
  82. package/dist/renderer/assets/classDiagram-4FO5ZUOK-Cq95X99o.js +23 -0
  83. package/dist/renderer/assets/classDiagram-v2-Q7XG4LA2-Cq95X99o.js +23 -0
  84. package/dist/renderer/assets/cose-bilkent-S5V4N54A-XasiD0bu.js +4942 -0
  85. package/dist/renderer/assets/cytoscape.esm-CpHeHM5e.js +30269 -0
  86. package/dist/renderer/assets/dagre-BM42HDAG-Nq84Gfx4.js +705 -0
  87. package/dist/renderer/assets/defaultLocale-B2RvLBDe.js +206 -0
  88. package/dist/renderer/assets/diagram-2AECGRRQ-DwuB1GWt.js +301 -0
  89. package/dist/renderer/assets/diagram-5GNKFQAL-C2tgeI1h.js +169 -0
  90. package/dist/renderer/assets/diagram-KO2AKTUF-D5KzjNBc.js +632 -0
  91. package/dist/renderer/assets/diagram-LMA3HP47-C12xHS1c.js +212 -0
  92. package/dist/renderer/assets/diagram-OG6HWLK6-CnxI9oEa.js +851 -0
  93. package/dist/renderer/assets/erDiagram-TEJ5UH35-D_uPaKwn.js +1227 -0
  94. package/dist/renderer/assets/flowDiagram-I6XJVG4X-B6q_1-tE.js +2332 -0
  95. package/dist/renderer/assets/ganttDiagram-6RSMTGT7-CFo7ifF9.js +3720 -0
  96. package/dist/renderer/assets/gitGraphDiagram-PVQCEYII-WSexHTnq.js +1373 -0
  97. package/dist/renderer/assets/graph-DyX_9f6d.js +1988 -0
  98. package/dist/renderer/assets/index-DW7LS8C1.js +72292 -0
  99. package/dist/renderer/assets/index-dyHEFYvY.css +2184 -0
  100. package/dist/renderer/assets/infoDiagram-5YYISTIA-DaeJdLRq.js +31 -0
  101. package/dist/renderer/assets/init-ZxktEp_H.js +16 -0
  102. package/dist/renderer/assets/ishikawaDiagram-YF4QCWOH-DDCZc35f.js +967 -0
  103. package/dist/renderer/assets/journeyDiagram-JHISSGLW-BEdmpAgl.js +1255 -0
  104. package/dist/renderer/assets/kanban-definition-UN3LZRKU-BEFtQcFb.js +1052 -0
  105. package/dist/renderer/assets/layout-CAJgQHdw.js +2610 -0
  106. package/dist/renderer/assets/linear-B2ggJ8Am.js +340 -0
  107. package/dist/renderer/assets/mindmap-definition-RKZ34NQL-DSxVgHB5.js +1180 -0
  108. package/dist/renderer/assets/ordinal-DSZU4PqD.js +76 -0
  109. package/dist/renderer/assets/pieDiagram-4H26LBE5-CwYoJBuL.js +246 -0
  110. package/dist/renderer/assets/quadrantDiagram-W4KKPZXB-CST9Fvg9.js +1344 -0
  111. package/dist/renderer/assets/requirementDiagram-4Y6WPE33-DtrH52jS.js +1204 -0
  112. package/dist/renderer/assets/sankeyDiagram-5OEKKPKP-ca1tPzJ_.js +1274 -0
  113. package/dist/renderer/assets/sequenceDiagram-3UESZ5HK-Dfp1EJZ7.js +4514 -0
  114. package/dist/renderer/assets/stateDiagram-AJRCARHV-Bha2QoNB.js +450 -0
  115. package/dist/renderer/assets/stateDiagram-v2-BHNVJYJU-DWgFUYu1.js +21 -0
  116. package/dist/renderer/assets/timeline-definition-PNZ67QCA-C3h_-OTj.js +1596 -0
  117. package/dist/renderer/assets/vennDiagram-CIIHVFJN-DFzjSrZi.js +2486 -0
  118. package/dist/renderer/assets/wardley-L42UT6IY-Cx-VbqoS.js +30699 -0
  119. package/dist/renderer/assets/wardleyDiagram-YWT4CUSO-S2D9XqX6.js +975 -0
  120. package/dist/renderer/assets/xychartDiagram-2RQKCTM6-Cfxigbts.js +1932 -0
  121. package/dist/renderer/index.html +19 -0
  122. package/docs/agent-diff-view.md +48 -0
  123. package/electron-builder.yml +57 -0
  124. package/electron.vite.config.ts +30 -0
  125. package/package.json +40 -0
  126. package/resources/entitlements.mac.plist +12 -0
  127. package/resources/icon.icns +0 -0
  128. package/resources/icon.png +0 -0
  129. package/resources/icon.svg +23 -0
  130. package/resources/templates/slides/icon.png +0 -0
  131. package/resources/templates/slides/slides-template.md +74 -0
  132. package/resources/templates/slides/template.html +535 -0
  133. package/scripts/afterPack.js +13 -0
  134. package/src/main/index.ts +881 -0
  135. package/src/preload/index.ts +110 -0
  136. package/src/renderer/editor/editor.ts +204 -0
  137. package/src/renderer/editor/html-view.ts +15 -0
  138. package/src/renderer/editor/plugins/index.ts +76 -0
  139. package/src/renderer/editor/plugins/math-plugin.ts +297 -0
  140. package/src/renderer/editor/plugins/mermaid-plugin-custom.css +431 -0
  141. package/src/renderer/editor/plugins/mermaid-plugin-dark.css +428 -0
  142. package/src/renderer/editor/plugins/mermaid-plugin-elegant.css +443 -0
  143. package/src/renderer/editor/plugins/mermaid-plugin-newsprint.css +208 -0
  144. package/src/renderer/editor/plugins/mermaid-plugin.css +111 -0
  145. package/src/renderer/editor/plugins/mermaid-plugin.ts +679 -0
  146. package/src/renderer/env.d.ts +7 -0
  147. package/src/renderer/index.html +18 -0
  148. package/src/renderer/main.ts +303 -0
  149. package/src/renderer/themes/base.css +509 -0
  150. package/src/renderer/themes/theme-manager.ts +40 -0
  151. package/themes/README.md +280 -0
  152. package/themes/elegant.css +664 -0
  153. package/themes/guizang.css +732 -0
  154. package/tsconfig.json +14 -0
  155. package/tsconfig.main.json +11 -0
  156. package/tsconfig.preload.json +11 -0
  157. package/tsconfig.renderer.json +12 -0
@@ -0,0 +1,1344 @@
1
+ import { s as setAccDescription, g as getAccDescription, q as getDiagramTitle, p as setDiagramTitle, a as getAccTitle, b as setAccTitle, _ as __name, c as getConfig2, l as log, d as select, e as configureSvgSize, z as clear, G as defaultConfig_default, i as sanitizeText, K as getThemeVariables3 } from "./index-DW7LS8C1.js";
2
+ import { l as linear } from "./linear-B2ggJ8Am.js";
3
+ import "./init-ZxktEp_H.js";
4
+ import "./defaultLocale-B2RvLBDe.js";
5
+ var parser = (function() {
6
+ var o = /* @__PURE__ */ __name(function(k, v, o2, l) {
7
+ for (o2 = o2 || {}, l = k.length; l--; o2[k[l]] = v) ;
8
+ return o2;
9
+ }, "o"), $V0 = [1, 3], $V1 = [1, 4], $V2 = [1, 5], $V3 = [1, 6], $V4 = [1, 7], $V5 = [1, 4, 5, 10, 12, 13, 14, 15, 18, 25, 35, 37, 39, 41, 42, 48, 50, 51, 52, 53, 54, 55, 56, 57, 60, 61, 63, 64, 65, 66, 67], $V6 = [1, 4, 5, 10, 12, 13, 14, 15, 18, 25, 28, 35, 37, 39, 41, 42, 48, 50, 51, 52, 53, 54, 55, 56, 57, 60, 61, 63, 64, 65, 66, 67], $V7 = [55, 56, 57], $V8 = [2, 36], $V9 = [1, 37], $Va = [1, 36], $Vb = [1, 38], $Vc = [1, 35], $Vd = [1, 43], $Ve = [1, 41], $Vf = [1, 45], $Vg = [1, 14], $Vh = [1, 23], $Vi = [1, 18], $Vj = [1, 19], $Vk = [1, 20], $Vl = [1, 21], $Vm = [1, 22], $Vn = [1, 24], $Vo = [1, 25], $Vp = [1, 26], $Vq = [1, 27], $Vr = [1, 28], $Vs = [1, 29], $Vt = [1, 32], $Vu = [1, 33], $Vv = [1, 34], $Vw = [1, 39], $Vx = [1, 40], $Vy = [1, 42], $Vz = [1, 44], $VA = [1, 63], $VB = [1, 62], $VC = [4, 5, 8, 10, 12, 13, 14, 15, 18, 44, 47, 49, 55, 56, 57, 63, 64, 65, 66, 67], $VD = [1, 66], $VE = [1, 67], $VF = [1, 68], $VG = [1, 69], $VH = [1, 70], $VI = [1, 71], $VJ = [1, 72], $VK = [1, 73], $VL = [1, 74], $VM = [1, 75], $VN = [1, 76], $VO = [1, 77], $VP = [4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 18], $VQ = [1, 91], $VR = [1, 92], $VS = [1, 93], $VT = [1, 100], $VU = [1, 94], $VV = [1, 97], $VW = [1, 95], $VX = [1, 96], $VY = [1, 98], $VZ = [1, 99], $V_ = [1, 103], $V$ = [10, 55, 56, 57], $V01 = [4, 5, 6, 8, 10, 11, 13, 17, 18, 19, 20, 55, 56, 57];
10
+ var parser2 = {
11
+ trace: /* @__PURE__ */ __name(function trace() {
12
+ }, "trace"),
13
+ yy: {},
14
+ symbols_: { "error": 2, "idStringToken": 3, "ALPHA": 4, "NUM": 5, "NODE_STRING": 6, "DOWN": 7, "MINUS": 8, "DEFAULT": 9, "COMMA": 10, "COLON": 11, "AMP": 12, "BRKT": 13, "MULT": 14, "UNICODE_TEXT": 15, "styleComponent": 16, "UNIT": 17, "SPACE": 18, "STYLE": 19, "PCT": 20, "idString": 21, "style": 22, "stylesOpt": 23, "classDefStatement": 24, "CLASSDEF": 25, "start": 26, "eol": 27, "QUADRANT": 28, "document": 29, "line": 30, "statement": 31, "axisDetails": 32, "quadrantDetails": 33, "points": 34, "title": 35, "title_value": 36, "acc_title": 37, "acc_title_value": 38, "acc_descr": 39, "acc_descr_value": 40, "acc_descr_multiline_value": 41, "section": 42, "text": 43, "point_start": 44, "point_x": 45, "point_y": 46, "class_name": 47, "X-AXIS": 48, "AXIS-TEXT-DELIMITER": 49, "Y-AXIS": 50, "QUADRANT_1": 51, "QUADRANT_2": 52, "QUADRANT_3": 53, "QUADRANT_4": 54, "NEWLINE": 55, "SEMI": 56, "EOF": 57, "alphaNumToken": 58, "textNoTagsToken": 59, "STR": 60, "MD_STR": 61, "alphaNum": 62, "PUNCTUATION": 63, "PLUS": 64, "EQUALS": 65, "DOT": 66, "UNDERSCORE": 67, "$accept": 0, "$end": 1 },
15
+ terminals_: { 2: "error", 4: "ALPHA", 5: "NUM", 6: "NODE_STRING", 7: "DOWN", 8: "MINUS", 9: "DEFAULT", 10: "COMMA", 11: "COLON", 12: "AMP", 13: "BRKT", 14: "MULT", 15: "UNICODE_TEXT", 17: "UNIT", 18: "SPACE", 19: "STYLE", 20: "PCT", 25: "CLASSDEF", 28: "QUADRANT", 35: "title", 36: "title_value", 37: "acc_title", 38: "acc_title_value", 39: "acc_descr", 40: "acc_descr_value", 41: "acc_descr_multiline_value", 42: "section", 44: "point_start", 45: "point_x", 46: "point_y", 47: "class_name", 48: "X-AXIS", 49: "AXIS-TEXT-DELIMITER", 50: "Y-AXIS", 51: "QUADRANT_1", 52: "QUADRANT_2", 53: "QUADRANT_3", 54: "QUADRANT_4", 55: "NEWLINE", 56: "SEMI", 57: "EOF", 60: "STR", 61: "MD_STR", 63: "PUNCTUATION", 64: "PLUS", 65: "EQUALS", 66: "DOT", 67: "UNDERSCORE" },
16
+ productions_: [0, [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [3, 1], [16, 1], [16, 1], [16, 1], [16, 1], [16, 1], [16, 1], [16, 1], [16, 1], [16, 1], [16, 1], [21, 1], [21, 2], [22, 1], [22, 2], [23, 1], [23, 3], [24, 5], [26, 2], [26, 2], [26, 2], [29, 0], [29, 2], [30, 2], [31, 0], [31, 1], [31, 2], [31, 1], [31, 1], [31, 1], [31, 2], [31, 2], [31, 2], [31, 1], [31, 1], [34, 4], [34, 5], [34, 5], [34, 6], [32, 4], [32, 3], [32, 2], [32, 4], [32, 3], [32, 2], [33, 2], [33, 2], [33, 2], [33, 2], [27, 1], [27, 1], [27, 1], [43, 1], [43, 2], [43, 1], [43, 1], [62, 1], [62, 2], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [58, 1], [59, 1], [59, 1], [59, 1]],
17
+ performAction: /* @__PURE__ */ __name(function anonymous(yytext, yyleng, yylineno, yy, yystate, $$, _$) {
18
+ var $0 = $$.length - 1;
19
+ switch (yystate) {
20
+ case 23:
21
+ this.$ = $$[$0];
22
+ break;
23
+ case 24:
24
+ this.$ = $$[$0 - 1] + "" + $$[$0];
25
+ break;
26
+ case 26:
27
+ this.$ = $$[$0 - 1] + $$[$0];
28
+ break;
29
+ case 27:
30
+ this.$ = [$$[$0].trim()];
31
+ break;
32
+ case 28:
33
+ $$[$0 - 2].push($$[$0].trim());
34
+ this.$ = $$[$0 - 2];
35
+ break;
36
+ case 29:
37
+ this.$ = $$[$0 - 4];
38
+ yy.addClass($$[$0 - 2], $$[$0]);
39
+ break;
40
+ case 37:
41
+ this.$ = [];
42
+ break;
43
+ case 42:
44
+ this.$ = $$[$0].trim();
45
+ yy.setDiagramTitle(this.$);
46
+ break;
47
+ case 43:
48
+ this.$ = $$[$0].trim();
49
+ yy.setAccTitle(this.$);
50
+ break;
51
+ case 44:
52
+ case 45:
53
+ this.$ = $$[$0].trim();
54
+ yy.setAccDescription(this.$);
55
+ break;
56
+ case 46:
57
+ yy.addSection($$[$0].substr(8));
58
+ this.$ = $$[$0].substr(8);
59
+ break;
60
+ case 47:
61
+ yy.addPoint($$[$0 - 3], "", $$[$0 - 1], $$[$0], []);
62
+ break;
63
+ case 48:
64
+ yy.addPoint($$[$0 - 4], $$[$0 - 3], $$[$0 - 1], $$[$0], []);
65
+ break;
66
+ case 49:
67
+ yy.addPoint($$[$0 - 4], "", $$[$0 - 2], $$[$0 - 1], $$[$0]);
68
+ break;
69
+ case 50:
70
+ yy.addPoint($$[$0 - 5], $$[$0 - 4], $$[$0 - 2], $$[$0 - 1], $$[$0]);
71
+ break;
72
+ case 51:
73
+ yy.setXAxisLeftText($$[$0 - 2]);
74
+ yy.setXAxisRightText($$[$0]);
75
+ break;
76
+ case 52:
77
+ $$[$0 - 1].text += " ⟶ ";
78
+ yy.setXAxisLeftText($$[$0 - 1]);
79
+ break;
80
+ case 53:
81
+ yy.setXAxisLeftText($$[$0]);
82
+ break;
83
+ case 54:
84
+ yy.setYAxisBottomText($$[$0 - 2]);
85
+ yy.setYAxisTopText($$[$0]);
86
+ break;
87
+ case 55:
88
+ $$[$0 - 1].text += " ⟶ ";
89
+ yy.setYAxisBottomText($$[$0 - 1]);
90
+ break;
91
+ case 56:
92
+ yy.setYAxisBottomText($$[$0]);
93
+ break;
94
+ case 57:
95
+ yy.setQuadrant1Text($$[$0]);
96
+ break;
97
+ case 58:
98
+ yy.setQuadrant2Text($$[$0]);
99
+ break;
100
+ case 59:
101
+ yy.setQuadrant3Text($$[$0]);
102
+ break;
103
+ case 60:
104
+ yy.setQuadrant4Text($$[$0]);
105
+ break;
106
+ case 64:
107
+ this.$ = { text: $$[$0], type: "text" };
108
+ break;
109
+ case 65:
110
+ this.$ = { text: $$[$0 - 1].text + "" + $$[$0], type: $$[$0 - 1].type };
111
+ break;
112
+ case 66:
113
+ this.$ = { text: $$[$0], type: "text" };
114
+ break;
115
+ case 67:
116
+ this.$ = { text: $$[$0], type: "markdown" };
117
+ break;
118
+ case 68:
119
+ this.$ = $$[$0];
120
+ break;
121
+ case 69:
122
+ this.$ = $$[$0 - 1] + "" + $$[$0];
123
+ break;
124
+ }
125
+ }, "anonymous"),
126
+ table: [{ 18: $V0, 26: 1, 27: 2, 28: $V1, 55: $V2, 56: $V3, 57: $V4 }, { 1: [3] }, { 18: $V0, 26: 8, 27: 2, 28: $V1, 55: $V2, 56: $V3, 57: $V4 }, { 18: $V0, 26: 9, 27: 2, 28: $V1, 55: $V2, 56: $V3, 57: $V4 }, o($V5, [2, 33], { 29: 10 }), o($V6, [2, 61]), o($V6, [2, 62]), o($V6, [2, 63]), { 1: [2, 30] }, { 1: [2, 31] }, o($V7, $V8, { 30: 11, 31: 12, 24: 13, 32: 15, 33: 16, 34: 17, 43: 30, 58: 31, 1: [2, 32], 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $Vg, 25: $Vh, 35: $Vi, 37: $Vj, 39: $Vk, 41: $Vl, 42: $Vm, 48: $Vn, 50: $Vo, 51: $Vp, 52: $Vq, 53: $Vr, 54: $Vs, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V5, [2, 34]), { 27: 46, 55: $V2, 56: $V3, 57: $V4 }, o($V7, [2, 37]), o($V7, $V8, { 24: 13, 32: 15, 33: 16, 34: 17, 43: 30, 58: 31, 31: 47, 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $Vg, 25: $Vh, 35: $Vi, 37: $Vj, 39: $Vk, 41: $Vl, 42: $Vm, 48: $Vn, 50: $Vo, 51: $Vp, 52: $Vq, 53: $Vr, 54: $Vs, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 39]), o($V7, [2, 40]), o($V7, [2, 41]), { 36: [1, 48] }, { 38: [1, 49] }, { 40: [1, 50] }, o($V7, [2, 45]), o($V7, [2, 46]), { 18: [1, 51] }, { 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 43: 52, 58: 31, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }, { 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 43: 53, 58: 31, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }, { 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 43: 54, 58: 31, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }, { 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 43: 55, 58: 31, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }, { 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 43: 56, 58: 31, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }, { 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 43: 57, 58: 31, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }, { 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 44: [1, 58], 47: [1, 59], 58: 61, 59: 60, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }, o($VC, [2, 64]), o($VC, [2, 66]), o($VC, [2, 67]), o($VC, [2, 70]), o($VC, [2, 71]), o($VC, [2, 72]), o($VC, [2, 73]), o($VC, [2, 74]), o($VC, [2, 75]), o($VC, [2, 76]), o($VC, [2, 77]), o($VC, [2, 78]), o($VC, [2, 79]), o($VC, [2, 80]), o($VC, [2, 81]), o($V5, [2, 35]), o($V7, [2, 38]), o($V7, [2, 42]), o($V7, [2, 43]), o($V7, [2, 44]), { 3: 65, 4: $VD, 5: $VE, 6: $VF, 7: $VG, 8: $VH, 9: $VI, 10: $VJ, 11: $VK, 12: $VL, 13: $VM, 14: $VN, 15: $VO, 21: 64 }, o($V7, [2, 53], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 49: [1, 78], 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 56], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 49: [1, 79], 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 57], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 58], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 59], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 60], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), { 45: [1, 80] }, { 44: [1, 81] }, o($VC, [2, 65]), o($VC, [2, 82]), o($VC, [2, 83]), o($VC, [2, 84]), { 3: 83, 4: $VD, 5: $VE, 6: $VF, 7: $VG, 8: $VH, 9: $VI, 10: $VJ, 11: $VK, 12: $VL, 13: $VM, 14: $VN, 15: $VO, 18: [1, 82] }, o($VP, [2, 23]), o($VP, [2, 1]), o($VP, [2, 2]), o($VP, [2, 3]), o($VP, [2, 4]), o($VP, [2, 5]), o($VP, [2, 6]), o($VP, [2, 7]), o($VP, [2, 8]), o($VP, [2, 9]), o($VP, [2, 10]), o($VP, [2, 11]), o($VP, [2, 12]), o($V7, [2, 52], { 58: 31, 43: 84, 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 55], { 58: 31, 43: 85, 4: $V9, 5: $Va, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 60: $Vt, 61: $Vu, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), { 46: [1, 86] }, { 45: [1, 87] }, { 4: $VQ, 5: $VR, 6: $VS, 8: $VT, 11: $VU, 13: $VV, 16: 90, 17: $VW, 18: $VX, 19: $VY, 20: $VZ, 22: 89, 23: 88 }, o($VP, [2, 24]), o($V7, [2, 51], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 54], { 59: 60, 58: 61, 4: $V9, 5: $Va, 8: $VA, 10: $Vb, 12: $Vc, 13: $Vd, 14: $Ve, 15: $Vf, 18: $VB, 63: $Vv, 64: $Vw, 65: $Vx, 66: $Vy, 67: $Vz }), o($V7, [2, 47], { 22: 89, 16: 90, 23: 101, 4: $VQ, 5: $VR, 6: $VS, 8: $VT, 11: $VU, 13: $VV, 17: $VW, 18: $VX, 19: $VY, 20: $VZ }), { 46: [1, 102] }, o($V7, [2, 29], { 10: $V_ }), o($V$, [2, 27], { 16: 104, 4: $VQ, 5: $VR, 6: $VS, 8: $VT, 11: $VU, 13: $VV, 17: $VW, 18: $VX, 19: $VY, 20: $VZ }), o($V01, [2, 25]), o($V01, [2, 13]), o($V01, [2, 14]), o($V01, [2, 15]), o($V01, [2, 16]), o($V01, [2, 17]), o($V01, [2, 18]), o($V01, [2, 19]), o($V01, [2, 20]), o($V01, [2, 21]), o($V01, [2, 22]), o($V7, [2, 49], { 10: $V_ }), o($V7, [2, 48], { 22: 89, 16: 90, 23: 105, 4: $VQ, 5: $VR, 6: $VS, 8: $VT, 11: $VU, 13: $VV, 17: $VW, 18: $VX, 19: $VY, 20: $VZ }), { 4: $VQ, 5: $VR, 6: $VS, 8: $VT, 11: $VU, 13: $VV, 16: 90, 17: $VW, 18: $VX, 19: $VY, 20: $VZ, 22: 106 }, o($V01, [2, 26]), o($V7, [2, 50], { 10: $V_ }), o($V$, [2, 28], { 16: 104, 4: $VQ, 5: $VR, 6: $VS, 8: $VT, 11: $VU, 13: $VV, 17: $VW, 18: $VX, 19: $VY, 20: $VZ })],
127
+ defaultActions: { 8: [2, 30], 9: [2, 31] },
128
+ parseError: /* @__PURE__ */ __name(function parseError(str, hash) {
129
+ if (hash.recoverable) {
130
+ this.trace(str);
131
+ } else {
132
+ var error = new Error(str);
133
+ error.hash = hash;
134
+ throw error;
135
+ }
136
+ }, "parseError"),
137
+ parse: /* @__PURE__ */ __name(function parse(input) {
138
+ var self = this, stack = [0], tstack = [], vstack = [null], lstack = [], table = this.table, yytext = "", yylineno = 0, yyleng = 0, TERROR = 2, EOF = 1;
139
+ var args = lstack.slice.call(arguments, 1);
140
+ var lexer2 = Object.create(this.lexer);
141
+ var sharedState = { yy: {} };
142
+ for (var k in this.yy) {
143
+ if (Object.prototype.hasOwnProperty.call(this.yy, k)) {
144
+ sharedState.yy[k] = this.yy[k];
145
+ }
146
+ }
147
+ lexer2.setInput(input, sharedState.yy);
148
+ sharedState.yy.lexer = lexer2;
149
+ sharedState.yy.parser = this;
150
+ if (typeof lexer2.yylloc == "undefined") {
151
+ lexer2.yylloc = {};
152
+ }
153
+ var yyloc = lexer2.yylloc;
154
+ lstack.push(yyloc);
155
+ var ranges = lexer2.options && lexer2.options.ranges;
156
+ if (typeof sharedState.yy.parseError === "function") {
157
+ this.parseError = sharedState.yy.parseError;
158
+ } else {
159
+ this.parseError = Object.getPrototypeOf(this).parseError;
160
+ }
161
+ function popStack(n) {
162
+ stack.length = stack.length - 2 * n;
163
+ vstack.length = vstack.length - n;
164
+ lstack.length = lstack.length - n;
165
+ }
166
+ __name(popStack, "popStack");
167
+ function lex() {
168
+ var token;
169
+ token = tstack.pop() || lexer2.lex() || EOF;
170
+ if (typeof token !== "number") {
171
+ if (token instanceof Array) {
172
+ tstack = token;
173
+ token = tstack.pop();
174
+ }
175
+ token = self.symbols_[token] || token;
176
+ }
177
+ return token;
178
+ }
179
+ __name(lex, "lex");
180
+ var symbol, state, action, r, yyval = {}, p, len, newState, expected;
181
+ while (true) {
182
+ state = stack[stack.length - 1];
183
+ if (this.defaultActions[state]) {
184
+ action = this.defaultActions[state];
185
+ } else {
186
+ if (symbol === null || typeof symbol == "undefined") {
187
+ symbol = lex();
188
+ }
189
+ action = table[state] && table[state][symbol];
190
+ }
191
+ if (typeof action === "undefined" || !action.length || !action[0]) {
192
+ var errStr = "";
193
+ expected = [];
194
+ for (p in table[state]) {
195
+ if (this.terminals_[p] && p > TERROR) {
196
+ expected.push("'" + this.terminals_[p] + "'");
197
+ }
198
+ }
199
+ if (lexer2.showPosition) {
200
+ errStr = "Parse error on line " + (yylineno + 1) + ":\n" + lexer2.showPosition() + "\nExpecting " + expected.join(", ") + ", got '" + (this.terminals_[symbol] || symbol) + "'";
201
+ } else {
202
+ errStr = "Parse error on line " + (yylineno + 1) + ": Unexpected " + (symbol == EOF ? "end of input" : "'" + (this.terminals_[symbol] || symbol) + "'");
203
+ }
204
+ this.parseError(errStr, {
205
+ text: lexer2.match,
206
+ token: this.terminals_[symbol] || symbol,
207
+ line: lexer2.yylineno,
208
+ loc: yyloc,
209
+ expected
210
+ });
211
+ }
212
+ if (action[0] instanceof Array && action.length > 1) {
213
+ throw new Error("Parse Error: multiple actions possible at state: " + state + ", token: " + symbol);
214
+ }
215
+ switch (action[0]) {
216
+ case 1:
217
+ stack.push(symbol);
218
+ vstack.push(lexer2.yytext);
219
+ lstack.push(lexer2.yylloc);
220
+ stack.push(action[1]);
221
+ symbol = null;
222
+ {
223
+ yyleng = lexer2.yyleng;
224
+ yytext = lexer2.yytext;
225
+ yylineno = lexer2.yylineno;
226
+ yyloc = lexer2.yylloc;
227
+ }
228
+ break;
229
+ case 2:
230
+ len = this.productions_[action[1]][1];
231
+ yyval.$ = vstack[vstack.length - len];
232
+ yyval._$ = {
233
+ first_line: lstack[lstack.length - (len || 1)].first_line,
234
+ last_line: lstack[lstack.length - 1].last_line,
235
+ first_column: lstack[lstack.length - (len || 1)].first_column,
236
+ last_column: lstack[lstack.length - 1].last_column
237
+ };
238
+ if (ranges) {
239
+ yyval._$.range = [
240
+ lstack[lstack.length - (len || 1)].range[0],
241
+ lstack[lstack.length - 1].range[1]
242
+ ];
243
+ }
244
+ r = this.performAction.apply(yyval, [
245
+ yytext,
246
+ yyleng,
247
+ yylineno,
248
+ sharedState.yy,
249
+ action[1],
250
+ vstack,
251
+ lstack
252
+ ].concat(args));
253
+ if (typeof r !== "undefined") {
254
+ return r;
255
+ }
256
+ if (len) {
257
+ stack = stack.slice(0, -1 * len * 2);
258
+ vstack = vstack.slice(0, -1 * len);
259
+ lstack = lstack.slice(0, -1 * len);
260
+ }
261
+ stack.push(this.productions_[action[1]][0]);
262
+ vstack.push(yyval.$);
263
+ lstack.push(yyval._$);
264
+ newState = table[stack[stack.length - 2]][stack[stack.length - 1]];
265
+ stack.push(newState);
266
+ break;
267
+ case 3:
268
+ return true;
269
+ }
270
+ }
271
+ return true;
272
+ }, "parse")
273
+ };
274
+ var lexer = /* @__PURE__ */ (function() {
275
+ var lexer2 = {
276
+ EOF: 1,
277
+ parseError: /* @__PURE__ */ __name(function parseError(str, hash) {
278
+ if (this.yy.parser) {
279
+ this.yy.parser.parseError(str, hash);
280
+ } else {
281
+ throw new Error(str);
282
+ }
283
+ }, "parseError"),
284
+ // resets the lexer, sets new input
285
+ setInput: /* @__PURE__ */ __name(function(input, yy) {
286
+ this.yy = yy || this.yy || {};
287
+ this._input = input;
288
+ this._more = this._backtrack = this.done = false;
289
+ this.yylineno = this.yyleng = 0;
290
+ this.yytext = this.matched = this.match = "";
291
+ this.conditionStack = ["INITIAL"];
292
+ this.yylloc = {
293
+ first_line: 1,
294
+ first_column: 0,
295
+ last_line: 1,
296
+ last_column: 0
297
+ };
298
+ if (this.options.ranges) {
299
+ this.yylloc.range = [0, 0];
300
+ }
301
+ this.offset = 0;
302
+ return this;
303
+ }, "setInput"),
304
+ // consumes and returns one char from the input
305
+ input: /* @__PURE__ */ __name(function() {
306
+ var ch = this._input[0];
307
+ this.yytext += ch;
308
+ this.yyleng++;
309
+ this.offset++;
310
+ this.match += ch;
311
+ this.matched += ch;
312
+ var lines = ch.match(/(?:\r\n?|\n).*/g);
313
+ if (lines) {
314
+ this.yylineno++;
315
+ this.yylloc.last_line++;
316
+ } else {
317
+ this.yylloc.last_column++;
318
+ }
319
+ if (this.options.ranges) {
320
+ this.yylloc.range[1]++;
321
+ }
322
+ this._input = this._input.slice(1);
323
+ return ch;
324
+ }, "input"),
325
+ // unshifts one char (or a string) into the input
326
+ unput: /* @__PURE__ */ __name(function(ch) {
327
+ var len = ch.length;
328
+ var lines = ch.split(/(?:\r\n?|\n)/g);
329
+ this._input = ch + this._input;
330
+ this.yytext = this.yytext.substr(0, this.yytext.length - len);
331
+ this.offset -= len;
332
+ var oldLines = this.match.split(/(?:\r\n?|\n)/g);
333
+ this.match = this.match.substr(0, this.match.length - 1);
334
+ this.matched = this.matched.substr(0, this.matched.length - 1);
335
+ if (lines.length - 1) {
336
+ this.yylineno -= lines.length - 1;
337
+ }
338
+ var r = this.yylloc.range;
339
+ this.yylloc = {
340
+ first_line: this.yylloc.first_line,
341
+ last_line: this.yylineno + 1,
342
+ first_column: this.yylloc.first_column,
343
+ last_column: lines ? (lines.length === oldLines.length ? this.yylloc.first_column : 0) + oldLines[oldLines.length - lines.length].length - lines[0].length : this.yylloc.first_column - len
344
+ };
345
+ if (this.options.ranges) {
346
+ this.yylloc.range = [r[0], r[0] + this.yyleng - len];
347
+ }
348
+ this.yyleng = this.yytext.length;
349
+ return this;
350
+ }, "unput"),
351
+ // When called from action, caches matched text and appends it on next action
352
+ more: /* @__PURE__ */ __name(function() {
353
+ this._more = true;
354
+ return this;
355
+ }, "more"),
356
+ // 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.
357
+ reject: /* @__PURE__ */ __name(function() {
358
+ if (this.options.backtrack_lexer) {
359
+ this._backtrack = true;
360
+ } else {
361
+ 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).\n" + this.showPosition(), {
362
+ text: "",
363
+ token: null,
364
+ line: this.yylineno
365
+ });
366
+ }
367
+ return this;
368
+ }, "reject"),
369
+ // retain first n characters of the match
370
+ less: /* @__PURE__ */ __name(function(n) {
371
+ this.unput(this.match.slice(n));
372
+ }, "less"),
373
+ // displays already matched input, i.e. for error messages
374
+ pastInput: /* @__PURE__ */ __name(function() {
375
+ var past = this.matched.substr(0, this.matched.length - this.match.length);
376
+ return (past.length > 20 ? "..." : "") + past.substr(-20).replace(/\n/g, "");
377
+ }, "pastInput"),
378
+ // displays upcoming input, i.e. for error messages
379
+ upcomingInput: /* @__PURE__ */ __name(function() {
380
+ var next = this.match;
381
+ if (next.length < 20) {
382
+ next += this._input.substr(0, 20 - next.length);
383
+ }
384
+ return (next.substr(0, 20) + (next.length > 20 ? "..." : "")).replace(/\n/g, "");
385
+ }, "upcomingInput"),
386
+ // displays the character position where the lexing error occurred, i.e. for error messages
387
+ showPosition: /* @__PURE__ */ __name(function() {
388
+ var pre = this.pastInput();
389
+ var c = new Array(pre.length + 1).join("-");
390
+ return pre + this.upcomingInput() + "\n" + c + "^";
391
+ }, "showPosition"),
392
+ // test the lexed token: return FALSE when not a match, otherwise return token
393
+ test_match: /* @__PURE__ */ __name(function(match, indexed_rule) {
394
+ var token, lines, backup;
395
+ if (this.options.backtrack_lexer) {
396
+ backup = {
397
+ yylineno: this.yylineno,
398
+ yylloc: {
399
+ first_line: this.yylloc.first_line,
400
+ last_line: this.last_line,
401
+ first_column: this.yylloc.first_column,
402
+ last_column: this.yylloc.last_column
403
+ },
404
+ yytext: this.yytext,
405
+ match: this.match,
406
+ matches: this.matches,
407
+ matched: this.matched,
408
+ yyleng: this.yyleng,
409
+ offset: this.offset,
410
+ _more: this._more,
411
+ _input: this._input,
412
+ yy: this.yy,
413
+ conditionStack: this.conditionStack.slice(0),
414
+ done: this.done
415
+ };
416
+ if (this.options.ranges) {
417
+ backup.yylloc.range = this.yylloc.range.slice(0);
418
+ }
419
+ }
420
+ lines = match[0].match(/(?:\r\n?|\n).*/g);
421
+ if (lines) {
422
+ this.yylineno += lines.length;
423
+ }
424
+ this.yylloc = {
425
+ first_line: this.yylloc.last_line,
426
+ last_line: this.yylineno + 1,
427
+ first_column: this.yylloc.last_column,
428
+ last_column: lines ? lines[lines.length - 1].length - lines[lines.length - 1].match(/\r?\n?/)[0].length : this.yylloc.last_column + match[0].length
429
+ };
430
+ this.yytext += match[0];
431
+ this.match += match[0];
432
+ this.matches = match;
433
+ this.yyleng = this.yytext.length;
434
+ if (this.options.ranges) {
435
+ this.yylloc.range = [this.offset, this.offset += this.yyleng];
436
+ }
437
+ this._more = false;
438
+ this._backtrack = false;
439
+ this._input = this._input.slice(match[0].length);
440
+ this.matched += match[0];
441
+ token = this.performAction.call(this, this.yy, this, indexed_rule, this.conditionStack[this.conditionStack.length - 1]);
442
+ if (this.done && this._input) {
443
+ this.done = false;
444
+ }
445
+ if (token) {
446
+ return token;
447
+ } else if (this._backtrack) {
448
+ for (var k in backup) {
449
+ this[k] = backup[k];
450
+ }
451
+ return false;
452
+ }
453
+ return false;
454
+ }, "test_match"),
455
+ // return next match in input
456
+ next: /* @__PURE__ */ __name(function() {
457
+ if (this.done) {
458
+ return this.EOF;
459
+ }
460
+ if (!this._input) {
461
+ this.done = true;
462
+ }
463
+ var token, match, tempMatch, index;
464
+ if (!this._more) {
465
+ this.yytext = "";
466
+ this.match = "";
467
+ }
468
+ var rules = this._currentRules();
469
+ for (var i = 0; i < rules.length; i++) {
470
+ tempMatch = this._input.match(this.rules[rules[i]]);
471
+ if (tempMatch && (!match || tempMatch[0].length > match[0].length)) {
472
+ match = tempMatch;
473
+ index = i;
474
+ if (this.options.backtrack_lexer) {
475
+ token = this.test_match(tempMatch, rules[i]);
476
+ if (token !== false) {
477
+ return token;
478
+ } else if (this._backtrack) {
479
+ match = false;
480
+ continue;
481
+ } else {
482
+ return false;
483
+ }
484
+ } else if (!this.options.flex) {
485
+ break;
486
+ }
487
+ }
488
+ }
489
+ if (match) {
490
+ token = this.test_match(match, rules[index]);
491
+ if (token !== false) {
492
+ return token;
493
+ }
494
+ return false;
495
+ }
496
+ if (this._input === "") {
497
+ return this.EOF;
498
+ } else {
499
+ return this.parseError("Lexical error on line " + (this.yylineno + 1) + ". Unrecognized text.\n" + this.showPosition(), {
500
+ text: "",
501
+ token: null,
502
+ line: this.yylineno
503
+ });
504
+ }
505
+ }, "next"),
506
+ // return next match that has a token
507
+ lex: /* @__PURE__ */ __name(function lex() {
508
+ var r = this.next();
509
+ if (r) {
510
+ return r;
511
+ } else {
512
+ return this.lex();
513
+ }
514
+ }, "lex"),
515
+ // activates a new lexer condition state (pushes the new lexer condition state onto the condition stack)
516
+ begin: /* @__PURE__ */ __name(function begin(condition) {
517
+ this.conditionStack.push(condition);
518
+ }, "begin"),
519
+ // pop the previously active lexer condition state off the condition stack
520
+ popState: /* @__PURE__ */ __name(function popState() {
521
+ var n = this.conditionStack.length - 1;
522
+ if (n > 0) {
523
+ return this.conditionStack.pop();
524
+ } else {
525
+ return this.conditionStack[0];
526
+ }
527
+ }, "popState"),
528
+ // produce the lexer rule set which is active for the currently active lexer condition state
529
+ _currentRules: /* @__PURE__ */ __name(function _currentRules() {
530
+ if (this.conditionStack.length && this.conditionStack[this.conditionStack.length - 1]) {
531
+ return this.conditions[this.conditionStack[this.conditionStack.length - 1]].rules;
532
+ } else {
533
+ return this.conditions["INITIAL"].rules;
534
+ }
535
+ }, "_currentRules"),
536
+ // return the currently active lexer condition state; when an index argument is provided it produces the N-th previous condition state, if available
537
+ topState: /* @__PURE__ */ __name(function topState(n) {
538
+ n = this.conditionStack.length - 1 - Math.abs(n || 0);
539
+ if (n >= 0) {
540
+ return this.conditionStack[n];
541
+ } else {
542
+ return "INITIAL";
543
+ }
544
+ }, "topState"),
545
+ // alias for begin(condition)
546
+ pushState: /* @__PURE__ */ __name(function pushState(condition) {
547
+ this.begin(condition);
548
+ }, "pushState"),
549
+ // return the number of states currently on the stack
550
+ stateStackSize: /* @__PURE__ */ __name(function stateStackSize() {
551
+ return this.conditionStack.length;
552
+ }, "stateStackSize"),
553
+ options: { "case-insensitive": true },
554
+ performAction: /* @__PURE__ */ __name(function anonymous(yy, yy_, $avoiding_name_collisions, YY_START) {
555
+ switch ($avoiding_name_collisions) {
556
+ case 0:
557
+ break;
558
+ case 1:
559
+ break;
560
+ case 2:
561
+ return 55;
562
+ case 3:
563
+ break;
564
+ case 4:
565
+ this.begin("title");
566
+ return 35;
567
+ case 5:
568
+ this.popState();
569
+ return "title_value";
570
+ case 6:
571
+ this.begin("acc_title");
572
+ return 37;
573
+ case 7:
574
+ this.popState();
575
+ return "acc_title_value";
576
+ case 8:
577
+ this.begin("acc_descr");
578
+ return 39;
579
+ case 9:
580
+ this.popState();
581
+ return "acc_descr_value";
582
+ case 10:
583
+ this.begin("acc_descr_multiline");
584
+ break;
585
+ case 11:
586
+ this.popState();
587
+ break;
588
+ case 12:
589
+ return "acc_descr_multiline_value";
590
+ case 13:
591
+ return 48;
592
+ case 14:
593
+ return 50;
594
+ case 15:
595
+ return 49;
596
+ case 16:
597
+ return 51;
598
+ case 17:
599
+ return 52;
600
+ case 18:
601
+ return 53;
602
+ case 19:
603
+ return 54;
604
+ case 20:
605
+ return 25;
606
+ case 21:
607
+ this.begin("md_string");
608
+ break;
609
+ case 22:
610
+ return "MD_STR";
611
+ case 23:
612
+ this.popState();
613
+ break;
614
+ case 24:
615
+ this.begin("string");
616
+ break;
617
+ case 25:
618
+ this.popState();
619
+ break;
620
+ case 26:
621
+ return "STR";
622
+ case 27:
623
+ this.begin("class_name");
624
+ break;
625
+ case 28:
626
+ this.popState();
627
+ return 47;
628
+ case 29:
629
+ this.begin("point_start");
630
+ return 44;
631
+ case 30:
632
+ this.begin("point_x");
633
+ return 45;
634
+ case 31:
635
+ this.popState();
636
+ break;
637
+ case 32:
638
+ this.popState();
639
+ this.begin("point_y");
640
+ break;
641
+ case 33:
642
+ this.popState();
643
+ return 46;
644
+ case 34:
645
+ return 28;
646
+ case 35:
647
+ return 4;
648
+ case 36:
649
+ return 15;
650
+ case 37:
651
+ return 11;
652
+ case 38:
653
+ return 64;
654
+ case 39:
655
+ return 10;
656
+ case 40:
657
+ return 65;
658
+ case 41:
659
+ return 65;
660
+ case 42:
661
+ return 14;
662
+ case 43:
663
+ return 13;
664
+ case 44:
665
+ return 67;
666
+ case 45:
667
+ return 66;
668
+ case 46:
669
+ return 12;
670
+ case 47:
671
+ return 8;
672
+ case 48:
673
+ return 5;
674
+ case 49:
675
+ return 18;
676
+ case 50:
677
+ return 56;
678
+ case 51:
679
+ return 63;
680
+ case 52:
681
+ return 57;
682
+ }
683
+ }, "anonymous"),
684
+ rules: [/^(?:%%(?!\{)[^\n]*)/i, /^(?:[^\}]%%[^\n]*)/i, /^(?:[\n\r]+)/i, /^(?:%%[^\n]*)/i, /^(?:title\b)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accTitle\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*:\s*)/i, /^(?:(?!\n||)*[^\n]*)/i, /^(?:accDescr\s*\{\s*)/i, /^(?:[\}])/i, /^(?:[^\}]*)/i, /^(?: *x-axis *)/i, /^(?: *y-axis *)/i, /^(?: *--+> *)/i, /^(?: *quadrant-1 *)/i, /^(?: *quadrant-2 *)/i, /^(?: *quadrant-3 *)/i, /^(?: *quadrant-4 *)/i, /^(?:classDef\b)/i, /^(?:["][`])/i, /^(?:[^`"]+)/i, /^(?:[`]["])/i, /^(?:["])/i, /^(?:["])/i, /^(?:[^"]*)/i, /^(?::::)/i, /^(?:^\w+)/i, /^(?:\s*:\s*\[\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?:\s*\] *)/i, /^(?:\s*,\s*)/i, /^(?:(1)|(0(.\d+)?))/i, /^(?: *quadrantChart *)/i, /^(?:[A-Za-z]+)/i, /^(?:[^\x00-\x7F]+)/i, /^(?::)/i, /^(?:\+)/i, /^(?:,)/i, /^(?:=)/i, /^(?:=)/i, /^(?:\*)/i, /^(?:#)/i, /^(?:[\_])/i, /^(?:\.)/i, /^(?:&)/i, /^(?:-)/i, /^(?:[0-9]+)/i, /^(?:\s)/i, /^(?:;)/i, /^(?:[!"#$%&'*+,-.`?\\_/])/i, /^(?:$)/i],
685
+ conditions: { "class_name": { "rules": [28], "inclusive": false }, "point_y": { "rules": [33], "inclusive": false }, "point_x": { "rules": [32], "inclusive": false }, "point_start": { "rules": [30, 31], "inclusive": false }, "acc_descr_multiline": { "rules": [11, 12], "inclusive": false }, "acc_descr": { "rules": [9], "inclusive": false }, "acc_title": { "rules": [7], "inclusive": false }, "title": { "rules": [5], "inclusive": false }, "md_string": { "rules": [22, 23], "inclusive": false }, "string": { "rules": [25, 26], "inclusive": false }, "INITIAL": { "rules": [0, 1, 2, 3, 4, 6, 8, 10, 13, 14, 15, 16, 17, 18, 19, 20, 21, 24, 27, 29, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52], "inclusive": true } }
686
+ };
687
+ return lexer2;
688
+ })();
689
+ parser2.lexer = lexer;
690
+ function Parser() {
691
+ this.yy = {};
692
+ }
693
+ __name(Parser, "Parser");
694
+ Parser.prototype = parser2;
695
+ parser2.Parser = Parser;
696
+ return new Parser();
697
+ })();
698
+ parser.parser = parser;
699
+ var quadrant_default = parser;
700
+ var defaultThemeVariables = getThemeVariables3();
701
+ var QuadrantBuilder = class {
702
+ constructor() {
703
+ this.classes = /* @__PURE__ */ new Map();
704
+ this.config = this.getDefaultConfig();
705
+ this.themeConfig = this.getDefaultThemeConfig();
706
+ this.data = this.getDefaultData();
707
+ }
708
+ static {
709
+ __name(this, "QuadrantBuilder");
710
+ }
711
+ getDefaultData() {
712
+ return {
713
+ titleText: "",
714
+ quadrant1Text: "",
715
+ quadrant2Text: "",
716
+ quadrant3Text: "",
717
+ quadrant4Text: "",
718
+ xAxisLeftText: "",
719
+ xAxisRightText: "",
720
+ yAxisBottomText: "",
721
+ yAxisTopText: "",
722
+ points: []
723
+ };
724
+ }
725
+ getDefaultConfig() {
726
+ return {
727
+ showXAxis: true,
728
+ showYAxis: true,
729
+ showTitle: true,
730
+ chartHeight: defaultConfig_default.quadrantChart?.chartWidth || 500,
731
+ chartWidth: defaultConfig_default.quadrantChart?.chartHeight || 500,
732
+ titlePadding: defaultConfig_default.quadrantChart?.titlePadding || 10,
733
+ titleFontSize: defaultConfig_default.quadrantChart?.titleFontSize || 20,
734
+ quadrantPadding: defaultConfig_default.quadrantChart?.quadrantPadding || 5,
735
+ xAxisLabelPadding: defaultConfig_default.quadrantChart?.xAxisLabelPadding || 5,
736
+ yAxisLabelPadding: defaultConfig_default.quadrantChart?.yAxisLabelPadding || 5,
737
+ xAxisLabelFontSize: defaultConfig_default.quadrantChart?.xAxisLabelFontSize || 16,
738
+ yAxisLabelFontSize: defaultConfig_default.quadrantChart?.yAxisLabelFontSize || 16,
739
+ quadrantLabelFontSize: defaultConfig_default.quadrantChart?.quadrantLabelFontSize || 16,
740
+ quadrantTextTopPadding: defaultConfig_default.quadrantChart?.quadrantTextTopPadding || 5,
741
+ pointTextPadding: defaultConfig_default.quadrantChart?.pointTextPadding || 5,
742
+ pointLabelFontSize: defaultConfig_default.quadrantChart?.pointLabelFontSize || 12,
743
+ pointRadius: defaultConfig_default.quadrantChart?.pointRadius || 5,
744
+ xAxisPosition: defaultConfig_default.quadrantChart?.xAxisPosition || "top",
745
+ yAxisPosition: defaultConfig_default.quadrantChart?.yAxisPosition || "left",
746
+ quadrantInternalBorderStrokeWidth: defaultConfig_default.quadrantChart?.quadrantInternalBorderStrokeWidth || 1,
747
+ quadrantExternalBorderStrokeWidth: defaultConfig_default.quadrantChart?.quadrantExternalBorderStrokeWidth || 2
748
+ };
749
+ }
750
+ getDefaultThemeConfig() {
751
+ return {
752
+ quadrant1Fill: defaultThemeVariables.quadrant1Fill,
753
+ quadrant2Fill: defaultThemeVariables.quadrant2Fill,
754
+ quadrant3Fill: defaultThemeVariables.quadrant3Fill,
755
+ quadrant4Fill: defaultThemeVariables.quadrant4Fill,
756
+ quadrant1TextFill: defaultThemeVariables.quadrant1TextFill,
757
+ quadrant2TextFill: defaultThemeVariables.quadrant2TextFill,
758
+ quadrant3TextFill: defaultThemeVariables.quadrant3TextFill,
759
+ quadrant4TextFill: defaultThemeVariables.quadrant4TextFill,
760
+ quadrantPointFill: defaultThemeVariables.quadrantPointFill,
761
+ quadrantPointTextFill: defaultThemeVariables.quadrantPointTextFill,
762
+ quadrantXAxisTextFill: defaultThemeVariables.quadrantXAxisTextFill,
763
+ quadrantYAxisTextFill: defaultThemeVariables.quadrantYAxisTextFill,
764
+ quadrantTitleFill: defaultThemeVariables.quadrantTitleFill,
765
+ quadrantInternalBorderStrokeFill: defaultThemeVariables.quadrantInternalBorderStrokeFill,
766
+ quadrantExternalBorderStrokeFill: defaultThemeVariables.quadrantExternalBorderStrokeFill
767
+ };
768
+ }
769
+ clear() {
770
+ this.config = this.getDefaultConfig();
771
+ this.themeConfig = this.getDefaultThemeConfig();
772
+ this.data = this.getDefaultData();
773
+ this.classes = /* @__PURE__ */ new Map();
774
+ log.info("clear called");
775
+ }
776
+ setData(data) {
777
+ this.data = { ...this.data, ...data };
778
+ }
779
+ addPoints(points) {
780
+ this.data.points = [...points, ...this.data.points];
781
+ }
782
+ addClass(className, styles) {
783
+ this.classes.set(className, styles);
784
+ }
785
+ setConfig(config2) {
786
+ log.trace("setConfig called with: ", config2);
787
+ this.config = { ...this.config, ...config2 };
788
+ }
789
+ setThemeConfig(themeConfig) {
790
+ log.trace("setThemeConfig called with: ", themeConfig);
791
+ this.themeConfig = { ...this.themeConfig, ...themeConfig };
792
+ }
793
+ calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle) {
794
+ const xAxisSpaceCalculation = this.config.xAxisLabelPadding * 2 + this.config.xAxisLabelFontSize;
795
+ const xAxisSpace = {
796
+ top: xAxisPosition === "top" && showXAxis ? xAxisSpaceCalculation : 0,
797
+ bottom: xAxisPosition === "bottom" && showXAxis ? xAxisSpaceCalculation : 0
798
+ };
799
+ const yAxisSpaceCalculation = this.config.yAxisLabelPadding * 2 + this.config.yAxisLabelFontSize;
800
+ const yAxisSpace = {
801
+ left: this.config.yAxisPosition === "left" && showYAxis ? yAxisSpaceCalculation : 0,
802
+ right: this.config.yAxisPosition === "right" && showYAxis ? yAxisSpaceCalculation : 0
803
+ };
804
+ const titleSpaceCalculation = this.config.titleFontSize + this.config.titlePadding * 2;
805
+ const titleSpace = {
806
+ top: showTitle ? titleSpaceCalculation : 0
807
+ };
808
+ const quadrantLeft = this.config.quadrantPadding + yAxisSpace.left;
809
+ const quadrantTop = this.config.quadrantPadding + xAxisSpace.top + titleSpace.top;
810
+ const quadrantWidth = this.config.chartWidth - this.config.quadrantPadding * 2 - yAxisSpace.left - yAxisSpace.right;
811
+ const quadrantHeight = this.config.chartHeight - this.config.quadrantPadding * 2 - xAxisSpace.top - xAxisSpace.bottom - titleSpace.top;
812
+ const quadrantHalfWidth = quadrantWidth / 2;
813
+ const quadrantHalfHeight = quadrantHeight / 2;
814
+ const quadrantSpace = {
815
+ quadrantLeft,
816
+ quadrantTop,
817
+ quadrantWidth,
818
+ quadrantHalfWidth,
819
+ quadrantHeight,
820
+ quadrantHalfHeight
821
+ };
822
+ return {
823
+ xAxisSpace,
824
+ yAxisSpace,
825
+ titleSpace,
826
+ quadrantSpace
827
+ };
828
+ }
829
+ getAxisLabels(xAxisPosition, showXAxis, showYAxis, spaceData) {
830
+ const { quadrantSpace, titleSpace } = spaceData;
831
+ const {
832
+ quadrantHalfHeight,
833
+ quadrantHeight,
834
+ quadrantLeft,
835
+ quadrantHalfWidth,
836
+ quadrantTop,
837
+ quadrantWidth
838
+ } = quadrantSpace;
839
+ const drawXAxisLabelsInMiddle = Boolean(this.data.xAxisRightText);
840
+ const drawYAxisLabelsInMiddle = Boolean(this.data.yAxisTopText);
841
+ const axisLabels = [];
842
+ if (this.data.xAxisLeftText && showXAxis) {
843
+ axisLabels.push({
844
+ text: this.data.xAxisLeftText,
845
+ fill: this.themeConfig.quadrantXAxisTextFill,
846
+ x: quadrantLeft + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0),
847
+ y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding,
848
+ fontSize: this.config.xAxisLabelFontSize,
849
+ verticalPos: drawXAxisLabelsInMiddle ? "center" : "left",
850
+ horizontalPos: "top",
851
+ rotation: 0
852
+ });
853
+ }
854
+ if (this.data.xAxisRightText && showXAxis) {
855
+ axisLabels.push({
856
+ text: this.data.xAxisRightText,
857
+ fill: this.themeConfig.quadrantXAxisTextFill,
858
+ x: quadrantLeft + quadrantHalfWidth + (drawXAxisLabelsInMiddle ? quadrantHalfWidth / 2 : 0),
859
+ y: xAxisPosition === "top" ? this.config.xAxisLabelPadding + titleSpace.top : this.config.xAxisLabelPadding + quadrantTop + quadrantHeight + this.config.quadrantPadding,
860
+ fontSize: this.config.xAxisLabelFontSize,
861
+ verticalPos: drawXAxisLabelsInMiddle ? "center" : "left",
862
+ horizontalPos: "top",
863
+ rotation: 0
864
+ });
865
+ }
866
+ if (this.data.yAxisBottomText && showYAxis) {
867
+ axisLabels.push({
868
+ text: this.data.yAxisBottomText,
869
+ fill: this.themeConfig.quadrantYAxisTextFill,
870
+ x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding,
871
+ y: quadrantTop + quadrantHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0),
872
+ fontSize: this.config.yAxisLabelFontSize,
873
+ verticalPos: drawYAxisLabelsInMiddle ? "center" : "left",
874
+ horizontalPos: "top",
875
+ rotation: -90
876
+ });
877
+ }
878
+ if (this.data.yAxisTopText && showYAxis) {
879
+ axisLabels.push({
880
+ text: this.data.yAxisTopText,
881
+ fill: this.themeConfig.quadrantYAxisTextFill,
882
+ x: this.config.yAxisPosition === "left" ? this.config.yAxisLabelPadding : this.config.yAxisLabelPadding + quadrantLeft + quadrantWidth + this.config.quadrantPadding,
883
+ y: quadrantTop + quadrantHalfHeight - (drawYAxisLabelsInMiddle ? quadrantHalfHeight / 2 : 0),
884
+ fontSize: this.config.yAxisLabelFontSize,
885
+ verticalPos: drawYAxisLabelsInMiddle ? "center" : "left",
886
+ horizontalPos: "top",
887
+ rotation: -90
888
+ });
889
+ }
890
+ return axisLabels;
891
+ }
892
+ getQuadrants(spaceData) {
893
+ const { quadrantSpace } = spaceData;
894
+ const { quadrantHalfHeight, quadrantLeft, quadrantHalfWidth, quadrantTop } = quadrantSpace;
895
+ const quadrants = [
896
+ {
897
+ text: {
898
+ text: this.data.quadrant1Text,
899
+ fill: this.themeConfig.quadrant1TextFill,
900
+ x: 0,
901
+ y: 0,
902
+ fontSize: this.config.quadrantLabelFontSize,
903
+ verticalPos: "center",
904
+ horizontalPos: "middle",
905
+ rotation: 0
906
+ },
907
+ x: quadrantLeft + quadrantHalfWidth,
908
+ y: quadrantTop,
909
+ width: quadrantHalfWidth,
910
+ height: quadrantHalfHeight,
911
+ fill: this.themeConfig.quadrant1Fill
912
+ },
913
+ {
914
+ text: {
915
+ text: this.data.quadrant2Text,
916
+ fill: this.themeConfig.quadrant2TextFill,
917
+ x: 0,
918
+ y: 0,
919
+ fontSize: this.config.quadrantLabelFontSize,
920
+ verticalPos: "center",
921
+ horizontalPos: "middle",
922
+ rotation: 0
923
+ },
924
+ x: quadrantLeft,
925
+ y: quadrantTop,
926
+ width: quadrantHalfWidth,
927
+ height: quadrantHalfHeight,
928
+ fill: this.themeConfig.quadrant2Fill
929
+ },
930
+ {
931
+ text: {
932
+ text: this.data.quadrant3Text,
933
+ fill: this.themeConfig.quadrant3TextFill,
934
+ x: 0,
935
+ y: 0,
936
+ fontSize: this.config.quadrantLabelFontSize,
937
+ verticalPos: "center",
938
+ horizontalPos: "middle",
939
+ rotation: 0
940
+ },
941
+ x: quadrantLeft,
942
+ y: quadrantTop + quadrantHalfHeight,
943
+ width: quadrantHalfWidth,
944
+ height: quadrantHalfHeight,
945
+ fill: this.themeConfig.quadrant3Fill
946
+ },
947
+ {
948
+ text: {
949
+ text: this.data.quadrant4Text,
950
+ fill: this.themeConfig.quadrant4TextFill,
951
+ x: 0,
952
+ y: 0,
953
+ fontSize: this.config.quadrantLabelFontSize,
954
+ verticalPos: "center",
955
+ horizontalPos: "middle",
956
+ rotation: 0
957
+ },
958
+ x: quadrantLeft + quadrantHalfWidth,
959
+ y: quadrantTop + quadrantHalfHeight,
960
+ width: quadrantHalfWidth,
961
+ height: quadrantHalfHeight,
962
+ fill: this.themeConfig.quadrant4Fill
963
+ }
964
+ ];
965
+ for (const quadrant of quadrants) {
966
+ quadrant.text.x = quadrant.x + quadrant.width / 2;
967
+ if (this.data.points.length === 0) {
968
+ quadrant.text.y = quadrant.y + quadrant.height / 2;
969
+ quadrant.text.horizontalPos = "middle";
970
+ } else {
971
+ quadrant.text.y = quadrant.y + this.config.quadrantTextTopPadding;
972
+ quadrant.text.horizontalPos = "top";
973
+ }
974
+ }
975
+ return quadrants;
976
+ }
977
+ getQuadrantPoints(spaceData) {
978
+ const { quadrantSpace } = spaceData;
979
+ const { quadrantHeight, quadrantLeft, quadrantTop, quadrantWidth } = quadrantSpace;
980
+ const xAxis = linear().domain([0, 1]).range([quadrantLeft, quadrantWidth + quadrantLeft]);
981
+ const yAxis = linear().domain([0, 1]).range([quadrantHeight + quadrantTop, quadrantTop]);
982
+ const points = this.data.points.map((point) => {
983
+ const classStyles = this.classes.get(point.className);
984
+ if (classStyles) {
985
+ point = { ...classStyles, ...point };
986
+ }
987
+ const props = {
988
+ x: xAxis(point.x),
989
+ y: yAxis(point.y),
990
+ fill: point.color ?? this.themeConfig.quadrantPointFill,
991
+ radius: point.radius ?? this.config.pointRadius,
992
+ text: {
993
+ text: point.text,
994
+ fill: this.themeConfig.quadrantPointTextFill,
995
+ x: xAxis(point.x),
996
+ y: yAxis(point.y) + this.config.pointTextPadding,
997
+ verticalPos: "center",
998
+ horizontalPos: "top",
999
+ fontSize: this.config.pointLabelFontSize,
1000
+ rotation: 0
1001
+ },
1002
+ strokeColor: point.strokeColor ?? this.themeConfig.quadrantPointFill,
1003
+ strokeWidth: point.strokeWidth ?? "0px"
1004
+ };
1005
+ return props;
1006
+ });
1007
+ return points;
1008
+ }
1009
+ getBorders(spaceData) {
1010
+ const halfExternalBorderWidth = this.config.quadrantExternalBorderStrokeWidth / 2;
1011
+ const { quadrantSpace } = spaceData;
1012
+ const {
1013
+ quadrantHalfHeight,
1014
+ quadrantHeight,
1015
+ quadrantLeft,
1016
+ quadrantHalfWidth,
1017
+ quadrantTop,
1018
+ quadrantWidth
1019
+ } = quadrantSpace;
1020
+ const borderLines = [
1021
+ // top border
1022
+ {
1023
+ strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill,
1024
+ strokeWidth: this.config.quadrantExternalBorderStrokeWidth,
1025
+ x1: quadrantLeft - halfExternalBorderWidth,
1026
+ y1: quadrantTop,
1027
+ x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth,
1028
+ y2: quadrantTop
1029
+ },
1030
+ // right border
1031
+ {
1032
+ strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill,
1033
+ strokeWidth: this.config.quadrantExternalBorderStrokeWidth,
1034
+ x1: quadrantLeft + quadrantWidth,
1035
+ y1: quadrantTop + halfExternalBorderWidth,
1036
+ x2: quadrantLeft + quadrantWidth,
1037
+ y2: quadrantTop + quadrantHeight - halfExternalBorderWidth
1038
+ },
1039
+ // bottom border
1040
+ {
1041
+ strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill,
1042
+ strokeWidth: this.config.quadrantExternalBorderStrokeWidth,
1043
+ x1: quadrantLeft - halfExternalBorderWidth,
1044
+ y1: quadrantTop + quadrantHeight,
1045
+ x2: quadrantLeft + quadrantWidth + halfExternalBorderWidth,
1046
+ y2: quadrantTop + quadrantHeight
1047
+ },
1048
+ // left border
1049
+ {
1050
+ strokeFill: this.themeConfig.quadrantExternalBorderStrokeFill,
1051
+ strokeWidth: this.config.quadrantExternalBorderStrokeWidth,
1052
+ x1: quadrantLeft,
1053
+ y1: quadrantTop + halfExternalBorderWidth,
1054
+ x2: quadrantLeft,
1055
+ y2: quadrantTop + quadrantHeight - halfExternalBorderWidth
1056
+ },
1057
+ // vertical inner border
1058
+ {
1059
+ strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill,
1060
+ strokeWidth: this.config.quadrantInternalBorderStrokeWidth,
1061
+ x1: quadrantLeft + quadrantHalfWidth,
1062
+ y1: quadrantTop + halfExternalBorderWidth,
1063
+ x2: quadrantLeft + quadrantHalfWidth,
1064
+ y2: quadrantTop + quadrantHeight - halfExternalBorderWidth
1065
+ },
1066
+ // horizontal inner border
1067
+ {
1068
+ strokeFill: this.themeConfig.quadrantInternalBorderStrokeFill,
1069
+ strokeWidth: this.config.quadrantInternalBorderStrokeWidth,
1070
+ x1: quadrantLeft + halfExternalBorderWidth,
1071
+ y1: quadrantTop + quadrantHalfHeight,
1072
+ x2: quadrantLeft + quadrantWidth - halfExternalBorderWidth,
1073
+ y2: quadrantTop + quadrantHalfHeight
1074
+ }
1075
+ ];
1076
+ return borderLines;
1077
+ }
1078
+ getTitle(showTitle) {
1079
+ if (showTitle) {
1080
+ return {
1081
+ text: this.data.titleText,
1082
+ fill: this.themeConfig.quadrantTitleFill,
1083
+ fontSize: this.config.titleFontSize,
1084
+ horizontalPos: "top",
1085
+ verticalPos: "center",
1086
+ rotation: 0,
1087
+ y: this.config.titlePadding,
1088
+ x: this.config.chartWidth / 2
1089
+ };
1090
+ }
1091
+ return;
1092
+ }
1093
+ build() {
1094
+ const showXAxis = this.config.showXAxis && !!(this.data.xAxisLeftText || this.data.xAxisRightText);
1095
+ const showYAxis = this.config.showYAxis && !!(this.data.yAxisTopText || this.data.yAxisBottomText);
1096
+ const showTitle = this.config.showTitle && !!this.data.titleText;
1097
+ const xAxisPosition = this.data.points.length > 0 ? "bottom" : this.config.xAxisPosition;
1098
+ const calculatedSpace = this.calculateSpace(xAxisPosition, showXAxis, showYAxis, showTitle);
1099
+ return {
1100
+ points: this.getQuadrantPoints(calculatedSpace),
1101
+ quadrants: this.getQuadrants(calculatedSpace),
1102
+ axisLabels: this.getAxisLabels(xAxisPosition, showXAxis, showYAxis, calculatedSpace),
1103
+ borderLines: this.getBorders(calculatedSpace),
1104
+ title: this.getTitle(showTitle)
1105
+ };
1106
+ }
1107
+ };
1108
+ var InvalidStyleError = class extends Error {
1109
+ static {
1110
+ __name(this, "InvalidStyleError");
1111
+ }
1112
+ constructor(style, value, type) {
1113
+ super(`value for ${style} ${value} is invalid, please use a valid ${type}`);
1114
+ this.name = "InvalidStyleError";
1115
+ }
1116
+ };
1117
+ function validateHexCode(value) {
1118
+ return !/^#?([\dA-Fa-f]{6}|[\dA-Fa-f]{3})$/.test(value);
1119
+ }
1120
+ __name(validateHexCode, "validateHexCode");
1121
+ function validateNumber(value) {
1122
+ return !/^\d+$/.test(value);
1123
+ }
1124
+ __name(validateNumber, "validateNumber");
1125
+ function validateSizeInPixels(value) {
1126
+ return !/^\d+px$/.test(value);
1127
+ }
1128
+ __name(validateSizeInPixels, "validateSizeInPixels");
1129
+ var config = getConfig2();
1130
+ function textSanitizer(text) {
1131
+ return sanitizeText(text.trim(), config);
1132
+ }
1133
+ __name(textSanitizer, "textSanitizer");
1134
+ var quadrantBuilder = new QuadrantBuilder();
1135
+ function setQuadrant1Text(textObj) {
1136
+ quadrantBuilder.setData({ quadrant1Text: textSanitizer(textObj.text) });
1137
+ }
1138
+ __name(setQuadrant1Text, "setQuadrant1Text");
1139
+ function setQuadrant2Text(textObj) {
1140
+ quadrantBuilder.setData({ quadrant2Text: textSanitizer(textObj.text) });
1141
+ }
1142
+ __name(setQuadrant2Text, "setQuadrant2Text");
1143
+ function setQuadrant3Text(textObj) {
1144
+ quadrantBuilder.setData({ quadrant3Text: textSanitizer(textObj.text) });
1145
+ }
1146
+ __name(setQuadrant3Text, "setQuadrant3Text");
1147
+ function setQuadrant4Text(textObj) {
1148
+ quadrantBuilder.setData({ quadrant4Text: textSanitizer(textObj.text) });
1149
+ }
1150
+ __name(setQuadrant4Text, "setQuadrant4Text");
1151
+ function setXAxisLeftText(textObj) {
1152
+ quadrantBuilder.setData({ xAxisLeftText: textSanitizer(textObj.text) });
1153
+ }
1154
+ __name(setXAxisLeftText, "setXAxisLeftText");
1155
+ function setXAxisRightText(textObj) {
1156
+ quadrantBuilder.setData({ xAxisRightText: textSanitizer(textObj.text) });
1157
+ }
1158
+ __name(setXAxisRightText, "setXAxisRightText");
1159
+ function setYAxisTopText(textObj) {
1160
+ quadrantBuilder.setData({ yAxisTopText: textSanitizer(textObj.text) });
1161
+ }
1162
+ __name(setYAxisTopText, "setYAxisTopText");
1163
+ function setYAxisBottomText(textObj) {
1164
+ quadrantBuilder.setData({ yAxisBottomText: textSanitizer(textObj.text) });
1165
+ }
1166
+ __name(setYAxisBottomText, "setYAxisBottomText");
1167
+ function parseStyles(styles) {
1168
+ const stylesObject = {};
1169
+ for (const style of styles) {
1170
+ const [key, value] = style.trim().split(/\s*:\s*/);
1171
+ if (key === "radius") {
1172
+ if (validateNumber(value)) {
1173
+ throw new InvalidStyleError(key, value, "number");
1174
+ }
1175
+ stylesObject.radius = parseInt(value);
1176
+ } else if (key === "color") {
1177
+ if (validateHexCode(value)) {
1178
+ throw new InvalidStyleError(key, value, "hex code");
1179
+ }
1180
+ stylesObject.color = value;
1181
+ } else if (key === "stroke-color") {
1182
+ if (validateHexCode(value)) {
1183
+ throw new InvalidStyleError(key, value, "hex code");
1184
+ }
1185
+ stylesObject.strokeColor = value;
1186
+ } else if (key === "stroke-width") {
1187
+ if (validateSizeInPixels(value)) {
1188
+ throw new InvalidStyleError(key, value, "number of pixels (eg. 10px)");
1189
+ }
1190
+ stylesObject.strokeWidth = value;
1191
+ } else {
1192
+ throw new Error(`style named ${key} is not supported.`);
1193
+ }
1194
+ }
1195
+ return stylesObject;
1196
+ }
1197
+ __name(parseStyles, "parseStyles");
1198
+ function addPoint(textObj, className, x, y, styles) {
1199
+ const stylesObject = parseStyles(styles);
1200
+ quadrantBuilder.addPoints([
1201
+ {
1202
+ x,
1203
+ y,
1204
+ text: textSanitizer(textObj.text),
1205
+ className,
1206
+ ...stylesObject
1207
+ }
1208
+ ]);
1209
+ }
1210
+ __name(addPoint, "addPoint");
1211
+ function addClass(className, styles) {
1212
+ quadrantBuilder.addClass(className, parseStyles(styles));
1213
+ }
1214
+ __name(addClass, "addClass");
1215
+ function setWidth(width) {
1216
+ quadrantBuilder.setConfig({ chartWidth: width });
1217
+ }
1218
+ __name(setWidth, "setWidth");
1219
+ function setHeight(height) {
1220
+ quadrantBuilder.setConfig({ chartHeight: height });
1221
+ }
1222
+ __name(setHeight, "setHeight");
1223
+ function getQuadrantData() {
1224
+ const config2 = getConfig2();
1225
+ const { themeVariables, quadrantChart: quadrantChartConfig } = config2;
1226
+ if (quadrantChartConfig) {
1227
+ quadrantBuilder.setConfig(quadrantChartConfig);
1228
+ }
1229
+ quadrantBuilder.setThemeConfig({
1230
+ quadrant1Fill: themeVariables.quadrant1Fill,
1231
+ quadrant2Fill: themeVariables.quadrant2Fill,
1232
+ quadrant3Fill: themeVariables.quadrant3Fill,
1233
+ quadrant4Fill: themeVariables.quadrant4Fill,
1234
+ quadrant1TextFill: themeVariables.quadrant1TextFill,
1235
+ quadrant2TextFill: themeVariables.quadrant2TextFill,
1236
+ quadrant3TextFill: themeVariables.quadrant3TextFill,
1237
+ quadrant4TextFill: themeVariables.quadrant4TextFill,
1238
+ quadrantPointFill: themeVariables.quadrantPointFill,
1239
+ quadrantPointTextFill: themeVariables.quadrantPointTextFill,
1240
+ quadrantXAxisTextFill: themeVariables.quadrantXAxisTextFill,
1241
+ quadrantYAxisTextFill: themeVariables.quadrantYAxisTextFill,
1242
+ quadrantExternalBorderStrokeFill: themeVariables.quadrantExternalBorderStrokeFill,
1243
+ quadrantInternalBorderStrokeFill: themeVariables.quadrantInternalBorderStrokeFill,
1244
+ quadrantTitleFill: themeVariables.quadrantTitleFill
1245
+ });
1246
+ quadrantBuilder.setData({ titleText: getDiagramTitle() });
1247
+ return quadrantBuilder.build();
1248
+ }
1249
+ __name(getQuadrantData, "getQuadrantData");
1250
+ var clear2 = /* @__PURE__ */ __name(function() {
1251
+ quadrantBuilder.clear();
1252
+ clear();
1253
+ }, "clear");
1254
+ var quadrantDb_default = {
1255
+ setWidth,
1256
+ setHeight,
1257
+ setQuadrant1Text,
1258
+ setQuadrant2Text,
1259
+ setQuadrant3Text,
1260
+ setQuadrant4Text,
1261
+ setXAxisLeftText,
1262
+ setXAxisRightText,
1263
+ setYAxisTopText,
1264
+ setYAxisBottomText,
1265
+ parseStyles,
1266
+ addPoint,
1267
+ addClass,
1268
+ getQuadrantData,
1269
+ clear: clear2,
1270
+ setAccTitle,
1271
+ getAccTitle,
1272
+ setDiagramTitle,
1273
+ getDiagramTitle,
1274
+ getAccDescription,
1275
+ setAccDescription
1276
+ };
1277
+ var draw = /* @__PURE__ */ __name((txt, id, _version, diagObj) => {
1278
+ function getDominantBaseLine(horizontalPos) {
1279
+ return horizontalPos === "top" ? "hanging" : "middle";
1280
+ }
1281
+ __name(getDominantBaseLine, "getDominantBaseLine");
1282
+ function getTextAnchor(verticalPos) {
1283
+ return verticalPos === "left" ? "start" : "middle";
1284
+ }
1285
+ __name(getTextAnchor, "getTextAnchor");
1286
+ function getTransformation(data) {
1287
+ return `translate(${data.x}, ${data.y}) rotate(${data.rotation || 0})`;
1288
+ }
1289
+ __name(getTransformation, "getTransformation");
1290
+ const conf = getConfig2();
1291
+ log.debug("Rendering quadrant chart\n" + txt);
1292
+ const securityLevel = conf.securityLevel;
1293
+ let sandboxElement;
1294
+ if (securityLevel === "sandbox") {
1295
+ sandboxElement = select("#i" + id);
1296
+ }
1297
+ const root = securityLevel === "sandbox" ? select(sandboxElement.nodes()[0].contentDocument.body) : select("body");
1298
+ const svg = root.select(`[id="${id}"]`);
1299
+ const group = svg.append("g").attr("class", "main");
1300
+ const width = conf.quadrantChart?.chartWidth ?? 500;
1301
+ const height = conf.quadrantChart?.chartHeight ?? 500;
1302
+ configureSvgSize(svg, height, width, conf.quadrantChart?.useMaxWidth ?? true);
1303
+ svg.attr("viewBox", "0 0 " + width + " " + height);
1304
+ diagObj.db.setHeight(height);
1305
+ diagObj.db.setWidth(width);
1306
+ const quadrantData = diagObj.db.getQuadrantData();
1307
+ const quadrantsGroup = group.append("g").attr("class", "quadrants");
1308
+ const borderGroup = group.append("g").attr("class", "border");
1309
+ const dataPointGroup = group.append("g").attr("class", "data-points");
1310
+ const labelGroup = group.append("g").attr("class", "labels");
1311
+ const titleGroup = group.append("g").attr("class", "title");
1312
+ if (quadrantData.title) {
1313
+ titleGroup.append("text").attr("x", 0).attr("y", 0).attr("fill", quadrantData.title.fill).attr("font-size", quadrantData.title.fontSize).attr("dominant-baseline", getDominantBaseLine(quadrantData.title.horizontalPos)).attr("text-anchor", getTextAnchor(quadrantData.title.verticalPos)).attr("transform", getTransformation(quadrantData.title)).text(quadrantData.title.text);
1314
+ }
1315
+ if (quadrantData.borderLines) {
1316
+ borderGroup.selectAll("line").data(quadrantData.borderLines).enter().append("line").attr("x1", (data) => data.x1).attr("y1", (data) => data.y1).attr("x2", (data) => data.x2).attr("y2", (data) => data.y2).style("stroke", (data) => data.strokeFill).style("stroke-width", (data) => data.strokeWidth);
1317
+ }
1318
+ const quadrants = quadrantsGroup.selectAll("g.quadrant").data(quadrantData.quadrants).enter().append("g").attr("class", "quadrant");
1319
+ quadrants.append("rect").attr("x", (data) => data.x).attr("y", (data) => data.y).attr("width", (data) => data.width).attr("height", (data) => data.height).attr("fill", (data) => data.fill);
1320
+ quadrants.append("text").attr("x", 0).attr("y", 0).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr(
1321
+ "dominant-baseline",
1322
+ (data) => getDominantBaseLine(data.text.horizontalPos)
1323
+ ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text)).text((data) => data.text.text);
1324
+ const labels = labelGroup.selectAll("g.label").data(quadrantData.axisLabels).enter().append("g").attr("class", "label");
1325
+ labels.append("text").attr("x", 0).attr("y", 0).text((data) => data.text).attr("fill", (data) => data.fill).attr("font-size", (data) => data.fontSize).attr("dominant-baseline", (data) => getDominantBaseLine(data.horizontalPos)).attr("text-anchor", (data) => getTextAnchor(data.verticalPos)).attr("transform", (data) => getTransformation(data));
1326
+ const dataPoints = dataPointGroup.selectAll("g.data-point").data(quadrantData.points).enter().append("g").attr("class", "data-point");
1327
+ dataPoints.append("circle").attr("cx", (data) => data.x).attr("cy", (data) => data.y).attr("r", (data) => data.radius).attr("fill", (data) => data.fill).attr("stroke", (data) => data.strokeColor).attr("stroke-width", (data) => data.strokeWidth);
1328
+ dataPoints.append("text").attr("x", 0).attr("y", 0).text((data) => data.text.text).attr("fill", (data) => data.text.fill).attr("font-size", (data) => data.text.fontSize).attr(
1329
+ "dominant-baseline",
1330
+ (data) => getDominantBaseLine(data.text.horizontalPos)
1331
+ ).attr("text-anchor", (data) => getTextAnchor(data.text.verticalPos)).attr("transform", (data) => getTransformation(data.text));
1332
+ }, "draw");
1333
+ var quadrantRenderer_default = {
1334
+ draw
1335
+ };
1336
+ var diagram = {
1337
+ parser: quadrant_default,
1338
+ db: quadrantDb_default,
1339
+ renderer: quadrantRenderer_default,
1340
+ styles: /* @__PURE__ */ __name(() => "", "styles")
1341
+ };
1342
+ export {
1343
+ diagram
1344
+ };