@myrialabs/clopen 0.2.1 → 0.2.3

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 (422) hide show
  1. package/.dockerignore +5 -0
  2. package/.env.example +2 -5
  3. package/CONTRIBUTING.md +4 -0
  4. package/README.md +4 -2
  5. package/backend/{lib/auth → auth}/auth-service.ts +2 -2
  6. package/backend/{lib/chat → chat}/stream-manager.ts +1 -1
  7. package/backend/{lib/database → database}/queries/message-queries.ts +42 -0
  8. package/backend/{lib/database → database}/utils/connection.ts +5 -5
  9. package/backend/{lib/engine → engine}/adapters/claude/environment.ts +3 -4
  10. package/backend/{lib/engine → engine}/adapters/opencode/message-converter.ts +1 -1
  11. package/backend/{lib/engine → engine}/adapters/opencode/server.ts +7 -1
  12. package/backend/{lib/files → files}/file-watcher.ts +1 -1
  13. package/backend/{lib/git → git}/git-executor.ts +3 -2
  14. package/backend/index.ts +16 -16
  15. package/backend/{lib/mcp → mcp}/README.md +68 -79
  16. package/backend/{lib/mcp → mcp}/config.ts +1 -1
  17. package/backend/{lib/mcp → mcp}/servers/browser-automation/actions.ts +4 -4
  18. package/backend/{lib/mcp → mcp}/servers/browser-automation/browser.ts +3 -3
  19. package/backend/{lib/mcp → mcp}/servers/browser-automation/inspection.ts +3 -3
  20. package/backend/middleware/cors.ts +1 -1
  21. package/backend/middleware/error-handler.ts +1 -1
  22. package/backend/{lib/preview → preview}/browser/browser-preview-service.ts +1 -1
  23. package/backend/{lib/preview → preview}/browser/browser-tab-manager.ts +1 -1
  24. package/backend/{lib/preview → preview}/browser/types.ts +1 -1
  25. package/backend/{lib/project → project}/status-manager.ts +223 -223
  26. package/backend/{lib/snapshot → snapshot}/blob-store.ts +2 -2
  27. package/backend/{lib/terminal → terminal}/shell-utils.ts +1 -1
  28. package/backend/{lib/shared → utils}/env.ts +13 -15
  29. package/backend/{lib/shared → utils}/index.ts +4 -1
  30. package/backend/utils/paths.ts +11 -0
  31. package/backend/{lib/shared → utils}/port-utils.ts +19 -6
  32. package/backend/{lib/utils → utils}/ws.ts +2 -2
  33. package/backend/ws/README.md +9 -9
  34. package/backend/ws/auth/invites.ts +2 -2
  35. package/backend/ws/auth/login.ts +9 -9
  36. package/backend/ws/auth/status.ts +2 -2
  37. package/backend/ws/auth/users.ts +1 -1
  38. package/backend/ws/chat/background.ts +2 -2
  39. package/backend/ws/chat/stream.ts +3 -3
  40. package/backend/ws/engine/claude/accounts.ts +4 -4
  41. package/backend/ws/engine/claude/status.ts +1 -1
  42. package/backend/ws/files/read.ts +2 -2
  43. package/backend/ws/files/watch.ts +2 -2
  44. package/backend/ws/files/write.ts +1 -1
  45. package/backend/ws/git/branch.ts +2 -2
  46. package/backend/ws/git/commit.ts +2 -2
  47. package/backend/ws/git/conflict.ts +2 -2
  48. package/backend/ws/git/diff.ts +2 -2
  49. package/backend/ws/git/log.ts +2 -2
  50. package/backend/ws/git/remote.ts +2 -2
  51. package/backend/ws/git/staging.ts +2 -2
  52. package/backend/ws/git/status.ts +3 -3
  53. package/backend/ws/messages/crud.ts +53 -1
  54. package/backend/ws/preview/browser/cleanup.ts +2 -2
  55. package/backend/ws/preview/browser/console.ts +2 -2
  56. package/backend/ws/preview/browser/interact.ts +2 -2
  57. package/backend/ws/preview/browser/mcp.ts +1 -1
  58. package/backend/ws/preview/browser/native-ui.ts +2 -2
  59. package/backend/ws/preview/browser/stats.ts +2 -2
  60. package/backend/ws/preview/browser/tab-info.ts +2 -2
  61. package/backend/ws/preview/browser/tab.ts +2 -2
  62. package/backend/ws/preview/browser/webcodecs.ts +2 -2
  63. package/backend/ws/projects/crud.ts +3 -3
  64. package/backend/ws/projects/presence.ts +3 -3
  65. package/backend/ws/projects/status.ts +3 -3
  66. package/backend/ws/sessions/crud.ts +2 -2
  67. package/backend/ws/settings/crud.ts +2 -2
  68. package/backend/ws/snapshot/restore.ts +5 -5
  69. package/backend/ws/snapshot/timeline.ts +3 -3
  70. package/backend/ws/system/operations.ts +1 -1
  71. package/backend/ws/terminal/persistence.ts +3 -3
  72. package/backend/ws/terminal/session.ts +6 -6
  73. package/backend/ws/terminal/stream.ts +2 -2
  74. package/backend/ws/tunnel/operations.ts +1 -1
  75. package/backend/ws/user/crud.ts +4 -4
  76. package/bin/clopen.ts +15 -15
  77. package/docker-compose.yml +31 -0
  78. package/frontend/App.svelte +13 -13
  79. package/frontend/{lib/components → components}/auth/InvitePage.svelte +2 -2
  80. package/frontend/{lib/components → components}/auth/LoginPage.svelte +1 -1
  81. package/frontend/{lib/components → components}/auth/SetupPage.svelte +49 -17
  82. package/frontend/{lib/components → components}/chat/ChatInterface.svelte +14 -14
  83. package/frontend/{lib/components → components}/chat/formatters/ErrorMessage.svelte +1 -1
  84. package/frontend/{lib/components → components}/chat/formatters/MessageFormatter.svelte +4 -4
  85. package/frontend/{lib/components → components}/chat/formatters/TextMessage.svelte +1 -1
  86. package/frontend/{lib/components → components}/chat/formatters/Tools.svelte +1 -1
  87. package/frontend/{lib/components → components}/chat/input/ChatInput.svelte +12 -12
  88. package/frontend/{lib/components → components}/chat/input/components/ChatInputActions.svelte +1 -1
  89. package/frontend/{lib/components → components}/chat/input/components/EditModeIndicator.svelte +2 -2
  90. package/frontend/{lib/components → components}/chat/input/components/EngineModelPicker.svelte +9 -9
  91. package/frontend/{lib/components → components}/chat/input/components/FileAttachmentPreview.svelte +1 -1
  92. package/frontend/{lib/components → components}/chat/input/components/LoadingIndicator.svelte +2 -2
  93. package/frontend/{lib/components → components}/chat/input/composables/use-chat-actions.svelte.ts +8 -8
  94. package/frontend/{lib/components → components}/chat/input/composables/use-file-handling.svelte.ts +1 -1
  95. package/frontend/{lib/components → components}/chat/input/composables/use-input-state.svelte.ts +6 -6
  96. package/frontend/{lib/components → components}/chat/message/ChatMessage.svelte +8 -8
  97. package/frontend/{lib/components → components}/chat/message/ChatMessages.svelte +7 -7
  98. package/frontend/{lib/components → components}/chat/message/MessageBubble.svelte +1 -1
  99. package/frontend/{lib/components → components}/chat/message/MessageHeader.svelte +2 -2
  100. package/frontend/{lib/components → components}/chat/modal/DebugModal.svelte +2 -2
  101. package/frontend/{lib/components → components}/chat/modal/TokenUsageModal.svelte +2 -2
  102. package/frontend/{lib/components → components}/chat/tools/AskUserQuestionTool.svelte +4 -4
  103. package/frontend/{lib/components → components}/chat/tools/CustomMcpTool.svelte +1 -1
  104. package/frontend/{lib/components → components}/chat/tools/EditTool.svelte +1 -1
  105. package/frontend/{lib/components → components}/chat/tools/TodoWriteTool.svelte +1 -1
  106. package/frontend/{lib/components → components}/chat/tools/components/CodeBlock.svelte +2 -2
  107. package/frontend/{lib/components → components}/chat/tools/components/DiffBlock.svelte +1 -1
  108. package/frontend/{lib/components → components}/chat/tools/components/FileHeader.svelte +2 -2
  109. package/frontend/{lib/components → components}/chat/tools/components/InfoLine.svelte +1 -1
  110. package/frontend/{lib/components → components}/chat/widgets/FloatingTodoList.svelte +127 -13
  111. package/frontend/{lib/components → components}/chat/widgets/TokenUsage.svelte +4 -4
  112. package/frontend/{lib/components → components}/checkpoint/TimelineModal.svelte +10 -10
  113. package/frontend/{lib/components → components}/checkpoint/timeline/TimelineNode.svelte +1 -1
  114. package/frontend/{lib/components/common → components/common/display}/Icon.svelte +2 -2
  115. package/frontend/{lib/components/common → components/common/display}/PageTemplate.svelte +1 -1
  116. package/frontend/{lib/components/common → components/common/display}/ProjectUserAvatars.svelte +1 -1
  117. package/frontend/{lib/components/common → components/common/display}/ThemeToggle.svelte +1 -1
  118. package/frontend/{lib/components/common → components/common/editor}/MonacoEditor.svelte +2 -2
  119. package/frontend/{lib/components/common → components/common/feedback}/Alert.svelte +1 -1
  120. package/frontend/{lib/components/common → components/common/feedback}/ConnectionBanner.svelte +3 -3
  121. package/frontend/{lib/components/common → components/common/feedback}/LoadingScreen.svelte +1 -1
  122. package/frontend/{lib/components/common → components/common/feedback}/NotificationToast.svelte +2 -2
  123. package/frontend/{lib/components/common → components/common/feedback}/UpdateBanner.svelte +5 -5
  124. package/frontend/{lib/components/common → components/common/form}/Checkbox.svelte +1 -1
  125. package/frontend/{lib/components/common → components/common/form}/FolderBrowser.svelte +6 -6
  126. package/frontend/{lib/components/common → components/common/form}/Input.svelte +1 -1
  127. package/frontend/{lib/components/common → components/common/form}/ModelSelector.svelte +3 -3
  128. package/frontend/{lib/components/common → components/common/form}/Select.svelte +1 -1
  129. package/frontend/{lib/components/common → components/common/form}/Textarea.svelte +1 -1
  130. package/frontend/{lib/components/common → components/common/overlay}/Dialog.svelte +1 -1
  131. package/frontend/{lib/components/common → components/common/overlay}/Lightbox.svelte +3 -3
  132. package/frontend/{lib/components/common → components/common/overlay}/ModalProvider.svelte +2 -2
  133. package/frontend/{lib/components → components}/common/xterm/XTerm.svelte +5 -5
  134. package/frontend/{lib/components → components}/common/xterm/xterm-service.ts +2 -2
  135. package/frontend/{lib/components → components}/files/FileNode.svelte +3 -3
  136. package/frontend/{lib/components → components}/files/FileTree.svelte +5 -5
  137. package/frontend/{lib/components → components}/files/FileViewer.svelte +7 -7
  138. package/frontend/{lib/components → components}/files/SearchResults.svelte +3 -3
  139. package/frontend/{lib/components → components}/git/BranchManager.svelte +6 -6
  140. package/frontend/{lib/components → components}/git/ChangesSection.svelte +1 -1
  141. package/frontend/{lib/components → components}/git/CommitForm.svelte +1 -1
  142. package/frontend/{lib/components → components}/git/ConflictResolver.svelte +1 -1
  143. package/frontend/{lib/components → components}/git/DiffViewer.svelte +7 -7
  144. package/frontend/{lib/components → components}/git/FileChangeItem.svelte +3 -3
  145. package/frontend/{lib/components → components}/git/GitButton.svelte +1 -1
  146. package/frontend/{lib/components → components}/git/GitLog.svelte +2 -2
  147. package/frontend/{lib/components → components}/git/GitModal.svelte +3 -3
  148. package/frontend/{lib/components → components}/history/HistoryModal.svelte +41 -89
  149. package/frontend/{lib/components → components}/history/HistoryView.svelte +57 -104
  150. package/frontend/{lib/components → components}/index.ts +9 -9
  151. package/frontend/{lib/components → components}/preview/browser/BrowserPreview.svelte +3 -3
  152. package/frontend/{lib/components → components}/preview/browser/components/Canvas.svelte +2 -2
  153. package/frontend/{lib/components → components}/preview/browser/components/ConsolePanel.svelte +1 -1
  154. package/frontend/{lib/components → components}/preview/browser/components/Container.svelte +2 -2
  155. package/frontend/{lib/components → components}/preview/browser/components/ContextMenu.svelte +1 -1
  156. package/frontend/{lib/components → components}/preview/browser/components/SelectDropdown.svelte +1 -1
  157. package/frontend/{lib/components → components}/preview/browser/components/Toolbar.svelte +2 -2
  158. package/frontend/{lib/components → components}/preview/browser/core/cleanup.svelte.ts +1 -1
  159. package/frontend/{lib/components → components}/preview/browser/core/coordinator.svelte.ts +4 -4
  160. package/frontend/{lib/components → components}/preview/browser/core/interactions.svelte.ts +3 -3
  161. package/frontend/{lib/components → components}/preview/browser/core/mcp-handlers.svelte.ts +2 -2
  162. package/frontend/{lib/components → components}/preview/browser/core/native-ui-handlers.svelte.ts +2 -2
  163. package/frontend/{lib/components → components}/preview/browser/core/tab-manager.svelte.ts +1 -1
  164. package/frontend/{lib/components → components}/preview/browser/core/tab-operations.svelte.ts +3 -3
  165. package/frontend/{lib/components → components}/settings/SettingsModal.svelte +4 -4
  166. package/frontend/{lib/components → components}/settings/SettingsView.svelte +2 -2
  167. package/frontend/{lib/components → components}/settings/admin/InviteManagement.svelte +5 -5
  168. package/frontend/{lib/components → components}/settings/admin/UserManagement.svelte +5 -5
  169. package/frontend/{lib/components → components}/settings/appearance/AppearanceSettings.svelte +5 -5
  170. package/frontend/{lib/components → components}/settings/appearance/LayoutPresetSettings.svelte +3 -3
  171. package/frontend/{lib/components → components}/settings/appearance/LayoutPreview.svelte +1 -1
  172. package/frontend/{lib/components → components}/settings/engines/AIEnginesSettings.svelte +6 -6
  173. package/frontend/{lib/components → components}/settings/general/AdvancedSettings.svelte +5 -5
  174. package/frontend/{lib/components → components}/settings/general/AuthModeSettings.svelte +5 -5
  175. package/frontend/{lib/components → components}/settings/general/DataManagementSettings.svelte +9 -9
  176. package/frontend/{lib/components → components}/settings/general/UpdateSettings.svelte +3 -3
  177. package/frontend/{lib/components → components}/settings/model/ModelSettings.svelte +2 -2
  178. package/frontend/{lib/components → components}/settings/notifications/NotificationSettings.svelte +4 -4
  179. package/frontend/{lib/components → components}/settings/user/UserSettings.svelte +5 -5
  180. package/frontend/{lib/components → components}/terminal/Terminal.svelte +9 -9
  181. package/frontend/{lib/components → components}/terminal/TerminalTabs.svelte +1 -1
  182. package/frontend/{lib/components → components}/terminal/TerminalView.svelte +5 -5
  183. package/frontend/{lib/components → components}/tunnel/TunnelActive.svelte +3 -3
  184. package/frontend/{lib/components → components}/tunnel/TunnelButton.svelte +2 -2
  185. package/frontend/{lib/components → components}/tunnel/TunnelInactive.svelte +4 -4
  186. package/frontend/{lib/components → components}/tunnel/TunnelModal.svelte +2 -2
  187. package/frontend/{lib/components → components}/workspace/DesktopNavigator.svelte +372 -372
  188. package/frontend/{lib/components → components}/workspace/MobileNavigator.svelte +380 -380
  189. package/frontend/{lib/components → components}/workspace/PanelContainer.svelte +3 -3
  190. package/frontend/{lib/components → components}/workspace/PanelHeader.svelte +10 -10
  191. package/frontend/{lib/components → components}/workspace/ViewMenu.svelte +4 -4
  192. package/frontend/{lib/components → components}/workspace/WorkspaceLayout.svelte +17 -17
  193. package/frontend/{lib/components → components}/workspace/layout/DesktopLayout.svelte +1 -1
  194. package/frontend/{lib/components → components}/workspace/layout/MobileLayout.svelte +1 -1
  195. package/frontend/{lib/components → components}/workspace/layout/split-pane/Container.svelte +1 -1
  196. package/frontend/{lib/components → components}/workspace/layout/split-pane/Handle.svelte +2 -2
  197. package/frontend/{lib/components → components}/workspace/layout/split-pane/Layout.svelte +2 -2
  198. package/frontend/{lib/components → components}/workspace/panels/ChatPanel.svelte +14 -14
  199. package/frontend/{lib/components → components}/workspace/panels/FilesPanel.svelte +51 -13
  200. package/frontend/{lib/components → components}/workspace/panels/GitPanel.svelte +55 -17
  201. package/frontend/{lib/components → components}/workspace/panels/PreviewPanel.svelte +5 -5
  202. package/frontend/{lib/components → components}/workspace/panels/TerminalPanel.svelte +6 -6
  203. package/frontend/{lib/services → services}/chat/chat.service.ts +8 -8
  204. package/frontend/{lib/services → services}/notification/global-stream-monitor.ts +117 -117
  205. package/frontend/{lib/services → services}/notification/push.service.ts +1 -1
  206. package/frontend/{lib/services → services}/notification/sound.service.ts +1 -1
  207. package/frontend/{lib/services → services}/preview/browser/browser-console.service.ts +1 -1
  208. package/frontend/{lib/services → services}/preview/browser/browser-webcodecs.service.ts +1 -1
  209. package/frontend/{lib/services → services}/preview/browser/mcp-integration.svelte.ts +2 -2
  210. package/frontend/{lib/services → services}/project/status.service.ts +160 -160
  211. package/frontend/{lib/services → services}/snapshot/snapshot.service.ts +2 -2
  212. package/frontend/{lib/services → services}/terminal/background/index.ts +1 -1
  213. package/frontend/{lib/services → services}/terminal/background/session-restore.ts +1 -1
  214. package/frontend/{lib/services → services}/terminal/background/stream-manager.ts +1 -1
  215. package/frontend/{lib/services → services}/terminal/project.service.ts +2 -2
  216. package/frontend/{lib/services → services}/terminal/terminal.service.ts +2 -2
  217. package/frontend/{lib/stores → stores}/core/app.svelte.ts +1 -1
  218. package/frontend/{lib/stores → stores}/core/presence.svelte.ts +4 -4
  219. package/frontend/{lib/stores → stores}/core/projects.svelte.ts +5 -5
  220. package/frontend/{lib/stores → stores}/core/sessions.svelte.ts +3 -3
  221. package/frontend/{lib/stores → stores}/features/auth.svelte.ts +30 -2
  222. package/frontend/{lib/stores → stores}/features/claude-accounts.svelte.ts +1 -1
  223. package/frontend/{lib/stores → stores}/features/models.svelte.ts +1 -1
  224. package/frontend/{lib/stores → stores}/features/settings.svelte.ts +2 -2
  225. package/frontend/{lib/stores → stores}/features/terminal.svelte.ts +4 -4
  226. package/frontend/{lib/stores → stores}/features/tunnel.svelte.ts +1 -1
  227. package/frontend/{lib/stores → stores}/features/user.svelte.ts +1 -1
  228. package/frontend/{lib/stores → stores}/ui/edit-mode.svelte.ts +3 -3
  229. package/frontend/{lib/stores → stores}/ui/update.svelte.ts +8 -2
  230. package/frontend/{lib/utils → utils}/theme.ts +1 -1
  231. package/frontend/{lib/utils → utils}/ws.ts +1 -1
  232. package/package.json +2 -2
  233. package/scripts/dev.ts +4 -3
  234. package/scripts/generate-icons.ts +2 -2
  235. package/scripts/start.ts +24 -0
  236. package/shared/types/ui/icons.ts +4 -4
  237. package/shared/utils/anonymous-user.ts +1 -1
  238. package/shared/utils/ws-server.ts +3 -3
  239. package/vite.config.ts +2 -2
  240. /package/backend/{lib/auth → auth}/index.ts +0 -0
  241. /package/backend/{lib/auth → auth}/permissions.ts +0 -0
  242. /package/backend/{lib/auth → auth}/rate-limiter.ts +0 -0
  243. /package/backend/{lib/auth → auth}/tokens.ts +0 -0
  244. /package/backend/{lib/chat → chat}/helpers.ts +0 -0
  245. /package/backend/{lib/chat → chat}/index.ts +0 -0
  246. /package/backend/{lib/database → database}/README.md +0 -0
  247. /package/backend/{lib/database → database}/index.ts +0 -0
  248. /package/backend/{lib/database → database}/migrations/001_create_projects_table.ts +0 -0
  249. /package/backend/{lib/database → database}/migrations/002_create_chat_sessions_table.ts +0 -0
  250. /package/backend/{lib/database → database}/migrations/003_create_messages_table.ts +0 -0
  251. /package/backend/{lib/database → database}/migrations/004_create_prompt_templates_table.ts +0 -0
  252. /package/backend/{lib/database → database}/migrations/005_create_settings_table.ts +0 -0
  253. /package/backend/{lib/database → database}/migrations/006_add_user_to_messages.ts +0 -0
  254. /package/backend/{lib/database → database}/migrations/007_create_stream_states_table.ts +0 -0
  255. /package/backend/{lib/database → database}/migrations/008_create_message_snapshots_table.ts +0 -0
  256. /package/backend/{lib/database → database}/migrations/009_add_delta_snapshot_fields.ts +0 -0
  257. /package/backend/{lib/database → database}/migrations/010_add_soft_delete_and_branch_support.ts +0 -0
  258. /package/backend/{lib/database → database}/migrations/011_git_like_commit_graph.ts +0 -0
  259. /package/backend/{lib/database → database}/migrations/012_add_file_change_statistics.ts +0 -0
  260. /package/backend/{lib/database → database}/migrations/013_checkpoint_tree_state.ts +0 -0
  261. /package/backend/{lib/database → database}/migrations/014_add_engine_to_sessions.ts +0 -0
  262. /package/backend/{lib/database → database}/migrations/015_add_model_to_sessions.ts +0 -0
  263. /package/backend/{lib/database → database}/migrations/016_create_user_projects_table.ts +0 -0
  264. /package/backend/{lib/database → database}/migrations/017_add_current_session_to_user_projects.ts +0 -0
  265. /package/backend/{lib/database → database}/migrations/018_create_claude_accounts_table.ts +0 -0
  266. /package/backend/{lib/database → database}/migrations/019_add_claude_account_to_sessions.ts +0 -0
  267. /package/backend/{lib/database → database}/migrations/020_add_snapshot_tree_hash.ts +0 -0
  268. /package/backend/{lib/database → database}/migrations/021_drop_prompt_templates_table.ts +0 -0
  269. /package/backend/{lib/database → database}/migrations/022_add_snapshot_changes_column.ts +0 -0
  270. /package/backend/{lib/database → database}/migrations/023_create_user_unread_sessions_table.ts +0 -0
  271. /package/backend/{lib/database → database}/migrations/024_create_users_table.ts +0 -0
  272. /package/backend/{lib/database → database}/migrations/025_create_auth_sessions_table.ts +0 -0
  273. /package/backend/{lib/database → database}/migrations/026_create_invite_tokens_table.ts +0 -0
  274. /package/backend/{lib/database → database}/migrations/index.ts +0 -0
  275. /package/backend/{lib/database → database}/queries/auth-queries.ts +0 -0
  276. /package/backend/{lib/database → database}/queries/checkpoint-queries.ts +0 -0
  277. /package/backend/{lib/database → database}/queries/engine-queries.ts +0 -0
  278. /package/backend/{lib/database → database}/queries/index.ts +0 -0
  279. /package/backend/{lib/database → database}/queries/project-queries.ts +0 -0
  280. /package/backend/{lib/database → database}/queries/session-queries.ts +0 -0
  281. /package/backend/{lib/database → database}/queries/settings-queries.ts +0 -0
  282. /package/backend/{lib/database → database}/queries/snapshot-queries.ts +0 -0
  283. /package/backend/{lib/database → database}/queries/utils-queries.ts +0 -0
  284. /package/backend/{lib/database → database}/seeders/index.ts +0 -0
  285. /package/backend/{lib/database → database}/seeders/settings_seeder.ts +0 -0
  286. /package/backend/{lib/database → database}/utils/index.ts +0 -0
  287. /package/backend/{lib/database → database}/utils/migration-runner.ts +0 -0
  288. /package/backend/{lib/database → database}/utils/seeder-runner.ts +0 -0
  289. /package/backend/{lib/engine → engine}/adapters/claude/error-handler.ts +0 -0
  290. /package/backend/{lib/engine → engine}/adapters/claude/index.ts +0 -0
  291. /package/backend/{lib/engine → engine}/adapters/claude/path-utils.ts +0 -0
  292. /package/backend/{lib/engine → engine}/adapters/claude/stream.ts +0 -0
  293. /package/backend/{lib/engine → engine}/adapters/opencode/index.ts +0 -0
  294. /package/backend/{lib/engine → engine}/adapters/opencode/stream.ts +0 -0
  295. /package/backend/{lib/engine → engine}/index.ts +0 -0
  296. /package/backend/{lib/engine → engine}/types.ts +0 -0
  297. /package/backend/{lib/files → files}/file-operations.ts +0 -0
  298. /package/backend/{lib/files → files}/file-reading.ts +0 -0
  299. /package/backend/{lib/files → files}/path-browsing.ts +0 -0
  300. /package/backend/{lib/git → git}/git-parser.ts +0 -0
  301. /package/backend/{lib/git → git}/git-service.ts +0 -0
  302. /package/backend/{lib/mcp → mcp}/index.ts +0 -0
  303. /package/backend/{lib/mcp → mcp}/project-context.ts +0 -0
  304. /package/backend/{lib/mcp → mcp}/remote-server.ts +0 -0
  305. /package/backend/{lib/mcp → mcp}/servers/browser-automation/index.ts +0 -0
  306. /package/backend/{lib/mcp → mcp}/servers/helper.ts +0 -0
  307. /package/backend/{lib/mcp → mcp}/servers/index.ts +0 -0
  308. /package/backend/{lib/mcp → mcp}/servers/weather/get-temperature.ts +0 -0
  309. /package/backend/{lib/mcp → mcp}/servers/weather/index.ts +0 -0
  310. /package/backend/{lib/mcp → mcp}/types.ts +0 -0
  311. /package/backend/{lib/preview → preview}/browser/browser-audio-capture.ts +0 -0
  312. /package/backend/{lib/preview → preview}/browser/browser-console-manager.ts +0 -0
  313. /package/backend/{lib/preview → preview}/browser/browser-dialog-handler.ts +0 -0
  314. /package/backend/{lib/preview → preview}/browser/browser-interaction-handler.ts +0 -0
  315. /package/backend/{lib/preview → preview}/browser/browser-mcp-control.ts +0 -0
  316. /package/backend/{lib/preview → preview}/browser/browser-native-ui-handler.ts +0 -0
  317. /package/backend/{lib/preview → preview}/browser/browser-navigation-tracker.ts +0 -0
  318. /package/backend/{lib/preview → preview}/browser/browser-pool.ts +0 -0
  319. /package/backend/{lib/preview → preview}/browser/browser-video-capture.ts +0 -0
  320. /package/backend/{lib/preview → preview}/browser/scripts/audio-stream.ts +0 -0
  321. /package/backend/{lib/preview → preview}/browser/scripts/cursor-tracking.ts +0 -0
  322. /package/backend/{lib/preview → preview}/browser/scripts/video-stream.ts +0 -0
  323. /package/backend/{lib/preview → preview}/index.ts +0 -0
  324. /package/backend/{lib/project → project}/index.ts +0 -0
  325. /package/backend/{lib/snapshot → snapshot}/gitignore.ts +0 -0
  326. /package/backend/{lib/snapshot → snapshot}/helpers.ts +0 -0
  327. /package/backend/{lib/snapshot → snapshot}/snapshot-service.ts +0 -0
  328. /package/backend/{lib/terminal → terminal}/helpers.ts +0 -0
  329. /package/backend/{lib/terminal → terminal}/index.ts +0 -0
  330. /package/backend/{lib/terminal → terminal}/pty-manager.ts +0 -0
  331. /package/backend/{lib/terminal → terminal}/pty-session-manager.ts +0 -0
  332. /package/backend/{lib/terminal → terminal}/stream-manager.ts +0 -0
  333. /package/backend/{lib/tunnel → tunnel}/global-tunnel-manager.ts +0 -0
  334. /package/backend/{lib/tunnel → tunnel}/project-tunnel-manager.ts +0 -0
  335. /package/backend/{lib/shared → utils}/process-manager.ts +0 -0
  336. /package/backend/{lib/user/helpers.ts → utils/user-helpers.ts} +0 -0
  337. /package/frontend/{lib/app-environment.ts → app-environment.ts} +0 -0
  338. /package/frontend/{lib/components → components}/chat/formatters/index.ts +0 -0
  339. /package/frontend/{lib/components → components}/chat/input/components/DragDropOverlay.svelte +0 -0
  340. /package/frontend/{lib/components → components}/chat/input/composables/use-animations.svelte.ts +0 -0
  341. /package/frontend/{lib/components → components}/chat/input/composables/use-textarea-resize.svelte.ts +0 -0
  342. /package/frontend/{lib/components → components}/chat/message/DateSeparator.svelte +0 -0
  343. /package/frontend/{lib/components → components}/chat/shared/index.ts +0 -0
  344. /package/frontend/{lib/components → components}/chat/shared/utils.ts +0 -0
  345. /package/frontend/{lib/components → components}/chat/tools/AgentTool.svelte +0 -0
  346. /package/frontend/{lib/components → components}/chat/tools/BashOutputTool.svelte +0 -0
  347. /package/frontend/{lib/components → components}/chat/tools/BashTool.svelte +0 -0
  348. /package/frontend/{lib/components → components}/chat/tools/EnterPlanModeTool.svelte +0 -0
  349. /package/frontend/{lib/components → components}/chat/tools/ExitPlanModeTool.svelte +0 -0
  350. /package/frontend/{lib/components → components}/chat/tools/GlobTool.svelte +0 -0
  351. /package/frontend/{lib/components → components}/chat/tools/GrepTool.svelte +0 -0
  352. /package/frontend/{lib/components → components}/chat/tools/ListMcpResourcesTool.svelte +0 -0
  353. /package/frontend/{lib/components → components}/chat/tools/NotebookEditTool.svelte +0 -0
  354. /package/frontend/{lib/components → components}/chat/tools/ReadMcpResourceTool.svelte +0 -0
  355. /package/frontend/{lib/components → components}/chat/tools/ReadTool.svelte +0 -0
  356. /package/frontend/{lib/components → components}/chat/tools/TaskStopTool.svelte +0 -0
  357. /package/frontend/{lib/components → components}/chat/tools/TaskTool.svelte +0 -0
  358. /package/frontend/{lib/components → components}/chat/tools/WebFetchTool.svelte +0 -0
  359. /package/frontend/{lib/components → components}/chat/tools/WebSearchTool.svelte +0 -0
  360. /package/frontend/{lib/components → components}/chat/tools/WriteTool.svelte +0 -0
  361. /package/frontend/{lib/components → components}/chat/tools/components/StatsBadges.svelte +0 -0
  362. /package/frontend/{lib/components → components}/chat/tools/components/TerminalCommand.svelte +0 -0
  363. /package/frontend/{lib/components → components}/chat/tools/components/index.ts +0 -0
  364. /package/frontend/{lib/components → components}/chat/tools/index.ts +0 -0
  365. /package/frontend/{lib/components → components}/checkpoint/timeline/TimelineEdge.svelte +0 -0
  366. /package/frontend/{lib/components → components}/checkpoint/timeline/TimelineGraph.svelte +0 -0
  367. /package/frontend/{lib/components → components}/checkpoint/timeline/TimelineVersionGroup.svelte +0 -0
  368. /package/frontend/{lib/components → components}/checkpoint/timeline/animation.ts +0 -0
  369. /package/frontend/{lib/components → components}/checkpoint/timeline/config.ts +0 -0
  370. /package/frontend/{lib/components → components}/checkpoint/timeline/graph-builder.ts +0 -0
  371. /package/frontend/{lib/components → components}/checkpoint/timeline/types.ts +0 -0
  372. /package/frontend/{lib/components → components}/checkpoint/timeline/utils.ts +0 -0
  373. /package/frontend/{lib/components/common → components/common/display}/AvatarBubble.svelte +0 -0
  374. /package/frontend/{lib/components/common → components/common/display}/Button.svelte +0 -0
  375. /package/frontend/{lib/components/common → components/common/display}/Card.svelte +0 -0
  376. /package/frontend/{lib/components/common → components/common/feedback}/LoadingSpinner.svelte +0 -0
  377. /package/frontend/{lib/components → components}/common/lucide-icons.ts +0 -0
  378. /package/frontend/{lib/components → components}/common/material-icons.ts +0 -0
  379. /package/frontend/{lib/components/common → components/common/overlay}/Modal.svelte +0 -0
  380. /package/frontend/{lib/components → components}/common/xterm/index.ts +0 -0
  381. /package/frontend/{lib/components → components}/common/xterm/terminal-config.ts +0 -0
  382. /package/frontend/{lib/components → components}/common/xterm/types.ts +0 -0
  383. /package/frontend/{lib/components → components}/preview/browser/components/VirtualCursor.svelte +0 -0
  384. /package/frontend/{lib/components → components}/preview/browser/core/stream-handler.svelte.ts +0 -0
  385. /package/frontend/{lib/components → components}/preview/index.ts +0 -0
  386. /package/frontend/{lib/components → components}/settings/account/AccountSettings.svelte +0 -0
  387. /package/frontend/{lib/components → components}/settings/general/GeneralSettings.svelte +0 -0
  388. /package/frontend/{lib/components → components}/settings/security/SecuritySettings.svelte +0 -0
  389. /package/frontend/{lib/components → components}/settings/system/SystemSettings.svelte +0 -0
  390. /package/frontend/{lib/components → components}/tunnel/TunnelQRCode.svelte +0 -0
  391. /package/frontend/{lib/services → services}/chat/index.ts +0 -0
  392. /package/frontend/{lib/services → services}/notification/index.ts +0 -0
  393. /package/frontend/{lib/services → services}/preview/index.ts +0 -0
  394. /package/frontend/{lib/services → services}/project/index.ts +0 -0
  395. /package/frontend/{lib/services → services}/terminal/index.ts +0 -0
  396. /package/frontend/{lib/services → services}/terminal/persistence.service.ts +0 -0
  397. /package/frontend/{lib/services → services}/terminal/session.service.ts +0 -0
  398. /package/frontend/{lib/stores → stores}/core/files.svelte.ts +0 -0
  399. /package/frontend/{lib/stores → stores}/ui/chat-input.svelte.ts +0 -0
  400. /package/frontend/{lib/stores → stores}/ui/chat-model.svelte.ts +0 -0
  401. /package/frontend/{lib/stores → stores}/ui/connection.svelte.ts +0 -0
  402. /package/frontend/{lib/stores → stores}/ui/dialog.svelte.ts +0 -0
  403. /package/frontend/{lib/stores → stores}/ui/notification.svelte.ts +0 -0
  404. /package/frontend/{lib/stores → stores}/ui/settings-modal.svelte.ts +0 -0
  405. /package/frontend/{lib/stores → stores}/ui/theme.svelte.ts +0 -0
  406. /package/frontend/{lib/stores → stores}/ui/workspace.svelte.ts +0 -0
  407. /package/frontend/{lib/utils → utils}/chat/date-separator.ts +0 -0
  408. /package/frontend/{lib/utils → utils}/chat/message-grouper.ts +0 -0
  409. /package/frontend/{lib/utils → utils}/chat/message-processor.ts +0 -0
  410. /package/frontend/{lib/utils → utils}/chat/tool-handler.ts +0 -0
  411. /package/frontend/{lib/utils → utils}/chat/virtual-scroll.svelte.ts +0 -0
  412. /package/frontend/{lib/utils → utils}/click-outside.ts +0 -0
  413. /package/frontend/{lib/utils → utils}/context-manager.ts +0 -0
  414. /package/frontend/{lib/utils → utils}/file-icon-mappings.ts +0 -0
  415. /package/frontend/{lib/utils → utils}/folder-icon-mappings.ts +0 -0
  416. /package/frontend/{lib/utils → utils}/git-status.ts +0 -0
  417. /package/frontend/{lib/types → utils}/native-ui.ts +0 -0
  418. /package/frontend/{lib/utils → utils}/platform.ts +0 -0
  419. /package/frontend/{lib/utils → utils}/port-check.ts +0 -0
  420. /package/frontend/{lib/constants/preview.ts → utils/preview-constants.ts} +0 -0
  421. /package/frontend/{lib/utils/terminalFormatter.ts → utils/terminal-formatter.ts} +0 -0
  422. /package/frontend/{lib/utils → utils}/tree-visualizer.ts +0 -0
