@nextsparkjs/core 0.1.0-beta.15 → 0.1.0-beta.151
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 +35 -55
- 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 +87 -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 +19 -2
- package/dist/components/dashboard/block-editor/block-picker.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-picker.js +328 -80
- package/dist/components/dashboard/block-editor/block-preview-canvas.d.ts +4 -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 +140 -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 +2 -1
- package/dist/components/dashboard/block-editor/builder-editor-view.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/builder-editor-view.js +423 -178
- 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 +15 -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 +99 -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 +14 -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 +142 -0
- package/dist/components/dashboard/block-editor/tree-view.d.ts +20 -0
- package/dist/components/dashboard/block-editor/tree-view.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/tree-view.js +131 -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/DashboardAuthLayout.d.ts +7 -0
- package/dist/components/dashboard/layouts/DashboardAuthLayout.d.ts.map +1 -0
- package/dist/components/dashboard/layouts/DashboardAuthLayout.js +44 -0
- package/dist/components/dashboard/layouts/DashboardShell.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/DashboardShell.js +16 -18
- 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.d.ts +1 -0
- package/dist/components/dashboard/layouts/index.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/index.js +6 -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 +12 -16
- package/dist/components/dashboard/mobile/MobileMoreSheet.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/MobileMoreSheet.js +50 -44
- 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 +90 -56
- 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 +1 -1
- package/dist/components/entities/EntityTable.d.ts.map +1 -1
- package/dist/components/entities/EntityTable.js +56 -42
- package/dist/components/entities/ErrorBoundary.js +3 -3
- package/dist/components/entities/entity-table.types.d.ts +2 -0
- package/dist/components/entities/entity-table.types.d.ts.map +1 -1
- 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.d.ts.map +1 -1
- package/dist/components/entities/wrappers/EntityListWrapper.js +36 -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 +5 -1
- package/dist/components/public/pageBuilder/PageRenderer.d.ts.map +1 -1
- package/dist/components/public/pageBuilder/PageRenderer.js +13 -12
- 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 +24 -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/emails/otp-verification.d.ts +9 -0
- package/dist/emails/otp-verification.d.ts.map +1 -0
- package/dist/emails/otp-verification.js +72 -0
- package/dist/emails/reset-password.d.ts +9 -0
- package/dist/emails/reset-password.d.ts.map +1 -0
- package/dist/emails/reset-password.js +95 -0
- package/dist/emails/team-invitation.d.ts +9 -0
- package/dist/emails/team-invitation.d.ts.map +1 -0
- package/dist/emails/team-invitation.js +93 -0
- package/dist/emails/verify-email.d.ts +13 -0
- package/dist/emails/verify-email.d.ts.map +1 -0
- package/dist/emails/verify-email.js +84 -0
- 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/entities.d.ts +6 -1
- package/dist/lib/api/entities.d.ts.map +1 -1
- package/dist/lib/api/entities.js +23 -2
- 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 +300 -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 +140 -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 +100 -26
- 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 +32 -64
- package/dist/lib/billing/gateways/stripe.d.ts.map +1 -1
- package/dist/lib/billing/gateways/stripe.js +156 -86
- 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/clipboard.d.ts +11 -0
- package/dist/lib/blocks/clipboard.d.ts.map +1 -0
- package/dist/lib/blocks/clipboard.js +30 -0
- package/dist/lib/blocks/loader.d.ts +9 -0
- package/dist/lib/blocks/loader.d.ts.map +1 -1
- package/dist/lib/blocks/loader.js +9 -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 +74 -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 +135 -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.d.ts +1 -0
- package/dist/lib/email/index.d.ts.map +1 -1
- package/dist/lib/email/index.js +15 -3
- package/dist/lib/email/send.d.ts +15 -0
- package/dist/lib/email/send.d.ts.map +1 -0
- package/dist/lib/email/send.js +11 -0
- package/dist/lib/email/templates.d.ts +42 -25
- package/dist/lib/email/templates.d.ts.map +1 -1
- package/dist/lib/email/templates.js +8 -242
- package/dist/lib/email/types.d.ts +38 -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 +41 -7
- package/dist/lib/entities/queries.d.ts.map +1 -1
- package/dist/lib/entities/queries.js +24 -0
- package/dist/lib/entities/query-generator.js +8 -7
- package/dist/lib/entities/registry.client.d.ts +7 -1
- package/dist/lib/entities/registry.client.d.ts.map +1 -1
- package/dist/lib/entities/registry.client.js +12 -1
- 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 -80
- package/dist/lib/entities/schema-generator.d.ts.map +1 -1
- package/dist/lib/entities/schema-generator.js +40 -7
- 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 +71 -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 +7 -7
- package/dist/lib/services/subscription.service.d.ts.map +1 -1
- package/dist/lib/services/subscription.service.js +69 -56
- 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 +7 -0
- package/dist/lib/translations/registry.d.ts.map +1 -1
- package/dist/lib/translations/registry.js +32 -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/email.json +58 -0
- 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 +124 -4
- 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/email.json +58 -0
- package/dist/messages/en/features.json +8 -0
- package/dist/messages/en/index.d.ts +585 -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 +124 -4
- 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/email.json +58 -0
- package/dist/messages/es/features.json +8 -0
- package/dist/messages/es/index.d.ts +550 -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/email.json +58 -0
- 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/email.json +58 -0
- 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/email.json +58 -0
- 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/DashboardProviders.d.ts +12 -0
- package/dist/providers/DashboardProviders.d.ts.map +1 -0
- package/dist/providers/DashboardProviders.js +16 -0
- package/dist/providers/TranslationContextManager.js +1 -1
- package/dist/providers/index.d.ts +1 -0
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js +5 -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/providers/static-intl-provider.d.ts +9 -0
- package/dist/providers/static-intl-provider.d.ts.map +1 -0
- package/dist/providers/static-intl-provider.js +9 -0
- package/dist/styles/classes.json +115 -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 +25 -0
- package/dist/templates/app/(auth)/forgot-password/page.tsx +1 -2
- package/dist/templates/app/(auth)/layout.tsx +4 -1
- package/dist/templates/app/(auth)/login/page.tsx +0 -1
- package/dist/templates/app/(auth)/reset-password/page.tsx +10 -11
- package/dist/templates/app/(auth)/signup/page.tsx +32 -2
- package/dist/templates/app/(auth)/verify-email/page.tsx +8 -9
- package/dist/templates/app/(public)/[...slug]/page.tsx +128 -9
- 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/(public)/layout.tsx +4 -1
- package/dist/templates/app/403/page.tsx +1 -1
- package/dist/templates/app/api/auth/[...all]/route.ts +86 -14
- package/dist/templates/app/api/csp-report/route.ts +181 -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 +495 -0
- package/dist/templates/app/api/v1/billing/webhooks/stripe/route.ts +23 -417
- 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 +14 -12
- 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]/edit/page.tsx +1 -1
- package/dist/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +12 -27
- package/dist/templates/app/dashboard/(main)/[entity]/create/page.tsx +1 -1
- package/dist/templates/app/dashboard/(main)/[entity]/loading.tsx +5 -2
- package/dist/templates/app/dashboard/(main)/[entity]/page.tsx +9 -23
- package/dist/templates/app/dashboard/(main)/layout.tsx +64 -7
- 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/layout.tsx +6 -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 +9 -19
- 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 -50
- 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/blocks/page.tsx +10 -1
- package/dist/templates/app/devtools/config/page.tsx +10 -1
- package/dist/templates/app/devtools/features/page.tsx +10 -1
- package/dist/templates/app/devtools/flows/page.tsx +10 -1
- package/dist/templates/app/devtools/layout.tsx +6 -1
- package/dist/templates/app/devtools/page.tsx +10 -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/devtools/tags/page.tsx +10 -1
- package/dist/templates/app/devtools/tests/[[...path]]/page.tsx +10 -1
- package/dist/templates/app/globals.css +7 -312
- package/dist/templates/app/layout.ppr.tsx +105 -0
- package/dist/templates/app/layout.tsx +19 -15
- package/dist/templates/app/superadmin/docs/[section]/[page]/page.tsx +77 -0
- package/dist/templates/app/superadmin/docs/page.tsx +75 -0
- package/dist/templates/app/superadmin/layout.tsx +64 -35
- 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 +19 -16
- package/dist/templates/app/superadmin/teams/page.tsx +37 -84
- package/dist/templates/app/superadmin/users/[userId]/page.tsx +1 -1
- 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 +58 -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/emails/_README.md +69 -0
- package/dist/templates/contents/themes/starter/emails/verify-email.ts +34 -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 +139 -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 +191 -29
- package/scripts/build/docs-registry.mjs +94 -148
- package/scripts/build/registry/__tests__/translation-registry-ppr.test.mjs +118 -0
- 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/emails.mjs +146 -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 +58 -9
- package/scripts/build/registry/generators/docs-registry.mjs +241 -0
- package/scripts/build/registry/generators/email-registry.mjs +94 -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/middleware-registry.mjs +1 -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 +93 -4
- 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 +224 -11
- 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 +64 -16
- 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 +25 -0
- package/templates/app/(auth)/forgot-password/page.tsx +1 -2
- package/templates/app/(auth)/layout.tsx +4 -1
- package/templates/app/(auth)/login/page.tsx +0 -1
- package/templates/app/(auth)/reset-password/page.tsx +10 -11
- package/templates/app/(auth)/signup/page.tsx +32 -2
- package/templates/app/(auth)/verify-email/page.tsx +8 -9
- package/templates/app/(public)/[...slug]/page.tsx +128 -9
- 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/(public)/layout.tsx +4 -1
- package/templates/app/403/page.tsx +1 -1
- package/templates/app/api/auth/[...all]/route.ts +86 -14
- package/templates/app/api/csp-report/route.ts +181 -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 +495 -0
- package/templates/app/api/v1/billing/webhooks/stripe/route.ts +23 -417
- 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 +14 -12
- 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]/edit/page.tsx +1 -1
- package/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +12 -27
- package/templates/app/dashboard/(main)/[entity]/create/page.tsx +1 -1
- package/templates/app/dashboard/(main)/[entity]/loading.tsx +5 -2
- package/templates/app/dashboard/(main)/[entity]/page.tsx +9 -23
- package/templates/app/dashboard/(main)/layout.tsx +64 -7
- 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/layout.tsx +6 -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 +9 -19
- 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 -50
- 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/blocks/page.tsx +10 -1
- package/templates/app/devtools/config/page.tsx +10 -1
- package/templates/app/devtools/features/page.tsx +10 -1
- package/templates/app/devtools/flows/page.tsx +10 -1
- package/templates/app/devtools/layout.tsx +6 -1
- package/templates/app/devtools/page.tsx +10 -1
- package/templates/app/devtools/plugins/[plugin]/page.tsx +17 -0
- package/templates/app/devtools/scheduled-actions/page.tsx +1 -1
- package/templates/app/devtools/tags/page.tsx +10 -1
- package/templates/app/devtools/tests/[[...path]]/page.tsx +10 -1
- package/templates/app/globals.css +7 -312
- package/templates/app/layout.ppr.tsx +105 -0
- package/templates/app/layout.tsx +19 -15
- package/templates/app/superadmin/docs/[section]/[page]/page.tsx +77 -0
- package/templates/app/superadmin/docs/page.tsx +75 -0
- package/templates/app/superadmin/layout.tsx +64 -35
- 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 +19 -16
- package/templates/app/superadmin/teams/page.tsx +37 -84
- package/templates/app/superadmin/users/[userId]/page.tsx +1 -1
- 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 +58 -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/emails/_README.md +69 -0
- package/templates/contents/themes/starter/emails/verify-email.ts +34 -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 +139 -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/block-registry.ts +2 -0
- package/tests/jest/__mocks__/@nextsparkjs/registries/docs-registry.ts +161 -0
- package/tests/jest/__mocks__/@nextsparkjs/registries/email-registry.ts +41 -0
- package/tests/jest/__mocks__/@nextsparkjs/registries/permissions-registry.ts +37 -0
- package/tests/jest/__mocks__/next-intl-server.js +55 -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,36 @@ 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 { checkPermission } from "../../permissions/check.js";
|
|
22
|
+
import { extractPatternIds } from "../../blocks/pattern-resolver.js";
|
|
23
|
+
import { isPatternReference } from "../../../types/pattern-reference.js";
|
|
24
|
+
import { PatternUsageService } from "../../services/pattern-usage.service.js";
|
|
25
|
+
import { SubscriptionService } from "../../services/subscription.service.js";
|
|
26
|
+
import { UsageService } from "../../services/usage.service.js";
|
|
27
|
+
import { BILLING_REGISTRY } from "@nextsparkjs/registries/billing-registry";
|
|
28
|
+
function filterPublicFields(data, entityConfig, userId) {
|
|
29
|
+
var _a;
|
|
30
|
+
const publicFields = (_a = entityConfig.access) == null ? void 0 : _a.publicFields;
|
|
31
|
+
if (!publicFields || publicFields.length === 0 || userId !== null) {
|
|
32
|
+
return data;
|
|
33
|
+
}
|
|
34
|
+
const allowedSet = new Set(publicFields);
|
|
35
|
+
const filterItem = (item) => {
|
|
36
|
+
const filtered = {};
|
|
37
|
+
for (const key of allowedSet) {
|
|
38
|
+
if (key in item) {
|
|
39
|
+
filtered[key] = item[key];
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
return filtered;
|
|
43
|
+
};
|
|
44
|
+
if (Array.isArray(data)) {
|
|
45
|
+
return data.map((item) => filterItem(item));
|
|
46
|
+
}
|
|
47
|
+
return filterItem(data);
|
|
48
|
+
}
|
|
21
49
|
async function includeTaxonomiesInData(entityConfig, items, userId) {
|
|
22
50
|
var _a, _b, _c;
|
|
23
51
|
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,12 +156,49 @@ function parseTaxonomyFilterParams(url, entityConfig) {
|
|
|
128
156
|
function getTableName(entityConfig) {
|
|
129
157
|
return entityConfig.tableName || entityConfig.slug;
|
|
130
158
|
}
|
|
159
|
+
async function filterOrphanedPatternReferences(blocks, userId) {
|
|
160
|
+
if (!Array.isArray(blocks) || blocks.length === 0) return blocks;
|
|
161
|
+
const patternIds = extractPatternIds(blocks);
|
|
162
|
+
if (patternIds.length === 0) return blocks;
|
|
163
|
+
const existingIds = await PatternUsageService.getExistingPatternIds(patternIds, userId);
|
|
164
|
+
if (existingIds.size === patternIds.length) return blocks;
|
|
165
|
+
const filtered = blocks.filter((block) => {
|
|
166
|
+
if (isPatternReference(block)) {
|
|
167
|
+
const exists = existingIds.has(block.ref);
|
|
168
|
+
if (!exists) {
|
|
169
|
+
console.info(`[generic-handler] Filtering orphaned PatternReference: ${block.ref}`);
|
|
170
|
+
}
|
|
171
|
+
return exists;
|
|
172
|
+
}
|
|
173
|
+
return true;
|
|
174
|
+
});
|
|
175
|
+
return filtered;
|
|
176
|
+
}
|
|
131
177
|
function getTeamIdFromRequest(request) {
|
|
132
178
|
return request.headers.get("x-team-id");
|
|
133
179
|
}
|
|
134
180
|
function isBuilderRequest(request) {
|
|
135
181
|
return request.headers.get("x-builder-source") === "true";
|
|
136
182
|
}
|
|
183
|
+
async function checkSessionPermission(authResult, entitySlug, action, teamId, request) {
|
|
184
|
+
var _a;
|
|
185
|
+
if (authResult.type !== "session" || !((_a = authResult.user) == null ? void 0 : _a.id)) return null;
|
|
186
|
+
const permission = `${entitySlug}.${action}`;
|
|
187
|
+
try {
|
|
188
|
+
const allowed = await checkPermission(authResult.user.id, teamId, permission);
|
|
189
|
+
if (!allowed) {
|
|
190
|
+
const response = createApiError(
|
|
191
|
+
`Permission denied: insufficient permissions for ${entitySlug}.${action}`,
|
|
192
|
+
403,
|
|
193
|
+
void 0,
|
|
194
|
+
"PERMISSION_DENIED"
|
|
195
|
+
);
|
|
196
|
+
return addCorsHeaders(response, request);
|
|
197
|
+
}
|
|
198
|
+
} catch {
|
|
199
|
+
}
|
|
200
|
+
return null;
|
|
201
|
+
}
|
|
137
202
|
async function validateTeamMembership(userId, teamId) {
|
|
138
203
|
try {
|
|
139
204
|
console.log("[GenericHandler] Validating team membership:", { userId, teamId, teamIdLength: teamId == null ? void 0 : teamId.length });
|
|
@@ -154,7 +219,7 @@ async function validateTeamContextWithBypass(request, authResult, userId) {
|
|
|
154
219
|
const canBypass = await canBypassTeamContext(authResult, request);
|
|
155
220
|
if (canBypass) {
|
|
156
221
|
console.log("[GenericHandler] Admin bypass active:", { userId, teamId: teamId || "cross-team" });
|
|
157
|
-
return { valid: true, teamId };
|
|
222
|
+
return { valid: true, teamId, isBypass: true };
|
|
158
223
|
}
|
|
159
224
|
if (!teamId) {
|
|
160
225
|
const response = createApiError(
|
|
@@ -175,25 +240,26 @@ async function validateTeamContextWithBypass(request, authResult, userId) {
|
|
|
175
240
|
);
|
|
176
241
|
return { valid: false, error: await addCorsHeaders(response) };
|
|
177
242
|
}
|
|
178
|
-
return { valid: true, teamId };
|
|
243
|
+
return { valid: true, teamId, isBypass: false };
|
|
179
244
|
}
|
|
180
245
|
async function handleGenericList(request) {
|
|
181
|
-
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j;
|
|
246
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m;
|
|
182
247
|
try {
|
|
183
248
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
184
249
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
185
250
|
const response2 = createApiError("Entity not found", 404);
|
|
186
|
-
return addCorsHeaders(response2);
|
|
251
|
+
return addCorsHeaders(response2, request);
|
|
187
252
|
}
|
|
188
253
|
if (!validateEntityOperation(resolution.entityConfig, "list")) {
|
|
189
254
|
const response2 = createApiError("List operation not supported for this entity", 405);
|
|
190
|
-
return addCorsHeaders(response2);
|
|
255
|
+
return addCorsHeaders(response2, request);
|
|
191
256
|
}
|
|
192
257
|
const authResult = await authenticateRequest(request);
|
|
193
258
|
let userId = null;
|
|
194
259
|
let teamId = null;
|
|
260
|
+
let isBypass = false;
|
|
195
261
|
if (!authResult.success && ((_a = resolution.entityConfig.access) == null ? void 0 : _a.public)) {
|
|
196
|
-
|
|
262
|
+
teamId = request.headers.get("x-team-id") ?? null;
|
|
197
263
|
} else if (!authResult.success) {
|
|
198
264
|
return NextResponse.json(
|
|
199
265
|
{ success: false, error: "Authentication required", code: "AUTHENTICATION_FAILED" },
|
|
@@ -205,7 +271,7 @@ async function handleGenericList(request) {
|
|
|
205
271
|
}
|
|
206
272
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:read`)) {
|
|
207
273
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
208
|
-
return addCorsHeaders(response2);
|
|
274
|
+
return addCorsHeaders(response2, request);
|
|
209
275
|
}
|
|
210
276
|
userId = authResult.user.id;
|
|
211
277
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, userId);
|
|
@@ -213,6 +279,7 @@ async function handleGenericList(request) {
|
|
|
213
279
|
return teamValidation.error;
|
|
214
280
|
}
|
|
215
281
|
teamId = teamValidation.teamId;
|
|
282
|
+
isBypass = teamValidation.isBypass;
|
|
216
283
|
}
|
|
217
284
|
const pagination = parsePaginationParams(request);
|
|
218
285
|
const metaParams = parseMetaParams(request);
|
|
@@ -252,10 +319,13 @@ async function handleGenericList(request) {
|
|
|
252
319
|
return `t.${columnName}`;
|
|
253
320
|
}).join(", ");
|
|
254
321
|
} else {
|
|
255
|
-
const systemFields = ["id", "createdAt", "updatedAt"];
|
|
322
|
+
const systemFields = ["id", "userId", "teamId", "createdAt", "updatedAt"];
|
|
256
323
|
if ((_b = entityConfig.builder) == null ? void 0 : _b.enabled) {
|
|
257
324
|
systemFields.push("blocks");
|
|
258
325
|
}
|
|
326
|
+
if ((_c = entityConfig.table) == null ? void 0 : _c.softDelete) {
|
|
327
|
+
systemFields.push("deletedAt", "deletedBy");
|
|
328
|
+
}
|
|
259
329
|
const configFields = entityConfig.fields.map((field) => {
|
|
260
330
|
const columnName = /[A-Z]/.test(field.name) ? `"${field.name}"` : field.name;
|
|
261
331
|
return `t.${columnName}`;
|
|
@@ -265,6 +335,9 @@ async function handleGenericList(request) {
|
|
|
265
335
|
return `t.${columnName}`;
|
|
266
336
|
});
|
|
267
337
|
fields = [...systemFieldsFormatted, ...configFields].join(", ");
|
|
338
|
+
if (entityConfig.slug === "patterns") {
|
|
339
|
+
fields += ', COALESCE(pu.usage_count, 0)::int as "usageCount"';
|
|
340
|
+
}
|
|
268
341
|
}
|
|
269
342
|
let query;
|
|
270
343
|
let queryParams;
|
|
@@ -273,8 +346,8 @@ async function handleGenericList(request) {
|
|
|
273
346
|
const fromDate = url.searchParams.get("from");
|
|
274
347
|
const toDate = url.searchParams.get("to");
|
|
275
348
|
const dateFieldName = url.searchParams.get("dateField");
|
|
276
|
-
const isPublicEntity = ((
|
|
277
|
-
const requestingPublishedOnly = (
|
|
349
|
+
const isPublicEntity = ((_d = entityConfig.access) == null ? void 0 : _d.public) === true;
|
|
350
|
+
const requestingPublishedOnly = (_e = customFilters["status"]) == null ? void 0 : _e.includes("published");
|
|
278
351
|
const skipUserFilter = isPublicEntity && requestingPublishedOnly;
|
|
279
352
|
if (skipUserFilter && process.env.NODE_ENV === "development") {
|
|
280
353
|
console.log(`[GenericHandler] Public access mode: skipping userId filter for ${entityConfig.slug} (status=published)`);
|
|
@@ -285,20 +358,23 @@ async function handleGenericList(request) {
|
|
|
285
358
|
const idPlaceholders = specificIds.map(() => `$${paramIndex++}`).join(", ");
|
|
286
359
|
query = `SELECT ${fields} FROM "${tableName}" t WHERE t.id IN (${idPlaceholders})`;
|
|
287
360
|
queryParams = [...specificIds];
|
|
288
|
-
if (teamId
|
|
361
|
+
if (teamId) {
|
|
289
362
|
query += ` AND t."teamId" = $${paramIndex++}`;
|
|
290
363
|
queryParams.push(teamId);
|
|
291
364
|
}
|
|
292
|
-
if (userId && !((
|
|
365
|
+
if (userId && !((_f = entityConfig.access) == null ? void 0 : _f.shared) && !skipUserFilter && !isBypass) {
|
|
293
366
|
query += ` AND t."userId" = $${paramIndex++}`;
|
|
294
367
|
queryParams.push(userId);
|
|
295
368
|
}
|
|
369
|
+
if (((_g = entityConfig.table) == null ? void 0 : _g.softDelete) && !isBypass) {
|
|
370
|
+
query += ` AND t."deletedAt" IS NULL`;
|
|
371
|
+
}
|
|
296
372
|
} else if (fieldsParam && distinctParam) {
|
|
297
373
|
const fieldName = fieldsParam;
|
|
298
374
|
const parentId = url.searchParams.get("parentId");
|
|
299
375
|
query = `SELECT ${fields} FROM "${tableName}" t WHERE 1=1`;
|
|
300
376
|
queryParams = [];
|
|
301
|
-
if (teamId
|
|
377
|
+
if (teamId) {
|
|
302
378
|
query += ` AND t."teamId" = $${paramIndex++}`;
|
|
303
379
|
queryParams.push(teamId);
|
|
304
380
|
}
|
|
@@ -306,24 +382,30 @@ async function handleGenericList(request) {
|
|
|
306
382
|
query += ` AND t."parentId" = $${paramIndex++}`;
|
|
307
383
|
queryParams.push(parentId);
|
|
308
384
|
}
|
|
309
|
-
if (userId && !((
|
|
385
|
+
if (userId && !((_h = entityConfig.access) == null ? void 0 : _h.shared) && !skipUserFilter && !isBypass) {
|
|
310
386
|
query += ` AND t."userId" = $${paramIndex++}`;
|
|
311
387
|
queryParams.push(userId);
|
|
312
388
|
}
|
|
389
|
+
if (((_i = entityConfig.table) == null ? void 0 : _i.softDelete) && !isBypass) {
|
|
390
|
+
query += ` AND t."deletedAt" IS NULL`;
|
|
391
|
+
}
|
|
313
392
|
query += ` ORDER BY "${fieldName}" ASC LIMIT $${paramIndex++}`;
|
|
314
393
|
queryParams.push(pagination.limit);
|
|
315
394
|
} else {
|
|
316
395
|
const whereConditions = [];
|
|
317
396
|
queryParams = [];
|
|
318
397
|
paramIndex = 1;
|
|
319
|
-
if (teamId
|
|
398
|
+
if (teamId) {
|
|
320
399
|
whereConditions.push(`t."teamId" = $${paramIndex++}`);
|
|
321
400
|
queryParams.push(teamId);
|
|
322
401
|
}
|
|
323
|
-
if (userId && !((
|
|
402
|
+
if (userId && !((_j = entityConfig.access) == null ? void 0 : _j.shared) && !skipUserFilter && !isBypass) {
|
|
324
403
|
whereConditions.push(`t."userId" = $${paramIndex++}`);
|
|
325
404
|
queryParams.push(userId);
|
|
326
405
|
}
|
|
406
|
+
if (((_k = entityConfig.table) == null ? void 0 : _k.softDelete) && !isBypass) {
|
|
407
|
+
whereConditions.push(`t."deletedAt" IS NULL`);
|
|
408
|
+
}
|
|
327
409
|
if (searchParam && searchParam.trim() !== "") {
|
|
328
410
|
const searchTerm = searchParam.trim();
|
|
329
411
|
const hasName = entityConfig.fields.some((f) => f.name === "name");
|
|
@@ -397,107 +479,42 @@ async function handleGenericList(request) {
|
|
|
397
479
|
queryParams.push(taxonomyFilter.taxonomyId);
|
|
398
480
|
}
|
|
399
481
|
const whereClause = whereConditions.length > 0 ? `WHERE ${whereConditions.join(" AND ")}` : "";
|
|
482
|
+
let joinClause = "";
|
|
483
|
+
if (entityConfig.slug === "patterns") {
|
|
484
|
+
joinClause = `
|
|
485
|
+
LEFT JOIN (
|
|
486
|
+
SELECT "patternId", COUNT(*) as usage_count
|
|
487
|
+
FROM pattern_usages
|
|
488
|
+
GROUP BY "patternId"
|
|
489
|
+
) pu ON t.id = pu."patternId"
|
|
490
|
+
`;
|
|
491
|
+
}
|
|
492
|
+
const sortByParam = url.searchParams.get("sortBy");
|
|
493
|
+
const sortOrderParam = ((_l = url.searchParams.get("sortOrder")) == null ? void 0 : _l.toUpperCase()) === "ASC" ? "ASC" : "DESC";
|
|
494
|
+
let orderByClause = 't."createdAt" DESC';
|
|
495
|
+
if (sortByParam) {
|
|
496
|
+
const baseFields = ["id", "createdAt", "updatedAt", "teamId"];
|
|
497
|
+
const isValidField = entityConfig.fields.some((f) => f.name === sortByParam) || baseFields.includes(sortByParam);
|
|
498
|
+
if (isValidField) {
|
|
499
|
+
orderByClause = `t."${sortByParam}" ${sortOrderParam}`;
|
|
500
|
+
}
|
|
501
|
+
}
|
|
400
502
|
query = `
|
|
401
|
-
SELECT ${fields}
|
|
503
|
+
SELECT ${fields}, COUNT(*) OVER() as total_count
|
|
402
504
|
FROM "${tableName}" t
|
|
505
|
+
${joinClause}
|
|
403
506
|
${whereClause}
|
|
404
|
-
ORDER BY
|
|
507
|
+
ORDER BY ${orderByClause}
|
|
405
508
|
LIMIT $${paramIndex++} OFFSET $${paramIndex++}
|
|
406
509
|
`;
|
|
407
510
|
queryParams.push(pagination.limit, pagination.offset);
|
|
408
511
|
}
|
|
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
|
-
}
|
|
512
|
+
const rawData = await queryWithRLS(query, queryParams, userId);
|
|
513
|
+
const total = rawData.length > 0 ? Number(rawData[0].total_count) || 0 : 0;
|
|
514
|
+
const data = rawData.map((row) => {
|
|
515
|
+
const { total_count, ...rest } = row;
|
|
516
|
+
return rest;
|
|
484
517
|
});
|
|
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
518
|
const paginationMeta = createPaginationMeta(pagination.page, pagination.limit, total);
|
|
502
519
|
let dataWithMeta = data;
|
|
503
520
|
if (metaParams.includeMetadata && userId) {
|
|
@@ -520,32 +537,33 @@ async function handleGenericList(request) {
|
|
|
520
537
|
);
|
|
521
538
|
}
|
|
522
539
|
let dataWithTaxonomies = dataWithChild;
|
|
523
|
-
if ((
|
|
540
|
+
if ((_m = entityConfig.taxonomies) == null ? void 0 : _m.enabled) {
|
|
524
541
|
dataWithTaxonomies = await includeTaxonomiesInData(
|
|
525
542
|
entityConfig,
|
|
526
543
|
dataWithChild,
|
|
527
544
|
userId
|
|
528
545
|
);
|
|
529
546
|
}
|
|
530
|
-
const
|
|
531
|
-
|
|
547
|
+
const finalData = filterPublicFields(dataWithTaxonomies, entityConfig, userId);
|
|
548
|
+
const response = createApiResponse(finalData, paginationMeta);
|
|
549
|
+
return addCorsHeaders(response, request);
|
|
532
550
|
} catch (error) {
|
|
533
551
|
console.error("Error in generic list handler:", error);
|
|
534
552
|
const response = createApiError("Internal server error", 500);
|
|
535
|
-
return addCorsHeaders(response);
|
|
553
|
+
return addCorsHeaders(response, request);
|
|
536
554
|
}
|
|
537
555
|
}
|
|
538
556
|
async function handleGenericCreate(request) {
|
|
539
|
-
var _a, _b, _c, _d, _e, _f, _g;
|
|
557
|
+
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j;
|
|
540
558
|
try {
|
|
541
559
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
542
560
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
543
561
|
const response2 = createApiError("Entity not found", 404);
|
|
544
|
-
return addCorsHeaders(response2);
|
|
562
|
+
return addCorsHeaders(response2, request);
|
|
545
563
|
}
|
|
546
564
|
if (!validateEntityOperation(resolution.entityConfig, "create")) {
|
|
547
565
|
const response2 = createApiError("Create operation not supported for this entity", 405);
|
|
548
|
-
return addCorsHeaders(response2);
|
|
566
|
+
return addCorsHeaders(response2, request);
|
|
549
567
|
}
|
|
550
568
|
const authResult = await authenticateRequest(request);
|
|
551
569
|
if (!authResult.success) {
|
|
@@ -559,14 +577,14 @@ async function handleGenericCreate(request) {
|
|
|
559
577
|
}
|
|
560
578
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:write`)) {
|
|
561
579
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
562
|
-
return addCorsHeaders(response2);
|
|
580
|
+
return addCorsHeaders(response2, request);
|
|
563
581
|
}
|
|
564
582
|
let body;
|
|
565
583
|
try {
|
|
566
584
|
body = await request.json();
|
|
567
585
|
} catch {
|
|
568
586
|
const response2 = createApiError("Invalid JSON body", 400);
|
|
569
|
-
return addCorsHeaders(response2);
|
|
587
|
+
return addCorsHeaders(response2, request);
|
|
570
588
|
}
|
|
571
589
|
const { metas, ...entityData } = body;
|
|
572
590
|
const rawUserId = entityData.userId;
|
|
@@ -580,7 +598,7 @@ async function handleGenericCreate(request) {
|
|
|
580
598
|
errors: validation.error.issues
|
|
581
599
|
});
|
|
582
600
|
const response2 = createApiError("Validation error", 400, validation.error.issues, "VALIDATION_ERROR");
|
|
583
|
-
return addCorsHeaders(response2);
|
|
601
|
+
return addCorsHeaders(response2, request);
|
|
584
602
|
}
|
|
585
603
|
const validatedData = validation.data;
|
|
586
604
|
const idStrategy = ((_a = entityConfig.idStrategy) == null ? void 0 : _a.type) || "uuid";
|
|
@@ -597,8 +615,10 @@ async function handleGenericCreate(request) {
|
|
|
597
615
|
const teamId = teamValidation.teamId;
|
|
598
616
|
if (!teamId) {
|
|
599
617
|
const response2 = createApiError("Team context required for create operations. Include x-team-id header.", 400, void 0, "TEAM_CONTEXT_REQUIRED");
|
|
600
|
-
return addCorsHeaders(response2);
|
|
618
|
+
return addCorsHeaders(response2, request);
|
|
601
619
|
}
|
|
620
|
+
const permDenied = await checkSessionPermission(authResult, entityConfig.slug, "create", teamId, request);
|
|
621
|
+
if (permDenied) return permDenied;
|
|
602
622
|
if (idStrategy === "serial") {
|
|
603
623
|
insertFields = ['"userId"', '"teamId"'];
|
|
604
624
|
placeholders = ["$1", "$2"];
|
|
@@ -614,7 +634,8 @@ async function handleGenericCreate(request) {
|
|
|
614
634
|
const builderRequest = isBuilderRequest(request);
|
|
615
635
|
const entityHasBuilder = ((_c = entityConfig.builder) == null ? void 0 : _c.enabled) === true;
|
|
616
636
|
if (builderRequest && entityHasBuilder && "blocks" in validatedData) {
|
|
617
|
-
|
|
637
|
+
let blocksValue = validatedData.blocks;
|
|
638
|
+
blocksValue = await filterOrphanedPatternReferences(blocksValue, authResult.user.id);
|
|
618
639
|
insertFields.push('"blocks"');
|
|
619
640
|
placeholders.push(`$${paramCount++}::jsonb`);
|
|
620
641
|
values.push(JSON.stringify(blocksValue));
|
|
@@ -624,7 +645,7 @@ async function handleGenericCreate(request) {
|
|
|
624
645
|
var _a2, _b2;
|
|
625
646
|
if (key === "userId" || key === "teamId") return;
|
|
626
647
|
const field = entityConfig.fields.find((f) => f.name === key);
|
|
627
|
-
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)
|
|
648
|
+
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)) {
|
|
628
649
|
const columnName = `"${key}"`;
|
|
629
650
|
insertFields.push(columnName);
|
|
630
651
|
if (field.type === "relation") {
|
|
@@ -670,14 +691,45 @@ async function handleGenericCreate(request) {
|
|
|
670
691
|
}
|
|
671
692
|
}
|
|
672
693
|
});
|
|
694
|
+
const createAction = `${entityConfig.slug}.create`;
|
|
695
|
+
const limitSlug = (_f = (_e = (_d = BILLING_REGISTRY) == null ? void 0 : _d.actionMappings) == null ? void 0 : _e.limits) == null ? void 0 : _f[createAction];
|
|
696
|
+
if (limitSlug) {
|
|
697
|
+
const actionResult = await SubscriptionService.canPerformAction(
|
|
698
|
+
authResult.user.id,
|
|
699
|
+
teamId,
|
|
700
|
+
createAction
|
|
701
|
+
);
|
|
702
|
+
if (!actionResult.allowed) {
|
|
703
|
+
const statusCode = actionResult.reason === "quota_exceeded" ? 429 : 403;
|
|
704
|
+
const response2 = createApiError(
|
|
705
|
+
actionResult.message || `Quota exceeded for ${entityConfig.slug}`,
|
|
706
|
+
statusCode,
|
|
707
|
+
void 0,
|
|
708
|
+
actionResult.reason === "quota_exceeded" ? "QUOTA_EXCEEDED" : "FEATURE_NOT_IN_PLAN"
|
|
709
|
+
);
|
|
710
|
+
return addCorsHeaders(response2, request);
|
|
711
|
+
}
|
|
712
|
+
}
|
|
673
713
|
const insertQuery = `
|
|
674
714
|
INSERT INTO "${tableName}" (${insertFields.join(", ")})
|
|
675
715
|
VALUES (${placeholders.join(", ")}) RETURNING *
|
|
676
716
|
`;
|
|
677
717
|
const insertResult = await mutateWithRLS(insertQuery, values, authResult.user.id);
|
|
678
|
-
const createdEntityId = String((
|
|
679
|
-
|
|
680
|
-
|
|
718
|
+
const createdEntityId = String((_g = insertResult.rows[0]) == null ? void 0 : _g.id);
|
|
719
|
+
if (limitSlug) {
|
|
720
|
+
UsageService.track({
|
|
721
|
+
teamId,
|
|
722
|
+
userId: authResult.user.id,
|
|
723
|
+
limitSlug,
|
|
724
|
+
delta: 1,
|
|
725
|
+
action: createAction,
|
|
726
|
+
resourceType: entityConfig.slug,
|
|
727
|
+
resourceId: createdEntityId
|
|
728
|
+
}).catch(() => {
|
|
729
|
+
});
|
|
730
|
+
}
|
|
731
|
+
const systemFields = ["id", "userId", "teamId", "createdAt", "updatedAt"];
|
|
732
|
+
if ((_h = entityConfig.builder) == null ? void 0 : _h.enabled) {
|
|
681
733
|
systemFields.push("blocks");
|
|
682
734
|
}
|
|
683
735
|
const configFields = entityConfig.fields.map((field) => {
|
|
@@ -696,7 +748,7 @@ async function handleGenericCreate(request) {
|
|
|
696
748
|
`;
|
|
697
749
|
const createdItems = await queryWithRLS(selectQuery, [createdEntityId], authResult.user.id);
|
|
698
750
|
const createdItem = createdItems[0];
|
|
699
|
-
if ((
|
|
751
|
+
if ((_i = entityConfig.taxonomies) == null ? void 0 : _i.enabled) {
|
|
700
752
|
await processTaxonomyRelations(entityConfig, createdEntityId, body, authResult.user.id, false);
|
|
701
753
|
}
|
|
702
754
|
const metadataWasProvided = metas && typeof metas === "object" && Object.keys(metas).length > 0;
|
|
@@ -709,7 +761,7 @@ async function handleGenericCreate(request) {
|
|
|
709
761
|
);
|
|
710
762
|
}
|
|
711
763
|
let responseItem = createdItem;
|
|
712
|
-
if ((
|
|
764
|
+
if ((_j = entityConfig.taxonomies) == null ? void 0 : _j.enabled) {
|
|
713
765
|
const itemsWithTaxonomies = await includeTaxonomiesInData(
|
|
714
766
|
entityConfig,
|
|
715
767
|
[createdItem],
|
|
@@ -729,29 +781,41 @@ async function handleGenericCreate(request) {
|
|
|
729
781
|
console.error(`[generic-handler] Error in afterEntityCreate hook for ${entityConfig.slug}:`, hookError);
|
|
730
782
|
}
|
|
731
783
|
const response = createApiResponse(responseData, { created: true }, 201);
|
|
732
|
-
return addCorsHeaders(response);
|
|
784
|
+
return addCorsHeaders(response, request);
|
|
733
785
|
} catch (error) {
|
|
734
786
|
console.error("Error in generic create handler:", error);
|
|
787
|
+
if (error && typeof error === "object" && "code" in error && error.code === "23505") {
|
|
788
|
+
const detail = "detail" in error ? error.detail : void 0;
|
|
789
|
+
const constraint = "constraint" in error ? error.constraint : void 0;
|
|
790
|
+
const response2 = createApiError(
|
|
791
|
+
"A record with this value already exists",
|
|
792
|
+
409,
|
|
793
|
+
{ constraint, detail },
|
|
794
|
+
"UNIQUE_CONSTRAINT_VIOLATION"
|
|
795
|
+
);
|
|
796
|
+
return addCorsHeaders(response2, request);
|
|
797
|
+
}
|
|
735
798
|
const response = createApiError("Internal server error", 500);
|
|
736
|
-
return addCorsHeaders(response);
|
|
799
|
+
return addCorsHeaders(response, request);
|
|
737
800
|
}
|
|
738
801
|
}
|
|
739
802
|
async function handleGenericRead(request, { params }) {
|
|
740
|
-
var _a, _b, _c, _d;
|
|
803
|
+
var _a, _b, _c, _d, _e, _f;
|
|
741
804
|
try {
|
|
742
805
|
const { id } = await params;
|
|
743
806
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
744
807
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
745
808
|
const response2 = createApiError("Entity not found", 404);
|
|
746
|
-
return addCorsHeaders(response2);
|
|
809
|
+
return addCorsHeaders(response2, request);
|
|
747
810
|
}
|
|
748
811
|
if (!validateEntityOperation(resolution.entityConfig, "read")) {
|
|
749
812
|
const response2 = createApiError("Read operation not supported for this entity", 405);
|
|
750
|
-
return addCorsHeaders(response2);
|
|
813
|
+
return addCorsHeaders(response2, request);
|
|
751
814
|
}
|
|
752
815
|
const authResult = await authenticateRequest(request);
|
|
753
816
|
let userId = null;
|
|
754
817
|
let teamId = null;
|
|
818
|
+
let isBypass = false;
|
|
755
819
|
if (!authResult.success && ((_a = resolution.entityConfig.access) == null ? void 0 : _a.public)) {
|
|
756
820
|
console.log(`[GenericHandler] Public access allowed for ${resolution.entityConfig.slug} read`);
|
|
757
821
|
} else if (!authResult.success) {
|
|
@@ -765,7 +829,7 @@ async function handleGenericRead(request, { params }) {
|
|
|
765
829
|
}
|
|
766
830
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:read`)) {
|
|
767
831
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
768
|
-
return addCorsHeaders(response2);
|
|
832
|
+
return addCorsHeaders(response2, request);
|
|
769
833
|
}
|
|
770
834
|
userId = authResult.user.id;
|
|
771
835
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, userId);
|
|
@@ -773,13 +837,17 @@ async function handleGenericRead(request, { params }) {
|
|
|
773
837
|
return teamValidation.error;
|
|
774
838
|
}
|
|
775
839
|
teamId = teamValidation.teamId;
|
|
840
|
+
isBypass = teamValidation.isBypass;
|
|
776
841
|
}
|
|
777
842
|
const entityConfig = resolution.entityConfig;
|
|
778
843
|
const tableName = getTableName(entityConfig);
|
|
779
|
-
const systemFields = ["id", "createdAt", "updatedAt"];
|
|
844
|
+
const systemFields = ["id", "userId", "teamId", "createdAt", "updatedAt"];
|
|
780
845
|
if ((_b = entityConfig.builder) == null ? void 0 : _b.enabled) {
|
|
781
846
|
systemFields.push("blocks");
|
|
782
847
|
}
|
|
848
|
+
if ((_c = entityConfig.table) == null ? void 0 : _c.softDelete) {
|
|
849
|
+
systemFields.push("deletedAt", "deletedBy");
|
|
850
|
+
}
|
|
783
851
|
const configFields = entityConfig.fields.map((field) => {
|
|
784
852
|
const columnName = /[A-Z]/.test(field.name) ? `"${field.name}"` : field.name;
|
|
785
853
|
return `t.${columnName}`;
|
|
@@ -802,14 +870,17 @@ async function handleGenericRead(request, { params }) {
|
|
|
802
870
|
query += ` AND t."teamId" = $${paramIndex++}`;
|
|
803
871
|
queryParams.push(teamId);
|
|
804
872
|
}
|
|
805
|
-
if (userId && !((
|
|
873
|
+
if (userId && !((_d = entityConfig.access) == null ? void 0 : _d.shared) && !isBypass) {
|
|
806
874
|
query += ` AND t."userId" = $${paramIndex++}`;
|
|
807
875
|
queryParams.push(userId);
|
|
808
876
|
}
|
|
877
|
+
if (((_e = entityConfig.table) == null ? void 0 : _e.softDelete) && !isBypass) {
|
|
878
|
+
query += ` AND t."deletedAt" IS NULL`;
|
|
879
|
+
}
|
|
809
880
|
const items = await queryWithRLS(query, queryParams, userId);
|
|
810
881
|
if (!items[0]) {
|
|
811
882
|
const response2 = createApiError("Item not found", 404);
|
|
812
|
-
return addCorsHeaders(response2);
|
|
883
|
+
return addCorsHeaders(response2, request);
|
|
813
884
|
}
|
|
814
885
|
const item = items[0];
|
|
815
886
|
const metaParams = parseMetaParams(request);
|
|
@@ -836,7 +907,7 @@ async function handleGenericRead(request, { params }) {
|
|
|
836
907
|
itemWithChild = itemsWithChild[0] || itemWithMeta;
|
|
837
908
|
}
|
|
838
909
|
let itemWithTaxonomies = itemWithChild;
|
|
839
|
-
if ((
|
|
910
|
+
if ((_f = entityConfig.taxonomies) == null ? void 0 : _f.enabled) {
|
|
840
911
|
const itemsWithTaxonomies = await includeTaxonomiesInData(
|
|
841
912
|
entityConfig,
|
|
842
913
|
[itemWithChild],
|
|
@@ -844,12 +915,13 @@ async function handleGenericRead(request, { params }) {
|
|
|
844
915
|
);
|
|
845
916
|
itemWithTaxonomies = itemsWithTaxonomies[0] || itemWithChild;
|
|
846
917
|
}
|
|
847
|
-
const
|
|
848
|
-
|
|
918
|
+
const finalItem = filterPublicFields(itemWithTaxonomies, entityConfig, userId);
|
|
919
|
+
const response = createApiResponse(finalItem);
|
|
920
|
+
return addCorsHeaders(response, request);
|
|
849
921
|
} catch (error) {
|
|
850
922
|
console.error("Error in generic read handler:", error);
|
|
851
923
|
const response = createApiError("Internal server error", 500);
|
|
852
|
-
return addCorsHeaders(response);
|
|
924
|
+
return addCorsHeaders(response, request);
|
|
853
925
|
}
|
|
854
926
|
}
|
|
855
927
|
async function handleGenericUpdate(request, { params }) {
|
|
@@ -859,11 +931,11 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
859
931
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
860
932
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
861
933
|
const response2 = createApiError("Entity not found", 404);
|
|
862
|
-
return addCorsHeaders(response2);
|
|
934
|
+
return addCorsHeaders(response2, request);
|
|
863
935
|
}
|
|
864
936
|
if (!validateEntityOperation(resolution.entityConfig, "update")) {
|
|
865
937
|
const response2 = createApiError("Update operation not supported for this entity", 405);
|
|
866
|
-
return addCorsHeaders(response2);
|
|
938
|
+
return addCorsHeaders(response2, request);
|
|
867
939
|
}
|
|
868
940
|
const authResult = await authenticateRequest(request);
|
|
869
941
|
if (!authResult.success) {
|
|
@@ -877,7 +949,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
877
949
|
}
|
|
878
950
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:write`)) {
|
|
879
951
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
880
|
-
return addCorsHeaders(response2);
|
|
952
|
+
return addCorsHeaders(response2, request);
|
|
881
953
|
}
|
|
882
954
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, authResult.user.id);
|
|
883
955
|
if (!teamValidation.valid) {
|
|
@@ -886,14 +958,16 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
886
958
|
const teamId = teamValidation.teamId;
|
|
887
959
|
if (!teamId) {
|
|
888
960
|
const response2 = createApiError("Team context required for update operations. Include x-team-id header.", 400, void 0, "TEAM_CONTEXT_REQUIRED");
|
|
889
|
-
return addCorsHeaders(response2);
|
|
961
|
+
return addCorsHeaders(response2, request);
|
|
890
962
|
}
|
|
963
|
+
const permDenied = await checkSessionPermission(authResult, resolution.entityConfig.slug, "update", teamId, request);
|
|
964
|
+
if (permDenied) return permDenied;
|
|
891
965
|
let body;
|
|
892
966
|
try {
|
|
893
967
|
body = await request.json();
|
|
894
968
|
} catch {
|
|
895
969
|
const response2 = createApiError("Invalid JSON body", 400);
|
|
896
|
-
return addCorsHeaders(response2);
|
|
970
|
+
return addCorsHeaders(response2, request);
|
|
897
971
|
}
|
|
898
972
|
const { metas, ...entityData } = body;
|
|
899
973
|
const entityConfig = resolution.entityConfig;
|
|
@@ -906,7 +980,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
906
980
|
errors: validation.error.issues
|
|
907
981
|
});
|
|
908
982
|
const response2 = createApiError("Validation error", 400, validation.error.issues, "VALIDATION_ERROR");
|
|
909
|
-
return addCorsHeaders(response2);
|
|
983
|
+
return addCorsHeaders(response2, request);
|
|
910
984
|
}
|
|
911
985
|
const validatedData = validation.data;
|
|
912
986
|
const updates = [];
|
|
@@ -915,8 +989,10 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
915
989
|
const builderRequest = isBuilderRequest(request);
|
|
916
990
|
const entityHasBuilder = ((_a = entityConfig.builder) == null ? void 0 : _a.enabled) === true;
|
|
917
991
|
if (builderRequest && entityHasBuilder && "blocks" in entityData) {
|
|
992
|
+
let blocksData = entityData.blocks;
|
|
993
|
+
blocksData = await filterOrphanedPatternReferences(blocksData, authResult.user.id);
|
|
918
994
|
updates.push(`"blocks" = $${paramCount++}::jsonb`);
|
|
919
|
-
values.push(JSON.stringify(
|
|
995
|
+
values.push(JSON.stringify(blocksData));
|
|
920
996
|
}
|
|
921
997
|
const originalKeys = Object.keys(entityData);
|
|
922
998
|
const fieldsToUpdate = Object.entries(validatedData).filter(([key]) => originalKeys.includes(key));
|
|
@@ -924,7 +1000,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
924
1000
|
var _a2, _b2;
|
|
925
1001
|
if (key === "blocks") return;
|
|
926
1002
|
const field = entityConfig.fields.find((f) => f.name === key);
|
|
927
|
-
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)
|
|
1003
|
+
if (field && !((_a2 = field.api) == null ? void 0 : _a2.readOnly)) {
|
|
928
1004
|
const columnName = `"${key}"`;
|
|
929
1005
|
if (field.type === "relation") {
|
|
930
1006
|
let relationId = null;
|
|
@@ -972,7 +1048,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
972
1048
|
const metadataWasProvided = metas && typeof metas === "object" && Object.keys(metas).length > 0;
|
|
973
1049
|
if (updates.length === 0 && !metadataWasProvided) {
|
|
974
1050
|
const response2 = createApiError("No fields to update", 400);
|
|
975
|
-
return addCorsHeaders(response2);
|
|
1051
|
+
return addCorsHeaders(response2, request);
|
|
976
1052
|
}
|
|
977
1053
|
if (updates.length > 0) {
|
|
978
1054
|
updates.push(`"updatedAt" = CURRENT_TIMESTAMP`);
|
|
@@ -998,7 +1074,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
998
1074
|
const result = await mutateWithRLS(updateQuery, values, authResult.user.id);
|
|
999
1075
|
if (!result.rows || result.rows.length === 0) {
|
|
1000
1076
|
const response2 = createApiError("Item not found", 404);
|
|
1001
|
-
return addCorsHeaders(response2);
|
|
1077
|
+
return addCorsHeaders(response2, request);
|
|
1002
1078
|
}
|
|
1003
1079
|
updatedItem = result.rows[0];
|
|
1004
1080
|
} else {
|
|
@@ -1011,7 +1087,7 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
1011
1087
|
const result = await queryWithRLS(selectQuery, selectValues, authResult.user.id);
|
|
1012
1088
|
if (!result || result.length === 0) {
|
|
1013
1089
|
const response2 = createApiError("Item not found", 404);
|
|
1014
|
-
return addCorsHeaders(response2);
|
|
1090
|
+
return addCorsHeaders(response2, request);
|
|
1015
1091
|
}
|
|
1016
1092
|
updatedItem = result[0];
|
|
1017
1093
|
}
|
|
@@ -1047,25 +1123,36 @@ async function handleGenericUpdate(request, { params }) {
|
|
|
1047
1123
|
console.error(`[generic-handler] Error in afterEntityUpdate hook for ${entityConfig.slug}:`, hookError);
|
|
1048
1124
|
}
|
|
1049
1125
|
const response = createApiResponse(responseData);
|
|
1050
|
-
return addCorsHeaders(response);
|
|
1126
|
+
return addCorsHeaders(response, request);
|
|
1051
1127
|
} catch (error) {
|
|
1052
1128
|
console.error("Error in generic update handler:", error);
|
|
1129
|
+
if (error && typeof error === "object" && "code" in error && error.code === "23505") {
|
|
1130
|
+
const detail = "detail" in error ? error.detail : void 0;
|
|
1131
|
+
const constraint = "constraint" in error ? error.constraint : void 0;
|
|
1132
|
+
const response2 = createApiError(
|
|
1133
|
+
"A record with this value already exists",
|
|
1134
|
+
409,
|
|
1135
|
+
{ constraint, detail },
|
|
1136
|
+
"UNIQUE_CONSTRAINT_VIOLATION"
|
|
1137
|
+
);
|
|
1138
|
+
return addCorsHeaders(response2, request);
|
|
1139
|
+
}
|
|
1053
1140
|
const response = createApiError("Internal server error", 500);
|
|
1054
|
-
return addCorsHeaders(response);
|
|
1141
|
+
return addCorsHeaders(response, request);
|
|
1055
1142
|
}
|
|
1056
1143
|
}
|
|
1057
1144
|
async function handleGenericDelete(request, { params }) {
|
|
1058
|
-
var _a;
|
|
1145
|
+
var _a, _b, _c, _d, _e;
|
|
1059
1146
|
try {
|
|
1060
1147
|
const { id } = await params;
|
|
1061
1148
|
const resolution = await resolveEntityFromUrl(request.nextUrl.pathname);
|
|
1062
1149
|
if (!resolution.isValidEntity || !resolution.entityConfig) {
|
|
1063
1150
|
const response2 = createApiError("Entity not found", 404);
|
|
1064
|
-
return addCorsHeaders(response2);
|
|
1151
|
+
return addCorsHeaders(response2, request);
|
|
1065
1152
|
}
|
|
1066
1153
|
if (!validateEntityOperation(resolution.entityConfig, "delete")) {
|
|
1067
1154
|
const response2 = createApiError("Delete operation not supported for this entity", 405);
|
|
1068
|
-
return addCorsHeaders(response2);
|
|
1155
|
+
return addCorsHeaders(response2, request);
|
|
1069
1156
|
}
|
|
1070
1157
|
const authResult = await authenticateRequest(request);
|
|
1071
1158
|
if (!authResult.success) {
|
|
@@ -1079,7 +1166,7 @@ async function handleGenericDelete(request, { params }) {
|
|
|
1079
1166
|
}
|
|
1080
1167
|
if (!hasRequiredScope(authResult, `${resolution.entityConfig.slug}:write`)) {
|
|
1081
1168
|
const response2 = createApiError("Insufficient permissions", 403);
|
|
1082
|
-
return addCorsHeaders(response2);
|
|
1169
|
+
return addCorsHeaders(response2, request);
|
|
1083
1170
|
}
|
|
1084
1171
|
const teamValidation = await validateTeamContextWithBypass(request, authResult, authResult.user.id);
|
|
1085
1172
|
if (!teamValidation.valid) {
|
|
@@ -1088,8 +1175,10 @@ async function handleGenericDelete(request, { params }) {
|
|
|
1088
1175
|
const teamId = teamValidation.teamId;
|
|
1089
1176
|
if (!teamId) {
|
|
1090
1177
|
const response2 = createApiError("Team context required for delete operations. Include x-team-id header.", 400, void 0, "TEAM_CONTEXT_REQUIRED");
|
|
1091
|
-
return addCorsHeaders(response2);
|
|
1178
|
+
return addCorsHeaders(response2, request);
|
|
1092
1179
|
}
|
|
1180
|
+
const permDenied = await checkSessionPermission(authResult, resolution.entityConfig.slug, "delete", teamId, request);
|
|
1181
|
+
if (permDenied) return permDenied;
|
|
1093
1182
|
const entityConfig = resolution.entityConfig;
|
|
1094
1183
|
const tableName = getTableName(entityConfig);
|
|
1095
1184
|
const whereConditions = ["id = $1"];
|
|
@@ -1103,31 +1192,68 @@ async function handleGenericDelete(request, { params }) {
|
|
|
1103
1192
|
whereConditions.push(`"userId" = $${paramIndex++}`);
|
|
1104
1193
|
deleteParams.push(authResult.user.id);
|
|
1105
1194
|
}
|
|
1106
|
-
|
|
1107
|
-
|
|
1108
|
-
|
|
1109
|
-
|
|
1110
|
-
|
|
1195
|
+
let deleteQuery;
|
|
1196
|
+
if ((_b = entityConfig.table) == null ? void 0 : _b.softDelete) {
|
|
1197
|
+
whereConditions.push(`"deletedAt" IS NULL`);
|
|
1198
|
+
deleteQuery = `
|
|
1199
|
+
UPDATE "${tableName}"
|
|
1200
|
+
SET "deletedAt" = NOW(), "deletedBy" = $${paramIndex++}
|
|
1201
|
+
WHERE ${whereConditions.join(" AND ")}
|
|
1202
|
+
RETURNING id
|
|
1203
|
+
`;
|
|
1204
|
+
deleteParams.push(authResult.user.id);
|
|
1205
|
+
} else {
|
|
1206
|
+
deleteQuery = `
|
|
1207
|
+
DELETE FROM "${tableName}"
|
|
1208
|
+
WHERE ${whereConditions.join(" AND ")}
|
|
1209
|
+
RETURNING id
|
|
1210
|
+
`;
|
|
1211
|
+
}
|
|
1111
1212
|
const result = await mutateWithRLS(deleteQuery, deleteParams, authResult.user.id);
|
|
1112
1213
|
if (!result.rows || result.rows.length === 0) {
|
|
1113
1214
|
const response2 = createApiError("Item not found", 404);
|
|
1114
|
-
return addCorsHeaders(response2);
|
|
1215
|
+
return addCorsHeaders(response2, request);
|
|
1115
1216
|
}
|
|
1116
1217
|
try {
|
|
1117
1218
|
await afterEntityDelete(entityConfig.slug, id, authResult.user.id);
|
|
1118
1219
|
} catch (hookError) {
|
|
1119
1220
|
console.error(`[generic-handler] Error in afterEntityDelete hook for ${entityConfig.slug}:`, hookError);
|
|
1120
1221
|
}
|
|
1222
|
+
const deleteAction = `${entityConfig.slug}.create`;
|
|
1223
|
+
const deleteLimitSlug = (_e = (_d = (_c = BILLING_REGISTRY) == null ? void 0 : _c.actionMappings) == null ? void 0 : _d.limits) == null ? void 0 : _e[deleteAction];
|
|
1224
|
+
if (deleteLimitSlug) {
|
|
1225
|
+
UsageService.track({
|
|
1226
|
+
teamId,
|
|
1227
|
+
userId: authResult.user.id,
|
|
1228
|
+
limitSlug: deleteLimitSlug,
|
|
1229
|
+
delta: -1,
|
|
1230
|
+
action: `${entityConfig.slug}.delete`,
|
|
1231
|
+
resourceType: entityConfig.slug,
|
|
1232
|
+
resourceId: id
|
|
1233
|
+
}).catch(() => {
|
|
1234
|
+
});
|
|
1235
|
+
}
|
|
1121
1236
|
const response = createApiResponse({ success: true, id });
|
|
1122
|
-
return addCorsHeaders(response);
|
|
1237
|
+
return addCorsHeaders(response, request);
|
|
1123
1238
|
} catch (error) {
|
|
1124
1239
|
console.error("Error in generic delete handler:", error);
|
|
1240
|
+
if (error && typeof error === "object" && "code" in error && error.code === "23503") {
|
|
1241
|
+
const detail = "detail" in error ? error.detail : void 0;
|
|
1242
|
+
const constraint = "constraint" in error ? error.constraint : void 0;
|
|
1243
|
+
const response2 = createApiError(
|
|
1244
|
+
detail || "Cannot delete: this record is referenced by other records",
|
|
1245
|
+
409,
|
|
1246
|
+
{ constraint },
|
|
1247
|
+
"FOREIGN_KEY_VIOLATION"
|
|
1248
|
+
);
|
|
1249
|
+
return addCorsHeaders(response2, request);
|
|
1250
|
+
}
|
|
1125
1251
|
const response = createApiError("Internal server error", 500);
|
|
1126
|
-
return addCorsHeaders(response);
|
|
1252
|
+
return addCorsHeaders(response, request);
|
|
1127
1253
|
}
|
|
1128
1254
|
}
|
|
1129
|
-
async function handleGenericOptions() {
|
|
1130
|
-
return handleCorsPreflightRequest();
|
|
1255
|
+
async function handleGenericOptions(request) {
|
|
1256
|
+
return handleCorsPreflightRequest(request);
|
|
1131
1257
|
}
|
|
1132
1258
|
async function handleDistinctJsonbField(entityConfig, fieldName, url, userId) {
|
|
1133
1259
|
var _a;
|