@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,967 @@
1
+ <script lang="ts">
2
+ import type { RuneInfo } from '../api/client.js';
3
+ import type { RendererNode } from '@refrakt-md/transform';
4
+ import type { ThemeConfig } from '@refrakt-md/transform';
5
+ import {
6
+ parseBlocks,
7
+ serializeBlocks,
8
+ buildRuneMap,
9
+ blockLabel,
10
+ extractRuneInner,
11
+ type ParsedBlock,
12
+ } from '../editor/block-parser.js';
13
+ import { editorState } from '../state/editor.svelte.js';
14
+ import BlockCard from './BlockCard.svelte';
15
+ import BlockEditPanel from './BlockEditPanel.svelte';
16
+ import FrontmatterEditPanel from './FrontmatterEditPanel.svelte';
17
+
18
+ interface Props {
19
+ bodyContent: string;
20
+ onchange: (body: string) => void;
21
+ runes: RuneInfo[];
22
+ themeConfig: ThemeConfig | null;
23
+ themeCss: string;
24
+ highlightCss?: string;
25
+ highlightTransform?: ((tree: RendererNode) => RendererNode) | null;
26
+ showInsertMenu?: boolean;
27
+ frontmatter?: Record<string, unknown>;
28
+ readOnly?: boolean;
29
+ }
30
+
31
+ let {
32
+ bodyContent,
33
+ onchange,
34
+ runes,
35
+ themeConfig,
36
+ themeCss,
37
+ highlightCss = '',
38
+ highlightTransform = null,
39
+ showInsertMenu: showInsertMenuProp = true,
40
+ frontmatter = {},
41
+ readOnly = false,
42
+ }: Props = $props();
43
+
44
+ let blocks: ParsedBlock[] = $state([]);
45
+ let runeMap = $derived(buildRuneMap(runes));
46
+
47
+ // Track the source we last parsed from, to avoid re-parsing our own updates
48
+ let lastParsedSource = '';
49
+
50
+ /** Match new blocks to old blocks and reuse IDs for edited-in-place blocks */
51
+ function reconcileIds(prev: ParsedBlock[], next: ParsedBlock[]): void {
52
+ if (prev.length === 0) return;
53
+
54
+ const prevIdSet = new Set(prev.map(b => b.id));
55
+ const nextIdSet = new Set(next.map(b => b.id));
56
+
57
+ // Old blocks whose content changed (ID no longer present in next)
58
+ const lost = prev.filter(b => !nextIdSet.has(b.id));
59
+ // New blocks with no matching old ID
60
+ const gained = next.filter(b => !prevIdSet.has(b.id));
61
+
62
+ if (lost.length === 0 || gained.length === 0) return;
63
+
64
+ // Match each gained block to the closest lost block by position + type
65
+ const available = [...lost];
66
+ for (const nb of gained) {
67
+ let best = -1;
68
+ let bestScore = Infinity;
69
+ for (let j = 0; j < available.length; j++) {
70
+ const ob = available[j];
71
+ const typeBonus = ob.type === nb.type ? 0 : 1000;
72
+ const score = Math.abs(ob.startLine - nb.startLine) + typeBonus;
73
+ if (score < bestScore) {
74
+ bestScore = score;
75
+ best = j;
76
+ }
77
+ }
78
+ if (best >= 0) {
79
+ nb.id = available[best].id;
80
+ available.splice(best, 1);
81
+ }
82
+ }
83
+ }
84
+
85
+ // Parse blocks when body content changes (from outside, e.g. file switch)
86
+ $effect(() => {
87
+ const body = bodyContent;
88
+ if (body !== lastParsedSource) {
89
+ const newBlocks = parseBlocks(body);
90
+ reconcileIds(blocks, newBlocks);
91
+ blocks = newBlocks;
92
+ lastParsedSource = body;
93
+ // Close edit panel when switching files
94
+ activeIndex = null;
95
+ }
96
+ });
97
+
98
+ // Sync edit panel open state to global state (for layout adjustments)
99
+ $effect(() => {
100
+ editorState.editPanelOpen = !readOnly && (activeIndex !== null || editingFrontmatter);
101
+ return () => { editorState.editPanelOpen = false; };
102
+ });
103
+
104
+ /** Sync blocks back to source text */
105
+ function syncToSource() {
106
+ const newSource = serializeBlocks(blocks);
107
+ lastParsedSource = newSource;
108
+ onchange(newSource);
109
+ }
110
+
111
+ // ── Frontmatter summary for visual mode header ──────────────
112
+
113
+ let editingFrontmatter = $state(false);
114
+ let fmTitle = $derived((frontmatter.title as string) || '');
115
+ let fmDesc = $derived(() => {
116
+ const desc = (frontmatter.description as string) || '';
117
+ return desc.length > 80 ? desc.slice(0, 80) + '...' : desc;
118
+ });
119
+
120
+ // ── Active block (rail selection) ────────────────────────────
121
+
122
+ let activeIndex: number | null = $state(null);
123
+
124
+ function toggleBlock(index: number) {
125
+ editingFrontmatter = false;
126
+ activeIndex = activeIndex === index ? null : index;
127
+ }
128
+
129
+ function toggleFrontmatter() {
130
+ activeIndex = null;
131
+ editingFrontmatter = !editingFrontmatter;
132
+ }
133
+
134
+ function handleKeydown(e: KeyboardEvent) {
135
+ if (readOnly) return;
136
+ if (e.key === 'Escape') {
137
+ if (showInsertMenu) {
138
+ closeInsertMenu();
139
+ } else if (activeIndex !== null || editingFrontmatter) {
140
+ activeIndex = null;
141
+ editingFrontmatter = false;
142
+ }
143
+ }
144
+ }
145
+
146
+ // ── Block operations ─────────────────────────────────────────
147
+
148
+ function handleUpdateBlock(index: number, updated: ParsedBlock) {
149
+ blocks = blocks.map((b, i) => (i === index ? updated : b));
150
+ syncToSource();
151
+ }
152
+
153
+ function handleRemoveBlock(index: number) {
154
+ // Adjust activeIndex
155
+ if (activeIndex !== null) {
156
+ if (activeIndex === index) {
157
+ activeIndex = null;
158
+ } else if (activeIndex > index) {
159
+ activeIndex--;
160
+ }
161
+ }
162
+ blocks = blocks.filter((_, i) => i !== index);
163
+ syncToSource();
164
+ }
165
+
166
+ // ── Drag and drop ────────────────────────────────────────────
167
+
168
+ let dragIndex: number | null = $state(null);
169
+ let dropIndex: number | null = $state(null);
170
+
171
+ function handleDragStart(e: DragEvent, index: number) {
172
+ dragIndex = index;
173
+ if (e.dataTransfer) {
174
+ e.dataTransfer.effectAllowed = 'move';
175
+ e.dataTransfer.setData('text/plain', String(index));
176
+ }
177
+ }
178
+
179
+ function handleDragOver(e: DragEvent, index: number) {
180
+ e.preventDefault();
181
+ if (e.dataTransfer) {
182
+ e.dataTransfer.dropEffect = 'move';
183
+ }
184
+ dropIndex = index;
185
+ }
186
+
187
+ function handleDrop(e: DragEvent, index: number) {
188
+ e.preventDefault();
189
+ if (dragIndex !== null && dragIndex !== index) {
190
+ const moved = blocks[dragIndex];
191
+ const next = blocks.filter((_, i) => i !== dragIndex);
192
+ next.splice(index, 0, moved);
193
+ blocks = next;
194
+
195
+ // Update activeIndex to follow the active block
196
+ if (activeIndex !== null) {
197
+ if (activeIndex === dragIndex) {
198
+ activeIndex = index > dragIndex ? index - 1 : index;
199
+ } else {
200
+ // Adjust if the move shifts the active block's position
201
+ let newActive = activeIndex;
202
+ if (dragIndex < activeIndex && index >= activeIndex) {
203
+ newActive--;
204
+ } else if (dragIndex > activeIndex && index <= activeIndex) {
205
+ newActive++;
206
+ }
207
+ activeIndex = newActive;
208
+ }
209
+ }
210
+
211
+ syncToSource();
212
+ }
213
+ dragIndex = null;
214
+ dropIndex = null;
215
+ }
216
+
217
+ // ── Insert block menu ────────────────────────────────────────
218
+
219
+ let showInsertMenu = $state(false);
220
+ let insertAtIndex: number | null = $state(null);
221
+
222
+ function openInsertAt(index: number) {
223
+ insertAtIndex = index;
224
+ showInsertMenu = true;
225
+ }
226
+
227
+ function closeInsertMenu() {
228
+ showInsertMenu = false;
229
+ insertAtIndex = null;
230
+ }
231
+
232
+ function handleClickOutside(e: MouseEvent) {
233
+ if (!showInsertMenu) return;
234
+ const target = e.target as HTMLElement;
235
+ if (target.closest('.insert-menu--floating') || target.closest('.block-editor__insert-dot')) return;
236
+ closeInsertMenu();
237
+ }
238
+
239
+ function insertBlock(type: 'heading' | 'paragraph' | 'fence' | 'hr' | 'rune', runeName?: string) {
240
+ let newBlock: ParsedBlock;
241
+ const id = `blk_new_${Date.now()}`;
242
+
243
+ switch (type) {
244
+ case 'heading':
245
+ newBlock = {
246
+ id,
247
+ type: 'heading',
248
+ source: '## New heading',
249
+ startLine: 0,
250
+ endLine: 0,
251
+ level: 2,
252
+ text: 'New heading',
253
+ };
254
+ break;
255
+ case 'paragraph':
256
+ newBlock = {
257
+ id,
258
+ type: 'paragraph',
259
+ source: 'New paragraph text.',
260
+ startLine: 0,
261
+ endLine: 0,
262
+ };
263
+ break;
264
+ case 'fence':
265
+ newBlock = {
266
+ id,
267
+ type: 'fence',
268
+ source: '```\n\n```',
269
+ startLine: 0,
270
+ endLine: 0,
271
+ language: '',
272
+ code: '',
273
+ };
274
+ break;
275
+ case 'hr':
276
+ newBlock = {
277
+ id,
278
+ type: 'hr',
279
+ source: '---',
280
+ startLine: 0,
281
+ endLine: 0,
282
+ };
283
+ break;
284
+ case 'rune': {
285
+ const name = runeName ?? 'hint';
286
+ const info = runeMap.get(name);
287
+ const selfClosing = info?.selfClosing ?? false;
288
+ // Pre-fill required attributes
289
+ const attrs: Record<string, string> = {};
290
+ if (info) {
291
+ for (const [attrName, attrInfo] of Object.entries(info.attributes)) {
292
+ if (attrInfo.required) {
293
+ attrs[attrName] = attrInfo.values?.[0] ?? '';
294
+ }
295
+ }
296
+ }
297
+ const attrStr = Object.entries(attrs)
298
+ .map(([k, v]) => `${k}="${v}"`)
299
+ .join(' ');
300
+ const attrPart = attrStr ? ' ' + attrStr : '';
301
+ if (selfClosing) {
302
+ newBlock = {
303
+ id,
304
+ type: 'rune',
305
+ source: `{% ${name}${attrPart} /%}`,
306
+ startLine: 0,
307
+ endLine: 0,
308
+ runeName: name,
309
+ selfClosing: true,
310
+ attributes: attrs,
311
+ innerContent: '',
312
+ };
313
+ } else {
314
+ const inner = info?.example ? extractRuneInner(info.example, name) : '';
315
+ newBlock = {
316
+ id,
317
+ type: 'rune',
318
+ source: `{% ${name}${attrPart} %}\n${inner}\n{% /${name} %}`,
319
+ startLine: 0,
320
+ endLine: 0,
321
+ runeName: name,
322
+ selfClosing: false,
323
+ attributes: attrs,
324
+ innerContent: inner,
325
+ };
326
+ }
327
+ break;
328
+ }
329
+ }
330
+
331
+ const pos = insertAtIndex ?? blocks.length;
332
+ blocks = [...blocks.slice(0, pos), newBlock, ...blocks.slice(pos)];
333
+ insertAtIndex = null;
334
+ showInsertMenu = false;
335
+ editingFrontmatter = false;
336
+ activeIndex = pos;
337
+ syncToSource();
338
+ }
339
+
340
+ // Group runes by category for the insert menu
341
+ let runesByCategory = $derived.by(() => {
342
+ const map = new Map<string, RuneInfo[]>();
343
+ for (const r of runes) {
344
+ const list = map.get(r.category) ?? [];
345
+ list.push(r);
346
+ map.set(r.category, list);
347
+ }
348
+ return map;
349
+ });
350
+ </script>
351
+
352
+ <svelte:window onkeydown={handleKeydown} onmousedown={handleClickOutside} />
353
+
354
+ <div class="block-editor">
355
+ {#if blocks.length === 0 && !readOnly}
356
+ <div class="block-editor__empty">
357
+ <svg class="block-editor__empty-icon" width="40" height="40" viewBox="0 0 48 48" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round">
358
+ <rect x="6" y="8" width="36" height="32" rx="3" />
359
+ <line x1="14" y1="18" x2="34" y2="18" />
360
+ <line x1="14" y1="24" x2="28" y2="24" />
361
+ <line x1="14" y1="30" x2="22" y2="30" />
362
+ </svg>
363
+ <span class="block-editor__empty-text">No content blocks yet</span>
364
+ <span class="block-editor__empty-hint">Click a + dot in the rail to add blocks</span>
365
+ </div>
366
+ {/if}
367
+
368
+ <div class="block-editor__stage" class:editing={!readOnly && (activeIndex !== null || editingFrontmatter)}>
369
+ <!-- Scrollable list + rail area -->
370
+ <div class="block-editor__scroll" class:has-rail={!readOnly}>
371
+ <div class="block-editor__list-wrap">
372
+ <!-- Frontmatter summary header (blocks mode only) -->
373
+ {#if !readOnly}
374
+ <div class="block-editor__fm-header">
375
+ <div class="block-editor__fm-info">
376
+ <span class="block-editor__fm-title">{fmTitle || 'Untitled'}</span>
377
+ {#if fmDesc()}
378
+ <span class="block-editor__fm-desc">{fmDesc()}</span>
379
+ {/if}
380
+ </div>
381
+ <button
382
+ class="block-editor__fm-edit"
383
+ class:active={editingFrontmatter}
384
+ onclick={toggleFrontmatter}
385
+ title="Edit frontmatter"
386
+ >
387
+ <svg width="14" height="14" viewBox="0 0 16 16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round">
388
+ <path d="M11.5 1.5l3 3L5 14H2v-3L11.5 1.5z" />
389
+ </svg>
390
+ Edit
391
+ </button>
392
+ </div>
393
+ {/if}
394
+
395
+ {#snippet insertMenuContent()}
396
+ <div class="insert-menu__section">
397
+ <span class="insert-menu__label">Content</span>
398
+ <div class="insert-menu__grid">
399
+ <button class="insert-menu__btn" onclick={() => insertBlock('heading')}>
400
+ <svg class="insert-menu__icon" width="14" height="14" viewBox="0 0 16 16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round">
401
+ <path d="M3 3v10M13 3v10M3 8h10" />
402
+ </svg>
403
+ Heading
404
+ </button>
405
+ <button class="insert-menu__btn" onclick={() => insertBlock('paragraph')}>
406
+ <svg class="insert-menu__icon" width="14" height="14" viewBox="0 0 16 16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round">
407
+ <line x1="2" y1="4" x2="14" y2="4" />
408
+ <line x1="2" y1="8" x2="14" y2="8" />
409
+ <line x1="2" y1="12" x2="10" y2="12" />
410
+ </svg>
411
+ Paragraph
412
+ </button>
413
+ <button class="insert-menu__btn" onclick={() => insertBlock('fence')}>
414
+ <svg class="insert-menu__icon" width="14" height="14" viewBox="0 0 16 16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round" stroke-linejoin="round">
415
+ <polyline points="5 4 2 8 5 12" />
416
+ <polyline points="11 4 14 8 11 12" />
417
+ </svg>
418
+ Code Block
419
+ </button>
420
+ <button class="insert-menu__btn" onclick={() => insertBlock('hr')}>
421
+ <svg class="insert-menu__icon" width="14" height="14" viewBox="0 0 16 16" fill="none" stroke="currentColor" stroke-width="1.5" stroke-linecap="round">
422
+ <line x1="2" y1="8" x2="14" y2="8" />
423
+ </svg>
424
+ Divider
425
+ </button>
426
+ </div>
427
+ </div>
428
+ {#each [...runesByCategory.entries()] as [category, categoryRunes]}
429
+ <div class="insert-menu__section">
430
+ <span class="insert-menu__label">{category}</span>
431
+ <div class="insert-menu__grid">
432
+ {#each categoryRunes as rune}
433
+ <button
434
+ class="insert-menu__btn insert-menu__btn--rune"
435
+ onclick={() => insertBlock('rune', rune.name)}
436
+ >
437
+ <span class="insert-menu__rune-dot"></span>
438
+ <span class="insert-menu__rune-info">
439
+ <span class="insert-menu__rune-name">{rune.name}</span>
440
+ {#if rune.description}
441
+ <span class="insert-menu__rune-desc">{rune.description}</span>
442
+ {/if}
443
+ </span>
444
+ </button>
445
+ {/each}
446
+ </div>
447
+ </div>
448
+ {/each}
449
+ <button class="insert-menu__close" onclick={closeInsertMenu}>&times; Close</button>
450
+ {/snippet}
451
+
452
+ {#snippet insertZone(pos: number)}
453
+ <div class="block-editor__insert-zone">
454
+ <div class="block-editor__insert-zone-spacer"></div>
455
+ <button
456
+ class="block-editor__insert-dot"
457
+ onclick={() => openInsertAt(pos)}
458
+ title="Insert block"
459
+ >
460
+ <span class="block-editor__dot-icon"></span>
461
+ </button>
462
+ {#if showInsertMenu && insertAtIndex === pos}
463
+ <div class="insert-menu insert-menu--floating">
464
+ {@render insertMenuContent()}
465
+ </div>
466
+ {/if}
467
+ </div>
468
+ {/snippet}
469
+
470
+ {#if !readOnly && showInsertMenuProp}
471
+ {@render insertZone(0)}
472
+ {/if}
473
+
474
+ {#each blocks as block, i (block.id)}
475
+ <div
476
+ class="block-editor__row"
477
+ class:drag-source={!readOnly && dragIndex === i}
478
+ class:drag-over={!readOnly && dropIndex === i && dragIndex !== i}
479
+ >
480
+ <div class="block-editor__block-cell">
481
+ <BlockCard
482
+ {block}
483
+ {themeConfig}
484
+ {themeCss}
485
+ {highlightCss}
486
+ {highlightTransform}
487
+ ondragstart={readOnly ? undefined : (e) => handleDragStart(e, i)}
488
+ ondragover={readOnly ? undefined : (e) => handleDragOver(e, i)}
489
+ ondrop={readOnly ? undefined : (e) => handleDrop(e, i)}
490
+ />
491
+ </div>
492
+ {#if !readOnly}
493
+ <button
494
+ class="block-editor__rail-label"
495
+ class:active={activeIndex === i}
496
+ onclick={() => toggleBlock(i)}
497
+ aria-pressed={activeIndex === i}
498
+ >
499
+ {blockLabel(block)}
500
+ </button>
501
+ {/if}
502
+ </div>
503
+ {#if !readOnly && showInsertMenuProp}
504
+ {@render insertZone(i + 1)}
505
+ {/if}
506
+ {/each}
507
+ </div>
508
+ </div>
509
+
510
+ <!-- Edit panel — slides in from the right (blocks mode only) -->
511
+ {#if !readOnly}
512
+ <div class="block-editor__edit-panel">
513
+ {#if editingFrontmatter}
514
+ <FrontmatterEditPanel
515
+ onclose={() => { editingFrontmatter = false; }}
516
+ />
517
+ {:else if activeIndex !== null && blocks[activeIndex]}
518
+ <BlockEditPanel
519
+ block={blocks[activeIndex]}
520
+ {runeMap}
521
+ runes={() => runes}
522
+ onupdate={(updated) => handleUpdateBlock(activeIndex!, updated)}
523
+ onremove={() => { const idx = activeIndex!; activeIndex = null; handleRemoveBlock(idx); }}
524
+ onclose={() => { activeIndex = null; }}
525
+ />
526
+ {/if}
527
+ </div>
528
+ {/if}
529
+ </div>
530
+ </div>
531
+
532
+
533
+ <style>
534
+ .block-editor {
535
+ flex: 1;
536
+ min-height: 0;
537
+ display: flex;
538
+ flex-direction: column;
539
+ }
540
+
541
+ /* Stage: flex container for scroll area + edit panel */
542
+ .block-editor__stage {
543
+ display: flex;
544
+ flex: 1;
545
+ min-height: 0;
546
+ overflow: hidden;
547
+ position: relative;
548
+ }
549
+
550
+ /* Scrollable block list + rail area */
551
+ .block-editor__scroll {
552
+ flex: 1;
553
+ min-height: 0;
554
+ display: flex;
555
+ flex-direction: column;
556
+ transition: margin-right var(--ed-transition-slow);
557
+ }
558
+
559
+ .block-editor__list-wrap {
560
+ width: 100%;
561
+ padding: var(--ed-space-4);
562
+ padding-right: 0;
563
+ flex: 1;
564
+ min-height: 0;
565
+ overflow-y: auto;
566
+ }
567
+
568
+ /* Rail column: vertical border + diagonal stripe background */
569
+ .block-editor__scroll.has-rail .block-editor__list-wrap {
570
+ background-origin: content-box;
571
+ background-clip: border-box;
572
+ background:
573
+ /* Vertical border at left edge of rail */
574
+ linear-gradient(to right,
575
+ transparent calc(100% - 91px),
576
+ var(--ed-border-default) calc(100% - 91px),
577
+ var(--ed-border-default) calc(100% - 90px),
578
+ transparent calc(100% - 90px)
579
+ ),
580
+ /* Solid background masking stripes in the content area */
581
+ linear-gradient(to right,
582
+ var(--ed-surface-0) calc(100% - 90px),
583
+ transparent calc(100% - 90px)
584
+ ),
585
+ /* Stripe pattern */
586
+ repeating-linear-gradient(
587
+ -45deg,
588
+ transparent,
589
+ transparent 4px,
590
+ rgba(0, 0, 0, 0.04) 4px,
591
+ rgba(0, 0, 0, 0.04) 5px
592
+ );
593
+ }
594
+
595
+ /* Frontmatter summary header */
596
+ .block-editor__fm-header {
597
+ display: flex;
598
+ align-items: center;
599
+ gap: var(--ed-space-3);
600
+ padding: var(--ed-space-3) var(--ed-space-4);
601
+ border-bottom: 1px solid var(--ed-border-subtle);
602
+ margin-bottom: var(--ed-space-2);
603
+ }
604
+
605
+ .block-editor__fm-info {
606
+ flex: 1;
607
+ min-width: 0;
608
+ display: flex;
609
+ flex-direction: column;
610
+ gap: 0.15rem;
611
+ }
612
+
613
+ .block-editor__fm-title {
614
+ font-size: var(--ed-text-md);
615
+ font-weight: 600;
616
+ color: var(--ed-text-primary);
617
+ overflow: hidden;
618
+ text-overflow: ellipsis;
619
+ white-space: nowrap;
620
+ }
621
+
622
+ .block-editor__fm-desc {
623
+ font-size: var(--ed-text-sm);
624
+ color: var(--ed-text-muted);
625
+ overflow: hidden;
626
+ text-overflow: ellipsis;
627
+ white-space: nowrap;
628
+ }
629
+
630
+ .block-editor__fm-edit {
631
+ display: flex;
632
+ align-items: center;
633
+ gap: var(--ed-space-1);
634
+ padding: var(--ed-space-1) var(--ed-space-2);
635
+ border: 1px solid var(--ed-border-default);
636
+ border-radius: var(--ed-radius-sm);
637
+ background: var(--ed-surface-0);
638
+ color: var(--ed-text-tertiary);
639
+ font-size: var(--ed-text-xs);
640
+ font-weight: 500;
641
+ cursor: pointer;
642
+ white-space: nowrap;
643
+ transition: color var(--ed-transition-fast), border-color var(--ed-transition-fast), background var(--ed-transition-fast);
644
+ flex-shrink: 0;
645
+ }
646
+
647
+ .block-editor__fm-edit:hover {
648
+ color: var(--ed-text-secondary);
649
+ border-color: var(--ed-border-strong);
650
+ }
651
+
652
+ .block-editor__fm-edit.active {
653
+ background: var(--ed-accent-muted);
654
+ border-color: var(--ed-accent);
655
+ color: var(--ed-accent);
656
+ }
657
+
658
+ /* Block row: preview cell + rail label */
659
+ .block-editor__row {
660
+ display: flex;
661
+ align-items: flex-start;
662
+ transition: transform var(--ed-transition-fast), opacity var(--ed-transition-fast);
663
+ }
664
+
665
+ .block-editor__block-cell {
666
+ flex: 1;
667
+ min-width: 0;
668
+ }
669
+
670
+ .block-editor__row.drag-source {
671
+ opacity: 0.6;
672
+ transform: rotate(0.5deg);
673
+ }
674
+
675
+ .block-editor__row.drag-over {
676
+ box-shadow: 0 -3px 10px var(--ed-accent-ring);
677
+ border-top: 2px solid var(--ed-accent);
678
+ padding-top: 2px;
679
+ }
680
+
681
+ /* Rail labels — aligned to the right of each block */
682
+ .block-editor__rail-label {
683
+ width: 80px;
684
+ flex-shrink: 0;
685
+ margin-left: var(--ed-space-5);
686
+ padding: 0.5rem 0.6rem 0.5rem 1rem;
687
+ font-size: 10px;
688
+ font-weight: 600;
689
+ color: var(--ed-text-muted);
690
+ text-transform: uppercase;
691
+ letter-spacing: 0.03em;
692
+ text-align: left;
693
+ background: transparent;
694
+ border: none;
695
+ cursor: pointer;
696
+ white-space: nowrap;
697
+ overflow: hidden;
698
+ text-overflow: ellipsis;
699
+ transition: color var(--ed-transition-fast);
700
+ align-self: stretch;
701
+ line-height: 1.3;
702
+ }
703
+
704
+ .block-editor__rail-label:hover {
705
+ color: var(--ed-text-secondary);
706
+ }
707
+
708
+ .block-editor__rail-label.active {
709
+ color: var(--ed-accent);
710
+ font-weight: 700;
711
+ }
712
+
713
+ /* Insert zones — between blocks in the rail */
714
+ .block-editor__insert-zone {
715
+ display: flex;
716
+ align-items: center;
717
+ height: 12px;
718
+ position: relative;
719
+ overflow: visible;
720
+ z-index: 2;
721
+ }
722
+
723
+ .block-editor__insert-zone-spacer {
724
+ flex: 1;
725
+ }
726
+
727
+ .block-editor__insert-dot {
728
+ width: 80px;
729
+ flex-shrink: 0;
730
+ margin-left: var(--ed-space-5);
731
+ display: flex;
732
+ align-items: center;
733
+ justify-content: flex-start;
734
+ border: none;
735
+ background: transparent;
736
+ cursor: pointer;
737
+ height: 100%;
738
+ padding: 0;
739
+ position: relative;
740
+ overflow: visible;
741
+ }
742
+
743
+ .block-editor__dot-icon {
744
+ position: absolute;
745
+ left: 1px;
746
+ top: 50%;
747
+ transform: translate(-50%, -50%);
748
+ width: 5px;
749
+ height: 5px;
750
+ border-radius: 50%;
751
+ background: var(--ed-text-muted);
752
+ transition: width var(--ed-transition-fast), height var(--ed-transition-fast), background var(--ed-transition-fast);
753
+ }
754
+
755
+ .block-editor__insert-dot:hover .block-editor__dot-icon {
756
+ width: 18px;
757
+ height: 18px;
758
+ background: var(--ed-accent);
759
+ }
760
+
761
+ .block-editor__dot-icon::before,
762
+ .block-editor__dot-icon::after {
763
+ content: '';
764
+ position: absolute;
765
+ background: white;
766
+ border-radius: 1px;
767
+ opacity: 0;
768
+ transition: opacity var(--ed-transition-fast);
769
+ }
770
+
771
+ .block-editor__dot-icon::before {
772
+ width: 10px;
773
+ height: 1.5px;
774
+ top: 50%;
775
+ left: 50%;
776
+ transform: translate(-50%, -50%);
777
+ }
778
+
779
+ .block-editor__dot-icon::after {
780
+ width: 1.5px;
781
+ height: 10px;
782
+ top: 50%;
783
+ left: 50%;
784
+ transform: translate(-50%, -50%);
785
+ }
786
+
787
+ .block-editor__insert-dot:hover .block-editor__dot-icon::before,
788
+ .block-editor__insert-dot:hover .block-editor__dot-icon::after {
789
+ opacity: 1;
790
+ }
791
+
792
+ /* Floating insert menu — anchored to the insert zone */
793
+ .insert-menu--floating {
794
+ position: absolute;
795
+ right: 0;
796
+ top: 100%;
797
+ z-index: 20;
798
+ width: 360px;
799
+ max-height: 400px;
800
+ overflow-y: auto;
801
+ }
802
+
803
+ /* Edit panel — fixed to right edge of viewport, outside the card */
804
+ .block-editor__edit-panel {
805
+ position: fixed;
806
+ top: 60px;
807
+ right: 0;
808
+ bottom: 0;
809
+ width: 480px;
810
+ overflow-y: auto;
811
+ background: var(--ed-surface-1);
812
+ border-left: 1px solid var(--ed-border-default);
813
+ transform: translateX(100%);
814
+ transition: transform var(--ed-transition-slow);
815
+ z-index: 10;
816
+ }
817
+
818
+ .block-editor__stage.editing .block-editor__edit-panel {
819
+ transform: translateX(0);
820
+ }
821
+
822
+ /* Empty state */
823
+ .block-editor__empty {
824
+ display: flex;
825
+ flex-direction: column;
826
+ align-items: center;
827
+ justify-content: center;
828
+ padding: 3rem 2rem;
829
+ gap: var(--ed-space-2);
830
+ }
831
+
832
+ .block-editor__empty-icon {
833
+ color: var(--ed-border-strong);
834
+ margin-bottom: var(--ed-space-1);
835
+ }
836
+
837
+ .block-editor__empty-text {
838
+ color: var(--ed-text-secondary);
839
+ font-size: var(--ed-text-md);
840
+ font-weight: 500;
841
+ }
842
+
843
+ .block-editor__empty-hint {
844
+ color: var(--ed-text-muted);
845
+ font-size: var(--ed-text-sm);
846
+ }
847
+
848
+ /* Insert menu (shared between floating and any future inline) */
849
+ .insert-menu {
850
+ border: 1px solid var(--ed-border-default);
851
+ border-radius: 10px;
852
+ background: var(--ed-surface-0);
853
+ padding: var(--ed-space-4);
854
+ display: flex;
855
+ flex-direction: column;
856
+ gap: var(--ed-space-3);
857
+ box-shadow: var(--ed-shadow-lg);
858
+ animation: menu-enter var(--ed-transition-normal);
859
+ }
860
+
861
+ @keyframes menu-enter {
862
+ from { opacity: 0; transform: translateY(4px); }
863
+ to { opacity: 1; transform: translateY(0); }
864
+ }
865
+
866
+ .insert-menu__section {
867
+ display: flex;
868
+ flex-direction: column;
869
+ gap: 0.4rem;
870
+ }
871
+
872
+ .insert-menu__label {
873
+ font-size: var(--ed-text-xs);
874
+ font-weight: 600;
875
+ color: var(--ed-text-muted);
876
+ text-transform: uppercase;
877
+ letter-spacing: 0.05em;
878
+ }
879
+
880
+ .insert-menu__grid {
881
+ display: grid;
882
+ grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
883
+ gap: 0.35rem;
884
+ }
885
+
886
+ .insert-menu__btn {
887
+ display: flex;
888
+ align-items: center;
889
+ gap: 0.4rem;
890
+ padding: var(--ed-space-2) var(--ed-space-2);
891
+ border: 1px solid var(--ed-border-default);
892
+ border-radius: var(--ed-radius-sm);
893
+ background: var(--ed-surface-1);
894
+ color: var(--ed-text-secondary);
895
+ font-size: var(--ed-text-sm);
896
+ cursor: pointer;
897
+ transition: background var(--ed-transition-fast), border-color var(--ed-transition-fast);
898
+ text-align: left;
899
+ }
900
+
901
+ .insert-menu__btn:hover {
902
+ background: var(--ed-accent-muted);
903
+ border-color: var(--ed-accent);
904
+ color: var(--ed-heading);
905
+ }
906
+
907
+ .insert-menu__icon {
908
+ flex-shrink: 0;
909
+ opacity: 0.6;
910
+ }
911
+
912
+ /* Rune buttons */
913
+ .insert-menu__btn--rune {
914
+ align-items: flex-start;
915
+ padding: var(--ed-space-2);
916
+ }
917
+
918
+ .insert-menu__rune-dot {
919
+ width: 6px;
920
+ height: 6px;
921
+ border-radius: 50%;
922
+ background: var(--ed-warning);
923
+ flex-shrink: 0;
924
+ margin-top: 0.3rem;
925
+ }
926
+
927
+ .insert-menu__rune-info {
928
+ display: flex;
929
+ flex-direction: column;
930
+ gap: 0.15rem;
931
+ min-width: 0;
932
+ }
933
+
934
+ .insert-menu__rune-name {
935
+ font-weight: 500;
936
+ }
937
+
938
+ .insert-menu__rune-desc {
939
+ font-size: 10px;
940
+ color: var(--ed-text-muted);
941
+ overflow: hidden;
942
+ text-overflow: ellipsis;
943
+ white-space: nowrap;
944
+ }
945
+
946
+ .insert-menu__btn--rune:hover {
947
+ background: var(--ed-warning-subtle);
948
+ border-color: var(--ed-warning);
949
+ }
950
+
951
+ .insert-menu__close {
952
+ align-self: flex-end;
953
+ padding: var(--ed-space-1) var(--ed-space-2);
954
+ border: none;
955
+ border-radius: var(--ed-radius-sm);
956
+ background: transparent;
957
+ color: var(--ed-text-muted);
958
+ font-size: var(--ed-text-sm);
959
+ cursor: pointer;
960
+ transition: background var(--ed-transition-fast), color var(--ed-transition-fast);
961
+ }
962
+
963
+ .insert-menu__close:hover {
964
+ background: var(--ed-surface-2);
965
+ color: var(--ed-text-secondary);
966
+ }
967
+ </style>