spine-framework 0.1.61 → 1.0.0

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 (425) hide show
  1. package/LICENSE.md +223 -0
  2. package/README.md +327 -0
  3. package/package.json +107 -216
  4. package/src/cli/commands/init.ts +192 -0
  5. package/src/cli/commands/install.ts +25 -0
  6. package/src/cli/commands/list.ts +33 -0
  7. package/src/cli/commands/migrate.ts +24 -0
  8. package/src/cli/index.ts +46 -0
  9. package/src/components/AppLayout.tsx +21 -0
  10. package/src/components/AuthGuard.tsx +21 -0
  11. package/src/components/RoleGuard.tsx +23 -0
  12. package/src/components/index.ts +3 -0
  13. package/src/contexts/AppContext.tsx +122 -0
  14. package/src/contexts/AuthContext.tsx +87 -0
  15. package/src/contexts/SpineContext.tsx +46 -0
  16. package/src/contexts/index.ts +3 -0
  17. package/src/hooks/index.ts +4 -0
  18. package/src/hooks/useItems.ts +78 -0
  19. package/src/hooks/useThreads.ts +73 -0
  20. package/src/hooks/useWebSocket.ts +97 -0
  21. package/src/index.ts +22 -0
  22. package/src/types/index.ts +163 -0
  23. package/src/utils/api.ts +88 -0
  24. package/src/utils/client.ts +146 -0
  25. package/src/utils/config.ts +20 -0
  26. package/src/utils/index.ts +3 -0
  27. package/.framework/README.md +0 -129
  28. package/.framework/cli/bin.cjs +0 -14
  29. package/.framework/cli/commands/agents.ts +0 -153
  30. package/.framework/cli/commands/auth.ts +0 -94
  31. package/.framework/cli/commands/create-app.ts +0 -185
  32. package/.framework/cli/commands/dev.ts +0 -113
  33. package/.framework/cli/commands/doctor.ts +0 -442
  34. package/.framework/cli/commands/generate.ts +0 -332
  35. package/.framework/cli/commands/init.ts +0 -186
  36. package/.framework/cli/commands/install-app.ts +0 -565
  37. package/.framework/cli/commands/items.ts +0 -253
  38. package/.framework/cli/commands/migrate.ts +0 -139
  39. package/.framework/cli/commands/migrations.ts +0 -141
  40. package/.framework/cli/commands/pipelines.ts +0 -166
  41. package/.framework/cli/commands/status.ts +0 -197
  42. package/.framework/cli/commands/system.ts +0 -184
  43. package/.framework/cli/commands/test.ts +0 -227
  44. package/.framework/cli/commands/uninstall-app.ts +0 -166
  45. package/.framework/cli/context.ts +0 -268
  46. package/.framework/cli/env-loader.ts +0 -36
  47. package/.framework/cli/index.ts +0 -116
  48. package/.framework/cli/welcome.cjs +0 -45
  49. package/.framework/docs/API.md +0 -384
  50. package/.framework/docs/STABILITY.md +0 -52
  51. package/.framework/docs/admin-routes.md +0 -76
  52. package/.framework/docs/api-docs-progress.md +0 -38
  53. package/.framework/docs/api-governance.md +0 -146
  54. package/.framework/docs/api-testing-results.md +0 -212
  55. package/.framework/docs/apis/admin-configs.md +0 -567
  56. package/.framework/docs/apis/admin-data.md +0 -272
  57. package/.framework/docs/apis/index.md +0 -231
  58. package/.framework/docs/apis/internal.md +0 -295
  59. package/.framework/docs/apis/runtime.md +0 -537
  60. package/.framework/docs/assembly-launch-guide.md +0 -138
  61. package/.framework/docs/audit-results.md +0 -590
  62. package/.framework/docs/authorization-model.md +0 -170
  63. package/.framework/docs/db-api-inventory.md +0 -95
  64. package/.framework/docs/examples/custom-app/README.md +0 -77
  65. package/.framework/docs/examples/custom-function/README.md +0 -27
  66. package/.framework/docs/examples/custom-function/handler.ts +0 -48
  67. package/.framework/docs/examples/custom-webhook/README.md +0 -68
  68. package/.framework/docs/gap-remediation-backlog.md +0 -103
  69. package/.framework/docs/guides/cli-guide.md +0 -224
  70. package/.framework/docs/guides/getting-started.md +0 -103
  71. package/.framework/docs/guides/import-guide.md +0 -193
  72. package/.framework/docs/guides/testing-guide.md +0 -229
  73. package/.framework/docs/permission-examples.md +0 -326
  74. package/.framework/docs/ui-adoption-verification.md +0 -111
  75. package/.framework/docs/ui-api-coverage.md +0 -84
  76. package/.framework/docs/v2-compatibility-audit.md +0 -228
  77. package/.framework/functions/.gitkeep +0 -1
  78. package/.framework/functions/_shared/agent-runner.ts +0 -1097
  79. package/.framework/functions/_shared/app-manifest.ts +0 -184
  80. package/.framework/functions/_shared/audit.ts +0 -150
  81. package/.framework/functions/_shared/db.ts +0 -178
  82. package/.framework/functions/_shared/index.ts +0 -391
  83. package/.framework/functions/_shared/middleware.ts +0 -490
  84. package/.framework/functions/_shared/permissions.ts +0 -1325
  85. package/.framework/functions/_shared/pipeline-runner.ts +0 -731
  86. package/.framework/functions/_shared/principal.ts +0 -818
  87. package/.framework/functions/_shared/resolve-ids.ts +0 -106
  88. package/.framework/functions/_shared/schema-utils.ts +0 -967
  89. package/.framework/functions/_shared/testing.ts +0 -258
  90. package/.framework/functions/_shared/trigger-engine.ts +0 -425
  91. package/.framework/functions/_shared/webhook-registration.ts +0 -168
  92. package/.framework/functions/_shared/webhook-registry.ts +0 -129
  93. package/.framework/functions/account-nodes.ts +0 -111
  94. package/.framework/functions/admin-data.ts +0 -606
  95. package/.framework/functions/ai-agents.ts +0 -323
  96. package/.framework/functions/api-keys.ts +0 -376
  97. package/.framework/functions/apps.ts +0 -483
  98. package/.framework/functions/auth.ts +0 -196
  99. package/.framework/functions/debug-auth.ts +0 -107
  100. package/.framework/functions/embeddings.ts +0 -556
  101. package/.framework/functions/integration-routes.ts +0 -523
  102. package/.framework/functions/integrations.ts +0 -319
  103. package/.framework/functions/item-progress.ts +0 -272
  104. package/.framework/functions/logs.ts +0 -438
  105. package/.framework/functions/observability.ts +0 -275
  106. package/.framework/functions/pipeline-executions.ts +0 -494
  107. package/.framework/functions/pipelines.ts +0 -485
  108. package/.framework/functions/prompt-configs.ts +0 -339
  109. package/.framework/functions/roles.ts +0 -387
  110. package/.framework/functions/system-cron.ts +0 -742
  111. package/.framework/functions/system.ts +0 -323
  112. package/.framework/functions/tests.ts +0 -119
  113. package/.framework/functions/timers.ts +0 -357
  114. package/.framework/functions/triggers.ts +0 -563
  115. package/.framework/functions/types.ts +0 -604
  116. package/.framework/index.html +0 -16
  117. package/.framework/migrations/000_foundation.sql +0 -1266
  118. package/.framework/migrations/001_seed.sql +0 -163
  119. package/.framework/migrations/002_seed_constraints.sql +0 -19
  120. package/.framework/migrations/003_auth_user_trigger.sql +0 -67
  121. package/.framework/src/App.tsx +0 -126
  122. package/.framework/src/apps/admin/index.tsx +0 -173
  123. package/.framework/src/components/AppWrapper.tsx +0 -56
  124. package/.framework/src/components/CustomAppLoader.tsx +0 -116
  125. package/.framework/src/components/admin/AdminListPage.tsx +0 -151
  126. package/.framework/src/components/admin/AdminSidebar.tsx +0 -166
  127. package/.framework/src/components/admin/AdminStatsCard.tsx +0 -62
  128. package/.framework/src/components/admin/SortableTableHeader.tsx +0 -42
  129. package/.framework/src/components/app-shell/GenericAppShell.tsx +0 -181
  130. package/.framework/src/components/app-shell/GenericDetailPage.tsx +0 -200
  131. package/.framework/src/components/app-shell/GenericListPage.tsx +0 -116
  132. package/.framework/src/components/app-sidebar.tsx +0 -228
  133. package/.framework/src/components/auth/ProtectedRoute.tsx +0 -88
  134. package/.framework/src/components/layout/AppShell.tsx +0 -91
  135. package/.framework/src/components/layout/Header.tsx +0 -88
  136. package/.framework/src/components/layout/Layout.tsx +0 -95
  137. package/.framework/src/components/layout/Sidebar.tsx +0 -329
  138. package/.framework/src/components/runtime/DataDetailHeader.tsx +0 -77
  139. package/.framework/src/components/runtime/DataDetailPage.tsx +0 -171
  140. package/.framework/src/components/runtime/DataFilters.tsx +0 -91
  141. package/.framework/src/components/runtime/DataHeader.tsx +0 -68
  142. package/.framework/src/components/runtime/DataListPage.tsx +0 -124
  143. package/.framework/src/components/runtime/DataStats.tsx +0 -70
  144. package/.framework/src/components/runtime/DataTable.tsx +0 -174
  145. package/.framework/src/components/runtime/SchemaDetailForm.tsx +0 -134
  146. package/.framework/src/components/runtime/index.ts +0 -18
  147. package/.framework/src/components/search-form.tsx +0 -29
  148. package/.framework/src/components/shared/AgentView.tsx +0 -213
  149. package/.framework/src/components/shared/FieldRenderer.tsx +0 -478
  150. package/.framework/src/components/shared/SchemaFields.tsx +0 -226
  151. package/.framework/src/components/ui/DataTable.tsx +0 -343
  152. package/.framework/src/components/ui/Form.tsx +0 -281
  153. package/.framework/src/components/ui/ItemCard.tsx +0 -296
  154. package/.framework/src/components/ui/ItemListView.tsx +0 -308
  155. package/.framework/src/components/ui/LoadingSpinner.tsx +0 -52
  156. package/.framework/src/components/ui/Modal.tsx +0 -61
  157. package/.framework/src/components/ui/RichTextEditor.tsx +0 -210
  158. package/.framework/src/components/ui/accordion.tsx +0 -82
  159. package/.framework/src/components/ui/alert-dialog.tsx +0 -197
  160. package/.framework/src/components/ui/alert.tsx +0 -76
  161. package/.framework/src/components/ui/aspect-ratio.tsx +0 -11
  162. package/.framework/src/components/ui/avatar.tsx +0 -110
  163. package/.framework/src/components/ui/badge.tsx +0 -49
  164. package/.framework/src/components/ui/breadcrumb.tsx +0 -122
  165. package/.framework/src/components/ui/button-group.tsx +0 -83
  166. package/.framework/src/components/ui/button.tsx +0 -65
  167. package/.framework/src/components/ui/calendar.tsx +0 -222
  168. package/.framework/src/components/ui/card.tsx +0 -100
  169. package/.framework/src/components/ui/carousel.tsx +0 -240
  170. package/.framework/src/components/ui/chart.tsx +0 -368
  171. package/.framework/src/components/ui/checkbox.tsx +0 -31
  172. package/.framework/src/components/ui/collapsible.tsx +0 -33
  173. package/.framework/src/components/ui/combobox.tsx +0 -299
  174. package/.framework/src/components/ui/command.tsx +0 -193
  175. package/.framework/src/components/ui/context-menu.tsx +0 -261
  176. package/.framework/src/components/ui/dialog.tsx +0 -165
  177. package/.framework/src/components/ui/direction.tsx +0 -6
  178. package/.framework/src/components/ui/drawer.tsx +0 -132
  179. package/.framework/src/components/ui/dropdown-menu.tsx +0 -269
  180. package/.framework/src/components/ui/empty.tsx +0 -104
  181. package/.framework/src/components/ui/field.tsx +0 -238
  182. package/.framework/src/components/ui/hover-card.tsx +0 -42
  183. package/.framework/src/components/ui/input-group.tsx +0 -153
  184. package/.framework/src/components/ui/input-otp.tsx +0 -87
  185. package/.framework/src/components/ui/input.tsx +0 -19
  186. package/.framework/src/components/ui/item.tsx +0 -196
  187. package/.framework/src/components/ui/kbd.tsx +0 -26
  188. package/.framework/src/components/ui/label.tsx +0 -22
  189. package/.framework/src/components/ui/menubar.tsx +0 -277
  190. package/.framework/src/components/ui/native-select.tsx +0 -61
  191. package/.framework/src/components/ui/navigation-menu.tsx +0 -164
  192. package/.framework/src/components/ui/pagination.tsx +0 -129
  193. package/.framework/src/components/ui/popover.tsx +0 -87
  194. package/.framework/src/components/ui/progress.tsx +0 -31
  195. package/.framework/src/components/ui/radio-group.tsx +0 -42
  196. package/.framework/src/components/ui/resizable.tsx +0 -50
  197. package/.framework/src/components/ui/scroll-area.tsx +0 -53
  198. package/.framework/src/components/ui/select.tsx +0 -195
  199. package/.framework/src/components/ui/separator.tsx +0 -26
  200. package/.framework/src/components/ui/sheet.tsx +0 -145
  201. package/.framework/src/components/ui/sidebar.tsx +0 -706
  202. package/.framework/src/components/ui/skeleton.tsx +0 -13
  203. package/.framework/src/components/ui/slider.tsx +0 -59
  204. package/.framework/src/components/ui/sonner.tsx +0 -47
  205. package/.framework/src/components/ui/spinner.tsx +0 -10
  206. package/.framework/src/components/ui/switch.tsx +0 -33
  207. package/.framework/src/components/ui/table-primitives.tsx +0 -141
  208. package/.framework/src/components/ui/table.tsx +0 -114
  209. package/.framework/src/components/ui/tabs.tsx +0 -90
  210. package/.framework/src/components/ui/textarea.tsx +0 -18
  211. package/.framework/src/components/ui/toggle-group.tsx +0 -89
  212. package/.framework/src/components/ui/toggle.tsx +0 -45
  213. package/.framework/src/components/ui/tooltip.tsx +0 -57
  214. package/.framework/src/contexts/AppContext.tsx +0 -133
  215. package/.framework/src/contexts/AuthContext.tsx +0 -371
  216. package/.framework/src/hooks/use-mobile.ts +0 -19
  217. package/.framework/src/hooks/useApi.ts +0 -526
  218. package/.framework/src/hooks/useApps.ts +0 -114
  219. package/.framework/src/hooks/useEntityList.ts +0 -190
  220. package/.framework/src/hooks/useEntityRecord.ts +0 -308
  221. package/.framework/src/hooks/useForm.ts +0 -307
  222. package/.framework/src/hooks/useListSchema.ts +0 -264
  223. package/.framework/src/hooks/useSchemaRecord.ts +0 -223
  224. package/.framework/src/index.css +0 -128
  225. package/.framework/src/lib/api.ts +0 -156
  226. package/.framework/src/lib/supabase.ts +0 -94
  227. package/.framework/src/lib/utils.ts +0 -317
  228. package/.framework/src/main.tsx +0 -27
  229. package/.framework/src/pages/DashboardPage.tsx +0 -181
  230. package/.framework/src/pages/NotFoundPage.tsx +0 -39
  231. package/.framework/src/pages/admin/AIAgentDetailPage.tsx +0 -161
  232. package/.framework/src/pages/admin/AIAgentsPage.tsx +0 -318
  233. package/.framework/src/pages/admin/APIKeyDetailPage.tsx +0 -199
  234. package/.framework/src/pages/admin/APIKeysPage.tsx +0 -303
  235. package/.framework/src/pages/admin/AlertsConfigPage.tsx +0 -523
  236. package/.framework/src/pages/admin/AppDetailPage.tsx +0 -493
  237. package/.framework/src/pages/admin/AppsPage.tsx +0 -355
  238. package/.framework/src/pages/admin/DesignedPage.tsx +0 -491
  239. package/.framework/src/pages/admin/EmbeddingDetailPage.tsx +0 -534
  240. package/.framework/src/pages/admin/EmbeddingsPage.tsx +0 -424
  241. package/.framework/src/pages/admin/ExtendedShadcnTestPage.tsx +0 -176
  242. package/.framework/src/pages/admin/IncrementalShadcnTestPage.tsx +0 -109
  243. package/.framework/src/pages/admin/IntegratedDashboard.tsx +0 -402
  244. package/.framework/src/pages/admin/IntegrationDetailPage.tsx +0 -187
  245. package/.framework/src/pages/admin/IntegrationsPage.tsx +0 -301
  246. package/.framework/src/pages/admin/LogsPage.tsx +0 -283
  247. package/.framework/src/pages/admin/MinimalShadcnTestPage.tsx +0 -85
  248. package/.framework/src/pages/admin/ObservabilityDashboard.tsx +0 -470
  249. package/.framework/src/pages/admin/PipelineDetailPage.tsx +0 -183
  250. package/.framework/src/pages/admin/PipelineExecutionsPage.tsx +0 -279
  251. package/.framework/src/pages/admin/PipelinesPage.tsx +0 -390
  252. package/.framework/src/pages/admin/PromptConfigDetailPage.tsx +0 -299
  253. package/.framework/src/pages/admin/PromptConfigsPage.tsx +0 -292
  254. package/.framework/src/pages/admin/ProperlyDesignedPage.tsx +0 -434
  255. package/.framework/src/pages/admin/RoleDetailPage.tsx +0 -273
  256. package/.framework/src/pages/admin/RolesPage.tsx +0 -292
  257. package/.framework/src/pages/admin/SelectTestPage.tsx +0 -61
  258. package/.framework/src/pages/admin/ShadcnTestPage.tsx +0 -588
  259. package/.framework/src/pages/admin/SimpleDashboard.tsx +0 -387
  260. package/.framework/src/pages/admin/TestRunDetailPage.tsx +0 -172
  261. package/.framework/src/pages/admin/TestingDashboard.tsx +0 -257
  262. package/.framework/src/pages/admin/TimerDetailPage.tsx +0 -151
  263. package/.framework/src/pages/admin/TimersPage.tsx +0 -376
  264. package/.framework/src/pages/admin/TriggerDetailPage.tsx +0 -149
  265. package/.framework/src/pages/admin/TriggersPage.tsx +0 -381
  266. package/.framework/src/pages/admin/TypeDetailPage.tsx +0 -694
  267. package/.framework/src/pages/admin/TypesPage.tsx +0 -295
  268. package/.framework/src/pages/auth/LoginPage.tsx +0 -187
  269. package/.framework/src/pages/auth/RegisterPage.tsx +0 -163
  270. package/.framework/src/pages/spine-framework/APIPage.tsx +0 -17
  271. package/.framework/src/pages/spine-framework/CLIPage.tsx +0 -25
  272. package/.framework/src/types/auth.ts +0 -125
  273. package/.framework/src/types/types.ts +0 -407
  274. package/STRUCTURE.md +0 -150
  275. package/bin/spine-framework.cjs +0 -62
  276. package/bin/welcome.cjs +0 -45
  277. package/bin/ws-shim.cjs +0 -8
  278. package/bin/ws-shim.ts +0 -10
  279. package/config/components.json +0 -25
  280. package/config/deno.lock +0 -108
  281. package/config/package-lock.json +0 -17183
  282. package/config/postcss.config.cjs +0 -10
  283. package/config/tailwind.config.cjs +0 -78
  284. package/config/tsconfig.build.json +0 -32
  285. package/config/tsconfig.cli.json +0 -18
  286. package/config/tsconfig.json +0 -41
  287. package/config/tsconfig.node.json +0 -17
  288. package/config/tsconfig.node.tsbuildinfo +0 -1
  289. package/config/tsconfig.tsbuildinfo +0 -1
  290. package/config/typedoc.json +0 -16
  291. package/config/vite.config.d.ts +0 -2
  292. package/config/vite.config.ts +0 -72
  293. package/dist/cli/commands/agents.d.ts +0 -39
  294. package/dist/cli/commands/agents.d.ts.map +0 -1
  295. package/dist/cli/commands/auth.d.ts +0 -36
  296. package/dist/cli/commands/auth.d.ts.map +0 -1
  297. package/dist/cli/commands/create-app.d.ts +0 -23
  298. package/dist/cli/commands/create-app.d.ts.map +0 -1
  299. package/dist/cli/commands/dev.d.ts +0 -24
  300. package/dist/cli/commands/dev.d.ts.map +0 -1
  301. package/dist/cli/commands/doctor.d.ts +0 -42
  302. package/dist/cli/commands/doctor.d.ts.map +0 -1
  303. package/dist/cli/commands/generate.d.ts +0 -36
  304. package/dist/cli/commands/generate.d.ts.map +0 -1
  305. package/dist/cli/commands/init.d.ts +0 -20
  306. package/dist/cli/commands/init.d.ts.map +0 -1
  307. package/dist/cli/commands/install-app.d.ts +0 -30
  308. package/dist/cli/commands/install-app.d.ts.map +0 -1
  309. package/dist/cli/commands/items.d.ts +0 -45
  310. package/dist/cli/commands/items.d.ts.map +0 -1
  311. package/dist/cli/commands/migrate.d.ts +0 -21
  312. package/dist/cli/commands/migrate.d.ts.map +0 -1
  313. package/dist/cli/commands/migrations.d.ts +0 -41
  314. package/dist/cli/commands/migrations.d.ts.map +0 -1
  315. package/dist/cli/commands/pipelines.d.ts +0 -40
  316. package/dist/cli/commands/pipelines.d.ts.map +0 -1
  317. package/dist/cli/commands/status.d.ts +0 -23
  318. package/dist/cli/commands/status.d.ts.map +0 -1
  319. package/dist/cli/commands/system.d.ts +0 -29
  320. package/dist/cli/commands/system.d.ts.map +0 -1
  321. package/dist/cli/commands/test.d.ts +0 -46
  322. package/dist/cli/commands/test.d.ts.map +0 -1
  323. package/dist/cli/commands/uninstall-app.d.ts +0 -23
  324. package/dist/cli/commands/uninstall-app.d.ts.map +0 -1
  325. package/dist/cli/context.d.ts +0 -88
  326. package/dist/cli/context.d.ts.map +0 -1
  327. package/dist/cli/env-loader.d.ts +0 -14
  328. package/dist/cli/env-loader.d.ts.map +0 -1
  329. package/dist/cli/index.d.ts +0 -41
  330. package/dist/cli/index.d.ts.map +0 -1
  331. package/dist/functions/_shared/agent-runner.d.ts +0 -156
  332. package/dist/functions/_shared/agent-runner.d.ts.map +0 -1
  333. package/dist/functions/_shared/app-manifest.d.ts +0 -68
  334. package/dist/functions/_shared/app-manifest.d.ts.map +0 -1
  335. package/dist/functions/_shared/audit.d.ts +0 -91
  336. package/dist/functions/_shared/audit.d.ts.map +0 -1
  337. package/dist/functions/_shared/db.d.ts +0 -125
  338. package/dist/functions/_shared/db.d.ts.map +0 -1
  339. package/dist/functions/_shared/index.d.ts +0 -299
  340. package/dist/functions/_shared/index.d.ts.map +0 -1
  341. package/dist/functions/_shared/middleware.d.ts +0 -315
  342. package/dist/functions/_shared/middleware.d.ts.map +0 -1
  343. package/dist/functions/_shared/permissions.d.ts +0 -626
  344. package/dist/functions/_shared/permissions.d.ts.map +0 -1
  345. package/dist/functions/_shared/pipeline-runner.d.ts +0 -124
  346. package/dist/functions/_shared/pipeline-runner.d.ts.map +0 -1
  347. package/dist/functions/_shared/principal.d.ts +0 -284
  348. package/dist/functions/_shared/principal.d.ts.map +0 -1
  349. package/dist/functions/_shared/resolve-ids.d.ts +0 -10
  350. package/dist/functions/_shared/resolve-ids.d.ts.map +0 -1
  351. package/dist/functions/_shared/schema-utils.d.ts +0 -181
  352. package/dist/functions/_shared/schema-utils.d.ts.map +0 -1
  353. package/dist/functions/_shared/testing.d.ts +0 -172
  354. package/dist/functions/_shared/testing.d.ts.map +0 -1
  355. package/dist/functions/_shared/trigger-engine.d.ts +0 -140
  356. package/dist/functions/_shared/trigger-engine.d.ts.map +0 -1
  357. package/dist/functions/_shared/webhook-registration.d.ts +0 -81
  358. package/dist/functions/_shared/webhook-registration.d.ts.map +0 -1
  359. package/dist/functions/_shared/webhook-registry.d.ts +0 -57
  360. package/dist/functions/_shared/webhook-registry.d.ts.map +0 -1
  361. package/dist/functions/account-nodes.d.ts +0 -48
  362. package/dist/functions/account-nodes.d.ts.map +0 -1
  363. package/dist/functions/admin-data.d.ts +0 -178
  364. package/dist/functions/admin-data.d.ts.map +0 -1
  365. package/dist/functions/ai-agents.d.ts +0 -125
  366. package/dist/functions/ai-agents.d.ts.map +0 -1
  367. package/dist/functions/api-keys.d.ts +0 -140
  368. package/dist/functions/api-keys.d.ts.map +0 -1
  369. package/dist/functions/apps.d.ts +0 -163
  370. package/dist/functions/apps.d.ts.map +0 -1
  371. package/dist/functions/auth.d.ts +0 -74
  372. package/dist/functions/auth.d.ts.map +0 -1
  373. package/dist/functions/debug-auth.d.ts +0 -33
  374. package/dist/functions/debug-auth.d.ts.map +0 -1
  375. package/dist/functions/embeddings.d.ts +0 -205
  376. package/dist/functions/embeddings.d.ts.map +0 -1
  377. package/dist/functions/integration-routes.d.ts +0 -45
  378. package/dist/functions/integration-routes.d.ts.map +0 -1
  379. package/dist/functions/integrations.d.ts +0 -124
  380. package/dist/functions/integrations.d.ts.map +0 -1
  381. package/dist/functions/item-progress.d.ts +0 -41
  382. package/dist/functions/item-progress.d.ts.map +0 -1
  383. package/dist/functions/logs.d.ts +0 -162
  384. package/dist/functions/logs.d.ts.map +0 -1
  385. package/dist/functions/observability.d.ts +0 -123
  386. package/dist/functions/observability.d.ts.map +0 -1
  387. package/dist/functions/pipeline-executions.d.ts +0 -190
  388. package/dist/functions/pipeline-executions.d.ts.map +0 -1
  389. package/dist/functions/pipelines.d.ts +0 -171
  390. package/dist/functions/pipelines.d.ts.map +0 -1
  391. package/dist/functions/prompt-configs.d.ts +0 -125
  392. package/dist/functions/prompt-configs.d.ts.map +0 -1
  393. package/dist/functions/roles.d.ts +0 -118
  394. package/dist/functions/roles.d.ts.map +0 -1
  395. package/dist/functions/system-cron.d.ts +0 -65
  396. package/dist/functions/system-cron.d.ts.map +0 -1
  397. package/dist/functions/system.d.ts +0 -29
  398. package/dist/functions/system.d.ts.map +0 -1
  399. package/dist/functions/tests.d.ts +0 -28
  400. package/dist/functions/tests.d.ts.map +0 -1
  401. package/dist/functions/timers.d.ts +0 -139
  402. package/dist/functions/timers.d.ts.map +0 -1
  403. package/dist/functions/triggers.d.ts +0 -203
  404. package/dist/functions/triggers.d.ts.map +0 -1
  405. package/dist/functions/types.d.ts +0 -151
  406. package/dist/functions/types.d.ts.map +0 -1
  407. package/dist/src/types/types.d.ts +0 -364
  408. package/dist/src/types/types.d.ts.map +0 -1
  409. package/index.html +0 -13
  410. package/netlify.toml +0 -36
  411. package/package-project.json +0 -64
  412. package/scripts/app-install-cli.ts +0 -286
  413. package/scripts/assemble-frontend.sh +0 -79
  414. package/scripts/assemble-functions.sh +0 -62
  415. package/scripts/assemble.sh +0 -41
  416. package/scripts/boundary-check.sh +0 -106
  417. package/scripts/build-manifest.sh +0 -80
  418. package/scripts/check-core-integrity.sh +0 -82
  419. package/scripts/ingest-chunks.cjs +0 -202
  420. package/scripts/kb-chunk-parser.cjs +0 -312
  421. package/scripts/kb-chunk-parser.ts +0 -330
  422. package/scripts/load-test-app-install.ts +0 -484
  423. package/scripts/netlify-dev-wrapper.sh +0 -22
  424. package/scripts/verify-integrity.sh +0 -69
  425. package/vitest.config.ts +0 -45
