@refrakt-md/editor 0.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (473) hide show
  1. package/app/dist/assets/abap-BdImnpbu.js +1 -0
  2. package/app/dist/assets/actionscript-3-CoDkCxhg.js +1 -0
  3. package/app/dist/assets/ada-bCR0ucgS.js +1 -0
  4. package/app/dist/assets/andromeeda-C4gqWexZ.js +1 -0
  5. package/app/dist/assets/angular-html-CU67Zn6k.js +1 -0
  6. package/app/dist/assets/angular-ts-BwZT4LLn.js +1 -0
  7. package/app/dist/assets/apache-Pmp26Uib.js +1 -0
  8. package/app/dist/assets/apex-D8_7TLub.js +1 -0
  9. package/app/dist/assets/apl-B4CMkyY2.js +1 -0
  10. package/app/dist/assets/apl-dKokRX4l.js +1 -0
  11. package/app/dist/assets/applescript-Co6uUVPk.js +1 -0
  12. package/app/dist/assets/ara-BRHolxvo.js +1 -0
  13. package/app/dist/assets/asciiarmor-Df11BRmG.js +1 -0
  14. package/app/dist/assets/asciidoc-Dv7Oe6Be.js +1 -0
  15. package/app/dist/assets/asm-D_Q5rh1f.js +1 -0
  16. package/app/dist/assets/asn1-EdZsLKOL.js +1 -0
  17. package/app/dist/assets/asterisk-B-8jnY81.js +1 -0
  18. package/app/dist/assets/astro-CbQHKStN.js +1 -0
  19. package/app/dist/assets/aurora-x-D-2ljcwZ.js +1 -0
  20. package/app/dist/assets/awk-DMzUqQB5.js +1 -0
  21. package/app/dist/assets/ayu-dark-CMjwMIkn.js +1 -0
  22. package/app/dist/assets/ayu-light-C47S-Tmv.js +1 -0
  23. package/app/dist/assets/ayu-mirage-CjoLj4QM.js +1 -0
  24. package/app/dist/assets/ballerina-BFfxhgS-.js +1 -0
  25. package/app/dist/assets/bat-BkioyH1T.js +1 -0
  26. package/app/dist/assets/beancount-k_qm7-4y.js +1 -0
  27. package/app/dist/assets/berry-uYugtg8r.js +1 -0
  28. package/app/dist/assets/bibtex-CHM0blh-.js +1 -0
  29. package/app/dist/assets/bicep-Bmn6On1c.js +1 -0
  30. package/app/dist/assets/blade-D4QpJJKB.js +1 -0
  31. package/app/dist/assets/brainfuck-C4LP7Hcl.js +1 -0
  32. package/app/dist/assets/bsl-BO_Y6i37.js +1 -0
  33. package/app/dist/assets/c-BIGW1oBm.js +1 -0
  34. package/app/dist/assets/c3-VCDPK7BO.js +1 -0
  35. package/app/dist/assets/cadence-Bv_4Rxtq.js +1 -0
  36. package/app/dist/assets/cairo-KRGpt6FW.js +1 -0
  37. package/app/dist/assets/catppuccin-frappe-DFWUc33u.js +1 -0
  38. package/app/dist/assets/catppuccin-latte-C9dUb6Cb.js +1 -0
  39. package/app/dist/assets/catppuccin-macchiato-DQyhUUbL.js +1 -0
  40. package/app/dist/assets/catppuccin-mocha-D87Tk5Gz.js +1 -0
  41. package/app/dist/assets/clarity-D53aC0YG.js +1 -0
  42. package/app/dist/assets/clike-B9uivgTg.js +1 -0
  43. package/app/dist/assets/clojure-BMjYHr_A.js +1 -0
  44. package/app/dist/assets/clojure-P80f7IUj.js +1 -0
  45. package/app/dist/assets/cmake-BQqOBYOt.js +1 -0
  46. package/app/dist/assets/cmake-D1j8_8rp.js +1 -0
  47. package/app/dist/assets/cobol-CWcv1MsR.js +1 -0
  48. package/app/dist/assets/cobol-nwyudZeR.js +1 -0
  49. package/app/dist/assets/codeowners-Bp6g37R7.js +1 -0
  50. package/app/dist/assets/codeql-DsOJ9woJ.js +1 -0
  51. package/app/dist/assets/coffee-Ch7k5sss.js +1 -0
  52. package/app/dist/assets/coffeescript-S37ZYGWr.js +1 -0
  53. package/app/dist/assets/common-lisp-Cg-RD9OK.js +1 -0
  54. package/app/dist/assets/commonlisp-DBKNyK5s.js +1 -0
  55. package/app/dist/assets/coq-DkFqJrB1.js +1 -0
  56. package/app/dist/assets/cpp-CofmeUqb.js +1 -0
  57. package/app/dist/assets/crystal-SjHAIU92.js +1 -0
  58. package/app/dist/assets/crystal-tKQVLTB8.js +1 -0
  59. package/app/dist/assets/csharp-COcwbKMJ.js +1 -0
  60. package/app/dist/assets/css-BnMrqG3P.js +1 -0
  61. package/app/dist/assets/css-DPfMkruS.js +1 -0
  62. package/app/dist/assets/csv-fuZLfV_i.js +1 -0
  63. package/app/dist/assets/cue-D82EKSYY.js +1 -0
  64. package/app/dist/assets/cypher-COkxafJQ.js +1 -0
  65. package/app/dist/assets/cypher-C_CwsFkJ.js +1 -0
  66. package/app/dist/assets/d-85-TOEBH.js +1 -0
  67. package/app/dist/assets/d-pRatUO7H.js +1 -0
  68. package/app/dist/assets/dark-plus-C3mMm8J8.js +1 -0
  69. package/app/dist/assets/dart-CF10PKvl.js +1 -0
  70. package/app/dist/assets/dax-CEL-wOlO.js +1 -0
  71. package/app/dist/assets/desktop-BmXAJ9_W.js +1 -0
  72. package/app/dist/assets/diff-D97Zzqfu.js +1 -0
  73. package/app/dist/assets/diff-DbItnlRl.js +1 -0
  74. package/app/dist/assets/docker-BcOcwvcX.js +1 -0
  75. package/app/dist/assets/dockerfile-BKs6k2Af.js +1 -0
  76. package/app/dist/assets/dotenv-Da5cRb03.js +1 -0
  77. package/app/dist/assets/dracula-BzJJZx-M.js +1 -0
  78. package/app/dist/assets/dracula-soft-BXkSAIEj.js +1 -0
  79. package/app/dist/assets/dream-maker-BtqSS_iP.js +1 -0
  80. package/app/dist/assets/dtd-DF_7sFjM.js +1 -0
  81. package/app/dist/assets/dylan-DwRh75JA.js +1 -0
  82. package/app/dist/assets/ebnf-CDyGwa7X.js +1 -0
  83. package/app/dist/assets/ecl-Cabwm37j.js +1 -0
  84. package/app/dist/assets/edge-BkV0erSs.js +1 -0
  85. package/app/dist/assets/eiffel-CnydiIhH.js +1 -0
  86. package/app/dist/assets/elixir-CDX3lj18.js +1 -0
  87. package/app/dist/assets/elm-DbKCFpqz.js +1 -0
  88. package/app/dist/assets/elm-vLlmbW-K.js +1 -0
  89. package/app/dist/assets/emacs-lisp-C9XAeP06.js +1 -0
  90. package/app/dist/assets/erb-CgJxNhIT.js +1 -0
  91. package/app/dist/assets/erlang-BNw1qcRV.js +1 -0
  92. package/app/dist/assets/erlang-DsQrWhSR.js +1 -0
  93. package/app/dist/assets/everforest-dark-BgDCqdQA.js +1 -0
  94. package/app/dist/assets/everforest-light-C8M2exoo.js +1 -0
  95. package/app/dist/assets/factor-kuTfRLto.js +1 -0
  96. package/app/dist/assets/fcl-Kvtd6kyn.js +1 -0
  97. package/app/dist/assets/fennel-BYunw83y.js +1 -0
  98. package/app/dist/assets/fish-BvzEVeQv.js +1 -0
  99. package/app/dist/assets/fluent-C4IJs8-o.js +1 -0
  100. package/app/dist/assets/forth-Ffai-XNe.js +1 -0
  101. package/app/dist/assets/fortran-DYz_wnZ1.js +1 -0
  102. package/app/dist/assets/fortran-fixed-form-CkoXwp7k.js +1 -0
  103. package/app/dist/assets/fortran-free-form-BxgE0vQu.js +1 -0
  104. package/app/dist/assets/fsharp-CXgrBDvD.js +1 -0
  105. package/app/dist/assets/gas-Bneqetm1.js +1 -0
  106. package/app/dist/assets/gdresource-BOOCDP_w.js +1 -0
  107. package/app/dist/assets/gdscript-C5YyOfLZ.js +1 -0
  108. package/app/dist/assets/gdshader-DkwncUOv.js +1 -0
  109. package/app/dist/assets/genie-D0YGMca9.js +1 -0
  110. package/app/dist/assets/gherkin-DyxjwDmM.js +1 -0
  111. package/app/dist/assets/gherkin-heZmZLOM.js +1 -0
  112. package/app/dist/assets/git-commit-F4YmCXRG.js +1 -0
  113. package/app/dist/assets/git-rebase-r7XF79zn.js +1 -0
  114. package/app/dist/assets/github-dark-DHJKELXO.js +1 -0
  115. package/app/dist/assets/github-dark-default-Cuk6v7N8.js +1 -0
  116. package/app/dist/assets/github-dark-dimmed-DH5Ifo-i.js +1 -0
  117. package/app/dist/assets/github-dark-high-contrast-E3gJ1_iC.js +1 -0
  118. package/app/dist/assets/github-light-DAi9KRSo.js +1 -0
  119. package/app/dist/assets/github-light-default-D7oLnXFd.js +1 -0
  120. package/app/dist/assets/github-light-high-contrast-BfjtVDDH.js +1 -0
  121. package/app/dist/assets/gleam-BspZqrRM.js +1 -0
  122. package/app/dist/assets/glimmer-js-Rg0-pVw9.js +1 -0
  123. package/app/dist/assets/glimmer-ts-U6CK756n.js +1 -0
  124. package/app/dist/assets/glsl-DplSGwfg.js +1 -0
  125. package/app/dist/assets/gn-n2N0HUVH.js +1 -0
  126. package/app/dist/assets/gnuplot-DdkO51Og.js +1 -0
  127. package/app/dist/assets/go-CxLEBnE3.js +1 -0
  128. package/app/dist/assets/graphql-ChdNCCLP.js +1 -0
  129. package/app/dist/assets/groovy-D9Dt4D0W.js +1 -0
  130. package/app/dist/assets/groovy-gcz8RCvz.js +1 -0
  131. package/app/dist/assets/gruvbox-dark-hard-CFHQjOhq.js +1 -0
  132. package/app/dist/assets/gruvbox-dark-medium-GsRaNv29.js +1 -0
  133. package/app/dist/assets/gruvbox-dark-soft-CVdnzihN.js +1 -0
  134. package/app/dist/assets/gruvbox-light-hard-CH1njM8p.js +1 -0
  135. package/app/dist/assets/gruvbox-light-medium-DRw_LuNl.js +1 -0
  136. package/app/dist/assets/gruvbox-light-soft-hJgmCMqR.js +1 -0
  137. package/app/dist/assets/hack-CaT9iCJl.js +1 -0
  138. package/app/dist/assets/haml-B8DHNrY2.js +1 -0
  139. package/app/dist/assets/handlebars-BL8al0AC.js +1 -0
  140. package/app/dist/assets/haskell-Cw1EW3IL.js +1 -0
  141. package/app/dist/assets/haskell-Df6bDoY_.js +1 -0
  142. package/app/dist/assets/haxe-CzTSHFRz.js +1 -0
  143. package/app/dist/assets/haxe-H-WmDvRZ.js +1 -0
  144. package/app/dist/assets/hcl-BWvSN4gD.js +1 -0
  145. package/app/dist/assets/hjson-D5-asLiD.js +1 -0
  146. package/app/dist/assets/hlsl-D3lLCCz7.js +1 -0
  147. package/app/dist/assets/horizon-BUw7H-hv.js +1 -0
  148. package/app/dist/assets/houston-DnULxvSX.js +1 -0
  149. package/app/dist/assets/html-GMplVEZG.js +1 -0
  150. package/app/dist/assets/html-derivative-BFtXZ54Q.js +1 -0
  151. package/app/dist/assets/http-DBlCnlav.js +1 -0
  152. package/app/dist/assets/http-jrhK8wxY.js +1 -0
  153. package/app/dist/assets/hurl-irOxFIW8.js +1 -0
  154. package/app/dist/assets/hxml-Bvhsp5Yf.js +1 -0
  155. package/app/dist/assets/hy-DFXneXwc.js +1 -0
  156. package/app/dist/assets/idl-BEugSyMb.js +1 -0
  157. package/app/dist/assets/imba-DGztddWO.js +1 -0
  158. package/app/dist/assets/index-5zX9_mJn.js +1 -0
  159. package/app/dist/assets/index-B4OhG7R9.js +1 -0
  160. package/app/dist/assets/index-B4kat0j1.js +7 -0
  161. package/app/dist/assets/index-BbFg11BX.js +1 -0
  162. package/app/dist/assets/index-BeI31aOW.js +48 -0
  163. package/app/dist/assets/index-C07W8XY7.js +1 -0
  164. package/app/dist/assets/index-CLCqkEcA.js +1 -0
  165. package/app/dist/assets/index-COgEItgI.js +1 -0
  166. package/app/dist/assets/index-Caa-a1PE.js +2 -0
  167. package/app/dist/assets/index-CvAaUCm5.js +1 -0
  168. package/app/dist/assets/index-DDqgfG5o.js +1 -0
  169. package/app/dist/assets/index-DLjiZx9h.js +1 -0
  170. package/app/dist/assets/index-DcnZ8L6Y.js +3 -0
  171. package/app/dist/assets/index-DksBloEA.js +1 -0
  172. package/app/dist/assets/index-DlrXwdpb.css +1 -0
  173. package/app/dist/assets/index-FVD-6MCq.js +1 -0
  174. package/app/dist/assets/index-IZk0Eanm.js +334 -0
  175. package/app/dist/assets/index-aSkmrFGo.js +1 -0
  176. package/app/dist/assets/index-iTcD8pV7.js +1 -0
  177. package/app/dist/assets/index-wQuJ1T-l.js +1 -0
  178. package/app/dist/assets/ini-BEwlwnbL.js +1 -0
  179. package/app/dist/assets/java-CylS5w8V.js +1 -0
  180. package/app/dist/assets/javascript-iXu5QeM3.js +1 -0
  181. package/app/dist/assets/javascript-wDzz0qaB.js +1 -0
  182. package/app/dist/assets/jinja-4LBKfQ-Z.js +1 -0
  183. package/app/dist/assets/jison-wvAkD_A8.js +1 -0
  184. package/app/dist/assets/json-Cp-IABpG.js +1 -0
  185. package/app/dist/assets/json5-C9tS-k6U.js +1 -0
  186. package/app/dist/assets/jsonc-Des-eS-w.js +1 -0
  187. package/app/dist/assets/jsonl-DcaNXYhu.js +1 -0
  188. package/app/dist/assets/jsonnet-DFQXde-d.js +1 -0
  189. package/app/dist/assets/jssm-C2t-YnRu.js +1 -0
  190. package/app/dist/assets/jsx-g9-lgVsj.js +1 -0
  191. package/app/dist/assets/julia-CxzCAyBv.js +1 -0
  192. package/app/dist/assets/julia-DuME0IfC.js +1 -0
  193. package/app/dist/assets/kanagawa-dragon-CkXjmgJE.js +1 -0
  194. package/app/dist/assets/kanagawa-lotus-CfQXZHmo.js +1 -0
  195. package/app/dist/assets/kanagawa-wave-DWedfzmr.js +1 -0
  196. package/app/dist/assets/kdl-DV7GczEv.js +1 -0
  197. package/app/dist/assets/kotlin-BdnUsdx6.js +1 -0
  198. package/app/dist/assets/kusto-DZf3V79B.js +1 -0
  199. package/app/dist/assets/laserwave-DUszq2jm.js +1 -0
  200. package/app/dist/assets/latex-DGMBWnxU.js +1 -0
  201. package/app/dist/assets/lean-BZvkOJ9d.js +1 -0
  202. package/app/dist/assets/less-B1dDrJ26.js +1 -0
  203. package/app/dist/assets/light-plus-B7mTdjB0.js +1 -0
  204. package/app/dist/assets/liquid-DYVedYrR.js +1 -0
  205. package/app/dist/assets/livescript-BwQOo05w.js +1 -0
  206. package/app/dist/assets/llvm-BtvRca6l.js +1 -0
  207. package/app/dist/assets/log-2UxHyX5q.js +1 -0
  208. package/app/dist/assets/logo-BtOb2qkB.js +1 -0
  209. package/app/dist/assets/lua-BaeVxFsk.js +1 -0
  210. package/app/dist/assets/lua-BgMRiT3U.js +1 -0
  211. package/app/dist/assets/luau-C-HG3fhB.js +1 -0
  212. package/app/dist/assets/make-CHLpvVh8.js +1 -0
  213. package/app/dist/assets/markdown-Cvjx9yec.js +1 -0
  214. package/app/dist/assets/marko-DZsq8hO1.js +1 -0
  215. package/app/dist/assets/material-theme-D5KoaKCx.js +1 -0
  216. package/app/dist/assets/material-theme-darker-BfHTSMKl.js +1 -0
  217. package/app/dist/assets/material-theme-lighter-B0m2ddpp.js +1 -0
  218. package/app/dist/assets/material-theme-ocean-CyktbL80.js +1 -0
  219. package/app/dist/assets/material-theme-palenight-Csfq5Kiy.js +1 -0
  220. package/app/dist/assets/mathematica-DTrFuWx2.js +1 -0
  221. package/app/dist/assets/matlab-D7o27uSR.js +1 -0
  222. package/app/dist/assets/mbox-CNhZ1qSd.js +1 -0
  223. package/app/dist/assets/mdc-DUICxH0z.js +1 -0
  224. package/app/dist/assets/mdx-Cmh6b_Ma.js +1 -0
  225. package/app/dist/assets/mermaid-mWjccvbQ.js +1 -0
  226. package/app/dist/assets/min-dark-CafNBF8u.js +1 -0
  227. package/app/dist/assets/min-light-CTRr51gU.js +1 -0
  228. package/app/dist/assets/mipsasm-CKIfxQSi.js +1 -0
  229. package/app/dist/assets/mirc-CjQqDB4T.js +1 -0
  230. package/app/dist/assets/mllike-CXdrOF99.js +1 -0
  231. package/app/dist/assets/modelica-Dc1JOy9r.js +1 -0
  232. package/app/dist/assets/mojo-B93PlW-d.js +1 -0
  233. package/app/dist/assets/monokai-D4h5O-jR.js +1 -0
  234. package/app/dist/assets/moonbit-Ba13S78F.js +1 -0
  235. package/app/dist/assets/move-IF9eRakj.js +1 -0
  236. package/app/dist/assets/mscgen-BA5vi2Kp.js +1 -0
  237. package/app/dist/assets/mumps-BT43cFF4.js +1 -0
  238. package/app/dist/assets/narrat-DRg8JJMk.js +1 -0
  239. package/app/dist/assets/nextflow-BrzmwbiE.js +1 -0
  240. package/app/dist/assets/nginx-BpAMiNFr.js +1 -0
  241. package/app/dist/assets/nginx-DdIZxoE0.js +1 -0
  242. package/app/dist/assets/night-owl-C39BiMTA.js +1 -0
  243. package/app/dist/assets/night-owl-light-CMTm3GFP.js +1 -0
  244. package/app/dist/assets/nim-CVrawwO9.js +1 -0
  245. package/app/dist/assets/nix-CwoSXNpI.js +1 -0
  246. package/app/dist/assets/nord-Ddv68eIx.js +1 -0
  247. package/app/dist/assets/nsis-LdVXkNf5.js +1 -0
  248. package/app/dist/assets/ntriples-BfvgReVJ.js +1 -0
  249. package/app/dist/assets/nushell-C-sUppwS.js +1 -0
  250. package/app/dist/assets/objective-c-DXmwc3jG.js +1 -0
  251. package/app/dist/assets/objective-cpp-CLxacb5B.js +1 -0
  252. package/app/dist/assets/ocaml-C0hk2d4L.js +1 -0
  253. package/app/dist/assets/octave-Ck1zUtKM.js +1 -0
  254. package/app/dist/assets/odin-BBf5iR-q.js +1 -0
  255. package/app/dist/assets/one-dark-pro-DVMEJ2y_.js +1 -0
  256. package/app/dist/assets/one-light-C3Wv6jpd.js +1 -0
  257. package/app/dist/assets/openscad-C4EeE6gA.js +1 -0
  258. package/app/dist/assets/oz-BzwKVEFT.js +1 -0
  259. package/app/dist/assets/pascal--L3eBynH.js +1 -0
  260. package/app/dist/assets/pascal-D93ZcfNL.js +1 -0
  261. package/app/dist/assets/perl-C0TMdlhV.js +1 -0
  262. package/app/dist/assets/perl-CdXCOZ3F.js +1 -0
  263. package/app/dist/assets/php-Dhbhpdrm.js +1 -0
  264. package/app/dist/assets/pig-CevX1Tat.js +1 -0
  265. package/app/dist/assets/pkl-u5AG7uiY.js +1 -0
  266. package/app/dist/assets/plastic-3e1v2bzS.js +1 -0
  267. package/app/dist/assets/plsql-ChMvpjG-.js +1 -0
  268. package/app/dist/assets/po-BTJTHyun.js +1 -0
  269. package/app/dist/assets/poimandres-CS3Unz2-.js +1 -0
  270. package/app/dist/assets/polar-C0HS_06l.js +1 -0
  271. package/app/dist/assets/postcss-CXtECtnM.js +1 -0
  272. package/app/dist/assets/powerquery-CEu0bR-o.js +1 -0
  273. package/app/dist/assets/powershell-CFHJl5sT.js +1 -0
  274. package/app/dist/assets/powershell-Dpen1YoG.js +1 -0
  275. package/app/dist/assets/prisma-Dd19v3D-.js +1 -0
  276. package/app/dist/assets/prolog-CbFg5uaA.js +1 -0
  277. package/app/dist/assets/properties-C78fOPTZ.js +1 -0
  278. package/app/dist/assets/proto-C7zT0LnQ.js +1 -0
  279. package/app/dist/assets/protobuf-ChK-085T.js +1 -0
  280. package/app/dist/assets/pug-CGlum2m_.js +1 -0
  281. package/app/dist/assets/pug-DeIclll2.js +1 -0
  282. package/app/dist/assets/puppet-BMWR74SV.js +1 -0
  283. package/app/dist/assets/puppet-DMA9R1ak.js +1 -0
  284. package/app/dist/assets/purescript-CklMAg4u.js +1 -0
  285. package/app/dist/assets/python-B6aJPvgy.js +1 -0
  286. package/app/dist/assets/python-BuPzkPfP.js +1 -0
  287. package/app/dist/assets/q-pXgVlZs6.js +1 -0
  288. package/app/dist/assets/qml-3beO22l8.js +1 -0
  289. package/app/dist/assets/qmldir-C8lEn-DE.js +1 -0
  290. package/app/dist/assets/qss-IeuSbFQv.js +1 -0
  291. package/app/dist/assets/r-B6wPVr8A.js +1 -0
  292. package/app/dist/assets/r-Dspwwk_N.js +1 -0
  293. package/app/dist/assets/racket-BqYA7rlc.js +1 -0
  294. package/app/dist/assets/raku-DXvB9xmW.js +1 -0
  295. package/app/dist/assets/razor-Uh8Bk_45.js +1 -0
  296. package/app/dist/assets/red-bN70gL4F.js +1 -0
  297. package/app/dist/assets/reg-C-SQnVFl.js +1 -0
  298. package/app/dist/assets/regexp-CDVJQ6XC.js +1 -0
  299. package/app/dist/assets/rel-C3B-1QV4.js +1 -0
  300. package/app/dist/assets/riscv-BM1_JUlF.js +1 -0
  301. package/app/dist/assets/ron-BhRPY-oY.js +1 -0
  302. package/app/dist/assets/rose-pine-dawn-DHQR4-dF.js +1 -0
  303. package/app/dist/assets/rose-pine-moon-D4_iv3hh.js +1 -0
  304. package/app/dist/assets/rose-pine-qdsjHGoJ.js +1 -0
  305. package/app/dist/assets/rosmsg-BJDFO7_C.js +1 -0
  306. package/app/dist/assets/rpm-CTu-6PCP.js +1 -0
  307. package/app/dist/assets/rst-D5oM4XIm.js +1 -0
  308. package/app/dist/assets/ruby-B2Rjki9n.js +1 -0
  309. package/app/dist/assets/ruby-Cw6WdidG.js +1 -0
  310. package/app/dist/assets/rust-B1yitclQ.js +1 -0
  311. package/app/dist/assets/sas-B4kiWyti.js +1 -0
  312. package/app/dist/assets/sas-cz2c8ADy.js +1 -0
  313. package/app/dist/assets/sass-Cj5Yp3dK.js +1 -0
  314. package/app/dist/assets/scala-C151Ov-r.js +1 -0
  315. package/app/dist/assets/scheme-C41bIUwD.js +1 -0
  316. package/app/dist/assets/scheme-C98Dy4si.js +1 -0
  317. package/app/dist/assets/scss-OYdSNvt2.js +1 -0
  318. package/app/dist/assets/sdbl-DVxCFoDh.js +1 -0
  319. package/app/dist/assets/shaderlab-Dg9Lc6iA.js +1 -0
  320. package/app/dist/assets/shell-CjFT_Tl9.js +1 -0
  321. package/app/dist/assets/shellscript-Yzrsuije.js +1 -0
  322. package/app/dist/assets/shellsession-BADoaaVG.js +1 -0
  323. package/app/dist/assets/sieve-C3Gn_uJK.js +1 -0
  324. package/app/dist/assets/simple-mode-GW_nhZxv.js +1 -0
  325. package/app/dist/assets/slack-dark-BthQWCQV.js +1 -0
  326. package/app/dist/assets/slack-ochin-DqwNpetd.js +1 -0
  327. package/app/dist/assets/smalltalk-BERRCDM3.js +1 -0
  328. package/app/dist/assets/smalltalk-CnHTOXQT.js +1 -0
  329. package/app/dist/assets/snazzy-light-Bw305WKR.js +1 -0
  330. package/app/dist/assets/solarized-dark-DXbdFlpD.js +1 -0
  331. package/app/dist/assets/solarized-light-L9t79GZl.js +1 -0
  332. package/app/dist/assets/solidity-rGO070M0.js +1 -0
  333. package/app/dist/assets/solr-DehyRSwq.js +1 -0
  334. package/app/dist/assets/soy-Brmx7dQM.js +1 -0
  335. package/app/dist/assets/sparql-DkYu6x3z.js +1 -0
  336. package/app/dist/assets/sparql-rVzFXLq3.js +1 -0
  337. package/app/dist/assets/splunk-BtCnVYZw.js +1 -0
  338. package/app/dist/assets/spreadsheet-BCZA_wO0.js +1 -0
  339. package/app/dist/assets/sql-BLtJtn59.js +1 -0
  340. package/app/dist/assets/sql-D0XecflT.js +1 -0
  341. package/app/dist/assets/ssh-config-_ykCGR6B.js +1 -0
  342. package/app/dist/assets/stata-BH5u7GGu.js +1 -0
  343. package/app/dist/assets/stex-C3f8Ysf7.js +1 -0
  344. package/app/dist/assets/stylus-B533Al4x.js +1 -0
  345. package/app/dist/assets/stylus-BEDo0Tqx.js +1 -0
  346. package/app/dist/assets/surrealql-Bq5Q-fJD.js +1 -0
  347. package/app/dist/assets/svelte-zxCyuUbr.js +1 -0
  348. package/app/dist/assets/swift-BzpIVaGY.js +1 -0
  349. package/app/dist/assets/swift-Dg5xB15N.js +1 -0
  350. package/app/dist/assets/synthwave-84-CbfX1IO0.js +1 -0
  351. package/app/dist/assets/system-verilog-CnnmHF94.js +1 -0
  352. package/app/dist/assets/systemd-4A_iFExJ.js +1 -0
  353. package/app/dist/assets/talonscript-CkByrt1z.js +1 -0
  354. package/app/dist/assets/tasl-QIJgUcNo.js +1 -0
  355. package/app/dist/assets/tcl-DVfN8rqt.js +1 -0
  356. package/app/dist/assets/tcl-dwOrl1Do.js +1 -0
  357. package/app/dist/assets/templ-P3uqSqPl.js +1 -0
  358. package/app/dist/assets/terraform-BETggiCN.js +1 -0
  359. package/app/dist/assets/tex-CvyZ59Mk.js +1 -0
  360. package/app/dist/assets/textile-CnDTJFAw.js +1 -0
  361. package/app/dist/assets/tiddlywiki-DO-Gjzrf.js +1 -0
  362. package/app/dist/assets/tiki-DGYXhP31.js +1 -0
  363. package/app/dist/assets/tokyo-night-hegEt444.js +1 -0
  364. package/app/dist/assets/toml-Bm5Em-hy.js +1 -0
  365. package/app/dist/assets/toml-vGWfd6FD.js +1 -0
  366. package/app/dist/assets/troff-wAsdV37c.js +1 -0
  367. package/app/dist/assets/ts-tags-zn1MmPIZ.js +1 -0
  368. package/app/dist/assets/tsv-B_m7g4N7.js +1 -0
  369. package/app/dist/assets/tsx-COt5Ahok.js +1 -0
  370. package/app/dist/assets/ttcn-CfJYG6tj.js +1 -0
  371. package/app/dist/assets/ttcn-cfg-B9xdYoR4.js +1 -0
  372. package/app/dist/assets/turtle-B1tBg_DP.js +1 -0
  373. package/app/dist/assets/turtle-BsS91CYL.js +1 -0
  374. package/app/dist/assets/twig-ChbOoGGc.js +1 -0
  375. package/app/dist/assets/typescript-BPQ3VLAy.js +1 -0
  376. package/app/dist/assets/typespec-BGHnOYBU.js +1 -0
  377. package/app/dist/assets/typst-DHCkPAjA.js +1 -0
  378. package/app/dist/assets/v-BcVCzyr7.js +1 -0
  379. package/app/dist/assets/vala-CsfeWuGM.js +1 -0
  380. package/app/dist/assets/vb-CmGdzxic.js +1 -0
  381. package/app/dist/assets/vb-D17OF-Vu.js +1 -0
  382. package/app/dist/assets/vbscript-BuJXcnF6.js +1 -0
  383. package/app/dist/assets/velocity-D8B20fx6.js +1 -0
  384. package/app/dist/assets/verilog-BQ8w6xss.js +1 -0
  385. package/app/dist/assets/verilog-C6RDOZhf.js +1 -0
  386. package/app/dist/assets/vesper-DU1UobuO.js +1 -0
  387. package/app/dist/assets/vhdl-CeAyd5Ju.js +1 -0
  388. package/app/dist/assets/vhdl-lSbBsy5d.js +1 -0
  389. package/app/dist/assets/viml-CJc9bBzg.js +1 -0
  390. package/app/dist/assets/vitesse-black-Bkuqu6BP.js +1 -0
  391. package/app/dist/assets/vitesse-dark-D0r3Knsf.js +1 -0
  392. package/app/dist/assets/vitesse-light-CVO1_9PV.js +1 -0
  393. package/app/dist/assets/vue-DN_0RTcg.js +1 -0
  394. package/app/dist/assets/vue-html-AaS7Mt5G.js +1 -0
  395. package/app/dist/assets/vue-vine-CQOfvN7w.js +1 -0
  396. package/app/dist/assets/vyper-CDx5xZoG.js +1 -0
  397. package/app/dist/assets/wasm-CG6Dc4jp.js +1 -0
  398. package/app/dist/assets/wasm-MzD3tlZU.js +1 -0
  399. package/app/dist/assets/webidl-ZXfAyPTL.js +1 -0
  400. package/app/dist/assets/wenyan-BV7otONQ.js +1 -0
  401. package/app/dist/assets/wgsl-Dx-B1_4e.js +1 -0
  402. package/app/dist/assets/wikitext-BhOHFoWU.js +1 -0
  403. package/app/dist/assets/wit-5i3qLPDT.js +1 -0
  404. package/app/dist/assets/wolfram-lXgVvXCa.js +1 -0
  405. package/app/dist/assets/xml-sdJ4AIDG.js +1 -0
  406. package/app/dist/assets/xquery-DzFWVndE.js +1 -0
  407. package/app/dist/assets/xsl-CtQFsRM5.js +1 -0
  408. package/app/dist/assets/yacas-BJ4BC0dw.js +1 -0
  409. package/app/dist/assets/yaml-Buea-lGh.js +1 -0
  410. package/app/dist/assets/z80-Hz9HOZM7.js +1 -0
  411. package/app/dist/assets/zenscript-DVFEvuxE.js +1 -0
  412. package/app/dist/assets/zig-VOosw3JB.js +1 -0
  413. package/app/dist/index.html +13 -0
  414. package/app/src/lib/api/client.ts +234 -0
  415. package/app/src/lib/components/BlockCard.svelte +175 -0
  416. package/app/src/lib/components/BlockEditPanel.svelte +403 -0
  417. package/app/src/lib/components/BlockEditor.svelte +967 -0
  418. package/app/src/lib/components/CategoryNav.svelte +344 -0
  419. package/app/src/lib/components/ConfirmDialog.svelte +118 -0
  420. package/app/src/lib/components/ContextMenu.svelte +149 -0
  421. package/app/src/lib/components/CreateCategoryModal.svelte +171 -0
  422. package/app/src/lib/components/CreateDirectoryModal.svelte +212 -0
  423. package/app/src/lib/components/CreatePageModal.svelte +273 -0
  424. package/app/src/lib/components/EditorLayout.svelte +122 -0
  425. package/app/src/lib/components/ExternalChangeBanner.svelte +72 -0
  426. package/app/src/lib/components/FileTree.svelte +135 -0
  427. package/app/src/lib/components/FileTreeNode.svelte +253 -0
  428. package/app/src/lib/components/FrontmatterEditPanel.svelte +435 -0
  429. package/app/src/lib/components/FrontmatterEditor.svelte +549 -0
  430. package/app/src/lib/components/HeaderBar.svelte +322 -0
  431. package/app/src/lib/components/InlineEditor.svelte +234 -0
  432. package/app/src/lib/components/LayoutEditor.svelte +228 -0
  433. package/app/src/lib/components/MarkdownEditor.svelte +123 -0
  434. package/app/src/lib/components/NavEditor.svelte +359 -0
  435. package/app/src/lib/components/NavItemRow.svelte +165 -0
  436. package/app/src/lib/components/PageCard.svelte +45 -0
  437. package/app/src/lib/components/Popover.svelte +86 -0
  438. package/app/src/lib/components/PreviewPane.svelte +186 -0
  439. package/app/src/lib/components/RawYamlEditor.svelte +89 -0
  440. package/app/src/lib/components/RegionCard.svelte +258 -0
  441. package/app/src/lib/components/RenameDialog.svelte +143 -0
  442. package/app/src/lib/components/ResizeHandle.svelte +100 -0
  443. package/app/src/lib/components/RuneAttributes.svelte +197 -0
  444. package/app/src/lib/components/TagsInput.svelte +109 -0
  445. package/app/src/lib/editor/block-parser.ts +437 -0
  446. package/app/src/lib/preview/block-renderer.ts +74 -0
  447. package/dist/css.d.ts +6 -0
  448. package/dist/css.d.ts.map +1 -0
  449. package/dist/css.js +25 -0
  450. package/dist/css.js.map +1 -0
  451. package/dist/index.d.ts +5 -0
  452. package/dist/index.d.ts.map +1 -0
  453. package/dist/index.js +4 -0
  454. package/dist/index.js.map +1 -0
  455. package/dist/layout-resolver.d.ts +59 -0
  456. package/dist/layout-resolver.d.ts.map +1 -0
  457. package/dist/layout-resolver.js +166 -0
  458. package/dist/layout-resolver.js.map +1 -0
  459. package/dist/preview-builder.d.ts +16 -0
  460. package/dist/preview-builder.d.ts.map +1 -0
  461. package/dist/preview-builder.js +77 -0
  462. package/dist/preview-builder.js.map +1 -0
  463. package/dist/preview.d.ts +12 -0
  464. package/dist/preview.d.ts.map +1 -0
  465. package/dist/preview.js +70 -0
  466. package/dist/preview.js.map +1 -0
  467. package/dist/server.d.ts +26 -0
  468. package/dist/server.d.ts.map +1 -0
  469. package/dist/server.js +694 -0
  470. package/dist/server.js.map +1 -0
  471. package/package.json +76 -0
  472. package/preview-runtime/App.svelte +59 -0
  473. package/preview-runtime/index.html +17 -0
