crca 1.4.0__py3-none-any.whl

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 (501) hide show
  1. .github/ISSUE_TEMPLATE/bug_report.md +65 -0
  2. .github/ISSUE_TEMPLATE/feature_request.md +41 -0
  3. .github/PULL_REQUEST_TEMPLATE.md +20 -0
  4. .github/workflows/publish-manual.yml +61 -0
  5. .github/workflows/publish.yml +64 -0
  6. .gitignore +214 -0
  7. CRCA.py +4156 -0
  8. LICENSE +201 -0
  9. MANIFEST.in +43 -0
  10. PKG-INFO +5035 -0
  11. README.md +4959 -0
  12. __init__.py +17 -0
  13. branches/CRCA-Q.py +2728 -0
  14. branches/crca_cg/corposwarm.py +9065 -0
  15. branches/crca_cg/fix_rancher_docker_creds.ps1 +155 -0
  16. branches/crca_cg/package.json +5 -0
  17. branches/crca_cg/test_bolt_integration.py +446 -0
  18. branches/crca_cg/test_corposwarm_comprehensive.py +773 -0
  19. branches/crca_cg/test_new_features.py +163 -0
  20. branches/crca_sd/__init__.py +149 -0
  21. branches/crca_sd/crca_sd_core.py +770 -0
  22. branches/crca_sd/crca_sd_governance.py +1325 -0
  23. branches/crca_sd/crca_sd_mpc.py +1130 -0
  24. branches/crca_sd/crca_sd_realtime.py +1844 -0
  25. branches/crca_sd/crca_sd_tui.py +1133 -0
  26. crca-1.4.0.dist-info/METADATA +5035 -0
  27. crca-1.4.0.dist-info/RECORD +501 -0
  28. crca-1.4.0.dist-info/WHEEL +4 -0
  29. crca-1.4.0.dist-info/licenses/LICENSE +201 -0
  30. docs/CRCA-Q.md +2333 -0
  31. examples/config.yaml.example +25 -0
  32. examples/crca_sd_example.py +513 -0
  33. examples/data_broker_example.py +294 -0
  34. examples/logistics_corporation.py +861 -0
  35. examples/palantir_example.py +299 -0
  36. examples/policy_bench.py +934 -0
  37. examples/pridnestrovia-sd.py +705 -0
  38. examples/pridnestrovia_realtime.py +1902 -0
  39. prompts/__init__.py +10 -0
  40. prompts/default_crca.py +101 -0
  41. pyproject.toml +151 -0
  42. requirements.txt +76 -0
  43. schemas/__init__.py +43 -0
  44. schemas/mcpSchemas.py +51 -0
  45. schemas/policy.py +458 -0
  46. templates/__init__.py +38 -0
  47. templates/base_specialized_agent.py +195 -0
  48. templates/drift_detection.py +325 -0
  49. templates/examples/causal_agent_template.py +309 -0
  50. templates/examples/drag_drop_example.py +213 -0
  51. templates/examples/logistics_agent_template.py +207 -0
  52. templates/examples/trading_agent_template.py +206 -0
  53. templates/feature_mixins.py +253 -0
  54. templates/graph_management.py +442 -0
  55. templates/llm_integration.py +194 -0
  56. templates/module_registry.py +276 -0
  57. templates/mpc_planner.py +280 -0
  58. templates/policy_loop.py +1168 -0
  59. templates/prediction_framework.py +448 -0
  60. templates/statistical_methods.py +778 -0
  61. tests/sanity.yml +31 -0
  62. tests/sanity_check +406 -0
  63. tests/test_core.py +47 -0
  64. tests/test_crca_excel.py +166 -0
  65. tests/test_crca_sd.py +780 -0
  66. tests/test_data_broker.py +424 -0
  67. tests/test_palantir.py +349 -0
  68. tools/__init__.py +38 -0
  69. tools/actuators.py +437 -0
  70. tools/bolt.diy/Dockerfile +103 -0
  71. tools/bolt.diy/app/components/@settings/core/AvatarDropdown.tsx +175 -0
  72. tools/bolt.diy/app/components/@settings/core/ControlPanel.tsx +345 -0
  73. tools/bolt.diy/app/components/@settings/core/constants.tsx +108 -0
  74. tools/bolt.diy/app/components/@settings/core/types.ts +114 -0
  75. tools/bolt.diy/app/components/@settings/index.ts +12 -0
  76. tools/bolt.diy/app/components/@settings/shared/components/TabTile.tsx +151 -0
  77. tools/bolt.diy/app/components/@settings/shared/service-integration/ConnectionForm.tsx +193 -0
  78. tools/bolt.diy/app/components/@settings/shared/service-integration/ConnectionTestIndicator.tsx +60 -0
  79. tools/bolt.diy/app/components/@settings/shared/service-integration/ErrorState.tsx +102 -0
  80. tools/bolt.diy/app/components/@settings/shared/service-integration/LoadingState.tsx +94 -0
  81. tools/bolt.diy/app/components/@settings/shared/service-integration/ServiceHeader.tsx +72 -0
  82. tools/bolt.diy/app/components/@settings/shared/service-integration/index.ts +6 -0
  83. tools/bolt.diy/app/components/@settings/tabs/data/DataTab.tsx +721 -0
  84. tools/bolt.diy/app/components/@settings/tabs/data/DataVisualization.tsx +384 -0
  85. tools/bolt.diy/app/components/@settings/tabs/event-logs/EventLogsTab.tsx +1013 -0
  86. tools/bolt.diy/app/components/@settings/tabs/features/FeaturesTab.tsx +295 -0
  87. tools/bolt.diy/app/components/@settings/tabs/github/GitHubTab.tsx +281 -0
  88. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubAuthDialog.tsx +173 -0
  89. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubCacheManager.tsx +367 -0
  90. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubConnection.tsx +233 -0
  91. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubErrorBoundary.tsx +105 -0
  92. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubProgressiveLoader.tsx +266 -0
  93. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubRepositoryCard.tsx +121 -0
  94. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubRepositorySelector.tsx +312 -0
  95. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubStats.tsx +291 -0
  96. tools/bolt.diy/app/components/@settings/tabs/github/components/GitHubUserProfile.tsx +46 -0
  97. tools/bolt.diy/app/components/@settings/tabs/github/components/shared/GitHubStateIndicators.tsx +264 -0
  98. tools/bolt.diy/app/components/@settings/tabs/github/components/shared/RepositoryCard.tsx +361 -0
  99. tools/bolt.diy/app/components/@settings/tabs/github/components/shared/index.ts +11 -0
  100. tools/bolt.diy/app/components/@settings/tabs/gitlab/GitLabTab.tsx +305 -0
  101. tools/bolt.diy/app/components/@settings/tabs/gitlab/components/GitLabAuthDialog.tsx +186 -0
  102. tools/bolt.diy/app/components/@settings/tabs/gitlab/components/GitLabConnection.tsx +253 -0
  103. tools/bolt.diy/app/components/@settings/tabs/gitlab/components/GitLabRepositorySelector.tsx +358 -0
  104. tools/bolt.diy/app/components/@settings/tabs/gitlab/components/RepositoryCard.tsx +79 -0
  105. tools/bolt.diy/app/components/@settings/tabs/gitlab/components/RepositoryList.tsx +142 -0
  106. tools/bolt.diy/app/components/@settings/tabs/gitlab/components/StatsDisplay.tsx +91 -0
  107. tools/bolt.diy/app/components/@settings/tabs/gitlab/components/index.ts +4 -0
  108. tools/bolt.diy/app/components/@settings/tabs/mcp/McpServerList.tsx +99 -0
  109. tools/bolt.diy/app/components/@settings/tabs/mcp/McpServerListItem.tsx +70 -0
  110. tools/bolt.diy/app/components/@settings/tabs/mcp/McpStatusBadge.tsx +37 -0
  111. tools/bolt.diy/app/components/@settings/tabs/mcp/McpTab.tsx +239 -0
  112. tools/bolt.diy/app/components/@settings/tabs/netlify/NetlifyTab.tsx +1393 -0
  113. tools/bolt.diy/app/components/@settings/tabs/netlify/components/NetlifyConnection.tsx +990 -0
  114. tools/bolt.diy/app/components/@settings/tabs/netlify/components/index.ts +1 -0
  115. tools/bolt.diy/app/components/@settings/tabs/notifications/NotificationsTab.tsx +300 -0
  116. tools/bolt.diy/app/components/@settings/tabs/profile/ProfileTab.tsx +181 -0
  117. tools/bolt.diy/app/components/@settings/tabs/providers/cloud/CloudProvidersTab.tsx +308 -0
  118. tools/bolt.diy/app/components/@settings/tabs/providers/local/ErrorBoundary.tsx +68 -0
  119. tools/bolt.diy/app/components/@settings/tabs/providers/local/HealthStatusBadge.tsx +64 -0
  120. tools/bolt.diy/app/components/@settings/tabs/providers/local/LoadingSkeleton.tsx +107 -0
  121. tools/bolt.diy/app/components/@settings/tabs/providers/local/LocalProvidersTab.tsx +556 -0
  122. tools/bolt.diy/app/components/@settings/tabs/providers/local/ModelCard.tsx +106 -0
  123. tools/bolt.diy/app/components/@settings/tabs/providers/local/ProviderCard.tsx +120 -0
  124. tools/bolt.diy/app/components/@settings/tabs/providers/local/SetupGuide.tsx +671 -0
  125. tools/bolt.diy/app/components/@settings/tabs/providers/local/StatusDashboard.tsx +91 -0
  126. tools/bolt.diy/app/components/@settings/tabs/providers/local/types.ts +44 -0
  127. tools/bolt.diy/app/components/@settings/tabs/settings/SettingsTab.tsx +215 -0
  128. tools/bolt.diy/app/components/@settings/tabs/supabase/SupabaseTab.tsx +1089 -0
  129. tools/bolt.diy/app/components/@settings/tabs/vercel/VercelTab.tsx +909 -0
  130. tools/bolt.diy/app/components/@settings/tabs/vercel/components/VercelConnection.tsx +368 -0
  131. tools/bolt.diy/app/components/@settings/tabs/vercel/components/index.ts +1 -0
  132. tools/bolt.diy/app/components/@settings/utils/tab-helpers.ts +54 -0
  133. tools/bolt.diy/app/components/chat/APIKeyManager.tsx +169 -0
  134. tools/bolt.diy/app/components/chat/Artifact.tsx +296 -0
  135. tools/bolt.diy/app/components/chat/AssistantMessage.tsx +192 -0
  136. tools/bolt.diy/app/components/chat/BaseChat.module.scss +47 -0
  137. tools/bolt.diy/app/components/chat/BaseChat.tsx +522 -0
  138. tools/bolt.diy/app/components/chat/Chat.client.tsx +670 -0
  139. tools/bolt.diy/app/components/chat/ChatAlert.tsx +108 -0
  140. tools/bolt.diy/app/components/chat/ChatBox.tsx +334 -0
  141. tools/bolt.diy/app/components/chat/CodeBlock.module.scss +10 -0
  142. tools/bolt.diy/app/components/chat/CodeBlock.tsx +85 -0
  143. tools/bolt.diy/app/components/chat/DicussMode.tsx +17 -0
  144. tools/bolt.diy/app/components/chat/ExamplePrompts.tsx +37 -0
  145. tools/bolt.diy/app/components/chat/FilePreview.tsx +38 -0
  146. tools/bolt.diy/app/components/chat/GitCloneButton.tsx +327 -0
  147. tools/bolt.diy/app/components/chat/ImportFolderButton.tsx +141 -0
  148. tools/bolt.diy/app/components/chat/LLMApiAlert.tsx +109 -0
  149. tools/bolt.diy/app/components/chat/MCPTools.tsx +129 -0
  150. tools/bolt.diy/app/components/chat/Markdown.module.scss +171 -0
  151. tools/bolt.diy/app/components/chat/Markdown.spec.ts +48 -0
  152. tools/bolt.diy/app/components/chat/Markdown.tsx +252 -0
  153. tools/bolt.diy/app/components/chat/Messages.client.tsx +102 -0
  154. tools/bolt.diy/app/components/chat/ModelSelector.tsx +797 -0
  155. tools/bolt.diy/app/components/chat/NetlifyDeploymentLink.client.tsx +51 -0
  156. tools/bolt.diy/app/components/chat/ProgressCompilation.tsx +110 -0
  157. tools/bolt.diy/app/components/chat/ScreenshotStateManager.tsx +33 -0
  158. tools/bolt.diy/app/components/chat/SendButton.client.tsx +39 -0
  159. tools/bolt.diy/app/components/chat/SpeechRecognition.tsx +28 -0
  160. tools/bolt.diy/app/components/chat/StarterTemplates.tsx +38 -0
  161. tools/bolt.diy/app/components/chat/SupabaseAlert.tsx +199 -0
  162. tools/bolt.diy/app/components/chat/SupabaseConnection.tsx +339 -0
  163. tools/bolt.diy/app/components/chat/ThoughtBox.tsx +43 -0
  164. tools/bolt.diy/app/components/chat/ToolInvocations.tsx +409 -0
  165. tools/bolt.diy/app/components/chat/UserMessage.tsx +101 -0
  166. tools/bolt.diy/app/components/chat/VercelDeploymentLink.client.tsx +158 -0
  167. tools/bolt.diy/app/components/chat/chatExportAndImport/ExportChatButton.tsx +49 -0
  168. tools/bolt.diy/app/components/chat/chatExportAndImport/ImportButtons.tsx +96 -0
  169. tools/bolt.diy/app/components/deploy/DeployAlert.tsx +197 -0
  170. tools/bolt.diy/app/components/deploy/DeployButton.tsx +277 -0
  171. tools/bolt.diy/app/components/deploy/GitHubDeploy.client.tsx +171 -0
  172. tools/bolt.diy/app/components/deploy/GitHubDeploymentDialog.tsx +1041 -0
  173. tools/bolt.diy/app/components/deploy/GitLabDeploy.client.tsx +171 -0
  174. tools/bolt.diy/app/components/deploy/GitLabDeploymentDialog.tsx +764 -0
  175. tools/bolt.diy/app/components/deploy/NetlifyDeploy.client.tsx +246 -0
  176. tools/bolt.diy/app/components/deploy/VercelDeploy.client.tsx +235 -0
  177. tools/bolt.diy/app/components/editor/codemirror/BinaryContent.tsx +7 -0
  178. tools/bolt.diy/app/components/editor/codemirror/CodeMirrorEditor.tsx +555 -0
  179. tools/bolt.diy/app/components/editor/codemirror/EnvMasking.ts +80 -0
  180. tools/bolt.diy/app/components/editor/codemirror/cm-theme.ts +192 -0
  181. tools/bolt.diy/app/components/editor/codemirror/indent.ts +68 -0
  182. tools/bolt.diy/app/components/editor/codemirror/languages.ts +112 -0
  183. tools/bolt.diy/app/components/git/GitUrlImport.client.tsx +147 -0
  184. tools/bolt.diy/app/components/header/Header.tsx +42 -0
  185. tools/bolt.diy/app/components/header/HeaderActionButtons.client.tsx +54 -0
  186. tools/bolt.diy/app/components/mandate/MandateSubmission.tsx +167 -0
  187. tools/bolt.diy/app/components/observability/DeploymentStatus.tsx +168 -0
  188. tools/bolt.diy/app/components/observability/EventTimeline.tsx +119 -0
  189. tools/bolt.diy/app/components/observability/FileDiffViewer.tsx +121 -0
  190. tools/bolt.diy/app/components/observability/GovernanceStatus.tsx +197 -0
  191. tools/bolt.diy/app/components/observability/GovernorMetrics.tsx +246 -0
  192. tools/bolt.diy/app/components/observability/LogStream.tsx +244 -0
  193. tools/bolt.diy/app/components/observability/MandateDetails.tsx +201 -0
  194. tools/bolt.diy/app/components/observability/ObservabilityDashboard.tsx +200 -0
  195. tools/bolt.diy/app/components/sidebar/HistoryItem.tsx +187 -0
  196. tools/bolt.diy/app/components/sidebar/Menu.client.tsx +536 -0
  197. tools/bolt.diy/app/components/sidebar/date-binning.ts +59 -0
  198. tools/bolt.diy/app/components/txt +1 -0
  199. tools/bolt.diy/app/components/ui/BackgroundRays/index.tsx +18 -0
  200. tools/bolt.diy/app/components/ui/BackgroundRays/styles.module.scss +246 -0
  201. tools/bolt.diy/app/components/ui/Badge.tsx +53 -0
  202. tools/bolt.diy/app/components/ui/BranchSelector.tsx +270 -0
  203. tools/bolt.diy/app/components/ui/Breadcrumbs.tsx +101 -0
  204. tools/bolt.diy/app/components/ui/Button.tsx +46 -0
  205. tools/bolt.diy/app/components/ui/Card.tsx +55 -0
  206. tools/bolt.diy/app/components/ui/Checkbox.tsx +32 -0
  207. tools/bolt.diy/app/components/ui/CloseButton.tsx +49 -0
  208. tools/bolt.diy/app/components/ui/CodeBlock.tsx +103 -0
  209. tools/bolt.diy/app/components/ui/Collapsible.tsx +9 -0
  210. tools/bolt.diy/app/components/ui/ColorSchemeDialog.tsx +378 -0
  211. tools/bolt.diy/app/components/ui/Dialog.tsx +449 -0
  212. tools/bolt.diy/app/components/ui/Dropdown.tsx +63 -0
  213. tools/bolt.diy/app/components/ui/EmptyState.tsx +154 -0
  214. tools/bolt.diy/app/components/ui/FileIcon.tsx +346 -0
  215. tools/bolt.diy/app/components/ui/FilterChip.tsx +92 -0
  216. tools/bolt.diy/app/components/ui/GlowingEffect.tsx +192 -0
  217. tools/bolt.diy/app/components/ui/GradientCard.tsx +100 -0
  218. tools/bolt.diy/app/components/ui/IconButton.tsx +84 -0
  219. tools/bolt.diy/app/components/ui/Input.tsx +22 -0
  220. tools/bolt.diy/app/components/ui/Label.tsx +20 -0
  221. tools/bolt.diy/app/components/ui/LoadingDots.tsx +27 -0
  222. tools/bolt.diy/app/components/ui/LoadingOverlay.tsx +32 -0
  223. tools/bolt.diy/app/components/ui/PanelHeader.tsx +20 -0
  224. tools/bolt.diy/app/components/ui/PanelHeaderButton.tsx +36 -0
  225. tools/bolt.diy/app/components/ui/Popover.tsx +29 -0
  226. tools/bolt.diy/app/components/ui/Progress.tsx +22 -0
  227. tools/bolt.diy/app/components/ui/RepositoryStats.tsx +87 -0
  228. tools/bolt.diy/app/components/ui/ScrollArea.tsx +41 -0
  229. tools/bolt.diy/app/components/ui/SearchInput.tsx +80 -0
  230. tools/bolt.diy/app/components/ui/SearchResultItem.tsx +134 -0
  231. tools/bolt.diy/app/components/ui/Separator.tsx +22 -0
  232. tools/bolt.diy/app/components/ui/SettingsButton.tsx +35 -0
  233. tools/bolt.diy/app/components/ui/Slider.tsx +73 -0
  234. tools/bolt.diy/app/components/ui/StatusIndicator.tsx +90 -0
  235. tools/bolt.diy/app/components/ui/Switch.tsx +37 -0
  236. tools/bolt.diy/app/components/ui/Tabs.tsx +52 -0
  237. tools/bolt.diy/app/components/ui/TabsWithSlider.tsx +112 -0
  238. tools/bolt.diy/app/components/ui/ThemeSwitch.tsx +29 -0
  239. tools/bolt.diy/app/components/ui/Tooltip.tsx +122 -0
  240. tools/bolt.diy/app/components/ui/index.ts +38 -0
  241. tools/bolt.diy/app/components/ui/use-toast.ts +66 -0
  242. tools/bolt.diy/app/components/workbench/DiffView.tsx +796 -0
  243. tools/bolt.diy/app/components/workbench/EditorPanel.tsx +174 -0
  244. tools/bolt.diy/app/components/workbench/ExpoQrModal.tsx +55 -0
  245. tools/bolt.diy/app/components/workbench/FileBreadcrumb.tsx +150 -0
  246. tools/bolt.diy/app/components/workbench/FileTree.tsx +565 -0
  247. tools/bolt.diy/app/components/workbench/Inspector.tsx +126 -0
  248. tools/bolt.diy/app/components/workbench/InspectorPanel.tsx +146 -0
  249. tools/bolt.diy/app/components/workbench/LockManager.tsx +262 -0
  250. tools/bolt.diy/app/components/workbench/PortDropdown.tsx +91 -0
  251. tools/bolt.diy/app/components/workbench/Preview.tsx +1049 -0
  252. tools/bolt.diy/app/components/workbench/ScreenshotSelector.tsx +293 -0
  253. tools/bolt.diy/app/components/workbench/Search.tsx +257 -0
  254. tools/bolt.diy/app/components/workbench/Workbench.client.tsx +506 -0
  255. tools/bolt.diy/app/components/workbench/terminal/Terminal.tsx +131 -0
  256. tools/bolt.diy/app/components/workbench/terminal/TerminalManager.tsx +68 -0
  257. tools/bolt.diy/app/components/workbench/terminal/TerminalTabs.tsx +277 -0
  258. tools/bolt.diy/app/components/workbench/terminal/theme.ts +36 -0
  259. tools/bolt.diy/app/components/workflow/WorkflowPhase.tsx +109 -0
  260. tools/bolt.diy/app/components/workflow/WorkflowStatus.tsx +60 -0
  261. tools/bolt.diy/app/components/workflow/WorkflowTimeline.tsx +150 -0
  262. tools/bolt.diy/app/entry.client.tsx +7 -0
  263. tools/bolt.diy/app/entry.server.tsx +80 -0
  264. tools/bolt.diy/app/root.tsx +156 -0
  265. tools/bolt.diy/app/routes/_index.tsx +175 -0
  266. tools/bolt.diy/app/routes/api.bug-report.ts +254 -0
  267. tools/bolt.diy/app/routes/api.chat.ts +463 -0
  268. tools/bolt.diy/app/routes/api.check-env-key.ts +41 -0
  269. tools/bolt.diy/app/routes/api.configured-providers.ts +110 -0
  270. tools/bolt.diy/app/routes/api.corporate-swarm-status.ts +55 -0
  271. tools/bolt.diy/app/routes/api.enhancer.ts +137 -0
  272. tools/bolt.diy/app/routes/api.export-api-keys.ts +44 -0
  273. tools/bolt.diy/app/routes/api.git-info.ts +69 -0
  274. tools/bolt.diy/app/routes/api.git-proxy.$.ts +178 -0
  275. tools/bolt.diy/app/routes/api.github-branches.ts +166 -0
  276. tools/bolt.diy/app/routes/api.github-deploy.ts +67 -0
  277. tools/bolt.diy/app/routes/api.github-stats.ts +198 -0
  278. tools/bolt.diy/app/routes/api.github-template.ts +242 -0
  279. tools/bolt.diy/app/routes/api.github-user.ts +287 -0
  280. tools/bolt.diy/app/routes/api.gitlab-branches.ts +143 -0
  281. tools/bolt.diy/app/routes/api.gitlab-deploy.ts +67 -0
  282. tools/bolt.diy/app/routes/api.gitlab-projects.ts +105 -0
  283. tools/bolt.diy/app/routes/api.health.ts +8 -0
  284. tools/bolt.diy/app/routes/api.llmcall.ts +298 -0
  285. tools/bolt.diy/app/routes/api.mandate.ts +351 -0
  286. tools/bolt.diy/app/routes/api.mcp-check.ts +16 -0
  287. tools/bolt.diy/app/routes/api.mcp-update-config.ts +23 -0
  288. tools/bolt.diy/app/routes/api.models.$provider.ts +2 -0
  289. tools/bolt.diy/app/routes/api.models.ts +90 -0
  290. tools/bolt.diy/app/routes/api.netlify-deploy.ts +240 -0
  291. tools/bolt.diy/app/routes/api.netlify-user.ts +142 -0
  292. tools/bolt.diy/app/routes/api.supabase-user.ts +199 -0
  293. tools/bolt.diy/app/routes/api.supabase.query.ts +92 -0
  294. tools/bolt.diy/app/routes/api.supabase.ts +56 -0
  295. tools/bolt.diy/app/routes/api.supabase.variables.ts +32 -0
  296. tools/bolt.diy/app/routes/api.system.diagnostics.ts +142 -0
  297. tools/bolt.diy/app/routes/api.system.disk-info.ts +311 -0
  298. tools/bolt.diy/app/routes/api.system.git-info.ts +332 -0
  299. tools/bolt.diy/app/routes/api.update.ts +21 -0
  300. tools/bolt.diy/app/routes/api.vercel-deploy.ts +497 -0
  301. tools/bolt.diy/app/routes/api.vercel-user.ts +161 -0
  302. tools/bolt.diy/app/routes/api.workflow-status.$proposalId.ts +309 -0
  303. tools/bolt.diy/app/routes/chat.$id.tsx +8 -0
  304. tools/bolt.diy/app/routes/execute.$mandateId.tsx +432 -0
  305. tools/bolt.diy/app/routes/git.tsx +25 -0
  306. tools/bolt.diy/app/routes/observability.$mandateId.tsx +50 -0
  307. tools/bolt.diy/app/routes/webcontainer.connect.$id.tsx +32 -0
  308. tools/bolt.diy/app/routes/webcontainer.preview.$id.tsx +97 -0
  309. tools/bolt.diy/app/routes/workflow.$proposalId.tsx +170 -0
  310. tools/bolt.diy/app/styles/animations.scss +49 -0
  311. tools/bolt.diy/app/styles/components/code.scss +9 -0
  312. tools/bolt.diy/app/styles/components/editor.scss +135 -0
  313. tools/bolt.diy/app/styles/components/resize-handle.scss +30 -0
  314. tools/bolt.diy/app/styles/components/terminal.scss +3 -0
  315. tools/bolt.diy/app/styles/components/toast.scss +23 -0
  316. tools/bolt.diy/app/styles/diff-view.css +72 -0
  317. tools/bolt.diy/app/styles/index.scss +73 -0
  318. tools/bolt.diy/app/styles/variables.scss +255 -0
  319. tools/bolt.diy/app/styles/z-index.scss +37 -0
  320. tools/bolt.diy/app/types/GitHub.ts +182 -0
  321. tools/bolt.diy/app/types/GitLab.ts +103 -0
  322. tools/bolt.diy/app/types/actions.ts +85 -0
  323. tools/bolt.diy/app/types/artifact.ts +5 -0
  324. tools/bolt.diy/app/types/context.ts +26 -0
  325. tools/bolt.diy/app/types/design-scheme.ts +93 -0
  326. tools/bolt.diy/app/types/global.d.ts +13 -0
  327. tools/bolt.diy/app/types/mandate.ts +333 -0
  328. tools/bolt.diy/app/types/model.ts +25 -0
  329. tools/bolt.diy/app/types/netlify.ts +94 -0
  330. tools/bolt.diy/app/types/supabase.ts +54 -0
  331. tools/bolt.diy/app/types/template.ts +8 -0
  332. tools/bolt.diy/app/types/terminal.ts +9 -0
  333. tools/bolt.diy/app/types/theme.ts +1 -0
  334. tools/bolt.diy/app/types/vercel.ts +67 -0
  335. tools/bolt.diy/app/utils/buffer.ts +29 -0
  336. tools/bolt.diy/app/utils/classNames.ts +65 -0
  337. tools/bolt.diy/app/utils/constants.ts +147 -0
  338. tools/bolt.diy/app/utils/debounce.ts +13 -0
  339. tools/bolt.diy/app/utils/debugLogger.ts +1284 -0
  340. tools/bolt.diy/app/utils/diff.spec.ts +11 -0
  341. tools/bolt.diy/app/utils/diff.ts +117 -0
  342. tools/bolt.diy/app/utils/easings.ts +3 -0
  343. tools/bolt.diy/app/utils/fileLocks.ts +96 -0
  344. tools/bolt.diy/app/utils/fileUtils.ts +121 -0
  345. tools/bolt.diy/app/utils/folderImport.ts +73 -0
  346. tools/bolt.diy/app/utils/formatSize.ts +12 -0
  347. tools/bolt.diy/app/utils/getLanguageFromExtension.ts +24 -0
  348. tools/bolt.diy/app/utils/githubStats.ts +9 -0
  349. tools/bolt.diy/app/utils/gitlabStats.ts +54 -0
  350. tools/bolt.diy/app/utils/logger.ts +162 -0
  351. tools/bolt.diy/app/utils/markdown.ts +155 -0
  352. tools/bolt.diy/app/utils/mobile.ts +4 -0
  353. tools/bolt.diy/app/utils/os.ts +4 -0
  354. tools/bolt.diy/app/utils/path.ts +19 -0
  355. tools/bolt.diy/app/utils/projectCommands.ts +197 -0
  356. tools/bolt.diy/app/utils/promises.ts +19 -0
  357. tools/bolt.diy/app/utils/react.ts +6 -0
  358. tools/bolt.diy/app/utils/sampler.ts +49 -0
  359. tools/bolt.diy/app/utils/selectStarterTemplate.ts +255 -0
  360. tools/bolt.diy/app/utils/shell.ts +384 -0
  361. tools/bolt.diy/app/utils/stacktrace.ts +27 -0
  362. tools/bolt.diy/app/utils/stripIndent.ts +23 -0
  363. tools/bolt.diy/app/utils/terminal.ts +11 -0
  364. tools/bolt.diy/app/utils/unreachable.ts +3 -0
  365. tools/bolt.diy/app/vite-env.d.ts +2 -0
  366. tools/bolt.diy/assets/entitlements.mac.plist +25 -0
  367. tools/bolt.diy/assets/icons/icon.icns +0 -0
  368. tools/bolt.diy/assets/icons/icon.ico +0 -0
  369. tools/bolt.diy/assets/icons/icon.png +0 -0
  370. tools/bolt.diy/bindings.js +78 -0
  371. tools/bolt.diy/bindings.sh +33 -0
  372. tools/bolt.diy/docker-compose.yaml +145 -0
  373. tools/bolt.diy/electron/main/index.ts +201 -0
  374. tools/bolt.diy/electron/main/tsconfig.json +30 -0
  375. tools/bolt.diy/electron/main/ui/menu.ts +29 -0
  376. tools/bolt.diy/electron/main/ui/window.ts +54 -0
  377. tools/bolt.diy/electron/main/utils/auto-update.ts +110 -0
  378. tools/bolt.diy/electron/main/utils/constants.ts +4 -0
  379. tools/bolt.diy/electron/main/utils/cookie.ts +40 -0
  380. tools/bolt.diy/electron/main/utils/reload.ts +35 -0
  381. tools/bolt.diy/electron/main/utils/serve.ts +71 -0
  382. tools/bolt.diy/electron/main/utils/store.ts +3 -0
  383. tools/bolt.diy/electron/main/utils/vite-server.ts +44 -0
  384. tools/bolt.diy/electron/main/vite.config.ts +44 -0
  385. tools/bolt.diy/electron/preload/index.ts +22 -0
  386. tools/bolt.diy/electron/preload/tsconfig.json +7 -0
  387. tools/bolt.diy/electron/preload/vite.config.ts +31 -0
  388. tools/bolt.diy/electron-builder.yml +64 -0
  389. tools/bolt.diy/electron-update.yml +4 -0
  390. tools/bolt.diy/eslint.config.mjs +57 -0
  391. tools/bolt.diy/functions/[[path]].ts +12 -0
  392. tools/bolt.diy/icons/angular.svg +1 -0
  393. tools/bolt.diy/icons/astro.svg +8 -0
  394. tools/bolt.diy/icons/chat.svg +1 -0
  395. tools/bolt.diy/icons/expo-brand.svg +1 -0
  396. tools/bolt.diy/icons/expo.svg +4 -0
  397. tools/bolt.diy/icons/logo-text.svg +1 -0
  398. tools/bolt.diy/icons/logo.svg +4 -0
  399. tools/bolt.diy/icons/mcp.svg +1 -0
  400. tools/bolt.diy/icons/nativescript.svg +1 -0
  401. tools/bolt.diy/icons/netlify.svg +10 -0
  402. tools/bolt.diy/icons/nextjs.svg +1 -0
  403. tools/bolt.diy/icons/nuxt.svg +1 -0
  404. tools/bolt.diy/icons/qwik.svg +1 -0
  405. tools/bolt.diy/icons/react.svg +1 -0
  406. tools/bolt.diy/icons/remix.svg +24 -0
  407. tools/bolt.diy/icons/remotion.svg +1 -0
  408. tools/bolt.diy/icons/shadcn.svg +21 -0
  409. tools/bolt.diy/icons/slidev.svg +60 -0
  410. tools/bolt.diy/icons/solidjs.svg +1 -0
  411. tools/bolt.diy/icons/stars.svg +1 -0
  412. tools/bolt.diy/icons/svelte.svg +1 -0
  413. tools/bolt.diy/icons/typescript.svg +1 -0
  414. tools/bolt.diy/icons/vite.svg +1 -0
  415. tools/bolt.diy/icons/vue.svg +1 -0
  416. tools/bolt.diy/load-context.ts +9 -0
  417. tools/bolt.diy/notarize.cjs +31 -0
  418. tools/bolt.diy/package.json +218 -0
  419. tools/bolt.diy/playwright.config.preview.ts +35 -0
  420. tools/bolt.diy/pre-start.cjs +26 -0
  421. tools/bolt.diy/public/apple-touch-icon-precomposed.png +0 -0
  422. tools/bolt.diy/public/apple-touch-icon.png +0 -0
  423. tools/bolt.diy/public/favicon.ico +0 -0
  424. tools/bolt.diy/public/favicon.svg +4 -0
  425. tools/bolt.diy/public/icons/AmazonBedrock.svg +1 -0
  426. tools/bolt.diy/public/icons/Anthropic.svg +4 -0
  427. tools/bolt.diy/public/icons/Cohere.svg +4 -0
  428. tools/bolt.diy/public/icons/Deepseek.svg +5 -0
  429. tools/bolt.diy/public/icons/Default.svg +4 -0
  430. tools/bolt.diy/public/icons/Google.svg +4 -0
  431. tools/bolt.diy/public/icons/Groq.svg +4 -0
  432. tools/bolt.diy/public/icons/HuggingFace.svg +4 -0
  433. tools/bolt.diy/public/icons/Hyperbolic.svg +3 -0
  434. tools/bolt.diy/public/icons/LMStudio.svg +5 -0
  435. tools/bolt.diy/public/icons/Mistral.svg +4 -0
  436. tools/bolt.diy/public/icons/Ollama.svg +4 -0
  437. tools/bolt.diy/public/icons/OpenAI.svg +4 -0
  438. tools/bolt.diy/public/icons/OpenAILike.svg +4 -0
  439. tools/bolt.diy/public/icons/OpenRouter.svg +4 -0
  440. tools/bolt.diy/public/icons/Perplexity.svg +4 -0
  441. tools/bolt.diy/public/icons/Together.svg +4 -0
  442. tools/bolt.diy/public/icons/xAI.svg +5 -0
  443. tools/bolt.diy/public/inspector-script.js +292 -0
  444. tools/bolt.diy/public/logo-dark-styled.png +0 -0
  445. tools/bolt.diy/public/logo-dark.png +0 -0
  446. tools/bolt.diy/public/logo-light-styled.png +0 -0
  447. tools/bolt.diy/public/logo-light.png +0 -0
  448. tools/bolt.diy/public/logo.svg +15 -0
  449. tools/bolt.diy/public/social_preview_index.jpg +0 -0
  450. tools/bolt.diy/scripts/clean.js +45 -0
  451. tools/bolt.diy/scripts/electron-dev.mjs +181 -0
  452. tools/bolt.diy/scripts/setup-env.sh +41 -0
  453. tools/bolt.diy/scripts/update-imports.sh +7 -0
  454. tools/bolt.diy/scripts/update.sh +52 -0
  455. tools/bolt.diy/services/execution-governor/Dockerfile +41 -0
  456. tools/bolt.diy/services/execution-governor/config.ts +42 -0
  457. tools/bolt.diy/services/execution-governor/index.ts +683 -0
  458. tools/bolt.diy/services/execution-governor/metrics.ts +141 -0
  459. tools/bolt.diy/services/execution-governor/package.json +31 -0
  460. tools/bolt.diy/services/execution-governor/priority-queue.ts +139 -0
  461. tools/bolt.diy/services/execution-governor/tsconfig.json +21 -0
  462. tools/bolt.diy/services/execution-governor/types.ts +145 -0
  463. tools/bolt.diy/services/headless-executor/Dockerfile +43 -0
  464. tools/bolt.diy/services/headless-executor/executor.ts +210 -0
  465. tools/bolt.diy/services/headless-executor/index.ts +323 -0
  466. tools/bolt.diy/services/headless-executor/package.json +27 -0
  467. tools/bolt.diy/services/headless-executor/tsconfig.json +21 -0
  468. tools/bolt.diy/services/headless-executor/types.ts +38 -0
  469. tools/bolt.diy/test-workflows.sh +240 -0
  470. tools/bolt.diy/tests/integration/corporate-swarm.test.ts +208 -0
  471. tools/bolt.diy/tests/mandates/budget-limited.json +34 -0
  472. tools/bolt.diy/tests/mandates/complex.json +53 -0
  473. tools/bolt.diy/tests/mandates/constraint-enforced.json +36 -0
  474. tools/bolt.diy/tests/mandates/simple.json +35 -0
  475. tools/bolt.diy/tsconfig.json +37 -0
  476. tools/bolt.diy/types/istextorbinary.d.ts +15 -0
  477. tools/bolt.diy/uno.config.ts +279 -0
  478. tools/bolt.diy/vite-electron.config.ts +76 -0
  479. tools/bolt.diy/vite.config.ts +112 -0
  480. tools/bolt.diy/worker-configuration.d.ts +22 -0
  481. tools/bolt.diy/wrangler.toml +6 -0
  482. tools/code_generator.py +461 -0
  483. tools/file_operations.py +465 -0
  484. tools/mandate_generator.py +337 -0
  485. tools/mcpClientUtils.py +1216 -0
  486. tools/sensors.py +285 -0
  487. utils/Agent_types.py +15 -0
  488. utils/AnyToStr.py +0 -0
  489. utils/HHCS.py +277 -0
  490. utils/__init__.py +30 -0
  491. utils/agent.py +3627 -0
  492. utils/aop.py +2948 -0
  493. utils/canonical.py +143 -0
  494. utils/conversation.py +1195 -0
  495. utils/doctrine_versioning +230 -0
  496. utils/formatter.py +474 -0
  497. utils/ledger.py +311 -0
  498. utils/out_types.py +16 -0
  499. utils/rollback.py +339 -0
  500. utils/router.py +929 -0
  501. utils/tui.py +1908 -0