@@ -1,706 +0,0 @@
1
- import * as React from "react"
2
- import { cva, type VariantProps } from "class-variance-authority"
3
- import { Slot } from "@radix-ui/react-slot"
4
-
5
- import { useIsMobile } from "@/hooks/use-mobile"
6
- import { cn } from "@/lib/utils"
7
- import { Button } from "@/components/ui/button"
8
- import { Input } from "@/components/ui/input"
9
- import { Separator } from "@/components/ui/separator"
10
- import {
11
- Sheet,
12
- SheetContent,
13
- SheetDescription,
14
- SheetHeader,
15
- SheetTitle,
16
- } from "@/components/ui/sheet"
17
- import { Skeleton } from "@/components/ui/skeleton"
18
- import {
19
- Tooltip,
20
- TooltipContent,
21
- TooltipTrigger,
22
- } from "@/components/ui/tooltip"
23
- import { PanelLeftIcon } from "lucide-react"
24
-
25
- const SIDEBAR_COOKIE_NAME = "sidebar_state"
26
- const SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7
27
- const SIDEBAR_WIDTH = "16rem"
28
- const SIDEBAR_WIDTH_MOBILE = "18rem"
29
- const SIDEBAR_WIDTH_ICON = "3rem"
30
- const SIDEBAR_KEYBOARD_SHORTCUT = "b"
31
-
32
- type SidebarContextProps = {
33
- state: "expanded" | "collapsed"
34
- open: boolean
35
- setOpen: (open: boolean) => void
36
- openMobile: boolean
37
- setOpenMobile: (open: boolean) => void
38
- isMobile: boolean
39
- toggleSidebar: () => void
40
- }
41
-
42
- const SidebarContext = React.createContext<SidebarContextProps | null>(null)
43
-
44
- function useSidebar() {
45
- const context = React.useContext(SidebarContext)
46
- if (!context) {
47
- throw new Error("useSidebar must be used within a SidebarProvider.")
48
- }
49
-
50
- return context
51
- }
52
-
53
- function SidebarProvider({
54
- defaultOpen = true,
55
- open: openProp,
56
- onOpenChange: setOpenProp,
57
- className,
58
- style,
59
- children,
60
- ...props
61
- }: React.ComponentProps<"div"> & {
62
- defaultOpen?: boolean
63
- open?: boolean
64
- onOpenChange?: (open: boolean) => void
65
- }) {
66
- const isMobile = useIsMobile()
67
- const [openMobile, setOpenMobile] = React.useState(false)
68
-
69
- // This is the internal state of the sidebar.
70
- // We use openProp and setOpenProp for control from outside the component.
71
- const [_open, _setOpen] = React.useState(defaultOpen)
72
- const open = openProp ?? _open
73
- const setOpen = React.useCallback(
74
- (value: boolean | ((value: boolean) => boolean)) => {
75
- const openState = typeof value === "function" ? value(open) : value
76
- if (setOpenProp) {
77
- setOpenProp(openState)
78
- } else {
79
- _setOpen(openState)
80
- }
81
-
82
- // This sets the cookie to keep the sidebar state.
83
- document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`
84
- },
85
- [setOpenProp, open]
86
- )
87
-
88
- // Helper to toggle the sidebar.
89
- const toggleSidebar = React.useCallback(() => {
90
- return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open)
91
- }, [isMobile, setOpen, setOpenMobile])
92
-
93
- // Adds a keyboard shortcut to toggle the sidebar.
94
- React.useEffect(() => {
95
- const handleKeyDown = (event: KeyboardEvent) => {
96
- if (
97
- event.key === SIDEBAR_KEYBOARD_SHORTCUT &&
98
- (event.metaKey || event.ctrlKey)
99
- ) {
100
- event.preventDefault()
101
- toggleSidebar()
102
- }
103
- }
104
-
105
- window.addEventListener("keydown", handleKeyDown)
106
- return () => window.removeEventListener("keydown", handleKeyDown)
107
- }, [toggleSidebar])
108
-
109
- // We add a state so that we can do data-state="expanded" or "collapsed".
110
- // This makes it easier to style the sidebar with Tailwind classes.
111
- const state = open ? "expanded" : "collapsed"
112
-
113
- const contextValue = React.useMemo<SidebarContextProps>(
114
- () => ({
115
- state,
116
- open,
117
- setOpen,
118
- isMobile,
119
- openMobile,
120
- setOpenMobile,
121
- toggleSidebar,
122
- }),
123
- [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar]
124
- )
125
-
126
- return (
127
- <SidebarContext.Provider value={contextValue}>
128
- <div
129
- data-slot="sidebar-wrapper"
130
- style={
131
- {
132
- "--sidebar-width": SIDEBAR_WIDTH,
133
- "--sidebar-width-icon": SIDEBAR_WIDTH_ICON,
134
- ...style,
135
- } as React.CSSProperties
136
- }
137
- className={cn(
138
- "group/sidebar-wrapper flex min-h-svh w-full has-data-[variant=inset]:bg-sidebar",
139
- className
140
- )}
141
- {...props}
142
- >
143
- {children}
144
- </div>
145
- </SidebarContext.Provider>
146
- )
147
- }
148
-
149
- function Sidebar({
150
- side = "left",
151
- variant = "sidebar",
152
- collapsible = "offcanvas",
153
- className,
154
- children,
155
- dir,
156
- ...props
157
- }: React.ComponentProps<"div"> & {
158
- side?: "left" | "right"
159
- variant?: "sidebar" | "floating" | "inset"
160
- collapsible?: "offcanvas" | "icon" | "none"
161
- }) {
162
- const { isMobile, state, openMobile, setOpenMobile } = useSidebar()
163
-
164
- if (collapsible === "none") {
165
- return (
166
- <div
167
- data-slot="sidebar"
168
- className={cn(
169
- "flex h-full w-(--sidebar-width) flex-col bg-sidebar text-sidebar-foreground",
170
- className
171
- )}
172
- {...props}
173
- >
174
- {children}
175
- </div>
176
- )
177
- }
178
-
179
- if (isMobile) {
180
- return (
181
- <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>
182
- <SheetContent
183
- dir={dir}
184
- data-sidebar="sidebar"
185
- data-slot="sidebar"
186
- data-mobile="true"
187
- className="w-(--sidebar-width) bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden"
188
- style={
189
- {
190
- "--sidebar-width": SIDEBAR_WIDTH_MOBILE,
191
- } as React.CSSProperties
192
- }
193
- side={side}
194
- >
195
- <SheetHeader className="sr-only">
196
- <SheetTitle>Sidebar</SheetTitle>
197
- <SheetDescription>Displays the mobile sidebar.</SheetDescription>
198
- </SheetHeader>
199
- <div className="flex h-full w-full flex-col">{children}</div>
200
- </SheetContent>
201
- </Sheet>
202
- )
203
- }
204
-
205
- return (
206
- <div
207
- className="group peer hidden text-sidebar-foreground md:block"
208
- data-state={state}
209
- data-collapsible={state === "collapsed" ? collapsible : ""}
210
- data-variant={variant}
211
- data-side={side}
212
- data-slot="sidebar"
213
- >
214
- {/* This is what handles the sidebar gap on desktop */}
215
- <div
216
- data-slot="sidebar-gap"
217
- className={cn(
218
- "relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear",
219
- "group-data-[collapsible=offcanvas]:w-0",
220
- "group-data-[side=right]:rotate-180",
221
- variant === "floating" || variant === "inset"
222
- ? "group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]"
223
- : "group-data-[collapsible=icon]:w-(--sidebar-width-icon)"
224
- )}
225
- />
226
- <div
227
- data-slot="sidebar-container"
228
- data-side={side}
229
- className={cn(
230
- "fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear data-[side=left]:left-0 data-[side=left]:group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)] data-[side=right]:right-0 data-[side=right]:group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)] md:flex",
231
- // Adjust the padding for floating and inset variants.
232
- variant === "floating" || variant === "inset"
233
- ? "p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]"
234
- : "group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l",
235
- className
236
- )}
237
- {...props}
238
- >
239
- <div
240
- data-sidebar="sidebar"
241
- data-slot="sidebar-inner"
242
- className="flex size-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:shadow-sm group-data-[variant=floating]:ring-1 group-data-[variant=floating]:ring-sidebar-border"
243
- >
244
- {children}
245
- </div>
246
- </div>
247
- </div>
248
- )
249
- }
250
-
251
- function SidebarTrigger({
252
- className,
253
- onClick,
254
- ...props
255
- }: React.ComponentProps<typeof Button>) {
256
- const { toggleSidebar } = useSidebar()
257
-
258
- return (
259
- <Button
260
- data-sidebar="trigger"
261
- data-slot="sidebar-trigger"
262
- variant="ghost"
263
- size="icon-sm"
264
- className={cn(className)}
265
- onClick={(event) => {
266
- onClick?.(event)
267
- toggleSidebar()
268
- }}
269
- {...props}
270
- >
271
- <PanelLeftIcon />
272
- <span className="sr-only">Toggle Sidebar</span>
273
- </Button>
274
- )
275
- }
276
-
277
- function SidebarRail({ className, ...props }: React.ComponentProps<"button">) {
278
- const { toggleSidebar } = useSidebar()
279
-
280
- return (
281
- <button
282
- data-sidebar="rail"
283
- data-slot="sidebar-rail"
284
- aria-label="Toggle Sidebar"
285
- tabIndex={-1}
286
- onClick={toggleSidebar}
287
- title="Toggle Sidebar"
288
- className={cn(
289
- "absolute inset-y-0 z-20 hidden w-4 transition-all ease-linear group-data-[side=left]:-right-4 group-data-[side=right]:left-0 after:absolute after:inset-y-0 after:start-1/2 after:w-[2px] hover:after:bg-sidebar-border sm:flex ltr:-translate-x-1/2 rtl:-translate-x-1/2",
290
- "in-data-[side=left]:cursor-w-resize in-data-[side=right]:cursor-e-resize",
291
- "[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize",
292
- "group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full hover:group-data-[collapsible=offcanvas]:bg-sidebar",
293
- "[[data-side=left][data-collapsible=offcanvas]_&]:-right-2",
294
- "[[data-side=right][data-collapsible=offcanvas]_&]:-left-2",
295
- className
296
- )}
297
- {...props}
298
- />
299
- )
300
- }
301
-
302
- function SidebarInset({ className, ...props }: React.ComponentProps<"main">) {
303
- return (
304
- <main
305
- data-slot="sidebar-inset"
306
- className={cn(
307
- "relative flex w-full flex-1 flex-col bg-background md:peer-data-[variant=inset]:m-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow-sm md:peer-data-[variant=inset]:peer-data-[state=collapsed]:ml-2",
308
- className
309
- )}
310
- {...props}
311
- />
312
- )
313
- }
314
-
315
- function SidebarInput({
316
- className,
317
- ...props
318
- }: React.ComponentProps<typeof Input>) {
319
- return (
320
- <Input
321
- data-slot="sidebar-input"
322
- data-sidebar="input"
323
- className={cn(
324
- "h-8 w-full border-input bg-muted/20 dark:bg-muted/30",
325
- className
326
- )}
327
- {...props}
328
- />
329
- )
330
- }
331
-
332
- function SidebarHeader({ className, ...props }: React.ComponentProps<"div">) {
333
- return (
334
- <div
335
- data-slot="sidebar-header"
336
- data-sidebar="header"
337
- className={cn("flex flex-col gap-2 p-2", className)}
338
- {...props}
339
- />
340
- )
341
- }
342
-
343
- function SidebarFooter({ className, ...props }: React.ComponentProps<"div">) {
344
- return (
345
- <div
346
- data-slot="sidebar-footer"
347
- data-sidebar="footer"
348
- className={cn("flex flex-col gap-2 p-2", className)}
349
- {...props}
350
- />
351
- )
352
- }
353
-
354
- function SidebarSeparator({
355
- className,
356
- ...props
357
- }: React.ComponentProps<typeof Separator>) {
358
- return (
359
- <Separator
360
- data-slot="sidebar-separator"
361
- data-sidebar="separator"
362
- className={cn("mx-2 w-auto bg-sidebar-border", className)}
363
- {...props}
364
- />
365
- )
366
- }
367
-
368
- function SidebarContent({ className, ...props }: React.ComponentProps<"div">) {
369
- return (
370
- <div
371
- data-slot="sidebar-content"
372
- data-sidebar="content"
373
- className={cn(
374
- "no-scrollbar flex min-h-0 flex-1 flex-col gap-0 overflow-auto group-data-[collapsible=icon]:overflow-hidden",
375
- className
376
- )}
377
- {...props}
378
- />
379
- )
380
- }
381
-
382
- function SidebarGroup({ className, ...props }: React.ComponentProps<"div">) {
383
- return (
384
- <div
385
- data-slot="sidebar-group"
386
- data-sidebar="group"
387
- className={cn(
388
- "relative flex w-full min-w-0 flex-col px-2 py-1",
389
- className
390
- )}
391
- {...props}
392
- />
393
- )
394
- }
395
-
396
- function SidebarGroupLabel({
397
- className,
398
- asChild = false,
399
- ...props
400
- }: React.ComponentProps<"div"> & { asChild?: boolean }) {
401
- const Comp = asChild ? Slot : "div"
402
-
403
- return (
404
- <Comp
405
- data-slot="sidebar-group-label"
406
- data-sidebar="group-label"
407
- className={cn(
408
- "flex h-8 shrink-0 items-center rounded-md px-2 text-xs text-sidebar-foreground/70 ring-sidebar-ring outline-hidden transition-[margin,opacity] duration-200 ease-linear group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0 focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0",
409
- className
410
- )}
411
- {...props}
412
- />
413
- )
414
- }
415
-
416
- function SidebarGroupAction({
417
- className,
418
- asChild = false,
419
- ...props
420
- }: React.ComponentProps<"button"> & { asChild?: boolean }) {
421
- const Comp = asChild ? Slot : "button"
422
-
423
- return (
424
- <Comp
425
- data-slot="sidebar-group-action"
426
- data-sidebar="group-action"
427
- className={cn(
428
- "absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground ring-sidebar-ring outline-hidden transition-transform group-data-[collapsible=icon]:hidden after:absolute after:-inset-2 hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 md:after:hidden [&>svg]:size-4 [&>svg]:shrink-0",
429
- className
430
- )}
431
- {...props}
432
- />
433
- )
434
- }
435
-
436
- function SidebarGroupContent({
437
- className,
438
- ...props
439
- }: React.ComponentProps<"div">) {
440
- return (
441
- <div
442
- data-slot="sidebar-group-content"
443
- data-sidebar="group-content"
444
- className={cn("w-full text-xs", className)}
445
- {...props}
446
- />
447
- )
448
- }
449
-
450
- function SidebarMenu({ className, ...props }: React.ComponentProps<"ul">) {
451
- return (
452
- <ul
453
- data-slot="sidebar-menu"
454
- data-sidebar="menu"
455
- className={cn("flex w-full min-w-0 flex-col gap-px", className)}
456
- {...props}
457
- />
458
- )
459
- }
460
-
461
- function SidebarMenuItem({ className, ...props }: React.ComponentProps<"li">) {
462
- return (
463
- <li
464
- data-slot="sidebar-menu-item"
465
- data-sidebar="menu-item"
466
- className={cn("group/menu-item relative", className)}
467
- {...props}
468
- />
469
- )
470
- }
471
-
472
- const sidebarMenuButtonVariants = cva(
473
- "peer/menu-button group/menu-button flex w-full items-center gap-2 overflow-hidden rounded-[calc(var(--radius-sm)+2px)] p-2 text-left text-xs ring-sidebar-ring outline-hidden transition-[width,height,padding] group-has-data-[sidebar=menu-action]/menu-item:pr-8 group-data-[collapsible=icon]:size-8! group-data-[collapsible=icon]:p-2! hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-open:hover:bg-sidebar-accent data-open:hover:text-sidebar-accent-foreground data-active:bg-sidebar-accent data-active:font-medium data-active:text-sidebar-accent-foreground [&_svg]:size-4 [&_svg]:shrink-0 [&>span:last-child]:truncate",
474
- {
475
- variants: {
476
- variant: {
477
- default: "hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",
478
- outline:
479
- "bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]",
480
- },
481
- size: {
482
- default: "h-8 text-xs",
483
- sm: "h-7 text-xs",
484
- lg: "h-12 text-xs group-data-[collapsible=icon]:p-0!",
485
- },
486
- },
487
- defaultVariants: {
488
- variant: "default",
489
- size: "default",
490
- },
491
- }
492
- )
493
-
494
- function SidebarMenuButton({
495
- asChild = false,
496
- isActive = false,
497
- variant = "default",
498
- size = "default",
499
- tooltip,
500
- className,
501
- ...props
502
- }: React.ComponentProps<"button"> & {
503
- asChild?: boolean
504
- isActive?: boolean
505
- tooltip?: string | React.ComponentProps<typeof TooltipContent>
506
- } & VariantProps<typeof sidebarMenuButtonVariants>) {
507
- const Comp = asChild ? Slot : "button"
508
- const { isMobile, state } = useSidebar()
509
-
510
- const button = (
511
- <Comp
512
- data-slot="sidebar-menu-button"
513
- data-sidebar="menu-button"
514
- data-size={size}
515
- data-active={isActive}
516
- className={cn(sidebarMenuButtonVariants({ variant, size }), className)}
517
- {...props}
518
- />
519
- )
520
-
521
- if (!tooltip) {
522
- return button
523
- }
524
-
525
- if (typeof tooltip === "string") {
526
- tooltip = {
527
- children: tooltip,
528
- }
529
- }
530
-
531
- return (
532
- <Tooltip>
533
- <TooltipTrigger asChild>{button}</TooltipTrigger>
534
- <TooltipContent
535
- side="right"
536
- align="center"
537
- hidden={state !== "collapsed" || isMobile}
538
- {...tooltip}
539
- />
540
- </Tooltip>
541
- )
542
- }
543
-
544
- function SidebarMenuAction({
545
- className,
546
- asChild = false,
547
- showOnHover = false,
548
- ...props
549
- }: React.ComponentProps<"button"> & {
550
- asChild?: boolean
551
- showOnHover?: boolean
552
- }) {
553
- const Comp = asChild ? Slot : "button"
554
-
555
- return (
556
- <Comp
557
- data-slot="sidebar-menu-action"
558
- data-sidebar="menu-action"
559
- className={cn(
560
- "absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-[calc(var(--radius-sm)-2px)] p-0 text-sidebar-foreground ring-sidebar-ring outline-hidden transition-transform group-data-[collapsible=icon]:hidden peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[size=default]/menu-button:top-1.5 peer-data-[size=lg]/menu-button:top-2.5 peer-data-[size=sm]/menu-button:top-1 after:absolute after:-inset-2 hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 md:after:hidden [&>svg]:size-4 [&>svg]:shrink-0",
561
- showOnHover &&
562
- "group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 peer-data-active/menu-button:text-sidebar-accent-foreground aria-expanded:opacity-100 md:opacity-0",
563
- className
564
- )}
565
- {...props}
566
- />
567
- )
568
- }
569
-
570
- function SidebarMenuBadge({
571
- className,
572
- ...props
573
- }: React.ComponentProps<"div">) {
574
- return (
575
- <div
576
- data-slot="sidebar-menu-badge"
577
- data-sidebar="menu-badge"
578
- className={cn(
579
- "pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-[calc(var(--radius-sm)-2px)] px-1 text-xs font-medium text-sidebar-foreground tabular-nums select-none group-data-[collapsible=icon]:hidden peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[size=default]/menu-button:top-1.5 peer-data-[size=lg]/menu-button:top-2.5 peer-data-[size=sm]/menu-button:top-1 peer-data-active/menu-button:text-sidebar-accent-foreground",
580
- className
581
- )}
582
- {...props}
583
- />
584
- )
585
- }
586
-
587
- function SidebarMenuSkeleton({
588
- className,
589
- showIcon = false,
590
- ...props
591
- }: React.ComponentProps<"div"> & {
592
- showIcon?: boolean
593
- }) {
594
- // Random width between 50 to 90%.
595
- const [width] = React.useState(() => {
596
- return `${Math.floor(Math.random() * 40) + 50}%`
597
- })
598
-
599
- return (
600
- <div
601
- data-slot="sidebar-menu-skeleton"
602
- data-sidebar="menu-skeleton"
603
- className={cn("flex h-8 items-center gap-2 rounded-md px-2", className)}
604
- {...props}
605
- >
606
- {showIcon && (
607
- <Skeleton
608
- className="size-4 rounded-md"
609
- data-sidebar="menu-skeleton-icon"
610
- />
611
- )}
612
- <Skeleton
613
- className="h-4 max-w-(--skeleton-width) flex-1"
614
- data-sidebar="menu-skeleton-text"
615
- style={
616
- {
617
- "--skeleton-width": width,
618
- } as React.CSSProperties
619
- }
620
- />
621
- </div>
622
- )
623
- }
624
-
625
- function SidebarMenuSub({ className, ...props }: React.ComponentProps<"ul">) {
626
- return (
627
- <ul
628
- data-slot="sidebar-menu-sub"
629
- data-sidebar="menu-sub"
630
- className={cn(
631
- "mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5 group-data-[collapsible=icon]:hidden",
632
- className
633
- )}
634
- {...props}
635
- />
636
- )
637
- }
638
-
639
- function SidebarMenuSubItem({
640
- className,
641
- ...props
642
- }: React.ComponentProps<"li">) {
643
- return (
644
- <li
645
- data-slot="sidebar-menu-sub-item"
646
- data-sidebar="menu-sub-item"
647
- className={cn("group/menu-sub-item relative", className)}
648
- {...props}
649
- />
650
- )
651
- }
652
-
653
- function SidebarMenuSubButton({
654
- asChild = false,
655
- size = "md",
656
- isActive = false,
657
- className,
658
- ...props
659
- }: React.ComponentProps<"a"> & {
660
- asChild?: boolean
661
- size?: "sm" | "md"
662
- isActive?: boolean
663
- }) {
664
- const Comp = asChild ? Slot : "a"
665
-
666
- return (
667
- <Comp
668
- data-slot="sidebar-menu-sub-button"
669
- data-sidebar="menu-sub-button"
670
- data-size={size}
671
- data-active={isActive}
672
- className={cn(
673
- "flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground ring-sidebar-ring outline-hidden group-data-[collapsible=icon]:hidden hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[size=md]:text-xs data-[size=sm]:text-xs data-active:bg-sidebar-accent data-active:text-sidebar-accent-foreground [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground",
674
- className
675
- )}
676
- {...props}
677
- />
678
- )
679
- }
680
-
681
- export {
682
- Sidebar,
683
- SidebarContent,
684
- SidebarFooter,
685
- SidebarGroup,
686
- SidebarGroupAction,
687
- SidebarGroupContent,
688
- SidebarGroupLabel,
689
- SidebarHeader,
690
- SidebarInput,
691
- SidebarInset,
692
- SidebarMenu,
693
- SidebarMenuAction,
694
- SidebarMenuBadge,
695
- SidebarMenuButton,
696
- SidebarMenuItem,
697
- SidebarMenuSkeleton,
698
- SidebarMenuSub,
699
- SidebarMenuSubButton,
700
- SidebarMenuSubItem,
701
- SidebarProvider,
702
- SidebarRail,
703
- SidebarSeparator,
704
- SidebarTrigger,
705
- useSidebar,
706
- }