@@ -0,0 +1,228 @@
1
+ <script lang="ts">
2
+ import { editorState } from '../state/editor.svelte.js';
3
+ import {
4
+ parseLayoutClient, serializeLayout,
5
+ type ParsedLayout, type ParsedRegion,
6
+ } from '../utils/layout-parser.js';
7
+ import RegionCard from './RegionCard.svelte';
8
+ import MarkdownEditor from './MarkdownEditor.svelte';
9
+
10
+ let rawMode = $state(false);
11
+ let layout: ParsedLayout = $state({ regions: [] });
12
+
13
+ // Parse the editor content into regions when it changes externally
14
+ // (e.g., file switch or save)
15
+ let lastParsedFrom = '';
16
+
17
+ $effect(() => {
18
+ const content = editorState.editorContent;
19
+ if (content !== lastParsedFrom) {
20
+ layout = parseLayoutClient(content);
21
+ lastParsedFrom = content;
22
+ }
23
+ });
24
+
25
+ function syncToEditor() {
26
+ const serialized = serializeLayout(layout);
27
+ lastParsedFrom = serialized;
28
+ editorState.editorContent = serialized;
29
+ editorState.bodyContent = serialized;
30
+ }
31
+
32
+ function handleRegionChange(idx: number, region: ParsedRegion) {
33
+ layout.regions[idx] = region;
34
+ layout = { ...layout };
35
+ syncToEditor();
36
+ }
37
+
38
+ function handleRegionDelete(idx: number) {
39
+ layout.regions.splice(idx, 1);
40
+ layout = { ...layout };
41
+ syncToEditor();
42
+ }
43
+
44
+ function handleAddRegion() {
45
+ layout.regions.push({ name: '', mode: 'replace', content: '' });
46
+ layout = { ...layout };
47
+ syncToEditor();
48
+ }
49
+ </script>
50
+
51
+ <div class="layout-editor">
52
+ <div class="layout-editor__header">
53
+ <div class="layout-editor__title-row">
54
+ <svg class="layout-editor__icon" width="16" height="16" viewBox="0 0 16 16" fill="none">
55
+ <rect x="1" y="1" width="14" height="14" rx="2" stroke="currentColor" stroke-width="1.2"/>
56
+ <path d="M1 5h14M6 5v10" stroke="currentColor" stroke-width="1.2"/>
57
+ </svg>
58
+ <span class="layout-editor__title">Layout</span>
59
+ {#if editorState.currentPath}
60
+ <span class="layout-editor__path">{editorState.currentPath}</span>
61
+ {/if}
62
+ </div>
63
+ <div class="layout-editor__mode-track">
64
+ <button
65
+ class="layout-editor__mode-btn"
66
+ class:active={!rawMode}
67
+ onclick={() => { rawMode = false; }}
68
+ >Visual</button>
69
+ <button
70
+ class="layout-editor__mode-btn"
71
+ class:active={rawMode}
72
+ onclick={() => { rawMode = true; }}
73
+ >Raw</button>
74
+ </div>
75
+ </div>
76
+
77
+ {#if rawMode}
78
+ <div class="layout-editor__raw">
79
+ <MarkdownEditor />
80
+ </div>
81
+ {:else}
82
+ <div class="layout-editor__regions">
83
+ {#if layout.regions.length === 0}
84
+ <div class="layout-editor__empty">
85
+ <p>No regions defined. Add a region to get started.</p>
86
+ </div>
87
+ {/if}
88
+
89
+ {#each layout.regions as region, idx}
90
+ <RegionCard
91
+ {region}
92
+ onchange={(r) => handleRegionChange(idx, r)}
93
+ ondelete={() => handleRegionDelete(idx)}
94
+ />
95
+ {/each}
96
+
97
+ <button class="layout-editor__add-btn" onclick={handleAddRegion}>
98
+ <svg width="14" height="14" viewBox="0 0 16 16" fill="none">
99
+ <path d="M8 3v10M3 8h10" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"/>
100
+ </svg>
101
+ Add Region
102
+ </button>
103
+ </div>
104
+ {/if}
105
+ </div>
106
+
107
+ <style>
108
+ .layout-editor {
109
+ display: flex;
110
+ flex-direction: column;
111
+ height: 100%;
112
+ overflow: hidden;
113
+ }
114
+
115
+ .layout-editor__header {
116
+ display: flex;
117
+ align-items: center;
118
+ justify-content: space-between;
119
+ padding: var(--ed-space-2) var(--ed-space-3);
120
+ border-bottom: 1px solid var(--ed-border-default);
121
+ background: var(--ed-surface-1);
122
+ flex-shrink: 0;
123
+ }
124
+
125
+ .layout-editor__title-row {
126
+ display: flex;
127
+ align-items: center;
128
+ gap: 0.4rem;
129
+ min-width: 0;
130
+ }
131
+
132
+ .layout-editor__icon {
133
+ color: var(--ed-warning);
134
+ flex-shrink: 0;
135
+ }
136
+
137
+ .layout-editor__title {
138
+ font-size: var(--ed-text-base);
139
+ font-weight: 600;
140
+ color: var(--ed-text-primary);
141
+ }
142
+
143
+ .layout-editor__path {
144
+ font-size: var(--ed-text-xs);
145
+ color: var(--ed-text-muted);
146
+ overflow: hidden;
147
+ text-overflow: ellipsis;
148
+ white-space: nowrap;
149
+ }
150
+
151
+ .layout-editor__mode-track {
152
+ display: inline-flex;
153
+ background: var(--ed-surface-2);
154
+ border-radius: var(--ed-radius-md);
155
+ padding: 2px;
156
+ gap: 2px;
157
+ flex-shrink: 0;
158
+ }
159
+
160
+ .layout-editor__mode-btn {
161
+ font-size: var(--ed-text-xs);
162
+ padding: 0.15rem var(--ed-space-2);
163
+ border: none;
164
+ border-radius: calc(var(--ed-radius-md) - 2px);
165
+ background: transparent;
166
+ color: var(--ed-text-tertiary);
167
+ cursor: pointer;
168
+ font-weight: 500;
169
+ transition: background var(--ed-transition-fast), color var(--ed-transition-fast), box-shadow var(--ed-transition-fast);
170
+ }
171
+
172
+ .layout-editor__mode-btn:hover:not(.active) {
173
+ color: var(--ed-text-secondary);
174
+ }
175
+
176
+ .layout-editor__mode-btn.active {
177
+ background: var(--ed-surface-0);
178
+ color: var(--ed-text-primary);
179
+ box-shadow: var(--ed-shadow-sm);
180
+ }
181
+
182
+ .layout-editor__raw {
183
+ flex: 1;
184
+ min-height: 0;
185
+ display: flex;
186
+ flex-direction: column;
187
+ }
188
+
189
+ .layout-editor__regions {
190
+ flex: 1;
191
+ overflow-y: auto;
192
+ padding: var(--ed-space-3);
193
+ display: flex;
194
+ flex-direction: column;
195
+ gap: var(--ed-space-3);
196
+ background: var(--ed-surface-1);
197
+ }
198
+
199
+ .layout-editor__empty {
200
+ text-align: center;
201
+ padding: 2rem var(--ed-space-4);
202
+ color: var(--ed-text-muted);
203
+ font-size: var(--ed-text-md);
204
+ }
205
+
206
+ .layout-editor__empty p {
207
+ margin: 0;
208
+ }
209
+
210
+ .layout-editor__add-btn {
211
+ display: flex;
212
+ align-items: center;
213
+ justify-content: center;
214
+ gap: 0.35rem;
215
+ padding: var(--ed-space-2) var(--ed-space-4);
216
+ border: 1px dashed var(--ed-border-default);
217
+ border-radius: var(--ed-radius-md);
218
+ background: none;
219
+ color: var(--ed-text-muted);
220
+ font-size: var(--ed-text-base);
221
+ cursor: pointer;
222
+ }
223
+
224
+ .layout-editor__add-btn:hover {
225
+ border-color: var(--ed-accent);
226
+ color: var(--ed-accent);
227
+ }
228
+ </style>
@@ -0,0 +1,123 @@
1
+ <script lang="ts">
2
+ import { EditorState } from '@codemirror/state';
3
+ import {
4
+ EditorView,
5
+ keymap,
6
+ lineNumbers,
7
+ highlightActiveLineGutter,
8
+ highlightActiveLine,
9
+ } from '@codemirror/view';
10
+ import { defaultKeymap, history, historyKeymap } from '@codemirror/commands';
11
+ import { markdown } from '@codemirror/lang-markdown';
12
+ import { syntaxHighlighting } from '@codemirror/language';
13
+ import { searchKeymap, highlightSelectionMatches } from '@codemirror/search';
14
+ import { autocompletion, startCompletion } from '@codemirror/autocomplete';
15
+ import { untrack } from 'svelte';
16
+ import { editorState } from '../state/editor.svelte.js';
17
+ import { runeCompletionSource } from '../editor/rune-palette.js';
18
+ import { attributeCompletionSource } from '../editor/attribute-completion.js';
19
+ import { markdocHighlight } from '../editor/markdoc-highlight.js';
20
+ import { lightTheme, highlightTheme } from '../editor/codemirror-theme.js';
21
+
22
+ let container: HTMLElement;
23
+ let editorView: EditorView;
24
+
25
+ // Create CodeMirror when container is available, destroy on cleanup
26
+ $effect(() => {
27
+ if (!container) return;
28
+
29
+ const state = EditorState.create({
30
+ doc: untrack(() => editorState.bodyContent),
31
+ extensions: [
32
+ lineNumbers(),
33
+ highlightActiveLineGutter(),
34
+ highlightActiveLine(),
35
+ history(),
36
+ markdown(),
37
+ lightTheme,
38
+ syntaxHighlighting(highlightTheme),
39
+ highlightSelectionMatches(),
40
+ keymap.of([
41
+ ...defaultKeymap,
42
+ ...historyKeymap,
43
+ ...searchKeymap,
44
+ { key: 'Mod-/', run: (view) => { startCompletion(view); return true; } },
45
+ ]),
46
+ EditorView.updateListener.of((update) => {
47
+ if (update.docChanged) {
48
+ editorState.updateBody(update.state.doc.toString());
49
+ }
50
+ }),
51
+ EditorView.lineWrapping,
52
+ // Markdoc extensions
53
+ markdocHighlight(),
54
+ autocompletion({
55
+ override: [
56
+ runeCompletionSource(() => editorState.runes),
57
+ attributeCompletionSource(() => editorState.runes),
58
+ ],
59
+ icons: false,
60
+ }),
61
+ ],
62
+ });
63
+
64
+ editorView = new EditorView({ state, parent: container });
65
+
66
+ return () => {
67
+ editorView?.destroy();
68
+ };
69
+ });
70
+
71
+ // Sync external value changes (file switch) into CodeMirror
72
+ $effect(() => {
73
+ const current = editorState.bodyContent;
74
+ if (!editorView) return;
75
+
76
+ const cmContent = editorView.state.doc.toString();
77
+ if (current !== cmContent) {
78
+ editorView.dispatch({
79
+ changes: {
80
+ from: 0,
81
+ to: editorView.state.doc.length,
82
+ insert: current,
83
+ },
84
+ });
85
+ }
86
+ });
87
+ </script>
88
+
89
+ <div class="md-editor" bind:this={container} class:hidden={!editorState.currentPath}></div>
90
+ {#if !editorState.currentPath}
91
+ <div class="md-editor__empty">
92
+ <span class="md-editor__empty-text">Select a file to edit</span>
93
+ </div>
94
+ {/if}
95
+
96
+ <style>
97
+ .md-editor {
98
+ flex: 1;
99
+ min-height: 0;
100
+ overflow: hidden;
101
+ }
102
+
103
+ .md-editor.hidden {
104
+ display: none;
105
+ }
106
+
107
+ .md-editor :global(.cm-editor) {
108
+ height: 100%;
109
+ }
110
+
111
+ .md-editor__empty {
112
+ flex: 1;
113
+ display: flex;
114
+ align-items: center;
115
+ justify-content: center;
116
+ height: 100%;
117
+ }
118
+
119
+ .md-editor__empty-text {
120
+ color: var(--ed-text-secondary);
121
+ font-size: var(--ed-text-md);
122
+ }
123
+ </style>
@@ -0,0 +1,359 @@
1
+ <script lang="ts">
2
+ import {
3
+ extractNavContent, replaceNavContent,
4
+ parseNavContent, serializeNavContent,
5
+ type ParsedNav, type NavGroup,
6
+ } from '../utils/layout-parser.js';
7
+ import NavItemRow from './NavItemRow.svelte';
8
+
9
+ interface Props {
10
+ content: string;
11
+ onchange: (content: string) => void;
12
+ }
13
+
14
+ let { content, onchange }: Props = $props();
15
+
16
+ let nav: ParsedNav = $state({ groups: [], ungrouped: [] });
17
+ let addItemGroupIdx: number | null = $state(null);
18
+ let addItemValue = $state('');
19
+ let addGroupValue = $state('');
20
+ let showAddGroup = $state(false);
21
+
22
+ // Drag state
23
+ let dragSource: { groupIdx: number; itemIdx: number } | null = $state(null);
24
+ let dragOverTarget: { groupIdx: number; itemIdx: number } | null = $state(null);
25
+
26
+ // Parse content into nav structure
27
+ $effect(() => {
28
+ const inner = extractNavContent(content);
29
+ if (inner !== null) {
30
+ nav = parseNavContent(inner);
31
+ }
32
+ });
33
+
34
+ function emitChange() {
35
+ const inner = serializeNavContent(nav);
36
+ const newContent = replaceNavContent(content, inner);
37
+ onchange(newContent);
38
+ }
39
+
40
+ // ── Group operations ─────────────────────────────────────────
41
+
42
+ function handleGroupTitleChange(idx: number, title: string) {
43
+ nav.groups[idx] = { ...nav.groups[idx], title };
44
+ nav = { ...nav };
45
+ emitChange();
46
+ }
47
+
48
+ function handleDeleteGroup(idx: number) {
49
+ const group = nav.groups[idx];
50
+ if (group.items.length > 0) {
51
+ if (!confirm(`Delete group "${group.title}" and its ${group.items.length} items?`)) return;
52
+ }
53
+ nav.groups.splice(idx, 1);
54
+ nav = { ...nav };
55
+ emitChange();
56
+ }
57
+
58
+ function handleAddGroup() {
59
+ const title = addGroupValue.trim();
60
+ if (!title) return;
61
+ nav.groups.push({ title, items: [] });
62
+ nav = { ...nav };
63
+ addGroupValue = '';
64
+ showAddGroup = false;
65
+ emitChange();
66
+ }
67
+
68
+ // ── Item operations ──────────────────────────────────────────
69
+
70
+ function handleItemChange(groupIdx: number, itemIdx: number, newSlug: string) {
71
+ nav.groups[groupIdx].items[itemIdx] = newSlug;
72
+ nav = { ...nav };
73
+ emitChange();
74
+ }
75
+
76
+ function handleItemDelete(groupIdx: number, itemIdx: number) {
77
+ nav.groups[groupIdx].items.splice(itemIdx, 1);
78
+ nav = { ...nav };
79
+ emitChange();
80
+ }
81
+
82
+ function handleAddItem(groupIdx: number) {
83
+ const slug = addItemValue.trim();
84
+ if (!slug) return;
85
+ nav.groups[groupIdx].items.push(slug);
86
+ nav = { ...nav };
87
+ addItemValue = '';
88
+ addItemGroupIdx = null;
89
+ emitChange();
90
+ }
91
+
92
+ function handleAddItemKeydown(e: KeyboardEvent, groupIdx: number) {
93
+ if (e.key === 'Enter') {
94
+ e.preventDefault();
95
+ handleAddItem(groupIdx);
96
+ } else if (e.key === 'Escape') {
97
+ addItemGroupIdx = null;
98
+ addItemValue = '';
99
+ }
100
+ }
101
+
102
+ function handleAddGroupKeydown(e: KeyboardEvent) {
103
+ if (e.key === 'Enter') {
104
+ e.preventDefault();
105
+ handleAddGroup();
106
+ } else if (e.key === 'Escape') {
107
+ showAddGroup = false;
108
+ addGroupValue = '';
109
+ }
110
+ }
111
+
112
+ // ── Drag and drop ────────────────────────────────────────────
113
+
114
+ function handleDragStart(e: PointerEvent, groupIdx: number, itemIdx: number) {
115
+ const el = e.currentTarget as HTMLElement;
116
+ el.setPointerCapture(e.pointerId);
117
+ dragSource = { groupIdx, itemIdx };
118
+ }
119
+
120
+ function handleDragMove(e: PointerEvent, groupIdx: number, itemIdx: number) {
121
+ if (!dragSource) return;
122
+ dragOverTarget = { groupIdx, itemIdx };
123
+ }
124
+
125
+ function handleDragEnd(e: PointerEvent) {
126
+ if (!dragSource || !dragOverTarget) {
127
+ dragSource = null;
128
+ dragOverTarget = null;
129
+ return;
130
+ }
131
+
132
+ const { groupIdx: srcGroup, itemIdx: srcItem } = dragSource;
133
+ const { groupIdx: dstGroup, itemIdx: dstItem } = dragOverTarget;
134
+
135
+ if (srcGroup === dstGroup && srcItem === dstItem) {
136
+ dragSource = null;
137
+ dragOverTarget = null;
138
+ return;
139
+ }
140
+
141
+ // Remove from source
142
+ const [removed] = nav.groups[srcGroup].items.splice(srcItem, 1);
143
+
144
+ // Insert at destination (adjust index if same group and source was before dest)
145
+ let insertIdx = dstItem;
146
+ if (srcGroup === dstGroup && srcItem < dstItem) {
147
+ insertIdx = dstItem - 1;
148
+ }
149
+
150
+ nav.groups[dstGroup].items.splice(insertIdx, 0, removed);
151
+ nav = { ...nav };
152
+
153
+ dragSource = null;
154
+ dragOverTarget = null;
155
+ emitChange();
156
+ }
157
+ </script>
158
+
159
+ <div class="nav-editor">
160
+ {#each nav.groups as group, groupIdx}
161
+ <div class="nav-editor__group">
162
+ <div class="nav-editor__group-header">
163
+ <input
164
+ class="nav-editor__group-title"
165
+ type="text"
166
+ value={group.title}
167
+ oninput={(e) => handleGroupTitleChange(groupIdx, (e.target as HTMLInputElement).value)}
168
+ placeholder="Group title"
169
+ />
170
+ <button
171
+ class="nav-editor__group-delete"
172
+ onclick={() => handleDeleteGroup(groupIdx)}
173
+ title="Delete group"
174
+ >
175
+ <svg width="12" height="12" viewBox="0 0 16 16" fill="none">
176
+ <path d="M4 4l8 8M12 4l-8 8" stroke="currentColor" stroke-width="1.5" stroke-linecap="round"/>
177
+ </svg>
178
+ </button>
179
+ </div>
180
+ <div class="nav-editor__items">
181
+ {#each group.items as slug, itemIdx}
182
+ <div
183
+ class="nav-editor__item-wrapper"
184
+ class:drag-over={dragOverTarget?.groupIdx === groupIdx && dragOverTarget?.itemIdx === itemIdx}
185
+ onpointermove={(e) => handleDragMove(e, groupIdx, itemIdx)}
186
+ onpointerup={handleDragEnd}
187
+ role="listitem"
188
+ >
189
+ <NavItemRow
190
+ {slug}
191
+ onchange={(newSlug) => handleItemChange(groupIdx, itemIdx, newSlug)}
192
+ ondelete={() => handleItemDelete(groupIdx, itemIdx)}
193
+ ondragstart={(e) => handleDragStart(e, groupIdx, itemIdx)}
194
+ />
195
+ </div>
196
+ {/each}
197
+ </div>
198
+ {#if addItemGroupIdx === groupIdx}
199
+ <div class="nav-editor__add-item">
200
+ <input
201
+ class="nav-editor__add-input"
202
+ type="text"
203
+ bind:value={addItemValue}
204
+ onkeydown={(e) => handleAddItemKeydown(e, groupIdx)}
205
+ onblur={() => { addItemGroupIdx = null; addItemValue = ''; }}
206
+ placeholder="Page slug..."
207
+ autofocus
208
+ />
209
+ </div>
210
+ {:else}
211
+ <button
212
+ class="nav-editor__add-item-btn"
213
+ onclick={() => { addItemGroupIdx = groupIdx; addItemValue = ''; }}
214
+ >
215
+ + Add item
216
+ </button>
217
+ {/if}
218
+ </div>
219
+ {/each}
220
+
221
+ {#if showAddGroup}
222
+ <div class="nav-editor__add-group">
223
+ <input
224
+ class="nav-editor__add-input"
225
+ type="text"
226
+ bind:value={addGroupValue}
227
+ onkeydown={handleAddGroupKeydown}
228
+ onblur={() => { showAddGroup = false; addGroupValue = ''; }}
229
+ placeholder="Group title..."
230
+ autofocus
231
+ />
232
+ </div>
233
+ {:else}
234
+ <button
235
+ class="nav-editor__add-group-btn"
236
+ onclick={() => { showAddGroup = true; addGroupValue = ''; }}
237
+ >
238
+ + Add group
239
+ </button>
240
+ {/if}
241
+ </div>
242
+
243
+ <style>
244
+ .nav-editor {
245
+ padding: var(--ed-space-2) 0;
246
+ display: flex;
247
+ flex-direction: column;
248
+ gap: var(--ed-space-4);
249
+ }
250
+
251
+ .nav-editor__group {
252
+ }
253
+
254
+ .nav-editor__group-header {
255
+ display: flex;
256
+ align-items: center;
257
+ gap: var(--ed-space-2);
258
+ padding: var(--ed-space-1) 0;
259
+ background: transparent;
260
+ border-bottom: 1px solid var(--ed-border-default);
261
+ margin-bottom: var(--ed-space-1);
262
+ }
263
+
264
+ .nav-editor__group-title {
265
+ flex: 1;
266
+ font-size: var(--ed-text-sm);
267
+ font-weight: 600;
268
+ color: var(--ed-text-tertiary);
269
+ border: 1px solid transparent;
270
+ border-radius: var(--ed-radius-sm);
271
+ padding: 0.1rem 0.25rem;
272
+ background: transparent;
273
+ outline: none;
274
+ text-transform: uppercase;
275
+ letter-spacing: 0.05em;
276
+ }
277
+
278
+ .nav-editor__group-title:focus {
279
+ border-color: var(--ed-accent);
280
+ background: var(--ed-surface-0);
281
+ text-transform: none;
282
+ }
283
+
284
+ .nav-editor__group-delete {
285
+ display: flex;
286
+ align-items: center;
287
+ justify-content: center;
288
+ width: 18px;
289
+ height: 18px;
290
+ border: none;
291
+ background: none;
292
+ color: var(--ed-border-strong);
293
+ cursor: pointer;
294
+ border-radius: var(--ed-radius-sm);
295
+ }
296
+
297
+ .nav-editor__group-delete:hover {
298
+ color: var(--ed-danger);
299
+ background: var(--ed-danger-subtle);
300
+ }
301
+
302
+ .nav-editor__items {
303
+ padding: 0;
304
+ }
305
+
306
+ .nav-editor__item-wrapper.drag-over {
307
+ border-top: 2px solid var(--ed-accent);
308
+ }
309
+
310
+ .nav-editor__add-item {
311
+ padding: var(--ed-space-1) var(--ed-space-2) 0.35rem;
312
+ }
313
+
314
+ .nav-editor__add-input {
315
+ width: 100%;
316
+ font-size: var(--ed-text-sm);
317
+ padding: 0.2rem 0.35rem;
318
+ border: 1px solid var(--ed-accent);
319
+ border-radius: var(--ed-radius-sm);
320
+ outline: none;
321
+ color: var(--ed-text-primary);
322
+ background: var(--ed-surface-0);
323
+ }
324
+
325
+ .nav-editor__add-item-btn {
326
+ font-size: var(--ed-text-xs);
327
+ color: var(--ed-text-muted);
328
+ background: none;
329
+ border: none;
330
+ cursor: pointer;
331
+ padding: 0.2rem 0.25rem;
332
+ text-align: left;
333
+ }
334
+
335
+ .nav-editor__add-item-btn:hover {
336
+ color: var(--ed-accent);
337
+ }
338
+
339
+ .nav-editor__add-group {
340
+ padding: var(--ed-space-1) 0;
341
+ }
342
+
343
+ .nav-editor__add-group-btn {
344
+ font-size: var(--ed-text-sm);
345
+ color: var(--ed-text-muted);
346
+ background: none;
347
+ border: 1px dashed var(--ed-border-default);
348
+ border-radius: var(--ed-radius-md);
349
+ cursor: pointer;
350
+ padding: var(--ed-space-2) var(--ed-space-3);
351
+ width: 100%;
352
+ text-align: center;
353
+ }
354
+
355
+ .nav-editor__add-group-btn:hover {
356
+ color: var(--ed-accent);
357
+ border-color: var(--ed-accent);
358
+ }
359
+ </style>