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,295 +0,0 @@
1
- /**
2
- * @module src/pages/admin/TypesPage
3
- * @audience installer
4
- * @layer frontend-page
5
- * @stability stable
6
- *
7
- * Admin list page for item/account/person types. Fetches all types via
8
- * `/api/types?action=list`, then applies client-side search, category
9
- * filter (`all` | `system` | `custom` | `active`), and sort. Renders
10
- * inside `AdminListPage` with four stat cards and a sortable table.
11
- * Row clicks navigate to `/spine-framework/admin/configs/types/:id`.
12
- *
13
- * @seeAlso src/components/admin/AdminListPage.tsx
14
- * @seeAlso src/pages/admin/TypeDetailPage.tsx
15
- */
16
-
17
- import React, { useState } from 'react'
18
- import { useApi } from '../../hooks/useApi'
19
- import { apiFetch } from '../../lib/api'
20
- import {
21
- Plus,
22
- Box,
23
- FileText,
24
- Calendar,
25
- Settings,
26
- CheckCircle
27
- } from 'lucide-react'
28
- import { LoadingSpinner } from '../../components/ui/LoadingSpinner'
29
- import { Button } from '../../components/ui/button'
30
- import { AdminListPage } from '../../components/admin/AdminListPage'
31
- import { SortableTableHeader } from '../../components/admin/SortableTableHeader'
32
- import { formatDateTime } from '../../lib/utils'
33
-
34
- interface Type {
35
- id: string
36
- name: string
37
- slug: string
38
- kind: string
39
- description?: string
40
- icon?: string
41
- color?: string
42
- schema: {
43
- fields: Record<string, {
44
- type: string
45
- label?: string
46
- required?: boolean
47
- options?: string[]
48
- }>
49
- }
50
- ownership: string
51
- is_active: boolean
52
- created_at: string
53
- updated_at: string
54
- app_id?: string | null
55
- app?: any
56
- }
57
-
58
- export function TypesPage() {
59
- const [searchTerm, setSearchTerm] = useState('')
60
- const [selectedCategory, setSelectedCategory] = useState('all')
61
- const [sortKey, setSortKey] = useState('name')
62
- const [sortDirection, setSortDirection] = useState<'asc' | 'desc'>('asc')
63
-
64
- // Fetch types from API
65
- const { data: types, loading, error, refetch } = useApi<Type[]>(
66
- async ({ signal }: { signal?: AbortSignal }) => {
67
- const response = await apiFetch('/api/types?action=list', { signal })
68
- if (!response.ok) throw new Error('Failed to fetch types')
69
- const result = await response.json()
70
- return result.data || []
71
- },
72
- { immediate: true }
73
- )
74
-
75
- const categories = [
76
- { value: 'all', label: 'All Types' },
77
- { value: 'system', label: 'System Types' },
78
- { value: 'custom', label: 'Custom Types' },
79
- { value: 'active', label: 'Active Only' },
80
- ]
81
-
82
- const filteredTypes = (types || []).filter(type => {
83
- const matchesSearch = type.name.toLowerCase().includes(searchTerm.toLowerCase()) ||
84
- (type.description && type.description.toLowerCase().includes(searchTerm.toLowerCase()))
85
-
86
- let matchesCategory = true
87
- if (selectedCategory === 'system') {
88
- matchesCategory = type.ownership === 'system'
89
- } else if (selectedCategory === 'custom') {
90
- matchesCategory = type.ownership !== 'system'
91
- } else if (selectedCategory === 'active') {
92
- matchesCategory = type.is_active
93
- }
94
-
95
- return matchesSearch && matchesCategory
96
- })
97
-
98
- // Helper functions
99
- const getCategoryBadgeColor = (type: Type) => {
100
- if (type.ownership === 'system') {
101
- return 'bg-purple-50 text-purple-700'
102
- }
103
- return 'bg-primary/10 text-primary'
104
- }
105
-
106
- const getStatusBadgeColor = (isActive: boolean) => {
107
- return isActive
108
- ? 'bg-green-50 text-green-700'
109
- : 'bg-muted text-muted-foreground'
110
- }
111
-
112
- const handleSort = (key: string) => {
113
- if (sortKey === key) {
114
- setSortDirection(sortDirection === 'asc' ? 'desc' : 'asc')
115
- } else {
116
- setSortKey(key)
117
- setSortDirection('asc')
118
- }
119
- }
120
-
121
- const handleRowClick = (type: Type) => {
122
- window.location.href = `/spine-framework/admin/configs/types/${type.id}`
123
- }
124
-
125
- // Sort types
126
- const sortedTypes = [...(filteredTypes || [])].sort((a, b) => {
127
- let aValue: any = a[sortKey as keyof Type]
128
- let bValue: any = b[sortKey as keyof Type]
129
-
130
- if (typeof aValue === 'string') {
131
- return sortDirection === 'asc'
132
- ? aValue.localeCompare(bValue)
133
- : bValue.localeCompare(aValue)
134
- }
135
-
136
- if (typeof aValue === 'number') {
137
- return sortDirection === 'asc' ? aValue - bValue : bValue - aValue
138
- }
139
-
140
- return 0
141
- })
142
-
143
- const statsCards = [
144
- {
145
- title: 'Total Types',
146
- value: (types || []).length,
147
- icon: Settings,
148
- iconColor: 'text-primary',
149
- },
150
- {
151
- title: 'Custom Types',
152
- value: (types || []).filter(t => t.ownership !== 'system').length,
153
- icon: Box,
154
- iconColor: 'text-green-600',
155
- },
156
- {
157
- title: 'Active Types',
158
- value: (types || []).filter(t => t.is_active).length,
159
- icon: CheckCircle,
160
- iconColor: 'text-orange-600',
161
- },
162
- {
163
- title: 'Total Fields',
164
- value: (types || []).reduce((sum, t) => sum + Object.keys(t.schema?.fields || {}).length, 0),
165
- icon: FileText,
166
- iconColor: 'text-purple-600',
167
- }
168
- ]
169
-
170
- const filters = [
171
- {
172
- label: 'Category',
173
- value: selectedCategory,
174
- options: categories,
175
- onChange: setSelectedCategory
176
- }
177
- ]
178
-
179
- return (
180
- <AdminListPage
181
- title="Types"
182
- description="Manage item types and their schemas"
183
- newButtonText="New Type"
184
- newButtonHref="/spine-framework/admin/configs/types/new"
185
- statsCards={statsCards}
186
- searchPlaceholder="Search types..."
187
- searchValue={searchTerm}
188
- onSearchChange={setSearchTerm}
189
- filters={filters}
190
- loading={loading}
191
- error={error}
192
- onRetry={refetch}
193
- emptyMessage="No types found"
194
- emptyIcon={Settings}
195
- >
196
- {sortedTypes.length === 0 ? (
197
- <div className="p-8 text-center">
198
- <Settings className="mx-auto h-12 w-12 text-muted-foreground" />
199
- <h3 className="mt-2 text-sm font-medium text-foreground">No types found</h3>
200
- <p className="mt-1 text-sm text-muted-foreground">
201
- Try adjusting your search or filters
202
- </p>
203
- </div>
204
- ) : (
205
- <table className="min-w-full divide-y divide-border">
206
- <thead className="bg-muted">
207
- <tr>
208
- <SortableTableHeader
209
- title="Type"
210
- sortKey="name"
211
- currentSortKey={sortKey}
212
- currentSortDirection={sortDirection}
213
- onSort={handleSort}
214
- />
215
- <SortableTableHeader
216
- title="Category"
217
- sortKey="ownership"
218
- currentSortKey={sortKey}
219
- currentSortDirection={sortDirection}
220
- onSort={handleSort}
221
- />
222
- <SortableTableHeader
223
- title="Status"
224
- sortKey="is_active"
225
- currentSortKey={sortKey}
226
- currentSortDirection={sortDirection}
227
- onSort={handleSort}
228
- />
229
- <SortableTableHeader
230
- title="Fields"
231
- sortKey="schema"
232
- currentSortKey={sortKey}
233
- currentSortDirection={sortDirection}
234
- onSort={handleSort}
235
- />
236
- <SortableTableHeader
237
- title="Created"
238
- sortKey="created_at"
239
- currentSortKey={sortKey}
240
- currentSortDirection={sortDirection}
241
- onSort={handleSort}
242
- />
243
- <th className="relative px-6 py-3">
244
- <span className="sr-only">Actions</span>
245
- </th>
246
- </tr>
247
- </thead>
248
- <tbody className="bg-background divide-y divide-border">
249
- {sortedTypes.map((type) => (
250
- <tr
251
- key={type.id}
252
- className="hover:bg-muted/50 cursor-pointer transition-colors"
253
- onClick={() => handleRowClick(type)}
254
- >
255
- <td className="px-6 py-4 whitespace-nowrap">
256
- <div>
257
- <div className="font-medium text-foreground">
258
- <span className="text-primary hover:text-primary/80">
259
- {type.name}
260
- </span>
261
- </div>
262
- <div className="text-sm text-muted-foreground">
263
- {type.description || type.slug}
264
- <span className="mx-1.5 text-muted-foreground">&middot;</span>
265
- {Object.keys(type.schema?.fields || {}).length} fields
266
- </div>
267
- </div>
268
- </td>
269
- <td className="px-6 py-4 whitespace-nowrap">
270
- <span className={`inline-flex px-2 py-0.5 text-xs font-medium rounded-md ${getCategoryBadgeColor(type)}`}>
271
- {type.ownership === 'system' ? 'System' : 'Custom'}
272
- </span>
273
- </td>
274
- <td className="px-6 py-4 whitespace-nowrap">
275
- <span className={`inline-flex px-2 py-0.5 text-xs font-medium rounded-md ${getStatusBadgeColor(type.is_active)}`}>
276
- {type.is_active ? 'Active' : 'Inactive'}
277
- </span>
278
- </td>
279
- <td className="px-6 py-4 whitespace-nowrap text-sm text-muted-foreground">
280
- {Object.keys(type.schema?.fields || {}).length}
281
- </td>
282
- <td className="px-6 py-4 whitespace-nowrap text-sm text-muted-foreground">
283
- {formatDateTime(type.created_at)}
284
- </td>
285
- <td className="px-6 py-4 whitespace-nowrap text-right">
286
- <span className="text-muted-foreground">→</span>
287
- </td>
288
- </tr>
289
- ))}
290
- </tbody>
291
- </table>
292
- )}
293
- </AdminListPage>
294
- )
295
- }
@@ -1,187 +0,0 @@
1
- /**
2
- * @module src/pages/auth/LoginPage
3
- * @audience installer
4
- * @layer frontend-page
5
- * @stability stable
6
- *
7
- * Unauthenticated login page. Renders a centred card with email/password
8
- * inputs. On submit, calls `AuthContext.login(email, password)` and
9
- * navigates to `/dashboard` on success. Displays inline error text on
10
- * failure. Shows a `LoadingSpinner` inside the submit button while the
11
- * auth request is in-flight.
12
- *
13
- * @seeAlso src/contexts/AuthContext.tsx (login implementation)
14
- */
15
-
16
- import React, { useState, useEffect } from 'react'
17
- import { Link, useNavigate } from 'react-router-dom'
18
- import { useAuth } from '../../contexts/AuthContext'
19
- import { useAppsRegistry } from '../../contexts/AppContext'
20
- import { LoadingSpinner } from '../../components/ui/LoadingSpinner'
21
-
22
- export function LoginPage() {
23
- const [email, setEmail] = useState('')
24
- const [password, setPassword] = useState('')
25
- const [error, setError] = useState('')
26
- const [isLoading, setIsLoading] = useState(false)
27
-
28
- const { user, login } = useAuth()
29
- const navigate = useNavigate()
30
- const { routableApps: apps, loading } = useAppsRegistry()
31
-
32
- // Redirect logged-in users to their qualified app
33
- useEffect(() => {
34
- if (user && !loading) {
35
- // System admin gets special handling
36
- if (user.roles?.includes('system_admin')) {
37
- navigate('/spine-framework/admin', { replace: true })
38
- return
39
- }
40
-
41
- // Find app matching user's role, or fall back to first routable app
42
- const userRole = user.roles?.[0]
43
- const routableApps = apps.filter(a => a.route_prefix && a.renderer !== 'none')
44
- const matchingApp = (userRole && routableApps.find(app => app.min_role === userRole))
45
- || routableApps[0]
46
- if (matchingApp?.route_prefix) {
47
- navigate(matchingApp.route_prefix, { replace: true })
48
- return
49
- }
50
-
51
- // No routable apps installed — stay on login
52
- }
53
- }, [user, loading, apps, navigate])
54
-
55
- // Show loading while checking auth state (but allow redirect logic to run)
56
- if (loading) {
57
- return (
58
- <div className="min-h-screen flex items-center justify-center bg-slate-50">
59
- <div className="text-center">
60
- <LoadingSpinner className="w-8 h-8 mx-auto mb-4" />
61
- <p className="text-slate-600">Checking authentication...</p>
62
- </div>
63
- </div>
64
- )
65
- }
66
-
67
- const handleSubmit = async (e: React.FormEvent) => {
68
- e.preventDefault()
69
- setError('')
70
- setIsLoading(true)
71
-
72
- try {
73
- console.log('Attempting login...')
74
- await login(email, password)
75
- // Redirect will be handled by useEffect above
76
- console.log('Login successful, redirect will be handled by useEffect...')
77
- } catch (err: any) {
78
- console.error('Login error:', err)
79
- setError(err.message || 'Login failed')
80
- } finally {
81
- console.log('Login process completed, setting loading to false')
82
- setIsLoading(false)
83
- }
84
- }
85
-
86
- return (
87
- <div className="min-h-screen flex items-center justify-center bg-slate-50 py-12 px-4 sm:px-6 lg:px-8">
88
- <div className="max-w-md w-full space-y-8">
89
- <div>
90
- <div className="mx-auto h-12 w-12 flex items-center justify-center rounded-full bg-slate-900">
91
- <span className="text-white font-bold text-xl">S</span>
92
- </div>
93
- <h2 className="mt-6 text-center text-3xl font-extrabold text-slate-900">
94
- Sign in to Spine
95
- </h2>
96
- <p className="mt-2 text-center text-sm text-slate-600">
97
- Or{' '}
98
- <Link to="/register" className="font-medium text-accent-blue hover:text-accent-blue-light">
99
- create a new account
100
- </Link>
101
- </p>
102
- </div>
103
-
104
- <form className="mt-8 space-y-6" onSubmit={handleSubmit}>
105
- {error && (
106
- <div className="rounded-md bg-red-50 p-4">
107
- <div className="text-sm text-red-800">{error}</div>
108
- </div>
109
- )}
110
-
111
- <div className="space-y-4">
112
- <div>
113
- <label htmlFor="email" className="block text-sm font-medium text-slate-700">
114
- Email address
115
- </label>
116
- <input
117
- id="email"
118
- name="email"
119
- type="email"
120
- autoComplete="email"
121
- required
122
- value={email}
123
- onChange={(e) => setEmail(e.target.value)}
124
- className="mt-1 block w-full px-3 py-2 border border-slate-300 rounded-[5px] shadow-sm placeholder-slate-400 focus:outline-none focus:ring-accent-blue focus:border-accent-blue sm:text-sm"
125
- placeholder="Enter your email"
126
- />
127
- </div>
128
-
129
- <div>
130
- <label htmlFor="password" className="block text-sm font-medium text-slate-700">
131
- Password
132
- </label>
133
- <input
134
- id="password"
135
- name="password"
136
- type="password"
137
- autoComplete="current-password"
138
- required
139
- value={password}
140
- onChange={(e) => setPassword(e.target.value)}
141
- className="mt-1 block w-full px-3 py-2 border border-slate-300 rounded-[5px] shadow-sm placeholder-slate-400 focus:outline-none focus:ring-accent-blue focus:border-accent-blue sm:text-sm"
142
- placeholder="Enter your password"
143
- />
144
- </div>
145
- </div>
146
-
147
- <div className="flex items-center justify-between">
148
- <div className="flex items-center">
149
- <input
150
- id="remember-me"
151
- name="remember-me"
152
- type="checkbox"
153
- className="h-4 w-4 text-accent-blue focus:ring-accent-blue border-slate-300 rounded"
154
- />
155
- <label htmlFor="remember-me" className="ml-2 block text-sm text-slate-900">
156
- Remember me
157
- </label>
158
- </div>
159
-
160
- <div className="text-sm">
161
- <Link to="/forgot-password" className="font-medium text-accent-blue hover:text-accent-blue-light">
162
- Forgot your password?
163
- </Link>
164
- </div>
165
- </div>
166
-
167
- <div>
168
- <button
169
- type="submit"
170
- disabled={isLoading}
171
- className="group relative w-full flex justify-center py-2 px-4 border border-transparent rounded-[5px] shadow-sm text-sm font-medium text-white bg-slate-900 hover:bg-slate-800 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-accent-blue disabled:opacity-50 disabled:cursor-not-allowed"
172
- >
173
- {isLoading ? (
174
- <>
175
- <LoadingSpinner size="sm" />
176
- <span className="ml-2">Signing in...</span>
177
- </>
178
- ) : (
179
- 'Sign in'
180
- )}
181
- </button>
182
- </div>
183
- </form>
184
- </div>
185
- </div>
186
- )
187
- }
@@ -1,163 +0,0 @@
1
- /**
2
- * @module src/pages/auth/RegisterPage
3
- * @audience installer
4
- * @layer frontend-page
5
- * @stability stable
6
- *
7
- * Self-registration page. Renders a centred card with email/password/name
8
- * inputs. On submit, calls Supabase signUp and navigates to /login with
9
- * a confirmation message.
10
- */
11
-
12
- import React, { useState } from 'react'
13
- import { Link, useNavigate } from 'react-router-dom'
14
- import { useAuth } from '../../contexts/AuthContext'
15
- import { LoadingSpinner } from '../../components/ui/LoadingSpinner'
16
- import { supabase } from '../../lib/supabase'
17
-
18
- export function RegisterPage() {
19
- const [email, setEmail] = useState('')
20
- const [password, setPassword] = useState('')
21
- const [fullName, setFullName] = useState('')
22
- const [error, setError] = useState('')
23
- const [success, setSuccess] = useState('')
24
- const [isLoading, setIsLoading] = useState(false)
25
-
26
- const navigate = useNavigate()
27
-
28
- const handleSubmit = async (e: React.FormEvent) => {
29
- e.preventDefault()
30
- setError('')
31
- setSuccess('')
32
- setIsLoading(true)
33
-
34
- try {
35
- const { error: signUpError } = await supabase.auth.signUp({
36
- email,
37
- password,
38
- options: {
39
- data: {
40
- full_name: fullName,
41
- },
42
- },
43
- })
44
-
45
- if (signUpError) {
46
- setError(signUpError.message)
47
- return
48
- }
49
-
50
- setSuccess('Account created! Check your email for a confirmation link.')
51
- setTimeout(() => navigate('/login'), 3000)
52
- } catch (err: any) {
53
- setError(err.message || 'Registration failed')
54
- } finally {
55
- setIsLoading(false)
56
- }
57
- }
58
-
59
- return (
60
- <div className="min-h-screen flex items-center justify-center bg-slate-50 py-12 px-4 sm:px-6 lg:px-8">
61
- <div className="max-w-md w-full space-y-8">
62
- <div>
63
- <div className="mx-auto h-12 w-12 flex items-center justify-center rounded-full bg-slate-900">
64
- <span className="text-white font-bold text-xl">S</span>
65
- </div>
66
- <h2 className="mt-6 text-center text-3xl font-extrabold text-slate-900">
67
- Create your account
68
- </h2>
69
- <p className="mt-2 text-center text-sm text-slate-600">
70
- Already have an account?{' '}
71
- <Link to="/login" className="font-medium text-accent-blue hover:text-accent-blue-light">
72
- Sign in
73
- </Link>
74
- </p>
75
- </div>
76
-
77
- <form className="mt-8 space-y-6" onSubmit={handleSubmit}>
78
- {error && (
79
- <div className="rounded-md bg-red-50 p-4">
80
- <div className="text-sm text-red-800">{error}</div>
81
- </div>
82
- )}
83
-
84
- {success && (
85
- <div className="rounded-md bg-green-50 p-4">
86
- <div className="text-sm text-green-800">{success}</div>
87
- </div>
88
- )}
89
-
90
- <div className="space-y-4">
91
- <div>
92
- <label htmlFor="fullName" className="block text-sm font-medium text-slate-700">
93
- Full name
94
- </label>
95
- <input
96
- id="fullName"
97
- name="fullName"
98
- type="text"
99
- required
100
- value={fullName}
101
- onChange={(e) => setFullName(e.target.value)}
102
- className="mt-1 block w-full px-3 py-2 border border-slate-300 rounded-[5px] shadow-sm placeholder-slate-400 focus:outline-none focus:ring-accent-blue focus:border-accent-blue sm:text-sm"
103
- placeholder="Enter your full name"
104
- />
105
- </div>
106
-
107
- <div>
108
- <label htmlFor="email" className="block text-sm font-medium text-slate-700">
109
- Email address
110
- </label>
111
- <input
112
- id="email"
113
- name="email"
114
- type="email"
115
- autoComplete="email"
116
- required
117
- value={email}
118
- onChange={(e) => setEmail(e.target.value)}
119
- className="mt-1 block w-full px-3 py-2 border border-slate-300 rounded-[5px] shadow-sm placeholder-slate-400 focus:outline-none focus:ring-accent-blue focus:border-accent-blue sm:text-sm"
120
- placeholder="Enter your email"
121
- />
122
- </div>
123
-
124
- <div>
125
- <label htmlFor="password" className="block text-sm font-medium text-slate-700">
126
- Password
127
- </label>
128
- <input
129
- id="password"
130
- name="password"
131
- type="password"
132
- autoComplete="new-password"
133
- required
134
- minLength={6}
135
- value={password}
136
- onChange={(e) => setPassword(e.target.value)}
137
- className="mt-1 block w-full px-3 py-2 border border-slate-300 rounded-[5px] shadow-sm placeholder-slate-400 focus:outline-none focus:ring-accent-blue focus:border-accent-blue sm:text-sm"
138
- placeholder="Choose a password (min 6 characters)"
139
- />
140
- </div>
141
- </div>
142
-
143
- <div>
144
- <button
145
- type="submit"
146
- disabled={isLoading}
147
- className="group relative w-full flex justify-center py-2 px-4 border border-transparent rounded-[5px] shadow-sm text-sm font-medium text-white bg-slate-900 hover:bg-slate-800 focus:outline-none focus:ring-2 focus:ring-offset-2 focus:ring-accent-blue disabled:opacity-50 disabled:cursor-not-allowed"
148
- >
149
- {isLoading ? (
150
- <>
151
- <LoadingSpinner size="sm" />
152
- <span className="ml-2">Creating account...</span>
153
- </>
154
- ) : (
155
- 'Create account'
156
- )}
157
- </button>
158
- </div>
159
- </form>
160
- </div>
161
- </div>
162
- )
163
- }
@@ -1,17 +0,0 @@
1
- import { Layout } from '../../components/layout/Layout'
2
-
3
- export function APIPage() {
4
- return (
5
- <Layout>
6
- <div className="p-8 max-w-3xl">
7
- <h1 className="text-2xl font-bold text-slate-900 mb-2">Framework API</h1>
8
- <p className="text-slate-500 mb-6">
9
- Core API endpoints available to all authenticated users and custom applications.
10
- </p>
11
- <div className="bg-amber-50 border border-amber-200 rounded-lg p-4 text-sm text-amber-800">
12
- API reference documentation coming soon.
13
- </div>
14
- </div>
15
- </Layout>
16
- )
17
- }
@@ -1,25 +0,0 @@
1
- import { Layout } from '../../components/layout/Layout'
2
-
3
- export function CLIPage() {
4
- return (
5
- <Layout>
6
- <div className="p-8 max-w-3xl">
7
- <h1 className="text-2xl font-bold text-slate-900 mb-2">Framework CLI</h1>
8
- <p className="text-slate-500 mb-6">
9
- The <code className="bg-slate-100 px-1.5 py-0.5 rounded text-slate-800">spine-framework</code> CLI runs locally in your terminal or agentic IDE.
10
- </p>
11
- <div className="bg-slate-50 border border-slate-200 rounded-lg p-4 font-mono text-sm text-slate-700 space-y-1 mb-4">
12
- <div><span className="text-slate-400">$</span> npx spine-framework --help</div>
13
- <div><span className="text-slate-400">$</span> npx spine-framework auth whoami</div>
14
- <div><span className="text-slate-400">$</span> npx spine-framework migrations list</div>
15
- <div><span className="text-slate-400">$</span> npx spine-framework pipelines run &lt;id&gt;</div>
16
- <div><span className="text-slate-400">$</span> npx spine-framework items list --type support_ticket</div>
17
- <div><span className="text-slate-400">$</span> npx spine-framework doctor</div>
18
- </div>
19
- <div className="bg-amber-50 border border-amber-200 rounded-lg p-4 text-sm text-amber-800">
20
- Full CLI reference documentation coming soon.
21
- </div>
22
- </div>
23
- </Layout>
24
- )
25
- }