crewswarm 0.8.1-beta

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 (362) hide show
  1. package/.env.example +155 -0
  2. package/LICENSE +21 -0
  3. package/README.md +316 -0
  4. package/apps/dashboard/dist/assets/chat-core-BwSoInmZ.js +1 -0
  5. package/apps/dashboard/dist/assets/chat-core-BwSoInmZ.js.br +0 -0
  6. package/apps/dashboard/dist/assets/cli-process-COMRNPqr.js +1 -0
  7. package/apps/dashboard/dist/assets/cli-process-COMRNPqr.js.br +0 -0
  8. package/apps/dashboard/dist/assets/components-CSUb80ze.js +1 -0
  9. package/apps/dashboard/dist/assets/components-CSUb80ze.js.br +0 -0
  10. package/apps/dashboard/dist/assets/core-utils-CAVnDoe1.js +1 -0
  11. package/apps/dashboard/dist/assets/core-utils-CAVnDoe1.js.br +0 -0
  12. package/apps/dashboard/dist/assets/index-CF0aJRtC.css +1 -0
  13. package/apps/dashboard/dist/assets/index-CF0aJRtC.css.br +0 -0
  14. package/apps/dashboard/dist/assets/index-Px49zu76.js +2 -0
  15. package/apps/dashboard/dist/assets/index-Px49zu76.js.br +0 -0
  16. package/apps/dashboard/dist/assets/orchestration-Ca2DLWN-.js +1 -0
  17. package/apps/dashboard/dist/assets/orchestration-Ca2DLWN-.js.br +0 -0
  18. package/apps/dashboard/dist/assets/setup-wizard-i3eEixlo.js +1 -0
  19. package/apps/dashboard/dist/assets/setup-wizard-i3eEixlo.js.br +0 -0
  20. package/apps/dashboard/dist/assets/tab-agents-tab-BThdsdJY.js +1 -0
  21. package/apps/dashboard/dist/assets/tab-agents-tab-BThdsdJY.js.br +0 -0
  22. package/apps/dashboard/dist/assets/tab-benchmarks-tab-DfCuAClu.js +1 -0
  23. package/apps/dashboard/dist/assets/tab-comms-tab-eHpOSBhG.js +1 -0
  24. package/apps/dashboard/dist/assets/tab-comms-tab-eHpOSBhG.js.br +0 -0
  25. package/apps/dashboard/dist/assets/tab-contacts-tab-yEegNyO4.js +1 -0
  26. package/apps/dashboard/dist/assets/tab-contacts-tab-yEegNyO4.js.br +0 -0
  27. package/apps/dashboard/dist/assets/tab-engines-tab-C3DYxTwy.js +1 -0
  28. package/apps/dashboard/dist/assets/tab-engines-tab-C3DYxTwy.js.br +0 -0
  29. package/apps/dashboard/dist/assets/tab-memory-tab-C59BYFQD.js +1 -0
  30. package/apps/dashboard/dist/assets/tab-memory-tab-C59BYFQD.js.br +0 -0
  31. package/apps/dashboard/dist/assets/tab-models-tab-9Ur7pXWA.js +1 -0
  32. package/apps/dashboard/dist/assets/tab-models-tab-9Ur7pXWA.js.br +0 -0
  33. package/apps/dashboard/dist/assets/tab-pm-loop-tab-D7mnDelU.js +1 -0
  34. package/apps/dashboard/dist/assets/tab-pm-loop-tab-D7mnDelU.js.br +0 -0
  35. package/apps/dashboard/dist/assets/tab-projects-tab-C6h2Mv1K.js +1 -0
  36. package/apps/dashboard/dist/assets/tab-projects-tab-C6h2Mv1K.js.br +0 -0
  37. package/apps/dashboard/dist/assets/tab-prompts-tab-C0wZvWK3.js +1 -0
  38. package/apps/dashboard/dist/assets/tab-prompts-tab-C0wZvWK3.js.br +0 -0
  39. package/apps/dashboard/dist/assets/tab-services-tab-DBj_w3bc.js +1 -0
  40. package/apps/dashboard/dist/assets/tab-services-tab-DBj_w3bc.js.br +0 -0
  41. package/apps/dashboard/dist/assets/tab-settings-tab-ezeqAjZk.js +1 -0
  42. package/apps/dashboard/dist/assets/tab-settings-tab-ezeqAjZk.js.br +0 -0
  43. package/apps/dashboard/dist/assets/tab-skills-tab-BYdU2whk.js +1 -0
  44. package/apps/dashboard/dist/assets/tab-skills-tab-BYdU2whk.js.br +0 -0
  45. package/apps/dashboard/dist/assets/tab-spending-tab-Bg6w9t_p.js +1 -0
  46. package/apps/dashboard/dist/assets/tab-spending-tab-Bg6w9t_p.js.br +0 -0
  47. package/apps/dashboard/dist/assets/tab-swarm-chat-tab-BBV9HB2X.js +1 -0
  48. package/apps/dashboard/dist/assets/tab-swarm-chat-tab-BBV9HB2X.js.br +0 -0
  49. package/apps/dashboard/dist/assets/tab-swarm-tab-ChqLlEVs.js +1 -0
  50. package/apps/dashboard/dist/assets/tab-swarm-tab-ChqLlEVs.js.br +0 -0
  51. package/apps/dashboard/dist/assets/tab-usage-tab-B2UWXenJ.js +1 -0
  52. package/apps/dashboard/dist/assets/tab-usage-tab-B2UWXenJ.js.br +0 -0
  53. package/apps/dashboard/dist/assets/tab-waves-tab-SaJDkb4x.js +1 -0
  54. package/apps/dashboard/dist/assets/tab-waves-tab-SaJDkb4x.js.br +0 -0
  55. package/apps/dashboard/dist/assets/tab-workflows-tab-6QSXLJ0i.js +1 -0
  56. package/apps/dashboard/dist/assets/tab-workflows-tab-6QSXLJ0i.js.br +0 -0
  57. package/apps/dashboard/dist/favicon.png +0 -0
  58. package/apps/dashboard/dist/index.html +6466 -0
  59. package/apps/dashboard/dist/index.html.br +0 -0
  60. package/apps/dashboard/dist/index.html.gz +0 -0
  61. package/apps/dashboard/dist/signup.html +446 -0
  62. package/apps/dashboard/index.html +6442 -0
  63. package/apps/dashboard/package.json +15 -0
  64. package/apps/dashboard/src/app.js +2823 -0
  65. package/apps/dashboard/src/app.js.br +0 -0
  66. package/apps/dashboard/src/app.js.gz +0 -0
  67. package/apps/dashboard/src/chat/chat-actions.js +1847 -0
  68. package/apps/dashboard/src/chat/chat-actions.js.br +0 -0
  69. package/apps/dashboard/src/chat/unified-messages.js +327 -0
  70. package/apps/dashboard/src/chat/unified-messages.js.br +0 -0
  71. package/apps/dashboard/src/cli-process.js +208 -0
  72. package/apps/dashboard/src/cli-process.js.br +0 -0
  73. package/apps/dashboard/src/cli-process.js.gz +0 -0
  74. package/apps/dashboard/src/components/active-tasks-panel.js +175 -0
  75. package/apps/dashboard/src/components/active-tasks-panel.js.br +0 -0
  76. package/apps/dashboard/src/core/api.js +18 -0
  77. package/apps/dashboard/src/core/api.js.br +0 -0
  78. package/apps/dashboard/src/core/dom.js +220 -0
  79. package/apps/dashboard/src/core/dom.js.br +0 -0
  80. package/apps/dashboard/src/core/state.js +91 -0
  81. package/apps/dashboard/src/core/state.js.br +0 -0
  82. package/apps/dashboard/src/core/task-manager.js +134 -0
  83. package/apps/dashboard/src/core/task-manager.js.br +0 -0
  84. package/apps/dashboard/src/orchestration-status.js +127 -0
  85. package/apps/dashboard/src/orchestration-status.js.br +0 -0
  86. package/apps/dashboard/src/setup-wizard.js +555 -0
  87. package/apps/dashboard/src/setup-wizard.js.br +0 -0
  88. package/apps/dashboard/src/styles.css +2085 -0
  89. package/apps/dashboard/src/styles.css.br +0 -0
  90. package/apps/dashboard/src/styles.css.gz +0 -0
  91. package/apps/dashboard/src/tabs/agents-tab.js +2237 -0
  92. package/apps/dashboard/src/tabs/agents-tab.js.br +0 -0
  93. package/apps/dashboard/src/tabs/benchmarks-tab.js +229 -0
  94. package/apps/dashboard/src/tabs/benchmarks-tab.js.br +0 -0
  95. package/apps/dashboard/src/tabs/comms-tab.js +955 -0
  96. package/apps/dashboard/src/tabs/comms-tab.js.br +0 -0
  97. package/apps/dashboard/src/tabs/contacts-tab.js +654 -0
  98. package/apps/dashboard/src/tabs/contacts-tab.js.br +0 -0
  99. package/apps/dashboard/src/tabs/engines-tab.js +175 -0
  100. package/apps/dashboard/src/tabs/engines-tab.js.br +0 -0
  101. package/apps/dashboard/src/tabs/memory-tab.js +182 -0
  102. package/apps/dashboard/src/tabs/memory-tab.js.br +0 -0
  103. package/apps/dashboard/src/tabs/models-tab.js +441 -0
  104. package/apps/dashboard/src/tabs/models-tab.js.br +0 -0
  105. package/apps/dashboard/src/tabs/pm-loop-tab.js +185 -0
  106. package/apps/dashboard/src/tabs/pm-loop-tab.js.br +0 -0
  107. package/apps/dashboard/src/tabs/projects-tab.js +663 -0
  108. package/apps/dashboard/src/tabs/projects-tab.js.br +0 -0
  109. package/apps/dashboard/src/tabs/projects-tab.js.gz +0 -0
  110. package/apps/dashboard/src/tabs/prompts-tab.js +160 -0
  111. package/apps/dashboard/src/tabs/prompts-tab.js.br +0 -0
  112. package/apps/dashboard/src/tabs/services-tab.js +202 -0
  113. package/apps/dashboard/src/tabs/services-tab.js.br +0 -0
  114. package/apps/dashboard/src/tabs/settings-tab.js +803 -0
  115. package/apps/dashboard/src/tabs/settings-tab.js.br +0 -0
  116. package/apps/dashboard/src/tabs/skills-tab.js +284 -0
  117. package/apps/dashboard/src/tabs/skills-tab.js.br +0 -0
  118. package/apps/dashboard/src/tabs/spending-tab.js +173 -0
  119. package/apps/dashboard/src/tabs/spending-tab.js.br +0 -0
  120. package/apps/dashboard/src/tabs/swarm-chat-tab.js +660 -0
  121. package/apps/dashboard/src/tabs/swarm-chat-tab.js.br +0 -0
  122. package/apps/dashboard/src/tabs/swarm-tab.js +538 -0
  123. package/apps/dashboard/src/tabs/swarm-tab.js.br +0 -0
  124. package/apps/dashboard/src/tabs/usage-tab.js +390 -0
  125. package/apps/dashboard/src/tabs/usage-tab.js.br +0 -0
  126. package/apps/dashboard/src/tabs/waves-tab.js +238 -0
  127. package/apps/dashboard/src/tabs/waves-tab.js.br +0 -0
  128. package/apps/dashboard/src/tabs/workflows-tab.js +747 -0
  129. package/apps/dashboard/src/tabs/workflows-tab.js.br +0 -0
  130. package/apps/vibe/.crew/agent-memory/pipeline.json +249 -0
  131. package/apps/vibe/.crew/cost.json +17 -0
  132. package/apps/vibe/.crew/json-parse-metrics.jsonl +22 -0
  133. package/apps/vibe/.crew/pipeline-metrics.jsonl +22 -0
  134. package/apps/vibe/.crew/pipeline-runs/pipeline-0f90c392-2425-4ae5-850c-bd9d17b1d690.jsonl +5 -0
  135. package/apps/vibe/.crew/pipeline-runs/pipeline-1c269dd9-a63f-4fba-af81-5cf08048ef06.jsonl +5 -0
  136. package/apps/vibe/.crew/pipeline-runs/pipeline-288a7765-da24-4a22-89bc-1f3cc9b0562c.jsonl +1 -0
  137. package/apps/vibe/.crew/pipeline-runs/pipeline-2c78fd22-a657-4bd1-bc49-0679fb384409.jsonl +5 -0
  138. package/apps/vibe/.crew/pipeline-runs/pipeline-3e6fe08d-3264-404a-8df3-aab7efef10e7.jsonl +5 -0
  139. package/apps/vibe/.crew/pipeline-runs/pipeline-42eec610-57fe-4e09-9e7e-b315038495c2.jsonl +5 -0
  140. package/apps/vibe/.crew/pipeline-runs/pipeline-4438eb4c-ae13-42b1-90e2-b043d8983be8.jsonl +5 -0
  141. package/apps/vibe/.crew/pipeline-runs/pipeline-4740a9f5-86e7-44b6-a394-de433e291727.jsonl +5 -0
  142. package/apps/vibe/.crew/pipeline-runs/pipeline-49e1da6a-957e-48fd-9220-415019e4f8e2.jsonl +5 -0
  143. package/apps/vibe/.crew/pipeline-runs/pipeline-4c9251db-be68-427b-a3fc-a264f2b5778d.jsonl +5 -0
  144. package/apps/vibe/.crew/pipeline-runs/pipeline-65e29a57-664d-4196-8109-017e364f182e.jsonl +5 -0
  145. package/apps/vibe/.crew/pipeline-runs/pipeline-6aa04bc5-9593-4b1f-b58d-3bf2978cb602.jsonl +5 -0
  146. package/apps/vibe/.crew/pipeline-runs/pipeline-6e1cba53-9b70-457e-99e0-59199149dd21.jsonl +5 -0
  147. package/apps/vibe/.crew/pipeline-runs/pipeline-749f41cc-4dac-4204-be64-873a6080a0d2.jsonl +5 -0
  148. package/apps/vibe/.crew/pipeline-runs/pipeline-74d68121-e181-4864-bd9a-c3211341dfaf.jsonl +5 -0
  149. package/apps/vibe/.crew/pipeline-runs/pipeline-8509bc24-142d-4e07-b44a-a50bf99d1103.jsonl +5 -0
  150. package/apps/vibe/.crew/pipeline-runs/pipeline-960339c6-07ca-43ce-9900-f6e1702b39b9.jsonl +5 -0
  151. package/apps/vibe/.crew/pipeline-runs/pipeline-9c6480a9-7031-4146-b241-825b9a2d1de1.jsonl +5 -0
  152. package/apps/vibe/.crew/pipeline-runs/pipeline-9fd42426-8492-4157-9d5f-e1537c060489.jsonl +2 -0
  153. package/apps/vibe/.crew/pipeline-runs/pipeline-ad6d40a3-2f5e-46a9-a345-47caaccc51aa.jsonl +5 -0
  154. package/apps/vibe/.crew/pipeline-runs/pipeline-bc606133-8d5b-4535-8d85-f1a29cdaa981.jsonl +5 -0
  155. package/apps/vibe/.crew/pipeline-runs/pipeline-c1a13ccd-634a-4d01-a4a7-1177b8a752ff.jsonl +5 -0
  156. package/apps/vibe/.crew/pipeline-runs/pipeline-c7d27b42-249e-4bd4-8f26-6aa998110b8a.jsonl +5 -0
  157. package/apps/vibe/.crew/pipeline-runs/pipeline-cca2e9b9-4a34-4d25-a311-5c793fa7e91e.jsonl +5 -0
  158. package/apps/vibe/.crew/sandbox.json +7 -0
  159. package/apps/vibe/.crew/session.json +285 -0
  160. package/apps/vibe/.crew/training-data.jsonl +0 -0
  161. package/apps/vibe/.github/workflows/studio-quality.yml +37 -0
  162. package/apps/vibe/.studio-data/project-messages/chuck-norris.jsonl +12 -0
  163. package/apps/vibe/.studio-data/project-messages/general.jsonl +54 -0
  164. package/apps/vibe/.studio-data/project-messages/studio-local.jsonl +10 -0
  165. package/apps/vibe/ARCHITECTURE.md +3393 -0
  166. package/apps/vibe/QUICK-REFERENCE.md +211 -0
  167. package/apps/vibe/README.md +76 -0
  168. package/apps/vibe/ROADMAP.md +41 -0
  169. package/apps/vibe/STUDIO-SETUP-COMPLETE.md +35 -0
  170. package/apps/vibe/VISUAL-GUIDE.md +378 -0
  171. package/apps/vibe/capture-demo.mjs +160 -0
  172. package/apps/vibe/capture-vibe-assets.mjs +71 -0
  173. package/apps/vibe/capture-vibe-video.mjs +260 -0
  174. package/apps/vibe/check-buttons.js +41 -0
  175. package/apps/vibe/diagnose.html +106 -0
  176. package/apps/vibe/fix-buttons.js +103 -0
  177. package/apps/vibe/index.html +3401 -0
  178. package/apps/vibe/package-lock.json +920 -0
  179. package/apps/vibe/package.json +31 -0
  180. package/apps/vibe/public/favicon.png +0 -0
  181. package/apps/vibe/scripts/studio-pty-host.py +117 -0
  182. package/apps/vibe/server.mjs +1835 -0
  183. package/apps/vibe/src/main.js +2846 -0
  184. package/apps/vibe/src/register-all-languages.js +98 -0
  185. package/apps/vibe/start-studio.sh +11 -0
  186. package/apps/vibe/test/accessibility-tests.js +77 -0
  187. package/apps/vibe/test/browser-performance-audit.mjs +205 -0
  188. package/apps/vibe/test/performance-tests.js +120 -0
  189. package/apps/vibe/test/security-tests.js +213 -0
  190. package/apps/vibe/tests/e2e.local.mjs +54 -0
  191. package/apps/vibe/tests/server.smoke.mjs +106 -0
  192. package/apps/vibe/update_website.mjs +74 -0
  193. package/apps/vibe/vite.config.js +19 -0
  194. package/apps/vibe/watch-server.mjs +108 -0
  195. package/contrib/openclaw-plugin/README.md +199 -0
  196. package/contrib/openclaw-plugin/index.ts +306 -0
  197. package/contrib/openclaw-plugin/openclaw.plugin.json +41 -0
  198. package/contrib/openclaw-plugin/package.json +27 -0
  199. package/contrib/openclaw-plugin/skills/crewswarm/SKILL.md +88 -0
  200. package/crew-lead.mjs +649 -0
  201. package/engines/claude-code.json +36 -0
  202. package/engines/codex.json +37 -0
  203. package/engines/crew-cli.json +42 -0
  204. package/engines/cursor.json +40 -0
  205. package/engines/docker-sandbox.json +38 -0
  206. package/engines/gemini-cli.json +75 -0
  207. package/engines/opencode.json +31 -0
  208. package/gateway-bridge.mjs +1575 -0
  209. package/install.sh +738 -0
  210. package/lib/agent-registry.mjs +232 -0
  211. package/lib/agents/daemon.mjs +121 -0
  212. package/lib/agents/dispatch.mjs +225 -0
  213. package/lib/agents/permissions.mjs +90 -0
  214. package/lib/agents/platform-formatting.mjs +102 -0
  215. package/lib/agents/registry.mjs +81 -0
  216. package/lib/agents/tool-instructions.mjs +257 -0
  217. package/lib/agents/validation.mjs +75 -0
  218. package/lib/approval/policy-manager.mjs +221 -0
  219. package/lib/autoharness/index.mjs +391 -0
  220. package/lib/bridges/cli-executor.mjs +332 -0
  221. package/lib/bridges/gateway-ws.mjs +345 -0
  222. package/lib/bridges/integration.mjs +229 -0
  223. package/lib/bridges/rag-helper.mjs +90 -0
  224. package/lib/browser/opencode-passthrough-filter.js +44 -0
  225. package/lib/browser/passthrough-stderr.js +109 -0
  226. package/lib/chat/autonomous-mentions.mjs +373 -0
  227. package/lib/chat/history.mjs +82 -0
  228. package/lib/chat/mention-routing-intent.mjs +136 -0
  229. package/lib/chat/participants.mjs +95 -0
  230. package/lib/chat/project-messages-rag.mjs +265 -0
  231. package/lib/chat/project-messages.mjs +479 -0
  232. package/lib/chat/shared-chat-prompt-overlay.mjs +52 -0
  233. package/lib/chat/thread-binding.mjs +34 -0
  234. package/lib/chat/unified-history.mjs +223 -0
  235. package/lib/chat/unified-wrapper.mjs +41 -0
  236. package/lib/cli-process-tracker.mjs +228 -0
  237. package/lib/collections/index.mjs +433 -0
  238. package/lib/contacts/identity-linker.mjs +248 -0
  239. package/lib/contacts/index.mjs +341 -0
  240. package/lib/crew-judge/PROMPT.md +93 -0
  241. package/lib/crew-judge/judge.mjs +260 -0
  242. package/lib/crew-lead/agent-manager.mjs +125 -0
  243. package/lib/crew-lead/background.mjs +270 -0
  244. package/lib/crew-lead/brain.mjs +110 -0
  245. package/lib/crew-lead/chat-handler.mjs +2603 -0
  246. package/lib/crew-lead/chat-handler.mjs.bak +1274 -0
  247. package/lib/crew-lead/classifier.mjs +83 -0
  248. package/lib/crew-lead/http-server.mjs +4824 -0
  249. package/lib/crew-lead/intent.mjs +102 -0
  250. package/lib/crew-lead/interval-manager.mjs +41 -0
  251. package/lib/crew-lead/llm-caller.mjs +544 -0
  252. package/lib/crew-lead/prompts.mjs +392 -0
  253. package/lib/crew-lead/retry-manager.mjs +118 -0
  254. package/lib/crew-lead/tools.mjs +318 -0
  255. package/lib/crew-lead/wave-dispatcher.mjs +798 -0
  256. package/lib/crew-lead/waves-config.json +73 -0
  257. package/lib/crew-lead/waves-loader.mjs +110 -0
  258. package/lib/crew-lead/ws-router.mjs +428 -0
  259. package/lib/dispatch/parsers.mjs +299 -0
  260. package/lib/domain-planning/detector.mjs +196 -0
  261. package/lib/domain-planning/prompts/crew-pm-cli.md +96 -0
  262. package/lib/domain-planning/prompts/crew-pm-core.md +122 -0
  263. package/lib/domain-planning/prompts/crew-pm-frontend.md +111 -0
  264. package/lib/engines/crew-cli-sandbox.mjs +422 -0
  265. package/lib/engines/crew-cli.mjs +155 -0
  266. package/lib/engines/cursor-launcher.mjs +110 -0
  267. package/lib/engines/engine-registry.mjs +253 -0
  268. package/lib/engines/llm-direct.mjs +184 -0
  269. package/lib/engines/opencode.mjs +256 -0
  270. package/lib/engines/ouroboros.mjs +114 -0
  271. package/lib/engines/rt-envelope.mjs +1643 -0
  272. package/lib/engines/rt-envelope.mjs.backup-current +870 -0
  273. package/lib/engines/runners.mjs +1367 -0
  274. package/lib/gemini-cli-passthrough-noise.mjs +37 -0
  275. package/lib/integrations/code-search.mjs +259 -0
  276. package/lib/integrations/greptile.mjs +148 -0
  277. package/lib/integrations/multimodal.mjs +313 -0
  278. package/lib/integrations/telegram-streaming.mjs +153 -0
  279. package/lib/integrations/tts.mjs +312 -0
  280. package/lib/integrations/twitter-links.mjs +294 -0
  281. package/lib/memory/shared-adapter.mjs +296 -0
  282. package/lib/pipeline/manager.mjs +539 -0
  283. package/lib/preferences/extractor.mjs +347 -0
  284. package/lib/project-dir.mjs +20 -0
  285. package/lib/runtime/config.mjs +388 -0
  286. package/lib/runtime/dlq.mjs +170 -0
  287. package/lib/runtime/log-rotation.mjs +82 -0
  288. package/lib/runtime/logger.mjs +58 -0
  289. package/lib/runtime/memory.mjs +421 -0
  290. package/lib/runtime/paths.mjs +76 -0
  291. package/lib/runtime/project-dir.mjs +127 -0
  292. package/lib/runtime/spending.mjs +204 -0
  293. package/lib/runtime/startup-guard.mjs +291 -0
  294. package/lib/runtime/task-lease.mjs +234 -0
  295. package/lib/runtime/telemetry-schema.mjs +208 -0
  296. package/lib/runtime/telemetry.mjs +101 -0
  297. package/lib/runtime/utils.mjs +64 -0
  298. package/lib/skills/index.mjs +265 -0
  299. package/lib/tools/browser.mjs +135 -0
  300. package/lib/tools/executor.mjs +913 -0
  301. package/lib/types.d.ts +57 -0
  302. package/package.json +106 -0
  303. package/pm-loop.mjs +1626 -0
  304. package/prompts/coder-back.md +27 -0
  305. package/prompts/coder-front.md +27 -0
  306. package/prompts/coder.md +28 -0
  307. package/prompts/copywriter.md +17 -0
  308. package/prompts/fixer.md +39 -0
  309. package/prompts/frontend.md +23 -0
  310. package/prompts/github.md +24 -0
  311. package/prompts/main.md +39 -0
  312. package/prompts/pm-cli.md +95 -0
  313. package/prompts/pm-core.md +121 -0
  314. package/prompts/pm-frontend.md +110 -0
  315. package/prompts/pm.md +234 -0
  316. package/prompts/qa.md +44 -0
  317. package/prompts/security.md +19 -0
  318. package/scripts/build-crew-chat.sh +28 -0
  319. package/scripts/build-llms-full.mjs +52 -0
  320. package/scripts/chatmock-login.sh +16 -0
  321. package/scripts/chatmock-serve.sh +16 -0
  322. package/scripts/check-dashboard.mjs +88 -0
  323. package/scripts/crew-scribe.mjs +326 -0
  324. package/scripts/dashboard-helpers.mjs +391 -0
  325. package/scripts/dashboard-validation.mjs +198 -0
  326. package/scripts/dashboard.mjs +9717 -0
  327. package/scripts/dlq-replay.mjs +61 -0
  328. package/scripts/doctor.mjs +196 -0
  329. package/scripts/file-lock.mjs +186 -0
  330. package/scripts/fresh-machine-smoke.sh +323 -0
  331. package/scripts/generate-changelog.mjs +227 -0
  332. package/scripts/generate-openapi.mjs +334 -0
  333. package/scripts/health-check.mjs +229 -0
  334. package/scripts/install-docker.sh +213 -0
  335. package/scripts/mcp-server.mjs +1625 -0
  336. package/scripts/opencrew-rt-daemon.mjs +568 -0
  337. package/scripts/openswitchctl +646 -0
  338. package/scripts/refactor-configs.mjs +39 -0
  339. package/scripts/release-check.sh +46 -0
  340. package/scripts/resolve-node-bin.sh +25 -0
  341. package/scripts/restart-all-from-repo.sh +329 -0
  342. package/scripts/restart-crew-lead.sh +98 -0
  343. package/scripts/restart-dashboard.sh +104 -0
  344. package/scripts/restart-service.sh +274 -0
  345. package/scripts/run-accessibility-audit.mjs +356 -0
  346. package/scripts/run-integration-bounded.mjs +188 -0
  347. package/scripts/run-scheduled-pipeline.mjs +230 -0
  348. package/scripts/run.mjs +41 -0
  349. package/scripts/scan-skills.mjs +79 -0
  350. package/scripts/setup-firewall.sh +128 -0
  351. package/scripts/smoke-dispatch.mjs +149 -0
  352. package/scripts/smoke.sh +163 -0
  353. package/scripts/start-crew.mjs +328 -0
  354. package/scripts/start.mjs +146 -0
  355. package/scripts/swiftbar-restart-service.sh +19 -0
  356. package/scripts/sync-agents.mjs +152 -0
  357. package/scripts/sync-prompts.mjs +79 -0
  358. package/scripts/validate-config.mjs +337 -0
  359. package/scripts/wow.mjs +89 -0
  360. package/telegram-bridge.mjs +2421 -0
  361. package/unified-orchestrator.mjs +519 -0
  362. package/whatsapp-bridge.mjs +1481 -0
