@delmaredigital/payload-puck 0.6.10 → 0.6.13
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 +79 -1
- package/dist/admin/EditWithPuckButton.d.ts +1 -1
- package/dist/admin/EditWithPuckButton.d.ts.map +1 -1
- package/dist/admin/EditWithPuckButton.js +65 -25
- package/dist/admin/EditWithPuckButton.js.map +1 -1
- package/dist/admin/EditWithPuckCell.js +43 -13
- package/dist/admin/EditWithPuckCell.js.map +1 -1
- package/dist/admin/PuckEditorView.d.ts +1 -1
- package/dist/admin/PuckEditorView.d.ts.map +1 -1
- package/dist/admin/PuckEditorView.js +118 -32
- package/dist/admin/PuckEditorView.js.map +1 -1
- package/dist/admin/client.d.ts +2 -2
- package/dist/admin/client.d.ts.map +1 -1
- package/dist/admin/client.js +4 -4
- package/dist/admin/client.js.map +1 -1
- package/dist/admin/generateAdminComponents.js +7 -7
- package/dist/admin/generateAdminComponents.js.map +1 -1
- package/dist/admin/index.d.ts +5 -5
- package/dist/admin/index.d.ts.map +1 -1
- package/dist/admin/index.js +3 -2
- package/dist/admin/index.js.map +1 -1
- package/dist/ai/collections/AiContext.js +56 -29
- package/dist/ai/collections/AiContext.js.map +1 -1
- package/dist/ai/collections/AiPrompts.js +24 -19
- package/dist/ai/collections/AiPrompts.js.map +1 -1
- package/dist/ai/createAiApiRoutes.js +28 -19
- package/dist/ai/createAiApiRoutes.js.map +1 -1
- package/dist/ai/createAiGenerate.js +7 -8
- package/dist/ai/createAiGenerate.js.map +1 -1
- package/dist/ai/createAiPlugin.js +7 -9
- package/dist/ai/createAiPlugin.js.map +1 -1
- package/dist/ai/hooks/useAiContext.js +50 -39
- package/dist/ai/hooks/useAiContext.js.map +1 -1
- package/dist/ai/hooks/useAiPrompts.js +33 -25
- package/dist/ai/hooks/useAiPrompts.js.map +1 -1
- package/dist/ai/index.js +9 -10
- package/dist/ai/index.js.map +1 -1
- package/dist/ai/plugins/ContextEditorPanel.d.ts +1 -1
- package/dist/ai/plugins/ContextEditorPanel.d.ts.map +1 -1
- package/dist/ai/plugins/ContextEditorPanel.js +399 -107
- package/dist/ai/plugins/ContextEditorPanel.js.map +1 -1
- package/dist/ai/plugins/PromptEditorPanel.d.ts +1 -1
- package/dist/ai/plugins/PromptEditorPanel.d.ts.map +1 -1
- package/dist/ai/plugins/PromptEditorPanel.js +237 -51
- package/dist/ai/plugins/PromptEditorPanel.js.map +1 -1
- package/dist/ai/plugins/contextEditorPlugin.js +12 -5
- package/dist/ai/plugins/contextEditorPlugin.js.map +1 -1
- package/dist/ai/plugins/promptApiRoutes.js +119 -50
- package/dist/ai/plugins/promptApiRoutes.js.map +1 -1
- package/dist/ai/plugins/promptEditorPlugin.js +12 -5
- package/dist/ai/plugins/promptEditorPlugin.js.map +1 -1
- package/dist/ai/presets/componentAiDefaults.js +108 -83
- package/dist/ai/presets/componentAiDefaults.js.map +1 -1
- package/dist/ai/presets/index.js +12 -18
- package/dist/ai/presets/index.js.map +1 -1
- package/dist/ai/presets/instructions/interactive.js +85 -75
- package/dist/ai/presets/instructions/interactive.js.map +1 -1
- package/dist/ai/presets/instructions/layout.js +122 -117
- package/dist/ai/presets/instructions/layout.js.map +1 -1
- package/dist/ai/presets/instructions/media.js +31 -29
- package/dist/ai/presets/instructions/media.js.map +1 -1
- package/dist/ai/presets/instructions/pagePatterns.js +4 -6
- package/dist/ai/presets/instructions/pagePatterns.js.map +1 -1
- package/dist/ai/presets/instructions/schemas.js +495 -137
- package/dist/ai/presets/instructions/schemas.js.map +1 -1
- package/dist/ai/presets/instructions/typography.js +38 -33
- package/dist/ai/presets/instructions/typography.js.map +1 -1
- package/dist/ai/tools/index.js +92 -55
- package/dist/ai/tools/index.js.map +1 -1
- package/dist/ai/types.js +7 -1
- package/dist/ai/types.js.map +1 -1
- package/dist/ai/utils/injectAiConfig.js +33 -40
- package/dist/ai/utils/injectAiConfig.js.map +1 -1
- package/dist/api/createPuckApiRoutes.d.ts +1 -1
- package/dist/api/createPuckApiRoutes.d.ts.map +1 -1
- package/dist/api/createPuckApiRoutes.js +123 -65
- package/dist/api/createPuckApiRoutes.js.map +1 -1
- package/dist/api/createPuckApiRoutesVersions.d.ts +1 -1
- package/dist/api/createPuckApiRoutesVersions.d.ts.map +1 -1
- package/dist/api/createPuckApiRoutesVersions.js +88 -37
- package/dist/api/createPuckApiRoutesVersions.js.map +1 -1
- package/dist/api/createPuckApiRoutesWithId.d.ts +1 -1
- package/dist/api/createPuckApiRoutesWithId.d.ts.map +1 -1
- package/dist/api/createPuckApiRoutesWithId.js +166 -72
- package/dist/api/createPuckApiRoutesWithId.js.map +1 -1
- package/dist/api/index.d.ts +5 -5
- package/dist/api/index.d.ts.map +1 -1
- package/dist/api/index.js +6 -6
- package/dist/api/index.js.map +1 -1
- package/dist/api/payload-config.d.js +15 -0
- package/dist/api/payload-config.d.js.map +1 -0
- package/dist/api/types.js +4 -1
- package/dist/api/types.js.map +1 -1
- package/dist/api/utils/mapRootProps.d.ts +1 -1
- package/dist/api/utils/mapRootProps.d.ts.map +1 -1
- package/dist/api/utils/mapRootProps.js +77 -44
- package/dist/api/utils/mapRootProps.js.map +1 -1
- package/dist/collections/Templates.js +24 -20
- package/dist/collections/Templates.js.map +1 -1
- package/dist/components/AccordionClient.d.ts +2 -2
- package/dist/components/AccordionClient.d.ts.map +1 -1
- package/dist/components/AccordionClient.js +81 -22
- package/dist/components/AccordionClient.js.map +1 -1
- package/dist/components/AnimatedWrapper.d.ts +2 -2
- package/dist/components/AnimatedWrapper.d.ts.map +1 -1
- package/dist/components/AnimatedWrapper.js +31 -16
- package/dist/components/AnimatedWrapper.js.map +1 -1
- package/dist/components/exports.js +2 -2
- package/dist/components/exports.js.map +1 -1
- package/dist/components/index.d.ts +5 -5
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +7 -7
- package/dist/components/index.js.map +1 -1
- package/dist/components/interactive/Accordion.d.ts +1 -1
- package/dist/components/interactive/Accordion.d.ts.map +1 -1
- package/dist/components/interactive/Accordion.js +149 -55
- package/dist/components/interactive/Accordion.js.map +1 -1
- package/dist/components/interactive/Accordion.server.d.ts +1 -1
- package/dist/components/interactive/Accordion.server.d.ts.map +1 -1
- package/dist/components/interactive/Accordion.server.js +25 -7
- package/dist/components/interactive/Accordion.server.js.map +1 -1
- package/dist/components/interactive/Button.d.ts +3 -3
- package/dist/components/interactive/Button.d.ts.map +1 -1
- package/dist/components/interactive/Button.js +89 -43
- package/dist/components/interactive/Button.js.map +1 -1
- package/dist/components/interactive/Button.server.d.ts +2 -2
- package/dist/components/interactive/Button.server.d.ts.map +1 -1
- package/dist/components/interactive/Button.server.js +40 -20
- package/dist/components/interactive/Button.server.js.map +1 -1
- package/dist/components/interactive/Card.d.ts +3 -3
- package/dist/components/interactive/Card.d.ts.map +1 -1
- package/dist/components/interactive/Card.js +131 -39
- package/dist/components/interactive/Card.js.map +1 -1
- package/dist/components/interactive/Card.server.d.ts +3 -3
- package/dist/components/interactive/Card.server.d.ts.map +1 -1
- package/dist/components/interactive/Card.server.js +72 -11
- package/dist/components/interactive/Card.server.js.map +1 -1
- package/dist/components/interactive/Divider.d.ts +1 -1
- package/dist/components/interactive/Divider.d.ts.map +1 -1
- package/dist/components/interactive/Divider.js +54 -26
- package/dist/components/interactive/Divider.js.map +1 -1
- package/dist/components/interactive/Divider.server.d.ts +1 -1
- package/dist/components/interactive/Divider.server.d.ts.map +1 -1
- package/dist/components/interactive/Divider.server.js +28 -12
- package/dist/components/interactive/Divider.server.js.map +1 -1
- package/dist/components/interactive/index.d.ts +4 -4
- package/dist/components/interactive/index.d.ts.map +1 -1
- package/dist/components/interactive/index.js +5 -5
- package/dist/components/interactive/index.js.map +1 -1
- package/dist/components/layout/Container.d.ts +1 -1
- package/dist/components/layout/Container.d.ts.map +1 -1
- package/dist/components/layout/Container.js +101 -47
- package/dist/components/layout/Container.js.map +1 -1
- package/dist/components/layout/Container.server.d.ts +1 -1
- package/dist/components/layout/Container.server.d.ts.map +1 -1
- package/dist/components/layout/Container.server.js +67 -19
- package/dist/components/layout/Container.server.js.map +1 -1
- package/dist/components/layout/Flex.d.ts +2 -2
- package/dist/components/layout/Flex.d.ts.map +1 -1
- package/dist/components/layout/Flex.js +124 -55
- package/dist/components/layout/Flex.js.map +1 -1
- package/dist/components/layout/Flex.server.d.ts +1 -1
- package/dist/components/layout/Flex.server.d.ts.map +1 -1
- package/dist/components/layout/Flex.server.js +50 -14
- package/dist/components/layout/Flex.server.js.map +1 -1
- package/dist/components/layout/Grid.d.ts +1 -1
- package/dist/components/layout/Grid.d.ts.map +1 -1
- package/dist/components/layout/Grid.js +93 -44
- package/dist/components/layout/Grid.js.map +1 -1
- package/dist/components/layout/Grid.server.d.ts +1 -1
- package/dist/components/layout/Grid.server.d.ts.map +1 -1
- package/dist/components/layout/Grid.server.js +56 -14
- package/dist/components/layout/Grid.server.js.map +1 -1
- package/dist/components/layout/Section.d.ts +1 -1
- package/dist/components/layout/Section.d.ts.map +1 -1
- package/dist/components/layout/Section.js +147 -64
- package/dist/components/layout/Section.js.map +1 -1
- package/dist/components/layout/Section.server.d.ts +1 -1
- package/dist/components/layout/Section.server.d.ts.map +1 -1
- package/dist/components/layout/Section.server.js +92 -28
- package/dist/components/layout/Section.server.js.map +1 -1
- package/dist/components/layout/Spacer.d.ts +1 -1
- package/dist/components/layout/Spacer.d.ts.map +1 -1
- package/dist/components/layout/Spacer.js +80 -30
- package/dist/components/layout/Spacer.js.map +1 -1
- package/dist/components/layout/Spacer.server.d.ts +1 -1
- package/dist/components/layout/Spacer.server.d.ts.map +1 -1
- package/dist/components/layout/Spacer.server.js +31 -9
- package/dist/components/layout/Spacer.server.js.map +1 -1
- package/dist/components/layout/Template.d.ts +1 -1
- package/dist/components/layout/Template.d.ts.map +1 -1
- package/dist/components/layout/Template.js +58 -30
- package/dist/components/layout/Template.js.map +1 -1
- package/dist/components/layout/Template.server.d.ts +1 -1
- package/dist/components/layout/Template.server.d.ts.map +1 -1
- package/dist/components/layout/Template.server.js +43 -11
- package/dist/components/layout/Template.server.js.map +1 -1
- package/dist/components/layout/index.d.ts +8 -8
- package/dist/components/layout/index.d.ts.map +1 -1
- package/dist/components/layout/index.js +8 -8
- package/dist/components/layout/index.js.map +1 -1
- package/dist/components/media/Image.d.ts +3 -3
- package/dist/components/media/Image.d.ts.map +1 -1
- package/dist/components/media/Image.js +122 -39
- package/dist/components/media/Image.js.map +1 -1
- package/dist/components/media/Image.server.d.ts +3 -3
- package/dist/components/media/Image.server.d.ts.map +1 -1
- package/dist/components/media/Image.server.js +76 -13
- package/dist/components/media/Image.server.js.map +1 -1
- package/dist/components/media/index.d.ts +1 -1
- package/dist/components/media/index.d.ts.map +1 -1
- package/dist/components/media/index.js +2 -2
- package/dist/components/media/index.js.map +1 -1
- package/dist/components/typography/Heading.d.ts +2 -2
- package/dist/components/typography/Heading.d.ts.map +1 -1
- package/dist/components/typography/Heading.js +45 -25
- package/dist/components/typography/Heading.js.map +1 -1
- package/dist/components/typography/Heading.server.d.ts +2 -2
- package/dist/components/typography/Heading.server.d.ts.map +1 -1
- package/dist/components/typography/Heading.server.js +16 -10
- package/dist/components/typography/Heading.server.js.map +1 -1
- package/dist/components/typography/RichText.editor.d.ts +1 -1
- package/dist/components/typography/RichText.editor.d.ts.map +1 -1
- package/dist/components/typography/RichText.editor.js +44 -19
- package/dist/components/typography/RichText.editor.js.map +1 -1
- package/dist/components/typography/RichText.server.d.ts +2 -2
- package/dist/components/typography/RichText.server.d.ts.map +1 -1
- package/dist/components/typography/RichText.server.js +33 -14
- package/dist/components/typography/RichText.server.js.map +1 -1
- package/dist/components/typography/Text.d.ts +2 -2
- package/dist/components/typography/Text.d.ts.map +1 -1
- package/dist/components/typography/Text.js +49 -23
- package/dist/components/typography/Text.js.map +1 -1
- package/dist/components/typography/Text.server.d.ts +2 -2
- package/dist/components/typography/Text.server.d.ts.map +1 -1
- package/dist/components/typography/Text.server.js +21 -8
- package/dist/components/typography/Text.server.js.map +1 -1
- package/dist/components/typography/index.d.ts +4 -4
- package/dist/components/typography/index.d.ts.map +1 -1
- package/dist/components/typography/index.js +5 -5
- package/dist/components/typography/index.js.map +1 -1
- package/dist/config/config.editor.d.ts +3 -3
- package/dist/config/config.editor.d.ts.map +1 -1
- package/dist/config/config.editor.js +119 -54
- package/dist/config/config.editor.js.map +1 -1
- package/dist/config/index.d.ts +4 -4
- package/dist/config/index.d.ts.map +1 -1
- package/dist/config/index.js +62 -35
- package/dist/config/index.js.map +1 -1
- package/dist/config/merge.d.ts +1 -1
- package/dist/config/merge.d.ts.map +1 -1
- package/dist/config/merge.js +23 -26
- package/dist/config/merge.js.map +1 -1
- package/dist/config/presets.d.ts +4 -4
- package/dist/config/presets.js +195 -75
- package/dist/config/presets.js.map +1 -1
- package/dist/config/types.js +6 -2
- package/dist/config/types.js.map +1 -1
- package/dist/editor/PuckEditor.d.ts +12 -4
- package/dist/editor/PuckEditor.d.ts.map +1 -1
- package/dist/editor/PuckEditor.js +168 -67
- package/dist/editor/PuckEditor.js.map +1 -1
- package/dist/editor/PuckEditorImpl.client.d.ts +4 -4
- package/dist/editor/PuckEditorImpl.client.d.ts.map +1 -1
- package/dist/editor/PuckEditorImpl.client.js +304 -152
- package/dist/editor/PuckEditorImpl.client.js.map +1 -1
- package/dist/editor/components/DarkModeStyles.js +11 -12
- package/dist/editor/components/DarkModeStyles.js.map +1 -1
- package/dist/editor/components/HeaderActions.js +308 -64
- package/dist/editor/components/HeaderActions.js.map +1 -1
- package/dist/editor/components/IframeWrapper.d.ts +1 -1
- package/dist/editor/components/IframeWrapper.d.ts.map +1 -1
- package/dist/editor/components/IframeWrapper.js +82 -58
- package/dist/editor/components/IframeWrapper.js.map +1 -1
- package/dist/editor/components/LoadingState.d.ts +1 -1
- package/dist/editor/components/LoadingState.d.ts.map +1 -1
- package/dist/editor/components/LoadingState.js +17 -3
- package/dist/editor/components/LoadingState.js.map +1 -1
- package/dist/editor/components/PreviewModal.js +234 -78
- package/dist/editor/components/PreviewModal.js.map +1 -1
- package/dist/editor/components/PreviewModeToggle.js +43 -15
- package/dist/editor/components/PreviewModeToggle.js.map +1 -1
- package/dist/editor/components/VersionHistory.js +219 -71
- package/dist/editor/components/VersionHistory.js.map +1 -1
- package/dist/editor/hooks/useDarkMode.js +36 -23
- package/dist/editor/hooks/useDarkMode.js.map +1 -1
- package/dist/editor/hooks/useUnsavedChanges.js +8 -8
- package/dist/editor/hooks/useUnsavedChanges.js.map +1 -1
- package/dist/editor/index.js +5 -6
- package/dist/editor/index.js.map +1 -1
- package/dist/editor/plugins/VersionHistoryPanel.js +236 -75
- package/dist/editor/plugins/VersionHistoryPanel.js.map +1 -1
- package/dist/editor/plugins/index.js +4 -4
- package/dist/editor/plugins/index.js.map +1 -1
- package/dist/editor/plugins/versionHistoryPlugin.js +10 -8
- package/dist/editor/plugins/versionHistoryPlugin.js.map +1 -1
- package/dist/editor/utils/detectPageTree.js +5 -5
- package/dist/editor/utils/detectPageTree.js.map +1 -1
- package/dist/editor/utils/index.js +1 -0
- package/dist/editor/utils/index.js.map +1 -1
- package/dist/editor/utils/injectPageTreeFields.js +13 -9
- package/dist/editor/utils/injectPageTreeFields.js.map +1 -1
- package/dist/endpoints/ai.js +58 -34
- package/dist/endpoints/ai.js.map +1 -1
- package/dist/endpoints/context.js +86 -40
- package/dist/endpoints/context.js.map +1 -1
- package/dist/endpoints/index.js +153 -76
- package/dist/endpoints/index.js.map +1 -1
- package/dist/endpoints/postcss.d.js +5 -0
- package/dist/endpoints/postcss.d.js.map +1 -0
- package/dist/endpoints/prompts.js +81 -39
- package/dist/endpoints/prompts.js.map +1 -1
- package/dist/endpoints/styles.js +34 -36
- package/dist/endpoints/styles.js.map +1 -1
- package/dist/exports/client.js +2 -2
- package/dist/exports/client.js.map +1 -1
- package/dist/exports/rsc.js +2 -2
- package/dist/exports/rsc.js.map +1 -1
- package/dist/fields/AlignmentField.d.ts +1 -1
- package/dist/fields/AlignmentField.d.ts.map +1 -1
- package/dist/fields/AlignmentField.js +93 -30
- package/dist/fields/AlignmentField.js.map +1 -1
- package/dist/fields/AnimationField.d.ts +2 -2
- package/dist/fields/AnimationField.d.ts.map +1 -1
- package/dist/fields/AnimationField.js +558 -84
- package/dist/fields/AnimationField.js.map +1 -1
- package/dist/fields/BackgroundField.d.ts +2 -2
- package/dist/fields/BackgroundField.d.ts.map +1 -1
- package/dist/fields/BackgroundField.js +754 -120
- package/dist/fields/BackgroundField.js.map +1 -1
- package/dist/fields/BorderField.d.ts +2 -2
- package/dist/fields/BorderField.d.ts.map +1 -1
- package/dist/fields/BorderField.js +275 -73
- package/dist/fields/BorderField.js.map +1 -1
- package/dist/fields/ColorPickerField.d.ts +2 -2
- package/dist/fields/ColorPickerField.d.ts.map +1 -1
- package/dist/fields/ColorPickerField.js +210 -68
- package/dist/fields/ColorPickerField.js.map +1 -1
- package/dist/fields/ContentAlignmentField.d.ts +1 -1
- package/dist/fields/ContentAlignmentField.d.ts.map +1 -1
- package/dist/fields/ContentAlignmentField.js +161 -75
- package/dist/fields/ContentAlignmentField.js.map +1 -1
- package/dist/fields/DimensionsField.d.ts +2 -2
- package/dist/fields/DimensionsField.d.ts.map +1 -1
- package/dist/fields/DimensionsField.js +575 -146
- package/dist/fields/DimensionsField.js.map +1 -1
- package/dist/fields/FlexAlignmentField.d.ts +2 -2
- package/dist/fields/FlexAlignmentField.d.ts.map +1 -1
- package/dist/fields/FlexAlignmentField.js +189 -51
- package/dist/fields/FlexAlignmentField.js.map +1 -1
- package/dist/fields/FolderPickerField.d.ts +8 -1
- package/dist/fields/FolderPickerField.d.ts.map +1 -1
- package/dist/fields/FolderPickerField.js +288 -75
- package/dist/fields/FolderPickerField.js.map +1 -1
- package/dist/fields/GradientEditor.d.ts +2 -2
- package/dist/fields/GradientEditor.d.ts.map +1 -1
- package/dist/fields/GradientEditor.js +462 -86
- package/dist/fields/GradientEditor.js.map +1 -1
- package/dist/fields/LockedField.d.ts +15 -2
- package/dist/fields/LockedField.d.ts.map +1 -1
- package/dist/fields/LockedField.js +180 -49
- package/dist/fields/LockedField.js.map +1 -1
- package/dist/fields/MarginField.d.ts +2 -2
- package/dist/fields/MarginField.d.ts.map +1 -1
- package/dist/fields/MarginField.js +144 -46
- package/dist/fields/MarginField.js.map +1 -1
- package/dist/fields/MediaField.d.ts +1 -1
- package/dist/fields/MediaField.d.ts.map +1 -1
- package/dist/fields/MediaField.js +688 -186
- package/dist/fields/MediaField.js.map +1 -1
- package/dist/fields/PaddingField.d.ts +2 -2
- package/dist/fields/PaddingField.d.ts.map +1 -1
- package/dist/fields/PaddingField.js +144 -46
- package/dist/fields/PaddingField.js.map +1 -1
- package/dist/fields/PageSegmentField.d.ts +15 -2
- package/dist/fields/PageSegmentField.d.ts.map +1 -1
- package/dist/fields/PageSegmentField.js +156 -54
- package/dist/fields/PageSegmentField.js.map +1 -1
- package/dist/fields/ResetField.d.ts +1 -1
- package/dist/fields/ResetField.d.ts.map +1 -1
- package/dist/fields/ResetField.js +59 -31
- package/dist/fields/ResetField.js.map +1 -1
- package/dist/fields/ResponsiveField.d.ts +1 -1
- package/dist/fields/ResponsiveField.d.ts.map +1 -1
- package/dist/fields/ResponsiveField.js +233 -90
- package/dist/fields/ResponsiveField.js.map +1 -1
- package/dist/fields/ResponsiveVisibilityField.d.ts +2 -2
- package/dist/fields/ResponsiveVisibilityField.d.ts.map +1 -1
- package/dist/fields/ResponsiveVisibilityField.js +119 -36
- package/dist/fields/ResponsiveVisibilityField.js.map +1 -1
- package/dist/fields/SizeField.d.ts +3 -3
- package/dist/fields/SizeField.d.ts.map +1 -1
- package/dist/fields/SizeField.js +226 -52
- package/dist/fields/SizeField.js.map +1 -1
- package/dist/fields/SlugPreviewField.d.ts +8 -1
- package/dist/fields/SlugPreviewField.d.ts.map +1 -1
- package/dist/fields/SlugPreviewField.js +65 -16
- package/dist/fields/SlugPreviewField.js.map +1 -1
- package/dist/fields/TemplateField.d.ts +1 -1
- package/dist/fields/TemplateField.d.ts.map +1 -1
- package/dist/fields/TemplateField.js +362 -120
- package/dist/fields/TemplateField.js.map +1 -1
- package/dist/fields/TransformField.d.ts +2 -2
- package/dist/fields/TransformField.d.ts.map +1 -1
- package/dist/fields/TransformField.js +517 -81
- package/dist/fields/TransformField.js.map +1 -1
- package/dist/fields/VerticalAlignmentField.d.ts +1 -1
- package/dist/fields/VerticalAlignmentField.d.ts.map +1 -1
- package/dist/fields/VerticalAlignmentField.js +93 -30
- package/dist/fields/VerticalAlignmentField.js.map +1 -1
- package/dist/fields/WidthField.d.ts +2 -2
- package/dist/fields/WidthField.d.ts.map +1 -1
- package/dist/fields/WidthField.js +278 -81
- package/dist/fields/WidthField.js.map +1 -1
- package/dist/fields/index.d.ts +41 -41
- package/dist/fields/index.d.ts.map +1 -1
- package/dist/fields/index.js +37 -43
- package/dist/fields/index.js.map +1 -1
- package/dist/fields/richtext/controls/ColorPickerControl.d.ts +13 -2
- package/dist/fields/richtext/controls/ColorPickerControl.d.ts.map +1 -1
- package/dist/fields/richtext/controls/ColorPickerControl.js +212 -47
- package/dist/fields/richtext/controls/ColorPickerControl.js.map +1 -1
- package/dist/fields/richtext/controls/DropdownPortal.d.ts +2 -2
- package/dist/fields/richtext/controls/DropdownPortal.d.ts.map +1 -1
- package/dist/fields/richtext/controls/DropdownPortal.js +36 -4
- package/dist/fields/richtext/controls/DropdownPortal.js.map +1 -1
- package/dist/fields/richtext/controls/FontSizeControl.d.ts +9 -1
- package/dist/fields/richtext/controls/FontSizeControl.d.ts.map +1 -1
- package/dist/fields/richtext/controls/FontSizeControl.js +109 -24
- package/dist/fields/richtext/controls/FontSizeControl.js.map +1 -1
- package/dist/fields/richtext/controls/HighlightControl.d.ts +12 -1
- package/dist/fields/richtext/controls/HighlightControl.d.ts.map +1 -1
- package/dist/fields/richtext/controls/HighlightControl.js +54 -17
- package/dist/fields/richtext/controls/HighlightControl.js.map +1 -1
- package/dist/fields/richtext/controls/index.d.ts +5 -5
- package/dist/fields/richtext/controls/index.d.ts.map +1 -1
- package/dist/fields/richtext/controls/index.js +8 -11
- package/dist/fields/richtext/controls/index.js.map +1 -1
- package/dist/fields/richtext/controls/shared.js +108 -63
- package/dist/fields/richtext/controls/shared.js.map +1 -1
- package/dist/fields/richtext/createRichTextField.d.ts +18 -4
- package/dist/fields/richtext/createRichTextField.d.ts.map +1 -1
- package/dist/fields/richtext/createRichTextField.js +113 -26
- package/dist/fields/richtext/createRichTextField.js.map +1 -1
- package/dist/fields/richtext/extensions/FontSize.js +26 -20
- package/dist/fields/richtext/extensions/FontSize.js.map +1 -1
- package/dist/fields/richtext/extensions/index.d.ts +1 -1
- package/dist/fields/richtext/extensions/index.d.ts.map +1 -1
- package/dist/fields/richtext/extensions/index.js +2 -2
- package/dist/fields/richtext/extensions/index.js.map +1 -1
- package/dist/fields/richtext/index.d.ts +6 -6
- package/dist/fields/richtext/index.d.ts.map +1 -1
- package/dist/fields/richtext/index.js +8 -8
- package/dist/fields/richtext/index.js.map +1 -1
- package/dist/fields/shared.d.ts +1 -1
- package/dist/fields/shared.d.ts.map +1 -1
- package/dist/fields/shared.js +915 -478
- package/dist/fields/shared.js.map +1 -1
- package/dist/hooks/index.d.ts +2 -2
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +3 -3
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/useResponsiveStyles.d.ts +1 -1
- package/dist/hooks/useResponsiveStyles.d.ts.map +1 -1
- package/dist/hooks/useResponsiveStyles.js +36 -32
- package/dist/hooks/useResponsiveStyles.js.map +1 -1
- package/dist/hooks/useScrollAnimation.js +26 -24
- package/dist/hooks/useScrollAnimation.js.map +1 -1
- package/dist/index.d.ts +4 -4
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +5 -5
- package/dist/index.js.map +1 -1
- package/dist/layouts/LayoutWrapper.d.ts +3 -3
- package/dist/layouts/LayoutWrapper.d.ts.map +1 -1
- package/dist/layouts/LayoutWrapper.js +115 -51
- package/dist/layouts/LayoutWrapper.js.map +1 -1
- package/dist/layouts/defaults.d.ts +1 -1
- package/dist/layouts/defaults.d.ts.map +1 -1
- package/dist/layouts/defaults.js +23 -31
- package/dist/layouts/defaults.js.map +1 -1
- package/dist/layouts/index.d.ts +4 -4
- package/dist/layouts/index.d.ts.map +1 -1
- package/dist/layouts/index.js +5 -4
- package/dist/layouts/index.js.map +1 -1
- package/dist/layouts/types.js +4 -2
- package/dist/layouts/types.js.map +1 -1
- package/dist/layouts/utils.d.ts +1 -1
- package/dist/layouts/utils.d.ts.map +1 -1
- package/dist/layouts/utils.js +32 -40
- package/dist/layouts/utils.js.map +1 -1
- package/dist/next/index.js +31 -34
- package/dist/next/index.js.map +1 -1
- package/dist/plugin/collections/Pages.d.ts +2 -2
- package/dist/plugin/collections/Pages.d.ts.map +1 -1
- package/dist/plugin/collections/Pages.js +46 -43
- package/dist/plugin/collections/Pages.js.map +1 -1
- package/dist/plugin/fields/index.d.ts +3 -3
- package/dist/plugin/fields/index.d.ts.map +1 -1
- package/dist/plugin/fields/index.js +100 -78
- package/dist/plugin/fields/index.js.map +1 -1
- package/dist/plugin/fields/types.d.ts +1 -1
- package/dist/plugin/fields/types.d.ts.map +1 -1
- package/dist/plugin/fields/types.js +26 -2
- package/dist/plugin/fields/types.js.map +1 -1
- package/dist/plugin/hooks/index.d.ts +1 -1
- package/dist/plugin/hooks/index.d.ts.map +1 -1
- package/dist/plugin/hooks/index.js +2 -2
- package/dist/plugin/hooks/index.js.map +1 -1
- package/dist/plugin/hooks/isHomepageUnique.js +28 -19
- package/dist/plugin/hooks/isHomepageUnique.js.map +1 -1
- package/dist/plugin/index.d.ts +8 -8
- package/dist/plugin/index.d.ts.map +1 -1
- package/dist/plugin/index.js +192 -188
- package/dist/plugin/index.js.map +1 -1
- package/dist/render/HybridPageRenderer.d.ts +2 -2
- package/dist/render/HybridPageRenderer.d.ts.map +1 -1
- package/dist/render/HybridPageRenderer.js +58 -10
- package/dist/render/HybridPageRenderer.js.map +1 -1
- package/dist/render/PageRenderer.d.ts +2 -2
- package/dist/render/PageRenderer.d.ts.map +1 -1
- package/dist/render/PageRenderer.js +31 -14
- package/dist/render/PageRenderer.js.map +1 -1
- package/dist/render/PuckEditor.client.d.ts +1 -1
- package/dist/render/PuckEditor.client.d.ts.map +1 -1
- package/dist/render/PuckEditor.client.js +33 -16
- package/dist/render/PuckEditor.client.js.map +1 -1
- package/dist/render/index.d.ts +5 -5
- package/dist/render/index.d.ts.map +1 -1
- package/dist/render/index.js +5 -6
- package/dist/render/index.js.map +1 -1
- package/dist/styles/puck-dark-mode.css +101 -0
- package/dist/theme/context.d.ts +2 -2
- package/dist/theme/context.d.ts.map +1 -1
- package/dist/theme/context.js +21 -18
- package/dist/theme/context.js.map +1 -1
- package/dist/theme/defaults.d.ts +1 -1
- package/dist/theme/defaults.d.ts.map +1 -1
- package/dist/theme/defaults.js +83 -37
- package/dist/theme/defaults.js.map +1 -1
- package/dist/theme/example.d.ts +1 -1
- package/dist/theme/example.d.ts.map +1 -1
- package/dist/theme/example.js +68 -30
- package/dist/theme/example.js.map +1 -1
- package/dist/theme/index.d.ts +5 -5
- package/dist/theme/index.d.ts.map +1 -1
- package/dist/theme/index.js +6 -5
- package/dist/theme/index.js.map +1 -1
- package/dist/theme/types.js +6 -2
- package/dist/theme/types.js.map +1 -1
- package/dist/theme/utils.d.ts +1 -1
- package/dist/theme/utils.d.ts.map +1 -1
- package/dist/theme/utils.js +24 -25
- package/dist/theme/utils.js.map +1 -1
- package/dist/types/index.d.ts +42 -6
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +3 -1
- package/dist/types/index.js.map +1 -1
- package/dist/utils/index.d.ts +2 -2
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +13 -22
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/migration.d.ts +1 -1
- package/dist/utils/migration.d.ts.map +1 -1
- package/dist/utils/migration.js +43 -49
- package/dist/utils/migration.js.map +1 -1
- package/dist/utils/validation.d.ts +1 -1
- package/dist/utils/validation.d.ts.map +1 -1
- package/dist/utils/validation.js +36 -43
- package/dist/utils/validation.js.map +1 -1
- package/dist/version.d.ts +1 -1
- package/dist/version.js +2 -1
- package/dist/version.js.map +1 -1
- package/dist/views/PuckConfigContext.d.ts +1 -1
- package/dist/views/PuckConfigContext.d.ts.map +1 -1
- package/dist/views/PuckConfigContext.js +25 -10
- package/dist/views/PuckConfigContext.js.map +1 -1
- package/dist/views/PuckEditorView.d.ts +1 -1
- package/dist/views/PuckEditorView.d.ts.map +1 -1
- package/dist/views/PuckEditorView.js +137 -41
- package/dist/views/PuckEditorView.js.map +1 -1
- package/dist/views/index.js +2 -2
- package/dist/views/index.js.map +1 -1
- package/package.json +62 -42
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"MediaField.js","sourceRoot":"","sources":["../../src/fields/MediaField.tsx"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/fields/MediaField.tsx"],"sourcesContent":["'use client'\n\n/**\n * MediaField - Custom Puck field for selecting Payload CMS media\n *\n * This component provides a media picker that integrates with Payload's\n * media collection, allowing users to browse and select images.\n */\n\nimport React, { useState, useEffect, useCallback, memo, type CSSProperties } from 'react'\nimport type { CustomField } from '@puckeditor/core'\nimport { Image, X, Search, Loader2, Upload, AlertCircle, Link } from 'lucide-react'\n\n// =============================================================================\n// Types\n// =============================================================================\n\nexport interface MediaReference {\n id: string | number\n url: string\n alt?: string\n width?: number\n height?: number\n}\n\ninterface MediaFieldProps {\n value: MediaReference | null\n onChange: (value: MediaReference | null) => void\n label?: string\n readOnly?: boolean\n apiEndpoint?: string\n}\n\ninterface MediaItem {\n id: string | number\n url: string\n alt?: string\n filename?: string\n width?: number\n height?: number\n mimeType?: string\n}\n\ntype DialogTab = 'browse' | 'upload' | 'url'\n\ninterface UploadState {\n file: File | null\n preview: string | null\n uploading: boolean\n error: string | null\n}\n\ninterface UrlState {\n url: string\n loading: boolean\n error: string | null\n previewLoaded: boolean\n}\n\n// =============================================================================\n// Styles\n// =============================================================================\n\nconst styles = {\n label: {\n display: 'block',\n fontSize: '14px',\n fontWeight: 500,\n color: 'var(--theme-elevation-700)',\n marginBottom: '8px',\n } as CSSProperties,\n previewContainer: {\n display: 'flex',\n alignItems: 'flex-start',\n gap: '16px',\n } as CSSProperties,\n imagePreview: {\n position: 'relative',\n } as CSSProperties,\n previewImage: {\n width: '96px',\n height: '96px',\n objectFit: 'cover',\n borderRadius: '6px',\n border: '1px solid var(--theme-elevation-200)',\n } as CSSProperties,\n removeButton: {\n position: 'absolute',\n top: '-8px',\n right: '-8px',\n padding: '4px',\n backgroundColor: 'var(--theme-error-500)',\n color: 'white',\n borderRadius: '50%',\n border: 'none',\n cursor: 'pointer',\n opacity: 0,\n transition: 'opacity 0.15s',\n } as CSSProperties,\n placeholder: {\n width: '96px',\n height: '96px',\n backgroundColor: 'var(--theme-elevation-100)',\n borderRadius: '6px',\n border: '1px dashed var(--theme-elevation-300)',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n } as CSSProperties,\n actionsColumn: {\n display: 'flex',\n flexDirection: 'column',\n gap: '8px',\n } as CSSProperties,\n buttonOutline: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n padding: '6px 12px',\n fontSize: '14px',\n fontWeight: 500,\n color: 'var(--theme-elevation-700)',\n backgroundColor: 'var(--theme-bg)',\n border: '1px solid var(--theme-elevation-300)',\n borderRadius: '6px',\n cursor: 'pointer',\n transition: 'background-color 0.15s',\n } as CSSProperties,\n buttonGhost: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n padding: '6px 12px',\n fontSize: '14px',\n fontWeight: 500,\n color: 'var(--theme-error-600)',\n backgroundColor: 'transparent',\n border: 'none',\n borderRadius: '6px',\n cursor: 'pointer',\n transition: 'background-color 0.15s',\n } as CSSProperties,\n buttonPrimary: {\n display: 'inline-flex',\n alignItems: 'center',\n justifyContent: 'center',\n padding: '8px 16px',\n fontSize: '14px',\n fontWeight: 500,\n color: 'var(--theme-bg)',\n backgroundColor: 'var(--theme-elevation-900)',\n border: 'none',\n borderRadius: '6px',\n cursor: 'pointer',\n transition: 'background-color 0.15s',\n } as CSSProperties,\n buttonDisabled: {\n opacity: 0.5,\n cursor: 'not-allowed',\n } as CSSProperties,\n urlDisplay: {\n display: 'flex',\n alignItems: 'center',\n gap: '6px',\n fontSize: '12px',\n color: 'var(--theme-elevation-500)',\n marginTop: '8px',\n } as CSSProperties,\n // Dialog styles\n dialogOverlay: {\n position: 'fixed',\n inset: 0,\n zIndex: 9999,\n backgroundColor: 'rgba(0, 0, 0, 0.5)',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n } as CSSProperties,\n dialogContent: {\n backgroundColor: 'var(--theme-bg)',\n borderRadius: '8px',\n boxShadow: '0 25px 50px -12px rgba(0, 0, 0, 0.25)',\n width: '100%',\n maxWidth: '800px',\n maxHeight: '90vh',\n margin: '16px',\n display: 'flex',\n flexDirection: 'column',\n overflow: 'hidden',\n } as CSSProperties,\n dialogHeader: {\n padding: '16px 20px',\n borderBottom: '1px solid var(--theme-elevation-200)',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n flexShrink: 0,\n } as CSSProperties,\n dialogTitle: {\n fontSize: '18px',\n fontWeight: 600,\n color: 'var(--theme-elevation-900)',\n margin: 0,\n } as CSSProperties,\n closeButton: {\n padding: '4px',\n backgroundColor: 'transparent',\n border: 'none',\n cursor: 'pointer',\n color: 'var(--theme-elevation-500)',\n borderRadius: '4px',\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n } as CSSProperties,\n tabBar: {\n display: 'flex',\n flexWrap: 'wrap',\n borderBottom: '1px solid var(--theme-elevation-200)',\n padding: '0 20px',\n flexShrink: 0,\n } as CSSProperties,\n tabButton: {\n padding: '12px 16px',\n fontSize: '14px',\n fontWeight: 500,\n backgroundColor: 'transparent',\n border: 'none',\n borderBottomWidth: '2px',\n borderBottomStyle: 'solid',\n borderBottomColor: 'transparent',\n cursor: 'pointer',\n transition: 'color 0.15s, border-color 0.15s',\n color: 'var(--theme-elevation-500)',\n } as CSSProperties,\n tabButtonActive: {\n color: 'var(--theme-elevation-900)',\n borderBottomColor: 'var(--theme-elevation-900)',\n } as CSSProperties,\n searchContainer: {\n padding: '16px 20px',\n position: 'relative',\n flexShrink: 0,\n } as CSSProperties,\n searchInput: {\n width: '100%',\n padding: '8px 12px 8px 40px',\n fontSize: '14px',\n border: '1px solid var(--theme-elevation-300)',\n borderRadius: '6px',\n outline: 'none',\n } as CSSProperties,\n searchIcon: {\n position: 'absolute',\n left: '32px',\n top: '50%',\n transform: 'translateY(-50%)',\n color: 'var(--theme-elevation-400)',\n pointerEvents: 'none',\n } as CSSProperties,\n contentArea: {\n flex: 1,\n overflowY: 'auto',\n padding: '16px 20px',\n } as CSSProperties,\n mediaGrid: {\n display: 'grid',\n gridTemplateColumns: 'repeat(auto-fill, minmax(80px, 1fr))',\n gap: '12px',\n } as CSSProperties,\n mediaItem: {\n position: 'relative',\n aspectRatio: '1',\n overflow: 'hidden',\n borderRadius: '6px',\n border: '2px solid var(--theme-elevation-200)',\n cursor: 'pointer',\n transition: 'border-color 0.15s, box-shadow 0.15s',\n backgroundColor: 'var(--theme-elevation-100)',\n } as CSSProperties,\n mediaItemSelected: {\n borderColor: 'var(--theme-elevation-900)',\n boxShadow: '0 0 0 2px var(--theme-elevation-200)',\n } as CSSProperties,\n mediaItemImage: {\n width: '100%',\n height: '100%',\n objectFit: 'cover',\n } as CSSProperties,\n mediaItemAlt: {\n position: 'absolute',\n bottom: 0,\n left: 0,\n right: 0,\n backgroundColor: 'rgba(0, 0, 0, 0.6)',\n color: 'white',\n fontSize: '12px',\n padding: '4px',\n overflow: 'hidden',\n textOverflow: 'ellipsis',\n whiteSpace: 'nowrap',\n } as CSSProperties,\n loadMoreContainer: {\n display: 'flex',\n justifyContent: 'center',\n marginTop: '16px',\n } as CSSProperties,\n emptyState: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n height: '200px',\n color: 'var(--theme-elevation-500)',\n } as CSSProperties,\n skeleton: {\n backgroundColor: 'var(--theme-elevation-200)',\n borderRadius: '6px',\n aspectRatio: '1',\n animation: 'pulse 2s infinite',\n } as CSSProperties,\n uploadContainer: {\n display: 'flex',\n flexDirection: 'column',\n alignItems: 'center',\n justifyContent: 'center',\n minHeight: '300px',\n padding: '20px',\n } as CSSProperties,\n uploadPreview: {\n width: '100%',\n maxWidth: '448px',\n display: 'flex',\n flexDirection: 'column',\n gap: '16px',\n } as CSSProperties,\n uploadImageContainer: {\n position: 'relative',\n aspectRatio: '16/9',\n backgroundColor: 'var(--theme-elevation-100)',\n borderRadius: '8px',\n overflow: 'hidden',\n } as CSSProperties,\n uploadImage: {\n width: '100%',\n height: '100%',\n objectFit: 'contain',\n } as CSSProperties,\n uploadMeta: {\n fontSize: '14px',\n color: 'var(--theme-elevation-500)',\n display: 'flex',\n flexDirection: 'column',\n gap: '4px',\n } as CSSProperties,\n errorBox: {\n padding: '12px',\n backgroundColor: 'var(--theme-error-50)',\n border: '1px solid var(--theme-error-200)',\n borderRadius: '6px',\n color: 'var(--theme-error-700)',\n fontSize: '14px',\n display: 'flex',\n alignItems: 'flex-start',\n gap: '8px',\n } as CSSProperties,\n actionsRow: {\n display: 'flex',\n gap: '8px',\n } as CSSProperties,\n dropZone: {\n textAlign: 'center',\n } as CSSProperties,\n dropZoneIcon: {\n width: '64px',\n height: '64px',\n color: 'var(--theme-elevation-300)',\n margin: '0 auto 16px',\n } as CSSProperties,\n hiddenInput: {\n display: 'none',\n } as CSSProperties,\n urlContainer: {\n width: '100%',\n maxWidth: '448px',\n display: 'flex',\n flexDirection: 'column',\n gap: '16px',\n } as CSSProperties,\n urlIntro: {\n textAlign: 'center',\n marginBottom: '24px',\n } as CSSProperties,\n urlIcon: {\n width: '48px',\n height: '48px',\n color: 'var(--theme-elevation-400)',\n margin: '0 auto 8px',\n } as CSSProperties,\n inputGroup: {\n display: 'flex',\n flexDirection: 'column',\n gap: '8px',\n } as CSSProperties,\n inputLabel: {\n fontSize: '14px',\n fontWeight: 500,\n color: 'var(--theme-elevation-700)',\n } as CSSProperties,\n input: {\n width: '100%',\n padding: '8px 12px',\n fontSize: '14px',\n border: '1px solid var(--theme-elevation-300)',\n borderRadius: '6px',\n outline: 'none',\n } as CSSProperties,\n previewLoading: {\n position: 'absolute',\n inset: 0,\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n backgroundColor: 'var(--theme-elevation-100)',\n } as CSSProperties,\n icon: {\n width: '16px',\n height: '16px',\n } as CSSProperties,\n iconSmall: {\n width: '12px',\n height: '12px',\n flexShrink: 0,\n } as CSSProperties,\n}\n\n// =============================================================================\n// Utility Functions\n// =============================================================================\n\nfunction formatFileSize(bytes: number | undefined): string {\n if (!bytes) return 'Unknown'\n if (bytes < 1024) return `${bytes} B`\n if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(1)} KB`\n return `${(bytes / (1024 * 1024)).toFixed(1)} MB`\n}\n\n// =============================================================================\n// MediaField Component\n// =============================================================================\n\nfunction MediaFieldInner({\n value,\n onChange,\n label,\n readOnly,\n apiEndpoint = '/api/media',\n}: MediaFieldProps) {\n const [isOpen, setIsOpen] = useState(false)\n const [mediaList, setMediaList] = useState<MediaItem[]>([])\n const [loading, setLoading] = useState(false)\n const [searchQuery, setSearchQuery] = useState('')\n const [page, setPage] = useState(1)\n const [hasMore, setHasMore] = useState(true)\n const [activeTab, setActiveTab] = useState<DialogTab>('browse')\n const [hoveredItem, setHoveredItem] = useState<string | number | null>(null)\n const [previewHovered, setPreviewHovered] = useState(false)\n const [uploadState, setUploadState] = useState<UploadState>({\n file: null,\n preview: null,\n uploading: false,\n error: null,\n })\n const [urlState, setUrlState] = useState<UrlState>({\n url: '',\n loading: false,\n error: null,\n previewLoaded: false,\n })\n\n // Fetch media from Payload API\n const fetchMedia = useCallback(async (searchTerm: string = '', pageNum: number = 1) => {\n setLoading(true)\n try {\n const params = new URLSearchParams({\n limit: '24',\n page: pageNum.toString(),\n sort: '-createdAt',\n })\n\n params.set('where[mimeType][contains]', 'image')\n\n if (searchTerm) {\n params.set('where[alt][contains]', searchTerm)\n }\n\n const response = await fetch(`${apiEndpoint}?${params}`)\n if (!response.ok) throw new Error('Failed to fetch media')\n\n const data = await response.json()\n const items: MediaItem[] = (data.docs || []).map((doc: Record<string, unknown>) => ({\n id: doc.id as string | number,\n url: (doc.url as string) || '',\n alt: (doc.alt as string) || '',\n filename: (doc.filename as string) || '',\n width: doc.width as number | undefined,\n height: doc.height as number | undefined,\n mimeType: (doc.mimeType as string) || '',\n }))\n\n if (pageNum === 1) {\n setMediaList(items)\n } else {\n setMediaList((prev) => [...prev, ...items])\n }\n\n setHasMore(data.hasNextPage || false)\n } catch (error) {\n console.error('Error fetching media:', error)\n } finally {\n setLoading(false)\n }\n }, [apiEndpoint])\n\n // Load media when dialog opens\n useEffect(() => {\n if (isOpen) {\n setPage(1)\n fetchMedia(searchQuery, 1)\n }\n }, [isOpen, fetchMedia, searchQuery])\n\n // Handle search with debounce\n useEffect(() => {\n if (!isOpen) return\n\n const timer = setTimeout(() => {\n setPage(1)\n fetchMedia(searchQuery, 1)\n }, 300)\n\n return () => clearTimeout(timer)\n }, [searchQuery, isOpen, fetchMedia])\n\n // Handle media selection\n const handleSelect = (item: MediaItem) => {\n onChange({\n id: item.id,\n url: item.url,\n alt: item.alt,\n width: item.width,\n height: item.height,\n })\n setIsOpen(false)\n }\n\n // Handle remove\n const handleRemove = () => {\n onChange(null)\n }\n\n // Load more\n const handleLoadMore = () => {\n const nextPage = page + 1\n setPage(nextPage)\n fetchMedia(searchQuery, nextPage)\n }\n\n // Reset upload state\n const resetUploadState = useCallback(() => {\n setUploadState((prev) => {\n if (prev.preview) URL.revokeObjectURL(prev.preview)\n return { file: null, preview: null, uploading: false, error: null }\n })\n }, [])\n\n // Reset URL state\n const resetUrlState = useCallback(() => {\n setUrlState({ url: '', loading: false, error: null, previewLoaded: false })\n }, [])\n\n // Handle URL submission\n const handleUrlSubmit = useCallback(() => {\n const url = urlState.url.trim()\n if (!url) {\n setUrlState((prev) => ({ ...prev, error: 'Please enter a URL' }))\n return\n }\n\n try {\n new URL(url)\n } catch {\n setUrlState((prev) => ({ ...prev, error: 'Please enter a valid URL' }))\n return\n }\n\n onChange({\n id: `external-${Date.now()}`,\n url: url,\n alt: '',\n })\n setIsOpen(false)\n resetUrlState()\n }, [urlState.url, onChange, resetUrlState])\n\n const handleUrlPreviewLoad = useCallback(() => {\n setUrlState((prev) => ({ ...prev, previewLoaded: true, error: null }))\n }, [])\n\n const handleUrlPreviewError = useCallback(() => {\n setUrlState((prev) => ({\n ...prev,\n previewLoaded: false,\n error: 'Unable to load image from this URL',\n }))\n }, [])\n\n // Handle file selection\n const handleFileSelect = useCallback((e: React.ChangeEvent<HTMLInputElement>) => {\n const file = e.target.files?.[0]\n if (!file) return\n\n if (!file.type.startsWith('image/')) {\n setUploadState((prev) => ({ ...prev, error: 'Only image files are allowed' }))\n return\n }\n\n setUploadState((prev) => {\n if (prev.preview) URL.revokeObjectURL(prev.preview)\n return prev\n })\n\n const preview = URL.createObjectURL(file)\n setUploadState({ file, preview, uploading: false, error: null })\n }, [])\n\n // Handle upload\n const handleUpload = useCallback(async () => {\n if (!uploadState.file) return\n\n setUploadState((prev) => ({ ...prev, uploading: true, error: null }))\n\n try {\n const formData = new FormData()\n formData.append('file', uploadState.file)\n const altText = uploadState.file.name.replace(/\\.[^/.]+$/, '').replace(/[-_]/g, ' ')\n formData.append('alt', altText)\n\n const response = await fetch(apiEndpoint, {\n method: 'POST',\n body: formData,\n })\n\n if (!response.ok) {\n const error = await response.json().catch(() => ({ message: 'Upload failed' }))\n throw new Error(error.message || error.errors?.[0]?.message || 'Upload failed')\n }\n\n const data = await response.json()\n const doc = data.doc || data\n onChange({\n id: doc.id,\n url: doc.url,\n alt: doc.alt,\n width: doc.width,\n height: doc.height,\n })\n setIsOpen(false)\n resetUploadState()\n } catch (error) {\n setUploadState((prev) => ({\n ...prev,\n uploading: false,\n error: error instanceof Error ? error.message : 'Upload failed',\n }))\n }\n }, [uploadState.file, apiEndpoint, onChange, resetUploadState])\n\n // Handle dialog close\n const handleDialogClose = useCallback(() => {\n setIsOpen(false)\n resetUploadState()\n resetUrlState()\n setActiveTab('browse')\n }, [resetUploadState, resetUrlState])\n\n // Handle escape key\n useEffect(() => {\n if (!isOpen) return\n\n const handleEscape = (e: KeyboardEvent) => {\n if (e.key === 'Escape') {\n handleDialogClose()\n }\n }\n\n document.addEventListener('keydown', handleEscape)\n return () => document.removeEventListener('keydown', handleEscape)\n }, [isOpen, handleDialogClose])\n\n return (\n <div className=\"puck-field\">\n {label && <label style={styles.label}>{label}</label>}\n\n <div style={{ display: 'flex', flexDirection: 'column', gap: '8px' }}>\n <div style={styles.previewContainer}>\n {/* Preview */}\n {value?.url ? (\n <div\n style={styles.imagePreview}\n onMouseEnter={() => setPreviewHovered(true)}\n onMouseLeave={() => setPreviewHovered(false)}\n >\n {/* eslint-disable-next-line @next/next/no-img-element */}\n <img\n src={value.url}\n alt={value.alt || ''}\n style={styles.previewImage}\n />\n {!readOnly && (\n <button\n type=\"button\"\n onClick={handleRemove}\n style={{\n ...styles.removeButton,\n opacity: previewHovered ? 1 : 0,\n }}\n aria-label=\"Remove image\"\n >\n <X style={styles.iconSmall} />\n </button>\n )}\n </div>\n ) : (\n <div style={styles.placeholder}>\n <Image style={{ width: '32px', height: '32px', color: 'var(--theme-elevation-400)' }} />\n </div>\n )}\n\n {/* Actions */}\n {!readOnly && (\n <div style={styles.actionsColumn}>\n <button\n type=\"button\"\n onClick={() => setIsOpen(true)}\n style={styles.buttonOutline}\n >\n {value ? 'Change Image' : 'Select Image'}\n </button>\n {value && (\n <button\n type=\"button\"\n onClick={handleRemove}\n style={styles.buttonGhost}\n >\n Remove\n </button>\n )}\n </div>\n )}\n </div>\n\n {/* Current URL display */}\n {value?.url && (\n <div style={styles.urlDisplay}>\n <Link style={styles.iconSmall} />\n <span style={{ overflow: 'hidden', textOverflow: 'ellipsis', maxWidth: '280px' }} title={value.url}>\n {value.url}\n </span>\n </div>\n )}\n </div>\n\n {/* Media Picker Dialog */}\n {isOpen && (\n <div style={styles.dialogOverlay} onClick={handleDialogClose}>\n <div style={styles.dialogContent} onClick={(e) => e.stopPropagation()}>\n {/* Header */}\n <div style={styles.dialogHeader}>\n <h2 style={styles.dialogTitle}>Select Media</h2>\n <button type=\"button\" onClick={handleDialogClose} style={styles.closeButton}>\n <X style={styles.icon} />\n </button>\n </div>\n\n {/* Tab Bar */}\n <div style={styles.tabBar}>\n <button\n type=\"button\"\n onClick={() => setActiveTab('browse')}\n style={{\n ...styles.tabButton,\n ...(activeTab === 'browse' ? styles.tabButtonActive : {}),\n }}\n >\n Browse Library\n </button>\n <button\n type=\"button\"\n onClick={() => setActiveTab('upload')}\n style={{\n ...styles.tabButton,\n ...(activeTab === 'upload' ? styles.tabButtonActive : {}),\n }}\n >\n Upload New\n </button>\n <button\n type=\"button\"\n onClick={() => setActiveTab('url')}\n style={{\n ...styles.tabButton,\n ...(activeTab === 'url' ? styles.tabButtonActive : {}),\n }}\n >\n From URL\n </button>\n </div>\n\n {/* Search (browse tab only) */}\n {activeTab === 'browse' && (\n <div style={styles.searchContainer}>\n <Search style={styles.searchIcon as CSSProperties} />\n <input\n type=\"text\"\n placeholder=\"Search by alt text...\"\n value={searchQuery}\n onChange={(e) => setSearchQuery(e.target.value)}\n style={styles.searchInput}\n />\n </div>\n )}\n\n {/* Content Area */}\n <div style={styles.contentArea}>\n {activeTab === 'browse' ? (\n /* Browse Tab */\n loading && mediaList.length === 0 ? (\n <div style={styles.mediaGrid}>\n {[...Array(8)].map((_, i) => (\n <div key={i} style={styles.skeleton} />\n ))}\n </div>\n ) : mediaList.length === 0 ? (\n <div style={styles.emptyState}>No images found</div>\n ) : (\n <>\n <div style={styles.mediaGrid}>\n {mediaList.map((item) => (\n <button\n key={item.id}\n type=\"button\"\n onClick={() => handleSelect(item)}\n onMouseEnter={() => setHoveredItem(item.id)}\n onMouseLeave={() => setHoveredItem(null)}\n style={{\n ...styles.mediaItem,\n ...(value?.id === item.id ? styles.mediaItemSelected : {}),\n ...(hoveredItem === item.id ? { borderColor: 'var(--theme-elevation-600)' } : {}),\n }}\n >\n {/* eslint-disable-next-line @next/next/no-img-element */}\n <img\n src={item.url}\n alt={item.alt || item.filename || ''}\n style={styles.mediaItemImage}\n loading=\"lazy\"\n />\n {item.alt && (\n <div style={styles.mediaItemAlt}>{item.alt}</div>\n )}\n </button>\n ))}\n </div>\n\n {hasMore && (\n <div style={styles.loadMoreContainer}>\n <button\n type=\"button\"\n onClick={handleLoadMore}\n disabled={loading}\n style={{\n ...styles.buttonOutline,\n ...(loading ? styles.buttonDisabled : {}),\n }}\n >\n {loading ? (\n <>\n <Loader2 style={{ ...styles.icon, marginRight: '8px', animation: 'spin 1s linear infinite' }} />\n Loading...\n </>\n ) : (\n 'Load More'\n )}\n </button>\n </div>\n )}\n </>\n )\n ) : activeTab === 'upload' ? (\n /* Upload Tab */\n <div style={styles.uploadContainer}>\n {uploadState.preview ? (\n <div style={styles.uploadPreview}>\n <div style={styles.uploadImageContainer}>\n {/* eslint-disable-next-line @next/next/no-img-element */}\n <img\n src={uploadState.preview}\n alt=\"Preview\"\n style={styles.uploadImage}\n />\n </div>\n\n <div style={styles.uploadMeta}>\n <p><span style={{ fontWeight: 500 }}>Filename:</span> {uploadState.file?.name}</p>\n <p><span style={{ fontWeight: 500 }}>Size:</span> {formatFileSize(uploadState.file?.size)}</p>\n </div>\n\n {uploadState.error && (\n <div style={styles.errorBox}>\n <AlertCircle style={{ ...styles.icon, flexShrink: 0, marginTop: '2px' }} />\n <span>{uploadState.error}</span>\n </div>\n )}\n\n <div style={styles.actionsRow}>\n <button\n type=\"button\"\n onClick={handleUpload}\n disabled={uploadState.uploading}\n style={{\n ...styles.buttonPrimary,\n ...(uploadState.uploading ? styles.buttonDisabled : {}),\n }}\n >\n {uploadState.uploading ? (\n <>\n <Loader2 style={{ ...styles.icon, marginRight: '8px', animation: 'spin 1s linear infinite' }} />\n Uploading...\n </>\n ) : (\n <>\n <Upload style={{ ...styles.icon, marginRight: '8px' }} />\n Upload & Select\n </>\n )}\n </button>\n <button\n type=\"button\"\n onClick={resetUploadState}\n disabled={uploadState.uploading}\n style={{\n ...styles.buttonOutline,\n ...(uploadState.uploading ? styles.buttonDisabled : {}),\n }}\n >\n Cancel\n </button>\n </div>\n </div>\n ) : (\n <div style={styles.dropZone}>\n <Image style={styles.dropZoneIcon} />\n <label style={{ cursor: 'pointer' }}>\n <span style={styles.buttonPrimary}>\n Select Image\n </span>\n <input\n type=\"file\"\n accept=\"image/*\"\n onChange={handleFileSelect}\n style={styles.hiddenInput}\n />\n </label>\n <p style={{ marginTop: '8px', fontSize: '14px', color: 'var(--theme-elevation-500)' }}>\n Select an image file to upload\n </p>\n {uploadState.error && (\n <div style={{ ...styles.errorBox, marginTop: '16px' }}>\n {uploadState.error}\n </div>\n )}\n </div>\n )}\n </div>\n ) : activeTab === 'url' ? (\n /* URL Tab */\n <div style={styles.uploadContainer}>\n <div style={styles.urlContainer}>\n <div style={styles.urlIntro as CSSProperties}>\n <Link style={styles.urlIcon} />\n <p style={{ fontSize: '14px', color: 'var(--theme-elevation-500)' }}>\n Enter an image URL from an external source\n </p>\n </div>\n\n <div style={styles.inputGroup as CSSProperties}>\n <label style={styles.inputLabel} htmlFor=\"image-url\">Image URL</label>\n <input\n id=\"image-url\"\n type=\"url\"\n placeholder=\"https://example.com/image.jpg\"\n value={urlState.url}\n onChange={(e) =>\n setUrlState((prev) => ({\n ...prev,\n url: e.target.value,\n error: null,\n previewLoaded: false,\n }))\n }\n onKeyDown={(e) => {\n if (e.key === 'Enter') {\n e.preventDefault()\n handleUrlSubmit()\n }\n }}\n style={styles.input}\n />\n </div>\n\n {urlState.url && !urlState.error && (\n <div style={styles.uploadImageContainer}>\n {/* eslint-disable-next-line @next/next/no-img-element */}\n <img\n src={urlState.url}\n alt=\"Preview\"\n style={styles.uploadImage}\n onLoad={handleUrlPreviewLoad}\n onError={handleUrlPreviewError}\n />\n {!urlState.previewLoaded && (\n <div style={styles.previewLoading}>\n <Loader2 style={{ width: '32px', height: '32px', animation: 'spin 1s linear infinite', color: 'var(--theme-elevation-400)' }} />\n </div>\n )}\n </div>\n )}\n\n {urlState.error && (\n <div style={styles.errorBox}>\n <AlertCircle style={{ ...styles.icon, flexShrink: 0, marginTop: '2px' }} />\n <span>{urlState.error}</span>\n </div>\n )}\n\n <div style={styles.actionsRow}>\n <button\n type=\"button\"\n onClick={handleUrlSubmit}\n disabled={!urlState.url || urlState.loading}\n style={{\n ...styles.buttonPrimary,\n ...((!urlState.url || urlState.loading) ? styles.buttonDisabled : {}),\n }}\n >\n <Link style={{ ...styles.icon, marginRight: '8px' }} />\n Use This URL\n </button>\n {urlState.url && (\n <button\n type=\"button\"\n onClick={resetUrlState}\n style={styles.buttonOutline}\n >\n Clear\n </button>\n )}\n </div>\n </div>\n </div>\n ) : null}\n </div>\n </div>\n </div>\n )}\n </div>\n )\n}\n\n// Memoize to prevent unnecessary re-renders\nexport const MediaField = memo(MediaFieldInner)\n\n// =============================================================================\n// Field Configuration Factory\n// =============================================================================\n\n/**\n * Creates a Puck field configuration for media selection\n */\nexport function createMediaField(config: {\n label?: string\n apiEndpoint?: string\n}): CustomField<MediaReference | null> {\n return {\n type: 'custom',\n label: config.label,\n render: ({ value, onChange, readOnly }) => (\n <MediaField\n value={value}\n onChange={onChange}\n label={config.label}\n readOnly={readOnly}\n apiEndpoint={config.apiEndpoint}\n />\n ),\n }\n}\n"],"names":["React","useState","useEffect","useCallback","memo","Image","X","Search","Loader2","Upload","AlertCircle","Link","styles","label","display","fontSize","fontWeight","color","marginBottom","previewContainer","alignItems","gap","imagePreview","position","previewImage","width","height","objectFit","borderRadius","border","removeButton","top","right","padding","backgroundColor","cursor","opacity","transition","placeholder","justifyContent","actionsColumn","flexDirection","buttonOutline","buttonGhost","buttonPrimary","buttonDisabled","urlDisplay","marginTop","dialogOverlay","inset","zIndex","dialogContent","boxShadow","maxWidth","maxHeight","margin","overflow","dialogHeader","borderBottom","flexShrink","dialogTitle","closeButton","tabBar","flexWrap","tabButton","borderBottomWidth","borderBottomStyle","borderBottomColor","tabButtonActive","searchContainer","searchInput","outline","searchIcon","left","transform","pointerEvents","contentArea","flex","overflowY","mediaGrid","gridTemplateColumns","mediaItem","aspectRatio","mediaItemSelected","borderColor","mediaItemImage","mediaItemAlt","bottom","textOverflow","whiteSpace","loadMoreContainer","emptyState","skeleton","animation","uploadContainer","minHeight","uploadPreview","uploadImageContainer","uploadImage","uploadMeta","errorBox","actionsRow","dropZone","textAlign","dropZoneIcon","hiddenInput","urlContainer","urlIntro","urlIcon","inputGroup","inputLabel","input","previewLoading","icon","iconSmall","formatFileSize","bytes","toFixed","MediaFieldInner","value","onChange","readOnly","apiEndpoint","isOpen","setIsOpen","mediaList","setMediaList","loading","setLoading","searchQuery","setSearchQuery","page","setPage","hasMore","setHasMore","activeTab","setActiveTab","hoveredItem","setHoveredItem","previewHovered","setPreviewHovered","uploadState","setUploadState","file","preview","uploading","error","urlState","setUrlState","url","previewLoaded","fetchMedia","searchTerm","pageNum","params","URLSearchParams","limit","toString","sort","set","response","fetch","ok","Error","data","json","items","docs","map","doc","id","alt","filename","mimeType","prev","hasNextPage","console","timer","setTimeout","clearTimeout","handleSelect","item","handleRemove","handleLoadMore","nextPage","resetUploadState","URL","revokeObjectURL","resetUrlState","handleUrlSubmit","trim","Date","now","handleUrlPreviewLoad","handleUrlPreviewError","handleFileSelect","e","target","files","type","startsWith","createObjectURL","handleUpload","formData","FormData","append","altText","name","replace","method","body","catch","message","errors","handleDialogClose","handleEscape","key","document","addEventListener","removeEventListener","div","className","style","onMouseEnter","onMouseLeave","img","src","button","onClick","aria-label","span","title","stopPropagation","h2","length","Array","_","i","disabled","marginRight","p","size","accept","htmlFor","onKeyDown","preventDefault","onLoad","onError","MediaField","createMediaField","config","render"],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@
|
|
|
8
8
|
*/
|
|
9
9
|
import React from 'react';
|
|
10
10
|
import type { CustomField } from '@puckeditor/core';
|
|
11
|
-
import type { PaddingValue } from './shared';
|
|
11
|
+
import type { PaddingValue } from './shared.js';
|
|
12
12
|
interface PaddingFieldProps {
|
|
13
13
|
value: PaddingValue | null;
|
|
14
14
|
onChange: (value: PaddingValue | null) => void;
|
|
@@ -16,7 +16,7 @@ interface PaddingFieldProps {
|
|
|
16
16
|
readOnly?: boolean;
|
|
17
17
|
showUnits?: boolean;
|
|
18
18
|
}
|
|
19
|
-
declare function PaddingFieldInner({ value, onChange, label, readOnly, showUnits, }: PaddingFieldProps):
|
|
19
|
+
declare function PaddingFieldInner({ value, onChange, label, readOnly, showUnits, }: PaddingFieldProps): React.JSX.Element;
|
|
20
20
|
export declare const PaddingField: React.MemoExoticComponent<typeof PaddingFieldInner>;
|
|
21
21
|
/**
|
|
22
22
|
* Creates a Puck field configuration for padding/spacing
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PaddingField.d.ts","sourceRoot":"","sources":["../../src/fields/PaddingField.tsx"],"names":[],"mappings":"AAEA;;;;;;;GAOG;AAEH,OAAO,KAAgD,MAAM,OAAO,CAAA;AACpE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAEnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"PaddingField.d.ts","sourceRoot":"","sources":["../../src/fields/PaddingField.tsx"],"names":[],"mappings":"AAEA;;;;;;;GAOG;AAEH,OAAO,KAAgD,MAAM,OAAO,CAAA;AACpE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAEnD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAA;AAQ/C,UAAU,iBAAiB;IACzB,KAAK,EAAE,YAAY,GAAG,IAAI,CAAA;IAC1B,QAAQ,EAAE,CAAC,KAAK,EAAE,YAAY,GAAG,IAAI,KAAK,IAAI,CAAA;IAC9C,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB;AAoJD,iBAAS,iBAAiB,CAAC,EACzB,KAAK,EACL,QAAQ,EACR,KAAK,EACL,QAAQ,EACR,SAAgB,GACjB,EAAE,iBAAiB,qBAmJnB;AAED,eAAO,MAAM,YAAY,qDAA0B,CAAA;AAMnD;;GAEG;AACH,wBAAgB,kBAAkB,CAAC,MAAM,EAAE;IACzC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,SAAS,CAAC,EAAE,OAAO,CAAA;CACpB,GAAG,WAAW,CAAC,YAAY,GAAG,IAAI,CAAC,CAcnC"}
|
|
@@ -7,8 +7,7 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
7
7
|
* - 4 number inputs for top/right/bottom/left
|
|
8
8
|
* - Link/unlink toggle button (when linked, all values sync)
|
|
9
9
|
* - Unit selector (px, rem)
|
|
10
|
-
*/
|
|
11
|
-
import { useCallback, memo } from 'react';
|
|
10
|
+
*/ import React, { useCallback, memo } from 'react';
|
|
12
11
|
import { Link, Unlink } from 'lucide-react';
|
|
13
12
|
// =============================================================================
|
|
14
13
|
// Default Value
|
|
@@ -19,7 +18,7 @@ const DEFAULT_VALUE = {
|
|
|
19
18
|
bottom: 0,
|
|
20
19
|
left: 0,
|
|
21
20
|
unit: 'px',
|
|
22
|
-
linked: true
|
|
21
|
+
linked: true
|
|
23
22
|
};
|
|
24
23
|
// =============================================================================
|
|
25
24
|
// Styles
|
|
@@ -28,17 +27,17 @@ const styles = {
|
|
|
28
27
|
container: {
|
|
29
28
|
display: 'flex',
|
|
30
29
|
flexDirection: 'column',
|
|
31
|
-
gap: '12px'
|
|
30
|
+
gap: '12px'
|
|
32
31
|
},
|
|
33
32
|
header: {
|
|
34
33
|
display: 'flex',
|
|
35
34
|
alignItems: 'center',
|
|
36
|
-
justifyContent: 'space-between'
|
|
35
|
+
justifyContent: 'space-between'
|
|
37
36
|
},
|
|
38
37
|
label: {
|
|
39
38
|
fontSize: '14px',
|
|
40
39
|
fontWeight: 500,
|
|
41
|
-
color: 'var(--theme-elevation-800)'
|
|
40
|
+
color: 'var(--theme-elevation-800)'
|
|
42
41
|
},
|
|
43
42
|
linkButton: {
|
|
44
43
|
display: 'flex',
|
|
@@ -51,7 +50,7 @@ const styles = {
|
|
|
51
50
|
borderRadius: '4px',
|
|
52
51
|
backgroundColor: 'var(--theme-bg)',
|
|
53
52
|
color: 'var(--theme-elevation-500)',
|
|
54
|
-
cursor: 'pointer'
|
|
53
|
+
cursor: 'pointer'
|
|
55
54
|
},
|
|
56
55
|
linkButtonActive: {
|
|
57
56
|
display: 'flex',
|
|
@@ -64,7 +63,7 @@ const styles = {
|
|
|
64
63
|
borderRadius: '4px',
|
|
65
64
|
backgroundColor: 'var(--theme-elevation-800)',
|
|
66
65
|
color: 'var(--theme-bg)',
|
|
67
|
-
cursor: 'pointer'
|
|
66
|
+
cursor: 'pointer'
|
|
68
67
|
},
|
|
69
68
|
grid: {
|
|
70
69
|
display: 'grid',
|
|
@@ -72,12 +71,12 @@ const styles = {
|
|
|
72
71
|
gap: '8px',
|
|
73
72
|
padding: '8px',
|
|
74
73
|
backgroundColor: 'var(--theme-elevation-50)',
|
|
75
|
-
borderRadius: '6px'
|
|
74
|
+
borderRadius: '6px'
|
|
76
75
|
},
|
|
77
76
|
inputRow: {
|
|
78
77
|
display: 'flex',
|
|
79
78
|
alignItems: 'center',
|
|
80
|
-
gap: '8px'
|
|
79
|
+
gap: '8px'
|
|
81
80
|
},
|
|
82
81
|
inputLabel: {
|
|
83
82
|
fontSize: '10px',
|
|
@@ -86,7 +85,7 @@ const styles = {
|
|
|
86
85
|
color: 'var(--theme-elevation-500)',
|
|
87
86
|
width: '24px',
|
|
88
87
|
textAlign: 'right',
|
|
89
|
-
flexShrink: 0
|
|
88
|
+
flexShrink: 0
|
|
90
89
|
},
|
|
91
90
|
input: {
|
|
92
91
|
height: '28px',
|
|
@@ -98,27 +97,27 @@ const styles = {
|
|
|
98
97
|
border: '1px solid var(--theme-elevation-150)',
|
|
99
98
|
borderRadius: '4px',
|
|
100
99
|
backgroundColor: 'var(--theme-input-bg)',
|
|
101
|
-
color: 'var(--theme-elevation-800)'
|
|
100
|
+
color: 'var(--theme-elevation-800)'
|
|
102
101
|
},
|
|
103
102
|
footer: {
|
|
104
103
|
display: 'flex',
|
|
105
104
|
alignItems: 'center',
|
|
106
105
|
justifyContent: 'space-between',
|
|
107
106
|
flexWrap: 'wrap',
|
|
108
|
-
gap: '8px'
|
|
107
|
+
gap: '8px'
|
|
109
108
|
},
|
|
110
109
|
unitGroup: {
|
|
111
110
|
display: 'flex',
|
|
112
111
|
alignItems: 'center',
|
|
113
|
-
gap: '8px'
|
|
112
|
+
gap: '8px'
|
|
114
113
|
},
|
|
115
114
|
unitLabel: {
|
|
116
115
|
fontSize: '12px',
|
|
117
|
-
color: 'var(--theme-elevation-500)'
|
|
116
|
+
color: 'var(--theme-elevation-500)'
|
|
118
117
|
},
|
|
119
118
|
unitButtons: {
|
|
120
119
|
display: 'flex',
|
|
121
|
-
gap: '4px'
|
|
120
|
+
gap: '4px'
|
|
122
121
|
},
|
|
123
122
|
unitButton: {
|
|
124
123
|
height: '28px',
|
|
@@ -129,7 +128,7 @@ const styles = {
|
|
|
129
128
|
borderRadius: '4px',
|
|
130
129
|
backgroundColor: 'var(--theme-bg)',
|
|
131
130
|
color: 'var(--theme-elevation-500)',
|
|
132
|
-
cursor: 'pointer'
|
|
131
|
+
cursor: 'pointer'
|
|
133
132
|
},
|
|
134
133
|
unitButtonActive: {
|
|
135
134
|
height: '28px',
|
|
@@ -140,24 +139,24 @@ const styles = {
|
|
|
140
139
|
borderRadius: '4px',
|
|
141
140
|
backgroundColor: 'var(--theme-elevation-800)',
|
|
142
141
|
color: 'var(--theme-bg)',
|
|
143
|
-
cursor: 'pointer'
|
|
142
|
+
cursor: 'pointer'
|
|
144
143
|
},
|
|
145
144
|
summary: {
|
|
146
145
|
fontSize: '12px',
|
|
147
146
|
fontFamily: 'monospace',
|
|
148
|
-
color: 'var(--theme-elevation-500)'
|
|
149
|
-
}
|
|
147
|
+
color: 'var(--theme-elevation-500)'
|
|
148
|
+
}
|
|
150
149
|
};
|
|
151
150
|
// =============================================================================
|
|
152
151
|
// PaddingField Component
|
|
153
152
|
// =============================================================================
|
|
154
|
-
function PaddingFieldInner({ value, onChange, label, readOnly, showUnits = true
|
|
153
|
+
function PaddingFieldInner({ value, onChange, label, readOnly, showUnits = true }) {
|
|
155
154
|
// Use default if no value
|
|
156
155
|
const currentValue = value || DEFAULT_VALUE;
|
|
157
156
|
// Use explicit linked state from value, default to true if not set
|
|
158
157
|
const isLinked = currentValue.linked ?? true;
|
|
159
158
|
// Handle individual side change
|
|
160
|
-
const handleSideChange = useCallback((side, newValue)
|
|
159
|
+
const handleSideChange = useCallback((side, newValue)=>{
|
|
161
160
|
if (isLinked) {
|
|
162
161
|
// When linked, update all sides
|
|
163
162
|
onChange({
|
|
@@ -166,28 +165,30 @@ function PaddingFieldInner({ value, onChange, label, readOnly, showUnits = true,
|
|
|
166
165
|
right: newValue,
|
|
167
166
|
bottom: newValue,
|
|
168
167
|
left: newValue,
|
|
169
|
-
linked: true
|
|
168
|
+
linked: true
|
|
170
169
|
});
|
|
171
|
-
}
|
|
172
|
-
else {
|
|
170
|
+
} else {
|
|
173
171
|
// When unlinked, update only the specific side
|
|
174
172
|
onChange({
|
|
175
173
|
...currentValue,
|
|
176
174
|
[side]: newValue,
|
|
177
|
-
linked: false
|
|
175
|
+
linked: false
|
|
178
176
|
});
|
|
179
177
|
}
|
|
180
|
-
}, [
|
|
178
|
+
}, [
|
|
179
|
+
currentValue,
|
|
180
|
+
onChange,
|
|
181
|
+
isLinked
|
|
182
|
+
]);
|
|
181
183
|
// Handle link toggle
|
|
182
|
-
const handleLinkToggle = useCallback(()
|
|
184
|
+
const handleLinkToggle = useCallback(()=>{
|
|
183
185
|
if (isLinked) {
|
|
184
186
|
// Unlinking - keep current values but mark as unlinked
|
|
185
187
|
onChange({
|
|
186
188
|
...currentValue,
|
|
187
|
-
linked: false
|
|
189
|
+
linked: false
|
|
188
190
|
});
|
|
189
|
-
}
|
|
190
|
-
else {
|
|
191
|
+
} else {
|
|
191
192
|
// Linking - set all sides to the top value and mark as linked
|
|
192
193
|
onChange({
|
|
193
194
|
...currentValue,
|
|
@@ -195,38 +196,135 @@ function PaddingFieldInner({ value, onChange, label, readOnly, showUnits = true,
|
|
|
195
196
|
right: currentValue.top,
|
|
196
197
|
bottom: currentValue.top,
|
|
197
198
|
left: currentValue.top,
|
|
198
|
-
linked: true
|
|
199
|
+
linked: true
|
|
199
200
|
});
|
|
200
201
|
}
|
|
201
|
-
}, [
|
|
202
|
+
}, [
|
|
203
|
+
currentValue,
|
|
204
|
+
onChange,
|
|
205
|
+
isLinked
|
|
206
|
+
]);
|
|
202
207
|
// Handle unit change
|
|
203
|
-
const handleUnitChange = useCallback((unit)
|
|
208
|
+
const handleUnitChange = useCallback((unit)=>{
|
|
204
209
|
onChange({
|
|
205
210
|
...currentValue,
|
|
206
|
-
unit
|
|
211
|
+
unit
|
|
207
212
|
});
|
|
208
|
-
}, [
|
|
213
|
+
}, [
|
|
214
|
+
currentValue,
|
|
215
|
+
onChange
|
|
216
|
+
]);
|
|
209
217
|
// Render a single side input - compact horizontal layout
|
|
210
|
-
const renderSideInput = (side, sideLabel)
|
|
211
|
-
|
|
218
|
+
const renderSideInput = (side, sideLabel)=>/*#__PURE__*/ _jsxs("div", {
|
|
219
|
+
style: styles.inputRow,
|
|
220
|
+
children: [
|
|
221
|
+
/*#__PURE__*/ _jsx("label", {
|
|
222
|
+
style: styles.inputLabel,
|
|
223
|
+
children: sideLabel.charAt(0)
|
|
224
|
+
}),
|
|
225
|
+
/*#__PURE__*/ _jsx("input", {
|
|
226
|
+
type: "number",
|
|
227
|
+
min: 0,
|
|
228
|
+
value: currentValue[side],
|
|
229
|
+
onChange: (e)=>handleSideChange(side, parseInt(e.target.value, 10) || 0),
|
|
230
|
+
disabled: readOnly,
|
|
231
|
+
style: styles.input
|
|
232
|
+
})
|
|
233
|
+
]
|
|
234
|
+
});
|
|
235
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
236
|
+
className: "puck-field",
|
|
237
|
+
style: styles.container,
|
|
238
|
+
children: [
|
|
239
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
240
|
+
style: styles.header,
|
|
241
|
+
children: [
|
|
242
|
+
label && /*#__PURE__*/ _jsx("label", {
|
|
243
|
+
style: styles.label,
|
|
244
|
+
children: label
|
|
245
|
+
}),
|
|
246
|
+
!readOnly && /*#__PURE__*/ _jsx("button", {
|
|
247
|
+
type: "button",
|
|
248
|
+
onClick: handleLinkToggle,
|
|
249
|
+
style: isLinked ? styles.linkButtonActive : styles.linkButton,
|
|
250
|
+
title: isLinked ? 'Click to unlink (set sides individually)' : 'Click to link (all sides same value)',
|
|
251
|
+
children: isLinked ? /*#__PURE__*/ _jsx(Link, {
|
|
252
|
+
style: {
|
|
253
|
+
width: '16px',
|
|
254
|
+
height: '16px'
|
|
255
|
+
}
|
|
256
|
+
}) : /*#__PURE__*/ _jsx(Unlink, {
|
|
257
|
+
style: {
|
|
258
|
+
width: '16px',
|
|
259
|
+
height: '16px'
|
|
260
|
+
}
|
|
261
|
+
})
|
|
262
|
+
})
|
|
263
|
+
]
|
|
264
|
+
}),
|
|
265
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
266
|
+
style: styles.grid,
|
|
267
|
+
children: [
|
|
268
|
+
renderSideInput('top', 'Top'),
|
|
269
|
+
renderSideInput('right', 'Right'),
|
|
270
|
+
renderSideInput('bottom', 'Bottom'),
|
|
271
|
+
renderSideInput('left', 'Left')
|
|
272
|
+
]
|
|
273
|
+
}),
|
|
274
|
+
showUnits && !readOnly && /*#__PURE__*/ _jsxs("div", {
|
|
275
|
+
style: styles.footer,
|
|
276
|
+
children: [
|
|
277
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
278
|
+
style: styles.unitGroup,
|
|
279
|
+
children: [
|
|
280
|
+
/*#__PURE__*/ _jsx("label", {
|
|
281
|
+
style: styles.unitLabel,
|
|
282
|
+
children: "Unit:"
|
|
283
|
+
}),
|
|
284
|
+
/*#__PURE__*/ _jsx("div", {
|
|
285
|
+
style: styles.unitButtons,
|
|
286
|
+
children: [
|
|
287
|
+
'px',
|
|
288
|
+
'rem'
|
|
289
|
+
].map((unit)=>{
|
|
212
290
|
const isActive = currentValue.unit === unit;
|
|
213
|
-
return
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
291
|
+
return /*#__PURE__*/ _jsx("button", {
|
|
292
|
+
type: "button",
|
|
293
|
+
onClick: ()=>handleUnitChange(unit),
|
|
294
|
+
style: isActive ? styles.unitButtonActive : styles.unitButton,
|
|
295
|
+
children: unit
|
|
296
|
+
}, unit);
|
|
297
|
+
})
|
|
298
|
+
})
|
|
299
|
+
]
|
|
300
|
+
}),
|
|
301
|
+
/*#__PURE__*/ _jsx("span", {
|
|
302
|
+
style: styles.summary,
|
|
303
|
+
children: isLinked ? `${currentValue.top}${currentValue.unit}` : `${currentValue.top} ${currentValue.right} ${currentValue.bottom} ${currentValue.left}${currentValue.unit}`
|
|
304
|
+
})
|
|
305
|
+
]
|
|
306
|
+
})
|
|
307
|
+
]
|
|
308
|
+
});
|
|
217
309
|
}
|
|
218
|
-
export const PaddingField = memo(PaddingFieldInner);
|
|
310
|
+
export const PaddingField = /*#__PURE__*/ memo(PaddingFieldInner);
|
|
219
311
|
// =============================================================================
|
|
220
312
|
// Field Configuration Factory
|
|
221
313
|
// =============================================================================
|
|
222
314
|
/**
|
|
223
315
|
* Creates a Puck field configuration for padding/spacing
|
|
224
|
-
*/
|
|
225
|
-
export function createPaddingField(config) {
|
|
316
|
+
*/ export function createPaddingField(config) {
|
|
226
317
|
return {
|
|
227
318
|
type: 'custom',
|
|
228
319
|
label: config.label,
|
|
229
|
-
render: ({ value, onChange, readOnly })
|
|
320
|
+
render: ({ value, onChange, readOnly })=>/*#__PURE__*/ _jsx(PaddingField, {
|
|
321
|
+
value: value,
|
|
322
|
+
onChange: onChange,
|
|
323
|
+
label: config.label,
|
|
324
|
+
readOnly: readOnly,
|
|
325
|
+
showUnits: config.showUnits
|
|
326
|
+
})
|
|
230
327
|
};
|
|
231
328
|
}
|
|
329
|
+
|
|
232
330
|
//# sourceMappingURL=PaddingField.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"PaddingField.js","sourceRoot":"","sources":["../../src/fields/PaddingField.tsx"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"sources":["../../src/fields/PaddingField.tsx"],"sourcesContent":["'use client'\n\n/**\n * PaddingField - Custom Puck field for 4-sided padding/margin control\n *\n * This component provides:\n * - 4 number inputs for top/right/bottom/left\n * - Link/unlink toggle button (when linked, all values sync)\n * - Unit selector (px, rem)\n */\n\nimport React, { useCallback, memo, type CSSProperties } from 'react'\nimport type { CustomField } from '@puckeditor/core'\nimport { Link, Unlink } from 'lucide-react'\nimport type { PaddingValue } from './shared.js'\n\n// =============================================================================\n// Types\n// =============================================================================\n\ntype SpacingUnit = 'px' | 'rem' | 'em' | '%'\n\ninterface PaddingFieldProps {\n value: PaddingValue | null\n onChange: (value: PaddingValue | null) => void\n label?: string\n readOnly?: boolean\n showUnits?: boolean\n}\n\n// =============================================================================\n// Default Value\n// =============================================================================\n\nconst DEFAULT_VALUE: PaddingValue = {\n top: 0,\n right: 0,\n bottom: 0,\n left: 0,\n unit: 'px',\n linked: true,\n}\n\n// =============================================================================\n// Styles\n// =============================================================================\n\nconst styles = {\n container: {\n display: 'flex',\n flexDirection: 'column',\n gap: '12px',\n } as CSSProperties,\n header: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n } as CSSProperties,\n label: {\n fontSize: '14px',\n fontWeight: 500,\n color: 'var(--theme-elevation-800)',\n } as CSSProperties,\n linkButton: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '28px',\n height: '28px',\n padding: 0,\n border: '1px solid var(--theme-elevation-150)',\n borderRadius: '4px',\n backgroundColor: 'var(--theme-bg)',\n color: 'var(--theme-elevation-500)',\n cursor: 'pointer',\n } as CSSProperties,\n linkButtonActive: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'center',\n width: '28px',\n height: '28px',\n padding: 0,\n border: '1px solid var(--theme-elevation-800)',\n borderRadius: '4px',\n backgroundColor: 'var(--theme-elevation-800)',\n color: 'var(--theme-bg)',\n cursor: 'pointer',\n } as CSSProperties,\n grid: {\n display: 'grid',\n gridTemplateColumns: '1fr 1fr',\n gap: '8px',\n padding: '8px',\n backgroundColor: 'var(--theme-elevation-50)',\n borderRadius: '6px',\n } as CSSProperties,\n inputRow: {\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n } as CSSProperties,\n inputLabel: {\n fontSize: '10px',\n textTransform: 'uppercase',\n letterSpacing: '0.05em',\n color: 'var(--theme-elevation-500)',\n width: '24px',\n textAlign: 'right',\n flexShrink: 0,\n } as CSSProperties,\n input: {\n height: '28px',\n width: '100%',\n padding: '0 4px',\n textAlign: 'center',\n fontSize: '14px',\n fontFamily: 'monospace',\n border: '1px solid var(--theme-elevation-150)',\n borderRadius: '4px',\n backgroundColor: 'var(--theme-input-bg)',\n color: 'var(--theme-elevation-800)',\n } as CSSProperties,\n footer: {\n display: 'flex',\n alignItems: 'center',\n justifyContent: 'space-between',\n flexWrap: 'wrap',\n gap: '8px',\n } as CSSProperties,\n unitGroup: {\n display: 'flex',\n alignItems: 'center',\n gap: '8px',\n } as CSSProperties,\n unitLabel: {\n fontSize: '12px',\n color: 'var(--theme-elevation-500)',\n } as CSSProperties,\n unitButtons: {\n display: 'flex',\n gap: '4px',\n } as CSSProperties,\n unitButton: {\n height: '28px',\n padding: '0 10px',\n fontSize: '12px',\n fontFamily: 'monospace',\n border: '1px solid var(--theme-elevation-150)',\n borderRadius: '4px',\n backgroundColor: 'var(--theme-bg)',\n color: 'var(--theme-elevation-500)',\n cursor: 'pointer',\n } as CSSProperties,\n unitButtonActive: {\n height: '28px',\n padding: '0 10px',\n fontSize: '12px',\n fontFamily: 'monospace',\n border: '1px solid var(--theme-elevation-800)',\n borderRadius: '4px',\n backgroundColor: 'var(--theme-elevation-800)',\n color: 'var(--theme-bg)',\n cursor: 'pointer',\n } as CSSProperties,\n summary: {\n fontSize: '12px',\n fontFamily: 'monospace',\n color: 'var(--theme-elevation-500)',\n } as CSSProperties,\n}\n\n// =============================================================================\n// PaddingField Component\n// =============================================================================\n\nfunction PaddingFieldInner({\n value,\n onChange,\n label,\n readOnly,\n showUnits = true,\n}: PaddingFieldProps) {\n // Use default if no value\n const currentValue = value || DEFAULT_VALUE\n\n // Use explicit linked state from value, default to true if not set\n const isLinked = currentValue.linked ?? true\n\n // Handle individual side change\n const handleSideChange = useCallback((\n side: 'top' | 'right' | 'bottom' | 'left',\n newValue: number\n ) => {\n if (isLinked) {\n // When linked, update all sides\n onChange({\n ...currentValue,\n top: newValue,\n right: newValue,\n bottom: newValue,\n left: newValue,\n linked: true,\n })\n } else {\n // When unlinked, update only the specific side\n onChange({\n ...currentValue,\n [side]: newValue,\n linked: false,\n })\n }\n }, [currentValue, onChange, isLinked])\n\n // Handle link toggle\n const handleLinkToggle = useCallback(() => {\n if (isLinked) {\n // Unlinking - keep current values but mark as unlinked\n onChange({\n ...currentValue,\n linked: false,\n })\n } else {\n // Linking - set all sides to the top value and mark as linked\n onChange({\n ...currentValue,\n top: currentValue.top,\n right: currentValue.top,\n bottom: currentValue.top,\n left: currentValue.top,\n linked: true,\n })\n }\n }, [currentValue, onChange, isLinked])\n\n // Handle unit change\n const handleUnitChange = useCallback((unit: SpacingUnit) => {\n onChange({\n ...currentValue,\n unit,\n })\n }, [currentValue, onChange])\n\n // Render a single side input - compact horizontal layout\n const renderSideInput = (\n side: 'top' | 'right' | 'bottom' | 'left',\n sideLabel: string\n ) => (\n <div style={styles.inputRow}>\n <label style={styles.inputLabel as CSSProperties}>\n {sideLabel.charAt(0)}\n </label>\n <input\n type=\"number\"\n min={0}\n value={currentValue[side]}\n onChange={(e) => handleSideChange(side, parseInt(e.target.value, 10) || 0)}\n disabled={readOnly}\n style={styles.input as CSSProperties}\n />\n </div>\n )\n\n return (\n <div className=\"puck-field\" style={styles.container}>\n {/* Header with label and link toggle */}\n <div style={styles.header}>\n {label && (\n <label style={styles.label}>\n {label}\n </label>\n )}\n {/* Link/Unlink toggle button */}\n {!readOnly && (\n <button\n type=\"button\"\n onClick={handleLinkToggle}\n style={isLinked ? styles.linkButtonActive : styles.linkButton}\n title={isLinked ? 'Click to unlink (set sides individually)' : 'Click to link (all sides same value)'}\n >\n {isLinked ? (\n <Link style={{ width: '16px', height: '16px' }} />\n ) : (\n <Unlink style={{ width: '16px', height: '16px' }} />\n )}\n </button>\n )}\n </div>\n\n {/* Compact 2x2 grid layout */}\n <div style={styles.grid}>\n {renderSideInput('top', 'Top')}\n {renderSideInput('right', 'Right')}\n {renderSideInput('bottom', 'Bottom')}\n {renderSideInput('left', 'Left')}\n </div>\n\n {/* Unit selector and summary */}\n {showUnits && !readOnly && (\n <div style={styles.footer}>\n <div style={styles.unitGroup}>\n <label style={styles.unitLabel}>Unit:</label>\n <div style={styles.unitButtons}>\n {(['px', 'rem'] as SpacingUnit[]).map((unit) => {\n const isActive = currentValue.unit === unit\n return (\n <button\n key={unit}\n type=\"button\"\n onClick={() => handleUnitChange(unit)}\n style={isActive ? styles.unitButtonActive : styles.unitButton}\n >\n {unit}\n </button>\n )\n })}\n </div>\n </div>\n {/* Current value summary */}\n <span style={styles.summary}>\n {isLinked\n ? `${currentValue.top}${currentValue.unit}`\n : `${currentValue.top} ${currentValue.right} ${currentValue.bottom} ${currentValue.left}${currentValue.unit}`\n }\n </span>\n </div>\n )}\n </div>\n )\n}\n\nexport const PaddingField = memo(PaddingFieldInner)\n\n// =============================================================================\n// Field Configuration Factory\n// =============================================================================\n\n/**\n * Creates a Puck field configuration for padding/spacing\n */\nexport function createPaddingField(config: {\n label?: string\n showUnits?: boolean\n}): CustomField<PaddingValue | null> {\n return {\n type: 'custom',\n label: config.label,\n render: ({ value, onChange, readOnly }) => (\n <PaddingField\n value={value}\n onChange={onChange}\n label={config.label}\n readOnly={readOnly}\n showUnits={config.showUnits}\n />\n ),\n }\n}\n"],"names":["React","useCallback","memo","Link","Unlink","DEFAULT_VALUE","top","right","bottom","left","unit","linked","styles","container","display","flexDirection","gap","header","alignItems","justifyContent","label","fontSize","fontWeight","color","linkButton","width","height","padding","border","borderRadius","backgroundColor","cursor","linkButtonActive","grid","gridTemplateColumns","inputRow","inputLabel","textTransform","letterSpacing","textAlign","flexShrink","input","fontFamily","footer","flexWrap","unitGroup","unitLabel","unitButtons","unitButton","unitButtonActive","summary","PaddingFieldInner","value","onChange","readOnly","showUnits","currentValue","isLinked","handleSideChange","side","newValue","handleLinkToggle","handleUnitChange","renderSideInput","sideLabel","div","style","charAt","type","min","e","parseInt","target","disabled","className","button","onClick","title","map","isActive","span","PaddingField","createPaddingField","config","render"],"mappings":"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"}
|