@nextsparkjs/core 0.1.0-beta.82 → 0.1.0-beta.84

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 (365) hide show
  1. package/dist/components/entities/wrappers/EntityDetailWrapper.d.ts.map +1 -1
  2. package/dist/components/entities/wrappers/EntityDetailWrapper.js +11 -39
  3. package/dist/hooks/useEntityQuery.d.ts.map +1 -1
  4. package/dist/hooks/useEntityQuery.js +21 -3
  5. package/dist/lib/theme/get-default-theme-mode.d.ts +11 -0
  6. package/dist/lib/theme/get-default-theme-mode.d.ts.map +1 -1
  7. package/dist/lib/theme/get-default-theme-mode.js +42 -25
  8. package/dist/styles/classes.json +1 -1
  9. package/dist/types/theme.d.ts +2 -0
  10. package/dist/types/theme.d.ts.map +1 -1
  11. package/package.json +3 -3
  12. package/dist/templates/app/(auth)/forgot-password/page.tsx +0 -216
  13. package/dist/templates/app/(auth)/layout.tsx +0 -51
  14. package/dist/templates/app/(auth)/login/page.tsx +0 -21
  15. package/dist/templates/app/(auth)/reset-password/page.tsx +0 -212
  16. package/dist/templates/app/(auth)/signup/page.tsx +0 -21
  17. package/dist/templates/app/(auth)/verify-email/page.tsx +0 -190
  18. package/dist/templates/app/(public)/[...slug]/page.tsx +0 -378
  19. package/dist/templates/app/(public)/docs/[section]/[page]/page.tsx +0 -90
  20. package/dist/templates/app/(public)/docs/layout.tsx +0 -25
  21. package/dist/templates/app/(public)/docs/page.tsx +0 -81
  22. package/dist/templates/app/(public)/layout.tsx +0 -41
  23. package/dist/templates/app/(public)/page.tsx +0 -19
  24. package/dist/templates/app/403/page.tsx +0 -89
  25. package/dist/templates/app/api/auth/[...all]/route.ts +0 -78
  26. package/dist/templates/app/api/cron/billing/lifecycle/route.ts +0 -98
  27. package/dist/templates/app/api/csp-report/route.ts +0 -175
  28. package/dist/templates/app/api/devtools/config/entities/route.ts +0 -108
  29. package/dist/templates/app/api/devtools/config/theme/route.ts +0 -66
  30. package/dist/templates/app/api/devtools/tests/[...path]/route.ts +0 -130
  31. package/dist/templates/app/api/devtools/tests/route.ts +0 -134
  32. package/dist/templates/app/api/health/route.ts +0 -29
  33. package/dist/templates/app/api/internal/user-metadata/route.ts +0 -36
  34. package/dist/templates/app/api/superadmin/subscriptions/route.ts +0 -310
  35. package/dist/templates/app/api/superadmin/teams/[teamId]/route.ts +0 -286
  36. package/dist/templates/app/api/superadmin/teams/route.ts +0 -188
  37. package/dist/templates/app/api/superadmin/users/[userId]/route.ts +0 -540
  38. package/dist/templates/app/api/superadmin/users/route.ts +0 -323
  39. package/dist/templates/app/api/user/delete-account/route.ts +0 -55
  40. package/dist/templates/app/api/user/plan-flags/route.ts +0 -283
  41. package/dist/templates/app/api/user/profile/route.ts +0 -133
  42. package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +0 -210
  43. package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +0 -331
  44. package/dist/templates/app/api/v1/[entity]/[id]/route.ts +0 -35
  45. package/dist/templates/app/api/v1/[entity]/docs.md +0 -369
  46. package/dist/templates/app/api/v1/[entity]/presets.ts +0 -194
  47. package/dist/templates/app/api/v1/[entity]/route.ts +0 -31
  48. package/dist/templates/app/api/v1/api-keys/[id]/route.ts +0 -303
  49. package/dist/templates/app/api/v1/api-keys/docs.md +0 -101
  50. package/dist/templates/app/api/v1/api-keys/presets.ts +0 -31
  51. package/dist/templates/app/api/v1/api-keys/route.ts +0 -250
  52. package/dist/templates/app/api/v1/auth/docs.md +0 -184
  53. package/dist/templates/app/api/v1/auth/presets.ts +0 -44
  54. package/dist/templates/app/api/v1/auth/signup-with-invite/route.ts +0 -227
  55. package/dist/templates/app/api/v1/billing/cancel/route.ts +0 -206
  56. package/dist/templates/app/api/v1/billing/change-plan/route.ts +0 -97
  57. package/dist/templates/app/api/v1/billing/check-action/route.ts +0 -81
  58. package/dist/templates/app/api/v1/billing/checkout/route.ts +0 -124
  59. package/dist/templates/app/api/v1/billing/docs.md +0 -209
  60. package/dist/templates/app/api/v1/billing/plans/route.ts +0 -85
  61. package/dist/templates/app/api/v1/billing/portal/route.ts +0 -90
  62. package/dist/templates/app/api/v1/billing/presets.ts +0 -121
  63. package/dist/templates/app/api/v1/billing/webhooks/stripe/route.ts +0 -428
  64. package/dist/templates/app/api/v1/blocks/[slug]/route.ts +0 -29
  65. package/dist/templates/app/api/v1/blocks/docs.md +0 -173
  66. package/dist/templates/app/api/v1/blocks/presets.ts +0 -121
  67. package/dist/templates/app/api/v1/blocks/route.ts +0 -45
  68. package/dist/templates/app/api/v1/blocks/validate/route.ts +0 -45
  69. package/dist/templates/app/api/v1/cron/docs.md +0 -116
  70. package/dist/templates/app/api/v1/cron/presets.ts +0 -26
  71. package/dist/templates/app/api/v1/cron/process/route.ts +0 -108
  72. package/dist/templates/app/api/v1/devtools/blocks/route.ts +0 -82
  73. package/dist/templates/app/api/v1/devtools/docs/route.ts +0 -150
  74. package/dist/templates/app/api/v1/devtools/docs.md +0 -204
  75. package/dist/templates/app/api/v1/devtools/features/route.ts +0 -61
  76. package/dist/templates/app/api/v1/devtools/flows/route.ts +0 -61
  77. package/dist/templates/app/api/v1/devtools/presets.ts +0 -113
  78. package/dist/templates/app/api/v1/devtools/scheduled-actions/route.ts +0 -120
  79. package/dist/templates/app/api/v1/devtools/testing/route.ts +0 -82
  80. package/dist/templates/app/api/v1/media/docs.md +0 -117
  81. package/dist/templates/app/api/v1/media/presets.ts +0 -24
  82. package/dist/templates/app/api/v1/media/upload/route.ts +0 -150
  83. package/dist/templates/app/api/v1/patterns/[id]/usages/route.ts +0 -116
  84. package/dist/templates/app/api/v1/plugin/[...path]/route.ts +0 -373
  85. package/dist/templates/app/api/v1/plugin/docs.md +0 -79
  86. package/dist/templates/app/api/v1/plugin/presets.ts +0 -21
  87. package/dist/templates/app/api/v1/plugin/route.ts +0 -96
  88. package/dist/templates/app/api/v1/post-categories/[id]/route.ts +0 -255
  89. package/dist/templates/app/api/v1/post-categories/docs.md +0 -134
  90. package/dist/templates/app/api/v1/post-categories/presets.ts +0 -78
  91. package/dist/templates/app/api/v1/post-categories/route.ts +0 -119
  92. package/dist/templates/app/api/v1/team-invitations/[token]/accept/route.ts +0 -179
  93. package/dist/templates/app/api/v1/team-invitations/[token]/decline/route.ts +0 -120
  94. package/dist/templates/app/api/v1/team-invitations/[token]/route.ts +0 -89
  95. package/dist/templates/app/api/v1/team-invitations/docs.md +0 -88
  96. package/dist/templates/app/api/v1/team-invitations/presets.ts +0 -43
  97. package/dist/templates/app/api/v1/team-invitations/route.ts +0 -114
  98. package/dist/templates/app/api/v1/teams/[teamId]/invitations/route.ts +0 -171
  99. package/dist/templates/app/api/v1/teams/[teamId]/invoices/[invoiceNumber]/route.ts +0 -105
  100. package/dist/templates/app/api/v1/teams/[teamId]/invoices/route.ts +0 -125
  101. package/dist/templates/app/api/v1/teams/[teamId]/members/[memberId]/route.ts +0 -263
  102. package/dist/templates/app/api/v1/teams/[teamId]/members/route.ts +0 -358
  103. package/dist/templates/app/api/v1/teams/[teamId]/route.ts +0 -322
  104. package/dist/templates/app/api/v1/teams/[teamId]/subscription/route.ts +0 -50
  105. package/dist/templates/app/api/v1/teams/[teamId]/usage/[limitSlug]/route.ts +0 -91
  106. package/dist/templates/app/api/v1/teams/docs.md +0 -320
  107. package/dist/templates/app/api/v1/teams/presets.ts +0 -178
  108. package/dist/templates/app/api/v1/teams/route.ts +0 -293
  109. package/dist/templates/app/api/v1/teams/switch/route.ts +0 -88
  110. package/dist/templates/app/api/v1/theme/[...path]/route.ts +0 -361
  111. package/dist/templates/app/api/v1/theme/docs.md +0 -74
  112. package/dist/templates/app/api/v1/theme/presets.ts +0 -21
  113. package/dist/templates/app/api/v1/theme/route.ts +0 -96
  114. package/dist/templates/app/api/v1/users/[id]/meta/[key]/route.ts +0 -363
  115. package/dist/templates/app/api/v1/users/[id]/route.ts +0 -302
  116. package/dist/templates/app/api/v1/users/docs.md +0 -93
  117. package/dist/templates/app/api/v1/users/presets.ts +0 -59
  118. package/dist/templates/app/api/v1/users/route.ts +0 -197
  119. package/dist/templates/app/dashboard/(main)/[entity]/[id]/edit/page.tsx +0 -117
  120. package/dist/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +0 -103
  121. package/dist/templates/app/dashboard/(main)/[entity]/create/page.tsx +0 -95
  122. package/dist/templates/app/dashboard/(main)/[entity]/error.tsx +0 -51
  123. package/dist/templates/app/dashboard/(main)/[entity]/layout.tsx +0 -113
  124. package/dist/templates/app/dashboard/(main)/[entity]/loading.tsx +0 -61
  125. package/dist/templates/app/dashboard/(main)/[entity]/page.tsx +0 -90
  126. package/dist/templates/app/dashboard/(main)/layout.tsx +0 -98
  127. package/dist/templates/app/dashboard/(main)/loading.tsx +0 -5
  128. package/dist/templates/app/dashboard/(main)/page.tsx +0 -201
  129. package/dist/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +0 -114
  130. package/dist/templates/app/dashboard/(main)/patterns/[id]/page.tsx +0 -20
  131. package/dist/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +0 -171
  132. package/dist/templates/app/dashboard/(main)/patterns/create/page.tsx +0 -86
  133. package/dist/templates/app/dashboard/(main)/patterns/page.tsx +0 -444
  134. package/dist/templates/app/dashboard/features/analytics/page.tsx +0 -35
  135. package/dist/templates/app/dashboard/features/automation/page.tsx +0 -35
  136. package/dist/templates/app/dashboard/features/layout.tsx +0 -13
  137. package/dist/templates/app/dashboard/features/loading.tsx +0 -5
  138. package/dist/templates/app/dashboard/features/webhooks/page.tsx +0 -35
  139. package/dist/templates/app/dashboard/layout.tsx +0 -86
  140. package/dist/templates/app/dashboard/permission-denied/page.tsx +0 -29
  141. package/dist/templates/app/dashboard/settings/api-keys/loading.tsx +0 -5
  142. package/dist/templates/app/dashboard/settings/api-keys/page.tsx +0 -513
  143. package/dist/templates/app/dashboard/settings/billing/loading.tsx +0 -5
  144. package/dist/templates/app/dashboard/settings/billing/page.tsx +0 -284
  145. package/dist/templates/app/dashboard/settings/invoices/[invoiceNumber]/page.tsx +0 -222
  146. package/dist/templates/app/dashboard/settings/invoices/loading.tsx +0 -5
  147. package/dist/templates/app/dashboard/settings/invoices/page.tsx +0 -82
  148. package/dist/templates/app/dashboard/settings/layout.tsx +0 -151
  149. package/dist/templates/app/dashboard/settings/loading.tsx +0 -5
  150. package/dist/templates/app/dashboard/settings/notifications/loading.tsx +0 -5
  151. package/dist/templates/app/dashboard/settings/notifications/page.tsx +0 -462
  152. package/dist/templates/app/dashboard/settings/page.tsx +0 -92
  153. package/dist/templates/app/dashboard/settings/password/loading.tsx +0 -5
  154. package/dist/templates/app/dashboard/settings/password/page.tsx +0 -306
  155. package/dist/templates/app/dashboard/settings/plans/loading.tsx +0 -5
  156. package/dist/templates/app/dashboard/settings/plans/page.tsx +0 -40
  157. package/dist/templates/app/dashboard/settings/profile/loading.tsx +0 -5
  158. package/dist/templates/app/dashboard/settings/profile/page.tsx +0 -686
  159. package/dist/templates/app/dashboard/settings/security/loading.tsx +0 -5
  160. package/dist/templates/app/dashboard/settings/security/page.tsx +0 -505
  161. package/dist/templates/app/dashboard/settings/teams/loading.tsx +0 -5
  162. package/dist/templates/app/dashboard/settings/teams/page.tsx +0 -272
  163. package/dist/templates/app/dashboard/settings/teams/permissions/page.tsx +0 -92
  164. package/dist/templates/app/devtools/blocks/[slug]/page.tsx +0 -39
  165. package/dist/templates/app/devtools/blocks/page.tsx +0 -31
  166. package/dist/templates/app/devtools/config/page.tsx +0 -31
  167. package/dist/templates/app/devtools/features/page.tsx +0 -31
  168. package/dist/templates/app/devtools/flows/page.tsx +0 -31
  169. package/dist/templates/app/devtools/layout.tsx +0 -58
  170. package/dist/templates/app/devtools/page.tsx +0 -121
  171. package/dist/templates/app/devtools/scheduled-actions/page.tsx +0 -157
  172. package/dist/templates/app/devtools/style/page.tsx +0 -330
  173. package/dist/templates/app/devtools/tags/page.tsx +0 -31
  174. package/dist/templates/app/devtools/tests/[[...path]]/page.tsx +0 -47
  175. package/dist/templates/app/favicon.ico +0 -0
  176. package/dist/templates/app/globals.css +0 -12
  177. package/dist/templates/app/layout.tsx +0 -96
  178. package/dist/templates/app/public/page.tsx +0 -30
  179. package/dist/templates/app/superadmin/docs/[section]/[page]/page.tsx +0 -92
  180. package/dist/templates/app/superadmin/docs/page.tsx +0 -75
  181. package/dist/templates/app/superadmin/layout.tsx +0 -67
  182. package/dist/templates/app/superadmin/page.tsx +0 -149
  183. package/dist/templates/app/superadmin/subscriptions/page.tsx +0 -655
  184. package/dist/templates/app/superadmin/team-roles/page.tsx +0 -493
  185. package/dist/templates/app/superadmin/teams/[teamId]/page.tsx +0 -687
  186. package/dist/templates/app/superadmin/teams/page.tsx +0 -302
  187. package/dist/templates/app/superadmin/users/[userId]/page.tsx +0 -548
  188. package/dist/templates/app/superadmin/users/page.tsx +0 -528
  189. package/templates/app/(auth)/forgot-password/page.tsx +0 -216
  190. package/templates/app/(auth)/layout.tsx +0 -51
  191. package/templates/app/(auth)/login/page.tsx +0 -21
  192. package/templates/app/(auth)/reset-password/page.tsx +0 -212
  193. package/templates/app/(auth)/signup/page.tsx +0 -21
  194. package/templates/app/(auth)/verify-email/page.tsx +0 -190
  195. package/templates/app/(public)/[...slug]/page.tsx +0 -378
  196. package/templates/app/(public)/docs/[section]/[page]/page.tsx +0 -90
  197. package/templates/app/(public)/docs/layout.tsx +0 -25
  198. package/templates/app/(public)/docs/page.tsx +0 -81
  199. package/templates/app/(public)/layout.tsx +0 -41
  200. package/templates/app/(public)/page.tsx +0 -19
  201. package/templates/app/403/page.tsx +0 -89
  202. package/templates/app/api/auth/[...all]/route.ts +0 -78
  203. package/templates/app/api/cron/billing/lifecycle/route.ts +0 -98
  204. package/templates/app/api/csp-report/route.ts +0 -175
  205. package/templates/app/api/devtools/config/entities/route.ts +0 -108
  206. package/templates/app/api/devtools/config/theme/route.ts +0 -66
  207. package/templates/app/api/devtools/tests/[...path]/route.ts +0 -130
  208. package/templates/app/api/devtools/tests/route.ts +0 -134
  209. package/templates/app/api/health/route.ts +0 -29
  210. package/templates/app/api/internal/user-metadata/route.ts +0 -36
  211. package/templates/app/api/superadmin/subscriptions/route.ts +0 -310
  212. package/templates/app/api/superadmin/teams/[teamId]/route.ts +0 -286
  213. package/templates/app/api/superadmin/teams/route.ts +0 -188
  214. package/templates/app/api/superadmin/users/[userId]/route.ts +0 -540
  215. package/templates/app/api/superadmin/users/route.ts +0 -323
  216. package/templates/app/api/user/delete-account/route.ts +0 -55
  217. package/templates/app/api/user/plan-flags/route.ts +0 -283
  218. package/templates/app/api/user/profile/route.ts +0 -133
  219. package/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +0 -210
  220. package/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +0 -331
  221. package/templates/app/api/v1/[entity]/[id]/route.ts +0 -35
  222. package/templates/app/api/v1/[entity]/docs.md +0 -369
  223. package/templates/app/api/v1/[entity]/presets.ts +0 -194
  224. package/templates/app/api/v1/[entity]/route.ts +0 -31
  225. package/templates/app/api/v1/api-keys/[id]/route.ts +0 -303
  226. package/templates/app/api/v1/api-keys/docs.md +0 -101
  227. package/templates/app/api/v1/api-keys/presets.ts +0 -31
  228. package/templates/app/api/v1/api-keys/route.ts +0 -250
  229. package/templates/app/api/v1/auth/docs.md +0 -184
  230. package/templates/app/api/v1/auth/presets.ts +0 -44
  231. package/templates/app/api/v1/auth/signup-with-invite/route.ts +0 -227
  232. package/templates/app/api/v1/billing/cancel/route.ts +0 -206
  233. package/templates/app/api/v1/billing/change-plan/route.ts +0 -97
  234. package/templates/app/api/v1/billing/check-action/route.ts +0 -81
  235. package/templates/app/api/v1/billing/checkout/route.ts +0 -124
  236. package/templates/app/api/v1/billing/docs.md +0 -209
  237. package/templates/app/api/v1/billing/plans/route.ts +0 -85
  238. package/templates/app/api/v1/billing/portal/route.ts +0 -90
  239. package/templates/app/api/v1/billing/presets.ts +0 -121
  240. package/templates/app/api/v1/billing/webhooks/stripe/route.ts +0 -428
  241. package/templates/app/api/v1/blocks/[slug]/route.ts +0 -29
  242. package/templates/app/api/v1/blocks/docs.md +0 -173
  243. package/templates/app/api/v1/blocks/presets.ts +0 -121
  244. package/templates/app/api/v1/blocks/route.ts +0 -45
  245. package/templates/app/api/v1/blocks/validate/route.ts +0 -45
  246. package/templates/app/api/v1/cron/docs.md +0 -116
  247. package/templates/app/api/v1/cron/presets.ts +0 -26
  248. package/templates/app/api/v1/cron/process/route.ts +0 -108
  249. package/templates/app/api/v1/devtools/blocks/route.ts +0 -82
  250. package/templates/app/api/v1/devtools/docs/route.ts +0 -150
  251. package/templates/app/api/v1/devtools/docs.md +0 -204
  252. package/templates/app/api/v1/devtools/features/route.ts +0 -61
  253. package/templates/app/api/v1/devtools/flows/route.ts +0 -61
  254. package/templates/app/api/v1/devtools/presets.ts +0 -113
  255. package/templates/app/api/v1/devtools/scheduled-actions/route.ts +0 -120
  256. package/templates/app/api/v1/devtools/testing/route.ts +0 -82
  257. package/templates/app/api/v1/media/docs.md +0 -117
  258. package/templates/app/api/v1/media/presets.ts +0 -24
  259. package/templates/app/api/v1/media/upload/route.ts +0 -150
  260. package/templates/app/api/v1/patterns/[id]/usages/route.ts +0 -116
  261. package/templates/app/api/v1/plugin/[...path]/route.ts +0 -373
  262. package/templates/app/api/v1/plugin/docs.md +0 -79
  263. package/templates/app/api/v1/plugin/presets.ts +0 -21
  264. package/templates/app/api/v1/plugin/route.ts +0 -96
  265. package/templates/app/api/v1/post-categories/[id]/route.ts +0 -255
  266. package/templates/app/api/v1/post-categories/docs.md +0 -134
  267. package/templates/app/api/v1/post-categories/presets.ts +0 -78
  268. package/templates/app/api/v1/post-categories/route.ts +0 -119
  269. package/templates/app/api/v1/team-invitations/[token]/accept/route.ts +0 -179
  270. package/templates/app/api/v1/team-invitations/[token]/decline/route.ts +0 -120
  271. package/templates/app/api/v1/team-invitations/[token]/route.ts +0 -89
  272. package/templates/app/api/v1/team-invitations/docs.md +0 -88
  273. package/templates/app/api/v1/team-invitations/presets.ts +0 -43
  274. package/templates/app/api/v1/team-invitations/route.ts +0 -114
  275. package/templates/app/api/v1/teams/[teamId]/invitations/route.ts +0 -171
  276. package/templates/app/api/v1/teams/[teamId]/invoices/[invoiceNumber]/route.ts +0 -105
  277. package/templates/app/api/v1/teams/[teamId]/invoices/route.ts +0 -125
  278. package/templates/app/api/v1/teams/[teamId]/members/[memberId]/route.ts +0 -263
  279. package/templates/app/api/v1/teams/[teamId]/members/route.ts +0 -358
  280. package/templates/app/api/v1/teams/[teamId]/route.ts +0 -322
  281. package/templates/app/api/v1/teams/[teamId]/subscription/route.ts +0 -50
  282. package/templates/app/api/v1/teams/[teamId]/usage/[limitSlug]/route.ts +0 -91
  283. package/templates/app/api/v1/teams/docs.md +0 -320
  284. package/templates/app/api/v1/teams/presets.ts +0 -178
  285. package/templates/app/api/v1/teams/route.ts +0 -293
  286. package/templates/app/api/v1/teams/switch/route.ts +0 -88
  287. package/templates/app/api/v1/theme/[...path]/route.ts +0 -361
  288. package/templates/app/api/v1/theme/docs.md +0 -74
  289. package/templates/app/api/v1/theme/presets.ts +0 -21
  290. package/templates/app/api/v1/theme/route.ts +0 -96
  291. package/templates/app/api/v1/users/[id]/meta/[key]/route.ts +0 -363
  292. package/templates/app/api/v1/users/[id]/route.ts +0 -302
  293. package/templates/app/api/v1/users/docs.md +0 -93
  294. package/templates/app/api/v1/users/presets.ts +0 -59
  295. package/templates/app/api/v1/users/route.ts +0 -197
  296. package/templates/app/dashboard/(main)/[entity]/[id]/edit/page.tsx +0 -117
  297. package/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +0 -103
  298. package/templates/app/dashboard/(main)/[entity]/create/page.tsx +0 -95
  299. package/templates/app/dashboard/(main)/[entity]/error.tsx +0 -51
  300. package/templates/app/dashboard/(main)/[entity]/layout.tsx +0 -113
  301. package/templates/app/dashboard/(main)/[entity]/loading.tsx +0 -61
  302. package/templates/app/dashboard/(main)/[entity]/page.tsx +0 -90
  303. package/templates/app/dashboard/(main)/layout.tsx +0 -98
  304. package/templates/app/dashboard/(main)/loading.tsx +0 -5
  305. package/templates/app/dashboard/(main)/page.tsx +0 -201
  306. package/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +0 -114
  307. package/templates/app/dashboard/(main)/patterns/[id]/page.tsx +0 -20
  308. package/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +0 -171
  309. package/templates/app/dashboard/(main)/patterns/create/page.tsx +0 -86
  310. package/templates/app/dashboard/(main)/patterns/page.tsx +0 -444
  311. package/templates/app/dashboard/features/analytics/page.tsx +0 -35
  312. package/templates/app/dashboard/features/automation/page.tsx +0 -35
  313. package/templates/app/dashboard/features/layout.tsx +0 -13
  314. package/templates/app/dashboard/features/loading.tsx +0 -5
  315. package/templates/app/dashboard/features/webhooks/page.tsx +0 -35
  316. package/templates/app/dashboard/layout.tsx +0 -86
  317. package/templates/app/dashboard/permission-denied/page.tsx +0 -29
  318. package/templates/app/dashboard/settings/api-keys/loading.tsx +0 -5
  319. package/templates/app/dashboard/settings/api-keys/page.tsx +0 -513
  320. package/templates/app/dashboard/settings/billing/loading.tsx +0 -5
  321. package/templates/app/dashboard/settings/billing/page.tsx +0 -284
  322. package/templates/app/dashboard/settings/invoices/[invoiceNumber]/page.tsx +0 -222
  323. package/templates/app/dashboard/settings/invoices/loading.tsx +0 -5
  324. package/templates/app/dashboard/settings/invoices/page.tsx +0 -82
  325. package/templates/app/dashboard/settings/layout.tsx +0 -151
  326. package/templates/app/dashboard/settings/loading.tsx +0 -5
  327. package/templates/app/dashboard/settings/notifications/loading.tsx +0 -5
  328. package/templates/app/dashboard/settings/notifications/page.tsx +0 -462
  329. package/templates/app/dashboard/settings/page.tsx +0 -92
  330. package/templates/app/dashboard/settings/password/loading.tsx +0 -5
  331. package/templates/app/dashboard/settings/password/page.tsx +0 -306
  332. package/templates/app/dashboard/settings/plans/loading.tsx +0 -5
  333. package/templates/app/dashboard/settings/plans/page.tsx +0 -40
  334. package/templates/app/dashboard/settings/profile/loading.tsx +0 -5
  335. package/templates/app/dashboard/settings/profile/page.tsx +0 -686
  336. package/templates/app/dashboard/settings/security/loading.tsx +0 -5
  337. package/templates/app/dashboard/settings/security/page.tsx +0 -505
  338. package/templates/app/dashboard/settings/teams/loading.tsx +0 -5
  339. package/templates/app/dashboard/settings/teams/page.tsx +0 -272
  340. package/templates/app/dashboard/settings/teams/permissions/page.tsx +0 -92
  341. package/templates/app/devtools/blocks/[slug]/page.tsx +0 -39
  342. package/templates/app/devtools/blocks/page.tsx +0 -31
  343. package/templates/app/devtools/config/page.tsx +0 -31
  344. package/templates/app/devtools/features/page.tsx +0 -31
  345. package/templates/app/devtools/flows/page.tsx +0 -31
  346. package/templates/app/devtools/layout.tsx +0 -58
  347. package/templates/app/devtools/page.tsx +0 -121
  348. package/templates/app/devtools/scheduled-actions/page.tsx +0 -157
  349. package/templates/app/devtools/style/page.tsx +0 -330
  350. package/templates/app/devtools/tags/page.tsx +0 -31
  351. package/templates/app/devtools/tests/[[...path]]/page.tsx +0 -47
  352. package/templates/app/favicon.ico +0 -0
  353. package/templates/app/globals.css +0 -12
  354. package/templates/app/layout.tsx +0 -96
  355. package/templates/app/public/page.tsx +0 -30
  356. package/templates/app/superadmin/docs/[section]/[page]/page.tsx +0 -92
  357. package/templates/app/superadmin/docs/page.tsx +0 -75
  358. package/templates/app/superadmin/layout.tsx +0 -67
  359. package/templates/app/superadmin/page.tsx +0 -149
  360. package/templates/app/superadmin/subscriptions/page.tsx +0 -655
  361. package/templates/app/superadmin/team-roles/page.tsx +0 -493
  362. package/templates/app/superadmin/teams/[teamId]/page.tsx +0 -687
  363. package/templates/app/superadmin/teams/page.tsx +0 -302
  364. package/templates/app/superadmin/users/[userId]/page.tsx +0 -548
  365. package/templates/app/superadmin/users/page.tsx +0 -528