@@ -7,7 +7,7 @@
7
7
 
8
8
  import { t } from 'elysia';
9
9
  import { createRouter } from '$shared/utils/ws-server';
10
- import { messageQueries, sessionQueries, checkpointQueries, snapshotQueries } from '../../lib/database/queries';
10
+ import { messageQueries, sessionQueries, checkpointQueries, snapshotQueries } from '../../database/queries';
11
11
  import { debug } from '$shared/utils/logger';
12
12
  import {
13
13
  extractMessageText,
@@ -17,8 +17,8 @@ import {
17
17
  isDescendant,
18
18
  getCheckpointFileStats,
19
19
  INITIAL_NODE_ID
20
- } from '../../lib/snapshot/helpers';
21
- import type { CheckpointNode, TimelineResponse } from '../../lib/snapshot/helpers';
20
+ } from '../../snapshot/helpers';
21
+ import type { CheckpointNode, TimelineResponse } from '../../snapshot/helpers';
22
22
  import type { SDKMessage } from '$shared/types/messaging';
23
23
 
24
24
  export const timelineHandler = createRouter()
@@ -11,7 +11,7 @@ import { t } from 'elysia';
11
11
  import { join } from 'node:path';
12
12
  import { readFileSync } from 'node:fs';
13
13
  import { createRouter } from '$shared/utils/ws-server';
