@plumile/ui 0.1.99 → 0.1.101

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 (122) hide show
  1. package/lib/esm/{BackofficeJsonViewerAsync-GenasLA-.js → BackofficeJsonViewerAsync-niwHe9is.js} +2 -2
  2. package/lib/esm/{BackofficeJsonViewerAsync-GenasLA-.js.map → BackofficeJsonViewerAsync-niwHe9is.js.map} +1 -1
  3. package/lib/esm/HighlightCode-KpWSo7Zx.js.map +1 -1
  4. package/lib/esm/{MarkdownCodeBlock-DZRdzjJ9.js → MarkdownCodeBlock-CLK5KJgU.js} +3 -3
  5. package/lib/esm/{MarkdownCodeBlock-DZRdzjJ9.js.map → MarkdownCodeBlock-CLK5KJgU.js.map} +1 -1
  6. package/lib/esm/{MarkdownRenderer-DBpMvD98.js → MarkdownRenderer-c_Ic29c2.js} +2 -2
  7. package/lib/esm/{MarkdownRenderer-DBpMvD98.js.map → MarkdownRenderer-c_Ic29c2.js.map} +1 -1
  8. package/lib/esm/{MarkdownShikiCodeBlock-BhdpnKJo.js → MarkdownShikiCodeBlock-CbaOKfZO.js} +1180 -1175
  9. package/lib/esm/MarkdownShikiCodeBlock-CbaOKfZO.js.map +1 -0
  10. package/lib/esm/_baseFor-Z--4BB_X.js.map +1 -1
  11. package/lib/esm/arc-BUZ4igwO.js.map +1 -1
  12. package/lib/esm/architectureDiagram-Q4EWVU46-DpoNV55s.js.map +1 -1
  13. package/lib/esm/array-CTFiDRBi.js.map +1 -1
  14. package/lib/esm/blockDiagram-DXYQGD6D-DJxDffAk.js.map +1 -1
  15. package/lib/esm/c4Diagram-AHTNJAMY-DxAt6CyF.js.map +1 -1
  16. package/lib/esm/chunk-2KRD3SAO-C5ZUgIak.js.map +1 -1
  17. package/lib/esm/{chunk-336JU56O-24m8cXIL.js → chunk-336JU56O-BsMYboJR.js} +3 -3
  18. package/lib/esm/{chunk-336JU56O-24m8cXIL.js.map → chunk-336JU56O-BsMYboJR.js.map} +1 -1
  19. package/lib/esm/chunk-426QAEUC-b2PRuT9o.js.map +1 -1
  20. package/lib/esm/chunk-4BX2VUAB-BkyyJ41z.js.map +1 -1
  21. package/lib/esm/{chunk-4TB4RGXK-CsiupxiO.js → chunk-4TB4RGXK-LzOZn6e3.js} +2 -2
  22. package/lib/esm/{chunk-4TB4RGXK-CsiupxiO.js.map → chunk-4TB4RGXK-LzOZn6e3.js.map} +1 -1
  23. package/lib/esm/chunk-55IACEB6-CZ1WMXNv.js.map +1 -1
  24. package/lib/esm/chunk-5FUZZQ4R-Hp5ZXYAE.js.map +1 -1
  25. package/lib/esm/chunk-5PVQY5BW-CQdr0IGy.js.map +1 -1
  26. package/lib/esm/chunk-67CJDMHE-DQCJ08Vv.js.map +1 -1
  27. package/lib/esm/chunk-7N4EOEYR-CTdQRezU.js.map +1 -1
  28. package/lib/esm/chunk-AA7GKIK3-x61iJxkf.js.map +1 -1
  29. package/lib/esm/chunk-BSJP7CBP-BRqWaFD3.js.map +1 -1
  30. package/lib/esm/chunk-CIAEETIT-Dm4nDheA.js.map +1 -1
  31. package/lib/esm/chunk-EDXVE4YY-CyZVAPxl.js.map +1 -1
  32. package/lib/esm/chunk-ENJZ2VHE-D1RBdOy4.js.map +1 -1
  33. package/lib/esm/chunk-FOC6F5B3-DTxKWzfh.js.map +1 -1
  34. package/lib/esm/chunk-ICPOFSXX-BQ7-Poft.js.map +1 -1
  35. package/lib/esm/chunk-K5T4RW27-BZbwqbnj.js.map +1 -1
  36. package/lib/esm/chunk-KGLVRYIC-DGO8PqNS.js.map +1 -1
  37. package/lib/esm/chunk-LIHQZDEY-DRQpYuDY.js.map +1 -1
  38. package/lib/esm/chunk-ORNJ4GCN-BWnkQx42.js.map +1 -1
  39. package/lib/esm/{chunk-OYMX7WX6-C3qIK5JJ.js → chunk-OYMX7WX6-C3p3qx9s.js} +2 -2
  40. package/lib/esm/{chunk-OYMX7WX6-C3qIK5JJ.js.map → chunk-OYMX7WX6-C3p3qx9s.js.map} +1 -1
  41. package/lib/esm/chunk-QZHKN3VN-BIoC_CBh.js.map +1 -1
  42. package/lib/esm/chunk-U2HBQHQK-CNpf2t7b.js.map +1 -1
  43. package/lib/esm/chunk-X2U36JSP-Dh9T66Fy.js.map +1 -1
  44. package/lib/esm/chunk-XPW4576I-CdsuZylH.js.map +1 -1
  45. package/lib/esm/chunk-YZCP3GAM-D-LQWFJc.js.map +1 -1
  46. package/lib/esm/chunk-ZZ45TVLE-CP_4OsJR.js.map +1 -1
  47. package/lib/esm/{classDiagram-6PBFFD2Q-CfClLEok.js → classDiagram-6PBFFD2Q-CfucyocV.js} +3 -3
  48. package/lib/esm/{classDiagram-6PBFFD2Q-CfClLEok.js.map → classDiagram-6PBFFD2Q-CfucyocV.js.map} +1 -1
  49. package/lib/esm/{classDiagram-v2-HSJHXN6E-BlbDAEH6.js → classDiagram-v2-HSJHXN6E-BcU6iB1L.js} +3 -3
  50. package/lib/esm/{classDiagram-v2-HSJHXN6E-BlbDAEH6.js.map → classDiagram-v2-HSJHXN6E-BcU6iB1L.js.map} +1 -1
  51. package/lib/esm/clone-DhB5s2T9.js.map +1 -1
  52. package/lib/esm/cose-bilkent-S5V4N54A-BdVqhM8C.js.map +1 -1
  53. package/lib/esm/cytoscape.esm-CT-fsRss.js.map +1 -1
  54. package/lib/esm/dagre-BQULeUjQ.js.map +1 -1
  55. package/lib/esm/dagre-KV5264BT-DTy5YJ5_.js.map +1 -1
  56. package/lib/esm/diagram-5BDNPKRD-w19gCTBw.js.map +1 -1
  57. package/lib/esm/diagram-G4DWMVQ6-EfJtDPEB.js.map +1 -1
  58. package/lib/esm/diagram-MMDJMWI5-DsPB2uYP.js.map +1 -1
  59. package/lib/esm/diagram-TYMM5635-D3ecq7oF.js.map +1 -1
  60. package/lib/esm/dist-CZs_brJz.js.map +1 -1
  61. package/lib/esm/{erDiagram-SMLLAGMA-sgCGzaHO.js → erDiagram-SMLLAGMA-DsYSva8K.js} +2 -2
  62. package/lib/esm/{erDiagram-SMLLAGMA-sgCGzaHO.js.map → erDiagram-SMLLAGMA-DsYSva8K.js.map} +1 -1
  63. package/lib/esm/flatten-CRDGWjhS.js.map +1 -1
  64. package/lib/esm/{flowDiagram-DWJPFMVM-BlOft6GA.js → flowDiagram-DWJPFMVM-BkxIhdyA.js} +2 -2
  65. package/lib/esm/{flowDiagram-DWJPFMVM-BlOft6GA.js.map → flowDiagram-DWJPFMVM-BkxIhdyA.js.map} +1 -1
  66. package/lib/esm/ganttDiagram-T4ZO3ILL-BGrn6yEi.js.map +1 -1
  67. package/lib/esm/gitGraphDiagram-UUTBAWPF-BV73nor5.js.map +1 -1
  68. package/lib/esm/graphlib-B76sPwTV.js.map +1 -1
  69. package/lib/esm/infoDiagram-42DDH7IO-CYONnQuR.js.map +1 -1
  70. package/lib/esm/init-DcYXQL-k.js.map +1 -1
  71. package/lib/esm/isEmpty-DLTQgX7m.js.map +1 -1
  72. package/lib/esm/ishikawaDiagram-UXIWVN3A-B2ISni0r.js.map +1 -1
  73. package/lib/esm/journeyDiagram-VCZTEJTY-CjNMX7wx.js.map +1 -1
  74. package/lib/esm/kanban-definition-6JOO6SKY-BNsv25Cl.js.map +1 -1
  75. package/lib/esm/katex-DpumU0Fc.js.map +1 -1
  76. package/lib/esm/line-Dyv5of1r.js.map +1 -1
  77. package/lib/esm/linear-LpGdIFrk.js.map +1 -1
  78. package/lib/esm/mermaid-parser.core-D5sUsnWF.js.map +1 -1
  79. package/lib/esm/{mermaid.core-o6lwF-Gt.js → mermaid.core-i12yADTp.js} +12 -12
  80. package/lib/esm/{mermaid.core-o6lwF-Gt.js.map → mermaid.core-i12yADTp.js.map} +1 -1
  81. package/lib/esm/{mindmap-definition-QFDTVHPH-C63UTb48.js → mindmap-definition-QFDTVHPH-BfrBPDUJ.js} +2 -2
  82. package/lib/esm/{mindmap-definition-QFDTVHPH-C63UTb48.js.map → mindmap-definition-QFDTVHPH-BfrBPDUJ.js.map} +1 -1
  83. package/lib/esm/ordinal-B2RGggQH.js.map +1 -1
  84. package/lib/esm/path-Bg_3NlDP.js.map +1 -1
  85. package/lib/esm/pieDiagram-DEJITSTG-YByZ__0R.js.map +1 -1
  86. package/lib/esm/quadrantDiagram-34T5L4WZ-DLFKZc02.js.map +1 -1
  87. package/lib/esm/reduce-0ekdtexD.js.map +1 -1
  88. package/lib/esm/{requirementDiagram-MS252O5E-CJXcr8r4.js → requirementDiagram-MS252O5E-CulfPmse.js} +2 -2
  89. package/lib/esm/{requirementDiagram-MS252O5E-CJXcr8r4.js.map → requirementDiagram-MS252O5E-CulfPmse.js.map} +1 -1
  90. package/lib/esm/rough.esm-IQz7gRXZ.js.map +1 -1
  91. package/lib/esm/sankeyDiagram-XADWPNL6-DMByY6gK.js.map +1 -1
  92. package/lib/esm/sequenceDiagram-FGHM5R23-vJC9cjdX.js.map +1 -1
  93. package/lib/esm/src-BZm6Awwh.js.map +1 -1
  94. package/lib/esm/{src-C5doNKmD.js → src-DT2iBPF8.js} +629 -541
  95. package/lib/esm/src-DT2iBPF8.js.map +1 -0
  96. package/lib/esm/{stateDiagram-FHFEXIEX-G9WWEBGm.js → stateDiagram-FHFEXIEX-CofVLBPX.js} +3 -3
  97. package/lib/esm/{stateDiagram-FHFEXIEX-G9WWEBGm.js.map → stateDiagram-FHFEXIEX-CofVLBPX.js.map} +1 -1
  98. package/lib/esm/{stateDiagram-v2-QKLJ7IA2-BSg62pbb.js → stateDiagram-v2-QKLJ7IA2-DTXym7Y8.js} +3 -3
  99. package/lib/esm/{stateDiagram-v2-QKLJ7IA2-BSg62pbb.js.map → stateDiagram-v2-QKLJ7IA2-DTXym7Y8.js.map} +1 -1
  100. package/lib/esm/style.css +1 -1
  101. package/lib/esm/timeline-definition-GMOUNBTQ-DeWjV_e-.js.map +1 -1
  102. package/lib/esm/ui.js +4 -4
  103. package/lib/esm/vennDiagram-DHZGUBPP-CKdXCzw7.js.map +1 -1
  104. package/lib/esm/wardleyDiagram-NUSXRM2D-BzD8LDJv.js.map +1 -1
  105. package/lib/esm/xychartDiagram-5P7HB3ND-C2ITEA5J.js.map +1 -1
  106. package/lib/types/backoffice/molecules/backoffice_load_more/BackofficeLoadMore.d.ts +2 -1
  107. package/lib/types/backoffice/molecules/backoffice_load_more/BackofficeLoadMore.d.ts.map +1 -1
  108. package/lib/types/backoffice/molecules/backoffice_load_more/backofficeLoadMore.css.d.ts +1 -0
  109. package/lib/types/backoffice/molecules/backoffice_load_more/backofficeLoadMore.css.d.ts.map +1 -1
  110. package/lib/types/backoffice/molecules/sidebar_nav_section/SidebarNavSection.d.ts +1 -1
  111. package/lib/types/backoffice/molecules/sidebar_nav_section/SidebarNavSection.d.ts.map +1 -1
  112. package/lib/types/components/data-table/DataTable.d.ts +2 -0
  113. package/lib/types/components/data-table/DataTable.d.ts.map +1 -1
  114. package/lib/types/components/data-table/ResponsiveRecordList.css.d.ts +21 -0
  115. package/lib/types/components/data-table/ResponsiveRecordList.css.d.ts.map +1 -0
  116. package/lib/types/components/data-table/ResponsiveRecordList.d.ts +17 -0
  117. package/lib/types/components/data-table/ResponsiveRecordList.d.ts.map +1 -0
  118. package/lib/types/index.d.ts +2 -0
  119. package/lib/types/index.d.ts.map +1 -1
  120. package/package.json +12 -12
  121. package/lib/esm/MarkdownShikiCodeBlock-BhdpnKJo.js.map +0 -1
  122. package/lib/esm/src-C5doNKmD.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"gitGraphDiagram-UUTBAWPF-BV73nor5.js","names":["select"],"sources":["../../../../node_modules/mermaid/dist/chunks/mermaid.core/gitGraphDiagram-UUTBAWPF.mjs"],"sourcesContent":["import {\n populateCommonDb\n} from \"./chunk-4BX2VUAB.mjs\";\nimport {\n ImperativeState\n} from \"./chunk-QZHKN3VN.mjs\";\nimport {\n cleanAndMerge,\n random,\n utils_default\n} from \"./chunk-5PVQY5BW.mjs\";\nimport {\n clear,\n common_default,\n defaultConfig_default,\n getAccDescription,\n getAccTitle,\n getConfig,\n getConfig2,\n getDiagramTitle,\n setAccDescription,\n setAccTitle,\n setDiagramTitle,\n setupGraphViewbox2 as setupGraphViewbox\n} from \"./chunk-ICPOFSXX.mjs\";\nimport {\n __name,\n log\n} from \"./chunk-AGHRB4JF.mjs\";\n\n// src/diagrams/git/gitGraphParser.ts\nimport { parse } from \"@mermaid-js/parser\";\n\n// src/diagrams/git/gitGraphTypes.ts\nvar commitType = {\n NORMAL: 0,\n REVERSE: 1,\n HIGHLIGHT: 2,\n MERGE: 3,\n CHERRY_PICK: 4\n};\n\n// src/diagrams/git/gitGraphAst.ts\nvar DEFAULT_GITGRAPH_CONFIG = defaultConfig_default.gitGraph;\nvar getConfig3 = /* @__PURE__ */ __name(() => {\n const config = cleanAndMerge({\n ...DEFAULT_GITGRAPH_CONFIG,\n ...getConfig().gitGraph\n });\n return config;\n}, \"getConfig\");\nvar state = new ImperativeState(() => {\n const config = getConfig3();\n const mainBranchName = config.mainBranchName;\n const mainBranchOrder = config.mainBranchOrder;\n return {\n mainBranchName,\n commits: /* @__PURE__ */ new Map(),\n head: null,\n branchConfig: /* @__PURE__ */ new Map([[mainBranchName, { name: mainBranchName, order: mainBranchOrder }]]),\n branches: /* @__PURE__ */ new Map([[mainBranchName, null]]),\n currBranch: mainBranchName,\n direction: \"LR\",\n seq: 0,\n options: {}\n };\n});\nfunction getID() {\n return random({ length: 7 });\n}\n__name(getID, \"getID\");\nfunction uniqBy(list, fn) {\n const recordMap = /* @__PURE__ */ Object.create(null);\n return list.reduce((out, item) => {\n const key = fn(item);\n if (!recordMap[key]) {\n recordMap[key] = true;\n out.push(item);\n }\n return out;\n }, []);\n}\n__name(uniqBy, \"uniqBy\");\nvar setDirection = /* @__PURE__ */ __name(function(dir2) {\n state.records.direction = dir2;\n}, \"setDirection\");\nvar setOptions = /* @__PURE__ */ __name(function(rawOptString) {\n log.debug(\"options str\", rawOptString);\n rawOptString = rawOptString?.trim();\n rawOptString = rawOptString || \"{}\";\n try {\n state.records.options = JSON.parse(rawOptString);\n } catch (e) {\n log.error(\"error while parsing gitGraph options\", e.message);\n }\n}, \"setOptions\");\nvar getOptions = /* @__PURE__ */ __name(function() {\n return state.records.options;\n}, \"getOptions\");\nvar commit = /* @__PURE__ */ __name(function(commitDB) {\n let msg = commitDB.msg;\n let id = commitDB.id;\n const type = commitDB.type;\n let tags = commitDB.tags;\n log.info(\"commit\", msg, id, type, tags);\n log.debug(\"Entering commit:\", msg, id, type, tags);\n const config = getConfig3();\n id = common_default.sanitizeText(id, config);\n msg = common_default.sanitizeText(msg, config);\n tags = tags?.map((tag) => common_default.sanitizeText(tag, config));\n const newCommit = {\n id: id ? id : state.records.seq + \"-\" + getID(),\n message: msg,\n seq: state.records.seq++,\n type: type ?? commitType.NORMAL,\n tags: tags ?? [],\n parents: state.records.head == null ? [] : [state.records.head.id],\n branch: state.records.currBranch\n };\n state.records.head = newCommit;\n log.info(\"main branch\", config.mainBranchName);\n if (state.records.commits.has(newCommit.id)) {\n log.warn(`Commit ID ${newCommit.id} already exists`);\n }\n state.records.commits.set(newCommit.id, newCommit);\n state.records.branches.set(state.records.currBranch, newCommit.id);\n log.debug(\"in pushCommit \" + newCommit.id);\n}, \"commit\");\nvar branch = /* @__PURE__ */ __name(function(branchDB) {\n let name = branchDB.name;\n const order = branchDB.order;\n name = common_default.sanitizeText(name, getConfig3());\n if (state.records.branches.has(name)) {\n throw new Error(\n `Trying to create an existing branch. (Help: Either use a new name if you want create a new branch or try using \"checkout ${name}\")`\n );\n }\n state.records.branches.set(name, state.records.head != null ? state.records.head.id : null);\n state.records.branchConfig.set(name, { name, order });\n checkout(name);\n log.debug(\"in createBranch\");\n}, \"branch\");\nvar merge = /* @__PURE__ */ __name((mergeDB) => {\n let otherBranch = mergeDB.branch;\n let customId = mergeDB.id;\n const overrideType = mergeDB.type;\n const customTags = mergeDB.tags;\n const config = getConfig3();\n otherBranch = common_default.sanitizeText(otherBranch, config);\n if (customId) {\n customId = common_default.sanitizeText(customId, config);\n }\n const currentBranchCheck = state.records.branches.get(state.records.currBranch);\n const otherBranchCheck = state.records.branches.get(otherBranch);\n const currentCommit = currentBranchCheck ? state.records.commits.get(currentBranchCheck) : void 0;\n const otherCommit = otherBranchCheck ? state.records.commits.get(otherBranchCheck) : void 0;\n if (currentCommit && otherCommit && currentCommit.branch === otherBranch) {\n throw new Error(`Cannot merge branch '${otherBranch}' into itself.`);\n }\n if (state.records.currBranch === otherBranch) {\n const error = new Error('Incorrect usage of \"merge\". Cannot merge a branch to itself');\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [\"branch abc\"]\n };\n throw error;\n }\n if (currentCommit === void 0 || !currentCommit) {\n const error = new Error(\n `Incorrect usage of \"merge\". Current branch (${state.records.currBranch})has no commits`\n );\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [\"commit\"]\n };\n throw error;\n }\n if (!state.records.branches.has(otherBranch)) {\n const error = new Error(\n 'Incorrect usage of \"merge\". Branch to be merged (' + otherBranch + \") does not exist\"\n );\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [`branch ${otherBranch}`]\n };\n throw error;\n }\n if (otherCommit === void 0 || !otherCommit) {\n const error = new Error(\n 'Incorrect usage of \"merge\". Branch to be merged (' + otherBranch + \") has no commits\"\n );\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: ['\"commit\"']\n };\n throw error;\n }\n if (currentCommit === otherCommit) {\n const error = new Error('Incorrect usage of \"merge\". Both branches have same head');\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [\"branch abc\"]\n };\n throw error;\n }\n if (customId && state.records.commits.has(customId)) {\n const error = new Error(\n 'Incorrect usage of \"merge\". Commit with id:' + customId + \" already exists, use different custom id\"\n );\n error.hash = {\n text: `merge ${otherBranch} ${customId} ${overrideType} ${customTags?.join(\" \")}`,\n token: `merge ${otherBranch} ${customId} ${overrideType} ${customTags?.join(\" \")}`,\n expected: [\n `merge ${otherBranch} ${customId}_UNIQUE ${overrideType} ${customTags?.join(\" \")}`\n ]\n };\n throw error;\n }\n const verifiedBranch = otherBranchCheck ? otherBranchCheck : \"\";\n const commit2 = {\n id: customId || `${state.records.seq}-${getID()}`,\n message: `merged branch ${otherBranch} into ${state.records.currBranch}`,\n seq: state.records.seq++,\n parents: state.records.head == null ? [] : [state.records.head.id, verifiedBranch],\n branch: state.records.currBranch,\n type: commitType.MERGE,\n customType: overrideType,\n customId: customId ? true : false,\n tags: customTags ?? []\n };\n state.records.head = commit2;\n state.records.commits.set(commit2.id, commit2);\n state.records.branches.set(state.records.currBranch, commit2.id);\n log.debug(state.records.branches);\n log.debug(\"in mergeBranch\");\n}, \"merge\");\nvar cherryPick = /* @__PURE__ */ __name(function(cherryPickDB) {\n let sourceId = cherryPickDB.id;\n let targetId = cherryPickDB.targetId;\n let tags = cherryPickDB.tags;\n let parentCommitId = cherryPickDB.parent;\n log.debug(\"Entering cherryPick:\", sourceId, targetId, tags);\n const config = getConfig3();\n sourceId = common_default.sanitizeText(sourceId, config);\n targetId = common_default.sanitizeText(targetId, config);\n tags = tags?.map((tag) => common_default.sanitizeText(tag, config));\n parentCommitId = common_default.sanitizeText(parentCommitId, config);\n if (!sourceId || !state.records.commits.has(sourceId)) {\n const error = new Error(\n 'Incorrect usage of \"cherryPick\". Source commit id should exist and provided'\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const sourceCommit = state.records.commits.get(sourceId);\n if (sourceCommit === void 0 || !sourceCommit) {\n throw new Error('Incorrect usage of \"cherryPick\". Source commit id should exist and provided');\n }\n if (parentCommitId && !(Array.isArray(sourceCommit.parents) && sourceCommit.parents.includes(parentCommitId))) {\n const error = new Error(\n \"Invalid operation: The specified parent commit is not an immediate parent of the cherry-picked commit.\"\n );\n throw error;\n }\n const sourceCommitBranch = sourceCommit.branch;\n if (sourceCommit.type === commitType.MERGE && !parentCommitId) {\n const error = new Error(\n \"Incorrect usage of cherry-pick: If the source commit is a merge commit, an immediate parent commit must be specified.\"\n );\n throw error;\n }\n if (!targetId || !state.records.commits.has(targetId)) {\n if (sourceCommitBranch === state.records.currBranch) {\n const error = new Error(\n 'Incorrect usage of \"cherryPick\". Source commit is already on current branch'\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const currentCommitId = state.records.branches.get(state.records.currBranch);\n if (currentCommitId === void 0 || !currentCommitId) {\n const error = new Error(\n `Incorrect usage of \"cherry-pick\". Current branch (${state.records.currBranch})has no commits`\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const currentCommit = state.records.commits.get(currentCommitId);\n if (currentCommit === void 0 || !currentCommit) {\n const error = new Error(\n `Incorrect usage of \"cherry-pick\". Current branch (${state.records.currBranch})has no commits`\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const commit2 = {\n id: state.records.seq + \"-\" + getID(),\n message: `cherry-picked ${sourceCommit?.message} into ${state.records.currBranch}`,\n seq: state.records.seq++,\n parents: state.records.head == null ? [] : [state.records.head.id, sourceCommit.id],\n branch: state.records.currBranch,\n type: commitType.CHERRY_PICK,\n tags: tags ? tags.filter(Boolean) : [\n `cherry-pick:${sourceCommit.id}${sourceCommit.type === commitType.MERGE ? `|parent:${parentCommitId}` : \"\"}`\n ]\n };\n state.records.head = commit2;\n state.records.commits.set(commit2.id, commit2);\n state.records.branches.set(state.records.currBranch, commit2.id);\n log.debug(state.records.branches);\n log.debug(\"in cherryPick\");\n }\n}, \"cherryPick\");\nvar checkout = /* @__PURE__ */ __name(function(branch2) {\n branch2 = common_default.sanitizeText(branch2, getConfig3());\n if (!state.records.branches.has(branch2)) {\n const error = new Error(\n `Trying to checkout branch which is not yet created. (Help try using \"branch ${branch2}\")`\n );\n error.hash = {\n text: `checkout ${branch2}`,\n token: `checkout ${branch2}`,\n expected: [`branch ${branch2}`]\n };\n throw error;\n } else {\n state.records.currBranch = branch2;\n const id = state.records.branches.get(state.records.currBranch);\n if (id === void 0 || !id) {\n state.records.head = null;\n } else {\n state.records.head = state.records.commits.get(id) ?? null;\n }\n }\n}, \"checkout\");\nfunction upsert(arr, key, newVal) {\n const index = arr.indexOf(key);\n if (index === -1) {\n arr.push(newVal);\n } else {\n arr.splice(index, 1, newVal);\n }\n}\n__name(upsert, \"upsert\");\nfunction prettyPrintCommitHistory(commitArr) {\n const commit2 = commitArr.reduce((out, commit3) => {\n if (out.seq > commit3.seq) {\n return out;\n }\n return commit3;\n }, commitArr[0]);\n let line = \"\";\n commitArr.forEach(function(c) {\n if (c === commit2) {\n line += \"\t*\";\n } else {\n line += \"\t|\";\n }\n });\n const label = [line, commit2.id, commit2.seq];\n for (const branch2 in state.records.branches) {\n if (state.records.branches.get(branch2) === commit2.id) {\n label.push(branch2);\n }\n }\n log.debug(label.join(\" \"));\n if (commit2.parents && commit2.parents.length == 2 && commit2.parents[0] && commit2.parents[1]) {\n const newCommit = state.records.commits.get(commit2.parents[0]);\n upsert(commitArr, commit2, newCommit);\n if (commit2.parents[1]) {\n commitArr.push(state.records.commits.get(commit2.parents[1]));\n }\n } else if (commit2.parents.length == 0) {\n return;\n } else {\n if (commit2.parents[0]) {\n const newCommit = state.records.commits.get(commit2.parents[0]);\n upsert(commitArr, commit2, newCommit);\n }\n }\n commitArr = uniqBy(commitArr, (c) => c.id);\n prettyPrintCommitHistory(commitArr);\n}\n__name(prettyPrintCommitHistory, \"prettyPrintCommitHistory\");\nvar prettyPrint = /* @__PURE__ */ __name(function() {\n log.debug(state.records.commits);\n const node = getCommitsArray()[0];\n prettyPrintCommitHistory([node]);\n}, \"prettyPrint\");\nvar clear2 = /* @__PURE__ */ __name(function() {\n state.reset();\n clear();\n}, \"clear\");\nvar getBranchesAsObjArray = /* @__PURE__ */ __name(function() {\n const branchesArray = [...state.records.branchConfig.values()].map((branchConfig, i) => {\n if (branchConfig.order !== null && branchConfig.order !== void 0) {\n return branchConfig;\n }\n return {\n ...branchConfig,\n order: parseFloat(`0.${i}`)\n };\n }).sort((a, b) => (a.order ?? 0) - (b.order ?? 0)).map(({ name }) => ({ name }));\n return branchesArray;\n}, \"getBranchesAsObjArray\");\nvar getBranches = /* @__PURE__ */ __name(function() {\n return state.records.branches;\n}, \"getBranches\");\nvar getCommits = /* @__PURE__ */ __name(function() {\n return state.records.commits;\n}, \"getCommits\");\nvar getCommitsArray = /* @__PURE__ */ __name(function() {\n const commitArr = [...state.records.commits.values()];\n commitArr.forEach(function(o) {\n log.debug(o.id);\n });\n commitArr.sort((a, b) => a.seq - b.seq);\n return commitArr;\n}, \"getCommitsArray\");\nvar getCurrentBranch = /* @__PURE__ */ __name(function() {\n return state.records.currBranch;\n}, \"getCurrentBranch\");\nvar getDirection = /* @__PURE__ */ __name(function() {\n return state.records.direction;\n}, \"getDirection\");\nvar getHead = /* @__PURE__ */ __name(function() {\n return state.records.head;\n}, \"getHead\");\nvar db = {\n commitType,\n getConfig: getConfig3,\n setDirection,\n setOptions,\n getOptions,\n commit,\n branch,\n merge,\n cherryPick,\n checkout,\n //reset,\n prettyPrint,\n clear: clear2,\n getBranchesAsObjArray,\n getBranches,\n getCommits,\n getCommitsArray,\n getCurrentBranch,\n getDirection,\n getHead,\n setAccTitle,\n getAccTitle,\n getAccDescription,\n setAccDescription,\n setDiagramTitle,\n getDiagramTitle\n};\n\n// src/diagrams/git/gitGraphParser.ts\nvar populate = /* @__PURE__ */ __name((ast, db2) => {\n populateCommonDb(ast, db2);\n if (ast.dir) {\n db2.setDirection(ast.dir);\n }\n for (const statement of ast.statements) {\n parseStatement(statement, db2);\n }\n}, \"populate\");\nvar parseStatement = /* @__PURE__ */ __name((statement, db2) => {\n const parsers = {\n Commit: /* @__PURE__ */ __name((stmt) => db2.commit(parseCommit(stmt)), \"Commit\"),\n Branch: /* @__PURE__ */ __name((stmt) => db2.branch(parseBranch(stmt)), \"Branch\"),\n Merge: /* @__PURE__ */ __name((stmt) => db2.merge(parseMerge(stmt)), \"Merge\"),\n Checkout: /* @__PURE__ */ __name((stmt) => db2.checkout(parseCheckout(stmt)), \"Checkout\"),\n CherryPicking: /* @__PURE__ */ __name((stmt) => db2.cherryPick(parseCherryPicking(stmt)), \"CherryPicking\")\n };\n const parser2 = parsers[statement.$type];\n if (parser2) {\n parser2(statement);\n } else {\n log.error(`Unknown statement type: ${statement.$type}`);\n }\n}, \"parseStatement\");\nvar parseCommit = /* @__PURE__ */ __name((commit2) => {\n const commitDB = {\n id: commit2.id,\n msg: commit2.message ?? \"\",\n type: commit2.type !== void 0 ? commitType[commit2.type] : commitType.NORMAL,\n tags: commit2.tags ?? void 0\n };\n return commitDB;\n}, \"parseCommit\");\nvar parseBranch = /* @__PURE__ */ __name((branch2) => {\n const branchDB = {\n name: branch2.name,\n order: branch2.order ?? 0\n };\n return branchDB;\n}, \"parseBranch\");\nvar parseMerge = /* @__PURE__ */ __name((merge2) => {\n const mergeDB = {\n branch: merge2.branch,\n id: merge2.id ?? \"\",\n type: merge2.type !== void 0 ? commitType[merge2.type] : void 0,\n tags: merge2.tags ?? void 0\n };\n return mergeDB;\n}, \"parseMerge\");\nvar parseCheckout = /* @__PURE__ */ __name((checkout2) => {\n const branch2 = checkout2.branch;\n return branch2;\n}, \"parseCheckout\");\nvar parseCherryPicking = /* @__PURE__ */ __name((cherryPicking) => {\n const cherryPickDB = {\n id: cherryPicking.id,\n targetId: \"\",\n tags: cherryPicking.tags?.length === 0 ? void 0 : cherryPicking.tags,\n parent: cherryPicking.parent\n };\n return cherryPickDB;\n}, \"parseCherryPicking\");\nvar parser = {\n parse: /* @__PURE__ */ __name(async (input) => {\n const ast = await parse(\"gitGraph\", input);\n log.debug(ast);\n populate(ast, db);\n }, \"parse\")\n};\nif (void 0) {\n const { it, expect, describe } = void 0;\n const mockDB = {\n commitType,\n setDirection: vi.fn(),\n commit: vi.fn(),\n branch: vi.fn(),\n merge: vi.fn(),\n cherryPick: vi.fn(),\n checkout: vi.fn()\n };\n describe(\"GitGraph Parser\", () => {\n it(\"should parse a commit statement\", () => {\n const commit2 = {\n $type: \"Commit\",\n id: \"1\",\n message: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n };\n parseStatement(commit2, mockDB);\n expect(mockDB.commit).toHaveBeenCalledWith({\n id: \"1\",\n msg: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n });\n it(\"should parse a branch statement\", () => {\n const branch2 = {\n $type: \"Branch\",\n name: \"newBranch\",\n order: 1\n };\n parseStatement(branch2, mockDB);\n expect(mockDB.branch).toHaveBeenCalledWith({ name: \"newBranch\", order: 1 });\n });\n it(\"should parse a checkout statement\", () => {\n const checkout2 = {\n $type: \"Checkout\",\n branch: \"newBranch\"\n };\n parseStatement(checkout2, mockDB);\n expect(mockDB.checkout).toHaveBeenCalledWith(\"newBranch\");\n });\n it(\"should parse a merge statement\", () => {\n const merge2 = {\n $type: \"Merge\",\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n };\n parseStatement(merge2, mockDB);\n expect(mockDB.merge).toHaveBeenCalledWith({\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n });\n it(\"should parse a cherry picking statement\", () => {\n const cherryPick2 = {\n $type: \"CherryPicking\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n parent: \"2\"\n };\n parseStatement(cherryPick2, mockDB);\n expect(mockDB.cherryPick).toHaveBeenCalledWith({\n id: \"1\",\n targetId: \"\",\n parent: \"2\",\n tags: [\"tag1\", \"tag2\"]\n });\n });\n it(\"should parse a langium generated gitGraph ast\", () => {\n const dummy = {\n $type: \"GitGraph\",\n statements: [],\n accDescr: \"\",\n accTitle: \"\",\n title: \"\"\n };\n const gitGraphAst = {\n $type: \"GitGraph\",\n statements: [\n {\n $container: dummy,\n $type: \"Commit\",\n id: \"1\",\n message: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n },\n {\n $container: dummy,\n $type: \"Branch\",\n name: \"newBranch\",\n order: 1\n },\n {\n $container: dummy,\n $type: \"Merge\",\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n },\n {\n $container: dummy,\n $type: \"Checkout\",\n branch: \"newBranch\"\n },\n {\n $container: dummy,\n $type: \"CherryPicking\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n parent: \"2\"\n }\n ],\n accDescr: \"\",\n accTitle: \"\",\n title: \"\"\n };\n populate(gitGraphAst, mockDB);\n expect(mockDB.commit).toHaveBeenCalledWith({\n id: \"1\",\n msg: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n expect(mockDB.branch).toHaveBeenCalledWith({ name: \"newBranch\", order: 1 });\n expect(mockDB.merge).toHaveBeenCalledWith({\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n expect(mockDB.checkout).toHaveBeenCalledWith(\"newBranch\");\n });\n });\n}\n\n// src/diagrams/git/gitGraphRenderer.ts\nimport { select } from \"d3\";\nvar LAYOUT_OFFSET = 10;\nvar COMMIT_STEP = 40;\nvar PX = 4;\nvar PY = 2;\nvar THEME_COLOR_LIMIT = 8;\nvar REDUX_GEOMETRY_THEMES = /* @__PURE__ */ new Set([\"redux\", \"redux-dark\", \"redux-color\", \"redux-dark-color\"]);\nvar REDUX_BRANCH_LABEL_PADDING_Y = 12;\nvar COLOR_THEMES = /* @__PURE__ */ new Set([\"redux-color\", \"redux-dark-color\"]);\nvar DARK_THEMES = /* @__PURE__ */ new Set([\"dark\", \"redux-dark\", \"redux-dark-color\", \"neo-dark\"]);\nvar calcColorIndex = /* @__PURE__ */ __name((rawIndex, limit, avoidDefaultColor = false) => {\n if (avoidDefaultColor && rawIndex > 0) {\n return (rawIndex - 1) % (limit - 1) + 1;\n }\n return rawIndex % limit;\n}, \"calcColorIndex\");\nvar branchPos = /* @__PURE__ */ new Map();\nvar commitPos = /* @__PURE__ */ new Map();\nvar defaultPos = 30;\nvar allCommitsDict = /* @__PURE__ */ new Map();\nvar lanes = [];\nvar maxPos = 0;\nvar dir = \"LR\";\nvar clear3 = /* @__PURE__ */ __name(() => {\n branchPos.clear();\n commitPos.clear();\n allCommitsDict.clear();\n maxPos = 0;\n lanes = [];\n dir = \"LR\";\n}, \"clear\");\nvar drawText = /* @__PURE__ */ __name((txt) => {\n const svgLabel = document.createElementNS(\"http://www.w3.org/2000/svg\", \"text\");\n const rows = typeof txt === \"string\" ? txt.split(/\\\\n|\\n|<br\\s*\\/?>/gi) : txt;\n rows.forEach((row) => {\n const tspan = document.createElementNS(\"http://www.w3.org/2000/svg\", \"tspan\");\n tspan.setAttributeNS(\"http://www.w3.org/XML/1998/namespace\", \"xml:space\", \"preserve\");\n tspan.setAttribute(\"dy\", \"1em\");\n tspan.setAttribute(\"x\", \"0\");\n tspan.setAttribute(\"class\", \"row\");\n tspan.textContent = row.trim();\n svgLabel.appendChild(tspan);\n });\n return svgLabel;\n}, \"drawText\");\nvar findClosestParent = /* @__PURE__ */ __name((parents) => {\n let closestParent;\n let comparisonFunc;\n let targetPosition;\n if (dir === \"BT\") {\n comparisonFunc = /* @__PURE__ */ __name((a, b) => a <= b, \"comparisonFunc\");\n targetPosition = Infinity;\n } else {\n comparisonFunc = /* @__PURE__ */ __name((a, b) => a >= b, \"comparisonFunc\");\n targetPosition = 0;\n }\n parents.forEach((parent) => {\n const parentPosition = dir === \"TB\" || dir == \"BT\" ? commitPos.get(parent)?.y : commitPos.get(parent)?.x;\n if (parentPosition !== void 0 && comparisonFunc(parentPosition, targetPosition)) {\n closestParent = parent;\n targetPosition = parentPosition;\n }\n });\n return closestParent;\n}, \"findClosestParent\");\nvar findClosestParentBT = /* @__PURE__ */ __name((parents) => {\n let closestParent = \"\";\n let maxPosition = Infinity;\n parents.forEach((parent) => {\n const parentPosition = commitPos.get(parent).y;\n if (parentPosition <= maxPosition) {\n closestParent = parent;\n maxPosition = parentPosition;\n }\n });\n return closestParent || void 0;\n}, \"findClosestParentBT\");\nvar setParallelBTPos = /* @__PURE__ */ __name((sortedKeys, commits, defaultPos2) => {\n let curPos = defaultPos2;\n let maxPosition = defaultPos2;\n const roots = [];\n sortedKeys.forEach((key) => {\n const commit2 = commits.get(key);\n if (!commit2) {\n throw new Error(`Commit not found for key ${key}`);\n }\n if (commit2.parents.length) {\n curPos = calculateCommitPosition(commit2);\n maxPosition = Math.max(curPos, maxPosition);\n } else {\n roots.push(commit2);\n }\n setCommitPosition(commit2, curPos);\n });\n curPos = maxPosition;\n roots.forEach((commit2) => {\n setRootPosition(commit2, curPos, defaultPos2);\n });\n sortedKeys.forEach((key) => {\n const commit2 = commits.get(key);\n if (commit2?.parents.length) {\n const closestParent = findClosestParentBT(commit2.parents);\n curPos = commitPos.get(closestParent).y - COMMIT_STEP;\n if (curPos <= maxPosition) {\n maxPosition = curPos;\n }\n const x = branchPos.get(commit2.branch).pos;\n const y = curPos - LAYOUT_OFFSET;\n commitPos.set(commit2.id, { x, y });\n }\n });\n}, \"setParallelBTPos\");\nvar findClosestParentPos = /* @__PURE__ */ __name((commit2) => {\n const closestParent = findClosestParent(commit2.parents.filter((p) => p !== null));\n if (!closestParent) {\n throw new Error(`Closest parent not found for commit ${commit2.id}`);\n }\n const closestParentPos = commitPos.get(closestParent)?.y;\n if (closestParentPos === void 0) {\n throw new Error(`Closest parent position not found for commit ${commit2.id}`);\n }\n return closestParentPos;\n}, \"findClosestParentPos\");\nvar calculateCommitPosition = /* @__PURE__ */ __name((commit2) => {\n const closestParentPos = findClosestParentPos(commit2);\n return closestParentPos + COMMIT_STEP;\n}, \"calculateCommitPosition\");\nvar setCommitPosition = /* @__PURE__ */ __name((commit2, curPos) => {\n const branch2 = branchPos.get(commit2.branch);\n if (!branch2) {\n throw new Error(`Branch not found for commit ${commit2.id}`);\n }\n const x = branch2.pos;\n const y = curPos + LAYOUT_OFFSET;\n commitPos.set(commit2.id, { x, y });\n return { x, y };\n}, \"setCommitPosition\");\nvar setRootPosition = /* @__PURE__ */ __name((commit2, curPos, defaultPos2) => {\n const branch2 = branchPos.get(commit2.branch);\n if (!branch2) {\n throw new Error(`Branch not found for commit ${commit2.id}`);\n }\n const y = curPos + defaultPos2;\n const x = branch2.pos;\n commitPos.set(commit2.id, { x, y });\n}, \"setRootPosition\");\nvar drawCommitBullet = /* @__PURE__ */ __name((gBullets, commit2, commitPosition, typeClass, branchIndex, commitSymbolType) => {\n const { theme } = getConfig2();\n const useReduxGeometry = REDUX_GEOMETRY_THEMES.has(theme ?? \"\");\n const useColorTheme = COLOR_THEMES.has(theme ?? \"\");\n const isDark = DARK_THEMES.has(theme ?? \"\");\n if (commitSymbolType === commitType.HIGHLIGHT) {\n gBullets.append(\"rect\").attr(\"x\", commitPosition.x - 10 + (useReduxGeometry ? 3 : 0)).attr(\"y\", commitPosition.y - 10 + (useReduxGeometry ? 3 : 0)).attr(\"width\", useReduxGeometry ? 14 : 20).attr(\"height\", useReduxGeometry ? 14 : 20).attr(\n \"class\",\n `commit ${commit2.id} commit-highlight${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)} ${typeClass}-outer`\n );\n gBullets.append(\"rect\").attr(\"x\", commitPosition.x - 6 + (useReduxGeometry ? 2 : 0)).attr(\"y\", commitPosition.y - 6 + (useReduxGeometry ? 2 : 0)).attr(\"width\", useReduxGeometry ? 8 : 12).attr(\"height\", useReduxGeometry ? 8 : 12).attr(\n \"class\",\n `commit ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)} ${typeClass}-inner`\n );\n } else if (commitSymbolType === commitType.CHERRY_PICK) {\n gBullets.append(\"circle\").attr(\"cx\", commitPosition.x).attr(\"cy\", commitPosition.y).attr(\"r\", useReduxGeometry ? 7 : 10).attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"circle\").attr(\"cx\", commitPosition.x - 3).attr(\"cy\", commitPosition.y + 2).attr(\"r\", useReduxGeometry ? 2.5 : 2.75).attr(\"fill\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"circle\").attr(\"cx\", commitPosition.x + 3).attr(\"cy\", commitPosition.y + 2).attr(\"r\", useReduxGeometry ? 2.5 : 2.75).attr(\"fill\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"line\").attr(\"x1\", commitPosition.x + 3).attr(\"y1\", commitPosition.y + 1).attr(\"x2\", commitPosition.x).attr(\"y2\", commitPosition.y - 5).attr(\"stroke\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"line\").attr(\"x1\", commitPosition.x - 3).attr(\"y1\", commitPosition.y + 1).attr(\"x2\", commitPosition.x).attr(\"y2\", commitPosition.y - 5).attr(\"stroke\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n } else {\n const circle = gBullets.append(\"circle\");\n circle.attr(\"cx\", commitPosition.x);\n circle.attr(\"cy\", commitPosition.y);\n circle.attr(\"r\", useReduxGeometry ? 7 : 10);\n circle.attr(\n \"class\",\n `commit ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)}`\n );\n if (commitSymbolType === commitType.MERGE) {\n const circle2 = gBullets.append(\"circle\");\n circle2.attr(\"cx\", commitPosition.x);\n circle2.attr(\"cy\", commitPosition.y);\n circle2.attr(\"r\", useReduxGeometry ? 5 : 6);\n circle2.attr(\n \"class\",\n `commit ${typeClass} ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)}`\n );\n }\n if (commitSymbolType === commitType.REVERSE) {\n const cross = gBullets.append(\"path\");\n const constValue = useReduxGeometry ? 4 : 5;\n cross.attr(\n \"d\",\n `M ${commitPosition.x - constValue},${commitPosition.y - constValue}L${commitPosition.x + constValue},${commitPosition.y + constValue}M${commitPosition.x - constValue},${commitPosition.y + constValue}L${commitPosition.x + constValue},${commitPosition.y - constValue}`\n ).attr(\n \"class\",\n `commit ${typeClass} ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)}`\n );\n }\n }\n}, \"drawCommitBullet\");\nvar drawCommitLabel = /* @__PURE__ */ __name((gLabels, commit2, commitPosition, pos, gitGraphConfig) => {\n if (commit2.type !== commitType.CHERRY_PICK && (commit2.customId && commit2.type === commitType.MERGE || commit2.type !== commitType.MERGE) && gitGraphConfig.showCommitLabel) {\n const wrapper = gLabels.append(\"g\");\n const labelBkg = wrapper.insert(\"rect\").attr(\"class\", \"commit-label-bkg\");\n const text = wrapper.append(\"text\").attr(\"x\", pos).attr(\"y\", commitPosition.y + 25).attr(\"class\", \"commit-label\").text(commit2.id);\n const bbox = text.node()?.getBBox();\n if (bbox) {\n labelBkg.attr(\"x\", commitPosition.posWithOffset - bbox.width / 2 - PY).attr(\"y\", commitPosition.y + 13.5).attr(\"width\", bbox.width + 2 * PY).attr(\"height\", bbox.height + 2 * PY);\n if (dir === \"TB\" || dir === \"BT\") {\n labelBkg.attr(\"x\", commitPosition.x - (bbox.width + 4 * PX + 5)).attr(\"y\", commitPosition.y - 12);\n text.attr(\"x\", commitPosition.x - (bbox.width + 4 * PX)).attr(\"y\", commitPosition.y + bbox.height - 12);\n } else {\n text.attr(\"x\", commitPosition.posWithOffset - bbox.width / 2);\n }\n if (gitGraphConfig.rotateCommitLabel) {\n if (dir === \"TB\" || dir === \"BT\") {\n text.attr(\n \"transform\",\n \"rotate(-45, \" + commitPosition.x + \", \" + commitPosition.y + \")\"\n );\n labelBkg.attr(\n \"transform\",\n \"rotate(-45, \" + commitPosition.x + \", \" + commitPosition.y + \")\"\n );\n } else {\n const r_x = -7.5 - (bbox.width + 10) / 25 * 9.5;\n const r_y = 10 + bbox.width / 25 * 8.5;\n wrapper.attr(\n \"transform\",\n \"translate(\" + r_x + \", \" + r_y + \") rotate(-45, \" + pos + \", \" + commitPosition.y + \")\"\n );\n }\n }\n }\n }\n}, \"drawCommitLabel\");\nvar drawCommitTags = /* @__PURE__ */ __name((gLabels, commit2, commitPosition, pos) => {\n if (commit2.tags.length > 0) {\n let yOffset = 0;\n let maxTagBboxWidth = 0;\n let maxTagBboxHeight = 0;\n const tagElements = [];\n for (const tagValue of commit2.tags.reverse()) {\n const rect = gLabels.insert(\"polygon\");\n const hole = gLabels.append(\"circle\");\n const tag = gLabels.append(\"text\").attr(\"y\", commitPosition.y - 16 - yOffset).attr(\"class\", \"tag-label\").text(tagValue);\n const tagBbox = tag.node()?.getBBox();\n if (!tagBbox) {\n throw new Error(\"Tag bbox not found\");\n }\n maxTagBboxWidth = Math.max(maxTagBboxWidth, tagBbox.width);\n maxTagBboxHeight = Math.max(maxTagBboxHeight, tagBbox.height);\n tag.attr(\"x\", commitPosition.posWithOffset - tagBbox.width / 2);\n tagElements.push({\n tag,\n hole,\n rect,\n yOffset\n });\n yOffset += 20;\n }\n for (const { tag, hole, rect, yOffset: yOffset2 } of tagElements) {\n const h2 = maxTagBboxHeight / 2;\n const ly = commitPosition.y - 19.2 - yOffset2;\n rect.attr(\"class\", \"tag-label-bkg\").attr(\n \"points\",\n `\n ${pos - maxTagBboxWidth / 2 - PX / 2},${ly + PY} \n ${pos - maxTagBboxWidth / 2 - PX / 2},${ly - PY}\n ${commitPosition.posWithOffset - maxTagBboxWidth / 2 - PX},${ly - h2 - PY}\n ${commitPosition.posWithOffset + maxTagBboxWidth / 2 + PX},${ly - h2 - PY}\n ${commitPosition.posWithOffset + maxTagBboxWidth / 2 + PX},${ly + h2 + PY}\n ${commitPosition.posWithOffset - maxTagBboxWidth / 2 - PX},${ly + h2 + PY}`\n );\n hole.attr(\"cy\", ly).attr(\"cx\", pos - maxTagBboxWidth / 2 + PX / 2).attr(\"r\", 1.5).attr(\"class\", \"tag-hole\");\n if (dir === \"TB\" || dir === \"BT\") {\n const yOrigin = pos + yOffset2;\n rect.attr(\"class\", \"tag-label-bkg\").attr(\n \"points\",\n `\n ${commitPosition.x},${yOrigin + 2}\n ${commitPosition.x},${yOrigin - 2}\n ${commitPosition.x + LAYOUT_OFFSET},${yOrigin - h2 - 2}\n ${commitPosition.x + LAYOUT_OFFSET + maxTagBboxWidth + 4},${yOrigin - h2 - 2}\n ${commitPosition.x + LAYOUT_OFFSET + maxTagBboxWidth + 4},${yOrigin + h2 + 2}\n ${commitPosition.x + LAYOUT_OFFSET},${yOrigin + h2 + 2}`\n ).attr(\"transform\", \"translate(12,12) rotate(45, \" + commitPosition.x + \",\" + pos + \")\");\n hole.attr(\"cx\", commitPosition.x + PX / 2).attr(\"cy\", yOrigin).attr(\"transform\", \"translate(12,12) rotate(45, \" + commitPosition.x + \",\" + pos + \")\");\n tag.attr(\"x\", commitPosition.x + 5).attr(\"y\", yOrigin + 3).attr(\"transform\", \"translate(14,14) rotate(45, \" + commitPosition.x + \",\" + pos + \")\");\n }\n }\n }\n}, \"drawCommitTags\");\nvar getCommitClassType = /* @__PURE__ */ __name((commit2) => {\n const commitSymbolType = commit2.customType ?? commit2.type;\n switch (commitSymbolType) {\n case commitType.NORMAL:\n return \"commit-normal\";\n case commitType.REVERSE:\n return \"commit-reverse\";\n case commitType.HIGHLIGHT:\n return \"commit-highlight\";\n case commitType.MERGE:\n return \"commit-merge\";\n case commitType.CHERRY_PICK:\n return \"commit-cherry-pick\";\n default:\n return \"commit-normal\";\n }\n}, \"getCommitClassType\");\nvar calculatePosition = /* @__PURE__ */ __name((commit2, dir2, pos, commitPos2) => {\n const defaultCommitPosition = { x: 0, y: 0 };\n if (commit2.parents.length > 0) {\n const closestParent = findClosestParent(commit2.parents);\n if (closestParent) {\n const parentPosition = commitPos2.get(closestParent) ?? defaultCommitPosition;\n if (dir2 === \"TB\") {\n return parentPosition.y + COMMIT_STEP;\n } else if (dir2 === \"BT\") {\n const currentPosition = commitPos2.get(commit2.id) ?? defaultCommitPosition;\n return currentPosition.y - COMMIT_STEP;\n } else {\n return parentPosition.x + COMMIT_STEP;\n }\n }\n } else {\n if (dir2 === \"TB\") {\n return defaultPos;\n } else if (dir2 === \"BT\") {\n const currentPosition = commitPos2.get(commit2.id) ?? defaultCommitPosition;\n return currentPosition.y - COMMIT_STEP;\n } else {\n return 0;\n }\n }\n return 0;\n}, \"calculatePosition\");\nvar getCommitPosition = /* @__PURE__ */ __name((commit2, pos, isParallelCommits) => {\n const posWithOffset = dir === \"BT\" && isParallelCommits ? pos : pos + LAYOUT_OFFSET;\n const branchY = branchPos.get(commit2.branch)?.pos;\n const x = dir === \"TB\" || dir === \"BT\" ? branchPos.get(commit2.branch)?.pos : posWithOffset;\n if (x === void 0 || branchY === void 0) {\n throw new Error(`Position were undefined for commit ${commit2.id}`);\n }\n const useReduxGeometry = REDUX_GEOMETRY_THEMES.has(getConfig2().theme ?? \"\");\n const y = dir === \"TB\" || dir === \"BT\" ? posWithOffset : branchY + (useReduxGeometry ? REDUX_BRANCH_LABEL_PADDING_Y / 2 + 1 : -2);\n return { x, y, posWithOffset };\n}, \"getCommitPosition\");\nvar drawCommits = /* @__PURE__ */ __name((svg, commits, modifyGraph, gitGraphConfig) => {\n const gBullets = svg.append(\"g\").attr(\"class\", \"commit-bullets\");\n const gLabels = svg.append(\"g\").attr(\"class\", \"commit-labels\");\n let pos = dir === \"TB\" || dir === \"BT\" ? defaultPos : 0;\n const keys = [...commits.keys()];\n const isParallelCommits = gitGraphConfig.parallelCommits ?? false;\n const sortKeys = /* @__PURE__ */ __name((a, b) => {\n const seqA = commits.get(a)?.seq;\n const seqB = commits.get(b)?.seq;\n return seqA !== void 0 && seqB !== void 0 ? seqA - seqB : 0;\n }, \"sortKeys\");\n let sortedKeys = keys.sort(sortKeys);\n if (dir === \"BT\") {\n if (isParallelCommits) {\n setParallelBTPos(sortedKeys, commits, pos);\n }\n sortedKeys = sortedKeys.reverse();\n }\n sortedKeys.forEach((key) => {\n const commit2 = commits.get(key);\n if (!commit2) {\n throw new Error(`Commit not found for key ${key}`);\n }\n if (isParallelCommits) {\n pos = calculatePosition(commit2, dir, pos, commitPos);\n }\n const commitPosition = getCommitPosition(commit2, pos, isParallelCommits);\n if (modifyGraph) {\n const typeClass = getCommitClassType(commit2);\n const commitSymbolType = commit2.customType ?? commit2.type;\n const branchIndex = branchPos.get(commit2.branch)?.index ?? 0;\n drawCommitBullet(gBullets, commit2, commitPosition, typeClass, branchIndex, commitSymbolType);\n drawCommitLabel(gLabels, commit2, commitPosition, pos, gitGraphConfig);\n drawCommitTags(gLabels, commit2, commitPosition, pos);\n }\n if (dir === \"TB\" || dir === \"BT\") {\n commitPos.set(commit2.id, { x: commitPosition.x, y: commitPosition.posWithOffset });\n } else {\n commitPos.set(commit2.id, { x: commitPosition.posWithOffset, y: commitPosition.y });\n }\n pos = dir === \"BT\" && isParallelCommits ? pos + COMMIT_STEP : pos + COMMIT_STEP + LAYOUT_OFFSET;\n if (pos > maxPos) {\n maxPos = pos;\n }\n });\n}, \"drawCommits\");\nvar shouldRerouteArrow = /* @__PURE__ */ __name((commitA, commitB, p1, p2, allCommits) => {\n const commitBIsFurthest = dir === \"TB\" || dir === \"BT\" ? p1.x < p2.x : p1.y < p2.y;\n const branchToGetCurve = commitBIsFurthest ? commitB.branch : commitA.branch;\n const isOnBranchToGetCurve = /* @__PURE__ */ __name((x) => x.branch === branchToGetCurve, \"isOnBranchToGetCurve\");\n const isBetweenCommits = /* @__PURE__ */ __name((x) => x.seq > commitA.seq && x.seq < commitB.seq, \"isBetweenCommits\");\n return [...allCommits.values()].some((commitX) => {\n return isBetweenCommits(commitX) && isOnBranchToGetCurve(commitX);\n });\n}, \"shouldRerouteArrow\");\nvar findLane = /* @__PURE__ */ __name((y1, y2, depth = 0) => {\n const candidate = y1 + Math.abs(y1 - y2) / 2;\n if (depth > 5) {\n return candidate;\n }\n const ok = lanes.every((lane) => Math.abs(lane - candidate) >= 10);\n if (ok) {\n lanes.push(candidate);\n return candidate;\n }\n const diff = Math.abs(y1 - y2);\n return findLane(y1, y2 - diff / 5, depth + 1);\n}, \"findLane\");\nvar drawArrow = /* @__PURE__ */ __name((svg, commitA, commitB, allCommits) => {\n const { theme: arrowTheme } = getConfig2();\n const useColorTheme = COLOR_THEMES.has(arrowTheme ?? \"\");\n const p1 = commitPos.get(commitA.id);\n const p2 = commitPos.get(commitB.id);\n if (p1 === void 0 || p2 === void 0) {\n throw new Error(`Commit positions not found for commits ${commitA.id} and ${commitB.id}`);\n }\n const arrowNeedsRerouting = shouldRerouteArrow(commitA, commitB, p1, p2, allCommits);\n let arc = \"\";\n let arc2 = \"\";\n let radius = 0;\n let offset = 0;\n let colorClassNum = branchPos.get(commitB.branch)?.index;\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n }\n let lineDef;\n if (arrowNeedsRerouting) {\n arc = \"A 10 10, 0, 0, 0,\";\n arc2 = \"A 10 10, 0, 0, 1,\";\n radius = 10;\n offset = 10;\n const lineY = p1.y < p2.y ? findLane(p1.y, p2.y) : findLane(p2.y, p1.y);\n const lineX = p1.x < p2.x ? findLane(p1.x, p2.x) : findLane(p2.x, p1.x);\n if (dir === \"TB\") {\n if (p1.x < p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${lineX - radius} ${p1.y} ${arc2} ${lineX} ${p1.y + offset} L ${lineX} ${p2.y - radius} ${arc} ${lineX + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n lineDef = `M ${p1.x} ${p1.y} L ${lineX + radius} ${p1.y} ${arc} ${lineX} ${p1.y + offset} L ${lineX} ${p2.y - radius} ${arc2} ${lineX - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n } else if (dir === \"BT\") {\n if (p1.x < p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${lineX - radius} ${p1.y} ${arc} ${lineX} ${p1.y - offset} L ${lineX} ${p2.y + radius} ${arc2} ${lineX + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n lineDef = `M ${p1.x} ${p1.y} L ${lineX + radius} ${p1.y} ${arc2} ${lineX} ${p1.y - offset} L ${lineX} ${p2.y + radius} ${arc} ${lineX - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n } else {\n if (p1.y < p2.y) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${lineY - radius} ${arc} ${p1.x + offset} ${lineY} L ${p2.x - radius} ${lineY} ${arc2} ${p2.x} ${lineY + offset} L ${p2.x} ${p2.y}`;\n } else {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${lineY + radius} ${arc2} ${p1.x + offset} ${lineY} L ${p2.x - radius} ${lineY} ${arc} ${p2.x} ${lineY - offset} L ${p2.x} ${p2.y}`;\n }\n }\n } else {\n arc = \"A 20 20, 0, 0, 0,\";\n arc2 = \"A 20 20, 0, 0, 1,\";\n radius = 20;\n offset = 20;\n if (dir === \"TB\") {\n if (p1.x < p2.x) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc2} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x > p2.x) {\n arc = \"A 20 20, 0, 0, 0,\";\n arc2 = \"A 20 20, 0, 0, 1,\";\n radius = 20;\n offset = 20;\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc2} ${p1.x - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x + radius} ${p1.y} ${arc} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x === p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`;\n }\n } else if (dir === \"BT\") {\n if (p1.x < p2.x) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y + radius} ${arc2} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc} ${p2.x} ${p1.y - offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x > p2.x) {\n arc = \"A 20 20, 0, 0, 0,\";\n arc2 = \"A 20 20, 0, 0, 1,\";\n radius = 20;\n offset = 20;\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y + radius} ${arc} ${p1.x - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x + radius} ${p1.y} ${arc2} ${p2.x} ${p1.y - offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x === p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`;\n }\n } else {\n if (p1.y < p2.y) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc2} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.y > p2.y) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc} ${p2.x} ${p1.y - offset} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y + radius} ${arc2} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.y === p2.y) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`;\n }\n }\n }\n if (lineDef === void 0) {\n throw new Error(\"Line definition not found\");\n }\n svg.append(\"path\").attr(\"d\", lineDef).attr(\n \"class\",\n \"arrow arrow\" + calcColorIndex(colorClassNum, THEME_COLOR_LIMIT, useColorTheme)\n );\n}, \"drawArrow\");\nvar drawArrows = /* @__PURE__ */ __name((svg, commits) => {\n const gArrows = svg.append(\"g\").attr(\"class\", \"commit-arrows\");\n [...commits.keys()].forEach((key) => {\n const commit2 = commits.get(key);\n if (commit2.parents && commit2.parents.length > 0) {\n commit2.parents.forEach((parent) => {\n drawArrow(gArrows, commits.get(parent), commit2, commits);\n });\n }\n });\n}, \"drawArrows\");\nvar drawBranches = /* @__PURE__ */ __name((svg, branches, gitGraphConfig, id) => {\n const { look, theme, themeVariables } = getConfig2();\n const { dropShadow, THEME_COLOR_LIMIT: themeColorLimit } = themeVariables;\n const useReduxGeometry = REDUX_GEOMETRY_THEMES.has(theme ?? \"\");\n const useColorTheme = COLOR_THEMES.has(theme ?? \"\");\n const g = svg.append(\"g\");\n branches.forEach((branch2, index) => {\n const adjustIndexForTheme = calcColorIndex(\n index,\n useReduxGeometry ? themeColorLimit : THEME_COLOR_LIMIT,\n useColorTheme\n );\n const pos = branchPos.get(branch2.name)?.pos;\n if (pos === void 0) {\n throw new Error(`Position not found for branch ${branch2.name}`);\n }\n const spineY = dir === \"TB\" || dir === \"BT\" ? pos : useReduxGeometry ? pos + REDUX_BRANCH_LABEL_PADDING_Y / 2 + 1 : pos - 2;\n const line = g.append(\"line\");\n line.attr(\"x1\", 0);\n line.attr(\"y1\", spineY);\n line.attr(\"x2\", maxPos);\n line.attr(\"y2\", spineY);\n line.attr(\"class\", \"branch branch\" + adjustIndexForTheme);\n if (dir === \"TB\") {\n line.attr(\"y1\", defaultPos);\n line.attr(\"x1\", pos);\n line.attr(\"y2\", maxPos);\n line.attr(\"x2\", pos);\n } else if (dir === \"BT\") {\n line.attr(\"y1\", maxPos);\n line.attr(\"x1\", pos);\n line.attr(\"y2\", defaultPos);\n line.attr(\"x2\", pos);\n }\n lanes.push(spineY);\n const name = branch2.name;\n const labelElement = drawText(name);\n const bkg = g.insert(\"rect\");\n const branchLabel = g.insert(\"g\").attr(\"class\", \"branchLabel\");\n const label = branchLabel.insert(\"g\").attr(\"class\", \"label branch-label\" + adjustIndexForTheme);\n label.node().appendChild(labelElement);\n const bbox = labelElement.getBBox();\n const borderRadius = useReduxGeometry ? 0 : 4;\n const labelPaddingX = useReduxGeometry ? 16 : 0;\n const labelPaddingY = useReduxGeometry ? REDUX_BRANCH_LABEL_PADDING_Y : 0;\n if (look === \"neo\") {\n bkg.attr(\"data-look\", `neo`);\n }\n bkg.attr(\"class\", \"branchLabelBkg label\" + adjustIndexForTheme).attr(\n \"style\",\n look === \"neo\" ? `filter:${useReduxGeometry ? `url(#${id}-drop-shadow)` : dropShadow}` : \"\"\n ).attr(\"rx\", borderRadius).attr(\"ry\", borderRadius).attr(\"x\", -bbox.width - 4 - (gitGraphConfig.rotateCommitLabel === true ? 30 : 0)).attr(\"y\", -bbox.height / 2 + 10).attr(\"width\", bbox.width + 18 + labelPaddingX).attr(\"height\", bbox.height + 4 + labelPaddingY);\n label.attr(\n \"transform\",\n \"translate(\" + (-bbox.width - 14 - (gitGraphConfig.rotateCommitLabel === true ? 30 : 0) + labelPaddingX / 2) + \", \" + (spineY - bbox.height / 2 - 2) + \")\"\n );\n if (dir === \"TB\") {\n bkg.attr(\"x\", pos - bbox.width / 2 - 10).attr(\"y\", 0);\n label.attr(\"transform\", \"translate(\" + (pos - bbox.width / 2 - 5) + \", 0)\");\n if (useReduxGeometry) {\n bkg.attr(\"transform\", `translate(${-labelPaddingX / 2 - 3}, ${-labelPaddingY - 10})`);\n label.attr(\n \"transform\",\n \"translate(\" + (pos - bbox.width / 2 - 5) + \", \" + (-labelPaddingY * 2 + 7) + \")\"\n );\n }\n } else if (dir === \"BT\") {\n bkg.attr(\"x\", pos - bbox.width / 2 - 10).attr(\"y\", maxPos);\n label.attr(\"transform\", \"translate(\" + (pos - bbox.width / 2 - 5) + \", \" + maxPos + \")\");\n if (useReduxGeometry) {\n bkg.attr(\"transform\", `translate(${-labelPaddingX / 2 - 3}, ${labelPaddingY + 10})`);\n label.attr(\n \"transform\",\n \"translate(\" + (pos - bbox.width / 2 - 5) + \", \" + (maxPos + labelPaddingY * 2 + 4) + \")\"\n );\n }\n } else {\n bkg.attr(\"transform\", \"translate(-19, \" + (spineY - 12 - labelPaddingY / 2) + \")\");\n }\n });\n}, \"drawBranches\");\nvar setBranchPosition = /* @__PURE__ */ __name(function(name, pos, index, bbox, rotateCommitLabel) {\n branchPos.set(name, { pos, index });\n pos += 50 + (rotateCommitLabel ? 40 : 0) + (dir === \"TB\" || dir === \"BT\" ? bbox.width / 2 : 0);\n return pos;\n}, \"setBranchPosition\");\nvar draw = /* @__PURE__ */ __name(function(txt, id, ver, diagObj) {\n clear3();\n log.debug(\"in gitgraph renderer\", txt + \"\\n\", \"id:\", id, ver);\n const db2 = diagObj.db;\n if (!db2.getConfig) {\n log.error(\"getConfig method is not available on db\");\n return;\n }\n const gitGraphConfig = db2.getConfig();\n const rotateCommitLabel = gitGraphConfig.rotateCommitLabel ?? false;\n allCommitsDict = db2.getCommits();\n const branches = db2.getBranchesAsObjArray();\n dir = db2.getDirection();\n const diagram2 = select(`[id=\"${id}\"]`);\n const { look, theme, themeVariables } = getConfig2();\n const { useGradient, gradientStart, gradientStop, filterColor } = themeVariables;\n if (useGradient) {\n const gradient = diagram2.append(\"defs\").append(\"linearGradient\").attr(\"id\", id + \"-gradient\").attr(\"gradientUnits\", \"objectBoundingBox\").attr(\"x1\", \"0%\").attr(\"y1\", \"0%\").attr(\"x2\", \"100%\").attr(\"y2\", \"0%\");\n gradient.append(\"stop\").attr(\"offset\", \"0%\").attr(\"stop-color\", gradientStart).attr(\"stop-opacity\", 1);\n gradient.append(\"stop\").attr(\"offset\", \"100%\").attr(\"stop-color\", gradientStop).attr(\"stop-opacity\", 1);\n }\n if (look === \"neo\" && REDUX_GEOMETRY_THEMES.has(theme ?? \"\")) {\n diagram2.append(\"defs\").append(\"filter\").attr(\"id\", id + \"-drop-shadow\").attr(\"height\", \"130%\").attr(\"width\", \"130%\").append(\"feDropShadow\").attr(\"dx\", \"4\").attr(\"dy\", \"4\").attr(\"stdDeviation\", 0).attr(\"flood-opacity\", \"0.06\").attr(\"flood-color\", filterColor);\n }\n let pos = 0;\n branches.forEach((branch2, index) => {\n const labelElement = drawText(branch2.name);\n const g = diagram2.append(\"g\");\n const branchLabel = g.insert(\"g\").attr(\"class\", \"branchLabel\");\n const label = branchLabel.insert(\"g\").attr(\"class\", \"label branch-label\");\n label.node()?.appendChild(labelElement);\n const bbox = labelElement.getBBox();\n pos = setBranchPosition(branch2.name, pos, index, bbox, rotateCommitLabel);\n label.remove();\n branchLabel.remove();\n g.remove();\n });\n drawCommits(diagram2, allCommitsDict, false, gitGraphConfig);\n if (gitGraphConfig.showBranches) {\n drawBranches(diagram2, branches, gitGraphConfig, id);\n }\n drawArrows(diagram2, allCommitsDict);\n drawCommits(diagram2, allCommitsDict, true, gitGraphConfig);\n utils_default.insertTitle(\n diagram2,\n \"gitTitleText\",\n gitGraphConfig.titleTopMargin ?? 0,\n db2.getDiagramTitle()\n );\n setupGraphViewbox(void 0, diagram2, gitGraphConfig.diagramPadding, gitGraphConfig.useMaxWidth);\n}, \"draw\");\nvar gitGraphRenderer_default = {\n draw\n};\nif (void 0) {\n const { it, expect, describe } = void 0;\n describe(\"drawText\", () => {\n it(\"should drawText\", () => {\n const svgLabel = drawText(\"main\");\n expect(svgLabel).toBeDefined();\n expect(svgLabel.children[0].innerHTML).toBe(\"main\");\n });\n });\n describe(\"branchPosition\", () => {\n const bbox = {\n x: 0,\n y: 0,\n width: 10,\n height: 10,\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n toJSON: /* @__PURE__ */ __name(() => \"\", \"toJSON\")\n };\n it(\"should setBranchPositions LR with two branches\", () => {\n dir = \"LR\";\n const pos = setBranchPosition(\"main\", 0, 0, bbox, true);\n expect(pos).toBe(90);\n expect(branchPos.get(\"main\")).toEqual({ pos: 0, index: 0 });\n const posNext = setBranchPosition(\"develop\", pos, 1, bbox, true);\n expect(posNext).toBe(180);\n expect(branchPos.get(\"develop\")).toEqual({ pos, index: 1 });\n });\n it(\"should setBranchPositions TB with two branches\", () => {\n dir = \"TB\";\n bbox.width = 34.9921875;\n const pos = setBranchPosition(\"main\", 0, 0, bbox, true);\n expect(pos).toBe(107.49609375);\n expect(branchPos.get(\"main\")).toEqual({ pos: 0, index: 0 });\n bbox.width = 56.421875;\n const posNext = setBranchPosition(\"develop\", pos, 1, bbox, true);\n expect(posNext).toBe(225.70703125);\n expect(branchPos.get(\"develop\")).toEqual({ pos, index: 1 });\n });\n });\n describe(\"commitPosition\", () => {\n const commits = /* @__PURE__ */ new Map([\n [\n \"commitZero\",\n {\n id: \"ZERO\",\n message: \"\",\n seq: 0,\n type: commitType.NORMAL,\n tags: [],\n parents: [],\n branch: \"main\"\n }\n ],\n [\n \"commitA\",\n {\n id: \"A\",\n message: \"\",\n seq: 1,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"ZERO\"],\n branch: \"feature\"\n }\n ],\n [\n \"commitB\",\n {\n id: \"B\",\n message: \"\",\n seq: 2,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"A\"],\n branch: \"feature\"\n }\n ],\n [\n \"commitM\",\n {\n id: \"M\",\n message: \"merged branch feature into main\",\n seq: 3,\n type: commitType.MERGE,\n tags: [],\n parents: [\"ZERO\", \"B\"],\n branch: \"main\",\n customId: true\n }\n ],\n [\n \"commitC\",\n {\n id: \"C\",\n message: \"\",\n seq: 4,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"ZERO\"],\n branch: \"release\"\n }\n ],\n [\n \"commit5_8928ea0\",\n {\n id: \"5-8928ea0\",\n message: \"cherry-picked [object Object] into release\",\n seq: 5,\n type: commitType.CHERRY_PICK,\n tags: [],\n parents: [\"C\", \"M\"],\n branch: \"release\"\n }\n ],\n [\n \"commitD\",\n {\n id: \"D\",\n message: \"\",\n seq: 6,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"5-8928ea0\"],\n branch: \"release\"\n }\n ],\n [\n \"commit7_ed848ba\",\n {\n id: \"7-ed848ba\",\n message: \"cherry-picked [object Object] into release\",\n seq: 7,\n type: commitType.CHERRY_PICK,\n tags: [],\n parents: [\"D\", \"M\"],\n branch: \"release\"\n }\n ]\n ]);\n let pos = 0;\n branchPos.set(\"main\", { pos: 0, index: 0 });\n branchPos.set(\"feature\", { pos: 107.49609375, index: 1 });\n branchPos.set(\"release\", { pos: 224.03515625, index: 2 });\n describe(\"TB\", () => {\n pos = 30;\n dir = \"TB\";\n const expectedCommitPositionTB = /* @__PURE__ */ new Map([\n [\"commitZero\", { x: 0, y: 40, posWithOffset: 40 }],\n [\"commitA\", { x: 107.49609375, y: 90, posWithOffset: 90 }],\n [\"commitB\", { x: 107.49609375, y: 140, posWithOffset: 140 }],\n [\"commitM\", { x: 0, y: 190, posWithOffset: 190 }],\n [\"commitC\", { x: 224.03515625, y: 240, posWithOffset: 240 }],\n [\"commit5_8928ea0\", { x: 224.03515625, y: 290, posWithOffset: 290 }],\n [\"commitD\", { x: 224.03515625, y: 340, posWithOffset: 340 }],\n [\"commit7_ed848ba\", { x: 224.03515625, y: 390, posWithOffset: 390 }]\n ]);\n commits.forEach((commit2, key) => {\n it(`should give the correct position for commit ${key}`, () => {\n const position = getCommitPosition(commit2, pos, false);\n expect(position).toEqual(expectedCommitPositionTB.get(key));\n pos += 50;\n });\n });\n });\n describe(\"LR\", () => {\n let pos2 = 30;\n dir = \"LR\";\n const expectedCommitPositionLR = /* @__PURE__ */ new Map([\n [\"commitZero\", { x: 0, y: 40, posWithOffset: 40 }],\n [\"commitA\", { x: 107.49609375, y: 90, posWithOffset: 90 }],\n [\"commitB\", { x: 107.49609375, y: 140, posWithOffset: 140 }],\n [\"commitM\", { x: 0, y: 190, posWithOffset: 190 }],\n [\"commitC\", { x: 224.03515625, y: 240, posWithOffset: 240 }],\n [\"commit5_8928ea0\", { x: 224.03515625, y: 290, posWithOffset: 290 }],\n [\"commitD\", { x: 224.03515625, y: 340, posWithOffset: 340 }],\n [\"commit7_ed848ba\", { x: 224.03515625, y: 390, posWithOffset: 390 }]\n ]);\n commits.forEach((commit2, key) => {\n it(`should give the correct position for commit ${key}`, () => {\n const position = getCommitPosition(commit2, pos2, false);\n expect(position).toEqual(expectedCommitPositionLR.get(key));\n pos2 += 50;\n });\n });\n });\n describe(\"getCommitClassType\", () => {\n const expectedCommitClassType = /* @__PURE__ */ new Map([\n [\"commitZero\", \"commit-normal\"],\n [\"commitA\", \"commit-normal\"],\n [\"commitB\", \"commit-normal\"],\n [\"commitM\", \"commit-merge\"],\n [\"commitC\", \"commit-normal\"],\n [\"commit5_8928ea0\", \"commit-cherry-pick\"],\n [\"commitD\", \"commit-normal\"],\n [\"commit7_ed848ba\", \"commit-cherry-pick\"]\n ]);\n commits.forEach((commit2, key) => {\n it(`should give the correct class type for commit ${key}`, () => {\n const classType = getCommitClassType(commit2);\n expect(classType).toBe(expectedCommitClassType.get(key));\n });\n });\n });\n });\n describe(\"building BT parallel commit diagram\", () => {\n const commits = /* @__PURE__ */ new Map([\n [\n \"1-abcdefg\",\n {\n id: \"1-abcdefg\",\n message: \"\",\n seq: 0,\n type: 0,\n tags: [],\n parents: [],\n branch: \"main\"\n }\n ],\n [\n \"2-abcdefg\",\n {\n id: \"2-abcdefg\",\n message: \"\",\n seq: 1,\n type: 0,\n tags: [],\n parents: [\"1-abcdefg\"],\n branch: \"main\"\n }\n ],\n [\n \"3-abcdefg\",\n {\n id: \"3-abcdefg\",\n message: \"\",\n seq: 2,\n type: 0,\n tags: [],\n parents: [\"2-abcdefg\"],\n branch: \"develop\"\n }\n ],\n [\n \"4-abcdefg\",\n {\n id: \"4-abcdefg\",\n message: \"\",\n seq: 3,\n type: 0,\n tags: [],\n parents: [\"3-abcdefg\"],\n branch: \"develop\"\n }\n ],\n [\n \"5-abcdefg\",\n {\n id: \"5-abcdefg\",\n message: \"\",\n seq: 4,\n type: 0,\n tags: [],\n parents: [\"2-abcdefg\"],\n branch: \"feature\"\n }\n ],\n [\n \"6-abcdefg\",\n {\n id: \"6-abcdefg\",\n message: \"\",\n seq: 5,\n type: 0,\n tags: [],\n parents: [\"5-abcdefg\"],\n branch: \"feature\"\n }\n ],\n [\n \"7-abcdefg\",\n {\n id: \"7-abcdefg\",\n message: \"\",\n seq: 6,\n type: 0,\n tags: [],\n parents: [\"2-abcdefg\"],\n branch: \"main\"\n }\n ],\n [\n \"8-abcdefg\",\n {\n id: \"8-abcdefg\",\n message: \"\",\n seq: 7,\n type: 0,\n tags: [],\n parents: [\"7-abcdefg\"],\n branch: \"main\"\n }\n ]\n ]);\n const expectedCommitPosition = /* @__PURE__ */ new Map([\n [\"1-abcdefg\", { x: 0, y: 40 }],\n [\"2-abcdefg\", { x: 0, y: 90 }],\n [\"3-abcdefg\", { x: 107.49609375, y: 140 }],\n [\"4-abcdefg\", { x: 107.49609375, y: 190 }],\n [\"5-abcdefg\", { x: 225.70703125, y: 140 }],\n [\"6-abcdefg\", { x: 225.70703125, y: 190 }],\n [\"7-abcdefg\", { x: 0, y: 140 }],\n [\"8-abcdefg\", { x: 0, y: 190 }]\n ]);\n const expectedCommitPositionAfterParallel = /* @__PURE__ */ new Map([\n [\"1-abcdefg\", { x: 0, y: 210 }],\n [\"2-abcdefg\", { x: 0, y: 160 }],\n [\"3-abcdefg\", { x: 107.49609375, y: 110 }],\n [\"4-abcdefg\", { x: 107.49609375, y: 60 }],\n [\"5-abcdefg\", { x: 225.70703125, y: 110 }],\n [\"6-abcdefg\", { x: 225.70703125, y: 60 }],\n [\"7-abcdefg\", { x: 0, y: 110 }],\n [\"8-abcdefg\", { x: 0, y: 60 }]\n ]);\n const expectedCommitCurrentPosition = /* @__PURE__ */ new Map([\n [\"1-abcdefg\", 30],\n [\"2-abcdefg\", 80],\n [\"3-abcdefg\", 130],\n [\"4-abcdefg\", 180],\n [\"5-abcdefg\", 130],\n [\"6-abcdefg\", 180],\n [\"7-abcdefg\", 130],\n [\"8-abcdefg\", 180]\n ]);\n const sortedKeys = [...expectedCommitPosition.keys()];\n it(\"should get the correct commit position and current position\", () => {\n dir = \"BT\";\n let curPos = 30;\n commitPos.clear();\n branchPos.clear();\n branchPos.set(\"main\", { pos: 0, index: 0 });\n branchPos.set(\"develop\", { pos: 107.49609375, index: 1 });\n branchPos.set(\"feature\", { pos: 225.70703125, index: 2 });\n commits.forEach((commit2, key) => {\n if (commit2.parents.length > 0) {\n curPos = calculateCommitPosition(commit2);\n }\n const position = setCommitPosition(commit2, curPos);\n expect(position).toEqual(expectedCommitPosition.get(key));\n expect(curPos).toEqual(expectedCommitCurrentPosition.get(key));\n });\n });\n it(\"should get the correct commit position after parallel commits\", () => {\n commitPos.clear();\n branchPos.clear();\n dir = \"BT\";\n const curPos = 30;\n commitPos.clear();\n branchPos.clear();\n branchPos.set(\"main\", { pos: 0, index: 0 });\n branchPos.set(\"develop\", { pos: 107.49609375, index: 1 });\n branchPos.set(\"feature\", { pos: 225.70703125, index: 2 });\n setParallelBTPos(sortedKeys, commits, curPos);\n sortedKeys.forEach((commit2) => {\n const position = commitPos.get(commit2);\n expect(position).toEqual(expectedCommitPositionAfterParallel.get(commit2));\n });\n });\n });\n it(\"add\", () => {\n commitPos.set(\"parent1\", { x: 1, y: 1 });\n commitPos.set(\"parent2\", { x: 2, y: 2 });\n commitPos.set(\"parent3\", { x: 3, y: 3 });\n dir = \"LR\";\n const parents = [\"parent1\", \"parent2\", \"parent3\"];\n const closestParent = findClosestParent(parents);\n expect(closestParent).toBe(\"parent3\");\n commitPos.clear();\n });\n}\n\n// src/diagrams/git/styles.js\nvar GIT_NAMED_COLOR_COUNT = 8;\nvar REDUX_GEOMETRY_THEMES2 = /* @__PURE__ */ new Set([\"redux\", \"redux-dark\", \"redux-color\", \"redux-dark-color\"]);\nvar COLOR_THEMES2 = /* @__PURE__ */ new Set([\"redux-color\", \"redux-dark-color\"]);\nvar NEO_THEMES = /* @__PURE__ */ new Set([\"neo\", \"neo-dark\"]);\nvar DARK_THEMES2 = /* @__PURE__ */ new Set([\"dark\", \"redux-dark\", \"redux-dark-color\", \"neo-dark\"]);\nvar NEO_COLOR_GEN_THEMES = /* @__PURE__ */ new Set([\n \"redux\",\n \"redux-dark\",\n \"redux-color\",\n \"redux-dark-color\",\n \"neo\",\n \"neo-dark\"\n]);\nvar genGitGraphGradient = /* @__PURE__ */ __name((options) => {\n const { svgId } = options;\n let sections = \"\";\n if (options.useGradient && svgId) {\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n sections += `\n .label${i} { fill: ${options.mainBkg}; stroke: url(${svgId}-gradient); stroke-width: ${options.strokeWidth};}\n `;\n }\n }\n return sections;\n}, \"genGitGraphGradient\");\nvar genColor = /* @__PURE__ */ __name((options) => {\n const config = getConfig();\n const { theme, themeVariables } = config;\n const { borderColorArray } = themeVariables;\n const useReduxGeometry = REDUX_GEOMETRY_THEMES2.has(theme);\n if (NEO_THEMES.has(theme)) {\n let sections = \"\";\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n if (i === 0) {\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder};}\n .commit${i} { stroke: ${options.nodeBorder}; }\n .commit-highlight${i} { stroke: ${options.nodeBorder}; fill: ${options.nodeBorder}; }\n .arrow${i} { stroke: ${options.nodeBorder}; }\n .commit-bullets { fill: ${options.nodeBorder}; }\n .commit-cherry-pick${i} { stroke: ${options.nodeBorder}; }\n ${genGitGraphGradient(options)}`;\n } else {\n const ci = i % GIT_NAMED_COLOR_COUNT;\n sections += `\n .branch-label${i} { fill: ${options[\"gitBranchLabel\" + ci]}; }\n .commit${i} { stroke: ${options[\"git\" + ci]}; fill: ${options[\"git\" + ci]}; }\n .commit-highlight${i} { stroke: ${options[\"gitInv\" + ci]}; fill: ${options[\"gitInv\" + ci]}; }\n .arrow${i} { stroke: ${options[\"git\" + ci]}; }\n `;\n }\n }\n return sections;\n } else if (!COLOR_THEMES2.has(theme)) {\n let sections = \"\";\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .commit${i} { stroke: ${options.nodeBorder}; }\n .commit-highlight${i} { stroke: ${options.nodeBorder}; fill: ${options.nodeBorder}; }\n .label${i} { fill: ${options.mainBkg}; stroke: ${options.nodeBorder}; stroke-width: ${options.strokeWidth}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"}}\n .arrow${i} { stroke: ${options.nodeBorder}; }\n .commit-bullets { fill: ${options.nodeBorder}; }\n .commit-cherry-pick${i} { stroke: ${options.nodeBorder}; }\n `;\n }\n return sections;\n } else {\n let sections = \"\";\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n if (i === 0) {\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .commit${i} { stroke: ${options.nodeBorder}; }\n .commit-highlight${i} { stroke: ${options.nodeBorder}; fill: ${options.mainBkg}; }\n .label${i} { fill: ${options.mainBkg}; stroke: ${options.nodeBorder}; stroke-width: ${options.strokeWidth}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .arrow${i} { stroke: ${options.nodeBorder}; }\n .commit-bullets { fill: ${options.nodeBorder}; }\n `;\n } else {\n const colorIndex = i % borderColorArray.length;\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .commit${i} { stroke: ${borderColorArray[colorIndex]}; fill: ${borderColorArray[colorIndex]}; }\n .commit-highlight${i} { stroke: ${borderColorArray[colorIndex]}; fill: ${borderColorArray[colorIndex]}; }\n .label${i} { fill: ${DARK_THEMES2.has(theme) ? options.mainBkg : borderColorArray[colorIndex]}; stroke: ${borderColorArray[colorIndex]}; stroke-width: ${options.strokeWidth}; }\n .arrow${i} { stroke: ${borderColorArray[colorIndex]}; }\n `;\n }\n }\n return sections;\n }\n}, \"genColor\");\nvar normalTheme = /* @__PURE__ */ __name((options) => {\n return `${Array.from({ length: options.THEME_COLOR_LIMIT }, (_, i) => i).map((i) => {\n const ci = i % GIT_NAMED_COLOR_COUNT;\n return `\n .branch-label${i} { fill: ${options[\"gitBranchLabel\" + ci]}; }\n .commit${i} { stroke: ${options[\"git\" + ci]}; fill: ${options[\"git\" + ci]}; }\n .commit-highlight${i} { stroke: ${options[\"gitInv\" + ci]}; fill: ${options[\"gitInv\" + ci]}; }\n .label${i} { fill: ${options[\"git\" + ci]}; }\n .arrow${i} { stroke: ${options[\"git\" + ci]}; }\n `;\n }).join(\"\\n\")}`;\n}, \"normalTheme\");\nvar getStyles = /* @__PURE__ */ __name((options) => {\n const config = getConfig();\n const { theme } = config;\n const useNeoColorGen = NEO_COLOR_GEN_THEMES.has(theme);\n return `\n .commit-id,\n .commit-msg,\n .branch-label {\n fill: lightgrey;\n color: lightgrey;\n font-family: 'trebuchet ms', verdana, arial, sans-serif;\n font-family: var(--mermaid-font-family);\n }\n \n ${useNeoColorGen ? genColor(options) : normalTheme(options)}\n\n .branch {\n stroke-width: ${options.strokeWidth};\n stroke: ${options.commitLineColor ?? options.lineColor};\n stroke-dasharray: ${useNeoColorGen ? \"4 2\" : \"2\"};\n }\n .commit-label { font-size: ${options.commitLabelFontSize}; fill: ${useNeoColorGen ? options.nodeBorder : options.commitLabelColor}; ${useNeoColorGen ? `font-weight:${options.noteFontWeight};` : \"\"}}\n .commit-label-bkg { font-size: ${options.commitLabelFontSize}; fill: ${useNeoColorGen ? \"transparent\" : options.commitLabelBackground}; opacity: ${useNeoColorGen ? \"\" : 0.5}; }\n .tag-label { font-size: ${options.tagLabelFontSize}; fill: ${options.tagLabelColor};}\n .tag-label-bkg { fill: ${useNeoColorGen ? options.mainBkg : options.tagLabelBackground}; stroke: ${useNeoColorGen ? options.nodeBorder : options.tagLabelBorder}; ${useNeoColorGen ? `filter:${options.dropShadow}` : \"\"} }\n .tag-hole { fill: ${options.textColor}; }\n\n .commit-merge {\n stroke: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n fill: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n }\n .commit-reverse {\n stroke: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n fill: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n stroke-width: ${useNeoColorGen ? options.strokeWidth : 3};\n }\n .commit-highlight-outer {\n }\n .commit-highlight-inner {\n stroke: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n fill: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n }\n\n .arrow {\n /* Intentional: neo themes keep the bold 8px arrow (like classic themes); only redux-geometry themes use the thinner options.strokeWidth. */\n stroke-width: ${REDUX_GEOMETRY_THEMES2.has(theme) ? options.strokeWidth : 8};\n stroke-linecap: round;\n fill: none\n }\n .gitTitleText {\n text-anchor: middle;\n font-size: 18px;\n fill: ${options.textColor};\n }\n`;\n}, \"getStyles\");\nvar styles_default = getStyles;\n\n// src/diagrams/git/gitGraphDiagram.ts\nvar diagram = {\n parser,\n db,\n renderer: gitGraphRenderer_default,\n styles: styles_default\n};\nexport {\n diagram\n};\n"],"x_google_ignoreList":[0],"mappings":"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"}
1
+ {"version":3,"file":"gitGraphDiagram-UUTBAWPF-BV73nor5.js","names":["select"],"sources":["../../../../node_modules/mermaid/dist/chunks/mermaid.core/gitGraphDiagram-UUTBAWPF.mjs"],"sourcesContent":["import {\n populateCommonDb\n} from \"./chunk-4BX2VUAB.mjs\";\nimport {\n ImperativeState\n} from \"./chunk-QZHKN3VN.mjs\";\nimport {\n cleanAndMerge,\n random,\n utils_default\n} from \"./chunk-5PVQY5BW.mjs\";\nimport {\n clear,\n common_default,\n defaultConfig_default,\n getAccDescription,\n getAccTitle,\n getConfig,\n getConfig2,\n getDiagramTitle,\n setAccDescription,\n setAccTitle,\n setDiagramTitle,\n setupGraphViewbox2 as setupGraphViewbox\n} from \"./chunk-ICPOFSXX.mjs\";\nimport {\n __name,\n log\n} from \"./chunk-AGHRB4JF.mjs\";\n\n// src/diagrams/git/gitGraphParser.ts\nimport { parse } from \"@mermaid-js/parser\";\n\n// src/diagrams/git/gitGraphTypes.ts\nvar commitType = {\n NORMAL: 0,\n REVERSE: 1,\n HIGHLIGHT: 2,\n MERGE: 3,\n CHERRY_PICK: 4\n};\n\n// src/diagrams/git/gitGraphAst.ts\nvar DEFAULT_GITGRAPH_CONFIG = defaultConfig_default.gitGraph;\nvar getConfig3 = /* @__PURE__ */ __name(() => {\n const config = cleanAndMerge({\n ...DEFAULT_GITGRAPH_CONFIG,\n ...getConfig().gitGraph\n });\n return config;\n}, \"getConfig\");\nvar state = new ImperativeState(() => {\n const config = getConfig3();\n const mainBranchName = config.mainBranchName;\n const mainBranchOrder = config.mainBranchOrder;\n return {\n mainBranchName,\n commits: /* @__PURE__ */ new Map(),\n head: null,\n branchConfig: /* @__PURE__ */ new Map([[mainBranchName, { name: mainBranchName, order: mainBranchOrder }]]),\n branches: /* @__PURE__ */ new Map([[mainBranchName, null]]),\n currBranch: mainBranchName,\n direction: \"LR\",\n seq: 0,\n options: {}\n };\n});\nfunction getID() {\n return random({ length: 7 });\n}\n__name(getID, \"getID\");\nfunction uniqBy(list, fn) {\n const recordMap = /* @__PURE__ */ Object.create(null);\n return list.reduce((out, item) => {\n const key = fn(item);\n if (!recordMap[key]) {\n recordMap[key] = true;\n out.push(item);\n }\n return out;\n }, []);\n}\n__name(uniqBy, \"uniqBy\");\nvar setDirection = /* @__PURE__ */ __name(function(dir2) {\n state.records.direction = dir2;\n}, \"setDirection\");\nvar setOptions = /* @__PURE__ */ __name(function(rawOptString) {\n log.debug(\"options str\", rawOptString);\n rawOptString = rawOptString?.trim();\n rawOptString = rawOptString || \"{}\";\n try {\n state.records.options = JSON.parse(rawOptString);\n } catch (e) {\n log.error(\"error while parsing gitGraph options\", e.message);\n }\n}, \"setOptions\");\nvar getOptions = /* @__PURE__ */ __name(function() {\n return state.records.options;\n}, \"getOptions\");\nvar commit = /* @__PURE__ */ __name(function(commitDB) {\n let msg = commitDB.msg;\n let id = commitDB.id;\n const type = commitDB.type;\n let tags = commitDB.tags;\n log.info(\"commit\", msg, id, type, tags);\n log.debug(\"Entering commit:\", msg, id, type, tags);\n const config = getConfig3();\n id = common_default.sanitizeText(id, config);\n msg = common_default.sanitizeText(msg, config);\n tags = tags?.map((tag) => common_default.sanitizeText(tag, config));\n const newCommit = {\n id: id ? id : state.records.seq + \"-\" + getID(),\n message: msg,\n seq: state.records.seq++,\n type: type ?? commitType.NORMAL,\n tags: tags ?? [],\n parents: state.records.head == null ? [] : [state.records.head.id],\n branch: state.records.currBranch\n };\n state.records.head = newCommit;\n log.info(\"main branch\", config.mainBranchName);\n if (state.records.commits.has(newCommit.id)) {\n log.warn(`Commit ID ${newCommit.id} already exists`);\n }\n state.records.commits.set(newCommit.id, newCommit);\n state.records.branches.set(state.records.currBranch, newCommit.id);\n log.debug(\"in pushCommit \" + newCommit.id);\n}, \"commit\");\nvar branch = /* @__PURE__ */ __name(function(branchDB) {\n let name = branchDB.name;\n const order = branchDB.order;\n name = common_default.sanitizeText(name, getConfig3());\n if (state.records.branches.has(name)) {\n throw new Error(\n `Trying to create an existing branch. (Help: Either use a new name if you want create a new branch or try using \"checkout ${name}\")`\n );\n }\n state.records.branches.set(name, state.records.head != null ? state.records.head.id : null);\n state.records.branchConfig.set(name, { name, order });\n checkout(name);\n log.debug(\"in createBranch\");\n}, \"branch\");\nvar merge = /* @__PURE__ */ __name((mergeDB) => {\n let otherBranch = mergeDB.branch;\n let customId = mergeDB.id;\n const overrideType = mergeDB.type;\n const customTags = mergeDB.tags;\n const config = getConfig3();\n otherBranch = common_default.sanitizeText(otherBranch, config);\n if (customId) {\n customId = common_default.sanitizeText(customId, config);\n }\n const currentBranchCheck = state.records.branches.get(state.records.currBranch);\n const otherBranchCheck = state.records.branches.get(otherBranch);\n const currentCommit = currentBranchCheck ? state.records.commits.get(currentBranchCheck) : void 0;\n const otherCommit = otherBranchCheck ? state.records.commits.get(otherBranchCheck) : void 0;\n if (currentCommit && otherCommit && currentCommit.branch === otherBranch) {\n throw new Error(`Cannot merge branch '${otherBranch}' into itself.`);\n }\n if (state.records.currBranch === otherBranch) {\n const error = new Error('Incorrect usage of \"merge\". Cannot merge a branch to itself');\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [\"branch abc\"]\n };\n throw error;\n }\n if (currentCommit === void 0 || !currentCommit) {\n const error = new Error(\n `Incorrect usage of \"merge\". Current branch (${state.records.currBranch})has no commits`\n );\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [\"commit\"]\n };\n throw error;\n }\n if (!state.records.branches.has(otherBranch)) {\n const error = new Error(\n 'Incorrect usage of \"merge\". Branch to be merged (' + otherBranch + \") does not exist\"\n );\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [`branch ${otherBranch}`]\n };\n throw error;\n }\n if (otherCommit === void 0 || !otherCommit) {\n const error = new Error(\n 'Incorrect usage of \"merge\". Branch to be merged (' + otherBranch + \") has no commits\"\n );\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: ['\"commit\"']\n };\n throw error;\n }\n if (currentCommit === otherCommit) {\n const error = new Error('Incorrect usage of \"merge\". Both branches have same head');\n error.hash = {\n text: `merge ${otherBranch}`,\n token: `merge ${otherBranch}`,\n expected: [\"branch abc\"]\n };\n throw error;\n }\n if (customId && state.records.commits.has(customId)) {\n const error = new Error(\n 'Incorrect usage of \"merge\". Commit with id:' + customId + \" already exists, use different custom id\"\n );\n error.hash = {\n text: `merge ${otherBranch} ${customId} ${overrideType} ${customTags?.join(\" \")}`,\n token: `merge ${otherBranch} ${customId} ${overrideType} ${customTags?.join(\" \")}`,\n expected: [\n `merge ${otherBranch} ${customId}_UNIQUE ${overrideType} ${customTags?.join(\" \")}`\n ]\n };\n throw error;\n }\n const verifiedBranch = otherBranchCheck ? otherBranchCheck : \"\";\n const commit2 = {\n id: customId || `${state.records.seq}-${getID()}`,\n message: `merged branch ${otherBranch} into ${state.records.currBranch}`,\n seq: state.records.seq++,\n parents: state.records.head == null ? [] : [state.records.head.id, verifiedBranch],\n branch: state.records.currBranch,\n type: commitType.MERGE,\n customType: overrideType,\n customId: customId ? true : false,\n tags: customTags ?? []\n };\n state.records.head = commit2;\n state.records.commits.set(commit2.id, commit2);\n state.records.branches.set(state.records.currBranch, commit2.id);\n log.debug(state.records.branches);\n log.debug(\"in mergeBranch\");\n}, \"merge\");\nvar cherryPick = /* @__PURE__ */ __name(function(cherryPickDB) {\n let sourceId = cherryPickDB.id;\n let targetId = cherryPickDB.targetId;\n let tags = cherryPickDB.tags;\n let parentCommitId = cherryPickDB.parent;\n log.debug(\"Entering cherryPick:\", sourceId, targetId, tags);\n const config = getConfig3();\n sourceId = common_default.sanitizeText(sourceId, config);\n targetId = common_default.sanitizeText(targetId, config);\n tags = tags?.map((tag) => common_default.sanitizeText(tag, config));\n parentCommitId = common_default.sanitizeText(parentCommitId, config);\n if (!sourceId || !state.records.commits.has(sourceId)) {\n const error = new Error(\n 'Incorrect usage of \"cherryPick\". Source commit id should exist and provided'\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const sourceCommit = state.records.commits.get(sourceId);\n if (sourceCommit === void 0 || !sourceCommit) {\n throw new Error('Incorrect usage of \"cherryPick\". Source commit id should exist and provided');\n }\n if (parentCommitId && !(Array.isArray(sourceCommit.parents) && sourceCommit.parents.includes(parentCommitId))) {\n const error = new Error(\n \"Invalid operation: The specified parent commit is not an immediate parent of the cherry-picked commit.\"\n );\n throw error;\n }\n const sourceCommitBranch = sourceCommit.branch;\n if (sourceCommit.type === commitType.MERGE && !parentCommitId) {\n const error = new Error(\n \"Incorrect usage of cherry-pick: If the source commit is a merge commit, an immediate parent commit must be specified.\"\n );\n throw error;\n }\n if (!targetId || !state.records.commits.has(targetId)) {\n if (sourceCommitBranch === state.records.currBranch) {\n const error = new Error(\n 'Incorrect usage of \"cherryPick\". Source commit is already on current branch'\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const currentCommitId = state.records.branches.get(state.records.currBranch);\n if (currentCommitId === void 0 || !currentCommitId) {\n const error = new Error(\n `Incorrect usage of \"cherry-pick\". Current branch (${state.records.currBranch})has no commits`\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const currentCommit = state.records.commits.get(currentCommitId);\n if (currentCommit === void 0 || !currentCommit) {\n const error = new Error(\n `Incorrect usage of \"cherry-pick\". Current branch (${state.records.currBranch})has no commits`\n );\n error.hash = {\n text: `cherryPick ${sourceId} ${targetId}`,\n token: `cherryPick ${sourceId} ${targetId}`,\n expected: [\"cherry-pick abc\"]\n };\n throw error;\n }\n const commit2 = {\n id: state.records.seq + \"-\" + getID(),\n message: `cherry-picked ${sourceCommit?.message} into ${state.records.currBranch}`,\n seq: state.records.seq++,\n parents: state.records.head == null ? [] : [state.records.head.id, sourceCommit.id],\n branch: state.records.currBranch,\n type: commitType.CHERRY_PICK,\n tags: tags ? tags.filter(Boolean) : [\n `cherry-pick:${sourceCommit.id}${sourceCommit.type === commitType.MERGE ? `|parent:${parentCommitId}` : \"\"}`\n ]\n };\n state.records.head = commit2;\n state.records.commits.set(commit2.id, commit2);\n state.records.branches.set(state.records.currBranch, commit2.id);\n log.debug(state.records.branches);\n log.debug(\"in cherryPick\");\n }\n}, \"cherryPick\");\nvar checkout = /* @__PURE__ */ __name(function(branch2) {\n branch2 = common_default.sanitizeText(branch2, getConfig3());\n if (!state.records.branches.has(branch2)) {\n const error = new Error(\n `Trying to checkout branch which is not yet created. (Help try using \"branch ${branch2}\")`\n );\n error.hash = {\n text: `checkout ${branch2}`,\n token: `checkout ${branch2}`,\n expected: [`branch ${branch2}`]\n };\n throw error;\n } else {\n state.records.currBranch = branch2;\n const id = state.records.branches.get(state.records.currBranch);\n if (id === void 0 || !id) {\n state.records.head = null;\n } else {\n state.records.head = state.records.commits.get(id) ?? null;\n }\n }\n}, \"checkout\");\nfunction upsert(arr, key, newVal) {\n const index = arr.indexOf(key);\n if (index === -1) {\n arr.push(newVal);\n } else {\n arr.splice(index, 1, newVal);\n }\n}\n__name(upsert, \"upsert\");\nfunction prettyPrintCommitHistory(commitArr) {\n const commit2 = commitArr.reduce((out, commit3) => {\n if (out.seq > commit3.seq) {\n return out;\n }\n return commit3;\n }, commitArr[0]);\n let line = \"\";\n commitArr.forEach(function(c) {\n if (c === commit2) {\n line += \"\t*\";\n } else {\n line += \"\t|\";\n }\n });\n const label = [line, commit2.id, commit2.seq];\n for (const branch2 in state.records.branches) {\n if (state.records.branches.get(branch2) === commit2.id) {\n label.push(branch2);\n }\n }\n log.debug(label.join(\" \"));\n if (commit2.parents && commit2.parents.length == 2 && commit2.parents[0] && commit2.parents[1]) {\n const newCommit = state.records.commits.get(commit2.parents[0]);\n upsert(commitArr, commit2, newCommit);\n if (commit2.parents[1]) {\n commitArr.push(state.records.commits.get(commit2.parents[1]));\n }\n } else if (commit2.parents.length == 0) {\n return;\n } else {\n if (commit2.parents[0]) {\n const newCommit = state.records.commits.get(commit2.parents[0]);\n upsert(commitArr, commit2, newCommit);\n }\n }\n commitArr = uniqBy(commitArr, (c) => c.id);\n prettyPrintCommitHistory(commitArr);\n}\n__name(prettyPrintCommitHistory, \"prettyPrintCommitHistory\");\nvar prettyPrint = /* @__PURE__ */ __name(function() {\n log.debug(state.records.commits);\n const node = getCommitsArray()[0];\n prettyPrintCommitHistory([node]);\n}, \"prettyPrint\");\nvar clear2 = /* @__PURE__ */ __name(function() {\n state.reset();\n clear();\n}, \"clear\");\nvar getBranchesAsObjArray = /* @__PURE__ */ __name(function() {\n const branchesArray = [...state.records.branchConfig.values()].map((branchConfig, i) => {\n if (branchConfig.order !== null && branchConfig.order !== void 0) {\n return branchConfig;\n }\n return {\n ...branchConfig,\n order: parseFloat(`0.${i}`)\n };\n }).sort((a, b) => (a.order ?? 0) - (b.order ?? 0)).map(({ name }) => ({ name }));\n return branchesArray;\n}, \"getBranchesAsObjArray\");\nvar getBranches = /* @__PURE__ */ __name(function() {\n return state.records.branches;\n}, \"getBranches\");\nvar getCommits = /* @__PURE__ */ __name(function() {\n return state.records.commits;\n}, \"getCommits\");\nvar getCommitsArray = /* @__PURE__ */ __name(function() {\n const commitArr = [...state.records.commits.values()];\n commitArr.forEach(function(o) {\n log.debug(o.id);\n });\n commitArr.sort((a, b) => a.seq - b.seq);\n return commitArr;\n}, \"getCommitsArray\");\nvar getCurrentBranch = /* @__PURE__ */ __name(function() {\n return state.records.currBranch;\n}, \"getCurrentBranch\");\nvar getDirection = /* @__PURE__ */ __name(function() {\n return state.records.direction;\n}, \"getDirection\");\nvar getHead = /* @__PURE__ */ __name(function() {\n return state.records.head;\n}, \"getHead\");\nvar db = {\n commitType,\n getConfig: getConfig3,\n setDirection,\n setOptions,\n getOptions,\n commit,\n branch,\n merge,\n cherryPick,\n checkout,\n //reset,\n prettyPrint,\n clear: clear2,\n getBranchesAsObjArray,\n getBranches,\n getCommits,\n getCommitsArray,\n getCurrentBranch,\n getDirection,\n getHead,\n setAccTitle,\n getAccTitle,\n getAccDescription,\n setAccDescription,\n setDiagramTitle,\n getDiagramTitle\n};\n\n// src/diagrams/git/gitGraphParser.ts\nvar populate = /* @__PURE__ */ __name((ast, db2) => {\n populateCommonDb(ast, db2);\n if (ast.dir) {\n db2.setDirection(ast.dir);\n }\n for (const statement of ast.statements) {\n parseStatement(statement, db2);\n }\n}, \"populate\");\nvar parseStatement = /* @__PURE__ */ __name((statement, db2) => {\n const parsers = {\n Commit: /* @__PURE__ */ __name((stmt) => db2.commit(parseCommit(stmt)), \"Commit\"),\n Branch: /* @__PURE__ */ __name((stmt) => db2.branch(parseBranch(stmt)), \"Branch\"),\n Merge: /* @__PURE__ */ __name((stmt) => db2.merge(parseMerge(stmt)), \"Merge\"),\n Checkout: /* @__PURE__ */ __name((stmt) => db2.checkout(parseCheckout(stmt)), \"Checkout\"),\n CherryPicking: /* @__PURE__ */ __name((stmt) => db2.cherryPick(parseCherryPicking(stmt)), \"CherryPicking\")\n };\n const parser2 = parsers[statement.$type];\n if (parser2) {\n parser2(statement);\n } else {\n log.error(`Unknown statement type: ${statement.$type}`);\n }\n}, \"parseStatement\");\nvar parseCommit = /* @__PURE__ */ __name((commit2) => {\n const commitDB = {\n id: commit2.id,\n msg: commit2.message ?? \"\",\n type: commit2.type !== void 0 ? commitType[commit2.type] : commitType.NORMAL,\n tags: commit2.tags ?? void 0\n };\n return commitDB;\n}, \"parseCommit\");\nvar parseBranch = /* @__PURE__ */ __name((branch2) => {\n const branchDB = {\n name: branch2.name,\n order: branch2.order ?? 0\n };\n return branchDB;\n}, \"parseBranch\");\nvar parseMerge = /* @__PURE__ */ __name((merge2) => {\n const mergeDB = {\n branch: merge2.branch,\n id: merge2.id ?? \"\",\n type: merge2.type !== void 0 ? commitType[merge2.type] : void 0,\n tags: merge2.tags ?? void 0\n };\n return mergeDB;\n}, \"parseMerge\");\nvar parseCheckout = /* @__PURE__ */ __name((checkout2) => {\n const branch2 = checkout2.branch;\n return branch2;\n}, \"parseCheckout\");\nvar parseCherryPicking = /* @__PURE__ */ __name((cherryPicking) => {\n const cherryPickDB = {\n id: cherryPicking.id,\n targetId: \"\",\n tags: cherryPicking.tags?.length === 0 ? void 0 : cherryPicking.tags,\n parent: cherryPicking.parent\n };\n return cherryPickDB;\n}, \"parseCherryPicking\");\nvar parser = {\n parse: /* @__PURE__ */ __name(async (input) => {\n const ast = await parse(\"gitGraph\", input);\n log.debug(ast);\n populate(ast, db);\n }, \"parse\")\n};\nif (void 0) {\n const { it, expect, describe } = void 0;\n const mockDB = {\n commitType,\n setDirection: vi.fn(),\n commit: vi.fn(),\n branch: vi.fn(),\n merge: vi.fn(),\n cherryPick: vi.fn(),\n checkout: vi.fn()\n };\n describe(\"GitGraph Parser\", () => {\n it(\"should parse a commit statement\", () => {\n const commit2 = {\n $type: \"Commit\",\n id: \"1\",\n message: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n };\n parseStatement(commit2, mockDB);\n expect(mockDB.commit).toHaveBeenCalledWith({\n id: \"1\",\n msg: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n });\n it(\"should parse a branch statement\", () => {\n const branch2 = {\n $type: \"Branch\",\n name: \"newBranch\",\n order: 1\n };\n parseStatement(branch2, mockDB);\n expect(mockDB.branch).toHaveBeenCalledWith({ name: \"newBranch\", order: 1 });\n });\n it(\"should parse a checkout statement\", () => {\n const checkout2 = {\n $type: \"Checkout\",\n branch: \"newBranch\"\n };\n parseStatement(checkout2, mockDB);\n expect(mockDB.checkout).toHaveBeenCalledWith(\"newBranch\");\n });\n it(\"should parse a merge statement\", () => {\n const merge2 = {\n $type: \"Merge\",\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n };\n parseStatement(merge2, mockDB);\n expect(mockDB.merge).toHaveBeenCalledWith({\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n });\n it(\"should parse a cherry picking statement\", () => {\n const cherryPick2 = {\n $type: \"CherryPicking\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n parent: \"2\"\n };\n parseStatement(cherryPick2, mockDB);\n expect(mockDB.cherryPick).toHaveBeenCalledWith({\n id: \"1\",\n targetId: \"\",\n parent: \"2\",\n tags: [\"tag1\", \"tag2\"]\n });\n });\n it(\"should parse a langium generated gitGraph ast\", () => {\n const dummy = {\n $type: \"GitGraph\",\n statements: [],\n accDescr: \"\",\n accTitle: \"\",\n title: \"\"\n };\n const gitGraphAst = {\n $type: \"GitGraph\",\n statements: [\n {\n $container: dummy,\n $type: \"Commit\",\n id: \"1\",\n message: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n },\n {\n $container: dummy,\n $type: \"Branch\",\n name: \"newBranch\",\n order: 1\n },\n {\n $container: dummy,\n $type: \"Merge\",\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: \"NORMAL\"\n },\n {\n $container: dummy,\n $type: \"Checkout\",\n branch: \"newBranch\"\n },\n {\n $container: dummy,\n $type: \"CherryPicking\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n parent: \"2\"\n }\n ],\n accDescr: \"\",\n accTitle: \"\",\n title: \"\"\n };\n populate(gitGraphAst, mockDB);\n expect(mockDB.commit).toHaveBeenCalledWith({\n id: \"1\",\n msg: \"test\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n expect(mockDB.branch).toHaveBeenCalledWith({ name: \"newBranch\", order: 1 });\n expect(mockDB.merge).toHaveBeenCalledWith({\n branch: \"newBranch\",\n id: \"1\",\n tags: [\"tag1\", \"tag2\"],\n type: 0\n });\n expect(mockDB.checkout).toHaveBeenCalledWith(\"newBranch\");\n });\n });\n}\n\n// src/diagrams/git/gitGraphRenderer.ts\nimport { select } from \"d3\";\nvar LAYOUT_OFFSET = 10;\nvar COMMIT_STEP = 40;\nvar PX = 4;\nvar PY = 2;\nvar THEME_COLOR_LIMIT = 8;\nvar REDUX_GEOMETRY_THEMES = /* @__PURE__ */ new Set([\"redux\", \"redux-dark\", \"redux-color\", \"redux-dark-color\"]);\nvar REDUX_BRANCH_LABEL_PADDING_Y = 12;\nvar COLOR_THEMES = /* @__PURE__ */ new Set([\"redux-color\", \"redux-dark-color\"]);\nvar DARK_THEMES = /* @__PURE__ */ new Set([\"dark\", \"redux-dark\", \"redux-dark-color\", \"neo-dark\"]);\nvar calcColorIndex = /* @__PURE__ */ __name((rawIndex, limit, avoidDefaultColor = false) => {\n if (avoidDefaultColor && rawIndex > 0) {\n return (rawIndex - 1) % (limit - 1) + 1;\n }\n return rawIndex % limit;\n}, \"calcColorIndex\");\nvar branchPos = /* @__PURE__ */ new Map();\nvar commitPos = /* @__PURE__ */ new Map();\nvar defaultPos = 30;\nvar allCommitsDict = /* @__PURE__ */ new Map();\nvar lanes = [];\nvar maxPos = 0;\nvar dir = \"LR\";\nvar clear3 = /* @__PURE__ */ __name(() => {\n branchPos.clear();\n commitPos.clear();\n allCommitsDict.clear();\n maxPos = 0;\n lanes = [];\n dir = \"LR\";\n}, \"clear\");\nvar drawText = /* @__PURE__ */ __name((txt) => {\n const svgLabel = document.createElementNS(\"http://www.w3.org/2000/svg\", \"text\");\n const rows = typeof txt === \"string\" ? txt.split(/\\\\n|\\n|<br\\s*\\/?>/gi) : txt;\n rows.forEach((row) => {\n const tspan = document.createElementNS(\"http://www.w3.org/2000/svg\", \"tspan\");\n tspan.setAttributeNS(\"http://www.w3.org/XML/1998/namespace\", \"xml:space\", \"preserve\");\n tspan.setAttribute(\"dy\", \"1em\");\n tspan.setAttribute(\"x\", \"0\");\n tspan.setAttribute(\"class\", \"row\");\n tspan.textContent = row.trim();\n svgLabel.appendChild(tspan);\n });\n return svgLabel;\n}, \"drawText\");\nvar findClosestParent = /* @__PURE__ */ __name((parents) => {\n let closestParent;\n let comparisonFunc;\n let targetPosition;\n if (dir === \"BT\") {\n comparisonFunc = /* @__PURE__ */ __name((a, b) => a <= b, \"comparisonFunc\");\n targetPosition = Infinity;\n } else {\n comparisonFunc = /* @__PURE__ */ __name((a, b) => a >= b, \"comparisonFunc\");\n targetPosition = 0;\n }\n parents.forEach((parent) => {\n const parentPosition = dir === \"TB\" || dir == \"BT\" ? commitPos.get(parent)?.y : commitPos.get(parent)?.x;\n if (parentPosition !== void 0 && comparisonFunc(parentPosition, targetPosition)) {\n closestParent = parent;\n targetPosition = parentPosition;\n }\n });\n return closestParent;\n}, \"findClosestParent\");\nvar findClosestParentBT = /* @__PURE__ */ __name((parents) => {\n let closestParent = \"\";\n let maxPosition = Infinity;\n parents.forEach((parent) => {\n const parentPosition = commitPos.get(parent).y;\n if (parentPosition <= maxPosition) {\n closestParent = parent;\n maxPosition = parentPosition;\n }\n });\n return closestParent || void 0;\n}, \"findClosestParentBT\");\nvar setParallelBTPos = /* @__PURE__ */ __name((sortedKeys, commits, defaultPos2) => {\n let curPos = defaultPos2;\n let maxPosition = defaultPos2;\n const roots = [];\n sortedKeys.forEach((key) => {\n const commit2 = commits.get(key);\n if (!commit2) {\n throw new Error(`Commit not found for key ${key}`);\n }\n if (commit2.parents.length) {\n curPos = calculateCommitPosition(commit2);\n maxPosition = Math.max(curPos, maxPosition);\n } else {\n roots.push(commit2);\n }\n setCommitPosition(commit2, curPos);\n });\n curPos = maxPosition;\n roots.forEach((commit2) => {\n setRootPosition(commit2, curPos, defaultPos2);\n });\n sortedKeys.forEach((key) => {\n const commit2 = commits.get(key);\n if (commit2?.parents.length) {\n const closestParent = findClosestParentBT(commit2.parents);\n curPos = commitPos.get(closestParent).y - COMMIT_STEP;\n if (curPos <= maxPosition) {\n maxPosition = curPos;\n }\n const x = branchPos.get(commit2.branch).pos;\n const y = curPos - LAYOUT_OFFSET;\n commitPos.set(commit2.id, { x, y });\n }\n });\n}, \"setParallelBTPos\");\nvar findClosestParentPos = /* @__PURE__ */ __name((commit2) => {\n const closestParent = findClosestParent(commit2.parents.filter((p) => p !== null));\n if (!closestParent) {\n throw new Error(`Closest parent not found for commit ${commit2.id}`);\n }\n const closestParentPos = commitPos.get(closestParent)?.y;\n if (closestParentPos === void 0) {\n throw new Error(`Closest parent position not found for commit ${commit2.id}`);\n }\n return closestParentPos;\n}, \"findClosestParentPos\");\nvar calculateCommitPosition = /* @__PURE__ */ __name((commit2) => {\n const closestParentPos = findClosestParentPos(commit2);\n return closestParentPos + COMMIT_STEP;\n}, \"calculateCommitPosition\");\nvar setCommitPosition = /* @__PURE__ */ __name((commit2, curPos) => {\n const branch2 = branchPos.get(commit2.branch);\n if (!branch2) {\n throw new Error(`Branch not found for commit ${commit2.id}`);\n }\n const x = branch2.pos;\n const y = curPos + LAYOUT_OFFSET;\n commitPos.set(commit2.id, { x, y });\n return { x, y };\n}, \"setCommitPosition\");\nvar setRootPosition = /* @__PURE__ */ __name((commit2, curPos, defaultPos2) => {\n const branch2 = branchPos.get(commit2.branch);\n if (!branch2) {\n throw new Error(`Branch not found for commit ${commit2.id}`);\n }\n const y = curPos + defaultPos2;\n const x = branch2.pos;\n commitPos.set(commit2.id, { x, y });\n}, \"setRootPosition\");\nvar drawCommitBullet = /* @__PURE__ */ __name((gBullets, commit2, commitPosition, typeClass, branchIndex, commitSymbolType) => {\n const { theme } = getConfig2();\n const useReduxGeometry = REDUX_GEOMETRY_THEMES.has(theme ?? \"\");\n const useColorTheme = COLOR_THEMES.has(theme ?? \"\");\n const isDark = DARK_THEMES.has(theme ?? \"\");\n if (commitSymbolType === commitType.HIGHLIGHT) {\n gBullets.append(\"rect\").attr(\"x\", commitPosition.x - 10 + (useReduxGeometry ? 3 : 0)).attr(\"y\", commitPosition.y - 10 + (useReduxGeometry ? 3 : 0)).attr(\"width\", useReduxGeometry ? 14 : 20).attr(\"height\", useReduxGeometry ? 14 : 20).attr(\n \"class\",\n `commit ${commit2.id} commit-highlight${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)} ${typeClass}-outer`\n );\n gBullets.append(\"rect\").attr(\"x\", commitPosition.x - 6 + (useReduxGeometry ? 2 : 0)).attr(\"y\", commitPosition.y - 6 + (useReduxGeometry ? 2 : 0)).attr(\"width\", useReduxGeometry ? 8 : 12).attr(\"height\", useReduxGeometry ? 8 : 12).attr(\n \"class\",\n `commit ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)} ${typeClass}-inner`\n );\n } else if (commitSymbolType === commitType.CHERRY_PICK) {\n gBullets.append(\"circle\").attr(\"cx\", commitPosition.x).attr(\"cy\", commitPosition.y).attr(\"r\", useReduxGeometry ? 7 : 10).attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"circle\").attr(\"cx\", commitPosition.x - 3).attr(\"cy\", commitPosition.y + 2).attr(\"r\", useReduxGeometry ? 2.5 : 2.75).attr(\"fill\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"circle\").attr(\"cx\", commitPosition.x + 3).attr(\"cy\", commitPosition.y + 2).attr(\"r\", useReduxGeometry ? 2.5 : 2.75).attr(\"fill\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"line\").attr(\"x1\", commitPosition.x + 3).attr(\"y1\", commitPosition.y + 1).attr(\"x2\", commitPosition.x).attr(\"y2\", commitPosition.y - 5).attr(\"stroke\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n gBullets.append(\"line\").attr(\"x1\", commitPosition.x - 3).attr(\"y1\", commitPosition.y + 1).attr(\"x2\", commitPosition.x).attr(\"y2\", commitPosition.y - 5).attr(\"stroke\", isDark ? \"#000000\" : \"#fff\").attr(\"class\", `commit ${commit2.id} ${typeClass}`);\n } else {\n const circle = gBullets.append(\"circle\");\n circle.attr(\"cx\", commitPosition.x);\n circle.attr(\"cy\", commitPosition.y);\n circle.attr(\"r\", useReduxGeometry ? 7 : 10);\n circle.attr(\n \"class\",\n `commit ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)}`\n );\n if (commitSymbolType === commitType.MERGE) {\n const circle2 = gBullets.append(\"circle\");\n circle2.attr(\"cx\", commitPosition.x);\n circle2.attr(\"cy\", commitPosition.y);\n circle2.attr(\"r\", useReduxGeometry ? 5 : 6);\n circle2.attr(\n \"class\",\n `commit ${typeClass} ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)}`\n );\n }\n if (commitSymbolType === commitType.REVERSE) {\n const cross = gBullets.append(\"path\");\n const constValue = useReduxGeometry ? 4 : 5;\n cross.attr(\n \"d\",\n `M ${commitPosition.x - constValue},${commitPosition.y - constValue}L${commitPosition.x + constValue},${commitPosition.y + constValue}M${commitPosition.x - constValue},${commitPosition.y + constValue}L${commitPosition.x + constValue},${commitPosition.y - constValue}`\n ).attr(\n \"class\",\n `commit ${typeClass} ${commit2.id} commit${calcColorIndex(branchIndex, THEME_COLOR_LIMIT, useColorTheme)}`\n );\n }\n }\n}, \"drawCommitBullet\");\nvar drawCommitLabel = /* @__PURE__ */ __name((gLabels, commit2, commitPosition, pos, gitGraphConfig) => {\n if (commit2.type !== commitType.CHERRY_PICK && (commit2.customId && commit2.type === commitType.MERGE || commit2.type !== commitType.MERGE) && gitGraphConfig.showCommitLabel) {\n const wrapper = gLabels.append(\"g\");\n const labelBkg = wrapper.insert(\"rect\").attr(\"class\", \"commit-label-bkg\");\n const text = wrapper.append(\"text\").attr(\"x\", pos).attr(\"y\", commitPosition.y + 25).attr(\"class\", \"commit-label\").text(commit2.id);\n const bbox = text.node()?.getBBox();\n if (bbox) {\n labelBkg.attr(\"x\", commitPosition.posWithOffset - bbox.width / 2 - PY).attr(\"y\", commitPosition.y + 13.5).attr(\"width\", bbox.width + 2 * PY).attr(\"height\", bbox.height + 2 * PY);\n if (dir === \"TB\" || dir === \"BT\") {\n labelBkg.attr(\"x\", commitPosition.x - (bbox.width + 4 * PX + 5)).attr(\"y\", commitPosition.y - 12);\n text.attr(\"x\", commitPosition.x - (bbox.width + 4 * PX)).attr(\"y\", commitPosition.y + bbox.height - 12);\n } else {\n text.attr(\"x\", commitPosition.posWithOffset - bbox.width / 2);\n }\n if (gitGraphConfig.rotateCommitLabel) {\n if (dir === \"TB\" || dir === \"BT\") {\n text.attr(\n \"transform\",\n \"rotate(-45, \" + commitPosition.x + \", \" + commitPosition.y + \")\"\n );\n labelBkg.attr(\n \"transform\",\n \"rotate(-45, \" + commitPosition.x + \", \" + commitPosition.y + \")\"\n );\n } else {\n const r_x = -7.5 - (bbox.width + 10) / 25 * 9.5;\n const r_y = 10 + bbox.width / 25 * 8.5;\n wrapper.attr(\n \"transform\",\n \"translate(\" + r_x + \", \" + r_y + \") rotate(-45, \" + pos + \", \" + commitPosition.y + \")\"\n );\n }\n }\n }\n }\n}, \"drawCommitLabel\");\nvar drawCommitTags = /* @__PURE__ */ __name((gLabels, commit2, commitPosition, pos) => {\n if (commit2.tags.length > 0) {\n let yOffset = 0;\n let maxTagBboxWidth = 0;\n let maxTagBboxHeight = 0;\n const tagElements = [];\n for (const tagValue of commit2.tags.reverse()) {\n const rect = gLabels.insert(\"polygon\");\n const hole = gLabels.append(\"circle\");\n const tag = gLabels.append(\"text\").attr(\"y\", commitPosition.y - 16 - yOffset).attr(\"class\", \"tag-label\").text(tagValue);\n const tagBbox = tag.node()?.getBBox();\n if (!tagBbox) {\n throw new Error(\"Tag bbox not found\");\n }\n maxTagBboxWidth = Math.max(maxTagBboxWidth, tagBbox.width);\n maxTagBboxHeight = Math.max(maxTagBboxHeight, tagBbox.height);\n tag.attr(\"x\", commitPosition.posWithOffset - tagBbox.width / 2);\n tagElements.push({\n tag,\n hole,\n rect,\n yOffset\n });\n yOffset += 20;\n }\n for (const { tag, hole, rect, yOffset: yOffset2 } of tagElements) {\n const h2 = maxTagBboxHeight / 2;\n const ly = commitPosition.y - 19.2 - yOffset2;\n rect.attr(\"class\", \"tag-label-bkg\").attr(\n \"points\",\n `\n ${pos - maxTagBboxWidth / 2 - PX / 2},${ly + PY} \n ${pos - maxTagBboxWidth / 2 - PX / 2},${ly - PY}\n ${commitPosition.posWithOffset - maxTagBboxWidth / 2 - PX},${ly - h2 - PY}\n ${commitPosition.posWithOffset + maxTagBboxWidth / 2 + PX},${ly - h2 - PY}\n ${commitPosition.posWithOffset + maxTagBboxWidth / 2 + PX},${ly + h2 + PY}\n ${commitPosition.posWithOffset - maxTagBboxWidth / 2 - PX},${ly + h2 + PY}`\n );\n hole.attr(\"cy\", ly).attr(\"cx\", pos - maxTagBboxWidth / 2 + PX / 2).attr(\"r\", 1.5).attr(\"class\", \"tag-hole\");\n if (dir === \"TB\" || dir === \"BT\") {\n const yOrigin = pos + yOffset2;\n rect.attr(\"class\", \"tag-label-bkg\").attr(\n \"points\",\n `\n ${commitPosition.x},${yOrigin + 2}\n ${commitPosition.x},${yOrigin - 2}\n ${commitPosition.x + LAYOUT_OFFSET},${yOrigin - h2 - 2}\n ${commitPosition.x + LAYOUT_OFFSET + maxTagBboxWidth + 4},${yOrigin - h2 - 2}\n ${commitPosition.x + LAYOUT_OFFSET + maxTagBboxWidth + 4},${yOrigin + h2 + 2}\n ${commitPosition.x + LAYOUT_OFFSET},${yOrigin + h2 + 2}`\n ).attr(\"transform\", \"translate(12,12) rotate(45, \" + commitPosition.x + \",\" + pos + \")\");\n hole.attr(\"cx\", commitPosition.x + PX / 2).attr(\"cy\", yOrigin).attr(\"transform\", \"translate(12,12) rotate(45, \" + commitPosition.x + \",\" + pos + \")\");\n tag.attr(\"x\", commitPosition.x + 5).attr(\"y\", yOrigin + 3).attr(\"transform\", \"translate(14,14) rotate(45, \" + commitPosition.x + \",\" + pos + \")\");\n }\n }\n }\n}, \"drawCommitTags\");\nvar getCommitClassType = /* @__PURE__ */ __name((commit2) => {\n const commitSymbolType = commit2.customType ?? commit2.type;\n switch (commitSymbolType) {\n case commitType.NORMAL:\n return \"commit-normal\";\n case commitType.REVERSE:\n return \"commit-reverse\";\n case commitType.HIGHLIGHT:\n return \"commit-highlight\";\n case commitType.MERGE:\n return \"commit-merge\";\n case commitType.CHERRY_PICK:\n return \"commit-cherry-pick\";\n default:\n return \"commit-normal\";\n }\n}, \"getCommitClassType\");\nvar calculatePosition = /* @__PURE__ */ __name((commit2, dir2, pos, commitPos2) => {\n const defaultCommitPosition = { x: 0, y: 0 };\n if (commit2.parents.length > 0) {\n const closestParent = findClosestParent(commit2.parents);\n if (closestParent) {\n const parentPosition = commitPos2.get(closestParent) ?? defaultCommitPosition;\n if (dir2 === \"TB\") {\n return parentPosition.y + COMMIT_STEP;\n } else if (dir2 === \"BT\") {\n const currentPosition = commitPos2.get(commit2.id) ?? defaultCommitPosition;\n return currentPosition.y - COMMIT_STEP;\n } else {\n return parentPosition.x + COMMIT_STEP;\n }\n }\n } else {\n if (dir2 === \"TB\") {\n return defaultPos;\n } else if (dir2 === \"BT\") {\n const currentPosition = commitPos2.get(commit2.id) ?? defaultCommitPosition;\n return currentPosition.y - COMMIT_STEP;\n } else {\n return 0;\n }\n }\n return 0;\n}, \"calculatePosition\");\nvar getCommitPosition = /* @__PURE__ */ __name((commit2, pos, isParallelCommits) => {\n const posWithOffset = dir === \"BT\" && isParallelCommits ? pos : pos + LAYOUT_OFFSET;\n const branchY = branchPos.get(commit2.branch)?.pos;\n const x = dir === \"TB\" || dir === \"BT\" ? branchPos.get(commit2.branch)?.pos : posWithOffset;\n if (x === void 0 || branchY === void 0) {\n throw new Error(`Position were undefined for commit ${commit2.id}`);\n }\n const useReduxGeometry = REDUX_GEOMETRY_THEMES.has(getConfig2().theme ?? \"\");\n const y = dir === \"TB\" || dir === \"BT\" ? posWithOffset : branchY + (useReduxGeometry ? REDUX_BRANCH_LABEL_PADDING_Y / 2 + 1 : -2);\n return { x, y, posWithOffset };\n}, \"getCommitPosition\");\nvar drawCommits = /* @__PURE__ */ __name((svg, commits, modifyGraph, gitGraphConfig) => {\n const gBullets = svg.append(\"g\").attr(\"class\", \"commit-bullets\");\n const gLabels = svg.append(\"g\").attr(\"class\", \"commit-labels\");\n let pos = dir === \"TB\" || dir === \"BT\" ? defaultPos : 0;\n const keys = [...commits.keys()];\n const isParallelCommits = gitGraphConfig.parallelCommits ?? false;\n const sortKeys = /* @__PURE__ */ __name((a, b) => {\n const seqA = commits.get(a)?.seq;\n const seqB = commits.get(b)?.seq;\n return seqA !== void 0 && seqB !== void 0 ? seqA - seqB : 0;\n }, \"sortKeys\");\n let sortedKeys = keys.sort(sortKeys);\n if (dir === \"BT\") {\n if (isParallelCommits) {\n setParallelBTPos(sortedKeys, commits, pos);\n }\n sortedKeys = sortedKeys.reverse();\n }\n sortedKeys.forEach((key) => {\n const commit2 = commits.get(key);\n if (!commit2) {\n throw new Error(`Commit not found for key ${key}`);\n }\n if (isParallelCommits) {\n pos = calculatePosition(commit2, dir, pos, commitPos);\n }\n const commitPosition = getCommitPosition(commit2, pos, isParallelCommits);\n if (modifyGraph) {\n const typeClass = getCommitClassType(commit2);\n const commitSymbolType = commit2.customType ?? commit2.type;\n const branchIndex = branchPos.get(commit2.branch)?.index ?? 0;\n drawCommitBullet(gBullets, commit2, commitPosition, typeClass, branchIndex, commitSymbolType);\n drawCommitLabel(gLabels, commit2, commitPosition, pos, gitGraphConfig);\n drawCommitTags(gLabels, commit2, commitPosition, pos);\n }\n if (dir === \"TB\" || dir === \"BT\") {\n commitPos.set(commit2.id, { x: commitPosition.x, y: commitPosition.posWithOffset });\n } else {\n commitPos.set(commit2.id, { x: commitPosition.posWithOffset, y: commitPosition.y });\n }\n pos = dir === \"BT\" && isParallelCommits ? pos + COMMIT_STEP : pos + COMMIT_STEP + LAYOUT_OFFSET;\n if (pos > maxPos) {\n maxPos = pos;\n }\n });\n}, \"drawCommits\");\nvar shouldRerouteArrow = /* @__PURE__ */ __name((commitA, commitB, p1, p2, allCommits) => {\n const commitBIsFurthest = dir === \"TB\" || dir === \"BT\" ? p1.x < p2.x : p1.y < p2.y;\n const branchToGetCurve = commitBIsFurthest ? commitB.branch : commitA.branch;\n const isOnBranchToGetCurve = /* @__PURE__ */ __name((x) => x.branch === branchToGetCurve, \"isOnBranchToGetCurve\");\n const isBetweenCommits = /* @__PURE__ */ __name((x) => x.seq > commitA.seq && x.seq < commitB.seq, \"isBetweenCommits\");\n return [...allCommits.values()].some((commitX) => {\n return isBetweenCommits(commitX) && isOnBranchToGetCurve(commitX);\n });\n}, \"shouldRerouteArrow\");\nvar findLane = /* @__PURE__ */ __name((y1, y2, depth = 0) => {\n const candidate = y1 + Math.abs(y1 - y2) / 2;\n if (depth > 5) {\n return candidate;\n }\n const ok = lanes.every((lane) => Math.abs(lane - candidate) >= 10);\n if (ok) {\n lanes.push(candidate);\n return candidate;\n }\n const diff = Math.abs(y1 - y2);\n return findLane(y1, y2 - diff / 5, depth + 1);\n}, \"findLane\");\nvar drawArrow = /* @__PURE__ */ __name((svg, commitA, commitB, allCommits) => {\n const { theme: arrowTheme } = getConfig2();\n const useColorTheme = COLOR_THEMES.has(arrowTheme ?? \"\");\n const p1 = commitPos.get(commitA.id);\n const p2 = commitPos.get(commitB.id);\n if (p1 === void 0 || p2 === void 0) {\n throw new Error(`Commit positions not found for commits ${commitA.id} and ${commitB.id}`);\n }\n const arrowNeedsRerouting = shouldRerouteArrow(commitA, commitB, p1, p2, allCommits);\n let arc = \"\";\n let arc2 = \"\";\n let radius = 0;\n let offset = 0;\n let colorClassNum = branchPos.get(commitB.branch)?.index;\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n }\n let lineDef;\n if (arrowNeedsRerouting) {\n arc = \"A 10 10, 0, 0, 0,\";\n arc2 = \"A 10 10, 0, 0, 1,\";\n radius = 10;\n offset = 10;\n const lineY = p1.y < p2.y ? findLane(p1.y, p2.y) : findLane(p2.y, p1.y);\n const lineX = p1.x < p2.x ? findLane(p1.x, p2.x) : findLane(p2.x, p1.x);\n if (dir === \"TB\") {\n if (p1.x < p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${lineX - radius} ${p1.y} ${arc2} ${lineX} ${p1.y + offset} L ${lineX} ${p2.y - radius} ${arc} ${lineX + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n lineDef = `M ${p1.x} ${p1.y} L ${lineX + radius} ${p1.y} ${arc} ${lineX} ${p1.y + offset} L ${lineX} ${p2.y - radius} ${arc2} ${lineX - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n } else if (dir === \"BT\") {\n if (p1.x < p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${lineX - radius} ${p1.y} ${arc} ${lineX} ${p1.y - offset} L ${lineX} ${p2.y + radius} ${arc2} ${lineX + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n lineDef = `M ${p1.x} ${p1.y} L ${lineX + radius} ${p1.y} ${arc2} ${lineX} ${p1.y - offset} L ${lineX} ${p2.y + radius} ${arc} ${lineX - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n } else {\n if (p1.y < p2.y) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${lineY - radius} ${arc} ${p1.x + offset} ${lineY} L ${p2.x - radius} ${lineY} ${arc2} ${p2.x} ${lineY + offset} L ${p2.x} ${p2.y}`;\n } else {\n colorClassNum = branchPos.get(commitA.branch)?.index;\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${lineY + radius} ${arc2} ${p1.x + offset} ${lineY} L ${p2.x - radius} ${lineY} ${arc} ${p2.x} ${lineY - offset} L ${p2.x} ${p2.y}`;\n }\n }\n } else {\n arc = \"A 20 20, 0, 0, 0,\";\n arc2 = \"A 20 20, 0, 0, 1,\";\n radius = 20;\n offset = 20;\n if (dir === \"TB\") {\n if (p1.x < p2.x) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc2} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x > p2.x) {\n arc = \"A 20 20, 0, 0, 0,\";\n arc2 = \"A 20 20, 0, 0, 1,\";\n radius = 20;\n offset = 20;\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc2} ${p1.x - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x + radius} ${p1.y} ${arc} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x === p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`;\n }\n } else if (dir === \"BT\") {\n if (p1.x < p2.x) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y + radius} ${arc2} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc} ${p2.x} ${p1.y - offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x > p2.x) {\n arc = \"A 20 20, 0, 0, 0,\";\n arc2 = \"A 20 20, 0, 0, 1,\";\n radius = 20;\n offset = 20;\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y + radius} ${arc} ${p1.x - offset} ${p2.y} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x + radius} ${p1.y} ${arc2} ${p2.x} ${p1.y - offset} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.x === p2.x) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`;\n }\n } else {\n if (p1.y < p2.y) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc2} ${p2.x} ${p1.y + offset} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y - radius} ${arc} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.y > p2.y) {\n if (commitB.type === commitType.MERGE && commitA.id !== commitB.parents[0]) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x - radius} ${p1.y} ${arc} ${p2.x} ${p1.y - offset} L ${p2.x} ${p2.y}`;\n } else {\n lineDef = `M ${p1.x} ${p1.y} L ${p1.x} ${p2.y + radius} ${arc2} ${p1.x + offset} ${p2.y} L ${p2.x} ${p2.y}`;\n }\n }\n if (p1.y === p2.y) {\n lineDef = `M ${p1.x} ${p1.y} L ${p2.x} ${p2.y}`;\n }\n }\n }\n if (lineDef === void 0) {\n throw new Error(\"Line definition not found\");\n }\n svg.append(\"path\").attr(\"d\", lineDef).attr(\n \"class\",\n \"arrow arrow\" + calcColorIndex(colorClassNum, THEME_COLOR_LIMIT, useColorTheme)\n );\n}, \"drawArrow\");\nvar drawArrows = /* @__PURE__ */ __name((svg, commits) => {\n const gArrows = svg.append(\"g\").attr(\"class\", \"commit-arrows\");\n [...commits.keys()].forEach((key) => {\n const commit2 = commits.get(key);\n if (commit2.parents && commit2.parents.length > 0) {\n commit2.parents.forEach((parent) => {\n drawArrow(gArrows, commits.get(parent), commit2, commits);\n });\n }\n });\n}, \"drawArrows\");\nvar drawBranches = /* @__PURE__ */ __name((svg, branches, gitGraphConfig, id) => {\n const { look, theme, themeVariables } = getConfig2();\n const { dropShadow, THEME_COLOR_LIMIT: themeColorLimit } = themeVariables;\n const useReduxGeometry = REDUX_GEOMETRY_THEMES.has(theme ?? \"\");\n const useColorTheme = COLOR_THEMES.has(theme ?? \"\");\n const g = svg.append(\"g\");\n branches.forEach((branch2, index) => {\n const adjustIndexForTheme = calcColorIndex(\n index,\n useReduxGeometry ? themeColorLimit : THEME_COLOR_LIMIT,\n useColorTheme\n );\n const pos = branchPos.get(branch2.name)?.pos;\n if (pos === void 0) {\n throw new Error(`Position not found for branch ${branch2.name}`);\n }\n const spineY = dir === \"TB\" || dir === \"BT\" ? pos : useReduxGeometry ? pos + REDUX_BRANCH_LABEL_PADDING_Y / 2 + 1 : pos - 2;\n const line = g.append(\"line\");\n line.attr(\"x1\", 0);\n line.attr(\"y1\", spineY);\n line.attr(\"x2\", maxPos);\n line.attr(\"y2\", spineY);\n line.attr(\"class\", \"branch branch\" + adjustIndexForTheme);\n if (dir === \"TB\") {\n line.attr(\"y1\", defaultPos);\n line.attr(\"x1\", pos);\n line.attr(\"y2\", maxPos);\n line.attr(\"x2\", pos);\n } else if (dir === \"BT\") {\n line.attr(\"y1\", maxPos);\n line.attr(\"x1\", pos);\n line.attr(\"y2\", defaultPos);\n line.attr(\"x2\", pos);\n }\n lanes.push(spineY);\n const name = branch2.name;\n const labelElement = drawText(name);\n const bkg = g.insert(\"rect\");\n const branchLabel = g.insert(\"g\").attr(\"class\", \"branchLabel\");\n const label = branchLabel.insert(\"g\").attr(\"class\", \"label branch-label\" + adjustIndexForTheme);\n label.node().appendChild(labelElement);\n const bbox = labelElement.getBBox();\n const borderRadius = useReduxGeometry ? 0 : 4;\n const labelPaddingX = useReduxGeometry ? 16 : 0;\n const labelPaddingY = useReduxGeometry ? REDUX_BRANCH_LABEL_PADDING_Y : 0;\n if (look === \"neo\") {\n bkg.attr(\"data-look\", `neo`);\n }\n bkg.attr(\"class\", \"branchLabelBkg label\" + adjustIndexForTheme).attr(\n \"style\",\n look === \"neo\" ? `filter:${useReduxGeometry ? `url(#${id}-drop-shadow)` : dropShadow}` : \"\"\n ).attr(\"rx\", borderRadius).attr(\"ry\", borderRadius).attr(\"x\", -bbox.width - 4 - (gitGraphConfig.rotateCommitLabel === true ? 30 : 0)).attr(\"y\", -bbox.height / 2 + 10).attr(\"width\", bbox.width + 18 + labelPaddingX).attr(\"height\", bbox.height + 4 + labelPaddingY);\n label.attr(\n \"transform\",\n \"translate(\" + (-bbox.width - 14 - (gitGraphConfig.rotateCommitLabel === true ? 30 : 0) + labelPaddingX / 2) + \", \" + (spineY - bbox.height / 2 - 2) + \")\"\n );\n if (dir === \"TB\") {\n bkg.attr(\"x\", pos - bbox.width / 2 - 10).attr(\"y\", 0);\n label.attr(\"transform\", \"translate(\" + (pos - bbox.width / 2 - 5) + \", 0)\");\n if (useReduxGeometry) {\n bkg.attr(\"transform\", `translate(${-labelPaddingX / 2 - 3}, ${-labelPaddingY - 10})`);\n label.attr(\n \"transform\",\n \"translate(\" + (pos - bbox.width / 2 - 5) + \", \" + (-labelPaddingY * 2 + 7) + \")\"\n );\n }\n } else if (dir === \"BT\") {\n bkg.attr(\"x\", pos - bbox.width / 2 - 10).attr(\"y\", maxPos);\n label.attr(\"transform\", \"translate(\" + (pos - bbox.width / 2 - 5) + \", \" + maxPos + \")\");\n if (useReduxGeometry) {\n bkg.attr(\"transform\", `translate(${-labelPaddingX / 2 - 3}, ${labelPaddingY + 10})`);\n label.attr(\n \"transform\",\n \"translate(\" + (pos - bbox.width / 2 - 5) + \", \" + (maxPos + labelPaddingY * 2 + 4) + \")\"\n );\n }\n } else {\n bkg.attr(\"transform\", \"translate(-19, \" + (spineY - 12 - labelPaddingY / 2) + \")\");\n }\n });\n}, \"drawBranches\");\nvar setBranchPosition = /* @__PURE__ */ __name(function(name, pos, index, bbox, rotateCommitLabel) {\n branchPos.set(name, { pos, index });\n pos += 50 + (rotateCommitLabel ? 40 : 0) + (dir === \"TB\" || dir === \"BT\" ? bbox.width / 2 : 0);\n return pos;\n}, \"setBranchPosition\");\nvar draw = /* @__PURE__ */ __name(function(txt, id, ver, diagObj) {\n clear3();\n log.debug(\"in gitgraph renderer\", txt + \"\\n\", \"id:\", id, ver);\n const db2 = diagObj.db;\n if (!db2.getConfig) {\n log.error(\"getConfig method is not available on db\");\n return;\n }\n const gitGraphConfig = db2.getConfig();\n const rotateCommitLabel = gitGraphConfig.rotateCommitLabel ?? false;\n allCommitsDict = db2.getCommits();\n const branches = db2.getBranchesAsObjArray();\n dir = db2.getDirection();\n const diagram2 = select(`[id=\"${id}\"]`);\n const { look, theme, themeVariables } = getConfig2();\n const { useGradient, gradientStart, gradientStop, filterColor } = themeVariables;\n if (useGradient) {\n const gradient = diagram2.append(\"defs\").append(\"linearGradient\").attr(\"id\", id + \"-gradient\").attr(\"gradientUnits\", \"objectBoundingBox\").attr(\"x1\", \"0%\").attr(\"y1\", \"0%\").attr(\"x2\", \"100%\").attr(\"y2\", \"0%\");\n gradient.append(\"stop\").attr(\"offset\", \"0%\").attr(\"stop-color\", gradientStart).attr(\"stop-opacity\", 1);\n gradient.append(\"stop\").attr(\"offset\", \"100%\").attr(\"stop-color\", gradientStop).attr(\"stop-opacity\", 1);\n }\n if (look === \"neo\" && REDUX_GEOMETRY_THEMES.has(theme ?? \"\")) {\n diagram2.append(\"defs\").append(\"filter\").attr(\"id\", id + \"-drop-shadow\").attr(\"height\", \"130%\").attr(\"width\", \"130%\").append(\"feDropShadow\").attr(\"dx\", \"4\").attr(\"dy\", \"4\").attr(\"stdDeviation\", 0).attr(\"flood-opacity\", \"0.06\").attr(\"flood-color\", filterColor);\n }\n let pos = 0;\n branches.forEach((branch2, index) => {\n const labelElement = drawText(branch2.name);\n const g = diagram2.append(\"g\");\n const branchLabel = g.insert(\"g\").attr(\"class\", \"branchLabel\");\n const label = branchLabel.insert(\"g\").attr(\"class\", \"label branch-label\");\n label.node()?.appendChild(labelElement);\n const bbox = labelElement.getBBox();\n pos = setBranchPosition(branch2.name, pos, index, bbox, rotateCommitLabel);\n label.remove();\n branchLabel.remove();\n g.remove();\n });\n drawCommits(diagram2, allCommitsDict, false, gitGraphConfig);\n if (gitGraphConfig.showBranches) {\n drawBranches(diagram2, branches, gitGraphConfig, id);\n }\n drawArrows(diagram2, allCommitsDict);\n drawCommits(diagram2, allCommitsDict, true, gitGraphConfig);\n utils_default.insertTitle(\n diagram2,\n \"gitTitleText\",\n gitGraphConfig.titleTopMargin ?? 0,\n db2.getDiagramTitle()\n );\n setupGraphViewbox(void 0, diagram2, gitGraphConfig.diagramPadding, gitGraphConfig.useMaxWidth);\n}, \"draw\");\nvar gitGraphRenderer_default = {\n draw\n};\nif (void 0) {\n const { it, expect, describe } = void 0;\n describe(\"drawText\", () => {\n it(\"should drawText\", () => {\n const svgLabel = drawText(\"main\");\n expect(svgLabel).toBeDefined();\n expect(svgLabel.children[0].innerHTML).toBe(\"main\");\n });\n });\n describe(\"branchPosition\", () => {\n const bbox = {\n x: 0,\n y: 0,\n width: 10,\n height: 10,\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n toJSON: /* @__PURE__ */ __name(() => \"\", \"toJSON\")\n };\n it(\"should setBranchPositions LR with two branches\", () => {\n dir = \"LR\";\n const pos = setBranchPosition(\"main\", 0, 0, bbox, true);\n expect(pos).toBe(90);\n expect(branchPos.get(\"main\")).toEqual({ pos: 0, index: 0 });\n const posNext = setBranchPosition(\"develop\", pos, 1, bbox, true);\n expect(posNext).toBe(180);\n expect(branchPos.get(\"develop\")).toEqual({ pos, index: 1 });\n });\n it(\"should setBranchPositions TB with two branches\", () => {\n dir = \"TB\";\n bbox.width = 34.9921875;\n const pos = setBranchPosition(\"main\", 0, 0, bbox, true);\n expect(pos).toBe(107.49609375);\n expect(branchPos.get(\"main\")).toEqual({ pos: 0, index: 0 });\n bbox.width = 56.421875;\n const posNext = setBranchPosition(\"develop\", pos, 1, bbox, true);\n expect(posNext).toBe(225.70703125);\n expect(branchPos.get(\"develop\")).toEqual({ pos, index: 1 });\n });\n });\n describe(\"commitPosition\", () => {\n const commits = /* @__PURE__ */ new Map([\n [\n \"commitZero\",\n {\n id: \"ZERO\",\n message: \"\",\n seq: 0,\n type: commitType.NORMAL,\n tags: [],\n parents: [],\n branch: \"main\"\n }\n ],\n [\n \"commitA\",\n {\n id: \"A\",\n message: \"\",\n seq: 1,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"ZERO\"],\n branch: \"feature\"\n }\n ],\n [\n \"commitB\",\n {\n id: \"B\",\n message: \"\",\n seq: 2,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"A\"],\n branch: \"feature\"\n }\n ],\n [\n \"commitM\",\n {\n id: \"M\",\n message: \"merged branch feature into main\",\n seq: 3,\n type: commitType.MERGE,\n tags: [],\n parents: [\"ZERO\", \"B\"],\n branch: \"main\",\n customId: true\n }\n ],\n [\n \"commitC\",\n {\n id: \"C\",\n message: \"\",\n seq: 4,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"ZERO\"],\n branch: \"release\"\n }\n ],\n [\n \"commit5_8928ea0\",\n {\n id: \"5-8928ea0\",\n message: \"cherry-picked [object Object] into release\",\n seq: 5,\n type: commitType.CHERRY_PICK,\n tags: [],\n parents: [\"C\", \"M\"],\n branch: \"release\"\n }\n ],\n [\n \"commitD\",\n {\n id: \"D\",\n message: \"\",\n seq: 6,\n type: commitType.NORMAL,\n tags: [],\n parents: [\"5-8928ea0\"],\n branch: \"release\"\n }\n ],\n [\n \"commit7_ed848ba\",\n {\n id: \"7-ed848ba\",\n message: \"cherry-picked [object Object] into release\",\n seq: 7,\n type: commitType.CHERRY_PICK,\n tags: [],\n parents: [\"D\", \"M\"],\n branch: \"release\"\n }\n ]\n ]);\n let pos = 0;\n branchPos.set(\"main\", { pos: 0, index: 0 });\n branchPos.set(\"feature\", { pos: 107.49609375, index: 1 });\n branchPos.set(\"release\", { pos: 224.03515625, index: 2 });\n describe(\"TB\", () => {\n pos = 30;\n dir = \"TB\";\n const expectedCommitPositionTB = /* @__PURE__ */ new Map([\n [\"commitZero\", { x: 0, y: 40, posWithOffset: 40 }],\n [\"commitA\", { x: 107.49609375, y: 90, posWithOffset: 90 }],\n [\"commitB\", { x: 107.49609375, y: 140, posWithOffset: 140 }],\n [\"commitM\", { x: 0, y: 190, posWithOffset: 190 }],\n [\"commitC\", { x: 224.03515625, y: 240, posWithOffset: 240 }],\n [\"commit5_8928ea0\", { x: 224.03515625, y: 290, posWithOffset: 290 }],\n [\"commitD\", { x: 224.03515625, y: 340, posWithOffset: 340 }],\n [\"commit7_ed848ba\", { x: 224.03515625, y: 390, posWithOffset: 390 }]\n ]);\n commits.forEach((commit2, key) => {\n it(`should give the correct position for commit ${key}`, () => {\n const position = getCommitPosition(commit2, pos, false);\n expect(position).toEqual(expectedCommitPositionTB.get(key));\n pos += 50;\n });\n });\n });\n describe(\"LR\", () => {\n let pos2 = 30;\n dir = \"LR\";\n const expectedCommitPositionLR = /* @__PURE__ */ new Map([\n [\"commitZero\", { x: 0, y: 40, posWithOffset: 40 }],\n [\"commitA\", { x: 107.49609375, y: 90, posWithOffset: 90 }],\n [\"commitB\", { x: 107.49609375, y: 140, posWithOffset: 140 }],\n [\"commitM\", { x: 0, y: 190, posWithOffset: 190 }],\n [\"commitC\", { x: 224.03515625, y: 240, posWithOffset: 240 }],\n [\"commit5_8928ea0\", { x: 224.03515625, y: 290, posWithOffset: 290 }],\n [\"commitD\", { x: 224.03515625, y: 340, posWithOffset: 340 }],\n [\"commit7_ed848ba\", { x: 224.03515625, y: 390, posWithOffset: 390 }]\n ]);\n commits.forEach((commit2, key) => {\n it(`should give the correct position for commit ${key}`, () => {\n const position = getCommitPosition(commit2, pos2, false);\n expect(position).toEqual(expectedCommitPositionLR.get(key));\n pos2 += 50;\n });\n });\n });\n describe(\"getCommitClassType\", () => {\n const expectedCommitClassType = /* @__PURE__ */ new Map([\n [\"commitZero\", \"commit-normal\"],\n [\"commitA\", \"commit-normal\"],\n [\"commitB\", \"commit-normal\"],\n [\"commitM\", \"commit-merge\"],\n [\"commitC\", \"commit-normal\"],\n [\"commit5_8928ea0\", \"commit-cherry-pick\"],\n [\"commitD\", \"commit-normal\"],\n [\"commit7_ed848ba\", \"commit-cherry-pick\"]\n ]);\n commits.forEach((commit2, key) => {\n it(`should give the correct class type for commit ${key}`, () => {\n const classType = getCommitClassType(commit2);\n expect(classType).toBe(expectedCommitClassType.get(key));\n });\n });\n });\n });\n describe(\"building BT parallel commit diagram\", () => {\n const commits = /* @__PURE__ */ new Map([\n [\n \"1-abcdefg\",\n {\n id: \"1-abcdefg\",\n message: \"\",\n seq: 0,\n type: 0,\n tags: [],\n parents: [],\n branch: \"main\"\n }\n ],\n [\n \"2-abcdefg\",\n {\n id: \"2-abcdefg\",\n message: \"\",\n seq: 1,\n type: 0,\n tags: [],\n parents: [\"1-abcdefg\"],\n branch: \"main\"\n }\n ],\n [\n \"3-abcdefg\",\n {\n id: \"3-abcdefg\",\n message: \"\",\n seq: 2,\n type: 0,\n tags: [],\n parents: [\"2-abcdefg\"],\n branch: \"develop\"\n }\n ],\n [\n \"4-abcdefg\",\n {\n id: \"4-abcdefg\",\n message: \"\",\n seq: 3,\n type: 0,\n tags: [],\n parents: [\"3-abcdefg\"],\n branch: \"develop\"\n }\n ],\n [\n \"5-abcdefg\",\n {\n id: \"5-abcdefg\",\n message: \"\",\n seq: 4,\n type: 0,\n tags: [],\n parents: [\"2-abcdefg\"],\n branch: \"feature\"\n }\n ],\n [\n \"6-abcdefg\",\n {\n id: \"6-abcdefg\",\n message: \"\",\n seq: 5,\n type: 0,\n tags: [],\n parents: [\"5-abcdefg\"],\n branch: \"feature\"\n }\n ],\n [\n \"7-abcdefg\",\n {\n id: \"7-abcdefg\",\n message: \"\",\n seq: 6,\n type: 0,\n tags: [],\n parents: [\"2-abcdefg\"],\n branch: \"main\"\n }\n ],\n [\n \"8-abcdefg\",\n {\n id: \"8-abcdefg\",\n message: \"\",\n seq: 7,\n type: 0,\n tags: [],\n parents: [\"7-abcdefg\"],\n branch: \"main\"\n }\n ]\n ]);\n const expectedCommitPosition = /* @__PURE__ */ new Map([\n [\"1-abcdefg\", { x: 0, y: 40 }],\n [\"2-abcdefg\", { x: 0, y: 90 }],\n [\"3-abcdefg\", { x: 107.49609375, y: 140 }],\n [\"4-abcdefg\", { x: 107.49609375, y: 190 }],\n [\"5-abcdefg\", { x: 225.70703125, y: 140 }],\n [\"6-abcdefg\", { x: 225.70703125, y: 190 }],\n [\"7-abcdefg\", { x: 0, y: 140 }],\n [\"8-abcdefg\", { x: 0, y: 190 }]\n ]);\n const expectedCommitPositionAfterParallel = /* @__PURE__ */ new Map([\n [\"1-abcdefg\", { x: 0, y: 210 }],\n [\"2-abcdefg\", { x: 0, y: 160 }],\n [\"3-abcdefg\", { x: 107.49609375, y: 110 }],\n [\"4-abcdefg\", { x: 107.49609375, y: 60 }],\n [\"5-abcdefg\", { x: 225.70703125, y: 110 }],\n [\"6-abcdefg\", { x: 225.70703125, y: 60 }],\n [\"7-abcdefg\", { x: 0, y: 110 }],\n [\"8-abcdefg\", { x: 0, y: 60 }]\n ]);\n const expectedCommitCurrentPosition = /* @__PURE__ */ new Map([\n [\"1-abcdefg\", 30],\n [\"2-abcdefg\", 80],\n [\"3-abcdefg\", 130],\n [\"4-abcdefg\", 180],\n [\"5-abcdefg\", 130],\n [\"6-abcdefg\", 180],\n [\"7-abcdefg\", 130],\n [\"8-abcdefg\", 180]\n ]);\n const sortedKeys = [...expectedCommitPosition.keys()];\n it(\"should get the correct commit position and current position\", () => {\n dir = \"BT\";\n let curPos = 30;\n commitPos.clear();\n branchPos.clear();\n branchPos.set(\"main\", { pos: 0, index: 0 });\n branchPos.set(\"develop\", { pos: 107.49609375, index: 1 });\n branchPos.set(\"feature\", { pos: 225.70703125, index: 2 });\n commits.forEach((commit2, key) => {\n if (commit2.parents.length > 0) {\n curPos = calculateCommitPosition(commit2);\n }\n const position = setCommitPosition(commit2, curPos);\n expect(position).toEqual(expectedCommitPosition.get(key));\n expect(curPos).toEqual(expectedCommitCurrentPosition.get(key));\n });\n });\n it(\"should get the correct commit position after parallel commits\", () => {\n commitPos.clear();\n branchPos.clear();\n dir = \"BT\";\n const curPos = 30;\n commitPos.clear();\n branchPos.clear();\n branchPos.set(\"main\", { pos: 0, index: 0 });\n branchPos.set(\"develop\", { pos: 107.49609375, index: 1 });\n branchPos.set(\"feature\", { pos: 225.70703125, index: 2 });\n setParallelBTPos(sortedKeys, commits, curPos);\n sortedKeys.forEach((commit2) => {\n const position = commitPos.get(commit2);\n expect(position).toEqual(expectedCommitPositionAfterParallel.get(commit2));\n });\n });\n });\n it(\"add\", () => {\n commitPos.set(\"parent1\", { x: 1, y: 1 });\n commitPos.set(\"parent2\", { x: 2, y: 2 });\n commitPos.set(\"parent3\", { x: 3, y: 3 });\n dir = \"LR\";\n const parents = [\"parent1\", \"parent2\", \"parent3\"];\n const closestParent = findClosestParent(parents);\n expect(closestParent).toBe(\"parent3\");\n commitPos.clear();\n });\n}\n\n// src/diagrams/git/styles.js\nvar GIT_NAMED_COLOR_COUNT = 8;\nvar REDUX_GEOMETRY_THEMES2 = /* @__PURE__ */ new Set([\"redux\", \"redux-dark\", \"redux-color\", \"redux-dark-color\"]);\nvar COLOR_THEMES2 = /* @__PURE__ */ new Set([\"redux-color\", \"redux-dark-color\"]);\nvar NEO_THEMES = /* @__PURE__ */ new Set([\"neo\", \"neo-dark\"]);\nvar DARK_THEMES2 = /* @__PURE__ */ new Set([\"dark\", \"redux-dark\", \"redux-dark-color\", \"neo-dark\"]);\nvar NEO_COLOR_GEN_THEMES = /* @__PURE__ */ new Set([\n \"redux\",\n \"redux-dark\",\n \"redux-color\",\n \"redux-dark-color\",\n \"neo\",\n \"neo-dark\"\n]);\nvar genGitGraphGradient = /* @__PURE__ */ __name((options) => {\n const { svgId } = options;\n let sections = \"\";\n if (options.useGradient && svgId) {\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n sections += `\n .label${i} { fill: ${options.mainBkg}; stroke: url(${svgId}-gradient); stroke-width: ${options.strokeWidth};}\n `;\n }\n }\n return sections;\n}, \"genGitGraphGradient\");\nvar genColor = /* @__PURE__ */ __name((options) => {\n const config = getConfig();\n const { theme, themeVariables } = config;\n const { borderColorArray } = themeVariables;\n const useReduxGeometry = REDUX_GEOMETRY_THEMES2.has(theme);\n if (NEO_THEMES.has(theme)) {\n let sections = \"\";\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n if (i === 0) {\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder};}\n .commit${i} { stroke: ${options.nodeBorder}; }\n .commit-highlight${i} { stroke: ${options.nodeBorder}; fill: ${options.nodeBorder}; }\n .arrow${i} { stroke: ${options.nodeBorder}; }\n .commit-bullets { fill: ${options.nodeBorder}; }\n .commit-cherry-pick${i} { stroke: ${options.nodeBorder}; }\n ${genGitGraphGradient(options)}`;\n } else {\n const ci = i % GIT_NAMED_COLOR_COUNT;\n sections += `\n .branch-label${i} { fill: ${options[\"gitBranchLabel\" + ci]}; }\n .commit${i} { stroke: ${options[\"git\" + ci]}; fill: ${options[\"git\" + ci]}; }\n .commit-highlight${i} { stroke: ${options[\"gitInv\" + ci]}; fill: ${options[\"gitInv\" + ci]}; }\n .arrow${i} { stroke: ${options[\"git\" + ci]}; }\n `;\n }\n }\n return sections;\n } else if (!COLOR_THEMES2.has(theme)) {\n let sections = \"\";\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .commit${i} { stroke: ${options.nodeBorder}; }\n .commit-highlight${i} { stroke: ${options.nodeBorder}; fill: ${options.nodeBorder}; }\n .label${i} { fill: ${options.mainBkg}; stroke: ${options.nodeBorder}; stroke-width: ${options.strokeWidth}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"}}\n .arrow${i} { stroke: ${options.nodeBorder}; }\n .commit-bullets { fill: ${options.nodeBorder}; }\n .commit-cherry-pick${i} { stroke: ${options.nodeBorder}; }\n `;\n }\n return sections;\n } else {\n let sections = \"\";\n for (let i = 0; i < options.THEME_COLOR_LIMIT; i++) {\n if (i === 0) {\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .commit${i} { stroke: ${options.nodeBorder}; }\n .commit-highlight${i} { stroke: ${options.nodeBorder}; fill: ${options.mainBkg}; }\n .label${i} { fill: ${options.mainBkg}; stroke: ${options.nodeBorder}; stroke-width: ${options.strokeWidth}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .arrow${i} { stroke: ${options.nodeBorder}; }\n .commit-bullets { fill: ${options.nodeBorder}; }\n `;\n } else {\n const colorIndex = i % borderColorArray.length;\n sections += `\n .branch-label${i} { fill: ${options.nodeBorder}; ${useReduxGeometry ? `font-weight:${options.noteFontWeight}` : \"\"} }\n .commit${i} { stroke: ${borderColorArray[colorIndex]}; fill: ${borderColorArray[colorIndex]}; }\n .commit-highlight${i} { stroke: ${borderColorArray[colorIndex]}; fill: ${borderColorArray[colorIndex]}; }\n .label${i} { fill: ${DARK_THEMES2.has(theme) ? options.mainBkg : borderColorArray[colorIndex]}; stroke: ${borderColorArray[colorIndex]}; stroke-width: ${options.strokeWidth}; }\n .arrow${i} { stroke: ${borderColorArray[colorIndex]}; }\n `;\n }\n }\n return sections;\n }\n}, \"genColor\");\nvar normalTheme = /* @__PURE__ */ __name((options) => {\n return `${Array.from({ length: options.THEME_COLOR_LIMIT }, (_, i) => i).map((i) => {\n const ci = i % GIT_NAMED_COLOR_COUNT;\n return `\n .branch-label${i} { fill: ${options[\"gitBranchLabel\" + ci]}; }\n .commit${i} { stroke: ${options[\"git\" + ci]}; fill: ${options[\"git\" + ci]}; }\n .commit-highlight${i} { stroke: ${options[\"gitInv\" + ci]}; fill: ${options[\"gitInv\" + ci]}; }\n .label${i} { fill: ${options[\"git\" + ci]}; }\n .arrow${i} { stroke: ${options[\"git\" + ci]}; }\n `;\n }).join(\"\\n\")}`;\n}, \"normalTheme\");\nvar getStyles = /* @__PURE__ */ __name((options) => {\n const config = getConfig();\n const { theme } = config;\n const useNeoColorGen = NEO_COLOR_GEN_THEMES.has(theme);\n return `\n .commit-id,\n .commit-msg,\n .branch-label {\n fill: lightgrey;\n color: lightgrey;\n font-family: 'trebuchet ms', verdana, arial, sans-serif;\n font-family: var(--mermaid-font-family);\n }\n \n ${useNeoColorGen ? genColor(options) : normalTheme(options)}\n\n .branch {\n stroke-width: ${options.strokeWidth};\n stroke: ${options.commitLineColor ?? options.lineColor};\n stroke-dasharray: ${useNeoColorGen ? \"4 2\" : \"2\"};\n }\n .commit-label { font-size: ${options.commitLabelFontSize}; fill: ${useNeoColorGen ? options.nodeBorder : options.commitLabelColor}; ${useNeoColorGen ? `font-weight:${options.noteFontWeight};` : \"\"}}\n .commit-label-bkg { font-size: ${options.commitLabelFontSize}; fill: ${useNeoColorGen ? \"transparent\" : options.commitLabelBackground}; opacity: ${useNeoColorGen ? \"\" : 0.5}; }\n .tag-label { font-size: ${options.tagLabelFontSize}; fill: ${options.tagLabelColor};}\n .tag-label-bkg { fill: ${useNeoColorGen ? options.mainBkg : options.tagLabelBackground}; stroke: ${useNeoColorGen ? options.nodeBorder : options.tagLabelBorder}; ${useNeoColorGen ? `filter:${options.dropShadow}` : \"\"} }\n .tag-hole { fill: ${options.textColor}; }\n\n .commit-merge {\n stroke: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n fill: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n }\n .commit-reverse {\n stroke: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n fill: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n stroke-width: ${useNeoColorGen ? options.strokeWidth : 3};\n }\n .commit-highlight-outer {\n }\n .commit-highlight-inner {\n stroke: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n fill: ${useNeoColorGen ? options.mainBkg : options.primaryColor};\n }\n\n .arrow {\n /* Intentional: neo themes keep the bold 8px arrow (like classic themes); only redux-geometry themes use the thinner options.strokeWidth. */\n stroke-width: ${REDUX_GEOMETRY_THEMES2.has(theme) ? options.strokeWidth : 8};\n stroke-linecap: round;\n fill: none\n }\n .gitTitleText {\n text-anchor: middle;\n font-size: 18px;\n fill: ${options.textColor};\n }\n`;\n}, \"getStyles\");\nvar styles_default = getStyles;\n\n// src/diagrams/git/gitGraphDiagram.ts\nvar diagram = {\n parser,\n db,\n renderer: gitGraphRenderer_default,\n styles: styles_default\n};\nexport {\n diagram\n};\n"],"x_google_ignoreList":[0],"mappings":";;;;;;;AAkCA,IAAI,IAAa;CACf,QAAQ;CACR,SAAS;CACT,WAAW;CACX,OAAO;CACP,aAAa;CACd,EAGG,KAA0B,EAAsB,UAChD,IAA6B,wBAChB,EAAc;CAC3B,GAAG;CACH,GAAG,GAAW,CAAC;CAChB,CACY,EACZ,YAAY,EACX,IAAQ,IAAI,QAAsB;CACpC,IAAM,IAAS,GAAY,EACrB,IAAiB,EAAO,gBACxB,IAAkB,EAAO;CAC/B,OAAO;EACL;EACA,yBAAyB,IAAI,KAAK;EAClC,MAAM;EACN,8BAA8B,IAAI,IAAI,CAAC,CAAC,GAAgB;GAAE,MAAM;GAAgB,OAAO;GAAiB,CAAC,CAAC,CAAC;EAC3G,0BAA0B,IAAI,IAAI,CAAC,CAAC,GAAgB,KAAK,CAAC,CAAC;EAC3D,YAAY;EACZ,WAAW;EACX,KAAK;EACL,SAAS,EAAE;EACZ;EACD;AACF,SAAS,IAAQ;CACf,OAAO,EAAO,EAAE,QAAQ,GAAG,CAAC;;AAE9B,EAAO,GAAO,QAAQ;AACtB,SAAS,EAAO,GAAM,GAAI;CACxB,IAAM,IAA4B,uBAAO,OAAO,KAAK;CACrD,OAAO,EAAK,QAAQ,GAAK,MAAS;EAChC,IAAM,IAAM,EAAG,EAAK;EAKpB,OAJK,EAAU,OACb,EAAU,KAAO,IACjB,EAAI,KAAK,EAAK,GAET;IACN,EAAE,CAAC;;AAER,EAAO,GAAQ,SAAS;AACxB,IAAI,KAA+B,kBAAO,SAAS,GAAM;CACvD,EAAM,QAAQ,YAAY;GACzB,eAAe,EACd,KAA6B,kBAAO,SAAS,GAAc;CAG7D,AAFA,EAAI,MAAM,eAAe,EAAa,EACtC,IAAe,GAAc,MAAM,EACnC,MAA+B;CAC/B,IAAI;EACF,EAAM,QAAQ,UAAU,KAAK,MAAM,EAAa;UACzC,GAAG;EACV,EAAI,MAAM,wCAAwC,EAAE,QAAQ;;GAE7D,aAAa,EACZ,KAA6B,kBAAO,WAAW;CACjD,OAAO,EAAM,QAAQ;GACpB,aAAa,EACZ,KAAyB,kBAAO,SAAS,GAAU;CACrD,IAAI,IAAM,EAAS,KACf,IAAK,EAAS,IACZ,IAAO,EAAS,MAClB,IAAO,EAAS;CAEpB,AADA,EAAI,KAAK,UAAU,GAAK,GAAI,GAAM,EAAK,EACvC,EAAI,MAAM,oBAAoB,GAAK,GAAI,GAAM,EAAK;CAClD,IAAM,IAAS,GAAY;CAG3B,AAFA,IAAK,EAAe,aAAa,GAAI,EAAO,EAC5C,IAAM,EAAe,aAAa,GAAK,EAAO,EAC9C,IAAO,GAAM,KAAK,MAAQ,EAAe,aAAa,GAAK,EAAO,CAAC;CACnE,IAAM,IAAY;EAChB,IAAI,KAAU,EAAM,QAAQ,MAAM,MAAM,GAAO;EAC/C,SAAS;EACT,KAAK,EAAM,QAAQ;EACnB,MAAM,KAAQ,EAAW;EACzB,MAAM,KAAQ,EAAE;EAChB,SAAS,EAAM,QAAQ,QAAQ,OAAO,EAAE,GAAG,CAAC,EAAM,QAAQ,KAAK,GAAG;EAClE,QAAQ,EAAM,QAAQ;EACvB;CAQD,AAPA,EAAM,QAAQ,OAAO,GACrB,EAAI,KAAK,eAAe,EAAO,eAAe,EAC1C,EAAM,QAAQ,QAAQ,IAAI,EAAU,GAAG,IACzC,EAAI,KAAK,aAAa,EAAU,GAAG,iBAAiB,EAEtD,EAAM,QAAQ,QAAQ,IAAI,EAAU,IAAI,EAAU,EAClD,EAAM,QAAQ,SAAS,IAAI,EAAM,QAAQ,YAAY,EAAU,GAAG,EAClE,EAAI,MAAM,mBAAmB,EAAU,GAAG;GACzC,SAAS,EACR,KAAyB,kBAAO,SAAS,GAAU;CACrD,IAAI,IAAO,EAAS,MACd,IAAQ,EAAS;CAEvB,IADA,IAAO,EAAe,aAAa,GAAM,GAAY,CAAC,EAClD,EAAM,QAAQ,SAAS,IAAI,EAAK,EAClC,MAAU,MACR,4HAA4H,EAAK,IAClI;CAKH,AAHA,EAAM,QAAQ,SAAS,IAAI,GAAM,EAAM,QAAQ,QAAQ,OAA+B,OAAxB,EAAM,QAAQ,KAAK,GAAU,EAC3F,EAAM,QAAQ,aAAa,IAAI,GAAM;EAAE;EAAM;EAAO,CAAC,EACrD,EAAS,EAAK,EACd,EAAI,MAAM,kBAAkB;GAC3B,SAAS,EACR,KAAwB,mBAAQ,MAAY;CAC9C,IAAI,IAAc,EAAQ,QACtB,IAAW,EAAQ,IACjB,IAAe,EAAQ,MACvB,IAAa,EAAQ,MACrB,IAAS,GAAY;CAE3B,AADA,IAAc,EAAe,aAAa,GAAa,EAAO,EAC9D,AACE,MAAW,EAAe,aAAa,GAAU,EAAO;CAE1D,IAAM,IAAqB,EAAM,QAAQ,SAAS,IAAI,EAAM,QAAQ,WAAW,EACzE,IAAmB,EAAM,QAAQ,SAAS,IAAI,EAAY,EAC1D,IAAgB,IAAqB,EAAM,QAAQ,QAAQ,IAAI,EAAmB,GAAG,KAAK,GAC1F,IAAc,IAAmB,EAAM,QAAQ,QAAQ,IAAI,EAAiB,GAAG,KAAK;CAC1F,IAAI,KAAiB,KAAe,EAAc,WAAW,GAC3D,MAAU,MAAM,wBAAwB,EAAY,gBAAgB;CAEtE,IAAI,EAAM,QAAQ,eAAe,GAAa;EAC5C,IAAM,IAAQ,gBAAI,MAAM,gEAA8D;EAMtF,MALA,EAAM,OAAO;GACX,MAAM,SAAS;GACf,OAAO,SAAS;GAChB,UAAU,CAAC,aAAa;GACzB,EACK;;CAER,IAAI,MAAkB,KAAK,KAAK,CAAC,GAAe;EAC9C,IAAM,IAAQ,gBAAI,MAChB,+CAA+C,EAAM,QAAQ,WAAW,iBACzE;EAMD,MALA,EAAM,OAAO;GACX,MAAM,SAAS;GACf,OAAO,SAAS;GAChB,UAAU,CAAC,SAAS;GACrB,EACK;;CAER,IAAI,CAAC,EAAM,QAAQ,SAAS,IAAI,EAAY,EAAE;EAC5C,IAAM,IAAQ,gBAAI,MAChB,wDAAsD,IAAc,mBACrE;EAMD,MALA,EAAM,OAAO;GACX,MAAM,SAAS;GACf,OAAO,SAAS;GAChB,UAAU,CAAC,UAAU,IAAc;GACpC,EACK;;CAER,IAAI,MAAgB,KAAK,KAAK,CAAC,GAAa;EAC1C,IAAM,IAAQ,gBAAI,MAChB,wDAAsD,IAAc,mBACrE;EAMD,MALA,EAAM,OAAO;GACX,MAAM,SAAS;GACf,OAAO,SAAS;GAChB,UAAU,CAAC,aAAW;GACvB,EACK;;CAER,IAAI,MAAkB,GAAa;EACjC,IAAM,IAAQ,gBAAI,MAAM,6DAA2D;EAMnF,MALA,EAAM,OAAO;GACX,MAAM,SAAS;GACf,OAAO,SAAS;GAChB,UAAU,CAAC,aAAa;GACzB,EACK;;CAER,IAAI,KAAY,EAAM,QAAQ,QAAQ,IAAI,EAAS,EAAE;EACnD,IAAM,IAAQ,gBAAI,MAChB,kDAAgD,IAAW,2CAC5D;EAQD,MAPA,EAAM,OAAO;GACX,MAAM,SAAS,EAAY,GAAG,EAAS,GAAG,EAAa,GAAG,GAAY,KAAK,IAAI;GAC/E,OAAO,SAAS,EAAY,GAAG,EAAS,GAAG,EAAa,GAAG,GAAY,KAAK,IAAI;GAChF,UAAU,CACR,SAAS,EAAY,GAAG,EAAS,UAAU,EAAa,GAAG,GAAY,KAAK,IAAI,GACjF;GACF,EACK;;CAER,IAAM,IAAiB,KAAsC,IACvD,IAAU;EACd,IAAI,KAAY,GAAG,EAAM,QAAQ,IAAI,GAAG,GAAO;EAC/C,SAAS,iBAAiB,EAAY,QAAQ,EAAM,QAAQ;EAC5D,KAAK,EAAM,QAAQ;EACnB,SAAS,EAAM,QAAQ,QAAQ,OAAO,EAAE,GAAG,CAAC,EAAM,QAAQ,KAAK,IAAI,EAAe;EAClF,QAAQ,EAAM,QAAQ;EACtB,MAAM,EAAW;EACjB,YAAY;EACZ,UAAU;EACV,MAAM,KAAc,EAAE;EACvB;CAKD,AAJA,EAAM,QAAQ,OAAO,GACrB,EAAM,QAAQ,QAAQ,IAAI,EAAQ,IAAI,EAAQ,EAC9C,EAAM,QAAQ,SAAS,IAAI,EAAM,QAAQ,YAAY,EAAQ,GAAG,EAChE,EAAI,MAAM,EAAM,QAAQ,SAAS,EACjC,EAAI,MAAM,iBAAiB;GAC1B,QAAQ,EACP,KAA6B,kBAAO,SAAS,GAAc;CAC7D,IAAI,IAAW,EAAa,IACxB,IAAW,EAAa,UACxB,IAAO,EAAa,MACpB,IAAiB,EAAa;CAClC,EAAI,MAAM,wBAAwB,GAAU,GAAU,EAAK;CAC3D,IAAM,IAAS,GAAY;CAK3B,IAJA,IAAW,EAAe,aAAa,GAAU,EAAO,EACxD,IAAW,EAAe,aAAa,GAAU,EAAO,EACxD,IAAO,GAAM,KAAK,MAAQ,EAAe,aAAa,GAAK,EAAO,CAAC,EACnE,IAAiB,EAAe,aAAa,GAAgB,EAAO,EAChE,CAAC,KAAY,CAAC,EAAM,QAAQ,QAAQ,IAAI,EAAS,EAAE;EACrD,IAAM,IAAQ,gBAAI,MAChB,gFACD;EAMD,MALA,EAAM,OAAO;GACX,MAAM,cAAc,EAAS,GAAG;GAChC,OAAO,cAAc,EAAS,GAAG;GACjC,UAAU,CAAC,kBAAkB;GAC9B,EACK;;CAER,IAAM,IAAe,EAAM,QAAQ,QAAQ,IAAI,EAAS;CACxD,IAAI,MAAiB,KAAK,KAAK,CAAC,GAC9B,MAAU,MAAM,gFAA8E;CAEhG,IAAI,KAAkB,EAAE,MAAM,QAAQ,EAAa,QAAQ,IAAI,EAAa,QAAQ,SAAS,EAAe,GAI1G,MAAM,gBAHY,MAChB,yGAES;CAEb,IAAM,IAAqB,EAAa;CACxC,IAAI,EAAa,SAAS,EAAW,SAAS,CAAC,GAI7C,MAAM,gBAHY,MAChB,wHAES;CAEb,IAAI,CAAC,KAAY,CAAC,EAAM,QAAQ,QAAQ,IAAI,EAAS,EAAE;EACrD,IAAI,MAAuB,EAAM,QAAQ,YAAY;GACnD,IAAM,IAAQ,gBAAI,MAChB,gFACD;GAMD,MALA,EAAM,OAAO;IACX,MAAM,cAAc,EAAS,GAAG;IAChC,OAAO,cAAc,EAAS,GAAG;IACjC,UAAU,CAAC,kBAAkB;IAC9B,EACK;;EAER,IAAM,IAAkB,EAAM,QAAQ,SAAS,IAAI,EAAM,QAAQ,WAAW;EAC5E,IAAI,MAAoB,KAAK,KAAK,CAAC,GAAiB;GAClD,IAAM,IAAQ,gBAAI,MAChB,qDAAqD,EAAM,QAAQ,WAAW,iBAC/E;GAMD,MALA,EAAM,OAAO;IACX,MAAM,cAAc,EAAS,GAAG;IAChC,OAAO,cAAc,EAAS,GAAG;IACjC,UAAU,CAAC,kBAAkB;IAC9B,EACK;;EAER,IAAM,IAAgB,EAAM,QAAQ,QAAQ,IAAI,EAAgB;EAChE,IAAI,MAAkB,KAAK,KAAK,CAAC,GAAe;GAC9C,IAAM,IAAQ,gBAAI,MAChB,qDAAqD,EAAM,QAAQ,WAAW,iBAC/E;GAMD,MALA,EAAM,OAAO;IACX,MAAM,cAAc,EAAS,GAAG;IAChC,OAAO,cAAc,EAAS,GAAG;IACjC,UAAU,CAAC,kBAAkB;IAC9B,EACK;;EAER,IAAM,IAAU;GACd,IAAI,EAAM,QAAQ,MAAM,MAAM,GAAO;GACrC,SAAS,iBAAiB,GAAc,QAAQ,QAAQ,EAAM,QAAQ;GACtE,KAAK,EAAM,QAAQ;GACnB,SAAS,EAAM,QAAQ,QAAQ,OAAO,EAAE,GAAG,CAAC,EAAM,QAAQ,KAAK,IAAI,EAAa,GAAG;GACnF,QAAQ,EAAM,QAAQ;GACtB,MAAM,EAAW;GACjB,MAAM,IAAO,EAAK,OAAO,QAAQ,GAAG,CAClC,eAAe,EAAa,KAAK,EAAa,SAAS,EAAW,QAAQ,WAAW,MAAmB,KACzG;GACF;EAKD,AAJA,EAAM,QAAQ,OAAO,GACrB,EAAM,QAAQ,QAAQ,IAAI,EAAQ,IAAI,EAAQ,EAC9C,EAAM,QAAQ,SAAS,IAAI,EAAM,QAAQ,YAAY,EAAQ,GAAG,EAChE,EAAI,MAAM,EAAM,QAAQ,SAAS,EACjC,EAAI,MAAM,gBAAgB;;GAE3B,aAAa,EACZ,IAA2B,kBAAO,SAAS,GAAS;CAEtD,IADA,IAAU,EAAe,aAAa,GAAS,GAAY,CAAC,EACvD,EAAM,QAAQ,SAAS,IAAI,EAAQ,EAUjC;EACL,EAAM,QAAQ,aAAa;EAC3B,IAAM,IAAK,EAAM,QAAQ,SAAS,IAAI,EAAM,QAAQ,WAAW;EAC/D,AAAI,MAAO,KAAK,KAAK,CAAC,IACpB,EAAM,QAAQ,OAAO,OAErB,EAAM,QAAQ,OAAO,EAAM,QAAQ,QAAQ,IAAI,EAAG,IAAI;QAhBhB;EACxC,IAAM,IAAQ,gBAAI,MAChB,+EAA+E,EAAQ,IACxF;EAMD,MALA,EAAM,OAAO;GACX,MAAM,YAAY;GAClB,OAAO,YAAY;GACnB,UAAU,CAAC,UAAU,IAAU;GAChC,EACK;;GAUP,WAAW;AACd,SAAS,EAAO,GAAK,GAAK,GAAQ;CAChC,IAAM,IAAQ,EAAI,QAAQ,EAAI;CAC9B,AAAI,MAAU,KACZ,EAAI,KAAK,EAAO,GAEhB,EAAI,OAAO,GAAO,GAAG,EAAO;;AAGhC,EAAO,GAAQ,SAAS;AACxB,SAAS,EAAyB,GAAW;CAC3C,IAAM,IAAU,EAAU,QAAQ,GAAK,MACjC,EAAI,MAAM,EAAQ,MACb,IAEF,GACN,EAAU,GAAG,EACZ,IAAO;CACX,EAAU,QAAQ,SAAS,GAAG;EAC5B,AAAI,MAAM,IACR,KAAQ,OAER,KAAQ;GAEV;CACF,IAAM,IAAQ;EAAC;EAAM,EAAQ;EAAI,EAAQ;EAAI;CAC7C,KAAK,IAAM,KAAW,EAAM,QAAQ,UAClC,AAAI,EAAM,QAAQ,SAAS,IAAI,EAAQ,KAAK,EAAQ,MAClD,EAAM,KAAK,EAAQ;CAIvB,IADA,EAAI,MAAM,EAAM,KAAK,IAAI,CAAC,EACtB,EAAQ,WAAW,EAAQ,QAAQ,UAAU,KAAK,EAAQ,QAAQ,MAAM,EAAQ,QAAQ,IAAI;EAC9F,IAAM,IAAY,EAAM,QAAQ,QAAQ,IAAI,EAAQ,QAAQ,GAAG;EAE/D,AADA,EAAO,GAAW,GAAS,EAAU,EACjC,EAAQ,QAAQ,MAClB,EAAU,KAAK,EAAM,QAAQ,QAAQ,IAAI,EAAQ,QAAQ,GAAG,CAAC;QAE1D,IAAI,EAAQ,QAAQ,UAAU,GACnC;MAEA,IAAI,EAAQ,QAAQ,IAAI;EACtB,IAAM,IAAY,EAAM,QAAQ,QAAQ,IAAI,EAAQ,QAAQ,GAAG;EAC/D,EAAO,GAAW,GAAS,EAAU;;CAIzC,AADA,IAAY,EAAO,IAAY,MAAM,EAAE,GAAG,EAC1C,EAAyB,EAAU;;AAErC,EAAO,GAA0B,2BAA2B;AAC5D,IAAI,KAA8B,kBAAO,WAAW;CAClD,EAAI,MAAM,EAAM,QAAQ,QAAQ;CAChC,IAAM,IAAO,GAAiB,CAAC;CAC/B,EAAyB,CAAC,EAAK,CAAC;GAC/B,cAAc,EACb,KAAyB,kBAAO,WAAW;CAE7C,AADA,EAAM,OAAO,EACb,GAAO;GACN,QAAQ,EACP,KAAwC,kBAAO,WAAW;CAU5D,OATsB,CAAC,GAAG,EAAM,QAAQ,aAAa,QAAQ,CAAC,CAAC,KAAK,GAAc,MAC5E,EAAa,UAAU,QAAQ,EAAa,UAAU,KAAK,IACtD,IAEF;EACL,GAAG;EACH,OAAO,WAAW,KAAK,IAAI;EAC5B,CACD,CAAC,MAAM,GAAG,OAAO,EAAE,SAAS,MAAM,EAAE,SAAS,GAAG,CAAC,KAAK,EAAE,eAAY,EAAE,SAAM,EAC1D;GACnB,wBAAwB,EACvB,KAA8B,kBAAO,WAAW;CAClD,OAAO,EAAM,QAAQ;GACpB,cAAc,EACb,KAA6B,kBAAO,WAAW;CACjD,OAAO,EAAM,QAAQ;GACpB,aAAa,EACZ,IAAkC,kBAAO,WAAW;CACtD,IAAM,IAAY,CAAC,GAAG,EAAM,QAAQ,QAAQ,QAAQ,CAAC;CAKrD,OAJA,EAAU,QAAQ,SAAS,GAAG;EAC5B,EAAI,MAAM,EAAE,GAAG;GACf,EACF,EAAU,MAAM,GAAG,MAAM,EAAE,MAAM,EAAE,IAAI,EAChC;GACN,kBAAkB,EAUjB,IAAK;CACP;CACA,WAAW;CACX;CACA;CACA;CACA;CACA;CACA;CACA;CACA;CAEA;CACA,OAAO;CACP;CACA;CACA;CACA;CACA,kBA3BqC,kBAAO,WAAW;EACvD,OAAO,EAAM,QAAQ;IACpB,mBAyBe;CAChB,cAzBiC,kBAAO,WAAW;EACnD,OAAO,EAAM,QAAQ;IACpB,eAuBW;CACZ,SAvB4B,kBAAO,WAAW;EAC9C,OAAO,EAAM,QAAQ;IACpB,UAqBM;CACP;CACA;CACA;CACA;CACA;CACA;CACD,EAGG,KAA2B,mBAAQ,GAAK,MAAQ;CAElD,AADA,EAAiB,GAAK,EAAI,EACtB,EAAI,OACN,EAAI,aAAa,EAAI,IAAI;CAE3B,KAAK,IAAM,KAAa,EAAI,YAC1B,GAAe,GAAW,EAAI;GAE/B,WAAW,EACV,KAAiC,mBAAQ,GAAW,MAAQ;CAQ9D,IAAM,IAAU;EANd,QAAwB,mBAAQ,MAAS,EAAI,OAAO,GAAY,EAAK,CAAC,EAAE,SAAS;EACjF,QAAwB,mBAAQ,MAAS,EAAI,OAAO,GAAY,EAAK,CAAC,EAAE,SAAS;EACjF,OAAuB,mBAAQ,MAAS,EAAI,MAAM,GAAW,EAAK,CAAC,EAAE,QAAQ;EAC7E,UAA0B,mBAAQ,MAAS,EAAI,SAAS,GAAc,EAAK,CAAC,EAAE,WAAW;EACzF,eAA+B,mBAAQ,MAAS,EAAI,WAAW,GAAmB,EAAK,CAAC,EAAE,gBAAgB;EAErF,CAAC,EAAU;CAClC,AAAI,IACF,EAAQ,EAAU,GAElB,EAAI,MAAM,2BAA2B,EAAU,QAAQ;GAExD,iBAAiB,EAChB,KAA8B,mBAAQ,OAOjC;CALL,IAAI,EAAQ;CACZ,KAAK,EAAQ,WAAW;CACxB,MAAM,EAAQ,SAAS,KAAK,IAA+B,EAAW,SAAtC,EAAW,EAAQ;CACnD,MAAM,EAAQ,QAAQ,KAAK;CAEd,GACd,cAAc,EACb,KAA8B,mBAAQ,OAKjC;CAHL,MAAM,EAAQ;CACd,OAAO,EAAQ,SAAS;CAEX,GACd,cAAc,EACb,KAA6B,mBAAQ,OAOhC;CALL,QAAQ,EAAO;CACf,IAAI,EAAO,MAAM;CACjB,MAAM,EAAO,SAAS,KAAK,IAA8B,KAAK,IAA/B,EAAW,EAAO;CACjD,MAAM,EAAO,QAAQ,KAAK;CAEd,GACb,aAAa,EACZ,KAAgC,mBAAQ,MAC1B,EAAU,QAEzB,gBAAgB,EACf,KAAqC,mBAAQ,OAOxC;CALL,IAAI,EAAc;CAClB,UAAU;CACV,MAAM,EAAc,MAAM,WAAW,IAAI,KAAK,IAAI,EAAc;CAChE,QAAQ,EAAc;CAEL,GAClB,qBAAqB,EACpB,KAAS,EACX,OAAuB,kBAAO,OAAO,MAAU;CAC7C,IAAM,IAAM,MAAM,EAAM,YAAY,EAAM;CAE1C,AADA,EAAI,MAAM,EAAI,EACd,GAAS,GAAK,EAAG;GAChB,QAAQ,EACZ,EAoJG,IAAgB,IAChB,IAAc,IACd,IAAK,GACL,IAAK,GACL,IAAoB,GACpB,oBAAwC,IAAI,IAAI;CAAC;CAAS;CAAc;CAAe;CAAmB,CAAC,EAC3G,IAA+B,IAC/B,oBAA+B,IAAI,IAAI,CAAC,eAAe,mBAAmB,CAAC,EAC3E,qBAA8B,IAAI,IAAI;CAAC;CAAQ;CAAc;CAAoB;CAAW,CAAC,EAC7F,IAAiC,mBAAQ,GAAU,GAAO,IAAoB,OAC5E,KAAqB,IAAW,KAC1B,IAAW,MAAM,IAAQ,KAAK,IAEjC,IAAW,GACjB,iBAAiB,EAChB,oBAA4B,IAAI,KAAK,EACrC,oBAA4B,IAAI,KAAK,EACrC,IAAa,IACb,oBAAiC,IAAI,KAAK,EAC1C,IAAQ,EAAE,EACV,IAAS,GACT,IAAM,MACN,KAAyB,wBAAa;CAMxC,AALA,EAAU,OAAO,EACjB,EAAU,OAAO,EACjB,EAAe,OAAO,EACtB,IAAS,GACT,IAAQ,EAAE,EACV,IAAM;GACL,QAAQ,EACP,IAA2B,mBAAQ,MAAQ;CAC7C,IAAM,IAAW,SAAS,gBAAgB,8BAA8B,OAAO;CAW/E,QAVa,OAAO,KAAQ,WAAW,EAAI,MAAM,sBAAsB,GAAG,GACrE,SAAS,MAAQ;EACpB,IAAM,IAAQ,SAAS,gBAAgB,8BAA8B,QAAQ;EAM7E,AALA,EAAM,eAAe,wCAAwC,aAAa,WAAW,EACrF,EAAM,aAAa,MAAM,MAAM,EAC/B,EAAM,aAAa,KAAK,IAAI,EAC5B,EAAM,aAAa,SAAS,MAAM,EAClC,EAAM,cAAc,EAAI,MAAM,EAC9B,EAAS,YAAY,EAAM;GAC3B,EACK;GACN,WAAW,EACV,IAAoC,mBAAQ,MAAY;CAC1D,IAAI,GACA,GACA;CAeJ,OAdI,MAAQ,QACV,IAAiC,mBAAQ,GAAG,MAAM,KAAK,GAAG,iBAAiB,EAC3E,IAAiB,aAEjB,IAAiC,mBAAQ,GAAG,MAAM,KAAK,GAAG,iBAAiB,EAC3E,IAAiB,IAEnB,EAAQ,SAAS,MAAW;EAC1B,IAAM,IAAiB,MAAQ,QAAQ,KAAO,OAAO,EAAU,IAAI,EAAO,EAAE,IAAI,EAAU,IAAI,EAAO,EAAE;EACvG,AAAI,MAAmB,KAAK,KAAK,EAAe,GAAgB,EAAe,KAC7E,IAAgB,GAChB,IAAiB;GAEnB,EACK;GACN,oBAAoB,EACnB,KAAsC,mBAAQ,MAAY;CAC5D,IAAI,IAAgB,IAChB,IAAc;CAQlB,OAPA,EAAQ,SAAS,MAAW;EAC1B,IAAM,IAAiB,EAAU,IAAI,EAAO,CAAC;EAC7C,AAAI,KAAkB,MACpB,IAAgB,GAChB,IAAc;GAEhB,EACK,KAAiB,KAAK;GAC5B,sBAAsB,EACrB,KAAmC,mBAAQ,GAAY,GAAS,MAAgB;CAClF,IAAI,IAAS,GACT,IAAc,GACZ,IAAQ,EAAE;CAkBhB,AAjBA,EAAW,SAAS,MAAQ;EAC1B,IAAM,IAAU,EAAQ,IAAI,EAAI;EAChC,IAAI,CAAC,GACH,MAAU,MAAM,4BAA4B,IAAM;EAQpD,AANI,EAAQ,QAAQ,UAClB,IAAS,GAAwB,EAAQ,EACzC,IAAc,KAAK,IAAI,GAAQ,EAAY,IAE3C,EAAM,KAAK,EAAQ,EAErB,GAAkB,GAAS,EAAO;GAClC,EACF,IAAS,GACT,EAAM,SAAS,MAAY;EACzB,GAAgB,GAAS,GAAQ,EAAY;GAC7C,EACF,EAAW,SAAS,MAAQ;EAC1B,IAAM,IAAU,EAAQ,IAAI,EAAI;EAChC,IAAI,GAAS,QAAQ,QAAQ;GAC3B,IAAM,IAAgB,GAAoB,EAAQ,QAAQ;GAE1D,AADA,IAAS,EAAU,IAAI,EAAc,CAAC,IAAI,GACtC,KAAU,MACZ,IAAc;GAEhB,IAAM,IAAI,EAAU,IAAI,EAAQ,OAAO,CAAC,KAClC,IAAI,IAAS;GACnB,EAAU,IAAI,EAAQ,IAAI;IAAE;IAAG;IAAG,CAAC;;GAErC;GACD,mBAAmB,EAClB,KAAuC,mBAAQ,MAAY;CAC7D,IAAM,IAAgB,EAAkB,EAAQ,QAAQ,QAAQ,MAAM,MAAM,KAAK,CAAC;CAClF,IAAI,CAAC,GACH,MAAU,MAAM,uCAAuC,EAAQ,KAAK;CAEtE,IAAM,IAAmB,EAAU,IAAI,EAAc,EAAE;CACvD,IAAI,MAAqB,KAAK,GAC5B,MAAU,MAAM,gDAAgD,EAAQ,KAAK;CAE/E,OAAO;GACN,uBAAuB,EACtB,KAA0C,mBAAQ,MAC3B,GAAqB,EACvB,GAAG,GACzB,0BAA0B,EACzB,KAAoC,mBAAQ,GAAS,MAAW;CAClE,IAAM,IAAU,EAAU,IAAI,EAAQ,OAAO;CAC7C,IAAI,CAAC,GACH,MAAU,MAAM,+BAA+B,EAAQ,KAAK;CAE9D,IAAM,IAAI,EAAQ,KACZ,IAAI,IAAS;CAEnB,OADA,EAAU,IAAI,EAAQ,IAAI;EAAE;EAAG;EAAG,CAAC,EAC5B;EAAE;EAAG;EAAG;GACd,oBAAoB,EACnB,KAAkC,mBAAQ,GAAS,GAAQ,MAAgB;CAC7E,IAAM,IAAU,EAAU,IAAI,EAAQ,OAAO;CAC7C,IAAI,CAAC,GACH,MAAU,MAAM,+BAA+B,EAAQ,KAAK;CAE9D,IAAM,IAAI,IAAS,GACb,IAAI,EAAQ;CAClB,EAAU,IAAI,EAAQ,IAAI;EAAE;EAAG;EAAG,CAAC;GAClC,kBAAkB,EACjB,KAAmC,mBAAQ,GAAU,GAAS,GAAgB,GAAW,GAAa,MAAqB;CAC7H,IAAM,EAAE,aAAU,GAAY,EACxB,IAAmB,EAAsB,IAAI,KAAS,GAAG,EACzD,IAAgB,EAAa,IAAI,KAAS,GAAG,EAC7C,IAAS,GAAY,IAAI,KAAS,GAAG;CAC3C,IAAI,MAAqB,EAAW,WAKlC,AAJA,EAAS,OAAO,OAAO,CAAC,KAAK,KAAK,EAAe,IAAI,MAAM,IAAmB,IAAI,GAAG,CAAC,KAAK,KAAK,EAAe,IAAI,MAAM,IAAmB,IAAI,GAAG,CAAC,KAAK,SAAS,IAAmB,KAAK,GAAG,CAAC,KAAK,UAAU,IAAmB,KAAK,GAAG,CAAC,KACvO,SACA,UAAU,EAAQ,GAAG,mBAAmB,EAAe,GAAa,GAAmB,EAAc,CAAC,GAAG,EAAU,QACpH,EACD,EAAS,OAAO,OAAO,CAAC,KAAK,KAAK,EAAe,IAAI,KAAK,IAAmB,IAAI,GAAG,CAAC,KAAK,KAAK,EAAe,IAAI,KAAK,IAAmB,IAAI,GAAG,CAAC,KAAK,SAAS,IAAmB,IAAI,GAAG,CAAC,KAAK,UAAU,IAAmB,IAAI,GAAG,CAAC,KACnO,SACA,UAAU,EAAQ,GAAG,SAAS,EAAe,GAAa,GAAmB,EAAc,CAAC,GAAG,EAAU,QAC1G;MACI,IAAI,MAAqB,EAAW,aAKzC,AAJA,EAAS,OAAO,SAAS,CAAC,KAAK,MAAM,EAAe,EAAE,CAAC,KAAK,MAAM,EAAe,EAAE,CAAC,KAAK,KAAK,IAAmB,IAAI,GAAG,CAAC,KAAK,SAAS,UAAU,EAAQ,GAAG,GAAG,IAAY,EAC3K,EAAS,OAAO,SAAS,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,KAAK,IAAmB,MAAM,KAAK,CAAC,KAAK,QAAQ,IAAS,YAAY,OAAO,CAAC,KAAK,SAAS,UAAU,EAAQ,GAAG,GAAG,IAAY,EACjO,EAAS,OAAO,SAAS,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,KAAK,IAAmB,MAAM,KAAK,CAAC,KAAK,QAAQ,IAAS,YAAY,OAAO,CAAC,KAAK,SAAS,UAAU,EAAQ,GAAG,GAAG,IAAY,EACjO,EAAS,OAAO,OAAO,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,MAAM,EAAe,EAAE,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,UAAU,IAAS,YAAY,OAAO,CAAC,KAAK,SAAS,UAAU,EAAQ,GAAG,GAAG,IAAY,EACtP,EAAS,OAAO,OAAO,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,MAAM,EAAe,EAAE,CAAC,KAAK,MAAM,EAAe,IAAI,EAAE,CAAC,KAAK,UAAU,IAAS,YAAY,OAAO,CAAC,KAAK,SAAS,UAAU,EAAQ,GAAG,GAAG,IAAY;MACjP;EACL,IAAM,IAAS,EAAS,OAAO,SAAS;EAQxC,IAPA,EAAO,KAAK,MAAM,EAAe,EAAE,EACnC,EAAO,KAAK,MAAM,EAAe,EAAE,EACnC,EAAO,KAAK,KAAK,IAAmB,IAAI,GAAG,EAC3C,EAAO,KACL,SACA,UAAU,EAAQ,GAAG,SAAS,EAAe,GAAa,GAAmB,EAAc,GAC5F,EACG,MAAqB,EAAW,OAAO;GACzC,IAAM,IAAU,EAAS,OAAO,SAAS;GAIzC,AAHA,EAAQ,KAAK,MAAM,EAAe,EAAE,EACpC,EAAQ,KAAK,MAAM,EAAe,EAAE,EACpC,EAAQ,KAAK,KAAK,IAAmB,IAAI,EAAE,EAC3C,EAAQ,KACN,SACA,UAAU,EAAU,GAAG,EAAQ,GAAG,SAAS,EAAe,GAAa,GAAmB,EAAc,GACzG;;EAEH,IAAI,MAAqB,EAAW,SAAS;GAC3C,IAAM,IAAQ,EAAS,OAAO,OAAO,EAC/B,IAAa,IAAmB,IAAI;GAC1C,EAAM,KACJ,KACA,KAAK,EAAe,IAAI,EAAW,GAAG,EAAe,IAAI,EAAW,GAAG,EAAe,IAAI,EAAW,GAAG,EAAe,IAAI,EAAW,GAAG,EAAe,IAAI,EAAW,GAAG,EAAe,IAAI,EAAW,GAAG,EAAe,IAAI,EAAW,GAAG,EAAe,IAAI,IAChQ,CAAC,KACA,SACA,UAAU,EAAU,GAAG,EAAQ,GAAG,SAAS,EAAe,GAAa,GAAmB,EAAc,GACzG;;;GAGJ,mBAAmB,EAClB,KAAkC,mBAAQ,GAAS,GAAS,GAAgB,GAAK,MAAmB;CACtG,IAAI,EAAQ,SAAS,EAAW,gBAAgB,EAAQ,YAAY,EAAQ,SAAS,EAAW,SAAS,EAAQ,SAAS,EAAW,UAAU,EAAe,iBAAiB;EAC7K,IAAM,IAAU,EAAQ,OAAO,IAAI,EAC7B,IAAW,EAAQ,OAAO,OAAO,CAAC,KAAK,SAAS,mBAAmB,EACnE,IAAO,EAAQ,OAAO,OAAO,CAAC,KAAK,KAAK,EAAI,CAAC,KAAK,KAAK,EAAe,IAAI,GAAG,CAAC,KAAK,SAAS,eAAe,CAAC,KAAK,EAAQ,GAAG,EAC5H,IAAO,EAAK,MAAM,EAAE,SAAS;EACnC,IAAI,MACF,EAAS,KAAK,KAAK,EAAe,gBAAgB,EAAK,QAAQ,IAAI,EAAG,CAAC,KAAK,KAAK,EAAe,IAAI,KAAK,CAAC,KAAK,SAAS,EAAK,QAAQ,IAAI,EAAG,CAAC,KAAK,UAAU,EAAK,SAAS,IAAI,EAAG,EAC7K,MAAQ,QAAQ,MAAQ,QAC1B,EAAS,KAAK,KAAK,EAAe,KAAK,EAAK,QAAQ,IAAI,IAAK,GAAG,CAAC,KAAK,KAAK,EAAe,IAAI,GAAG,EACjG,EAAK,KAAK,KAAK,EAAe,KAAK,EAAK,QAAQ,IAAI,GAAI,CAAC,KAAK,KAAK,EAAe,IAAI,EAAK,SAAS,GAAG,IAEvG,EAAK,KAAK,KAAK,EAAe,gBAAgB,EAAK,QAAQ,EAAE,EAE3D,EAAe,oBACjB,IAAI,MAAQ,QAAQ,MAAQ,MAK1B,AAJA,EAAK,KACH,aACA,iBAAiB,EAAe,IAAI,OAAO,EAAe,IAAI,IAC/D,EACD,EAAS,KACP,aACA,iBAAiB,EAAe,IAAI,OAAO,EAAe,IAAI,IAC/D;OACI;GACL,IAAM,IAAM,QAAQ,EAAK,QAAQ,MAAM,KAAK,KACtC,IAAM,KAAK,EAAK,QAAQ,KAAK;GACnC,EAAQ,KACN,aACA,eAAe,IAAM,OAAO,IAAM,mBAAmB,IAAM,OAAO,EAAe,IAAI,IACtF;;;GAKR,kBAAkB,EACjB,KAAiC,mBAAQ,GAAS,GAAS,GAAgB,MAAQ;CACrF,IAAI,EAAQ,KAAK,SAAS,GAAG;EAC3B,IAAI,IAAU,GACV,IAAkB,GAClB,IAAmB,GACjB,IAAc,EAAE;EACtB,KAAK,IAAM,KAAY,EAAQ,KAAK,SAAS,EAAE;GAC7C,IAAM,IAAO,EAAQ,OAAO,UAAU,EAChC,IAAO,EAAQ,OAAO,SAAS,EAC/B,IAAM,EAAQ,OAAO,OAAO,CAAC,KAAK,KAAK,EAAe,IAAI,KAAK,EAAQ,CAAC,KAAK,SAAS,YAAY,CAAC,KAAK,EAAS,EACjH,IAAU,EAAI,MAAM,EAAE,SAAS;GACrC,IAAI,CAAC,GACH,MAAU,MAAM,qBAAqB;GAWvC,AATA,IAAkB,KAAK,IAAI,GAAiB,EAAQ,MAAM,EAC1D,IAAmB,KAAK,IAAI,GAAkB,EAAQ,OAAO,EAC7D,EAAI,KAAK,KAAK,EAAe,gBAAgB,EAAQ,QAAQ,EAAE,EAC/D,EAAY,KAAK;IACf;IACA;IACA;IACA;IACD,CAAC,EACF,KAAW;;EAEb,KAAK,IAAM,EAAE,QAAK,SAAM,SAAM,SAAS,OAAc,GAAa;GAChE,IAAM,IAAK,IAAmB,GACxB,IAAK,EAAe,IAAI,OAAO;GAYrC,IAXA,EAAK,KAAK,SAAS,gBAAgB,CAAC,KAClC,UACA;QACA,IAAM,IAAkB,IAAI,IAAK,EAAE,GAAG,IAAK,EAAG;QAC9C,IAAM,IAAkB,IAAI,IAAK,EAAE,GAAG,IAAK,EAAG;QAC9C,EAAe,gBAAgB,IAAkB,IAAI,EAAG,GAAG,IAAK,IAAK,EAAG;QACxE,EAAe,gBAAgB,IAAkB,IAAI,EAAG,GAAG,IAAK,IAAK,EAAG;QACxE,EAAe,gBAAgB,IAAkB,IAAI,EAAG,GAAG,IAAK,IAAK,EAAG;QACxE,EAAe,gBAAgB,IAAkB,IAAI,EAAG,GAAG,IAAK,IAAK,IACtE,EACD,EAAK,KAAK,MAAM,EAAG,CAAC,KAAK,MAAM,IAAM,IAAkB,IAAI,IAAK,EAAE,CAAC,KAAK,KAAK,IAAI,CAAC,KAAK,SAAS,WAAW,EACvG,MAAQ,QAAQ,MAAQ,MAAM;IAChC,IAAM,IAAU,IAAM;IAYtB,AAXA,EAAK,KAAK,SAAS,gBAAgB,CAAC,KAClC,UACA;UACA,EAAe,EAAE,GAAG,IAAU,EAAE;UAChC,EAAe,EAAE,GAAG,IAAU,EAAE;UAChC,EAAe,IAAI,EAAc,GAAG,IAAU,IAAK,EAAE;UACrD,EAAe,IAAI,IAAgB,IAAkB,EAAE,GAAG,IAAU,IAAK,EAAE;UAC3E,EAAe,IAAI,IAAgB,IAAkB,EAAE,GAAG,IAAU,IAAK,EAAE;UAC3E,EAAe,IAAI,EAAc,GAAG,IAAU,IAAK,IACpD,CAAC,KAAK,aAAa,iCAAiC,EAAe,IAAI,MAAM,IAAM,IAAI,EACxF,EAAK,KAAK,MAAM,EAAe,IAAI,IAAK,EAAE,CAAC,KAAK,MAAM,EAAQ,CAAC,KAAK,aAAa,iCAAiC,EAAe,IAAI,MAAM,IAAM,IAAI,EACrJ,EAAI,KAAK,KAAK,EAAe,IAAI,EAAE,CAAC,KAAK,KAAK,IAAU,EAAE,CAAC,KAAK,aAAa,iCAAiC,EAAe,IAAI,MAAM,IAAM,IAAI;;;;GAItJ,iBAAiB,EAChB,KAAqC,mBAAQ,MAAY;CAE3D,QADyB,EAAQ,cAAc,EAAQ,MACvD;EACE,KAAK,EAAW,QACd,OAAO;EACT,KAAK,EAAW,SACd,OAAO;EACT,KAAK,EAAW,WACd,OAAO;EACT,KAAK,EAAW,OACd,OAAO;EACT,KAAK,EAAW,aACd,OAAO;EACT,SACE,OAAO;;GAEV,qBAAqB,EACpB,KAAoC,mBAAQ,GAAS,GAAM,GAAK,MAAe;CACjF,IAAM,IAAwB;EAAE,GAAG;EAAG,GAAG;EAAG;CAC5C,IAAI,EAAQ,QAAQ,SAAS,GAAG;EAC9B,IAAM,IAAgB,EAAkB,EAAQ,QAAQ;EACxD,IAAI,GAAe;GACjB,IAAM,IAAiB,EAAW,IAAI,EAAc,IAAI;GAOtD,OANE,MAAS,OACJ,EAAe,IAAI,IACjB,MAAS,QACM,EAAW,IAAI,EAAQ,GAAG,IAAI,GAC/B,IAAI,IAEpB,EAAe,IAAI;;QAI9B,IAAI,MAAS,MACX,OAAO;MACF,IAAI,MAAS,MAElB,QADwB,EAAW,IAAI,EAAQ,GAAG,IAAI,GAC/B,IAAI;MAE3B,OAAO;CAGX,OAAO;GACN,oBAAoB,EACnB,KAAoC,mBAAQ,GAAS,GAAK,MAAsB;CAClF,IAAM,IAAgB,MAAQ,QAAQ,IAAoB,IAAM,IAAM,GAChE,IAAU,EAAU,IAAI,EAAQ,OAAO,EAAE,KACzC,IAAI,MAAQ,QAAQ,MAAQ,OAAO,EAAU,IAAI,EAAQ,OAAO,EAAE,MAAM;CAC9E,IAAI,MAAM,KAAK,KAAK,MAAY,KAAK,GACnC,MAAU,MAAM,sCAAsC,EAAQ,KAAK;CAErE,IAAM,IAAmB,EAAsB,IAAI,GAAY,CAAC,SAAS,GAAG;CAE5E,OAAO;EAAE;EAAG,GADF,MAAQ,QAAQ,MAAQ,OAAO,IAAgB,KAAW,IAAmB,IAA+B,IAAI,IAAI;EAC/G;EAAe;GAC7B,oBAAoB,EACnB,IAA8B,mBAAQ,GAAK,GAAS,GAAa,MAAmB;CACtF,IAAM,IAAW,EAAI,OAAO,IAAI,CAAC,KAAK,SAAS,iBAAiB,EAC1D,IAAU,EAAI,OAAO,IAAI,CAAC,KAAK,SAAS,gBAAgB,EAC1D,IAAM,MAAQ,QAAQ,MAAQ,OAAO,IAAa,GAChD,IAAO,CAAC,GAAG,EAAQ,MAAM,CAAC,EAC1B,IAAoB,EAAe,mBAAmB,IACtD,IAA2B,mBAAQ,GAAG,MAAM;EAChD,IAAM,IAAO,EAAQ,IAAI,EAAE,EAAE,KACvB,IAAO,EAAQ,IAAI,EAAE,EAAE;EAC7B,OAAO,MAAS,KAAK,KAAK,MAAS,KAAK,IAAI,IAAO,IAAO;IACzD,WAAW,EACV,IAAa,EAAK,KAAK,EAAS;CAOpC,AANI,MAAQ,SACN,KACF,GAAiB,GAAY,GAAS,EAAI,EAE5C,IAAa,EAAW,SAAS,GAEnC,EAAW,SAAS,MAAQ;EAC1B,IAAM,IAAU,EAAQ,IAAI,EAAI;EAChC,IAAI,CAAC,GACH,MAAU,MAAM,4BAA4B,IAAM;EAEpD,AAAI,MACF,IAAM,GAAkB,GAAS,GAAK,GAAK,EAAU;EAEvD,IAAM,IAAiB,GAAkB,GAAS,GAAK,EAAkB;EACzE,IAAI,GAAa;GACf,IAAM,IAAY,GAAmB,EAAQ,EACvC,IAAmB,EAAQ,cAAc,EAAQ;GAIvD,AAFA,GAAiB,GAAU,GAAS,GAAgB,GADhC,EAAU,IAAI,EAAQ,OAAO,EAAE,SAAS,GACgB,EAAiB,EAC7F,GAAgB,GAAS,GAAS,GAAgB,GAAK,EAAe,EACtE,GAAe,GAAS,GAAS,GAAgB,EAAI;;EAQvD,AANI,MAAQ,QAAQ,MAAQ,OAC1B,EAAU,IAAI,EAAQ,IAAI;GAAE,GAAG,EAAe;GAAG,GAAG,EAAe;GAAe,CAAC,GAEnF,EAAU,IAAI,EAAQ,IAAI;GAAE,GAAG,EAAe;GAAe,GAAG,EAAe;GAAG,CAAC,EAErF,IAAM,MAAQ,QAAQ,IAAoB,IAAM,IAAc,IAAM,IAAc,GAC9E,IAAM,MACR,IAAS;GAEX;GACD,cAAc,EACb,KAAqC,mBAAQ,GAAS,GAAS,GAAI,GAAI,MAAe;CAExF,IAAM,KADoB,MAAQ,QAAQ,MAAQ,OAAO,EAAG,IAAI,EAAG,IAAI,EAAG,IAAI,EAAG,KACpC,EAAQ,SAAS,EAAQ,QAChE,IAAuC,mBAAQ,MAAM,EAAE,WAAW,GAAkB,uBAAuB,EAC3G,IAAmC,mBAAQ,MAAM,EAAE,MAAM,EAAQ,OAAO,EAAE,MAAM,EAAQ,KAAK,mBAAmB;CACtH,OAAO,CAAC,GAAG,EAAW,QAAQ,CAAC,CAAC,MAAM,MAC7B,EAAiB,EAAQ,IAAI,EAAqB,EAAQ,CACjE;GACD,qBAAqB,EACpB,IAA2B,mBAAQ,GAAI,GAAI,IAAQ,MAAM;CAC3D,IAAM,IAAY,IAAK,KAAK,IAAI,IAAK,EAAG,GAAG;CAU3C,OATI,IAAQ,IACH,IAEE,EAAM,OAAO,MAAS,KAAK,IAAI,IAAO,EAAU,IAAI,GACzD,IACJ,EAAM,KAAK,EAAU,EACd,KAGF,EAAS,GAAI,IADP,KAAK,IAAI,IAAK,EACE,GAAG,GAAG,IAAQ,EAAE;GAC5C,WAAW,EACV,KAA4B,mBAAQ,GAAK,GAAS,GAAS,MAAe;CAC5E,IAAM,EAAE,OAAO,MAAe,GAAY,EACpC,IAAgB,EAAa,IAAI,KAAc,GAAG,EAClD,IAAK,EAAU,IAAI,EAAQ,GAAG,EAC9B,IAAK,EAAU,IAAI,EAAQ,GAAG;CACpC,IAAI,MAAO,KAAK,KAAK,MAAO,KAAK,GAC/B,MAAU,MAAM,0CAA0C,EAAQ,GAAG,OAAO,EAAQ,KAAK;CAE3F,IAAM,IAAsB,GAAmB,GAAS,GAAS,GAAI,GAAI,EAAW,EAChF,IAAM,IACN,IAAO,IACP,IAAS,GACT,IAAS,GACT,IAAgB,EAAU,IAAI,EAAQ,OAAO,EAAE;CACnD,AAAI,EAAQ,SAAS,EAAW,SAAS,EAAQ,OAAO,EAAQ,QAAQ,OACtE,IAAgB,EAAU,IAAI,EAAQ,OAAO,EAAE;CAEjD,IAAI;CACJ,IAAI,GAAqB;EAIvB,AAHA,IAAM,qBACN,IAAO,qBACP,IAAS,IACT,IAAS;EACT,IAAM,IAAQ,EAAG,IAAI,EAAG,IAAI,EAAS,EAAG,GAAG,EAAG,EAAE,GAAG,EAAS,EAAG,GAAG,EAAG,EAAE,EACjE,IAAQ,EAAG,IAAI,EAAG,IAAI,EAAS,EAAG,GAAG,EAAG,EAAE,GAAG,EAAS,EAAG,GAAG,EAAG,EAAE;EACvE,AAAI,MAAQ,OACN,EAAG,IAAI,EAAG,IACZ,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,IAAQ,EAAO,GAAG,EAAG,EAAE,GAAG,EAAK,GAAG,EAAM,GAAG,EAAG,IAAI,EAAO,KAAK,EAAM,GAAG,EAAG,IAAI,EAAO,GAAG,EAAI,GAAG,IAAQ,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,OAEvK,IAAgB,EAAU,IAAI,EAAQ,OAAO,EAAE,OAC/C,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,IAAQ,EAAO,GAAG,EAAG,EAAE,GAAG,EAAI,GAAG,EAAM,GAAG,EAAG,IAAI,EAAO,KAAK,EAAM,GAAG,EAAG,IAAI,EAAO,GAAG,EAAK,GAAG,IAAQ,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,OAEhK,MAAQ,OACb,EAAG,IAAI,EAAG,IACZ,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,IAAQ,EAAO,GAAG,EAAG,EAAE,GAAG,EAAI,GAAG,EAAM,GAAG,EAAG,IAAI,EAAO,KAAK,EAAM,GAAG,EAAG,IAAI,EAAO,GAAG,EAAK,GAAG,IAAQ,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,OAEvK,IAAgB,EAAU,IAAI,EAAQ,OAAO,EAAE,OAC/C,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,IAAQ,EAAO,GAAG,EAAG,EAAE,GAAG,EAAK,GAAG,EAAM,GAAG,EAAG,IAAI,EAAO,KAAK,EAAM,GAAG,EAAG,IAAI,EAAO,GAAG,EAAI,GAAG,IAAQ,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,OAGrK,EAAG,IAAI,EAAG,IACZ,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,IAAQ,EAAO,GAAG,EAAI,GAAG,EAAG,IAAI,EAAO,GAAG,EAAM,KAAK,EAAG,IAAI,EAAO,GAAG,EAAM,GAAG,EAAK,GAAG,EAAG,EAAE,GAAG,IAAQ,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG,OAEvK,IAAgB,EAAU,IAAI,EAAQ,OAAO,EAAE,OAC/C,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,IAAQ,EAAO,GAAG,EAAK,GAAG,EAAG,IAAI,EAAO,GAAG,EAAM,KAAK,EAAG,IAAI,EAAO,GAAG,EAAM,GAAG,EAAI,GAAG,EAAG,EAAE,GAAG,IAAQ,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG;QAQ3K,AAJA,IAAM,qBACN,IAAO,qBACP,IAAS,IACT,IAAS,IACL,MAAQ,QACN,EAAG,IAAI,EAAG,MACZ,AAGE,IAHE,EAAQ,SAAS,EAAW,SAAS,EAAQ,OAAO,EAAQ,QAAQ,KAC5D,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,GAAG,EAAI,GAAG,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,MAE7F,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,GAAG,EAAK,GAAG,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG,MAGxG,EAAG,IAAI,EAAG,MACZ,IAAM,qBACN,IAAO,qBACP,IAAS,IACT,IAAS,IACT,AAGE,IAHE,EAAQ,SAAS,EAAW,SAAS,EAAQ,OAAO,EAAQ,QAAQ,KAC5D,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,GAAG,EAAK,GAAG,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,MAE9F,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,GAAG,EAAI,GAAG,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG,MAGvG,EAAG,MAAM,EAAG,MACd,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,QAErC,MAAQ,QACb,EAAG,IAAI,EAAG,MACZ,AAGE,IAHE,EAAQ,SAAS,EAAW,SAAS,EAAQ,OAAO,EAAQ,QAAQ,KAC5D,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,GAAG,EAAK,GAAG,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,MAE9F,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,GAAG,EAAI,GAAG,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG,MAGvG,EAAG,IAAI,EAAG,MACZ,IAAM,qBACN,IAAO,qBACP,IAAS,IACT,IAAS,IACT,AAGE,IAHE,EAAQ,SAAS,EAAW,SAAS,EAAQ,OAAO,EAAQ,QAAQ,KAC5D,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,GAAG,EAAI,GAAG,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,MAE7F,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,GAAG,EAAK,GAAG,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG,MAGxG,EAAG,MAAM,EAAG,MACd,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,SAG1C,EAAG,IAAI,EAAG,MACZ,AAGE,IAHE,EAAQ,SAAS,EAAW,SAAS,EAAQ,OAAO,EAAQ,QAAQ,KAC5D,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,GAAG,EAAK,GAAG,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG,MAE9F,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,GAAG,EAAI,GAAG,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,MAGvG,EAAG,IAAI,EAAG,MACZ,AAGE,IAHE,EAAQ,SAAS,EAAW,SAAS,EAAQ,OAAO,EAAQ,QAAQ,KAC5D,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,GAAG,EAAI,GAAG,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,KAAK,EAAG,EAAE,GAAG,EAAG,MAE7F,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,IAAI,EAAO,GAAG,EAAK,GAAG,EAAG,IAAI,EAAO,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG,MAGxG,EAAG,MAAM,EAAG,MACd,IAAU,KAAK,EAAG,EAAE,GAAG,EAAG,EAAE,KAAK,EAAG,EAAE,GAAG,EAAG;CAIlD,IAAI,MAAY,KAAK,GACnB,MAAU,MAAM,4BAA4B;CAE9C,EAAI,OAAO,OAAO,CAAC,KAAK,KAAK,EAAQ,CAAC,KACpC,SACA,gBAAgB,EAAe,GAAe,GAAmB,EAAc,CAChF;GACA,YAAY,EACX,KAA6B,mBAAQ,GAAK,MAAY;CACxD,IAAM,IAAU,EAAI,OAAO,IAAI,CAAC,KAAK,SAAS,gBAAgB;CAC9D,CAAC,GAAG,EAAQ,MAAM,CAAC,CAAC,SAAS,MAAQ;EACnC,IAAM,IAAU,EAAQ,IAAI,EAAI;EAChC,AAAI,EAAQ,WAAW,EAAQ,QAAQ,SAAS,KAC9C,EAAQ,QAAQ,SAAS,MAAW;GAClC,GAAU,GAAS,EAAQ,IAAI,EAAO,EAAE,GAAS,EAAQ;IACzD;GAEJ;GACD,aAAa,EACZ,KAA+B,mBAAQ,GAAK,GAAU,GAAgB,MAAO;CAC/E,IAAM,EAAE,SAAM,UAAO,sBAAmB,GAAY,EAC9C,EAAE,eAAY,mBAAmB,MAAoB,GACrD,IAAmB,EAAsB,IAAI,KAAS,GAAG,EACzD,IAAgB,EAAa,IAAI,KAAS,GAAG,EAC7C,IAAI,EAAI,OAAO,IAAI;CACzB,EAAS,SAAS,GAAS,MAAU;EACnC,IAAM,IAAsB,EAC1B,GACA,IAAmB,IAAkB,GACrC,EACD,EACK,IAAM,EAAU,IAAI,EAAQ,KAAK,EAAE;EACzC,IAAI,MAAQ,KAAK,GACf,MAAU,MAAM,iCAAiC,EAAQ,OAAO;EAElE,IAAM,IAAS,MAAQ,QAAQ,MAAQ,OAAO,IAAM,IAAmB,IAAM,IAA+B,IAAI,IAAI,IAAM,GACpH,IAAO,EAAE,OAAO,OAAO;EAiB7B,AAhBA,EAAK,KAAK,MAAM,EAAE,EAClB,EAAK,KAAK,MAAM,EAAO,EACvB,EAAK,KAAK,MAAM,EAAO,EACvB,EAAK,KAAK,MAAM,EAAO,EACvB,EAAK,KAAK,SAAS,kBAAkB,EAAoB,EACrD,MAAQ,QACV,EAAK,KAAK,MAAM,EAAW,EAC3B,EAAK,KAAK,MAAM,EAAI,EACpB,EAAK,KAAK,MAAM,EAAO,EACvB,EAAK,KAAK,MAAM,EAAI,IACX,MAAQ,SACjB,EAAK,KAAK,MAAM,EAAO,EACvB,EAAK,KAAK,MAAM,EAAI,EACpB,EAAK,KAAK,MAAM,EAAW,EAC3B,EAAK,KAAK,MAAM,EAAI,GAEtB,EAAM,KAAK,EAAO;EAClB,IAAM,IAAO,EAAQ,MACf,IAAe,EAAS,EAAK,EAC7B,IAAM,EAAE,OAAO,OAAO,EAEtB,IADc,EAAE,OAAO,IAAI,CAAC,KAAK,SAAS,cACvB,CAAC,OAAO,IAAI,CAAC,KAAK,SAAS,uBAAuB,EAAoB;EAC/F,EAAM,MAAM,CAAC,YAAY,EAAa;EACtC,IAAM,IAAO,EAAa,SAAS,EAC7B,IAAe,IAAmB,IAAI,GACtC,IAAgB,IAAmB,KAAK,GACxC,IAAgB,IAAmB,IAA+B;EAYxE,AAXI,MAAS,SACX,EAAI,KAAK,aAAa,MAAM,EAE9B,EAAI,KAAK,SAAS,yBAAyB,EAAoB,CAAC,KAC9D,SACA,MAAS,QAAQ,UAAU,IAAmB,QAAQ,EAAG,iBAAiB,MAAe,GAC1F,CAAC,KAAK,MAAM,EAAa,CAAC,KAAK,MAAM,EAAa,CAAC,KAAK,KAAK,CAAC,EAAK,QAAQ,KAAK,EAAe,sBAAsB,KAAO,KAAK,GAAG,CAAC,KAAK,KAAK,CAAC,EAAK,SAAS,IAAI,GAAG,CAAC,KAAK,SAAS,EAAK,QAAQ,KAAK,EAAc,CAAC,KAAK,UAAU,EAAK,SAAS,IAAI,EAAc,EACrQ,EAAM,KACJ,aACA,gBAAgB,CAAC,EAAK,QAAQ,MAAM,EAAe,sBAAsB,KAAO,KAAK,KAAK,IAAgB,KAAK,QAAQ,IAAS,EAAK,SAAS,IAAI,KAAK,IACxJ,EACG,MAAQ,QACV,EAAI,KAAK,KAAK,IAAM,EAAK,QAAQ,IAAI,GAAG,CAAC,KAAK,KAAK,EAAE,EACrD,EAAM,KAAK,aAAa,gBAAgB,IAAM,EAAK,QAAQ,IAAI,KAAK,OAAO,EACvE,MACF,EAAI,KAAK,aAAa,aAAa,CAAC,IAAgB,IAAI,EAAE,IAAI,CAAC,IAAgB,GAAG,GAAG,EACrF,EAAM,KACJ,aACA,gBAAgB,IAAM,EAAK,QAAQ,IAAI,KAAK,QAAQ,CAAC,IAAgB,IAAI,KAAK,IAC/E,KAEM,MAAQ,QACjB,EAAI,KAAK,KAAK,IAAM,EAAK,QAAQ,IAAI,GAAG,CAAC,KAAK,KAAK,EAAO,EAC1D,EAAM,KAAK,aAAa,gBAAgB,IAAM,EAAK,QAAQ,IAAI,KAAK,OAAO,IAAS,IAAI,EACpF,MACF,EAAI,KAAK,aAAa,aAAa,CAAC,IAAgB,IAAI,EAAE,IAAI,IAAgB,GAAG,GAAG,EACpF,EAAM,KACJ,aACA,gBAAgB,IAAM,EAAK,QAAQ,IAAI,KAAK,QAAQ,IAAS,IAAgB,IAAI,KAAK,IACvF,KAGH,EAAI,KAAK,aAAa,qBAAqB,IAAS,KAAK,IAAgB,KAAK,IAAI;GAEpF;GACD,eAAe,EACd,KAAoC,kBAAO,SAAS,GAAM,GAAK,GAAO,GAAM,GAAmB;CAGjG,OAFA,EAAU,IAAI,GAAM;EAAE;EAAK;EAAO,CAAC,EACnC,KAAO,MAAM,IAAoB,KAAK,MAAM,MAAQ,QAAQ,MAAQ,OAAO,EAAK,QAAQ,IAAI,IACrF;GACN,oBAAoB,EAoDnB,KAA2B,EAC7B,MApDyB,kBAAO,SAAS,GAAK,GAAI,GAAK,GAAS;CAEhE,AADA,IAAQ,EACR,EAAI,MAAM,wBAAwB,IAAM,MAAM,OAAO,GAAI,EAAI;CAC7D,IAAM,IAAM,EAAQ;CACpB,IAAI,CAAC,EAAI,WAAW;EAClB,EAAI,MAAM,0CAA0C;EACpD;;CAEF,IAAM,IAAiB,EAAI,WAAW,EAChC,IAAoB,EAAe,qBAAqB;CAC9D,IAAiB,EAAI,YAAY;CACjC,IAAM,IAAW,EAAI,uBAAuB;CAC5C,IAAM,EAAI,cAAc;CACxB,IAAM,IAAWA,EAAO,QAAQ,EAAG,IAAI,EACjC,EAAE,SAAM,UAAO,sBAAmB,GAAY,EAC9C,EAAE,gBAAa,kBAAe,iBAAc,mBAAgB;CAClE,IAAI,GAAa;EACf,IAAM,IAAW,EAAS,OAAO,OAAO,CAAC,OAAO,iBAAiB,CAAC,KAAK,MAAM,IAAK,YAAY,CAAC,KAAK,iBAAiB,oBAAoB,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,MAAM,KAAK,CAAC,KAAK,MAAM,OAAO,CAAC,KAAK,MAAM,KAAK;EAE/M,AADA,EAAS,OAAO,OAAO,CAAC,KAAK,UAAU,KAAK,CAAC,KAAK,cAAc,EAAc,CAAC,KAAK,gBAAgB,EAAE,EACtG,EAAS,OAAO,OAAO,CAAC,KAAK,UAAU,OAAO,CAAC,KAAK,cAAc,EAAa,CAAC,KAAK,gBAAgB,EAAE;;CAEzG,AAAI,MAAS,SAAS,EAAsB,IAAI,KAAS,GAAG,IAC1D,EAAS,OAAO,OAAO,CAAC,OAAO,SAAS,CAAC,KAAK,MAAM,IAAK,eAAe,CAAC,KAAK,UAAU,OAAO,CAAC,KAAK,SAAS,OAAO,CAAC,OAAO,eAAe,CAAC,KAAK,MAAM,IAAI,CAAC,KAAK,MAAM,IAAI,CAAC,KAAK,gBAAgB,EAAE,CAAC,KAAK,iBAAiB,OAAO,CAAC,KAAK,eAAe,EAAY;CAErQ,IAAI,IAAM;CAyBV,AAxBA,EAAS,SAAS,GAAS,MAAU;EACnC,IAAM,IAAe,EAAS,EAAQ,KAAK,EACrC,IAAI,EAAS,OAAO,IAAI,EACxB,IAAc,EAAE,OAAO,IAAI,CAAC,KAAK,SAAS,cAAc,EACxD,IAAQ,EAAY,OAAO,IAAI,CAAC,KAAK,SAAS,qBAAqB;EACzE,EAAM,MAAM,EAAE,YAAY,EAAa;EACvC,IAAM,IAAO,EAAa,SAAS;EAInC,AAHA,IAAM,GAAkB,EAAQ,MAAM,GAAK,GAAO,GAAM,EAAkB,EAC1E,EAAM,QAAQ,EACd,EAAY,QAAQ,EACpB,EAAE,QAAQ;GACV,EACF,EAAY,GAAU,GAAgB,IAAO,EAAe,EACxD,EAAe,gBACjB,GAAa,GAAU,GAAU,GAAgB,EAAG,EAEtD,GAAW,GAAU,EAAe,EACpC,EAAY,GAAU,GAAgB,IAAM,EAAe,EAC3D,EAAc,YACZ,GACA,gBACA,EAAe,kBAAkB,GACjC,EAAI,iBAAiB,CACtB,EACD,EAAkB,KAAK,GAAG,GAAU,EAAe,gBAAgB,EAAe,YAAY;GAC7F,OAEG,EACL,EAiYG,IAAwB,GACxB,oBAAyC,IAAI,IAAI;CAAC;CAAS;CAAc;CAAe;CAAmB,CAAC,EAC5G,oBAAgC,IAAI,IAAI,CAAC,eAAe,mBAAmB,CAAC,EAC5E,qBAA6B,IAAI,IAAI,CAAC,OAAO,WAAW,CAAC,EACzD,qBAA+B,IAAI,IAAI;CAAC;CAAQ;CAAc;CAAoB;CAAW,CAAC,EAC9F,qBAAuC,IAAI,IAAI;CACjD;CACA;CACA;CACA;CACA;CACA;CACD,CAAC,EACE,KAAsC,mBAAQ,MAAY;CAC5D,IAAM,EAAE,aAAU,GACd,IAAW;CACf,IAAI,EAAQ,eAAe,GACzB,KAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,mBAAmB,KAC7C,KAAY;cACJ,EAAE,YAAY,EAAQ,QAAQ,gBAAgB,EAAM,4BAA4B,EAAQ,YAAY;;CAIhH,OAAO;GACN,sBAAsB,EACrB,KAA2B,mBAAQ,MAAY;CAEjD,IAAM,EAAE,UAAO,sBADA,GACyB,EAClC,EAAE,wBAAqB,GACvB,IAAmB,EAAuB,IAAI,EAAM;CAC1D,IAAI,GAAW,IAAI,EAAM,EAAE;EACzB,IAAI,IAAW;EACf,KAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,mBAAmB,KAC7C,IAAI,MAAM,GACR,KAAY;uBACG,EAAE,WAAW,EAAQ,WAAW;iBACtC,EAAE,aAAa,EAAQ,WAAW;2BACxB,EAAE,aAAa,EAAQ,WAAW,UAAU,EAAQ,WAAW;gBAC1E,EAAE,aAAa,EAAQ,WAAW;kCAChB,EAAQ,WAAW;6BACxB,EAAE,aAAa,EAAQ,WAAW;UACrD,GAAoB,EAAQ;OACzB;GACL,IAAM,IAAK,IAAI;GACf,KAAY;uBACG,EAAE,WAAW,EAAQ,mBAAmB,GAAI;iBAClD,EAAE,aAAa,EAAQ,QAAQ,GAAI,UAAU,EAAQ,QAAQ,GAAI;2BACvD,EAAE,aAAa,EAAQ,WAAW,GAAI,UAAU,EAAQ,WAAW,GAAI;gBAClF,EAAE,aAAa,EAAQ,QAAQ,GAAI;;;EAI/C,OAAO;QACF,IAAK,EAAc,IAAI,EAAM,EAc7B;EACL,IAAI,IAAW;EACf,KAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,mBAAmB,KAC7C,IAAI,MAAM,GACR,KAAY;uBACG,EAAE,WAAW,EAAQ,WAAW,IAAI,IAAmB,eAAe,EAAQ,mBAAmB,GAAG;iBAC1G,EAAE,aAAa,EAAQ,WAAW;2BACxB,EAAE,aAAa,EAAQ,WAAW,UAAU,EAAQ,QAAQ;gBACvE,EAAE,YAAY,EAAQ,QAAQ,YAAY,EAAQ,WAAW,kBAAkB,EAAQ,YAAY,IAAI,IAAmB,eAAe,EAAQ,mBAAmB,GAAG;gBACvK,EAAE,aAAa,EAAQ,WAAW;kCAChB,EAAQ,WAAW;;OAExC;GACL,IAAM,IAAa,IAAI,EAAiB;GACxC,KAAY;uBACG,EAAE,WAAW,EAAQ,WAAW,IAAI,IAAmB,eAAe,EAAQ,mBAAmB,GAAG;iBAC1G,EAAE,aAAa,EAAiB,GAAY,UAAU,EAAiB,GAAY;2BACzE,EAAE,aAAa,EAAiB,GAAY,UAAU,EAAiB,GAAY;gBAC9F,EAAE,YAAY,GAAa,IAAI,EAAM,GAAG,EAAQ,UAAU,EAAiB,GAAY,YAAY,EAAiB,GAAY,mBAAmB,EAAQ,YAAY;gBACvK,EAAE,aAAa,EAAiB,GAAY;;;EAIxD,OAAO;QArC6B;EACpC,IAAI,IAAW;EACf,KAAK,IAAI,IAAI,GAAG,IAAI,EAAQ,mBAAmB,KAC7C,KAAY;uBACK,EAAE,WAAW,EAAQ,WAAW,IAAI,IAAmB,eAAe,EAAQ,mBAAmB,GAAG;iBAC1G,EAAE,aAAa,EAAQ,WAAW;2BACxB,EAAE,aAAa,EAAQ,WAAW,UAAU,EAAQ,WAAW;gBAC1E,EAAE,YAAY,EAAQ,QAAQ,YAAY,EAAQ,WAAW,kBAAkB,EAAQ,YAAY,IAAI,IAAmB,eAAe,EAAQ,mBAAmB,GAAG;gBACvK,EAAE,aAAa,EAAQ,WAAW;kCAChB,EAAQ,WAAW;6BACxB,EAAE,aAAa,EAAQ,WAAW;;EAG3D,OAAO;;GA0BR,WAAW,EACV,KAA8B,mBAAQ,MACjC,GAAG,MAAM,KAAK,EAAE,QAAQ,EAAQ,mBAAmB,GAAG,GAAG,MAAM,EAAE,CAAC,KAAK,MAAM;CAClF,IAAM,IAAK,IAAI;CACf,OAAO;uBACY,EAAE,WAAW,EAAQ,mBAAmB,GAAI;iBAClD,EAAE,aAAa,EAAQ,QAAQ,GAAI,UAAU,EAAQ,QAAQ,GAAI;2BACvD,EAAE,aAAa,EAAQ,WAAW,GAAI,UAAU,EAAQ,WAAW,GAAI;gBAClF,EAAE,YAAY,EAAQ,QAAQ,GAAI;gBAClC,EAAE,aAAa,EAAQ,QAAQ,GAAI;;EAE/C,CAAC,KAAK,KAAK,IACZ,cAAc,EA4Db,KAAU;CACZ;CACA;CACA,UAAU;CACV,QA/D8B,mBAAQ,MAAY;EAElD,IAAM,EAAE,aADO,GACS,EAClB,IAAiB,GAAqB,IAAI,EAAM;EACtD,OAAO;;;;;;;;;;IAUL,IAAiB,GAAS,EAAQ,GAAG,GAAY,EAAQ,CAAC;;;oBAG1C,EAAQ,YAAY;cAC1B,EAAQ,mBAAmB,EAAQ,UAAU;yBAClC,IAAiB,QAAQ,IAAI;;+BAEvB,EAAQ,oBAAoB,UAAU,IAAiB,EAAQ,aAAa,EAAQ,iBAAiB,IAAI,IAAiB,eAAe,EAAQ,eAAe,KAAK,GAAG;mCACpK,EAAQ,oBAAoB,UAAU,IAAiB,gBAAgB,EAAQ,sBAAsB,aAAa,IAAiB,KAAK,GAAI;4BACnJ,EAAQ,iBAAiB,UAAU,EAAQ,cAAc;2BAC1D,IAAiB,EAAQ,UAAU,EAAQ,mBAAmB,YAAY,IAAiB,EAAQ,aAAa,EAAQ,eAAe,IAAI,IAAiB,UAAU,EAAQ,eAAe,GAAG;sBACrM,EAAQ,UAAU;;;cAG1B,IAAiB,EAAQ,UAAU,EAAQ,aAAa;YAC1D,IAAiB,EAAQ,UAAU,EAAQ,aAAa;;;cAGtD,IAAiB,EAAQ,UAAU,EAAQ,aAAa;YAC1D,IAAiB,EAAQ,UAAU,EAAQ,aAAa;oBAChD,IAAiB,EAAQ,cAAc,EAAE;;;;;cAK/C,IAAiB,EAAQ,UAAU,EAAQ,aAAa;YAC1D,IAAiB,EAAQ,UAAU,EAAQ,aAAa;;;;;oBAKhD,EAAuB,IAAI,EAAM,GAAG,EAAQ,cAAc,EAAE;;;;;;;YAOpE,EAAQ,UAAU;;;IAG3B,YAQqB;CACvB"}