@nextsparkjs/theme-default 0.1.0-beta.1 → 0.1.0-beta.100

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 (325) hide show
  1. package/LICENSE +21 -0
  2. package/api/ai/chat/stream/route.ts +4 -1
  3. package/api/ai/orchestrator/route.ts +10 -3
  4. package/api/ai/single-agent/route.ts +10 -3
  5. package/api/ai/usage/route.ts +4 -1
  6. package/blocks/benefits/component.tsx +4 -4
  7. package/blocks/cta-section/component.tsx +4 -4
  8. package/blocks/faq-accordion/component.tsx +2 -2
  9. package/blocks/features-grid/component.tsx +5 -5
  10. package/blocks/hero/component.tsx +2 -2
  11. package/blocks/hero/fields.ts +1 -1
  12. package/blocks/hero-with-form/component.tsx +7 -7
  13. package/blocks/hero-with-form/fields.ts +1 -1
  14. package/blocks/jumbotron/component.tsx +7 -7
  15. package/blocks/jumbotron/fields.ts +1 -1
  16. package/blocks/logo-cloud/component.tsx +6 -6
  17. package/blocks/logo-cloud/fields.ts +1 -1
  18. package/blocks/post-content/component.tsx +2 -2
  19. package/blocks/pricing-table/component.tsx +5 -5
  20. package/blocks/split-content/component.tsx +5 -5
  21. package/blocks/split-content/fields.ts +1 -1
  22. package/blocks/stats-counter/component.tsx +9 -9
  23. package/blocks/testimonials/component.tsx +4 -4
  24. package/blocks/testimonials/fields.ts +1 -1
  25. package/blocks/text-content/component.tsx +12 -10
  26. package/blocks/timeline/component.tsx +12 -12
  27. package/blocks/video-hero/component.tsx +7 -7
  28. package/blocks/video-hero/fields.ts +1 -1
  29. package/components/ai-chat/ChatPanel.tsx +7 -7
  30. package/components/ai-chat/Message.tsx +2 -2
  31. package/components/ai-chat/MessageInput.tsx +3 -3
  32. package/components/ai-chat/MessageList.tsx +3 -3
  33. package/components/ai-chat/TypingIndicator.tsx +2 -2
  34. package/config/app.config.ts +54 -62
  35. package/config/dashboard.config.ts +14 -0
  36. package/config/features.config.ts +10 -0
  37. package/config/permissions.config.ts +26 -1
  38. package/docs/{01-overview → public/01-overview}/01-introduction.md +5 -0
  39. package/docs/{01-overview → public/01-overview}/02-customization.md +5 -0
  40. package/docs/{02-features → public/02-features}/03-tasks-entity.md +5 -0
  41. package/docs/{03-ai → public/03-ai}/01-overview.md +5 -0
  42. package/docs/{03-ai → public/03-ai}/02-customization.md +5 -0
  43. package/docs/superadmin/01-setup/01-configuration.md +79 -0
  44. package/docs/superadmin/01-setup/02-deployment.md +82 -0
  45. package/docs/superadmin/02-management/01-users.md +83 -0
  46. package/docs/superadmin/03-integrations/01-langchain.md +139 -0
  47. package/entities/customers/api/docs.md +107 -0
  48. package/entities/customers/api/presets.ts +80 -0
  49. package/entities/pages/api/docs.md +114 -0
  50. package/entities/pages/api/presets.ts +72 -0
  51. package/entities/posts/api/docs.md +120 -0
  52. package/entities/posts/api/presets.ts +74 -0
  53. package/entities/tasks/api/docs.md +126 -0
  54. package/entities/tasks/api/presets.ts +84 -0
  55. package/lib/selectors.ts +7 -4
  56. package/messages/de/admin.json +45 -0
  57. package/messages/en/admin.json +56 -0
  58. package/messages/en/navigation.json +2 -1
  59. package/messages/es/admin.json +56 -0
  60. package/messages/es/navigation.json +2 -1
  61. package/messages/fr/admin.json +45 -0
  62. package/messages/it/admin.json +45 -0
  63. package/messages/pt/admin.json +45 -0
  64. package/migrations/093_pages_sample_data.sql +7 -7
  65. package/migrations/098_patterns_sample_data.sql +234 -0
  66. package/package.json +8 -3
  67. package/styles/globals.css +42 -0
  68. package/templates/(public)/blog/[slug]/page.tsx +1 -1
  69. package/templates/(public)/page.tsx +1 -1
  70. package/tests/cypress/e2e/_utils/devtools/access.bdd.md +262 -0
  71. package/tests/cypress/e2e/_utils/devtools/access.cy.ts +171 -0
  72. package/tests/cypress/e2e/_utils/devtools/navigation.bdd.md +261 -0
  73. package/tests/cypress/e2e/_utils/devtools/navigation.cy.ts +157 -0
  74. package/tests/cypress/e2e/_utils/devtools/pages.bdd.md +303 -0
  75. package/tests/cypress/e2e/_utils/devtools/pages.cy.ts +184 -0
  76. package/tests/cypress/e2e/_utils/docs/README.md +215 -0
  77. package/tests/cypress/e2e/_utils/selectors/auth.bdd.md +354 -0
  78. package/tests/cypress/e2e/_utils/selectors/auth.cy.ts +310 -0
  79. package/tests/cypress/e2e/_utils/selectors/billing.bdd.md +276 -0
  80. package/tests/cypress/e2e/_utils/selectors/billing.cy.ts +182 -0
  81. package/tests/cypress/e2e/_utils/selectors/block-editor.bdd.md +615 -0
  82. package/tests/cypress/e2e/_utils/selectors/block-editor.cy.ts +783 -0
  83. package/tests/cypress/e2e/_utils/selectors/dashboard-container.cy.ts +52 -0
  84. package/tests/cypress/e2e/_utils/selectors/dashboard-mobile.bdd.md +205 -0
  85. package/tests/cypress/e2e/_utils/selectors/dashboard-mobile.cy.ts +137 -0
  86. package/tests/cypress/e2e/_utils/selectors/dashboard-navigation.bdd.md +147 -0
  87. package/tests/cypress/e2e/_utils/selectors/dashboard-navigation.cy.ts +114 -0
  88. package/tests/cypress/e2e/_utils/selectors/dashboard-sidebar.bdd.md +76 -0
  89. package/tests/cypress/e2e/_utils/selectors/dashboard-sidebar.cy.ts +68 -0
  90. package/tests/cypress/e2e/_utils/selectors/dashboard-topnav.bdd.md +326 -0
  91. package/tests/cypress/e2e/_utils/selectors/dashboard-topnav.cy.ts +177 -0
  92. package/tests/cypress/e2e/_utils/selectors/devtools.bdd.md +306 -0
  93. package/tests/cypress/e2e/_utils/selectors/devtools.cy.ts +273 -0
  94. package/tests/cypress/e2e/_utils/selectors/global-search.bdd.md +115 -0
  95. package/tests/cypress/e2e/_utils/selectors/global-search.cy.ts +93 -0
  96. package/tests/cypress/e2e/_utils/selectors/patterns.bdd.md +388 -0
  97. package/tests/cypress/e2e/_utils/selectors/patterns.cy.ts +559 -0
  98. package/tests/cypress/e2e/_utils/selectors/public.cy.ts +112 -0
  99. package/tests/cypress/e2e/_utils/selectors/settings-api-keys.bdd.md +266 -0
  100. package/tests/cypress/e2e/_utils/selectors/settings-api-keys.cy.ts +233 -0
  101. package/tests/cypress/e2e/_utils/selectors/settings-billing.bdd.md +78 -0
  102. package/tests/cypress/e2e/_utils/selectors/settings-billing.cy.ts +108 -0
  103. package/tests/cypress/e2e/_utils/selectors/settings-layout.bdd.md +129 -0
  104. package/tests/cypress/e2e/_utils/selectors/settings-layout.cy.ts +115 -0
  105. package/tests/cypress/e2e/_utils/selectors/settings-password.bdd.md +82 -0
  106. package/tests/cypress/e2e/_utils/selectors/settings-password.cy.ts +74 -0
  107. package/tests/cypress/e2e/_utils/selectors/settings-profile.bdd.md +77 -0
  108. package/tests/cypress/e2e/_utils/selectors/settings-profile.cy.ts +79 -0
  109. package/tests/cypress/e2e/_utils/selectors/settings-teams.bdd.md +130 -0
  110. package/tests/cypress/e2e/_utils/selectors/settings-teams.cy.ts +86 -0
  111. package/tests/cypress/e2e/_utils/selectors/superadmin.bdd.md +261 -0
  112. package/tests/cypress/e2e/_utils/selectors/superadmin.cy.ts +193 -0
  113. package/tests/cypress/e2e/_utils/selectors/tasks.bdd.md +593 -0
  114. package/tests/cypress/e2e/_utils/selectors/tasks.cy.ts +864 -0
  115. package/tests/cypress/e2e/_utils/selectors/taxonomies.cy.ts +126 -0
  116. package/tests/cypress/e2e/_utils/selectors/teams.bdd.md +278 -0
  117. package/tests/cypress/e2e/_utils/selectors/teams.cy.ts +195 -0
  118. package/tests/cypress/e2e/_utils/superadmin/all-teams.bdd.md +261 -0
  119. package/tests/cypress/e2e/_utils/superadmin/all-teams.cy.ts +177 -0
  120. package/tests/cypress/e2e/_utils/superadmin/all-users.bdd.md +406 -0
  121. package/tests/cypress/e2e/_utils/superadmin/all-users.cy.ts +294 -0
  122. package/tests/cypress/e2e/_utils/superadmin/dashboard.bdd.md +235 -0
  123. package/tests/cypress/e2e/_utils/superadmin/dashboard.cy.ts +149 -0
  124. package/tests/cypress/e2e/_utils/superadmin/subscriptions-overview.bdd.md +290 -0
  125. package/tests/cypress/e2e/_utils/superadmin/subscriptions-overview.cy.ts +194 -0
  126. package/tests/cypress/e2e/ai/ai-usage.cy.ts +209 -0
  127. package/tests/cypress/e2e/ai/chat-api.cy.ts +119 -0
  128. package/tests/cypress/e2e/ai/guardrails.cy.ts +332 -0
  129. package/tests/cypress/e2e/api/_core/billing/BillingAPIController.js +319 -0
  130. package/tests/cypress/e2e/api/_core/billing/check-action.cy.ts +326 -0
  131. package/tests/cypress/e2e/api/_core/billing/checkout.cy.ts +358 -0
  132. package/tests/cypress/e2e/api/_core/billing/lifecycle.cy.ts +423 -0
  133. package/tests/cypress/e2e/api/_core/billing/plans/README.md +345 -0
  134. package/tests/cypress/e2e/api/_core/billing/plans/business.cy.ts +412 -0
  135. package/tests/cypress/e2e/api/_core/billing/plans/downgrade.cy.ts +510 -0
  136. package/tests/cypress/e2e/api/_core/billing/plans/fixtures/billing-plans.json +163 -0
  137. package/tests/cypress/e2e/api/_core/billing/plans/free.cy.ts +500 -0
  138. package/tests/cypress/e2e/api/_core/billing/plans/pro.cy.ts +497 -0
  139. package/tests/cypress/e2e/api/_core/billing/plans/starter.cy.ts +342 -0
  140. package/tests/cypress/e2e/api/_core/billing/portal.cy.ts +313 -0
  141. package/tests/cypress/e2e/api/_core/devtools/registries.bdd.md +300 -0
  142. package/tests/cypress/e2e/api/_core/devtools/registries.cy.ts +368 -0
  143. package/tests/cypress/e2e/api/_core/scheduled-actions/cron-endpoint.bdd.md +375 -0
  144. package/tests/cypress/e2e/api/_core/scheduled-actions/cron-endpoint.cy.ts +346 -0
  145. package/tests/cypress/e2e/api/_core/scheduled-actions/devtools-endpoint.bdd.md +451 -0
  146. package/tests/cypress/e2e/api/_core/scheduled-actions/devtools-endpoint.cy.ts +447 -0
  147. package/tests/cypress/e2e/api/_core/scheduled-actions/scheduling.bdd.md +649 -0
  148. package/tests/cypress/e2e/api/_core/scheduled-actions/scheduling.cy.ts +333 -0
  149. package/tests/cypress/e2e/api/_core/security/security-headers.cy.ts +601 -0
  150. package/tests/cypress/e2e/api/_core/settings/api-keys.crud.cy.ts +923 -0
  151. package/tests/cypress/e2e/api/_core/teams/teams-security.cy.ts +415 -0
  152. package/tests/cypress/e2e/api/_core/users/users-crud.cy.ts +469 -0
  153. package/tests/cypress/e2e/api/_core/users/users-metas.cy.ts +913 -0
  154. package/tests/cypress/e2e/api/_core/users/users-security.cy.ts +375 -0
  155. package/tests/cypress/e2e/api/entities/customers/customers-crud.cy.ts +648 -0
  156. package/tests/cypress/e2e/api/entities/customers/customers-metas.cy.ts +839 -0
  157. package/tests/cypress/e2e/api/entities/media/media-crud.cy.ts +600 -0
  158. package/tests/cypress/e2e/api/entities/media/media-role-permissions.cy.ts +617 -0
  159. package/tests/cypress/e2e/api/entities/media/media-team-isolation.cy.ts +464 -0
  160. package/tests/cypress/e2e/api/entities/pages/blocks-scope.cy.ts +396 -0
  161. package/tests/cypress/e2e/api/entities/pages/pages-crud.cy.ts +425 -0
  162. package/tests/cypress/e2e/api/entities/pages/pages-status.cy.ts +335 -0
  163. package/tests/cypress/e2e/api/entities/posts/post-categories-crud.cy.ts +610 -0
  164. package/tests/cypress/e2e/api/entities/posts/posts-crud.cy.ts +709 -0
  165. package/tests/cypress/e2e/api/entities/posts/posts-status.cy.ts +396 -0
  166. package/tests/cypress/e2e/api/entities/tasks/tasks-crud.cy.ts +602 -0
  167. package/tests/cypress/e2e/api/entities/tasks/tasks-metas.cy.ts +878 -0
  168. package/tests/cypress/e2e/patterns/patterns-in-pages.cy.ts +367 -0
  169. package/tests/cypress/e2e/uat/_core/auth/app-roles/developer-login.bdd.md +231 -0
  170. package/tests/cypress/e2e/uat/_core/auth/app-roles/developer-login.cy.ts +144 -0
  171. package/tests/cypress/e2e/uat/_core/auth/app-roles/superadmin-login.bdd.md +118 -0
  172. package/tests/cypress/e2e/uat/_core/auth/app-roles/superadmin-login.cy.ts +84 -0
  173. package/tests/cypress/e2e/uat/_core/auth/custom-roles/editor-login.bdd.md +288 -0
  174. package/tests/cypress/e2e/uat/_core/auth/custom-roles/editor-login.cy.ts +188 -0
  175. package/tests/cypress/e2e/uat/_core/auth/login-logout.bdd.md +160 -0
  176. package/tests/cypress/e2e/uat/_core/auth/login-logout.cy.ts +116 -0
  177. package/tests/cypress/e2e/uat/_core/auth/password-reset.bdd.md +289 -0
  178. package/tests/cypress/e2e/uat/_core/auth/password-reset.cy.ts +200 -0
  179. package/tests/cypress/e2e/uat/_core/auth/team-roles/admin-login.bdd.md +225 -0
  180. package/tests/cypress/e2e/uat/_core/auth/team-roles/admin-login.cy.ts +148 -0
  181. package/tests/cypress/e2e/uat/_core/auth/team-roles/member-login.bdd.md +251 -0
  182. package/tests/cypress/e2e/uat/_core/auth/team-roles/member-login.cy.ts +163 -0
  183. package/tests/cypress/e2e/uat/_core/auth/team-roles/owner-login.bdd.md +231 -0
  184. package/tests/cypress/e2e/uat/_core/auth/team-roles/owner-login.cy.ts +141 -0
  185. package/tests/cypress/e2e/uat/_core/billing/extended.bdd.md +273 -0
  186. package/tests/cypress/e2e/uat/_core/billing/extended.cy.ts +209 -0
  187. package/tests/cypress/e2e/uat/_core/billing/feature-gates.bdd.md +407 -0
  188. package/tests/cypress/e2e/uat/_core/billing/feature-gates.cy.ts +307 -0
  189. package/tests/cypress/e2e/uat/_core/billing/page.bdd.md +329 -0
  190. package/tests/cypress/e2e/uat/_core/billing/page.cy.ts +250 -0
  191. package/tests/cypress/e2e/uat/_core/billing/status.bdd.md +190 -0
  192. package/tests/cypress/e2e/uat/_core/billing/status.cy.ts +145 -0
  193. package/tests/cypress/e2e/uat/_core/billing/team-switch.bdd.md +156 -0
  194. package/tests/cypress/e2e/uat/_core/billing/team-switch.cy.ts +122 -0
  195. package/tests/cypress/e2e/uat/_core/billing/usage.bdd.md +218 -0
  196. package/tests/cypress/e2e/uat/_core/billing/usage.cy.ts +176 -0
  197. package/tests/cypress/e2e/uat/_core/blocks/hero.bdd.md +124 -0
  198. package/tests/cypress/e2e/uat/_core/blocks/hero.cy.ts +56 -0
  199. package/tests/cypress/e2e/uat/_core/devtools/api-tester.cy.ts +390 -0
  200. package/tests/cypress/e2e/uat/_core/performance/suspense-loading.cy.ts +134 -0
  201. package/tests/cypress/e2e/uat/_core/scheduled-actions/devtools-ui.bdd.md +736 -0
  202. package/tests/cypress/e2e/uat/_core/scheduled-actions/devtools-ui.cy.ts +740 -0
  203. package/tests/cypress/e2e/uat/_core/teams/inline-edit.cy.ts +278 -0
  204. package/tests/cypress/e2e/uat/_core/teams/roles-matrix.bdd.md +553 -0
  205. package/tests/cypress/e2e/uat/_core/teams/roles-matrix.cy.ts +185 -0
  206. package/tests/cypress/e2e/uat/_core/teams/switcher.bdd.md +1151 -0
  207. package/tests/cypress/e2e/uat/_core/teams/switcher.cy.ts +497 -0
  208. package/tests/cypress/e2e/uat/_core/teams/team-switcher.md +198 -0
  209. package/tests/cypress/e2e/uat/entities/customers/member.bdd.md +275 -0
  210. package/tests/cypress/e2e/uat/entities/customers/member.cy.ts +122 -0
  211. package/tests/cypress/e2e/uat/entities/customers/owner.bdd.md +243 -0
  212. package/tests/cypress/e2e/uat/entities/customers/owner.cy.ts +165 -0
  213. package/tests/cypress/e2e/uat/entities/pages/block-crud.bdd.md +476 -0
  214. package/tests/cypress/e2e/uat/entities/pages/block-crud.cy.ts +486 -0
  215. package/tests/cypress/e2e/uat/entities/pages/block-editor.bdd.md +460 -0
  216. package/tests/cypress/e2e/uat/entities/pages/block-editor.cy.ts +301 -0
  217. package/tests/cypress/e2e/uat/entities/pages/list.bdd.md +432 -0
  218. package/tests/cypress/e2e/uat/entities/pages/list.cy.ts +273 -0
  219. package/tests/cypress/e2e/uat/entities/pages/public-rendering.bdd.md +696 -0
  220. package/tests/cypress/e2e/uat/entities/pages/public-rendering.cy.ts +340 -0
  221. package/tests/cypress/e2e/uat/entities/posts/categories-api-aware.bdd.md +161 -0
  222. package/tests/cypress/e2e/uat/entities/posts/categories-api-aware.cy.ts +104 -0
  223. package/tests/cypress/e2e/uat/entities/posts/categories.bdd.md +375 -0
  224. package/tests/cypress/e2e/uat/entities/posts/categories.cy.ts +241 -0
  225. package/tests/cypress/e2e/uat/entities/posts/editor.bdd.md +429 -0
  226. package/tests/cypress/e2e/uat/entities/posts/editor.cy.ts +257 -0
  227. package/tests/cypress/e2e/uat/entities/posts/list.bdd.md +340 -0
  228. package/tests/cypress/e2e/uat/entities/posts/list.cy.ts +177 -0
  229. package/tests/cypress/e2e/uat/entities/posts/public.bdd.md +614 -0
  230. package/tests/cypress/e2e/uat/entities/posts/public.cy.ts +249 -0
  231. package/tests/cypress/e2e/uat/entities/tasks/member.bdd.md +222 -0
  232. package/tests/cypress/e2e/uat/entities/tasks/member.cy.ts +165 -0
  233. package/tests/cypress/e2e/uat/entities/tasks/owner.bdd.md +419 -0
  234. package/tests/cypress/e2e/uat/entities/tasks/owner.cy.ts +191 -0
  235. package/tests/cypress/e2e/uat/features/roles/editor-role.bdd.md +552 -0
  236. package/tests/cypress/e2e/uat/features/roles/editor-role.cy.ts +210 -0
  237. package/tests/cypress/e2e/uat/features/roles/member-restrictions.bdd.md +450 -0
  238. package/tests/cypress/e2e/uat/features/roles/member-restrictions.cy.ts +189 -0
  239. package/tests/cypress/e2e/uat/features/roles/owner-full-crud.bdd.md +530 -0
  240. package/tests/cypress/e2e/uat/features/roles/owner-full-crud.cy.ts +247 -0
  241. package/tests/cypress/fixtures/blocks.json +218 -0
  242. package/tests/cypress/fixtures/entities.json +87 -0
  243. package/tests/cypress/fixtures/page-builder.json +21 -0
  244. package/tests/cypress/src/components/CategoriesPOM.ts +382 -0
  245. package/tests/cypress/src/components/CustomersPOM.ts +439 -0
  246. package/tests/cypress/src/components/DevKeyringPOM.ts +160 -0
  247. package/tests/cypress/src/components/EntityForm.ts +375 -0
  248. package/tests/cypress/src/components/EntityList.ts +389 -0
  249. package/tests/cypress/src/components/PageBuilderPOM.ts +710 -0
  250. package/tests/cypress/src/components/PostEditorPOM.ts +370 -0
  251. package/tests/cypress/src/components/PostsListPOM.ts +223 -0
  252. package/tests/cypress/src/components/PublicPagePOM.ts +447 -0
  253. package/tests/cypress/src/components/PublicPostPOM.ts +146 -0
  254. package/tests/cypress/src/components/TasksPOM.ts +272 -0
  255. package/tests/cypress/src/components/TeamSwitcherPOM.ts +450 -0
  256. package/tests/cypress/src/components/index.ts +21 -0
  257. package/tests/cypress/src/controllers/ApiKeysAPIController.js +178 -0
  258. package/tests/cypress/src/controllers/BaseAPIController.js +317 -0
  259. package/tests/cypress/src/controllers/CustomerAPIController.js +251 -0
  260. package/tests/cypress/src/controllers/MediaAPIController.js +231 -0
  261. package/tests/cypress/src/controllers/PagesAPIController.js +226 -0
  262. package/tests/cypress/src/controllers/PostsAPIController.js +250 -0
  263. package/tests/cypress/src/controllers/TaskAPIController.js +240 -0
  264. package/tests/cypress/src/controllers/UsersAPIController.js +242 -0
  265. package/tests/cypress/src/controllers/index.js +25 -0
  266. package/tests/cypress/src/core/AuthPOM.ts +450 -0
  267. package/tests/cypress/src/core/BasePOM.ts +33 -0
  268. package/tests/cypress/src/core/BlockEditorBasePOM.ts +874 -0
  269. package/tests/cypress/src/core/DashboardEntityPOM.ts +41 -0
  270. package/tests/cypress/src/core/index.ts +14 -0
  271. package/tests/cypress/src/entities/CustomersPOM.ts +172 -0
  272. package/tests/cypress/src/entities/PagesPOM.ts +137 -0
  273. package/tests/cypress/src/entities/PatternsPOM.ts +329 -0
  274. package/tests/cypress/src/entities/PostsPOM.ts +137 -0
  275. package/tests/cypress/src/entities/TasksPOM.ts +246 -0
  276. package/tests/cypress/src/entities/index.ts +16 -0
  277. package/tests/cypress/src/features/BillingPOM.ts +385 -0
  278. package/tests/cypress/src/features/DashboardPOM.ts +271 -0
  279. package/tests/cypress/src/features/DevtoolsPOM.ts +750 -0
  280. package/tests/cypress/src/features/PageBuilderPOM.ts +283 -0
  281. package/tests/cypress/src/features/PostEditorPOM.ts +313 -0
  282. package/tests/cypress/src/features/ScheduledActionsPOM.ts +463 -0
  283. package/tests/cypress/src/features/SettingsPOM.ts +707 -0
  284. package/tests/cypress/src/features/SuperadminPOM.ts +851 -0
  285. package/tests/cypress/src/features/SuperadminTeamRolesPOM.ts +285 -0
  286. package/tests/cypress/src/features/index.ts +28 -0
  287. package/tests/cypress/src/helpers/ApiInterceptor.ts +20 -0
  288. package/tests/cypress/src/index.ts +101 -0
  289. package/tests/cypress/src/pages/dashboard/Dashboard.js +677 -0
  290. package/tests/cypress/src/pages/dashboard/DashboardPage.js +43 -0
  291. package/tests/cypress/src/pages/dashboard/DashboardStats.js +546 -0
  292. package/tests/cypress/src/pages/dashboard/index.js +6 -0
  293. package/tests/cypress/src/pages/index.js +5 -0
  294. package/tests/cypress/src/pages/public/FeaturesPage.js +28 -0
  295. package/tests/cypress/src/pages/public/LandingPage.js +69 -0
  296. package/tests/cypress/src/pages/public/PricingPage.js +33 -0
  297. package/tests/cypress/src/pages/public/index.js +6 -0
  298. package/tests/cypress/src/selectors.ts +46 -0
  299. package/tests/cypress/src/session-helpers.ts +518 -0
  300. package/tests/cypress/support/doc-commands.ts +260 -0
  301. package/tests/cypress/support/e2e.ts +90 -0
  302. package/tests/cypress.config.ts +178 -0
  303. package/tests/jest/__mocks__/@nextsparkjs/core/components/ui/badge.js +16 -0
  304. package/tests/jest/__mocks__/@nextsparkjs/core/lib/db.js +11 -0
  305. package/tests/jest/__mocks__/@nextsparkjs/registries/permissions-registry.ts +160 -0
  306. package/tests/jest/__mocks__/@nextsparkjs/registries/theme-registry.ts +68 -0
  307. package/tests/jest/__mocks__/jose.js +22 -0
  308. package/tests/jest/__mocks__/next/image.js +15 -0
  309. package/tests/jest/__mocks__/next-server.js +56 -0
  310. package/tests/jest/components/post-header.test.tsx +377 -0
  311. package/tests/jest/jest.config.cjs +154 -0
  312. package/tests/jest/langchain/COVERAGE.md +372 -0
  313. package/tests/jest/langchain/guardrails.test.ts +465 -0
  314. package/tests/jest/langchain/streaming.test.ts +370 -0
  315. package/tests/jest/langchain/token-tracker.test.ts +455 -0
  316. package/tests/jest/langchain/tracer-callbacks.test.ts +881 -0
  317. package/tests/jest/langchain/tracer.test.ts +823 -0
  318. package/tests/jest/services/tasks.service.test.ts +707 -0
  319. package/tests/jest/setup.ts +170 -0
  320. package/tests/jest/tsconfig.jest.json +6 -0
  321. package/tests/jest/validation/categories.test.ts +429 -0
  322. package/tests/jest/validation/posts.test.ts +546 -0
  323. package/tests/tsconfig.json +21 -0
  324. /package/docs/{02-features → public/02-features}/01-components.md +0 -0
  325. /package/docs/{02-features → public/02-features}/02-styling.md +0 -0
