@questpie/admin 1.1.1 → 3.0.0
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/README.md +256 -488
- package/dist/augmentation.d.mts +414 -0
- package/dist/client/blocks/block-renderer.d.mts +45 -0
- package/dist/client/blocks/block-renderer.mjs +105 -0
- package/dist/client/blocks/index.d.mts +2 -0
- package/dist/client/blocks/types.d.mts +68 -0
- package/dist/client/blocks/types.mjs +19 -0
- package/dist/client/builder/admin-types.d.mts +40 -0
- package/dist/client/builder/admin.d.mts +110 -0
- package/dist/client/builder/admin.mjs +151 -0
- package/dist/client/builder/field/field.d.mts +51 -0
- package/dist/client/builder/field/field.mjs +37 -0
- package/dist/client/builder/index.d.mts +31 -0
- package/dist/client/builder/page/page.d.mts +24 -0
- package/dist/client/builder/page/page.mjs +31 -0
- package/dist/client/builder/registry.d.mts +50 -0
- package/dist/client/builder/types/action-registry.mjs +276 -0
- package/dist/client/builder/types/action-types.d.mts +226 -0
- package/dist/client/builder/types/collection-types.mjs +10 -0
- package/dist/client/builder/types/common.d.mts +46 -0
- package/dist/client/builder/types/field-types.d.mts +592 -0
- package/dist/client/builder/types/field-types.mjs +18 -0
- package/dist/client/builder/types/ui-config.d.mts +158 -0
- package/dist/client/builder/types/widget-types.d.mts +562 -0
- package/dist/client/builder/validation.d.mts +33 -0
- package/dist/client/builder/validation.mjs +227 -0
- package/dist/client/builder/view/view.d.mts +49 -0
- package/dist/client/builder/view/view.mjs +27 -0
- package/dist/client/builder/widget/widget.d.mts +27 -0
- package/dist/client/builder/widget/widget.mjs +21 -0
- package/dist/client/components/actions/action-button.mjs +245 -0
- package/dist/client/components/actions/action-dialog.mjs +559 -0
- package/dist/client/components/actions/confirmation-dialog.mjs +201 -0
- package/dist/client/components/actions/header-actions.mjs +210 -0
- package/dist/client/components/admin-link.d.mts +66 -0
- package/dist/client/components/admin-link.mjs +171 -0
- package/dist/client/components/auth/auth-guard.d.mts +50 -0
- package/dist/client/components/auth/auth-guard.mjs +60 -0
- package/dist/client/components/auth/auth-loading.d.mts +35 -0
- package/dist/client/components/auth/auth-loading.mjs +55 -0
- package/dist/client/components/blocks/block-canvas.mjs +159 -0
- package/dist/client/components/blocks/block-editor-context.mjs +125 -0
- package/dist/client/components/blocks/block-editor-layout.mjs +199 -0
- package/dist/client/components/blocks/block-editor-provider.mjs +235 -0
- package/dist/client/components/blocks/block-fields-renderer.mjs +240 -0
- package/dist/client/components/blocks/block-insert-button.mjs +189 -0
- package/dist/client/components/blocks/block-item-menu.mjs +363 -0
- package/dist/client/components/blocks/block-item.mjs +434 -0
- package/dist/client/components/blocks/block-library-sidebar.mjs +285 -0
- package/dist/client/components/blocks/block-tree.mjs +103 -0
- package/dist/client/components/blocks/block-type-icon.mjs +95 -0
- package/dist/client/components/blocks/utils/tree-utils.mjs +185 -0
- package/dist/client/components/component-renderer.d.mts +114 -0
- package/dist/client/components/component-renderer.mjs +258 -0
- package/dist/client/components/error-boundary.mjs +144 -0
- package/dist/client/components/fields/array-field.mjs +506 -0
- package/dist/client/components/fields/asset-preview-field.mjs +159 -0
- package/dist/client/components/fields/blocks-field/blocks-field.mjs +209 -0
- package/dist/client/components/fields/boolean-field.mjs +77 -0
- package/dist/client/components/fields/date-field.mjs +76 -0
- package/dist/client/components/fields/datetime-field.mjs +74 -0
- package/dist/client/components/fields/email-field.mjs +67 -0
- package/dist/client/components/fields/field-utils.mjs +64 -0
- package/dist/client/components/fields/field-wrapper.mjs +124 -0
- package/dist/client/components/fields/json-field.mjs +461 -0
- package/dist/client/components/fields/locale-badge.mjs +25 -0
- package/dist/client/components/fields/number-field.mjs +73 -0
- package/dist/client/components/fields/object-array-field.mjs +707 -0
- package/dist/client/components/fields/object-field.mjs +686 -0
- package/dist/client/components/fields/relation/displays/cards-display.mjs +254 -0
- package/dist/client/components/fields/relation/displays/chips-display.mjs +173 -0
- package/dist/client/components/fields/relation/displays/grid-display.mjs +209 -0
- package/dist/client/components/fields/relation/displays/list-display.mjs +247 -0
- package/dist/client/components/fields/relation/displays/table-display.mjs +309 -0
- package/dist/client/components/fields/relation/displays/types.mjs +72 -0
- package/dist/client/components/fields/relation/relation-items-display.mjs +143 -0
- package/dist/client/components/fields/relation-field.mjs +161 -0
- package/dist/client/components/fields/relation-picker.mjs +296 -0
- package/dist/client/components/fields/relation-select.mjs +232 -0
- package/dist/client/components/fields/rich-text-editor/bubble-menu.mjs +105 -0
- package/dist/client/components/fields/rich-text-editor/extensions.mjs +144 -0
- package/dist/client/components/fields/rich-text-editor/image-popover.mjs +221 -0
- package/dist/client/components/fields/rich-text-editor/index.mjs +520 -0
- package/dist/client/components/fields/rich-text-editor/link-popover.mjs +85 -0
- package/dist/client/components/fields/rich-text-editor/presets.mjs +123 -0
- package/dist/client/components/fields/rich-text-editor/slash-commands.mjs +188 -0
- package/dist/client/components/fields/rich-text-editor/table-controls.mjs +433 -0
- package/dist/client/components/fields/rich-text-editor/toolbar.mjs +541 -0
- package/dist/client/components/fields/rich-text-editor/types.mjs +30 -0
- package/dist/client/components/fields/rich-text-editor/utils.mjs +50 -0
- package/dist/client/components/fields/rich-text-field.mjs +64 -0
- package/dist/client/components/fields/select-field.mjs +88 -0
- package/dist/client/components/fields/text-field.mjs +72 -0
- package/dist/client/components/fields/textarea-field.mjs +71 -0
- package/dist/client/components/fields/time-field.mjs +67 -0
- package/dist/client/components/fields/upload-field.mjs +621 -0
- package/dist/client/components/filter-builder/columns-tab.mjs +325 -0
- package/dist/client/components/filter-builder/filter-builder-sheet.mjs +456 -0
- package/dist/client/components/filter-builder/filters-tab.mjs +663 -0
- package/dist/client/components/filter-builder/saved-views-tab.mjs +278 -0
- package/dist/client/components/history-sidebar.mjs +496 -0
- package/dist/client/components/layout/field-layout-renderer.mjs +301 -0
- package/dist/client/components/locale-switcher.mjs +251 -0
- package/dist/client/components/media/media-grid.mjs +314 -0
- package/dist/client/components/media/media-picker-dialog.mjs +563 -0
- package/dist/client/components/preview/live-preview-mode.mjs +503 -0
- package/dist/client/components/preview/preview-pane.mjs +388 -0
- package/dist/client/components/primitives/asset-preview.mjs +771 -0
- package/dist/client/components/primitives/checkbox-input.mjs +59 -0
- package/dist/client/components/primitives/date-input.mjs +461 -0
- package/dist/client/components/primitives/dropzone.mjs +368 -0
- package/dist/client/components/primitives/number-input.mjs +117 -0
- package/dist/client/components/primitives/select-multi.mjs +590 -0
- package/dist/client/components/primitives/select-single.mjs +473 -0
- package/dist/client/components/primitives/text-input.mjs +45 -0
- package/dist/client/components/primitives/textarea-input.mjs +43 -0
- package/dist/client/components/primitives/time-input.mjs +145 -0
- package/dist/client/components/primitives/toggle-input.mjs +51 -0
- package/dist/client/components/primitives/types.mjs +12 -0
- package/dist/client/components/sheets/resource-sheet.mjs +86 -0
- package/dist/client/components/ui/accordion.mjs +169 -0
- package/dist/client/components/ui/alert.mjs +85 -0
- package/dist/client/components/ui/badge.mjs +76 -0
- package/dist/client/components/ui/button.mjs +84 -0
- package/dist/client/components/ui/card.mjs +206 -0
- package/dist/client/components/ui/checkbox.mjs +82 -0
- package/dist/client/components/ui/command.mjs +239 -0
- package/dist/client/components/ui/dialog.mjs +296 -0
- package/dist/client/components/ui/drawer.mjs +278 -0
- package/dist/client/components/ui/dropdown-menu.mjs +315 -0
- package/dist/client/components/ui/empty-state.mjs +99 -0
- package/dist/client/components/ui/field.mjs +354 -0
- package/dist/client/components/ui/input-group.mjs +201 -0
- package/dist/client/components/ui/input.mjs +46 -0
- package/dist/client/components/ui/kbd.mjs +53 -0
- package/dist/client/components/ui/label.mjs +45 -0
- package/dist/client/components/ui/popover.mjs +176 -0
- package/dist/client/components/ui/responsive-dialog.mjs +308 -0
- package/dist/client/components/ui/search-input.mjs +139 -0
- package/dist/client/components/ui/select.mjs +325 -0
- package/dist/client/components/ui/separator.mjs +47 -0
- package/dist/client/components/ui/sheet.mjs +280 -0
- package/dist/client/components/ui/sidebar.mjs +774 -0
- package/dist/client/components/ui/skeleton.mjs +40 -0
- package/dist/client/components/ui/sonner.d.mts +13 -0
- package/dist/client/components/ui/sonner.mjs +85 -0
- package/dist/client/components/ui/spinner.mjs +52 -0
- package/dist/client/components/ui/switch.mjs +58 -0
- package/dist/client/components/ui/table.mjs +276 -0
- package/dist/client/components/ui/tabs.mjs +160 -0
- package/dist/client/components/ui/textarea.mjs +40 -0
- package/dist/client/components/ui/toolbar.mjs +136 -0
- package/dist/client/components/ui/tooltip.mjs +146 -0
- package/dist/client/components/widgets/chart-widget.mjs +582 -0
- package/dist/client/components/widgets/progress-widget.mjs +200 -0
- package/dist/client/components/widgets/quick-actions-widget.mjs +209 -0
- package/dist/client/components/widgets/recent-items-widget.mjs +196 -0
- package/dist/client/components/widgets/stats-widget.mjs +261 -0
- package/dist/client/components/widgets/table-widget.mjs +273 -0
- package/dist/client/components/widgets/timeline-widget.mjs +279 -0
- package/dist/client/components/widgets/value-widget.mjs +312 -0
- package/dist/client/components/widgets/widget-skeletons.mjs +427 -0
- package/dist/client/contexts/breadcrumb-context.mjs +60 -0
- package/dist/client/contexts/focus-context.d.mts +87 -0
- package/dist/client/contexts/focus-context.mjs +250 -0
- package/dist/client/hooks/typed-hooks.d.mts +110 -0
- package/dist/client/hooks/typed-hooks.mjs +888 -0
- package/dist/client/hooks/use-action.mjs +329 -0
- package/dist/client/hooks/use-admin-config.mjs +69 -0
- package/dist/client/hooks/use-admin-preferences.mjs +171 -0
- package/dist/client/hooks/use-admin-routes.mjs +130 -0
- package/dist/client/hooks/use-audit-history.mjs +157 -0
- package/dist/client/hooks/use-auth.d.mts +97 -0
- package/dist/{use-auth-BoLmWtmU.mjs → client/hooks/use-auth.mjs} +9 -10
- package/dist/client/hooks/use-collection-fields.mjs +71 -0
- package/dist/client/hooks/use-collection-meta.mjs +153 -0
- package/dist/client/hooks/use-collection-schema.mjs +90 -0
- package/dist/client/hooks/use-collection-validation.mjs +88 -0
- package/dist/client/hooks/use-collection.d.mts +96 -0
- package/dist/client/hooks/use-collection.mjs +673 -0
- package/dist/client/hooks/use-current-user.d.mts +60 -0
- package/dist/client/hooks/use-current-user.mjs +79 -0
- package/dist/client/hooks/use-field-hooks.mjs +199 -0
- package/dist/client/hooks/use-field-options.d.mts +57 -0
- package/dist/client/hooks/use-field-options.mjs +269 -0
- package/dist/client/hooks/use-global-fields.mjs +58 -0
- package/dist/client/hooks/use-global-meta.mjs +105 -0
- package/dist/client/hooks/use-global-schema.mjs +53 -0
- package/dist/client/hooks/use-global.d.mts +51 -0
- package/dist/client/hooks/use-global.mjs +284 -0
- package/dist/client/hooks/use-locks.mjs +452 -0
- package/dist/client/hooks/use-media-query.d.mts +22 -0
- package/dist/client/hooks/use-media-query.mjs +81 -0
- package/dist/client/hooks/use-prefill-params.mjs +47 -0
- package/dist/client/hooks/use-questpie-query-options.mjs +50 -0
- package/dist/client/hooks/use-reactive-fields.d.mts +78 -0
- package/dist/client/hooks/use-reactive-fields.mjs +201 -0
- package/dist/client/hooks/use-realtime-highlight.mjs +158 -0
- package/dist/client/hooks/use-saved-views.mjs +140 -0
- package/dist/client/hooks/use-search-param-toggle.d.mts +12 -0
- package/dist/client/hooks/use-search-param-toggle.mjs +115 -0
- package/dist/client/hooks/use-search.mjs +258 -0
- package/dist/client/hooks/use-server-actions.mjs +191 -0
- package/dist/client/hooks/use-server-validation.mjs +291 -0
- package/dist/client/hooks/use-server-widget-data.d.mts +25 -0
- package/dist/client/hooks/use-server-widget-data.mjs +65 -0
- package/dist/client/hooks/use-setup-status.d.mts +38 -0
- package/dist/client/hooks/use-setup-status.mjs +62 -0
- package/dist/client/hooks/use-sidebar-search-param.d.mts +9 -0
- package/dist/client/hooks/use-sidebar-search-param.mjs +104 -0
- package/dist/client/hooks/use-transition-stage.mjs +125 -0
- package/dist/client/hooks/use-upload-collection.mjs +31 -0
- package/dist/client/hooks/use-upload.mjs +209 -0
- package/dist/client/hooks/use-validation-error-map.mjs +57 -0
- package/dist/client/hooks/use-view-state.mjs +479 -0
- package/dist/client/i18n/hooks.mjs +284 -0
- package/dist/client/i18n/intl-cache.mjs +64 -0
- package/dist/client/i18n/messages.mjs +6 -0
- package/dist/client/i18n/simple.d.mts +21 -0
- package/dist/client/i18n/simple.mjs +156 -0
- package/dist/client/i18n/types.d.mts +109 -0
- package/dist/client/lib/cookies.mjs +9 -0
- package/dist/client/lib/events.mjs +5 -0
- package/dist/client/lib/render-profiler.mjs +51 -0
- package/dist/client/lib/utils.mjs +23 -0
- package/dist/client/preview/block-scope-context.d.mts +73 -0
- package/dist/client/preview/block-scope-context.mjs +116 -0
- package/dist/client/preview/index.d.mts +5 -0
- package/dist/client/preview/preview-banner.d.mts +45 -0
- package/dist/client/preview/preview-banner.mjs +134 -0
- package/dist/client/preview/preview-field.d.mts +107 -0
- package/dist/client/preview/preview-field.mjs +227 -0
- package/dist/client/preview/types.d.mts +114 -0
- package/dist/client/preview/types.mjs +20 -0
- package/dist/client/preview/use-collection-preview.d.mts +70 -0
- package/dist/client/preview/use-collection-preview.mjs +163 -0
- package/dist/client/runtime/content-locales-provider.d.mts +1 -0
- package/dist/client/runtime/content-locales-provider.mjs +136 -0
- package/dist/client/runtime/index.d.mts +5 -0
- package/dist/client/runtime/index.mjs +6 -0
- package/dist/client/runtime/locale-scope.d.mts +2 -0
- package/dist/client/runtime/locale-scope.mjs +108 -0
- package/dist/client/runtime/provider.d.mts +203 -0
- package/dist/client/runtime/provider.mjs +393 -0
- package/dist/client/runtime/routes.d.mts +49 -0
- package/dist/client/runtime/routes.mjs +91 -0
- package/dist/client/runtime/translations-provider.mjs +242 -0
- package/dist/client/scope/index.d.mts +3 -0
- package/dist/client/scope/picker.d.mts +53 -0
- package/dist/client/scope/picker.mjs +395 -0
- package/dist/client/scope/provider.d.mts +103 -0
- package/dist/client/scope/provider.mjs +167 -0
- package/dist/client/scope/types.d.mts +111 -0
- package/dist/client/styles/index.css +344 -188
- package/dist/client/utils/auto-expand-fields.mjs +83 -0
- package/dist/client/utils/build-field-definitions-from-schema.mjs +259 -0
- package/dist/client/utils/dependency-tracker.mjs +61 -0
- package/dist/client/utils/detect-relations.mjs +45 -0
- package/dist/client/utils/locale-to-flag.d.mts +119 -0
- package/dist/client/utils/locale-to-flag.mjs +129 -0
- package/dist/client/utils/routes.mjs +195 -0
- package/dist/client/views/auth/accept-invite-form.d.mts +72 -0
- package/dist/client/views/auth/accept-invite-form.mjs +473 -0
- package/dist/client/views/auth/auth-layout.d.mts +43 -0
- package/dist/client/views/auth/auth-layout.mjs +116 -0
- package/dist/client/views/auth/forgot-password-form.d.mts +58 -0
- package/dist/client/views/auth/forgot-password-form.mjs +386 -0
- package/dist/client/views/auth/invite-form.mjs +497 -0
- package/dist/client/views/auth/login-form.d.mts +75 -0
- package/dist/client/views/auth/login-form.mjs +387 -0
- package/dist/client/views/auth/reset-password-form.d.mts +65 -0
- package/dist/client/views/auth/reset-password-form.mjs +515 -0
- package/dist/client/views/auth/setup-form.d.mts +60 -0
- package/dist/client/views/auth/setup-form.mjs +526 -0
- package/dist/client/views/collection/auto-form-fields.mjs +873 -0
- package/dist/client/views/collection/bulk-action-toolbar.mjs +480 -0
- package/dist/client/views/collection/cells/complex-cells.mjs +746 -0
- package/dist/client/views/collection/cells/primitive-cells.mjs +395 -0
- package/dist/client/views/collection/cells/relation-cells.mjs +260 -0
- package/dist/client/views/collection/cells/shared/asset-thumbnail.mjs +509 -0
- package/dist/client/views/collection/cells/shared/cell-helpers.mjs +125 -0
- package/dist/client/views/collection/cells/shared/relation-chip.mjs +121 -0
- package/dist/client/views/collection/cells/upload-cells.mjs +28 -0
- package/dist/client/views/collection/columns/build-columns.mjs +195 -0
- package/dist/client/views/collection/columns/column-defaults.mjs +123 -0
- package/dist/client/views/collection/field-context.mjs +126 -0
- package/dist/client/views/collection/field-renderer.mjs +368 -0
- package/dist/client/views/collection/form-view.mjs +1566 -0
- package/dist/client/views/collection/table-view.mjs +832 -0
- package/dist/client/views/collection/view-skeletons.mjs +215 -0
- package/dist/client/views/common/global-search.mjs +700 -0
- package/dist/client/views/dashboard/dashboard-grid.mjs +881 -0
- package/dist/client/views/dashboard/dashboard-widget.mjs +265 -0
- package/dist/client/views/dashboard/widget-card.mjs +372 -0
- package/dist/client/views/globals/global-form-view.mjs +1306 -0
- package/dist/client/views/layout/admin-layout-provider.d.mts +137 -0
- package/dist/client/views/layout/admin-layout-provider.mjs +193 -0
- package/dist/client/views/layout/admin-layout.d.mts +133 -0
- package/dist/client/views/layout/admin-layout.mjs +302 -0
- package/dist/client/views/layout/admin-router.d.mts +93 -0
- package/dist/client/views/layout/admin-router.mjs +1254 -0
- package/dist/client/views/layout/admin-sidebar.d.mts +99 -0
- package/dist/client/views/layout/admin-sidebar.mjs +1379 -0
- package/dist/client/views/layout/admin-topbar.mjs +236 -0
- package/dist/client/views/pages/accept-invite-page.d.mts +66 -0
- package/dist/client/views/pages/accept-invite-page.mjs +349 -0
- package/dist/client/views/pages/dashboard-page.d.mts +43 -0
- package/dist/client/views/pages/dashboard-page.mjs +84 -0
- package/dist/client/views/pages/forgot-password-page.d.mts +56 -0
- package/dist/client/views/pages/forgot-password-page.mjs +152 -0
- package/dist/client/views/pages/invite-page.d.mts +70 -0
- package/dist/client/views/pages/invite-page.mjs +161 -0
- package/dist/client/views/pages/login-page.d.mts +69 -0
- package/dist/client/views/pages/login-page.mjs +193 -0
- package/dist/client/views/pages/reset-password-page.d.mts +63 -0
- package/dist/client/views/pages/reset-password-page.mjs +257 -0
- package/dist/client/views/pages/setup-page.d.mts +61 -0
- package/dist/client/views/pages/setup-page.mjs +156 -0
- package/dist/client-module.d.mts +3 -0
- package/dist/client-module.mjs +3 -0
- package/dist/client.d.mts +99 -3
- package/dist/client.mjs +52 -12
- package/dist/components/rich-text/index.d.mts +1 -0
- package/dist/components/rich-text/rich-text-renderer.d.mts +103 -0
- package/dist/components/rich-text/rich-text-renderer.mjs +237 -0
- package/dist/index.d.mts +59 -3
- package/dist/index.mjs +52 -12
- package/dist/plugin.d.mts +2 -0
- package/dist/plugin.mjs +3 -0
- package/dist/server/adapters/nextjs.d.mts +120 -0
- package/dist/server/adapters/nextjs.mjs +110 -0
- package/dist/server/adapters/tanstack.d.mts +132 -0
- package/dist/server/adapters/tanstack.mjs +89 -0
- package/dist/server/augmentation/actions.d.mts +279 -0
- package/dist/server/augmentation/common.d.mts +76 -0
- package/dist/server/augmentation/dashboard.d.mts +547 -0
- package/dist/server/augmentation/form-layout.d.mts +303 -0
- package/dist/server/augmentation/index.d.mts +44 -0
- package/dist/server/augmentation/index.mjs +10 -0
- package/dist/server/augmentation/sidebar.d.mts +181 -0
- package/dist/server/augmentation/views.d.mts +237 -0
- package/dist/server/augmentation.d.mts +7 -0
- package/dist/server/block/index.d.mts +4 -0
- package/dist/server/codegen/admin-client-template.mjs +93 -0
- package/dist/server/codegen/projection-validator.mjs +67 -0
- package/dist/server/fields/blocks.d.mts +71 -0
- package/dist/server/fields/blocks.mjs +151 -0
- package/dist/server/fields/index.d.mts +15 -0
- package/dist/server/fields/index.mjs +15 -0
- package/dist/server/fields/rich-text.d.mts +68 -0
- package/dist/server/fields/rich-text.mjs +147 -0
- package/dist/server/i18n/index.mjs +43 -0
- package/dist/server/i18n/messages/cs.mjs +461 -0
- package/dist/server/i18n/messages/de.mjs +461 -0
- package/dist/server/i18n/messages/en.mjs +707 -0
- package/dist/server/i18n/messages/es.mjs +461 -0
- package/dist/server/i18n/messages/fr.mjs +461 -0
- package/dist/server/i18n/messages/index.mjs +23 -0
- package/dist/server/i18n/messages/pl.mjs +461 -0
- package/dist/server/i18n/messages/pt.mjs +464 -0
- package/dist/server/i18n/messages/sk.mjs +689 -0
- package/dist/server/modules/admin/.generated/module.d.mts +52 -0
- package/dist/server/modules/admin/.generated/module.mjs +78 -0
- package/dist/server/modules/admin/.generated/registries.d.mts +22 -0
- package/dist/server/modules/admin/auth-helpers.d.mts +142 -0
- package/dist/server/modules/admin/auth-helpers.mjs +107 -0
- package/dist/server/modules/admin/block/block-builder.d.mts +383 -0
- package/dist/server/modules/admin/block/block-builder.mjs +315 -0
- package/dist/server/modules/admin/block/index.d.mts +3 -0
- package/dist/server/modules/admin/block/introspection.d.mts +89 -0
- package/dist/server/modules/admin/block/introspection.mjs +100 -0
- package/dist/server/modules/admin/block/prefetch.d.mts +78 -0
- package/dist/server/modules/admin/block/prefetch.mjs +241 -0
- package/dist/server/modules/admin/client/.generated/module.d.mts +94 -0
- package/dist/server/modules/admin/client/.generated/module.mjs +91 -0
- package/dist/server/modules/admin/client/components/badge.d.mts +1 -0
- package/dist/server/modules/admin/client/components/icon.d.mts +1 -0
- package/dist/server/modules/admin/client/fields/array.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/array.mjs +12 -0
- package/dist/server/modules/admin/client/fields/assetPreview.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/assetPreview.mjs +18 -0
- package/dist/server/modules/admin/client/fields/blocks.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/blocks.mjs +12 -0
- package/dist/server/modules/admin/client/fields/boolean.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/boolean.mjs +12 -0
- package/dist/server/modules/admin/client/fields/date.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/date.mjs +12 -0
- package/dist/server/modules/admin/client/fields/datetime.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/datetime.mjs +12 -0
- package/dist/server/modules/admin/client/fields/email.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/email.mjs +12 -0
- package/dist/server/modules/admin/client/fields/json.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/json.mjs +11 -0
- package/dist/server/modules/admin/client/fields/number.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/number.mjs +12 -0
- package/dist/server/modules/admin/client/fields/object.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/object.mjs +12 -0
- package/dist/server/modules/admin/client/fields/relation.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/relation.mjs +12 -0
- package/dist/server/modules/admin/client/fields/richText.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/richText.mjs +11 -0
- package/dist/server/modules/admin/client/fields/select.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/select.mjs +12 -0
- package/dist/server/modules/admin/client/fields/text.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/text.mjs +12 -0
- package/dist/server/modules/admin/client/fields/textarea.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/textarea.mjs +12 -0
- package/dist/server/modules/admin/client/fields/time.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/time.mjs +12 -0
- package/dist/server/modules/admin/client/fields/upload.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/upload.mjs +12 -0
- package/dist/server/modules/admin/client/fields/url.d.mts +6 -0
- package/dist/server/modules/admin/client/fields/url.mjs +12 -0
- package/dist/server/modules/admin/client/index.d.mts +1 -0
- package/dist/server/modules/admin/client/pages/dashboard.d.mts +6 -0
- package/dist/server/modules/admin/client/pages/dashboard.mjs +11 -0
- package/dist/server/modules/admin/client/pages/forgotPassword.d.mts +6 -0
- package/dist/server/modules/admin/client/pages/forgotPassword.mjs +11 -0
- package/dist/server/modules/admin/client/pages/login.d.mts +6 -0
- package/dist/server/modules/admin/client/pages/login.mjs +11 -0
- package/dist/server/modules/admin/client/pages/resetPassword.d.mts +6 -0
- package/dist/server/modules/admin/client/pages/resetPassword.mjs +11 -0
- package/dist/server/modules/admin/client/pages/setup.d.mts +6 -0
- package/dist/server/modules/admin/client/pages/setup.mjs +11 -0
- package/dist/server/modules/admin/client/views/collection-form.mjs +10 -0
- package/dist/server/modules/admin/client/views/collection-table.mjs +10 -0
- package/dist/server/modules/admin/client/views/global-form.mjs +10 -0
- package/dist/server/modules/admin/client/widgets/chart.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/chart.mjs +7 -0
- package/dist/server/modules/admin/client/widgets/progress.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/progress.mjs +7 -0
- package/dist/server/modules/admin/client/widgets/quickActions.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/quickActions.mjs +7 -0
- package/dist/server/modules/admin/client/widgets/recentItems.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/recentItems.mjs +7 -0
- package/dist/server/modules/admin/client/widgets/stats.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/stats.mjs +7 -0
- package/dist/server/modules/admin/client/widgets/table.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/table.mjs +7 -0
- package/dist/server/modules/admin/client/widgets/timeline.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/timeline.mjs +7 -0
- package/dist/server/modules/admin/client/widgets/value.d.mts +6 -0
- package/dist/server/modules/admin/client/widgets/value.mjs +7 -0
- package/dist/server/modules/admin/collections/account.d.mts +77 -0
- package/dist/server/modules/admin/collections/account.mjs +23 -0
- package/dist/server/modules/admin/collections/admin-locks.d.mts +90 -0
- package/dist/server/modules/admin/collections/admin-locks.mjs +16 -0
- package/dist/server/modules/admin/collections/admin-preferences.d.mts +69 -0
- package/dist/server/modules/admin/collections/admin-preferences.mjs +16 -0
- package/dist/server/modules/admin/collections/admin-saved-views.d.mts +83 -0
- package/dist/server/modules/admin/collections/admin-saved-views.mjs +16 -0
- package/dist/server/modules/admin/collections/apikey.d.mts +99 -0
- package/dist/server/modules/admin/collections/apikey.mjs +15 -0
- package/dist/server/modules/admin/collections/assets.d.mts +72 -0
- package/dist/server/modules/admin/collections/assets.mjs +71 -0
- package/dist/server/modules/admin/collections/session.d.mts +69 -0
- package/dist/server/modules/admin/collections/session.mjs +15 -0
- package/dist/server/modules/admin/collections/user.d.mts +85 -0
- package/dist/server/modules/admin/collections/user.mjs +204 -0
- package/dist/server/modules/admin/collections/verification.d.mts +63 -0
- package/dist/server/modules/admin/collections/verification.mjs +15 -0
- package/dist/server/modules/admin/components/badge.d.mts +10 -0
- package/dist/server/modules/admin/components/badge.mjs +10 -0
- package/dist/server/modules/admin/components/icon.d.mts +9 -0
- package/dist/server/modules/admin/components/icon.mjs +11 -0
- package/dist/server/modules/admin/config/admin.mjs +34 -0
- package/dist/server/modules/admin/dto/admin-config.dto.mjs +102 -0
- package/dist/server/modules/admin/factories.mjs +172 -0
- package/dist/server/modules/admin/index.d.mts +1093 -0
- package/dist/server/modules/admin/index.mjs +26 -0
- package/dist/server/modules/admin/modules.mjs +11 -0
- package/dist/server/modules/admin/plugin.mjs +13 -0
- package/dist/server/modules/admin/routes/admin-config.d.mts +28 -0
- package/dist/server/modules/admin/routes/admin-config.mjs +552 -0
- package/dist/server/modules/admin/routes/execute-action.d.mts +92 -0
- package/dist/server/modules/admin/routes/execute-action.mjs +433 -0
- package/dist/server/modules/admin/routes/locales.d.mts +18 -0
- package/dist/server/modules/admin/routes/locales.mjs +69 -0
- package/dist/server/modules/admin/routes/preview.d.mts +80 -0
- package/dist/server/modules/admin/routes/preview.mjs +230 -0
- package/dist/server/modules/admin/routes/reactive.d.mts +74 -0
- package/dist/server/modules/admin/routes/reactive.mjs +350 -0
- package/dist/server/modules/admin/routes/route-helpers.d.mts +23 -0
- package/dist/server/modules/admin/routes/route-helpers.mjs +76 -0
- package/dist/server/modules/admin/routes/setup.d.mts +63 -0
- package/dist/server/modules/admin/routes/setup.mjs +114 -0
- package/dist/server/modules/admin/routes/translations.d.mts +26 -0
- package/dist/server/modules/admin/routes/translations.mjs +114 -0
- package/dist/server/modules/admin/routes/widget-data.d.mts +32 -0
- package/dist/server/modules/admin/routes/widget-data.mjs +62 -0
- package/dist/server/modules/admin/views/form.d.mts +8 -0
- package/dist/server/modules/admin/views/form.mjs +7 -0
- package/dist/server/modules/admin/views/global-form.d.mts +8 -0
- package/dist/server/modules/admin/views/global-form.mjs +7 -0
- package/dist/server/modules/admin/views/table.d.mts +8 -0
- package/dist/server/modules/admin/views/table.mjs +7 -0
- package/dist/server/modules/admin-preferences/collections/admin-preferences.mjs +37 -0
- package/dist/server/modules/admin-preferences/collections/locks.collection.mjs +55 -0
- package/dist/server/modules/admin-preferences/collections/saved-views.d.mts +99 -0
- package/dist/server/modules/admin-preferences/collections/saved-views.mjs +38 -0
- package/dist/server/modules/audit/.generated/module.d.mts +60 -0
- package/dist/server/modules/audit/.generated/module.mjs +30 -0
- package/dist/server/modules/audit/collections/audit-log.d.mts +214 -0
- package/dist/server/modules/audit/collections/audit-log.mjs +107 -0
- package/dist/server/modules/audit/config/admin.mjs +21 -0
- package/dist/server/modules/audit/config/app.mjs +262 -0
- package/dist/server/modules/audit/index.d.mts +2 -0
- package/dist/server/modules/audit/jobs/audit-cleanup.d.mts +13 -0
- package/dist/server/modules/audit/jobs/audit-cleanup.mjs +28 -0
- package/dist/server/plugin.d.mts +26 -0
- package/dist/server/plugin.mjs +385 -0
- package/dist/server/proxy-factories.d.mts +85 -0
- package/dist/server/proxy-factories.mjs +302 -0
- package/dist/server/registry-helpers.d.mts +83 -0
- package/dist/server/registry-helpers.mjs +104 -0
- package/dist/server.d.mts +33 -250
- package/dist/server.mjs +22 -832
- package/dist/shared/preview-utils.d.mts +53 -0
- package/dist/{preview-utils-BKQ9-TMa.mjs → shared/preview-utils.mjs} +2 -3
- package/dist/{saved-views.types-BMsz5mCy.d.mts → shared/types/saved-views.types.d.mts} +7 -2
- package/dist/shared.d.mts +3 -57
- package/dist/shared.mjs +1 -1
- package/package.json +56 -51
- package/skills/questpie-admin/SKILL.md +397 -0
- package/skills/questpie-admin/blocks/SKILL.md +305 -0
- package/skills/questpie-admin/custom-ui/SKILL.md +307 -0
- package/skills/questpie-admin/views/SKILL.md +442 -0
- package/dist/auth-layout-M8K8_q5R.mjs +0 -181
- package/dist/auth-layout-M8K8_q5R.mjs.map +0 -1
- package/dist/bulk-upload-dialog-D7w7W1Hl.mjs +0 -273
- package/dist/bulk-upload-dialog-D7w7W1Hl.mjs.map +0 -1
- package/dist/card-BKHjBQfw.mjs +0 -58
- package/dist/card-BKHjBQfw.mjs.map +0 -1
- package/dist/client-D1DqawtP.d.mts +0 -13403
- package/dist/client-D1DqawtP.d.mts.map +0 -1
- package/dist/client-njX1rZmi.mjs +0 -22612
- package/dist/client-njX1rZmi.mjs.map +0 -1
- package/dist/content-locales-provider-BXvuIgfg.mjs +0 -1650
- package/dist/content-locales-provider-BXvuIgfg.mjs.map +0 -1
- package/dist/dashboard-page-B4PGEdc2.mjs +0 -2500
- package/dist/dashboard-page-B4PGEdc2.mjs.map +0 -1
- package/dist/dashboard-page-mCY0pgZv.mjs +0 -3
- package/dist/dropzone-Do3awXKd.mjs +0 -634
- package/dist/dropzone-Do3awXKd.mjs.map +0 -1
- package/dist/forgot-password-page-Bcp-An4Y.mjs +0 -221
- package/dist/forgot-password-page-Bcp-An4Y.mjs.map +0 -1
- package/dist/forgot-password-page-CEwsdLwn.mjs +0 -3
- package/dist/index-B4H3amCD.d.mts +0 -2753
- package/dist/index-B4H3amCD.d.mts.map +0 -1
- package/dist/login-page-BUnpCbCa.mjs +0 -3
- package/dist/login-page-CP4gA-dl.mjs +0 -298
- package/dist/login-page-CP4gA-dl.mjs.map +0 -1
- package/dist/preview-utils-BKQ9-TMa.mjs.map +0 -1
- package/dist/reset-password-page-BqfDmLxA.mjs +0 -281
- package/dist/reset-password-page-BqfDmLxA.mjs.map +0 -1
- package/dist/reset-password-page-CufHz3h3.mjs +0 -3
- package/dist/runtime-6VZM878K.mjs +0 -69
- package/dist/runtime-6VZM878K.mjs.map +0 -1
- package/dist/saved-views.types-BMsz5mCy.d.mts.map +0 -1
- package/dist/server.d.mts.map +0 -1
- package/dist/server.mjs.map +0 -1
- package/dist/setup-page-BNNzt_Z6.mjs +0 -3
- package/dist/setup-page-YAP_fzqh.mjs +0 -264
- package/dist/setup-page-YAP_fzqh.mjs.map +0 -1
- package/dist/shared.d.mts.map +0 -1
- package/dist/use-auth-BoLmWtmU.mjs.map +0 -1
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
import { useResolveText, useTranslation } from "../../i18n/hooks.mjs";
|
|
2
|
+
import { cn } from "../../lib/utils.mjs";
|
|
3
|
+
import { selectClient, useAdminStore } from "../../runtime/provider.mjs";
|
|
4
|
+
import { resolveIconElement } from "../component-renderer.mjs";
|
|
5
|
+
import { Button } from "../ui/button.mjs";
|
|
6
|
+
import { LocaleBadge } from "./locale-badge.mjs";
|
|
7
|
+
import { useAdminConfig } from "../../hooks/use-admin-config.mjs";
|
|
8
|
+
import { SelectSingle } from "../primitives/select-single.mjs";
|
|
9
|
+
import { useCollectionItem } from "../../hooks/use-collection.mjs";
|
|
10
|
+
import { ResourceSheet } from "../sheets/resource-sheet.mjs";
|
|
11
|
+
import { Icon } from "@iconify/react";
|
|
12
|
+
import * as React from "react";
|
|
13
|
+
import { useQueryClient } from "@tanstack/react-query";
|
|
14
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
15
|
+
import { toast } from "sonner";
|
|
16
|
+
import { createQuestpieQueryOptions } from "@questpie/tanstack-query";
|
|
17
|
+
|
|
18
|
+
//#region src/client/components/fields/relation-select.tsx
|
|
19
|
+
/**
|
|
20
|
+
* RelationSelect Component
|
|
21
|
+
*
|
|
22
|
+
* Single relation field (one-to-one) with:
|
|
23
|
+
* - Searchable select dropdown to choose existing item
|
|
24
|
+
* - Plus button to create new related item (opens side sheet)
|
|
25
|
+
* - Edit button to modify selected item (opens side sheet)
|
|
26
|
+
* - Responsive: Popover on desktop, Drawer on mobile
|
|
27
|
+
*/
|
|
28
|
+
function RelationSelect({ name, value, onChange, targetCollection, label, filter, required, disabled, readOnly, placeholder, error, localized, locale, renderOption, renderValue }) {
|
|
29
|
+
"use no memo";
|
|
30
|
+
const { t } = useTranslation();
|
|
31
|
+
const resolveText = useResolveText();
|
|
32
|
+
const resolvedLabel = label ? resolveText(label) : void 0;
|
|
33
|
+
const resolvedPlaceholder = placeholder ? resolveText(placeholder) : void 0;
|
|
34
|
+
const labelText = resolvedLabel || targetCollection;
|
|
35
|
+
const selectLabel = t("relation.select", { name: labelText });
|
|
36
|
+
const noResultsLabel = t("relation.noResults", { name: labelText });
|
|
37
|
+
const createLabel = t("relation.createNew", { name: labelText });
|
|
38
|
+
const [isSheetOpen, setIsSheetOpen] = React.useState(false);
|
|
39
|
+
const [editingItemId, setEditingItemId] = React.useState();
|
|
40
|
+
const { data: serverConfig } = useAdminConfig();
|
|
41
|
+
const client = useAdminStore(selectClient);
|
|
42
|
+
const collectionIconRef = (serverConfig?.collections?.[targetCollection])?.icon;
|
|
43
|
+
const loadOptions = React.useCallback(async (search) => {
|
|
44
|
+
if (!client) return [];
|
|
45
|
+
try {
|
|
46
|
+
const options = {
|
|
47
|
+
limit: 50,
|
|
48
|
+
locale
|
|
49
|
+
};
|
|
50
|
+
if (search) options.search = search;
|
|
51
|
+
if (filter) options.where = filter({});
|
|
52
|
+
const response = await client.collections[targetCollection].find(options);
|
|
53
|
+
let docs;
|
|
54
|
+
if (response) if (response.docs) docs = response.docs;
|
|
55
|
+
else docs = [];
|
|
56
|
+
else docs = [];
|
|
57
|
+
return docs.map((item) => {
|
|
58
|
+
let label_0;
|
|
59
|
+
if (renderOption) label_0 = String(renderOption(item));
|
|
60
|
+
else if (item._title) label_0 = item._title;
|
|
61
|
+
else if (item.id) label_0 = item.id;
|
|
62
|
+
else label_0 = "";
|
|
63
|
+
return {
|
|
64
|
+
value: item.id,
|
|
65
|
+
label: label_0,
|
|
66
|
+
icon: resolveIconElement(collectionIconRef, { className: "size-3.5 text-muted-foreground" })
|
|
67
|
+
};
|
|
68
|
+
});
|
|
69
|
+
} catch (error_0) {
|
|
70
|
+
console.error("Failed to load relation options:", error_0);
|
|
71
|
+
toast.error(t("error.failedToLoadOptions"));
|
|
72
|
+
return [];
|
|
73
|
+
}
|
|
74
|
+
}, [
|
|
75
|
+
client,
|
|
76
|
+
targetCollection,
|
|
77
|
+
filter,
|
|
78
|
+
renderOption,
|
|
79
|
+
collectionIconRef,
|
|
80
|
+
locale,
|
|
81
|
+
t
|
|
82
|
+
]);
|
|
83
|
+
const queryClient = useQueryClient();
|
|
84
|
+
const queryOpts = React.useMemo(() => createQuestpieQueryOptions(client ?? {}, { keyPrefix: ["questpie", "collections"] }), [client]);
|
|
85
|
+
const refetch = React.useCallback(async () => {
|
|
86
|
+
queryClient.invalidateQueries({ queryKey: queryOpts.key([
|
|
87
|
+
"collections",
|
|
88
|
+
targetCollection,
|
|
89
|
+
"find"
|
|
90
|
+
]) });
|
|
91
|
+
queryClient.invalidateQueries({ queryKey: queryOpts.key([
|
|
92
|
+
"collections",
|
|
93
|
+
targetCollection,
|
|
94
|
+
"findOne",
|
|
95
|
+
{ where: { id: value || "" } }
|
|
96
|
+
]) });
|
|
97
|
+
}, [
|
|
98
|
+
queryClient,
|
|
99
|
+
queryOpts,
|
|
100
|
+
targetCollection,
|
|
101
|
+
value
|
|
102
|
+
]);
|
|
103
|
+
const { data: selectedItem } = useCollectionItem(targetCollection, value || "", void 0, { enabled: !!value });
|
|
104
|
+
const selectedOptions = React.useMemo(() => {
|
|
105
|
+
if (!selectedItem) return [];
|
|
106
|
+
return [{
|
|
107
|
+
value: selectedItem.id,
|
|
108
|
+
label: renderValue ? String(renderValue(selectedItem)) : selectedItem._title || selectedItem.id || "",
|
|
109
|
+
icon: resolveIconElement(collectionIconRef, { className: "size-3.5 text-muted-foreground" })
|
|
110
|
+
}];
|
|
111
|
+
}, [
|
|
112
|
+
selectedItem,
|
|
113
|
+
renderValue,
|
|
114
|
+
collectionIconRef
|
|
115
|
+
]);
|
|
116
|
+
const handleOpenCreate = () => {
|
|
117
|
+
setEditingItemId(void 0);
|
|
118
|
+
setIsSheetOpen(true);
|
|
119
|
+
};
|
|
120
|
+
const handleOpenEdit = () => {
|
|
121
|
+
if (!value) return;
|
|
122
|
+
setEditingItemId(value);
|
|
123
|
+
setIsSheetOpen(true);
|
|
124
|
+
};
|
|
125
|
+
const handleValueChange = (newValue) => {
|
|
126
|
+
onChange(newValue);
|
|
127
|
+
};
|
|
128
|
+
const handleSheetSave = React.useCallback(async (result) => {
|
|
129
|
+
if (!editingItemId && result?.id) onChange(result.id);
|
|
130
|
+
await refetch();
|
|
131
|
+
}, [
|
|
132
|
+
editingItemId,
|
|
133
|
+
onChange,
|
|
134
|
+
refetch
|
|
135
|
+
]);
|
|
136
|
+
return /* @__PURE__ */ jsxs("div", {
|
|
137
|
+
className: "qa-relation-select space-y-2",
|
|
138
|
+
children: [
|
|
139
|
+
label && /* @__PURE__ */ jsxs("div", {
|
|
140
|
+
className: "flex items-center gap-2",
|
|
141
|
+
children: [/* @__PURE__ */ jsxs("label", {
|
|
142
|
+
htmlFor: name,
|
|
143
|
+
className: "flex items-center gap-1.5 text-sm font-medium",
|
|
144
|
+
children: [
|
|
145
|
+
resolveIconElement(collectionIconRef, { className: "size-3.5 text-muted-foreground" }),
|
|
146
|
+
resolvedLabel,
|
|
147
|
+
required && /* @__PURE__ */ jsx("span", {
|
|
148
|
+
className: "text-destructive",
|
|
149
|
+
children: "*"
|
|
150
|
+
})
|
|
151
|
+
]
|
|
152
|
+
}), localized && /* @__PURE__ */ jsx(LocaleBadge, { locale: locale || "i18n" })]
|
|
153
|
+
}),
|
|
154
|
+
/* @__PURE__ */ jsxs("div", {
|
|
155
|
+
className: "flex items-stretch gap-0",
|
|
156
|
+
children: [/* @__PURE__ */ jsx("div", {
|
|
157
|
+
className: "min-w-0 flex-1",
|
|
158
|
+
children: /* @__PURE__ */ jsx(SelectSingle, {
|
|
159
|
+
id: name,
|
|
160
|
+
value: value || null,
|
|
161
|
+
onChange: handleValueChange,
|
|
162
|
+
options: selectedOptions,
|
|
163
|
+
loadOptions,
|
|
164
|
+
queryKey: (search_0) => queryOpts.key([
|
|
165
|
+
"collections",
|
|
166
|
+
targetCollection,
|
|
167
|
+
"find",
|
|
168
|
+
{
|
|
169
|
+
limit: 50,
|
|
170
|
+
locale,
|
|
171
|
+
search: search_0,
|
|
172
|
+
where: filter ? filter({}) : void 0
|
|
173
|
+
}
|
|
174
|
+
]),
|
|
175
|
+
prefetchOnMount: true,
|
|
176
|
+
placeholder: resolvedPlaceholder || `${selectLabel}...`,
|
|
177
|
+
disabled: disabled || readOnly,
|
|
178
|
+
clearable: !required,
|
|
179
|
+
emptyMessage: noResultsLabel,
|
|
180
|
+
drawerTitle: selectLabel,
|
|
181
|
+
className: cn(!readOnly && "rounded-r-none", error && "border-destructive"),
|
|
182
|
+
"aria-invalid": !!error
|
|
183
|
+
})
|
|
184
|
+
}), !readOnly && /* @__PURE__ */ jsxs("div", {
|
|
185
|
+
className: "flex",
|
|
186
|
+
children: [value && /* @__PURE__ */ jsx(Button, {
|
|
187
|
+
type: "button",
|
|
188
|
+
variant: "outline",
|
|
189
|
+
size: "icon",
|
|
190
|
+
onClick: handleOpenEdit,
|
|
191
|
+
disabled,
|
|
192
|
+
title: t("collection.edit", { name: labelText }),
|
|
193
|
+
"aria-label": t("collection.edit", { name: labelText }),
|
|
194
|
+
className: "rounded-none border-l-0",
|
|
195
|
+
children: /* @__PURE__ */ jsx(Icon, {
|
|
196
|
+
icon: "ph:pencil",
|
|
197
|
+
className: "h-4 w-4"
|
|
198
|
+
})
|
|
199
|
+
}), /* @__PURE__ */ jsx(Button, {
|
|
200
|
+
type: "button",
|
|
201
|
+
variant: "outline",
|
|
202
|
+
size: "icon",
|
|
203
|
+
onClick: handleOpenCreate,
|
|
204
|
+
disabled,
|
|
205
|
+
title: createLabel,
|
|
206
|
+
"aria-label": createLabel,
|
|
207
|
+
className: "rounded-l-none border-l-0",
|
|
208
|
+
children: /* @__PURE__ */ jsx(Icon, {
|
|
209
|
+
icon: "ph:plus",
|
|
210
|
+
className: "h-4 w-4"
|
|
211
|
+
})
|
|
212
|
+
})]
|
|
213
|
+
})]
|
|
214
|
+
}),
|
|
215
|
+
error && /* @__PURE__ */ jsx("p", {
|
|
216
|
+
className: "text-destructive text-sm",
|
|
217
|
+
children: error
|
|
218
|
+
}),
|
|
219
|
+
/* @__PURE__ */ jsx(ResourceSheet, {
|
|
220
|
+
type: "collection",
|
|
221
|
+
collection: targetCollection,
|
|
222
|
+
itemId: editingItemId,
|
|
223
|
+
open: isSheetOpen,
|
|
224
|
+
onOpenChange: setIsSheetOpen,
|
|
225
|
+
onSave: handleSheetSave
|
|
226
|
+
})
|
|
227
|
+
]
|
|
228
|
+
});
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
//#endregion
|
|
232
|
+
export { RelationSelect };
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { useTranslation } from "../../../i18n/hooks.mjs";
|
|
2
|
+
import { EDITOR_ICONS, ToolbarButton } from "./toolbar.mjs";
|
|
3
|
+
import { c } from "react/compiler-runtime";
|
|
4
|
+
import "react";
|
|
5
|
+
import { jsx, jsxs } from "react/jsx-runtime";
|
|
6
|
+
import { BubbleMenu } from "@tiptap/react";
|
|
7
|
+
|
|
8
|
+
//#region src/client/components/fields/rich-text-editor/bubble-menu.tsx
|
|
9
|
+
/**
|
|
10
|
+
* Bubble menu that appears on text selection
|
|
11
|
+
*/
|
|
12
|
+
function RichTextBubbleMenu(t0) {
|
|
13
|
+
const $ = c(27);
|
|
14
|
+
const { editor, features, disabled, onLinkClick } = t0;
|
|
15
|
+
const { t } = useTranslation();
|
|
16
|
+
const isEditable = !disabled;
|
|
17
|
+
let t1;
|
|
18
|
+
if ($[0] !== editor || $[1] !== features.bold || $[2] !== isEditable || $[3] !== t) {
|
|
19
|
+
t1 = features.bold && /* @__PURE__ */ jsx(ToolbarButton, {
|
|
20
|
+
icon: EDITOR_ICONS.bold,
|
|
21
|
+
active: editor.isActive("bold"),
|
|
22
|
+
disabled: !isEditable,
|
|
23
|
+
title: t("editor.bold"),
|
|
24
|
+
shortcut: "⌘B",
|
|
25
|
+
onClick: () => editor.chain().focus().toggleBold().run()
|
|
26
|
+
});
|
|
27
|
+
$[0] = editor;
|
|
28
|
+
$[1] = features.bold;
|
|
29
|
+
$[2] = isEditable;
|
|
30
|
+
$[3] = t;
|
|
31
|
+
$[4] = t1;
|
|
32
|
+
} else t1 = $[4];
|
|
33
|
+
let t2;
|
|
34
|
+
if ($[5] !== editor || $[6] !== features.italic || $[7] !== isEditable || $[8] !== t) {
|
|
35
|
+
t2 = features.italic && /* @__PURE__ */ jsx(ToolbarButton, {
|
|
36
|
+
icon: EDITOR_ICONS.italic,
|
|
37
|
+
active: editor.isActive("italic"),
|
|
38
|
+
disabled: !isEditable,
|
|
39
|
+
title: t("editor.italic"),
|
|
40
|
+
shortcut: "⌘I",
|
|
41
|
+
onClick: () => editor.chain().focus().toggleItalic().run()
|
|
42
|
+
});
|
|
43
|
+
$[5] = editor;
|
|
44
|
+
$[6] = features.italic;
|
|
45
|
+
$[7] = isEditable;
|
|
46
|
+
$[8] = t;
|
|
47
|
+
$[9] = t2;
|
|
48
|
+
} else t2 = $[9];
|
|
49
|
+
let t3;
|
|
50
|
+
if ($[10] !== editor || $[11] !== features.underline || $[12] !== isEditable || $[13] !== t) {
|
|
51
|
+
t3 = features.underline && /* @__PURE__ */ jsx(ToolbarButton, {
|
|
52
|
+
icon: EDITOR_ICONS.underline,
|
|
53
|
+
active: editor.isActive("underline"),
|
|
54
|
+
disabled: !isEditable,
|
|
55
|
+
title: t("editor.underline"),
|
|
56
|
+
shortcut: "⌘U",
|
|
57
|
+
onClick: () => editor.chain().focus().toggleUnderline().run()
|
|
58
|
+
});
|
|
59
|
+
$[10] = editor;
|
|
60
|
+
$[11] = features.underline;
|
|
61
|
+
$[12] = isEditable;
|
|
62
|
+
$[13] = t;
|
|
63
|
+
$[14] = t3;
|
|
64
|
+
} else t3 = $[14];
|
|
65
|
+
let t4;
|
|
66
|
+
if ($[15] !== editor || $[16] !== features.link || $[17] !== isEditable || $[18] !== onLinkClick || $[19] !== t) {
|
|
67
|
+
t4 = features.link && /* @__PURE__ */ jsx(ToolbarButton, {
|
|
68
|
+
icon: EDITOR_ICONS.link,
|
|
69
|
+
active: editor.isActive("link"),
|
|
70
|
+
disabled: !isEditable,
|
|
71
|
+
title: t("editor.link"),
|
|
72
|
+
shortcut: "⌘K",
|
|
73
|
+
onClick: onLinkClick
|
|
74
|
+
});
|
|
75
|
+
$[15] = editor;
|
|
76
|
+
$[16] = features.link;
|
|
77
|
+
$[17] = isEditable;
|
|
78
|
+
$[18] = onLinkClick;
|
|
79
|
+
$[19] = t;
|
|
80
|
+
$[20] = t4;
|
|
81
|
+
} else t4 = $[20];
|
|
82
|
+
let t5;
|
|
83
|
+
if ($[21] !== editor || $[22] !== t1 || $[23] !== t2 || $[24] !== t3 || $[25] !== t4) {
|
|
84
|
+
t5 = /* @__PURE__ */ jsxs(BubbleMenu, {
|
|
85
|
+
editor,
|
|
86
|
+
className: "bg-background flex items-center gap-1 border p-1 shadow-lg",
|
|
87
|
+
children: [
|
|
88
|
+
t1,
|
|
89
|
+
t2,
|
|
90
|
+
t3,
|
|
91
|
+
t4
|
|
92
|
+
]
|
|
93
|
+
});
|
|
94
|
+
$[21] = editor;
|
|
95
|
+
$[22] = t1;
|
|
96
|
+
$[23] = t2;
|
|
97
|
+
$[24] = t3;
|
|
98
|
+
$[25] = t4;
|
|
99
|
+
$[26] = t5;
|
|
100
|
+
} else t5 = $[26];
|
|
101
|
+
return t5;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
//#endregion
|
|
105
|
+
export { RichTextBubbleMenu };
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
import { createSlashCommandExtension } from "./slash-commands.mjs";
|
|
2
|
+
import CharacterCount from "@tiptap/extension-character-count";
|
|
3
|
+
import Image from "@tiptap/extension-image";
|
|
4
|
+
import Link from "@tiptap/extension-link";
|
|
5
|
+
import Placeholder from "@tiptap/extension-placeholder";
|
|
6
|
+
import Table from "@tiptap/extension-table";
|
|
7
|
+
import TableCell from "@tiptap/extension-table-cell";
|
|
8
|
+
import TableHeader from "@tiptap/extension-table-header";
|
|
9
|
+
import TableRow from "@tiptap/extension-table-row";
|
|
10
|
+
import TextAlign from "@tiptap/extension-text-align";
|
|
11
|
+
import Underline from "@tiptap/extension-underline";
|
|
12
|
+
import StarterKit from "@tiptap/starter-kit";
|
|
13
|
+
|
|
14
|
+
//#region src/client/components/fields/rich-text-editor/extensions.tsx
|
|
15
|
+
let codeBlockExtension = null;
|
|
16
|
+
let codeBlockLoadPromise = null;
|
|
17
|
+
/**
|
|
18
|
+
* Returns the cached CodeBlockLowlight extension synchronously if already
|
|
19
|
+
* loaded, otherwise starts a single shared fetch and returns the promise.
|
|
20
|
+
*/
|
|
21
|
+
function getCodeBlockExtension() {
|
|
22
|
+
if (codeBlockExtension) return codeBlockExtension;
|
|
23
|
+
if (!codeBlockLoadPromise) codeBlockLoadPromise = Promise.all([import("@tiptap/extension-code-block-lowlight"), import("lowlight")]).then(([{ default: CodeBlockLowlight }, { common, createLowlight }]) => {
|
|
24
|
+
const lowlight = createLowlight(common);
|
|
25
|
+
codeBlockExtension = CodeBlockLowlight.configure({ lowlight });
|
|
26
|
+
return codeBlockExtension;
|
|
27
|
+
});
|
|
28
|
+
return codeBlockLoadPromise;
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Build Tiptap extensions based on feature configuration.
|
|
32
|
+
*
|
|
33
|
+
* Returns **synchronously** (`AnyExtension[]`) when no async deps are needed
|
|
34
|
+
* (i.e. codeBlock disabled, or lowlight already cached). Only returns a
|
|
35
|
+
* `Promise` on the first build that includes codeBlock.
|
|
36
|
+
*/
|
|
37
|
+
function buildExtensions({ features, placeholder, maxCharacters, customExtensions }) {
|
|
38
|
+
const base = buildBaseExtensions({
|
|
39
|
+
features,
|
|
40
|
+
placeholder,
|
|
41
|
+
maxCharacters,
|
|
42
|
+
customExtensions
|
|
43
|
+
});
|
|
44
|
+
if (!features.codeBlock) return base;
|
|
45
|
+
const codeBlock = getCodeBlockExtension();
|
|
46
|
+
if (!(codeBlock instanceof Promise)) return [...base, codeBlock];
|
|
47
|
+
return codeBlock.then((ext) => [...base, ext]);
|
|
48
|
+
}
|
|
49
|
+
function buildBaseExtensions({ features, placeholder, maxCharacters, customExtensions }) {
|
|
50
|
+
const starterKitConfig = { codeBlock: false };
|
|
51
|
+
if (!features.bold) starterKitConfig.bold = false;
|
|
52
|
+
if (!features.italic) starterKitConfig.italic = false;
|
|
53
|
+
if (!features.strike) starterKitConfig.strike = false;
|
|
54
|
+
if (!features.code) starterKitConfig.code = false;
|
|
55
|
+
if (!features.blockquote) starterKitConfig.blockquote = false;
|
|
56
|
+
if (!features.heading) starterKitConfig.heading = false;
|
|
57
|
+
if (!features.bulletList) starterKitConfig.bulletList = false;
|
|
58
|
+
if (!features.orderedList) starterKitConfig.orderedList = false;
|
|
59
|
+
if (!features.bulletList && !features.orderedList) starterKitConfig.listItem = false;
|
|
60
|
+
if (!features.horizontalRule) starterKitConfig.horizontalRule = false;
|
|
61
|
+
if (!features.history) starterKitConfig.history = false;
|
|
62
|
+
const extensions = [StarterKit.configure(starterKitConfig), Placeholder.configure({ placeholder: placeholder || "Start writing..." })];
|
|
63
|
+
if (features.underline) extensions.push(Underline);
|
|
64
|
+
if (features.link) extensions.push(Link.configure({
|
|
65
|
+
openOnClick: false,
|
|
66
|
+
autolink: true,
|
|
67
|
+
linkOnPaste: true
|
|
68
|
+
}));
|
|
69
|
+
if (features.align) extensions.push(TextAlign.configure({ types: ["heading", "paragraph"] }));
|
|
70
|
+
if (features.image) extensions.push(Image);
|
|
71
|
+
if (features.table) extensions.push(Table.configure({ resizable: true }), TableRow, TableHeader, TableCell);
|
|
72
|
+
if (features.characterCount && maxCharacters) extensions.push(CharacterCount.configure({ limit: maxCharacters }));
|
|
73
|
+
if (features.slashCommands) extensions.push(createSlashCommandExtension((editor) => {
|
|
74
|
+
const commands = [];
|
|
75
|
+
if (features.heading) commands.push({
|
|
76
|
+
title: "Heading 1",
|
|
77
|
+
description: "Large section heading",
|
|
78
|
+
keywords: ["h1"],
|
|
79
|
+
command: (cmdEditor) => cmdEditor.chain().focus().toggleHeading({ level: 1 }).run()
|
|
80
|
+
}, {
|
|
81
|
+
title: "Heading 2",
|
|
82
|
+
description: "Medium section heading",
|
|
83
|
+
keywords: ["h2"],
|
|
84
|
+
command: (cmdEditor) => cmdEditor.chain().focus().toggleHeading({ level: 2 }).run()
|
|
85
|
+
}, {
|
|
86
|
+
title: "Heading 3",
|
|
87
|
+
description: "Small section heading",
|
|
88
|
+
keywords: ["h3"],
|
|
89
|
+
command: (cmdEditor) => cmdEditor.chain().focus().toggleHeading({ level: 3 }).run()
|
|
90
|
+
});
|
|
91
|
+
commands.push({
|
|
92
|
+
title: "Paragraph",
|
|
93
|
+
description: "Start with plain text",
|
|
94
|
+
keywords: ["text"],
|
|
95
|
+
command: (cmdEditor) => cmdEditor.chain().focus().setParagraph().run()
|
|
96
|
+
});
|
|
97
|
+
if (features.bulletList) commands.push({
|
|
98
|
+
title: "Bullet list",
|
|
99
|
+
description: "Create a bulleted list",
|
|
100
|
+
keywords: ["list", "ul"],
|
|
101
|
+
command: (cmdEditor) => cmdEditor.chain().focus().toggleBulletList().run()
|
|
102
|
+
});
|
|
103
|
+
if (features.orderedList) commands.push({
|
|
104
|
+
title: "Numbered list",
|
|
105
|
+
description: "Create an ordered list",
|
|
106
|
+
keywords: ["list", "ol"],
|
|
107
|
+
command: (cmdEditor) => cmdEditor.chain().focus().toggleOrderedList().run()
|
|
108
|
+
});
|
|
109
|
+
if (features.blockquote) commands.push({
|
|
110
|
+
title: "Quote",
|
|
111
|
+
description: "Capture a quote",
|
|
112
|
+
keywords: ["blockquote"],
|
|
113
|
+
command: (cmdEditor) => cmdEditor.chain().focus().toggleBlockquote().run()
|
|
114
|
+
});
|
|
115
|
+
if (features.codeBlock) commands.push({
|
|
116
|
+
title: "Code block",
|
|
117
|
+
description: "Insert code snippet",
|
|
118
|
+
keywords: ["code"],
|
|
119
|
+
command: (cmdEditor) => cmdEditor.chain().focus().toggleCodeBlock().run()
|
|
120
|
+
});
|
|
121
|
+
if (features.horizontalRule) commands.push({
|
|
122
|
+
title: "Divider",
|
|
123
|
+
description: "Insert a horizontal rule",
|
|
124
|
+
keywords: ["hr"],
|
|
125
|
+
command: (cmdEditor) => cmdEditor.chain().focus().setHorizontalRule().run()
|
|
126
|
+
});
|
|
127
|
+
if (features.table) commands.push({
|
|
128
|
+
title: "Table",
|
|
129
|
+
description: "Insert a 3x3 table",
|
|
130
|
+
keywords: ["grid"],
|
|
131
|
+
command: (cmdEditor) => cmdEditor.chain().focus().insertTable({
|
|
132
|
+
rows: 3,
|
|
133
|
+
cols: 3,
|
|
134
|
+
withHeaderRow: true
|
|
135
|
+
}).run()
|
|
136
|
+
});
|
|
137
|
+
return commands;
|
|
138
|
+
}));
|
|
139
|
+
if (customExtensions?.length) extensions.push(...customExtensions);
|
|
140
|
+
return extensions;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
//#endregion
|
|
144
|
+
export { buildExtensions };
|
|
@@ -0,0 +1,221 @@
|
|
|
1
|
+
import { useTranslation } from "../../../i18n/hooks.mjs";
|
|
2
|
+
import { Button } from "../../ui/button.mjs";
|
|
3
|
+
import { Input } from "../../ui/input.mjs";
|
|
4
|
+
import { sanitizeFilename } from "../field-utils.mjs";
|
|
5
|
+
import { Popover, PopoverContent, PopoverHeader, PopoverTitle, PopoverTrigger } from "../../ui/popover.mjs";
|
|
6
|
+
import { useCollectionItem } from "../../../hooks/use-collection.mjs";
|
|
7
|
+
import { useUploadCollection } from "../../../hooks/use-upload-collection.mjs";
|
|
8
|
+
import { useUpload } from "../../../hooks/use-upload.mjs";
|
|
9
|
+
import { MediaPickerDialog } from "../../media/media-picker-dialog.mjs";
|
|
10
|
+
import * as React from "react";
|
|
11
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
12
|
+
import { toast } from "sonner";
|
|
13
|
+
|
|
14
|
+
//#region src/client/components/fields/rich-text-editor/image-popover.tsx
|
|
15
|
+
/**
|
|
16
|
+
* Image insertion popover
|
|
17
|
+
*/
|
|
18
|
+
function ImagePopover({ editor, open, onOpenChange, disabled, onImageUpload, imageCollection, enableMediaLibrary }) {
|
|
19
|
+
"use no memo";
|
|
20
|
+
const { t } = useTranslation();
|
|
21
|
+
const [imageUrl, setImageUrl] = React.useState("");
|
|
22
|
+
const [imageAlt, setImageAlt] = React.useState("");
|
|
23
|
+
const [uploadingImage, setUploadingImage] = React.useState(false);
|
|
24
|
+
const fileInputRef = React.useRef(null);
|
|
25
|
+
const [isPickerOpen, setIsPickerOpen] = React.useState(false);
|
|
26
|
+
const [selectedAssetId, setSelectedAssetId] = React.useState(null);
|
|
27
|
+
const { upload } = useUpload();
|
|
28
|
+
const { collection, collections: availableUploadCollections } = useUploadCollection(imageCollection);
|
|
29
|
+
const showMediaLibrary = enableMediaLibrary ?? true;
|
|
30
|
+
const { data: selectedAsset } = useCollectionItem(collection || "", selectedAssetId || "", void 0, { enabled: !!collection && !!selectedAssetId });
|
|
31
|
+
const handleInsertImageUrl = React.useCallback(() => {
|
|
32
|
+
if (!editor || !imageUrl) return;
|
|
33
|
+
editor.chain().focus().setImage({
|
|
34
|
+
src: imageUrl,
|
|
35
|
+
alt: imageAlt || void 0
|
|
36
|
+
}).run();
|
|
37
|
+
setImageUrl("");
|
|
38
|
+
setImageAlt("");
|
|
39
|
+
onOpenChange(false);
|
|
40
|
+
}, [
|
|
41
|
+
editor,
|
|
42
|
+
imageAlt,
|
|
43
|
+
imageUrl,
|
|
44
|
+
onOpenChange
|
|
45
|
+
]);
|
|
46
|
+
const handleImageUpload = React.useCallback(async (event) => {
|
|
47
|
+
const file = event.target.files?.[0];
|
|
48
|
+
if (!file || !editor) return;
|
|
49
|
+
try {
|
|
50
|
+
setUploadingImage(true);
|
|
51
|
+
let url;
|
|
52
|
+
if (onImageUpload) url = await onImageUpload(file);
|
|
53
|
+
else {
|
|
54
|
+
if (!collection) {
|
|
55
|
+
let errorMessage;
|
|
56
|
+
if (availableUploadCollections.length > 1) errorMessage = `Multiple upload collections are available (${availableUploadCollections.join(", ")}). Configure rich-text imageCollection to choose one.`;
|
|
57
|
+
else errorMessage = "No upload collection is configured for rich-text image uploads.";
|
|
58
|
+
toast.error(errorMessage);
|
|
59
|
+
setUploadingImage(false);
|
|
60
|
+
event.target.value = "";
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const sanitizedName = sanitizeFilename(file.name);
|
|
64
|
+
let uploadFile;
|
|
65
|
+
if (sanitizedName === file.name) uploadFile = file;
|
|
66
|
+
else uploadFile = new File([file], sanitizedName, { type: file.type });
|
|
67
|
+
const uploadedAsset = await upload(uploadFile, { to: collection });
|
|
68
|
+
if (uploadedAsset) {
|
|
69
|
+
if (uploadedAsset.url) url = uploadedAsset.url;
|
|
70
|
+
}
|
|
71
|
+
if (!url) {
|
|
72
|
+
toast.error(t("upload.error"));
|
|
73
|
+
setUploadingImage(false);
|
|
74
|
+
event.target.value = "";
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
if (url) {
|
|
79
|
+
let altValue;
|
|
80
|
+
if (imageAlt) altValue = imageAlt;
|
|
81
|
+
else altValue = void 0;
|
|
82
|
+
editor.chain().focus().setImage({
|
|
83
|
+
src: url,
|
|
84
|
+
alt: altValue
|
|
85
|
+
}).run();
|
|
86
|
+
setImageUrl("");
|
|
87
|
+
setImageAlt("");
|
|
88
|
+
onOpenChange(false);
|
|
89
|
+
}
|
|
90
|
+
setUploadingImage(false);
|
|
91
|
+
event.target.value = "";
|
|
92
|
+
} catch (err) {
|
|
93
|
+
let uploadError;
|
|
94
|
+
if (err instanceof Error) uploadError = err;
|
|
95
|
+
else uploadError = new Error(t("upload.error"));
|
|
96
|
+
toast.error(uploadError.message);
|
|
97
|
+
setUploadingImage(false);
|
|
98
|
+
event.target.value = "";
|
|
99
|
+
}
|
|
100
|
+
}, [
|
|
101
|
+
collection,
|
|
102
|
+
availableUploadCollections,
|
|
103
|
+
editor,
|
|
104
|
+
imageAlt,
|
|
105
|
+
onImageUpload,
|
|
106
|
+
onOpenChange,
|
|
107
|
+
t,
|
|
108
|
+
upload
|
|
109
|
+
]);
|
|
110
|
+
React.useEffect(() => {
|
|
111
|
+
if (!selectedAssetId || !selectedAsset || !editor) return;
|
|
112
|
+
const assetUrl = selectedAsset?.url;
|
|
113
|
+
if (!assetUrl) {
|
|
114
|
+
toast.error(t("upload.error"));
|
|
115
|
+
setSelectedAssetId(null);
|
|
116
|
+
return;
|
|
117
|
+
}
|
|
118
|
+
editor.chain().focus().setImage({
|
|
119
|
+
src: assetUrl,
|
|
120
|
+
alt: imageAlt || selectedAsset?.alt || void 0
|
|
121
|
+
}).run();
|
|
122
|
+
setImageUrl("");
|
|
123
|
+
setImageAlt("");
|
|
124
|
+
setSelectedAssetId(null);
|
|
125
|
+
onOpenChange(false);
|
|
126
|
+
}, [
|
|
127
|
+
editor,
|
|
128
|
+
imageAlt,
|
|
129
|
+
onOpenChange,
|
|
130
|
+
selectedAsset,
|
|
131
|
+
selectedAssetId,
|
|
132
|
+
t
|
|
133
|
+
]);
|
|
134
|
+
const handlePickerSelect = (ids) => {
|
|
135
|
+
const selectedId = Array.isArray(ids) ? ids[0] : ids;
|
|
136
|
+
if (!selectedId) return;
|
|
137
|
+
setSelectedAssetId(selectedId);
|
|
138
|
+
setIsPickerOpen(false);
|
|
139
|
+
};
|
|
140
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsxs(Popover, {
|
|
141
|
+
open,
|
|
142
|
+
onOpenChange,
|
|
143
|
+
children: [/* @__PURE__ */ jsx(PopoverTrigger, { render: /* @__PURE__ */ jsx("div", { className: "sr-only" }) }), /* @__PURE__ */ jsxs(PopoverContent, {
|
|
144
|
+
className: "w-80",
|
|
145
|
+
children: [/* @__PURE__ */ jsx(PopoverHeader, { children: /* @__PURE__ */ jsx(PopoverTitle, { children: t("editor.image") }) }), /* @__PURE__ */ jsxs("div", {
|
|
146
|
+
className: "space-y-3",
|
|
147
|
+
children: [/* @__PURE__ */ jsxs("div", {
|
|
148
|
+
className: "space-y-2",
|
|
149
|
+
children: [
|
|
150
|
+
/* @__PURE__ */ jsx(Input, {
|
|
151
|
+
value: imageUrl,
|
|
152
|
+
placeholder: "https://example.com/image.jpg",
|
|
153
|
+
onChange: (event_0) => setImageUrl(event_0.target.value),
|
|
154
|
+
disabled
|
|
155
|
+
}),
|
|
156
|
+
/* @__PURE__ */ jsx(Input, {
|
|
157
|
+
value: imageAlt,
|
|
158
|
+
placeholder: t("editor.altText"),
|
|
159
|
+
onChange: (event_1) => setImageAlt(event_1.target.value),
|
|
160
|
+
disabled
|
|
161
|
+
}),
|
|
162
|
+
/* @__PURE__ */ jsx("div", {
|
|
163
|
+
className: "flex justify-end gap-2",
|
|
164
|
+
children: /* @__PURE__ */ jsx(Button, {
|
|
165
|
+
type: "button",
|
|
166
|
+
size: "xs",
|
|
167
|
+
onClick: handleInsertImageUrl,
|
|
168
|
+
disabled: disabled || !imageUrl,
|
|
169
|
+
children: t("editor.insertUrl")
|
|
170
|
+
})
|
|
171
|
+
})
|
|
172
|
+
]
|
|
173
|
+
}), /* @__PURE__ */ jsxs("div", {
|
|
174
|
+
className: "space-y-2",
|
|
175
|
+
children: [
|
|
176
|
+
/* @__PURE__ */ jsx("div", {
|
|
177
|
+
className: "text-xs font-medium",
|
|
178
|
+
children: t("editor.uploadFile")
|
|
179
|
+
}),
|
|
180
|
+
/* @__PURE__ */ jsx("input", {
|
|
181
|
+
ref: fileInputRef,
|
|
182
|
+
type: "file",
|
|
183
|
+
accept: "image/*",
|
|
184
|
+
onChange: handleImageUpload,
|
|
185
|
+
className: "sr-only",
|
|
186
|
+
disabled: disabled || uploadingImage
|
|
187
|
+
}),
|
|
188
|
+
/* @__PURE__ */ jsxs("div", {
|
|
189
|
+
className: "flex items-center gap-2",
|
|
190
|
+
children: [/* @__PURE__ */ jsx(Button, {
|
|
191
|
+
type: "button",
|
|
192
|
+
size: "xs",
|
|
193
|
+
variant: "outline",
|
|
194
|
+
onClick: () => fileInputRef.current?.click(),
|
|
195
|
+
disabled: disabled || uploadingImage || !onImageUpload && !collection,
|
|
196
|
+
children: uploadingImage ? t("editor.uploading") : t("editor.chooseFile")
|
|
197
|
+
}), showMediaLibrary && /* @__PURE__ */ jsx(Button, {
|
|
198
|
+
type: "button",
|
|
199
|
+
size: "xs",
|
|
200
|
+
variant: "outline",
|
|
201
|
+
onClick: () => setIsPickerOpen(true),
|
|
202
|
+
disabled: disabled || !collection,
|
|
203
|
+
children: t("editor.browseLibrary")
|
|
204
|
+
})]
|
|
205
|
+
})
|
|
206
|
+
]
|
|
207
|
+
})]
|
|
208
|
+
})]
|
|
209
|
+
})]
|
|
210
|
+
}), showMediaLibrary && /* @__PURE__ */ jsx(MediaPickerDialog, {
|
|
211
|
+
open: isPickerOpen,
|
|
212
|
+
onOpenChange: setIsPickerOpen,
|
|
213
|
+
mode: "single",
|
|
214
|
+
accept: ["image/*"],
|
|
215
|
+
onSelect: handlePickerSelect,
|
|
216
|
+
collection
|
|
217
|
+
})] });
|
|
218
|
+
}
|
|
219
|
+
|
|
220
|
+
//#endregion
|
|
221
|
+
export { ImagePopover };
|