14
- import { initializeDatabase, getDatabase } from '../../lib/database';
14
+ import { initializeDatabase, getDatabase } from '../../database';
15
15
  import { debug } from '$shared/utils/logger';
16
16
 
17
17
  /** Read current version from package.json */
@@ -9,10 +9,10 @@
9
9
 
10
10
  import { t } from 'elysia';
11
11
  import { createRouter } from '$shared/utils/ws-server';
12
- import { terminalStreamManager } from '../../lib/terminal/stream-manager';
12
+ import { terminalStreamManager } from '../../terminal/stream-manager';
13
13
  import { debug } from '$shared/utils/logger';
14
- import { ws } from '$backend/lib/utils/ws';
15
- import { ptySessionManager } from '../../lib/terminal/pty-session-manager';
14
+ import { ws } from '$backend/utils/ws';
15
+ import { ptySessionManager } from '../../terminal/pty-session-manager';
16
16
 
17
17
  export const persistenceHandler = createRouter()
18
18
  // Get stream status
@@ -12,14 +12,14 @@
12
12
 
13
13
  import { t } from 'elysia';
14
14
  import { createRouter } from '$shared/utils/ws-server';
15
- import { ptySessionManager } from '../../lib/terminal/pty-session-manager';
16
- import { terminalStreamManager } from '../../lib/terminal/stream-manager';
15
+ import { ptySessionManager } from '../../terminal/pty-session-manager';
16
+ import { terminalStreamManager } from '../../terminal/stream-manager';
17
17
  import { debug } from '$shared/utils/logger';