@@ -0,0 +1,447 @@
1
+ /// <reference types="cypress" />
2
+
3
+ /**
4
+ * Scheduled Actions API - DevTools Endpoint Tests
5
+ *
6
+ * Tests for /api/v1/devtools/scheduled-actions endpoint that:
7
+ * - Validates authentication (requires superadmin/developer API key)
8
+ * - Supports status filtering (pending, running, completed, failed)
9
+ * - Supports action_type filtering
10
+ * - Returns paginated results
11
+ * - Includes registered action types in meta
12
+ *
13
+ * Session: 2025-12-30-scheduled-actions-v1
14
+ * Phase: 9 (api-tester)
15
+ *
16
+ * AC Coverage:
17
+ * - AC-27: Filter by status
18
+ * - AC-28: Filter by action_type
19
+ * - AC-29: Combined filters
20
+ * - AC-30: Invalid filter handling
21
+ * - AC-31: Pagination with filters
22
+ * - AC-32: Meta includes registeredActionTypes
23
+ */
24
+
25
+ import * as allure from 'allure-cypress'
26
+
27
+ describe('Scheduled Actions API - DevTools Endpoint', {
28
+ tags: ['@api', '@feat-scheduled-actions', '@regression']
29
+ }, () => {
30
+ const BASE_URL = Cypress.config('baseUrl') || 'http://localhost:5173'
31
+ const DEVTOOLS_ENDPOINT = `${BASE_URL}/api/v1/devtools/scheduled-actions`
32
+
33
+ // API key for superadmin/developer access
34
+ const API_KEY = Cypress.env('SUPERADMIN_API_KEY') || 'test_api_key_for_testing_purposes_only_not_a_real_secret_key_abc123'
35
+
36
+ beforeEach(() => {
37
+ allure.epic('API')
38
+ allure.feature('Scheduled Actions')
39
+ allure.story('DevTools Endpoint')
40
+ })
41
+
42
+ // ============================================================
43
+ // TEST 1: Authentication
44
+ // ============================================================
45
+ describe('Authentication', () => {
46
+ it('SA_DEVTOOLS_AUTH_001: Should return 401 without API key', () => {
47
+ allure.severity('critical')
48
+
49
+ cy.request({
50
+ method: 'GET',
51
+ url: DEVTOOLS_ENDPOINT,
52
+ failOnStatusCode: false
53
+ }).then((response) => {
54
+ expect(response.status).to.eq(401)
55
+ expect(response.body.success).to.be.false
56
+ expect(response.body.error.code).to.eq('AUTHENTICATION_REQUIRED')
57
+
58
+ cy.log('Returns 401 without API key')
59
+ })
60
+ })
61
+
62
+ it('SA_DEVTOOLS_AUTH_002: Should return 200 with valid API key', () => {
63
+ allure.severity('critical')
64
+
65
+ cy.request({
66
+ method: 'GET',
67
+ url: DEVTOOLS_ENDPOINT,
68
+ headers: {
69
+ 'x-api-key': API_KEY
70
+ },
71
+ failOnStatusCode: false
72
+ }).then((response) => {
73
+ expect(response.status).to.eq(200)
74
+ expect(response.body.success).to.be.true
75
+
76
+ cy.log('Returns 200 with valid API key')
77
+ })
78
+ })
79
+ })
80
+
81
+ // ============================================================
82
+ // TEST 2: Status Filtering (AC-27)
83
+ // ============================================================
84
+ describe('Status Filtering', () => {
85
+ it('SA_DEVTOOLS_001: Should filter by status=pending', () => {
86
+ allure.severity('critical')
87
+ allure.tag('@ac-27')
88
+
89
+ cy.request({
90
+ method: 'GET',
91
+ url: `${DEVTOOLS_ENDPOINT}?status=pending`,
92
+ headers: {
93
+ 'x-api-key': API_KEY
94
+ }
95
+ }).then((response) => {
96
+ expect(response.status).to.eq(200)
97
+ expect(response.body.success).to.be.true
98
+ expect(response.body.data).to.have.property('actions')
99
+ expect(response.body.data.actions).to.be.an('array')
100
+
101
+ // All returned actions should have status=pending
102
+ response.body.data.actions.forEach((action: { status: string }) => {
103
+ expect(action.status).to.eq('pending')
104
+ })
105
+
106
+ cy.log(`Found ${response.body.data.actions.length} pending actions`)
107
+ })
108
+ })
109
+
110
+ it('SA_DEVTOOLS_002: Should filter by status=completed', () => {
111
+ allure.severity('critical')
112
+ allure.tag('@ac-27')
113
+
114
+ cy.request({
115
+ method: 'GET',
116
+ url: `${DEVTOOLS_ENDPOINT}?status=completed`,
117
+ headers: {
118
+ 'x-api-key': API_KEY
119
+ }
120
+ }).then((response) => {
121
+ expect(response.status).to.eq(200)
122
+ expect(response.body.success).to.be.true
123
+
124
+ // All returned actions should have status=completed
125
+ response.body.data.actions.forEach((action: { status: string }) => {
126
+ expect(action.status).to.eq('completed')
127
+ })
128
+
129
+ cy.log(`Found ${response.body.data.actions.length} completed actions`)
130
+ })
131
+ })
132
+
133
+ it('SA_DEVTOOLS_002b: Should filter by status=failed', () => {
134
+ allure.severity('normal')
135
+ allure.tag('@ac-27')
136
+
137
+ cy.request({
138
+ method: 'GET',
139
+ url: `${DEVTOOLS_ENDPOINT}?status=failed`,
140
+ headers: {
141
+ 'x-api-key': API_KEY
142
+ }
143
+ }).then((response) => {
144
+ expect(response.status).to.eq(200)
145
+ expect(response.body.success).to.be.true
146
+
147
+ // All returned actions should have status=failed
148
+ response.body.data.actions.forEach((action: { status: string }) => {
149
+ expect(action.status).to.eq('failed')
150
+ })
151
+
152
+ cy.log(`Found ${response.body.data.actions.length} failed actions`)
153
+ })
154
+ })
155
+
156
+ it('SA_DEVTOOLS_002c: Should filter by status=running', () => {
157
+ allure.severity('normal')
158
+ allure.tag('@ac-27')
159
+
160
+ cy.request({
161
+ method: 'GET',
162
+ url: `${DEVTOOLS_ENDPOINT}?status=running`,
163
+ headers: {
164
+ 'x-api-key': API_KEY
165
+ }
166
+ }).then((response) => {
167
+ expect(response.status).to.eq(200)
168
+ expect(response.body.success).to.be.true
169
+
170
+ // All returned actions should have status=running
171
+ response.body.data.actions.forEach((action: { status: string }) => {
172
+ expect(action.status).to.eq('running')
173
+ })
174
+
175
+ cy.log(`Found ${response.body.data.actions.length} running actions`)
176
+ })
177
+ })
178
+ })
179
+
180
+ // ============================================================
181
+ // TEST 3: Action Type Filtering (AC-28)
182
+ // ============================================================
183
+ describe('Action Type Filtering', () => {
184
+ it('SA_DEVTOOLS_003: Should filter by action_type=webhook:send', () => {
185
+ allure.severity('critical')
186
+ allure.tag('@ac-28')
187
+
188
+ cy.request({
189
+ method: 'GET',
190
+ url: `${DEVTOOLS_ENDPOINT}?action_type=webhook:send`,
191
+ headers: {
192
+ 'x-api-key': API_KEY
193
+ }
194
+ }).then((response) => {
195
+ expect(response.status).to.eq(200)
196
+ expect(response.body.success).to.be.true
197
+
198
+ // All returned actions should have actionType=webhook:send
199
+ response.body.data.actions.forEach((action: { actionType: string }) => {
200
+ expect(action.actionType).to.eq('webhook:send')
201
+ })
202
+
203
+ cy.log(`Found ${response.body.data.actions.length} webhook:send actions`)
204
+ })
205
+ })
206
+
207
+ it('SA_DEVTOOLS_003b: Should filter by action_type=billing:check-renewals', () => {
208
+ allure.severity('normal')
209
+ allure.tag('@ac-28')
210
+
211
+ cy.request({
212
+ method: 'GET',
213
+ url: `${DEVTOOLS_ENDPOINT}?action_type=billing:check-renewals`,
214
+ headers: {
215
+ 'x-api-key': API_KEY
216
+ }
217
+ }).then((response) => {
218
+ expect(response.status).to.eq(200)
219
+ expect(response.body.success).to.be.true
220
+
221
+ // All returned actions should have actionType=billing:check-renewals
222
+ response.body.data.actions.forEach((action: { actionType: string }) => {
223
+ expect(action.actionType).to.eq('billing:check-renewals')
224
+ })
225
+
226
+ cy.log(`Found ${response.body.data.actions.length} billing:check-renewals actions`)
227
+ })
228
+ })
229
+ })
230
+
231
+ // ============================================================
232
+ // TEST 4: Combined Filters (AC-29)
233
+ // ============================================================
234
+ describe('Combined Filters', () => {
235
+ it('SA_DEVTOOLS_004: Should filter by status AND action_type together', () => {
236
+ allure.severity('critical')
237
+ allure.tag('@ac-29')
238
+
239
+ cy.request({
240
+ method: 'GET',
241
+ url: `${DEVTOOLS_ENDPOINT}?status=completed&action_type=webhook:send`,
242
+ headers: {
243
+ 'x-api-key': API_KEY
244
+ }
245
+ }).then((response) => {
246
+ expect(response.status).to.eq(200)
247
+ expect(response.body.success).to.be.true
248
+
249
+ // All returned actions should match both criteria
250
+ response.body.data.actions.forEach((action: { status: string; actionType: string }) => {
251
+ expect(action.status).to.eq('completed')
252
+ expect(action.actionType).to.eq('webhook:send')
253
+ })
254
+
255
+ cy.log(`Found ${response.body.data.actions.length} completed webhook:send actions`)
256
+ })
257
+ })
258
+ })
259
+
260
+ // ============================================================
261
+ // TEST 5: Invalid Filter Handling (AC-30)
262
+ // ============================================================
263
+ describe('Invalid Filter Handling', () => {
264
+ it('SA_DEVTOOLS_005: Should return empty array for non-existent action_type', () => {
265
+ allure.severity('normal')
266
+ allure.tag('@ac-30')
267
+
268
+ cy.request({
269
+ method: 'GET',
270
+ url: `${DEVTOOLS_ENDPOINT}?action_type=non-existent:action`,
271
+ headers: {
272
+ 'x-api-key': API_KEY
273
+ }
274
+ }).then((response) => {
275
+ expect(response.status).to.eq(200)
276
+ expect(response.body.success).to.be.true
277
+ expect(response.body.data.actions).to.be.an('array')
278
+ expect(response.body.data.actions.length).to.eq(0)
279
+ expect(response.body.data.pagination.total).to.eq(0)
280
+
281
+ cy.log('Returns empty array for non-existent action type')
282
+ })
283
+ })
284
+
285
+ it('SA_DEVTOOLS_005b: Should handle invalid status gracefully', () => {
286
+ allure.severity('normal')
287
+ allure.tag('@ac-30')
288
+
289
+ cy.request({
290
+ method: 'GET',
291
+ url: `${DEVTOOLS_ENDPOINT}?status=invalid_status`,
292
+ headers: {
293
+ 'x-api-key': API_KEY
294
+ }
295
+ }).then((response) => {
296
+ // Should either return empty or treat as no filter
297
+ expect(response.status).to.eq(200)
298
+ expect(response.body.success).to.be.true
299
+
300
+ cy.log('Handles invalid status gracefully')
301
+ })
302
+ })
303
+ })
304
+
305
+ // ============================================================
306
+ // TEST 6: Pagination with Filters (AC-31)
307
+ // ============================================================
308
+ describe('Pagination with Filters', () => {
309
+ it('SA_DEVTOOLS_006: Should paginate filtered results correctly', () => {
310
+ allure.severity('critical')
311
+ allure.tag('@ac-31')
312
+
313
+ cy.request({
314
+ method: 'GET',
315
+ url: `${DEVTOOLS_ENDPOINT}?status=completed&limit=5&page=1`,
316
+ headers: {
317
+ 'x-api-key': API_KEY
318
+ }
319
+ }).then((response) => {
320
+ expect(response.status).to.eq(200)
321
+ expect(response.body.success).to.be.true
322
+ expect(response.body.data).to.have.property('pagination')
323
+ expect(response.body.data.pagination).to.have.property('total')
324
+ expect(response.body.data.pagination).to.have.property('page')
325
+ expect(response.body.data.pagination).to.have.property('limit')
326
+ expect(response.body.data.pagination).to.have.property('totalPages')
327
+
328
+ expect(response.body.data.pagination.page).to.eq(1)
329
+ expect(response.body.data.pagination.limit).to.eq(5)
330
+ expect(response.body.data.actions.length).to.be.at.most(5)
331
+
332
+ cy.log(`Page 1: ${response.body.data.actions.length} actions`)
333
+ cy.log(`Total: ${response.body.data.pagination.total}`)
334
+ cy.log(`Total Pages: ${response.body.data.pagination.totalPages}`)
335
+ })
336
+ })
337
+
338
+ it('SA_DEVTOOLS_006b: Should navigate to page 2 with filters', () => {
339
+ allure.severity('normal')
340
+ allure.tag('@ac-31')
341
+
342
+ // First, get page 1 to see if there are enough items
343
+ cy.request({
344
+ method: 'GET',
345
+ url: `${DEVTOOLS_ENDPOINT}?limit=5&page=1`,
346
+ headers: {
347
+ 'x-api-key': API_KEY
348
+ }
349
+ }).then((response) => {
350
+ expect(response.status).to.eq(200)
351
+ const totalPages = response.body.data.pagination.totalPages
352
+
353
+ if (totalPages >= 2) {
354
+ // Request page 2
355
+ cy.request({
356
+ method: 'GET',
357
+ url: `${DEVTOOLS_ENDPOINT}?limit=5&page=2`,
358
+ headers: {
359
+ 'x-api-key': API_KEY
360
+ }
361
+ }).then((page2Response) => {
362
+ expect(page2Response.status).to.eq(200)
363
+ expect(page2Response.body.data.pagination.page).to.eq(2)
364
+
365
+ cy.log(`Page 2: ${page2Response.body.data.actions.length} actions`)
366
+ })
367
+ } else {
368
+ cy.log('Not enough data for page 2 test - only 1 page exists')
369
+ }
370
+ })
371
+ })
372
+ })
373
+
374
+ // ============================================================
375
+ // TEST 7: Response Meta (AC-32)
376
+ // ============================================================
377
+ describe('Response Meta', () => {
378
+ it('SA_DEVTOOLS_007: Should include registeredActionTypes in meta', () => {
379
+ allure.severity('critical')
380
+ allure.tag('@ac-32')
381
+
382
+ cy.request({
383
+ method: 'GET',
384
+ url: DEVTOOLS_ENDPOINT,
385
+ headers: {
386
+ 'x-api-key': API_KEY
387
+ }
388
+ }).then((response) => {
389
+ expect(response.status).to.eq(200)
390
+ expect(response.body.success).to.be.true
391
+ expect(response.body.data).to.have.property('meta')
392
+ expect(response.body.data.meta).to.have.property('registeredActionTypes')
393
+ expect(response.body.data.meta.registeredActionTypes).to.be.an('array')
394
+
395
+ // Should include known action types
396
+ const actionTypes = response.body.data.meta.registeredActionTypes
397
+ expect(actionTypes).to.include('webhook:send')
398
+ expect(actionTypes).to.include('billing:check-renewals')
399
+
400
+ cy.log(`Registered action types: ${actionTypes.join(', ')}`)
401
+ })
402
+ })
403
+ })
404
+
405
+ // ============================================================
406
+ // TEST 8: Response Structure
407
+ // ============================================================
408
+ describe('Response Structure', () => {
409
+ it('SA_DEVTOOLS_008: Should return correct action structure', () => {
410
+ allure.severity('critical')
411
+
412
+ cy.request({
413
+ method: 'GET',
414
+ url: `${DEVTOOLS_ENDPOINT}?limit=1`,
415
+ headers: {
416
+ 'x-api-key': API_KEY
417
+ }
418
+ }).then((response) => {
419
+ expect(response.status).to.eq(200)
420
+ expect(response.body.success).to.be.true
421
+
422
+ if (response.body.data.actions.length > 0) {
423
+ const action = response.body.data.actions[0]
424
+
425
+ // Validate action structure
426
+ expect(action).to.have.property('id')
427
+ expect(action).to.have.property('actionType')
428
+ expect(action).to.have.property('status')
429
+ expect(action).to.have.property('payload')
430
+ expect(action).to.have.property('teamId')
431
+ expect(action).to.have.property('scheduledAt')
432
+ expect(action).to.have.property('createdAt')
433
+ expect(action).to.have.property('updatedAt')
434
+ expect(action).to.have.property('attempts')
435
+ expect(action).to.have.property('recurringInterval')
436
+
437
+ cy.log('Action structure validated')
438
+ cy.log(`Action ID: ${action.id}`)
439
+ cy.log(`Type: ${action.actionType}`)
440
+ cy.log(`Status: ${action.status}`)
441
+ } else {
442
+ cy.log('No actions found to validate structure')
443
+ }
444
+ })
445
+ })
446
+ })
447
+ })