@cryptiklemur/lattice 4.0.2 → 5.0.1

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 (394) hide show
  1. package/bin/lattice +1 -9
  2. package/dist/client/assets/{angular-html-N8PCEquT.js → angular-html-DKTL-XDO.js} +1 -1
  3. package/dist/client/assets/{angular-ts-CJ8RJIPD.js → angular-ts-tvBzOwQR.js} +1 -1
  4. package/dist/client/assets/{apl-BD6tCLWN.js → apl-CCzl5qFl.js} +1 -1
  5. package/dist/client/assets/{astro-CpIIfBs6.js → astro-DNQTpO2Y.js} +1 -1
  6. package/dist/client/assets/{blade-D3qgnjiV.js → blade-CyJoIMeJ.js} +1 -1
  7. package/dist/client/assets/{c-Dr6ADN_t.js → c-OEwk5KN8.js} +1 -1
  8. package/dist/client/assets/{cobol-BIfDE0Hr.js → cobol-DpHyJzz2.js} +1 -1
  9. package/dist/client/assets/{coffee-DHQ57vfY.js → coffee-BX5dbDzZ.js} +1 -1
  10. package/dist/client/assets/{cpp-CEBY6JOp.js → cpp-BTBjNg2U.js} +1 -1
  11. package/dist/client/assets/{crystal-D125CSmP.js → crystal-CNzZd6DW.js} +1 -1
  12. package/dist/client/assets/{css-CBmrkYSr.js → css-BuKsNmms.js} +1 -1
  13. package/dist/client/assets/{dist-A_mCRD1f.js → dist-CKpDHMy6.js} +2 -2
  14. package/dist/client/assets/{edge-Ccsz7cJW.js → edge-DzhnGgJE.js} +1 -1
  15. package/dist/client/assets/{elixir-Do6gk14X.js → elixir-Dqs0waqF.js} +1 -1
  16. package/dist/client/assets/{elm-Db22zT4C.js → elm-BtWwjxWn.js} +1 -1
  17. package/dist/client/assets/{erb-MXVqAAJD.js → erb-iPD89b4v.js} +1 -1
  18. package/dist/client/assets/{git-rebase-B-LLWBOA.js → git-rebase-BxVNXJL4.js} +1 -1
  19. package/dist/client/assets/{glimmer-js-eWszRU73.js → glimmer-js-BlyCupwF.js} +1 -1
  20. package/dist/client/assets/{glimmer-ts-VQmwGqUp.js → glimmer-ts-DjIxWOS9.js} +1 -1
  21. package/dist/client/assets/{glsl-B8ilOfAl.js → glsl-CGIL-65r.js} +1 -1
  22. package/dist/client/assets/{graphql-DnTqxeOc.js → graphql-DeOn6mNV.js} +1 -1
  23. package/dist/client/assets/{hack-XJsHYSQb.js → hack-DVppeCmS.js} +1 -1
  24. package/dist/client/assets/{haml-CQ7Vqzwp.js → haml-WDhua0Mp.js} +1 -1
  25. package/dist/client/assets/{handlebars-C4szooBf.js → handlebars-i2Fu_9HI.js} +1 -1
  26. package/dist/client/assets/{html-B6EgAiSd.js → html-B1e6oxzK.js} +1 -1
  27. package/dist/client/assets/{html-derivative-DdinogQX.js → html-derivative-MofKXIVd.js} +1 -1
  28. package/dist/client/assets/{http-BSLxCgRq.js → http-Dk6S5pRD.js} +1 -1
  29. package/dist/client/assets/{hurl-pOsTwNfp.js → hurl-CroFYYJG.js} +1 -1
  30. package/dist/client/assets/{index-BHQ_8mvl.js → index-CVu-S6Yk.js} +2 -2
  31. package/dist/client/assets/{java-DRQLiiST.js → java-B89FYjqS.js} +1 -1
  32. package/dist/client/assets/{javascript-DvEK2-47.js → javascript-m6CO1Uiy.js} +1 -1
  33. package/dist/client/assets/{jinja-D2NYJ25y.js → jinja-DC9Wi41X.js} +1 -1
  34. package/dist/client/assets/{jison-DDZaLNAp.js → jison-6xiegwDk.js} +1 -1
  35. package/dist/client/assets/{json-TGR0NIWd.js → json-HA-96-qr.js} +1 -1
  36. package/dist/client/assets/{jsx-BjUoPYga.js → jsx-Wt1a8i8U.js} +1 -1
  37. package/dist/client/assets/{julia-C4gjSpFu.js → julia-7M93VBON.js} +1 -1
  38. package/dist/client/assets/{just-H351x5u_.js → just-CjfDLYLv.js} +1 -1
  39. package/dist/client/assets/{latex-BiTmf6gf.js → latex-CitsJ46x.js} +1 -1
  40. package/dist/client/assets/{liquid-86ufjRy-.js → liquid-C8VIFin8.js} +1 -1
  41. package/dist/client/assets/{lua-BNxR0F_8.js → lua-Ba2N7esc.js} +1 -1
  42. package/dist/client/assets/{marko-CvRxpRjM.js → marko-lTLvb2wu.js} +1 -1
  43. package/dist/client/assets/{mdc-CYbAIy2C.js → mdc-D6IV-8FD.js} +1 -1
  44. package/dist/client/assets/{nginx-egdgMq-F.js → nginx-Ch5AjE6S.js} +1 -1
  45. package/dist/client/assets/{nim-CXBJVz_w.js → nim-WmDDC6LW.js} +1 -1
  46. package/dist/client/assets/{perl-XRfMobzg.js → perl-CQv0gYuq.js} +1 -1
  47. package/dist/client/assets/{php-Br7a8uil.js → php-BJmH0qOB.js} +1 -1
  48. package/dist/client/assets/{pug-BVbbUVvy.js → pug-CsHPkzc9.js} +1 -1
  49. package/dist/client/assets/{qml-ByKvrL1j.js → qml-B36ecArG.js} +1 -1
  50. package/dist/client/assets/{r-mVoV0Ni6.js → r-D5Yi5Z4y.js} +1 -1
  51. package/dist/client/assets/{razor-T5O-9UJL.js → razor-CHAxVq4R.js} +1 -1
  52. package/dist/client/assets/{regexp-CioRuhuN.js → regexp-gfs--3M7.js} +1 -1
  53. package/dist/client/assets/{rst-V__uTudD.js → rst-ugdlp-hl.js} +1 -1
  54. package/dist/client/assets/{ruby-C_PuKPTI.js → ruby-CDRRW37j.js} +1 -1
  55. package/dist/client/assets/{sas-D_DqqQH4.js → sas-DZaNQaIP.js} +1 -1
  56. package/dist/client/assets/{scss-D-TjzZ4c.js → scss-CzWQEplj.js} +1 -1
  57. package/dist/client/assets/{shellscript-E5759VHu.js → shellscript-fgYvpu9N.js} +1 -1
  58. package/dist/client/assets/{shellsession-AESTM-Pv.js → shellsession-BoAohHh7.js} +1 -1
  59. package/dist/client/assets/{soy-QrbrrcDv.js → soy-DBzVgv9x.js} +1 -1
  60. package/dist/client/assets/{sql-0M8VcDHD.js → sql-BYXpAYTs.js} +1 -1
  61. package/dist/client/assets/{stata-CgeIpGtc.js → stata-I71MMY3p.js} +1 -1
  62. package/dist/client/assets/{surrealql-DBGwnZbw.js → surrealql-C9U8_1VO.js} +1 -1
  63. package/dist/client/assets/{svelte-Cv0PvUc_.js → svelte-VOFrPnWT.js} +1 -1
  64. package/dist/client/assets/{templ-B9t7xRE4.js → templ-BIaxAEtC.js} +1 -1
  65. package/dist/client/assets/{tex-DhZZ8dr2.js → tex-D1dwnBE5.js} +1 -1
  66. package/dist/client/assets/{ts-tags-BFv8sbnd.js → ts-tags-C0L2Q0r5.js} +1 -1
  67. package/dist/client/assets/{tsx-CXC9KSbY.js → tsx-BqcycEv1.js} +1 -1
  68. package/dist/client/assets/{twig-CM_OO66r.js → twig-vyWqOhpM.js} +1 -1
  69. package/dist/client/assets/{typescript-BdgOTaoD.js → typescript-B2YbovqG.js} +1 -1
  70. package/dist/client/assets/{vue-BnQhjnCm.js → vue-CbXxGdjo.js} +1 -1
  71. package/dist/client/assets/{vue-html-CNnGecRI.js → vue-html-DDX4KXW7.js} +1 -1
  72. package/dist/client/assets/{vue-vine-DCuMkRhK.js → vue-vine-DsyY1LR5.js} +1 -1
  73. package/dist/client/assets/{xml-CbTD7cB8.js → xml-Ddi0-r0D.js} +1 -1
  74. package/dist/client/assets/{xsl-uOqqo7cf.js → xsl-CsFcZHFS.js} +1 -1
  75. package/dist/client/assets/{yaml-BNrLoH59.js → yaml-tGJWoH6Y.js} +1 -1
  76. package/dist/client/index.html +1 -1
  77. package/dist/client/sw.js +1 -1
  78. package/dist/server/analytics/engine.js +832 -0
  79. package/dist/server/assets.js +39 -0
  80. package/dist/server/auth/passphrase.js +70 -0
  81. package/dist/server/config.js +47 -0
  82. package/dist/server/daemon.js +533 -0
  83. package/dist/server/features/ralph-loop.js +138 -0
  84. package/dist/server/features/scheduler.js +260 -0
  85. package/dist/server/features/sticky-notes.js +99 -0
  86. package/dist/server/handlers/analytics.js +28 -0
  87. package/dist/server/handlers/attachment.js +158 -0
  88. package/dist/server/handlers/bookmarks.js +41 -0
  89. package/dist/server/handlers/chat.js +350 -0
  90. package/dist/server/handlers/editor.js +72 -0
  91. package/dist/server/handlers/fs.js +234 -0
  92. package/dist/server/handlers/loop.js +33 -0
  93. package/dist/server/handlers/memory.js +181 -0
  94. package/dist/server/handlers/mesh.js +322 -0
  95. package/dist/server/handlers/notes.js +36 -0
  96. package/dist/server/handlers/plugins.js +593 -0
  97. package/dist/server/handlers/project-settings.js +166 -0
  98. package/dist/server/handlers/scheduler.js +52 -0
  99. package/dist/server/handlers/session.js +194 -0
  100. package/dist/server/handlers/settings.js +148 -0
  101. package/dist/server/handlers/skills.js +360 -0
  102. package/dist/server/handlers/terminal.js +75 -0
  103. package/dist/server/handlers/themes.js +102 -0
  104. package/dist/server/handlers/update.js +124 -0
  105. package/dist/server/identity.js +45 -0
  106. package/dist/server/index.js +435 -0
  107. package/dist/server/logger.js +20 -0
  108. package/dist/server/mesh/connector.js +355 -0
  109. package/dist/server/mesh/crypto.js +88 -0
  110. package/dist/server/mesh/discovery.js +95 -0
  111. package/dist/server/mesh/pairing.js +104 -0
  112. package/dist/server/mesh/peers.js +54 -0
  113. package/dist/server/mesh/proxy.js +86 -0
  114. package/dist/server/mesh/session-sync.js +85 -0
  115. package/dist/server/project/bookmarks.js +77 -0
  116. package/dist/server/project/context-breakdown.js +279 -0
  117. package/dist/server/project/file-browser.js +97 -0
  118. package/dist/server/project/project-files.js +274 -0
  119. package/dist/server/project/registry.js +51 -0
  120. package/dist/server/project/sdk-bridge.js +960 -0
  121. package/dist/server/project/session.js +696 -0
  122. package/dist/server/project/terminal.js +87 -0
  123. package/dist/server/project/warmup.js +242 -0
  124. package/dist/server/push.js +87 -0
  125. package/dist/server/tls.js +50 -0
  126. package/dist/server/tui.js +83 -0
  127. package/dist/server/update-checker.js +119 -0
  128. package/dist/server/ws/broadcast.js +50 -0
  129. package/dist/server/ws/router.js +105 -0
  130. package/dist/server/ws/server.js +2 -0
  131. package/dist/shared/analytics.js +1 -0
  132. package/dist/shared/messages.js +1 -0
  133. package/dist/shared/models.js +1 -0
  134. package/dist/shared/project-settings.js +1 -0
  135. package/package.json +5 -8
  136. package/themes/alabaster.json +9 -0
  137. package/themes/amoled.json +20 -0
  138. package/themes/ayu-light.json +9 -0
  139. package/themes/catppuccin-latte.json +9 -0
  140. package/themes/catppuccin-mocha.json +9 -0
  141. package/themes/clay-light.json +10 -0
  142. package/themes/clay.json +10 -0
  143. package/themes/dracula.json +9 -0
  144. package/themes/everforest-light.json +9 -0
  145. package/themes/everforest.json +9 -0
  146. package/themes/github-light.json +9 -0
  147. package/themes/gruvbox-dark.json +9 -0
  148. package/themes/gruvbox-light.json +9 -0
  149. package/themes/horizon-light.json +9 -0
  150. package/themes/kanagawa-lotus.json +9 -0
  151. package/themes/kanagawa.json +9 -0
  152. package/themes/modus-operandi.json +9 -0
  153. package/themes/monokai.json +9 -0
  154. package/themes/nightfox.json +9 -0
  155. package/themes/nord-light.json +9 -0
  156. package/themes/nord.json +9 -0
  157. package/themes/one-dark.json +9 -0
  158. package/themes/one-light.json +9 -0
  159. package/themes/palenight.json +9 -0
  160. package/themes/paper.json +9 -0
  161. package/themes/penumbra-light.json +9 -0
  162. package/themes/poimandres.json +9 -0
  163. package/themes/quiet-light.json +9 -0
  164. package/themes/rose-pine-dawn.json +9 -0
  165. package/themes/rose-pine.json +9 -0
  166. package/themes/solarized-dark.json +9 -0
  167. package/themes/solarized-light.json +9 -0
  168. package/themes/synthwave84.json +9 -0
  169. package/themes/tokyo-night-light.json +9 -0
  170. package/themes/tokyo-night.json +9 -0
  171. package/themes/vesper.json +9 -0
  172. package/index.html +0 -20
  173. package/public/icons/icon-192.svg +0 -11
  174. package/public/icons/icon-512.svg +0 -11
  175. package/public/sw-push.js +0 -53
  176. package/src/client/App.tsx +0 -42
  177. package/src/client/commands.ts +0 -36
  178. package/src/client/components/analytics/AnalyticsView.tsx +0 -244
  179. package/src/client/components/analytics/ChartCard.tsx +0 -194
  180. package/src/client/components/analytics/PeriodSelector.tsx +0 -42
  181. package/src/client/components/analytics/QuickStats.tsx +0 -122
  182. package/src/client/components/analytics/chartTokens.ts +0 -188
  183. package/src/client/components/analytics/charts/ActivityCalendar.tsx +0 -204
  184. package/src/client/components/analytics/charts/CacheEfficiencyChart.tsx +0 -56
  185. package/src/client/components/analytics/charts/ContextUtilizationChart.tsx +0 -106
  186. package/src/client/components/analytics/charts/CostAreaChart.tsx +0 -79
  187. package/src/client/components/analytics/charts/CostDistributionChart.tsx +0 -59
  188. package/src/client/components/analytics/charts/CostDonutChart.tsx +0 -84
  189. package/src/client/components/analytics/charts/CumulativeCostChart.tsx +0 -59
  190. package/src/client/components/analytics/charts/DailySummaryCards.tsx +0 -86
  191. package/src/client/components/analytics/charts/HourlyHeatmap.tsx +0 -133
  192. package/src/client/components/analytics/charts/NodeFleetOverview.tsx +0 -89
  193. package/src/client/components/analytics/charts/PermissionBreakdown.tsx +0 -98
  194. package/src/client/components/analytics/charts/ProjectRadar.tsx +0 -126
  195. package/src/client/components/analytics/charts/ResponseTimeScatter.tsx +0 -96
  196. package/src/client/components/analytics/charts/SessionBubbleChart.tsx +0 -114
  197. package/src/client/components/analytics/charts/SessionComplexityList.tsx +0 -65
  198. package/src/client/components/analytics/charts/SessionTimeline.tsx +0 -107
  199. package/src/client/components/analytics/charts/TokenFlowChart.tsx +0 -78
  200. package/src/client/components/analytics/charts/TokenSankeyChart.tsx +0 -93
  201. package/src/client/components/analytics/charts/ToolSunburst.tsx +0 -123
  202. package/src/client/components/analytics/charts/ToolTreemap.tsx +0 -110
  203. package/src/client/components/auth/PassphrasePrompt.tsx +0 -70
  204. package/src/client/components/chat/AttachmentChips.tsx +0 -116
  205. package/src/client/components/chat/ChatInput.tsx +0 -533
  206. package/src/client/components/chat/ChatView.tsx +0 -1076
  207. package/src/client/components/chat/CommandPalette.tsx +0 -162
  208. package/src/client/components/chat/ElicitationCard.tsx +0 -238
  209. package/src/client/components/chat/Message.tsx +0 -825
  210. package/src/client/components/chat/ModelSelector.tsx +0 -108
  211. package/src/client/components/chat/PermissionModeSelector.tsx +0 -41
  212. package/src/client/components/chat/PromptQuestion.tsx +0 -271
  213. package/src/client/components/chat/StatusBar.tsx +0 -50
  214. package/src/client/components/chat/TodoCard.tsx +0 -57
  215. package/src/client/components/chat/ToolGroup.tsx +0 -129
  216. package/src/client/components/chat/ToolResultRenderer.tsx +0 -348
  217. package/src/client/components/chat/VoiceRecorder.tsx +0 -85
  218. package/src/client/components/chat/toolSummary.ts +0 -41
  219. package/src/client/components/dashboard/DashboardView.tsx +0 -200
  220. package/src/client/components/dashboard/ProjectDashboardView.tsx +0 -179
  221. package/src/client/components/mesh/NodeBadge.tsx +0 -24
  222. package/src/client/components/mesh/PairingDialog.tsx +0 -340
  223. package/src/client/components/project-settings/ProjectClaude.tsx +0 -318
  224. package/src/client/components/project-settings/ProjectEnvironment.tsx +0 -235
  225. package/src/client/components/project-settings/ProjectGeneral.tsx +0 -76
  226. package/src/client/components/project-settings/ProjectMcp.tsx +0 -232
  227. package/src/client/components/project-settings/ProjectMemory.tsx +0 -488
  228. package/src/client/components/project-settings/ProjectNotifications.tsx +0 -48
  229. package/src/client/components/project-settings/ProjectPermissions.tsx +0 -209
  230. package/src/client/components/project-settings/ProjectPlugins.tsx +0 -117
  231. package/src/client/components/project-settings/ProjectRules.tsx +0 -286
  232. package/src/client/components/project-settings/ProjectSettingsView.tsx +0 -117
  233. package/src/client/components/project-settings/ProjectSkills.tsx +0 -91
  234. package/src/client/components/settings/Appearance.tsx +0 -275
  235. package/src/client/components/settings/BudgetSettings.tsx +0 -165
  236. package/src/client/components/settings/ClaudeSettings.tsx +0 -175
  237. package/src/client/components/settings/Editor.tsx +0 -123
  238. package/src/client/components/settings/Environment.tsx +0 -185
  239. package/src/client/components/settings/GlobalMcp.tsx +0 -216
  240. package/src/client/components/settings/GlobalMemory.tsx +0 -19
  241. package/src/client/components/settings/GlobalPlugins.tsx +0 -806
  242. package/src/client/components/settings/GlobalRules.tsx +0 -149
  243. package/src/client/components/settings/GlobalSkills.tsx +0 -140
  244. package/src/client/components/settings/MeshStatus.tsx +0 -183
  245. package/src/client/components/settings/Notifications.tsx +0 -123
  246. package/src/client/components/settings/SettingsView.tsx +0 -75
  247. package/src/client/components/settings/SkillMarketplace.tsx +0 -175
  248. package/src/client/components/settings/ThemePreview.tsx +0 -140
  249. package/src/client/components/settings/ThemeWizard.tsx +0 -405
  250. package/src/client/components/settings/mcp-shared.tsx +0 -194
  251. package/src/client/components/settings/skill-shared.tsx +0 -186
  252. package/src/client/components/setup/SetupWizard.tsx +0 -755
  253. package/src/client/components/sidebar/AddProjectModal.tsx +0 -438
  254. package/src/client/components/sidebar/NodeSettingsModal.tsx +0 -206
  255. package/src/client/components/sidebar/ProjectDropdown.tsx +0 -211
  256. package/src/client/components/sidebar/ProjectRail.tsx +0 -353
  257. package/src/client/components/sidebar/SearchFilter.tsx +0 -52
  258. package/src/client/components/sidebar/SessionList.tsx +0 -599
  259. package/src/client/components/sidebar/SettingsSidebar.tsx +0 -139
  260. package/src/client/components/sidebar/Sidebar.tsx +0 -469
  261. package/src/client/components/sidebar/UserIsland.tsx +0 -282
  262. package/src/client/components/sidebar/UserMenu.tsx +0 -107
  263. package/src/client/components/ui/CommandPalette.tsx +0 -321
  264. package/src/client/components/ui/ContextMenu.tsx +0 -153
  265. package/src/client/components/ui/ErrorBoundary.tsx +0 -56
  266. package/src/client/components/ui/IconPicker.tsx +0 -184
  267. package/src/client/components/ui/KeyboardShortcuts.tsx +0 -129
  268. package/src/client/components/ui/LatticeLogomark.tsx +0 -19
  269. package/src/client/components/ui/NodeDisconnectedOverlay.tsx +0 -35
  270. package/src/client/components/ui/PopupMenu.tsx +0 -120
  271. package/src/client/components/ui/SaveFooter.tsx +0 -63
  272. package/src/client/components/ui/Toast.tsx +0 -132
  273. package/src/client/components/ui/UpdateBanner.tsx +0 -110
  274. package/src/client/components/ui/UpdatePrompt.tsx +0 -47
  275. package/src/client/components/workspace/BookmarksView.tsx +0 -156
  276. package/src/client/components/workspace/FileBrowser.tsx +0 -174
  277. package/src/client/components/workspace/FileTree.tsx +0 -129
  278. package/src/client/components/workspace/FileViewer.tsx +0 -211
  279. package/src/client/components/workspace/NoteCard.tsx +0 -120
  280. package/src/client/components/workspace/NotesView.tsx +0 -102
  281. package/src/client/components/workspace/ScheduledTasksView.tsx +0 -117
  282. package/src/client/components/workspace/SplitPane.tsx +0 -81
  283. package/src/client/components/workspace/TabBar.tsx +0 -170
  284. package/src/client/components/workspace/TaskCard.tsx +0 -159
  285. package/src/client/components/workspace/TaskEditModal.tsx +0 -129
  286. package/src/client/components/workspace/TerminalInstance.tsx +0 -171
  287. package/src/client/components/workspace/TerminalView.tsx +0 -110
  288. package/src/client/components/workspace/WorkspaceView.tsx +0 -141
  289. package/src/client/hooks/useAnalytics.ts +0 -84
  290. package/src/client/hooks/useAttachments.ts +0 -313
  291. package/src/client/hooks/useBookmarks.ts +0 -57
  292. package/src/client/hooks/useEditorConfig.ts +0 -28
  293. package/src/client/hooks/useFocusTrap.ts +0 -74
  294. package/src/client/hooks/useIdleDetection.ts +0 -50
  295. package/src/client/hooks/useInstallPrompt.ts +0 -53
  296. package/src/client/hooks/useMesh.ts +0 -89
  297. package/src/client/hooks/useNotifications.ts +0 -54
  298. package/src/client/hooks/useOnline.ts +0 -6
  299. package/src/client/hooks/useProjectSettings.ts +0 -56
  300. package/src/client/hooks/useProjects.ts +0 -98
  301. package/src/client/hooks/usePushNotifications.ts +0 -92
  302. package/src/client/hooks/useSaveState.ts +0 -65
  303. package/src/client/hooks/useSession.ts +0 -580
  304. package/src/client/hooks/useSidebar.ts +0 -90
  305. package/src/client/hooks/useSkills.ts +0 -30
  306. package/src/client/hooks/useSpinnerVerb.ts +0 -36
  307. package/src/client/hooks/useSwipeDrawer.ts +0 -299
  308. package/src/client/hooks/useTheme.ts +0 -114
  309. package/src/client/hooks/useTimeTick.ts +0 -35
  310. package/src/client/hooks/useVoiceRecorder.ts +0 -169
  311. package/src/client/hooks/useWebSocket.ts +0 -27
  312. package/src/client/hooks/useWorkspace.ts +0 -57
  313. package/src/client/lib/theme-derive.ts +0 -196
  314. package/src/client/lib/workspace-url.ts +0 -219
  315. package/src/client/main.tsx +0 -10
  316. package/src/client/providers/WebSocketProvider.tsx +0 -186
  317. package/src/client/router.tsx +0 -578
  318. package/src/client/stores/analytics.ts +0 -68
  319. package/src/client/stores/bookmarks.ts +0 -45
  320. package/src/client/stores/mesh.ts +0 -78
  321. package/src/client/stores/session.ts +0 -569
  322. package/src/client/stores/sidebar.ts +0 -530
  323. package/src/client/stores/theme.ts +0 -44
  324. package/src/client/stores/workspace.ts +0 -518
  325. package/src/client/styles/global.css +0 -391
  326. package/src/client/styles/theme-vars.css +0 -18
  327. package/src/client/themes/index.ts +0 -105
  328. package/src/client/utils/editorUrl.ts +0 -55
  329. package/src/client/utils/findDuplicateKeys.ts +0 -12
  330. package/src/client/utils/formatSessionTitle.ts +0 -17
  331. package/src/client/vite-env.d.ts +0 -6
  332. package/src/server/analytics/engine.ts +0 -920
  333. package/src/server/assets.ts +0 -45
  334. package/src/server/auth/passphrase.ts +0 -78
  335. package/src/server/config.ts +0 -55
  336. package/src/server/daemon.ts +0 -567
  337. package/src/server/features/ralph-loop.ts +0 -173
  338. package/src/server/features/scheduler.ts +0 -304
  339. package/src/server/features/sticky-notes.ts +0 -104
  340. package/src/server/handlers/analytics.ts +0 -39
  341. package/src/server/handlers/attachment.ts +0 -189
  342. package/src/server/handlers/bookmarks.ts +0 -50
  343. package/src/server/handlers/chat.ts +0 -381
  344. package/src/server/handlers/editor.ts +0 -76
  345. package/src/server/handlers/fs.ts +0 -251
  346. package/src/server/handlers/loop.ts +0 -37
  347. package/src/server/handlers/memory.ts +0 -182
  348. package/src/server/handlers/mesh.ts +0 -362
  349. package/src/server/handlers/notes.ts +0 -47
  350. package/src/server/handlers/plugins.ts +0 -655
  351. package/src/server/handlers/project-settings.ts +0 -180
  352. package/src/server/handlers/scheduler.ts +0 -64
  353. package/src/server/handlers/session.ts +0 -226
  354. package/src/server/handlers/settings.ts +0 -157
  355. package/src/server/handlers/skills.ts +0 -378
  356. package/src/server/handlers/terminal.ts +0 -88
  357. package/src/server/handlers/themes.ts +0 -121
  358. package/src/server/handlers/update.ts +0 -133
  359. package/src/server/identity.ts +0 -56
  360. package/src/server/index.ts +0 -457
  361. package/src/server/logger.ts +0 -21
  362. package/src/server/mesh/connector.ts +0 -419
  363. package/src/server/mesh/crypto.ts +0 -106
  364. package/src/server/mesh/discovery.ts +0 -126
  365. package/src/server/mesh/pairing.ts +0 -123
  366. package/src/server/mesh/peers.ts +0 -60
  367. package/src/server/mesh/proxy.ts +0 -106
  368. package/src/server/mesh/session-sync.ts +0 -107
  369. package/src/server/project/bookmarks.ts +0 -83
  370. package/src/server/project/context-breakdown.ts +0 -307
  371. package/src/server/project/file-browser.ts +0 -106
  372. package/src/server/project/project-files.ts +0 -267
  373. package/src/server/project/pty-worker.cjs +0 -83
  374. package/src/server/project/registry.ts +0 -57
  375. package/src/server/project/sdk-bridge.ts +0 -1100
  376. package/src/server/project/session.ts +0 -723
  377. package/src/server/project/terminal.ts +0 -111
  378. package/src/server/project/warmup.ts +0 -285
  379. package/src/server/push.ts +0 -121
  380. package/src/server/tls.ts +0 -65
  381. package/src/server/tui.ts +0 -103
  382. package/src/server/update-checker.ts +0 -147
  383. package/src/server/ws/broadcast.ts +0 -61
  384. package/src/server/ws/router.ts +0 -123
  385. package/src/server/ws/server.ts +0 -2
  386. package/src/shared/analytics.ts +0 -40
  387. package/src/shared/messages.ts +0 -1302
  388. package/src/shared/models.ts +0 -255
  389. package/src/shared/project-settings.ts +0 -45
  390. package/tsconfig.json +0 -25
  391. package/vite.config.ts +0 -71
  392. /package/{src/server/runtime.ts → dist/server/runtime.js} +0 -0
  393. /package/{src/shared/constants.ts → dist/shared/constants.js} +0 -0
  394. /package/{src/shared/index.ts → dist/shared/index.js} +0 -0