18
18
  import { resolve } from 'path';
19
- import { isWindows } from '../../lib/terminal/shell-utils';
20
- import { existsSync } from '../../lib/terminal/helpers';
21
- import { ws } from '$backend/lib/utils/ws';
22
- import { activePtyProcesses } from '../../lib/terminal/pty-manager';
19
+ import { isWindows } from '../../terminal/shell-utils';
20
+ import { existsSync } from '../../terminal/helpers';
21
+ import { ws } from '$backend/utils/ws';
22
+ import { activePtyProcesses } from '../../terminal/pty-manager';
23
23
 
24
24
  export const sessionHandler = createRouter()
25
25
  // Create new terminal session
@@ -11,9 +11,9 @@
11
11
 
12
12
  import { t } from 'elysia';
13
13
  import { createRouter } from '$shared/utils/ws-server';
14
- import { ptySessionManager } from '../../lib/terminal/pty-session-manager';
14
+ import { ptySessionManager } from '../../terminal/pty-session-manager';
15
15
  import { debug } from '$shared/utils/logger';
16
- import { ws } from '$backend/lib/utils/ws';
16
+ import { ws } from '$backend/utils/ws';
17
17
 
18
18
  export const streamHandler = createRouter()
19
19
  // Send keyboard input to terminal
@@ -9,7 +9,7 @@
9
9
 