@@ -0,0 +1,327 @@
1
+ /**
2
+ * Unified Project Messages UI
3
+ * Adds unified view, search, and export functionality to chat tab
4
+ */
5
+
6
+ import { getJSON, postJSON } from '../core/api.js';
7
+ import { state } from '../core/state.js';
8
+ import { showNotification as notify } from '../core/dom.js';
9
+
10
+ let unifiedViewEnabled = false;
11
+
12
+ /**
13
+ * Toggle unified view (shows all sources with indicators)
14
+ */
15
+ export async function toggleUnifiedView() {
16
+ unifiedViewEnabled = !unifiedViewEnabled;
17
+
18
+ const btn = document.getElementById('unifiedViewToggle');
19
+ if (unifiedViewEnabled) {
20
+ btn.style.background = 'var(--accent)';
21
+ btn.style.color = '#fff';
22
+ btn.textContent = '📊 Unified ✓';
23
+ notify('Unified view enabled — showing all sources');
24
+ } else {
25
+ btn.style.background = '';
26
+ btn.style.color = '';
27
+ btn.textContent = '📊 Unified View';
28
+ notify('Standard view restored');
29
+ }
30
+
31
+ // Reload chat history with unified view
32
+ await loadChatHistoryWithUnified();
33
+ }
34
+
35
+ /**
36
+ * Load chat history with unified view (if enabled)
37
+ */
38
+ async function loadChatHistoryWithUnified() {
39
+ const projectId = state.chatActiveProjectId;
40
+ if (!projectId || projectId === 'general') {
41
+ // Fall back to standard history for general chat
42
+ return;
43
+ }
44
+
45
+ if (!unifiedViewEnabled) {
46
+ // Standard view — just reload normally
47
+ if (window.loadChatHistory) {
48
+ await window.loadChatHistory();
49
+ }
50
+ return;
51
+ }
52
+
53
+ try {
54
+ const data = await getJSON(`/api/crew-lead/project-messages?projectId=${encodeURIComponent(projectId)}&limit=100`);
55
+
56
+ if (!data.ok) {
57
+ console.error('Failed to load unified messages:', data.error);
58
+ notify('Failed to load unified view', true);
59
+ return;
60
+ }
61
+
62
+ // Clear and rebuild chat
63
+ const box = document.getElementById('chatMessages');
64
+ if (!box) return;
65
+
66
+ box.innerHTML = '';
67
+
68
+ // Source indicators
69
+ const sourceEmoji = {
70
+ dashboard: '💻',
71
+ cli: '⚡',
72
+ 'sub-agent': '👷',
73
+ agent: '🤖'
74
+ };
75
+
76
+ // Render messages
77
+ for (const msg of data.messages) {
78
+ const bubble = document.createElement('div');
79
+ bubble.className = `chat-bubble ${msg.role}`;
80
+
81
+ const emoji = sourceEmoji[msg.source] || '📝';
82
+ const agentLabel = msg.agent ? ` [${msg.agent}]` : '';
83
+ const timestamp = new Date(msg.ts).toLocaleTimeString();
84
+
85
+ bubble.innerHTML = `
86
+ <div style="font-size:10px;color:var(--text-3);margin-bottom:4px;">
87
+ ${emoji} <strong>${msg.source}</strong>${agentLabel} · ${timestamp}
88
+ </div>
89
+ <div style="white-space:pre-wrap;word-break:break-word;">${escapeHtml(msg.content)}</div>
90
+ `;
91
+
92
+ box.appendChild(bubble);
93
+ }
94
+
95
+ // Scroll to bottom
96
+ box.scrollTop = box.scrollHeight;
97
+
98
+ notify(`Loaded ${data.messages.length} messages from all sources`);
99
+ } catch (e) {
100
+ console.error('Failed to load unified messages:', e);
101
+ notify('Failed to load unified view', true);
102
+ }
103
+ }
104
+
105
+ /**
106
+ * Open search modal
107
+ */
108
+ export function openSearchModal() {
109
+ const projectId = state.chatActiveProjectId;
110
+ if (!projectId || projectId === 'general') {
111
+ notify('Search requires an active project', true);
112
+ return;
113
+ }
114
+
115
+ const modal = document.getElementById('searchModal');
116
+ if (modal) {
117
+ modal.style.display = 'flex';
118
+ document.getElementById('searchInput')?.focus();
119
+ }
120
+ }
121
+
122
+ /**
123
+ * Close search modal
124
+ */
125
+ export function closeSearchModal() {
126
+ const modal = document.getElementById('searchModal');
127
+ if (modal) {
128
+ modal.style.display = 'none';
129
+ }
130
+ }
131
+
132
+ /**
133
+ * Perform search
134
+ */
135
+ export async function performSearch() {
136
+ const projectId = state.chatActiveProjectId;
137
+ if (!projectId || projectId === 'general') {
138
+ notify('Search requires an active project', true);
139
+ return;
140
+ }
141
+
142
+ const query = document.getElementById('searchInput')?.value?.trim();
143
+ if (!query) {
144
+ notify('Enter a search query', true);
145
+ return;
146
+ }
147
+
148
+ const caseSensitive = document.getElementById('searchCaseSensitive')?.checked || false;
149
+ const source = document.getElementById('searchSource')?.value || '';
150
+
151
+ const resultsDiv = document.getElementById('searchResults');
152
+ if (!resultsDiv) return;
153
+
154
+ resultsDiv.innerHTML = '<div style="text-align:center;padding:20px;">Searching...</div>';
155
+
156
+ try {
157
+ let url = `/api/crew-lead/search-project-messages?projectId=${encodeURIComponent(projectId)}&q=${encodeURIComponent(query)}`;
158
+ if (caseSensitive) url += '&caseSensitive=true';
159
+ if (source) url += `&source=${encodeURIComponent(source)}`;
160
+
161
+ const data = await getJSON(url);
162
+
163
+ if (!data.ok) {
164
+ resultsDiv.innerHTML = `<div style="color:var(--red);padding:20px;">Error: ${escapeHtml(data.error)}</div>`;
165
+ return;
166
+ }
167
+
168
+ if (data.results.length === 0) {
169
+ resultsDiv.innerHTML = '<div style="text-align:center;color:var(--text-3);padding:20px;">No results found</div>';
170
+ return;
171
+ }
172
+
173
+ // Render results
174
+ const sourceEmoji = {
175
+ dashboard: '💻',
176
+ cli: '⚡',
177
+ 'sub-agent': '👷',
178
+ agent: '🤖'
179
+ };
180
+
181
+ let html = `<div style="margin-bottom:12px;font-weight:600;color:var(--text-2);">${data.results.length} results</div>`;
182
+
183
+ for (const result of data.results) {
184
+ const emoji = sourceEmoji[result.source] || '📝';
185
+ const agentLabel = result.agent ? ` [${result.agent}]` : '';
186
+ const timestamp = new Date(result.ts).toLocaleString();
187
+
188
+ html += `
189
+ <div style="border:1px solid var(--border);border-radius:6px;padding:12px;margin-bottom:8px;background:var(--bg-card2);">
190
+ <div style="font-size:11px;color:var(--text-3);margin-bottom:6px;">
191
+ ${emoji} <strong>${result.source}</strong>${agentLabel} · ${timestamp}
192
+ </div>
193
+ <div style="font-size:13px;color:var(--text-1);">
194
+ ${escapeHtml(result.snippet)}
195
+ </div>
196
+ </div>
197
+ `;
198
+ }
199
+
200
+ resultsDiv.innerHTML = html;
201
+ notify(`Found ${data.results.length} results`);
202
+ } catch (e) {
203
+ console.error('Search failed:', e);
204
+ resultsDiv.innerHTML = `<div style="color:var(--red);padding:20px;">Search failed: ${escapeHtml(e.message)}</div>`;
205
+ }
206
+ }
207
+
208
+ /**
209
+ * Export messages
210
+ */
211
+ export async function exportMessages() {
212
+ const projectId = state.chatActiveProjectId;
213
+ if (!projectId || projectId === 'general') {
214
+ notify('Export requires an active project', true);
215
+ return;
216
+ }
217
+
218
+ // Ask user for format
219
+ const format = await new Promise(resolve => {
220
+ const modal = document.createElement('div');
221
+ modal.style.cssText = 'position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,0.7);z-index:10001;display:flex;align-items:center;justify-content:center;';
222
+
223
+ modal.innerHTML = `
224
+ <div style="background:var(--bg-card);border-radius:12px;padding:24px;max-width:400px;">
225
+ <h3 style="margin:0 0 16px 0;">Export Format</h3>
226
+ <div style="display:flex;flex-direction:column;gap:8px;margin-bottom:16px;">
227
+ <button class="export-format-btn btn-ghost" data-format="markdown" style="text-align:left;padding:12px;">
228
+ 📝 Markdown (.md) — Best for reading
229
+ </button>
230
+ <button class="export-format-btn btn-ghost" data-format="json" style="text-align:left;padding:12px;">
231
+ 📋 JSON — Full data with metadata
232
+ </button>
233
+ <button class="export-format-btn btn-ghost" data-format="csv" style="text-align:left;padding:12px;">
234
+ 📊 CSV — Spreadsheet compatible
235
+ </button>
236
+ <button class="export-format-btn btn-ghost" data-format="txt" style="text-align:left;padding:12px;">
237
+ 📄 Plain Text (.txt)
238
+ </button>
239
+ </div>
240
+ <button onclick="this.closest('div').parentElement.remove()" class="btn-ghost" style="width:100%;">Cancel</button>
241
+ </div>
242
+ `;
243
+
244
+ document.body.appendChild(modal);
245
+
246
+ modal.querySelectorAll('.export-format-btn').forEach(btn => {
247
+ btn.onclick = () => {
248
+ resolve(btn.dataset.format);
249
+ modal.remove();
250
+ };
251
+ });
252
+
253
+ modal.onclick = (e) => {
254
+ if (e.target === modal) {
255
+ resolve(null);
256
+ modal.remove();
257
+ }
258
+ };
259
+ });
260
+
261
+ if (!format) return;
262
+
263
+ try {
264
+ notify('Exporting...');
265
+
266
+ const url = `/api/crew-lead/export-project-messages?projectId=${encodeURIComponent(projectId)}&format=${format}&includeMetadata=true`;
267
+
268
+ // Download file
269
+ const a = document.createElement('a');
270
+ a.href = url;
271
+ a.download = `project-${projectId}.${format === 'markdown' ? 'md' : format}`;
272
+ document.body.appendChild(a);
273
+ a.click();
274
+ document.body.removeChild(a);
275
+
276
+ notify(`Exported as ${format.toUpperCase()}`);
277
+ } catch (e) {
278
+ console.error('Export failed:', e);
279
+ notify('Export failed: ' + e.message, true);
280
+ }
281
+ }
282
+
283
+ /**
284
+ * Escape HTML
285
+ */
286
+ function escapeHtml(text) {
287
+ const div = document.createElement('div');
288
+ div.textContent = text;
289
+ return div.innerHTML;
290
+ }
291
+
292
+ // Expose functions globally
293
+ if (typeof window !== 'undefined') {
294
+ window.toggleUnifiedView = toggleUnifiedView;
295
+ window.openSearchModal = openSearchModal;
296
+ window.closeSearchModal = closeSearchModal;
297
+ window.performSearch = performSearch;
298
+ window.exportMessages = exportMessages;
299
+ }
300
+
301
+ // Add keyboard shortcuts
302
+ if (typeof window !== 'undefined') {
303
+ document.addEventListener('keydown', (e) => {
304
+ // Cmd/Ctrl + K to open search
305
+ if ((e.metaKey || e.ctrlKey) && e.key === 'k') {
306
+ const projectId = state.chatActiveProjectId;
307
+ if (projectId && projectId !== 'general') {
308
+ e.preventDefault();
309
+ openSearchModal();
310
+ }
311
+ }
312
+
313
+ // Escape to close search modal
314
+ if (e.key === 'Escape') {
315
+ const modal = document.getElementById('searchModal');
316
+ if (modal && modal.style.display !== 'none') {
317
+ closeSearchModal();
318
+ }
319
+ }
320
+
321
+ // Enter in search input to perform search
322
+ if (e.key === 'Enter' && e.target.id === 'searchInput') {
323
+ e.preventDefault();
324
+ performSearch();
325
+ }
326
+ });
327
+ }
@@ -0,0 +1,208 @@
1
+ /**
2
+ * CLI Process View - Orchestration status + model configuration
3
+ */
4
+
5
+ import { updateOrchestrationStatus, startOrchestrationStatusUpdates, stopOrchestrationStatusUpdates } from './orchestration-status.js';
6
+
7
+ let cliProcessMode = 'connected';
8
+
9
+ window.initCLIProcess = async function() {
10
+ await loadCLIProcessConfig();
11
+ startOrchestrationStatusUpdates();
12
+ setupCLIProcessListeners();
13
+ };
14
+
15
+ function setupCLIProcessListeners() {
16
+ document.querySelector('[data-action="toggleCLIProcessMode"]')?.addEventListener('click', toggleCLIProcessMode);
17
+ document.querySelector('[data-action="saveCLIProcessConfig"]')?.addEventListener('click', saveCLIProcessConfig);
18
+ document.querySelector('[data-action="applyRecommendedCLIProcessConfig"]')?.addEventListener('click', applyRecommendedCLIProcessConfig);
19
+ document.querySelector('[data-action="resetCLIProcessConfig"]')?.addEventListener('click', resetCLIProcessConfig);
20
+ bindCustomModelSelectors();
21
+ document.querySelector('[data-action="refreshCLIProcess"]')?.addEventListener('click', async () => {
22
+ await updateOrchestrationStatus();
23
+ await loadCLIProcessConfig();
24
+ });
25
+ }
26
+
27
+ function bindCustomModelSelectors() {
28
+ [
29
+ 'configChatModel',
30
+ 'configRouterModel',
31
+ 'configReasoningModel',
32
+ 'configL2AModel',
33
+ 'configL2BModel',
34
+ 'configExecutionModel',
35
+ 'configQAModel'
36
+ ].forEach((id) => {
37
+ const el = document.getElementById(id);
38
+ if (!el || el.dataset.customBound === '1') return;
39
+ el.dataset.customBound = '1';
40
+ el.addEventListener('change', () => handleCustomModelSelection(el));
41
+ });
42
+ }
43
+
44
+ function handleCustomModelSelection(selectEl) {
45
+ if (!selectEl || selectEl.value !== '__custom__') return;
46
+ const previous = selectEl.dataset.previousValue || '';
47
+ const raw = window.prompt('Enter exact model ID for this slot:', previous);
48
+ const custom = String(raw || '').trim();
49
+ if (!custom) {
50
+ selectEl.value = previous;
51
+ return;
52
+ }
53
+ let option = Array.from(selectEl.options).find((opt) => opt.value === custom);
54
+ if (!option) {
55
+ option = document.createElement('option');
56
+ option.value = custom;
57
+ option.textContent = `${custom} (custom)`;
58
+ const customMarker = Array.from(selectEl.options).find((opt) => opt.value === '__custom__');
59
+ if (customMarker) {
60
+ selectEl.insertBefore(option, customMarker);
61
+ } else {
62
+ selectEl.appendChild(option);
63
+ }
64
+ }
65
+ selectEl.value = custom;
66
+ selectEl.dataset.previousValue = custom;
67
+ }
68
+
69
+ function toggleCLIProcessMode() {
70
+ cliProcessMode = cliProcessMode === 'connected' ? 'standalone' : 'connected';
71
+ const btn = document.getElementById('cliProcessMode');
72
+ if (btn) {
73
+ btn.textContent = cliProcessMode === 'connected' ? '🔌 Connected Mode' : '🔌 Standalone Mode';
74
+ btn.style.color = cliProcessMode === 'connected' ? '#10b981' : '#6b7280';
75
+ }
76
+ cliProcessMode === 'connected' ? startOrchestrationStatusUpdates() : stopOrchestrationStatusUpdates();
77
+ }
78
+
79
+ async function loadCLIProcessConfig() {
80
+ try {
81
+ const res = await fetch('/api/settings/cli-models');
82
+ if (res.ok) {
83
+ const config = await res.json();
84
+ const set = (id, v) => {
85
+ const el = document.getElementById(id);
86
+ if (!el) return;
87
+ const value = v || '';
88
+ if (value && !Array.from(el.options).some((opt) => opt.value === value)) {
89
+ const option = document.createElement('option');
90
+ option.value = value;
91
+ option.textContent = `${value} (saved custom)`;
92
+ const customMarker = Array.from(el.options).find((opt) => opt.value === '__custom__');
93
+ if (customMarker) {
94
+ el.insertBefore(option, customMarker);
95
+ } else {
96
+ el.appendChild(option);
97
+ }
98
+ }
99
+ el.value = value;
100
+ el.dataset.previousValue = value;
101
+ };
102
+ set('configChatModel', config.CREW_CHAT_MODEL);
103
+ set('configRouterModel', config.CREW_ROUTER_MODEL);
104
+ set('configReasoningModel', config.CREW_REASONING_MODEL);
105
+ set('configL2AModel', config.CREW_L2A_MODEL);
106
+ set('configL2BModel', config.CREW_L2B_MODEL);
107
+ set('configExecutionModel', config.CREW_EXECUTION_MODEL);
108
+ set('configQAModel', config.CREW_QA_MODEL);
109
+ set('configMaxWorkers', config.CREW_MAX_PARALLEL_WORKERS || '6');
110
+ set('configExtraValidators', config.CREW_L2_EXTRA_VALIDATORS);
111
+ }
112
+ } catch (err) {
113
+ console.error('[CLI Process] Failed to load config:', err);
114
+ }
115
+ }
116
+
117
+ function getCLIProcessConfigFromForm() {
118
+ const get = (id) => document.getElementById(id)?.value || '';
119
+ return {
120
+ CREW_CHAT_MODEL: get('configChatModel'),
121
+ CREW_ROUTER_MODEL: get('configRouterModel'),
122
+ CREW_REASONING_MODEL: get('configReasoningModel'),
123
+ CREW_L2A_MODEL: get('configL2AModel'),
124
+ CREW_L2B_MODEL: get('configL2BModel'),
125
+ CREW_EXECUTION_MODEL: get('configExecutionModel'),
126
+ CREW_QA_MODEL: get('configQAModel'),
127
+ CREW_MAX_PARALLEL_WORKERS: get('configMaxWorkers') || '6',
128
+ CREW_L2_EXTRA_VALIDATORS: get('configExtraValidators')
129
+ };
130
+ }
131
+
132
+ async function saveCLIProcessConfig() {
133
+ const config = getCLIProcessConfigFromForm();
134
+ try {
135
+ const res = await fetch('/api/settings/cli-models', {
136
+ method: 'POST',
137
+ headers: { 'Content-Type': 'application/json' },
138
+ body: JSON.stringify(config)
139
+ });
140
+ if (!res.ok) {
141
+ const err = await res.json().catch(() => ({}));
142
+ throw new Error(err.error || res.statusText);
143
+ }
144
+ alert('✅ CLI configuration saved to crewswarm.json. Restart crew (Services → Start All) for changes to take effect.');
145
+ } catch (err) {
146
+ alert('❌ Save failed: ' + err.message);
147
+ }
148
+ }
149
+
150
+ async function applyRecommendedCLIProcessConfig() {
151
+ const config = {
152
+ CREW_CHAT_MODEL: 'grok-4-1-fast-non-reasoning',
153
+ CREW_ROUTER_MODEL: 'gpt-5.4',
154
+ CREW_REASONING_MODEL: 'gpt-5.4',
155
+ CREW_L2A_MODEL: 'gpt-5.4',
156
+ CREW_L2B_MODEL: 'gpt-5.4',
157
+ CREW_EXECUTION_MODEL: 'gemini-2.5-flash',
158
+ CREW_QA_MODEL: 'gpt-5.4',
159
+ CREW_MAX_PARALLEL_WORKERS: '6',
160
+ CREW_L2_EXTRA_VALIDATORS: ''
161
+ };
162
+ document.getElementById('configChatModel').value = config.CREW_CHAT_MODEL;
163
+ document.getElementById('configRouterModel').value = config.CREW_ROUTER_MODEL;
164
+ document.getElementById('configReasoningModel').value = config.CREW_REASONING_MODEL;
165
+ document.getElementById('configL2AModel').value = config.CREW_L2A_MODEL;
166
+ document.getElementById('configL2BModel').value = config.CREW_L2B_MODEL;
167
+ document.getElementById('configExecutionModel').value = config.CREW_EXECUTION_MODEL;
168
+ document.getElementById('configQAModel').value = config.CREW_QA_MODEL;
169
+ document.getElementById('configMaxWorkers').value = config.CREW_MAX_PARALLEL_WORKERS;
170
+ document.getElementById('configExtraValidators').value = config.CREW_L2_EXTRA_VALIDATORS;
171
+ bindCustomModelSelectors();
172
+ try {
173
+ const res = await fetch('/api/settings/cli-models', {
174
+ method: 'POST',
175
+ headers: { 'Content-Type': 'application/json' },
176
+ body: JSON.stringify(config)
177
+ });
178
+ if (res.ok) {
179
+ alert('✅ Recommended stack applied. Restart crew for changes to take effect.');
180
+ }
181
+ } catch (err) {
182
+ console.error('[CLI Process] Apply recommended failed:', err);
183
+ }
184
+ }
185
+
186
+ async function resetCLIProcessConfig() {
187
+ ['configChatModel','configRouterModel','configReasoningModel','configL2AModel','configL2BModel','configExecutionModel','configQAModel','configExtraValidators'].forEach(id => {
188
+ const el = document.getElementById(id);
189
+ if (el) el.value = '';
190
+ });
191
+ document.getElementById('configMaxWorkers').value = '6';
192
+ try {
193
+ const config = {
194
+ CREW_CHAT_MODEL: '', CREW_ROUTER_MODEL: '', CREW_REASONING_MODEL: '', CREW_L2A_MODEL: '', CREW_L2B_MODEL: '',
195
+ CREW_EXECUTION_MODEL: '', CREW_QA_MODEL: '', CREW_MAX_PARALLEL_WORKERS: '6', CREW_L2_EXTRA_VALIDATORS: ''
196
+ };
197
+ await fetch('/api/settings/cli-models', {
198
+ method: 'POST',
199
+ headers: { 'Content-Type': 'application/json' },
200
+ body: JSON.stringify(config)
201
+ });
202
+ } catch (err) {
203
+ console.error('[CLI Process] Reset save failed:', err);
204
+ }
205
+ alert('↻ Configuration reset');
206
+ }
207
+
208
+ export { cliProcessMode };