@@ -1,133 +0,0 @@
1
- import { NextResponse } from 'next/server'
2
- import { auth } from '@nextsparkjs/core/lib/auth'
3
- import { headers } from 'next/headers'
4
- import { queryOneWithRLS, mutateWithRLS, queryOne } from '@nextsparkjs/core/lib/db'
5
- import { profileSchema } from '@nextsparkjs/core/lib/validation'
6
- import { MetaService } from '@nextsparkjs/core/lib/services/meta.service'
7
-
8
- export async function GET(request: Request) {
9
- const url = new URL(request.url)
10
- const includeMeta = url.searchParams.get('includeMeta') === 'true'
11
- try {
12
- const sessionHeaders = await headers()
13
- const session = await auth.api.getSession({ headers: sessionHeaders })
14
-
15
- if (!session?.user) {
16
- return NextResponse.json({ error: 'Unauthorized' }, { status: 401 })
17
- }
18
-
19
- // Get user profile data including the new fields
20
- const user = await queryOneWithRLS(
21
- 'SELECT id, email, "firstName", "lastName", country, timezone, language, image, "emailVerified", "createdAt", "updatedAt" FROM "users" WHERE id = $1',
22
- [session.user.id],
23
- session.user.id
24
- )
25
-
26
- if (!user) {
27
- return NextResponse.json({ error: 'User not found' }, { status: 404 })
28
- }
29
-
30
- // Get auth method (check if user has password or uses OAuth) - using direct query for auth table
31
- const account = await queryOne<{ providerId: string }>(
32
- 'SELECT "providerId" FROM "account" WHERE "userId" = $1',
33
- [session.user.id]
34
- )
35
-
36
- const authMethod = account
37
- ? account.providerId === 'credential' ? 'Email' : 'Google'
38
- : 'Email'
39
-
40
- let result: Record<string, unknown> = {
41
- ...user,
42
- authMethod
43
- }
44
-
45
- // Include metadata if requested
46
- if (includeMeta) {
47
- const metadata = await MetaService.getEntityMetas('user', session.user.id, session.user.id, true)
48
- result = { ...result, meta: metadata }
49
- }
50
-
51
- return NextResponse.json(result)
52
- } catch (error) {
53
- console.error('Error fetching user profile:', error)
54
- return NextResponse.json({ error: 'Internal server error' }, { status: 500 })
55
- }
56
- }
57
-
58
- export async function PATCH(request: Request) {
59
- try {
60
- const sessionHeaders = await headers()
61
- const session = await auth.api.getSession({ headers: sessionHeaders })
62
-
63
- if (!session?.user) {
64
- return NextResponse.json({ error: 'Unauthorized' }, { status: 401 })
65
- }
66
-
67
- const body = await request.json()
68
- const { meta, ...profileData } = body
69
-
70
- // Handle metadata-only updates (formato anidado)
71
- if (meta && Object.keys(profileData).length === 0) {
72
- // Procesar cada grupo de metadata por separado
73
- for (const [metaKey, metaValue] of Object.entries(meta)) {
74
- if (metaValue && typeof metaValue === 'object') {
75
- await MetaService.setEntityMeta('user', session.user.id, metaKey, metaValue, session.user.id)
76
- }
77
- }
78
-
79
- return NextResponse.json({
80
- message: 'Settings updated successfully',
81
- success: true
82
- })
83
- }
84
-
85
- // Handle profile data updates
86
- if (Object.keys(profileData).length > 0) {
87
- // Validate the request body
88
- const validationResult = profileSchema.safeParse(profileData)
89
- if (!validationResult.success) {
90
- return NextResponse.json({
91
- error: 'Invalid data',
92
- details: validationResult.error.issues
93
- }, { status: 400 })
94
- }
95
-
96
- const { firstName, lastName, country, timezone, language } = validationResult.data
97
-
98
- // Update user profile
99
- const result = await mutateWithRLS(
100
- `UPDATE "users"
101
- SET "firstName" = $1, "lastName" = $2, country = $3, timezone = $4, language = $5, "updatedAt" = CURRENT_TIMESTAMP
102
- WHERE id = $6
103
- RETURNING id, email, "firstName", "lastName", country, timezone, language, image, "emailVerified", "createdAt", "updatedAt"`,
104
- [firstName, lastName, country, timezone, language, session.user.id],
105
- session.user.id
106
- )
107
-
108
- const updatedUser = result.rows[0]
109
-
110
- if (!updatedUser) {
111
- return NextResponse.json({ error: 'User not found' }, { status: 404 })
112
- }
113
- }
114
-
115
- // Handle metadata updates if provided (formato anidado)
116
- if (meta) {
117
- // Procesar cada grupo de metadata por separado
118
- for (const [metaKey, metaValue] of Object.entries(meta)) {
119
- if (metaValue && typeof metaValue === 'object') {
120
- await MetaService.setEntityMeta('user', session.user.id, metaKey, metaValue, session.user.id)
121
- }
122
- }
123
- }
124
-
125
- return NextResponse.json({
126
- message: 'Profile updated successfully',
127
- success: true
128
- })
129
- } catch (error) {
130
- console.error('Error updating user profile:', error)
131
- return NextResponse.json({ error: 'Internal server error' }, { status: 500 })
132
- }
133
- }
@@ -1,210 +0,0 @@
1
- /**
2
- * API endpoint for individual child entity operations
3
- * PUT /api/v1/[entity]/[id]/child/[childType]/[childId]
4
- * DELETE /api/v1/[entity]/[id]/child/[childType]/[childId]
5
- */
6
-
7
- // CRITICAL: Initialize entity registry for API routes
8
- // This import is processed by webpack which resolves the @nextsparkjs alias
9
- // The setEntityRegistry call happens at module load time
10
- import { setEntityRegistry, isRegistryInitialized, getChildEntities, getEntity } from '@nextsparkjs/core/lib/entities/queries'
11
- import { ENTITY_REGISTRY, ENTITY_METADATA } from '@nextsparkjs/registries/entity-registry'
12
- if (!isRegistryInitialized()) {
13
- setEntityRegistry(ENTITY_REGISTRY, ENTITY_METADATA)
14
- }
15
-
16
- import { NextRequest, NextResponse } from 'next/server'
17
- import { queryWithRLS } from '@nextsparkjs/core/lib/db'
18
- import { resolveEntityFromUrl } from '@nextsparkjs/core/lib/api/entity/resolver'
19
-
20
- interface RouteParams {
21
- entity: string
22
- id: string
23
- childType: string
24
- childId: string
25
- }
26
-
27
- export async function PUT(
28
- request: NextRequest,
29
- { params }: { params: Promise<RouteParams> }
30
- ) {
31
- const { entity, id, childType, childId } = await params
32
-
33
- try {
34
- const body = await request.json()
35
-
36
- // Resolve entity from URL (handles plural to singular conversion)
37
- const resolution = await resolveEntityFromUrl(request.nextUrl.pathname)
38
- if (!resolution.isValidEntity || !resolution.entityConfig) {
39
- return NextResponse.json(
40
- { error: `Entity "${entity}" not found` },
41
- { status: 404 }
42
- )
43
- }
44
-
45
- // Get child entities for this parent entity from registry
46
- const childEntities = getChildEntities(resolution.entityName as string)
47
- const childEntity = childEntities.find(child => child.name === childType)
48
-
49
- if (!childEntity) {
50
- return NextResponse.json(
51
- { error: `Child entity "${childType}" not found for "${entity}"` },
52
- { status: 404 }
53
- )
54
- }
55
-
56
- // Get child entity configuration from registry
57
- const childConfig = getEntity(childType as string)
58
- if (!childConfig) {
59
- return NextResponse.json(
60
- { error: `Child entity configuration "${childType}" not found` },
61
- { status: 404 }
62
- )
63
- }
64
-
65
- // Prepare data
66
- const childTable = childEntity.tableName
67
- const parentIdColumn = 'parentId' // Use consistent naming
68
-
69
- // Extract field names and values for update (exclude system fields)
70
- const systemFields = ['id', 'parentId', 'createdAt', 'updatedAt']
71
- const userFields = childConfig.fields.filter(field => !systemFields.includes(field.name))
72
- const fieldNames = userFields.map(field => field.name)
73
- const updateClauses = fieldNames
74
- .filter(name => body[name] !== undefined)
75
- .map(name => {
76
- const value = body[name]
77
- if (value === null) {
78
- return `"${name}" = NULL`
79
- }
80
-
81
- const field = childConfig.fields.find(f => f.name === name)
82
-
83
- // Handle relation fields specially - extract single ID from array or object
84
- if (field?.type === 'relation') {
85
- if (Array.isArray(value) && value.length > 0) {
86
- const firstItem = value[0]
87
- const relationId = typeof firstItem === 'object' && firstItem && 'id' in firstItem ? firstItem.id : firstItem
88
- return `"${name}" = '${String(relationId).replace(/'/g, "''")}'`
89
- } else if (typeof value === 'object' && value && 'id' in value) {
90
- return `"${name}" = '${String((value as { id: unknown }).id).replace(/'/g, "''")}'`
91
- } else if (typeof value === 'string') {
92
- return `"${name}" = '${String(value).replace(/'/g, "''")}'`
93
- }
94
- return `"${name}" = NULL`
95
- }
96
-
97
- // Handle relation-multi fields - store as JSONB array of IDs
98
- if (field?.type === 'relation-multi') {
99
- let relationIds = []
100
- if (Array.isArray(value)) {
101
- relationIds = value.map(item =>
102
- typeof item === 'object' && item && 'id' in item ? item.id : item
103
- ).filter(id => id && String(id).trim() !== '')
104
- }
105
- return `"${name}" = '${JSON.stringify(relationIds).replace(/'/g, "''")}'::jsonb`
106
- }
107
-
108
- // Handle multiselect, user, and other complex types as JSONB
109
- if (field?.type === 'multiselect' || field?.type === 'user' ||
110
- Array.isArray(value) || (typeof value === 'object' && value !== null)) {
111
- return `"${name}" = '${JSON.stringify(value).replace(/'/g, "''")}'::jsonb`
112
- }
113
-
114
- return `"${name}" = '${String(value).replace(/'/g, "''")}'`
115
- })
116
-
117
- // Add updatedAt
118
- updateClauses.push(`"updatedAt" = NOW()`)
119
-
120
- const query = `
121
- UPDATE "${childTable}"
122
- SET ${updateClauses.join(', ')}
123
- WHERE "id" = $1 AND "${parentIdColumn}" = $2
124
- RETURNING *
125
- `
126
-
127
- const result = await queryWithRLS<Record<string, unknown>>(query, [childId, id], 'system')
128
-
129
- if (result.length === 0) {
130
- return NextResponse.json(
131
- { error: 'Child entity not found' },
132
- { status: 404 }
133
- )
134
- }
135
-
136
- return NextResponse.json({
137
- success: true,
138
- data: result[0],
139
- info: {
140
- timestamp: new Date().toISOString()
141
- }
142
- })
143
- } catch (error) {
144
- console.error(`Error updating child entity:`, error)
145
- return NextResponse.json(
146
- { error: 'Internal server error' },
147
- { status: 500 }
148
- )
149
- }
150
- }
151
-
152
- export async function DELETE(
153
- request: NextRequest,
154
- { params }: { params: Promise<RouteParams> }
155
- ) {
156
- try {
157
- const { entity, id, childType, childId } = await params
158
-
159
- // Resolve entity from URL (handles plural to singular conversion)
160
- const resolution = await resolveEntityFromUrl(request.nextUrl.pathname)
161
- if (!resolution.isValidEntity || !resolution.entityConfig) {
162
- return NextResponse.json(
163
- { error: `Entity "${entity}" not found` },
164
- { status: 404 }
165
- )
166
- }
167
-
168
- // Get child entities for this parent entity from registry
169
- const childEntities = getChildEntities(resolution.entityName as string)
170
- const childEntity = childEntities.find(child => child.name === childType)
171
-
172
- if (!childEntity) {
173
- return NextResponse.json(
174
- { error: `Child entity "${childType}" not found for "${entity}"` },
175
- { status: 404 }
176
- )
177
- }
178
-
179
- // Delete child entity
180
- const childTable = childEntity.tableName
181
- const parentIdColumn = 'parentId' // Use consistent naming
182
-
183
- const query = `
184
- DELETE FROM "${childTable}"
185
- WHERE "id" = $1 AND "${parentIdColumn}" = $2
186
- RETURNING id
187
- `
188
-
189
- const result = await queryWithRLS<{ id: string }>(query, [childId, id], 'system')
190
-
191
- if (result.length === 0) {
192
- return NextResponse.json(
193
- { error: 'Child entity not found' },
194
- { status: 404 }
195
- )
196
- }
197
-
198
- return NextResponse.json({
199
- success: true,
200
- message: 'Child entity deleted successfully',
201
- id: result[0].id
202
- })
203
- } catch (error) {
204
- console.error(`Error deleting child entity:`, error)
205
- return NextResponse.json(
206
- { error: 'Internal server error' },
207
- { status: 500 }
208
- )
209
- }
210
- }
@@ -1,331 +0,0 @@
1
- /**
2
- * API endpoint for child entities
3
- * GET /api/v1/[entity]/[id]/child/[childType]
4
- * POST /api/v1/[entity]/[id]/child/[childType]
5
- */
6
-
7
- // CRITICAL: Initialize entity registry for API routes
8
- // This import is processed by webpack which resolves the @nextsparkjs alias
9
- // The setEntityRegistry call happens at module load time
10
- import { setEntityRegistry, isRegistryInitialized, getChildEntities, getEntity } from '@nextsparkjs/core/lib/entities/queries'
11
- import { ENTITY_REGISTRY, ENTITY_METADATA } from '@nextsparkjs/registries/entity-registry'
12
- if (!isRegistryInitialized()) {
13
- setEntityRegistry(ENTITY_REGISTRY, ENTITY_METADATA)
14
- }
15
-
16
- import { NextRequest, NextResponse } from 'next/server'
17
- import { queryWithRLS } from '@nextsparkjs/core/lib/db'
18
- import { resolveEntityFromUrl } from '@nextsparkjs/core/lib/api/entity/resolver'
19
-
20
-
21
- interface RouteParams {
22
- entity: string
23
- id: string
24
- childType: string
25
- }
26
-
27
- export async function GET(
28
- request: NextRequest,
29
- { params }: { params: Promise<RouteParams> }
30
- ) {
31
- const { entity, id, childType } = await params
32
-
33
- try {
34
-
35
- // Resolve entity from URL (handles plural to singular conversion)
36
- const resolution = await resolveEntityFromUrl(request.nextUrl.pathname)
37
- if (!resolution.isValidEntity || !resolution.entityConfig) {
38
- return NextResponse.json(
39
- { error: `Entity "${entity}" not found` },
40
- { status: 404 }
41
- )
42
- }
43
-
44
- // Check if child entity exists using the new registry system
45
- const childEntities = getChildEntities(resolution.entityName as string)
46
- const childEntity = childEntities.find(child => child.name === childType)
47
-
48
- if (!childEntity) {
49
- return NextResponse.json(
50
- { error: `Child entity "${childType}" not found for "${entity}"` },
51
- { status: 404 }
52
- )
53
- }
54
-
55
- // Get child config from registry
56
- const childConfig = getEntity(childType as string)
57
- if (!childConfig) {
58
- return NextResponse.json(
59
- { error: `Child entity configuration "${childType}" not found` },
60
- { status: 404 }
61
- )
62
- }
63
-
64
- // Query child entities
65
- const childTable = childEntity.tableName
66
- const parentIdColumn = 'parentId' // Child entities use 'parentId' as foreign key
67
-
68
- const query = `
69
- SELECT * FROM "${childTable}"
70
- WHERE "${parentIdColumn}" = $1
71
- ORDER BY "createdAt" DESC
72
- `
73
-
74
- const childRows = await queryWithRLS<Record<string, unknown>>(query, [id], 'system')
75
-
76
- return NextResponse.json({
77
- success: true,
78
- data: childRows,
79
- info: {
80
- timestamp: new Date().toISOString()
81
- }
82
- })
83
- } catch (error) {
84
- console.error(`Error loading child entities for ${entity}/${id}/${childType}:`, error)
85
- return NextResponse.json(
86
- { error: 'Internal server error' },
87
- { status: 500 }
88
- )
89
- }
90
- }
91
-
92
- export async function POST(
93
- request: NextRequest,
94
- { params }: { params: Promise<RouteParams> }
95
- ) {
96
- const { entity, id, childType } = await params
97
-
98
- try {
99
- console.log(`[ChildAPI] POST ${entity}/${id}/child/${childType}`)
100
- const body = await request.json()
101
- console.log(`[ChildAPI] Request body:`, body)
102
-
103
- // Resolve entity from URL (handles plural to singular conversion)
104
- const resolution = await resolveEntityFromUrl(request.nextUrl.pathname)
105
- console.log(`[ChildAPI] Resolution:`, resolution)
106
- if (!resolution.isValidEntity || !resolution.entityConfig) {
107
- return NextResponse.json(
108
- { error: `Entity "${entity}" not found` },
109
- { status: 404 }
110
- )
111
- }
112
-
113
- // Check if child entity exists using the new registry system
114
- const childEntities = getChildEntities(resolution.entityName as string)
115
- const childEntity = childEntities.find(child => child.name === childType)
116
- console.log(`[ChildAPI] Found child entities for ${entity}:`, childEntities.map(c => c.name))
117
- console.log(`[ChildAPI] Looking for childType:`, childType)
118
- console.log(`[ChildAPI] Found child entity:`, childEntity)
119
-
120
- if (!childEntity) {
121
- return NextResponse.json(
122
- { error: `Child entity "${childType}" not found for "${entity}"` },
123
- { status: 404 }
124
- )
125
- }
126
-
127
- // Get child config from registry
128
- const childConfig = getEntity(childType as string)
129
- console.log(`[ChildAPI] Child config for ${childType}:`, childConfig)
130
- if (!childConfig) {
131
- return NextResponse.json(
132
- { error: `Child entity configuration "${childType}" not found` },
133
- { status: 404 }
134
- )
135
- }
136
-
137
- // Prepare data
138
- const childTable = childEntity.tableName
139
- const parentIdColumn = 'parentId' // Child entities use 'parentId' as foreign key
140
-
141
- // Extract field names and values (exclude system fields that we'll add separately)
142
- const systemFields = ['id', 'parentId', 'createdAt', 'updatedAt']
143
- const userFields = childConfig.fields.filter(field => !systemFields.includes(field.name))
144
- const fieldNames = userFields.map(field => field.name)
145
- const fieldValues = fieldNames.map(name => body[name])
146
-
147
- // Determine ID generation strategy (default: uuid)
148
- const idStrategy = childConfig.idStrategy?.type || 'uuid'
149
-
150
- // Add parent ID and system fields based on ID strategy
151
- let allFields: string[]
152
- let allValues: string[]
153
-
154
- if (idStrategy === 'serial') {
155
- // SERIAL: Let database generate ID via DEFAULT/SERIAL
156
- allFields = [parentIdColumn, ...fieldNames, 'createdAt', 'updatedAt']
157
- allValues = [
158
- `'${id}'`, // parentId
159
- ...fieldValues.map((value, index) => {
160
-
161
- if (value === null || value === undefined) {
162
- return 'NULL'
163
- }
164
-
165
- const fieldName = fieldNames[index]
166
- const field = childConfig.fields.find(f => f.name === fieldName)
167
-
168
- // Handle number fields - convert empty strings to NULL
169
- if (field?.type === 'number') {
170
- if (typeof value === 'string' && value.trim() === '') {
171
- return 'NULL'
172
- }
173
- // Convert to number and validate
174
- const numValue = Number(value)
175
- if (isNaN(numValue)) {
176
- return 'NULL'
177
- }
178
- return String(numValue)
179
- }
180
-
181
- // Handle relation fields specially - extract single ID from array or object
182
- if (field?.type === 'relation') {
183
- if (Array.isArray(value) && value.length > 0) {
184
- const firstItem = value[0]
185
- const relationId = typeof firstItem === 'object' && firstItem && 'id' in firstItem ? firstItem.id : firstItem
186
- // Check if relationId is empty string or null/undefined
187
- if (!relationId || String(relationId).trim() === '') {
188
- return 'NULL'
189
- }
190
- return `'${String(relationId).replace(/'/g, "''")}'`
191
- } else if (typeof value === 'object' && value && 'id' in value) {
192
- const relationId = (value as { id: unknown }).id
193
- // Check if relationId is empty string or null/undefined
194
- if (!relationId || String(relationId).trim() === '') {
195
- return 'NULL'
196
- }
197
- return `'${String(relationId).replace(/'/g, "''")}'`
198
- } else if (typeof value === 'string') {
199
- // Check if string is empty or just whitespace
200
- if (value.trim() === '') {
201
- return 'NULL'
202
- }
203
- return `'${String(value).replace(/'/g, "''")}'`
204
- }
205
- return 'NULL'
206
- }
207
-
208
- // Handle relation-multi fields - store as JSONB array of IDs
209
- if (field?.type === 'relation-multi') {
210
- let relationIds = []
211
- if (Array.isArray(value)) {
212
- relationIds = value.map(item =>
213
- typeof item === 'object' && item && 'id' in item ? item.id : item
214
- ).filter(id => id && String(id).trim() !== '')
215
- }
216
- return `'${JSON.stringify(relationIds).replace(/'/g, "''")}'::jsonb`
217
- }
218
-
219
- // Handle multiselect, user, and other complex types as JSONB
220
- if (field?.type === 'multiselect' || field?.type === 'user' ||
221
- Array.isArray(value) || (typeof value === 'object' && value !== null)) {
222
- return `'${JSON.stringify(value).replace(/'/g, "''")}'::jsonb`
223
- }
224
-
225
- return `'${String(value).replace(/'/g, "''")}'`
226
- }), // properly handle null values and complex types
227
- 'NOW()', // createdAt
228
- 'NOW()' // updatedAt
229
- ]
230
- } else {
231
- // UUID: Generate ID and include in INSERT
232
- allFields = ['id', parentIdColumn, ...fieldNames, 'createdAt', 'updatedAt']
233
- allValues = [
234
- `gen_random_uuid()::TEXT`, // id
235
- `'${id}'`, // parentId
236
- ...fieldValues.map((value, index) => {
237
- if (value === null || value === undefined) {
238
- return 'NULL'
239
- }
240
-
241
- const fieldName = fieldNames[index]
242
- const field = childConfig.fields.find(f => f.name === fieldName)
243
-
244
- // Handle number fields - convert empty strings to NULL
245
- if (field?.type === 'number') {
246
- if (typeof value === 'string' && value.trim() === '') {
247
- return 'NULL'
248
- }
249
- // Convert to number and validate
250
- const numValue = Number(value)
251
- if (isNaN(numValue)) {
252
- return 'NULL'
253
- }
254
- return String(numValue)
255
- }
256
-
257
- // Handle relation fields specially - extract single ID from array or object
258
- if (field?.type === 'relation') {
259
- if (Array.isArray(value) && value.length > 0) {
260
- const firstItem = value[0]
261
- const relationId = typeof firstItem === 'object' && firstItem && 'id' in firstItem ? firstItem.id : firstItem
262
- // Check if relationId is empty string or null/undefined
263
- if (!relationId || String(relationId).trim() === '') {
264
- return 'NULL'
265
- }
266
- return `'${String(relationId).replace(/'/g, "''")}'`
267
- } else if (typeof value === 'object' && value && 'id' in value) {
268
- const relationId = (value as { id: unknown }).id
269
- // Check if relationId is empty string or null/undefined
270
- if (!relationId || String(relationId).trim() === '') {
271
- return 'NULL'
272
- }
273
- return `'${String(relationId).replace(/'/g, "''")}'`
274
- } else if (typeof value === 'string') {
275
- // Check if string is empty or just whitespace
276
- if (value.trim() === '') {
277
- return 'NULL'
278
- }
279
- return `'${String(value).replace(/'/g, "''")}'`
280
- }
281
- return 'NULL'
282
- }
283
-
284
- // Handle relation-multi fields - store as JSONB array of IDs
285
- if (field?.type === 'relation-multi') {
286
- let relationIds = []
287
- if (Array.isArray(value)) {
288
- relationIds = value.map(item =>
289
- typeof item === 'object' && item && 'id' in item ? item.id : item
290
- ).filter(id => id && String(id).trim() !== '')
291
- }
292
- return `'${JSON.stringify(relationIds).replace(/'/g, "''")}'::jsonb`
293
- }
294
-
295
- // Handle multiselect, user, and other complex types as JSONB
296
- if (field?.type === 'multiselect' || field?.type === 'user' ||
297
- Array.isArray(value) || (typeof value === 'object' && value !== null)) {
298
- return `'${JSON.stringify(value).replace(/'/g, "''")}'::jsonb`
299
- }
300
-
301
- return `'${String(value).replace(/'/g, "''")}'`
302
- }), // properly handle null values and complex types
303
- 'NOW()', // createdAt
304
- 'NOW()' // updatedAt
305
- ]
306
- }
307
-
308
- const query = `
309
- INSERT INTO "${childTable}" (${allFields.map(f => `"${f}"`).join(', ')})
310
- VALUES (${allValues.join(', ')})
311
- RETURNING *
312
- `
313
-
314
- const result = await queryWithRLS<Record<string, unknown>>(query, [], 'system')
315
-
316
- return NextResponse.json({
317
- success: true,
318
- data: result[0],
319
- info: {
320
- timestamp: new Date().toISOString()
321
- }
322
- })
323
- } catch (error) {
324
- console.error(`[ChildAPI] Error creating child entity for ${entity}/${id}/${childType}:`, error)
325
- console.error(`[ChildAPI] Error stack:`, error instanceof Error ? error.stack : 'No stack available')
326
- return NextResponse.json(
327
- { error: 'Internal server error', details: error instanceof Error ? error.message : String(error) },
328
- { status: 500 }
329
- )
330
- }
331
- }