@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,272 +0,0 @@
1
- 'use client'
2
-
3
- import { useState } from 'react'
4
- import { useTranslations } from 'next-intl'
5
- import { Users, Plus, Settings, ChevronRight, Crown, Shield, Eye, Loader2 } from 'lucide-react'
6
- import { Card, CardContent, CardDescription, CardHeader, CardTitle } from '@nextsparkjs/core/components/ui/card'
7
- import { Button } from '@nextsparkjs/core/components/ui/button'
8
- import { Badge } from '@nextsparkjs/core/components/ui/badge'
9
- import { Avatar, AvatarFallback, AvatarImage } from '@nextsparkjs/core/components/ui/avatar'
10
- import { Separator } from '@nextsparkjs/core/components/ui/separator'
11
- import { useTeamContext } from '@nextsparkjs/core/contexts/TeamContext'
12
- import { useTeamsConfig } from '@nextsparkjs/core/hooks/useTeamsConfig'
13
- import { TeamMembersList } from '@nextsparkjs/core/components/teams/TeamMembersList'
14
- import { TeamPendingInvitations } from '@nextsparkjs/core/components/teams/TeamPendingInvitations'
15
- import { CreateTeamDialog } from '@nextsparkjs/core/components/teams/CreateTeamDialog'
16
- import { InlineEditableField } from '@nextsparkjs/core/components/teams/InlineEditableField'
17
- import { sel } from '@nextsparkjs/core/selectors'
18
- import { TeamRole } from '@nextsparkjs/core/lib/teams/types'
19
- import { getTemplateOrDefaultClient } from '@nextsparkjs/registries/template-registry.client'
20
-
21
- // Role icons map - core roles only, custom roles use fallback
22
- const roleIconsMap: Record<string, typeof Crown | null> = {
23
- owner: Crown,
24
- admin: Shield,
25
- member: null,
26
- viewer: Eye,
27
- }
28
-
29
- // Role colors map - core roles only, custom roles use fallback
30
- const roleColorsMap: Record<string, 'destructive' | 'default' | 'secondary' | 'outline'> = {
31
- owner: 'destructive',
32
- admin: 'default',
33
- member: 'secondary',
34
- viewer: 'outline',
35
- }
36
-
37
- // Type-safe helpers - fallback handles any custom theme roles
38
- const getRoleIcon = (role: TeamRole) => roleIconsMap[role] ?? Eye
39
- const getRoleColor = (role: TeamRole) => roleColorsMap[role] ?? 'outline'
40
-
41
- function TeamsSettingsPage() {
42
- const t = useTranslations('settings')
43
- const tTeams = useTranslations('teams')
44
- const { userTeams, currentTeam, isLoading } = useTeamContext()
45
- const { mode, canCreate, canSwitch } = useTeamsConfig()
46
- const [selectedTeamId, setSelectedTeamId] = useState<string | null>(null)
47
- const [showCreateDialog, setShowCreateDialog] = useState(false)
48
-
49
- // In single-user mode, hide the teams settings page content
50
- // since there's only one team and no collaboration features
51
- const isSingleUserMode = mode === 'single-user'
52
-
53
- // Find selected team membership
54
- const selectedMembership = selectedTeamId
55
- ? userTeams.find(m => m.team.id === selectedTeamId)
56
- : null
57
-
58
- if (isLoading) {
59
- return (
60
- <div
61
- className="flex flex-col items-center justify-center py-12 gap-3"
62
- role="status"
63
- aria-label={tTeams('messages.loading')}
64
- data-cy={sel('settings.teams.loading')}
65
- >
66
- <Loader2 className="h-8 w-8 animate-spin text-muted-foreground" />
67
- <div className="text-sm text-muted-foreground">
68
- {tTeams('messages.loading')}
69
- </div>
70
- </div>
71
- )
72
- }
73
-
74
- return (
75
- <>
76
- <div
77
- className="max-w-4xl space-y-6"
78
- data-cy={sel('settings.teams.container')}
79
- >
80
- {/* Header */}
81
- <header data-cy={sel('settings.teams.header')}>
82
- <h1
83
- className="text-2xl font-bold"
84
- id="teams-settings-heading"
85
- >
86
- {t('teams.title')}
87
- </h1>
88
- <p className="text-muted-foreground mt-1">
89
- {t('teams.description')}
90
- </p>
91
- </header>
92
-
93
- {/* Single-user mode: show simplified view */}
94
- {isSingleUserMode && currentTeam && (
95
- <Card data-cy={sel('settings.teams.singleUserMode')}>
96
- <CardHeader>
97
- <div className="flex items-center gap-2">
98
- <Users className="h-5 w-5" aria-hidden="true" />
99
- <CardTitle>{t('teams.yourTeam')}</CardTitle>
100
- </div>
101
- <CardDescription>
102
- {t('teams.singleUserDescription', { fallback: 'Your personal workspace.' })}
103
- </CardDescription>
104
- </CardHeader>
105
- <CardContent>
106
- <div className="flex items-center gap-3 p-4 rounded-lg border">
107
- <Avatar className="h-10 w-10">
108
- <AvatarImage src={currentTeam.avatarUrl || undefined} alt={currentTeam.name} />
109
- <AvatarFallback>
110
- {currentTeam.name.slice(0, 2).toUpperCase()}
111
- </AvatarFallback>
112
- </Avatar>
113
- <div>
114
- <div className="font-medium">{currentTeam.name}</div>
115
- <div className="text-sm text-muted-foreground">{currentTeam.slug}</div>
116
- </div>
117
- </div>
118
- </CardContent>
119
- </Card>
120
- )}
121
-
122
- {/* Teams List Card - only show if not single-user mode */}
123
- {!isSingleUserMode && (
124
- <Card data-cy={sel('settings.teams.list.container')}>
125
- <CardHeader>
126
- <div className="flex items-center justify-between">
127
- <div className="flex items-center gap-2">
128
- <Users className="h-5 w-5" aria-hidden="true" />
129
- <CardTitle>{canSwitch ? t('teams.yourTeams') : t('teams.yourTeam')}</CardTitle>
130
- </div>
131
- {/* Only show Create Team button if mode allows it */}
132
- {canCreate && (
133
- <Button
134
- onClick={() => setShowCreateDialog(true)}
135
- size="sm"
136
- data-cy="create-team-button"
137
- >
138
- <Plus className="h-4 w-4 mr-2" aria-hidden="true" />
139
- {tTeams('actions.create')}
140
- </Button>
141
- )}
142
- </div>
143
- <CardDescription>
144
- {t('teams.yourTeamsDescription')}
145
- </CardDescription>
146
- </CardHeader>
147
- <CardContent>
148
- <div className="space-y-2">
149
- {userTeams.length === 0 ? (
150
- <div className="text-center py-8 text-muted-foreground">
151
- {t('teams.noTeams')}
152
- </div>
153
- ) : (
154
- userTeams.map((membership) => {
155
- const team = membership.team
156
- const role = membership.role as TeamRole
157
- const RoleIcon = getRoleIcon(role)
158
- const isSelected = selectedTeamId === team.id
159
-
160
- return (
161
- <button
162
- key={team.id}
163
- onClick={() => setSelectedTeamId(isSelected ? null : team.id)}
164
- className={`w-full flex items-center justify-between p-4 rounded-lg border transition-colors hover:bg-accent/50 ${
165
- isSelected ? 'bg-accent border-accent' : 'border-border'
166
- }`}
167
- data-cy={`team-item-${team.id}`}
168
- >
169
- <div className="flex items-center gap-3">
170
- <Avatar className="h-10 w-10">
171
- <AvatarImage src={team.avatarUrl || undefined} alt={team.name} />
172
- <AvatarFallback>
173
- {team.name.slice(0, 2).toUpperCase()}
174
- </AvatarFallback>
175
- </Avatar>
176
- <div className="text-left">
177
- <div className="flex items-center gap-2">
178
- <span className="font-medium">{team.name}</span>
179
- </div>
180
- <div className="text-sm text-muted-foreground">
181
- {team.slug}
182
- </div>
183
- </div>
184
- </div>
185
- <div className="flex items-center gap-3">
186
- <Badge variant={getRoleColor(role)}>
187
- {RoleIcon && <RoleIcon className="h-3 w-3 mr-1" aria-hidden="true" />}
188
- {tTeams(`roles.${role}`)}
189
- </Badge>
190
- <ChevronRight className={`h-4 w-4 text-muted-foreground transition-transform ${isSelected ? 'rotate-90' : ''}`} />
191
- </div>
192
- </button>
193
- )
194
- })
195
- )}
196
- </div>
197
- </CardContent>
198
- </Card>
199
- )}
200
-
201
- {/* Selected Team Details - only show if not single-user mode */}
202
- {!isSingleUserMode && selectedMembership && (
203
- <Card data-cy={sel('settings.teams.list.details', { id: selectedMembership.team.id })}>
204
- <CardHeader>
205
- <div className="flex items-center gap-2">
206
- <Settings className="h-5 w-5" aria-hidden="true" />
207
- <CardTitle className="flex-1">
208
- <InlineEditableField
209
- value={selectedMembership.team.name}
210
- fieldType="name"
211
- teamId={selectedMembership.team.id}
212
- placeholder={tTeams('createTeam.namePlaceholder')}
213
- disabled={selectedMembership.role !== 'owner'}
214
- />
215
- </CardTitle>
216
- </div>
217
- <CardDescription className="mt-2">
218
- <InlineEditableField
219
- value={selectedMembership.team.description}
220
- fieldType="description"
221
- teamId={selectedMembership.team.id}
222
- placeholder={tTeams('createTeam.descriptionPlaceholder')}
223
- multiline={true}
224
- disabled={selectedMembership.role !== 'owner'}
225
- />
226
- </CardDescription>
227
- </CardHeader>
228
- <CardContent className="space-y-6">
229
- {/* Team Info */}
230
- <div className="grid grid-cols-1 md:grid-cols-2 gap-4">
231
- <div>
232
- <label className="text-sm font-medium text-muted-foreground">
233
- {tTeams('fields.slug')}
234
- </label>
235
- <p className="mt-1">{selectedMembership.team.slug}</p>
236
- </div>
237
- <div>
238
- <label className="text-sm font-medium text-muted-foreground">
239
- {tTeams('fields.role')}
240
- </label>
241
- <div className="mt-1">
242
- <Badge variant={getRoleColor(selectedMembership.role as TeamRole)}>
243
- {tTeams(`roles.${selectedMembership.role}`)}
244
- </Badge>
245
- </div>
246
- </div>
247
- </div>
248
-
249
- <Separator />
250
-
251
- {/* Team Members */}
252
- <TeamMembersList teamId={selectedMembership.team.id} />
253
-
254
- {/* Pending Invitations */}
255
- <TeamPendingInvitations teamId={selectedMembership.team.id} />
256
- </CardContent>
257
- </Card>
258
- )}
259
- </div>
260
-
261
- {/* Create Team Dialog - only render if mode allows team creation */}
262
- {canCreate && (
263
- <CreateTeamDialog
264
- open={showCreateDialog}
265
- onOpenChange={setShowCreateDialog}
266
- />
267
- )}
268
- </>
269
- )
270
- }
271
-
272
- export default getTemplateOrDefaultClient('app/dashboard/settings/teams/page.tsx', TeamsSettingsPage)
@@ -1,92 +0,0 @@
1
- import { useTranslations } from 'next-intl'
2
- import { PermissionsMatrix } from '@nextsparkjs/core/components/permissions'
3
- import { Tabs, TabsContent, TabsList, TabsTrigger } from '@nextsparkjs/core/components/ui/tabs'
4
- import { Card, CardContent, CardDescription, CardHeader, CardTitle } from '@nextsparkjs/core/components/ui/card'
5
- // Use PermissionService which reads from the build-time generated registry
6
- import { PermissionService } from '@nextsparkjs/core/lib/services/permission.service'
7
-
8
- /**
9
- * Team Permissions Page
10
- *
11
- * Displays a visual permissions matrix showing what each team role can do.
12
- * Organized by categories with tabs for easy navigation.
13
- */
14
- export default function TeamPermissionsPage() {
15
- const t = useTranslations('permissions')
16
-
17
- // Get all unique categories from registry
18
- const categories = PermissionService.getCategories()
19
-
20
- return (
21
- <div className="space-y-6" data-cy="team-permissions-page">
22
- {/* Header */}
23
- <div>
24
- <h1 className="text-2xl font-bold tracking-tight">{t('title')}</h1>
25
- <p className="text-muted-foreground">{t('description')}</p>
26
- </div>
27
-
28
- {/* Info Card with Role Overview */}
29
- <Card>
30
- <CardHeader>
31
- <CardTitle>{t('rolesOverview')}</CardTitle>
32
- <CardDescription>{t('rolesOverviewDescription')}</CardDescription>
33
- </CardHeader>
34
- <CardContent>
35
- <div className="grid gap-4 md:grid-cols-4">
36
- <RoleCard role="owner" />
37
- <RoleCard role="admin" />
38
- <RoleCard role="member" />
39
- <RoleCard role="viewer" />
40
- </div>
41
- </CardContent>
42
- </Card>
43
-
44
- {/* Permissions Matrix with Tabs */}
45
- <Tabs defaultValue="all" className="space-y-4">
46
- <TabsList>
47
- <TabsTrigger value="all" data-cy="tab-all">
48
- {t('allPermissions')}
49
- </TabsTrigger>
50
- {categories.map(cat => (
51
- <TabsTrigger key={cat} value={cat} data-cy={`tab-${cat.toLowerCase()}`}>
52
- {cat}
53
- </TabsTrigger>
54
- ))}
55
- </TabsList>
56
-
57
- <TabsContent value="all">
58
- <PermissionsMatrix />
59
- </TabsContent>
60
-
61
- {categories.map(cat => (
62
- <TabsContent key={cat} value={cat}>
63
- <PermissionsMatrix category={cat} />
64
- </TabsContent>
65
- ))}
66
- </Tabs>
67
- </div>
68
- )
69
- }
70
-
71
- /**
72
- * RoleCard component
73
- *
74
- * Displays a visual card for each team role with color coding
75
- */
76
- function RoleCard({ role }: { role: 'owner' | 'admin' | 'member' | 'viewer' }) {
77
- const t = useTranslations('permissions')
78
-
79
- const roleColors = {
80
- owner: 'border-purple-200 bg-purple-50 dark:border-purple-800 dark:bg-purple-900/20',
81
- admin: 'border-blue-200 bg-blue-50 dark:border-blue-800 dark:bg-blue-900/20',
82
- member: 'border-green-200 bg-green-50 dark:border-green-800 dark:bg-green-900/20',
83
- viewer: 'border-gray-200 bg-gray-50 dark:border-gray-700 dark:bg-gray-800/20',
84
- }
85
-
86
- return (
87
- <div className={`rounded-lg border p-4 ${roleColors[role]}`} data-cy={`role-card-${role}`}>
88
- <h3 className="font-semibold">{t(`roles.${role}.title`)}</h3>
89
- <p className="text-sm text-muted-foreground">{t(`roles.${role}.description`)}</p>
90
- </div>
91
- )
92
- }
@@ -1,39 +0,0 @@
1
- import { BlockDetailViewer } from "@nextsparkjs/core/components/devtools/BlockDetailViewer";
2
- import { BLOCK_REGISTRY } from "@nextsparkjs/registries/block-registry";
3
- import { notFound } from "next/navigation";
4
-
5
- interface BlockDetailPageProps {
6
- params: Promise<{
7
- slug: string;
8
- }>;
9
- }
10
-
11
- /**
12
- * Block Detail Page
13
- *
14
- * Displays detailed information about a specific page builder block.
15
- * Shows fields, configuration, and test coverage.
16
- */
17
- export default async function BlockDetailPage({ params }: BlockDetailPageProps) {
18
- const { slug } = await params;
19
-
20
- // Verify block exists
21
- if (!BLOCK_REGISTRY[slug]) {
22
- notFound();
23
- }
24
-
25
- return (
26
- <div className="space-y-6" data-cy={`devtools-block-detail-${slug}`}>
27
- <BlockDetailViewer slug={slug} />
28
- </div>
29
- );
30
- }
31
-
32
- /**
33
- * Generate static params for all blocks
34
- */
35
- export async function generateStaticParams() {
36
- return Object.keys(BLOCK_REGISTRY).map((slug) => ({
37
- slug,
38
- }));
39
- }
@@ -1,31 +0,0 @@
1
- import { BlocksViewer } from "@nextsparkjs/core/components/devtools/BlocksViewer";
2
- import { LayoutGrid } from "lucide-react";
3
- import { getTranslations } from "next-intl/server";
4
-
5
- /**
6
- * Blocks Registry Page
7
- *
8
- * Displays all page builder blocks with field definitions and coverage info.
9
- * Provides filtering and search capabilities.
10
- */
11
- export default async function DevBlocksPage() {
12
- const t = await getTranslations("devtools.blocks");
13
-
14
- return (
15
- <div className="space-y-6" data-cy="devtools-blocks-page">
16
- {/* Header */}
17
- <div className="flex items-center gap-3">
18
- <div className="flex items-center justify-center w-12 h-12 bg-violet-100 dark:bg-violet-950 rounded-lg">
19
- <LayoutGrid className="h-6 w-6 text-violet-600 dark:text-violet-400" />
20
- </div>
21
- <div>
22
- <h1 className="text-3xl font-bold">{t("title")}</h1>
23
- <p className="text-muted-foreground">{t("description")}</p>
24
- </div>
25
- </div>
26
-
27
- {/* Blocks Viewer */}
28
- <BlocksViewer />
29
- </div>
30
- );
31
- }
@@ -1,31 +0,0 @@
1
- import { ConfigViewer } from "@nextsparkjs/core/components/devtools";
2
- import { Settings } from "lucide-react";
3
- import { getTranslations } from "next-intl/server";
4
-
5
- /**
6
- * Configuration Viewer Page
7
- *
8
- * Displays theme configuration and entity registry information.
9
- * Provides read-only view with JSON formatting and copy functionality.
10
- */
11
- export default async function DevConfigPage() {
12
- const t = await getTranslations('dev.config');
13
-
14
- return (
15
- <div className="space-y-6" data-cy="devtools-config-page">
16
- {/* Header */}
17
- <div className="flex items-center gap-3">
18
- <div className="flex items-center justify-center w-12 h-12 bg-violet-100 dark:bg-violet-950 rounded-lg">
19
- <Settings className="h-6 w-6 text-violet-600 dark:text-violet-400" />
20
- </div>
21
- <div>
22
- <h1 className="text-3xl font-bold">{t('title')}</h1>
23
- <p className="text-muted-foreground">{t('description')}</p>
24
- </div>
25
- </div>
26
-
27
- {/* Config Viewer */}
28
- <ConfigViewer />
29
- </div>
30
- );
31
- }
@@ -1,31 +0,0 @@
1
- import { FeaturesViewer } from "@nextsparkjs/core/components/devtools/FeaturesViewer";
2
- import { Layers } from "lucide-react";
3
- import { getTranslations } from "next-intl/server";
4
-
5
- /**
6
- * Features Registry Page
7
- *
8
- * Displays all features from the testing registry with coverage information.
9
- * Provides filtering and search capabilities.
10
- */
11
- export default async function DevFeaturesPage() {
12
- const t = await getTranslations("devtools.features");
13
-
14
- return (
15
- <div className="space-y-6" data-cy="devtools-features-page">
16
- {/* Header */}
17
- <div className="flex items-center gap-3">
18
- <div className="flex items-center justify-center w-12 h-12 bg-violet-100 dark:bg-violet-950 rounded-lg">
19
- <Layers className="h-6 w-6 text-violet-600 dark:text-violet-400" />
20
- </div>
21
- <div>
22
- <h1 className="text-3xl font-bold">{t("title")}</h1>
23
- <p className="text-muted-foreground">{t("description")}</p>
24
- </div>
25
- </div>
26
-
27
- {/* Features Viewer */}
28
- <FeaturesViewer />
29
- </div>
30
- );
31
- }
@@ -1,31 +0,0 @@
1
- import { FlowsViewer } from "@nextsparkjs/core/components/devtools/FlowsViewer";
2
- import { GitBranch } from "lucide-react";
3
- import { getTranslations } from "next-intl/server";
4
-
5
- /**
6
- * Flows Registry Page
7
- *
8
- * Displays all user journey flows from the testing registry with coverage information.
9
- * Provides filtering and search capabilities.
10
- */
11
- export default async function DevFlowsPage() {
12
- const t = await getTranslations("devtools.flows");
13
-
14
- return (
15
- <div className="space-y-6" data-cy="devtools-flows-page">
16
- {/* Header */}
17
- <div className="flex items-center gap-3">
18
- <div className="flex items-center justify-center w-12 h-12 bg-violet-100 dark:bg-violet-950 rounded-lg">
19
- <GitBranch className="h-6 w-6 text-violet-600 dark:text-violet-400" />
20
- </div>
21
- <div>
22
- <h1 className="text-3xl font-bold">{t("title")}</h1>
23
- <p className="text-muted-foreground">{t("description")}</p>
24
- </div>
25
- </div>
26
-
27
- {/* Flows Viewer */}
28
- <FlowsViewer />
29
- </div>
30
- );
31
- }
@@ -1,58 +0,0 @@
1
- import { DeveloperGuard } from "@nextsparkjs/core/components/app/guards/DeveloperGuard";
2
- import { DevtoolsSidebar, DevtoolsMobileHeader } from "@nextsparkjs/core/components/devtools";
3
- import { Metadata } from "next";
4
- import { getTemplateOrDefault, getMetadataOrDefault } from '@nextsparkjs/core/lib/template-resolver'
5
-
6
- const defaultMetadata: Metadata = {
7
- title: "DevTools",
8
- description: "Development tools and documentation",
9
- robots: "noindex, nofollow", // Prevent search engine indexing
10
- };
11
-
12
- export const metadata: Metadata = getMetadataOrDefault(
13
- 'app/devtools/layout.tsx',
14
- defaultMetadata
15
- )
16
-
17
- interface DevLayoutProps {
18
- children: React.ReactNode;
19
- }
20
-
21
- /**
22
- * Developer Area Layout
23
- *
24
- * Protected layout for developer-only sections with dedicated sidebar navigation.
25
- * Applies DeveloperGuard protection to all child routes.
26
- * Includes responsive design for mobile and desktop.
27
- * Uses purple/violet color scheme to differentiate from Admin Panel (red).
28
- */
29
- function DevLayout({ children }: DevLayoutProps) {
30
- return (
31
- <DeveloperGuard>
32
- <div className="flex h-screen bg-background">
33
- {/* Sidebar - Hidden on mobile, visible on desktop */}
34
- <div className="hidden lg:block">
35
- <DevtoolsSidebar />
36
- </div>
37
-
38
- {/* Main content area */}
39
- <div className="flex-1 flex flex-col overflow-hidden">
40
- {/* Mobile header for DevTools - Only visible on mobile */}
41
- <DevtoolsMobileHeader />
42
-
43
- {/* Content area with scrolling */}
44
- <main className="flex-1 overflow-y-auto overflow-x-hidden">
45
- <div className="container mx-auto p-6 max-w-7xl">
46
- {children}
47
- </div>
48
- </main>
49
- </div>
50
-
51
- {/* Mobile sidebar overlay (future enhancement) */}
52
- {/* Could add a mobile drawer/overlay sidebar here if needed */}
53
- </div>
54
- </DeveloperGuard>
55
- );
56
- }
57
-
58
- export default getTemplateOrDefault('app/devtools/layout.tsx', DevLayout)