10
10
  import { t } from 'elysia';
11
11
  import { createRouter } from '$shared/utils/ws-server';
12
- import { globalTunnelManager } from '../../lib/tunnel/global-tunnel-manager';
12
+ import { globalTunnelManager } from '../../tunnel/global-tunnel-manager';
13
13
  import { debug } from '$shared/utils/logger';
14
14
 
15
15
  export const operationsHandler = createRouter()
@@ -10,10 +10,10 @@
10
10
 
11
11
  import { t } from 'elysia';
12
12
  import { createRouter } from '$shared/utils/ws-server';
13
- import { generateAnonymousUser, generateColorFromString, getInitials } from '../../lib/user/helpers';
14
- import type { AnonymousUser } from '../../lib/user/helpers';
15
- import { ws } from '$backend/lib/utils/ws';
16
- import { settingsQueries } from '$backend/lib/database/queries';
13
+ import { generateAnonymousUser, generateColorFromString, getInitials } from '../../utils/user-helpers';
14
+ import type { AnonymousUser } from '../../utils/user-helpers';
15
+ import { ws } from '$backend/utils/ws';
16
+ import { settingsQueries } from '$backend/database/queries';
17
17
  import { debug } from '$shared/utils/logger';
18
18
 
19
19
  /**
package/bin/clopen.ts CHANGED
@@ -23,6 +23,7 @@ if (typeof globalThis.Bun === 'undefined') {
23
23
 
24
24
  import { existsSync, copyFileSync, readFileSync, writeFileSync } from 'fs';
25
25
  import { join } from 'path';
26
+ import { loadEnvFile } from '../backend/utils/env';
26
27
 
27
28
  // CLI Options interface
28
29
  interface CLIOptions {
@@ -88,7 +89,7 @@ const MAX_PORT = 65535;
88
89
 
89
90
  function showHelp() {
90
91
  console.log(`
91
- Clopen - Modern web UI for Claude Code
92
+ Clopen - All-in-one web workspace for Claude Code & OpenCode
92
93
 
93
94
  USAGE:
94
95
  clopen [OPTIONS]
@@ -106,7 +107,7 @@ OPTIONS:
106
107
 
107
108
  EXAMPLES:
108
109
  clopen # Start with default settings (port ${DEFAULT_PORT})
109
- clopen --port 9150 # Start on port 9150
110
+ clopen --port 9145 # Start on port 9145
110
111
  clopen --host 0.0.0.0 # Bind to all network interfaces
111
112
  clopen update # Update to the latest version
112
113
  clopen reset-pat # Regenerate admin login token
@@ -262,8 +263,8 @@ async function recoverAdminToken() {
262
263
  console.log(`\x1b[36mClopen\x1b[0m v${version} — Admin Token Recovery\n`);
263
264
 
264
265
  // Initialize database (import dynamically to avoid loading full backend)
265
- const { initializeDatabase } = await import('../backend/lib/database/index');
266
- const { listUsers, regeneratePAT } = await import('../backend/lib/auth/auth-service');
266
+ const { initializeDatabase } = await import('../backend/database/index');
267
+ const { listUsers, regeneratePAT } = await import('../backend/auth/auth-service');
267
268
 
268
269
  await initializeDatabase();
269
270
 
@@ -367,21 +368,20 @@ async function startServer(options: CLIOptions) {
367
368
  updateLoading('Starting server...');
368
369
  await delay();
369
370
 
370
- // Run server as subprocess to ensure it uses local node_modules
371
- const serverPath = join(__dirname, 'backend/index.ts');
371
+ // Delegate to scripts/start.ts handles port resolution (IPv4 + IPv6
372
+ // zombie detection) and starts backend in a single consistent path.
373
+ const startScript = join(__dirname, 'scripts/start.ts');
372
374
 
373
375
  stopLoading();
374
376
 
375
- // Prepare environment variables
376
- const env = { ...process.env };
377
- if (options.port) {
378
- env.PORT = options.port.toString();
379
- }
380
- if (options.host) {
381
- env.HOST = options.host;
382
- }
377
+ // Overlay clopen's own .env on top of process.env to override any
378
+ // pollution from a .env file in the directory where `clopen` was invoked.
379
+ // CLI args take highest priority on top of that.
380
+ const env = { ...process.env, ...loadEnvFile(ENV_FILE) };
381
+ if (options.port) env.PORT = options.port.toString();
382
+ if (options.host) env.HOST = options.host;
383
383
 
384
- const serverProc = Bun.spawn(['bun', serverPath], {
384
+ const serverProc = Bun.spawn(['bun', startScript], {
385
385
  cwd: __dirname,
386
386
  stdout: 'inherit',
387
387
  stderr: 'inherit',
@@ -0,0 +1,31 @@
1
+ services:
2
+ clopen:
3
+ build:
4
+ context: .
5
+ dockerfile_inline: |
6
+ FROM oven/bun:latest
7
+ USER root
8
+ RUN apt-get update && apt-get install -y --no-install-recommends \
9
+ git \
10
+ curl \
11
+ chromium \
12
+ && rm -rf /var/lib/apt/lists/*
13
+ ENV PUPPETEER_SKIP_CHROMIUM_DOWNLOAD=true
14
+ ENV PUPPETEER_EXECUTABLE_PATH=/usr/bin/chromium
15
+ RUN curl -fsSL https://claude.ai/install.sh | bash
16
+ ENV PATH="/root/.claude/local:$PATH"
17
+ RUN curl -fsSL https://opencode.ai/install | bash
18
+ RUN bun add -g @myrialabs/clopen
19
+ EXPOSE 9141
20
+ CMD ["clopen", "--host", "0.0.0.0"]
21
+ restart: unless-stopped
22
+ ports:
23
+ - "${PORT:-9141}:9141"
24
+ volumes:
25
+ - clopen_data:/root/.clopen
26
+ - ${PROJECTS_DIR:-./projects}:/root/projects
27
+ environment:
28
+ - NODE_ENV=production
29
+
30
+ volumes:
31
+ clopen_data:
@@ -1,18 +1,18 @@
1
1
  <script lang="ts">
2
2
  import { onMount, onDestroy } from 'svelte';
3
- import { authStore } from '$frontend/lib/stores/features/auth.svelte';
4
- import WorkspaceLayout from '$frontend/lib/components/workspace/WorkspaceLayout.svelte';
5
- import ConnectionBanner from '$frontend/lib/components/common/ConnectionBanner.svelte';
6
- import UpdateBanner from '$frontend/lib/components/common/UpdateBanner.svelte';
7
- import LoadingScreen from '$frontend/lib/components/common/LoadingScreen.svelte';
8
- import SetupPage from '$frontend/lib/components/auth/SetupPage.svelte';
9
- import LoginPage from '$frontend/lib/components/auth/LoginPage.svelte';
10
- import InvitePage from '$frontend/lib/components/auth/InvitePage.svelte';
11
- import { backgroundTerminalService } from '$frontend/lib/services/terminal/background';
12
- import { initializeMCPPreview } from '$frontend/lib/services/preview';
13
- import { globalStreamMonitor } from '$frontend/lib/services/notification/global-stream-monitor';
14
- import { tunnelStore } from '$frontend/lib/stores/features/tunnel.svelte';
15
- import { startUpdateChecker, stopUpdateChecker } from '$frontend/lib/stores/ui/update.svelte';
3
+ import { authStore } from '$frontend/stores/features/auth.svelte';
4
+ import WorkspaceLayout from '$frontend/components/workspace/WorkspaceLayout.svelte';
5
+ import ConnectionBanner from '$frontend/components/common/feedback/ConnectionBanner.svelte';
6
+ import UpdateBanner from '$frontend/components/common/feedback/UpdateBanner.svelte';
7
+ import LoadingScreen from '$frontend/components/common/feedback/LoadingScreen.svelte';
8
+ import SetupPage from '$frontend/components/auth/SetupPage.svelte';
9
+ import LoginPage from '$frontend/components/auth/LoginPage.svelte';
10
+ import InvitePage from '$frontend/components/auth/InvitePage.svelte';
11
+ import { backgroundTerminalService } from '$frontend/services/terminal/background';
12
+ import { initializeMCPPreview } from '$frontend/services/preview';
13
+ import { globalStreamMonitor } from '$frontend/services/notification/global-stream-monitor';
14
+ import { tunnelStore } from '$frontend/stores/features/tunnel.svelte';
15
+ import { startUpdateChecker, stopUpdateChecker } from '$frontend/stores/ui/update.svelte';
16
16
 
17
17
  let servicesInitialized = false;
18
18
 
@@ -1,7 +1,7 @@
1
1
  <script lang="ts">
2
2
  import { onMount } from 'svelte';
3
- import { authStore } from '$frontend/lib/stores/features/auth.svelte';
4
- import ws from '$frontend/lib/utils/ws';
3
+ import { authStore } from '$frontend/stores/features/auth.svelte';
4
+ import ws from '$frontend/utils/ws';
5
5
 
6
6
  let name = $state('');
7
7
  let error = $state('');
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import { authStore } from '$frontend/lib/stores/features/auth.svelte';
2
+ import { authStore } from '$frontend/stores/features/auth.svelte';
3
3
 
4
4
  let token = $state('');
5
5
  let error = $state('');
@@ -1,12 +1,12 @@
1
1
  <script lang="ts">
2
2
  import { onMount, onDestroy } from 'svelte';
3
- import { authStore } from '$frontend/lib/stores/features/auth.svelte';
4
- import { themeStore, toggleDarkMode, isDarkMode, initializeTheme } from '$frontend/lib/stores/ui/theme.svelte';
5
- import { settings, updateSettings, applyFontSize } from '$frontend/lib/stores/features/settings.svelte';
3
+ import { authStore } from '$frontend/stores/features/auth.svelte';
4
+ import { themeStore, toggleDarkMode, isDarkMode, initializeTheme } from '$frontend/stores/ui/theme.svelte';
5
+ import { settings, updateSettings, applyFontSize } from '$frontend/stores/features/settings.svelte';
6
6
  import { ENGINES } from '$shared/constants/engines';
7
- import { claudeAccountsStore, type ClaudeAccountItem } from '$frontend/lib/stores/features/claude-accounts.svelte';
8
- import Icon from '$frontend/lib/components/common/Icon.svelte';
9
- import ws from '$frontend/lib/utils/ws';
7
+ import { claudeAccountsStore, type ClaudeAccountItem } from '$frontend/stores/features/claude-accounts.svelte';
8
+ import Icon from '$frontend/components/common/display/Icon.svelte';
9
+ import ws from '$frontend/utils/ws';
10
10
  import type { AuthMode } from '$shared/types/stores/settings';
11
11
  import type { IconName } from '$shared/types/ui/icons';
12
12
 
@@ -100,14 +100,41 @@
100
100
  authModeLoading = true;
101
101
 
102
102
  try {
103
- if (selectedAuthMode === 'none') {
104
- await authStore.setupNoAuth();
105
- completedSteps.add('auth-mode');
106
- completedSteps.add('admin-account');
107
- completedSteps = new Set(completedSteps);
108
- currentStep = 'engines';
103
+ if (!isExistingUser) {
104
+ // Fresh setup — existing behavior
105
+ if (selectedAuthMode === 'none') {
106
+ await authStore.setupNoAuth();
107
+ completedSteps.add('auth-mode');
108
+ completedSteps.add('admin-account');
109
+ completedSteps = new Set(completedSteps);
110
+ currentStep = 'engines';
111
+ } else {
112
+ goToNextStep();
113
+ }
109
114
  } else {
110
- goToNextStep();
115
+ // Returning user (wizard shown again after refresh) — apply selected mode
116
+ const previousMode = authStore.authMode;
117
+ if (selectedAuthMode === 'none' && previousMode !== 'none') {
118
+ // with-auth → no-auth: update mode, skip admin-account
119
+ await authStore.switchToNoAuth();
120
+ completedSteps.add('auth-mode');
121
+ completedSteps.add('admin-account');
122
+ completedSteps = new Set(completedSteps);
123
+ currentStep = 'engines';
124
+ } else if (selectedAuthMode === 'required' && previousMode !== 'required') {
125
+ // no-auth → with-auth: update mode, regenerate PAT, go to admin-account
126
+ await authStore.switchToWithAuth();
127
+ goToNextStep();
128
+ } else if (selectedAuthMode === 'none') {
129
+ // Same mode (none) — skip admin-account, go to engines
130
+ completedSteps.add('auth-mode');
131
+ completedSteps.add('admin-account');
132
+ completedSteps = new Set(completedSteps);
133
+ currentStep = 'engines';
134
+ } else {
135
+ // Same mode (required) — advance to admin-account
136
+ goToNextStep();
137
+ }
111
138
  }
112
139
  } catch (err) {
113
140
  authModeError = err instanceof Error ? err.message : 'Setup failed';
@@ -133,11 +160,16 @@
133
160
  adminLoading = true;
134
161
  try {
135
162
  if (isExistingUser) {
136
- // Existing user — just update name if changed and proceed
163
+ // Existing user — update name if changed
137
164
  if (adminName.trim() !== existingUserName) {
138
165
  await authStore.updateName(adminName.trim());
139
166
  }
140
- goToNextStep();
167
+ // If a PAT was just generated (e.g. switched from no-auth to with-auth), show it
168
+ if (authStore.personalAccessToken) {
169
+ showPAT = true;
170
+ } else {
171
+ goToNextStep();
172
+ }
141
173
  } else {
142
174
  await authStore.setup(adminName.trim());
143
175
  showPAT = true;
@@ -324,8 +356,8 @@
324
356
  });
325
357
 
326
358
  // ─── Step 4: Preferences ───
327
- const FONT_SIZE_MIN = 10;
328
- const FONT_SIZE_MAX = 20;
359
+ const FONT_SIZE_MIN = 8;
360
+ const FONT_SIZE_MAX = 24;
329
361
 
330
362
  function handleFontSizeChange(e: Event) {
331
363
  const value = Number((e.target as HTMLInputElement).value);
@@ -10,29 +10,29 @@
10
10
  -->
11
11
 
12
12
  <script lang="ts">
13
- import { sessionState, setCurrentSession, createNewChatSession, clearMessages, loadMessagesForSession } from '$frontend/lib/stores/core/sessions.svelte';
14
- import { projectState } from '$frontend/lib/stores/core/projects.svelte';
15
- import { appState, isSessionUnread } from '$frontend/lib/stores/core/app.svelte';
16
- import { presenceState, isSessionWaitingInput } from '$frontend/lib/stores/core/presence.svelte';
17
- import { userStore } from '$frontend/lib/stores/features/user.svelte';
18
- import { addNotification } from '$frontend/lib/stores/ui/notification.svelte';
19
- import { chatService } from '$frontend/lib/services/chat/chat.service';
13
+ import { sessionState, setCurrentSession, createNewChatSession, clearMessages, loadMessagesForSession } from '$frontend/stores/core/sessions.svelte';
14
+ import { projectState } from '$frontend/stores/core/projects.svelte';
15
+ import { appState, isSessionUnread } from '$frontend/stores/core/app.svelte';
16
+ import { presenceState, isSessionWaitingInput } from '$frontend/stores/core/presence.svelte';
17
+ import { userStore } from '$frontend/stores/features/user.svelte';
18
+ import { addNotification } from '$frontend/stores/ui/notification.svelte';
19
+ import { chatService } from '$frontend/services/chat/chat.service';
20
20
  import { onMount } from 'svelte';
21
21
  import { fade } from 'svelte/transition';
22
22
  import ChatMessages from './message/ChatMessages.svelte';
23
23
  import ChatInput from './input/ChatInput.svelte';
24
24
  import FloatingTodoList from './widgets/FloatingTodoList.svelte';
25
- import TimelineModal from '$frontend/lib/components/checkpoint/TimelineModal.svelte';
25
+ import TimelineModal from '$frontend/components/checkpoint/TimelineModal.svelte';
26
26
  // import TokenUsage from './widgets/TokenUsage.svelte'; // DISABLED
27
- import Icon from '$frontend/lib/components/common/Icon.svelte';
28
- import AvatarBubble from '$frontend/lib/components/common/AvatarBubble.svelte';
29
- import Button from '$frontend/lib/components/common/Button.svelte';
30
- import PageTemplate from '$frontend/lib/components/common/PageTemplate.svelte';
31
- import Modal from '$frontend/lib/components/common/Modal.svelte';
27
+ import Icon from '$frontend/components/common/display/Icon.svelte';
28
+ import AvatarBubble from '$frontend/components/common/display/AvatarBubble.svelte';
29
+ import Button from '$frontend/components/common/display/Button.svelte';
30
+ import PageTemplate from '$frontend/components/common/display/PageTemplate.svelte';
31
+ import Modal from '$frontend/components/common/overlay/Modal.svelte';
32
32
  import type { IconName } from '$shared/types/ui/icons';
33
33
  import type { ChatSession } from '$shared/types/database/schema';
34
34
  import { debug } from '$shared/utils/logger';
35
- import ws from '$frontend/lib/utils/ws';
35
+ import ws from '$frontend/utils/ws';
36
36
 
37
37
  // Welcome state - don't show during restoration
38
38
  const isWelcomeState = $derived(
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import Icon from '$frontend/lib/components/common/Icon.svelte';
2
+ import Icon from '$frontend/components/common/display/Icon.svelte';
3
3
 
4
4
  const { errorText }: { errorText: string } = $props();
5
5
 
@@ -2,14 +2,14 @@
2
2
  import ErrorMessage from './ErrorMessage.svelte';
3
3
  import TextMessage from './TextMessage.svelte';
4
4
  import Tools from './Tools.svelte';
5
- import Lightbox from '$frontend/lib/components/common/Lightbox.svelte';
6
- import Icon from '$frontend/lib/components/common/Icon.svelte';
7
- import { getFileIcon } from '$frontend/lib/utils/file-icon-mappings';
5
+ import Lightbox from '$frontend/components/common/overlay/Lightbox.svelte';
6
+ import Icon from '$frontend/components/common/display/Icon.svelte';
7
+ import { getFileIcon } from '$frontend/utils/file-icon-mappings';
8
8
  import { formatFileSize } from '../shared/utils';
9
9
 
10
10
  import type { SDKMessage, SDKPartialAssistantMessage } from '$shared/types/messaging';
11
11
  import type { SDKMessageFormatter } from '$shared/types/database/schema';
12
- import { getCompactSummary } from '$frontend/lib/utils/chat/message-grouper';
12
+ import { getCompactSummary } from '$frontend/utils/chat/message-grouper';
13
13
 
14
14
  const { message }: { message: SDKMessageFormatter } = $props();
15
15
 
@@ -6,7 +6,7 @@
6
6
  splitContentIntoSegments,
7
7
  formatTerminalOutput,
8
8
  escapeHtml
9
- } from '$frontend/lib/utils/terminalFormatter';
9
+ } from '$frontend/utils/terminal-formatter';
10
10
 
11
11
  const { content }: { content: string } = $props();
12
12
 
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import Icon from '$frontend/lib/components/common/Icon.svelte';
2
+ import Icon from '$frontend/components/common/display/Icon.svelte';
3
3
  import type { ToolInput } from '$shared/types/messaging';
4
4
  import {
5
5
  BashTool, BashOutputTool, EditTool, EnterPlanModeTool, ExitPlanModeTool,
@@ -11,21 +11,21 @@
11
11
  -->
12
12
 
13
13
  <script lang="ts">
14
- import { sessionState } from '$frontend/lib/stores/core/sessions.svelte';
15
- import { projectState } from '$frontend/lib/stores/core/projects.svelte';
16
- import { appState } from '$frontend/lib/stores/core/app.svelte';
17
- import { settings } from '$frontend/lib/stores/features/settings.svelte';
14
+ import { sessionState } from '$frontend/stores/core/sessions.svelte';
15
+ import { projectState } from '$frontend/stores/core/projects.svelte';
16
+ import { appState } from '$frontend/stores/core/app.svelte';
17
+ import { settings } from '$frontend/stores/features/settings.svelte';
18
18
  import { onDestroy, untrack } from 'svelte';
19
- import { ChatService } from '$frontend/lib/services/chat';
20
- import { chatService } from '$frontend/lib/services/chat/chat.service';
19
+ import { ChatService } from '$frontend/services/chat';
20
+ import { chatService } from '$frontend/services/chat/chat.service';
21
21
  import { getEngineInfo } from '$shared/constants/engines';
22
- import { modelStore } from '$frontend/lib/stores/features/models.svelte';
23
- import { chatModelState } from '$frontend/lib/stores/ui/chat-model.svelte';
24
- import { presenceState } from '$frontend/lib/stores/core/presence.svelte';
25
- import { editModeState } from '$frontend/lib/stores/ui/edit-mode.svelte';
26
- import { claudeAccountsStore } from '$frontend/lib/stores/features/claude-accounts.svelte';
22
+ import { modelStore } from '$frontend/stores/features/models.svelte';
23
+ import { chatModelState } from '$frontend/stores/ui/chat-model.svelte';
24
+ import { presenceState } from '$frontend/stores/core/presence.svelte';
25
+ import { editModeState } from '$frontend/stores/ui/edit-mode.svelte';
26
+ import { claudeAccountsStore } from '$frontend/stores/features/claude-accounts.svelte';
27
27
  import type { IconName } from '$shared/types/ui/icons';
28
- import ws from '$frontend/lib/utils/ws';
28
+ import ws from '$frontend/utils/ws';
29
29
  import { debug } from '$shared/utils/logger';
30
30
 
31
31
  // Components
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import Icon from '$frontend/lib/components/common/Icon.svelte';
2
+ import Icon from '$frontend/components/common/display/Icon.svelte';
3
3
  import type { FileAttachment } from '../composables/use-file-handling.svelte';
4
4
 
5
5
  interface Props {
@@ -1,6 +1,6 @@
1
1
  <script lang="ts">
2
- import Icon from '$frontend/lib/components/common/Icon.svelte';
3
- import { editModeState } from '$frontend/lib/stores/ui/edit-mode.svelte';
2
+ import Icon from '$frontend/components/common/display/Icon.svelte';
3
+ import { editModeState } from '$frontend/stores/ui/edit-mode.svelte';
4
4
 
5
5
  interface Props {
6
6
  onCancel: () => void;
@@ -1,16 +1,16 @@
1
1
  <script lang="ts">
2
2
  import { untrack } from 'svelte';
3
- import { settings } from '$frontend/lib/stores/features/settings.svelte';
4
- import { modelStore } from '$frontend/lib/stores/features/models.svelte';
5
- import { sessionState } from '$frontend/lib/stores/core/sessions.svelte';
6
- import { appState } from '$frontend/lib/stores/core/app.svelte';
7
- import { userStore } from '$frontend/lib/stores/features/user.svelte';
8
- import { chatModelState, initChatModel, restoreChatModelFromSession } from '$frontend/lib/stores/ui/chat-model.svelte';
3
+ import { settings } from '$frontend/stores/features/settings.svelte';
4
+ import { modelStore } from '$frontend/stores/features/models.svelte';
5
+ import { sessionState } from '$frontend/stores/core/sessions.svelte';
6
+ import { appState } from '$frontend/stores/core/app.svelte';
7
+ import { userStore } from '$frontend/stores/features/user.svelte';
8
+ import { chatModelState, initChatModel, restoreChatModelFromSession } from '$frontend/stores/ui/chat-model.svelte';
9
9
  import { ENGINES } from '$shared/constants/engines';
10
10
  import type { EngineType, EngineModel } from '$shared/types/engine';
11
- import Icon from '$frontend/lib/components/common/Icon.svelte';
12
- import { claudeAccountsStore, type ClaudeAccountItem } from '$frontend/lib/stores/features/claude-accounts.svelte';
13
- import ws from '$frontend/lib/utils/ws';
11
+ import Icon from '$frontend/components/common/display/Icon.svelte';
12
+ import { claudeAccountsStore, type ClaudeAccountItem } from '$frontend/stores/features/claude-accounts.svelte';
13
+ import ws from '$frontend/utils/ws';
14
14
  import { debug } from '$shared/utils/logger';
15
15
 
16
16
  // ════════════════════════════════════════════
@@ -1,5 +1,5 @@
1
1
  <script lang="ts">
2
- import Icon from '$frontend/lib/components/common/Icon.svelte';
2
+ import Icon from '$frontend/components/common/display/Icon.svelte';
3
3
  import type { FileAttachment } from '../composables/use-file-handling.svelte';
4
4
 
5
5
  interface Props {
@@ -1,6 +1,6 @@
1
1
  <script lang="ts">
2
- import { appState } from '$frontend/lib/stores/core/app.svelte';
3
- import Icon from '$frontend/lib/components/common/Icon.svelte';
2
+ import { appState } from '$frontend/stores/core/app.svelte';
3
+ import Icon from '$frontend/components/common/display/Icon.svelte';
4
4
  import { fly } from 'svelte/transition';
5
5
 
6
6
  interface Props {
@@ -1,11 +1,11 @@
1
- import { appState } from '$frontend/lib/stores/core/app.svelte';
2
- import { sessionState, loadMessagesForSession } from '$frontend/lib/stores/core/sessions.svelte';
3
- import { chatService } from '$frontend/lib/services/chat/chat.service';
4
- import { snapshotService } from '$frontend/lib/services/snapshot/snapshot.service';
5
- import { soundNotification } from '$frontend/lib/services/notification';
6
- import { addNotification } from '$frontend/lib/stores/ui/notification.svelte';
7
- import { editModeState, cancelEdit } from '$frontend/lib/stores/ui/edit-mode.svelte';
8
- import { clearInput, setSkipNextRestore } from '$frontend/lib/stores/ui/chat-input.svelte';
1
+ import { appState } from '$frontend/stores/core/app.svelte';
2
+ import { sessionState, loadMessagesForSession } from '$frontend/stores/core/sessions.svelte';
3
+ import { chatService } from '$frontend/services/chat/chat.service';
4
+ import { snapshotService } from '$frontend/services/snapshot/snapshot.service';
5
+ import { soundNotification } from '$frontend/services/notification';
6
+ import { addNotification } from '$frontend/stores/ui/notification.svelte';
7
+ import { editModeState, cancelEdit } from '$frontend/stores/ui/edit-mode.svelte';
8
+ import { clearInput, setSkipNextRestore } from '$frontend/stores/ui/chat-input.svelte';
9
9
  import { debug } from '$shared/utils/logger';
10
10
  import type { FileAttachment } from './use-file-handling.svelte';
11
11
 
@@ -1,4 +1,4 @@
1
- import { addNotification } from '$frontend/lib/stores/ui/notification.svelte';
1
+ import { addNotification } from '$frontend/stores/ui/notification.svelte';
2
2
  import { debug } from '$shared/utils/logger';
3
3
 
4
4
  // File attachments interface
@@ -1,11 +1,11 @@
1
1
  import { onMount, onDestroy } from 'svelte';
2
- import { editModeState } from '$frontend/lib/stores/ui/edit-mode.svelte';
3
- import { chatInputState, resetFocus, shouldSkipRestore } from '$frontend/lib/stores/ui/chat-input.svelte';
4
- import { projectState } from '$frontend/lib/stores/core/projects.svelte';
5
- import { sessionState } from '$frontend/lib/stores/core/sessions.svelte';
6
- import { userStore } from '$frontend/lib/stores/features/user.svelte';
2
+ import { editModeState } from '$frontend/stores/ui/edit-mode.svelte';
3
+ import { chatInputState, resetFocus, shouldSkipRestore } from '$frontend/stores/ui/chat-input.svelte';
4
+ import { projectState } from '$frontend/stores/core/projects.svelte';
5
+ import { sessionState } from '$frontend/stores/core/sessions.svelte';
6
+ import { userStore } from '$frontend/stores/features/user.svelte';
7
7
  import { debug } from '$shared/utils/logger';
8
- import ws from '$frontend/lib/utils/ws';
8
+ import ws from '$frontend/utils/ws';
9
9
  import type { FileAttachment } from './use-file-handling.svelte';
10
10
 
11
11
  /**