@@ -1,110 +0,0 @@
1
- import { useState } from "react";
2
- import { Plus, X } from "lucide-react";
3
- import { TerminalInstance } from "./TerminalInstance";
4
-
5
- interface TerminalTab {
6
- id: string;
7
- label: string;
8
- }
9
-
10
- var nextTermNum = 1;
11
-
12
- function makeTab(): TerminalTab {
13
- var num = nextTermNum++;
14
- return { id: `term-${num}-${Date.now()}`, label: `Terminal ${num}` };
15
- }
16
-
17
- export function TerminalView() {
18
- var initialTab = makeTab();
19
- var [tabs, setTabs] = useState<TerminalTab[]>([initialTab]);
20
- var [activeId, setActiveId] = useState<string>(initialTab.id);
21
-
22
- function addTab() {
23
- var tab = makeTab();
24
- setTabs(function(prev) { return [...prev, tab]; });
25
- setActiveId(tab.id);
26
- }
27
-
28
- function closeTab(id: string) {
29
- setTabs(function(prev) {
30
- if (prev.length === 1) {
31
- var replacement = makeTab();
32
- setActiveId(replacement.id);
33
- return [replacement];
34
- }
35
- var next = prev.filter(function(t) { return t.id !== id; });
36
- if (id === activeId) {
37
- var idx = prev.findIndex(function(t) { return t.id === id; });
38
- var newActive = next[Math.min(idx, next.length - 1)];
39
- setActiveId(newActive.id);
40
- }
41
- return next;
42
- });
43
- }
44
-
45
- return (
46
- <div className="flex flex-col h-full w-full overflow-hidden">
47
- <div role="tablist" className="flex items-center h-8 bg-base-200 border-b border-base-content/15 flex-shrink-0 overflow-x-auto">
48
- {tabs.map(function(tab) {
49
- var isActive = tab.id === activeId;
50
- return (
51
- <div
52
- key={tab.id}
53
- tabIndex={0}
54
- role="tab"
55
- aria-selected={isActive}
56
- className={[
57
- "flex items-center gap-1 px-3 h-full text-[12px] cursor-pointer select-none border-r border-base-content/15 flex-shrink-0 outline-none focus-visible:ring-2 focus-visible:ring-primary/50 focus-visible:ring-offset-1 focus-visible:ring-offset-base-200",
58
- isActive
59
- ? "bg-base-100 text-base-content"
60
- : "text-base-content/50 hover:text-base-content hover:bg-base-100/50",
61
- ].join(" ")}
62
- onClick={function() { setActiveId(tab.id); }}
63
- onKeyDown={function(e) {
64
- if (e.key === "Enter" || e.key === " ") {
65
- e.preventDefault();
66
- setActiveId(tab.id);
67
- }
68
- }}
69
- >
70
- <span>{tab.label}</span>
71
- {tabs.length > 1 && (
72
- <button
73
- className="ml-1 rounded hover:bg-base-300 p-1 sm:p-0.5 outline-none focus-visible:ring-2 focus-visible:ring-primary/50 focus-visible:ring-offset-1 focus-visible:ring-offset-base-200"
74
- aria-label={"Close " + tab.label}
75
- onClick={function(e) {
76
- e.stopPropagation();
77
- closeTab(tab.id);
78
- }}
79
- >
80
- <X className="!size-3" />
81
- </button>
82
- )}
83
- </div>
84
- );
85
- })}
86
- <button
87
- className="flex items-center justify-center w-10 sm:w-8 h-full text-base-content/50 hover:text-base-content hover:bg-base-100/50 flex-shrink-0 outline-none focus-visible:ring-2 focus-visible:ring-primary/50 focus-visible:ring-offset-1 focus-visible:ring-offset-base-200"
88
- aria-label="New terminal"
89
- onClick={addTab}
90
- title="New terminal"
91
- >
92
- <Plus className="!size-4" />
93
- </button>
94
- </div>
95
- <div className="flex-1 min-h-0 relative">
96
- {tabs.map(function(tab) {
97
- return (
98
- <div
99
- key={tab.id}
100
- className="absolute inset-0"
101
- style={{ display: tab.id === activeId ? "block" : "none" }}
102
- >
103
- <TerminalInstance instanceId={tab.id} visible={tab.id === activeId} />
104
- </div>
105
- );
106
- })}
107
- </div>
108
- </div>
109
- );
110
- }
@@ -1,141 +0,0 @@
1
- import React from "react";
2
- import { WifiOff } from "lucide-react";
3
- import { useWorkspace } from "../../hooks/useWorkspace";
4
- import { useOnline } from "../../hooks/useOnline";
5
- import { TabBar } from "./TabBar";
6
- import { SplitPane } from "./SplitPane";
7
- import { ChatView } from "../chat/ChatView";
8
- import { TerminalView } from "./TerminalView";
9
- import { FileBrowser } from "./FileBrowser";
10
- import { NotesView } from "./NotesView";
11
- import { ScheduledTasksView } from "./ScheduledTasksView";
12
- import { BookmarksView } from "./BookmarksView";
13
- import { AnalyticsView } from "../analytics/AnalyticsView";
14
- import type { Pane, Tab } from "../../stores/workspace";
15
-
16
- var NON_CHAT_COMPONENTS: Record<string, () => React.JSX.Element> = {
17
- files: FileBrowser,
18
- terminal: TerminalView,
19
- notes: NotesView,
20
- tasks: ScheduledTasksView,
21
- bookmarks: BookmarksView,
22
- analytics: AnalyticsView,
23
- };
24
-
25
- function PaneContent({ pane, tabs, isActive, onFocus }: {
26
- pane: Pane;
27
- tabs: Tab[];
28
- isActive: boolean;
29
- onFocus: () => void;
30
- }) {
31
- var online = useOnline();
32
- var paneTabs = pane.tabIds.map(function (id) {
33
- return tabs.find(function (t) { return t.id === id; });
34
- }).filter(function (t): t is Tab { return t != null; });
35
-
36
- return (
37
- <div
38
- className="flex flex-col h-full w-full overflow-hidden"
39
- onClick={onFocus}
40
- >
41
- <TabBar paneId={pane.id} isActivePane={isActive} />
42
- {!online && (
43
- <div className="flex items-center gap-2 px-3 py-1.5 bg-warning/10 border-b border-warning/20 flex-shrink-0">
44
- <WifiOff size={13} className="text-warning flex-shrink-0" />
45
- <span className="text-[12px] text-warning">Disconnected — viewing only</span>
46
- </div>
47
- )}
48
- <div className="flex-1 min-h-0 relative">
49
- {paneTabs.map(function (tab) {
50
- var isTabActive = tab.id === pane.activeTabId;
51
- if (tab.type === "chat") {
52
- return (
53
- <div
54
- key={tab.id}
55
- className="absolute inset-0"
56
- style={{ display: isTabActive ? "flex" : "none", flexDirection: "column" }}
57
- >
58
- <ChatView sessionId={tab.sessionId} projectSlug={tab.projectSlug} />
59
- </div>
60
- );
61
- }
62
- var Component = NON_CHAT_COMPONENTS[tab.type];
63
- if (!Component) return null;
64
- return (
65
- <div
66
- key={tab.id}
67
- className="absolute inset-0"
68
- style={{ display: isTabActive ? "flex" : "none", flexDirection: "column" }}
69
- >
70
- <Component />
71
- </div>
72
- );
73
- })}
74
- </div>
75
- </div>
76
- );
77
- }
78
-
79
- export function WorkspaceView() {
80
- var { tabs, panes, activePaneId, splitDirection, splitRatio, setSplitRatio, setActivePaneId } = useWorkspace();
81
- var online = useOnline();
82
-
83
- if (!splitDirection || panes.length < 2) {
84
- var singlePane = panes[0];
85
- return (
86
- <div className="flex flex-col h-full w-full overflow-hidden">
87
- <TabBar paneId={singlePane?.id} />
88
- {!online && (
89
- <div className="flex items-center gap-2 px-3 py-1.5 bg-warning/10 border-b border-warning/20 flex-shrink-0 order-0 sm:order-none">
90
- <WifiOff size={13} className="text-warning flex-shrink-0" />
91
- <span className="text-[12px] text-warning">Disconnected — viewing only</span>
92
- </div>
93
- )}
94
- <div className="flex-1 min-h-0 relative order-0 sm:order-none">
95
- {tabs.map(function (tab) {
96
- var isActive = singlePane ? tab.id === singlePane.activeTabId : tab.id === "chat";
97
- if (tab.type === "chat") {
98
- return (
99
- <div
100
- key={tab.id}
101
- className="absolute inset-0"
102
- style={{ display: isActive ? "flex" : "none", flexDirection: "column" }}
103
- >
104
- <ChatView sessionId={tab.sessionId} projectSlug={tab.projectSlug} />
105
- </div>
106
- );
107
- }
108
- var Component = NON_CHAT_COMPONENTS[tab.type];
109
- if (!Component) return null;
110
- return (
111
- <div
112
- key={tab.id}
113
- className="absolute inset-0"
114
- style={{ display: isActive ? "flex" : "none", flexDirection: "column" }}
115
- >
116
- <Component />
117
- </div>
118
- );
119
- })}
120
- </div>
121
- </div>
122
- );
123
- }
124
-
125
- return (
126
- <SplitPane direction={splitDirection} ratio={splitRatio} onRatioChange={setSplitRatio}>
127
- <PaneContent
128
- pane={panes[0]}
129
- tabs={tabs}
130
- isActive={activePaneId === panes[0].id}
131
- onFocus={function () { setActivePaneId(panes[0].id); }}
132
- />
133
- <PaneContent
134
- pane={panes[1]}
135
- tabs={tabs}
136
- isActive={activePaneId === panes[1].id}
137
- onFocus={function () { setActivePaneId(panes[1].id); }}
138
- />
139
- </SplitPane>
140
- );
141
- }
@@ -1,84 +0,0 @@
1
- import { useCallback, useEffect, useRef } from "react";
2
- import { useStore } from "@tanstack/react-store";
3
- import { useWebSocket } from "./useWebSocket";
4
- import type { ServerMessage } from "#shared";
5
- import type { AnalyticsPeriod, AnalyticsScope, AnalyticsSectionName } from "#shared";
6
- import type { AnalyticsPayload } from "#shared";
7
- import {
8
- getAnalyticsStore,
9
- mergeAnalyticsSection,
10
- clearAnalyticsForRequest,
11
- setAnalyticsLoading,
12
- setAnalyticsError,
13
- setAnalyticsPeriod,
14
- setAnalyticsScope,
15
- } from "../stores/analytics";
16
- import type { AnalyticsState } from "../stores/analytics";
17
-
18
- export function useAnalytics(): AnalyticsState & {
19
- setPeriod: (period: AnalyticsPeriod) => void;
20
- setScope: (scope: AnalyticsScope, projectSlug?: string) => void;
21
- refresh: () => void;
22
- } {
23
- var store = getAnalyticsStore();
24
- var state = useStore(store, function (s) { return s; });
25
- var { send, subscribe, unsubscribe } = useWebSocket();
26
- var sendRef = useRef(send);
27
- sendRef.current = send;
28
-
29
- var requestAnalytics = useCallback(function (forceRefresh?: boolean) {
30
- var s = getAnalyticsStore().state;
31
- clearAnalyticsForRequest();
32
- sendRef.current({
33
- type: "analytics:request",
34
- requestId: crypto.randomUUID(),
35
- scope: s.scope,
36
- projectSlug: s.projectSlug || undefined,
37
- period: s.period,
38
- forceRefresh: forceRefresh,
39
- } as any);
40
- }, []);
41
-
42
- useEffect(function () {
43
- function handleSection(msg: ServerMessage) {
44
- var m = msg as { type: string; section: AnalyticsSectionName; data: Partial<AnalyticsPayload> };
45
- mergeAnalyticsSection(m.section, m.data);
46
- }
47
-
48
- function handleComplete() {
49
- setAnalyticsLoading(false);
50
- }
51
-
52
- function handleError(msg: ServerMessage) {
53
- var m = msg as { type: string; message: string };
54
- setAnalyticsError(m.message);
55
- }
56
-
57
- subscribe("analytics:section", handleSection);
58
- subscribe("analytics:complete", handleComplete);
59
- subscribe("analytics:error", handleError);
60
-
61
- return function () {
62
- unsubscribe("analytics:section", handleSection);
63
- unsubscribe("analytics:complete", handleComplete);
64
- unsubscribe("analytics:error", handleError);
65
- };
66
- }, [subscribe, unsubscribe]);
67
-
68
- useEffect(function () {
69
- requestAnalytics();
70
- }, [state.period, state.scope, state.projectSlug, requestAnalytics]);
71
-
72
- return {
73
- data: state.data,
74
- loadedSections: state.loadedSections,
75
- loading: state.loading,
76
- error: state.error,
77
- period: state.period,
78
- scope: state.scope,
79
- projectSlug: state.projectSlug,
80
- setPeriod: setAnalyticsPeriod,
81
- setScope: setAnalyticsScope,
82
- refresh: function () { requestAnalytics(true); },
83
- };
84
- }
@@ -1,313 +0,0 @@
1
- import { useState, useCallback, useRef, useEffect } from "react";
2
- import { useWebSocket } from "./useWebSocket";
3
- import type { ServerMessage } from "#shared";
4
-
5
- var CHUNK_SIZE = 64 * 1024;
6
- var MAX_FILE_SIZE = 50 * 1024 * 1024;
7
- var MAX_ATTACHMENTS = 20;
8
- var CHUNK_TIMEOUT_MS = 10000;
9
-
10
- export type AttachmentStatus = "uploading" | "ready" | "failed";
11
-
12
- export interface ClientAttachment {
13
- id: string;
14
- name: string;
15
- type: "file" | "image" | "paste";
16
- mimeType: string;
17
- size: number;
18
- lineCount?: number;
19
- status: AttachmentStatus;
20
- progress: number;
21
- error?: string;
22
- previewUrl?: string;
23
- content?: string;
24
- }
25
-
26
- export interface UseAttachmentsReturn {
27
- attachments: ClientAttachment[];
28
- addFile: (file: File) => void;
29
- addPaste: (text: string) => void;
30
- removeAttachment: (id: string) => void;
31
- retryAttachment: (id: string) => void;
32
- clearAll: () => void;
33
- readyIds: string[];
34
- hasUploading: boolean;
35
- canAttach: boolean;
36
- }
37
-
38
- function guessMimeType(file: File): string {
39
- if (file.type) return file.type;
40
- var ext = file.name.split(".").pop()?.toLowerCase() || "";
41
- var map: Record<string, string> = {
42
- ts: "application/typescript",
43
- tsx: "application/typescript",
44
- js: "application/javascript",
45
- jsx: "application/javascript",
46
- json: "application/json",
47
- yaml: "application/yaml",
48
- yml: "application/yaml",
49
- md: "text/markdown",
50
- txt: "text/plain",
51
- csv: "text/csv",
52
- py: "text/x-python",
53
- rs: "text/x-rust",
54
- go: "text/x-go",
55
- rb: "text/x-ruby",
56
- sh: "text/x-shellscript",
57
- css: "text/css",
58
- html: "text/html",
59
- xml: "application/xml",
60
- svg: "image/svg+xml",
61
- png: "image/png",
62
- jpg: "image/jpeg",
63
- jpeg: "image/jpeg",
64
- gif: "image/gif",
65
- webp: "image/webp",
66
- };
67
- return map[ext] || "application/octet-stream";
68
- }
69
-
70
- function isImageType(mime: string): boolean {
71
- return mime.startsWith("image/") && mime !== "image/svg+xml";
72
- }
73
-
74
- export function useAttachments(): UseAttachmentsReturn {
75
- var [attachments, setAttachments] = useState<ClientAttachment[]>([]);
76
- var { send, subscribe, unsubscribe } = useWebSocket();
77
- var pendingResolvers = useRef(new Map<string, { resolve: () => void; reject: (err: string) => void; timer: ReturnType<typeof setTimeout> }>());
78
- var fileCache = useRef(new Map<string, File>());
79
- var attachmentsRef = useRef(attachments);
80
- attachmentsRef.current = attachments;
81
-
82
- var updateAttachment = useCallback(function (id: string, updates: Partial<ClientAttachment>) {
83
- setAttachments(function (prev) {
84
- return prev.map(function (a) {
85
- return a.id === id ? { ...a, ...updates } : a;
86
- });
87
- });
88
- }, []);
89
-
90
- var uploadFile = useCallback(function (attachment: ClientAttachment, file: File) {
91
- var reader = new FileReader();
92
- reader.onload = function () {
93
- var buffer = reader.result as ArrayBuffer;
94
- var bytes = new Uint8Array(buffer);
95
- var totalChunks = Math.ceil(bytes.length / CHUNK_SIZE);
96
-
97
- var chunkIndex = 0;
98
-
99
- function sendNextChunk() {
100
- if (chunkIndex >= totalChunks) {
101
- send({
102
- type: "attachment:complete",
103
- attachmentId: attachment.id,
104
- attachmentType: attachment.type,
105
- name: attachment.name,
106
- mimeType: attachment.mimeType,
107
- size: attachment.size,
108
- lineCount: attachment.lineCount,
109
- });
110
- return;
111
- }
112
-
113
- var start = chunkIndex * CHUNK_SIZE;
114
- var end = Math.min(start + CHUNK_SIZE, bytes.length);
115
- var chunk = bytes.slice(start, end);
116
- var binary = "";
117
- for (var bi = 0; bi < chunk.length; bi++) {
118
- binary += String.fromCharCode(chunk[bi]);
119
- }
120
- var base64 = btoa(binary);
121
-
122
- send({
123
- type: "attachment:chunk",
124
- attachmentId: attachment.id,
125
- chunkIndex,
126
- totalChunks,
127
- data: base64,
128
- });
129
-
130
- var currentChunk = chunkIndex;
131
- var timer = setTimeout(function () {
132
- pendingResolvers.current.delete(attachment.id + ":" + currentChunk);
133
- updateAttachment(attachment.id, { status: "failed", error: "Upload timed out" });
134
- }, CHUNK_TIMEOUT_MS);
135
-
136
- pendingResolvers.current.set(attachment.id + ":" + currentChunk, {
137
- resolve: function () {
138
- clearTimeout(timer);
139
- chunkIndex++;
140
- var progress = Math.round((chunkIndex / totalChunks) * 100);
141
- updateAttachment(attachment.id, { progress });
142
- sendNextChunk();
143
- },
144
- reject: function (err: string) {
145
- clearTimeout(timer);
146
- updateAttachment(attachment.id, { status: "failed", error: err });
147
- },
148
- timer,
149
- });
150
- }
151
-
152
- function handleProgress(msg: ServerMessage) {
153
- var m = msg as { type: string; attachmentId: string; received: number; total: number };
154
- if (m.attachmentId !== attachment.id) return;
155
- var key = attachment.id + ":" + (m.received - 1);
156
- var resolver = pendingResolvers.current.get(key);
157
- if (resolver) {
158
- pendingResolvers.current.delete(key);
159
- resolver.resolve();
160
- }
161
- if (m.received === m.total) {
162
- updateAttachment(attachment.id, { status: "ready", progress: 100 });
163
- unsubscribe("attachment:progress", handleProgress);
164
- unsubscribe("attachment:error", handleError);
165
- }
166
- }
167
-
168
- function handleError(msg: ServerMessage) {
169
- var m = msg as { type: string; attachmentId: string; error: string };
170
- if (m.attachmentId !== attachment.id) return;
171
- updateAttachment(attachment.id, { status: "failed", error: m.error });
172
- unsubscribe("attachment:progress", handleProgress);
173
- unsubscribe("attachment:error", handleError);
174
- }
175
-
176
- subscribe("attachment:progress", handleProgress);
177
- subscribe("attachment:error", handleError);
178
- sendNextChunk();
179
- };
180
- reader.readAsArrayBuffer(file);
181
- }, [send, subscribe, unsubscribe, updateAttachment]);
182
-
183
- var addFile = useCallback(function (file: File) {
184
- if (file.size > MAX_FILE_SIZE) {
185
- return;
186
- }
187
-
188
- var id = crypto.randomUUID();
189
- var mime = guessMimeType(file);
190
- var type: "file" | "image" = isImageType(mime) ? "image" : "file";
191
-
192
- var previewUrl: string | undefined;
193
- if (type === "image") {
194
- previewUrl = URL.createObjectURL(file);
195
- }
196
-
197
- var att: ClientAttachment = {
198
- id,
199
- name: file.name,
200
- type,
201
- mimeType: mime,
202
- size: file.size,
203
- status: "uploading",
204
- progress: 0,
205
- previewUrl,
206
- };
207
-
208
- var added = false;
209
- setAttachments(function (prev) {
210
- if (prev.length >= MAX_ATTACHMENTS) {
211
- return prev;
212
- }
213
- added = true;
214
- return [...prev, att];
215
- });
216
-
217
- if (added) {
218
- fileCache.current.set(id, file);
219
- uploadFile(att, file);
220
- } else if (previewUrl) {
221
- URL.revokeObjectURL(previewUrl);
222
- }
223
- }, [uploadFile]);
224
-
225
- var addPaste = useCallback(function (text: string) {
226
- var id = crypto.randomUUID();
227
- var blob = new Blob([text], { type: "text/plain" });
228
- var file = new File([blob], "pasted-text.txt", { type: "text/plain" });
229
- var lineCount = text.split("\n").length;
230
-
231
- var att: ClientAttachment = {
232
- id,
233
- name: "Pasted text",
234
- type: "paste",
235
- mimeType: "text/plain",
236
- size: blob.size,
237
- lineCount,
238
- status: "uploading",
239
- progress: 0,
240
- content: text,
241
- };
242
-
243
- var added = false;
244
- setAttachments(function (prev) {
245
- if (prev.length >= MAX_ATTACHMENTS) {
246
- return prev;
247
- }
248
- added = true;
249
- return [...prev, att];
250
- });
251
-
252
- if (added) {
253
- fileCache.current.set(id, file);
254
- uploadFile(att, file);
255
- }
256
- }, [uploadFile]);
257
-
258
- var removeAttachment = useCallback(function (id: string) {
259
- setAttachments(function (prev) {
260
- var removed = prev.find(function (a) { return a.id === id; });
261
- if (removed && removed.previewUrl) {
262
- URL.revokeObjectURL(removed.previewUrl);
263
- }
264
- return prev.filter(function (a) { return a.id !== id; });
265
- });
266
- fileCache.current.delete(id);
267
- }, []);
268
-
269
- var retryAttachment = useCallback(function (id: string) {
270
- var file = fileCache.current.get(id);
271
- var att = attachments.find(function (a) { return a.id === id; });
272
- if (!file || !att) return;
273
- updateAttachment(id, { status: "uploading", progress: 0, error: undefined });
274
- uploadFile(att, file);
275
- }, [attachments, uploadFile, updateAttachment]);
276
-
277
- var clearAll = useCallback(function () {
278
- attachments.forEach(function (a) {
279
- if (a.previewUrl) URL.revokeObjectURL(a.previewUrl);
280
- });
281
- setAttachments([]);
282
- fileCache.current.clear();
283
- }, [attachments]);
284
-
285
- useEffect(function () {
286
- return function () {
287
- attachmentsRef.current.forEach(function (att) {
288
- if (att.previewUrl) {
289
- URL.revokeObjectURL(att.previewUrl);
290
- }
291
- });
292
- };
293
- }, []);
294
-
295
- var readyIds = attachments
296
- .filter(function (a) { return a.status === "ready"; })
297
- .map(function (a) { return a.id; });
298
-
299
- var hasUploading = attachments.some(function (a) { return a.status === "uploading"; });
300
- var canAttach = attachments.length < MAX_ATTACHMENTS;
301
-
302
- return {
303
- attachments,
304
- addFile,
305
- addPaste,
306
- removeAttachment,
307
- retryAttachment,
308
- clearAll,
309
- readyIds,
310
- hasUploading,
311
- canAttach,
312
- };
313
- }
@@ -1,57 +0,0 @@
1
- import { useEffect } from "react";
2
- import { useStore } from "@tanstack/react-store";
3
- import type { ServerMessage, BookmarkListResultMessage, MessageBookmark } from "#shared";
4
- import { useWebSocket } from "./useWebSocket";
5
- import { getBookmarkStore, setBookmarks, setAllBookmarks } from "../stores/bookmarks";
6
- import { getSessionStore } from "../stores/session";
7
- import type { BookmarkState } from "../stores/bookmarks";
8
-
9
- export function useBookmarks(): BookmarkState & {
10
- requestSessionBookmarks: () => void;
11
- requestAllBookmarks: () => void;
12
- } {
13
- var store = getBookmarkStore();
14
- var state = useStore(store, function (s) { return s; });
15
- var { send, subscribe, unsubscribe } = useWebSocket();
16
-
17
- useEffect(function () {
18
- function handleBookmarkList(msg: ServerMessage) {
19
- if (msg.type !== "bookmark:list_result") return;
20
- var data = msg as BookmarkListResultMessage;
21
- if (data.scope === "session") {
22
- setBookmarks(data.bookmarks);
23
- } else {
24
- setAllBookmarks(data.bookmarks);
25
- var sessionState = getSessionStore().state;
26
- if (sessionState.activeSessionId) {
27
- var sessionBookmarks = data.bookmarks.filter(function (b: MessageBookmark) {
28
- return b.sessionId === sessionState.activeSessionId;
29
- });
30
- setBookmarks(sessionBookmarks);
31
- }
32
- }
33
- }
34
-
35
- subscribe("bookmark:list_result", handleBookmarkList);
36
- return function () {
37
- unsubscribe("bookmark:list_result", handleBookmarkList);
38
- };
39
- }, [subscribe, unsubscribe]);
40
-
41
- function requestSessionBookmarks() {
42
- var sessionState = getSessionStore().state;
43
- if (!sessionState.activeSessionId || !sessionState.activeProjectSlug) return;
44
- send({ type: "bookmark:list", projectSlug: sessionState.activeProjectSlug, sessionId: sessionState.activeSessionId });
45
- }
46
-
47
- function requestAllBookmarks() {
48
- send({ type: "bookmark:list" });
49
- }
50
-
51
- return {
52
- bookmarks: state.bookmarks,
53
- allBookmarks: state.allBookmarks,
54
- requestSessionBookmarks,
55
- requestAllBookmarks,
56
- };
57
- }