@nikcli-ai/app 0.0.6
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.
- package/.turbo/turbo-build.log +661 -0
- package/.turbo/turbo-typecheck.log +1 -0
- package/AGENTS.md +30 -0
- package/README.md +51 -0
- package/dist/_headers +17 -0
- package/dist/apple-touch-icon-v3.png +0 -0
- package/dist/apple-touch-icon.png +0 -0
- package/dist/assets/BlexMonoNerdFontMono-Bold-B8jzonSj.woff2 +0 -0
- package/dist/assets/BlexMonoNerdFontMono-Medium-BvtJB5kd.woff2 +0 -0
- package/dist/assets/BlexMonoNerdFontMono-Regular-DSJ7IWr2.woff2 +0 -0
- package/dist/assets/CaskaydiaCoveNerdFontMono-Bold-CxABrWmj.woff2 +0 -0
- package/dist/assets/CaskaydiaCoveNerdFontMono-Regular-C_H0OSLN.woff2 +0 -0
- package/dist/assets/FiraCodeNerdFontMono-Bold-BjAeM3gJ.woff2 +0 -0
- package/dist/assets/FiraCodeNerdFontMono-Regular-io3c92n9.woff2 +0 -0
- package/dist/assets/HackNerdFontMono-Bold-BNG4kp7w.woff2 +0 -0
- package/dist/assets/HackNerdFontMono-Regular-IcpSchWC.woff2 +0 -0
- package/dist/assets/InconsolataNerdFontMono-Bold-oTRjQesI.woff2 +0 -0
- package/dist/assets/InconsolataNerdFontMono-Regular-CRHGEvh2.woff2 +0 -0
- package/dist/assets/IntoneMonoNerdFontMono-Bold-BL6LrHzx.woff2 +0 -0
- package/dist/assets/IntoneMonoNerdFontMono-Regular-BwjBdmsJ.woff2 +0 -0
- package/dist/assets/JetBrainsMonoNerdFontMono-Bold-CU80ifuM.woff2 +0 -0
- package/dist/assets/JetBrainsMonoNerdFontMono-Regular-QVq88ZfU.woff2 +0 -0
- package/dist/assets/KaTeX_AMS-Regular-BQhdFMY1.woff2 +0 -0
- package/dist/assets/KaTeX_AMS-Regular-DMm9YOAa.woff +0 -0
- package/dist/assets/KaTeX_AMS-Regular-DRggAlZN.ttf +0 -0
- package/dist/assets/KaTeX_Caligraphic-Bold-ATXxdsX0.ttf +0 -0
- package/dist/assets/KaTeX_Caligraphic-Bold-BEiXGLvX.woff +0 -0
- package/dist/assets/KaTeX_Caligraphic-Bold-Dq_IR9rO.woff2 +0 -0
- package/dist/assets/KaTeX_Caligraphic-Regular-CTRA-rTL.woff +0 -0
- package/dist/assets/KaTeX_Caligraphic-Regular-Di6jR-x-.woff2 +0 -0
- package/dist/assets/KaTeX_Caligraphic-Regular-wX97UBjC.ttf +0 -0
- package/dist/assets/KaTeX_Fraktur-Bold-BdnERNNW.ttf +0 -0
- package/dist/assets/KaTeX_Fraktur-Bold-BsDP51OF.woff +0 -0
- package/dist/assets/KaTeX_Fraktur-Bold-CL6g_b3V.woff2 +0 -0
- package/dist/assets/KaTeX_Fraktur-Regular-CB_wures.ttf +0 -0
- package/dist/assets/KaTeX_Fraktur-Regular-CTYiF6lA.woff2 +0 -0
- package/dist/assets/KaTeX_Fraktur-Regular-Dxdc4cR9.woff +0 -0
- package/dist/assets/KaTeX_Main-Bold-Cx986IdX.woff2 +0 -0
- package/dist/assets/KaTeX_Main-Bold-Jm3AIy58.woff +0 -0
- package/dist/assets/KaTeX_Main-Bold-waoOVXN0.ttf +0 -0
- package/dist/assets/KaTeX_Main-BoldItalic-DxDJ3AOS.woff2 +0 -0
- package/dist/assets/KaTeX_Main-BoldItalic-DzxPMmG6.ttf +0 -0
- package/dist/assets/KaTeX_Main-BoldItalic-SpSLRI95.woff +0 -0
- package/dist/assets/KaTeX_Main-Italic-3WenGoN9.ttf +0 -0
- package/dist/assets/KaTeX_Main-Italic-BMLOBm91.woff +0 -0
- package/dist/assets/KaTeX_Main-Italic-NWA7e6Wa.woff2 +0 -0
- package/dist/assets/KaTeX_Main-Regular-B22Nviop.woff2 +0 -0
- package/dist/assets/KaTeX_Main-Regular-Dr94JaBh.woff +0 -0
- package/dist/assets/KaTeX_Main-Regular-ypZvNtVU.ttf +0 -0
- package/dist/assets/KaTeX_Math-BoldItalic-B3XSjfu4.ttf +0 -0
- package/dist/assets/KaTeX_Math-BoldItalic-CZnvNsCZ.woff2 +0 -0
- package/dist/assets/KaTeX_Math-BoldItalic-iY-2wyZ7.woff +0 -0
- package/dist/assets/KaTeX_Math-Italic-DA0__PXp.woff +0 -0
- package/dist/assets/KaTeX_Math-Italic-flOr_0UB.ttf +0 -0
- package/dist/assets/KaTeX_Math-Italic-t53AETM-.woff2 +0 -0
- package/dist/assets/KaTeX_SansSerif-Bold-CFMepnvq.ttf +0 -0
- package/dist/assets/KaTeX_SansSerif-Bold-D1sUS0GD.woff2 +0 -0
- package/dist/assets/KaTeX_SansSerif-Bold-DbIhKOiC.woff +0 -0
- package/dist/assets/KaTeX_SansSerif-Italic-C3H0VqGB.woff2 +0 -0
- package/dist/assets/KaTeX_SansSerif-Italic-DN2j7dab.woff +0 -0
- package/dist/assets/KaTeX_SansSerif-Italic-YYjJ1zSn.ttf +0 -0
- package/dist/assets/KaTeX_SansSerif-Regular-BNo7hRIc.ttf +0 -0
- package/dist/assets/KaTeX_SansSerif-Regular-CS6fqUqJ.woff +0 -0
- package/dist/assets/KaTeX_SansSerif-Regular-DDBCnlJ7.woff2 +0 -0
- package/dist/assets/KaTeX_Script-Regular-C5JkGWo-.ttf +0 -0
- package/dist/assets/KaTeX_Script-Regular-D3wIWfF6.woff2 +0 -0
- package/dist/assets/KaTeX_Script-Regular-D5yQViql.woff +0 -0
- package/dist/assets/KaTeX_Size1-Regular-C195tn64.woff +0 -0
- package/dist/assets/KaTeX_Size1-Regular-Dbsnue_I.ttf +0 -0
- package/dist/assets/KaTeX_Size1-Regular-mCD8mA8B.woff2 +0 -0
- package/dist/assets/KaTeX_Size2-Regular-B7gKUWhC.ttf +0 -0
- package/dist/assets/KaTeX_Size2-Regular-Dy4dx90m.woff2 +0 -0
- package/dist/assets/KaTeX_Size2-Regular-oD1tc_U0.woff +0 -0
- package/dist/assets/KaTeX_Size3-Regular-CTq5MqoE.woff +0 -0
- package/dist/assets/KaTeX_Size3-Regular-DgpXs0kz.ttf +0 -0
- package/dist/assets/KaTeX_Size4-Regular-BF-4gkZK.woff +0 -0
- package/dist/assets/KaTeX_Size4-Regular-DWFBv043.ttf +0 -0
- package/dist/assets/KaTeX_Size4-Regular-Dl5lxZxV.woff2 +0 -0
- package/dist/assets/KaTeX_Typewriter-Regular-C0xS9mPB.woff +0 -0
- package/dist/assets/KaTeX_Typewriter-Regular-CO6r4hn1.woff2 +0 -0
- package/dist/assets/KaTeX_Typewriter-Regular-D3Ib7_Hf.ttf +0 -0
- package/dist/assets/MesloLGSNerdFontMono-Bold-CrpVO3ec.woff2 +0 -0
- package/dist/assets/MesloLGSNerdFontMono-Regular-j-nTZDWZ.woff2 +0 -0
- package/dist/assets/RobotoMonoNerdFontMono-Bold-DNxuDepp.woff2 +0 -0
- package/dist/assets/RobotoMonoNerdFontMono-Regular-DvxS3QZC.woff2 +0 -0
- package/dist/assets/SauceCodeProNerdFontMono-Bold-DloEeUVQ.woff2 +0 -0
- package/dist/assets/SauceCodeProNerdFontMono-Regular-Ba96Bdne.woff2 +0 -0
- package/dist/assets/UbuntuMonoNerdFontMono-Bold-wLXUURqB.woff2 +0 -0
- package/dist/assets/UbuntuMonoNerdFontMono-Regular-tdnXLyap.woff2 +0 -0
- package/dist/assets/abap-BXYWi5l2.js +1 -0
- package/dist/assets/abap-BdImnpbu.js +1 -0
- package/dist/assets/actionscript-3-CfeIJUat.js +1 -0
- package/dist/assets/actionscript-3-LjD3sNyx.js +1 -0
- package/dist/assets/ada-DeReRNhg.js +1 -0
- package/dist/assets/ada-bCR0ucgS.js +1 -0
- package/dist/assets/alert-01-BuOD_o_q.aac +0 -0
- package/dist/assets/alert-02-CS75AsoP.aac +0 -0
- package/dist/assets/alert-04-CaGsIGFP.aac +0 -0
- package/dist/assets/alert-05-D2gbGoRH.aac +0 -0
- package/dist/assets/alert-06-GK5Tqy6u.aac +0 -0
- package/dist/assets/alert-07-0r0kiLGz.aac +0 -0
- package/dist/assets/alert-08-CZowNquU.aac +0 -0
- package/dist/assets/alert-10-Ck5hR7zH.aac +0 -0
- package/dist/assets/android-studio-D0DqtVA4.svg +1 -0
- package/dist/assets/andromeeda-C-Jbm3Hp.js +1 -0
- package/dist/assets/angular-html-6NEUuZou.js +1 -0
- package/dist/assets/angular-html-CU67Zn6k.js +1 -0
- package/dist/assets/angular-ts-BfBSdvnY.js +1 -0
- package/dist/assets/angular-ts-BwZT4LLn.js +1 -0
- package/dist/assets/antigravity-XfClf80L.svg +1 -0
- package/dist/assets/apache-CCUDgqAf.js +1 -0
- package/dist/assets/apache-Pmp26Uib.js +1 -0
- package/dist/assets/apex-DDbsPZ6N.js +1 -0
- package/dist/assets/apex-ynV6aGfE.js +1 -0
- package/dist/assets/apl-C-KxP0FL.js +1 -0
- package/dist/assets/apl-dKokRX4l.js +1 -0
- package/dist/assets/applescript-Co6uUVPk.js +1 -0
- package/dist/assets/applescript-Dd26Nb5t.js +1 -0
- package/dist/assets/ara-BRHolxvo.js +1 -0
- package/dist/assets/ara-D6vCOKVX.js +1 -0
- package/dist/assets/asciidoc-DZ9uQOoP.js +1 -0
- package/dist/assets/asciidoc-Dv7Oe6Be.js +1 -0
- package/dist/assets/asm-CbVMAfFB.js +1 -0
- package/dist/assets/asm-D_Q5rh1f.js +1 -0
- package/dist/assets/astro-CbQHKStN.js +1 -0
- package/dist/assets/astro-OEl6i-aI.js +1 -0
- package/dist/assets/aurora-x-D-2ljcwZ.js +1 -0
- package/dist/assets/awk-DMzUqQB5.js +1 -0
- package/dist/assets/awk-UmR4Ublb.js +1 -0
- package/dist/assets/ayu-dark-Cv9koXgw.js +1 -0
- package/dist/assets/ballerina-BFfxhgS-.js +1 -0
- package/dist/assets/ballerina-BMbY-1wP.js +1 -0
- package/dist/assets/bat-BkioyH1T.js +1 -0
- package/dist/assets/bat-Dcnh2ot_.js +1 -0
- package/dist/assets/beancount-B92nBv9q.js +1 -0
- package/dist/assets/beancount-k_qm7-4y.js +1 -0
- package/dist/assets/berry-C9fz7p0n.js +1 -0
- package/dist/assets/berry-uYugtg8r.js +1 -0
- package/dist/assets/bibtex-CHM0blh-.js +1 -0
- package/dist/assets/bibtex-DELXwv0g.js +1 -0
- package/dist/assets/bicep-Bmn6On1c.js +1 -0
- package/dist/assets/bicep-D2njIRU5.js +1 -0
- package/dist/assets/bip-bop-03-DXp7Zb0f.aac +0 -0
- package/dist/assets/bip-bop-04-CfVtpI7z.aac +0 -0
- package/dist/assets/bip-bop-06-BuvNosjK.aac +0 -0
- package/dist/assets/bip-bop-08-DBf7Bwjz.aac +0 -0
- package/dist/assets/bip-bop-09-CxEgoAHQ.aac +0 -0
- package/dist/assets/blade-CwZbp2Ca.js +1 -0
- package/dist/assets/blade-DVc8C-J4.js +1 -0
- package/dist/assets/bsl-BO_Y6i37.js +1 -0
- package/dist/assets/bsl-C4qeDxuX.js +1 -0
- package/dist/assets/c-BIGW1oBm.js +1 -0
- package/dist/assets/c-CyUOlKFr.js +1 -0
- package/dist/assets/cadence-Bv_4Rxtq.js +1 -0
- package/dist/assets/cadence-bIHbUj02.js +1 -0
- package/dist/assets/cairo-C_mOTUpN.js +1 -0
- package/dist/assets/cairo-KRGpt6FW.js +1 -0
- package/dist/assets/catppuccin-frappe-DFWUc33u.js +1 -0
- package/dist/assets/catppuccin-latte-C9dUb6Cb.js +1 -0
- package/dist/assets/catppuccin-macchiato-DQyhUUbL.js +1 -0
- package/dist/assets/catppuccin-mocha-D87Tk5Gz.js +1 -0
- package/dist/assets/clarity-A4x-rz24.js +1 -0
- package/dist/assets/clarity-D53aC0YG.js +1 -0
- package/dist/assets/clojure-Bb2-3A0I.js +1 -0
- package/dist/assets/clojure-P80f7IUj.js +1 -0
- package/dist/assets/cmake-Cv5ljclQ.js +1 -0
- package/dist/assets/cmake-D1j8_8rp.js +1 -0
- package/dist/assets/cobol-Cg3yRVOY.js +1 -0
- package/dist/assets/cobol-nwyudZeR.js +1 -0
- package/dist/assets/codeowners-Bp6g37R7.js +1 -0
- package/dist/assets/codeowners-CKT8dJip.js +1 -0
- package/dist/assets/codeql-DXd8ggn3.js +1 -0
- package/dist/assets/codeql-DsOJ9woJ.js +1 -0
- package/dist/assets/coffee-CSg58a7P.js +1 -0
- package/dist/assets/coffee-Ch7k5sss.js +1 -0
- package/dist/assets/common-lisp-Cg-RD9OK.js +1 -0
- package/dist/assets/common-lisp-v102bg8X.js +1 -0
- package/dist/assets/coq-CxCehFeR.js +1 -0
- package/dist/assets/coq-DkFqJrB1.js +1 -0
- package/dist/assets/cpp-C28rag7_.js +1 -0
- package/dist/assets/cpp-CofmeUqb.js +1 -0
- package/dist/assets/crystal-kLfOnxTY.js +1 -0
- package/dist/assets/crystal-tKQVLTB8.js +1 -0
- package/dist/assets/csharp-DFQpaWb6.js +1 -0
- package/dist/assets/csharp-K5feNrxe.js +1 -0
- package/dist/assets/css-BSK200cd.js +1 -0
- package/dist/assets/css-DPfMkruS.js +1 -0
- package/dist/assets/csv-AZNL9t8Q.js +1 -0
- package/dist/assets/csv-fuZLfV_i.js +1 -0
- package/dist/assets/cue-D82EKSYY.js +1 -0
- package/dist/assets/cue-nzsbQn5T.js +1 -0
- package/dist/assets/cypher-BM7Pwunj.js +1 -0
- package/dist/assets/cypher-COkxafJQ.js +1 -0
- package/dist/assets/d-85-TOEBH.js +1 -0
- package/dist/assets/d-TG9YRPoI.js +1 -0
- package/dist/assets/dark-plus-C3mMm8J8.js +1 -0
- package/dist/assets/dart-CF10PKvl.js +1 -0
- package/dist/assets/dart-DArdxSyj.js +1 -0
- package/dist/assets/dax-B28Cho4e.js +1 -0
- package/dist/assets/dax-CEL-wOlO.js +1 -0
- package/dist/assets/desktop-BmXAJ9_W.js +1 -0
- package/dist/assets/desktop-Z9LhWKWr.js +1 -0
- package/dist/assets/diff-BlzBhZx2.js +1 -0
- package/dist/assets/diff-D97Zzqfu.js +1 -0
- package/dist/assets/docker-BcOcwvcX.js +1 -0
- package/dist/assets/docker-DIG_IqVK.js +1 -0
- package/dist/assets/dotenv-Bf0GLMGc.js +1 -0
- package/dist/assets/dotenv-Da5cRb03.js +1 -0
- package/dist/assets/dracula-BzJJZx-M.js +1 -0
- package/dist/assets/dracula-soft-BXkSAIEj.js +1 -0
- package/dist/assets/dream-maker-BtqSS_iP.js +1 -0
- package/dist/assets/dream-maker-DBhfoDN-.js +1 -0
- package/dist/assets/edge-BkV0erSs.js +1 -0
- package/dist/assets/edge-C9mkmEUa.js +1 -0
- package/dist/assets/elixir-B1OcFvXE.js +1 -0
- package/dist/assets/elixir-CDX3lj18.js +1 -0
- package/dist/assets/elm-BX_9EnK8.js +1 -0
- package/dist/assets/elm-DbKCFpqz.js +1 -0
- package/dist/assets/emacs-lisp-C9XAeP06.js +1 -0
- package/dist/assets/emacs-lisp-fXIB3QbG.js +1 -0
- package/dist/assets/erb-BOJIQeun.js +1 -0
- package/dist/assets/erb-CjsbKF3w.js +1 -0
- package/dist/assets/erlang-Dh270pQQ.js +1 -0
- package/dist/assets/erlang-DsQrWhSR.js +1 -0
- package/dist/assets/everforest-dark-BgDCqdQA.js +1 -0
- package/dist/assets/everforest-light-C8M2exoo.js +1 -0
- package/dist/assets/fennel-BYunw83y.js +1 -0
- package/dist/assets/fennel-CKW7gc4E.js +1 -0
- package/dist/assets/finder-CGxGn0h3.png +0 -0
- package/dist/assets/fish-BiaFC76h.js +1 -0
- package/dist/assets/fish-BvzEVeQv.js +1 -0
- package/dist/assets/fluent-C1VbA1FI.js +1 -0
- package/dist/assets/fluent-C4IJs8-o.js +1 -0
- package/dist/assets/fortran-fixed-form-BZjJHVRy.js +1 -0
- package/dist/assets/fortran-fixed-form-VBUom2Po.js +1 -0
- package/dist/assets/fortran-free-form-D22FLkUw.js +1 -0
- package/dist/assets/fortran-free-form-xZZnushS.js +1 -0
- package/dist/assets/fsharp-B6CigNpP.js +1 -0
- package/dist/assets/fsharp-CXgrBDvD.js +1 -0
- package/dist/assets/gdresource-B57lXvxj.js +1 -0
- package/dist/assets/gdresource-B7Tvp0Sc.js +1 -0
- package/dist/assets/gdscript-DTMYz4Jt.js +1 -0
- package/dist/assets/gdscript-etqGfJNh.js +1 -0
- package/dist/assets/gdshader-DkwncUOv.js +1 -0
- package/dist/assets/gdshader-MbeiIFWW.js +1 -0
- package/dist/assets/genie-CTXGoN_z.js +1 -0
- package/dist/assets/genie-D0YGMca9.js +1 -0
- package/dist/assets/gherkin-DQeIZrj7.js +1 -0
- package/dist/assets/gherkin-DyxjwDmM.js +1 -0
- package/dist/assets/ghostty-web-CsYhFgbJ.js +13 -0
- package/dist/assets/git-commit-BicZTByO.js +1 -0
- package/dist/assets/git-commit-F4YmCXRG.js +1 -0
- package/dist/assets/git-rebase-Bzlpfr7M.js +1 -0
- package/dist/assets/git-rebase-r7XF79zn.js +1 -0
- package/dist/assets/github-dark-DHJKELXO.js +1 -0
- package/dist/assets/github-dark-default-Cuk6v7N8.js +1 -0
- package/dist/assets/github-dark-dimmed-DH5Ifo-i.js +1 -0
- package/dist/assets/github-dark-high-contrast-E3gJ1_iC.js +1 -0
- package/dist/assets/github-light-DAi9KRSo.js +1 -0
- package/dist/assets/github-light-default-D7oLnXFd.js +1 -0
- package/dist/assets/github-light-high-contrast-BfjtVDDH.js +1 -0
- package/dist/assets/gleam-B-IqXlZK.js +1 -0
- package/dist/assets/gleam-BspZqrRM.js +1 -0
- package/dist/assets/glimmer-js-Rg0-pVw9.js +1 -0
- package/dist/assets/glimmer-js-cZi37nA1.js +1 -0
- package/dist/assets/glimmer-ts-BY3QTAW9.js +1 -0
- package/dist/assets/glimmer-ts-U6CK756n.js +1 -0
- package/dist/assets/glsl-Bk7TyU8J.js +1 -0
- package/dist/assets/glsl-DplSGwfg.js +1 -0
- package/dist/assets/gnuplot-BBjkHhdK.js +1 -0
- package/dist/assets/gnuplot-DdkO51Og.js +1 -0
- package/dist/assets/go-BYCC9JQ2.js +1 -0
- package/dist/assets/go-Dn2_MT6a.js +1 -0
- package/dist/assets/graphql-By4-2MiP.js +1 -0
- package/dist/assets/graphql-ChdNCCLP.js +1 -0
- package/dist/assets/groovy-DjMbfbx0.js +1 -0
- package/dist/assets/groovy-gcz8RCvz.js +1 -0
- package/dist/assets/gruvbox-dark-hard-CFHQjOhq.js +1 -0
- package/dist/assets/gruvbox-dark-medium-GsRaNv29.js +1 -0
- package/dist/assets/gruvbox-dark-soft-CVdnzihN.js +1 -0
- package/dist/assets/gruvbox-light-hard-CH1njM8p.js +1 -0
- package/dist/assets/gruvbox-light-medium-DRw_LuNl.js +1 -0
- package/dist/assets/gruvbox-light-soft-hJgmCMqR.js +1 -0
- package/dist/assets/hack-CaT9iCJl.js +1 -0
- package/dist/assets/hack-Ce3HFLQu.js +1 -0
- package/dist/assets/haml-B8DHNrY2.js +1 -0
- package/dist/assets/haml-C-C08OMF.js +1 -0
- package/dist/assets/handlebars-BFxKmXBZ.js +1 -0
- package/dist/assets/handlebars-BL8al0AC.js +1 -0
- package/dist/assets/haskell-Df6bDoY_.js +1 -0
- package/dist/assets/haskell-DtebQ3Kv.js +1 -0
- package/dist/assets/haxe-CzTSHFRz.js +1 -0
- package/dist/assets/haxe-n0Q_eay_.js +1 -0
- package/dist/assets/hcl-BWvSN4gD.js +1 -0
- package/dist/assets/hcl-shhv74hy.js +1 -0
- package/dist/assets/hjson-BEMFYqr7.js +1 -0
- package/dist/assets/hjson-D5-asLiD.js +1 -0
- package/dist/assets/hlsl-D3lLCCz7.js +1 -0
- package/dist/assets/hlsl-Pefxhtaj.js +1 -0
- package/dist/assets/home-DDFZTO3p.js +1 -0
- package/dist/assets/houston-DnULxvSX.js +1 -0
- package/dist/assets/html-DBrZJmtb.js +1 -0
- package/dist/assets/html-GMplVEZG.js +1 -0
- package/dist/assets/html-derivative-BFtXZ54Q.js +1 -0
- package/dist/assets/html-derivative-DgyNW28a.js +1 -0
- package/dist/assets/http-D0p2QOuJ.js +1 -0
- package/dist/assets/http-jrhK8wxY.js +1 -0
- package/dist/assets/hurl-CeF7EoTQ.js +1 -0
- package/dist/assets/hurl-irOxFIW8.js +1 -0
- package/dist/assets/hxml-B_SuSTPP.js +1 -0
- package/dist/assets/hxml-Bvhsp5Yf.js +1 -0
- package/dist/assets/hy-CTpXmg0M.js +1 -0
- package/dist/assets/hy-DFXneXwc.js +1 -0
- package/dist/assets/imba-DGztddWO.js +1 -0
- package/dist/assets/imba-z_cUhu9e.js +1 -0
- package/dist/assets/index-D0jX0BNw.js +1844 -0
- package/dist/assets/index-DDCRe3lm.css +1 -0
- package/dist/assets/ini-BEwlwnbL.js +1 -0
- package/dist/assets/ini-DOGW4-0C.js +1 -0
- package/dist/assets/inter-FIwubZjA.woff2 +0 -0
- package/dist/assets/iosevka-nerd-font-DKH7rjGs.woff2 +0 -0
- package/dist/assets/iosevka-nerd-font-bold-BObfzjZJ.woff2 +0 -0
- package/dist/assets/java-B2AjWfgk.js +1 -0
- package/dist/assets/java-CylS5w8V.js +1 -0
- package/dist/assets/javascript-XPxc2APE.js +1 -0
- package/dist/assets/javascript-wDzz0qaB.js +1 -0
- package/dist/assets/jinja-4LBKfQ-Z.js +1 -0
- package/dist/assets/jinja-DlBE7Xgz.js +1 -0
- package/dist/assets/jison-DRGa8fbr.js +1 -0
- package/dist/assets/jison-wvAkD_A8.js +1 -0
- package/dist/assets/json-CjLXzM_z.js +1 -0
- package/dist/assets/json-Cp-IABpG.js +1 -0
- package/dist/assets/json5-C9tS-k6U.js +1 -0
- package/dist/assets/json5-DE06a0U2.js +1 -0
- package/dist/assets/jsonc-BYi4HS05.js +1 -0
- package/dist/assets/jsonc-Des-eS-w.js +1 -0
- package/dist/assets/jsonl-CuhIcKDk.js +1 -0
- package/dist/assets/jsonl-DcaNXYhu.js +1 -0
- package/dist/assets/jsonnet-DFQXde-d.js +1 -0
- package/dist/assets/jsonnet-DtQdHwK-.js +1 -0
- package/dist/assets/jssm-BlhucWo7.js +1 -0
- package/dist/assets/jssm-C2t-YnRu.js +1 -0
- package/dist/assets/jsx-BGEKFWBk.js +1 -0
- package/dist/assets/jsx-g9-lgVsj.js +1 -0
- package/dist/assets/julia-Bh5qjrIj.js +1 -0
- package/dist/assets/julia-C8NyazO9.js +1 -0
- package/dist/assets/kanagawa-dragon-CkXjmgJE.js +1 -0
- package/dist/assets/kanagawa-lotus-CfQXZHmo.js +1 -0
- package/dist/assets/kanagawa-wave-DWedfzmr.js +1 -0
- package/dist/assets/kdl-DJsF4U57.js +1 -0
- package/dist/assets/kdl-DV7GczEv.js +1 -0
- package/dist/assets/kotlin-BdnUsdx6.js +1 -0
- package/dist/assets/kotlin-DwKqsDKK.js +1 -0
- package/dist/assets/kusto-BvAqAH-y.js +1 -0
- package/dist/assets/kusto-w7PrLrBe.js +1 -0
- package/dist/assets/laserwave-DUszq2jm.js +1 -0
- package/dist/assets/latex-BdAV_C_H.js +1 -0
- package/dist/assets/latex-BuzO6rjU.js +1 -0
- package/dist/assets/lean-Bc6EcWN3.js +1 -0
- package/dist/assets/lean-Dle5D8N4.js +1 -0
- package/dist/assets/less-B1dDrJ26.js +1 -0
- package/dist/assets/less-C76OjOdF.js +1 -0
- package/dist/assets/light-plus-B7mTdjB0.js +1 -0
- package/dist/assets/liquid-DYVedYrR.js +1 -0
- package/dist/assets/liquid-DdraCjph.js +1 -0
- package/dist/assets/llvm-BtvRca6l.js +1 -0
- package/dist/assets/llvm-s1WuUfOe.js +1 -0
- package/dist/assets/log-2UxHyX5q.js +1 -0
- package/dist/assets/log-CbW7hOWU.js +1 -0
- package/dist/assets/logo-BbooMuDm.js +1 -0
- package/dist/assets/logo-BtOb2qkB.js +1 -0
- package/dist/assets/lua-BbnMAYS6.js +1 -0
- package/dist/assets/lua-tkfysgZP.js +1 -0
- package/dist/assets/luau-CBwFb-vO.js +1 -0
- package/dist/assets/luau-CXu1NL6O.js +1 -0
- package/dist/assets/make-CHLpvVh8.js +1 -0
- package/dist/assets/make-s9FKP0VE.js +1 -0
- package/dist/assets/markdown-CKXSK5AY.js +1 -0
- package/dist/assets/markdown-Cvjx9yec.js +1 -0
- package/dist/assets/marko-BsqRlKIY.js +1 -0
- package/dist/assets/marko-CPi9NSCl.js +1 -0
- package/dist/assets/material-theme-D5KoaKCx.js +1 -0
- package/dist/assets/material-theme-darker-BfHTSMKl.js +1 -0
- package/dist/assets/material-theme-lighter-B0m2ddpp.js +1 -0
- package/dist/assets/material-theme-ocean-CyktbL80.js +1 -0
- package/dist/assets/material-theme-palenight-Csfq5Kiy.js +1 -0
- package/dist/assets/matlab-BQKM-LA_.js +1 -0
- package/dist/assets/matlab-D7o27uSR.js +1 -0
- package/dist/assets/mdc-BBM-UqJy.js +1 -0
- package/dist/assets/mdc-DUICxH0z.js +1 -0
- package/dist/assets/mdx-BWRhHdFl.js +1 -0
- package/dist/assets/mdx-Cmh6b_Ma.js +1 -0
- package/dist/assets/mermaid-DKYwYmdq.js +1 -0
- package/dist/assets/mermaid-DrapLM8U.js +1 -0
- package/dist/assets/min-dark-CafNBF8u.js +1 -0
- package/dist/assets/min-light-CTRr51gU.js +1 -0
- package/dist/assets/mipsasm-BElnB_7Q.js +1 -0
- package/dist/assets/mipsasm-CKIfxQSi.js +1 -0
- package/dist/assets/mojo-1DNp92w6.js +1 -0
- package/dist/assets/mojo-Dz6zCmiK.js +1 -0
- package/dist/assets/monokai-D4h5O-jR.js +1 -0
- package/dist/assets/move-Bu9oaDYs.js +1 -0
- package/dist/assets/move-Dvu4btzz.js +1 -0
- package/dist/assets/narrat-Cy2k80UN.js +1 -0
- package/dist/assets/narrat-DRg8JJMk.js +1 -0
- package/dist/assets/nextflow-BO4ujnzu.js +1 -0
- package/dist/assets/nextflow-BrzmwbiE.js +1 -0
- package/dist/assets/nginx-DknmC5AR.js +1 -0
- package/dist/assets/nginx-XmDIhN78.js +1 -0
- package/dist/assets/night-owl-C39BiMTA.js +1 -0
- package/dist/assets/nim-CVrawwO9.js +1 -0
- package/dist/assets/nim-Cm6-Nayq.js +1 -0
- package/dist/assets/nix-DcZRBjkC.js +1 -0
- package/dist/assets/nix-c8nO5XWb.js +1 -0
- package/dist/assets/nope-02-EygnDbCM.aac +0 -0
- package/dist/assets/nope-05-DZsXzrQW.aac +0 -0
- package/dist/assets/nope-08-COPo0uNf.aac +0 -0
- package/dist/assets/nope-11-CVdXg8G-.aac +0 -0
- package/dist/assets/nope-12-BJR1Ka3c.aac +0 -0
- package/dist/assets/nord-Ddv68eIx.js +1 -0
- package/dist/assets/nushell-C-sUppwS.js +1 -0
- package/dist/assets/nushell-Dqv-0Q5X.js +1 -0
- package/dist/assets/objective-c-DXmwc3jG.js +1 -0
- package/dist/assets/objective-c-sgtl-PdD.js +1 -0
- package/dist/assets/objective-cpp-BTQ37cYs.js +1 -0
- package/dist/assets/objective-cpp-CLxacb5B.js +1 -0
- package/dist/assets/ocaml-BvBP9Lm0.js +1 -0
- package/dist/assets/ocaml-C0hk2d4L.js +1 -0
- package/dist/assets/one-dark-pro-DVMEJ2y_.js +1 -0
- package/dist/assets/one-light-PoHY5YXO.js +1 -0
- package/dist/assets/openscad-C4EeE6gA.js +1 -0
- package/dist/assets/openscad-Dmi2c_42.js +1 -0
- package/dist/assets/pascal-D93ZcfNL.js +1 -0
- package/dist/assets/pascal-DYjw0AuS.js +1 -0
- package/dist/assets/perl-C0TMdlhV.js +1 -0
- package/dist/assets/perl-Djxv1YJ9.js +1 -0
- package/dist/assets/php-CDn_0X-4.js +1 -0
- package/dist/assets/php-DEfiO3Bd.js +1 -0
- package/dist/assets/pierre-dark-BXuwtOqb.js +1 -0
- package/dist/assets/pierre-light-dckrK0oj.js +1 -0
- package/dist/assets/pkl-Cij4Vm9z.js +1 -0
- package/dist/assets/pkl-u5AG7uiY.js +1 -0
- package/dist/assets/plastic-3e1v2bzS.js +1 -0
- package/dist/assets/plsql-Bd6NdBJI.js +1 -0
- package/dist/assets/plsql-ChMvpjG-.js +1 -0
- package/dist/assets/po-BTJTHyun.js +1 -0
- package/dist/assets/po-CUhVi7la.js +1 -0
- package/dist/assets/poimandres-CS3Unz2-.js +1 -0
- package/dist/assets/polar-B-qJ3AIy.js +1 -0
- package/dist/assets/polar-C0HS_06l.js +1 -0
- package/dist/assets/postcss-BSGhOJ4k.js +1 -0
- package/dist/assets/postcss-CXtECtnM.js +1 -0
- package/dist/assets/powerquery-CC1XieQO.js +1 -0
- package/dist/assets/powerquery-CEu0bR-o.js +1 -0
- package/dist/assets/powershell-DdRAnR4Z.js +1 -0
- package/dist/assets/powershell-Dpen1YoG.js +1 -0
- package/dist/assets/prisma-C0hJlfqX.js +1 -0
- package/dist/assets/prisma-Dd19v3D-.js +1 -0
- package/dist/assets/prolog-CbFg5uaA.js +1 -0
- package/dist/assets/prolog-bSi0SE3D.js +1 -0
- package/dist/assets/proto-DIGPV07t.js +1 -0
- package/dist/assets/proto-DyJlTyXw.js +1 -0
- package/dist/assets/pug-CGlum2m_.js +1 -0
- package/dist/assets/pug-ClQUpJlV.js +1 -0
- package/dist/assets/puppet-BMWR74SV.js +1 -0
- package/dist/assets/puppet-ja2MI9-b.js +1 -0
- package/dist/assets/purescript-CklMAg4u.js +1 -0
- package/dist/assets/purescript-CxgsQa43.js +1 -0
- package/dist/assets/python-B6aJPvgy.js +1 -0
- package/dist/assets/python-DgE28U1V.js +1 -0
- package/dist/assets/qml-3beO22l8.js +1 -0
- package/dist/assets/qml-BEkX6VoX.js +1 -0
- package/dist/assets/qmldir-C8lEn-DE.js +1 -0
- package/dist/assets/qmldir-DNYHzgow.js +1 -0
- package/dist/assets/qss-BZsEMKxJ.js +1 -0
- package/dist/assets/qss-IeuSbFQv.js +1 -0
- package/dist/assets/r-BfG_C0qz.js +1 -0
- package/dist/assets/r-DiinP2Uv.js +1 -0
- package/dist/assets/racket-BqYA7rlc.js +1 -0
- package/dist/assets/racket-CzHBKLyy.js +1 -0
- package/dist/assets/raku-CPccoUN1.js +1 -0
- package/dist/assets/raku-DXvB9xmW.js +1 -0
- package/dist/assets/razor-8rj0VRTp.js +1 -0
- package/dist/assets/razor-CE9lU5zL.js +1 -0
- package/dist/assets/red-bN70gL4F.js +1 -0
- package/dist/assets/reg-C-SQnVFl.js +1 -0
- package/dist/assets/reg-DkqHJyC0.js +1 -0
- package/dist/assets/regexp-BW_zLBm-.js +1 -0
- package/dist/assets/regexp-CDVJQ6XC.js +1 -0
- package/dist/assets/rel-BIqKdwke.js +1 -0
- package/dist/assets/rel-C3B-1QV4.js +1 -0
- package/dist/assets/riscv-BM1_JUlF.js +1 -0
- package/dist/assets/riscv-s6spwTFp.js +1 -0
- package/dist/assets/rose-pine-dawn-DHQR4-dF.js +1 -0
- package/dist/assets/rose-pine-moon-D4_iv3hh.js +1 -0
- package/dist/assets/rose-pine-qdsjHGoJ.js +1 -0
- package/dist/assets/rosmsg-BJDFO7_C.js +1 -0
- package/dist/assets/rosmsg-TcL_zzr8.js +1 -0
- package/dist/assets/rst-8IYWyo0X.js +1 -0
- package/dist/assets/rst-B0xPkSld.js +1 -0
- package/dist/assets/ruby-BvKwtOVI.js +1 -0
- package/dist/assets/ruby-CHyTNJrF.js +1 -0
- package/dist/assets/rust-B1yitclQ.js +1 -0
- package/dist/assets/rust-DJErdhjk.js +1 -0
- package/dist/assets/sas-BZeeyq_z.js +1 -0
- package/dist/assets/sas-cz2c8ADy.js +1 -0
- package/dist/assets/sass-CIfQ9yqV.js +1 -0
- package/dist/assets/sass-Cj5Yp3dK.js +1 -0
- package/dist/assets/scala-C151Ov-r.js +1 -0
- package/dist/assets/scala-CWwlNtab.js +1 -0
- package/dist/assets/scheme-ByM66cy_.js +1 -0
- package/dist/assets/scheme-C98Dy4si.js +1 -0
- package/dist/assets/scss-Dk05w39G.js +1 -0
- package/dist/assets/scss-OYdSNvt2.js +1 -0
- package/dist/assets/sdbl-C5Q1usnU.js +1 -0
- package/dist/assets/sdbl-DVxCFoDh.js +1 -0
- package/dist/assets/session-fRmszlju.js +41 -0
- package/dist/assets/shaderlab-DNkMdb2B.js +1 -0
- package/dist/assets/shaderlab-Dg9Lc6iA.js +1 -0
- package/dist/assets/shellscript-CE-5zpiL.js +1 -0
- package/dist/assets/shellscript-Yzrsuije.js +1 -0
- package/dist/assets/shellsession-BADoaaVG.js +1 -0
- package/dist/assets/shellsession-BhddCRKA.js +1 -0
- package/dist/assets/slack-dark-BthQWCQV.js +1 -0
- package/dist/assets/slack-ochin-DqwNpetd.js +1 -0
- package/dist/assets/smalltalk-BERRCDM3.js +1 -0
- package/dist/assets/smalltalk-GKfhTxrk.js +1 -0
- package/dist/assets/snazzy-light-Bw305WKR.js +1 -0
- package/dist/assets/solarized-dark-DXbdFlpD.js +1 -0
- package/dist/assets/solarized-light-L9t79GZl.js +1 -0
- package/dist/assets/solidity-DanOLEvk.js +1 -0
- package/dist/assets/solidity-rGO070M0.js +1 -0
- package/dist/assets/soy-Brmx7dQM.js +1 -0
- package/dist/assets/soy-C6ERzLIv.js +1 -0
- package/dist/assets/sparql-CHK3vDkL.js +1 -0
- package/dist/assets/sparql-rVzFXLq3.js +1 -0
- package/dist/assets/splunk-BtCnVYZw.js +1 -0
- package/dist/assets/splunk-YU1HCmJX.js +1 -0
- package/dist/assets/sprite-BxALe73Z.svg +882 -0
- package/dist/assets/sprite-Fb-TFjRY.svg +11707 -0
- package/dist/assets/sql-BLtJtn59.js +1 -0
- package/dist/assets/sql-CKXjX23X.js +1 -0
- package/dist/assets/ssh-config-Cpnw3KEt.js +1 -0
- package/dist/assets/ssh-config-_ykCGR6B.js +1 -0
- package/dist/assets/staplebops-03-Aug82oH0.aac +0 -0
- package/dist/assets/staplebops-04-olyHi8qQ.aac +0 -0
- package/dist/assets/staplebops-06-Cj_2vOI4.aac +0 -0
- package/dist/assets/staplebops-07-cqQEvbIf.aac +0 -0
- package/dist/assets/stata-BH5u7GGu.js +1 -0
- package/dist/assets/stata-BJqnY-gO.js +1 -0
- package/dist/assets/stylus-BEDo0Tqx.js +1 -0
- package/dist/assets/stylus-CHekGIgu.js +1 -0
- package/dist/assets/svelte-3Dk4HxPD.js +1 -0
- package/dist/assets/svelte-DmnhoTkn.js +1 -0
- package/dist/assets/swift-Deru3G9w.js +1 -0
- package/dist/assets/swift-Dg5xB15N.js +1 -0
- package/dist/assets/synthwave-84-CbfX1IO0.js +1 -0
- package/dist/assets/system-verilog-CnnmHF94.js +1 -0
- package/dist/assets/system-verilog-rKNYENrf.js +1 -0
- package/dist/assets/systemd-4A_iFExJ.js +1 -0
- package/dist/assets/systemd-C1FfcI00.js +1 -0
- package/dist/assets/talonscript-CkByrt1z.js +1 -0
- package/dist/assets/talonscript-bksoRmW6.js +1 -0
- package/dist/assets/tasl-Bl4tsGRM.js +1 -0
- package/dist/assets/tasl-QIJgUcNo.js +1 -0
- package/dist/assets/tcl-B2_VAYrd.js +1 -0
- package/dist/assets/tcl-dwOrl1Do.js +1 -0
- package/dist/assets/templ-CyHhV9jl.js +1 -0
- package/dist/assets/templ-W15q3VgB.js +1 -0
- package/dist/assets/terminal-Cpd_WDea.png +0 -0
- package/dist/assets/terraform-BETggiCN.js +1 -0
- package/dist/assets/terraform-Ba94thAr.js +1 -0
- package/dist/assets/tex-CxkMU7Pf.js +1 -0
- package/dist/assets/tex-DZ7Smwga.js +1 -0
- package/dist/assets/textmate-B-hymv65.png +0 -0
- package/dist/assets/tokyo-night-hegEt444.js +1 -0
- package/dist/assets/toml-Btlk-g9G.js +1 -0
- package/dist/assets/toml-vGWfd6FD.js +1 -0
- package/dist/assets/ts-tags-DMPjx__B.js +1 -0
- package/dist/assets/ts-tags-zn1MmPIZ.js +1 -0
- package/dist/assets/tsv-B_m7g4N7.js +1 -0
- package/dist/assets/tsv-DYfmKMIW.js +1 -0
- package/dist/assets/tsx-COt5Ahok.js +1 -0
- package/dist/assets/tsx-Dio8iE-N.js +1 -0
- package/dist/assets/turtle-BsS91CYL.js +1 -0
- package/dist/assets/turtle-whXsfw69.js +1 -0
- package/dist/assets/twig-CO9l9SDP.js +1 -0
- package/dist/assets/twig-vsFUeHgy.js +1 -0
- package/dist/assets/typescript-BPQ3VLAy.js +1 -0
- package/dist/assets/typescript-DttGkNCf.js +1 -0
- package/dist/assets/typespec-BGHnOYBU.js +1 -0
- package/dist/assets/typespec-C_z-8Pri.js +1 -0
- package/dist/assets/typst-D2RORpaG.js +1 -0
- package/dist/assets/typst-DHCkPAjA.js +1 -0
- package/dist/assets/v-BcVCzyr7.js +1 -0
- package/dist/assets/v-CvM42WIw.js +1 -0
- package/dist/assets/vala-B_5xOBNr.js +1 -0
- package/dist/assets/vala-CsfeWuGM.js +1 -0
- package/dist/assets/vb-BVDm3zBt.js +1 -0
- package/dist/assets/vb-D17OF-Vu.js +1 -0
- package/dist/assets/verilog-BQ8w6xss.js +1 -0
- package/dist/assets/verilog-D5iownw6.js +1 -0
- package/dist/assets/vesper-DU1UobuO.js +1 -0
- package/dist/assets/vhdl-Bmgbkl_-.js +1 -0
- package/dist/assets/vhdl-CeAyd5Ju.js +1 -0
- package/dist/assets/viml-3ZODU9FQ.js +1 -0
- package/dist/assets/viml-CJc9bBzg.js +1 -0
- package/dist/assets/vitesse-black-Bkuqu6BP.js +1 -0
- package/dist/assets/vitesse-dark-D0r3Knsf.js +1 -0
- package/dist/assets/vitesse-light-CVO1_9PV.js +1 -0
- package/dist/assets/vue-BJuclMoA.js +1 -0
- package/dist/assets/vue-DnHKYNfI.js +1 -0
- package/dist/assets/vue-html-CChd_i61.js +1 -0
- package/dist/assets/vue-html-CRAum25o.js +1 -0
- package/dist/assets/vue-vine-8moa0y9V.js +1 -0
- package/dist/assets/vue-vine-CDS6dxm6.js +1 -0
- package/dist/assets/vyper-B6NKdirK.js +1 -0
- package/dist/assets/vyper-CDx5xZoG.js +1 -0
- package/dist/assets/wasm-CG6Dc4jp.js +1 -0
- package/dist/assets/wasm-LUzQYg3H.js +1 -0
- package/dist/assets/wasm-MzD3tlZU.js +1 -0
- package/dist/assets/wenyan-8fXatRyt.js +1 -0
- package/dist/assets/wenyan-BV7otONQ.js +1 -0
- package/dist/assets/wgsl-CECC3vJ5.js +1 -0
- package/dist/assets/wgsl-Dx-B1_4e.js +1 -0
- package/dist/assets/wikitext-BaRWL9sq.js +1 -0
- package/dist/assets/wikitext-BhOHFoWU.js +1 -0
- package/dist/assets/wit-5i3qLPDT.js +1 -0
- package/dist/assets/wit-MEd50GYB.js +1 -0
- package/dist/assets/wolfram-CmMaIVaG.js +1 -0
- package/dist/assets/wolfram-lXgVvXCa.js +1 -0
- package/dist/assets/worker-CKpRWWws.js +153 -0
- package/dist/assets/xcode-4zqeTePl.png +0 -0
- package/dist/assets/xml-DtyAt_xK.js +1 -0
- package/dist/assets/xml-sdJ4AIDG.js +1 -0
- package/dist/assets/xsl-Btrj9DhN.js +1 -0
- package/dist/assets/xsl-CtQFsRM5.js +1 -0
- package/dist/assets/yaml-B92AUxDB.js +1 -0
- package/dist/assets/yaml-Buea-lGh.js +1 -0
- package/dist/assets/yup-01-BtRq6dLN.aac +0 -0
- package/dist/assets/yup-03-BHLEoqSS.aac +0 -0
- package/dist/assets/yup-04-C7yadpJT.aac +0 -0
- package/dist/assets/yup-05-CuuaeyjC.aac +0 -0
- package/dist/assets/zenscript-DVFEvuxE.js +1 -0
- package/dist/assets/zenscript-Dja4fBOE.js +1 -0
- package/dist/assets/zig-LhWa2ADv.js +1 -0
- package/dist/assets/zig-VOosw3JB.js +1 -0
- package/dist/favicon-96x96-v3.png +0 -0
- package/dist/favicon-96x96.png +0 -0
- package/dist/favicon-v3.ico +0 -0
- package/dist/favicon-v3.svg +7 -0
- package/dist/favicon.ico +0 -0
- package/dist/favicon.svg +7 -0
- package/dist/index.html +24 -0
- package/dist/oc-theme-preload.js +28 -0
- package/dist/site.webmanifest +21 -0
- package/dist/social-share-zen.png +0 -0
- package/dist/social-share.png +0 -0
- package/dist/web-app-manifest-192x192.png +0 -0
- package/dist/web-app-manifest-512x512.png +0 -0
- package/e2e/AGENTS.md +176 -0
- package/e2e/actions.ts +421 -0
- package/e2e/app/home.spec.ts +21 -0
- package/e2e/app/navigation.spec.ts +10 -0
- package/e2e/app/palette.spec.ts +11 -0
- package/e2e/app/server-default.spec.ts +55 -0
- package/e2e/app/session.spec.ts +16 -0
- package/e2e/app/titlebar-history.spec.ts +42 -0
- package/e2e/files/file-open.spec.ts +18 -0
- package/e2e/files/file-tree.spec.ts +37 -0
- package/e2e/files/file-viewer.spec.ts +26 -0
- package/e2e/fixtures.ts +87 -0
- package/e2e/models/model-picker.spec.ts +42 -0
- package/e2e/models/models-visibility.spec.ts +61 -0
- package/e2e/projects/project-edit.spec.ts +53 -0
- package/e2e/projects/projects-close.spec.ts +74 -0
- package/e2e/projects/projects-switch.spec.ts +35 -0
- package/e2e/projects/workspaces.spec.ts +333 -0
- package/e2e/prompt/context.spec.ts +40 -0
- package/e2e/prompt/prompt-mention.spec.ts +26 -0
- package/e2e/prompt/prompt-slash-open.spec.ts +22 -0
- package/e2e/prompt/prompt.spec.ts +58 -0
- package/e2e/selectors.ts +57 -0
- package/e2e/session/session.spec.ts +157 -0
- package/e2e/settings/settings-keybinds.spec.ts +320 -0
- package/e2e/settings/settings-models.spec.ts +122 -0
- package/e2e/settings/settings-providers.spec.ts +136 -0
- package/e2e/settings/settings.spec.ts +292 -0
- package/e2e/sidebar/sidebar-session-links.spec.ts +31 -0
- package/e2e/sidebar/sidebar.spec.ts +14 -0
- package/e2e/status/status-popover.spec.ts +94 -0
- package/e2e/terminal/terminal-init.spec.ts +26 -0
- package/e2e/terminal/terminal.spec.ts +17 -0
- package/e2e/thinking-level.spec.ts +25 -0
- package/e2e/tsconfig.json +8 -0
- package/e2e/utils.ts +35 -0
- package/happydom.ts +75 -0
- package/index.html +23 -0
- package/package.json +72 -0
- package/playwright.config.ts +43 -0
- package/public/_headers +17 -0
- package/public/oc-theme-preload.js +28 -0
- package/script/e2e-local.ts +140 -0
- package/src/addons/serialize.test.ts +319 -0
- package/src/addons/serialize.ts +634 -0
- package/src/app.tsx +170 -0
- package/src/components/dialog-connect-provider.tsx +456 -0
- package/src/components/dialog-custom-provider.tsx +424 -0
- package/src/components/dialog-edit-project.tsx +245 -0
- package/src/components/dialog-fork.tsx +100 -0
- package/src/components/dialog-manage-models.tsx +76 -0
- package/src/components/dialog-release-notes.tsx +158 -0
- package/src/components/dialog-select-directory.tsx +326 -0
- package/src/components/dialog-select-file.tsx +404 -0
- package/src/components/dialog-select-mcp.tsx +96 -0
- package/src/components/dialog-select-model-unpaid.tsx +132 -0
- package/src/components/dialog-select-model.tsx +271 -0
- package/src/components/dialog-select-provider.tsx +87 -0
- package/src/components/dialog-select-server.tsx +536 -0
- package/src/components/dialog-settings.tsx +82 -0
- package/src/components/file-tree.test.ts +77 -0
- package/src/components/file-tree.tsx +468 -0
- package/src/components/link.tsx +17 -0
- package/src/components/model-tooltip.tsx +91 -0
- package/src/components/prompt-input/attachments.ts +145 -0
- package/src/components/prompt-input/build-request-parts.test.ts +277 -0
- package/src/components/prompt-input/build-request-parts.ts +190 -0
- package/src/components/prompt-input/context-items.tsx +82 -0
- package/src/components/prompt-input/drag-overlay.tsx +20 -0
- package/src/components/prompt-input/editor-dom.test.ts +51 -0
- package/src/components/prompt-input/editor-dom.ts +135 -0
- package/src/components/prompt-input/history.test.ts +69 -0
- package/src/components/prompt-input/history.ts +160 -0
- package/src/components/prompt-input/image-attachments.tsx +51 -0
- package/src/components/prompt-input/placeholder.test.ts +35 -0
- package/src/components/prompt-input/placeholder.ts +13 -0
- package/src/components/prompt-input/slash-popover.tsx +144 -0
- package/src/components/prompt-input/submit.ts +411 -0
- package/src/components/prompt-input.tsx +1199 -0
- package/src/components/question-dock.tsx +295 -0
- package/src/components/server/server-row.tsx +77 -0
- package/src/components/session/index.ts +5 -0
- package/src/components/session/session-context-metrics.test.ts +93 -0
- package/src/components/session/session-context-metrics.ts +94 -0
- package/src/components/session/session-context-tab.tsx +400 -0
- package/src/components/session/session-header.tsx +571 -0
- package/src/components/session/session-new-view.tsx +78 -0
- package/src/components/session/session-sortable-tab.tsx +63 -0
- package/src/components/session/session-sortable-terminal-tab.tsx +190 -0
- package/src/components/session-context-usage.tsx +100 -0
- package/src/components/settings-agents.tsx +15 -0
- package/src/components/settings-commands.tsx +15 -0
- package/src/components/settings-general.tsx +434 -0
- package/src/components/settings-keybinds.tsx +435 -0
- package/src/components/settings-mcp.tsx +15 -0
- package/src/components/settings-models.tsx +130 -0
- package/src/components/settings-permissions.tsx +228 -0
- package/src/components/settings-providers.tsx +264 -0
- package/src/components/status-popover.tsx +371 -0
- package/src/components/terminal.tsx +464 -0
- package/src/components/titlebar-history.test.ts +63 -0
- package/src/components/titlebar-history.ts +57 -0
- package/src/components/titlebar.tsx +261 -0
- package/src/context/command-keybind.test.ts +43 -0
- package/src/context/command.test.ts +25 -0
- package/src/context/command.tsx +365 -0
- package/src/context/comments.test.ts +111 -0
- package/src/context/comments.tsx +185 -0
- package/src/context/file/content-cache.ts +88 -0
- package/src/context/file/path.test.ts +352 -0
- package/src/context/file/path.ts +143 -0
- package/src/context/file/tree-store.ts +170 -0
- package/src/context/file/types.ts +41 -0
- package/src/context/file/view-cache.ts +136 -0
- package/src/context/file/watcher.test.ts +118 -0
- package/src/context/file/watcher.ts +52 -0
- package/src/context/file-content-eviction-accounting.test.ts +65 -0
- package/src/context/file.tsx +263 -0
- package/src/context/global-sdk.tsx +108 -0
- package/src/context/global-sync/bootstrap.ts +195 -0
- package/src/context/global-sync/child-store.ts +263 -0
- package/src/context/global-sync/event-reducer.test.ts +201 -0
- package/src/context/global-sync/event-reducer.ts +319 -0
- package/src/context/global-sync/eviction.ts +28 -0
- package/src/context/global-sync/queue.ts +83 -0
- package/src/context/global-sync/session-load.ts +26 -0
- package/src/context/global-sync/session-trim.test.ts +59 -0
- package/src/context/global-sync/session-trim.ts +56 -0
- package/src/context/global-sync/types.ts +134 -0
- package/src/context/global-sync/utils.ts +25 -0
- package/src/context/global-sync.test.ts +136 -0
- package/src/context/global-sync.tsx +365 -0
- package/src/context/highlights.tsx +225 -0
- package/src/context/language.tsx +226 -0
- package/src/context/layout-scroll.test.ts +36 -0
- package/src/context/layout-scroll.ts +118 -0
- package/src/context/layout.test.ts +69 -0
- package/src/context/layout.tsx +844 -0
- package/src/context/local.tsx +229 -0
- package/src/context/models.tsx +140 -0
- package/src/context/notification-index.ts +66 -0
- package/src/context/notification.test.ts +73 -0
- package/src/context/notification.tsx +199 -0
- package/src/context/permission.tsx +186 -0
- package/src/context/platform.tsx +75 -0
- package/src/context/prompt.tsx +246 -0
- package/src/context/sdk.tsx +48 -0
- package/src/context/server.tsx +208 -0
- package/src/context/settings.tsx +177 -0
- package/src/context/sync-optimistic.test.ts +56 -0
- package/src/context/sync.tsx +358 -0
- package/src/context/terminal.test.ts +38 -0
- package/src/context/terminal.tsx +283 -0
- package/src/entry.tsx +104 -0
- package/src/env.d.ts +8 -0
- package/src/hooks/use-providers.ts +31 -0
- package/src/i18n/ar.ts +716 -0
- package/src/i18n/br.ts +722 -0
- package/src/i18n/bs.ts +749 -0
- package/src/i18n/da.ts +721 -0
- package/src/i18n/de.ts +766 -0
- package/src/i18n/en.ts +792 -0
- package/src/i18n/es.ts +727 -0
- package/src/i18n/fr.ts +733 -0
- package/src/i18n/ja.ts +715 -0
- package/src/i18n/ko.ts +720 -0
- package/src/i18n/no.ts +723 -0
- package/src/i18n/parity.test.ts +31 -0
- package/src/i18n/pl.ts +723 -0
- package/src/i18n/ru.ts +727 -0
- package/src/i18n/th.ts +714 -0
- package/src/i18n/zh.ts +754 -0
- package/src/i18n/zht.ts +752 -0
- package/src/index.css +1 -0
- package/src/index.ts +3 -0
- package/src/pages/directory-layout.tsx +71 -0
- package/src/pages/error.tsx +290 -0
- package/src/pages/home.tsx +126 -0
- package/src/pages/layout/deep-links.ts +26 -0
- package/src/pages/layout/helpers.test.ts +63 -0
- package/src/pages/layout/helpers.ts +65 -0
- package/src/pages/layout/inline-editor.tsx +113 -0
- package/src/pages/layout/sidebar-items.tsx +328 -0
- package/src/pages/layout/sidebar-project-helpers.test.ts +63 -0
- package/src/pages/layout/sidebar-project-helpers.ts +11 -0
- package/src/pages/layout/sidebar-project.tsx +283 -0
- package/src/pages/layout/sidebar-shell-helpers.ts +1 -0
- package/src/pages/layout/sidebar-shell.test.ts +13 -0
- package/src/pages/layout/sidebar-shell.tsx +109 -0
- package/src/pages/layout/sidebar-workspace-helpers.ts +2 -0
- package/src/pages/layout/sidebar-workspace.test.ts +13 -0
- package/src/pages/layout/sidebar-workspace.tsx +410 -0
- package/src/pages/layout.tsx +1996 -0
- package/src/pages/session/file-tab-scroll.test.ts +40 -0
- package/src/pages/session/file-tab-scroll.ts +67 -0
- package/src/pages/session/file-tabs.tsx +516 -0
- package/src/pages/session/helpers.test.ts +61 -0
- package/src/pages/session/helpers.ts +38 -0
- package/src/pages/session/message-gesture.test.ts +62 -0
- package/src/pages/session/message-gesture.ts +21 -0
- package/src/pages/session/message-timeline.tsx +348 -0
- package/src/pages/session/review-tab.tsx +158 -0
- package/src/pages/session/scroll-spy.test.ts +127 -0
- package/src/pages/session/scroll-spy.ts +274 -0
- package/src/pages/session/session-command-helpers.ts +10 -0
- package/src/pages/session/session-mobile-tabs.tsx +36 -0
- package/src/pages/session/session-prompt-dock.test.ts +22 -0
- package/src/pages/session/session-prompt-dock.tsx +137 -0
- package/src/pages/session/session-prompt-helpers.ts +4 -0
- package/src/pages/session/session-side-panel.tsx +319 -0
- package/src/pages/session/terminal-label.ts +16 -0
- package/src/pages/session/terminal-panel.test.ts +25 -0
- package/src/pages/session/terminal-panel.tsx +169 -0
- package/src/pages/session/use-session-commands.test.ts +44 -0
- package/src/pages/session/use-session-commands.tsx +455 -0
- package/src/pages/session/use-session-hash-scroll.test.ts +16 -0
- package/src/pages/session/use-session-hash-scroll.ts +174 -0
- package/src/pages/session.tsx +1755 -0
- package/src/sst-env.d.ts +12 -0
- package/src/utils/agent.ts +11 -0
- package/src/utils/aim.ts +138 -0
- package/src/utils/base64.ts +10 -0
- package/src/utils/dom.ts +51 -0
- package/src/utils/id.ts +99 -0
- package/src/utils/index.ts +1 -0
- package/src/utils/perf.ts +135 -0
- package/src/utils/persist.ts +451 -0
- package/src/utils/prompt.ts +203 -0
- package/src/utils/runtime-adapters.test.ts +62 -0
- package/src/utils/runtime-adapters.ts +39 -0
- package/src/utils/same.ts +6 -0
- package/src/utils/scoped-cache.test.ts +69 -0
- package/src/utils/scoped-cache.ts +104 -0
- package/src/utils/server-health.test.ts +42 -0
- package/src/utils/server-health.ts +29 -0
- package/src/utils/solid-dnd.tsx +55 -0
- package/src/utils/sound.ts +117 -0
- package/src/utils/speech.ts +326 -0
- package/src/utils/time.ts +14 -0
- package/src/utils/worktree.test.ts +46 -0
- package/src/utils/worktree.ts +73 -0
- package/sst-env.d.ts +10 -0
- package/tsconfig.json +26 -0
- package/vite.config.ts +15 -0
- package/vite.js +26 -0
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { describe, expect, test } from "bun:test"
|
|
2
|
+
import { nextTabListScrollLeft } from "./file-tab-scroll"
|
|
3
|
+
|
|
4
|
+
describe("nextTabListScrollLeft", () => {
|
|
5
|
+
test("does not scroll when width shrinks", () => {
|
|
6
|
+
const left = nextTabListScrollLeft({
|
|
7
|
+
prevScrollWidth: 500,
|
|
8
|
+
scrollWidth: 420,
|
|
9
|
+
clientWidth: 300,
|
|
10
|
+
prevContextOpen: false,
|
|
11
|
+
contextOpen: false,
|
|
12
|
+
})
|
|
13
|
+
|
|
14
|
+
expect(left).toBeUndefined()
|
|
15
|
+
})
|
|
16
|
+
|
|
17
|
+
test("scrolls to start when context tab opens", () => {
|
|
18
|
+
const left = nextTabListScrollLeft({
|
|
19
|
+
prevScrollWidth: 400,
|
|
20
|
+
scrollWidth: 500,
|
|
21
|
+
clientWidth: 320,
|
|
22
|
+
prevContextOpen: false,
|
|
23
|
+
contextOpen: true,
|
|
24
|
+
})
|
|
25
|
+
|
|
26
|
+
expect(left).toBe(0)
|
|
27
|
+
})
|
|
28
|
+
|
|
29
|
+
test("scrolls to right edge for new file tabs", () => {
|
|
30
|
+
const left = nextTabListScrollLeft({
|
|
31
|
+
prevScrollWidth: 500,
|
|
32
|
+
scrollWidth: 780,
|
|
33
|
+
clientWidth: 300,
|
|
34
|
+
prevContextOpen: true,
|
|
35
|
+
contextOpen: true,
|
|
36
|
+
})
|
|
37
|
+
|
|
38
|
+
expect(left).toBe(480)
|
|
39
|
+
})
|
|
40
|
+
})
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
type Input = {
|
|
2
|
+
prevScrollWidth: number
|
|
3
|
+
scrollWidth: number
|
|
4
|
+
clientWidth: number
|
|
5
|
+
prevContextOpen: boolean
|
|
6
|
+
contextOpen: boolean
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
export const nextTabListScrollLeft = (input: Input) => {
|
|
10
|
+
if (input.scrollWidth <= input.prevScrollWidth) return
|
|
11
|
+
if (!input.prevContextOpen && input.contextOpen) return 0
|
|
12
|
+
if (input.scrollWidth <= input.clientWidth) return
|
|
13
|
+
return input.scrollWidth - input.clientWidth
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
export const createFileTabListSync = (input: { el: HTMLDivElement; contextOpen: () => boolean }) => {
|
|
17
|
+
let frame: number | undefined
|
|
18
|
+
let prevScrollWidth = input.el.scrollWidth
|
|
19
|
+
let prevContextOpen = input.contextOpen()
|
|
20
|
+
|
|
21
|
+
const update = () => {
|
|
22
|
+
const scrollWidth = input.el.scrollWidth
|
|
23
|
+
const clientWidth = input.el.clientWidth
|
|
24
|
+
const contextOpen = input.contextOpen()
|
|
25
|
+
const left = nextTabListScrollLeft({
|
|
26
|
+
prevScrollWidth,
|
|
27
|
+
scrollWidth,
|
|
28
|
+
clientWidth,
|
|
29
|
+
prevContextOpen,
|
|
30
|
+
contextOpen,
|
|
31
|
+
})
|
|
32
|
+
|
|
33
|
+
if (left !== undefined) {
|
|
34
|
+
input.el.scrollTo({
|
|
35
|
+
left,
|
|
36
|
+
behavior: "smooth",
|
|
37
|
+
})
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
prevScrollWidth = scrollWidth
|
|
41
|
+
prevContextOpen = contextOpen
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
const schedule = () => {
|
|
45
|
+
if (frame !== undefined) cancelAnimationFrame(frame)
|
|
46
|
+
frame = requestAnimationFrame(() => {
|
|
47
|
+
frame = undefined
|
|
48
|
+
update()
|
|
49
|
+
})
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const onWheel = (e: WheelEvent) => {
|
|
53
|
+
if (Math.abs(e.deltaY) <= Math.abs(e.deltaX)) return
|
|
54
|
+
input.el.scrollLeft += e.deltaY > 0 ? 50 : -50
|
|
55
|
+
e.preventDefault()
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
input.el.addEventListener("wheel", onWheel, { passive: false })
|
|
59
|
+
const observer = new MutationObserver(schedule)
|
|
60
|
+
observer.observe(input.el, { childList: true })
|
|
61
|
+
|
|
62
|
+
return () => {
|
|
63
|
+
input.el.removeEventListener("wheel", onWheel)
|
|
64
|
+
observer.disconnect()
|
|
65
|
+
if (frame !== undefined) cancelAnimationFrame(frame)
|
|
66
|
+
}
|
|
67
|
+
}
|
|
@@ -0,0 +1,516 @@
|
|
|
1
|
+
import { type ValidComponent, createEffect, createMemo, For, Match, on, onCleanup, Show, Switch } from "solid-js"
|
|
2
|
+
import { createStore } from "solid-js/store"
|
|
3
|
+
import { Dynamic } from "solid-js/web"
|
|
4
|
+
import { checksum } from "@nikcli-ai/util/encode"
|
|
5
|
+
import { decode64 } from "@/utils/base64"
|
|
6
|
+
import { showToast } from "@nikcli-ai/ui/toast"
|
|
7
|
+
import { LineComment as LineCommentView, LineCommentEditor } from "@nikcli-ai/ui/line-comment"
|
|
8
|
+
import { Mark } from "@nikcli-ai/ui/logo"
|
|
9
|
+
import { Tabs } from "@nikcli-ai/ui/tabs"
|
|
10
|
+
import { useLayout } from "@/context/layout"
|
|
11
|
+
import { useFile, type SelectedLineRange } from "@/context/file"
|
|
12
|
+
import { useComments } from "@/context/comments"
|
|
13
|
+
import { useLanguage } from "@/context/language"
|
|
14
|
+
|
|
15
|
+
export function FileTabContent(props: {
|
|
16
|
+
tab: string
|
|
17
|
+
activeTab: () => string
|
|
18
|
+
tabs: () => ReturnType<ReturnType<typeof useLayout>["tabs"]>
|
|
19
|
+
view: () => ReturnType<ReturnType<typeof useLayout>["view"]>
|
|
20
|
+
handoffFiles: () => Record<string, SelectedLineRange | null> | undefined
|
|
21
|
+
file: ReturnType<typeof useFile>
|
|
22
|
+
comments: ReturnType<typeof useComments>
|
|
23
|
+
language: ReturnType<typeof useLanguage>
|
|
24
|
+
codeComponent: NonNullable<ValidComponent>
|
|
25
|
+
addCommentToContext: (input: {
|
|
26
|
+
file: string
|
|
27
|
+
selection: SelectedLineRange
|
|
28
|
+
comment: string
|
|
29
|
+
preview?: string
|
|
30
|
+
origin?: "review" | "file"
|
|
31
|
+
}) => void
|
|
32
|
+
}) {
|
|
33
|
+
let scroll: HTMLDivElement | undefined
|
|
34
|
+
let scrollFrame: number | undefined
|
|
35
|
+
let pending: { x: number; y: number } | undefined
|
|
36
|
+
let codeScroll: HTMLElement[] = []
|
|
37
|
+
|
|
38
|
+
const path = createMemo(() => props.file.pathFromTab(props.tab))
|
|
39
|
+
const state = createMemo(() => {
|
|
40
|
+
const p = path()
|
|
41
|
+
if (!p) return
|
|
42
|
+
return props.file.get(p)
|
|
43
|
+
})
|
|
44
|
+
const contents = createMemo(() => state()?.content?.content ?? "")
|
|
45
|
+
const cacheKey = createMemo(() => checksum(contents()))
|
|
46
|
+
const isImage = createMemo(() => {
|
|
47
|
+
const c = state()?.content
|
|
48
|
+
return c?.encoding === "base64" && c?.mimeType?.startsWith("image/") && c?.mimeType !== "image/svg+xml"
|
|
49
|
+
})
|
|
50
|
+
const isSvg = createMemo(() => {
|
|
51
|
+
const c = state()?.content
|
|
52
|
+
return c?.mimeType === "image/svg+xml"
|
|
53
|
+
})
|
|
54
|
+
const isBinary = createMemo(() => state()?.content?.mimeType?.startsWith("application/") || false)
|
|
55
|
+
const svgContent = createMemo(() => {
|
|
56
|
+
if (!isSvg()) return
|
|
57
|
+
const c = state()?.content
|
|
58
|
+
if (!c) return
|
|
59
|
+
if (c.encoding !== "base64") return c.content
|
|
60
|
+
return decode64(c.content)
|
|
61
|
+
})
|
|
62
|
+
|
|
63
|
+
const svgDecodeFailed = createMemo(() => {
|
|
64
|
+
if (!isSvg()) return false
|
|
65
|
+
const c = state()?.content
|
|
66
|
+
if (!c) return false
|
|
67
|
+
if (c.encoding !== "base64") return false
|
|
68
|
+
return svgContent() === undefined
|
|
69
|
+
})
|
|
70
|
+
|
|
71
|
+
const svgToast = { shown: false }
|
|
72
|
+
createEffect(() => {
|
|
73
|
+
if (!svgDecodeFailed()) return
|
|
74
|
+
if (svgToast.shown) return
|
|
75
|
+
svgToast.shown = true
|
|
76
|
+
showToast({
|
|
77
|
+
variant: "error",
|
|
78
|
+
title: props.language.t("toast.file.loadFailed.title"),
|
|
79
|
+
description: "Invalid base64 content.",
|
|
80
|
+
})
|
|
81
|
+
})
|
|
82
|
+
const svgPreviewUrl = createMemo(() => {
|
|
83
|
+
if (!isSvg()) return
|
|
84
|
+
const c = state()?.content
|
|
85
|
+
if (!c) return
|
|
86
|
+
if (c.encoding === "base64") return `data:image/svg+xml;base64,${c.content}`
|
|
87
|
+
return `data:image/svg+xml;charset=utf-8,${encodeURIComponent(c.content)}`
|
|
88
|
+
})
|
|
89
|
+
const imageDataUrl = createMemo(() => {
|
|
90
|
+
if (!isImage()) return
|
|
91
|
+
const c = state()?.content
|
|
92
|
+
return `data:${c?.mimeType};base64,${c?.content}`
|
|
93
|
+
})
|
|
94
|
+
const selectedLines = createMemo(() => {
|
|
95
|
+
const p = path()
|
|
96
|
+
if (!p) return null
|
|
97
|
+
if (props.file.ready()) return props.file.selectedLines(p) ?? null
|
|
98
|
+
return props.handoffFiles()?.[p] ?? null
|
|
99
|
+
})
|
|
100
|
+
|
|
101
|
+
let wrap: HTMLDivElement | undefined
|
|
102
|
+
|
|
103
|
+
const fileComments = createMemo(() => {
|
|
104
|
+
const p = path()
|
|
105
|
+
if (!p) return []
|
|
106
|
+
return props.comments.list(p)
|
|
107
|
+
})
|
|
108
|
+
|
|
109
|
+
const commentedLines = createMemo(() => fileComments().map((comment) => comment.selection))
|
|
110
|
+
|
|
111
|
+
const [note, setNote] = createStore({
|
|
112
|
+
openedComment: null as string | null,
|
|
113
|
+
commenting: null as SelectedLineRange | null,
|
|
114
|
+
draft: "",
|
|
115
|
+
positions: {} as Record<string, number>,
|
|
116
|
+
draftTop: undefined as number | undefined,
|
|
117
|
+
})
|
|
118
|
+
|
|
119
|
+
const openedComment = () => note.openedComment
|
|
120
|
+
const setOpenedComment = (
|
|
121
|
+
value: typeof note.openedComment | ((value: typeof note.openedComment) => typeof note.openedComment),
|
|
122
|
+
) => setNote("openedComment", value)
|
|
123
|
+
|
|
124
|
+
const commenting = () => note.commenting
|
|
125
|
+
const setCommenting = (value: typeof note.commenting | ((value: typeof note.commenting) => typeof note.commenting)) =>
|
|
126
|
+
setNote("commenting", value)
|
|
127
|
+
|
|
128
|
+
const draft = () => note.draft
|
|
129
|
+
const setDraft = (value: typeof note.draft | ((value: typeof note.draft) => typeof note.draft)) =>
|
|
130
|
+
setNote("draft", value)
|
|
131
|
+
|
|
132
|
+
const positions = () => note.positions
|
|
133
|
+
const setPositions = (value: typeof note.positions | ((value: typeof note.positions) => typeof note.positions)) =>
|
|
134
|
+
setNote("positions", value)
|
|
135
|
+
|
|
136
|
+
const draftTop = () => note.draftTop
|
|
137
|
+
const setDraftTop = (value: typeof note.draftTop | ((value: typeof note.draftTop) => typeof note.draftTop)) =>
|
|
138
|
+
setNote("draftTop", value)
|
|
139
|
+
|
|
140
|
+
const commentLabel = (range: SelectedLineRange) => {
|
|
141
|
+
const start = Math.min(range.start, range.end)
|
|
142
|
+
const end = Math.max(range.start, range.end)
|
|
143
|
+
if (start === end) return `line ${start}`
|
|
144
|
+
return `lines ${start}-${end}`
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
const getRoot = () => {
|
|
148
|
+
const el = wrap
|
|
149
|
+
if (!el) return
|
|
150
|
+
|
|
151
|
+
const host = el.querySelector("diffs-container")
|
|
152
|
+
if (!(host instanceof HTMLElement)) return
|
|
153
|
+
|
|
154
|
+
const root = host.shadowRoot
|
|
155
|
+
if (!root) return
|
|
156
|
+
|
|
157
|
+
return root
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
const findMarker = (root: ShadowRoot, range: SelectedLineRange) => {
|
|
161
|
+
const line = Math.max(range.start, range.end)
|
|
162
|
+
const node = root.querySelector(`[data-line="${line}"]`)
|
|
163
|
+
if (!(node instanceof HTMLElement)) return
|
|
164
|
+
return node
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
const markerTop = (wrapper: HTMLElement, marker: HTMLElement) => {
|
|
168
|
+
const wrapperRect = wrapper.getBoundingClientRect()
|
|
169
|
+
const rect = marker.getBoundingClientRect()
|
|
170
|
+
return rect.top - wrapperRect.top + Math.max(0, (rect.height - 20) / 2)
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
const updateComments = () => {
|
|
174
|
+
const el = wrap
|
|
175
|
+
const root = getRoot()
|
|
176
|
+
if (!el || !root) {
|
|
177
|
+
setPositions({})
|
|
178
|
+
setDraftTop(undefined)
|
|
179
|
+
return
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
const next: Record<string, number> = {}
|
|
183
|
+
for (const comment of fileComments()) {
|
|
184
|
+
const marker = findMarker(root, comment.selection)
|
|
185
|
+
if (!marker) continue
|
|
186
|
+
next[comment.id] = markerTop(el, marker)
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
setPositions(next)
|
|
190
|
+
|
|
191
|
+
const range = commenting()
|
|
192
|
+
if (!range) {
|
|
193
|
+
setDraftTop(undefined)
|
|
194
|
+
return
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
const marker = findMarker(root, range)
|
|
198
|
+
if (!marker) {
|
|
199
|
+
setDraftTop(undefined)
|
|
200
|
+
return
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
setDraftTop(markerTop(el, marker))
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
const scheduleComments = () => {
|
|
207
|
+
requestAnimationFrame(updateComments)
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
createEffect(() => {
|
|
211
|
+
fileComments()
|
|
212
|
+
scheduleComments()
|
|
213
|
+
})
|
|
214
|
+
|
|
215
|
+
createEffect(() => {
|
|
216
|
+
const range = commenting()
|
|
217
|
+
scheduleComments()
|
|
218
|
+
if (!range) return
|
|
219
|
+
setDraft("")
|
|
220
|
+
})
|
|
221
|
+
|
|
222
|
+
createEffect(() => {
|
|
223
|
+
const focus = props.comments.focus()
|
|
224
|
+
const p = path()
|
|
225
|
+
if (!focus || !p) return
|
|
226
|
+
if (focus.file !== p) return
|
|
227
|
+
if (props.activeTab() !== props.tab) return
|
|
228
|
+
|
|
229
|
+
const target = fileComments().find((comment) => comment.id === focus.id)
|
|
230
|
+
if (!target) return
|
|
231
|
+
|
|
232
|
+
setOpenedComment(target.id)
|
|
233
|
+
setCommenting(null)
|
|
234
|
+
props.file.setSelectedLines(p, target.selection)
|
|
235
|
+
requestAnimationFrame(() => props.comments.clearFocus())
|
|
236
|
+
})
|
|
237
|
+
|
|
238
|
+
const getCodeScroll = () => {
|
|
239
|
+
const el = scroll
|
|
240
|
+
if (!el) return []
|
|
241
|
+
|
|
242
|
+
const host = el.querySelector("diffs-container")
|
|
243
|
+
if (!(host instanceof HTMLElement)) return []
|
|
244
|
+
|
|
245
|
+
const root = host.shadowRoot
|
|
246
|
+
if (!root) return []
|
|
247
|
+
|
|
248
|
+
return Array.from(root.querySelectorAll("[data-code]")).filter(
|
|
249
|
+
(node): node is HTMLElement => node instanceof HTMLElement && node.clientWidth > 0,
|
|
250
|
+
)
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
const queueScrollUpdate = (next: { x: number; y: number }) => {
|
|
254
|
+
pending = next
|
|
255
|
+
if (scrollFrame !== undefined) return
|
|
256
|
+
|
|
257
|
+
scrollFrame = requestAnimationFrame(() => {
|
|
258
|
+
scrollFrame = undefined
|
|
259
|
+
|
|
260
|
+
const out = pending
|
|
261
|
+
pending = undefined
|
|
262
|
+
if (!out) return
|
|
263
|
+
|
|
264
|
+
props.view().setScroll(props.tab, out)
|
|
265
|
+
})
|
|
266
|
+
}
|
|
267
|
+
|
|
268
|
+
const handleCodeScroll = (event: Event) => {
|
|
269
|
+
const el = scroll
|
|
270
|
+
if (!el) return
|
|
271
|
+
|
|
272
|
+
const target = event.currentTarget
|
|
273
|
+
if (!(target instanceof HTMLElement)) return
|
|
274
|
+
|
|
275
|
+
queueScrollUpdate({
|
|
276
|
+
x: target.scrollLeft,
|
|
277
|
+
y: el.scrollTop,
|
|
278
|
+
})
|
|
279
|
+
}
|
|
280
|
+
|
|
281
|
+
const syncCodeScroll = () => {
|
|
282
|
+
const next = getCodeScroll()
|
|
283
|
+
if (next.length === codeScroll.length && next.every((el, i) => el === codeScroll[i])) return
|
|
284
|
+
|
|
285
|
+
for (const item of codeScroll) {
|
|
286
|
+
item.removeEventListener("scroll", handleCodeScroll)
|
|
287
|
+
}
|
|
288
|
+
|
|
289
|
+
codeScroll = next
|
|
290
|
+
|
|
291
|
+
for (const item of codeScroll) {
|
|
292
|
+
item.addEventListener("scroll", handleCodeScroll)
|
|
293
|
+
}
|
|
294
|
+
}
|
|
295
|
+
|
|
296
|
+
const restoreScroll = () => {
|
|
297
|
+
const el = scroll
|
|
298
|
+
if (!el) return
|
|
299
|
+
|
|
300
|
+
const s = props.view()?.scroll(props.tab)
|
|
301
|
+
if (!s) return
|
|
302
|
+
|
|
303
|
+
syncCodeScroll()
|
|
304
|
+
|
|
305
|
+
if (codeScroll.length > 0) {
|
|
306
|
+
for (const item of codeScroll) {
|
|
307
|
+
if (item.scrollLeft !== s.x) item.scrollLeft = s.x
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
if (el.scrollTop !== s.y) el.scrollTop = s.y
|
|
312
|
+
if (codeScroll.length > 0) return
|
|
313
|
+
if (el.scrollLeft !== s.x) el.scrollLeft = s.x
|
|
314
|
+
}
|
|
315
|
+
|
|
316
|
+
const handleScroll = (event: Event & { currentTarget: HTMLDivElement }) => {
|
|
317
|
+
if (codeScroll.length === 0) syncCodeScroll()
|
|
318
|
+
|
|
319
|
+
queueScrollUpdate({
|
|
320
|
+
x: codeScroll[0]?.scrollLeft ?? event.currentTarget.scrollLeft,
|
|
321
|
+
y: event.currentTarget.scrollTop,
|
|
322
|
+
})
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
createEffect(
|
|
326
|
+
on(
|
|
327
|
+
() => state()?.loaded,
|
|
328
|
+
(loaded) => {
|
|
329
|
+
if (!loaded) return
|
|
330
|
+
requestAnimationFrame(restoreScroll)
|
|
331
|
+
},
|
|
332
|
+
{ defer: true },
|
|
333
|
+
),
|
|
334
|
+
)
|
|
335
|
+
|
|
336
|
+
createEffect(
|
|
337
|
+
on(
|
|
338
|
+
() => props.file.ready(),
|
|
339
|
+
(ready) => {
|
|
340
|
+
if (!ready) return
|
|
341
|
+
requestAnimationFrame(restoreScroll)
|
|
342
|
+
},
|
|
343
|
+
{ defer: true },
|
|
344
|
+
),
|
|
345
|
+
)
|
|
346
|
+
|
|
347
|
+
createEffect(
|
|
348
|
+
on(
|
|
349
|
+
() => props.tabs().active() === props.tab,
|
|
350
|
+
(active) => {
|
|
351
|
+
if (!active) return
|
|
352
|
+
if (!state()?.loaded) return
|
|
353
|
+
requestAnimationFrame(restoreScroll)
|
|
354
|
+
},
|
|
355
|
+
),
|
|
356
|
+
)
|
|
357
|
+
|
|
358
|
+
onCleanup(() => {
|
|
359
|
+
for (const item of codeScroll) {
|
|
360
|
+
item.removeEventListener("scroll", handleCodeScroll)
|
|
361
|
+
}
|
|
362
|
+
|
|
363
|
+
if (scrollFrame === undefined) return
|
|
364
|
+
cancelAnimationFrame(scrollFrame)
|
|
365
|
+
})
|
|
366
|
+
|
|
367
|
+
const renderCode = (source: string, wrapperClass: string) => (
|
|
368
|
+
<div
|
|
369
|
+
ref={(el) => {
|
|
370
|
+
wrap = el
|
|
371
|
+
scheduleComments()
|
|
372
|
+
}}
|
|
373
|
+
class={`relative overflow-hidden ${wrapperClass}`}
|
|
374
|
+
>
|
|
375
|
+
<Dynamic
|
|
376
|
+
component={props.codeComponent}
|
|
377
|
+
file={{
|
|
378
|
+
name: path() ?? "",
|
|
379
|
+
contents: source,
|
|
380
|
+
cacheKey: cacheKey(),
|
|
381
|
+
}}
|
|
382
|
+
enableLineSelection
|
|
383
|
+
selectedLines={selectedLines()}
|
|
384
|
+
commentedLines={commentedLines()}
|
|
385
|
+
onRendered={() => {
|
|
386
|
+
requestAnimationFrame(restoreScroll)
|
|
387
|
+
requestAnimationFrame(scheduleComments)
|
|
388
|
+
}}
|
|
389
|
+
onLineSelected={(range: SelectedLineRange | null) => {
|
|
390
|
+
const p = path()
|
|
391
|
+
if (!p) return
|
|
392
|
+
props.file.setSelectedLines(p, range)
|
|
393
|
+
if (!range) setCommenting(null)
|
|
394
|
+
}}
|
|
395
|
+
onLineSelectionEnd={(range: SelectedLineRange | null) => {
|
|
396
|
+
if (!range) {
|
|
397
|
+
setCommenting(null)
|
|
398
|
+
return
|
|
399
|
+
}
|
|
400
|
+
|
|
401
|
+
setOpenedComment(null)
|
|
402
|
+
setCommenting(range)
|
|
403
|
+
}}
|
|
404
|
+
overflow="scroll"
|
|
405
|
+
class="select-text"
|
|
406
|
+
/>
|
|
407
|
+
<For each={fileComments()}>
|
|
408
|
+
{(comment) => (
|
|
409
|
+
<LineCommentView
|
|
410
|
+
id={comment.id}
|
|
411
|
+
top={positions()[comment.id]}
|
|
412
|
+
open={openedComment() === comment.id}
|
|
413
|
+
comment={comment.comment}
|
|
414
|
+
selection={commentLabel(comment.selection)}
|
|
415
|
+
onMouseEnter={() => {
|
|
416
|
+
const p = path()
|
|
417
|
+
if (!p) return
|
|
418
|
+
props.file.setSelectedLines(p, comment.selection)
|
|
419
|
+
}}
|
|
420
|
+
onClick={() => {
|
|
421
|
+
const p = path()
|
|
422
|
+
if (!p) return
|
|
423
|
+
setCommenting(null)
|
|
424
|
+
setOpenedComment((current) => (current === comment.id ? null : comment.id))
|
|
425
|
+
props.file.setSelectedLines(p, comment.selection)
|
|
426
|
+
}}
|
|
427
|
+
/>
|
|
428
|
+
)}
|
|
429
|
+
</For>
|
|
430
|
+
<Show when={commenting()}>
|
|
431
|
+
{(range) => (
|
|
432
|
+
<Show when={draftTop() !== undefined}>
|
|
433
|
+
<LineCommentEditor
|
|
434
|
+
top={draftTop()}
|
|
435
|
+
value={draft()}
|
|
436
|
+
selection={commentLabel(range())}
|
|
437
|
+
onInput={(value) => setDraft(value)}
|
|
438
|
+
onCancel={() => setCommenting(null)}
|
|
439
|
+
onSubmit={(value) => {
|
|
440
|
+
const p = path()
|
|
441
|
+
if (!p) return
|
|
442
|
+
props.addCommentToContext({
|
|
443
|
+
file: p,
|
|
444
|
+
selection: range(),
|
|
445
|
+
comment: value,
|
|
446
|
+
origin: "file",
|
|
447
|
+
})
|
|
448
|
+
setCommenting(null)
|
|
449
|
+
}}
|
|
450
|
+
onPopoverFocusOut={(e: FocusEvent) => {
|
|
451
|
+
const current = e.currentTarget as HTMLDivElement
|
|
452
|
+
const target = e.relatedTarget
|
|
453
|
+
if (target instanceof Node && current.contains(target)) return
|
|
454
|
+
|
|
455
|
+
setTimeout(() => {
|
|
456
|
+
if (!document.activeElement || !current.contains(document.activeElement)) {
|
|
457
|
+
setCommenting(null)
|
|
458
|
+
}
|
|
459
|
+
}, 0)
|
|
460
|
+
}}
|
|
461
|
+
/>
|
|
462
|
+
</Show>
|
|
463
|
+
)}
|
|
464
|
+
</Show>
|
|
465
|
+
</div>
|
|
466
|
+
)
|
|
467
|
+
|
|
468
|
+
return (
|
|
469
|
+
<Tabs.Content
|
|
470
|
+
value={props.tab}
|
|
471
|
+
class="mt-3 relative"
|
|
472
|
+
ref={(el: HTMLDivElement) => {
|
|
473
|
+
scroll = el
|
|
474
|
+
restoreScroll()
|
|
475
|
+
}}
|
|
476
|
+
onScroll={handleScroll}
|
|
477
|
+
>
|
|
478
|
+
<Switch>
|
|
479
|
+
<Match when={state()?.loaded && isImage()}>
|
|
480
|
+
<div class="px-6 py-4 pb-40">
|
|
481
|
+
<img
|
|
482
|
+
src={imageDataUrl()}
|
|
483
|
+
alt={path()}
|
|
484
|
+
class="max-w-full"
|
|
485
|
+
onLoad={() => requestAnimationFrame(restoreScroll)}
|
|
486
|
+
/>
|
|
487
|
+
</div>
|
|
488
|
+
</Match>
|
|
489
|
+
<Match when={state()?.loaded && isSvg()}>
|
|
490
|
+
<div class="flex flex-col gap-4 px-6 py-4">
|
|
491
|
+
{renderCode(svgContent() ?? "", "")}
|
|
492
|
+
<Show when={svgPreviewUrl()}>
|
|
493
|
+
<div class="flex justify-center pb-40">
|
|
494
|
+
<img src={svgPreviewUrl()} alt={path()} class="max-w-full max-h-96" />
|
|
495
|
+
</div>
|
|
496
|
+
</Show>
|
|
497
|
+
</div>
|
|
498
|
+
</Match>
|
|
499
|
+
<Match when={state()?.loaded && isBinary()}>
|
|
500
|
+
<div class="h-full px-6 pb-42 flex flex-col items-center justify-center text-center gap-6">
|
|
501
|
+
<Mark class="w-14 opacity-10" />
|
|
502
|
+
<div class="flex flex-col gap-2 max-w-md">
|
|
503
|
+
<div class="text-14-semibold text-text-strong truncate">{path()?.split("/").pop()}</div>
|
|
504
|
+
<div class="text-14-regular text-text-weak">{props.language.t("session.files.binaryContent")}</div>
|
|
505
|
+
</div>
|
|
506
|
+
</div>
|
|
507
|
+
</Match>
|
|
508
|
+
<Match when={state()?.loaded}>{renderCode(contents(), "pb-40")}</Match>
|
|
509
|
+
<Match when={state()?.loading}>
|
|
510
|
+
<div class="px-6 py-4 text-text-weak">{props.language.t("common.loading")}...</div>
|
|
511
|
+
</Match>
|
|
512
|
+
<Match when={state()?.error}>{(err) => <div class="px-6 py-4 text-text-weak">{err()}</div>}</Match>
|
|
513
|
+
</Switch>
|
|
514
|
+
</Tabs.Content>
|
|
515
|
+
)
|
|
516
|
+
}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { describe, expect, test } from "bun:test"
|
|
2
|
+
import { combineCommandSections, createOpenReviewFile, focusTerminalById } from "./helpers"
|
|
3
|
+
|
|
4
|
+
describe("createOpenReviewFile", () => {
|
|
5
|
+
test("opens and loads selected review file", () => {
|
|
6
|
+
const calls: string[] = []
|
|
7
|
+
const openReviewFile = createOpenReviewFile({
|
|
8
|
+
showAllFiles: () => calls.push("show"),
|
|
9
|
+
tabForPath: (path) => {
|
|
10
|
+
calls.push(`tab:${path}`)
|
|
11
|
+
return `file://${path}`
|
|
12
|
+
},
|
|
13
|
+
openTab: (tab) => calls.push(`open:${tab}`),
|
|
14
|
+
loadFile: (path) => calls.push(`load:${path}`),
|
|
15
|
+
})
|
|
16
|
+
|
|
17
|
+
openReviewFile("src/a.ts")
|
|
18
|
+
|
|
19
|
+
expect(calls).toEqual(["show", "tab:src/a.ts", "open:file://src/a.ts", "load:src/a.ts"])
|
|
20
|
+
})
|
|
21
|
+
})
|
|
22
|
+
|
|
23
|
+
describe("focusTerminalById", () => {
|
|
24
|
+
test("focuses textarea when present", () => {
|
|
25
|
+
document.body.innerHTML = `<div id="terminal-wrapper-one"><div data-component="terminal"><textarea></textarea></div></div>`
|
|
26
|
+
|
|
27
|
+
const focused = focusTerminalById("one")
|
|
28
|
+
|
|
29
|
+
expect(focused).toBe(true)
|
|
30
|
+
expect(document.activeElement?.tagName).toBe("TEXTAREA")
|
|
31
|
+
})
|
|
32
|
+
|
|
33
|
+
test("falls back to terminal element focus", () => {
|
|
34
|
+
document.body.innerHTML = `<div id="terminal-wrapper-two"><div data-component="terminal" tabindex="0"></div></div>`
|
|
35
|
+
const terminal = document.querySelector('[data-component="terminal"]') as HTMLElement
|
|
36
|
+
let pointerDown = false
|
|
37
|
+
terminal.addEventListener("pointerdown", () => {
|
|
38
|
+
pointerDown = true
|
|
39
|
+
})
|
|
40
|
+
|
|
41
|
+
const focused = focusTerminalById("two")
|
|
42
|
+
|
|
43
|
+
expect(focused).toBe(true)
|
|
44
|
+
expect(document.activeElement).toBe(terminal)
|
|
45
|
+
expect(pointerDown).toBe(true)
|
|
46
|
+
})
|
|
47
|
+
})
|
|
48
|
+
|
|
49
|
+
describe("combineCommandSections", () => {
|
|
50
|
+
test("keeps section order stable", () => {
|
|
51
|
+
const result = combineCommandSections([
|
|
52
|
+
[{ id: "a", title: "A" }],
|
|
53
|
+
[
|
|
54
|
+
{ id: "b", title: "B" },
|
|
55
|
+
{ id: "c", title: "C" },
|
|
56
|
+
],
|
|
57
|
+
])
|
|
58
|
+
|
|
59
|
+
expect(result.map((item) => item.id)).toEqual(["a", "b", "c"])
|
|
60
|
+
})
|
|
61
|
+
})
|