@nextsparkjs/core 0.1.0-beta.13 → 0.1.0-beta.131
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.
- package/dist/components/api/keys/ApiKeyDisplay.d.ts.map +1 -1
- package/dist/components/api/keys/ApiKeyDisplay.js +12 -14
- package/dist/components/api/keys/CreateApiKeyDialog.d.ts.map +1 -1
- package/dist/components/api/keys/CreateApiKeyDialog.js +33 -35
- package/dist/components/app/guards/DeveloperGuard.js +3 -3
- package/dist/components/app/guards/SuperAdminGuard.js +3 -3
- package/dist/components/app/guards/index.js +2 -2
- package/dist/components/app/index.js +5 -5
- package/dist/components/app/layouts/PublicFooter.d.ts.map +1 -1
- package/dist/components/app/layouts/PublicFooter.js +8 -4
- package/dist/components/app/layouts/PublicNavbar.d.ts.map +1 -1
- package/dist/components/app/layouts/PublicNavbar.js +8 -6
- package/dist/components/app/layouts/index.js +2 -2
- package/dist/components/app/misc/ThemeToggle.d.ts.map +1 -1
- package/dist/components/app/misc/ThemeToggle.js +6 -17
- package/dist/components/app/misc/index.js +1 -1
- package/dist/components/auth/DevKeyring.js +4 -4
- package/dist/components/auth/forms/LoginForm.d.ts.map +1 -1
- package/dist/components/auth/forms/LoginForm.js +30 -50
- package/dist/components/auth/forms/SignupForm.d.ts.map +1 -1
- package/dist/components/auth/forms/SignupForm.js +86 -88
- package/dist/components/auth/forms/index.js +2 -2
- package/dist/components/auth/index.js +5 -5
- package/dist/components/auth/layouts/AuthWrapperWithPreload.js +1 -1
- package/dist/components/auth/layouts/index.js +2 -2
- package/dist/components/auth/pages/AuthErrorPage.d.ts +2 -0
- package/dist/components/auth/pages/AuthErrorPage.d.ts.map +1 -0
- package/dist/components/auth/pages/AuthErrorPage.js +44 -0
- package/dist/components/billing/ConfirmPlanChangeModal.d.ts +29 -0
- package/dist/components/billing/ConfirmPlanChangeModal.d.ts.map +1 -0
- package/dist/components/billing/ConfirmPlanChangeModal.js +100 -0
- package/dist/components/billing/DowngradeWarning.js +2 -2
- package/dist/components/billing/FeatureGate.js +3 -3
- package/dist/components/billing/FeaturePlaceholder.js +2 -2
- package/dist/components/billing/InvoiceStatusBadge.js +2 -2
- package/dist/components/billing/InvoicesPagination.js +1 -1
- package/dist/components/billing/InvoicesTable.js +4 -4
- package/dist/components/billing/ManageBillingButton.d.ts +3 -3
- package/dist/components/billing/ManageBillingButton.js +2 -2
- package/dist/components/billing/PricingTable.d.ts +3 -0
- package/dist/components/billing/PricingTable.d.ts.map +1 -1
- package/dist/components/billing/PricingTable.js +151 -76
- package/dist/components/billing/QuotaGate.d.ts +21 -0
- package/dist/components/billing/QuotaGate.d.ts.map +1 -0
- package/dist/components/billing/QuotaGate.js +33 -0
- package/dist/components/billing/SubscriptionStatus.js +6 -6
- package/dist/components/billing/UpgradeModal.js +2 -2
- package/dist/components/billing/UsageBar.js +3 -3
- package/dist/components/billing/UsageDashboard.js +2 -2
- package/dist/components/billing/index.d.ts +2 -0
- package/dist/components/billing/index.d.ts.map +1 -1
- package/dist/components/billing/index.js +15 -11
- package/dist/components/dashboard/block-editor/array-field.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/array-field.js +76 -23
- package/dist/components/dashboard/block-editor/block-canvas.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-canvas.js +4 -3
- package/dist/components/dashboard/block-editor/block-picker.d.ts +14 -2
- package/dist/components/dashboard/block-editor/block-picker.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-picker.js +306 -80
- package/dist/components/dashboard/block-editor/block-preview-canvas.d.ts +3 -1
- package/dist/components/dashboard/block-editor/block-preview-canvas.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-preview-canvas.js +135 -35
- package/dist/components/dashboard/block-editor/block-settings-panel.d.ts +4 -2
- package/dist/components/dashboard/block-editor/block-settings-panel.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-settings-panel.js +152 -71
- package/dist/components/dashboard/block-editor/builder-editor-view.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/builder-editor-view.js +392 -176
- package/dist/components/dashboard/block-editor/category-helpers.d.ts +62 -0
- package/dist/components/dashboard/block-editor/category-helpers.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/category-helpers.js +59 -0
- package/dist/components/dashboard/block-editor/config-panel.d.ts +18 -0
- package/dist/components/dashboard/block-editor/config-panel.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/config-panel.js +492 -0
- package/dist/components/dashboard/block-editor/dynamic-form.d.ts +9 -0
- package/dist/components/dashboard/block-editor/dynamic-form.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/dynamic-form.js +259 -40
- package/dist/components/dashboard/block-editor/entity-fields-sidebar.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/entity-fields-sidebar.js +87 -16
- package/dist/components/dashboard/block-editor/floating-block-toolbar.d.ts +14 -0
- package/dist/components/dashboard/block-editor/floating-block-toolbar.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/floating-block-toolbar.js +83 -0
- package/dist/components/dashboard/block-editor/page-settings-panel.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/page-settings-panel.js +18 -17
- package/dist/components/dashboard/block-editor/pattern-card.d.ts +8 -0
- package/dist/components/dashboard/block-editor/pattern-card.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/pattern-card.js +74 -0
- package/dist/components/dashboard/block-editor/pattern-reference-preview.d.ts +10 -0
- package/dist/components/dashboard/block-editor/pattern-reference-preview.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/pattern-reference-preview.js +187 -0
- package/dist/components/dashboard/block-editor/sortable-block.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/sortable-block.js +11 -10
- package/dist/components/dashboard/block-editor/status-selector.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/status-selector.js +4 -3
- package/dist/components/dashboard/block-editor/tree-view-node.d.ts +11 -0
- package/dist/components/dashboard/block-editor/tree-view-node.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/tree-view-node.js +91 -0
- package/dist/components/dashboard/block-editor/tree-view.d.ts +17 -0
- package/dist/components/dashboard/block-editor/tree-view.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/tree-view.js +125 -0
- package/dist/components/dashboard/block-editor/viewport-toggle.d.ts +10 -0
- package/dist/components/dashboard/block-editor/viewport-toggle.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/viewport-toggle.js +55 -0
- package/dist/components/dashboard/index.js +2 -2
- package/dist/components/dashboard/layouts/AuthGuard.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/AuthGuard.js +12 -6
- package/dist/components/dashboard/layouts/DashboardShell.d.ts +1 -1
- package/dist/components/dashboard/layouts/DashboardShell.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/DashboardShell.js +16 -7
- package/dist/components/dashboard/layouts/Sidebar.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/Sidebar.js +17 -29
- package/dist/components/dashboard/layouts/TopNavbar.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/TopNavbar.js +90 -78
- package/dist/components/dashboard/layouts/index.js +4 -4
- package/dist/components/dashboard/misc/NotificationsDropdown.d.ts.map +1 -1
- package/dist/components/dashboard/misc/NotificationsDropdown.js +8 -20
- package/dist/components/dashboard/misc/QuickCreateDropdown.d.ts.map +1 -1
- package/dist/components/dashboard/misc/QuickCreateDropdown.js +19 -19
- package/dist/components/dashboard/misc/SearchDropdown.d.ts.map +1 -1
- package/dist/components/dashboard/misc/SearchDropdown.js +11 -19
- package/dist/components/dashboard/mobile/MobileBottomNav.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/MobileBottomNav.js +10 -14
- package/dist/components/dashboard/mobile/MobileMoreSheet.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/MobileMoreSheet.js +14 -25
- package/dist/components/dashboard/mobile/MobileTopBar.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/MobileTopBar.js +10 -28
- package/dist/components/dashboard/mobile/QuickCreateSheet.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/QuickCreateSheet.js +5 -7
- package/dist/components/dashboard/mobile/index.js +4 -4
- package/dist/components/dashboard/navigation/DynamicNavigation.d.ts +2 -1
- package/dist/components/dashboard/navigation/DynamicNavigation.d.ts.map +1 -1
- package/dist/components/dashboard/navigation/DynamicNavigation.js +41 -34
- package/dist/components/devtools/BlockDetailViewer.js +7 -7
- package/dist/components/devtools/BlocksViewer.js +5 -5
- package/dist/components/devtools/ConfigViewer.d.ts.map +1 -1
- package/dist/components/devtools/ConfigViewer.js +5 -5
- package/dist/components/devtools/DevtoolsSidebar.d.ts +5 -2
- package/dist/components/devtools/DevtoolsSidebar.d.ts.map +1 -1
- package/dist/components/devtools/DevtoolsSidebar.js +110 -45
- package/dist/components/devtools/FeaturesViewer.js +5 -5
- package/dist/components/devtools/FileTree.js +1 -1
- package/dist/components/devtools/FlowsViewer.js +5 -5
- package/dist/components/devtools/MarkdownViewer.js +1 -1
- package/dist/components/devtools/TagsOverview.js +6 -6
- package/dist/components/devtools/TestCasesViewer.d.ts.map +1 -1
- package/dist/components/devtools/TestCasesViewer.js +37 -30
- package/dist/components/devtools/TestCoverageDashboard.d.ts +2 -0
- package/dist/components/devtools/TestCoverageDashboard.d.ts.map +1 -0
- package/dist/components/devtools/TestCoverageDashboard.js +234 -0
- package/dist/components/devtools/api-explorer/ApiDocsModal.d.ts +9 -0
- package/dist/components/devtools/api-explorer/ApiDocsModal.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/ApiDocsModal.js +79 -0
- package/dist/components/devtools/api-explorer/ApiEndpointsSidebar.d.ts +16 -0
- package/dist/components/devtools/api-explorer/ApiEndpointsSidebar.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/ApiEndpointsSidebar.js +275 -0
- package/dist/components/devtools/api-explorer/ApiExplorer.d.ts +11 -0
- package/dist/components/devtools/api-explorer/ApiExplorer.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/ApiExplorer.js +330 -0
- package/dist/components/devtools/api-explorer/ApiRequestPanel.d.ts +39 -0
- package/dist/components/devtools/api-explorer/ApiRequestPanel.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/ApiRequestPanel.js +239 -0
- package/dist/components/devtools/api-explorer/ApiResponsePanel.d.ts +9 -0
- package/dist/components/devtools/api-explorer/ApiResponsePanel.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/ApiResponsePanel.js +110 -0
- package/dist/components/devtools/api-explorer/JsonEditor.d.ts +30 -0
- package/dist/components/devtools/api-explorer/JsonEditor.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/JsonEditor.js +106 -0
- package/dist/components/devtools/api-explorer/JsonViewer.d.ts +40 -0
- package/dist/components/devtools/api-explorer/JsonViewer.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/JsonViewer.js +105 -0
- package/dist/components/devtools/api-explorer/PresetsTab.d.ts +10 -0
- package/dist/components/devtools/api-explorer/PresetsTab.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/PresetsTab.js +154 -0
- package/dist/components/devtools/api-explorer/index.d.ts +9 -0
- package/dist/components/devtools/api-explorer/index.d.ts.map +1 -0
- package/dist/components/devtools/api-explorer/index.js +19 -0
- package/dist/components/devtools/api-tester/ApiTester.d.ts.map +1 -1
- package/dist/components/devtools/api-tester/ApiTester.js +25 -20
- package/dist/components/devtools/api-tester/AuthSelector.d.ts +3 -1
- package/dist/components/devtools/api-tester/AuthSelector.d.ts.map +1 -1
- package/dist/components/devtools/api-tester/AuthSelector.js +25 -13
- package/dist/components/devtools/api-tester/KeyValueEditor.d.ts.map +1 -1
- package/dist/components/devtools/api-tester/KeyValueEditor.js +5 -6
- package/dist/components/devtools/api-tester/MethodSelector.js +2 -2
- package/dist/components/devtools/api-tester/PathParamsEditor.js +3 -3
- package/dist/components/devtools/api-tester/PayloadEditor.d.ts +10 -0
- package/dist/components/devtools/api-tester/PayloadEditor.d.ts.map +1 -1
- package/dist/components/devtools/api-tester/PayloadEditor.js +3 -27
- package/dist/components/devtools/api-tester/ResponseViewer.js +5 -5
- package/dist/components/devtools/api-tester/TeamSelector.d.ts +16 -0
- package/dist/components/devtools/api-tester/TeamSelector.d.ts.map +1 -0
- package/dist/components/devtools/api-tester/TeamSelector.js +209 -0
- package/dist/components/devtools/api-tester/index.js +9 -9
- package/dist/components/devtools/bdd/BDDHeader.js +3 -3
- package/dist/components/devtools/bdd/BDDTableOfContents.d.ts.map +1 -1
- package/dist/components/devtools/bdd/BDDTableOfContents.js +26 -2
- package/dist/components/devtools/bdd/BDDTestCard.d.ts.map +1 -1
- package/dist/components/devtools/bdd/BDDTestCard.js +80 -7
- package/dist/components/devtools/bdd/BDDTestViewer.js +8 -8
- package/dist/components/devtools/bdd/GherkinHighlighter.js +1 -1
- package/dist/components/devtools/bdd/index.js +6 -6
- package/dist/components/devtools/bdd/parser.d.ts.map +1 -1
- package/dist/components/devtools/bdd/parser.js +35 -2
- package/dist/components/devtools/bdd/types.d.ts +8 -1
- package/dist/components/devtools/bdd/types.d.ts.map +1 -1
- package/dist/components/devtools/index.d.ts +2 -0
- package/dist/components/devtools/index.d.ts.map +1 -1
- package/dist/components/devtools/index.js +17 -14
- package/dist/components/devtools/scheduled-actions/actions-table.d.ts +1 -0
- package/dist/components/devtools/scheduled-actions/actions-table.d.ts.map +1 -1
- package/dist/components/devtools/scheduled-actions/actions-table.js +186 -50
- package/dist/components/devtools/scheduled-actions/filters.js +3 -3
- package/dist/components/devtools/scheduled-actions/types.d.ts +1 -0
- package/dist/components/devtools/scheduled-actions/types.d.ts.map +1 -1
- package/dist/components/docs/docs-layout.js +2 -2
- package/dist/components/docs/docs-sidebar.d.ts +6 -0
- package/dist/components/docs/docs-sidebar.d.ts.map +1 -1
- package/dist/components/docs/docs-sidebar.js +88 -266
- package/dist/components/docs/index.d.ts +1 -0
- package/dist/components/docs/index.d.ts.map +1 -1
- package/dist/components/docs/index.js +7 -5
- package/dist/components/docs/superadmin-docs-sidebar.d.ts +7 -0
- package/dist/components/docs/superadmin-docs-sidebar.d.ts.map +1 -0
- package/dist/components/docs/superadmin-docs-sidebar.js +122 -0
- package/dist/components/entities/EntityBulkActions.js +19 -19
- package/dist/components/entities/EntityChildManager.d.ts.map +1 -1
- package/dist/components/entities/EntityChildManager.js +12 -31
- package/dist/components/entities/EntityDetail.d.ts.map +1 -1
- package/dist/components/entities/EntityDetail.js +10 -22
- package/dist/components/entities/EntityDetailHeader.js +13 -13
- package/dist/components/entities/EntityDetailPage.js +6 -6
- package/dist/components/entities/EntityFieldRenderer.d.ts.map +1 -1
- package/dist/components/entities/EntityFieldRenderer.js +45 -30
- package/dist/components/entities/EntityForm.d.ts.map +1 -1
- package/dist/components/entities/EntityForm.js +16 -16
- package/dist/components/entities/EntityList.d.ts.map +1 -1
- package/dist/components/entities/EntityList.js +19 -37
- package/dist/components/entities/EntityNavigation.js +6 -6
- package/dist/components/entities/EntityPageHeader.js +1 -1
- package/dist/components/entities/EntitySearch.d.ts.map +1 -1
- package/dist/components/entities/EntitySearch.js +16 -29
- package/dist/components/entities/EntityTable.d.ts.map +1 -1
- package/dist/components/entities/EntityTable.js +42 -41
- package/dist/components/entities/ErrorBoundary.js +3 -3
- package/dist/components/entities/index.js +15 -15
- package/dist/components/entities/wrappers/EntityDetailWrapper.d.ts.map +1 -1
- package/dist/components/entities/wrappers/EntityDetailWrapper.js +16 -44
- package/dist/components/entities/wrappers/EntityFormWrapper.js +7 -7
- package/dist/components/entities/wrappers/EntityListWrapper.js +18 -18
- package/dist/components/entities/wrappers/index.js +3 -3
- package/dist/components/media/MediaCard.d.ts +24 -0
- package/dist/components/media/MediaCard.d.ts.map +1 -0
- package/dist/components/media/MediaCard.js +158 -0
- package/dist/components/media/MediaDetailPanel.d.ts +18 -0
- package/dist/components/media/MediaDetailPanel.d.ts.map +1 -0
- package/dist/components/media/MediaDetailPanel.js +343 -0
- package/dist/components/media/MediaGrid.d.ts +27 -0
- package/dist/components/media/MediaGrid.d.ts.map +1 -0
- package/dist/components/media/MediaGrid.js +79 -0
- package/dist/components/media/MediaLibrary.d.ts +20 -0
- package/dist/components/media/MediaLibrary.d.ts.map +1 -0
- package/dist/components/media/MediaLibrary.js +229 -0
- package/dist/components/media/MediaList.d.ts +25 -0
- package/dist/components/media/MediaList.d.ts.map +1 -0
- package/dist/components/media/MediaList.js +185 -0
- package/dist/components/media/MediaSelector.d.ts +19 -0
- package/dist/components/media/MediaSelector.d.ts.map +1 -0
- package/dist/components/media/MediaSelector.js +146 -0
- package/dist/components/media/MediaTagFilter.d.ts +16 -0
- package/dist/components/media/MediaTagFilter.d.ts.map +1 -0
- package/dist/components/media/MediaTagFilter.js +122 -0
- package/dist/components/media/MediaToolbar.d.ts +25 -0
- package/dist/components/media/MediaToolbar.d.ts.map +1 -0
- package/dist/components/media/MediaToolbar.js +136 -0
- package/dist/components/media/MediaUploadZone.d.ts +19 -0
- package/dist/components/media/MediaUploadZone.d.ts.map +1 -0
- package/dist/components/media/MediaUploadZone.js +248 -0
- package/dist/components/media/index.d.ts +15 -0
- package/dist/components/media/index.d.ts.map +1 -0
- package/dist/components/media/index.js +20 -0
- package/dist/components/patterns/DeletedPatternPlaceholder.d.ts +33 -0
- package/dist/components/patterns/DeletedPatternPlaceholder.d.ts.map +1 -0
- package/dist/components/patterns/DeletedPatternPlaceholder.js +44 -0
- package/dist/components/patterns/PatternDeleteDialog.d.ts +41 -0
- package/dist/components/patterns/PatternDeleteDialog.d.ts.map +1 -0
- package/dist/components/patterns/PatternDeleteDialog.js +148 -0
- package/dist/components/patterns/PatternUsageReport.d.ts +15 -0
- package/dist/components/patterns/PatternUsageReport.d.ts.map +1 -0
- package/dist/components/patterns/PatternUsageReport.js +134 -0
- package/dist/components/patterns/PatternUsageStats.d.ts +14 -0
- package/dist/components/patterns/PatternUsageStats.d.ts.map +1 -0
- package/dist/components/patterns/PatternUsageStats.js +63 -0
- package/dist/components/patterns/PatternUsageTable.d.ts +15 -0
- package/dist/components/patterns/PatternUsageTable.d.ts.map +1 -0
- package/dist/components/patterns/PatternUsageTable.js +134 -0
- package/dist/components/patterns/index.d.ts +11 -0
- package/dist/components/patterns/index.d.ts.map +1 -0
- package/dist/components/patterns/index.js +12 -0
- package/dist/components/patterns/pages/PatternEditPage.d.ts +8 -0
- package/dist/components/patterns/pages/PatternEditPage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternEditPage.js +80 -0
- package/dist/components/patterns/pages/PatternReportsPage.d.ts +9 -0
- package/dist/components/patterns/pages/PatternReportsPage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternReportsPage.js +133 -0
- package/dist/components/patterns/pages/PatternsCreatePage.d.ts +8 -0
- package/dist/components/patterns/pages/PatternsCreatePage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternsCreatePage.js +49 -0
- package/dist/components/patterns/pages/PatternsListPage.d.ts +8 -0
- package/dist/components/patterns/pages/PatternsListPage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternsListPage.js +336 -0
- package/dist/components/patterns/pages/index.d.ts +11 -0
- package/dist/components/patterns/pages/index.d.ts.map +1 -0
- package/dist/components/patterns/pages/index.js +10 -0
- package/dist/components/permissions/NoPermission.js +2 -2
- package/dist/components/permissions/PermissionGate.js +1 -1
- package/dist/components/permissions/PermissionsMatrix.js +4 -4
- package/dist/components/permissions/index.js +3 -3
- package/dist/components/public/entities/PublicEntityCard.js +2 -2
- package/dist/components/public/entities/PublicEntityDetail.js +9 -9
- package/dist/components/public/entities/PublicEntityGrid.js +9 -9
- package/dist/components/public/entities/index.js +3 -3
- package/dist/components/public/index.js +2 -2
- package/dist/components/public/pageBuilder/PageRenderer.d.ts.map +1 -1
- package/dist/components/public/pageBuilder/PageRenderer.js +11 -2
- package/dist/components/public/pageBuilder/index.js +1 -1
- package/dist/components/settings/SettingsPageSkeleton.js +2 -2
- package/dist/components/settings/index.js +2 -2
- package/dist/components/settings/layouts/SettingsSidebar.d.ts.map +1 -1
- package/dist/components/settings/layouts/SettingsSidebar.js +22 -17
- package/dist/components/settings/layouts/index.js +1 -1
- package/dist/components/shared/CopyableId.js +2 -2
- package/dist/components/shared/MultiSelectFilter.js +3 -3
- package/dist/components/shared/SearchInput.js +2 -2
- package/dist/components/shared/index.js +3 -3
- package/dist/components/superadmin/filters/FilterDropdown.js +2 -2
- package/dist/components/superadmin/filters/PaginationControls.d.ts +3 -1
- package/dist/components/superadmin/filters/PaginationControls.d.ts.map +1 -1
- package/dist/components/superadmin/filters/PaginationControls.js +10 -9
- package/dist/components/superadmin/filters/SearchInput.js +3 -3
- package/dist/components/superadmin/filters/index.js +3 -3
- package/dist/components/superadmin/index.js +8 -8
- package/dist/components/superadmin/layouts/SuperadminSidebar.d.ts +4 -1
- package/dist/components/superadmin/layouts/SuperadminSidebar.d.ts.map +1 -1
- package/dist/components/superadmin/layouts/SuperadminSidebar.js +68 -7
- package/dist/components/superadmin/layouts/index.js +1 -1
- package/dist/components/superadmin/misc/ComponentGallery.d.ts.map +1 -1
- package/dist/components/superadmin/misc/ComponentGallery.js +81 -16
- package/dist/components/superadmin/misc/FieldTypesGallery.js +5 -5
- package/dist/components/superadmin/misc/ThemePreview.js +3 -3
- package/dist/components/superadmin/misc/index.js +3 -3
- package/dist/components/superadmin/tables/PlanFeaturesMatrix.js +6 -6
- package/dist/components/superadmin/tables/RolesPermissionsMatrix.js +5 -5
- package/dist/components/superadmin/tables/TeamsTable.js +8 -8
- package/dist/components/superadmin/tables/index.js +3 -3
- package/dist/components/teams/CreateTeamButton.js +3 -3
- package/dist/components/teams/CreateTeamDialog.js +7 -7
- package/dist/components/teams/InlineEditableField.d.ts +13 -0
- package/dist/components/teams/InlineEditableField.d.ts.map +1 -0
- package/dist/components/teams/InlineEditableField.js +246 -0
- package/dist/components/teams/InviteMemberButton.js +3 -3
- package/dist/components/teams/InviteMemberDialog.js +8 -8
- package/dist/components/teams/TeamBadge.js +1 -1
- package/dist/components/teams/TeamDetailSection.js +3 -3
- package/dist/components/teams/TeamMembersList.d.ts.map +1 -1
- package/dist/components/teams/TeamMembersList.js +16 -13
- package/dist/components/teams/TeamPendingInvitations.d.ts.map +1 -1
- package/dist/components/teams/TeamPendingInvitations.js +18 -7
- package/dist/components/teams/TeamSwitchModal.js +4 -4
- package/dist/components/teams/TeamSwitcher.js +7 -7
- package/dist/components/teams/TeamSwitcherCompact.js +7 -7
- package/dist/components/teams/index.js +11 -11
- package/dist/components/ui/accordion.d.ts +1 -7
- package/dist/components/ui/accordion.d.ts.map +1 -1
- package/dist/components/ui/accordion.js +616 -8
- package/dist/components/ui/address-input.js +4 -4
- package/dist/components/ui/alert-dialog.js +2 -2
- package/dist/components/ui/alert.js +1 -1
- package/dist/components/ui/audio-upload.js +3 -3
- package/dist/components/ui/avatar.d.ts +1 -6
- package/dist/components/ui/avatar.d.ts.map +1 -1
- package/dist/components/ui/avatar.js +624 -5
- package/dist/components/ui/badge.d.ts +1 -9
- package/dist/components/ui/badge.d.ts.map +1 -1
- package/dist/components/ui/badge.js +632 -3
- package/dist/components/ui/breadcrumb.js +1 -1
- package/dist/components/ui/button-group.js +1 -1
- package/dist/components/ui/button.d.ts +1 -10
- package/dist/components/ui/button.d.ts.map +1 -1
- package/dist/components/ui/button.js +617 -15
- package/dist/components/ui/calendar.js +2 -2
- package/dist/components/ui/card.d.ts +1 -8
- package/dist/components/ui/card.d.ts.map +1 -1
- package/dist/components/ui/card.js +617 -22
- package/dist/components/ui/checkbox.d.ts +1 -4
- package/dist/components/ui/checkbox.d.ts.map +1 -1
- package/dist/components/ui/checkbox.js +627 -4
- package/dist/components/ui/combobox.js +4 -4
- package/dist/components/ui/command.js +2 -2
- package/dist/components/ui/context-menu.js +1 -1
- package/dist/components/ui/country-select.js +2 -2
- package/dist/components/ui/currency-select.js +2 -2
- package/dist/components/ui/dialog.js +1 -1
- package/dist/components/ui/double-range.js +1 -1
- package/dist/components/ui/dropdown-menu.js +1 -1
- package/dist/components/ui/dynamic-icon.d.ts +12 -0
- package/dist/components/ui/dynamic-icon.d.ts.map +1 -0
- package/dist/components/ui/dynamic-icon.js +11 -0
- package/dist/components/ui/file-upload.js +3 -3
- package/dist/components/ui/form.js +2 -2
- package/dist/components/ui/google-icon.js +1 -1
- package/dist/components/ui/image-upload.js +3 -3
- package/dist/components/ui/index.d.ts +8 -0
- package/dist/components/ui/index.d.ts.map +1 -1
- package/dist/components/ui/index.js +55 -47
- package/dist/components/ui/input.d.ts +1 -3
- package/dist/components/ui/input.d.ts.map +1 -1
- package/dist/components/ui/input.js +631 -3
- package/dist/components/ui/label.d.ts +1 -4
- package/dist/components/ui/label.d.ts.map +1 -1
- package/dist/components/ui/label.js +647 -6
- package/dist/components/ui/last-used-badge.d.ts.map +1 -1
- package/dist/components/ui/last-used-badge.js +1 -3
- package/dist/components/ui/menubar.js +1 -1
- package/dist/components/ui/multi-select.js +5 -5
- package/dist/components/ui/optimized-image.d.ts +88 -0
- package/dist/components/ui/optimized-image.d.ts.map +1 -0
- package/dist/components/ui/optimized-image.js +118 -0
- package/dist/components/ui/pagination.js +2 -2
- package/dist/components/ui/password-input.d.ts +7 -0
- package/dist/components/ui/password-input.d.ts.map +1 -1
- package/dist/components/ui/password-input.js +15 -8
- package/dist/components/ui/phone-input.js +2 -2
- package/dist/components/ui/popover.js +1 -1
- package/dist/components/ui/progress.d.ts +1 -4
- package/dist/components/ui/progress.d.ts.map +1 -1
- package/dist/components/ui/progress.js +628 -3
- package/dist/components/ui/radio-group.js +1 -1
- package/dist/components/ui/rating.js +1 -1
- package/dist/components/ui/rich-text-editor.js +3 -3
- package/dist/components/ui/scroll-area.js +1 -1
- package/dist/components/ui/select.js +1 -1
- package/dist/components/ui/separator.d.ts +1 -4
- package/dist/components/ui/separator.d.ts.map +1 -1
- package/dist/components/ui/separator.js +629 -3
- package/dist/components/ui/sheet.js +1 -1
- package/dist/components/ui/simple-relation-select.d.ts +7 -1
- package/dist/components/ui/simple-relation-select.d.ts.map +1 -1
- package/dist/components/ui/simple-relation-select.js +23 -29
- package/dist/components/ui/skeleton-dashboard.d.ts +32 -0
- package/dist/components/ui/skeleton-dashboard.d.ts.map +1 -0
- package/dist/components/ui/skeleton-dashboard.js +69 -0
- package/dist/components/ui/skeleton-detail.d.ts.map +1 -1
- package/dist/components/ui/skeleton-detail.js +2 -3
- package/dist/components/ui/skeleton-features.d.ts +27 -0
- package/dist/components/ui/skeleton-features.d.ts.map +1 -0
- package/dist/components/ui/skeleton-features.js +90 -0
- package/dist/components/ui/skeleton-form.d.ts.map +1 -1
- package/dist/components/ui/skeleton-form.js +2 -3
- package/dist/components/ui/skeleton-list.d.ts.map +1 -1
- package/dist/components/ui/skeleton-list.js +2 -3
- package/dist/components/ui/skeleton-public.d.ts +26 -0
- package/dist/components/ui/skeleton-public.d.ts.map +1 -0
- package/dist/components/ui/skeleton-public.js +61 -0
- package/dist/components/ui/skeleton-settings.d.ts +54 -0
- package/dist/components/ui/skeleton-settings.d.ts.map +1 -0
- package/dist/components/ui/skeleton-settings.js +332 -0
- package/dist/components/ui/skeleton.d.ts +1 -2
- package/dist/components/ui/skeleton.d.ts.map +1 -1
- package/dist/components/ui/skeleton.js +645 -9
- package/dist/components/ui/slider.d.ts +1 -4
- package/dist/components/ui/slider.d.ts.map +1 -1
- package/dist/components/ui/slider.js +633 -5
- package/dist/components/ui/switch.d.ts +1 -4
- package/dist/components/ui/switch.d.ts.map +1 -1
- package/dist/components/ui/switch.js +626 -3
- package/dist/components/ui/table.js +1 -1
- package/dist/components/ui/tabs.d.ts +1 -7
- package/dist/components/ui/tabs.d.ts.map +1 -1
- package/dist/components/ui/tabs.js +613 -5
- package/dist/components/ui/tags-input.js +3 -3
- package/dist/components/ui/textarea.d.ts +1 -3
- package/dist/components/ui/textarea.d.ts.map +1 -1
- package/dist/components/ui/textarea.js +639 -8
- package/dist/components/ui/timezone-select.js +23 -23
- package/dist/components/ui/toggle.js +1 -1
- package/dist/components/ui/tooltip.js +1 -1
- package/dist/components/ui/user-display.js +4 -4
- package/dist/components/ui/user-select.js +8 -8
- package/dist/components/ui/video-upload.js +2 -2
- package/dist/components/users/tables/SuperAdminsTable.js +6 -6
- package/dist/components/users/tables/UsersTable.js +11 -11
- package/dist/contexts/SubscriptionContext.d.ts +2 -0
- package/dist/contexts/SubscriptionContext.d.ts.map +1 -1
- package/dist/contexts/SubscriptionContext.js +4 -2
- package/dist/contexts/TeamContext.d.ts +2 -0
- package/dist/contexts/TeamContext.d.ts.map +1 -1
- package/dist/contexts/TeamContext.js +91 -75
- package/dist/contexts/index.js +3 -3
- package/dist/contexts/sidebar-context.js +1 -1
- package/dist/entities/index.d.ts +9 -0
- package/dist/entities/index.d.ts.map +1 -0
- package/dist/entities/index.js +12 -0
- package/dist/entities/patterns/index.d.ts +11 -0
- package/dist/entities/patterns/index.d.ts.map +1 -0
- package/dist/entities/patterns/index.js +10 -0
- package/dist/entities/patterns/messages/de.json +76 -0
- package/dist/entities/patterns/messages/en.json +87 -0
- package/dist/entities/patterns/messages/es.json +86 -0
- package/dist/entities/patterns/messages/fr.json +76 -0
- package/dist/entities/patterns/messages/it.json +76 -0
- package/dist/entities/patterns/messages/pt.json +76 -0
- package/dist/entities/patterns/patterns.config.d.ts +9 -0
- package/dist/entities/patterns/patterns.config.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.config.js +81 -0
- package/dist/entities/patterns/patterns.fields.d.ts +12 -0
- package/dist/entities/patterns/patterns.fields.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.fields.js +95 -0
- package/dist/entities/patterns/patterns.service.d.ts +135 -0
- package/dist/entities/patterns/patterns.service.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.service.js +581 -0
- package/dist/entities/patterns/patterns.types.d.ts +102 -0
- package/dist/entities/patterns/patterns.types.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.types.js +6 -0
- package/dist/hooks/index.d.ts +5 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +44 -39
- package/dist/hooks/teams/index.d.ts +28 -0
- package/dist/hooks/teams/index.d.ts.map +1 -0
- package/dist/hooks/teams/index.js +10 -0
- package/dist/hooks/teams/useAdminTeams.d.ts +82 -0
- package/dist/hooks/teams/useAdminTeams.d.ts.map +1 -0
- package/dist/hooks/teams/useAdminTeams.js +37 -0
- package/dist/hooks/teams/useTeamSearch.d.ts +58 -0
- package/dist/hooks/teams/useTeamSearch.d.ts.map +1 -0
- package/dist/hooks/teams/useTeamSearch.js +35 -0
- package/dist/hooks/teams/useUserTeams.d.ts +44 -0
- package/dist/hooks/teams/useUserTeams.d.ts.map +1 -0
- package/dist/hooks/teams/useUserTeams.js +41 -0
- package/dist/hooks/useApiExplorerNavigation.d.ts +38 -0
- package/dist/hooks/useApiExplorerNavigation.d.ts.map +1 -0
- package/dist/hooks/useApiExplorerNavigation.js +48 -0
- package/dist/hooks/useAuth.js +4 -4
- package/dist/hooks/useAuthMethodDetector.js +1 -1
- package/dist/hooks/useContextAwareTranslations.js +1 -1
- package/dist/hooks/useEnabledEntities.js +1 -1
- package/dist/hooks/useEnsureUserMetadata.d.ts +4 -0
- package/dist/hooks/useEnsureUserMetadata.d.ts.map +1 -1
- package/dist/hooks/useEnsureUserMetadata.js +86 -61
- package/dist/hooks/useEntity.js +2 -2
- package/dist/hooks/useEntityConfig.js +1 -1
- package/dist/hooks/useEntityMutations.d.ts.map +1 -1
- package/dist/hooks/useEntityMutations.js +5 -9
- package/dist/hooks/useEntityQuery.d.ts.map +1 -1
- package/dist/hooks/useEntityQuery.js +22 -4
- package/dist/hooks/useEntitySearch.js +3 -3
- package/dist/hooks/useEntityTranslations.js +3 -3
- package/dist/hooks/useEntityWithMeta.js +2 -2
- package/dist/hooks/useFeature.js +1 -1
- package/dist/hooks/useInvoice.js +1 -1
- package/dist/hooks/useInvoices.js +1 -1
- package/dist/hooks/useLocale.js +3 -3
- package/dist/hooks/useMedia.d.ts +56 -0
- package/dist/hooks/useMedia.d.ts.map +1 -0
- package/dist/hooks/useMedia.js +187 -0
- package/dist/hooks/useMediaUpload.d.ts +27 -0
- package/dist/hooks/useMediaUpload.d.ts.map +1 -0
- package/dist/hooks/useMediaUpload.js +36 -0
- package/dist/hooks/useMembership.js +1 -1
- package/dist/hooks/usePatternUsages.d.ts +273 -0
- package/dist/hooks/usePatternUsages.d.ts.map +1 -0
- package/dist/hooks/usePatternUsages.js +100 -0
- package/dist/hooks/usePrefetch.d.ts +43 -0
- package/dist/hooks/usePrefetch.d.ts.map +1 -0
- package/dist/hooks/usePrefetch.js +56 -0
- package/dist/hooks/useQuickCreateEntities.d.ts.map +1 -1
- package/dist/hooks/useQuickCreateEntities.js +4 -4
- package/dist/hooks/useQuota.js +1 -1
- package/dist/hooks/useQuotaCheck.d.ts +26 -0
- package/dist/hooks/useQuotaCheck.d.ts.map +1 -0
- package/dist/hooks/useQuotaCheck.js +33 -0
- package/dist/hooks/useSearch.js +2 -2
- package/dist/hooks/useSidebarState.js +1 -1
- package/dist/hooks/useSubscription.js +1 -1
- package/dist/hooks/useTeam.d.ts +1 -1
- package/dist/hooks/useTeam.js +1 -1
- package/dist/hooks/useTeamMembers.js +1 -1
- package/dist/hooks/useTeamUpdate.d.ts +26 -0
- package/dist/hooks/useTeamUpdate.d.ts.map +1 -0
- package/dist/hooks/useTeamUpdate.js +31 -0
- package/dist/hooks/useTeams.d.ts +21 -5
- package/dist/hooks/useTeams.d.ts.map +1 -1
- package/dist/hooks/useTeams.js +7 -18
- package/dist/hooks/useTeamsConfig.js +2 -2
- package/dist/hooks/useTranslationPreload.js +1 -1
- package/dist/hooks/useUrlFilters.d.ts +1 -1
- package/dist/hooks/useUrlFilters.d.ts.map +1 -1
- package/dist/hooks/useUrlFilters.js +3 -4
- package/dist/hooks/useUserProfile.js +1 -1
- package/dist/hooks/useUserSettings.d.ts +5 -4
- package/dist/hooks/useUserSettings.d.ts.map +1 -1
- package/dist/hooks/useUserSettings.js +43 -41
- package/dist/hooks/useValidationSchemas.js +1 -1
- package/dist/i18n.d.ts.map +1 -1
- package/dist/i18n.js +29 -19
- package/dist/index.d.ts +7 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +23 -5
- package/dist/lib/actions/entity.actions.d.ts +184 -0
- package/dist/lib/actions/entity.actions.d.ts.map +1 -0
- package/dist/lib/actions/entity.actions.js +334 -0
- package/dist/lib/actions/index.d.ts +52 -0
- package/dist/lib/actions/index.d.ts.map +1 -0
- package/dist/lib/actions/index.js +38 -0
- package/dist/lib/actions/team.actions.d.ts +107 -0
- package/dist/lib/actions/team.actions.d.ts.map +1 -0
- package/dist/lib/actions/team.actions.js +220 -0
- package/dist/lib/actions/types.d.ts +98 -0
- package/dist/lib/actions/types.d.ts.map +1 -0
- package/dist/lib/actions/user.actions.d.ts +99 -0
- package/dist/lib/actions/user.actions.d.ts.map +1 -0
- package/dist/lib/actions/user.actions.js +149 -0
- package/dist/lib/api/api-error.d.ts +41 -0
- package/dist/lib/api/api-error.d.ts.map +1 -0
- package/dist/lib/api/api-error.js +61 -0
- package/dist/lib/api/auth/dual-auth.d.ts +21 -2
- package/dist/lib/api/auth/dual-auth.d.ts.map +1 -1
- package/dist/lib/api/auth/dual-auth.js +29 -13
- package/dist/lib/api/auth/permissions.js +1 -1
- package/dist/lib/api/auth.js +3 -3
- package/dist/lib/api/distributed-cache.d.ts +122 -0
- package/dist/lib/api/distributed-cache.d.ts.map +1 -0
- package/dist/lib/api/distributed-cache.js +306 -0
- package/dist/lib/api/entity/generic-handler.d.ts +1 -1
- package/dist/lib/api/entity/generic-handler.d.ts.map +1 -1
- package/dist/lib/api/entity/generic-handler.js +241 -174
- package/dist/lib/api/entity/public-resolver.js +1 -1
- package/dist/lib/api/entity/resolver.d.ts.map +1 -1
- package/dist/lib/api/entity/resolver.js +2 -6
- package/dist/lib/api/entity-handler.js +4 -4
- package/dist/lib/api/helpers.d.ts +22 -0
- package/dist/lib/api/helpers.d.ts.map +1 -1
- package/dist/lib/api/helpers.js +57 -15
- package/dist/lib/api/index.d.ts +4 -0
- package/dist/lib/api/index.d.ts.map +1 -1
- package/dist/lib/api/index.js +12 -5
- package/dist/lib/api/meta.middleware.js +2 -2
- package/dist/lib/api/permission-middleware.d.ts.map +1 -1
- package/dist/lib/api/permission-middleware.js +3 -2
- package/dist/lib/api/rate-limit.d.ts +29 -0
- package/dist/lib/api/rate-limit.d.ts.map +1 -1
- package/dist/lib/api/rate-limit.js +137 -4
- package/dist/lib/api/routes/index.d.ts +8 -0
- package/dist/lib/api/routes/index.d.ts.map +1 -0
- package/dist/lib/api/routes/index.js +4 -0
- package/dist/lib/api/routes/patterns-usages.d.ts +36 -0
- package/dist/lib/api/routes/patterns-usages.d.ts.map +1 -0
- package/dist/lib/api/routes/patterns-usages.js +83 -0
- package/dist/lib/auth/registration-guard-plugin.d.ts +14 -0
- package/dist/lib/auth/registration-guard-plugin.d.ts.map +1 -0
- package/dist/lib/auth/registration-guard-plugin.js +37 -0
- package/dist/lib/auth/registration-helpers.d.ts +68 -0
- package/dist/lib/auth/registration-helpers.d.ts.map +1 -0
- package/dist/lib/auth/registration-helpers.js +51 -0
- package/dist/lib/auth-client.d.ts +697 -2
- package/dist/lib/auth-client.d.ts.map +1 -1
- package/dist/lib/auth-client.js +8 -4
- package/dist/lib/auth.d.ts.map +1 -1
- package/dist/lib/auth.js +86 -22
- package/dist/lib/billing/config-types.d.ts +6 -4
- package/dist/lib/billing/config-types.d.ts.map +1 -1
- package/dist/lib/billing/enforcement.js +1 -1
- package/dist/lib/billing/gateways/factory.d.ts +36 -0
- package/dist/lib/billing/gateways/factory.d.ts.map +1 -0
- package/dist/lib/billing/gateways/factory.js +41 -0
- package/dist/lib/billing/gateways/interface.d.ts +38 -0
- package/dist/lib/billing/gateways/interface.d.ts.map +1 -0
- package/dist/lib/billing/gateways/polar.d.ts +54 -0
- package/dist/lib/billing/gateways/polar.d.ts.map +1 -0
- package/dist/lib/billing/gateways/polar.js +175 -0
- package/dist/lib/billing/gateways/stripe.d.ts +26 -69
- package/dist/lib/billing/gateways/stripe.d.ts.map +1 -1
- package/dist/lib/billing/gateways/stripe.js +154 -85
- package/dist/lib/billing/gateways/types.d.ts +63 -0
- package/dist/lib/billing/gateways/types.d.ts.map +1 -0
- package/dist/lib/billing/jobs.d.ts +1 -1
- package/dist/lib/billing/jobs.js +1 -1
- package/dist/lib/billing/polar-webhook.d.ts +38 -0
- package/dist/lib/billing/polar-webhook.d.ts.map +1 -0
- package/dist/lib/billing/schema.d.ts +4 -5
- package/dist/lib/billing/schema.d.ts.map +1 -1
- package/dist/lib/billing/schema.js +1 -1
- package/dist/lib/billing/stripe-webhook.d.ts +48 -0
- package/dist/lib/billing/stripe-webhook.d.ts.map +1 -0
- package/dist/lib/billing/stripe-webhook.js +316 -0
- package/dist/lib/billing/types.d.ts +6 -2
- package/dist/lib/billing/types.d.ts.map +1 -1
- package/dist/lib/blocks/pattern-resolver.d.ts +71 -0
- package/dist/lib/blocks/pattern-resolver.d.ts.map +1 -0
- package/dist/lib/blocks/pattern-resolver.js +32 -0
- package/dist/lib/blocks/patterns-resolver.service.d.ts +39 -0
- package/dist/lib/blocks/patterns-resolver.service.d.ts.map +1 -0
- package/dist/lib/blocks/patterns-resolver.service.js +67 -0
- package/dist/lib/config/app.config.d.ts.map +1 -1
- package/dist/lib/config/app.config.js +61 -0
- package/dist/lib/config/config-loader.js +1 -1
- package/dist/lib/config/config-sync.d.ts +16 -0
- package/dist/lib/config/config-sync.d.ts.map +1 -1
- package/dist/lib/config/config-sync.js +59 -19
- package/dist/lib/config/config-types.d.ts +9 -0
- package/dist/lib/config/config-types.d.ts.map +1 -1
- package/dist/lib/config/dashboard.config.d.ts +12 -0
- package/dist/lib/config/dashboard.config.d.ts.map +1 -1
- package/dist/lib/config/dashboard.config.js +14 -0
- package/dist/lib/config/index.d.js +4 -4
- package/dist/lib/config/index.js +4 -4
- package/dist/lib/config/types.d.ts +112 -19
- package/dist/lib/config/types.d.ts.map +1 -1
- package/dist/lib/db.d.ts +76 -0
- package/dist/lib/db.d.ts.map +1 -1
- package/dist/lib/db.js +188 -15
- package/dist/lib/docs/parser.d.ts +1 -1
- package/dist/lib/docs/parser.d.ts.map +1 -1
- package/dist/lib/docs/parser.js +1 -1
- package/dist/lib/email/factory.d.ts.map +1 -1
- package/dist/lib/email/factory.js +2 -5
- package/dist/lib/email/index.d.js +3 -3
- package/dist/lib/email/index.js +3 -3
- package/dist/lib/email/templates.d.ts +5 -1
- package/dist/lib/email/templates.d.ts.map +1 -1
- package/dist/lib/email/templates.js +61 -0
- package/dist/lib/email/types.d.ts +6 -0
- package/dist/lib/email/types.d.ts.map +1 -1
- package/dist/lib/entities/api-generator.js +3 -3
- package/dist/lib/entities/entity-hooks.d.ts.map +1 -1
- package/dist/lib/entities/entity-hooks.js +4 -9
- package/dist/lib/entities/external-api-generator.js +4 -4
- package/dist/lib/entities/helpers.js +1 -1
- package/dist/lib/entities/meta-adapter.js +5 -5
- package/dist/lib/entities/migration-helper.d.ts.map +1 -1
- package/dist/lib/entities/migration-helper.js +1 -20
- package/dist/lib/entities/pattern-usage-hooks.d.ts +31 -0
- package/dist/lib/entities/pattern-usage-hooks.d.ts.map +1 -0
- package/dist/lib/entities/pattern-usage-hooks.js +96 -0
- package/dist/lib/entities/queries.d.ts +47 -7
- package/dist/lib/entities/queries.d.ts.map +1 -1
- package/dist/lib/entities/queries.js +34 -27
- package/dist/lib/entities/query-generator.js +8 -7
- package/dist/lib/entities/registry.client.d.ts +8 -2
- package/dist/lib/entities/registry.client.d.ts.map +1 -1
- package/dist/lib/entities/registry.client.js +15 -23
- package/dist/lib/entities/registry.d.ts +25 -13
- package/dist/lib/entities/registry.d.ts.map +1 -1
- package/dist/lib/entities/registry.js +50 -63
- package/dist/lib/entities/schema-generator.d.ts.map +1 -1
- package/dist/lib/entities/schema-generator.js +11 -5
- package/dist/lib/entities/testing.d.ts.map +1 -1
- package/dist/lib/entities/testing.js +3 -11
- package/dist/lib/entities/types.d.ts +65 -56
- package/dist/lib/entities/types.d.ts.map +1 -1
- package/dist/lib/helpers/entity-meta.helpers.js +1 -1
- package/dist/lib/i18n/AuthTranslationPreloader.js +1 -1
- package/dist/lib/i18n/DashboardTranslationPreloader.js +1 -1
- package/dist/lib/i18n-utils.js +1 -1
- package/dist/lib/index.d.ts +1 -0
- package/dist/lib/index.d.ts.map +1 -1
- package/dist/lib/index.js +9 -8
- package/dist/lib/locale-client.js +1 -1
- package/dist/lib/locale.js +3 -3
- package/dist/lib/media/schemas.d.ts +39 -0
- package/dist/lib/media/schemas.d.ts.map +1 -0
- package/dist/lib/media/schemas.js +32 -0
- package/dist/lib/media/types.d.ts +69 -0
- package/dist/lib/media/types.d.ts.map +1 -0
- package/dist/lib/media/utils.d.ts +26 -0
- package/dist/lib/media/utils.d.ts.map +1 -0
- package/dist/lib/media/utils.js +33 -0
- package/dist/lib/middleware/index.d.ts +64 -0
- package/dist/lib/middleware/index.d.ts.map +1 -0
- package/dist/lib/middleware/index.js +59 -0
- package/dist/lib/namespace-loader.js +2 -2
- package/dist/lib/oauth/encryption.js +1 -1
- package/dist/lib/oauth/index.d.ts +1 -1
- package/dist/lib/oauth/index.js +4 -4
- package/dist/lib/oauth/metadata.js +1 -1
- package/dist/lib/oauth/token-refresh.d.ts.map +1 -1
- package/dist/lib/oauth/token-refresh.js +4 -3
- package/dist/lib/permissions/check.d.ts.map +1 -1
- package/dist/lib/permissions/check.js +7 -14
- package/dist/lib/permissions/hooks.js +2 -2
- package/dist/lib/permissions/init.js +1 -1
- package/dist/lib/permissions/merge.d.ts +8 -0
- package/dist/lib/permissions/merge.d.ts.map +1 -1
- package/dist/lib/permissions/system.d.ts.map +1 -1
- package/dist/lib/permissions/system.js +40 -1
- package/dist/lib/plugins/env-loader.d.ts.map +1 -1
- package/dist/lib/plugins/env-loader.js +11 -3
- package/dist/lib/plugins/plugin-loader.js +1 -1
- package/dist/lib/rate-limit-redis.d.ts +49 -0
- package/dist/lib/rate-limit-redis.d.ts.map +1 -0
- package/dist/lib/rate-limit-redis.js +184 -0
- package/dist/lib/role-helpers.js +1 -1
- package/dist/lib/scheduled-actions/cleanup.js +2 -2
- package/dist/lib/scheduled-actions/handlers/index.d.ts +10 -0
- package/dist/lib/scheduled-actions/handlers/index.d.ts.map +1 -0
- package/dist/lib/scheduled-actions/handlers/index.js +4 -0
- package/dist/lib/scheduled-actions/handlers/invalidate-pattern-cache.d.ts +17 -0
- package/dist/lib/scheduled-actions/handlers/invalidate-pattern-cache.d.ts.map +1 -0
- package/dist/lib/scheduled-actions/handlers/invalidate-pattern-cache.js +84 -0
- package/dist/lib/scheduled-actions/index.d.js +5 -5
- package/dist/lib/scheduled-actions/index.js +5 -5
- package/dist/lib/scheduled-actions/initializer.d.ts +6 -3
- package/dist/lib/scheduled-actions/initializer.d.ts.map +1 -1
- package/dist/lib/scheduled-actions/initializer.js +11 -6
- package/dist/lib/scheduled-actions/processor.d.ts +20 -4
- package/dist/lib/scheduled-actions/processor.d.ts.map +1 -1
- package/dist/lib/scheduled-actions/processor.js +132 -38
- package/dist/lib/scheduled-actions/registry.d.ts +3 -0
- package/dist/lib/scheduled-actions/registry.d.ts.map +1 -1
- package/dist/lib/scheduled-actions/registry.js +2 -1
- package/dist/lib/scheduled-actions/scheduler.d.ts +1 -1
- package/dist/lib/scheduled-actions/scheduler.d.ts.map +1 -1
- package/dist/lib/scheduled-actions/scheduler.js +77 -39
- package/dist/lib/scheduled-actions/types.d.ts +73 -0
- package/dist/lib/scheduled-actions/types.d.ts.map +1 -1
- package/dist/lib/selectors/core-selectors.d.ts +1589 -0
- package/dist/lib/selectors/core-selectors.d.ts.map +1 -0
- package/dist/lib/selectors/core-selectors.js +34 -0
- package/dist/lib/selectors/domains/auth.selectors.d.ts +81 -0
- package/dist/lib/selectors/domains/auth.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/auth.selectors.js +77 -0
- package/dist/lib/selectors/domains/block-editor.selectors.d.ts +295 -0
- package/dist/lib/selectors/domains/block-editor.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/block-editor.selectors.js +315 -0
- package/dist/lib/selectors/domains/common.selectors.d.ts +38 -0
- package/dist/lib/selectors/domains/common.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/common.selectors.js +29 -0
- package/dist/lib/selectors/domains/dashboard.selectors.d.ts +212 -0
- package/dist/lib/selectors/domains/dashboard.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/dashboard.selectors.js +118 -0
- package/dist/lib/selectors/domains/devtools.selectors.d.ts +247 -0
- package/dist/lib/selectors/domains/devtools.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/devtools.selectors.js +242 -0
- package/dist/lib/selectors/domains/entities.selectors.d.ts +268 -0
- package/dist/lib/selectors/domains/entities.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/entities.selectors.js +148 -0
- package/dist/lib/selectors/domains/global-search.selectors.d.ts +14 -0
- package/dist/lib/selectors/domains/global-search.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/global-search.selectors.js +10 -0
- package/dist/lib/selectors/domains/index.d.ts +20 -0
- package/dist/lib/selectors/domains/index.d.ts.map +1 -0
- package/dist/lib/selectors/domains/index.js +30 -0
- package/dist/lib/selectors/domains/media.selectors.d.ts +96 -0
- package/dist/lib/selectors/domains/media.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/media.selectors.js +103 -0
- package/dist/lib/selectors/domains/patterns.selectors.d.ts +64 -0
- package/dist/lib/selectors/domains/patterns.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/patterns.selectors.js +58 -0
- package/dist/lib/selectors/domains/public.selectors.d.ts +39 -0
- package/dist/lib/selectors/domains/public.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/public.selectors.js +30 -0
- package/dist/lib/selectors/domains/settings.selectors.d.ts +314 -0
- package/dist/lib/selectors/domains/settings.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/settings.selectors.js +315 -0
- package/dist/lib/selectors/domains/superadmin.selectors.d.ts +314 -0
- package/dist/lib/selectors/domains/superadmin.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/superadmin.selectors.js +283 -0
- package/dist/lib/selectors/domains/taxonomies.selectors.d.ts +33 -0
- package/dist/lib/selectors/domains/taxonomies.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/taxonomies.selectors.js +29 -0
- package/dist/lib/selectors/domains/teams.selectors.d.ts +109 -0
- package/dist/lib/selectors/domains/teams.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/teams.selectors.js +104 -0
- package/dist/lib/selectors/index.d.ts +11 -0
- package/dist/lib/selectors/index.d.ts.map +1 -0
- package/dist/lib/selectors/index.js +27 -0
- package/dist/lib/selectors/selector-factory.d.ts.map +1 -0
- package/dist/lib/selectors/selectors.d.ts +3171 -0
- package/dist/lib/selectors/selectors.d.ts.map +1 -0
- package/dist/lib/selectors/selectors.js +26 -0
- package/dist/lib/services/api-docs.service.d.ts +78 -0
- package/dist/lib/services/api-docs.service.d.ts.map +1 -0
- package/dist/lib/services/api-docs.service.js +82 -0
- package/dist/lib/services/api-presets.service.d.ts +94 -0
- package/dist/lib/services/api-presets.service.d.ts.map +1 -0
- package/dist/lib/services/api-presets.service.js +120 -0
- package/dist/lib/services/base-entity.service.js +1 -1
- package/dist/lib/services/block.service.d.ts +29 -0
- package/dist/lib/services/block.service.d.ts.map +1 -1
- package/dist/lib/services/block.service.js +45 -0
- package/dist/lib/services/docs.service.d.ts +154 -0
- package/dist/lib/services/docs.service.d.ts.map +1 -0
- package/dist/lib/services/docs.service.js +277 -0
- package/dist/lib/services/generic-entity.service.d.ts +163 -0
- package/dist/lib/services/generic-entity.service.d.ts.map +1 -0
- package/dist/lib/services/generic-entity.service.js +595 -0
- package/dist/lib/services/index.d.js +18 -18
- package/dist/lib/services/index.d.ts +10 -2
- package/dist/lib/services/index.d.ts.map +1 -1
- package/dist/lib/services/index.js +53 -18
- package/dist/lib/services/invoice.service.d.ts +3 -3
- package/dist/lib/services/invoice.service.js +3 -3
- package/dist/lib/services/media.service.d.ts +132 -0
- package/dist/lib/services/media.service.d.ts.map +1 -0
- package/dist/lib/services/media.service.js +396 -0
- package/dist/lib/services/membership.service.d.ts.map +1 -1
- package/dist/lib/services/membership.service.js +34 -5
- package/dist/lib/services/meta.service.js +2 -2
- package/dist/lib/services/pattern-usage.service.d.ts +123 -0
- package/dist/lib/services/pattern-usage.service.d.ts.map +1 -0
- package/dist/lib/services/pattern-usage.service.js +282 -0
- package/dist/lib/services/plan.service.d.ts +4 -4
- package/dist/lib/services/plan.service.d.ts.map +1 -1
- package/dist/lib/services/plan.service.js +9 -6
- package/dist/lib/services/plugin.service.d.ts +1 -0
- package/dist/lib/services/plugin.service.d.ts.map +1 -1
- package/dist/lib/services/plugin.service.js +37 -11
- package/dist/lib/services/subscription.service.d.ts +5 -5
- package/dist/lib/services/subscription.service.d.ts.map +1 -1
- package/dist/lib/services/subscription.service.js +63 -50
- package/dist/lib/services/team-member.service.js +2 -2
- package/dist/lib/services/team.service.d.ts.map +1 -1
- package/dist/lib/services/team.service.js +8 -8
- package/dist/lib/services/transactional-meta.service.d.ts.map +1 -1
- package/dist/lib/services/transactional-meta.service.js +5 -3
- package/dist/lib/services/translation.service.d.ts +14 -0
- package/dist/lib/services/translation.service.d.ts.map +1 -1
- package/dist/lib/services/translation.service.js +63 -4
- package/dist/lib/services/usage.service.js +4 -4
- package/dist/lib/services/user-flags.service.js +1 -1
- package/dist/lib/services/user.service.js +2 -2
- package/dist/lib/teams/actions.js +1 -1
- package/dist/lib/teams/schema.d.ts +45 -38
- package/dist/lib/teams/schema.d.ts.map +1 -1
- package/dist/lib/teams/schema.js +27 -10
- package/dist/lib/teams/teams.api.d.ts +64 -0
- package/dist/lib/teams/teams.api.d.ts.map +1 -0
- package/dist/lib/teams/teams.api.js +96 -0
- package/dist/lib/teams/teams.keys.d.ts +54 -0
- package/dist/lib/teams/teams.keys.d.ts.map +1 -0
- package/dist/lib/teams/teams.keys.js +35 -0
- package/dist/lib/teams/types.d.ts +50 -0
- package/dist/lib/teams/types.d.ts.map +1 -1
- package/dist/lib/teams/types.js +1 -1
- package/dist/lib/template-resolver.js +2 -2
- package/dist/lib/test/index.d.ts +10 -18
- package/dist/lib/test/index.d.ts.map +1 -1
- package/dist/lib/test/index.js +3 -38
- package/dist/lib/test/utils.d.ts +2 -154
- package/dist/lib/test/utils.d.ts.map +1 -1
- package/dist/lib/test/utils.js +1 -105
- package/dist/lib/theme/ThemeProvider.js +3 -3
- package/dist/lib/theme/get-default-theme-mode.d.ts +11 -0
- package/dist/lib/theme/get-default-theme-mode.d.ts.map +1 -1
- package/dist/lib/theme/get-default-theme-mode.js +44 -27
- package/dist/lib/theme/theme-loader.d.ts.map +1 -1
- package/dist/lib/theme/theme-loader.js +9 -5
- package/dist/lib/translations/i18n-integration.js +4 -4
- package/dist/lib/translations/registry.d.ts +2 -0
- package/dist/lib/translations/registry.d.ts.map +1 -1
- package/dist/lib/translations/registry.js +31 -3
- package/dist/lib/user-data.d.ts +18 -0
- package/dist/lib/user-data.d.ts.map +1 -1
- package/dist/lib/user-data.js +128 -18
- package/dist/lib/utils/cors.d.ts +71 -0
- package/dist/lib/utils/cors.d.ts.map +1 -0
- package/dist/lib/utils/cors.js +64 -0
- package/dist/lib/utils/index.d.ts +9 -0
- package/dist/lib/utils/index.d.ts.map +1 -0
- package/dist/lib/utils/index.js +9 -0
- package/dist/messages/de/admin.json +9 -1
- package/dist/messages/de/auth.json +50 -3
- package/dist/messages/de/billing.json +10 -0
- package/dist/messages/de/common.json +3 -1
- package/dist/messages/de/devtools.json +42 -1
- package/dist/messages/de/docs.json +5 -1
- package/dist/messages/de/features.json +8 -0
- package/dist/messages/de/index.d.ts +232 -1
- package/dist/messages/de/index.d.ts.map +1 -1
- package/dist/messages/de/index.js +2 -0
- package/dist/messages/de/index.ts +2 -0
- package/dist/messages/de/patterns.json +76 -0
- package/dist/messages/de/permissions.json +2 -0
- package/dist/messages/de/teams.json +67 -3
- package/dist/messages/en/admin.json +119 -3
- package/dist/messages/en/auth.json +112 -9
- package/dist/messages/en/billing.json +21 -0
- package/dist/messages/en/common.json +3 -1
- package/dist/messages/en/devtools.json +56 -1
- package/dist/messages/en/docs.json +5 -1
- package/dist/messages/en/features.json +8 -0
- package/dist/messages/en/index.d.ts +581 -1
- package/dist/messages/en/index.d.ts.map +1 -1
- package/dist/messages/en/index.js +4 -0
- package/dist/messages/en/index.ts +4 -0
- package/dist/messages/en/media.json +148 -0
- package/dist/messages/en/navigation.json +1 -0
- package/dist/messages/en/patterns.json +87 -0
- package/dist/messages/en/permissions.json +2 -0
- package/dist/messages/en/settings.json +1 -0
- package/dist/messages/en/teams.json +67 -3
- package/dist/messages/es/admin.json +119 -3
- package/dist/messages/es/auth.json +117 -14
- package/dist/messages/es/billing.json +21 -0
- package/dist/messages/es/common.json +3 -1
- package/dist/messages/es/devtools.json +44 -1
- package/dist/messages/es/docs.json +5 -1
- package/dist/messages/es/features.json +8 -0
- package/dist/messages/es/index.d.ts +546 -1
- package/dist/messages/es/index.d.ts.map +1 -1
- package/dist/messages/es/index.js +4 -0
- package/dist/messages/es/index.ts +4 -0
- package/dist/messages/es/media.json +148 -0
- package/dist/messages/es/navigation.json +1 -0
- package/dist/messages/es/patterns.json +87 -0
- package/dist/messages/es/permissions.json +2 -0
- package/dist/messages/es/settings.json +1 -0
- package/dist/messages/es/teams.json +23 -3
- package/dist/messages/fr/admin.json +9 -1
- package/dist/messages/fr/auth.json +50 -3
- package/dist/messages/fr/billing.json +10 -0
- package/dist/messages/fr/common.json +3 -1
- package/dist/messages/fr/devtools.json +42 -1
- package/dist/messages/fr/docs.json +5 -1
- package/dist/messages/fr/features.json +8 -0
- package/dist/messages/fr/index.d.ts +232 -1
- package/dist/messages/fr/index.d.ts.map +1 -1
- package/dist/messages/fr/index.js +2 -0
- package/dist/messages/fr/index.ts +2 -0
- package/dist/messages/fr/patterns.json +76 -0
- package/dist/messages/fr/permissions.json +2 -0
- package/dist/messages/fr/teams.json +67 -3
- package/dist/messages/index.js +7 -7
- package/dist/messages/it/admin.json +9 -1
- package/dist/messages/it/auth.json +50 -3
- package/dist/messages/it/billing.json +10 -0
- package/dist/messages/it/common.json +3 -1
- package/dist/messages/it/devtools.json +42 -1
- package/dist/messages/it/docs.json +5 -1
- package/dist/messages/it/features.json +8 -0
- package/dist/messages/it/index.d.ts +232 -1
- package/dist/messages/it/index.d.ts.map +1 -1
- package/dist/messages/it/index.js +2 -0
- package/dist/messages/it/index.ts +2 -0
- package/dist/messages/it/patterns.json +76 -0
- package/dist/messages/it/permissions.json +2 -0
- package/dist/messages/it/teams.json +67 -3
- package/dist/messages/pt/admin.json +9 -1
- package/dist/messages/pt/auth.json +50 -3
- package/dist/messages/pt/billing.json +10 -0
- package/dist/messages/pt/common.json +3 -1
- package/dist/messages/pt/devtools.json +42 -1
- package/dist/messages/pt/docs.json +5 -1
- package/dist/messages/pt/features.json +8 -0
- package/dist/messages/pt/index.d.ts +232 -1
- package/dist/messages/pt/index.d.ts.map +1 -1
- package/dist/messages/pt/index.js +2 -0
- package/dist/messages/pt/index.ts +2 -0
- package/dist/messages/pt/patterns.json +76 -0
- package/dist/messages/pt/permissions.json +2 -0
- package/dist/messages/pt/teams.json +67 -3
- package/dist/migrations/001_better_auth_and_functions.sql +23 -11
- package/dist/migrations/007_teams_table.sql +3 -0
- package/dist/migrations/008_team_members_table.sql +27 -23
- package/dist/migrations/010_teams_functions_triggers.sql +36 -6
- package/dist/migrations/017_scheduled_actions_table.sql +21 -0
- package/dist/migrations/018_patterns_table.sql +104 -0
- package/dist/migrations/019_pattern_usages_table.sql +74 -0
- package/dist/migrations/021_media.sql +207 -0
- package/dist/migrations/090_sample_data.sql +54 -1
- package/dist/nextspark-entities.d.ts +59 -0
- package/dist/nextspark-registries.d.ts +20 -0
- package/dist/providers/TranslationContextManager.js +1 -1
- package/dist/providers/index.js +4 -4
- package/dist/providers/query-provider.d.ts +0 -1
- package/dist/providers/query-provider.d.ts.map +1 -1
- package/dist/providers/query-provider.js +26 -3
- package/dist/styles/classes.json +113 -34
- package/dist/styles/ui.css +1 -1
- package/dist/templates/app/(auth)/accept-invite/[token]/page.tsx +338 -0
- package/dist/templates/app/(auth)/auth-error/page.tsx +26 -0
- package/dist/templates/app/(auth)/forgot-password/page.tsx +1 -1
- package/dist/templates/app/(auth)/reset-password/page.tsx +9 -9
- package/dist/templates/app/(auth)/signup/page.tsx +23 -1
- package/dist/templates/app/(auth)/verify-email/page.tsx +7 -7
- package/dist/templates/app/(public)/[...slug]/page.tsx +113 -7
- package/dist/templates/app/(public)/docs/[section]/[page]/page.tsx +90 -0
- package/dist/templates/app/(public)/docs/layout.tsx +25 -0
- package/dist/templates/app/(public)/docs/page.tsx +81 -0
- package/dist/templates/app/api/auth/[...all]/route.ts +86 -14
- package/dist/templates/app/api/csp-report/route.ts +176 -0
- package/dist/templates/app/api/devtools/config/entities/route.ts +6 -8
- package/dist/templates/app/api/devtools/config/theme/route.ts +3 -2
- package/dist/templates/app/api/devtools/tests/[...path]/route.ts +4 -3
- package/dist/templates/app/api/devtools/tests/route.ts +3 -2
- package/dist/templates/app/api/health/route.ts +44 -22
- package/dist/templates/app/api/internal/user-metadata/route.ts +13 -2
- package/dist/templates/app/api/superadmin/subscriptions/route.ts +8 -2
- package/dist/templates/app/api/superadmin/teams/[teamId]/route.ts +10 -3
- package/dist/templates/app/api/superadmin/teams/route.ts +3 -2
- package/dist/templates/app/api/superadmin/users/[userId]/route.ts +7 -6
- package/dist/templates/app/api/superadmin/users/route.ts +7 -6
- package/dist/templates/app/api/user/delete-account/route.ts +3 -2
- package/dist/templates/app/api/user/plan-flags/route.ts +7 -14
- package/dist/templates/app/api/user/profile/route.ts +7 -6
- package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +13 -7
- package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +13 -7
- package/dist/templates/app/api/v1/[entity]/[id]/route.ts +17 -10
- package/dist/templates/app/api/v1/[entity]/docs.md +369 -0
- package/dist/templates/app/api/v1/[entity]/presets.ts +194 -0
- package/dist/templates/app/api/v1/[entity]/route.ts +15 -8
- package/dist/templates/app/api/v1/api-keys/[id]/route.ts +9 -8
- package/dist/templates/app/api/v1/api-keys/docs.md +101 -0
- package/dist/templates/app/api/v1/api-keys/presets.ts +31 -0
- package/dist/templates/app/api/v1/api-keys/route.ts +7 -6
- package/dist/templates/app/api/v1/auth/docs.md +184 -0
- package/dist/templates/app/api/v1/auth/presets.ts +44 -0
- package/dist/templates/app/api/v1/auth/signup-with-invite/route.ts +3 -2
- package/dist/templates/app/api/v1/billing/cancel/route.ts +24 -25
- package/dist/templates/app/api/v1/billing/change-plan/route.ts +13 -12
- package/dist/templates/app/api/v1/billing/check-action/route.ts +15 -13
- package/dist/templates/app/api/v1/billing/checkout/route.ts +50 -23
- package/dist/templates/app/api/v1/billing/docs.md +209 -0
- package/dist/templates/app/api/v1/billing/plans/route.ts +5 -4
- package/dist/templates/app/api/v1/billing/portal/route.ts +15 -14
- package/dist/templates/app/api/v1/billing/presets.ts +121 -0
- package/dist/templates/app/api/v1/billing/webhooks/polar/route.ts +487 -0
- package/dist/templates/app/api/v1/billing/webhooks/stripe/route.ts +18 -421
- package/dist/templates/app/api/v1/blocks/[slug]/route.ts +4 -3
- package/dist/templates/app/api/v1/blocks/docs.md +173 -0
- package/dist/templates/app/api/v1/blocks/presets.ts +121 -0
- package/dist/templates/app/api/v1/blocks/route.ts +3 -2
- package/dist/templates/app/api/v1/blocks/validate/route.ts +5 -3
- package/dist/templates/app/api/v1/cron/docs.md +116 -0
- package/dist/templates/app/api/v1/cron/presets.ts +26 -0
- package/dist/templates/app/api/v1/cron/process/route.ts +4 -6
- package/dist/templates/app/api/v1/devtools/blocks/route.ts +3 -2
- package/dist/templates/app/api/v1/devtools/docs/route.ts +151 -0
- package/dist/templates/app/api/v1/devtools/docs.md +204 -0
- package/dist/templates/app/api/v1/devtools/features/route.ts +3 -2
- package/dist/templates/app/api/v1/devtools/flows/route.ts +3 -2
- package/dist/templates/app/api/v1/devtools/presets.ts +113 -0
- package/dist/templates/app/api/v1/devtools/scheduled-actions/route.ts +125 -3
- package/dist/templates/app/api/v1/devtools/scheduled-actions/run/route.ts +110 -0
- package/dist/templates/app/api/v1/devtools/testing/route.ts +3 -2
- package/dist/templates/app/api/v1/media/[id]/route.ts +180 -0
- package/dist/templates/app/api/v1/media/[id]/tags/route.ts +220 -0
- package/dist/templates/app/api/v1/media/check-duplicates/route.ts +68 -0
- package/dist/templates/app/api/v1/media/docs.md +117 -0
- package/dist/templates/app/api/v1/media/presets.ts +24 -0
- package/dist/templates/app/api/v1/media/route.ts +68 -0
- package/dist/templates/app/api/v1/media/upload/route.ts +172 -36
- package/dist/templates/app/api/v1/media-tags/route.ts +85 -0
- package/dist/templates/app/api/v1/patterns/[id]/usages/route.ts +116 -0
- package/dist/templates/app/api/v1/plugin/[...path]/route.ts +16 -15
- package/dist/templates/app/api/v1/plugin/docs.md +79 -0
- package/dist/templates/app/api/v1/plugin/presets.ts +21 -0
- package/dist/templates/app/api/v1/plugin/route.ts +3 -2
- package/dist/templates/app/api/v1/post-categories/[id]/route.ts +10 -9
- package/dist/templates/app/api/v1/post-categories/docs.md +134 -0
- package/dist/templates/app/api/v1/post-categories/presets.ts +78 -0
- package/dist/templates/app/api/v1/post-categories/route.ts +5 -4
- package/dist/templates/app/api/v1/team-invitations/[token]/accept/route.ts +3 -3
- package/dist/templates/app/api/v1/team-invitations/[token]/decline/route.ts +3 -3
- package/dist/templates/app/api/v1/team-invitations/[token]/route.ts +3 -2
- package/dist/templates/app/api/v1/team-invitations/docs.md +88 -0
- package/dist/templates/app/api/v1/team-invitations/presets.ts +43 -0
- package/dist/templates/app/api/v1/team-invitations/route.ts +3 -2
- package/dist/templates/app/api/v1/teams/[teamId]/invitations/route.ts +5 -4
- package/dist/templates/app/api/v1/teams/[teamId]/invoices/[invoiceNumber]/route.ts +3 -2
- package/dist/templates/app/api/v1/teams/[teamId]/invoices/route.ts +3 -2
- package/dist/templates/app/api/v1/teams/[teamId]/members/[memberId]/route.ts +5 -4
- package/dist/templates/app/api/v1/teams/[teamId]/members/route.ts +5 -5
- package/dist/templates/app/api/v1/teams/[teamId]/route.ts +7 -6
- package/dist/templates/app/api/v1/teams/[teamId]/subscription/route.ts +3 -2
- package/dist/templates/app/api/v1/teams/[teamId]/usage/[limitSlug]/route.ts +5 -4
- package/dist/templates/app/api/v1/teams/docs.md +320 -0
- package/dist/templates/app/api/v1/teams/presets.ts +178 -0
- package/dist/templates/app/api/v1/teams/route.ts +7 -6
- package/dist/templates/app/api/v1/teams/switch/route.ts +3 -2
- package/dist/templates/app/api/v1/theme/[...path]/route.ts +16 -15
- package/dist/templates/app/api/v1/theme/docs.md +74 -0
- package/dist/templates/app/api/v1/theme/presets.ts +21 -0
- package/dist/templates/app/api/v1/theme/route.ts +3 -2
- package/dist/templates/app/api/v1/users/[id]/meta/[key]/route.ts +7 -6
- package/dist/templates/app/api/v1/users/[id]/route.ts +9 -8
- package/dist/templates/app/api/v1/users/docs.md +93 -0
- package/dist/templates/app/api/v1/users/presets.ts +59 -0
- package/dist/templates/app/api/v1/users/route.ts +7 -6
- package/dist/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +11 -8
- package/dist/templates/app/dashboard/(main)/[entity]/loading.tsx +5 -2
- package/dist/templates/app/dashboard/(main)/[entity]/page.tsx +6 -1
- package/dist/templates/app/dashboard/(main)/layout.tsx +69 -25
- package/dist/templates/app/dashboard/(main)/loading.tsx +8 -0
- package/dist/templates/app/dashboard/(main)/media/page.tsx +619 -0
- package/dist/templates/app/dashboard/(main)/page.tsx +1 -3
- package/dist/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +117 -0
- package/dist/templates/app/dashboard/(main)/patterns/[id]/page.tsx +23 -0
- package/dist/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +174 -0
- package/dist/templates/app/dashboard/(main)/patterns/create/page.tsx +89 -0
- package/dist/templates/app/dashboard/(main)/patterns/page.tsx +447 -0
- package/dist/templates/app/dashboard/features/analytics/page.tsx +4 -1
- package/dist/templates/app/dashboard/features/automation/page.tsx +4 -1
- package/dist/templates/app/dashboard/features/layout.tsx +5 -2
- package/dist/templates/app/dashboard/features/loading.tsx +8 -0
- package/dist/templates/app/dashboard/features/webhooks/page.tsx +4 -1
- package/dist/templates/app/dashboard/permission-denied/page.tsx +4 -1
- package/dist/templates/app/dashboard/settings/api-keys/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/api-keys/page.tsx +75 -75
- package/dist/templates/app/dashboard/settings/billing/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/billing/page.tsx +20 -26
- package/dist/templates/app/dashboard/settings/invoices/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/layout.tsx +8 -18
- package/dist/templates/app/dashboard/settings/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/notifications/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/notifications/page.tsx +17 -38
- package/dist/templates/app/dashboard/settings/page.tsx +5 -8
- package/dist/templates/app/dashboard/settings/password/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/password/page.tsx +25 -49
- package/dist/templates/app/dashboard/settings/plans/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/plans/page.tsx +29 -7
- package/dist/templates/app/dashboard/settings/profile/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/profile/page.tsx +25 -62
- package/dist/templates/app/dashboard/settings/security/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/security/page.tsx +17 -53
- package/dist/templates/app/dashboard/settings/teams/loading.tsx +8 -0
- package/dist/templates/app/dashboard/settings/teams/page.tsx +30 -31
- package/dist/templates/app/dashboard/settings/teams/permissions/page.tsx +4 -1
- package/dist/templates/app/devtools/api/[[...endpoint]]/page.tsx +33 -0
- package/dist/templates/app/devtools/api/layout.tsx +44 -0
- package/dist/templates/app/devtools/layout.tsx +3 -1
- package/dist/templates/app/devtools/plugins/[plugin]/page.tsx +17 -0
- package/dist/templates/app/devtools/scheduled-actions/page.tsx +1 -1
- package/dist/templates/app/globals.css +7 -312
- package/dist/templates/app/layout.tsx +16 -1
- package/dist/templates/app/superadmin/docs/[section]/[page]/page.tsx +92 -0
- package/dist/templates/app/superadmin/docs/page.tsx +75 -0
- package/dist/templates/app/superadmin/layout.tsx +3 -1
- package/dist/templates/app/superadmin/page.tsx +1 -1
- package/dist/templates/app/superadmin/plugins/[plugin]/page.tsx +17 -0
- package/dist/templates/app/superadmin/subscriptions/page.tsx +21 -18
- package/dist/templates/app/superadmin/teams/[teamId]/page.tsx +18 -15
- package/dist/templates/app/superadmin/teams/page.tsx +37 -84
- package/dist/templates/app/superadmin/users/page.tsx +4 -2
- package/dist/templates/blocks/README.md +80 -0
- package/dist/templates/blocks/cta-section/component.tsx +99 -0
- package/dist/templates/blocks/features-grid/component.tsx +111 -0
- package/dist/templates/blocks/hero/component.tsx +102 -0
- package/dist/templates/blocks/hero/schema.ts +33 -0
- package/dist/templates/blocks/testimonials/component.tsx +113 -0
- package/dist/templates/blocks/testimonials/schema.ts +41 -0
- package/dist/templates/blocks/text-content/component.tsx +96 -0
- package/dist/templates/ci-workflows/README.md +71 -0
- package/dist/templates/contents/themes/starter/config/app.config.ts +43 -18
- package/dist/templates/contents/themes/starter/config/features.config.ts +156 -0
- package/dist/templates/contents/themes/starter/config/permissions.config.ts +39 -0
- package/dist/templates/contents/themes/starter/docs/superadmin/01-setup/01-configuration.md +31 -0
- package/dist/templates/contents/themes/starter/docs/superadmin/02-entities/01-tasks.md +176 -0
- package/dist/templates/contents/themes/starter/entities/pages/api/docs.md +120 -0
- package/dist/templates/contents/themes/starter/entities/pages/api/presets.ts +72 -0
- package/dist/templates/contents/themes/starter/entities/pages/messages/en.json +41 -0
- package/dist/templates/contents/themes/starter/entities/pages/messages/es.json +41 -0
- package/dist/templates/contents/themes/starter/entities/pages/migrations/001_pages_table.sql +112 -0
- package/dist/templates/contents/themes/starter/entities/pages/migrations/002_pages_metas.sql +56 -0
- package/dist/templates/contents/themes/starter/entities/pages/migrations/003_add_status.sql +50 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages-management.service.ts +610 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.config.ts +95 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.fields.ts +101 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.service.ts +290 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.types.ts +124 -0
- package/dist/templates/contents/themes/starter/entities/posts/api/docs.md +127 -0
- package/dist/templates/contents/themes/starter/entities/posts/api/presets.ts +74 -0
- package/dist/templates/contents/themes/starter/entities/posts/components/post-header.tsx +97 -0
- package/dist/templates/contents/themes/starter/entities/posts/messages/en.json +55 -0
- package/dist/templates/contents/themes/starter/entities/posts/messages/es.json +55 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/001_posts_table.sql +115 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/003_add_status.sql +44 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/004_entity_taxonomy_relations.sql +129 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/006_posts_metas.sql +56 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.config.ts +102 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.fields.ts +116 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.service.ts +376 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.types.ts +74 -0
- package/dist/templates/contents/themes/starter/entities/tasks/api/docs.md +132 -0
- package/dist/templates/contents/themes/starter/entities/tasks/api/presets.ts +84 -0
- package/dist/templates/contents/themes/starter/entities/tasks/tasks.config.ts +2 -43
- package/dist/templates/contents/themes/starter/entities/tasks/tasks.service.ts +0 -5
- package/dist/templates/contents/themes/starter/lib/selectors.ts +2 -2
- package/dist/templates/contents/themes/starter/messages/de/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/de/dev.json +106 -0
- package/dist/templates/contents/themes/starter/messages/de/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/de/index.ts +17 -0
- package/dist/templates/contents/themes/starter/messages/de/navigation.json +1 -0
- package/dist/templates/contents/themes/starter/messages/en/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/en/dev.json +106 -0
- package/dist/templates/contents/themes/starter/messages/en/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/en/index.ts +17 -0
- package/dist/templates/contents/themes/starter/messages/en/navigation.json +1 -0
- package/dist/templates/contents/themes/starter/messages/es/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/es/dev.json +106 -0
- package/dist/templates/contents/themes/starter/messages/es/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/es/index.ts +17 -0
- package/dist/templates/contents/themes/starter/messages/es/navigation.json +1 -0
- package/dist/templates/contents/themes/starter/messages/fr/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/fr/dev.json +106 -0
- package/dist/templates/contents/themes/starter/messages/fr/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/fr/index.ts +17 -0
- package/dist/templates/contents/themes/starter/messages/fr/navigation.json +1 -0
- package/dist/templates/contents/themes/starter/messages/it/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/it/dev.json +106 -0
- package/dist/templates/contents/themes/starter/messages/it/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/it/index.ts +15 -0
- package/dist/templates/contents/themes/starter/messages/it/navigation.json +1 -0
- package/dist/templates/contents/themes/starter/messages/pt/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/pt/dev.json +106 -0
- package/dist/templates/contents/themes/starter/messages/pt/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/pt/index.ts +15 -0
- package/dist/templates/contents/themes/starter/messages/pt/navigation.json +1 -0
- package/dist/templates/contents/themes/starter/styles/globals.css +197 -7
- package/dist/templates/contents/themes/starter/templates/(public)/loading.tsx +5 -0
- package/dist/templates/contents/themes/starter/templates/dashboard/analytics/loading.tsx +5 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/access.bdd.md +262 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/access.cy.ts +171 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/navigation.bdd.md +261 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/navigation.cy.ts +157 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/pages.bdd.md +303 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/pages.cy.ts +184 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/docs/README.md +215 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/auth.bdd.md +354 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/auth.cy.ts +310 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/billing.bdd.md +276 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/billing.cy.ts +182 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/block-editor.bdd.md +491 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/block-editor.cy.ts +475 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-container.cy.ts +52 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-mobile.bdd.md +205 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-mobile.cy.ts +137 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-navigation.bdd.md +147 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-navigation.cy.ts +114 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-sidebar.bdd.md +76 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-sidebar.cy.ts +68 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-topnav.bdd.md +326 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-topnav.cy.ts +177 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/devtools.bdd.md +306 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/devtools.cy.ts +273 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/global-search.bdd.md +115 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/global-search.cy.ts +93 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/patterns.bdd.md +388 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/patterns.cy.ts +559 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-api-keys.bdd.md +266 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-api-keys.cy.ts +233 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-billing.bdd.md +78 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-billing.cy.ts +108 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-layout.bdd.md +129 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-layout.cy.ts +115 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-password.bdd.md +82 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-password.cy.ts +74 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-profile.bdd.md +77 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-profile.cy.ts +79 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-teams.bdd.md +130 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-teams.cy.ts +86 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/superadmin.bdd.md +261 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/superadmin.cy.ts +193 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/tasks.bdd.md +593 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/tasks.cy.ts +864 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/teams.bdd.md +278 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/teams.cy.ts +195 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-teams.bdd.md +261 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-teams.cy.ts +177 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-users.bdd.md +406 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-users.cy.ts +293 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/dashboard.bdd.md +235 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/dashboard.cy.ts +148 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/subscriptions-overview.bdd.md +290 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/subscriptions-overview.cy.ts +194 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/uat/entities/tasks/tasks-crud.bdd.md +278 -0
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/uat/entities/tasks/tasks-crud.cy.ts +431 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/components/DevKeyringPOM.ts +160 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/components/EntityForm.ts +375 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/components/EntityList.ts +389 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/components/TeamSwitcherPOM.ts +450 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/components/index.ts +13 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/core/BasePOM.ts +23 -120
- package/dist/templates/contents/themes/starter/tests/cypress/src/core/DashboardEntityPOM.ts +29 -661
- package/dist/templates/contents/themes/starter/tests/cypress/src/core/index.ts +2 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/entities/PatternsPOM.ts +333 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/entities/TasksPOM.ts +246 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/entities/index.ts +12 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/BillingPOM.ts +385 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/DashboardPOM.ts +271 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/DevtoolsPOM.ts +750 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/PageBuilderPOM.ts +283 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/PostEditorPOM.ts +313 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/ScheduledActionsPOM.ts +463 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/SettingsPOM.ts +523 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/SuperadminPOM.ts +851 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/SuperadminTeamRolesPOM.ts +285 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/features/index.ts +24 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/helpers/ApiInterceptor.ts +14 -164
- package/dist/templates/contents/themes/starter/tests/cypress/src/index.ts +88 -0
- package/dist/templates/contents/themes/starter/tests/cypress/src/selectors.ts +4 -4
- package/dist/templates/contents/themes/starter/tests/cypress/src/session-helpers.ts +340 -77
- package/dist/templates/contents/themes/starter/tests/cypress/support/e2e.ts +37 -4
- package/dist/templates/contents/themes/starter/tests/cypress.config.ts +84 -19
- package/dist/templates/contents/themes/starter/tests/jest/__mocks__/jose.js +22 -0
- package/dist/templates/contents/themes/starter/tests/jest/__mocks__/next-server.js +56 -0
- package/dist/templates/contents/themes/starter/tests/jest/example.test.tsx +87 -0
- package/dist/templates/contents/themes/starter/tests/jest/jest.config.cjs +95 -0
- package/dist/templates/contents/themes/starter/tests/jest/services/tasks.service.test.ts +547 -0
- package/dist/templates/contents/themes/starter/tests/jest/setup.ts +170 -0
- package/dist/templates/contents/themes/starter/tests/jest/tsconfig.jest.json +8 -0
- package/dist/templates/features/blog/blocks/post-content/component.tsx +2 -2
- package/dist/templates/features/blog/entities/posts/posts.config.ts +1 -0
- package/dist/templates/features/pages/blocks/hero/component.tsx +8 -5
- package/dist/templates/features/pages/blocks/hero/schema.ts +2 -1
- package/dist/templates/features/pages/entities/pages/pages.config.ts +1 -0
- package/dist/templates/instrumentation.ts +39 -0
- package/dist/templates/lib/billing/polar-webhook-extensions.ts +23 -0
- package/dist/templates/lib/billing/stripe-webhook-extensions.ts +23 -0
- package/dist/templates/migrations/README.md +408 -0
- package/dist/templates/next.config.mjs +136 -3
- package/dist/templates/pnpm-workspace.yaml +5 -0
- package/dist/templates/proxy.ts +194 -0
- package/dist/templates/scripts/cy-run-prod.cjs +277 -0
- package/dist/templates/tsconfig.cypress.json +2 -2
- package/dist/types/api-presets.d.ts +138 -0
- package/dist/types/api-presets.d.ts.map +1 -0
- package/dist/types/api-presets.js +6 -0
- package/dist/types/blocks.d.ts +35 -1
- package/dist/types/blocks.d.ts.map +1 -1
- package/dist/types/blocks.js +17 -1
- package/dist/types/docs.d.ts +11 -6
- package/dist/types/docs.d.ts.map +1 -1
- package/dist/types/index.d.ts +2 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +6 -4
- package/dist/types/pattern-reference.d.ts +70 -0
- package/dist/types/pattern-reference.d.ts.map +1 -0
- package/dist/types/pattern-reference.js +6 -0
- package/dist/types/plugin.d.ts +29 -0
- package/dist/types/plugin.d.ts.map +1 -1
- package/dist/types/theme.d.ts +2 -0
- package/dist/types/theme.d.ts.map +1 -1
- package/dist/types/user.types.js +1 -1
- package/globals.css +54 -0
- package/migrations/001_better_auth_and_functions.sql +23 -11
- package/migrations/007_teams_table.sql +3 -0
- package/migrations/008_team_members_table.sql +27 -23
- package/migrations/010_teams_functions_triggers.sql +36 -6
- package/migrations/017_scheduled_actions_table.sql +21 -0
- package/migrations/018_patterns_table.sql +104 -0
- package/migrations/019_pattern_usages_table.sql +74 -0
- package/migrations/021_media.sql +207 -0
- package/migrations/090_sample_data.sql +54 -1
- package/nextspark-entities.d.ts +59 -0
- package/package.json +185 -28
- package/scripts/build/docs-registry.mjs +94 -148
- package/scripts/build/registry/config.mjs +84 -5
- package/scripts/build/registry/discovery/api-presets.mjs +647 -0
- package/scripts/build/registry/discovery/blocks.mjs +8 -0
- package/scripts/build/registry/discovery/core-entities.mjs +166 -0
- package/scripts/build/registry/discovery/index.mjs +2 -0
- package/scripts/build/registry/discovery/permissions.mjs +92 -3
- package/scripts/build/registry/discovery/permissions.test.mjs +256 -0
- package/scripts/build/registry/discovery/plugins.mjs +25 -2
- package/scripts/build/registry/discovery/templates.mjs +82 -6
- package/scripts/build/registry/generators/api-presets-registry.mjs +410 -0
- package/scripts/build/registry/generators/billing-registry.mjs +6 -3
- package/scripts/build/registry/generators/block-registry.mjs +18 -3
- package/scripts/build/registry/generators/docs-registry.mjs +241 -0
- package/scripts/build/registry/generators/entity-registry.mjs +42 -7
- package/scripts/build/registry/generators/index.mjs +2 -1
- package/scripts/build/registry/generators/namespace-registry.mjs +2 -2
- package/scripts/build/registry/generators/permissions-registry.mjs +69 -102
- package/scripts/build/registry/generators/plugin-registry.mjs +92 -3
- package/scripts/build/registry/generators/route-handlers.mjs +8 -2
- package/scripts/build/registry/generators/template-registry.mjs +38 -11
- package/scripts/build/registry/generators/translation-registry.mjs +97 -9
- package/scripts/build/registry/generators/unified-registry.mjs +1 -0
- package/scripts/build/registry/index.mjs +0 -1
- package/scripts/build/registry/post-build/route-cleanup.mjs +0 -1
- package/scripts/build/registry/post-build/tree-display.mjs +21 -1
- package/scripts/build/registry/validate-env.test.mjs +92 -0
- package/scripts/build/registry.mjs +48 -15
- package/scripts/build/theme.mjs +124 -40
- package/scripts/create-theme.mjs +0 -0
- package/scripts/db/run-migrations.mjs +45 -16
- package/scripts/deploy/release-version.mjs +0 -0
- package/scripts/deploy/vercel-deploy.mjs +1 -1
- package/scripts/dev/watch-plugins.mjs +0 -0
- package/scripts/maintenance/update-core.mjs +0 -0
- package/scripts/postinstall.mjs +174 -0
- package/scripts/setup/npm-postinstall.mjs +0 -0
- package/scripts/setup/postinstall.mjs +0 -2
- package/scripts/setup/setup-ci.mjs +4 -5
- package/scripts/test/cy.mjs +98 -8
- package/scripts/test/jest-theme.mjs +65 -0
- package/scripts/utils/file-utils.mjs +34 -5
- package/scripts/utils/paths.mjs +30 -0
- package/scripts/validation/check-imports.sh +0 -0
- package/src/entities/index.ts +24 -0
- package/src/entities/patterns/index.ts +27 -0
- package/src/entities/patterns/messages/de.json +76 -0
- package/src/entities/patterns/messages/en.json +87 -0
- package/src/entities/patterns/messages/es.json +86 -0
- package/src/entities/patterns/messages/fr.json +76 -0
- package/src/entities/patterns/messages/it.json +76 -0
- package/src/entities/patterns/messages/pt.json +76 -0
- package/src/entities/patterns/patterns.config.ts +84 -0
- package/src/entities/patterns/patterns.fields.ts +104 -0
- package/src/entities/patterns/patterns.service.ts +718 -0
- package/src/entities/patterns/patterns.types.ts +118 -0
- package/styles/docs.css +82 -0
- package/styles/utilities.css +37 -0
- package/templates/app/(auth)/accept-invite/[token]/page.tsx +338 -0
- package/templates/app/(auth)/auth-error/page.tsx +26 -0
- package/templates/app/(auth)/forgot-password/page.tsx +1 -1
- package/templates/app/(auth)/reset-password/page.tsx +9 -9
- package/templates/app/(auth)/signup/page.tsx +23 -1
- package/templates/app/(auth)/verify-email/page.tsx +7 -7
- package/templates/app/(public)/[...slug]/page.tsx +113 -7
- package/templates/app/(public)/docs/[section]/[page]/page.tsx +90 -0
- package/templates/app/(public)/docs/layout.tsx +25 -0
- package/templates/app/(public)/docs/page.tsx +81 -0
- package/templates/app/api/auth/[...all]/route.ts +86 -14
- package/templates/app/api/csp-report/route.ts +176 -0
- package/templates/app/api/devtools/config/entities/route.ts +6 -8
- package/templates/app/api/devtools/config/theme/route.ts +3 -2
- package/templates/app/api/devtools/tests/[...path]/route.ts +4 -3
- package/templates/app/api/devtools/tests/route.ts +3 -2
- package/templates/app/api/health/route.ts +44 -22
- package/templates/app/api/internal/user-metadata/route.ts +13 -2
- package/templates/app/api/superadmin/subscriptions/route.ts +8 -2
- package/templates/app/api/superadmin/teams/[teamId]/route.ts +10 -3
- package/templates/app/api/superadmin/teams/route.ts +3 -2
- package/templates/app/api/superadmin/users/[userId]/route.ts +7 -6
- package/templates/app/api/superadmin/users/route.ts +7 -6
- package/templates/app/api/user/delete-account/route.ts +3 -2
- package/templates/app/api/user/plan-flags/route.ts +7 -14
- package/templates/app/api/user/profile/route.ts +7 -6
- package/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +13 -7
- package/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +13 -7
- package/templates/app/api/v1/[entity]/[id]/route.ts +17 -10
- package/templates/app/api/v1/[entity]/docs.md +369 -0
- package/templates/app/api/v1/[entity]/presets.ts +194 -0
- package/templates/app/api/v1/[entity]/route.ts +15 -8
- package/templates/app/api/v1/api-keys/[id]/route.ts +9 -8
- package/templates/app/api/v1/api-keys/docs.md +101 -0
- package/templates/app/api/v1/api-keys/presets.ts +31 -0
- package/templates/app/api/v1/api-keys/route.ts +7 -6
- package/templates/app/api/v1/auth/docs.md +184 -0
- package/templates/app/api/v1/auth/presets.ts +44 -0
- package/templates/app/api/v1/auth/signup-with-invite/route.ts +3 -2
- package/templates/app/api/v1/billing/cancel/route.ts +24 -25
- package/templates/app/api/v1/billing/change-plan/route.ts +13 -12
- package/templates/app/api/v1/billing/check-action/route.ts +15 -13
- package/templates/app/api/v1/billing/checkout/route.ts +50 -23
- package/templates/app/api/v1/billing/docs.md +209 -0
- package/templates/app/api/v1/billing/plans/route.ts +5 -4
- package/templates/app/api/v1/billing/portal/route.ts +15 -14
- package/templates/app/api/v1/billing/presets.ts +121 -0
- package/templates/app/api/v1/billing/webhooks/polar/route.ts +487 -0
- package/templates/app/api/v1/billing/webhooks/stripe/route.ts +18 -421
- package/templates/app/api/v1/blocks/[slug]/route.ts +4 -3
- package/templates/app/api/v1/blocks/docs.md +173 -0
- package/templates/app/api/v1/blocks/presets.ts +121 -0
- package/templates/app/api/v1/blocks/route.ts +3 -2
- package/templates/app/api/v1/blocks/validate/route.ts +5 -3
- package/templates/app/api/v1/cron/docs.md +116 -0
- package/templates/app/api/v1/cron/presets.ts +26 -0
- package/templates/app/api/v1/cron/process/route.ts +4 -6
- package/templates/app/api/v1/devtools/blocks/route.ts +3 -2
- package/templates/app/api/v1/devtools/docs/route.ts +151 -0
- package/templates/app/api/v1/devtools/docs.md +204 -0
- package/templates/app/api/v1/devtools/features/route.ts +3 -2
- package/templates/app/api/v1/devtools/flows/route.ts +3 -2
- package/templates/app/api/v1/devtools/presets.ts +113 -0
- package/templates/app/api/v1/devtools/scheduled-actions/route.ts +125 -3
- package/templates/app/api/v1/devtools/scheduled-actions/run/route.ts +110 -0
- package/templates/app/api/v1/devtools/testing/route.ts +3 -2
- package/templates/app/api/v1/media/[id]/route.ts +180 -0
- package/templates/app/api/v1/media/[id]/tags/route.ts +220 -0
- package/templates/app/api/v1/media/check-duplicates/route.ts +68 -0
- package/templates/app/api/v1/media/docs.md +117 -0
- package/templates/app/api/v1/media/presets.ts +24 -0
- package/templates/app/api/v1/media/route.ts +68 -0
- package/templates/app/api/v1/media/upload/route.ts +172 -36
- package/templates/app/api/v1/media-tags/route.ts +85 -0
- package/templates/app/api/v1/patterns/[id]/usages/route.ts +116 -0
- package/templates/app/api/v1/plugin/[...path]/route.ts +16 -15
- package/templates/app/api/v1/plugin/docs.md +79 -0
- package/templates/app/api/v1/plugin/presets.ts +21 -0
- package/templates/app/api/v1/plugin/route.ts +3 -2
- package/templates/app/api/v1/post-categories/[id]/route.ts +10 -9
- package/templates/app/api/v1/post-categories/docs.md +134 -0
- package/templates/app/api/v1/post-categories/presets.ts +78 -0
- package/templates/app/api/v1/post-categories/route.ts +5 -4
- package/templates/app/api/v1/team-invitations/[token]/accept/route.ts +3 -3
- package/templates/app/api/v1/team-invitations/[token]/decline/route.ts +3 -3
- package/templates/app/api/v1/team-invitations/[token]/route.ts +3 -2
- package/templates/app/api/v1/team-invitations/docs.md +88 -0
- package/templates/app/api/v1/team-invitations/presets.ts +43 -0
- package/templates/app/api/v1/team-invitations/route.ts +3 -2
- package/templates/app/api/v1/teams/[teamId]/invitations/route.ts +5 -4
- package/templates/app/api/v1/teams/[teamId]/invoices/[invoiceNumber]/route.ts +3 -2
- package/templates/app/api/v1/teams/[teamId]/invoices/route.ts +3 -2
- package/templates/app/api/v1/teams/[teamId]/members/[memberId]/route.ts +5 -4
- package/templates/app/api/v1/teams/[teamId]/members/route.ts +5 -5
- package/templates/app/api/v1/teams/[teamId]/route.ts +7 -6
- package/templates/app/api/v1/teams/[teamId]/subscription/route.ts +3 -2
- package/templates/app/api/v1/teams/[teamId]/usage/[limitSlug]/route.ts +5 -4
- package/templates/app/api/v1/teams/docs.md +320 -0
- package/templates/app/api/v1/teams/presets.ts +178 -0
- package/templates/app/api/v1/teams/route.ts +7 -6
- package/templates/app/api/v1/teams/switch/route.ts +3 -2
- package/templates/app/api/v1/theme/[...path]/route.ts +16 -15
- package/templates/app/api/v1/theme/docs.md +74 -0
- package/templates/app/api/v1/theme/presets.ts +21 -0
- package/templates/app/api/v1/theme/route.ts +3 -2
- package/templates/app/api/v1/users/[id]/meta/[key]/route.ts +7 -6
- package/templates/app/api/v1/users/[id]/route.ts +9 -8
- package/templates/app/api/v1/users/docs.md +93 -0
- package/templates/app/api/v1/users/presets.ts +59 -0
- package/templates/app/api/v1/users/route.ts +7 -6
- package/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +11 -8
- package/templates/app/dashboard/(main)/[entity]/loading.tsx +5 -2
- package/templates/app/dashboard/(main)/[entity]/page.tsx +6 -1
- package/templates/app/dashboard/(main)/layout.tsx +69 -25
- package/templates/app/dashboard/(main)/loading.tsx +8 -0
- package/templates/app/dashboard/(main)/media/page.tsx +619 -0
- package/templates/app/dashboard/(main)/page.tsx +1 -3
- package/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +117 -0
- package/templates/app/dashboard/(main)/patterns/[id]/page.tsx +23 -0
- package/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +174 -0
- package/templates/app/dashboard/(main)/patterns/create/page.tsx +89 -0
- package/templates/app/dashboard/(main)/patterns/page.tsx +447 -0
- package/templates/app/dashboard/features/analytics/page.tsx +4 -1
- package/templates/app/dashboard/features/automation/page.tsx +4 -1
- package/templates/app/dashboard/features/layout.tsx +5 -2
- package/templates/app/dashboard/features/loading.tsx +8 -0
- package/templates/app/dashboard/features/webhooks/page.tsx +4 -1
- package/templates/app/dashboard/permission-denied/page.tsx +4 -1
- package/templates/app/dashboard/settings/api-keys/loading.tsx +8 -0
- package/templates/app/dashboard/settings/api-keys/page.tsx +75 -75
- package/templates/app/dashboard/settings/billing/loading.tsx +8 -0
- package/templates/app/dashboard/settings/billing/page.tsx +20 -26
- package/templates/app/dashboard/settings/invoices/loading.tsx +8 -0
- package/templates/app/dashboard/settings/layout.tsx +8 -18
- package/templates/app/dashboard/settings/loading.tsx +8 -0
- package/templates/app/dashboard/settings/notifications/loading.tsx +8 -0
- package/templates/app/dashboard/settings/notifications/page.tsx +17 -38
- package/templates/app/dashboard/settings/page.tsx +5 -8
- package/templates/app/dashboard/settings/password/loading.tsx +8 -0
- package/templates/app/dashboard/settings/password/page.tsx +25 -49
- package/templates/app/dashboard/settings/plans/loading.tsx +8 -0
- package/templates/app/dashboard/settings/plans/page.tsx +29 -7
- package/templates/app/dashboard/settings/profile/loading.tsx +8 -0
- package/templates/app/dashboard/settings/profile/page.tsx +25 -62
- package/templates/app/dashboard/settings/security/loading.tsx +8 -0
- package/templates/app/dashboard/settings/security/page.tsx +17 -53
- package/templates/app/dashboard/settings/teams/loading.tsx +8 -0
- package/templates/app/dashboard/settings/teams/page.tsx +30 -31
- package/templates/app/dashboard/settings/teams/permissions/page.tsx +4 -1
- package/templates/app/devtools/api/[[...endpoint]]/page.tsx +33 -0
- package/templates/app/devtools/api/layout.tsx +44 -0
- package/templates/app/devtools/layout.tsx +3 -1
- package/templates/app/devtools/plugins/[plugin]/page.tsx +17 -0
- package/templates/app/devtools/scheduled-actions/page.tsx +1 -1
- package/templates/app/globals.css +7 -312
- package/templates/app/layout.tsx +16 -1
- package/templates/app/superadmin/docs/[section]/[page]/page.tsx +92 -0
- package/templates/app/superadmin/docs/page.tsx +75 -0
- package/templates/app/superadmin/layout.tsx +3 -1
- package/templates/app/superadmin/page.tsx +1 -1
- package/templates/app/superadmin/plugins/[plugin]/page.tsx +17 -0
- package/templates/app/superadmin/subscriptions/page.tsx +21 -18
- package/templates/app/superadmin/teams/[teamId]/page.tsx +18 -15
- package/templates/app/superadmin/teams/page.tsx +37 -84
- package/templates/app/superadmin/users/page.tsx +4 -2
- package/templates/blocks/README.md +80 -0
- package/templates/blocks/cta-section/component.tsx +99 -0
- package/templates/blocks/cta-section/config.ts +10 -0
- package/templates/blocks/cta-section/fields.ts +89 -0
- package/templates/blocks/cta-section/index.ts +6 -0
- package/templates/blocks/cta-section/schema.ts +32 -0
- package/templates/blocks/cta-section/thumbnail.png +1 -0
- package/templates/blocks/features-grid/component.tsx +111 -0
- package/templates/blocks/features-grid/config.ts +10 -0
- package/templates/blocks/features-grid/fields.ts +97 -0
- package/templates/blocks/features-grid/index.ts +6 -0
- package/templates/blocks/features-grid/schema.ts +40 -0
- package/templates/blocks/features-grid/thumbnail.png +1 -0
- package/templates/blocks/hero/component.tsx +102 -0
- package/templates/blocks/hero/schema.ts +33 -0
- package/templates/blocks/testimonials/component.tsx +113 -0
- package/templates/blocks/testimonials/config.ts +10 -0
- package/templates/blocks/testimonials/fields.ts +105 -0
- package/templates/blocks/testimonials/index.ts +6 -0
- package/templates/blocks/testimonials/schema.ts +41 -0
- package/templates/blocks/testimonials/thumbnail.png +1 -0
- package/templates/blocks/text-content/component.tsx +96 -0
- package/templates/blocks/text-content/config.ts +10 -0
- package/templates/blocks/text-content/fields.ts +88 -0
- package/templates/blocks/text-content/index.ts +6 -0
- package/templates/blocks/text-content/schema.ts +30 -0
- package/templates/blocks/text-content/thumbnail.png +1 -0
- package/templates/ci-workflows/README.md +71 -0
- package/templates/ci-workflows/github/cypress-regression.yml +136 -0
- package/templates/ci-workflows/github/cypress-smoke.yml +94 -0
- package/templates/contents/plugins/starter/plugin/README.md.template +97 -0
- package/templates/contents/plugins/starter/plugin/api/example/route.ts.template +94 -0
- package/templates/contents/plugins/starter/plugin/components/ExampleWidget.tsx.template +115 -0
- package/templates/contents/plugins/starter/plugin/entities/.gitkeep +18 -0
- package/templates/contents/plugins/starter/plugin/hooks/usePlugin.ts.template +102 -0
- package/templates/contents/plugins/starter/plugin/lib/core.ts.template +67 -0
- package/templates/contents/plugins/starter/plugin/lib/types.ts.template +105 -0
- package/templates/contents/plugins/starter/plugin/messages/de.json +20 -0
- package/templates/contents/plugins/starter/plugin/messages/en.json +37 -0
- package/templates/contents/plugins/starter/plugin/messages/es.json +37 -0
- package/templates/contents/plugins/starter/plugin/messages/fr.json +20 -0
- package/templates/contents/plugins/starter/plugin/messages/it.json +20 -0
- package/templates/contents/plugins/starter/plugin/messages/pt.json +20 -0
- package/templates/contents/plugins/starter/plugin/migrations/README.md +65 -0
- package/templates/contents/plugins/starter/plugin/plugin.config.ts.template +49 -0
- package/templates/contents/plugins/starter/plugin/tests/plugin.test.ts.template +85 -0
- package/templates/contents/themes/starter/config/app.config.ts +43 -18
- package/templates/contents/themes/starter/config/features.config.ts +156 -0
- package/templates/contents/themes/starter/config/permissions.config.ts +39 -0
- package/templates/contents/themes/starter/docs/superadmin/01-setup/01-configuration.md +31 -0
- package/templates/contents/themes/starter/docs/superadmin/02-entities/01-tasks.md +176 -0
- package/templates/contents/themes/starter/entities/pages/api/docs.md +120 -0
- package/templates/contents/themes/starter/entities/pages/api/presets.ts +72 -0
- package/templates/contents/themes/starter/entities/pages/messages/en.json +41 -0
- package/templates/contents/themes/starter/entities/pages/messages/es.json +41 -0
- package/templates/contents/themes/starter/entities/pages/migrations/001_pages_table.sql +112 -0
- package/templates/contents/themes/starter/entities/pages/migrations/002_pages_metas.sql +56 -0
- package/templates/contents/themes/starter/entities/pages/migrations/003_add_status.sql +50 -0
- package/templates/contents/themes/starter/entities/pages/pages-management.service.ts +610 -0
- package/templates/contents/themes/starter/entities/pages/pages.config.ts +95 -0
- package/templates/contents/themes/starter/entities/pages/pages.fields.ts +101 -0
- package/templates/contents/themes/starter/entities/pages/pages.service.ts +290 -0
- package/templates/contents/themes/starter/entities/pages/pages.types.ts +124 -0
- package/templates/contents/themes/starter/entities/posts/api/docs.md +127 -0
- package/templates/contents/themes/starter/entities/posts/api/presets.ts +74 -0
- package/templates/contents/themes/starter/entities/posts/components/post-header.tsx +97 -0
- package/templates/contents/themes/starter/entities/posts/messages/en.json +55 -0
- package/templates/contents/themes/starter/entities/posts/messages/es.json +55 -0
- package/templates/contents/themes/starter/entities/posts/migrations/001_posts_table.sql +115 -0
- package/templates/contents/themes/starter/entities/posts/migrations/003_add_status.sql +44 -0
- package/templates/contents/themes/starter/entities/posts/migrations/004_entity_taxonomy_relations.sql +129 -0
- package/templates/contents/themes/starter/entities/posts/migrations/006_posts_metas.sql +56 -0
- package/templates/contents/themes/starter/entities/posts/posts.config.ts +102 -0
- package/templates/contents/themes/starter/entities/posts/posts.fields.ts +116 -0
- package/templates/contents/themes/starter/entities/posts/posts.service.ts +376 -0
- package/templates/contents/themes/starter/entities/posts/posts.types.ts +74 -0
- package/templates/contents/themes/starter/entities/tasks/api/docs.md +132 -0
- package/templates/contents/themes/starter/entities/tasks/api/presets.ts +84 -0
- package/templates/contents/themes/starter/entities/tasks/tasks.config.ts +2 -43
- package/templates/contents/themes/starter/entities/tasks/tasks.service.ts +0 -5
- package/templates/contents/themes/starter/lib/selectors.ts +2 -2
- package/templates/contents/themes/starter/messages/de/common.json +4 -1
- package/templates/contents/themes/starter/messages/de/dev.json +106 -0
- package/templates/contents/themes/starter/messages/de/features.json +8 -0
- package/templates/contents/themes/starter/messages/de/index.ts +17 -0
- package/templates/contents/themes/starter/messages/de/navigation.json +1 -0
- package/templates/contents/themes/starter/messages/en/common.json +4 -1
- package/templates/contents/themes/starter/messages/en/dev.json +106 -0
- package/templates/contents/themes/starter/messages/en/features.json +8 -0
- package/templates/contents/themes/starter/messages/en/index.ts +17 -0
- package/templates/contents/themes/starter/messages/en/navigation.json +1 -0
- package/templates/contents/themes/starter/messages/es/common.json +4 -1
- package/templates/contents/themes/starter/messages/es/dev.json +106 -0
- package/templates/contents/themes/starter/messages/es/features.json +8 -0
- package/templates/contents/themes/starter/messages/es/index.ts +17 -0
- package/templates/contents/themes/starter/messages/es/navigation.json +1 -0
- package/templates/contents/themes/starter/messages/fr/common.json +4 -1
- package/templates/contents/themes/starter/messages/fr/dev.json +106 -0
- package/templates/contents/themes/starter/messages/fr/features.json +8 -0
- package/templates/contents/themes/starter/messages/fr/index.ts +17 -0
- package/templates/contents/themes/starter/messages/fr/navigation.json +1 -0
- package/templates/contents/themes/starter/messages/it/common.json +4 -1
- package/templates/contents/themes/starter/messages/it/dev.json +106 -0
- package/templates/contents/themes/starter/messages/it/features.json +8 -0
- package/templates/contents/themes/starter/messages/it/index.ts +15 -0
- package/templates/contents/themes/starter/messages/it/navigation.json +1 -0
- package/templates/contents/themes/starter/messages/pt/common.json +4 -1
- package/templates/contents/themes/starter/messages/pt/dev.json +106 -0
- package/templates/contents/themes/starter/messages/pt/features.json +8 -0
- package/templates/contents/themes/starter/messages/pt/index.ts +15 -0
- package/templates/contents/themes/starter/messages/pt/navigation.json +1 -0
- package/templates/contents/themes/starter/styles/globals.css +197 -7
- package/templates/contents/themes/starter/templates/(public)/loading.tsx +5 -0
- package/templates/contents/themes/starter/templates/dashboard/analytics/loading.tsx +5 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/access.bdd.md +262 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/access.cy.ts +171 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/navigation.bdd.md +261 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/navigation.cy.ts +157 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/pages.bdd.md +303 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/devtools/pages.cy.ts +184 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/docs/README.md +215 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/auth.bdd.md +354 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/auth.cy.ts +310 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/billing.bdd.md +276 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/billing.cy.ts +182 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/block-editor.bdd.md +491 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/block-editor.cy.ts +475 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-container.cy.ts +52 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-mobile.bdd.md +205 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-mobile.cy.ts +137 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-navigation.bdd.md +147 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-navigation.cy.ts +114 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-sidebar.bdd.md +76 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-sidebar.cy.ts +68 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-topnav.bdd.md +326 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/dashboard-topnav.cy.ts +177 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/devtools.bdd.md +306 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/devtools.cy.ts +273 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/global-search.bdd.md +115 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/global-search.cy.ts +93 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/patterns.bdd.md +388 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/patterns.cy.ts +559 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-api-keys.bdd.md +266 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-api-keys.cy.ts +233 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-billing.bdd.md +78 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-billing.cy.ts +108 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-layout.bdd.md +129 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-layout.cy.ts +115 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-password.bdd.md +82 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-password.cy.ts +74 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-profile.bdd.md +77 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-profile.cy.ts +79 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-teams.bdd.md +130 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/settings-teams.cy.ts +86 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/superadmin.bdd.md +261 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/superadmin.cy.ts +193 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/tasks.bdd.md +593 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/tasks.cy.ts +864 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/teams.bdd.md +278 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/selectors/teams.cy.ts +195 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-teams.bdd.md +261 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-teams.cy.ts +177 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-users.bdd.md +406 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/all-users.cy.ts +293 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/dashboard.bdd.md +235 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/dashboard.cy.ts +148 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/subscriptions-overview.bdd.md +290 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/_utils/superadmin/subscriptions-overview.cy.ts +194 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/uat/entities/tasks/tasks-crud.bdd.md +278 -0
- package/templates/contents/themes/starter/tests/cypress/e2e/uat/entities/tasks/tasks-crud.cy.ts +431 -0
- package/templates/contents/themes/starter/tests/cypress/src/components/DevKeyringPOM.ts +160 -0
- package/templates/contents/themes/starter/tests/cypress/src/components/EntityForm.ts +375 -0
- package/templates/contents/themes/starter/tests/cypress/src/components/EntityList.ts +389 -0
- package/templates/contents/themes/starter/tests/cypress/src/components/TeamSwitcherPOM.ts +450 -0
- package/templates/contents/themes/starter/tests/cypress/src/components/index.ts +13 -0
- package/templates/contents/themes/starter/tests/cypress/src/core/BasePOM.ts +23 -120
- package/templates/contents/themes/starter/tests/cypress/src/core/BlockEditorBasePOM.ts +576 -0
- package/templates/contents/themes/starter/tests/cypress/src/core/DashboardEntityPOM.ts +29 -661
- package/templates/contents/themes/starter/tests/cypress/src/core/index.ts +2 -0
- package/templates/contents/themes/starter/tests/cypress/src/entities/PatternsPOM.ts +333 -0
- package/templates/contents/themes/starter/tests/cypress/src/entities/TasksPOM.ts +246 -0
- package/templates/contents/themes/starter/tests/cypress/src/entities/index.ts +12 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/BillingPOM.ts +385 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/DashboardPOM.ts +271 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/DevtoolsPOM.ts +750 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/PageBuilderPOM.ts +283 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/PostEditorPOM.ts +313 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/ScheduledActionsPOM.ts +463 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/SettingsPOM.ts +523 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/SuperadminPOM.ts +851 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/SuperadminTeamRolesPOM.ts +285 -0
- package/templates/contents/themes/starter/tests/cypress/src/features/index.ts +24 -0
- package/templates/contents/themes/starter/tests/cypress/src/helpers/ApiInterceptor.ts +14 -164
- package/templates/contents/themes/starter/tests/cypress/src/index.ts +88 -0
- package/templates/contents/themes/starter/tests/cypress/src/selectors.ts +4 -4
- package/templates/contents/themes/starter/tests/cypress/src/session-helpers.ts +340 -77
- package/templates/contents/themes/starter/tests/cypress/support/e2e.ts +37 -4
- package/templates/contents/themes/starter/tests/cypress.config.ts +84 -19
- package/templates/contents/themes/starter/tests/jest/__mocks__/jose.js +22 -0
- package/templates/contents/themes/starter/tests/jest/__mocks__/next-server.js +56 -0
- package/templates/contents/themes/starter/tests/jest/example.test.tsx +87 -0
- package/templates/contents/themes/starter/tests/jest/jest.config.cjs +95 -0
- package/templates/contents/themes/starter/tests/jest/services/tasks.service.test.ts +547 -0
- package/templates/contents/themes/starter/tests/jest/setup.ts +170 -0
- package/templates/contents/themes/starter/tests/jest/tsconfig.jest.json +8 -0
- package/templates/features/blog/blocks/post-content/component.tsx +2 -2
- package/templates/features/blog/entities/posts/posts.config.ts +1 -0
- package/templates/features/pages/blocks/hero/component.tsx +8 -5
- package/templates/features/pages/blocks/hero/schema.ts +2 -1
- package/templates/features/pages/entities/pages/pages.config.ts +1 -0
- package/templates/instrumentation.ts +39 -0
- package/templates/lib/billing/polar-webhook-extensions.ts +23 -0
- package/templates/lib/billing/stripe-webhook-extensions.ts +23 -0
- package/templates/migrations/README.md +408 -0
- package/templates/migrations/private-mode/001_entity_table.sql.template +94 -0
- package/templates/migrations/private-mode/002_entity_metas.sql.template +102 -0
- package/templates/migrations/private-mode/003_entity_child.sql.template +92 -0
- package/templates/migrations/private-mode/100_entity_sample_data.sql.template +113 -0
- package/templates/migrations/public-mode/001_entity_table.sql.template +139 -0
- package/templates/migrations/public-mode/002_entity_metas.sql.template +110 -0
- package/templates/migrations/public-mode/003_entity_child.sql.template +93 -0
- package/templates/migrations/public-mode/100_entity_sample_data.sql.template +144 -0
- package/templates/migrations/shared-mode/001_entity_table.sql.template +103 -0
- package/templates/migrations/shared-mode/002_entity_metas.sql.template +89 -0
- package/templates/migrations/shared-mode/003_entity_child.sql.template +79 -0
- package/templates/migrations/shared-mode/100_entity_sample_data.sql.template +104 -0
- package/templates/migrations/team-mode/001_entity_table.sql.template +87 -0
- package/templates/migrations/team-mode/002_entity_metas.sql.template +106 -0
- package/templates/migrations/team-mode/003_entity_child.sql.template +99 -0
- package/templates/migrations/team-mode/100_entity_sample_data.sql.template +140 -0
- package/templates/next.config.mjs +136 -3
- package/templates/pnpm-workspace.yaml +5 -0
- package/templates/proxy.ts +194 -0
- package/templates/scripts/cy-run-prod.cjs +277 -0
- package/templates/tsconfig.cypress.json +2 -2
- package/tests/jest/__mocks__/@nextsparkjs/registries/billing-registry.ts +7 -8
- package/tests/jest/__mocks__/@nextsparkjs/registries/docs-registry.ts +161 -0
- package/tests/jest/__mocks__/@nextsparkjs/registries/permissions-registry.ts +37 -0
- package/tests/jest/setup.ts +5 -0
- package/dist/lib/test/core-selectors.d.ts +0 -863
- package/dist/lib/test/core-selectors.d.ts.map +0 -1
- package/dist/lib/test/core-selectors.js +0 -887
- package/dist/lib/test/index.d.js +0 -33
- package/dist/lib/test/selector-factory.d.ts.map +0 -1
- package/dist/lib/test/selectors.d.js +0 -4
- package/dist/lib/test/selectors.d.ts +0 -1764
- package/dist/lib/test/selectors.d.ts.map +0 -1
- package/dist/lib/test/selectors.js +0 -26
- package/dist/lib/testing-utils.d.ts +0 -215
- package/dist/lib/testing-utils.d.ts.map +0 -1
- package/dist/lib/testing-utils.js +0 -190
- package/dist/presets/ai-workflow/claude/README.md +0 -279
- package/dist/presets/ai-workflow/claude/agents/api-tester.md +0 -629
- package/dist/presets/ai-workflow/claude/agents/architecture-supervisor.md +0 -1088
- package/dist/presets/ai-workflow/claude/agents/backend-developer.md +0 -979
- package/dist/presets/ai-workflow/claude/agents/backend-validator.md +0 -393
- package/dist/presets/ai-workflow/claude/agents/bdd-docs-writer.md +0 -732
- package/dist/presets/ai-workflow/claude/agents/block-developer.md +0 -635
- package/dist/presets/ai-workflow/claude/agents/code-reviewer.md +0 -1434
- package/dist/presets/ai-workflow/claude/agents/db-developer.md +0 -719
- package/dist/presets/ai-workflow/claude/agents/db-validator.md +0 -402
- package/dist/presets/ai-workflow/claude/agents/demo-video-generator.md +0 -462
- package/dist/presets/ai-workflow/claude/agents/dev-plugin.md +0 -951
- package/dist/presets/ai-workflow/claude/agents/documentation-writer.md +0 -1235
- package/dist/presets/ai-workflow/claude/agents/frontend-developer.md +0 -1159
- package/dist/presets/ai-workflow/claude/agents/frontend-validator.md +0 -771
- package/dist/presets/ai-workflow/claude/agents/functional-validator.md +0 -625
- package/dist/presets/ai-workflow/claude/agents/plugin-creator.md +0 -459
- package/dist/presets/ai-workflow/claude/agents/plugin-validator.md +0 -353
- package/dist/presets/ai-workflow/claude/agents/product-manager.md +0 -861
- package/dist/presets/ai-workflow/claude/agents/qa-automation.md +0 -1685
- package/dist/presets/ai-workflow/claude/agents/qa-manual.md +0 -566
- package/dist/presets/ai-workflow/claude/agents/qa-tester.md +0 -1021
- package/dist/presets/ai-workflow/claude/agents/release-manager.md +0 -627
- package/dist/presets/ai-workflow/claude/agents/theme-creator.md +0 -457
- package/dist/presets/ai-workflow/claude/agents/theme-validator.md +0 -359
- package/dist/presets/ai-workflow/claude/agents/unit-test-writer.md +0 -766
- package/dist/presets/ai-workflow/claude/agents/workflow-maintainer.md +0 -383
- package/dist/presets/ai-workflow/claude/commands/bdd:write.md +0 -300
- package/dist/presets/ai-workflow/claude/commands/block:create.md +0 -156
- package/dist/presets/ai-workflow/claude/commands/block:docs.md +0 -251
- package/dist/presets/ai-workflow/claude/commands/block:list.md +0 -175
- package/dist/presets/ai-workflow/claude/commands/block:update.md +0 -156
- package/dist/presets/ai-workflow/claude/commands/block:validate.md +0 -239
- package/dist/presets/ai-workflow/claude/commands/db:entity.md +0 -470
- package/dist/presets/ai-workflow/claude/commands/db:fix.md +0 -385
- package/dist/presets/ai-workflow/claude/commands/db:sample.md +0 -266
- package/dist/presets/ai-workflow/claude/commands/doc:demo-feature.md +0 -472
- package/dist/presets/ai-workflow/claude/commands/doc:feature.md +0 -427
- package/dist/presets/ai-workflow/claude/commands/doc:read.md +0 -278
- package/dist/presets/ai-workflow/claude/commands/fix:bug.md +0 -442
- package/dist/presets/ai-workflow/claude/commands/fix:build.md +0 -284
- package/dist/presets/ai-workflow/claude/commands/plugin:create.md +0 -193
- package/dist/presets/ai-workflow/claude/commands/release:version.md +0 -450
- package/dist/presets/ai-workflow/claude/commands/task:demo.md +0 -345
- package/dist/presets/ai-workflow/claude/commands/task:execute.md +0 -920
- package/dist/presets/ai-workflow/claude/commands/task:explain.md +0 -276
- package/dist/presets/ai-workflow/claude/commands/task:pending.md +0 -299
- package/dist/presets/ai-workflow/claude/commands/task:plan.md +0 -344
- package/dist/presets/ai-workflow/claude/commands/task:pre-commit.md +0 -408
- package/dist/presets/ai-workflow/claude/commands/task:refine.md +0 -398
- package/dist/presets/ai-workflow/claude/commands/task:requirements.md +0 -547
- package/dist/presets/ai-workflow/claude/commands/task:review-final.md +0 -181
- package/dist/presets/ai-workflow/claude/commands/task:scope-change.md +0 -565
- package/dist/presets/ai-workflow/claude/commands/test:fix.md +0 -744
- package/dist/presets/ai-workflow/claude/commands/test:run.md +0 -422
- package/dist/presets/ai-workflow/claude/commands/test:write.md +0 -1115
- package/dist/presets/ai-workflow/claude/commands/workflow-update.md +0 -191
- package/dist/presets/ai-workflow/claude/config/agents.example.json +0 -40
- package/dist/presets/ai-workflow/claude/config/workflow.example.md +0 -1287
- package/dist/presets/ai-workflow/claude/settings.local.json +0 -111
- package/dist/presets/ai-workflow/claude/tools/clickup/api.md +0 -942
- package/dist/presets/ai-workflow/claude/tools/clickup/mcp.md +0 -588
- package/dist/presets/ai-workflow/claude/tools/clickup/templates/task.md +0 -32
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/clickup_task.md +0 -121
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/context.md +0 -418
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/pendings.md +0 -127
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/plan.md +0 -401
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/progress.md +0 -398
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/requirements.md +0 -177
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/scope.json +0 -56
- package/dist/presets/ai-workflow/claude/tools/sessions/templates/tests.md +0 -220
- package/dist/presets/blocks/README.md +0 -80
- package/dist/presets/blocks/cta-section/component.tsx +0 -99
- package/dist/presets/blocks/features-grid/component.tsx +0 -111
- package/dist/presets/blocks/hero/component.tsx +0 -99
- package/dist/presets/blocks/hero/schema.ts +0 -32
- package/dist/presets/blocks/testimonials/component.tsx +0 -113
- package/dist/presets/blocks/testimonials/schema.ts +0 -41
- package/dist/presets/blocks/text-content/component.tsx +0 -96
- package/dist/presets/ci-workflows/README.md +0 -71
- package/dist/presets/entity-tests/README.md +0 -206
- package/dist/presets/entity-tests/controllers/EntityAPIController.js.template +0 -203
- package/dist/presets/entity-tests/e2e/entity-crud.cy.ts.template +0 -346
- package/dist/presets/entity-tests/e2e/entity-owner.cy.ts.template +0 -204
- package/dist/presets/entity-tests/pom/EntityPOM.ts.template +0 -169
- package/dist/presets/entity-tests/selectors/entity-selectors.cy.ts.template +0 -119
- package/dist/presets/migrations/README.md +0 -408
- package/dist/presets/plugin/.env.example.template +0 -19
- package/dist/presets/theme/README.md +0 -111
- package/dist/presets/theme/about/business.md +0 -43
- package/dist/presets/theme/about/features.json +0 -101
- package/dist/presets/theme/about/team.md +0 -63
- package/dist/presets/theme/blocks/.gitkeep +0 -17
- package/dist/presets/theme/blocks/hero/component.tsx +0 -99
- package/dist/presets/theme/blocks/hero/schema.ts +0 -32
- package/dist/presets/theme/config/app.config.ts.template +0 -199
- package/dist/presets/theme/config/billing.config.ts.template +0 -237
- package/dist/presets/theme/config/dashboard.config.ts.template +0 -417
- package/dist/presets/theme/config/dev.config.ts.template +0 -91
- package/dist/presets/theme/config/permissions.config.ts.template +0 -172
- package/dist/presets/theme/config/theme.config.ts.template +0 -101
- package/dist/presets/theme/docs/01-overview/01-introduction.md +0 -98
- package/dist/presets/theme/docs/01-overview/02-customization.md +0 -109
- package/dist/presets/theme/entities/tasks/messages/de.json +0 -204
- package/dist/presets/theme/entities/tasks/messages/en.json +0 -204
- package/dist/presets/theme/entities/tasks/messages/es.json +0 -204
- package/dist/presets/theme/entities/tasks/messages/fr.json +0 -204
- package/dist/presets/theme/entities/tasks/messages/it.json +0 -204
- package/dist/presets/theme/entities/tasks/messages/pt.json +0 -204
- package/dist/presets/theme/entities/tasks/migrations/001_tasks_table.sql +0 -105
- package/dist/presets/theme/entities/tasks/migrations/002_task_metas.sql +0 -85
- package/dist/presets/theme/entities/tasks/migrations/003_tasks_sample_data.sql +0 -250
- package/dist/presets/theme/entities/tasks/migrations/100_tasks_sample_data.sql +0 -204
- package/dist/presets/theme/entities/tasks/migrations/sample_data.json +0 -77
- package/dist/presets/theme/entities/tasks/tasks.config.ts +0 -96
- package/dist/presets/theme/entities/tasks/tasks.fields.ts +0 -196
- package/dist/presets/theme/entities/tasks/tasks.service.ts +0 -329
- package/dist/presets/theme/entities/tasks/tasks.types.ts +0 -55
- package/dist/presets/theme/messages/de.json +0 -96
- package/dist/presets/theme/messages/en.json +0 -96
- package/dist/presets/theme/messages/es.json +0 -96
- package/dist/presets/theme/messages/fr.json +0 -96
- package/dist/presets/theme/messages/it.json +0 -96
- package/dist/presets/theme/messages/pt.json +0 -96
- package/dist/presets/theme/migrations/001_example_schema.sql +0 -73
- package/dist/presets/theme/migrations/002_custom_team_roles.sql +0 -25
- package/dist/presets/theme/migrations/README.md +0 -57
- package/dist/presets/theme/public/brand/.gitkeep +0 -8
- package/dist/presets/theme/styles/components.css +0 -101
- package/dist/presets/theme/styles/globals.css +0 -158
- package/dist/presets/theme/templates/(public)/layout.tsx +0 -31
- package/dist/presets/theme/templates/(public)/page.tsx +0 -125
- package/dist/presets/theme/templates/(public)/support/page.tsx +0 -162
- package/dist/presets/theme/tests/cypress/.gitkeep +0 -10
- package/dist/presets/theme/tests/cypress/_examples/tasks/TasksPOM.ts +0 -177
- package/dist/presets/theme/tests/cypress/_examples/tasks/tasks-crud.cy.ts +0 -609
- package/dist/presets/theme/tests/cypress/_examples/tasks/tasks-owner.cy.ts +0 -201
- package/dist/presets/theme/tests/cypress/e2e/api/billing/BillingAPIController.js +0 -178
- package/dist/presets/theme/tests/cypress/e2e/api/billing/check-action.cy.ts +0 -326
- package/dist/presets/theme/tests/cypress/e2e/api/billing/checkout.cy.ts +0 -358
- package/dist/presets/theme/tests/cypress/e2e/api/billing/lifecycle.cy.ts +0 -423
- package/dist/presets/theme/tests/cypress/e2e/api/billing/portal.cy.ts +0 -313
- package/dist/presets/theme/tests/cypress/fixtures/entities.json +0 -21
- package/dist/presets/theme/tests/cypress/src/controllers/BaseAPIController.js +0 -317
- package/dist/presets/theme/tests/cypress/src/controllers/index.js +0 -12
- package/dist/presets/theme/tests/cypress/src/core/AuthPOM.ts +0 -450
- package/dist/presets/theme/tests/cypress/src/core/BasePOM.ts +0 -86
- package/dist/presets/theme/tests/cypress/src/core/DashboardEntityPOM.ts +0 -692
- package/dist/presets/theme/tests/cypress/src/core/index.ts +0 -14
- package/dist/presets/theme/tests/cypress/src/helpers/ApiInterceptor.ts +0 -170
- package/dist/presets/theme/tests/cypress/src/selectors.ts +0 -129
- package/dist/presets/theme/tests/cypress/src/session-helpers.ts +0 -209
- package/dist/presets/theme/tests/cypress/support/commands.ts +0 -51
- package/dist/presets/theme/tests/cypress/support/doc-commands.ts +0 -260
- package/dist/presets/theme/tests/cypress/support/e2e.ts +0 -21
- package/dist/presets/theme/tests/cypress.config.ts +0 -155
- package/dist/presets/theme/tests/jest/README.md +0 -50
- package/dist/presets/theme/tests/tsconfig.json +0 -15
- package/dist/templates/app/README.md +0 -39
- package/dist/templates/app/accept-invite/[token]/page.tsx +0 -342
- package/dist/templates/app/devtools/api/[...path]/page.tsx +0 -36
- package/dist/templates/app/devtools/api/page.tsx +0 -213
- package/dist/templates/app/layout.tsx.ejs +0 -90
- package/dist/templates/app/theme-styles.css +0 -202
- package/dist/templates/contents/plugins/langchain/.env.example +0 -41
- package/dist/templates/contents/themes/starter/entities/tasks/migrations/003_tasks_sample_data.sql +0 -172
- package/dist/templates/contents/themes/starter/migrations/001_starter_users.sql +0 -17
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/tasks/TasksPOM.ts +0 -246
- package/dist/templates/contents/themes/starter/tests/cypress/e2e/tasks/tasks-crud.cy.ts +0 -423
- package/dist/testing/factories.d.ts +0 -15
- package/dist/testing/factories.d.ts.map +0 -1
- package/dist/testing/factories.js +0 -33
- package/dist/testing/index.d.ts +0 -4
- package/dist/testing/index.d.ts.map +0 -1
- package/dist/testing/index.js +0 -14
- package/dist/testing/mocks.d.ts +0 -32
- package/dist/testing/mocks.d.ts.map +0 -1
- package/dist/testing/mocks.js +0 -49
- package/dist/testing/render-helpers.js +0 -24
- package/scripts/build/registry/generators/plugin-registry.mjs.bak +0 -219
- package/scripts/setup/setup-claude.mjs +0 -294
- package/templates/app/README.md +0 -39
- package/templates/app/accept-invite/[token]/page.tsx +0 -342
- package/templates/app/devtools/api/[...path]/page.tsx +0 -36
- package/templates/app/devtools/api/page.tsx +0 -213
- package/templates/app/layout.tsx.ejs +0 -90
- package/templates/app/theme-styles.css +0 -202
- package/templates/contents/themes/starter/entities/tasks/migrations/003_tasks_sample_data.sql +0 -172
- package/templates/contents/themes/starter/migrations/001_starter_users.sql +0 -17
- package/templates/contents/themes/starter/tests/cypress/e2e/tasks/TaskAPIController.js +0 -240
- package/templates/contents/themes/starter/tests/cypress/e2e/tasks/TasksPOM.ts +0 -246
- package/templates/contents/themes/starter/tests/cypress/e2e/tasks/tasks-crud.cy.ts +0 -423
- package/tests/cypress/support/allure.ts +0 -2
- package/tests/cypress/support/commands/auth.ts +0 -31
- package/tests/cypress/support/commands/forms.ts +0 -27
- package/tests/cypress/support/commands/index.ts +0 -7
- package/tests/cypress/support/commands/navigation.ts +0 -19
- package/tests/cypress/support/commands.js +0 -61
- package/tests/cypress/support/commands.ts +0 -71
- package/tests/cypress/support/e2e.js +0 -49
- package/tests/cypress/support/e2e.ts +0 -67
- package/tests/cypress/support/index.ts +0 -7
- package/tests/cypress/support/pom/BasePage.ts +0 -23
- package/tests/cypress/support/pom/index.ts +0 -1
- package/tests/cypress/support/test-commands.ts +0 -336
- package/theme-styles.css +0 -202
- /package/dist/lib/{billing/gateways/stripe.d.js → actions/types.js} +0 -0
- /package/dist/lib/{test/core-selectors.d.js → billing/gateways/interface.js} +0 -0
- /package/dist/lib/{test/selector-factory.d.js → billing/gateways/types.js} +0 -0
- /package/dist/lib/{test/utils.d.js → billing/polar-webhook.js} +0 -0
- /package/dist/lib/{testing-utils.d.js → media/types.js} +0 -0
- /package/dist/lib/{test → selectors}/selector-factory.d.ts +0 -0
- /package/dist/lib/{test → selectors}/selector-factory.js +0 -0
- /package/dist/{presets → templates}/blocks/cta-section/config.ts +0 -0
- /package/dist/{presets → templates}/blocks/cta-section/fields.ts +0 -0
- /package/dist/{presets → templates}/blocks/cta-section/index.ts +0 -0
- /package/dist/{presets → templates}/blocks/cta-section/schema.ts +0 -0
- /package/dist/{presets → templates}/blocks/cta-section/thumbnail.png +0 -0
- /package/dist/{presets → templates}/blocks/features-grid/config.ts +0 -0
- /package/dist/{presets → templates}/blocks/features-grid/fields.ts +0 -0
- /package/dist/{presets → templates}/blocks/features-grid/index.ts +0 -0
- /package/dist/{presets → templates}/blocks/features-grid/schema.ts +0 -0
- /package/dist/{presets → templates}/blocks/features-grid/thumbnail.png +0 -0
- /package/dist/{presets → templates}/blocks/hero/config.ts +0 -0
- /package/dist/{presets → templates}/blocks/hero/fields.ts +0 -0
- /package/dist/{presets → templates}/blocks/hero/index.ts +0 -0
- /package/dist/{presets → templates}/blocks/hero/thumbnail.png +0 -0
- /package/dist/{presets → templates}/blocks/testimonials/config.ts +0 -0
- /package/dist/{presets → templates}/blocks/testimonials/fields.ts +0 -0
- /package/dist/{presets → templates}/blocks/testimonials/index.ts +0 -0
- /package/dist/{presets → templates}/blocks/testimonials/thumbnail.png +0 -0
- /package/dist/{presets → templates}/blocks/text-content/config.ts +0 -0
- /package/dist/{presets → templates}/blocks/text-content/fields.ts +0 -0
- /package/dist/{presets → templates}/blocks/text-content/index.ts +0 -0
- /package/dist/{presets → templates}/blocks/text-content/schema.ts +0 -0
- /package/dist/{presets → templates}/blocks/text-content/thumbnail.png +0 -0
- /package/dist/{presets → templates}/ci-workflows/github/cypress-regression.yml +0 -0
- /package/dist/{presets → templates}/ci-workflows/github/cypress-smoke.yml +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/README.md.template +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/api/example/route.ts.template +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/components/ExampleWidget.tsx.template +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/entities/.gitkeep +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/hooks/usePlugin.ts.template +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/lib/core.ts.template +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/lib/types.ts.template +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/messages/de.json +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/messages/en.json +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/messages/es.json +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/messages/fr.json +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/messages/it.json +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/messages/pt.json +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/migrations/README.md +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/plugin.config.ts.template +0 -0
- /package/dist/{presets → templates/contents/plugins/starter}/plugin/tests/plugin.test.ts.template +0 -0
- /package/dist/templates/contents/themes/starter/docs/{01-overview → public/01-overview}/01-introduction.md +0 -0
- /package/dist/templates/contents/themes/starter/docs/{01-overview → public/01-overview}/02-customization.md +0 -0
- /package/dist/templates/contents/themes/starter/templates/{(dashboard) → dashboard}/analytics/page.tsx +0 -0
- /package/dist/{presets/theme/tests/cypress/_examples → templates/contents/themes/starter/tests/cypress/e2e/api/entities}/tasks/TaskAPIController.js +0 -0
- /package/dist/{presets/theme → templates/contents/themes/starter}/tests/cypress/src/core/BlockEditorBasePOM.ts +0 -0
- /package/dist/{presets → templates}/migrations/private-mode/001_entity_table.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/private-mode/002_entity_metas.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/private-mode/003_entity_child.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/private-mode/100_entity_sample_data.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/public-mode/001_entity_table.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/public-mode/002_entity_metas.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/public-mode/003_entity_child.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/public-mode/100_entity_sample_data.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/shared-mode/001_entity_table.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/shared-mode/002_entity_metas.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/shared-mode/003_entity_child.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/shared-mode/100_entity_sample_data.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/team-mode/001_entity_table.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/team-mode/002_entity_metas.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/team-mode/003_entity_child.sql.template +0 -0
- /package/dist/{presets → templates}/migrations/team-mode/100_entity_sample_data.sql.template +0 -0
- /package/{dist/presets/theme → templates}/blocks/hero/config.ts +0 -0
- /package/{dist/presets/theme → templates}/blocks/hero/fields.ts +0 -0
- /package/{dist/presets/theme → templates}/blocks/hero/index.ts +0 -0
- /package/{dist/presets/theme → templates}/blocks/hero/thumbnail.png +0 -0
- /package/templates/contents/themes/starter/docs/{01-overview → public/01-overview}/01-introduction.md +0 -0
- /package/templates/contents/themes/starter/docs/{01-overview → public/01-overview}/02-customization.md +0 -0
- /package/templates/contents/themes/starter/templates/{(dashboard) → dashboard}/analytics/page.tsx +0 -0
- /package/{dist/templates/contents/themes/starter/tests/cypress/e2e → templates/contents/themes/starter/tests/cypress/e2e/api/entities}/tasks/TaskAPIController.js +0 -0
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
import { NextResponse } from "next/server";
|
|
2
|
-
import { authenticateRequest, hasRequiredScope, canBypassTeamContext } from "../auth/dual-auth";
|
|
3
|
-
import { resolveEntityFromUrl, validateEntityOperation } from "./resolver";
|
|
4
|
-
import { generateEntitySchemas } from "../../entities/schema-generator";
|
|
5
|
-
import { queryWithRLS, mutateWithRLS, queryOneWithRLS } from "../../db";
|
|
2
|
+
import { authenticateRequest, hasRequiredScope, canBypassTeamContext } from "../auth/dual-auth.js";
|
|
3
|
+
import { resolveEntityFromUrl, validateEntityOperation } from "./resolver.js";
|
|
4
|
+
import { generateEntitySchemas } from "../../entities/schema-generator.js";
|
|
5
|
+
import { queryWithRLS, mutateWithRLS, queryOneWithRLS } from "../../db.js";
|
|
6
6
|
import {
|
|
7
7
|
createApiResponse,
|
|
8
8
|
createApiError,
|
|
@@ -16,8 +16,35 @@ import {
|
|
|
16
16
|
handleEntityMetadataInResponse,
|
|
17
17
|
addCorsHeaders,
|
|
18
18
|
handleCorsPreflightRequest
|
|
19
|
-
} from "../helpers";
|
|
20
|
-
import { afterEntityCreate, afterEntityUpdate, afterEntityDelete } from "../../entities/entity-hooks";
|
|
19
|
+
} from "../helpers.js";
|
|
20
|
+
import { afterEntityCreate, afterEntityUpdate, afterEntityDelete } from "../../entities/entity-hooks.js";
|
|
21
|
+
import { extractPatternIds } from "../../blocks/pattern-resolver.js";
|
|
22
|
+
import { isPatternReference } from "../../../types/pattern-reference.js";
|
|
23
|
+
import { PatternUsageService } from "../../services/pattern-usage.service.js";
|
|
24
|
+
import { SubscriptionService } from "../../services/subscription.service.js";
|
|
25
|
+
import { UsageService } from "../../services/usage.service.js";
|
|
26
|
+
import { BILLING_REGISTRY } from "@nextsparkjs/registries/billing-registry";
|
|
27
|
+
function filterPublicFields(data, entityConfig, userId) {
|
|
28
|
+
var _a;
|
|
29
|
+
const publicFields = (_a = entityConfig.access) == null ? void 0 : _a.publicFields;
|
|
30
|
+
if (!publicFields || publicFields.length === 0 || userId !== null) {
|
|
31
|
+
return data;
|
|
32
|
+
}
|
|
33
|
+
const allowedSet = new Set(publicFields);
|
|
34
|
+
const filterItem = (item) => {
|
|
35
|
+
const filtered = {};
|
|
36
|
+
for (const key of allowedSet) {
|
|
37
|
+
if (key in item) {
|
|
38
|
+
filtered[key] = item[key];
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
return filtered;
|
|
42
|
+
};
|
|
43
|
+
if (Array.isArray(data)) {
|
|
44
|
+
return data.map((item) => filterItem(item));
|
|
45
|
+
}
|
|
46
|
+
return filterItem(data);
|
|
47
|
+
}
|
|
21
48
|
async function includeTaxonomiesInData(entityConfig, items, userId) {
|
|
22
49
|
var _a, _b, _c;
|
|
23
50
|
if (!((_a = entityConfig.taxonomies) == null ? void 0 : _a.enabled) || !((_c = (_b = entityConfig.taxonomies) == null ? void 0 : _b.types) == null ? void 0 : _c.length) || items.length === 0) {
|
|
@@ -128,6 +155,24 @@ function parseTaxonomyFilterParams(url, entityConfig) {
|
|
|
128
155
|
function getTableName(entityConfig) {
|
|
129
156
|
return entityConfig.tableName || entityConfig.slug;
|
|
130
157
|
}
|
|
158
|
+
async function filterOrphanedPatternReferences(blocks, userId) {
|
|
159
|
+
if (!Array.isArray(blocks) || blocks.length === 0) return blocks;
|
|
160
|
+
const patternIds = extractPatternIds(blocks);
|
|
161
|
+
if (patternIds.length === 0) return blocks;
|
|
162
|
+
const existingIds = await PatternUsageService.getExistingPatternIds(patternIds, userId);
|
|
163
|
+
if (existingIds.size === patternIds.length) return blocks;
|
|
164
|
+
const filtered = blocks.filter((block) => {
|
|
165
|
+
if (isPatternReference(block)) {
|
|
166
|
+
const exists = existingIds.has(block.ref);
|
|
167
|
+
if (!exists) {
|
|
168
|
+
console.info(`[generic-handler] Filtering orphaned PatternReference: ${block.ref}`);
|
|
169
|
+
}
|
|
170
|
+
return exists;
|
|
171
|
+
}
|
|
172
|
+
return true;
|
|
173
|
+
});
|
|
174
|
+
return filtered;
|
|
175
|
+
}
|
|
131
176
|
function getTeamIdFromRequest(request) {
|
|
132
177
|
return request.headers.get("x-team-id");
|
|
133
178
|
}
|
|
@@ -154,7 +199,7 @@ async function validateTeamContextWithBypass(request, authResult, userId) {
|
|
|
154
199
|
const canBypass = await canBypassTeamContext(authResult, request);
|
|
155
200
|
if (canBypass) {
|
|
156
201
|
console.log("[GenericHandler] Admin bypass active:", { userId, teamId: teamId || "cross-team" });
|
|
157
|
-
return { valid: true, teamId };
|
|
202
|
+
return { valid: true, teamId, isBypass: true };
|
|
158
203
|
}
|
|
159
204
|
if (!teamId) {
|
|
160
205
|
const response = createApiError(
|
|
@@ -175,25 +220,26 @@ async function validateTeamContextWithBypass(request, authResult, userId) {
|
|
|
175
220
|
);
|
|
176
221
|
return { valid: false, error: await addCorsHeaders(response) };
|
|
177
222
|
}
|
|
178
|
-
return { valid: true, teamId };
|
|
223
|
+
return { valid: true, teamId, isBypass: false };
|
|
179
224
|
}
|
|
180
225
|
async function handleGenericList(request) {
|
|
181
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j;
|
|
226
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m;
|
|
182
227
|
try {
|
|
183
228
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
184
229
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
185
230
|
const response2 = createApiError("Entity not found", 404);
|
|
186
|
-
return addCorsHeaders(response2);
|
|
231
|
+
return addCorsHeaders(response2, request);
|
|
187
232
|
}
|
|
188
233
|
if (!validateEntityOperation(resolution.entityConfig, "list")) {
|
|
189
234
|
const response2 = createApiError("List operation not supported for this entity", 405);
|
|
190
|
-
return addCorsHeaders(response2);
|
|
235
|
+
return addCorsHeaders(response2, request);
|
|
191
236
|
}
|
|
192
237
|
const authResult = await authenticateRequest(request);
|
|
193
238
|
let userId = null;
|
|
194
239
|
let teamId = null;
|
|
240
|
+
let isBypass = false;
|
|
195
241
|
if (!authResult.success && ((_a = resolution.entityConfig.access) == null ? void 0 : _a.public)) {
|
|
196
|
-
|
|
242
|
+
teamId = request.headers.get("x-team-id") ?? null;
|
|
197
243
|
} else if (!authResult.success) {
|
|
198
244
|
return NextResponse.json(
|
|
199
245
|
{ success: false, error: "Authentication required", code: "AUTHENTICATION_FAILED" },
|
|
@@ -205,7 +251,7 @@ async function handleGenericList(request) {
|
|
|
205
251
|
}
|
|
206
252
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:read`)) {
|
|
207
253
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
208
|
-
return addCorsHeaders(response2);
|
|
254
|
+
return addCorsHeaders(response2, request);
|
|
209
255
|
}
|
|
210
256
|
userId = authResult.user.id;
|
|
211
257
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, userId);
|
|
@@ -213,6 +259,7 @@ async function handleGenericList(request) {
|
|
|
213
259
|
return teamValidation.error;
|
|
214
260
|
}
|
|
215
261
|
teamId = teamValidation.teamId;
|
|
262
|
+
isBypass = teamValidation.isBypass;
|
|
216
263
|
}
|
|
217
264
|
const pagination = parsePaginationParams(request);
|
|
218
265
|
const metaParams = parseMetaParams(request);
|
|
@@ -252,10 +299,13 @@ async function handleGenericList(request) {
|
|
|
252
299
|
return `t.${columnName}`;
|
|
253
300
|
}).join(", ");
|
|
254
301
|
} else {
|
|
255
|
-
const systemFields = ["id", "createdAt", "updatedAt"];
|
|
302
|
+
const systemFields = ["id", "userId", "teamId", "createdAt", "updatedAt"];
|
|
256
303
|
if ((_b = entityConfig.builder) == null ? void 0 : _b.enabled) {
|
|
257
304
|
systemFields.push("blocks");
|
|
258
305
|
}
|
|
306
|
+
if ((_c = entityConfig.table) == null ? void 0 : _c.softDelete) {
|
|
307
|
+
systemFields.push("deletedAt", "deletedBy");
|
|
308
|
+
}
|
|
259
309
|
const configFields = entityConfig.fields.map((field) => {
|
|
260
310
|
const columnName = /[A-Z]/.test(field.name) ? `"${field.name}"` : field.name;
|
|
261
311
|
return `t.${columnName}`;
|
|
@@ -265,6 +315,9 @@ async function handleGenericList(request) {
|
|
|
265
315
|
return `t.${columnName}`;
|
|
266
316
|
});
|
|
267
317
|
fields = [...systemFieldsFormatted, ...configFields].join(", ");
|
|
318
|
+
if (entityConfig.slug === "patterns") {
|
|
319
|
+
fields += ', COALESCE(pu.usage_count, 0)::int as "usageCount"';
|
|
320
|
+
}
|
|
268
321
|
}
|
|
269
322
|
let query;
|
|
270
323
|
let queryParams;
|
|
@@ -273,8 +326,8 @@ async function handleGenericList(request) {
|
|
|
273
326
|
const fromDate = url.searchParams.get("from");
|
|
274
327
|
const toDate = url.searchParams.get("to");
|
|
275
328
|
const dateFieldName = url.searchParams.get("dateField");
|
|
276
|
-
const isPublicEntity = ((
|
|
277
|
-
const requestingPublishedOnly = (
|
|
329
|
+
const isPublicEntity = ((_d = entityConfig.access) == null ? void 0 : _d.public) === true;
|
|
330
|
+
const requestingPublishedOnly = (_e = customFilters["status"]) == null ? void 0 : _e.includes("published");
|
|
278
331
|
const skipUserFilter = isPublicEntity && requestingPublishedOnly;
|
|
279
332
|
if (skipUserFilter && process.env.NODE_ENV === "development") {
|
|
280
333
|
console.log(`[GenericHandler] Public access mode: skipping userId filter for ${entityConfig.slug} (status=published)`);
|
|
@@ -285,20 +338,23 @@ async function handleGenericList(request) {
|
|
|
285
338
|
const idPlaceholders = specificIds.map(() => `$${paramIndex++}`).join(", ");
|
|
286
339
|
query = `SELECT ${fields} FROM "${tableName}" t WHERE t.id IN (${idPlaceholders})`;
|
|
287
340
|
queryParams = [...specificIds];
|
|
288
|
-
if (teamId
|
|
341
|
+
if (teamId) {
|
|
289
342
|
query += ` AND t."teamId" = $${paramIndex++}`;
|
|
290
343
|
queryParams.push(teamId);
|
|
291
344
|
}
|
|
292
|
-
if (userId && !((
|
|
345
|
+
if (userId && !((_f = entityConfig.access) == null ? void 0 : _f.shared) && !skipUserFilter && !isBypass) {
|
|
293
346
|
query += ` AND t."userId" = $${paramIndex++}`;
|
|
294
347
|
queryParams.push(userId);
|
|
295
348
|
}
|
|
349
|
+
if (((_g = entityConfig.table) == null ? void 0 : _g.softDelete) && !isBypass) {
|
|
350
|
+
query += ` AND t."deletedAt" IS NULL`;
|
|
351
|
+
}
|
|
296
352
|
} else if (fieldsParam && distinctParam) {
|
|
297
353
|
const fieldName = fieldsParam;
|
|
298
354
|
const parentId = url.searchParams.get("parentId");
|
|
299
355
|
query = `SELECT ${fields} FROM "${tableName}" t WHERE 1=1`;
|
|
300
356
|
queryParams = [];
|
|
301
|
-
if (teamId
|
|
357
|
+
if (teamId) {
|
|
302
358
|
query += ` AND t."teamId" = $${paramIndex++}`;
|
|
303
359
|
queryParams.push(teamId);
|
|
304
360
|
}
|
|
@@ -306,24 +362,30 @@ async function handleGenericList(request) {
|
|
|
306
362
|
query += ` AND t."parentId" = $${paramIndex++}`;
|
|
307
363
|
queryParams.push(parentId);
|
|
308
364
|
}
|
|
309
|
-
if (userId && !((
|
|
365
|
+
if (userId && !((_h = entityConfig.access) == null ? void 0 : _h.shared) && !skipUserFilter && !isBypass) {
|
|
310
366
|
query += ` AND t."userId" = $${paramIndex++}`;
|
|
311
367
|
queryParams.push(userId);
|
|
312
368
|
}
|
|
369
|
+
if (((_i = entityConfig.table) == null ? void 0 : _i.softDelete) && !isBypass) {
|
|
370
|
+
query += ` AND t."deletedAt" IS NULL`;
|
|
371
|
+
}
|
|
313
372
|
query += ` ORDER BY "${fieldName}" ASC LIMIT $${paramIndex++}`;
|
|
314
373
|
queryParams.push(pagination.limit);
|
|
315
374
|
} else {
|
|
316
375
|
const whereConditions = [];
|
|
317
376
|
queryParams = [];
|
|
318
377
|
paramIndex = 1;
|
|
319
|
-
if (teamId
|
|
378
|
+
if (teamId) {
|
|
320
379
|
whereConditions.push(`t."teamId" = $${paramIndex++}`);
|
|
321
380
|
queryParams.push(teamId);
|
|
322
381
|
}
|
|
323
|
-
if (userId && !((
|
|
382
|
+
if (userId && !((_j = entityConfig.access) == null ? void 0 : _j.shared) && !skipUserFilter && !isBypass) {
|
|
324
383
|
whereConditions.push(`t."userId" = $${paramIndex++}`);
|
|
325
384
|
queryParams.push(userId);
|
|
326
385
|
}
|
|
386
|
+
if (((_k = entityConfig.table) == null ? void 0 : _k.softDelete) && !isBypass) {
|
|
387
|
+
whereConditions.push(`t."deletedAt" IS NULL`);
|
|
388
|
+
}
|
|
327
389
|
if (searchParam && searchParam.trim() !== "") {
|
|
328
390
|
const searchTerm = searchParam.trim();
|
|
329
391
|
const hasName = entityConfig.fields.some((f) => f.name === "name");
|
|
@@ -397,107 +459,42 @@ async function handleGenericList(request) {
|
|
|
397
459
|
queryParams.push(taxonomyFilter.taxonomyId);
|
|
398
460
|
}
|
|
399
461
|
const whereClause = whereConditions.length > 0 ? `WHERE ${whereConditions.join(" AND ")}` : "";
|
|
462
|
+
let joinClause = "";
|
|
463
|
+
if (entityConfig.slug === "patterns") {
|
|
464
|
+
joinClause = `
|
|
465
|
+
LEFT JOIN (
|
|
466
|
+
SELECT "patternId", COUNT(*) as usage_count
|
|
467
|
+
FROM pattern_usages
|
|
468
|
+
GROUP BY "patternId"
|
|
469
|
+
) pu ON t.id = pu."patternId"
|
|
470
|
+
`;
|
|
471
|
+
}
|
|
472
|
+
const sortByParam = url.searchParams.get("sortBy");
|
|
473
|
+
const sortOrderParam = ((_l = url.searchParams.get("sortOrder")) == null ? void 0 : _l.toUpperCase()) === "ASC" ? "ASC" : "DESC";
|
|
474
|
+
let orderByClause = 't."createdAt" DESC';
|
|
475
|
+
if (sortByParam) {
|
|
476
|
+
const baseFields = ["id", "createdAt", "updatedAt", "teamId"];
|
|
477
|
+
const isValidField = entityConfig.fields.some((f) => f.name === sortByParam) || baseFields.includes(sortByParam);
|
|
478
|
+
if (isValidField) {
|
|
479
|
+
orderByClause = `t."${sortByParam}" ${sortOrderParam}`;
|
|
480
|
+
}
|
|
481
|
+
}
|
|
400
482
|
query = `
|
|
401
|
-
SELECT ${fields}
|
|
483
|
+
SELECT ${fields}, COUNT(*) OVER() as total_count
|
|
402
484
|
FROM "${tableName}" t
|
|
485
|
+
${joinClause}
|
|
403
486
|
${whereClause}
|
|
404
|
-
ORDER BY
|
|
487
|
+
ORDER BY ${orderByClause}
|
|
405
488
|
LIMIT $${paramIndex++} OFFSET $${paramIndex++}
|
|
406
489
|
`;
|
|
407
490
|
queryParams.push(pagination.limit, pagination.offset);
|
|
408
491
|
}
|
|
409
|
-
const
|
|
410
|
-
|
|
411
|
-
const
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
if (teamId && !skipUserFilter) {
|
|
415
|
-
countWhereConditions.push(`"teamId" = $${countParamIndex++}`);
|
|
416
|
-
countParams.push(teamId);
|
|
417
|
-
}
|
|
418
|
-
if (userId && !((_h = entityConfig.access) == null ? void 0 : _h.shared) && !skipUserFilter) {
|
|
419
|
-
countWhereConditions.push(`"userId" = $${countParamIndex++}`);
|
|
420
|
-
countParams.push(userId);
|
|
421
|
-
}
|
|
422
|
-
if (searchParam && searchParam.trim() !== "") {
|
|
423
|
-
const searchTerm = searchParam.trim();
|
|
424
|
-
const hasName = entityConfig.fields.some((f) => f.name === "name");
|
|
425
|
-
const hasTitle = entityConfig.fields.some((f) => f.name === "title");
|
|
426
|
-
const hasSlug = entityConfig.fields.some((f) => f.name === "slug");
|
|
427
|
-
const hasContent = entityConfig.fields.some((f) => f.name === "content");
|
|
428
|
-
if (hasName || hasTitle || hasSlug || hasContent) {
|
|
429
|
-
const searchConditions = [];
|
|
430
|
-
if (hasName) {
|
|
431
|
-
searchConditions.push(`name ILIKE $${countParamIndex}`);
|
|
432
|
-
}
|
|
433
|
-
if (hasTitle) {
|
|
434
|
-
searchConditions.push(`title ILIKE $${countParamIndex}`);
|
|
435
|
-
}
|
|
436
|
-
if (hasSlug) {
|
|
437
|
-
searchConditions.push(`slug ILIKE $${countParamIndex}`);
|
|
438
|
-
}
|
|
439
|
-
if (hasContent) {
|
|
440
|
-
searchConditions.push(`content ILIKE $${countParamIndex}`);
|
|
441
|
-
}
|
|
442
|
-
countWhereConditions.push(`(${searchConditions.join(" OR ")})`);
|
|
443
|
-
countParams.push(`%${searchTerm}%`);
|
|
444
|
-
countParamIndex++;
|
|
445
|
-
}
|
|
446
|
-
}
|
|
447
|
-
if (dateFieldName && (fromDate || toDate)) {
|
|
448
|
-
const field = entityConfig.fields.find((f) => f.name === dateFieldName);
|
|
449
|
-
if (field && (field.type === "datetime" || field.type === "date")) {
|
|
450
|
-
if (fromDate) {
|
|
451
|
-
countWhereConditions.push(`"${dateFieldName}" >= $${countParamIndex++}`);
|
|
452
|
-
countParams.push(fromDate);
|
|
453
|
-
}
|
|
454
|
-
if (toDate) {
|
|
455
|
-
countWhereConditions.push(`"${dateFieldName}" <= $${countParamIndex++}`);
|
|
456
|
-
countParams.push(toDate);
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
}
|
|
460
|
-
Object.entries(customFilters).forEach(([key, values]) => {
|
|
461
|
-
const field = entityConfig.fields.find((f) => f.name === key);
|
|
462
|
-
if (field && values.length > 0) {
|
|
463
|
-
const columnName = `"${key}"`;
|
|
464
|
-
if (field.type === "relation-multi" || key === "socialPlatformId") {
|
|
465
|
-
const orConditions = values.map(() => {
|
|
466
|
-
const condition = `${columnName}::jsonb @> $${countParamIndex++}::jsonb`;
|
|
467
|
-
return condition;
|
|
468
|
-
});
|
|
469
|
-
values.forEach((value) => {
|
|
470
|
-
countParams.push(JSON.stringify([value]));
|
|
471
|
-
});
|
|
472
|
-
countWhereConditions.push(`(${orConditions.join(" OR ")})`);
|
|
473
|
-
} else {
|
|
474
|
-
const orConditions = values.map(() => {
|
|
475
|
-
const condition = `${columnName} = $${countParamIndex++}`;
|
|
476
|
-
return condition;
|
|
477
|
-
});
|
|
478
|
-
values.forEach((value) => {
|
|
479
|
-
countParams.push(value);
|
|
480
|
-
});
|
|
481
|
-
countWhereConditions.push(`(${orConditions.join(" OR ")})`);
|
|
482
|
-
}
|
|
483
|
-
}
|
|
492
|
+
const rawData = await queryWithRLS(query, queryParams, userId);
|
|
493
|
+
const total = rawData.length > 0 ? Number(rawData[0].total_count) || 0 : 0;
|
|
494
|
+
const data = rawData.map((row) => {
|
|
495
|
+
const { total_count, ...rest } = row;
|
|
496
|
+
return rest;
|
|
484
497
|
});
|
|
485
|
-
if (taxonomyFilter == null ? void 0 : taxonomyFilter.taxonomyId) {
|
|
486
|
-
countWhereConditions.push(`EXISTS (
|
|
487
|
-
SELECT 1 FROM entity_taxonomy_relations etr
|
|
488
|
-
WHERE etr."entityId" = id::text
|
|
489
|
-
AND etr."entityType" = '${entityConfig.slug}'
|
|
490
|
-
AND etr."taxonomyId" = $${countParamIndex++}
|
|
491
|
-
)`);
|
|
492
|
-
countParams.push(taxonomyFilter.taxonomyId);
|
|
493
|
-
}
|
|
494
|
-
const countWhereClause = countWhereConditions.length > 0 ? `WHERE ${countWhereConditions.join(" AND ")}` : "";
|
|
495
|
-
totalResult = await queryWithRLS(
|
|
496
|
-
`SELECT COUNT(*) as count FROM "${tableName}" ${countWhereClause}`,
|
|
497
|
-
countParams,
|
|
498
|
-
userId
|
|
499
|
-
);
|
|
500
|
-
const total = ((_i = totalResult[0]) == null ? void 0 : _i.count) || 0;
|
|
501
498
|
const paginationMeta = createPaginationMeta(pagination.page, pagination.limit, total);
|
|
502
499
|
let dataWithMeta = data;
|
|
503
500
|
if (metaParams.includeMetadata && userId) {
|
|
@@ -520,32 +517,33 @@ async function handleGenericList(request) {
|
|
|
520
517
|
);
|
|
521
518
|
}
|
|
522
519
|
let dataWithTaxonomies = dataWithChild;
|
|
523
|
-
if ((
|
|
520
|
+
if ((_m = entityConfig.taxonomies) == null ? void 0 : _m.enabled) {
|
|
524
521
|
dataWithTaxonomies = await includeTaxonomiesInData(
|
|
525
522
|
entityConfig,
|
|
526
523
|
dataWithChild,
|
|
527
524
|
userId
|
|
528
525
|
);
|
|
529
526
|
}
|
|
530
|
-
const
|
|
531
|
-
|
|
527
|
+
const finalData = filterPublicFields(dataWithTaxonomies, entityConfig, userId);
|
|
528
|
+
const response = createApiResponse(finalData, paginationMeta);
|
|
529
|
+
return addCorsHeaders(response, request);
|
|
532
530
|
} catch (error) {
|
|
533
531
|
console.error("Error in generic list handler:", error);
|
|
534
532
|
const response = createApiError("Internal server error", 500);
|
|
535
|
-
return addCorsHeaders(response);
|
|
533
|
+
return addCorsHeaders(response, request);
|
|
536
534
|
}
|
|
537
535
|
}
|
|
538
536
|
async function handleGenericCreate(request) {
|
|
539
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
537
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j;
|
|
540
538
|
try {
|
|
541
539
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
542
540
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
543
541
|
const response2 = createApiError("Entity not found", 404);
|
|
544
|
-
return addCorsHeaders(response2);
|
|
542
|
+
return addCorsHeaders(response2, request);
|
|
545
543
|
}
|
|
546
544
|
if (!validateEntityOperation(resolution.entityConfig, "create")) {
|
|
547
545
|
const response2 = createApiError("Create operation not supported for this entity", 405);
|
|
548
|
-
return addCorsHeaders(response2);
|
|
546
|
+
return addCorsHeaders(response2, request);
|
|
549
547
|
}
|
|
550
548
|
const authResult = await authenticateRequest(request);
|
|
551
549
|
if (!authResult.success) {
|
|
@@ -559,14 +557,14 @@ async function handleGenericCreate(request) {
|
|
|
559
557
|
}
|
|
560
558
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:write`)) {
|
|
561
559
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
562
|
-
return addCorsHeaders(response2);
|
|
560
|
+
return addCorsHeaders(response2, request);
|
|
563
561
|
}
|
|
564
562
|
let body;
|
|
565
563
|
try {
|
|
566
564
|
body = await request.json();
|
|
567
565
|
} catch {
|
|
568
566
|
const response2 = createApiError("Invalid JSON body", 400);
|
|
569
|
-
return addCorsHeaders(response2);
|
|
567
|
+
return addCorsHeaders(response2, request);
|
|
570
568
|
}
|
|
571
569
|
const { metas, ...entityData } = body;
|
|
572
570
|
const rawUserId = entityData.userId;
|
|
@@ -580,7 +578,7 @@ async function handleGenericCreate(request) {
|
|
|
580
578
|
errors: validation.error.issues
|
|
581
579
|
});
|
|
582
580
|
const response2 = createApiError("Validation error", 400, validation.error.issues, "VALIDATION_ERROR");
|
|
583
|
-
return addCorsHeaders(response2);
|
|
581
|
+
return addCorsHeaders(response2, request);
|
|
584
582
|
}
|
|
585
583
|
const validatedData = validation.data;
|
|
586
584
|
const idStrategy = ((_a = entityConfig.idStrategy) == null ? void 0 : _a.type) || "uuid";
|
|
@@ -597,7 +595,7 @@ async function handleGenericCreate(request) {
|
|
|
597
595
|
const teamId = teamValidation.teamId;
|
|
598
596
|
if (!teamId) {
|
|
599
597
|
const response2 = createApiError("Team context required for create operations. Include x-team-id header.", 400, void 0, "TEAM_CONTEXT_REQUIRED");
|
|
600
|
-
return addCorsHeaders(response2);
|
|
598
|
+
return addCorsHeaders(response2, request);
|
|
601
599
|
}
|
|
602
600
|
if (idStrategy === "serial") {
|
|
603
601
|
insertFields = ['"userId"', '"teamId"'];
|
|
@@ -614,7 +612,8 @@ async function handleGenericCreate(request) {
|
|
|
614
612
|
const builderRequest = isBuilderRequest(request);
|
|
615
613
|
const entityHasBuilder = ((_c = entityConfig.builder) == null ? void 0 : _c.enabled) === true;
|
|
616
614
|
if (builderRequest && entityHasBuilder && "blocks" in validatedData) {
|
|
617
|
-
|
|
615
|
+
let blocksValue = validatedData.blocks;
|
|
616
|
+
blocksValue = await filterOrphanedPatternReferences(blocksValue, authResult.user.id);
|
|
618
617
|
insertFields.push('"blocks"');
|
|
619
618
|
placeholders.push(`$${paramCount++}::jsonb`);
|
|
620
619
|
values.push(JSON.stringify(blocksValue));
|
|
@@ -624,7 +623,7 @@ async function handleGenericCreate(request) {
|
|
|
624
623
|
var _a2, _b2;
|
|
625
624
|
if (key === "userId" || key === "teamId") return;
|
|
626
625
|
const field = entityConfig.fields.find((f) => f.name === key);
|
|
627
|
-
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)
|
|
626
|
+
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)) {
|
|
628
627
|
const columnName = `"${key}"`;
|
|
629
628
|
insertFields.push(columnName);
|
|
630
629
|
if (field.type === "relation") {
|
|
@@ -670,14 +669,45 @@ async function handleGenericCreate(request) {
|
|
|
670
669
|
}
|
|
671
670
|
}
|
|
672
671
|
});
|
|
672
|
+
const createAction = `${entityConfig.slug}.create`;
|
|
673
|
+
const limitSlug = (_f = (_e = (_d = BILLING_REGISTRY) == null ? void 0 : _d.actionMappings) == null ? void 0 : _e.limits) == null ? void 0 : _f[createAction];
|
|
674
|
+
if (limitSlug) {
|
|
675
|
+
const actionResult = await SubscriptionService.canPerformAction(
|
|
676
|
+
authResult.user.id,
|
|
677
|
+
teamId,
|
|
678
|
+
createAction
|
|
679
|
+
);
|
|
680
|
+
if (!actionResult.allowed) {
|
|
681
|
+
const statusCode = actionResult.reason === "quota_exceeded" ? 429 : 403;
|
|
682
|
+
const response2 = createApiError(
|
|
683
|
+
actionResult.message || `Quota exceeded for ${entityConfig.slug}`,
|
|
684
|
+
statusCode,
|
|
685
|
+
void 0,
|
|
686
|
+
actionResult.reason === "quota_exceeded" ? "QUOTA_EXCEEDED" : "FEATURE_NOT_IN_PLAN"
|
|
687
|
+
);
|
|
688
|
+
return addCorsHeaders(response2, request);
|
|
689
|
+
}
|
|
690
|
+
}
|
|
673
691
|
const insertQuery = `
|
|
674
692
|
INSERT INTO "${tableName}" (${insertFields.join(", ")})
|
|
675
693
|
VALUES (${placeholders.join(", ")}) RETURNING *
|
|
676
694
|
`;
|
|
677
695
|
const insertResult = await mutateWithRLS(insertQuery, values, authResult.user.id);
|
|
678
|
-
const createdEntityId = String((
|
|
679
|
-
|
|
680
|
-
|
|
696
|
+
const createdEntityId = String((_g = insertResult.rows[0]) == null ? void 0 : _g.id);
|
|
697
|
+
if (limitSlug) {
|
|
698
|
+
UsageService.track({
|
|
699
|
+
teamId,
|
|
700
|
+
userId: authResult.user.id,
|
|
701
|
+
limitSlug,
|
|
702
|
+
delta: 1,
|
|
703
|
+
action: createAction,
|
|
704
|
+
resourceType: entityConfig.slug,
|
|
705
|
+
resourceId: createdEntityId
|
|
706
|
+
}).catch(() => {
|
|
707
|
+
});
|
|
708
|
+
}
|
|
709
|
+
const systemFields = ["id", "userId", "teamId", "createdAt", "updatedAt"];
|
|
710
|
+
if ((_h = entityConfig.builder) == null ? void 0 : _h.enabled) {
|
|
681
711
|
systemFields.push("blocks");
|
|
682
712
|
}
|
|
683
713
|
const configFields = entityConfig.fields.map((field) => {
|
|
@@ -696,7 +726,7 @@ async function handleGenericCreate(request) {
|
|
|
696
726
|
`;
|
|
697
727
|
const createdItems = await queryWithRLS(selectQuery, [createdEntityId], authResult.user.id);
|
|
698
728
|
const createdItem = createdItems[0];
|
|
699
|
-
if ((
|
|
729
|
+
if ((_i = entityConfig.taxonomies) == null ? void 0 : _i.enabled) {
|
|
700
730
|
await processTaxonomyRelations(entityConfig, createdEntityId, body, authResult.user.id, false);
|
|
701
731
|
}
|
|
702
732
|
const metadataWasProvided = metas && typeof metas === "object" && Object.keys(metas).length > 0;
|
|
@@ -709,7 +739,7 @@ async function handleGenericCreate(request) {
|
|
|
709
739
|
);
|
|
710
740
|
}
|
|
711
741
|
let responseItem = createdItem;
|
|
712
|
-
if ((
|
|
742
|
+
if ((_j = entityConfig.taxonomies) == null ? void 0 : _j.enabled) {
|
|
713
743
|
const itemsWithTaxonomies = await includeTaxonomiesInData(
|
|
714
744
|
entityConfig,
|
|
715
745
|
[createdItem],
|
|
@@ -729,29 +759,30 @@ async function handleGenericCreate(request) {
|
|
|
729
759
|
console.error(`[generic-handler] Error in afterEntityCreate hook for ${entityConfig.slug}:`, hookError);
|
|
730
760
|
}
|
|
731
761
|
const response = createApiResponse(responseData, { created: true }, 201);
|
|
732
|
-
return addCorsHeaders(response);
|
|
762
|
+
return addCorsHeaders(response, request);
|
|
733
763
|
} catch (error) {
|
|
734
764
|
console.error("Error in generic create handler:", error);
|
|
735
765
|
const response = createApiError("Internal server error", 500);
|
|
736
|
-
return addCorsHeaders(response);
|
|
766
|
+
return addCorsHeaders(response, request);
|
|
737
767
|
}
|
|
738
768
|
}
|
|
739
769
|
async function handleGenericRead(request, { params }) {
|
|
740
|
-
var _a, _b, _c, _d;
|
|
770
|
+
var _a, _b, _c, _d, _e, _f;
|
|
741
771
|
try {
|
|
742
772
|
const { id } = await params;
|
|
743
773
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
744
774
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
745
775
|
const response2 = createApiError("Entity not found", 404);
|
|
746
|
-
return addCorsHeaders(response2);
|
|
776
|
+
return addCorsHeaders(response2, request);
|
|
747
777
|
}
|
|
748
778
|
if (!validateEntityOperation(resolution.entityConfig, "read")) {
|
|
749
779
|
const response2 = createApiError("Read operation not supported for this entity", 405);
|
|
750
|
-
return addCorsHeaders(response2);
|
|
780
|
+
return addCorsHeaders(response2, request);
|
|
751
781
|
}
|
|
752
782
|
const authResult = await authenticateRequest(request);
|
|
753
783
|
let userId = null;
|
|
754
784
|
let teamId = null;
|
|
785
|
+
let isBypass = false;
|
|
755
786
|
if (!authResult.success && ((_a = resolution.entityConfig.access) == null ? void 0 : _a.public)) {
|
|
756
787
|
console.log(`[GenericHandler] Public access allowed for ${resolution.entityConfig.slug} read`);
|
|
757
788
|
} else if (!authResult.success) {
|
|
@@ -765,7 +796,7 @@ async function handleGenericRead(request, { params }) {
|
|
|
765
796
|
}
|
|
766
797
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:read`)) {
|
|
767
798
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
768
|
-
return addCorsHeaders(response2);
|
|
799
|
+
return addCorsHeaders(response2, request);
|
|
769
800
|
}
|
|
770
801
|
userId = authResult.user.id;
|
|
771
802
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, userId);
|
|
@@ -773,13 +804,17 @@ async function handleGenericRead(request, { params }) {
|
|
|
773
804
|
return teamValidation.error;
|
|
774
805
|
}
|
|
775
806
|
teamId = teamValidation.teamId;
|
|
807
|
+
isBypass = teamValidation.isBypass;
|
|
776
808
|
}
|
|
777
809
|
const entityConfig = resolution.entityConfig;
|
|
778
810
|
const tableName = getTableName(entityConfig);
|
|
779
|
-
const systemFields = ["id", "createdAt", "updatedAt"];
|
|
811
|
+
const systemFields = ["id", "userId", "teamId", "createdAt", "updatedAt"];
|
|
780
812
|
if ((_b = entityConfig.builder) == null ? void 0 : _b.enabled) {
|
|
781
813
|
systemFields.push("blocks");
|
|
782
814
|
}
|
|
815
|
+
if ((_c = entityConfig.table) == null ? void 0 : _c.softDelete) {
|
|
816
|
+
systemFields.push("deletedAt", "deletedBy");
|
|
817
|
+
}
|
|
783
818
|
const configFields = entityConfig.fields.map((field) => {
|
|
784
819
|
const columnName = /[A-Z]/.test(field.name) ? `"${field.name}"` : field.name;
|
|
785
820
|
return `t.${columnName}`;
|
|
@@ -802,14 +837,17 @@ async function handleGenericRead(request, { params }) {
|
|
|
802
837
|
query += ` AND t."teamId" = $${paramIndex++}`;
|
|
803
838
|
queryParams.push(teamId);
|
|
804
839
|
}
|
|
805
|
-
if (userId && !((
|
|
840
|
+
if (userId && !((_d = entityConfig.access) == null ? void 0 : _d.shared) && !isBypass) {
|
|
806
841
|
query += ` AND t."userId" = $${paramIndex++}`;
|
|
807
842
|
queryParams.push(userId);
|
|
808
843
|
}
|
|
844
|
+
if (((_e = entityConfig.table) == null ? void 0 : _e.softDelete) && !isBypass) {
|
|
845
|
+
query += ` AND t."deletedAt" IS NULL`;
|
|
846
|
+
}
|
|
809
847
|
const items = await queryWithRLS(query, queryParams, userId);
|
|
810
848
|
if (!items[0]) {
|
|
811
849
|
const response2 = createApiError("Item not found", 404);
|
|
812
|
-
return addCorsHeaders(response2);
|
|
850
|
+
return addCorsHeaders(response2, request);
|
|
813
851
|
}
|
|
814
852
|
const item = items[0];
|
|
815
853
|
const metaParams = parseMetaParams(request);
|
|
@@ -836,7 +874,7 @@ async function handleGenericRead(request, { params }) {
|
|
|
836
874
|
itemWithChild = itemsWithChild[0] || itemWithMeta;
|
|
837
875
|
}
|
|
838
876
|
let itemWithTaxonomies = itemWithChild;
|
|
839
|
-
if ((
|
|
877
|
+
if ((_f = entityConfig.taxonomies) == null ? void 0 : _f.enabled) {
|
|
840
878
|
const itemsWithTaxonomies = await includeTaxonomiesInData(
|
|
841
879
|
entityConfig,
|
|
842
880
|
[itemWithChild],
|
|
@@ -844,12 +882,13 @@ async function handleGenericRead(request, { params }) {
|
|
|
844
882
|
);
|
|
845
883
|
itemWithTaxonomies = itemsWithTaxonomies[0] || itemWithChild;
|
|
846
884
|
}
|
|
847
|
-
const
|
|
848
|
-
|
|
885
|
+
const finalItem = filterPublicFields(itemWithTaxonomies, entityConfig, userId);
|
|
886
|
+
const response = createApiResponse(finalItem);
|
|
887
|
+
return addCorsHeaders(response, request);
|
|
849
888
|
} catch (error) {
|
|
850
889
|
console.error("Error in generic read handler:", error);
|
|
851
890
|
const response = createApiError("Internal server error", 500);
|
|
852
|
-
return addCorsHeaders(response);
|
|
891
|
+
return addCorsHeaders(response, request);
|
|
853
892
|
}
|
|
854
893
|
}
|
|
855
894
|
async function handleGenericUpdate(request, { params }) {
|
|
@@ -859,11 +898,11 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
859
898
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
860
899
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
861
900
|
const response2 = createApiError("Entity not found", 404);
|
|
862
|
-
return addCorsHeaders(response2);
|
|
901
|
+
return addCorsHeaders(response2, request);
|
|
863
902
|
}
|
|
864
903
|
if (!validateEntityOperation(resolution.entityConfig, "update")) {
|
|
865
904
|
const response2 = createApiError("Update operation not supported for this entity", 405);
|
|
866
|
-
return addCorsHeaders(response2);
|
|
905
|
+
return addCorsHeaders(response2, request);
|
|
867
906
|
}
|
|
868
907
|
const authResult = await authenticateRequest(request);
|
|
869
908
|
if (!authResult.success) {
|
|
@@ -877,7 +916,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
877
916
|
}
|
|
878
917
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:write`)) {
|
|
879
918
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
880
|
-
return addCorsHeaders(response2);
|
|
919
|
+
return addCorsHeaders(response2, request);
|
|
881
920
|
}
|
|
882
921
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, authResult.user.id);
|
|
883
922
|
if (!teamValidation.valid) {
|
|
@@ -886,14 +925,14 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
886
925
|
const teamId = teamValidation.teamId;
|
|
887
926
|
if (!teamId) {
|
|
888
927
|
const response2 = createApiError("Team context required for update operations. Include x-team-id header.", 400, void 0, "TEAM_CONTEXT_REQUIRED");
|
|
889
|
-
return addCorsHeaders(response2);
|
|
928
|
+
return addCorsHeaders(response2, request);
|
|
890
929
|
}
|
|
891
930
|
let body;
|
|
892
931
|
try {
|
|
893
932
|
body = await request.json();
|
|
894
933
|
} catch {
|
|
895
934
|
const response2 = createApiError("Invalid JSON body", 400);
|
|
896
|
-
return addCorsHeaders(response2);
|
|
935
|
+
return addCorsHeaders(response2, request);
|
|
897
936
|
}
|
|
898
937
|
const { metas, ...entityData } = body;
|
|
899
938
|
const entityConfig = resolution.entityConfig;
|
|
@@ -906,7 +945,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
906
945
|
errors: validation.error.issues
|
|
907
946
|
});
|
|
908
947
|
const response2 = createApiError("Validation error", 400, validation.error.issues, "VALIDATION_ERROR");
|
|
909
|
-
return addCorsHeaders(response2);
|
|
948
|
+
return addCorsHeaders(response2, request);
|
|
910
949
|
}
|
|
911
950
|
const validatedData = validation.data;
|
|
912
951
|
const updates = [];
|
|
@@ -915,8 +954,10 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
915
954
|
const builderRequest = isBuilderRequest(request);
|
|
916
955
|
const entityHasBuilder = ((_a = entityConfig.builder) == null ? void 0 : _a.enabled) === true;
|
|
917
956
|
if (builderRequest && entityHasBuilder && "blocks" in entityData) {
|
|
957
|
+
let blocksData = entityData.blocks;
|
|
958
|
+
blocksData = await filterOrphanedPatternReferences(blocksData, authResult.user.id);
|
|
918
959
|
updates.push(`"blocks" = $${paramCount++}::jsonb`);
|
|
919
|
-
values.push(JSON.stringify(
|
|
960
|
+
values.push(JSON.stringify(blocksData));
|
|
920
961
|
}
|
|
921
962
|
const originalKeys = Object.keys(entityData);
|
|
922
963
|
const fieldsToUpdate = Object.entries(validatedData).filter(([key]) => originalKeys.includes(key));
|
|
@@ -924,7 +965,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
924
965
|
var _a2, _b2;
|
|
925
966
|
if (key === "blocks") return;
|
|
926
967
|
const field = entityConfig.fields.find((f) => f.name === key);
|
|
927
|
-
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)
|
|
968
|
+
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)) {
|
|
928
969
|
const columnName = `"${key}"`;
|
|
929
970
|
if (field.type === "relation") {
|
|
930
971
|
let relationId = null;
|
|
@@ -972,7 +1013,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
972
1013
|
const metadataWasProvided = metas && typeof metas === "object" && Object.keys(metas).length > 0;
|
|
973
1014
|
if (updates.length === 0 && !metadataWasProvided) {
|
|
974
1015
|
const response2 = createApiError("No fields to update", 400);
|
|
975
|
-
return addCorsHeaders(response2);
|
|
1016
|
+
return addCorsHeaders(response2, request);
|
|
976
1017
|
}
|
|
977
1018
|
if (updates.length > 0) {
|
|
978
1019
|
updates.push(`"updatedAt" = CURRENT_TIMESTAMP`);
|
|
@@ -998,7 +1039,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
998
1039
|
const result = await mutateWithRLS(updateQuery, values, authResult.user.id);
|
|
999
1040
|
if (!result.rows || result.rows.length === 0) {
|
|
1000
1041
|
const response2 = createApiError("Item not found", 404);
|
|
1001
|
-
return addCorsHeaders(response2);
|
|
1042
|
+
return addCorsHeaders(response2, request);
|
|
1002
1043
|
}
|
|
1003
1044
|
updatedItem = result.rows[0];
|
|
1004
1045
|
} else {
|
|
@@ -1011,7 +1052,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
1011
1052
|
const result = await queryWithRLS(selectQuery, selectValues, authResult.user.id);
|
|
1012
1053
|
if (!result || result.length === 0) {
|
|
1013
1054
|
const response2 = createApiError("Item not found", 404);
|
|
1014
|
-
return addCorsHeaders(response2);
|
|
1055
|
+
return addCorsHeaders(response2, request);
|
|
1015
1056
|
}
|
|
1016
1057
|
updatedItem = result[0];
|
|
1017
1058
|
}
|
|
@@ -1047,25 +1088,25 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
1047
1088
|
console.error(`[generic-handler] Error in afterEntityUpdate hook for ${entityConfig.slug}:`, hookError);
|
|
1048
1089
|
}
|
|
1049
1090
|
const response = createApiResponse(responseData);
|
|
1050
|
-
return addCorsHeaders(response);
|
|
1091
|
+
return addCorsHeaders(response, request);
|
|
1051
1092
|
} catch (error) {
|
|
1052
1093
|
console.error("Error in generic update handler:", error);
|
|
1053
1094
|
const response = createApiError("Internal server error", 500);
|
|
1054
|
-
return addCorsHeaders(response);
|
|
1095
|
+
return addCorsHeaders(response, request);
|
|
1055
1096
|
}
|
|
1056
1097
|
}
|
|
1057
1098
|
async function handleGenericDelete(request, { params }) {
|
|
1058
|
-
var _a;
|
|
1099
|
+
var _a, _b, _c, _d, _e;
|
|
1059
1100
|
try {
|
|
1060
1101
|
const { id } = await params;
|
|
1061
1102
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
1062
1103
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
1063
1104
|
const response2 = createApiError("Entity not found", 404);
|
|
1064
|
-
return addCorsHeaders(response2);
|
|
1105
|
+
return addCorsHeaders(response2, request);
|
|
1065
1106
|
}
|
|
1066
1107
|
if (!validateEntityOperation(resolution.entityConfig, "delete")) {
|
|
1067
1108
|
const response2 = createApiError("Delete operation not supported for this entity", 405);
|
|
1068
|
-
return addCorsHeaders(response2);
|
|
1109
|
+
return addCorsHeaders(response2, request);
|
|
1069
1110
|
}
|
|
1070
1111
|
const authResult = await authenticateRequest(request);
|
|
1071
1112
|
if (!authResult.success) {
|
|
@@ -1079,7 +1120,7 @@ async function handleGenericDelete(request, { params }) {
|
|
|
1079
1120
|
}
|
|
1080
1121
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:write`)) {
|
|
1081
1122
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
1082
|
-
return addCorsHeaders(response2);
|
|
1123
|
+
return addCorsHeaders(response2, request);
|
|
1083
1124
|
}
|
|
1084
1125
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, authResult.user.id);
|
|
1085
1126
|
if (!teamValidation.valid) {
|
|
@@ -1088,7 +1129,7 @@ async function handleGenericDelete(request, { params }) {
|
|
|
1088
1129
|
const teamId = teamValidation.teamId;
|
|
1089
1130
|
if (!teamId) {
|
|
1090
1131
|
const response2 = createApiError("Team context required for delete operations. Include x-team-id header.", 400, void 0, "TEAM_CONTEXT_REQUIRED");
|
|
1091
|
-
return addCorsHeaders(response2);
|
|
1132
|
+
return addCorsHeaders(response2, request);
|
|
1092
1133
|
}
|
|
1093
1134
|
const entityConfig = resolution.entityConfig;
|
|
1094
1135
|
const tableName = getTableName(entityConfig);
|
|
@@ -1103,31 +1144,57 @@ async function handleGenericDelete(request, { params }) {
|
|
|
1103
1144
|
whereConditions.push(`"userId" = $${paramIndex++}`);
|
|
1104
1145
|
deleteParams.push(authResult.user.id);
|
|
1105
1146
|
}
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1147
|
+
let deleteQuery;
|
|
1148
|
+
if ((_b = entityConfig.table) == null ? void 0 : _b.softDelete) {
|
|
1149
|
+
whereConditions.push(`"deletedAt" IS NULL`);
|
|
1150
|
+
deleteQuery = `
|
|
1151
|
+
UPDATE "${tableName}"
|
|
1152
|
+
SET "deletedAt" = NOW(), "deletedBy" = $${paramIndex++}
|
|
1153
|
+
WHERE ${whereConditions.join(" AND ")}
|
|
1154
|
+
RETURNING id
|
|
1155
|
+
`;
|
|
1156
|
+
deleteParams.push(authResult.user.id);
|
|
1157
|
+
} else {
|
|
1158
|
+
deleteQuery = `
|
|
1159
|
+
DELETE FROM "${tableName}"
|
|
1160
|
+
WHERE ${whereConditions.join(" AND ")}
|
|
1161
|
+
RETURNING id
|
|
1162
|
+
`;
|
|
1163
|
+
}
|
|
1111
1164
|
const result = await mutateWithRLS(deleteQuery, deleteParams, authResult.user.id);
|
|
1112
1165
|
if (!result.rows || result.rows.length === 0) {
|
|
1113
1166
|
const response2 = createApiError("Item not found", 404);
|
|
1114
|
-
return addCorsHeaders(response2);
|
|
1167
|
+
return addCorsHeaders(response2, request);
|
|
1115
1168
|
}
|
|
1116
1169
|
try {
|
|
1117
1170
|
await afterEntityDelete(entityConfig.slug, id, authResult.user.id);
|
|
1118
1171
|
} catch (hookError) {
|
|
1119
1172
|
console.error(`[generic-handler] Error in afterEntityDelete hook for ${entityConfig.slug}:`, hookError);
|
|
1120
1173
|
}
|
|
1174
|
+
const deleteAction = `${entityConfig.slug}.create`;
|
|
1175
|
+
const deleteLimitSlug = (_e = (_d = (_c = BILLING_REGISTRY) == null ? void 0 : _c.actionMappings) == null ? void 0 : _d.limits) == null ? void 0 : _e[deleteAction];
|
|
1176
|
+
if (deleteLimitSlug) {
|
|
1177
|
+
UsageService.track({
|
|
1178
|
+
teamId,
|
|
1179
|
+
userId: authResult.user.id,
|
|
1180
|
+
limitSlug: deleteLimitSlug,
|
|
1181
|
+
delta: -1,
|
|
1182
|
+
action: `${entityConfig.slug}.delete`,
|
|
1183
|
+
resourceType: entityConfig.slug,
|
|
1184
|
+
resourceId: id
|
|
1185
|
+
}).catch(() => {
|
|
1186
|
+
});
|
|
1187
|
+
}
|
|
1121
1188
|
const response = createApiResponse({ success: true, id });
|
|
1122
|
-
return addCorsHeaders(response);
|
|
1189
|
+
return addCorsHeaders(response, request);
|
|
1123
1190
|
} catch (error) {
|
|
1124
1191
|
console.error("Error in generic delete handler:", error);
|
|
1125
1192
|
const response = createApiError("Internal server error", 500);
|
|
1126
|
-
return addCorsHeaders(response);
|
|
1193
|
+
return addCorsHeaders(response, request);
|
|
1127
1194
|
}
|
|
1128
1195
|
}
|
|
1129
|
-
async function handleGenericOptions() {
|
|
1130
|
-
return handleCorsPreflightRequest();
|
|
1196
|
+
async function handleGenericOptions(request) {
|
|
1197
|
+
return handleCorsPreflightRequest(request);
|
|
1131
1198
|
}
|
|
1132
1199
|
async function handleDistinctJsonbField(entityConfig, fieldName, url, userId) {
|
|
1133
1200
|
var _a;
|