spine-framework 0.2.1 → 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 +213 -8
  2. package/README.md +327 -0
  3. package/package.json +107 -217
  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 -133
  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 -71
  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 -71
  412. package/scripts/app-install-cli.ts +0 -286
  413. package/scripts/assemble-frontend.sh +0 -76
  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,68 +0,0 @@
1
- /**
2
- * @module src/components/runtime/DataHeader
3
- * @audience installer
4
- * @layer frontend-component
5
- * @stability stable
6
- *
7
- * Title bar for entity list pages. Renders an entity icon, title,
8
- * description, and a "New" button that navigates to the create route.
9
- * The icon name is resolved dynamically from `@heroicons/react`; falls
10
- * back to `CubeIcon` if the name is unrecognised.
11
- *
12
- * @seeAlso src/components/runtime/DataListPage.tsx (mounts this component)
13
- */
14
-
15
- import React from 'react'
16
- import { Button } from '../ui/button'
17
- import * as Icons from 'lucide-react'
18
-
19
- /**
20
- * Props for `DataHeader`.
21
- *
22
- * @prop title - Entity name (displayed capitalised)
23
- * @prop icon - Heroicon name string (e.g. `'UserIcon'`)
24
- * @prop description - Short subtitle text
25
- * @prop newButtonHref - URL to navigate to when "New" is clicked
26
- */
27
- interface DataHeaderProps {
28
- title: string
29
- icon: string
30
- description: string
31
- newButtonHref: string
32
- }
33
-
34
- /**
35
- * Entity list page header with title, description, and new-record button.
36
- *
37
- * @param props - `DataHeaderProps`
38
- * @returns Header bar JSX
39
- * @sideEffects Navigates via `window.location.href` on button click
40
- */
41
- export function DataHeader({ title, icon, description, newButtonHref }: DataHeaderProps) {
42
- // Dynamically get the icon component
43
- const IconComponent = (Icons as Record<string, React.ComponentType<{ className?: string }>>)[icon] || Icons.Box
44
-
45
- return (
46
- <div className="flex justify-between items-center">
47
- <div className="flex items-center gap-3">
48
- <div className="flex h-10 w-10 items-center justify-center rounded-lg bg-primary/10">
49
- <IconComponent className="h-6 w-6 text-primary" />
50
- </div>
51
- <div>
52
- <h1 className="text-xl font-semibold text-foreground capitalize">
53
- {title}
54
- </h1>
55
- <p className="mt-0.5 text-sm text-muted-foreground">{description}</p>
56
- </div>
57
- </div>
58
-
59
- <Button
60
- onClick={() => window.location.href = newButtonHref}
61
- className="flex items-center gap-2"
62
- >
63
- <Icons.Plus className="h-4 w-4" />
64
- New {title.slice(0, -1)}
65
- </Button>
66
- </div>
67
- )
68
- }
@@ -1,124 +0,0 @@
1
- import { useParams } from 'react-router-dom'
2
- import { useListSchema } from '../../hooks/useListSchema'
3
- import { useEntityList } from '../../hooks/useEntityList'
4
- import { DataHeader } from './DataHeader'
5
- import { DataStats } from './DataStats'
6
- import { DataFilters } from './DataFilters'
7
- import { DataTable } from './DataTable'
8
- import { Card, CardContent } from '../ui/card'
9
- import { Skeleton } from '../ui/skeleton'
10
-
11
- export function DataListPage() {
12
- const { entity, typeSlug } = useParams<{ entity: string; typeSlug?: string }>()
13
-
14
- const { schema, view, loading: schemaLoading, error: schemaError } = useListSchema({
15
- entity: entity || '',
16
- viewSlug: 'default_list'
17
- })
18
-
19
- const config = view && schema ? {
20
- entity: entity || '',
21
- typeSlug: typeSlug || undefined,
22
- icon: 'database',
23
- api: {
24
- endpoint: 'admin-data',
25
- listAction: 'list'
26
- },
27
- list: {
28
- defaultSort: (view as any).default_sort || { field: 'created_at', direction: 'desc' },
29
- stats: (view as any).stats || [],
30
- filters: (view as any).filters || [],
31
- columns: Object.entries((view as any).fields || {}).map(([key, fieldConfig]: [string, any]) => ({
32
- key,
33
- label: schema.fields[key]?.label || key,
34
- sortable: fieldConfig.sortable !== false,
35
- display_type: fieldConfig.display_type
36
- }))
37
- }
38
- } : null
39
-
40
- const {
41
- data,
42
- loading,
43
- error,
44
- refetch,
45
- filters,
46
- setFilters,
47
- sort,
48
- setSort
49
- } = useEntityList(entity!, config)
50
-
51
- if (schemaLoading) {
52
- return (
53
- <div className="space-y-6">
54
- <Card>
55
- <CardContent className="p-6">
56
- <Skeleton className="h-8 w-48" />
57
- <Skeleton className="h-4 w-96 mt-2" />
58
- </CardContent>
59
- </Card>
60
- <div className="grid grid-cols-1 gap-5 sm:grid-cols-2 lg:grid-cols-4">
61
- <Skeleton className="h-24" />
62
- <Skeleton className="h-24" />
63
- <Skeleton className="h-24" />
64
- <Skeleton className="h-24" />
65
- </div>
66
- <Card>
67
- <CardContent className="p-8 space-y-4">
68
- <Skeleton className="h-8 w-full" />
69
- <Skeleton className="h-8 w-full" />
70
- <Skeleton className="h-8 w-3/4" />
71
- </CardContent>
72
- </Card>
73
- </div>
74
- )
75
- }
76
-
77
- if (schemaError || !config) {
78
- return (
79
- <Card>
80
- <CardContent className="p-8 text-center">
81
- <p className="text-lg font-medium text-destructive">Error</p>
82
- <p className="mt-2 text-sm text-muted-foreground">{schemaError || 'Failed to load entity configuration'}</p>
83
- </CardContent>
84
- </Card>
85
- )
86
- }
87
-
88
- return (
89
- <div className="space-y-6">
90
- <DataHeader
91
- title={config.entity.charAt(0).toUpperCase() + config.entity.slice(1)}
92
- icon={config.icon}
93
- description={`Manage ${config.entity}`}
94
- newButtonHref={`/spine-framework/admin/runtime/${entity}/new`}
95
- />
96
-
97
- <DataStats
98
- stats={config.list.stats}
99
- data={data}
100
- loading={loading}
101
- />
102
-
103
- <DataFilters
104
- filters={config.list.filters}
105
- values={filters}
106
- onChange={setFilters}
107
- onClear={() => setFilters({})}
108
- />
109
-
110
- <DataTable
111
- columns={config.list.columns}
112
- data={data}
113
- loading={loading}
114
- error={error}
115
- onRetry={refetch}
116
- sort={sort}
117
- onSort={setSort}
118
- entity={entity!}
119
- emptyMessage={`No ${config.entity} found`}
120
- emptyIcon={config.icon}
121
- />
122
- </div>
123
- )
124
- }
@@ -1,70 +0,0 @@
1
- import { EntityStat } from '../../types/types'
2
- import { Card, CardContent } from '../ui/card'
3
- import * as Icons from 'lucide-react'
4
-
5
- interface DataStatsProps {
6
- stats: EntityStat[]
7
- data: any[]
8
- loading?: boolean
9
- }
10
-
11
- const colorMap: Record<string, string> = {
12
- blue: 'bg-blue-500/10 text-blue-500',
13
- green: 'bg-green-500/10 text-green-500',
14
- red: 'bg-red-500/10 text-red-500',
15
- orange: 'bg-orange-500/10 text-orange-500',
16
- purple: 'bg-purple-500/10 text-purple-500',
17
- gray: 'bg-muted text-muted-foreground'
18
- }
19
-
20
- export function DataStats({ stats, data, loading }: DataStatsProps) {
21
- const calculateStat = (stat: EntityStat): number => {
22
- if (!data) return 0
23
-
24
- switch (stat.type) {
25
- case 'count':
26
- return data.length
27
- case 'filter_count':
28
- return data.filter(item => {
29
- if (!stat.filter) return true
30
- return Object.entries(stat.filter).every(([key, value]) => {
31
- const itemValue = key.includes('.')
32
- ? key.split('.').reduce((obj, k) => obj?.[k], item)
33
- : item[key]
34
- return itemValue === value
35
- })
36
- }).length
37
- default:
38
- return 0
39
- }
40
- }
41
-
42
- return (
43
- <div className="grid grid-cols-1 gap-5 sm:grid-cols-2 lg:grid-cols-4">
44
- {stats.map((stat, index) => {
45
- const IconComponent = (Icons as Record<string, React.ComponentType<{ className?: string }>>)[stat.icon] || Icons.Box
46
- const value = loading ? '-' : calculateStat(stat)
47
-
48
- return (
49
- <Card key={index}>
50
- <CardContent className="p-5">
51
- <div className="flex items-center">
52
- <div className={`flex-shrink-0 rounded-md p-3 ${colorMap[stat.color] || colorMap.gray}`}>
53
- <IconComponent className="h-6 w-6" />
54
- </div>
55
- <div className="ml-5 w-0 flex-1">
56
- <p className="text-sm font-medium text-muted-foreground truncate">
57
- {stat.title}
58
- </p>
59
- <p className="text-2xl font-semibold text-foreground">
60
- {typeof value === 'number' ? value.toLocaleString() : value}
61
- </p>
62
- </div>
63
- </div>
64
- </CardContent>
65
- </Card>
66
- )
67
- })}
68
- </div>
69
- )
70
- }
@@ -1,174 +0,0 @@
1
- import React from 'react'
2
- import { useNavigate } from 'react-router-dom'
3
- import { EntityColumn } from '../../types/types'
4
- import { formatDateTime } from '../../lib/utils'
5
- import {
6
- Table,
7
- TableBody,
8
- TableCell,
9
- TableHead,
10
- TableHeader,
11
- TableRow,
12
- } from '../ui/table'
13
- import { Card, CardContent } from '../ui/card'
14
- import { Button } from '../ui/button'
15
- import { Skeleton } from '../ui/skeleton'
16
- import { Badge } from '../ui/badge'
17
- import * as Icons from 'lucide-react'
18
-
19
- interface DataTableProps {
20
- columns: EntityColumn[]
21
- data: any[]
22
- loading?: boolean
23
- error?: string | null
24
- onRetry?: () => void
25
- sort: { field: string; direction: 'asc' | 'desc' }
26
- onSort: (sort: { field: string; direction: 'asc' | 'desc' }) => void
27
- entity: string
28
- emptyMessage: string
29
- emptyIcon: string
30
- }
31
-
32
- export function DataTable({
33
- columns,
34
- data,
35
- loading,
36
- error,
37
- onRetry,
38
- sort,
39
- onSort,
40
- entity,
41
- emptyMessage,
42
- emptyIcon
43
- }: DataTableProps) {
44
- const navigate = useNavigate()
45
- const EmptyIconComponent = (Icons as Record<string, React.ComponentType<{ className?: string }>>)[emptyIcon] || Icons.Box
46
-
47
- const handleSort = (key: string) => {
48
- if (sort.field === key) {
49
- onSort({
50
- field: key,
51
- direction: sort.direction === 'asc' ? 'desc' : 'asc'
52
- })
53
- } else {
54
- onSort({ field: key, direction: 'asc' })
55
- }
56
- }
57
-
58
- const getSortIcon = (key: string) => {
59
- if (sort.field !== key) {
60
- return <Icons.ArrowUpDown className="h-4 w-4 text-muted-foreground" />
61
- }
62
- return sort.direction === 'asc'
63
- ? <Icons.ArrowUp className="h-4 w-4 text-primary" />
64
- : <Icons.ArrowDown className="h-4 w-4 text-primary" />
65
- }
66
-
67
- const renderCell = (column: EntityColumn, row: any) => {
68
- const value = column.key.includes('.')
69
- ? column.key.split('.').reduce((obj, k) => obj?.[k], row)
70
- : row[column.key]
71
-
72
- if (column.type === 'timestamp' && value) {
73
- return formatDateTime(value)
74
- }
75
-
76
- if (column.type === 'badge' && column.badgeColors) {
77
- const colorClass = column.badgeColors[value?.toString()] || 'bg-muted text-muted-foreground'
78
- return (
79
- <Badge variant="secondary" className={colorClass}>
80
- {value?.toString() || 'Unknown'}
81
- </Badge>
82
- )
83
- }
84
-
85
- if (column.maxLength && typeof value === 'string' && value.length > column.maxLength) {
86
- return value.substring(0, column.maxLength) + '...'
87
- }
88
-
89
- return value?.toString() || '-'
90
- }
91
-
92
- const handleRowClick = (row: any) => {
93
- navigate(`/spine-framework/admin/runtime/${entity}/${row.id}`)
94
- }
95
-
96
- if (loading) {
97
- return (
98
- <Card>
99
- <CardContent className="p-8 space-y-4">
100
- <Skeleton className="h-8 w-full" />
101
- <Skeleton className="h-8 w-full" />
102
- <Skeleton className="h-8 w-3/4" />
103
- </CardContent>
104
- </Card>
105
- )
106
- }
107
-
108
- if (error) {
109
- return (
110
- <Card>
111
- <CardContent className="p-8 text-center">
112
- <p className="text-destructive">Error: {error}</p>
113
- {onRetry && (
114
- <Button onClick={onRetry} variant="outline" className="mt-4">
115
- Retry
116
- </Button>
117
- )}
118
- </CardContent>
119
- </Card>
120
- )
121
- }
122
-
123
- if (!data || data.length === 0) {
124
- return (
125
- <Card>
126
- <CardContent className="p-8 text-center">
127
- <EmptyIconComponent className="mx-auto h-12 w-12 text-muted-foreground" />
128
- <h3 className="mt-2 text-sm font-medium text-foreground">{emptyMessage}</h3>
129
- <p className="mt-1 text-sm text-muted-foreground">
130
- Try adjusting your filters or create a new record
131
- </p>
132
- </CardContent>
133
- </Card>
134
- )
135
- }
136
-
137
- return (
138
- <Card>
139
- <Table>
140
- <TableHeader>
141
- <TableRow>
142
- {columns.map((column) => (
143
- <TableHead
144
- key={column.key}
145
- className={column.sortable ? 'cursor-pointer' : ''}
146
- onClick={() => column.sortable && handleSort(column.key)}
147
- >
148
- <div className="flex items-center gap-1">
149
- {column.label}
150
- {column.sortable && getSortIcon(column.key)}
151
- </div>
152
- </TableHead>
153
- ))}
154
- </TableRow>
155
- </TableHeader>
156
- <TableBody>
157
- {data.map((row) => (
158
- <TableRow
159
- key={row.id}
160
- className="cursor-pointer"
161
- onClick={() => handleRowClick(row)}
162
- >
163
- {columns.map((column) => (
164
- <TableCell key={column.key}>
165
- {renderCell(column, row)}
166
- </TableCell>
167
- ))}
168
- </TableRow>
169
- ))}
170
- </TableBody>
171
- </Table>
172
- </Card>
173
- )
174
- }
@@ -1,134 +0,0 @@
1
- /**
2
- * @module src/components/runtime/SchemaDetailForm
3
- * @audience installer
4
- * @layer frontend-component
5
- * @stability stable
6
- *
7
- * Renders a `DetailView`'s sections as a schema-driven form. Each
8
- * `DetailViewSection` becomes a white card containing a `SchemaFields`
9
- * grid. Field definitions come from `DesignSchema.fields`; display widget
10
- * overrides come from the view's per-field `ViewFieldConfig.display_type`.
11
- *
12
- * **Field source resolution:**
13
- * - Field schema (`data_type`, `required`, `validation`, etc.) →
14
- * `schema.fields[fieldName]`
15
- * - Display widget override → `view.sections[n].fields[fieldName].display_type`
16
- * - `system` fields read from `record[fieldName]`; custom fields read
17
- * from `record.data[fieldName]` (split handled upstream by `DataDetailPage`)
18
- *
19
- * **Read vs edit rendering:** passes `readonly={!isEditing}` to `SchemaFields`
20
- * so all field components switch between display and input mode.
21
- *
22
- * @seeAlso src/components/shared/SchemaFields.tsx
23
- * @seeAlso src/types/types.ts (DesignSchema, DetailView)
24
- * @seeAlso src/components/runtime/DataDetailPage.tsx (parent, owns form state)
25
- */
26
-
27
- import { DesignSchema, DetailView, DetailViewSection, FieldDefinition } from '../../types/types'
28
- import { SchemaFields } from '../shared/SchemaFields'
29
-
30
- /**
31
- * Props for `SchemaDetailForm`.
32
- *
33
- * @prop schema - Full `DesignSchema` for field definitions and permissions
34
- * @prop view - The `default_detail` `DetailView` from the schema
35
- * @prop record - Raw fetched record (used in read-only mode)
36
- * @prop isEditing - If true, renders input fields; false = read-only display
37
- * @prop isCreating - If true, skips reading from `record` (no record yet)
38
- * @prop permissions - Per-field `{ read, write }` map from `useEntityRecord`
39
- * @prop formData - Controlled values for all fields (owned by `DataDetailPage`)
40
- * @prop onFieldChange - Callback to update a single field value
41
- */
42
- interface SchemaDetailFormProps {
43
- schema: DesignSchema
44
- view: DetailView
45
- record: any
46
- isEditing: boolean
47
- isCreating: boolean
48
- permissions: Record<string, { read: boolean; write: boolean }>
49
- formData: Record<string, any>
50
- onFieldChange: (key: string, value: any) => void
51
- }
52
-
53
- /**
54
- * Renders a schema-defined `DetailView` as a sectioned form.
55
- *
56
- * @param props - `SchemaDetailFormProps`
57
- * @returns One card per `DetailViewSection`, or an empty-state message
58
- * @sideEffects none (pure rendering)
59
- */
60
- export function SchemaDetailForm({
61
- schema,
62
- view,
63
- record,
64
- isEditing,
65
- isCreating,
66
- permissions,
67
- formData,
68
- onFieldChange
69
- }: SchemaDetailFormProps) {
70
-
71
- const renderSection = (section: DetailViewSection, sectionIndex: number) => {
72
- const fieldNames = Array.isArray(section.fields) ? section.fields : Object.keys(section.fields || {})
73
- const sectionFields = fieldNames.map((fieldName: string) => {
74
- const fieldDef = schema.fields[fieldName]
75
- if (!fieldDef) return null
76
-
77
- return {
78
- name: fieldName,
79
- label: fieldDef.label,
80
- data_type: fieldDef.data_type,
81
- required: fieldDef.required,
82
- validation: fieldDef.validation,
83
- options: fieldDef.options,
84
- permissions: fieldDef.permissions,
85
- system: fieldDef.system
86
- } as FieldDefinition
87
- }).filter((field): field is NonNullable<typeof field> => field !== null)
88
-
89
- // Build display_type map from view config — keeps field definitions clean
90
- const displayTypes: Record<string, string> = {}
91
- if (!Array.isArray(section.fields)) {
92
- Object.entries(section.fields || {}).forEach(([fieldName, viewConfig]: [string, any]) => {
93
- if (viewConfig.display_type) {
94
- displayTypes[fieldName] = viewConfig.display_type
95
- }
96
- })
97
- }
98
-
99
- if (sectionFields.length === 0) return null
100
-
101
- return (
102
- <div key={sectionIndex} className="bg-white shadow rounded-lg p-6">
103
- <h3 className="text-lg font-medium text-slate-900 mb-4">
104
- {section.title}
105
- </h3>
106
-
107
- <SchemaFields
108
- fields={sectionFields}
109
- data={isCreating || isEditing ? formData : (record || {})}
110
- readonly={!isEditing}
111
- twoColumn={false}
112
- onChange={onFieldChange}
113
- displayTypes={displayTypes}
114
- />
115
- </div>
116
- )
117
- }
118
-
119
- if (!view.sections || view.sections.length === 0) {
120
- return (
121
- <div className="bg-white shadow rounded-lg p-6">
122
- <div className="text-center py-8">
123
- <p className="text-slate-500">No fields configured for this view</p>
124
- </div>
125
- </div>
126
- )
127
- }
128
-
129
- return (
130
- <div className="space-y-6">
131
- {view.sections.map((section, index) => renderSection(section, index))}
132
- </div>
133
- )
134
- }
@@ -1,18 +0,0 @@
1
- /**
2
- * @module src/components/runtime
3
- * @audience installer
4
- * @layer frontend-component
5
- * @stability stable
6
- *
7
- * Barrel export for all schema-driven runtime page components.
8
- * Import from this module to get type-safe access to all runtime UI primitives.
9
- */
10
-
11
- export { DataListPage } from './DataListPage'
12
- export { DataDetailPage } from './DataDetailPage'
13
- export { DataHeader } from './DataHeader'
14
- export { DataStats } from './DataStats'
15
- export { DataFilters } from './DataFilters'
16
- export { DataTable } from './DataTable'
17
- export { DataDetailHeader } from './DataDetailHeader'
18
- export { SchemaDetailForm } from './SchemaDetailForm'
@@ -1,29 +0,0 @@
1
- "use client"
2
-
3
- import { Label } from "./ui/label"
4
- import {
5
- SidebarGroup,
6
- SidebarGroupContent,
7
- SidebarInput,
8
- } from "./ui/sidebar"
9
- import { SearchIcon } from "lucide-react"
10
-
11
- export function SearchForm({ ...props }: React.ComponentProps<"form">) {
12
- return (
13
- <form {...props}>
14
- <SidebarGroup className="py-0">
15
- <SidebarGroupContent className="relative">
16
- <Label htmlFor="search" className="sr-only">
17
- Search
18
- </Label>
19
- <SidebarInput
20
- id="search"
21
- placeholder="Search the docs..."
22
- className="pl-8"
23
- />
24
- <SearchIcon className="pointer-events-none absolute top-1/2 left-2 size-4 -translate-y-1/2 opacity-50 select-none" />
25
- </SidebarGroupContent>
26
- </SidebarGroup>
27
- </form>
28
- )
29
- }