@@ -0,0 +1,246 @@
1
+ .rayContainer {
2
+ // Theme-specific colors
3
+ --ray-color-primary: color-mix(in srgb, var(--primary-color), transparent 30%);
4
+ --ray-color-secondary: color-mix(in srgb, var(--secondary-color), transparent 30%);
5
+ --ray-color-accent: color-mix(in srgb, var(--accent-color), transparent 30%);
6
+
7
+ // Theme-specific gradients
8
+ --ray-gradient-primary: radial-gradient(var(--ray-color-primary) 0%, transparent 70%);
9
+ --ray-gradient-secondary: radial-gradient(var(--ray-color-secondary) 0%, transparent 70%);
10
+ --ray-gradient-accent: radial-gradient(var(--ray-color-accent) 0%, transparent 70%);
11
+
12
+ position: fixed;
13
+ inset: 0;
14
+ overflow: hidden;
15
+ animation: fadeIn 1.5s ease-out;
16
+ pointer-events: none;
17
+ z-index: 0;
18
+ // background-color: transparent;
19
+
20
+ :global(html[data-theme='dark']) & {
21
+ mix-blend-mode: screen;
22
+ }
23
+
24
+ :global(html[data-theme='light']) & {
25
+ mix-blend-mode: multiply;
26
+ }
27
+ }
28
+
29
+ .lightRay {
30
+ position: absolute;
31
+ border-radius: 100%;
32
+
33
+ :global(html[data-theme='dark']) & {
34
+ mix-blend-mode: screen;
35
+ }
36
+
37
+ :global(html[data-theme='light']) & {
38
+ mix-blend-mode: multiply;
39
+ opacity: 0.4;
40
+ }
41
+ }
42
+
43
+ .ray1 {
44
+ width: 600px;
45
+ height: 800px;
46
+ background: var(--ray-gradient-primary);
47
+ transform: rotate(65deg);
48
+ top: -500px;
49
+ left: -100px;
50
+ filter: blur(80px);
51
+ opacity: 0.6;
52
+ animation: float1 15s infinite ease-in-out;
53
+ }
54
+
55
+ .ray2 {
56
+ width: 400px;
57
+ height: 600px;
58
+ background: var(--ray-gradient-secondary);
59
+ transform: rotate(-30deg);
60
+ top: -300px;
61
+ left: 200px;
62
+ filter: blur(60px);
63
+ opacity: 0.6;
64
+ animation: float2 18s infinite ease-in-out;
65
+ }
66
+
67
+ .ray3 {
68
+ width: 500px;
69
+ height: 400px;
70
+ background: var(--ray-gradient-accent);
71
+ top: -320px;
72
+ left: 500px;
73
+ filter: blur(65px);
74
+ opacity: 0.5;
75
+ animation: float3 20s infinite ease-in-out;
76
+ }
77
+
78
+ .ray4 {
79
+ width: 400px;
80
+ height: 450px;
81
+ background: var(--ray-gradient-secondary);
82
+ top: -350px;
83
+ left: 800px;
84
+ filter: blur(55px);
85
+ opacity: 0.55;
86
+ animation: float4 17s infinite ease-in-out;
87
+ }
88
+
89
+ .ray5 {
90
+ width: 350px;
91
+ height: 500px;
92
+ background: var(--ray-gradient-primary);
93
+ transform: rotate(-45deg);
94
+ top: -250px;
95
+ left: 1000px;
96
+ filter: blur(45px);
97
+ opacity: 0.6;
98
+ animation: float5 16s infinite ease-in-out;
99
+ }
100
+
101
+ .ray6 {
102
+ width: 300px;
103
+ height: 700px;
104
+ background: var(--ray-gradient-accent);
105
+ transform: rotate(75deg);
106
+ top: -400px;
107
+ left: 600px;
108
+ filter: blur(75px);
109
+ opacity: 0.45;
110
+ animation: float6 19s infinite ease-in-out;
111
+ }
112
+
113
+ .ray7 {
114
+ width: 450px;
115
+ height: 600px;
116
+ background: var(--ray-gradient-primary);
117
+ transform: rotate(45deg);
118
+ top: -450px;
119
+ left: 350px;
120
+ filter: blur(65px);
121
+ opacity: 0.55;
122
+ animation: float7 21s infinite ease-in-out;
123
+ }
124
+
125
+ .ray8 {
126
+ width: 380px;
127
+ height: 550px;
128
+ background: var(--ray-gradient-secondary);
129
+ transform: rotate(-60deg);
130
+ top: -380px;
131
+ left: 750px;
132
+ filter: blur(58px);
133
+ opacity: 0.6;
134
+ animation: float8 14s infinite ease-in-out;
135
+ }
136
+
137
+ @keyframes float1 {
138
+ 0%,
139
+ 100% {
140
+ transform: rotate(65deg) translate(0, 0);
141
+ }
142
+ 25% {
143
+ transform: rotate(70deg) translate(30px, 20px);
144
+ }
145
+ 50% {
146
+ transform: rotate(60deg) translate(-20px, 40px);
147
+ }
148
+ 75% {
149
+ transform: rotate(68deg) translate(-40px, 10px);
150
+ }
151
+ }
152
+
153
+ @keyframes float2 {
154
+ 0%,
155
+ 100% {
156
+ transform: rotate(-30deg) scale(1);
157
+ }
158
+ 33% {
159
+ transform: rotate(-25deg) scale(1.1);
160
+ }
161
+ 66% {
162
+ transform: rotate(-35deg) scale(0.95);
163
+ }
164
+ }
165
+
166
+ @keyframes float3 {
167
+ 0%,
168
+ 100% {
169
+ transform: translate(0, 0) rotate(0deg);
170
+ }
171
+ 25% {
172
+ transform: translate(40px, 20px) rotate(5deg);
173
+ }
174
+ 75% {
175
+ transform: translate(-30px, 40px) rotate(-5deg);
176
+ }
177
+ }
178
+
179
+ @keyframes float4 {
180
+ 0%,
181
+ 100% {
182
+ transform: scale(1) rotate(0deg);
183
+ }
184
+ 50% {
185
+ transform: scale(1.15) rotate(10deg);
186
+ }
187
+ }
188
+
189
+ @keyframes float5 {
190
+ 0%,
191
+ 100% {
192
+ transform: rotate(-45deg) translate(0, 0);
193
+ }
194
+ 33% {
195
+ transform: rotate(-40deg) translate(25px, -20px);
196
+ }
197
+ 66% {
198
+ transform: rotate(-50deg) translate(-25px, 20px);
199
+ }
200
+ }
201
+
202
+ @keyframes float6 {
203
+ 0%,
204
+ 100% {
205
+ transform: rotate(75deg) scale(1);
206
+ filter: blur(75px);
207
+ }
208
+ 50% {
209
+ transform: rotate(85deg) scale(1.1);
210
+ filter: blur(65px);
211
+ }
212
+ }
213
+
214
+ @keyframes float7 {
215
+ 0%,
216
+ 100% {
217
+ transform: rotate(45deg) translate(0, 0);
218
+ opacity: 0.55;
219
+ }
220
+ 50% {
221
+ transform: rotate(40deg) translate(-30px, 30px);
222
+ opacity: 0.65;
223
+ }
224
+ }
225
+
226
+ @keyframes float8 {
227
+ 0%,
228
+ 100% {
229
+ transform: rotate(-60deg) scale(1);
230
+ }
231
+ 25% {
232
+ transform: rotate(-55deg) scale(1.05);
233
+ }
234
+ 75% {
235
+ transform: rotate(-65deg) scale(0.95);
236
+ }
237
+ }
238
+
239
+ @keyframes fadeIn {
240
+ from {
241
+ opacity: 0;
242
+ }
243
+ to {
244
+ opacity: 1;
245
+ }
246
+ }
@@ -0,0 +1,53 @@
1
+ 'use client';
2
+
3
+ import * as React from 'react';
4
+ import { cva, type VariantProps } from 'class-variance-authority';
5
+ import { classNames } from '~/utils/classNames';
6
+
7
+ const badgeVariants = cva(
8
+ 'inline-flex items-center gap-1 transition-colors focus:outline-none focus:ring-2 focus:ring-bolt-elements-ring focus:ring-offset-2',
9
+ {
10
+ variants: {
11
+ variant: {
12
+ default:
13
+ 'border-transparent bg-bolt-elements-background text-bolt-elements-textPrimary hover:bg-bolt-elements-background/80',
14
+ secondary:
15
+ 'border-transparent bg-bolt-elements-background text-bolt-elements-textSecondary hover:bg-bolt-elements-background/80',
16
+ destructive: 'border-transparent bg-red-500/10 text-red-500 hover:bg-red-500/20',
17
+ outline: 'text-bolt-elements-textPrimary',
18
+ primary: 'bg-purple-500/10 text-purple-600 dark:text-purple-400',
19
+ success: 'bg-green-500/10 text-green-600 dark:text-green-400',
20
+ warning: 'bg-yellow-500/10 text-yellow-600 dark:text-yellow-400',
21
+ danger: 'bg-red-500/10 text-red-600 dark:text-red-400',
22
+ info: 'bg-blue-500/10 text-blue-600 dark:text-blue-400',
23
+ subtle:
24
+ 'border border-bolt-elements-borderColor/30 dark:border-bolt-elements-borderColor-dark/30 bg-white/50 dark:bg-bolt-elements-background-depth-4/50 backdrop-blur-sm text-bolt-elements-textSecondary dark:text-bolt-elements-textSecondary-dark',
25
+ },
26
+ size: {
27
+ default: 'rounded-full px-2.5 py-0.5 text-xs font-semibold',
28
+ sm: 'rounded-full px-1.5 py-0.5 text-xs',
29
+ md: 'rounded-md px-2 py-1 text-xs font-medium',
30
+ lg: 'rounded-md px-2.5 py-1.5 text-sm',
31
+ },
32
+ },
33
+ defaultVariants: {
34
+ variant: 'default',
35
+ size: 'default',
36
+ },
37
+ },
38
+ );
39
+
40
+ export interface BadgeProps extends React.HTMLAttributes<HTMLDivElement>, VariantProps<typeof badgeVariants> {
41
+ icon?: string;
42
+ }
43
+
44
+ function Badge({ className, variant, size, icon, children, ...props }: BadgeProps) {
45
+ return (
46
+ <div className={classNames(badgeVariants({ variant, size }), className)} {...props}>
47
+ {icon && <span className={icon} />}
48
+ {children}
49
+ </div>
50
+ );
51
+ }
52
+
53
+ export { Badge, badgeVariants };
@@ -0,0 +1,270 @@
1
+ import React, { useState, useEffect } from 'react';
2
+ import { motion, AnimatePresence } from 'framer-motion';
3
+ import { Button } from './Button';
4
+ import { classNames } from '~/utils/classNames';
5
+ import { GitBranch, Check, Shield, Star, RefreshCw, X } from 'lucide-react';
6
+
7
+ interface BranchInfo {
8
+ name: string;
9
+ sha: string;
10
+ protected: boolean;
11
+ isDefault: boolean;
12
+ canPush?: boolean; // GitLab specific
13
+ }
14
+
15
+ interface BranchSelectorProps {
16
+ provider: 'github' | 'gitlab';
17
+ repoOwner: string;
18
+ repoName: string;
19
+ projectId?: string | number; // GitLab specific
20
+ token: string;
21
+ gitlabUrl?: string;
22
+ defaultBranch?: string;
23
+ onBranchSelect: (branch: string) => void;
24
+ onClose: () => void;
25
+ isOpen: boolean;
26
+ className?: string;
27
+ }
28
+
29
+ export function BranchSelector({
30
+ provider,
31
+ repoOwner,
32
+ repoName,
33
+ projectId,
34
+ token,
35
+ gitlabUrl,
36
+ defaultBranch,
37
+ onBranchSelect,
38
+ onClose,
39
+ isOpen,
40
+ className,
41
+ }: BranchSelectorProps) {
42
+ const [branches, setBranches] = useState<BranchInfo[]>([]);
43
+ const [isLoading, setIsLoading] = useState(false);
44
+ const [error, setError] = useState<string | null>(null);
45
+ const [searchQuery, setSearchQuery] = useState('');
46
+ const [selectedBranch, setSelectedBranch] = useState<string>('');
47
+
48
+ const filteredBranches = branches.filter((branch) => branch.name.toLowerCase().includes(searchQuery.toLowerCase()));
49
+
50
+ const fetchBranches = async () => {
51
+ setIsLoading(true);
52
+ setError(null);
53
+
54
+ try {
55
+ let response: Response;
56
+
57
+ if (provider === 'github') {
58
+ response = await fetch('/api/github-branches', {
59
+ method: 'POST',
60
+ headers: { 'Content-Type': 'application/json' },
61
+ body: JSON.stringify({
62
+ owner: repoOwner,
63
+ repo: repoName,
64
+ token,
65
+ }),
66
+ });
67
+ } else {
68
+ // GitLab
69
+ if (!projectId) {
70
+ throw new Error('Project ID is required for GitLab repositories');
71
+ }
72
+
73
+ response = await fetch('/api/gitlab-branches', {
74
+ method: 'POST',
75
+ headers: { 'Content-Type': 'application/json' },
76
+ body: JSON.stringify({
77
+ token,
78
+ gitlabUrl: gitlabUrl || 'https://gitlab.com',
79
+ projectId,
80
+ }),
81
+ });
82
+ }
83
+
84
+ if (!response.ok) {
85
+ const errorData: any = await response.json().catch(() => ({ error: 'Failed to fetch branches' }));
86
+ throw new Error(errorData.error || `HTTP ${response.status}`);
87
+ }
88
+
89
+ const data: any = await response.json();
90
+ setBranches(data.branches || []);
91
+
92
+ // Set default selected branch
93
+ const defaultBranchToSelect = data.defaultBranch || defaultBranch || 'main';
94
+ setSelectedBranch(defaultBranchToSelect);
95
+ } catch (err) {
96
+ console.error('Failed to fetch branches:', err);
97
+ setError(err instanceof Error ? err.message : 'Failed to fetch branches');
98
+ setBranches([]);
99
+ } finally {
100
+ setIsLoading(false);
101
+ }
102
+ };
103
+
104
+ const handleBranchSelect = (branchName: string) => {
105
+ setSelectedBranch(branchName);
106
+ };
107
+
108
+ const handleConfirmSelection = () => {
109
+ onBranchSelect(selectedBranch);
110
+ onClose();
111
+ };
112
+
113
+ useEffect(() => {
114
+ if (isOpen && !branches.length) {
115
+ fetchBranches();
116
+ }
117
+ }, [isOpen, repoOwner, repoName, projectId]);
118
+
119
+ // Reset search when closing
120
+ useEffect(() => {
121
+ if (!isOpen) {
122
+ setSearchQuery('');
123
+ }
124
+ }, [isOpen]);
125
+
126
+ if (!isOpen) {
127
+ return null;
128
+ }
129
+
130
+ return (
131
+ <AnimatePresence>
132
+ <div className="fixed inset-0 bg-black/50 backdrop-blur-sm z-50 flex items-center justify-center p-4">
133
+ <motion.div
134
+ initial={{ opacity: 0, scale: 0.95 }}
135
+ animate={{ opacity: 1, scale: 1 }}
136
+ exit={{ opacity: 0, scale: 0.95 }}
137
+ transition={{ duration: 0.2 }}
138
+ className={classNames(
139
+ 'bg-white dark:bg-gray-950 rounded-xl shadow-xl border border-bolt-elements-borderColor max-w-md w-full max-h-[80vh] flex flex-col',
140
+ className,
141
+ )}
142
+ >
143
+ {/* Header */}
144
+ <div className="p-6 border-b border-bolt-elements-borderColor flex items-center justify-between">
145
+ <div className="flex items-center gap-3">
146
+ <div className="w-10 h-10 rounded-lg bg-blue-500/10 flex items-center justify-center">
147
+ <GitBranch className="w-6 h-6 text-blue-600" />
148
+ </div>
149
+ <div>
150
+ <h3 className="text-lg font-semibold text-bolt-elements-textPrimary">Select Branch</h3>
151
+ <p className="text-sm text-bolt-elements-textSecondary">
152
+ {repoOwner}/{repoName}
153
+ </p>
154
+ </div>
155
+ </div>
156
+ <button
157
+ onClick={onClose}
158
+ className="p-2 rounded-lg hover:bg-bolt-elements-background-depth-1 text-bolt-elements-textSecondary hover:text-bolt-elements-textPrimary transition-all"
159
+ >
160
+ <X className="w-5 h-5" />
161
+ </button>
162
+ </div>
163
+
164
+ {/* Content */}
165
+ <div className="flex-1 overflow-hidden flex flex-col">
166
+ {isLoading ? (
167
+ <div className="flex flex-col items-center justify-center p-8 space-y-4">
168
+ <div className="animate-spin w-8 h-8 border-2 border-bolt-elements-borderColorActive border-t-transparent rounded-full" />
169
+ <p className="text-sm text-bolt-elements-textSecondary">Loading branches...</p>
170
+ </div>
171
+ ) : error ? (
172
+ <div className="flex flex-col items-center justify-center p-8 space-y-4">
173
+ <div className="text-red-500 mb-2">
174
+ <GitBranch className="w-8 h-8 mx-auto" />
175
+ </div>
176
+ <p className="text-sm text-red-600 text-center">{error}</p>
177
+ <Button onClick={fetchBranches} variant="outline" size="sm">
178
+ <RefreshCw className="w-4 h-4 mr-2" />
179
+ Retry
180
+ </Button>
181
+ </div>
182
+ ) : (
183
+ <>
184
+ {/* Search */}
185
+ {branches.length > 10 && (
186
+ <div className="p-4 border-b border-bolt-elements-borderColor">
187
+ <input
188
+ type="text"
189
+ placeholder="Search branches..."
190
+ value={searchQuery}
191
+ onChange={(e) => setSearchQuery(e.target.value)}
192
+ className="w-full px-3 py-2 rounded-lg bg-bolt-elements-background-depth-1 border border-bolt-elements-borderColor text-bolt-elements-textPrimary placeholder-bolt-elements-textTertiary focus:outline-none focus:ring-1 focus:ring-bolt-elements-borderColorActive"
193
+ />
194
+ </div>
195
+ )}
196
+
197
+ {/* Branch List */}
198
+ <div className="flex-1 overflow-y-auto">
199
+ {filteredBranches.length > 0 ? (
200
+ <div className="p-4 space-y-1">
201
+ {filteredBranches.map((branch) => (
202
+ <button
203
+ key={branch.name}
204
+ onClick={() => handleBranchSelect(branch.name)}
205
+ className={classNames(
206
+ 'w-full text-left p-3 rounded-lg transition-all duration-200 border',
207
+ selectedBranch === branch.name
208
+ ? 'bg-blue-50 border-blue-200 text-blue-900 dark:bg-blue-950 dark:border-blue-800 dark:text-blue-100'
209
+ : 'bg-bolt-elements-background-depth-1 border-transparent hover:bg-bolt-elements-background-depth-2',
210
+ )}
211
+ >
212
+ <div className="flex items-center justify-between">
213
+ <div className="flex items-center gap-2 min-w-0">
214
+ <GitBranch className="w-4 h-4 flex-shrink-0 text-bolt-elements-textSecondary" />
215
+ <span className="font-medium text-bolt-elements-textPrimary truncate">{branch.name}</span>
216
+ <div className="flex items-center gap-1 flex-shrink-0">
217
+ {branch.isDefault && <Star className="w-3 h-3 text-yellow-500" />}
218
+ {branch.protected && <Shield className="w-3 h-3 text-red-500" />}
219
+ </div>
220
+ </div>
221
+ {selectedBranch === branch.name && <Check className="w-4 h-4 text-blue-600" />}
222
+ </div>
223
+ <div className="text-xs text-bolt-elements-textSecondary mt-1 truncate">
224
+ {branch.sha.substring(0, 8)}
225
+ </div>
226
+ </button>
227
+ ))}
228
+ </div>
229
+ ) : (
230
+ <div className="flex items-center justify-center p-8">
231
+ <p className="text-sm text-bolt-elements-textSecondary">
232
+ {searchQuery ? 'No branches found matching your search.' : 'No branches available.'}
233
+ </p>
234
+ </div>
235
+ )}
236
+ </div>
237
+ </>
238
+ )}
239
+ </div>
240
+
241
+ {/* Footer */}
242
+ {!isLoading && !error && branches.length > 0 && (
243
+ <div className="p-6 border-t border-bolt-elements-borderColor flex items-center justify-between">
244
+ <div className="text-sm text-bolt-elements-textSecondary">
245
+ {selectedBranch && (
246
+ <>
247
+ Selected: <span className="font-medium">{selectedBranch}</span>
248
+ </>
249
+ )}
250
+ </div>
251
+ <div className="flex items-center gap-3">
252
+ <Button onClick={onClose} variant="outline" size="sm">
253
+ Cancel
254
+ </Button>
255
+ <Button
256
+ onClick={handleConfirmSelection}
257
+ disabled={!selectedBranch}
258
+ size="sm"
259
+ className="bg-blue-600 hover:bg-blue-700 text-white"
260
+ >
261
+ Clone Branch
262
+ </Button>
263
+ </div>
264
+ </div>
265
+ )}
266
+ </motion.div>
267
+ </div>
268
+ </AnimatePresence>
269
+ );
270
+ }
@@ -0,0 +1,101 @@
1
+ import React from 'react';
2
+ import { classNames } from '~/utils/classNames';
3
+ import { motion } from 'framer-motion';
4
+
5
+ interface BreadcrumbItem {
6
+ label: string;
7
+ href?: string;
8
+ icon?: string;
9
+ onClick?: () => void;
10
+ }
11
+
12
+ interface BreadcrumbsProps {
13
+ items: BreadcrumbItem[];
14
+ className?: string;
15
+ separator?: string;
16
+ maxItems?: number;
17
+ renderItem?: (item: BreadcrumbItem, index: number, isLast: boolean) => React.ReactNode;
18
+ }
19
+
20
+ export function Breadcrumbs({
21
+ items,
22
+ className,
23
+ separator = 'i-ph:caret-right',
24
+ maxItems = 0,
25
+ renderItem,
26
+ }: BreadcrumbsProps) {
27
+ const displayItems =
28
+ maxItems > 0 && items.length > maxItems
29
+ ? [
30
+ ...items.slice(0, 1),
31
+ { label: '...', onClick: undefined, href: undefined },
32
+ ...items.slice(-Math.max(1, maxItems - 2)),
33
+ ]
34
+ : items;
35
+
36
+ const defaultRenderItem = (item: BreadcrumbItem, index: number, isLast: boolean) => {
37
+ const content = (
38
+ <div className="flex items-center gap-1.5">
39
+ {item.icon && <span className={classNames(item.icon, 'w-3.5 h-3.5')} />}
40
+ <span
41
+ className={classNames(
42
+ isLast
43
+ ? 'font-medium text-bolt-elements-textPrimary dark:text-bolt-elements-textPrimary-dark'
44
+ : 'text-bolt-elements-textSecondary dark:text-bolt-elements-textSecondary-dark hover:text-bolt-elements-textPrimary dark:hover:text-bolt-elements-textPrimary-dark',
45
+ item.onClick || item.href ? 'cursor-pointer' : '',
46
+ )}
47
+ >
48
+ {item.label}
49
+ </span>
50
+ </div>
51
+ );
52
+
53
+ if (item.href && !isLast) {
54
+ return (
55
+ <motion.a href={item.href} className="hover:underline" whileHover={{ scale: 1.05 }} whileTap={{ scale: 0.95 }}>
56
+ {content}
57
+ </motion.a>
58
+ );
59
+ }
60
+
61
+ if (item.onClick && !isLast) {
62
+ return (
63
+ <motion.button
64
+ type="button"
65
+ onClick={item.onClick}
66
+ className="hover:underline"
67
+ whileHover={{ scale: 1.05 }}
68
+ whileTap={{ scale: 0.95 }}
69
+ >
70
+ {content}
71
+ </motion.button>
72
+ );
73
+ }
74
+
75
+ return content;
76
+ };
77
+
78
+ return (
79
+ <nav className={classNames('flex items-center', className)} aria-label="Breadcrumbs">
80
+ <ol className="flex items-center gap-1.5">
81
+ {displayItems.map((item, index) => {
82
+ const isLast = index === displayItems.length - 1;
83
+
84
+ return (
85
+ <li key={index} className="flex items-center">
86
+ {renderItem ? renderItem(item, index, isLast) : defaultRenderItem(item, index, isLast)}
87
+ {!isLast && (
88
+ <span
89
+ className={classNames(
90
+ separator,
91
+ 'w-3 h-3 mx-1 text-bolt-elements-textTertiary dark:text-bolt-elements-textTertiary-dark',
92
+ )}
93
+ />
94
+ )}
95
+ </li>
96
+ );
97
+ })}
98
+ </ol>
99
+ </nav>
100
+ );
101
+ }