@delmaredigital/payload-puck 0.6.12 → 0.6.14
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 +50 -1
- package/dist/admin/EditWithPuckButton.d.ts +1 -2
- package/dist/admin/EditWithPuckButton.js +64 -26
- package/dist/admin/EditWithPuckCell.d.ts +0 -1
- package/dist/admin/EditWithPuckCell.js +42 -14
- package/dist/admin/PuckEditorView.d.ts +1 -2
- package/dist/admin/PuckEditorView.js +117 -33
- package/dist/admin/client.d.ts +2 -3
- package/dist/admin/client.js +3 -5
- package/dist/admin/generateAdminComponents.d.ts +0 -1
- package/dist/admin/generateAdminComponents.js +6 -8
- package/dist/admin/index.d.ts +5 -6
- package/dist/admin/index.js +2 -3
- package/dist/ai/collections/AiContext.d.ts +0 -1
- package/dist/ai/collections/AiContext.js +55 -30
- package/dist/ai/collections/AiPrompts.d.ts +0 -1
- package/dist/ai/collections/AiPrompts.js +23 -20
- package/dist/ai/createAiApiRoutes.d.ts +0 -1
- package/dist/ai/createAiApiRoutes.js +27 -20
- package/dist/ai/createAiGenerate.d.ts +0 -1
- package/dist/ai/createAiGenerate.js +6 -9
- package/dist/ai/createAiPlugin.d.ts +0 -1
- package/dist/ai/createAiPlugin.js +6 -10
- package/dist/ai/hooks/useAiContext.d.ts +0 -1
- package/dist/ai/hooks/useAiContext.js +49 -40
- package/dist/ai/hooks/useAiPrompts.d.ts +0 -1
- package/dist/ai/hooks/useAiPrompts.js +32 -26
- package/dist/ai/index.d.ts +0 -1
- package/dist/ai/index.js +8 -11
- package/dist/ai/plugins/ContextEditorPanel.d.ts +1 -2
- package/dist/ai/plugins/ContextEditorPanel.js +398 -108
- package/dist/ai/plugins/PromptEditorPanel.d.ts +1 -2
- package/dist/ai/plugins/PromptEditorPanel.js +236 -52
- package/dist/ai/plugins/contextEditorPlugin.d.ts +0 -1
- package/dist/ai/plugins/contextEditorPlugin.js +11 -6
- package/dist/ai/plugins/promptApiRoutes.d.ts +0 -1
- package/dist/ai/plugins/promptApiRoutes.js +118 -51
- package/dist/ai/plugins/promptEditorPlugin.d.ts +0 -1
- package/dist/ai/plugins/promptEditorPlugin.js +11 -6
- package/dist/ai/presets/componentAiDefaults.d.ts +0 -1
- package/dist/ai/presets/componentAiDefaults.js +107 -84
- package/dist/ai/presets/index.d.ts +0 -1
- package/dist/ai/presets/index.js +11 -19
- package/dist/ai/presets/instructions/interactive.d.ts +0 -1
- package/dist/ai/presets/instructions/interactive.js +84 -76
- package/dist/ai/presets/instructions/layout.d.ts +0 -1
- package/dist/ai/presets/instructions/layout.js +121 -118
- package/dist/ai/presets/instructions/media.d.ts +0 -1
- package/dist/ai/presets/instructions/media.js +30 -30
- package/dist/ai/presets/instructions/pagePatterns.d.ts +0 -1
- package/dist/ai/presets/instructions/pagePatterns.js +3 -7
- package/dist/ai/presets/instructions/schemas.d.ts +0 -1
- package/dist/ai/presets/instructions/schemas.js +494 -138
- package/dist/ai/presets/instructions/typography.d.ts +0 -1
- package/dist/ai/presets/instructions/typography.js +37 -34
- package/dist/ai/tools/index.d.ts +0 -1
- package/dist/ai/tools/index.js +91 -56
- package/dist/ai/types.d.ts +0 -1
- package/dist/ai/types.js +6 -2
- package/dist/ai/utils/injectAiConfig.d.ts +0 -1
- package/dist/ai/utils/injectAiConfig.js +32 -41
- package/dist/api/createPuckApiRoutes.d.ts +1 -2
- package/dist/api/createPuckApiRoutes.js +122 -66
- package/dist/api/createPuckApiRoutesVersions.d.ts +1 -2
- package/dist/api/createPuckApiRoutesVersions.js +87 -38
- package/dist/api/createPuckApiRoutesWithId.d.ts +1 -2
- package/dist/api/createPuckApiRoutesWithId.js +165 -73
- package/dist/api/index.d.ts +5 -6
- package/dist/api/index.js +5 -7
- package/dist/api/payload-config.d.js +14 -0
- package/dist/api/types.d.ts +0 -1
- package/dist/api/types.js +3 -2
- package/dist/api/utils/mapRootProps.d.ts +1 -2
- package/dist/api/utils/mapRootProps.js +76 -45
- package/dist/collections/Templates.d.ts +0 -1
- package/dist/collections/Templates.js +23 -21
- package/dist/components/AccordionClient.d.ts +2 -3
- package/dist/components/AccordionClient.js +80 -23
- package/dist/components/AnimatedWrapper.d.ts +2 -3
- package/dist/components/AnimatedWrapper.js +30 -17
- package/dist/components/exports.d.ts +0 -1
- package/dist/components/exports.js +1 -3
- package/dist/components/index.d.ts +5 -6
- package/dist/components/index.js +6 -8
- package/dist/components/interactive/Accordion.d.ts +1 -2
- package/dist/components/interactive/Accordion.js +148 -56
- package/dist/components/interactive/Accordion.server.d.ts +1 -2
- package/dist/components/interactive/Accordion.server.js +24 -8
- package/dist/components/interactive/Button.d.ts +3 -4
- package/dist/components/interactive/Button.js +88 -44
- package/dist/components/interactive/Button.server.d.ts +2 -3
- package/dist/components/interactive/Button.server.js +39 -21
- package/dist/components/interactive/Card.d.ts +3 -4
- package/dist/components/interactive/Card.js +130 -40
- package/dist/components/interactive/Card.server.d.ts +3 -4
- package/dist/components/interactive/Card.server.js +71 -12
- package/dist/components/interactive/Divider.d.ts +1 -2
- package/dist/components/interactive/Divider.js +53 -27
- package/dist/components/interactive/Divider.server.d.ts +1 -2
- package/dist/components/interactive/Divider.server.js +27 -13
- package/dist/components/interactive/index.d.ts +4 -5
- package/dist/components/interactive/index.js +4 -6
- package/dist/components/layout/Container.d.ts +1 -2
- package/dist/components/layout/Container.js +100 -48
- package/dist/components/layout/Container.server.d.ts +1 -2
- package/dist/components/layout/Container.server.js +66 -20
- package/dist/components/layout/Flex.d.ts +2 -3
- package/dist/components/layout/Flex.js +123 -56
- package/dist/components/layout/Flex.server.d.ts +1 -2
- package/dist/components/layout/Flex.server.js +49 -15
- package/dist/components/layout/Grid.d.ts +1 -2
- package/dist/components/layout/Grid.js +92 -45
- package/dist/components/layout/Grid.server.d.ts +1 -2
- package/dist/components/layout/Grid.server.js +55 -15
- package/dist/components/layout/Section.d.ts +1 -2
- package/dist/components/layout/Section.js +146 -65
- package/dist/components/layout/Section.server.d.ts +1 -2
- package/dist/components/layout/Section.server.js +91 -29
- package/dist/components/layout/Spacer.d.ts +1 -2
- package/dist/components/layout/Spacer.js +79 -31
- package/dist/components/layout/Spacer.server.d.ts +1 -2
- package/dist/components/layout/Spacer.server.js +30 -10
- package/dist/components/layout/Template.d.ts +1 -2
- package/dist/components/layout/Template.js +57 -31
- package/dist/components/layout/Template.server.d.ts +1 -2
- package/dist/components/layout/Template.server.js +42 -12
- package/dist/components/layout/index.d.ts +8 -9
- package/dist/components/layout/index.js +7 -9
- package/dist/components/media/Image.d.ts +3 -4
- package/dist/components/media/Image.js +121 -40
- package/dist/components/media/Image.server.d.ts +3 -4
- package/dist/components/media/Image.server.js +75 -14
- package/dist/components/media/index.d.ts +1 -2
- package/dist/components/media/index.js +1 -3
- package/dist/components/typography/Heading.d.ts +2 -3
- package/dist/components/typography/Heading.js +44 -26
- package/dist/components/typography/Heading.server.d.ts +2 -3
- package/dist/components/typography/Heading.server.js +15 -11
- package/dist/components/typography/RichText.editor.d.ts +1 -2
- package/dist/components/typography/RichText.editor.js +43 -20
- package/dist/components/typography/RichText.server.d.ts +2 -3
- package/dist/components/typography/RichText.server.js +32 -15
- package/dist/components/typography/Text.d.ts +2 -3
- package/dist/components/typography/Text.js +48 -24
- package/dist/components/typography/Text.server.d.ts +2 -3
- package/dist/components/typography/Text.server.js +20 -9
- package/dist/components/typography/index.d.ts +4 -5
- package/dist/components/typography/index.js +4 -6
- package/dist/config/config.editor.d.ts +3 -4
- package/dist/config/config.editor.js +118 -55
- package/dist/config/index.d.ts +4 -5
- package/dist/config/index.js +61 -36
- package/dist/config/merge.d.ts +1 -2
- package/dist/config/merge.js +22 -27
- package/dist/config/presets.d.ts +4 -5
- package/dist/config/presets.js +194 -76
- package/dist/config/types.d.ts +0 -1
- package/dist/config/types.js +5 -3
- package/dist/editor/PuckEditor.d.ts +4 -5
- package/dist/editor/PuckEditor.js +161 -71
- package/dist/editor/PuckEditorImpl.client.d.ts +4 -5
- package/dist/editor/PuckEditorImpl.client.js +303 -153
- package/dist/editor/components/DarkModeStyles.d.ts +0 -1
- package/dist/editor/components/DarkModeStyles.js +10 -13
- package/dist/editor/components/HeaderActions.d.ts +0 -1
- package/dist/editor/components/HeaderActions.js +307 -65
- package/dist/editor/components/IframeWrapper.d.ts +1 -2
- package/dist/editor/components/IframeWrapper.js +81 -59
- package/dist/editor/components/LoadingState.d.ts +1 -2
- package/dist/editor/components/LoadingState.js +16 -4
- package/dist/editor/components/PreviewModal.d.ts +0 -1
- package/dist/editor/components/PreviewModal.js +233 -79
- package/dist/editor/components/PreviewModeToggle.d.ts +0 -1
- package/dist/editor/components/PreviewModeToggle.js +42 -16
- package/dist/editor/components/VersionHistory.d.ts +0 -1
- package/dist/editor/components/VersionHistory.js +218 -72
- package/dist/editor/hooks/useDarkMode.d.ts +0 -1
- package/dist/editor/hooks/useDarkMode.js +35 -24
- package/dist/editor/hooks/useUnsavedChanges.d.ts +0 -1
- package/dist/editor/hooks/useUnsavedChanges.js +7 -9
- package/dist/editor/index.d.ts +0 -1
- package/dist/editor/index.js +4 -7
- package/dist/editor/plugins/VersionHistoryPanel.d.ts +0 -1
- package/dist/editor/plugins/VersionHistoryPanel.js +235 -76
- package/dist/editor/plugins/index.d.ts +0 -1
- package/dist/editor/plugins/index.js +3 -5
- package/dist/editor/plugins/versionHistoryPlugin.d.ts +0 -1
- package/dist/editor/plugins/versionHistoryPlugin.js +9 -9
- package/dist/editor/utils/detectPageTree.d.ts +0 -1
- package/dist/editor/utils/detectPageTree.js +4 -6
- package/dist/editor/utils/index.d.ts +0 -1
- package/dist/editor/utils/index.js +0 -1
- package/dist/editor/utils/injectPageTreeFields.d.ts +0 -1
- package/dist/editor/utils/injectPageTreeFields.js +12 -10
- package/dist/endpoints/ai.d.ts +0 -1
- package/dist/endpoints/ai.js +57 -35
- package/dist/endpoints/context.d.ts +0 -1
- package/dist/endpoints/context.js +85 -41
- package/dist/endpoints/index.d.ts +0 -1
- package/dist/endpoints/index.js +152 -77
- package/dist/endpoints/postcss.d.js +4 -0
- package/dist/endpoints/prompts.d.ts +0 -1
- package/dist/endpoints/prompts.js +80 -40
- package/dist/endpoints/styles.d.ts +0 -1
- package/dist/endpoints/styles.js +33 -37
- package/dist/exports/client.d.ts +0 -1
- package/dist/exports/client.js +1 -3
- package/dist/exports/rsc.d.ts +0 -1
- package/dist/exports/rsc.js +1 -3
- package/dist/fields/AlignmentField.d.ts +1 -2
- package/dist/fields/AlignmentField.js +92 -31
- package/dist/fields/AnimationField.d.ts +2 -3
- package/dist/fields/AnimationField.js +557 -85
- package/dist/fields/BackgroundField.d.ts +2 -3
- package/dist/fields/BackgroundField.js +753 -121
- package/dist/fields/BorderField.d.ts +2 -3
- package/dist/fields/BorderField.js +274 -74
- package/dist/fields/ColorPickerField.d.ts +2 -3
- package/dist/fields/ColorPickerField.js +209 -69
- package/dist/fields/ContentAlignmentField.d.ts +1 -2
- package/dist/fields/ContentAlignmentField.js +160 -76
- package/dist/fields/DimensionsField.d.ts +2 -3
- package/dist/fields/DimensionsField.js +574 -147
- package/dist/fields/FlexAlignmentField.d.ts +2 -3
- package/dist/fields/FlexAlignmentField.js +188 -52
- package/dist/fields/FolderPickerField.d.ts +8 -2
- package/dist/fields/FolderPickerField.js +287 -76
- package/dist/fields/GradientEditor.d.ts +2 -3
- package/dist/fields/GradientEditor.js +461 -87
- package/dist/fields/LockedField.d.ts +15 -3
- package/dist/fields/LockedField.js +179 -50
- package/dist/fields/MarginField.d.ts +2 -3
- package/dist/fields/MarginField.js +143 -47
- package/dist/fields/MediaField.d.ts +1 -2
- package/dist/fields/MediaField.js +687 -187
- package/dist/fields/PaddingField.d.ts +2 -3
- package/dist/fields/PaddingField.js +143 -47
- package/dist/fields/PageSegmentField.d.ts +15 -3
- package/dist/fields/PageSegmentField.js +155 -55
- package/dist/fields/ResetField.d.ts +1 -2
- package/dist/fields/ResetField.js +58 -32
- package/dist/fields/ResponsiveField.d.ts +1 -2
- package/dist/fields/ResponsiveField.js +232 -91
- package/dist/fields/ResponsiveVisibilityField.d.ts +2 -3
- package/dist/fields/ResponsiveVisibilityField.js +118 -37
- package/dist/fields/SizeField.d.ts +3 -4
- package/dist/fields/SizeField.js +225 -53
- package/dist/fields/SlugPreviewField.d.ts +8 -2
- package/dist/fields/SlugPreviewField.js +64 -17
- package/dist/fields/TemplateField.d.ts +1 -2
- package/dist/fields/TemplateField.js +361 -121
- package/dist/fields/TransformField.d.ts +2 -3
- package/dist/fields/TransformField.js +516 -82
- package/dist/fields/VerticalAlignmentField.d.ts +1 -2
- package/dist/fields/VerticalAlignmentField.js +92 -31
- package/dist/fields/WidthField.d.ts +2 -3
- package/dist/fields/WidthField.js +277 -82
- package/dist/fields/index.d.ts +41 -42
- package/dist/fields/index.js +36 -44
- package/dist/fields/richtext/controls/ColorPickerControl.d.ts +13 -3
- package/dist/fields/richtext/controls/ColorPickerControl.js +211 -48
- package/dist/fields/richtext/controls/DropdownPortal.d.ts +2 -3
- package/dist/fields/richtext/controls/DropdownPortal.js +35 -5
- package/dist/fields/richtext/controls/FontSizeControl.d.ts +9 -2
- package/dist/fields/richtext/controls/FontSizeControl.js +108 -25
- package/dist/fields/richtext/controls/HighlightControl.d.ts +12 -2
- package/dist/fields/richtext/controls/HighlightControl.js +53 -18
- package/dist/fields/richtext/controls/index.d.ts +5 -6
- package/dist/fields/richtext/controls/index.js +7 -12
- package/dist/fields/richtext/controls/shared.d.ts +0 -1
- package/dist/fields/richtext/controls/shared.js +107 -64
- package/dist/fields/richtext/createRichTextField.d.ts +18 -5
- package/dist/fields/richtext/createRichTextField.js +112 -27
- package/dist/fields/richtext/extensions/FontSize.d.ts +0 -1
- package/dist/fields/richtext/extensions/FontSize.js +25 -21
- package/dist/fields/richtext/extensions/index.d.ts +1 -2
- package/dist/fields/richtext/extensions/index.js +1 -3
- package/dist/fields/richtext/index.d.ts +6 -7
- package/dist/fields/richtext/index.js +7 -9
- package/dist/fields/shared.d.ts +1 -2
- package/dist/fields/shared.js +914 -479
- package/dist/hooks/index.d.ts +2 -3
- package/dist/hooks/index.js +2 -4
- package/dist/hooks/useResponsiveStyles.d.ts +1 -2
- package/dist/hooks/useResponsiveStyles.js +35 -33
- package/dist/hooks/useScrollAnimation.d.ts +0 -1
- package/dist/hooks/useScrollAnimation.js +25 -25
- package/dist/index.d.ts +4 -5
- package/dist/index.js +4 -6
- package/dist/layouts/LayoutWrapper.d.ts +3 -4
- package/dist/layouts/LayoutWrapper.js +114 -52
- package/dist/layouts/defaults.d.ts +1 -2
- package/dist/layouts/defaults.js +22 -32
- package/dist/layouts/index.d.ts +4 -5
- package/dist/layouts/index.js +4 -5
- package/dist/layouts/types.d.ts +0 -1
- package/dist/layouts/types.js +3 -3
- package/dist/layouts/utils.d.ts +1 -2
- package/dist/layouts/utils.js +31 -41
- package/dist/next/index.d.ts +0 -1
- package/dist/next/index.js +30 -35
- package/dist/plugin/collections/Pages.d.ts +2 -3
- package/dist/plugin/collections/Pages.js +45 -44
- package/dist/plugin/fields/index.d.ts +3 -4
- package/dist/plugin/fields/index.js +99 -79
- package/dist/plugin/fields/types.d.ts +1 -2
- package/dist/plugin/fields/types.js +25 -3
- package/dist/plugin/hooks/index.d.ts +1 -2
- package/dist/plugin/hooks/index.js +1 -3
- package/dist/plugin/hooks/isHomepageUnique.d.ts +0 -1
- package/dist/plugin/hooks/isHomepageUnique.js +27 -20
- package/dist/plugin/index.d.ts +8 -9
- package/dist/plugin/index.js +189 -189
- package/dist/render/HybridPageRenderer.d.ts +2 -3
- package/dist/render/HybridPageRenderer.js +57 -11
- package/dist/render/PageRenderer.d.ts +2 -3
- package/dist/render/PageRenderer.js +30 -15
- package/dist/render/PuckEditor.client.d.ts +1 -2
- package/dist/render/PuckEditor.client.js +32 -17
- package/dist/render/index.d.ts +5 -6
- package/dist/render/index.js +4 -7
- package/dist/styles/puck-dark-mode.css +101 -0
- package/dist/theme/context.d.ts +2 -3
- package/dist/theme/context.js +20 -19
- package/dist/theme/defaults.d.ts +1 -2
- package/dist/theme/defaults.js +82 -38
- package/dist/theme/example.d.ts +1 -2
- package/dist/theme/example.js +67 -31
- package/dist/theme/index.d.ts +5 -6
- package/dist/theme/index.js +5 -6
- package/dist/theme/types.d.ts +0 -1
- package/dist/theme/types.js +5 -3
- package/dist/theme/utils.d.ts +1 -2
- package/dist/theme/utils.js +23 -26
- package/dist/types/index.d.ts +6 -7
- package/dist/types/index.js +2 -2
- package/dist/utils/index.d.ts +2 -3
- package/dist/utils/index.js +12 -23
- package/dist/utils/migration.d.ts +1 -2
- package/dist/utils/migration.js +42 -50
- package/dist/utils/validation.d.ts +1 -2
- package/dist/utils/validation.js +35 -44
- package/dist/version.d.ts +1 -2
- package/dist/version.js +1 -2
- package/dist/views/PuckConfigContext.d.ts +1 -2
- package/dist/views/PuckConfigContext.js +24 -11
- package/dist/views/PuckEditorView.d.ts +1 -2
- package/dist/views/PuckEditorView.js +105 -39
- package/dist/views/index.d.ts +0 -1
- package/dist/views/index.js +1 -3
- package/package.json +62 -42
- package/dist/admin/EditWithPuckButton.d.ts.map +0 -1
- package/dist/admin/EditWithPuckButton.js.map +0 -1
- package/dist/admin/EditWithPuckCell.d.ts.map +0 -1
- package/dist/admin/EditWithPuckCell.js.map +0 -1
- package/dist/admin/PuckEditorView.d.ts.map +0 -1
- package/dist/admin/PuckEditorView.js.map +0 -1
- package/dist/admin/client.d.ts.map +0 -1
- package/dist/admin/client.js.map +0 -1
- package/dist/admin/generateAdminComponents.d.ts.map +0 -1
- package/dist/admin/generateAdminComponents.js.map +0 -1
- package/dist/admin/index.d.ts.map +0 -1
- package/dist/admin/index.js.map +0 -1
- package/dist/ai/collections/AiContext.d.ts.map +0 -1
- package/dist/ai/collections/AiContext.js.map +0 -1
- package/dist/ai/collections/AiPrompts.d.ts.map +0 -1
- package/dist/ai/collections/AiPrompts.js.map +0 -1
- package/dist/ai/createAiApiRoutes.d.ts.map +0 -1
- package/dist/ai/createAiApiRoutes.js.map +0 -1
- package/dist/ai/createAiGenerate.d.ts.map +0 -1
- package/dist/ai/createAiGenerate.js.map +0 -1
- package/dist/ai/createAiPlugin.d.ts.map +0 -1
- package/dist/ai/createAiPlugin.js.map +0 -1
- package/dist/ai/hooks/useAiContext.d.ts.map +0 -1
- package/dist/ai/hooks/useAiContext.js.map +0 -1
- package/dist/ai/hooks/useAiPrompts.d.ts.map +0 -1
- package/dist/ai/hooks/useAiPrompts.js.map +0 -1
- package/dist/ai/index.d.ts.map +0 -1
- package/dist/ai/index.js.map +0 -1
- package/dist/ai/plugins/ContextEditorPanel.d.ts.map +0 -1
- package/dist/ai/plugins/ContextEditorPanel.js.map +0 -1
- package/dist/ai/plugins/PromptEditorPanel.d.ts.map +0 -1
- package/dist/ai/plugins/PromptEditorPanel.js.map +0 -1
- package/dist/ai/plugins/contextEditorPlugin.d.ts.map +0 -1
- package/dist/ai/plugins/contextEditorPlugin.js.map +0 -1
- package/dist/ai/plugins/promptApiRoutes.d.ts.map +0 -1
- package/dist/ai/plugins/promptApiRoutes.js.map +0 -1
- package/dist/ai/plugins/promptEditorPlugin.d.ts.map +0 -1
- package/dist/ai/plugins/promptEditorPlugin.js.map +0 -1
- package/dist/ai/presets/componentAiDefaults.d.ts.map +0 -1
- package/dist/ai/presets/componentAiDefaults.js.map +0 -1
- package/dist/ai/presets/index.d.ts.map +0 -1
- package/dist/ai/presets/index.js.map +0 -1
- package/dist/ai/presets/instructions/interactive.d.ts.map +0 -1
- package/dist/ai/presets/instructions/interactive.js.map +0 -1
- package/dist/ai/presets/instructions/layout.d.ts.map +0 -1
- package/dist/ai/presets/instructions/layout.js.map +0 -1
- package/dist/ai/presets/instructions/media.d.ts.map +0 -1
- package/dist/ai/presets/instructions/media.js.map +0 -1
- package/dist/ai/presets/instructions/pagePatterns.d.ts.map +0 -1
- package/dist/ai/presets/instructions/pagePatterns.js.map +0 -1
- package/dist/ai/presets/instructions/schemas.d.ts.map +0 -1
- package/dist/ai/presets/instructions/schemas.js.map +0 -1
- package/dist/ai/presets/instructions/typography.d.ts.map +0 -1
- package/dist/ai/presets/instructions/typography.js.map +0 -1
- package/dist/ai/tools/index.d.ts.map +0 -1
- package/dist/ai/tools/index.js.map +0 -1
- package/dist/ai/types.d.ts.map +0 -1
- package/dist/ai/types.js.map +0 -1
- package/dist/ai/utils/injectAiConfig.d.ts.map +0 -1
- package/dist/ai/utils/injectAiConfig.js.map +0 -1
- package/dist/api/createPuckApiRoutes.d.ts.map +0 -1
- package/dist/api/createPuckApiRoutes.js.map +0 -1
- package/dist/api/createPuckApiRoutesVersions.d.ts.map +0 -1
- package/dist/api/createPuckApiRoutesVersions.js.map +0 -1
- package/dist/api/createPuckApiRoutesWithId.d.ts.map +0 -1
- package/dist/api/createPuckApiRoutesWithId.js.map +0 -1
- package/dist/api/index.d.ts.map +0 -1
- package/dist/api/index.js.map +0 -1
- package/dist/api/types.d.ts.map +0 -1
- package/dist/api/types.js.map +0 -1
- package/dist/api/utils/mapRootProps.d.ts.map +0 -1
- package/dist/api/utils/mapRootProps.js.map +0 -1
- package/dist/collections/Templates.d.ts.map +0 -1
- package/dist/collections/Templates.js.map +0 -1
- package/dist/components/AccordionClient.d.ts.map +0 -1
- package/dist/components/AccordionClient.js.map +0 -1
- package/dist/components/AnimatedWrapper.d.ts.map +0 -1
- package/dist/components/AnimatedWrapper.js.map +0 -1
- package/dist/components/exports.d.ts.map +0 -1
- package/dist/components/exports.js.map +0 -1
- package/dist/components/index.d.ts.map +0 -1
- package/dist/components/index.js.map +0 -1
- package/dist/components/interactive/Accordion.d.ts.map +0 -1
- package/dist/components/interactive/Accordion.js.map +0 -1
- package/dist/components/interactive/Accordion.server.d.ts.map +0 -1
- package/dist/components/interactive/Accordion.server.js.map +0 -1
- package/dist/components/interactive/Button.d.ts.map +0 -1
- package/dist/components/interactive/Button.js.map +0 -1
- package/dist/components/interactive/Button.server.d.ts.map +0 -1
- package/dist/components/interactive/Button.server.js.map +0 -1
- package/dist/components/interactive/Card.d.ts.map +0 -1
- package/dist/components/interactive/Card.js.map +0 -1
- package/dist/components/interactive/Card.server.d.ts.map +0 -1
- package/dist/components/interactive/Card.server.js.map +0 -1
- package/dist/components/interactive/Divider.d.ts.map +0 -1
- package/dist/components/interactive/Divider.js.map +0 -1
- package/dist/components/interactive/Divider.server.d.ts.map +0 -1
- package/dist/components/interactive/Divider.server.js.map +0 -1
- package/dist/components/interactive/index.d.ts.map +0 -1
- package/dist/components/interactive/index.js.map +0 -1
- package/dist/components/layout/Container.d.ts.map +0 -1
- package/dist/components/layout/Container.js.map +0 -1
- package/dist/components/layout/Container.server.d.ts.map +0 -1
- package/dist/components/layout/Container.server.js.map +0 -1
- package/dist/components/layout/Flex.d.ts.map +0 -1
- package/dist/components/layout/Flex.js.map +0 -1
- package/dist/components/layout/Flex.server.d.ts.map +0 -1
- package/dist/components/layout/Flex.server.js.map +0 -1
- package/dist/components/layout/Grid.d.ts.map +0 -1
- package/dist/components/layout/Grid.js.map +0 -1
- package/dist/components/layout/Grid.server.d.ts.map +0 -1
- package/dist/components/layout/Grid.server.js.map +0 -1
- package/dist/components/layout/Section.d.ts.map +0 -1
- package/dist/components/layout/Section.js.map +0 -1
- package/dist/components/layout/Section.server.d.ts.map +0 -1
- package/dist/components/layout/Section.server.js.map +0 -1
- package/dist/components/layout/Spacer.d.ts.map +0 -1
- package/dist/components/layout/Spacer.js.map +0 -1
- package/dist/components/layout/Spacer.server.d.ts.map +0 -1
- package/dist/components/layout/Spacer.server.js.map +0 -1
- package/dist/components/layout/Template.d.ts.map +0 -1
- package/dist/components/layout/Template.js.map +0 -1
- package/dist/components/layout/Template.server.d.ts.map +0 -1
- package/dist/components/layout/Template.server.js.map +0 -1
- package/dist/components/layout/index.d.ts.map +0 -1
- package/dist/components/layout/index.js.map +0 -1
- package/dist/components/media/Image.d.ts.map +0 -1
- package/dist/components/media/Image.js.map +0 -1
- package/dist/components/media/Image.server.d.ts.map +0 -1
- package/dist/components/media/Image.server.js.map +0 -1
- package/dist/components/media/index.d.ts.map +0 -1
- package/dist/components/media/index.js.map +0 -1
- package/dist/components/typography/Heading.d.ts.map +0 -1
- package/dist/components/typography/Heading.js.map +0 -1
- package/dist/components/typography/Heading.server.d.ts.map +0 -1
- package/dist/components/typography/Heading.server.js.map +0 -1
- package/dist/components/typography/RichText.editor.d.ts.map +0 -1
- package/dist/components/typography/RichText.editor.js.map +0 -1
- package/dist/components/typography/RichText.server.d.ts.map +0 -1
- package/dist/components/typography/RichText.server.js.map +0 -1
- package/dist/components/typography/Text.d.ts.map +0 -1
- package/dist/components/typography/Text.js.map +0 -1
- package/dist/components/typography/Text.server.d.ts.map +0 -1
- package/dist/components/typography/Text.server.js.map +0 -1
- package/dist/components/typography/index.d.ts.map +0 -1
- package/dist/components/typography/index.js.map +0 -1
- package/dist/config/config.editor.d.ts.map +0 -1
- package/dist/config/config.editor.js.map +0 -1
- package/dist/config/index.d.ts.map +0 -1
- package/dist/config/index.js.map +0 -1
- package/dist/config/merge.d.ts.map +0 -1
- package/dist/config/merge.js.map +0 -1
- package/dist/config/presets.d.ts.map +0 -1
- package/dist/config/presets.js.map +0 -1
- package/dist/config/types.d.ts.map +0 -1
- package/dist/config/types.js.map +0 -1
- package/dist/editor/PuckEditor.d.ts.map +0 -1
- package/dist/editor/PuckEditor.js.map +0 -1
- package/dist/editor/PuckEditorImpl.client.d.ts.map +0 -1
- package/dist/editor/PuckEditorImpl.client.js.map +0 -1
- package/dist/editor/components/DarkModeStyles.d.ts.map +0 -1
- package/dist/editor/components/DarkModeStyles.js.map +0 -1
- package/dist/editor/components/HeaderActions.d.ts.map +0 -1
- package/dist/editor/components/HeaderActions.js.map +0 -1
- package/dist/editor/components/IframeWrapper.d.ts.map +0 -1
- package/dist/editor/components/IframeWrapper.js.map +0 -1
- package/dist/editor/components/LoadingState.d.ts.map +0 -1
- package/dist/editor/components/LoadingState.js.map +0 -1
- package/dist/editor/components/PreviewModal.d.ts.map +0 -1
- package/dist/editor/components/PreviewModal.js.map +0 -1
- package/dist/editor/components/PreviewModeToggle.d.ts.map +0 -1
- package/dist/editor/components/PreviewModeToggle.js.map +0 -1
- package/dist/editor/components/VersionHistory.d.ts.map +0 -1
- package/dist/editor/components/VersionHistory.js.map +0 -1
- package/dist/editor/hooks/useDarkMode.d.ts.map +0 -1
- package/dist/editor/hooks/useDarkMode.js.map +0 -1
- package/dist/editor/hooks/useUnsavedChanges.d.ts.map +0 -1
- package/dist/editor/hooks/useUnsavedChanges.js.map +0 -1
- package/dist/editor/index.d.ts.map +0 -1
- package/dist/editor/index.js.map +0 -1
- package/dist/editor/plugins/VersionHistoryPanel.d.ts.map +0 -1
- package/dist/editor/plugins/VersionHistoryPanel.js.map +0 -1
- package/dist/editor/plugins/index.d.ts.map +0 -1
- package/dist/editor/plugins/index.js.map +0 -1
- package/dist/editor/plugins/versionHistoryPlugin.d.ts.map +0 -1
- package/dist/editor/plugins/versionHistoryPlugin.js.map +0 -1
- package/dist/editor/utils/detectPageTree.d.ts.map +0 -1
- package/dist/editor/utils/detectPageTree.js.map +0 -1
- package/dist/editor/utils/index.d.ts.map +0 -1
- package/dist/editor/utils/index.js.map +0 -1
- package/dist/editor/utils/injectPageTreeFields.d.ts.map +0 -1
- package/dist/editor/utils/injectPageTreeFields.js.map +0 -1
- package/dist/endpoints/ai.d.ts.map +0 -1
- package/dist/endpoints/ai.js.map +0 -1
- package/dist/endpoints/context.d.ts.map +0 -1
- package/dist/endpoints/context.js.map +0 -1
- package/dist/endpoints/index.d.ts.map +0 -1
- package/dist/endpoints/index.js.map +0 -1
- package/dist/endpoints/prompts.d.ts.map +0 -1
- package/dist/endpoints/prompts.js.map +0 -1
- package/dist/endpoints/styles.d.ts.map +0 -1
- package/dist/endpoints/styles.js.map +0 -1
- package/dist/exports/client.d.ts.map +0 -1
- package/dist/exports/client.js.map +0 -1
- package/dist/exports/rsc.d.ts.map +0 -1
- package/dist/exports/rsc.js.map +0 -1
- package/dist/fields/AlignmentField.d.ts.map +0 -1
- package/dist/fields/AlignmentField.js.map +0 -1
- package/dist/fields/AnimationField.d.ts.map +0 -1
- package/dist/fields/AnimationField.js.map +0 -1
- package/dist/fields/BackgroundField.d.ts.map +0 -1
- package/dist/fields/BackgroundField.js.map +0 -1
- package/dist/fields/BorderField.d.ts.map +0 -1
- package/dist/fields/BorderField.js.map +0 -1
- package/dist/fields/ColorPickerField.d.ts.map +0 -1
- package/dist/fields/ColorPickerField.js.map +0 -1
- package/dist/fields/ContentAlignmentField.d.ts.map +0 -1
- package/dist/fields/ContentAlignmentField.js.map +0 -1
- package/dist/fields/DimensionsField.d.ts.map +0 -1
- package/dist/fields/DimensionsField.js.map +0 -1
- package/dist/fields/FlexAlignmentField.d.ts.map +0 -1
- package/dist/fields/FlexAlignmentField.js.map +0 -1
- package/dist/fields/FolderPickerField.d.ts.map +0 -1
- package/dist/fields/FolderPickerField.js.map +0 -1
- package/dist/fields/GradientEditor.d.ts.map +0 -1
- package/dist/fields/GradientEditor.js.map +0 -1
- package/dist/fields/LockedField.d.ts.map +0 -1
- package/dist/fields/LockedField.js.map +0 -1
- package/dist/fields/MarginField.d.ts.map +0 -1
- package/dist/fields/MarginField.js.map +0 -1
- package/dist/fields/MediaField.d.ts.map +0 -1
- package/dist/fields/MediaField.js.map +0 -1
- package/dist/fields/PaddingField.d.ts.map +0 -1
- package/dist/fields/PaddingField.js.map +0 -1
- package/dist/fields/PageSegmentField.d.ts.map +0 -1
- package/dist/fields/PageSegmentField.js.map +0 -1
- package/dist/fields/ResetField.d.ts.map +0 -1
- package/dist/fields/ResetField.js.map +0 -1
- package/dist/fields/ResponsiveField.d.ts.map +0 -1
- package/dist/fields/ResponsiveField.js.map +0 -1
- package/dist/fields/ResponsiveVisibilityField.d.ts.map +0 -1
- package/dist/fields/ResponsiveVisibilityField.js.map +0 -1
- package/dist/fields/SizeField.d.ts.map +0 -1
- package/dist/fields/SizeField.js.map +0 -1
- package/dist/fields/SlugPreviewField.d.ts.map +0 -1
- package/dist/fields/SlugPreviewField.js.map +0 -1
- package/dist/fields/TemplateField.d.ts.map +0 -1
- package/dist/fields/TemplateField.js.map +0 -1
- package/dist/fields/TransformField.d.ts.map +0 -1
- package/dist/fields/TransformField.js.map +0 -1
- package/dist/fields/VerticalAlignmentField.d.ts.map +0 -1
- package/dist/fields/VerticalAlignmentField.js.map +0 -1
- package/dist/fields/WidthField.d.ts.map +0 -1
- package/dist/fields/WidthField.js.map +0 -1
- package/dist/fields/index.d.ts.map +0 -1
- package/dist/fields/index.js.map +0 -1
- package/dist/fields/richtext/controls/ColorPickerControl.d.ts.map +0 -1
- package/dist/fields/richtext/controls/ColorPickerControl.js.map +0 -1
- package/dist/fields/richtext/controls/DropdownPortal.d.ts.map +0 -1
- package/dist/fields/richtext/controls/DropdownPortal.js.map +0 -1
- package/dist/fields/richtext/controls/FontSizeControl.d.ts.map +0 -1
- package/dist/fields/richtext/controls/FontSizeControl.js.map +0 -1
- package/dist/fields/richtext/controls/HighlightControl.d.ts.map +0 -1
- package/dist/fields/richtext/controls/HighlightControl.js.map +0 -1
- package/dist/fields/richtext/controls/index.d.ts.map +0 -1
- package/dist/fields/richtext/controls/index.js.map +0 -1
- package/dist/fields/richtext/controls/shared.d.ts.map +0 -1
- package/dist/fields/richtext/controls/shared.js.map +0 -1
- package/dist/fields/richtext/createRichTextField.d.ts.map +0 -1
- package/dist/fields/richtext/createRichTextField.js.map +0 -1
- package/dist/fields/richtext/extensions/FontSize.d.ts.map +0 -1
- package/dist/fields/richtext/extensions/FontSize.js.map +0 -1
- package/dist/fields/richtext/extensions/index.d.ts.map +0 -1
- package/dist/fields/richtext/extensions/index.js.map +0 -1
- package/dist/fields/richtext/index.d.ts.map +0 -1
- package/dist/fields/richtext/index.js.map +0 -1
- package/dist/fields/shared.d.ts.map +0 -1
- package/dist/fields/shared.js.map +0 -1
- package/dist/hooks/index.d.ts.map +0 -1
- package/dist/hooks/index.js.map +0 -1
- package/dist/hooks/useResponsiveStyles.d.ts.map +0 -1
- package/dist/hooks/useResponsiveStyles.js.map +0 -1
- package/dist/hooks/useScrollAnimation.d.ts.map +0 -1
- package/dist/hooks/useScrollAnimation.js.map +0 -1
- package/dist/index.d.ts.map +0 -1
- package/dist/index.js.map +0 -1
- package/dist/layouts/LayoutWrapper.d.ts.map +0 -1
- package/dist/layouts/LayoutWrapper.js.map +0 -1
- package/dist/layouts/defaults.d.ts.map +0 -1
- package/dist/layouts/defaults.js.map +0 -1
- package/dist/layouts/index.d.ts.map +0 -1
- package/dist/layouts/index.js.map +0 -1
- package/dist/layouts/types.d.ts.map +0 -1
- package/dist/layouts/types.js.map +0 -1
- package/dist/layouts/utils.d.ts.map +0 -1
- package/dist/layouts/utils.js.map +0 -1
- package/dist/next/index.d.ts.map +0 -1
- package/dist/next/index.js.map +0 -1
- package/dist/plugin/collections/Pages.d.ts.map +0 -1
- package/dist/plugin/collections/Pages.js.map +0 -1
- package/dist/plugin/fields/index.d.ts.map +0 -1
- package/dist/plugin/fields/index.js.map +0 -1
- package/dist/plugin/fields/types.d.ts.map +0 -1
- package/dist/plugin/fields/types.js.map +0 -1
- package/dist/plugin/hooks/index.d.ts.map +0 -1
- package/dist/plugin/hooks/index.js.map +0 -1
- package/dist/plugin/hooks/isHomepageUnique.d.ts.map +0 -1
- package/dist/plugin/hooks/isHomepageUnique.js.map +0 -1
- package/dist/plugin/index.d.ts.map +0 -1
- package/dist/plugin/index.js.map +0 -1
- package/dist/render/HybridPageRenderer.d.ts.map +0 -1
- package/dist/render/HybridPageRenderer.js.map +0 -1
- package/dist/render/PageRenderer.d.ts.map +0 -1
- package/dist/render/PageRenderer.js.map +0 -1
- package/dist/render/PuckEditor.client.d.ts.map +0 -1
- package/dist/render/PuckEditor.client.js.map +0 -1
- package/dist/render/index.d.ts.map +0 -1
- package/dist/render/index.js.map +0 -1
- package/dist/theme/context.d.ts.map +0 -1
- package/dist/theme/context.js.map +0 -1
- package/dist/theme/defaults.d.ts.map +0 -1
- package/dist/theme/defaults.js.map +0 -1
- package/dist/theme/example.d.ts.map +0 -1
- package/dist/theme/example.js.map +0 -1
- package/dist/theme/index.d.ts.map +0 -1
- package/dist/theme/index.js.map +0 -1
- package/dist/theme/types.d.ts.map +0 -1
- package/dist/theme/types.js.map +0 -1
- package/dist/theme/utils.d.ts.map +0 -1
- package/dist/theme/utils.js.map +0 -1
- package/dist/types/index.d.ts.map +0 -1
- package/dist/types/index.js.map +0 -1
- package/dist/utils/index.d.ts.map +0 -1
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/migration.d.ts.map +0 -1
- package/dist/utils/migration.js.map +0 -1
- package/dist/utils/validation.d.ts.map +0 -1
- package/dist/utils/validation.js.map +0 -1
- package/dist/version.d.ts.map +0 -1
- package/dist/version.js.map +0 -1
- package/dist/views/PuckConfigContext.d.ts.map +0 -1
- package/dist/views/PuckConfigContext.js.map +0 -1
- package/dist/views/PuckEditorView.d.ts.map +0 -1
- package/dist/views/PuckEditorView.js.map +0 -1
- package/dist/views/index.d.ts.map +0 -1
- package/dist/views/index.js.map +0 -1
|
@@ -10,10 +10,9 @@ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-run
|
|
|
10
10
|
* - Content alignment (left, center, right)
|
|
11
11
|
* - Progressive disclosure (simple vs advanced mode)
|
|
12
12
|
* - Preset quick-select buttons for common widths
|
|
13
|
-
*/
|
|
14
|
-
import {
|
|
15
|
-
import {
|
|
16
|
-
import { getDimensionsSummary } from './shared';
|
|
13
|
+
*/ import React, { useCallback, memo, useState } from 'react';
|
|
14
|
+
import { X, AlignStartHorizontal, AlignCenterHorizontal, AlignEndHorizontal, MoveHorizontal, Square, SlidersHorizontal, ChevronDown, ChevronUp } from 'lucide-react';
|
|
15
|
+
import { getDimensionsSummary } from './shared.js';
|
|
17
16
|
// =============================================================================
|
|
18
17
|
// Default Values
|
|
19
18
|
// =============================================================================
|
|
@@ -23,18 +22,40 @@ const DEFAULT_VALUE = {
|
|
|
23
22
|
maxWidth: {
|
|
24
23
|
value: 0,
|
|
25
24
|
unit: 'px',
|
|
26
|
-
enabled: false
|
|
25
|
+
enabled: false
|
|
27
26
|
},
|
|
28
|
-
advancedMode: false
|
|
27
|
+
advancedMode: false
|
|
29
28
|
};
|
|
30
29
|
const WIDTH_PRESETS = [
|
|
31
|
-
{
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
30
|
+
{
|
|
31
|
+
label: 'Narrow',
|
|
32
|
+
value: 680
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
label: 'Medium',
|
|
36
|
+
value: 960
|
|
37
|
+
},
|
|
38
|
+
{
|
|
39
|
+
label: 'Wide',
|
|
40
|
+
value: 1200
|
|
41
|
+
},
|
|
42
|
+
{
|
|
43
|
+
label: 'XL',
|
|
44
|
+
value: 1440
|
|
45
|
+
}
|
|
46
|
+
];
|
|
47
|
+
const WIDTH_UNITS = [
|
|
48
|
+
'px',
|
|
49
|
+
'rem',
|
|
50
|
+
'%',
|
|
51
|
+
'vw'
|
|
52
|
+
];
|
|
53
|
+
const HEIGHT_UNITS = [
|
|
54
|
+
'px',
|
|
55
|
+
'rem',
|
|
56
|
+
'%',
|
|
57
|
+
'vh'
|
|
35
58
|
];
|
|
36
|
-
const WIDTH_UNITS = ['px', 'rem', '%', 'vw'];
|
|
37
|
-
const HEIGHT_UNITS = ['px', 'rem', '%', 'vh'];
|
|
38
59
|
// =============================================================================
|
|
39
60
|
// Styles
|
|
40
61
|
// =============================================================================
|
|
@@ -42,17 +63,17 @@ const styles = {
|
|
|
42
63
|
container: {
|
|
43
64
|
display: 'flex',
|
|
44
65
|
flexDirection: 'column',
|
|
45
|
-
gap: '12px'
|
|
66
|
+
gap: '12px'
|
|
46
67
|
},
|
|
47
68
|
header: {
|
|
48
69
|
display: 'flex',
|
|
49
70
|
alignItems: 'center',
|
|
50
|
-
justifyContent: 'space-between'
|
|
71
|
+
justifyContent: 'space-between'
|
|
51
72
|
},
|
|
52
73
|
label: {
|
|
53
74
|
fontSize: '14px',
|
|
54
75
|
fontWeight: 500,
|
|
55
|
-
color: 'var(--theme-elevation-800)'
|
|
76
|
+
color: 'var(--theme-elevation-800)'
|
|
56
77
|
},
|
|
57
78
|
clearButton: {
|
|
58
79
|
display: 'flex',
|
|
@@ -65,12 +86,12 @@ const styles = {
|
|
|
65
86
|
borderRadius: '4px',
|
|
66
87
|
backgroundColor: 'transparent',
|
|
67
88
|
color: 'var(--theme-elevation-500)',
|
|
68
|
-
cursor: 'pointer'
|
|
89
|
+
cursor: 'pointer'
|
|
69
90
|
},
|
|
70
91
|
modeGroup: {
|
|
71
92
|
display: 'flex',
|
|
72
93
|
flexWrap: 'wrap',
|
|
73
|
-
gap: '4px'
|
|
94
|
+
gap: '4px'
|
|
74
95
|
},
|
|
75
96
|
modeButton: {
|
|
76
97
|
display: 'inline-flex',
|
|
@@ -83,7 +104,7 @@ const styles = {
|
|
|
83
104
|
borderRadius: '4px',
|
|
84
105
|
backgroundColor: 'var(--theme-bg)',
|
|
85
106
|
color: 'var(--theme-elevation-700)',
|
|
86
|
-
cursor: 'pointer'
|
|
107
|
+
cursor: 'pointer'
|
|
87
108
|
},
|
|
88
109
|
modeButtonActive: {
|
|
89
110
|
display: 'inline-flex',
|
|
@@ -96,7 +117,7 @@ const styles = {
|
|
|
96
117
|
borderRadius: '4px',
|
|
97
118
|
backgroundColor: 'var(--theme-elevation-800)',
|
|
98
119
|
color: 'var(--theme-bg)',
|
|
99
|
-
cursor: 'pointer'
|
|
120
|
+
cursor: 'pointer'
|
|
100
121
|
},
|
|
101
122
|
controlsPanel: {
|
|
102
123
|
display: 'flex',
|
|
@@ -104,23 +125,23 @@ const styles = {
|
|
|
104
125
|
gap: '12px',
|
|
105
126
|
padding: '12px',
|
|
106
127
|
backgroundColor: 'var(--theme-elevation-50)',
|
|
107
|
-
borderRadius: '6px'
|
|
128
|
+
borderRadius: '6px'
|
|
108
129
|
},
|
|
109
130
|
sectionLabel: {
|
|
110
131
|
fontSize: '10px',
|
|
111
132
|
textTransform: 'uppercase',
|
|
112
133
|
letterSpacing: '0.05em',
|
|
113
|
-
color: 'var(--theme-elevation-500)'
|
|
134
|
+
color: 'var(--theme-elevation-500)'
|
|
114
135
|
},
|
|
115
136
|
presetGroup: {
|
|
116
137
|
display: 'flex',
|
|
117
138
|
flexDirection: 'column',
|
|
118
|
-
gap: '6px'
|
|
139
|
+
gap: '6px'
|
|
119
140
|
},
|
|
120
141
|
presetButtons: {
|
|
121
142
|
display: 'flex',
|
|
122
143
|
flexWrap: 'wrap',
|
|
123
|
-
gap: '4px'
|
|
144
|
+
gap: '4px'
|
|
124
145
|
},
|
|
125
146
|
presetButton: {
|
|
126
147
|
flex: '1 1 auto',
|
|
@@ -133,7 +154,7 @@ const styles = {
|
|
|
133
154
|
backgroundColor: 'var(--theme-bg)',
|
|
134
155
|
color: 'var(--theme-elevation-700)',
|
|
135
156
|
cursor: 'pointer',
|
|
136
|
-
whiteSpace: 'nowrap'
|
|
157
|
+
whiteSpace: 'nowrap'
|
|
137
158
|
},
|
|
138
159
|
presetButtonActive: {
|
|
139
160
|
flex: '1 1 auto',
|
|
@@ -146,18 +167,18 @@ const styles = {
|
|
|
146
167
|
backgroundColor: 'var(--theme-elevation-800)',
|
|
147
168
|
color: 'var(--theme-bg)',
|
|
148
169
|
cursor: 'pointer',
|
|
149
|
-
whiteSpace: 'nowrap'
|
|
170
|
+
whiteSpace: 'nowrap'
|
|
150
171
|
},
|
|
151
172
|
inputGroup: {
|
|
152
173
|
display: 'flex',
|
|
153
174
|
flexDirection: 'column',
|
|
154
|
-
gap: '6px'
|
|
175
|
+
gap: '6px'
|
|
155
176
|
},
|
|
156
177
|
inputRow: {
|
|
157
178
|
display: 'flex',
|
|
158
179
|
alignItems: 'center',
|
|
159
180
|
flexWrap: 'wrap',
|
|
160
|
-
gap: '8px'
|
|
181
|
+
gap: '8px'
|
|
161
182
|
},
|
|
162
183
|
input: {
|
|
163
184
|
flex: 1,
|
|
@@ -169,12 +190,12 @@ const styles = {
|
|
|
169
190
|
border: '1px solid var(--theme-elevation-150)',
|
|
170
191
|
borderRadius: '4px',
|
|
171
192
|
backgroundColor: 'var(--theme-input-bg)',
|
|
172
|
-
color: 'var(--theme-elevation-800)'
|
|
193
|
+
color: 'var(--theme-elevation-800)'
|
|
173
194
|
},
|
|
174
195
|
unitGroup: {
|
|
175
196
|
display: 'flex',
|
|
176
197
|
flexShrink: 0,
|
|
177
|
-
gap: '4px'
|
|
198
|
+
gap: '4px'
|
|
178
199
|
},
|
|
179
200
|
unitButton: {
|
|
180
201
|
height: '32px',
|
|
@@ -185,7 +206,7 @@ const styles = {
|
|
|
185
206
|
borderRadius: '4px',
|
|
186
207
|
backgroundColor: 'var(--theme-bg)',
|
|
187
208
|
color: 'var(--theme-elevation-500)',
|
|
188
|
-
cursor: 'pointer'
|
|
209
|
+
cursor: 'pointer'
|
|
189
210
|
},
|
|
190
211
|
unitButtonActive: {
|
|
191
212
|
height: '32px',
|
|
@@ -196,28 +217,28 @@ const styles = {
|
|
|
196
217
|
borderRadius: '4px',
|
|
197
218
|
backgroundColor: 'var(--theme-elevation-800)',
|
|
198
219
|
color: 'var(--theme-bg)',
|
|
199
|
-
cursor: 'pointer'
|
|
220
|
+
cursor: 'pointer'
|
|
200
221
|
},
|
|
201
222
|
footer: {
|
|
202
223
|
display: 'flex',
|
|
203
224
|
alignItems: 'center',
|
|
204
225
|
justifyContent: 'space-between',
|
|
205
226
|
flexWrap: 'wrap',
|
|
206
|
-
gap: '8px'
|
|
227
|
+
gap: '8px'
|
|
207
228
|
},
|
|
208
229
|
alignGroup: {
|
|
209
230
|
display: 'flex',
|
|
210
231
|
alignItems: 'center',
|
|
211
|
-
gap: '8px'
|
|
232
|
+
gap: '8px'
|
|
212
233
|
},
|
|
213
234
|
alignLabel: {
|
|
214
235
|
fontSize: '12px',
|
|
215
236
|
color: 'var(--theme-elevation-500)',
|
|
216
|
-
flexShrink: 0
|
|
237
|
+
flexShrink: 0
|
|
217
238
|
},
|
|
218
239
|
alignButtons: {
|
|
219
240
|
display: 'flex',
|
|
220
|
-
gap: '4px'
|
|
241
|
+
gap: '4px'
|
|
221
242
|
},
|
|
222
243
|
alignButton: {
|
|
223
244
|
display: 'flex',
|
|
@@ -230,7 +251,7 @@ const styles = {
|
|
|
230
251
|
borderRadius: '4px',
|
|
231
252
|
backgroundColor: 'var(--theme-bg)',
|
|
232
253
|
color: 'var(--theme-elevation-700)',
|
|
233
|
-
cursor: 'pointer'
|
|
254
|
+
cursor: 'pointer'
|
|
234
255
|
},
|
|
235
256
|
alignButtonActive: {
|
|
236
257
|
display: 'flex',
|
|
@@ -243,16 +264,16 @@ const styles = {
|
|
|
243
264
|
borderRadius: '4px',
|
|
244
265
|
backgroundColor: 'var(--theme-elevation-800)',
|
|
245
266
|
color: 'var(--theme-bg)',
|
|
246
|
-
cursor: 'pointer'
|
|
267
|
+
cursor: 'pointer'
|
|
247
268
|
},
|
|
248
269
|
alignButtonDisabled: {
|
|
249
270
|
opacity: 0.5,
|
|
250
|
-
cursor: 'not-allowed'
|
|
271
|
+
cursor: 'not-allowed'
|
|
251
272
|
},
|
|
252
273
|
summary: {
|
|
253
274
|
fontSize: '12px',
|
|
254
275
|
color: 'var(--theme-elevation-500)',
|
|
255
|
-
fontFamily: 'monospace'
|
|
276
|
+
fontFamily: 'monospace'
|
|
256
277
|
},
|
|
257
278
|
advancedToggle: {
|
|
258
279
|
display: 'flex',
|
|
@@ -265,29 +286,29 @@ const styles = {
|
|
|
265
286
|
borderRadius: '4px',
|
|
266
287
|
backgroundColor: 'transparent',
|
|
267
288
|
color: 'var(--theme-elevation-500)',
|
|
268
|
-
cursor: 'pointer'
|
|
289
|
+
cursor: 'pointer'
|
|
269
290
|
},
|
|
270
291
|
constraintRow: {
|
|
271
292
|
display: 'flex',
|
|
272
293
|
alignItems: 'center',
|
|
273
|
-
gap: '8px'
|
|
294
|
+
gap: '8px'
|
|
274
295
|
},
|
|
275
296
|
checkboxLabel: {
|
|
276
297
|
display: 'flex',
|
|
277
298
|
alignItems: 'center',
|
|
278
299
|
gap: '8px',
|
|
279
300
|
cursor: 'pointer',
|
|
280
|
-
minWidth: '90px'
|
|
301
|
+
minWidth: '90px'
|
|
281
302
|
},
|
|
282
303
|
checkbox: {
|
|
283
304
|
width: '16px',
|
|
284
305
|
height: '16px',
|
|
285
306
|
accentColor: 'var(--theme-elevation-800)',
|
|
286
|
-
cursor: 'pointer'
|
|
307
|
+
cursor: 'pointer'
|
|
287
308
|
},
|
|
288
309
|
checkboxText: {
|
|
289
310
|
fontSize: '12px',
|
|
290
|
-
color: 'var(--theme-elevation-500)'
|
|
311
|
+
color: 'var(--theme-elevation-500)'
|
|
291
312
|
},
|
|
292
313
|
constraintInput: {
|
|
293
314
|
flex: 1,
|
|
@@ -299,7 +320,7 @@ const styles = {
|
|
|
299
320
|
border: '1px solid var(--theme-elevation-150)',
|
|
300
321
|
borderRadius: '4px',
|
|
301
322
|
backgroundColor: 'var(--theme-input-bg)',
|
|
302
|
-
color: 'var(--theme-elevation-800)'
|
|
323
|
+
color: 'var(--theme-elevation-800)'
|
|
303
324
|
},
|
|
304
325
|
smallUnitButton: {
|
|
305
326
|
height: '28px',
|
|
@@ -310,7 +331,7 @@ const styles = {
|
|
|
310
331
|
borderRadius: '4px',
|
|
311
332
|
backgroundColor: 'var(--theme-bg)',
|
|
312
333
|
color: 'var(--theme-elevation-500)',
|
|
313
|
-
cursor: 'pointer'
|
|
334
|
+
cursor: 'pointer'
|
|
314
335
|
},
|
|
315
336
|
smallUnitButtonActive: {
|
|
316
337
|
height: '28px',
|
|
@@ -321,218 +342,624 @@ const styles = {
|
|
|
321
342
|
borderRadius: '4px',
|
|
322
343
|
backgroundColor: 'var(--theme-elevation-800)',
|
|
323
344
|
color: 'var(--theme-bg)',
|
|
324
|
-
cursor: 'pointer'
|
|
345
|
+
cursor: 'pointer'
|
|
325
346
|
},
|
|
326
347
|
constraintsSection: {
|
|
327
348
|
display: 'flex',
|
|
328
349
|
flexDirection: 'column',
|
|
329
|
-
gap: '8px'
|
|
350
|
+
gap: '8px'
|
|
330
351
|
},
|
|
331
352
|
constraintsList: {
|
|
332
353
|
display: 'flex',
|
|
333
354
|
flexDirection: 'column',
|
|
334
355
|
gap: '8px',
|
|
335
|
-
paddingLeft: '4px'
|
|
336
|
-
}
|
|
356
|
+
paddingLeft: '4px'
|
|
357
|
+
}
|
|
337
358
|
};
|
|
338
|
-
function ConstraintInput({ label, constraint, onChange, onToggle, units, disabled, placeholder = '0'
|
|
359
|
+
function ConstraintInput({ label, constraint, onChange, onToggle, units, disabled, placeholder = '0' }) {
|
|
339
360
|
const isEnabled = constraint?.enabled ?? false;
|
|
340
361
|
const value = constraint?.value ?? 0;
|
|
341
362
|
const unit = constraint?.unit ?? 'px';
|
|
342
|
-
const handleValueChange = useCallback((e)
|
|
363
|
+
const handleValueChange = useCallback((e)=>{
|
|
343
364
|
const newValue = parseInt(e.target.value, 10) || 0;
|
|
344
365
|
onChange({
|
|
345
366
|
value: newValue,
|
|
346
367
|
unit,
|
|
347
|
-
enabled: isEnabled
|
|
368
|
+
enabled: isEnabled
|
|
348
369
|
});
|
|
349
|
-
}, [
|
|
350
|
-
|
|
370
|
+
}, [
|
|
371
|
+
unit,
|
|
372
|
+
isEnabled,
|
|
373
|
+
onChange
|
|
374
|
+
]);
|
|
375
|
+
const handleUnitChange = useCallback((newUnit)=>{
|
|
351
376
|
onChange({
|
|
352
377
|
value,
|
|
353
378
|
unit: newUnit,
|
|
354
|
-
enabled: isEnabled
|
|
379
|
+
enabled: isEnabled
|
|
355
380
|
});
|
|
356
|
-
}, [
|
|
357
|
-
|
|
381
|
+
}, [
|
|
382
|
+
value,
|
|
383
|
+
isEnabled,
|
|
384
|
+
onChange
|
|
385
|
+
]);
|
|
386
|
+
const handleToggle = useCallback((e)=>{
|
|
358
387
|
onToggle(e.target.checked);
|
|
359
|
-
}, [
|
|
360
|
-
|
|
388
|
+
}, [
|
|
389
|
+
onToggle
|
|
390
|
+
]);
|
|
391
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
392
|
+
style: styles.constraintRow,
|
|
393
|
+
children: [
|
|
394
|
+
/*#__PURE__*/ _jsxs("label", {
|
|
395
|
+
style: styles.checkboxLabel,
|
|
396
|
+
children: [
|
|
397
|
+
/*#__PURE__*/ _jsx("input", {
|
|
398
|
+
type: "checkbox",
|
|
399
|
+
checked: isEnabled,
|
|
400
|
+
onChange: handleToggle,
|
|
401
|
+
disabled: disabled,
|
|
402
|
+
style: styles.checkbox
|
|
403
|
+
}),
|
|
404
|
+
/*#__PURE__*/ _jsx("span", {
|
|
405
|
+
style: styles.checkboxText,
|
|
406
|
+
children: label
|
|
407
|
+
})
|
|
408
|
+
]
|
|
409
|
+
}),
|
|
410
|
+
/*#__PURE__*/ _jsx("input", {
|
|
411
|
+
type: "number",
|
|
412
|
+
min: 0,
|
|
413
|
+
value: isEnabled ? value : '',
|
|
414
|
+
onChange: handleValueChange,
|
|
415
|
+
disabled: disabled || !isEnabled,
|
|
416
|
+
placeholder: placeholder,
|
|
417
|
+
style: {
|
|
361
418
|
...styles.constraintInput,
|
|
362
|
-
...
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
419
|
+
...disabled || !isEnabled ? {
|
|
420
|
+
opacity: 0.5
|
|
421
|
+
} : {}
|
|
422
|
+
}
|
|
423
|
+
}),
|
|
424
|
+
/*#__PURE__*/ _jsx("div", {
|
|
425
|
+
style: {
|
|
426
|
+
display: 'flex',
|
|
427
|
+
gap: '2px',
|
|
428
|
+
flexShrink: 0
|
|
429
|
+
},
|
|
430
|
+
children: units.map((u)=>/*#__PURE__*/ _jsx("button", {
|
|
431
|
+
type: "button",
|
|
432
|
+
onClick: ()=>handleUnitChange(u),
|
|
433
|
+
disabled: disabled || !isEnabled,
|
|
434
|
+
style: {
|
|
435
|
+
...unit === u && isEnabled ? styles.smallUnitButtonActive : styles.smallUnitButton,
|
|
436
|
+
...disabled || !isEnabled ? {
|
|
437
|
+
opacity: 0.5,
|
|
438
|
+
cursor: 'not-allowed'
|
|
439
|
+
} : {}
|
|
440
|
+
},
|
|
441
|
+
children: u
|
|
442
|
+
}, u))
|
|
443
|
+
})
|
|
444
|
+
]
|
|
445
|
+
});
|
|
367
446
|
}
|
|
368
447
|
// =============================================================================
|
|
369
448
|
// DimensionsField Component
|
|
370
449
|
// =============================================================================
|
|
371
|
-
function DimensionsFieldInner({ value, onChange, label, readOnly, showHeightControls = true, showMinControls = true, defaultAdvancedMode = false
|
|
450
|
+
function DimensionsFieldInner({ value, onChange, label, readOnly, showHeightControls = true, showMinControls = true, defaultAdvancedMode = false }) {
|
|
372
451
|
const currentValue = value || DEFAULT_VALUE;
|
|
373
452
|
const [advancedMode, setAdvancedMode] = useState(currentValue.advancedMode ?? defaultAdvancedMode);
|
|
374
453
|
// Handle mode change
|
|
375
|
-
const handleModeChange = useCallback((mode)
|
|
454
|
+
const handleModeChange = useCallback((mode)=>{
|
|
376
455
|
if (mode === 'full') {
|
|
377
456
|
onChange({
|
|
378
457
|
...currentValue,
|
|
379
458
|
mode,
|
|
380
|
-
alignment: 'center'
|
|
459
|
+
alignment: 'center'
|
|
381
460
|
});
|
|
382
|
-
}
|
|
383
|
-
else {
|
|
461
|
+
} else {
|
|
384
462
|
onChange({
|
|
385
463
|
...currentValue,
|
|
386
|
-
mode
|
|
464
|
+
mode
|
|
387
465
|
});
|
|
388
466
|
}
|
|
389
|
-
}, [
|
|
467
|
+
}, [
|
|
468
|
+
currentValue,
|
|
469
|
+
onChange
|
|
470
|
+
]);
|
|
390
471
|
// Handle max width value change
|
|
391
|
-
const handleMaxWidthChange = useCallback((constraint)
|
|
472
|
+
const handleMaxWidthChange = useCallback((constraint)=>{
|
|
392
473
|
onChange({
|
|
393
474
|
...currentValue,
|
|
394
|
-
maxWidth: constraint
|
|
475
|
+
maxWidth: constraint
|
|
395
476
|
});
|
|
396
|
-
}, [
|
|
477
|
+
}, [
|
|
478
|
+
currentValue,
|
|
479
|
+
onChange
|
|
480
|
+
]);
|
|
397
481
|
// Handle max width toggle
|
|
398
|
-
const handleMaxWidthToggle = useCallback((enabled)
|
|
482
|
+
const handleMaxWidthToggle = useCallback((enabled)=>{
|
|
399
483
|
onChange({
|
|
400
484
|
...currentValue,
|
|
401
485
|
maxWidth: {
|
|
402
486
|
...currentValue.maxWidth,
|
|
403
|
-
enabled
|
|
404
|
-
}
|
|
487
|
+
enabled
|
|
488
|
+
}
|
|
405
489
|
});
|
|
406
|
-
}, [
|
|
490
|
+
}, [
|
|
491
|
+
currentValue,
|
|
492
|
+
onChange
|
|
493
|
+
]);
|
|
407
494
|
// Handle min width change
|
|
408
|
-
const handleMinWidthChange = useCallback((constraint)
|
|
495
|
+
const handleMinWidthChange = useCallback((constraint)=>{
|
|
409
496
|
onChange({
|
|
410
497
|
...currentValue,
|
|
411
|
-
minWidth: constraint
|
|
498
|
+
minWidth: constraint
|
|
412
499
|
});
|
|
413
|
-
}, [
|
|
500
|
+
}, [
|
|
501
|
+
currentValue,
|
|
502
|
+
onChange
|
|
503
|
+
]);
|
|
414
504
|
// Handle min width toggle
|
|
415
|
-
const handleMinWidthToggle = useCallback((enabled)
|
|
505
|
+
const handleMinWidthToggle = useCallback((enabled)=>{
|
|
416
506
|
onChange({
|
|
417
507
|
...currentValue,
|
|
418
|
-
minWidth: enabled
|
|
419
|
-
|
|
420
|
-
:
|
|
508
|
+
minWidth: enabled ? {
|
|
509
|
+
value: currentValue.minWidth?.value ?? 0,
|
|
510
|
+
unit: currentValue.minWidth?.unit ?? 'px',
|
|
511
|
+
enabled: true
|
|
512
|
+
} : {
|
|
513
|
+
...currentValue.minWidth,
|
|
514
|
+
enabled: false
|
|
515
|
+
}
|
|
421
516
|
});
|
|
422
|
-
}, [
|
|
517
|
+
}, [
|
|
518
|
+
currentValue,
|
|
519
|
+
onChange
|
|
520
|
+
]);
|
|
423
521
|
// Handle min height change
|
|
424
|
-
const handleMinHeightChange = useCallback((constraint)
|
|
522
|
+
const handleMinHeightChange = useCallback((constraint)=>{
|
|
425
523
|
onChange({
|
|
426
524
|
...currentValue,
|
|
427
|
-
minHeight: constraint
|
|
525
|
+
minHeight: constraint
|
|
428
526
|
});
|
|
429
|
-
}, [
|
|
527
|
+
}, [
|
|
528
|
+
currentValue,
|
|
529
|
+
onChange
|
|
530
|
+
]);
|
|
430
531
|
// Handle min height toggle
|
|
431
|
-
const handleMinHeightToggle = useCallback((enabled)
|
|
532
|
+
const handleMinHeightToggle = useCallback((enabled)=>{
|
|
432
533
|
onChange({
|
|
433
534
|
...currentValue,
|
|
434
|
-
minHeight: enabled
|
|
435
|
-
|
|
436
|
-
: currentValue.minHeight
|
|
535
|
+
minHeight: enabled ? {
|
|
536
|
+
value: currentValue.minHeight?.value ?? 0,
|
|
537
|
+
unit: currentValue.minHeight?.unit ?? 'px',
|
|
538
|
+
enabled: true
|
|
539
|
+
} : currentValue.minHeight ? {
|
|
540
|
+
...currentValue.minHeight,
|
|
541
|
+
enabled: false
|
|
542
|
+
} : null
|
|
437
543
|
});
|
|
438
|
-
}, [
|
|
544
|
+
}, [
|
|
545
|
+
currentValue,
|
|
546
|
+
onChange
|
|
547
|
+
]);
|
|
439
548
|
// Handle max height change
|
|
440
|
-
const handleMaxHeightChange = useCallback((constraint)
|
|
549
|
+
const handleMaxHeightChange = useCallback((constraint)=>{
|
|
441
550
|
onChange({
|
|
442
551
|
...currentValue,
|
|
443
|
-
maxHeight: constraint
|
|
552
|
+
maxHeight: constraint
|
|
444
553
|
});
|
|
445
|
-
}, [
|
|
554
|
+
}, [
|
|
555
|
+
currentValue,
|
|
556
|
+
onChange
|
|
557
|
+
]);
|
|
446
558
|
// Handle max height toggle
|
|
447
|
-
const handleMaxHeightToggle = useCallback((enabled)
|
|
559
|
+
const handleMaxHeightToggle = useCallback((enabled)=>{
|
|
448
560
|
onChange({
|
|
449
561
|
...currentValue,
|
|
450
|
-
maxHeight: enabled
|
|
451
|
-
|
|
452
|
-
: currentValue.maxHeight
|
|
562
|
+
maxHeight: enabled ? {
|
|
563
|
+
value: currentValue.maxHeight?.value ?? 0,
|
|
564
|
+
unit: currentValue.maxHeight?.unit ?? 'px',
|
|
565
|
+
enabled: true
|
|
566
|
+
} : currentValue.maxHeight ? {
|
|
567
|
+
...currentValue.maxHeight,
|
|
568
|
+
enabled: false
|
|
569
|
+
} : null
|
|
453
570
|
});
|
|
454
|
-
}, [
|
|
571
|
+
}, [
|
|
572
|
+
currentValue,
|
|
573
|
+
onChange
|
|
574
|
+
]);
|
|
455
575
|
// Handle alignment change
|
|
456
|
-
const handleAlignmentChange = useCallback((alignment)
|
|
576
|
+
const handleAlignmentChange = useCallback((alignment)=>{
|
|
457
577
|
onChange({
|
|
458
578
|
...currentValue,
|
|
459
|
-
alignment
|
|
579
|
+
alignment
|
|
460
580
|
});
|
|
461
|
-
}, [
|
|
581
|
+
}, [
|
|
582
|
+
currentValue,
|
|
583
|
+
onChange
|
|
584
|
+
]);
|
|
462
585
|
// Handle preset selection
|
|
463
|
-
const handlePresetSelect = useCallback((presetValue)
|
|
586
|
+
const handlePresetSelect = useCallback((presetValue)=>{
|
|
464
587
|
onChange({
|
|
465
588
|
...currentValue,
|
|
466
589
|
mode: 'contained',
|
|
467
590
|
maxWidth: {
|
|
468
591
|
value: presetValue,
|
|
469
592
|
unit: 'px',
|
|
470
|
-
enabled: true
|
|
471
|
-
}
|
|
593
|
+
enabled: true
|
|
594
|
+
}
|
|
472
595
|
});
|
|
473
|
-
}, [
|
|
596
|
+
}, [
|
|
597
|
+
currentValue,
|
|
598
|
+
onChange
|
|
599
|
+
]);
|
|
474
600
|
// Handle clear
|
|
475
|
-
const handleClear = useCallback(()
|
|
601
|
+
const handleClear = useCallback(()=>{
|
|
476
602
|
onChange(null);
|
|
477
|
-
}, [
|
|
603
|
+
}, [
|
|
604
|
+
onChange
|
|
605
|
+
]);
|
|
478
606
|
// Handle advanced mode toggle
|
|
479
|
-
const handleAdvancedToggle = useCallback(()
|
|
607
|
+
const handleAdvancedToggle = useCallback(()=>{
|
|
480
608
|
const newAdvancedMode = !advancedMode;
|
|
481
609
|
setAdvancedMode(newAdvancedMode);
|
|
482
610
|
if (value !== null) {
|
|
483
611
|
onChange({
|
|
484
612
|
...currentValue,
|
|
485
|
-
advancedMode: newAdvancedMode
|
|
613
|
+
advancedMode: newAdvancedMode
|
|
486
614
|
});
|
|
487
615
|
}
|
|
488
|
-
}, [
|
|
616
|
+
}, [
|
|
617
|
+
advancedMode,
|
|
618
|
+
currentValue,
|
|
619
|
+
onChange,
|
|
620
|
+
value
|
|
621
|
+
]);
|
|
489
622
|
// Mode labels
|
|
490
623
|
const modeConfig = [
|
|
491
|
-
{
|
|
492
|
-
|
|
493
|
-
|
|
624
|
+
{
|
|
625
|
+
mode: 'full',
|
|
626
|
+
icon: MoveHorizontal,
|
|
627
|
+
label: 'Full',
|
|
628
|
+
title: 'Full width (100%)'
|
|
629
|
+
},
|
|
630
|
+
{
|
|
631
|
+
mode: 'contained',
|
|
632
|
+
icon: Square,
|
|
633
|
+
label: 'Contain',
|
|
634
|
+
title: 'Contained (centered with max-width)'
|
|
635
|
+
},
|
|
636
|
+
{
|
|
637
|
+
mode: 'custom',
|
|
638
|
+
icon: SlidersHorizontal,
|
|
639
|
+
label: 'Custom',
|
|
640
|
+
title: 'Custom width settings'
|
|
641
|
+
}
|
|
494
642
|
];
|
|
495
643
|
const alignmentConfig = [
|
|
496
|
-
{
|
|
497
|
-
|
|
498
|
-
|
|
644
|
+
{
|
|
645
|
+
alignment: 'left',
|
|
646
|
+
icon: AlignStartHorizontal,
|
|
647
|
+
title: 'Align left'
|
|
648
|
+
},
|
|
649
|
+
{
|
|
650
|
+
alignment: 'center',
|
|
651
|
+
icon: AlignCenterHorizontal,
|
|
652
|
+
title: 'Align center'
|
|
653
|
+
},
|
|
654
|
+
{
|
|
655
|
+
alignment: 'right',
|
|
656
|
+
icon: AlignEndHorizontal,
|
|
657
|
+
title: 'Align right'
|
|
658
|
+
}
|
|
499
659
|
];
|
|
500
660
|
const showWidthControls = currentValue.mode !== 'full';
|
|
501
|
-
return
|
|
661
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
662
|
+
className: "puck-field",
|
|
663
|
+
style: styles.container,
|
|
664
|
+
children: [
|
|
665
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
666
|
+
style: styles.header,
|
|
667
|
+
children: [
|
|
668
|
+
label && /*#__PURE__*/ _jsx("label", {
|
|
669
|
+
style: styles.label,
|
|
670
|
+
children: label
|
|
671
|
+
}),
|
|
672
|
+
value && !readOnly && /*#__PURE__*/ _jsx("button", {
|
|
673
|
+
type: "button",
|
|
674
|
+
onClick: handleClear,
|
|
675
|
+
style: styles.clearButton,
|
|
676
|
+
title: "Reset to default",
|
|
677
|
+
children: /*#__PURE__*/ _jsx(X, {
|
|
678
|
+
style: {
|
|
679
|
+
width: '16px',
|
|
680
|
+
height: '16px'
|
|
681
|
+
}
|
|
682
|
+
})
|
|
683
|
+
})
|
|
684
|
+
]
|
|
685
|
+
}),
|
|
686
|
+
/*#__PURE__*/ _jsx("div", {
|
|
687
|
+
style: styles.modeGroup,
|
|
688
|
+
children: modeConfig.map(({ mode, icon: Icon, label: modeLabel, title })=>{
|
|
502
689
|
const isActive = currentValue.mode === mode;
|
|
503
|
-
return
|
|
504
|
-
|
|
505
|
-
|
|
506
|
-
|
|
507
|
-
|
|
508
|
-
|
|
509
|
-
|
|
510
|
-
|
|
511
|
-
|
|
512
|
-
|
|
690
|
+
return /*#__PURE__*/ _jsxs("button", {
|
|
691
|
+
type: "button",
|
|
692
|
+
onClick: ()=>handleModeChange(mode),
|
|
693
|
+
disabled: readOnly,
|
|
694
|
+
style: isActive ? styles.modeButtonActive : styles.modeButton,
|
|
695
|
+
title: title,
|
|
696
|
+
children: [
|
|
697
|
+
/*#__PURE__*/ _jsx(Icon, {
|
|
698
|
+
style: {
|
|
699
|
+
width: '14px',
|
|
700
|
+
height: '14px'
|
|
701
|
+
}
|
|
702
|
+
}),
|
|
703
|
+
modeLabel
|
|
704
|
+
]
|
|
705
|
+
}, mode);
|
|
706
|
+
})
|
|
707
|
+
}),
|
|
708
|
+
showWidthControls && /*#__PURE__*/ _jsxs("div", {
|
|
709
|
+
style: styles.controlsPanel,
|
|
710
|
+
children: [
|
|
711
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
712
|
+
style: styles.presetGroup,
|
|
713
|
+
children: [
|
|
714
|
+
/*#__PURE__*/ _jsx("label", {
|
|
715
|
+
style: styles.sectionLabel,
|
|
716
|
+
children: "Presets"
|
|
717
|
+
}),
|
|
718
|
+
/*#__PURE__*/ _jsx("div", {
|
|
719
|
+
style: styles.presetButtons,
|
|
720
|
+
children: WIDTH_PRESETS.map((preset)=>{
|
|
721
|
+
const isActive = currentValue.maxWidth.value === preset.value && currentValue.maxWidth.unit === 'px' && currentValue.maxWidth.enabled;
|
|
722
|
+
return /*#__PURE__*/ _jsx("button", {
|
|
723
|
+
type: "button",
|
|
724
|
+
onClick: ()=>handlePresetSelect(preset.value),
|
|
725
|
+
disabled: readOnly,
|
|
726
|
+
style: isActive ? styles.presetButtonActive : styles.presetButton,
|
|
727
|
+
children: preset.label
|
|
728
|
+
}, preset.value);
|
|
729
|
+
})
|
|
730
|
+
})
|
|
731
|
+
]
|
|
732
|
+
}),
|
|
733
|
+
!advancedMode && /*#__PURE__*/ _jsxs("div", {
|
|
734
|
+
style: styles.inputGroup,
|
|
735
|
+
children: [
|
|
736
|
+
/*#__PURE__*/ _jsx("label", {
|
|
737
|
+
style: styles.sectionLabel,
|
|
738
|
+
children: "Max Width"
|
|
739
|
+
}),
|
|
740
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
741
|
+
style: styles.inputRow,
|
|
742
|
+
children: [
|
|
743
|
+
/*#__PURE__*/ _jsx("input", {
|
|
744
|
+
type: "number",
|
|
745
|
+
min: 0,
|
|
746
|
+
value: currentValue.maxWidth.value,
|
|
747
|
+
onChange: (e)=>handleMaxWidthChange({
|
|
748
|
+
...currentValue.maxWidth,
|
|
749
|
+
value: parseInt(e.target.value, 10) || 0
|
|
750
|
+
}),
|
|
751
|
+
disabled: readOnly,
|
|
752
|
+
style: styles.input
|
|
753
|
+
}),
|
|
754
|
+
/*#__PURE__*/ _jsx("div", {
|
|
755
|
+
style: styles.unitGroup,
|
|
756
|
+
children: WIDTH_UNITS.map((unit)=>{
|
|
513
757
|
const isActive = currentValue.maxWidth.unit === unit;
|
|
514
|
-
return
|
|
515
|
-
|
|
516
|
-
|
|
517
|
-
|
|
518
|
-
|
|
758
|
+
return /*#__PURE__*/ _jsx("button", {
|
|
759
|
+
type: "button",
|
|
760
|
+
onClick: ()=>handleMaxWidthChange({
|
|
761
|
+
...currentValue.maxWidth,
|
|
762
|
+
unit
|
|
763
|
+
}),
|
|
764
|
+
disabled: readOnly,
|
|
765
|
+
style: isActive ? styles.unitButtonActive : styles.unitButton,
|
|
766
|
+
children: unit
|
|
767
|
+
}, unit);
|
|
768
|
+
})
|
|
769
|
+
})
|
|
770
|
+
]
|
|
771
|
+
})
|
|
772
|
+
]
|
|
773
|
+
}),
|
|
774
|
+
advancedMode && /*#__PURE__*/ _jsxs("div", {
|
|
775
|
+
style: {
|
|
776
|
+
display: 'flex',
|
|
777
|
+
flexDirection: 'column',
|
|
778
|
+
gap: '16px'
|
|
779
|
+
},
|
|
780
|
+
children: [
|
|
781
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
782
|
+
style: styles.constraintsSection,
|
|
783
|
+
children: [
|
|
784
|
+
/*#__PURE__*/ _jsx("label", {
|
|
785
|
+
style: styles.sectionLabel,
|
|
786
|
+
children: "Width Constraints"
|
|
787
|
+
}),
|
|
788
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
789
|
+
style: styles.constraintsList,
|
|
790
|
+
children: [
|
|
791
|
+
showMinControls && /*#__PURE__*/ _jsx(ConstraintInput, {
|
|
792
|
+
label: "Min Width",
|
|
793
|
+
constraint: currentValue.minWidth,
|
|
794
|
+
onChange: handleMinWidthChange,
|
|
795
|
+
onToggle: handleMinWidthToggle,
|
|
796
|
+
units: WIDTH_UNITS,
|
|
797
|
+
disabled: readOnly
|
|
798
|
+
}),
|
|
799
|
+
/*#__PURE__*/ _jsx(ConstraintInput, {
|
|
800
|
+
label: "Max Width",
|
|
801
|
+
constraint: currentValue.maxWidth,
|
|
802
|
+
onChange: handleMaxWidthChange,
|
|
803
|
+
onToggle: handleMaxWidthToggle,
|
|
804
|
+
units: WIDTH_UNITS,
|
|
805
|
+
disabled: readOnly
|
|
806
|
+
})
|
|
807
|
+
]
|
|
808
|
+
})
|
|
809
|
+
]
|
|
810
|
+
}),
|
|
811
|
+
showHeightControls && /*#__PURE__*/ _jsxs("div", {
|
|
812
|
+
style: styles.constraintsSection,
|
|
813
|
+
children: [
|
|
814
|
+
/*#__PURE__*/ _jsx("label", {
|
|
815
|
+
style: styles.sectionLabel,
|
|
816
|
+
children: "Height Constraints"
|
|
817
|
+
}),
|
|
818
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
819
|
+
style: styles.constraintsList,
|
|
820
|
+
children: [
|
|
821
|
+
showMinControls && /*#__PURE__*/ _jsx(ConstraintInput, {
|
|
822
|
+
label: "Min Height",
|
|
823
|
+
constraint: currentValue.minHeight,
|
|
824
|
+
onChange: handleMinHeightChange,
|
|
825
|
+
onToggle: handleMinHeightToggle,
|
|
826
|
+
units: HEIGHT_UNITS,
|
|
827
|
+
disabled: readOnly
|
|
828
|
+
}),
|
|
829
|
+
/*#__PURE__*/ _jsx(ConstraintInput, {
|
|
830
|
+
label: "Max Height",
|
|
831
|
+
constraint: currentValue.maxHeight,
|
|
832
|
+
onChange: handleMaxHeightChange,
|
|
833
|
+
onToggle: handleMaxHeightToggle,
|
|
834
|
+
units: HEIGHT_UNITS,
|
|
835
|
+
disabled: readOnly
|
|
836
|
+
})
|
|
837
|
+
]
|
|
838
|
+
})
|
|
839
|
+
]
|
|
840
|
+
})
|
|
841
|
+
]
|
|
842
|
+
})
|
|
843
|
+
]
|
|
844
|
+
}),
|
|
845
|
+
!showWidthControls && showHeightControls && advancedMode && /*#__PURE__*/ _jsxs("div", {
|
|
846
|
+
style: styles.controlsPanel,
|
|
847
|
+
children: [
|
|
848
|
+
/*#__PURE__*/ _jsx("label", {
|
|
849
|
+
style: styles.sectionLabel,
|
|
850
|
+
children: "Height Constraints"
|
|
851
|
+
}),
|
|
852
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
853
|
+
style: styles.constraintsList,
|
|
854
|
+
children: [
|
|
855
|
+
showMinControls && /*#__PURE__*/ _jsx(ConstraintInput, {
|
|
856
|
+
label: "Min Height",
|
|
857
|
+
constraint: currentValue.minHeight,
|
|
858
|
+
onChange: handleMinHeightChange,
|
|
859
|
+
onToggle: handleMinHeightToggle,
|
|
860
|
+
units: HEIGHT_UNITS,
|
|
861
|
+
disabled: readOnly
|
|
862
|
+
}),
|
|
863
|
+
/*#__PURE__*/ _jsx(ConstraintInput, {
|
|
864
|
+
label: "Max Height",
|
|
865
|
+
constraint: currentValue.maxHeight,
|
|
866
|
+
onChange: handleMaxHeightChange,
|
|
867
|
+
onToggle: handleMaxHeightToggle,
|
|
868
|
+
units: HEIGHT_UNITS,
|
|
869
|
+
disabled: readOnly
|
|
870
|
+
})
|
|
871
|
+
]
|
|
872
|
+
})
|
|
873
|
+
]
|
|
874
|
+
}),
|
|
875
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
876
|
+
style: styles.footer,
|
|
877
|
+
children: [
|
|
878
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
879
|
+
style: styles.alignGroup,
|
|
880
|
+
children: [
|
|
881
|
+
/*#__PURE__*/ _jsx("label", {
|
|
882
|
+
style: styles.alignLabel,
|
|
883
|
+
children: "Align:"
|
|
884
|
+
}),
|
|
885
|
+
/*#__PURE__*/ _jsx("div", {
|
|
886
|
+
style: styles.alignButtons,
|
|
887
|
+
children: alignmentConfig.map(({ alignment, icon: Icon, title })=>{
|
|
519
888
|
const isActive = currentValue.alignment === alignment;
|
|
520
889
|
const isDisabled = readOnly || currentValue.mode === 'full';
|
|
521
|
-
return
|
|
522
|
-
|
|
523
|
-
|
|
524
|
-
|
|
525
|
-
|
|
890
|
+
return /*#__PURE__*/ _jsx("button", {
|
|
891
|
+
type: "button",
|
|
892
|
+
onClick: ()=>handleAlignmentChange(alignment),
|
|
893
|
+
disabled: isDisabled,
|
|
894
|
+
style: {
|
|
895
|
+
...isActive ? styles.alignButtonActive : styles.alignButton,
|
|
896
|
+
...isDisabled ? styles.alignButtonDisabled : {}
|
|
897
|
+
},
|
|
898
|
+
title: title,
|
|
899
|
+
children: /*#__PURE__*/ _jsx(Icon, {
|
|
900
|
+
style: {
|
|
901
|
+
width: '14px',
|
|
902
|
+
height: '14px'
|
|
903
|
+
}
|
|
904
|
+
})
|
|
905
|
+
}, alignment);
|
|
906
|
+
})
|
|
907
|
+
})
|
|
908
|
+
]
|
|
909
|
+
}),
|
|
910
|
+
/*#__PURE__*/ _jsx("span", {
|
|
911
|
+
style: styles.summary,
|
|
912
|
+
children: getDimensionsSummary(currentValue)
|
|
913
|
+
})
|
|
914
|
+
]
|
|
915
|
+
}),
|
|
916
|
+
(showHeightControls || showMinControls) && /*#__PURE__*/ _jsx("button", {
|
|
917
|
+
type: "button",
|
|
918
|
+
onClick: handleAdvancedToggle,
|
|
919
|
+
disabled: readOnly,
|
|
920
|
+
style: styles.advancedToggle,
|
|
921
|
+
children: advancedMode ? /*#__PURE__*/ _jsxs(_Fragment, {
|
|
922
|
+
children: [
|
|
923
|
+
/*#__PURE__*/ _jsx(ChevronUp, {
|
|
924
|
+
style: {
|
|
925
|
+
width: '14px',
|
|
926
|
+
height: '14px',
|
|
927
|
+
marginRight: '4px'
|
|
928
|
+
}
|
|
929
|
+
}),
|
|
930
|
+
"Hide Advanced"
|
|
931
|
+
]
|
|
932
|
+
}) : /*#__PURE__*/ _jsxs(_Fragment, {
|
|
933
|
+
children: [
|
|
934
|
+
/*#__PURE__*/ _jsx(ChevronDown, {
|
|
935
|
+
style: {
|
|
936
|
+
width: '14px',
|
|
937
|
+
height: '14px',
|
|
938
|
+
marginRight: '4px'
|
|
939
|
+
}
|
|
940
|
+
}),
|
|
941
|
+
"Show Advanced"
|
|
942
|
+
]
|
|
943
|
+
})
|
|
944
|
+
})
|
|
945
|
+
]
|
|
946
|
+
});
|
|
526
947
|
}
|
|
527
|
-
export const DimensionsField = memo(DimensionsFieldInner);
|
|
948
|
+
export const DimensionsField = /*#__PURE__*/ memo(DimensionsFieldInner);
|
|
528
949
|
/**
|
|
529
950
|
* Creates a Puck field configuration for dimensions control
|
|
530
|
-
*/
|
|
531
|
-
export function createDimensionsField(config = {}) {
|
|
951
|
+
*/ export function createDimensionsField(config = {}) {
|
|
532
952
|
return {
|
|
533
953
|
type: 'custom',
|
|
534
954
|
label: config.label,
|
|
535
|
-
render: ({ value, onChange, readOnly })
|
|
955
|
+
render: ({ value, onChange, readOnly })=>/*#__PURE__*/ _jsx(DimensionsField, {
|
|
956
|
+
value: value,
|
|
957
|
+
onChange: onChange,
|
|
958
|
+
label: config.label,
|
|
959
|
+
readOnly: readOnly,
|
|
960
|
+
showHeightControls: config.showHeightControls,
|
|
961
|
+
showMinControls: config.showMinControls,
|
|
962
|
+
defaultAdvancedMode: config.defaultAdvancedMode
|
|
963
|
+
})
|
|
536
964
|
};
|
|
537
965
|
}
|
|
538
|
-
//# sourceMappingURL=DimensionsField.js.map
|