@nextsparkjs/core 0.1.0-beta.8 → 0.1.0-beta.81
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.js +2 -2
- package/dist/components/app/layouts/PublicNavbar.js +4 -4
- 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 +16 -41
- package/dist/components/auth/forms/SignupForm.d.ts.map +1 -1
- package/dist/components/auth/forms/SignupForm.js +17 -28
- 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/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.js +2 -2
- package/dist/components/billing/PricingTable.js +5 -5
- 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.js +11 -11
- package/dist/components/dashboard/block-editor/array-field.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/array-field.js +21 -20
- package/dist/components/dashboard/block-editor/block-canvas.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-canvas.js +4 -3
- package/dist/components/dashboard/block-editor/block-picker.d.ts +14 -2
- package/dist/components/dashboard/block-editor/block-picker.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-picker.js +304 -80
- package/dist/components/dashboard/block-editor/block-preview-canvas.d.ts +3 -1
- package/dist/components/dashboard/block-editor/block-preview-canvas.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-preview-canvas.js +134 -34
- package/dist/components/dashboard/block-editor/block-settings-panel.d.ts +4 -2
- package/dist/components/dashboard/block-editor/block-settings-panel.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/block-settings-panel.js +152 -71
- package/dist/components/dashboard/block-editor/builder-editor-view.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/builder-editor-view.js +388 -176
- package/dist/components/dashboard/block-editor/category-helpers.d.ts +62 -0
- package/dist/components/dashboard/block-editor/category-helpers.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/category-helpers.js +59 -0
- package/dist/components/dashboard/block-editor/config-panel.d.ts +18 -0
- package/dist/components/dashboard/block-editor/config-panel.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/config-panel.js +444 -0
- package/dist/components/dashboard/block-editor/dynamic-form.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/dynamic-form.js +31 -30
- package/dist/components/dashboard/block-editor/entity-fields-sidebar.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/entity-fields-sidebar.js +16 -13
- package/dist/components/dashboard/block-editor/floating-block-toolbar.d.ts +14 -0
- package/dist/components/dashboard/block-editor/floating-block-toolbar.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/floating-block-toolbar.js +83 -0
- package/dist/components/dashboard/block-editor/page-settings-panel.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/page-settings-panel.js +18 -17
- package/dist/components/dashboard/block-editor/pattern-card.d.ts +8 -0
- package/dist/components/dashboard/block-editor/pattern-card.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/pattern-card.js +74 -0
- package/dist/components/dashboard/block-editor/pattern-reference-preview.d.ts +10 -0
- package/dist/components/dashboard/block-editor/pattern-reference-preview.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/pattern-reference-preview.js +187 -0
- package/dist/components/dashboard/block-editor/sortable-block.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/sortable-block.js +11 -10
- package/dist/components/dashboard/block-editor/status-selector.d.ts.map +1 -1
- package/dist/components/dashboard/block-editor/status-selector.js +4 -3
- package/dist/components/dashboard/block-editor/tree-view-node.d.ts +11 -0
- package/dist/components/dashboard/block-editor/tree-view-node.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/tree-view-node.js +91 -0
- package/dist/components/dashboard/block-editor/tree-view.d.ts +17 -0
- package/dist/components/dashboard/block-editor/tree-view.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/tree-view.js +125 -0
- package/dist/components/dashboard/block-editor/viewport-toggle.d.ts +10 -0
- package/dist/components/dashboard/block-editor/viewport-toggle.d.ts.map +1 -0
- package/dist/components/dashboard/block-editor/viewport-toggle.js +55 -0
- package/dist/components/dashboard/index.js +2 -2
- package/dist/components/dashboard/layouts/AuthGuard.js +3 -3
- package/dist/components/dashboard/layouts/DashboardShell.d.ts +1 -1
- package/dist/components/dashboard/layouts/DashboardShell.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/DashboardShell.js +16 -7
- package/dist/components/dashboard/layouts/Sidebar.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/Sidebar.js +10 -25
- package/dist/components/dashboard/layouts/TopNavbar.d.ts.map +1 -1
- package/dist/components/dashboard/layouts/TopNavbar.js +89 -77
- package/dist/components/dashboard/layouts/index.js +4 -4
- package/dist/components/dashboard/misc/NotificationsDropdown.d.ts.map +1 -1
- package/dist/components/dashboard/misc/NotificationsDropdown.js +8 -20
- package/dist/components/dashboard/misc/QuickCreateDropdown.d.ts.map +1 -1
- package/dist/components/dashboard/misc/QuickCreateDropdown.js +7 -10
- package/dist/components/dashboard/misc/SearchDropdown.d.ts.map +1 -1
- package/dist/components/dashboard/misc/SearchDropdown.js +11 -19
- package/dist/components/dashboard/mobile/MobileBottomNav.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/MobileBottomNav.js +10 -14
- package/dist/components/dashboard/mobile/MobileMoreSheet.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/MobileMoreSheet.js +14 -25
- package/dist/components/dashboard/mobile/MobileTopBar.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/MobileTopBar.js +10 -28
- package/dist/components/dashboard/mobile/QuickCreateSheet.d.ts.map +1 -1
- package/dist/components/dashboard/mobile/QuickCreateSheet.js +5 -7
- package/dist/components/dashboard/mobile/index.js +4 -4
- package/dist/components/dashboard/navigation/DynamicNavigation.d.ts.map +1 -1
- package/dist/components/dashboard/navigation/DynamicNavigation.js +27 -14
- 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.map +1 -1
- package/dist/components/devtools/DevtoolsSidebar.js +10 -3
- 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.js +4 -4
- package/dist/components/devtools/scheduled-actions/filters.js +3 -3
- 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.js +29 -29
- package/dist/components/entities/EntityForm.d.ts.map +1 -1
- package/dist/components/entities/EntityForm.js +16 -16
- package/dist/components/entities/EntityList.d.ts.map +1 -1
- package/dist/components/entities/EntityList.js +19 -37
- package/dist/components/entities/EntityNavigation.js +6 -6
- package/dist/components/entities/EntityPageHeader.js +1 -1
- package/dist/components/entities/EntitySearch.d.ts.map +1 -1
- package/dist/components/entities/EntitySearch.js +16 -29
- package/dist/components/entities/EntityTable.d.ts.map +1 -1
- package/dist/components/entities/EntityTable.js +42 -41
- package/dist/components/entities/ErrorBoundary.js +3 -3
- package/dist/components/entities/index.js +15 -15
- package/dist/components/entities/wrappers/EntityDetailWrapper.js +6 -6
- package/dist/components/entities/wrappers/EntityFormWrapper.js +7 -7
- package/dist/components/entities/wrappers/EntityListWrapper.js +18 -18
- package/dist/components/entities/wrappers/index.js +3 -3
- package/dist/components/patterns/DeletedPatternPlaceholder.d.ts +33 -0
- package/dist/components/patterns/DeletedPatternPlaceholder.d.ts.map +1 -0
- package/dist/components/patterns/DeletedPatternPlaceholder.js +44 -0
- package/dist/components/patterns/PatternDeleteDialog.d.ts +41 -0
- package/dist/components/patterns/PatternDeleteDialog.d.ts.map +1 -0
- package/dist/components/patterns/PatternDeleteDialog.js +148 -0
- package/dist/components/patterns/PatternUsageReport.d.ts +15 -0
- package/dist/components/patterns/PatternUsageReport.d.ts.map +1 -0
- package/dist/components/patterns/PatternUsageReport.js +134 -0
- package/dist/components/patterns/PatternUsageStats.d.ts +14 -0
- package/dist/components/patterns/PatternUsageStats.d.ts.map +1 -0
- package/dist/components/patterns/PatternUsageStats.js +63 -0
- package/dist/components/patterns/PatternUsageTable.d.ts +15 -0
- package/dist/components/patterns/PatternUsageTable.d.ts.map +1 -0
- package/dist/components/patterns/PatternUsageTable.js +134 -0
- package/dist/components/patterns/index.d.ts +11 -0
- package/dist/components/patterns/index.d.ts.map +1 -0
- package/dist/components/patterns/index.js +12 -0
- package/dist/components/patterns/pages/PatternEditPage.d.ts +8 -0
- package/dist/components/patterns/pages/PatternEditPage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternEditPage.js +80 -0
- package/dist/components/patterns/pages/PatternReportsPage.d.ts +9 -0
- package/dist/components/patterns/pages/PatternReportsPage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternReportsPage.js +133 -0
- package/dist/components/patterns/pages/PatternsCreatePage.d.ts +8 -0
- package/dist/components/patterns/pages/PatternsCreatePage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternsCreatePage.js +49 -0
- package/dist/components/patterns/pages/PatternsListPage.d.ts +8 -0
- package/dist/components/patterns/pages/PatternsListPage.d.ts.map +1 -0
- package/dist/components/patterns/pages/PatternsListPage.js +336 -0
- package/dist/components/patterns/pages/index.d.ts +11 -0
- package/dist/components/patterns/pages/index.d.ts.map +1 -0
- package/dist/components/patterns/pages/index.js +10 -0
- package/dist/components/permissions/NoPermission.js +2 -2
- package/dist/components/permissions/PermissionGate.js +1 -1
- package/dist/components/permissions/PermissionsMatrix.js +4 -4
- package/dist/components/permissions/index.js +3 -3
- package/dist/components/public/entities/PublicEntityCard.js +2 -2
- package/dist/components/public/entities/PublicEntityDetail.js +9 -9
- package/dist/components/public/entities/PublicEntityGrid.js +9 -9
- package/dist/components/public/entities/index.js +3 -3
- package/dist/components/public/index.js +2 -2
- package/dist/components/public/pageBuilder/PageRenderer.d.ts.map +1 -1
- package/dist/components/public/pageBuilder/PageRenderer.js +11 -2
- package/dist/components/public/pageBuilder/index.js +1 -1
- package/dist/components/settings/SettingsPageSkeleton.js +2 -2
- package/dist/components/settings/index.js +2 -2
- package/dist/components/settings/layouts/SettingsSidebar.d.ts.map +1 -1
- package/dist/components/settings/layouts/SettingsSidebar.js +22 -17
- package/dist/components/settings/layouts/index.js +1 -1
- package/dist/components/shared/CopyableId.js +2 -2
- package/dist/components/shared/MultiSelectFilter.js +3 -3
- package/dist/components/shared/SearchInput.js +2 -2
- package/dist/components/shared/index.js +3 -3
- package/dist/components/superadmin/filters/FilterDropdown.js +2 -2
- package/dist/components/superadmin/filters/PaginationControls.d.ts +3 -1
- package/dist/components/superadmin/filters/PaginationControls.d.ts.map +1 -1
- package/dist/components/superadmin/filters/PaginationControls.js +10 -9
- package/dist/components/superadmin/filters/SearchInput.js +3 -3
- package/dist/components/superadmin/filters/index.js +3 -3
- package/dist/components/superadmin/index.js +8 -8
- package/dist/components/superadmin/layouts/SuperadminSidebar.d.ts.map +1 -1
- package/dist/components/superadmin/layouts/SuperadminSidebar.js +14 -6
- 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 +7 -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 +6 -41
- 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 +8 -39
- 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 +1 -22
- 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 +1 -46
- 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 +8 -53
- 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 +1 -25
- 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 +1 -20
- 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 +1 -20
- 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.js +3 -3
- 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 +1 -23
- 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 +1 -22
- package/dist/components/ui/sheet.js +1 -1
- package/dist/components/ui/simple-relation-select.js +4 -4
- 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 +8 -15
- 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 +1 -20
- 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 +1 -25
- 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 +6 -41
- 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 +1 -17
- package/dist/components/ui/timezone-select.js +2 -2
- 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.js +1 -1
- package/dist/contexts/TeamContext.d.ts +2 -0
- package/dist/contexts/TeamContext.d.ts.map +1 -1
- package/dist/contexts/TeamContext.js +86 -74
- package/dist/contexts/index.js +3 -3
- package/dist/contexts/sidebar-context.js +1 -1
- package/dist/entities/index.d.ts +9 -0
- package/dist/entities/index.d.ts.map +1 -0
- package/dist/entities/index.js +12 -0
- package/dist/entities/patterns/index.d.ts +11 -0
- package/dist/entities/patterns/index.d.ts.map +1 -0
- package/dist/entities/patterns/index.js +10 -0
- package/dist/entities/patterns/messages/de.json +76 -0
- package/dist/entities/patterns/messages/en.json +87 -0
- package/dist/entities/patterns/messages/es.json +86 -0
- package/dist/entities/patterns/messages/fr.json +76 -0
- package/dist/entities/patterns/messages/it.json +76 -0
- package/dist/entities/patterns/messages/pt.json +76 -0
- package/dist/entities/patterns/patterns.config.d.ts +9 -0
- package/dist/entities/patterns/patterns.config.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.config.js +81 -0
- package/dist/entities/patterns/patterns.fields.d.ts +12 -0
- package/dist/entities/patterns/patterns.fields.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.fields.js +95 -0
- package/dist/entities/patterns/patterns.service.d.ts +135 -0
- package/dist/entities/patterns/patterns.service.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.service.js +581 -0
- package/dist/entities/patterns/patterns.types.d.ts +102 -0
- package/dist/entities/patterns/patterns.types.d.ts.map +1 -0
- package/dist/entities/patterns/patterns.types.js +6 -0
- package/dist/hooks/index.d.ts +2 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +41 -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 +3 -3
- 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.js +1 -1
- package/dist/hooks/useEntity.js +2 -2
- package/dist/hooks/useEntityConfig.js +1 -1
- package/dist/hooks/useEntityMutations.js +1 -1
- package/dist/hooks/useEntityQuery.js +1 -1
- 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/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/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.js +1 -1
- 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 +24 -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/auth/dual-auth.js +3 -3
- package/dist/lib/api/auth/permissions.js +1 -1
- package/dist/lib/api/auth.js +3 -3
- package/dist/lib/api/distributed-cache.d.ts +122 -0
- package/dist/lib/api/distributed-cache.d.ts.map +1 -0
- package/dist/lib/api/distributed-cache.js +306 -0
- package/dist/lib/api/entity/generic-handler.d.ts +1 -1
- package/dist/lib/api/entity/generic-handler.d.ts.map +1 -1
- package/dist/lib/api/entity/generic-handler.js +103 -147
- 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 +2 -0
- package/dist/lib/api/index.d.ts.map +1 -1
- package/dist/lib/api/index.js +7 -5
- package/dist/lib/api/meta.middleware.js +2 -2
- package/dist/lib/api/permission-middleware.js +1 -1
- 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 +134 -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.d.ts.map +1 -1
- package/dist/lib/auth.js +10 -20
- package/dist/lib/billing/enforcement.js +1 -1
- package/dist/lib/billing/jobs.js +1 -1
- package/dist/lib/billing/schema.d.ts +3 -3
- 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/config-loader.js +1 -1
- package/dist/lib/config/config-sync.d.ts.map +1 -1
- package/dist/lib/config/config-sync.js +42 -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 +14 -19
- package/dist/lib/config/types.d.ts.map +1 -1
- package/dist/lib/db.d.ts +66 -0
- package/dist/lib/db.d.ts.map +1 -1
- package/dist/lib/db.js +179 -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.js +2 -2
- package/dist/lib/email/index.d.js +3 -3
- package/dist/lib/email/index.js +3 -3
- package/dist/lib/entities/api-generator.js +3 -3
- package/dist/lib/entities/entity-hooks.d.ts.map +1 -1
- package/dist/lib/entities/entity-hooks.js +4 -9
- package/dist/lib/entities/external-api-generator.js +4 -4
- package/dist/lib/entities/helpers.js +1 -1
- package/dist/lib/entities/meta-adapter.js +5 -5
- package/dist/lib/entities/migration-helper.d.ts.map +1 -1
- package/dist/lib/entities/migration-helper.js +1 -20
- package/dist/lib/entities/pattern-usage-hooks.d.ts +31 -0
- package/dist/lib/entities/pattern-usage-hooks.d.ts.map +1 -0
- package/dist/lib/entities/pattern-usage-hooks.js +96 -0
- package/dist/lib/entities/queries.d.ts +47 -7
- package/dist/lib/entities/queries.d.ts.map +1 -1
- package/dist/lib/entities/queries.js +34 -10
- package/dist/lib/entities/query-generator.js +6 -6
- package/dist/lib/entities/registry.client.d.ts +1 -1
- package/dist/lib/entities/registry.client.d.ts.map +1 -1
- package/dist/lib/entities/registry.client.js +3 -22
- package/dist/lib/entities/registry.d.ts +25 -13
- package/dist/lib/entities/registry.d.ts.map +1 -1
- package/dist/lib/entities/registry.js +50 -63
- package/dist/lib/entities/testing.d.ts.map +1 -1
- package/dist/lib/entities/testing.js +3 -11
- package/dist/lib/entities/types.d.ts +6 -52
- 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/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.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/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 +157 -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/processor.js +4 -4
- package/dist/lib/scheduled-actions/scheduler.js +2 -2
- package/dist/lib/selectors/core-selectors.d.ts +1487 -0
- package/dist/lib/selectors/core-selectors.d.ts.map +1 -0
- package/dist/lib/selectors/core-selectors.js +32 -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 +287 -0
- package/dist/lib/selectors/domains/block-editor.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/block-editor.selectors.js +306 -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 +241 -0
- package/dist/lib/selectors/domains/devtools.selectors.d.ts.map +1 -0
- package/dist/lib/selectors/domains/devtools.selectors.js +236 -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 +19 -0
- package/dist/lib/selectors/domains/index.d.ts.map +1 -0
- package/dist/lib/selectors/domains/index.js +28 -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 +2967 -0
- package/dist/lib/selectors/selectors.d.ts.map +1 -0
- package/dist/lib/{test → selectors}/selectors.js +2 -2
- 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 +8 -2
- package/dist/lib/services/index.d.ts.map +1 -1
- package/dist/lib/services/index.js +51 -18
- package/dist/lib/services/invoice.service.js +1 -1
- package/dist/lib/services/membership.service.js +5 -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.js +1 -1
- 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.js +7 -7
- package/dist/lib/services/team-member.service.js +2 -2
- package/dist/lib/services/team.service.js +1 -1
- 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/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 +39 -4
- package/dist/lib/teams/schema.d.ts.map +1 -1
- package/dist/lib/teams/schema.js +13 -3
- 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 +49 -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.js +2 -2
- package/dist/lib/theme/theme-loader.js +2 -2
- package/dist/lib/translations/i18n-integration.js +4 -4
- package/dist/lib/translations/registry.d.ts +2 -0
- package/dist/lib/translations/registry.d.ts.map +1 -1
- package/dist/lib/translations/registry.js +31 -3
- package/dist/lib/user-data.d.ts +18 -0
- package/dist/lib/user-data.d.ts.map +1 -1
- package/dist/lib/user-data.js +128 -18
- package/dist/lib/utils/cors.d.ts +71 -0
- package/dist/lib/utils/cors.d.ts.map +1 -0
- package/dist/lib/utils/cors.js +64 -0
- package/dist/lib/utils/index.d.ts +9 -0
- package/dist/lib/utils/index.d.ts.map +1 -0
- package/dist/lib/utils/index.js +9 -0
- package/dist/messages/de/common.json +3 -1
- package/dist/messages/de/devtools.json +26 -1
- package/dist/messages/de/docs.json +5 -1
- package/dist/messages/de/features.json +8 -0
- package/dist/messages/de/index.d.ts +150 -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/teams.json +67 -3
- package/dist/messages/en/admin.json +92 -2
- package/dist/messages/en/common.json +3 -1
- package/dist/messages/en/devtools.json +40 -1
- package/dist/messages/en/docs.json +5 -1
- package/dist/messages/en/features.json +8 -0
- package/dist/messages/en/index.d.ts +266 -1
- package/dist/messages/en/index.d.ts.map +1 -1
- package/dist/messages/en/index.js +2 -0
- package/dist/messages/en/index.ts +2 -0
- package/dist/messages/en/patterns.json +87 -0
- package/dist/messages/en/settings.json +1 -0
- package/dist/messages/en/teams.json +67 -3
- package/dist/messages/es/admin.json +92 -2
- package/dist/messages/es/common.json +3 -1
- package/dist/messages/es/devtools.json +28 -1
- package/dist/messages/es/docs.json +5 -1
- package/dist/messages/es/features.json +8 -0
- package/dist/messages/es/index.d.ts +231 -1
- package/dist/messages/es/index.d.ts.map +1 -1
- package/dist/messages/es/index.js +2 -0
- package/dist/messages/es/index.ts +2 -0
- package/dist/messages/es/patterns.json +87 -0
- package/dist/messages/es/settings.json +1 -0
- package/dist/messages/es/teams.json +23 -3
- package/dist/messages/fr/common.json +3 -1
- package/dist/messages/fr/devtools.json +26 -1
- package/dist/messages/fr/docs.json +5 -1
- package/dist/messages/fr/features.json +8 -0
- package/dist/messages/fr/index.d.ts +150 -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/teams.json +67 -3
- package/dist/messages/index.js +7 -7
- package/dist/messages/it/common.json +3 -1
- package/dist/messages/it/devtools.json +26 -1
- package/dist/messages/it/docs.json +5 -1
- package/dist/messages/it/features.json +8 -0
- package/dist/messages/it/index.d.ts +150 -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/teams.json +67 -3
- package/dist/messages/pt/common.json +3 -1
- package/dist/messages/pt/devtools.json +26 -1
- package/dist/messages/pt/docs.json +5 -1
- package/dist/messages/pt/features.json +8 -0
- package/dist/messages/pt/index.d.ts +150 -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/teams.json +67 -3
- package/dist/migrations/001_better_auth_and_functions.sql +18 -0
- package/dist/migrations/010_teams_functions_triggers.sql +36 -6
- package/dist/migrations/018_patterns_table.sql +104 -0
- package/dist/migrations/019_pattern_usages_table.sql +74 -0
- package/dist/nextspark-entities.d.ts +59 -0
- package/dist/presets/blocks/cta-section/component.tsx +4 -4
- package/dist/presets/blocks/features-grid/component.tsx +5 -5
- package/dist/presets/blocks/hero/component.tsx +2 -2
- package/dist/presets/blocks/testimonials/component.tsx +4 -4
- package/dist/presets/blocks/text-content/component.tsx +2 -2
- package/dist/presets/theme/blocks/hero/component.tsx +2 -2
- package/dist/presets/theme/entities/tasks/tasks.config.ts +3 -13
- package/dist/presets/theme/tests/cypress/src/core/BlockEditorBasePOM.ts +368 -99
- package/dist/presets/theme/tests/cypress/src/session-helpers.ts +27 -10
- package/dist/presets/theme/tests/cypress.config.ts +19 -5
- package/dist/providers/TranslationContextManager.js +1 -1
- package/dist/providers/index.js +4 -4
- package/dist/styles/classes.json +73 -33
- package/dist/styles/ui.css +1 -1
- package/dist/templates/ai-workflow/claude/config/context.json +54 -0
- package/dist/templates/app/(auth)/accept-invite/[token]/page.tsx +335 -0
- package/dist/templates/app/(auth)/forgot-password/page.tsx +1 -1
- package/dist/templates/app/(auth)/reset-password/page.tsx +9 -9
- package/dist/templates/app/(auth)/verify-email/page.tsx +7 -7
- package/dist/templates/app/(public)/[...slug]/page.tsx +113 -7
- package/dist/templates/app/(public)/docs/[section]/[page]/page.tsx +90 -0
- package/dist/templates/app/(public)/docs/layout.tsx +25 -0
- package/dist/templates/app/(public)/docs/page.tsx +81 -0
- package/dist/templates/app/api/auth/[...all]/route.ts +13 -5
- package/dist/templates/app/api/csp-report/route.ts +175 -0
- package/dist/templates/app/api/devtools/config/entities/route.ts +4 -13
- package/dist/templates/app/api/devtools/config/theme/route.ts +2 -2
- package/dist/templates/app/api/devtools/tests/[...path]/route.ts +2 -2
- package/dist/templates/app/api/devtools/tests/route.ts +2 -2
- package/dist/templates/app/api/superadmin/subscriptions/route.ts +4 -2
- package/dist/templates/app/api/superadmin/teams/[teamId]/route.ts +4 -2
- package/dist/templates/app/api/superadmin/teams/route.ts +4 -2
- package/dist/templates/app/api/superadmin/users/[userId]/route.ts +10 -4
- package/dist/templates/app/api/superadmin/users/route.ts +4 -2
- package/dist/templates/app/api/user/plan-flags/route.ts +10 -4
- package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +12 -4
- package/dist/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +13 -5
- package/dist/templates/app/api/v1/[entity]/[id]/route.ts +16 -7
- 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 -6
- 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/auth/docs.md +184 -0
- package/dist/templates/app/api/v1/auth/presets.ts +44 -0
- package/dist/templates/app/api/v1/billing/docs.md +209 -0
- package/dist/templates/app/api/v1/billing/presets.ts +121 -0
- 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/cron/docs.md +116 -0
- package/dist/templates/app/api/v1/cron/presets.ts +26 -0
- package/dist/templates/app/api/v1/devtools/docs/route.ts +150 -0
- package/dist/templates/app/api/v1/devtools/docs.md +204 -0
- package/dist/templates/app/api/v1/devtools/presets.ts +113 -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/patterns/[id]/usages/route.ts +116 -0
- 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/post-categories/docs.md +134 -0
- package/dist/templates/app/api/v1/post-categories/presets.ts +78 -0
- 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/teams/[teamId]/route.ts +52 -24
- 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 +11 -11
- 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/users/docs.md +93 -0
- package/dist/templates/app/api/v1/users/presets.ts +59 -0
- package/dist/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +11 -8
- package/dist/templates/app/dashboard/(main)/[entity]/page.tsx +6 -1
- package/dist/templates/app/dashboard/(main)/layout.tsx +72 -13
- package/dist/templates/app/dashboard/(main)/loading.tsx +5 -0
- package/dist/templates/app/dashboard/(main)/page.tsx +1 -3
- package/dist/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +114 -0
- package/dist/templates/app/dashboard/(main)/patterns/[id]/page.tsx +20 -0
- package/dist/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +171 -0
- package/dist/templates/app/dashboard/(main)/patterns/create/page.tsx +86 -0
- package/dist/templates/app/dashboard/(main)/patterns/page.tsx +444 -0
- package/dist/templates/app/dashboard/features/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/api-keys/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/api-keys/page.tsx +75 -75
- package/dist/templates/app/dashboard/settings/billing/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/billing/page.tsx +11 -22
- package/dist/templates/app/dashboard/settings/invoices/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/layout.tsx +8 -18
- package/dist/templates/app/dashboard/settings/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/notifications/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/notifications/page.tsx +17 -38
- package/dist/templates/app/dashboard/settings/page.tsx +3 -7
- package/dist/templates/app/dashboard/settings/password/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/password/page.tsx +25 -49
- package/dist/templates/app/dashboard/settings/plans/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/profile/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/profile/page.tsx +25 -62
- package/dist/templates/app/dashboard/settings/security/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/security/page.tsx +17 -53
- package/dist/templates/app/dashboard/settings/teams/loading.tsx +5 -0
- package/dist/templates/app/dashboard/settings/teams/page.tsx +30 -31
- 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/scheduled-actions/page.tsx +1 -1
- package/dist/templates/app/globals.css +7 -312
- package/dist/templates/app/layout.tsx +7 -1
- package/dist/templates/app/superadmin/docs/[section]/[page]/page.tsx +92 -0
- package/dist/templates/app/superadmin/docs/page.tsx +75 -0
- package/dist/templates/app/superadmin/page.tsx +1 -1
- package/dist/templates/app/superadmin/subscriptions/page.tsx +5 -4
- package/dist/templates/app/superadmin/teams/page.tsx +37 -84
- package/dist/templates/app/superadmin/users/page.tsx +4 -2
- package/dist/templates/contents/themes/starter/config/app.config.ts +22 -18
- package/dist/templates/contents/themes/starter/config/dev.config.ts +9 -28
- package/dist/templates/contents/themes/starter/config/features.config.ts +156 -0
- package/dist/templates/contents/themes/starter/config/permissions.config.ts +39 -0
- package/dist/templates/contents/themes/starter/docs/superadmin/01-setup/01-configuration.md +31 -0
- package/dist/templates/contents/themes/starter/docs/superadmin/02-entities/01-tasks.md +176 -0
- package/dist/templates/contents/themes/starter/entities/pages/api/docs.md +120 -0
- package/dist/templates/contents/themes/starter/entities/pages/api/presets.ts +72 -0
- package/dist/templates/contents/themes/starter/entities/pages/messages/en.json +41 -0
- package/dist/templates/contents/themes/starter/entities/pages/messages/es.json +41 -0
- package/dist/templates/contents/themes/starter/entities/pages/migrations/001_pages_table.sql +112 -0
- package/dist/templates/contents/themes/starter/entities/pages/migrations/002_pages_metas.sql +56 -0
- package/dist/templates/contents/themes/starter/entities/pages/migrations/003_add_status.sql +50 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages-management.service.ts +610 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.config.ts +95 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.fields.ts +101 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.service.ts +290 -0
- package/dist/templates/contents/themes/starter/entities/pages/pages.types.ts +124 -0
- package/dist/templates/contents/themes/starter/entities/posts/api/docs.md +127 -0
- package/dist/templates/contents/themes/starter/entities/posts/api/presets.ts +74 -0
- package/dist/templates/contents/themes/starter/entities/posts/components/post-header.tsx +97 -0
- package/dist/templates/contents/themes/starter/entities/posts/messages/en.json +55 -0
- package/dist/templates/contents/themes/starter/entities/posts/messages/es.json +55 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/001_posts_table.sql +115 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/003_add_status.sql +44 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/004_entity_taxonomy_relations.sql +129 -0
- package/dist/templates/contents/themes/starter/entities/posts/migrations/006_posts_metas.sql +56 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.config.ts +102 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.fields.ts +116 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.service.ts +376 -0
- package/dist/templates/contents/themes/starter/entities/posts/posts.types.ts +74 -0
- package/dist/templates/contents/themes/starter/entities/tasks/api/docs.md +132 -0
- package/dist/templates/contents/themes/starter/entities/tasks/api/presets.ts +84 -0
- package/dist/templates/contents/themes/starter/entities/tasks/tasks.config.ts +2 -43
- package/dist/templates/contents/themes/starter/entities/tasks/tasks.service.ts +0 -5
- package/dist/templates/contents/themes/starter/lib/selectors.ts +2 -2
- package/dist/templates/contents/themes/starter/messages/de/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/de/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/de/index.ts +15 -0
- package/dist/templates/contents/themes/starter/messages/en/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/en/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/en/index.ts +15 -0
- package/dist/templates/contents/themes/starter/messages/es/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/es/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/es/index.ts +15 -0
- package/dist/templates/contents/themes/starter/messages/fr/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/fr/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/fr/index.ts +15 -0
- package/dist/templates/contents/themes/starter/messages/it/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/it/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/it/index.ts +13 -0
- package/dist/templates/contents/themes/starter/messages/pt/common.json +4 -1
- package/dist/templates/contents/themes/starter/messages/pt/features.json +8 -0
- package/dist/templates/contents/themes/starter/messages/pt/index.ts +13 -0
- package/dist/templates/contents/themes/starter/styles/globals.css +183 -7
- package/dist/templates/contents/themes/starter/templates/(dashboard)/analytics/loading.tsx +5 -0
- package/dist/templates/contents/themes/starter/templates/(public)/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/{templates/contents/themes/starter/tests/cypress/e2e → dist/templates/contents/themes/starter/tests/cypress/e2e/uat/entities}/tasks/tasks-crud.cy.ts +24 -16
- 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/BlockEditorBasePOM.ts +576 -0
- 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/{e2e/tasks → src/entities}/TasksPOM.ts +1 -1
- 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/{contents/themes/starter → features/pages}/blocks/hero/component.tsx +2 -2
- package/dist/templates/features/pages/entities/pages/pages.config.ts +1 -0
- package/dist/templates/next.config.mjs +132 -2
- 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 +6 -0
- package/dist/types/blocks.d.ts.map +1 -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/user.types.js +1 -1
- package/globals.css +54 -0
- package/migrations/001_better_auth_and_functions.sql +18 -0
- package/migrations/010_teams_functions_triggers.sql +36 -6
- package/migrations/018_patterns_table.sql +104 -0
- package/migrations/019_pattern_usages_table.sql +74 -0
- package/nextspark-entities.d.ts +59 -0
- package/package.json +134 -28
- package/scripts/build/docs-registry.mjs +94 -148
- package/scripts/build/registry/config.mjs +41 -5
- package/scripts/build/registry/discovery/api-presets.mjs +647 -0
- package/scripts/build/registry/discovery/blocks.mjs +8 -0
- package/scripts/build/registry/discovery/core-entities.mjs +166 -0
- package/scripts/build/registry/discovery/index.mjs +2 -0
- package/scripts/build/registry/discovery/permissions.mjs +13 -1
- package/scripts/build/registry/discovery/permissions.test.mjs +256 -0
- package/scripts/build/registry/generators/api-presets-registry.mjs +410 -0
- package/scripts/build/registry/generators/block-registry.mjs +18 -3
- package/scripts/build/registry/generators/docs-registry.mjs +241 -0
- package/scripts/build/registry/generators/entity-registry.mjs +2 -0
- package/scripts/build/registry/generators/index.mjs +2 -1
- package/scripts/build/registry/generators/namespace-registry.mjs +2 -2
- package/scripts/build/registry/generators/permissions-registry.mjs +69 -102
- package/scripts/build/registry/generators/translation-registry.mjs +16 -7
- package/scripts/build/registry/generators/unified-registry.mjs +1 -0
- package/scripts/build/registry/index.mjs +0 -1
- package/scripts/build/registry/post-build/tree-display.mjs +21 -1
- package/scripts/build/registry.mjs +31 -15
- package/scripts/build/theme.mjs +124 -40
- package/scripts/create-theme.mjs +0 -0
- package/scripts/deploy/release-version.mjs +0 -0
- package/scripts/deploy/vercel-deploy.mjs +0 -0
- package/scripts/dev/watch-plugins.mjs +0 -0
- package/scripts/maintenance/update-core.mjs +0 -0
- package/scripts/postinstall.mjs +163 -0
- package/scripts/setup/npm-postinstall.mjs +0 -0
- package/scripts/setup/postinstall.mjs +0 -2
- package/scripts/setup/setup-claude.mjs +0 -0
- 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/ai-workflow/claude/config/context.json +54 -0
- package/templates/app/(auth)/accept-invite/[token]/page.tsx +335 -0
- package/templates/app/(auth)/forgot-password/page.tsx +1 -1
- package/templates/app/(auth)/reset-password/page.tsx +9 -9
- package/templates/app/(auth)/verify-email/page.tsx +7 -7
- package/templates/app/(public)/[...slug]/page.tsx +113 -7
- package/templates/app/(public)/docs/[section]/[page]/page.tsx +90 -0
- package/templates/app/(public)/docs/layout.tsx +25 -0
- package/templates/app/(public)/docs/page.tsx +81 -0
- package/templates/app/api/auth/[...all]/route.ts +13 -5
- package/templates/app/api/csp-report/route.ts +175 -0
- package/templates/app/api/devtools/config/entities/route.ts +4 -13
- package/templates/app/api/devtools/config/theme/route.ts +2 -2
- package/templates/app/api/devtools/tests/[...path]/route.ts +2 -2
- package/templates/app/api/devtools/tests/route.ts +2 -2
- package/templates/app/api/superadmin/subscriptions/route.ts +4 -2
- package/templates/app/api/superadmin/teams/[teamId]/route.ts +4 -2
- package/templates/app/api/superadmin/teams/route.ts +4 -2
- package/templates/app/api/superadmin/users/[userId]/route.ts +10 -4
- package/templates/app/api/superadmin/users/route.ts +4 -2
- package/templates/app/api/user/plan-flags/route.ts +10 -4
- package/templates/app/api/v1/[entity]/[id]/child/[childType]/[childId]/route.ts +12 -4
- package/templates/app/api/v1/[entity]/[id]/child/[childType]/route.ts +13 -5
- package/templates/app/api/v1/[entity]/[id]/route.ts +16 -7
- 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 -6
- 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/auth/docs.md +184 -0
- package/templates/app/api/v1/auth/presets.ts +44 -0
- package/templates/app/api/v1/billing/docs.md +209 -0
- package/templates/app/api/v1/billing/presets.ts +121 -0
- 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/cron/docs.md +116 -0
- package/templates/app/api/v1/cron/presets.ts +26 -0
- package/templates/app/api/v1/devtools/docs/route.ts +150 -0
- package/templates/app/api/v1/devtools/docs.md +204 -0
- package/templates/app/api/v1/devtools/presets.ts +113 -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/patterns/[id]/usages/route.ts +116 -0
- 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/post-categories/docs.md +134 -0
- package/templates/app/api/v1/post-categories/presets.ts +78 -0
- 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/teams/[teamId]/route.ts +52 -24
- 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 +11 -11
- 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/users/docs.md +93 -0
- package/templates/app/api/v1/users/presets.ts +59 -0
- package/templates/app/dashboard/(main)/[entity]/[id]/page.tsx +11 -8
- package/templates/app/dashboard/(main)/[entity]/page.tsx +6 -1
- package/templates/app/dashboard/(main)/layout.tsx +72 -13
- package/templates/app/dashboard/(main)/loading.tsx +5 -0
- package/templates/app/dashboard/(main)/page.tsx +1 -3
- package/templates/app/dashboard/(main)/patterns/[id]/edit/page.tsx +114 -0
- package/templates/app/dashboard/(main)/patterns/[id]/page.tsx +20 -0
- package/templates/app/dashboard/(main)/patterns/[id]/reports/page.tsx +171 -0
- package/templates/app/dashboard/(main)/patterns/create/page.tsx +86 -0
- package/templates/app/dashboard/(main)/patterns/page.tsx +444 -0
- package/templates/app/dashboard/features/loading.tsx +5 -0
- package/templates/app/dashboard/settings/api-keys/loading.tsx +5 -0
- package/templates/app/dashboard/settings/api-keys/page.tsx +75 -75
- package/templates/app/dashboard/settings/billing/loading.tsx +5 -0
- package/templates/app/dashboard/settings/billing/page.tsx +11 -22
- package/templates/app/dashboard/settings/invoices/loading.tsx +5 -0
- package/templates/app/dashboard/settings/layout.tsx +8 -18
- package/templates/app/dashboard/settings/loading.tsx +5 -0
- package/templates/app/dashboard/settings/notifications/loading.tsx +5 -0
- package/templates/app/dashboard/settings/notifications/page.tsx +17 -38
- package/templates/app/dashboard/settings/page.tsx +3 -7
- package/templates/app/dashboard/settings/password/loading.tsx +5 -0
- package/templates/app/dashboard/settings/password/page.tsx +25 -49
- package/templates/app/dashboard/settings/plans/loading.tsx +5 -0
- package/templates/app/dashboard/settings/profile/loading.tsx +5 -0
- package/templates/app/dashboard/settings/profile/page.tsx +25 -62
- package/templates/app/dashboard/settings/security/loading.tsx +5 -0
- package/templates/app/dashboard/settings/security/page.tsx +17 -53
- package/templates/app/dashboard/settings/teams/loading.tsx +5 -0
- package/templates/app/dashboard/settings/teams/page.tsx +30 -31
- package/templates/app/devtools/api/[[...endpoint]]/page.tsx +33 -0
- package/templates/app/devtools/api/layout.tsx +44 -0
- package/templates/app/devtools/scheduled-actions/page.tsx +1 -1
- package/templates/app/globals.css +7 -312
- package/templates/app/layout.tsx +7 -1
- package/templates/app/superadmin/docs/[section]/[page]/page.tsx +92 -0
- package/templates/app/superadmin/docs/page.tsx +75 -0
- package/templates/app/superadmin/page.tsx +1 -1
- package/templates/app/superadmin/subscriptions/page.tsx +5 -4
- package/templates/app/superadmin/teams/page.tsx +37 -84
- package/templates/app/superadmin/users/page.tsx +4 -2
- package/templates/contents/themes/starter/config/app.config.ts +22 -18
- package/templates/contents/themes/starter/config/dev.config.ts +9 -28
- package/templates/contents/themes/starter/config/features.config.ts +156 -0
- package/templates/contents/themes/starter/config/permissions.config.ts +39 -0
- package/templates/contents/themes/starter/docs/superadmin/01-setup/01-configuration.md +31 -0
- package/templates/contents/themes/starter/docs/superadmin/02-entities/01-tasks.md +176 -0
- package/templates/contents/themes/starter/entities/pages/api/docs.md +120 -0
- package/templates/contents/themes/starter/entities/pages/api/presets.ts +72 -0
- package/templates/contents/themes/starter/entities/pages/messages/en.json +41 -0
- package/templates/contents/themes/starter/entities/pages/messages/es.json +41 -0
- package/templates/contents/themes/starter/entities/pages/migrations/001_pages_table.sql +112 -0
- package/templates/contents/themes/starter/entities/pages/migrations/002_pages_metas.sql +56 -0
- package/templates/contents/themes/starter/entities/pages/migrations/003_add_status.sql +50 -0
- package/templates/contents/themes/starter/entities/pages/pages-management.service.ts +610 -0
- package/templates/contents/themes/starter/entities/pages/pages.config.ts +95 -0
- package/templates/contents/themes/starter/entities/pages/pages.fields.ts +101 -0
- package/templates/contents/themes/starter/entities/pages/pages.service.ts +290 -0
- package/templates/contents/themes/starter/entities/pages/pages.types.ts +124 -0
- package/templates/contents/themes/starter/entities/posts/api/docs.md +127 -0
- package/templates/contents/themes/starter/entities/posts/api/presets.ts +74 -0
- package/templates/contents/themes/starter/entities/posts/components/post-header.tsx +97 -0
- package/templates/contents/themes/starter/entities/posts/messages/en.json +55 -0
- package/templates/contents/themes/starter/entities/posts/messages/es.json +55 -0
- package/templates/contents/themes/starter/entities/posts/migrations/001_posts_table.sql +115 -0
- package/templates/contents/themes/starter/entities/posts/migrations/003_add_status.sql +44 -0
- package/templates/contents/themes/starter/entities/posts/migrations/004_entity_taxonomy_relations.sql +129 -0
- package/templates/contents/themes/starter/entities/posts/migrations/006_posts_metas.sql +56 -0
- package/templates/contents/themes/starter/entities/posts/posts.config.ts +102 -0
- package/templates/contents/themes/starter/entities/posts/posts.fields.ts +116 -0
- package/templates/contents/themes/starter/entities/posts/posts.service.ts +376 -0
- package/templates/contents/themes/starter/entities/posts/posts.types.ts +74 -0
- package/templates/contents/themes/starter/entities/tasks/api/docs.md +132 -0
- package/templates/contents/themes/starter/entities/tasks/api/presets.ts +84 -0
- package/templates/contents/themes/starter/entities/tasks/tasks.config.ts +2 -43
- package/templates/contents/themes/starter/entities/tasks/tasks.service.ts +0 -5
- package/templates/contents/themes/starter/lib/selectors.ts +2 -2
- package/templates/contents/themes/starter/messages/de/common.json +4 -1
- package/templates/contents/themes/starter/messages/de/features.json +8 -0
- package/templates/contents/themes/starter/messages/de/index.ts +15 -0
- package/templates/contents/themes/starter/messages/en/common.json +4 -1
- package/templates/contents/themes/starter/messages/en/features.json +8 -0
- package/templates/contents/themes/starter/messages/en/index.ts +15 -0
- package/templates/contents/themes/starter/messages/es/common.json +4 -1
- package/templates/contents/themes/starter/messages/es/features.json +8 -0
- package/templates/contents/themes/starter/messages/es/index.ts +15 -0
- package/templates/contents/themes/starter/messages/fr/common.json +4 -1
- package/templates/contents/themes/starter/messages/fr/features.json +8 -0
- package/templates/contents/themes/starter/messages/fr/index.ts +15 -0
- package/templates/contents/themes/starter/messages/it/common.json +4 -1
- package/templates/contents/themes/starter/messages/it/features.json +8 -0
- package/templates/contents/themes/starter/messages/it/index.ts +13 -0
- package/templates/contents/themes/starter/messages/pt/common.json +4 -1
- package/templates/contents/themes/starter/messages/pt/features.json +8 -0
- package/templates/contents/themes/starter/messages/pt/index.ts +13 -0
- package/templates/contents/themes/starter/styles/globals.css +183 -7
- package/templates/contents/themes/starter/templates/(dashboard)/analytics/loading.tsx +5 -0
- package/templates/contents/themes/starter/templates/(public)/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/{dist/templates/contents/themes/starter/tests/cypress/e2e → templates/contents/themes/starter/tests/cypress/e2e/uat/entities}/tasks/tasks-crud.cy.ts +24 -16
- 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/{e2e/tasks → src/entities}/TasksPOM.ts +1 -1
- 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/{contents/themes/starter → features/pages}/blocks/hero/component.tsx +2 -2
- package/templates/features/pages/entities/pages/pages.config.ts +1 -0
- package/templates/next.config.mjs +132 -2
- 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/docs-registry.ts +161 -0
- package/tests/jest/__mocks__/@nextsparkjs/registries/permissions-registry.ts +26 -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/testing-utils.d.js +0 -0
- 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/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/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/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/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/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/{test/core-selectors.d.js → actions/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/{lib/test/selector-factory.d.js → templates/contents/themes/starter/blocks/.gitkeep} +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/tests/cypress/e2e/{tasks → api/entities/tasks}/TaskAPIController.js +0 -0
- /package/dist/templates/{contents/themes/starter → features/pages}/blocks/hero/config.ts +0 -0
- /package/dist/templates/{contents/themes/starter → features/pages}/blocks/hero/fields.ts +0 -0
- /package/dist/templates/{contents/themes/starter → features/pages}/blocks/hero/index.ts +0 -0
- /package/dist/templates/{contents/themes/starter → features/pages}/blocks/hero/schema.ts +0 -0
- /package/{dist/lib/test/utils.d.js → templates/contents/themes/starter/blocks/.gitkeep} +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/tests/cypress/e2e/{tasks → api/entities/tasks}/TaskAPIController.js +0 -0
- /package/templates/{contents/themes/starter → features/pages}/blocks/hero/config.ts +0 -0
- /package/templates/{contents/themes/starter → features/pages}/blocks/hero/fields.ts +0 -0
- /package/templates/{contents/themes/starter → features/pages}/blocks/hero/index.ts +0 -0
- /package/templates/{contents/themes/starter → features/pages}/blocks/hero/schema.ts +0 -0
|
@@ -0,0 +1,595 @@
|
|
|
1
|
+
import { queryWithRLS, queryOneWithRLS, mutateWithRLS } from "../db.js";
|
|
2
|
+
import { entityRegistry } from "../entities/registry.js";
|
|
3
|
+
import { executeBeforeHooks, executeAfterHooks } from "../entities/hooks.js";
|
|
4
|
+
const SYSTEM_FIELDS = ["id", "userId", "teamId", "createdAt", "updatedAt"];
|
|
5
|
+
const DEFAULT_LIMIT = 20;
|
|
6
|
+
const DEFAULT_ORDER_BY = "createdAt";
|
|
7
|
+
const DEFAULT_ORDER_DIR = "desc";
|
|
8
|
+
const SAFE_SQL_IDENTIFIER = /^[a-zA-Z_][a-zA-Z0-9_]*$/;
|
|
9
|
+
function validateSqlIdentifier(name, type) {
|
|
10
|
+
if (!name || !SAFE_SQL_IDENTIFIER.test(name)) {
|
|
11
|
+
throw new Error(`Invalid ${type} name: "${name}" contains unsafe characters`);
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
function getTableName(entityConfig) {
|
|
15
|
+
const tableName = entityConfig.tableName || entityConfig.slug;
|
|
16
|
+
validateSqlIdentifier(tableName, "table");
|
|
17
|
+
return tableName;
|
|
18
|
+
}
|
|
19
|
+
function getFieldNames(entityConfig) {
|
|
20
|
+
if (!entityConfig.fields || !Array.isArray(entityConfig.fields)) {
|
|
21
|
+
return [];
|
|
22
|
+
}
|
|
23
|
+
return entityConfig.fields.map((field) => {
|
|
24
|
+
validateSqlIdentifier(field.name, "field");
|
|
25
|
+
return field.name;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
function getSearchableFields(entityConfig) {
|
|
29
|
+
if (!entityConfig.fields || !Array.isArray(entityConfig.fields)) {
|
|
30
|
+
return [];
|
|
31
|
+
}
|
|
32
|
+
return entityConfig.fields.filter((field) => {
|
|
33
|
+
var _a;
|
|
34
|
+
return ((_a = field.api) == null ? void 0 : _a.searchable) === true;
|
|
35
|
+
}).map((field) => field.name);
|
|
36
|
+
}
|
|
37
|
+
function quoteField(field) {
|
|
38
|
+
return field.includes("_") || /[A-Z]/.test(field) ? `"${field}"` : field;
|
|
39
|
+
}
|
|
40
|
+
function buildSelectClause(fieldNames) {
|
|
41
|
+
const allFields = [...SYSTEM_FIELDS, ...fieldNames];
|
|
42
|
+
return allFields.map((f) => quoteField(f)).join(", ");
|
|
43
|
+
}
|
|
44
|
+
function buildWhereClause(where, validFields, startIndex = 1) {
|
|
45
|
+
const conditions = [];
|
|
46
|
+
const params = [];
|
|
47
|
+
let paramIndex = startIndex;
|
|
48
|
+
for (const [key, value] of Object.entries(where)) {
|
|
49
|
+
if (value === void 0) continue;
|
|
50
|
+
if (!validFields.includes(key)) {
|
|
51
|
+
throw new Error(`Invalid filter field: "${key}"`);
|
|
52
|
+
}
|
|
53
|
+
const quotedKey = quoteField(key);
|
|
54
|
+
if (value === null) {
|
|
55
|
+
conditions.push(`${quotedKey} IS NULL`);
|
|
56
|
+
} else if (Array.isArray(value)) {
|
|
57
|
+
conditions.push(`${quotedKey} = ANY($${paramIndex})`);
|
|
58
|
+
params.push(value);
|
|
59
|
+
paramIndex++;
|
|
60
|
+
} else {
|
|
61
|
+
conditions.push(`${quotedKey} = $${paramIndex}`);
|
|
62
|
+
params.push(value);
|
|
63
|
+
paramIndex++;
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
return {
|
|
67
|
+
clause: conditions.length > 0 ? `WHERE ${conditions.join(" AND ")}` : "",
|
|
68
|
+
params,
|
|
69
|
+
nextIndex: paramIndex
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
function buildSearchCondition(search, searchableFields, paramIndex) {
|
|
73
|
+
if (!search || searchableFields.length === 0) {
|
|
74
|
+
return null;
|
|
75
|
+
}
|
|
76
|
+
const searchConditions = searchableFields.map((f) => `${quoteField(f)} ILIKE $${paramIndex}`).join(" OR ");
|
|
77
|
+
return {
|
|
78
|
+
condition: `(${searchConditions})`,
|
|
79
|
+
param: `%${search}%`
|
|
80
|
+
};
|
|
81
|
+
}
|
|
82
|
+
function mapRowToEntity(row) {
|
|
83
|
+
const entity = {};
|
|
84
|
+
for (const [key, value] of Object.entries(row)) {
|
|
85
|
+
entity[key] = value === null ? void 0 : value;
|
|
86
|
+
}
|
|
87
|
+
return entity;
|
|
88
|
+
}
|
|
89
|
+
function validateFieldType(field, value) {
|
|
90
|
+
switch (field.type) {
|
|
91
|
+
case "text":
|
|
92
|
+
case "textarea":
|
|
93
|
+
case "email":
|
|
94
|
+
case "url":
|
|
95
|
+
case "markdown":
|
|
96
|
+
case "richtext":
|
|
97
|
+
case "code":
|
|
98
|
+
case "phone":
|
|
99
|
+
if (typeof value !== "string") {
|
|
100
|
+
return `Field "${field.name}" must be a string`;
|
|
101
|
+
}
|
|
102
|
+
break;
|
|
103
|
+
case "number":
|
|
104
|
+
case "range":
|
|
105
|
+
case "rating":
|
|
106
|
+
if (typeof value !== "number") {
|
|
107
|
+
return `Field "${field.name}" must be a number`;
|
|
108
|
+
}
|
|
109
|
+
break;
|
|
110
|
+
case "boolean":
|
|
111
|
+
if (typeof value !== "boolean") {
|
|
112
|
+
return `Field "${field.name}" must be a boolean`;
|
|
113
|
+
}
|
|
114
|
+
break;
|
|
115
|
+
case "select":
|
|
116
|
+
case "radio":
|
|
117
|
+
case "buttongroup":
|
|
118
|
+
if (field.options && !field.options.some((opt) => opt.value === value)) {
|
|
119
|
+
return `Field "${field.name}" has invalid option value`;
|
|
120
|
+
}
|
|
121
|
+
break;
|
|
122
|
+
case "multiselect":
|
|
123
|
+
case "tags":
|
|
124
|
+
if (!Array.isArray(value)) {
|
|
125
|
+
return `Field "${field.name}" must be an array`;
|
|
126
|
+
}
|
|
127
|
+
if (field.options) {
|
|
128
|
+
const invalidValues = value.filter(
|
|
129
|
+
(v) => !field.options.some((opt) => opt.value === v)
|
|
130
|
+
);
|
|
131
|
+
if (invalidValues.length > 0) {
|
|
132
|
+
return `Field "${field.name}" contains invalid option values`;
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
break;
|
|
136
|
+
case "date":
|
|
137
|
+
case "datetime":
|
|
138
|
+
if (typeof value !== "string" && !(value instanceof Date)) {
|
|
139
|
+
return `Field "${field.name}" must be a date string or Date object`;
|
|
140
|
+
}
|
|
141
|
+
break;
|
|
142
|
+
case "json":
|
|
143
|
+
break;
|
|
144
|
+
}
|
|
145
|
+
return null;
|
|
146
|
+
}
|
|
147
|
+
function validateEntityData(entityConfig, data, isUpdate = false) {
|
|
148
|
+
const errors = [];
|
|
149
|
+
for (const field of entityConfig.fields) {
|
|
150
|
+
const value = data[field.name];
|
|
151
|
+
if (!isUpdate && field.required && (value === void 0 || value === null || value === "")) {
|
|
152
|
+
errors.push(`Field "${field.name}" is required`);
|
|
153
|
+
continue;
|
|
154
|
+
}
|
|
155
|
+
if (value === void 0 || value === null) {
|
|
156
|
+
continue;
|
|
157
|
+
}
|
|
158
|
+
if (field.validation) {
|
|
159
|
+
try {
|
|
160
|
+
const result = field.validation.safeParse(value);
|
|
161
|
+
if (!result.success) {
|
|
162
|
+
const zodError = result.error.issues[0];
|
|
163
|
+
errors.push(`Field "${field.name}": ${(zodError == null ? void 0 : zodError.message) || "Invalid value"}`);
|
|
164
|
+
continue;
|
|
165
|
+
}
|
|
166
|
+
} catch {
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
const typeError = validateFieldType(field, value);
|
|
170
|
+
if (typeError) {
|
|
171
|
+
errors.push(typeError);
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
return { valid: errors.length === 0, errors };
|
|
175
|
+
}
|
|
176
|
+
function createHookContext(entitySlug, operation, userId, data, previousData, role = "member") {
|
|
177
|
+
return {
|
|
178
|
+
entityName: entitySlug,
|
|
179
|
+
operation,
|
|
180
|
+
data,
|
|
181
|
+
previousData,
|
|
182
|
+
user: { id: userId, role }
|
|
183
|
+
};
|
|
184
|
+
}
|
|
185
|
+
class GenericEntityService {
|
|
186
|
+
/**
|
|
187
|
+
* Get entity by ID
|
|
188
|
+
*
|
|
189
|
+
* @param entitySlug - The entity type slug (e.g., 'campaigns', 'schools')
|
|
190
|
+
* @param id - Entity ID
|
|
191
|
+
* @param userId - Current user ID for RLS
|
|
192
|
+
* @param teamId - Team ID for team isolation (prevents cross-team access)
|
|
193
|
+
* @returns Entity or null if not found
|
|
194
|
+
*/
|
|
195
|
+
static async getById(entitySlug, id, userId, teamId) {
|
|
196
|
+
if (!(id == null ? void 0 : id.trim())) {
|
|
197
|
+
throw new Error("Entity ID is required");
|
|
198
|
+
}
|
|
199
|
+
if (!(userId == null ? void 0 : userId.trim())) {
|
|
200
|
+
throw new Error("User ID is required for authentication");
|
|
201
|
+
}
|
|
202
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
203
|
+
if (!entityConfig) {
|
|
204
|
+
throw new Error(`Entity "${entitySlug}" not found in registry`);
|
|
205
|
+
}
|
|
206
|
+
const tableName = getTableName(entityConfig);
|
|
207
|
+
const fieldNames = getFieldNames(entityConfig);
|
|
208
|
+
const selectClause = buildSelectClause(fieldNames);
|
|
209
|
+
const whereClause = teamId ? `WHERE id = $1 AND "teamId" = $2` : `WHERE id = $1`;
|
|
210
|
+
const params = teamId ? [id, teamId] : [id];
|
|
211
|
+
const row = await queryOneWithRLS(
|
|
212
|
+
`SELECT ${selectClause} FROM ${tableName} ${whereClause}`,
|
|
213
|
+
params,
|
|
214
|
+
userId
|
|
215
|
+
);
|
|
216
|
+
return row ? mapRowToEntity(row) : null;
|
|
217
|
+
}
|
|
218
|
+
/**
|
|
219
|
+
* List entities with pagination, filtering, and search
|
|
220
|
+
*
|
|
221
|
+
* @param entitySlug - The entity type slug
|
|
222
|
+
* @param userId - Current user ID for RLS
|
|
223
|
+
* @param options - List options (limit, offset, where, search, orderBy)
|
|
224
|
+
* @returns Paginated result with data and total count
|
|
225
|
+
*/
|
|
226
|
+
static async list(entitySlug, userId, options = {}) {
|
|
227
|
+
var _a;
|
|
228
|
+
if (!(userId == null ? void 0 : userId.trim())) {
|
|
229
|
+
throw new Error("User ID is required for authentication");
|
|
230
|
+
}
|
|
231
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
232
|
+
if (!entityConfig) {
|
|
233
|
+
throw new Error(`Entity "${entitySlug}" not found in registry`);
|
|
234
|
+
}
|
|
235
|
+
const tableName = getTableName(entityConfig);
|
|
236
|
+
const fieldNames = getFieldNames(entityConfig);
|
|
237
|
+
const searchableFields = getSearchableFields(entityConfig);
|
|
238
|
+
const selectClause = buildSelectClause(fieldNames);
|
|
239
|
+
const allFields = [...SYSTEM_FIELDS, ...fieldNames];
|
|
240
|
+
const {
|
|
241
|
+
limit = DEFAULT_LIMIT,
|
|
242
|
+
offset = 0,
|
|
243
|
+
orderBy = DEFAULT_ORDER_BY,
|
|
244
|
+
orderDir = DEFAULT_ORDER_DIR,
|
|
245
|
+
where = {},
|
|
246
|
+
search,
|
|
247
|
+
teamId
|
|
248
|
+
} = options;
|
|
249
|
+
const effectiveWhere = teamId ? { ...where, teamId } : where;
|
|
250
|
+
const { clause: whereClause, params, nextIndex } = buildWhereClause(effectiveWhere, allFields);
|
|
251
|
+
let fullWhereClause = whereClause;
|
|
252
|
+
const allParams = [...params];
|
|
253
|
+
let paramIdx = nextIndex;
|
|
254
|
+
if (search) {
|
|
255
|
+
const searchResult = buildSearchCondition(search, searchableFields, paramIdx);
|
|
256
|
+
if (searchResult) {
|
|
257
|
+
const connector = whereClause ? " AND " : "WHERE ";
|
|
258
|
+
fullWhereClause = `${whereClause}${connector}${searchResult.condition}`;
|
|
259
|
+
allParams.push(searchResult.param);
|
|
260
|
+
paramIdx++;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
const validOrderBy = allFields.includes(orderBy) ? orderBy : DEFAULT_ORDER_BY;
|
|
264
|
+
const validOrderDir = orderDir === "asc" ? "ASC" : "DESC";
|
|
265
|
+
const orderColumn = quoteField(validOrderBy);
|
|
266
|
+
const countResult = await queryWithRLS(
|
|
267
|
+
`SELECT COUNT(*)::text as count FROM ${tableName} ${fullWhereClause}`,
|
|
268
|
+
allParams,
|
|
269
|
+
userId
|
|
270
|
+
);
|
|
271
|
+
const total = parseInt(((_a = countResult[0]) == null ? void 0 : _a.count) || "0", 10);
|
|
272
|
+
const limitIdx = paramIdx;
|
|
273
|
+
const offsetIdx = paramIdx + 1;
|
|
274
|
+
const rows = await queryWithRLS(
|
|
275
|
+
`SELECT ${selectClause}
|
|
276
|
+
FROM ${tableName}
|
|
277
|
+
${fullWhereClause}
|
|
278
|
+
ORDER BY ${orderColumn} ${validOrderDir}
|
|
279
|
+
LIMIT $${limitIdx} OFFSET $${offsetIdx}`,
|
|
280
|
+
[...allParams, limit, offset],
|
|
281
|
+
userId
|
|
282
|
+
);
|
|
283
|
+
return {
|
|
284
|
+
data: rows.map((row) => mapRowToEntity(row)),
|
|
285
|
+
total,
|
|
286
|
+
limit,
|
|
287
|
+
offset
|
|
288
|
+
};
|
|
289
|
+
}
|
|
290
|
+
/**
|
|
291
|
+
* Create a new entity
|
|
292
|
+
*
|
|
293
|
+
* @param entitySlug - The entity type slug
|
|
294
|
+
* @param userId - Current user ID for RLS and ownership
|
|
295
|
+
* @param teamId - Team ID for team isolation
|
|
296
|
+
* @param data - Entity data
|
|
297
|
+
* @returns Created entity
|
|
298
|
+
*/
|
|
299
|
+
static async create(entitySlug, userId, teamId, data) {
|
|
300
|
+
if (!(userId == null ? void 0 : userId.trim())) {
|
|
301
|
+
throw new Error("User ID is required");
|
|
302
|
+
}
|
|
303
|
+
if (!(teamId == null ? void 0 : teamId.trim())) {
|
|
304
|
+
throw new Error("Team ID is required");
|
|
305
|
+
}
|
|
306
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
307
|
+
if (!entityConfig) {
|
|
308
|
+
throw new Error(`Entity "${entitySlug}" not found in registry`);
|
|
309
|
+
}
|
|
310
|
+
const beforeContext = createHookContext(entitySlug, "create", userId, data);
|
|
311
|
+
const beforeResult = await executeBeforeHooks(entitySlug, "create", beforeContext);
|
|
312
|
+
if (!beforeResult.continue) {
|
|
313
|
+
throw new Error(beforeResult.error || "Operation cancelled by hook");
|
|
314
|
+
}
|
|
315
|
+
const finalData = beforeResult.data ?? data;
|
|
316
|
+
const validation = validateEntityData(entityConfig, finalData, false);
|
|
317
|
+
if (!validation.valid) {
|
|
318
|
+
throw new Error(`Validation failed: ${validation.errors.join(", ")}`);
|
|
319
|
+
}
|
|
320
|
+
const tableName = getTableName(entityConfig);
|
|
321
|
+
const fieldNames = getFieldNames(entityConfig);
|
|
322
|
+
const selectClause = buildSelectClause(fieldNames);
|
|
323
|
+
const fields = ["userId", "teamId"];
|
|
324
|
+
const values = [userId, teamId];
|
|
325
|
+
const placeholders = ["$1", "$2"];
|
|
326
|
+
let paramIndex = 3;
|
|
327
|
+
for (const field of fieldNames) {
|
|
328
|
+
if (field in finalData && finalData[field] !== void 0) {
|
|
329
|
+
fields.push(field);
|
|
330
|
+
values.push(finalData[field]);
|
|
331
|
+
placeholders.push(`$${paramIndex}`);
|
|
332
|
+
paramIndex++;
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
const quotedFields = fields.map((f) => quoteField(f)).join(", ");
|
|
336
|
+
const result = await mutateWithRLS(
|
|
337
|
+
`INSERT INTO ${tableName} (${quotedFields})
|
|
338
|
+
VALUES (${placeholders.join(", ")})
|
|
339
|
+
RETURNING ${selectClause}`,
|
|
340
|
+
values,
|
|
341
|
+
userId
|
|
342
|
+
);
|
|
343
|
+
if (!result.rows[0]) {
|
|
344
|
+
throw new Error("Failed to create entity");
|
|
345
|
+
}
|
|
346
|
+
const createdEntity = mapRowToEntity(result.rows[0]);
|
|
347
|
+
const afterContext = createHookContext(entitySlug, "create", userId, createdEntity);
|
|
348
|
+
executeAfterHooks(entitySlug, "create", afterContext).catch((err) => {
|
|
349
|
+
console.error(`[GenericEntityService] afterCreate hook error for ${entitySlug}:`, err);
|
|
350
|
+
});
|
|
351
|
+
return createdEntity;
|
|
352
|
+
}
|
|
353
|
+
/**
|
|
354
|
+
* Update an existing entity
|
|
355
|
+
*
|
|
356
|
+
* @param entitySlug - The entity type slug
|
|
357
|
+
* @param id - Entity ID
|
|
358
|
+
* @param userId - Current user ID for RLS
|
|
359
|
+
* @param data - Fields to update
|
|
360
|
+
* @param teamId - Team ID for team isolation (prevents cross-team access)
|
|
361
|
+
* @returns Updated entity
|
|
362
|
+
*/
|
|
363
|
+
static async update(entitySlug, id, userId, data, teamId) {
|
|
364
|
+
if (!(id == null ? void 0 : id.trim())) {
|
|
365
|
+
throw new Error("Entity ID is required");
|
|
366
|
+
}
|
|
367
|
+
if (!(userId == null ? void 0 : userId.trim())) {
|
|
368
|
+
throw new Error("User ID is required");
|
|
369
|
+
}
|
|
370
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
371
|
+
if (!entityConfig) {
|
|
372
|
+
throw new Error(`Entity "${entitySlug}" not found in registry`);
|
|
373
|
+
}
|
|
374
|
+
const tableName = getTableName(entityConfig);
|
|
375
|
+
const fieldNames = getFieldNames(entityConfig);
|
|
376
|
+
const selectClause = buildSelectClause(fieldNames);
|
|
377
|
+
const fetchWhereClause = teamId ? `WHERE id = $1 AND "teamId" = $2` : `WHERE id = $1`;
|
|
378
|
+
const fetchParams = teamId ? [id, teamId] : [id];
|
|
379
|
+
const currentEntity = await queryOneWithRLS(
|
|
380
|
+
`SELECT ${selectClause} FROM ${tableName} ${fetchWhereClause}`,
|
|
381
|
+
fetchParams,
|
|
382
|
+
userId
|
|
383
|
+
);
|
|
384
|
+
if (!currentEntity) {
|
|
385
|
+
throw new Error("Entity not found or not authorized");
|
|
386
|
+
}
|
|
387
|
+
const beforeContext = createHookContext(entitySlug, "update", userId, data, currentEntity);
|
|
388
|
+
const beforeResult = await executeBeforeHooks(entitySlug, "update", beforeContext);
|
|
389
|
+
if (!beforeResult.continue) {
|
|
390
|
+
throw new Error(beforeResult.error || "Operation cancelled by hook");
|
|
391
|
+
}
|
|
392
|
+
const finalData = beforeResult.data ?? data;
|
|
393
|
+
const validation = validateEntityData(entityConfig, finalData, true);
|
|
394
|
+
if (!validation.valid) {
|
|
395
|
+
throw new Error(`Validation failed: ${validation.errors.join(", ")}`);
|
|
396
|
+
}
|
|
397
|
+
const setClauses = [];
|
|
398
|
+
const values = [];
|
|
399
|
+
let paramIndex = 1;
|
|
400
|
+
for (const field of fieldNames) {
|
|
401
|
+
if (field in finalData) {
|
|
402
|
+
setClauses.push(`${quoteField(field)} = $${paramIndex}`);
|
|
403
|
+
values.push(finalData[field]);
|
|
404
|
+
paramIndex++;
|
|
405
|
+
}
|
|
406
|
+
}
|
|
407
|
+
if (setClauses.length === 0) {
|
|
408
|
+
throw new Error("No fields to update");
|
|
409
|
+
}
|
|
410
|
+
setClauses.push(`"updatedAt" = now()`);
|
|
411
|
+
values.push(id);
|
|
412
|
+
const idParamIndex = paramIndex;
|
|
413
|
+
paramIndex++;
|
|
414
|
+
let updateWhereClause = `WHERE id = $${idParamIndex}`;
|
|
415
|
+
if (teamId) {
|
|
416
|
+
values.push(teamId);
|
|
417
|
+
updateWhereClause += ` AND "teamId" = $${paramIndex}`;
|
|
418
|
+
}
|
|
419
|
+
const result = await mutateWithRLS(
|
|
420
|
+
`UPDATE ${tableName}
|
|
421
|
+
SET ${setClauses.join(", ")}
|
|
422
|
+
${updateWhereClause}
|
|
423
|
+
RETURNING ${selectClause}`,
|
|
424
|
+
values,
|
|
425
|
+
userId
|
|
426
|
+
);
|
|
427
|
+
if (!result.rows[0]) {
|
|
428
|
+
throw new Error("Update failed");
|
|
429
|
+
}
|
|
430
|
+
const updatedEntity = mapRowToEntity(result.rows[0]);
|
|
431
|
+
const afterContext = createHookContext(entitySlug, "update", userId, updatedEntity, currentEntity);
|
|
432
|
+
executeAfterHooks(entitySlug, "update", afterContext).catch((err) => {
|
|
433
|
+
console.error(`[GenericEntityService] afterUpdate hook error for ${entitySlug}:`, err);
|
|
434
|
+
});
|
|
435
|
+
return updatedEntity;
|
|
436
|
+
}
|
|
437
|
+
/**
|
|
438
|
+
* Delete an entity
|
|
439
|
+
*
|
|
440
|
+
* @param entitySlug - The entity type slug
|
|
441
|
+
* @param id - Entity ID
|
|
442
|
+
* @param userId - Current user ID for RLS
|
|
443
|
+
* @param teamId - Team ID for team isolation (prevents cross-team access)
|
|
444
|
+
* @returns true if deleted, false if not found
|
|
445
|
+
*/
|
|
446
|
+
static async delete(entitySlug, id, userId, teamId) {
|
|
447
|
+
if (!(id == null ? void 0 : id.trim())) {
|
|
448
|
+
throw new Error("Entity ID is required");
|
|
449
|
+
}
|
|
450
|
+
if (!(userId == null ? void 0 : userId.trim())) {
|
|
451
|
+
throw new Error("User ID is required");
|
|
452
|
+
}
|
|
453
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
454
|
+
if (!entityConfig) {
|
|
455
|
+
throw new Error(`Entity "${entitySlug}" not found in registry`);
|
|
456
|
+
}
|
|
457
|
+
const tableName = getTableName(entityConfig);
|
|
458
|
+
const fieldNames = getFieldNames(entityConfig);
|
|
459
|
+
const selectClause = buildSelectClause(fieldNames);
|
|
460
|
+
const whereClause = teamId ? `WHERE id = $1 AND "teamId" = $2` : `WHERE id = $1`;
|
|
461
|
+
const params = teamId ? [id, teamId] : [id];
|
|
462
|
+
const entityToDelete = await queryOneWithRLS(
|
|
463
|
+
`SELECT ${selectClause} FROM ${tableName} ${whereClause}`,
|
|
464
|
+
params,
|
|
465
|
+
userId
|
|
466
|
+
);
|
|
467
|
+
if (!entityToDelete) {
|
|
468
|
+
return false;
|
|
469
|
+
}
|
|
470
|
+
const beforeContext = createHookContext(entitySlug, "delete", userId, void 0, entityToDelete);
|
|
471
|
+
const beforeResult = await executeBeforeHooks(entitySlug, "delete", beforeContext);
|
|
472
|
+
if (!beforeResult.continue) {
|
|
473
|
+
throw new Error(beforeResult.error || "Operation cancelled by hook");
|
|
474
|
+
}
|
|
475
|
+
const result = await mutateWithRLS(
|
|
476
|
+
`DELETE FROM ${tableName} ${whereClause}`,
|
|
477
|
+
params,
|
|
478
|
+
userId
|
|
479
|
+
);
|
|
480
|
+
const deleted = result.rowCount > 0;
|
|
481
|
+
if (deleted) {
|
|
482
|
+
const afterContext = createHookContext(entitySlug, "delete", userId, void 0, entityToDelete);
|
|
483
|
+
executeAfterHooks(entitySlug, "delete", afterContext).catch((err) => {
|
|
484
|
+
console.error(`[GenericEntityService] afterDelete hook error for ${entitySlug}:`, err);
|
|
485
|
+
});
|
|
486
|
+
}
|
|
487
|
+
return deleted;
|
|
488
|
+
}
|
|
489
|
+
/**
|
|
490
|
+
* Check if an entity exists
|
|
491
|
+
*
|
|
492
|
+
* @param entitySlug - The entity type slug
|
|
493
|
+
* @param id - Entity ID
|
|
494
|
+
* @param userId - Current user ID for RLS
|
|
495
|
+
* @param teamId - Team ID for team isolation (prevents cross-team access)
|
|
496
|
+
* @returns true if exists and accessible
|
|
497
|
+
*/
|
|
498
|
+
static async exists(entitySlug, id, userId, teamId) {
|
|
499
|
+
if (!(id == null ? void 0 : id.trim()) || !(userId == null ? void 0 : userId.trim())) {
|
|
500
|
+
return false;
|
|
501
|
+
}
|
|
502
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
503
|
+
if (!entityConfig) {
|
|
504
|
+
return false;
|
|
505
|
+
}
|
|
506
|
+
const tableName = getTableName(entityConfig);
|
|
507
|
+
const whereClause = teamId ? `WHERE id = $1 AND "teamId" = $2` : `WHERE id = $1`;
|
|
508
|
+
const params = teamId ? [id, teamId] : [id];
|
|
509
|
+
const result = await queryOneWithRLS(
|
|
510
|
+
`SELECT EXISTS(SELECT 1 FROM ${tableName} ${whereClause}) as exists`,
|
|
511
|
+
params,
|
|
512
|
+
userId
|
|
513
|
+
);
|
|
514
|
+
return (result == null ? void 0 : result.exists) ?? false;
|
|
515
|
+
}
|
|
516
|
+
/**
|
|
517
|
+
* Count entities with optional filtering
|
|
518
|
+
*
|
|
519
|
+
* @param entitySlug - The entity type slug
|
|
520
|
+
* @param userId - Current user ID for RLS
|
|
521
|
+
* @param where - Filter conditions
|
|
522
|
+
* @returns Count of matching entities
|
|
523
|
+
*/
|
|
524
|
+
static async count(entitySlug, userId, where = {}) {
|
|
525
|
+
var _a;
|
|
526
|
+
if (!(userId == null ? void 0 : userId.trim())) {
|
|
527
|
+
throw new Error("User ID is required");
|
|
528
|
+
}
|
|
529
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
530
|
+
if (!entityConfig) {
|
|
531
|
+
throw new Error(`Entity "${entitySlug}" not found in registry`);
|
|
532
|
+
}
|
|
533
|
+
const tableName = getTableName(entityConfig);
|
|
534
|
+
const fieldNames = getFieldNames(entityConfig);
|
|
535
|
+
const allFields = [...SYSTEM_FIELDS, ...fieldNames];
|
|
536
|
+
const { clause, params } = buildWhereClause(where, allFields);
|
|
537
|
+
const result = await queryWithRLS(
|
|
538
|
+
`SELECT COUNT(*)::text as count FROM ${tableName} ${clause}`,
|
|
539
|
+
params,
|
|
540
|
+
userId
|
|
541
|
+
);
|
|
542
|
+
return parseInt(((_a = result[0]) == null ? void 0 : _a.count) || "0", 10);
|
|
543
|
+
}
|
|
544
|
+
/**
|
|
545
|
+
* Delete multiple entities in a single query (batch operation)
|
|
546
|
+
*
|
|
547
|
+
* More efficient than calling delete() in a loop.
|
|
548
|
+
*
|
|
549
|
+
* @param entitySlug - The entity type slug
|
|
550
|
+
* @param ids - Array of entity IDs to delete
|
|
551
|
+
* @param userId - Current user ID for RLS
|
|
552
|
+
* @param options - Optional configuration
|
|
553
|
+
* @param options.executeHooks - If true, executes hooks for each entity (less efficient). Default: false
|
|
554
|
+
* @param options.teamId - Team ID for team isolation (prevents cross-team access)
|
|
555
|
+
* @returns Number of entities deleted
|
|
556
|
+
*
|
|
557
|
+
* @note When executeHooks is false (default), uses a single atomic DELETE query.
|
|
558
|
+
* When executeHooks is true, deletes are performed sequentially and are NOT transactional.
|
|
559
|
+
* If one delete fails mid-batch, previous deletes remain committed.
|
|
560
|
+
*/
|
|
561
|
+
static async deleteMany(entitySlug, ids, userId, options = {}) {
|
|
562
|
+
if (!(ids == null ? void 0 : ids.length)) {
|
|
563
|
+
throw new Error("At least one ID is required");
|
|
564
|
+
}
|
|
565
|
+
if (!(userId == null ? void 0 : userId.trim())) {
|
|
566
|
+
throw new Error("User ID is required");
|
|
567
|
+
}
|
|
568
|
+
const entityConfig = entityRegistry.get(entitySlug);
|
|
569
|
+
if (!entityConfig) {
|
|
570
|
+
throw new Error(`Entity "${entitySlug}" not found in registry`);
|
|
571
|
+
}
|
|
572
|
+
const tableName = getTableName(entityConfig);
|
|
573
|
+
const { executeHooks, teamId } = options;
|
|
574
|
+
if (executeHooks) {
|
|
575
|
+
let deletedCount = 0;
|
|
576
|
+
for (const id of ids) {
|
|
577
|
+
const deleted = await GenericEntityService.delete(entitySlug, id, userId, teamId);
|
|
578
|
+
if (deleted) deletedCount++;
|
|
579
|
+
}
|
|
580
|
+
return deletedCount;
|
|
581
|
+
}
|
|
582
|
+
const whereClause = teamId ? `WHERE id = ANY($1) AND "teamId" = $2` : `WHERE id = ANY($1)`;
|
|
583
|
+
const params = teamId ? [ids, teamId] : [ids];
|
|
584
|
+
const result = await mutateWithRLS(
|
|
585
|
+
`DELETE FROM ${tableName} ${whereClause}`,
|
|
586
|
+
params,
|
|
587
|
+
userId
|
|
588
|
+
);
|
|
589
|
+
return result.rowCount;
|
|
590
|
+
}
|
|
591
|
+
}
|
|
592
|
+
export {
|
|
593
|
+
GenericEntityService,
|
|
594
|
+
validateEntityData
|
|
595
|
+
};
|
|
@@ -1,21 +1,21 @@
|
|
|
1
|
-
import { UserService } from "./user.service";
|
|
2
|
-
import { MetaService } from "./meta.service";
|
|
3
|
-
import { PlanService } from "./plan.service";
|
|
4
|
-
import { SubscriptionService } from "./subscription.service";
|
|
5
|
-
import { UsageService } from "./usage.service";
|
|
6
|
-
import { InvoiceService } from "./invoice.service";
|
|
7
|
-
import { TeamService } from "./team.service";
|
|
8
|
-
import { TeamMemberService } from "./team-member.service";
|
|
9
|
-
import { PermissionService } from "./permission.service";
|
|
10
|
-
import { MembershipService, TeamMembership } from "./membership.service";
|
|
11
|
-
import { ThemeService } from "./theme.service";
|
|
12
|
-
import { EntityTypeService } from "./entity-type.service";
|
|
13
|
-
import { NamespaceService } from "./namespace.service";
|
|
14
|
-
import { MiddlewareService } from "./middleware.service";
|
|
15
|
-
import { ScopeService } from "./scope.service";
|
|
16
|
-
import { RouteHandlerService } from "./route-handler.service";
|
|
17
|
-
import { PluginService, usePlugin } from "./plugin.service";
|
|
18
|
-
import { ApiRoutesService } from "./api-routes.service";
|
|
1
|
+
import { UserService } from "./user.service.js";
|
|
2
|
+
import { MetaService } from "./meta.service.js";
|
|
3
|
+
import { PlanService } from "./plan.service.js";
|
|
4
|
+
import { SubscriptionService } from "./subscription.service.js";
|
|
5
|
+
import { UsageService } from "./usage.service.js";
|
|
6
|
+
import { InvoiceService } from "./invoice.service.js";
|
|
7
|
+
import { TeamService } from "./team.service.js";
|
|
8
|
+
import { TeamMemberService } from "./team-member.service.js";
|
|
9
|
+
import { PermissionService } from "./permission.service.js";
|
|
10
|
+
import { MembershipService, TeamMembership } from "./membership.service.js";
|
|
11
|
+
import { ThemeService } from "./theme.service.js";
|
|
12
|
+
import { EntityTypeService } from "./entity-type.service.js";
|
|
13
|
+
import { NamespaceService } from "./namespace.service.js";
|
|
14
|
+
import { MiddlewareService } from "./middleware.service.js";
|
|
15
|
+
import { ScopeService } from "./scope.service.js";
|
|
16
|
+
import { RouteHandlerService } from "./route-handler.service.js";
|
|
17
|
+
import { PluginService, usePlugin } from "./plugin.service.js";
|
|
18
|
+
import { ApiRoutesService } from "./api-routes.service.js";
|
|
19
19
|
export {
|
|
20
20
|
ApiRoutesService,
|
|
21
21
|
EntityTypeService,
|
|
@@ -17,14 +17,18 @@ export { TeamService } from './team.service';
|
|
|
17
17
|
export { TeamMemberService } from './team-member.service';
|
|
18
18
|
export { PermissionService } from './permission.service';
|
|
19
19
|
export { MembershipService, TeamMembership } from './membership.service';
|
|
20
|
-
export { ThemeService } from './theme.service';
|
|
20
|
+
export { ThemeService, getThemeAppConfig } from './theme.service';
|
|
21
21
|
export { EntityTypeService } from './entity-type.service';
|
|
22
22
|
export { NamespaceService } from './namespace.service';
|
|
23
|
-
export { MiddlewareService } from './middleware.service';
|
|
23
|
+
export { MiddlewareService, hasThemeMiddleware, executeThemeMiddleware, addUserHeadersMiddleware } from './middleware.service';
|
|
24
24
|
export { ScopeService } from './scope.service';
|
|
25
25
|
export { RouteHandlerService } from './route-handler.service';
|
|
26
26
|
export { PluginService, usePlugin } from './plugin.service';
|
|
27
27
|
export { ApiRoutesService } from './api-routes.service';
|
|
28
|
+
export { DocsService, getDocsRegistry, getAllDocs, getPublicDocs, getSuperadminDocs, findDocsSection, findDocsPage, searchDocs, } from './docs.service';
|
|
29
|
+
export { GenericEntityService } from './generic-entity.service';
|
|
30
|
+
export { PatternUsageService } from './pattern-usage.service';
|
|
31
|
+
export { TransactionalMetaService } from './transactional-meta.service';
|
|
28
32
|
export type { UpdateUserPayload } from './user.service';
|
|
29
33
|
export type { ListPlansOptions } from './plan.service';
|
|
30
34
|
export type { CreateSubscriptionOptions, ChangePlanResult } from './subscription.service';
|
|
@@ -40,4 +44,6 @@ export type { ScopeConfig, ApiConfig, RestrictionRule } from './scope.service';
|
|
|
40
44
|
export type { RouteHandler } from './route-handler.service';
|
|
41
45
|
export type { PluginRegistryEntry, RouteFileEndpoint, PluginEntity, PluginName, PluginConfig, RouteMetadata } from './plugin.service';
|
|
42
46
|
export type { ApiRouteEntry, RouteCategory } from './api-routes.service';
|
|
47
|
+
export type { GenericListOptions, GenericListResult } from './generic-entity.service';
|
|
48
|
+
export type { PatternUsage, PatternUsageWithEntityInfo, PatternUsageCount, GetUsagesOptions, GetUsagesResult } from './pattern-usage.service';
|
|
43
49
|
//# sourceMappingURL=index.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/services/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAA;AACxD,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/lib/services/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAA;AAC5D,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,cAAc,EAAE,MAAM,mBAAmB,CAAA;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAA;AACxD,OAAO,EAAE,iBAAiB,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AACxE,OAAO,EAAE,YAAY,EAAE,iBAAiB,EAAE,MAAM,iBAAiB,CAAA;AACjE,OAAO,EAAE,iBAAiB,EAAE,MAAM,uBAAuB,CAAA;AACzD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAA;AACtD,OAAO,EACL,iBAAiB,EACjB,kBAAkB,EAClB,sBAAsB,EACtB,wBAAwB,EACzB,MAAM,sBAAsB,CAAA;AAC7B,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAA;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAA;AAC7D,OAAO,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAA;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAA;AACvD,OAAO,EACL,WAAW,EACX,eAAe,EACf,UAAU,EACV,aAAa,EACb,iBAAiB,EACjB,eAAe,EACf,YAAY,EACZ,UAAU,GACX,MAAM,gBAAgB,CAAA;AACvB,OAAO,EAAE,oBAAoB,EAAE,MAAM,0BAA0B,CAAA;AAC/D,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAA;AAC7D,OAAO,EAAE,wBAAwB,EAAE,MAAM,8BAA8B,CAAA;AAGvE,YAAY,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AACvD,YAAY,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAA;AACtD,YAAY,EAAE,yBAAyB,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AACzF,YAAY,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,iBAAiB,CAAA;AAC7E,YAAY,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAA;AACtG,YAAY,EAAE,mBAAmB,EAAE,eAAe,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAA;AAC7F,YAAY,EAAE,kBAAkB,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AACjF,YAAY,EAAE,kBAAkB,EAAE,WAAW,EAAE,cAAc,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAA;AACjG,YAAY,EAAE,UAAU,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAA;AAC3F,YAAY,EAAE,oBAAoB,EAAE,eAAe,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAA;AAC/F,YAAY,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAA;AACnE,YAAY,EAAE,WAAW,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAA;AAC9E,YAAY,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAA;AAC3D,YAAY,EAAE,mBAAmB,EAAE,iBAAiB,EAAE,YAAY,EAAE,UAAU,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAA;AACrI,YAAY,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAA;AACxE,YAAY,EAAE,kBAAkB,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAA;AACrF,YAAY,EAAE,YAAY,EAAE,0BAA0B,EAAE,iBAAiB,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAA"}
|