@delmaredigital/payload-puck 0.1.3 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +293 -1237
- package/dist/admin/EditWithPuckButton.d.ts +74 -0
- package/dist/admin/EditWithPuckButton.d.ts.map +1 -0
- package/dist/admin/EditWithPuckButton.js +114 -0
- package/dist/admin/EditWithPuckButton.js.map +1 -0
- package/dist/admin/EditWithPuckCell.d.ts +43 -0
- package/dist/admin/EditWithPuckCell.d.ts.map +1 -0
- package/dist/admin/EditWithPuckCell.js +66 -0
- package/dist/admin/EditWithPuckCell.js.map +1 -0
- package/dist/admin/PuckEditorView.d.ts +85 -0
- package/dist/admin/PuckEditorView.d.ts.map +1 -0
- package/dist/admin/PuckEditorView.js +135 -0
- package/dist/admin/PuckEditorView.js.map +1 -0
- package/dist/admin/client.d.ts +8 -104
- package/dist/admin/client.d.ts.map +1 -0
- package/dist/admin/client.js +14 -176
- package/dist/admin/client.js.map +1 -0
- package/dist/admin/generateAdminComponents.d.ts +51 -0
- package/dist/admin/generateAdminComponents.d.ts.map +1 -0
- package/dist/admin/generateAdminComponents.js +42 -0
- package/dist/admin/generateAdminComponents.js.map +1 -0
- package/dist/admin/index.d.ts +14 -150
- package/dist/admin/index.d.ts.map +1 -0
- package/dist/admin/index.js +17 -30
- package/dist/admin/index.js.map +1 -0
- package/dist/api/createPuckApiRoutes.d.ts +31 -0
- package/dist/api/createPuckApiRoutes.d.ts.map +1 -0
- package/dist/api/createPuckApiRoutes.js +193 -0
- package/dist/api/createPuckApiRoutes.js.map +1 -0
- package/dist/api/createPuckApiRoutesVersions.d.ts +28 -0
- package/dist/api/createPuckApiRoutesVersions.d.ts.map +1 -0
- package/dist/api/createPuckApiRoutesVersions.js +144 -0
- package/dist/api/createPuckApiRoutesVersions.js.map +1 -0
- package/dist/api/createPuckApiRoutesWithId.d.ts +34 -0
- package/dist/api/createPuckApiRoutesWithId.d.ts.map +1 -0
- package/dist/api/createPuckApiRoutesWithId.js +251 -0
- package/dist/api/createPuckApiRoutesWithId.js.map +1 -0
- package/dist/api/index.d.ts +11 -431
- package/dist/api/index.d.ts.map +1 -0
- package/dist/api/index.js +40 -587
- package/dist/api/index.js.map +1 -0
- package/dist/api/types.d.ts +302 -0
- package/dist/api/types.d.ts.map +1 -0
- package/dist/api/types.js +2 -0
- package/dist/api/types.js.map +1 -0
- package/dist/api/utils/mapRootProps.d.ts +76 -0
- package/dist/api/utils/mapRootProps.d.ts.map +1 -0
- package/dist/api/utils/mapRootProps.js +169 -0
- package/dist/api/utils/mapRootProps.js.map +1 -0
- package/dist/collections/Templates.d.ts +9 -0
- package/dist/collections/Templates.d.ts.map +1 -0
- package/dist/collections/Templates.js +62 -0
- package/dist/collections/Templates.js.map +1 -0
- package/dist/components/AccordionClient.d.ts +20 -0
- package/dist/components/AccordionClient.d.ts.map +1 -0
- package/dist/components/AccordionClient.js +67 -0
- package/dist/components/AccordionClient.js.map +1 -0
- package/dist/components/AnimatedWrapper.d.ts +33 -0
- package/dist/components/AnimatedWrapper.d.ts.map +1 -0
- package/dist/components/AnimatedWrapper.js +61 -0
- package/dist/components/AnimatedWrapper.js.map +1 -0
- package/dist/components/exports.d.ts +54 -0
- package/dist/components/exports.d.ts.map +1 -0
- package/dist/components/exports.js +71 -0
- package/dist/components/exports.js.map +1 -0
- package/dist/components/index.d.ts +8 -219
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +15 -9155
- package/dist/components/index.js.map +1 -0
- package/dist/components/interactive/Accordion.d.ts +28 -0
- package/dist/components/interactive/Accordion.d.ts.map +1 -0
- package/dist/components/interactive/Accordion.js +159 -0
- package/dist/components/interactive/Accordion.js.map +1 -0
- package/dist/components/interactive/Accordion.server.d.ts +29 -0
- package/dist/components/interactive/Accordion.server.d.ts.map +1 -0
- package/dist/components/interactive/Accordion.server.js +30 -0
- package/dist/components/interactive/Accordion.server.js.map +1 -0
- package/dist/components/interactive/Button.d.ts +26 -0
- package/dist/components/interactive/Button.d.ts.map +1 -0
- package/dist/components/interactive/Button.js +133 -0
- package/dist/components/interactive/Button.js.map +1 -0
- package/dist/components/interactive/Button.server.d.ts +28 -0
- package/dist/components/interactive/Button.server.d.ts.map +1 -0
- package/dist/components/interactive/Button.server.js +96 -0
- package/dist/components/interactive/Button.server.js.map +1 -0
- package/dist/components/interactive/Card.d.ts +27 -0
- package/dist/components/interactive/Card.d.ts.map +1 -0
- package/dist/components/interactive/Card.js +128 -0
- package/dist/components/interactive/Card.js.map +1 -0
- package/dist/components/interactive/Card.server.d.ts +29 -0
- package/dist/components/interactive/Card.server.d.ts.map +1 -0
- package/dist/components/interactive/Card.server.js +77 -0
- package/dist/components/interactive/Card.server.js.map +1 -0
- package/dist/components/interactive/Divider.d.ts +18 -0
- package/dist/components/interactive/Divider.d.ts.map +1 -0
- package/dist/components/interactive/Divider.js +68 -0
- package/dist/components/interactive/Divider.js.map +1 -0
- package/dist/components/interactive/Divider.server.d.ts +20 -0
- package/dist/components/interactive/Divider.server.d.ts.map +1 -0
- package/dist/components/interactive/Divider.server.js +50 -0
- package/dist/components/interactive/Divider.server.js.map +1 -0
- package/dist/components/interactive/index.d.ts +10 -0
- package/dist/components/interactive/index.d.ts.map +1 -0
- package/dist/components/interactive/index.js +10 -0
- package/dist/components/interactive/index.js.map +1 -0
- package/dist/components/layout/Container.d.ts +29 -0
- package/dist/components/layout/Container.d.ts.map +1 -0
- package/dist/components/layout/Container.js +166 -0
- package/dist/components/layout/Container.js.map +1 -0
- package/dist/components/layout/Container.server.d.ts +32 -0
- package/dist/components/layout/Container.server.d.ts.map +1 -0
- package/dist/components/layout/Container.server.js +105 -0
- package/dist/components/layout/Container.server.js.map +1 -0
- package/dist/components/layout/Flex.d.ts +36 -0
- package/dist/components/layout/Flex.d.ts.map +1 -0
- package/dist/components/layout/Flex.js +183 -0
- package/dist/components/layout/Flex.js.map +1 -0
- package/dist/components/layout/Flex.server.d.ts +36 -0
- package/dist/components/layout/Flex.server.d.ts.map +1 -0
- package/dist/components/layout/Flex.server.js +97 -0
- package/dist/components/layout/Flex.server.js.map +1 -0
- package/dist/components/layout/Grid.d.ts +31 -0
- package/dist/components/layout/Grid.d.ts.map +1 -0
- package/dist/components/layout/Grid.js +164 -0
- package/dist/components/layout/Grid.js.map +1 -0
- package/dist/components/layout/Grid.server.d.ts +32 -0
- package/dist/components/layout/Grid.server.d.ts.map +1 -0
- package/dist/components/layout/Grid.server.js +92 -0
- package/dist/components/layout/Grid.server.js.map +1 -0
- package/dist/components/layout/Section.d.ts +35 -0
- package/dist/components/layout/Section.d.ts.map +1 -0
- package/dist/components/layout/Section.js +212 -0
- package/dist/components/layout/Section.js.map +1 -0
- package/dist/components/layout/Section.server.d.ts +35 -0
- package/dist/components/layout/Section.server.d.ts.map +1 -0
- package/dist/components/layout/Section.server.js +144 -0
- package/dist/components/layout/Section.server.js.map +1 -0
- package/dist/components/layout/Spacer.d.ts +18 -0
- package/dist/components/layout/Spacer.d.ts.map +1 -0
- package/dist/components/layout/Spacer.js +99 -0
- package/dist/components/layout/Spacer.js.map +1 -0
- package/dist/components/layout/Spacer.server.d.ts +21 -0
- package/dist/components/layout/Spacer.server.d.ts.map +1 -0
- package/dist/components/layout/Spacer.server.js +61 -0
- package/dist/components/layout/Spacer.server.js.map +1 -0
- package/dist/components/layout/Template.d.ts +35 -0
- package/dist/components/layout/Template.d.ts.map +1 -0
- package/dist/components/layout/Template.js +124 -0
- package/dist/components/layout/Template.js.map +1 -0
- package/dist/components/layout/Template.server.d.ts +32 -0
- package/dist/components/layout/Template.server.d.ts.map +1 -0
- package/dist/components/layout/Template.server.js +75 -0
- package/dist/components/layout/Template.server.js.map +1 -0
- package/dist/components/layout/index.d.ts +14 -0
- package/dist/components/layout/index.d.ts.map +1 -0
- package/dist/components/layout/index.js +13 -0
- package/dist/components/layout/index.js.map +1 -0
- package/dist/components/media/Image.d.ts +30 -0
- package/dist/components/media/Image.d.ts.map +1 -0
- package/dist/components/media/Image.js +123 -0
- package/dist/components/media/Image.js.map +1 -0
- package/dist/components/media/Image.server.d.ts +28 -0
- package/dist/components/media/Image.server.d.ts.map +1 -0
- package/dist/components/media/Image.server.js +76 -0
- package/dist/components/media/Image.server.js.map +1 -0
- package/dist/components/media/index.d.ts +7 -0
- package/dist/components/media/index.d.ts.map +1 -0
- package/dist/components/media/index.js +7 -0
- package/dist/components/media/index.js.map +1 -0
- package/dist/components/typography/Heading.d.ts +21 -0
- package/dist/components/typography/Heading.d.ts.map +1 -0
- package/dist/components/typography/Heading.js +71 -0
- package/dist/components/typography/Heading.js.map +1 -0
- package/dist/components/typography/Heading.server.d.ts +21 -0
- package/dist/components/typography/Heading.server.d.ts.map +1 -0
- package/dist/components/typography/Heading.server.js +49 -0
- package/dist/components/typography/Heading.server.js.map +1 -0
- package/dist/components/typography/RichText.d.ts +20 -0
- package/dist/components/typography/RichText.d.ts.map +1 -0
- package/dist/components/typography/RichText.editor.d.ts +11 -0
- package/dist/components/typography/RichText.editor.d.ts.map +1 -0
- package/dist/components/typography/RichText.editor.js +67 -0
- package/dist/components/typography/RichText.editor.js.map +1 -0
- package/dist/components/typography/RichText.js +73 -0
- package/dist/components/typography/RichText.js.map +1 -0
- package/dist/components/typography/RichText.server.d.ts +22 -0
- package/dist/components/typography/RichText.server.d.ts.map +1 -0
- package/dist/components/typography/RichText.server.js +52 -0
- package/dist/components/typography/RichText.server.js.map +1 -0
- package/dist/components/typography/Text.d.ts +20 -0
- package/dist/components/typography/Text.d.ts.map +1 -0
- package/dist/components/typography/Text.js +61 -0
- package/dist/components/typography/Text.js.map +1 -0
- package/dist/components/typography/Text.server.d.ts +21 -0
- package/dist/components/typography/Text.server.d.ts.map +1 -0
- package/dist/components/typography/Text.server.js +39 -0
- package/dist/components/typography/Text.server.js.map +1 -0
- package/dist/components/typography/index.d.ts +10 -0
- package/dist/components/typography/index.d.ts.map +1 -0
- package/dist/components/typography/index.js +10 -0
- package/dist/components/typography/index.js.map +1 -0
- package/dist/config/config.editor.d.ts +15 -56
- package/dist/config/config.editor.d.ts.map +1 -0
- package/dist/config/config.editor.js +125 -9364
- package/dist/config/config.editor.js.map +1 -0
- package/dist/config/index.d.ts +7 -33
- package/dist/config/index.d.ts.map +1 -0
- package/dist/config/index.js +110 -2028
- package/dist/config/index.js.map +1 -0
- package/dist/config/merge.d.ts +23 -0
- package/dist/config/merge.d.ts.map +1 -0
- package/dist/config/merge.js +80 -0
- package/dist/config/merge.js.map +1 -0
- package/dist/config/presets.d.ts +342 -0
- package/dist/config/presets.d.ts.map +1 -0
- package/dist/config/presets.js +247 -0
- package/dist/config/presets.js.map +1 -0
- package/dist/editor/PuckEditor.client.d.ts +131 -0
- package/dist/editor/PuckEditor.client.d.ts.map +1 -0
- package/dist/editor/PuckEditor.client.js +42 -0
- package/dist/editor/PuckEditor.client.js.map +1 -0
- package/dist/editor/PuckEditorCore.client.d.ts +141 -0
- package/dist/editor/PuckEditorCore.client.d.ts.map +1 -0
- package/dist/editor/PuckEditorCore.client.js +306 -0
- package/dist/editor/PuckEditorCore.client.js.map +1 -0
- package/dist/editor/components/HeaderActions.d.ts +109 -0
- package/dist/editor/components/HeaderActions.d.ts.map +1 -0
- package/dist/editor/components/HeaderActions.js +254 -0
- package/dist/editor/components/HeaderActions.js.map +1 -0
- package/dist/editor/components/IframeWrapper.d.ts +77 -0
- package/dist/editor/components/IframeWrapper.d.ts.map +1 -0
- package/dist/editor/components/IframeWrapper.js +257 -0
- package/dist/editor/components/IframeWrapper.js.map +1 -0
- package/dist/editor/components/LoadingState.d.ts +14 -0
- package/dist/editor/components/LoadingState.d.ts.map +1 -0
- package/dist/editor/components/LoadingState.js +12 -0
- package/dist/editor/components/LoadingState.js.map +1 -0
- package/dist/editor/components/PreviewModal.d.ts +54 -0
- package/dist/editor/components/PreviewModal.d.ts.map +1 -0
- package/dist/editor/components/PreviewModal.js +298 -0
- package/dist/editor/components/PreviewModal.js.map +1 -0
- package/dist/editor/components/VersionHistory.d.ts +44 -0
- package/dist/editor/components/VersionHistory.d.ts.map +1 -0
- package/dist/editor/components/VersionHistory.js +308 -0
- package/dist/editor/components/VersionHistory.js.map +1 -0
- package/dist/editor/hooks/useUnsavedChanges.d.ts +27 -0
- package/dist/editor/hooks/useUnsavedChanges.d.ts.map +1 -0
- package/dist/editor/hooks/useUnsavedChanges.js +55 -0
- package/dist/editor/hooks/useUnsavedChanges.js.map +1 -0
- package/dist/editor/index.d.ts +16 -756
- package/dist/editor/index.d.ts.map +1 -0
- package/dist/editor/index.js +49 -4533
- package/dist/editor/index.js.map +1 -0
- package/dist/editor/plugins/index.d.ts +12 -0
- package/dist/editor/plugins/index.d.ts.map +1 -0
- package/dist/editor/plugins/index.js +12 -0
- package/dist/editor/plugins/index.js.map +1 -0
- package/dist/endpoints/index.d.ts +46 -0
- package/dist/endpoints/index.d.ts.map +1 -0
- package/dist/endpoints/index.js +204 -0
- package/dist/endpoints/index.js.map +1 -0
- package/dist/exports/client.d.ts +19 -0
- package/dist/exports/client.d.ts.map +1 -0
- package/dist/exports/client.js +21 -0
- package/dist/exports/client.js.map +1 -0
- package/dist/exports/rsc.d.ts +19 -0
- package/dist/exports/rsc.d.ts.map +1 -0
- package/dist/exports/rsc.js +19 -0
- package/dist/exports/rsc.js.map +1 -0
- package/dist/fields/AlignmentField.d.ts +36 -0
- package/dist/fields/AlignmentField.d.ts.map +1 -0
- package/dist/fields/AlignmentField.js +120 -0
- package/dist/fields/AlignmentField.js.map +1 -0
- package/dist/fields/AnimationField.d.ts +44 -0
- package/dist/fields/AnimationField.d.ts.map +1 -0
- package/dist/fields/AnimationField.js +329 -0
- package/dist/fields/AnimationField.js.map +1 -0
- package/dist/fields/BackgroundField.d.ts +40 -0
- package/dist/fields/BackgroundField.d.ts.map +1 -0
- package/dist/fields/BackgroundField.js +413 -0
- package/dist/fields/BackgroundField.js.map +1 -0
- package/dist/fields/BorderField.d.ts +29 -0
- package/dist/fields/BorderField.d.ts.map +1 -0
- package/dist/fields/BorderField.js +264 -0
- package/dist/fields/BorderField.js.map +1 -0
- package/dist/fields/ColorPickerField.d.ts +43 -0
- package/dist/fields/ColorPickerField.d.ts.map +1 -0
- package/dist/fields/ColorPickerField.js +285 -0
- package/dist/fields/ColorPickerField.js.map +1 -0
- package/dist/fields/DimensionsField.d.ts +43 -0
- package/dist/fields/DimensionsField.d.ts.map +1 -0
- package/dist/fields/DimensionsField.js +532 -0
- package/dist/fields/DimensionsField.js.map +1 -0
- package/dist/fields/FlexAlignmentField.d.ts +61 -0
- package/dist/fields/FlexAlignmentField.d.ts.map +1 -0
- package/dist/fields/FlexAlignmentField.js +166 -0
- package/dist/fields/FlexAlignmentField.js.map +1 -0
- package/dist/fields/FolderPickerField.d.ts +17 -0
- package/dist/fields/FolderPickerField.d.ts.map +1 -0
- package/dist/fields/FolderPickerField.js +282 -0
- package/dist/fields/FolderPickerField.js.map +1 -0
- package/dist/fields/GradientEditor.d.ts +22 -0
- package/dist/fields/GradientEditor.d.ts.map +1 -0
- package/dist/fields/GradientEditor.js +322 -0
- package/dist/fields/GradientEditor.js.map +1 -0
- package/dist/fields/LockedField.d.ts +67 -0
- package/dist/fields/LockedField.d.ts.map +1 -0
- package/dist/fields/LockedField.js +170 -0
- package/dist/fields/LockedField.js.map +1 -0
- package/dist/fields/MarginField.d.ts +31 -0
- package/dist/fields/MarginField.d.ts.map +1 -0
- package/dist/fields/MarginField.js +233 -0
- package/dist/fields/MarginField.js.map +1 -0
- package/dist/fields/MediaField.d.ts +33 -0
- package/dist/fields/MediaField.d.ts.map +1 -0
- package/dist/fields/MediaField.js +677 -0
- package/dist/fields/MediaField.js.map +1 -0
- package/dist/fields/PaddingField.d.ts +29 -0
- package/dist/fields/PaddingField.d.ts.map +1 -0
- package/dist/fields/PaddingField.js +232 -0
- package/dist/fields/PaddingField.js.map +1 -0
- package/dist/fields/PageSegmentField.d.ts +17 -0
- package/dist/fields/PageSegmentField.d.ts.map +1 -0
- package/dist/fields/PageSegmentField.js +92 -0
- package/dist/fields/PageSegmentField.js.map +1 -0
- package/dist/fields/ResetField.d.ts +27 -0
- package/dist/fields/ResetField.d.ts.map +1 -0
- package/dist/fields/ResetField.js +122 -0
- package/dist/fields/ResetField.js.map +1 -0
- package/dist/fields/ResponsiveField.d.ts +38 -0
- package/dist/fields/ResponsiveField.d.ts.map +1 -0
- package/dist/fields/ResponsiveField.js +275 -0
- package/dist/fields/ResponsiveField.js.map +1 -0
- package/dist/fields/ResponsiveVisibilityField.d.ts +34 -0
- package/dist/fields/ResponsiveVisibilityField.d.ts.map +1 -0
- package/dist/fields/ResponsiveVisibilityField.js +145 -0
- package/dist/fields/ResponsiveVisibilityField.js.map +1 -0
- package/dist/fields/SizeField.d.ts +54 -0
- package/dist/fields/SizeField.d.ts.map +1 -0
- package/dist/fields/SizeField.js +255 -0
- package/dist/fields/SizeField.js.map +1 -0
- package/dist/fields/SlugPreviewField.d.ts +16 -0
- package/dist/fields/SlugPreviewField.d.ts.map +1 -0
- package/dist/fields/SlugPreviewField.js +49 -0
- package/dist/fields/SlugPreviewField.js.map +1 -0
- package/dist/fields/TemplateField.d.ts +31 -0
- package/dist/fields/TemplateField.d.ts.map +1 -0
- package/dist/fields/TemplateField.js +428 -0
- package/dist/fields/TemplateField.js.map +1 -0
- package/dist/fields/TiptapField.d.ts +40 -0
- package/dist/fields/TiptapField.d.ts.map +1 -0
- package/dist/fields/TiptapField.js +857 -0
- package/dist/fields/TiptapField.js.map +1 -0
- package/dist/fields/TiptapModal.d.ts +10 -0
- package/dist/fields/TiptapModal.d.ts.map +1 -0
- package/dist/fields/TiptapModal.js +114 -0
- package/dist/fields/TiptapModal.js.map +1 -0
- package/dist/fields/TiptapModalField.d.ts +23 -0
- package/dist/fields/TiptapModalField.d.ts.map +1 -0
- package/dist/fields/TiptapModalField.js +55 -0
- package/dist/fields/TiptapModalField.js.map +1 -0
- package/dist/fields/TransformField.d.ts +31 -0
- package/dist/fields/TransformField.d.ts.map +1 -0
- package/dist/fields/TransformField.js +384 -0
- package/dist/fields/TransformField.js.map +1 -0
- package/dist/fields/VerticalAlignmentField.d.ts +35 -0
- package/dist/fields/VerticalAlignmentField.d.ts.map +1 -0
- package/dist/fields/VerticalAlignmentField.js +120 -0
- package/dist/fields/VerticalAlignmentField.js.map +1 -0
- package/dist/fields/WidthField.d.ts +28 -0
- package/dist/fields/WidthField.d.ts.map +1 -0
- package/dist/fields/WidthField.js +339 -0
- package/dist/fields/WidthField.js.map +1 -0
- package/dist/fields/index.d.ts +44 -559
- package/dist/fields/index.d.ts.map +1 -0
- package/dist/fields/index.js +91 -7685
- package/dist/fields/index.js.map +1 -0
- package/dist/fields/richtext-output.css +219 -0
- package/dist/{shared-DeNKN95N.d.mts → fields/shared.d.ts} +114 -133
- package/dist/fields/shared.d.ts.map +1 -0
- package/dist/fields/shared.js +1542 -0
- package/dist/fields/shared.js.map +1 -0
- package/dist/fields/{index.css → tiptap-styles.css} +75 -166
- package/dist/hooks/index.d.ts +8 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +8 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useResponsiveStyles.d.ts +51 -0
- package/dist/hooks/useResponsiveStyles.d.ts.map +1 -0
- package/dist/hooks/useResponsiveStyles.js +149 -0
- package/dist/hooks/useResponsiveStyles.js.map +1 -0
- package/dist/hooks/useScrollAnimation.d.ts +56 -0
- package/dist/hooks/useScrollAnimation.d.ts.map +1 -0
- package/dist/hooks/useScrollAnimation.js +116 -0
- package/dist/hooks/useScrollAnimation.js.map +1 -0
- package/dist/index.d.ts +66 -6
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +67 -568
- package/dist/index.js.map +1 -0
- package/dist/layouts/LayoutWrapper.d.ts +33 -0
- package/dist/layouts/LayoutWrapper.d.ts.map +1 -0
- package/dist/layouts/LayoutWrapper.js +112 -0
- package/dist/layouts/LayoutWrapper.js.map +1 -0
- package/dist/layouts/defaults.d.ts +40 -0
- package/dist/layouts/defaults.d.ts.map +1 -0
- package/dist/layouts/defaults.js +106 -0
- package/dist/layouts/defaults.js.map +1 -0
- package/dist/layouts/index.d.ts +27 -94
- package/dist/layouts/index.d.ts.map +1 -0
- package/dist/layouts/index.js +30 -393
- package/dist/layouts/index.js.map +1 -0
- package/dist/{types-D7D3rZ1J.d.ts → layouts/types.d.ts} +8 -11
- package/dist/layouts/types.d.ts.map +1 -0
- package/dist/layouts/types.js +7 -0
- package/dist/layouts/types.js.map +1 -0
- package/dist/layouts/utils.d.ts +42 -0
- package/dist/layouts/utils.d.ts.map +1 -0
- package/dist/layouts/utils.js +83 -0
- package/dist/layouts/utils.js.map +1 -0
- package/dist/plugin/collections/Pages.d.ts +8 -0
- package/dist/plugin/collections/Pages.d.ts.map +1 -0
- package/dist/plugin/collections/Pages.js +117 -0
- package/dist/plugin/collections/Pages.js.map +1 -0
- package/dist/plugin/fields/index.d.ts +153 -0
- package/dist/plugin/fields/index.d.ts.map +1 -0
- package/dist/plugin/fields/index.js +364 -0
- package/dist/plugin/fields/index.js.map +1 -0
- package/dist/plugin/fields/types.d.ts +108 -0
- package/dist/plugin/fields/types.d.ts.map +1 -0
- package/dist/plugin/fields/types.js +7 -0
- package/dist/plugin/fields/types.js.map +1 -0
- package/dist/plugin/index.d.ts +13 -255
- package/dist/plugin/index.d.ts.map +1 -0
- package/dist/plugin/index.js +276 -553
- package/dist/plugin/index.js.map +1 -0
- package/dist/render/HybridPageRenderer.d.ts +85 -0
- package/dist/render/HybridPageRenderer.d.ts.map +1 -0
- package/dist/render/HybridPageRenderer.js +29 -0
- package/dist/render/HybridPageRenderer.js.map +1 -0
- package/dist/render/PageRenderer.d.ts +51 -0
- package/dist/render/PageRenderer.d.ts.map +1 -0
- package/dist/render/PageRenderer.js +61 -0
- package/dist/render/PageRenderer.js.map +1 -0
- package/dist/render/PuckEditor.client.d.ts +66 -0
- package/dist/render/PuckEditor.client.d.ts.map +1 -0
- package/dist/render/PuckEditor.client.js +66 -0
- package/dist/render/PuckEditor.client.js.map +1 -0
- package/dist/render/index.d.ts +8 -106
- package/dist/render/index.d.ts.map +1 -0
- package/dist/render/index.js +10 -2162
- package/dist/render/index.js.map +1 -0
- package/dist/theme/context.d.ts +59 -0
- package/dist/theme/context.d.ts.map +1 -0
- package/dist/theme/context.js +73 -0
- package/dist/theme/context.js.map +1 -0
- package/dist/theme/defaults.d.ts +39 -0
- package/dist/theme/defaults.d.ts.map +1 -0
- package/dist/theme/defaults.js +72 -0
- package/dist/theme/defaults.js.map +1 -0
- package/dist/theme/example.d.ts +30 -0
- package/dist/theme/example.d.ts.map +1 -0
- package/dist/theme/example.js +89 -0
- package/dist/theme/example.js.map +1 -0
- package/dist/theme/index.d.ts +17 -140
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +34 -200
- package/dist/theme/index.js.map +1 -0
- package/dist/{types-_6MvjyKv.d.ts → theme/types.d.ts} +8 -9
- package/dist/theme/types.d.ts.map +1 -0
- package/dist/theme/types.js +9 -0
- package/dist/theme/types.js.map +1 -0
- package/dist/theme/utils.d.ts +30 -0
- package/dist/theme/utils.d.ts.map +1 -0
- package/dist/theme/utils.js +84 -0
- package/dist/theme/utils.js.map +1 -0
- package/dist/{index-CQu6SzDg.d.mts → types/index.d.ts} +120 -115
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +2 -0
- package/dist/types/index.js.map +1 -0
- package/dist/utils/index.d.ts +23 -257
- package/dist/utils/index.d.ts.map +1 -0
- package/dist/utils/index.js +56 -425
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/{index.d.mts → migration.d.ts} +16 -112
- package/dist/utils/migration.d.ts.map +1 -0
- package/dist/utils/migration.js +309 -0
- package/dist/utils/migration.js.map +1 -0
- package/dist/utils/validation.d.ts +89 -0
- package/dist/utils/validation.d.ts.map +1 -0
- package/dist/utils/validation.js +247 -0
- package/dist/utils/validation.js.map +1 -0
- package/dist/views/PuckConfigContext.d.ts +71 -0
- package/dist/views/PuckConfigContext.d.ts.map +1 -0
- package/dist/views/PuckConfigContext.js +45 -0
- package/dist/views/PuckConfigContext.js.map +1 -0
- package/dist/views/PuckEditorClient.d.ts +73 -0
- package/dist/views/PuckEditorClient.d.ts.map +1 -0
- package/dist/views/PuckEditorClient.js +130 -0
- package/dist/views/PuckEditorClient.js.map +1 -0
- package/dist/views/PuckEditorView.d.ts +19 -0
- package/dist/views/PuckEditorView.d.ts.map +1 -0
- package/dist/views/PuckEditorView.js +106 -0
- package/dist/views/PuckEditorView.js.map +1 -0
- package/dist/views/index.d.ts +10 -0
- package/dist/views/index.d.ts.map +1 -0
- package/dist/views/index.js +10 -0
- package/dist/views/index.js.map +1 -0
- package/package.json +50 -72
- package/dist/AccordionClient.d.mts +0 -24
- package/dist/AccordionClient.d.ts +0 -24
- package/dist/AccordionClient.js +0 -786
- package/dist/AccordionClient.mjs +0 -784
- package/dist/AnimatedWrapper.d.mts +0 -30
- package/dist/AnimatedWrapper.d.ts +0 -30
- package/dist/AnimatedWrapper.js +0 -379
- package/dist/AnimatedWrapper.mjs +0 -377
- package/dist/admin/client.d.mts +0 -108
- package/dist/admin/client.mjs +0 -173
- package/dist/admin/index.d.mts +0 -157
- package/dist/admin/index.mjs +0 -29
- package/dist/api/index.d.mts +0 -460
- package/dist/api/index.mjs +0 -578
- package/dist/components/index.css +0 -339
- package/dist/components/index.d.mts +0 -222
- package/dist/components/index.mjs +0 -9109
- package/dist/config/config.editor.css +0 -339
- package/dist/config/config.editor.d.mts +0 -153
- package/dist/config/config.editor.mjs +0 -9347
- package/dist/config/index.d.mts +0 -68
- package/dist/config/index.mjs +0 -2008
- package/dist/editor/index.d.mts +0 -784
- package/dist/editor/index.mjs +0 -4500
- package/dist/fields/index.d.mts +0 -600
- package/dist/fields/index.mjs +0 -7569
- package/dist/index-CoUQnyC3.d.ts +0 -327
- package/dist/index.d.mts +0 -6
- package/dist/index.mjs +0 -555
- package/dist/layouts/index.d.mts +0 -96
- package/dist/layouts/index.mjs +0 -378
- package/dist/plugin/index.d.mts +0 -289
- package/dist/plugin/index.mjs +0 -555
- package/dist/render/index.d.mts +0 -109
- package/dist/render/index.mjs +0 -2140
- package/dist/shared-DeNKN95N.d.ts +0 -546
- package/dist/theme/index.d.mts +0 -155
- package/dist/theme/index.mjs +0 -186
- package/dist/types-D7D3rZ1J.d.mts +0 -116
- package/dist/types-_6MvjyKv.d.mts +0 -104
- package/dist/utils/index.mjs +0 -412
- package/dist/utils-DaRs9t0J.d.mts +0 -85
- package/dist/utils-gAvt0Vhw.d.ts +0 -85
- package/examples/README.md +0 -247
- package/examples/api/puck/pages/[id]/route.ts +0 -64
- package/examples/api/puck/pages/[id]/versions/route.ts +0 -47
- package/examples/api/puck/pages/route.ts +0 -45
- package/examples/app/(frontend)/page.tsx +0 -94
- package/examples/app/(manage)/layout.tsx +0 -31
- package/examples/app/[...slug]/page.tsx +0 -101
- package/examples/app/pages/[id]/edit/page.tsx +0 -148
- package/examples/components/CustomBanner.tsx +0 -368
- package/examples/config/custom-config.ts +0 -223
- package/examples/config/payload.config.example.ts +0 -64
- package/examples/lib/puck-layouts.ts +0 -258
- package/examples/lib/puck-theme.ts +0 -94
- package/examples/styles/puck-theme.css +0 -171
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ResponsiveField - Generic wrapper for breakpoint-specific field overrides
|
|
3
|
+
*
|
|
4
|
+
* This component wraps any existing field to provide responsive overrides
|
|
5
|
+
* at different breakpoints (xs, sm, md, lg, xl). It uses sparse storage,
|
|
6
|
+
* only storing values for breakpoints that have explicit overrides.
|
|
7
|
+
*/
|
|
8
|
+
import React from 'react';
|
|
9
|
+
import type { CustomField } from '@measured/puck';
|
|
10
|
+
import type { ResponsiveValue } from './shared';
|
|
11
|
+
interface ResponsiveFieldProps<T> {
|
|
12
|
+
value: ResponsiveValue<T> | null;
|
|
13
|
+
onChange: (value: ResponsiveValue<T> | null) => void;
|
|
14
|
+
label?: string;
|
|
15
|
+
readOnly?: boolean;
|
|
16
|
+
/** Render function for the inner field */
|
|
17
|
+
renderInnerField: (props: {
|
|
18
|
+
value: T | null;
|
|
19
|
+
onChange: (v: T | null) => void;
|
|
20
|
+
readOnly?: boolean;
|
|
21
|
+
}) => React.ReactNode;
|
|
22
|
+
/** Default value for the xs breakpoint */
|
|
23
|
+
defaultValue?: T;
|
|
24
|
+
}
|
|
25
|
+
export declare const ResponsiveField: <T>(props: ResponsiveFieldProps<T>) => React.ReactElement;
|
|
26
|
+
interface CreateResponsiveFieldConfig<T> {
|
|
27
|
+
label?: string;
|
|
28
|
+
innerField: (config: {
|
|
29
|
+
label?: string;
|
|
30
|
+
}) => CustomField<T | null>;
|
|
31
|
+
defaultValue?: T;
|
|
32
|
+
}
|
|
33
|
+
/**
|
|
34
|
+
* Creates a responsive wrapper around any Puck custom field.
|
|
35
|
+
*/
|
|
36
|
+
export declare function createResponsiveField<T>(config: CreateResponsiveFieldConfig<T>): CustomField<ResponsiveValue<T> | null>;
|
|
37
|
+
export {};
|
|
38
|
+
//# sourceMappingURL=ResponsiveField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResponsiveField.d.ts","sourceRoot":"","sources":["../../src/fields/ResponsiveField.tsx"],"names":[],"mappings":"AAEA;;;;;;GAMG;AAEH,OAAO,KAA0D,MAAM,OAAO,CAAA;AAC9E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAQjD,OAAO,KAAK,EAAc,eAAe,EAAE,MAAM,UAAU,CAAA;AAO3D,UAAU,oBAAoB,CAAC,CAAC;IAC9B,KAAK,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI,CAAA;IAChC,QAAQ,EAAE,CAAC,KAAK,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI,KAAK,IAAI,CAAA;IACpD,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,0CAA0C;IAC1C,gBAAgB,EAAE,CAAC,KAAK,EAAE;QACxB,KAAK,EAAE,CAAC,GAAG,IAAI,CAAA;QACf,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,KAAK,IAAI,CAAA;QAC/B,QAAQ,CAAC,EAAE,OAAO,CAAA;KACnB,KAAK,KAAK,CAAC,SAAS,CAAA;IACrB,0CAA0C;IAC1C,YAAY,CAAC,EAAE,CAAC,CAAA;CACjB;AAyXD,eAAO,MAAM,eAAe,EAAiC,CAAC,CAAC,EAC7D,KAAK,EAAE,oBAAoB,CAAC,CAAC,CAAC,KAC3B,KAAK,CAAC,YAAY,CAAA;AAMvB,UAAU,2BAA2B,CAAC,CAAC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,UAAU,EAAE,CAAC,MAAM,EAAE;QAAE,KAAK,CAAC,EAAE,MAAM,CAAA;KAAE,KAAK,WAAW,CAAC,CAAC,GAAG,IAAI,CAAC,CAAA;IACjE,YAAY,CAAC,EAAE,CAAC,CAAA;CACjB;AAED;;GAEG;AACH,wBAAgB,qBAAqB,CAAC,CAAC,EACrC,MAAM,EAAE,2BAA2B,CAAC,CAAC,CAAC,GACrC,WAAW,CAAC,eAAe,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,CA6BxC"}
|
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
3
|
+
/**
|
|
4
|
+
* ResponsiveField - Generic wrapper for breakpoint-specific field overrides
|
|
5
|
+
*
|
|
6
|
+
* This component wraps any existing field to provide responsive overrides
|
|
7
|
+
* at different breakpoints (xs, sm, md, lg, xl). It uses sparse storage,
|
|
8
|
+
* only storing values for breakpoints that have explicit overrides.
|
|
9
|
+
*/
|
|
10
|
+
import { useState, useCallback, memo } from 'react';
|
|
11
|
+
import { Smartphone, Tablet, Laptop, Monitor, X, } from 'lucide-react';
|
|
12
|
+
import { BREAKPOINTS } from './shared';
|
|
13
|
+
// =============================================================================
|
|
14
|
+
// Breakpoint Icons
|
|
15
|
+
// =============================================================================
|
|
16
|
+
const BREAKPOINT_ICONS = {
|
|
17
|
+
xs: Smartphone,
|
|
18
|
+
sm: Smartphone,
|
|
19
|
+
md: Tablet,
|
|
20
|
+
lg: Laptop,
|
|
21
|
+
xl: Monitor,
|
|
22
|
+
};
|
|
23
|
+
// =============================================================================
|
|
24
|
+
// Styles
|
|
25
|
+
// =============================================================================
|
|
26
|
+
const styles = {
|
|
27
|
+
container: {
|
|
28
|
+
display: 'flex',
|
|
29
|
+
flexDirection: 'column',
|
|
30
|
+
gap: '12px',
|
|
31
|
+
},
|
|
32
|
+
header: {
|
|
33
|
+
display: 'flex',
|
|
34
|
+
alignItems: 'center',
|
|
35
|
+
justifyContent: 'space-between',
|
|
36
|
+
},
|
|
37
|
+
labelGroup: {
|
|
38
|
+
display: 'flex',
|
|
39
|
+
alignItems: 'center',
|
|
40
|
+
gap: '8px',
|
|
41
|
+
},
|
|
42
|
+
label: {
|
|
43
|
+
fontSize: '14px',
|
|
44
|
+
fontWeight: 500,
|
|
45
|
+
color: 'var(--theme-elevation-800)',
|
|
46
|
+
},
|
|
47
|
+
overrideBadge: {
|
|
48
|
+
fontSize: '12px',
|
|
49
|
+
color: 'var(--theme-elevation-500)',
|
|
50
|
+
backgroundColor: 'var(--theme-elevation-100)',
|
|
51
|
+
padding: '2px 6px',
|
|
52
|
+
borderRadius: '4px',
|
|
53
|
+
},
|
|
54
|
+
clearButton: {
|
|
55
|
+
display: 'flex',
|
|
56
|
+
alignItems: 'center',
|
|
57
|
+
justifyContent: 'center',
|
|
58
|
+
width: '24px',
|
|
59
|
+
height: '24px',
|
|
60
|
+
padding: 0,
|
|
61
|
+
border: 'none',
|
|
62
|
+
borderRadius: '4px',
|
|
63
|
+
backgroundColor: 'transparent',
|
|
64
|
+
color: 'var(--theme-elevation-500)',
|
|
65
|
+
cursor: 'pointer',
|
|
66
|
+
},
|
|
67
|
+
tabsContainer: {
|
|
68
|
+
display: 'flex',
|
|
69
|
+
gap: '4px',
|
|
70
|
+
padding: '4px',
|
|
71
|
+
backgroundColor: 'var(--theme-elevation-50)',
|
|
72
|
+
borderRadius: '8px',
|
|
73
|
+
},
|
|
74
|
+
tab: {
|
|
75
|
+
position: 'relative',
|
|
76
|
+
display: 'flex',
|
|
77
|
+
alignItems: 'center',
|
|
78
|
+
justifyContent: 'center',
|
|
79
|
+
gap: '4px',
|
|
80
|
+
padding: '6px 8px',
|
|
81
|
+
fontSize: '12px',
|
|
82
|
+
fontWeight: 500,
|
|
83
|
+
borderRadius: '6px',
|
|
84
|
+
border: 'none',
|
|
85
|
+
cursor: 'pointer',
|
|
86
|
+
transition: 'all 0.15s',
|
|
87
|
+
flex: 1,
|
|
88
|
+
backgroundColor: 'var(--theme-elevation-100)',
|
|
89
|
+
color: 'var(--theme-elevation-500)',
|
|
90
|
+
},
|
|
91
|
+
tabActive: {
|
|
92
|
+
position: 'relative',
|
|
93
|
+
display: 'flex',
|
|
94
|
+
alignItems: 'center',
|
|
95
|
+
justifyContent: 'center',
|
|
96
|
+
gap: '4px',
|
|
97
|
+
padding: '6px 8px',
|
|
98
|
+
fontSize: '12px',
|
|
99
|
+
fontWeight: 500,
|
|
100
|
+
borderRadius: '6px',
|
|
101
|
+
border: 'none',
|
|
102
|
+
cursor: 'pointer',
|
|
103
|
+
transition: 'all 0.15s',
|
|
104
|
+
flex: 1,
|
|
105
|
+
backgroundColor: 'var(--theme-elevation-800)',
|
|
106
|
+
color: 'var(--theme-bg)',
|
|
107
|
+
},
|
|
108
|
+
tabDisabled: {
|
|
109
|
+
opacity: 0.5,
|
|
110
|
+
cursor: 'not-allowed',
|
|
111
|
+
},
|
|
112
|
+
overrideIndicator: {
|
|
113
|
+
position: 'absolute',
|
|
114
|
+
top: '-2px',
|
|
115
|
+
right: '-2px',
|
|
116
|
+
width: '8px',
|
|
117
|
+
height: '8px',
|
|
118
|
+
borderRadius: '50%',
|
|
119
|
+
backgroundColor: 'var(--theme-elevation-800)',
|
|
120
|
+
},
|
|
121
|
+
infoRow: {
|
|
122
|
+
display: 'flex',
|
|
123
|
+
alignItems: 'center',
|
|
124
|
+
justifyContent: 'space-between',
|
|
125
|
+
fontSize: '12px',
|
|
126
|
+
color: 'var(--theme-elevation-500)',
|
|
127
|
+
},
|
|
128
|
+
clearOverrideButton: {
|
|
129
|
+
padding: '2px 8px',
|
|
130
|
+
fontSize: '12px',
|
|
131
|
+
border: 'none',
|
|
132
|
+
borderRadius: '4px',
|
|
133
|
+
backgroundColor: 'transparent',
|
|
134
|
+
color: 'var(--theme-elevation-500)',
|
|
135
|
+
cursor: 'pointer',
|
|
136
|
+
},
|
|
137
|
+
innerFieldContainer: {
|
|
138
|
+
padding: '12px',
|
|
139
|
+
border: '1px solid var(--theme-elevation-150)',
|
|
140
|
+
borderRadius: '6px',
|
|
141
|
+
},
|
|
142
|
+
};
|
|
143
|
+
function BreakpointTab({ breakpoint, label, minWidth, isActive, hasOverride, onClick, disabled, }) {
|
|
144
|
+
const Icon = BREAKPOINT_ICONS[breakpoint];
|
|
145
|
+
return (_jsxs("button", { type: "button", onClick: onClick, disabled: disabled, title: minWidth ? `${label} (${minWidth}px+)` : label, style: {
|
|
146
|
+
...(isActive ? styles.tabActive : styles.tab),
|
|
147
|
+
...(disabled ? styles.tabDisabled : {}),
|
|
148
|
+
}, children: [_jsx(Icon, { style: { width: '14px', height: '14px' } }), _jsx("span", { children: label }), hasOverride && !isActive && (_jsx("span", { style: styles.overrideIndicator }))] }));
|
|
149
|
+
}
|
|
150
|
+
// =============================================================================
|
|
151
|
+
// ResponsiveField Component
|
|
152
|
+
// =============================================================================
|
|
153
|
+
function ResponsiveFieldInner({ value, onChange, label, readOnly, renderInnerField, defaultValue, }) {
|
|
154
|
+
const [activeBreakpoint, setActiveBreakpoint] = useState('xs');
|
|
155
|
+
// Get the current value for the active breakpoint
|
|
156
|
+
const getCurrentValue = useCallback(() => {
|
|
157
|
+
if (!value)
|
|
158
|
+
return null;
|
|
159
|
+
if (activeBreakpoint === 'xs') {
|
|
160
|
+
return value.xs ?? defaultValue ?? null;
|
|
161
|
+
}
|
|
162
|
+
const override = value[activeBreakpoint];
|
|
163
|
+
if (override !== undefined) {
|
|
164
|
+
return override;
|
|
165
|
+
}
|
|
166
|
+
const breakpointOrder = ['xl', 'lg', 'md', 'sm', 'xs'];
|
|
167
|
+
const activeIndex = breakpointOrder.indexOf(activeBreakpoint);
|
|
168
|
+
for (let i = activeIndex + 1; i < breakpointOrder.length; i++) {
|
|
169
|
+
const bp = breakpointOrder[i];
|
|
170
|
+
const val = value[bp];
|
|
171
|
+
if (val !== undefined) {
|
|
172
|
+
return val;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
return defaultValue ?? null;
|
|
176
|
+
}, [value, activeBreakpoint, defaultValue]);
|
|
177
|
+
const hasOverride = useCallback((breakpoint) => {
|
|
178
|
+
if (!value)
|
|
179
|
+
return false;
|
|
180
|
+
if (breakpoint === 'xs')
|
|
181
|
+
return false;
|
|
182
|
+
return value[breakpoint] !== undefined;
|
|
183
|
+
}, [value]);
|
|
184
|
+
const getInheritanceSource = useCallback(() => {
|
|
185
|
+
if (!value || activeBreakpoint === 'xs')
|
|
186
|
+
return null;
|
|
187
|
+
if (value[activeBreakpoint] !== undefined)
|
|
188
|
+
return null;
|
|
189
|
+
const breakpointOrder = ['xl', 'lg', 'md', 'sm', 'xs'];
|
|
190
|
+
const activeIndex = breakpointOrder.indexOf(activeBreakpoint);
|
|
191
|
+
for (let i = activeIndex + 1; i < breakpointOrder.length; i++) {
|
|
192
|
+
const bp = breakpointOrder[i];
|
|
193
|
+
if (value[bp] !== undefined) {
|
|
194
|
+
return bp;
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
return null;
|
|
198
|
+
}, [value, activeBreakpoint]);
|
|
199
|
+
const handleInnerChange = useCallback((newValue) => {
|
|
200
|
+
if (activeBreakpoint === 'xs') {
|
|
201
|
+
if (newValue === null) {
|
|
202
|
+
onChange(null);
|
|
203
|
+
}
|
|
204
|
+
else {
|
|
205
|
+
onChange({ ...value, xs: newValue });
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
else {
|
|
209
|
+
if (newValue === null) {
|
|
210
|
+
if (!value)
|
|
211
|
+
return;
|
|
212
|
+
const newResponsive = { ...value };
|
|
213
|
+
delete newResponsive[activeBreakpoint];
|
|
214
|
+
onChange(newResponsive);
|
|
215
|
+
}
|
|
216
|
+
else {
|
|
217
|
+
const xs = value?.xs ?? defaultValue;
|
|
218
|
+
if (xs === undefined)
|
|
219
|
+
return;
|
|
220
|
+
onChange({
|
|
221
|
+
...value,
|
|
222
|
+
xs,
|
|
223
|
+
[activeBreakpoint]: newValue,
|
|
224
|
+
});
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
}, [value, onChange, activeBreakpoint, defaultValue]);
|
|
228
|
+
const handleClearOverride = useCallback(() => {
|
|
229
|
+
if (activeBreakpoint === 'xs' || !value)
|
|
230
|
+
return;
|
|
231
|
+
const newResponsive = { ...value };
|
|
232
|
+
delete newResponsive[activeBreakpoint];
|
|
233
|
+
onChange(newResponsive);
|
|
234
|
+
}, [value, onChange, activeBreakpoint]);
|
|
235
|
+
const handleClearAll = useCallback(() => {
|
|
236
|
+
onChange(null);
|
|
237
|
+
}, [onChange]);
|
|
238
|
+
const currentValue = getCurrentValue();
|
|
239
|
+
const isOverrideBreakpoint = activeBreakpoint !== 'xs';
|
|
240
|
+
const currentHasOverride = hasOverride(activeBreakpoint);
|
|
241
|
+
const inheritanceSource = getInheritanceSource();
|
|
242
|
+
const overrideCount = value
|
|
243
|
+
? ['sm', 'md', 'lg', 'xl'].filter((bp) => value[bp] !== undefined).length
|
|
244
|
+
: 0;
|
|
245
|
+
return (_jsxs("div", { className: "puck-field", style: styles.container, children: [_jsxs("div", { style: styles.header, children: [label && (_jsxs("div", { style: styles.labelGroup, children: [_jsx("label", { style: styles.label, children: label }), overrideCount > 0 && (_jsxs("span", { style: styles.overrideBadge, children: [overrideCount, " override", overrideCount !== 1 ? 's' : ''] }))] })), value && !readOnly && (_jsx("button", { type: "button", onClick: handleClearAll, style: styles.clearButton, title: "Clear all values", children: _jsx(X, { style: { width: '16px', height: '16px' } }) }))] }), _jsx("div", { style: styles.tabsContainer, children: BREAKPOINTS.map((bp) => (_jsx(BreakpointTab, { breakpoint: bp.key, label: bp.label, minWidth: bp.minWidth, isActive: activeBreakpoint === bp.key, hasOverride: hasOverride(bp.key), onClick: () => setActiveBreakpoint(bp.key), disabled: readOnly }, bp.key))) }), _jsxs("div", { style: styles.infoRow, children: [_jsx("span", { children: activeBreakpoint === 'xs' ? ('Extra small screens (0-639px)') : (_jsxs(_Fragment, { children: [BREAKPOINTS.find((bp) => bp.key === activeBreakpoint)?.minWidth, "px and up", !currentHasOverride && inheritanceSource && (_jsxs("span", { style: { color: 'var(--theme-elevation-400)' }, children: [" (inheriting from ", inheritanceSource.toUpperCase(), ")"] }))] })) }), isOverrideBreakpoint && currentHasOverride && !readOnly && (_jsx("button", { type: "button", onClick: handleClearOverride, style: styles.clearOverrideButton, children: "Clear override" }))] }), _jsx("div", { style: styles.innerFieldContainer, children: renderInnerField({
|
|
246
|
+
value: currentValue,
|
|
247
|
+
onChange: handleInnerChange,
|
|
248
|
+
readOnly,
|
|
249
|
+
}) })] }));
|
|
250
|
+
}
|
|
251
|
+
export const ResponsiveField = memo(ResponsiveFieldInner);
|
|
252
|
+
/**
|
|
253
|
+
* Creates a responsive wrapper around any Puck custom field.
|
|
254
|
+
*/
|
|
255
|
+
export function createResponsiveField(config) {
|
|
256
|
+
const innerFieldConfig = config.innerField({ label: undefined });
|
|
257
|
+
return {
|
|
258
|
+
type: 'custom',
|
|
259
|
+
label: config.label,
|
|
260
|
+
render: ({ value, onChange, readOnly }) => (_jsx(ResponsiveField, { value: value, onChange: onChange, label: config.label, readOnly: readOnly, defaultValue: config.defaultValue, renderInnerField: (props) => {
|
|
261
|
+
if (innerFieldConfig.type === 'custom' && innerFieldConfig.render) {
|
|
262
|
+
return innerFieldConfig.render({
|
|
263
|
+
field: innerFieldConfig,
|
|
264
|
+
value: props.value,
|
|
265
|
+
onChange: props.onChange,
|
|
266
|
+
readOnly: props.readOnly,
|
|
267
|
+
name: 'responsive-inner',
|
|
268
|
+
id: 'responsive-inner',
|
|
269
|
+
});
|
|
270
|
+
}
|
|
271
|
+
return null;
|
|
272
|
+
} })),
|
|
273
|
+
};
|
|
274
|
+
}
|
|
275
|
+
//# sourceMappingURL=ResponsiveField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResponsiveField.js","sourceRoot":"","sources":["../../src/fields/ResponsiveField.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ResponsiveVisibilityField - Show/hide elements at different breakpoints
|
|
3
|
+
*
|
|
4
|
+
* Provides a compact visual interface for toggling element visibility
|
|
5
|
+
* at each breakpoint (xs, sm, md, lg, xl). Simple independent toggles
|
|
6
|
+
* like Elementor/Divi - each breakpoint is just on or off.
|
|
7
|
+
*/
|
|
8
|
+
import React from 'react';
|
|
9
|
+
import type { CustomField } from '@measured/puck';
|
|
10
|
+
import type { VisibilityValue } from './shared';
|
|
11
|
+
interface ResponsiveVisibilityFieldProps {
|
|
12
|
+
value: VisibilityValue | null;
|
|
13
|
+
onChange: (value: VisibilityValue | null) => void;
|
|
14
|
+
label?: string;
|
|
15
|
+
readOnly?: boolean;
|
|
16
|
+
}
|
|
17
|
+
declare function ResponsiveVisibilityFieldInner({ value, onChange, label, readOnly, }: ResponsiveVisibilityFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
export declare const ResponsiveVisibilityField: React.MemoExoticComponent<typeof ResponsiveVisibilityFieldInner>;
|
|
19
|
+
interface CreateResponsiveVisibilityFieldConfig {
|
|
20
|
+
label?: string;
|
|
21
|
+
}
|
|
22
|
+
/**
|
|
23
|
+
* Creates a Puck custom field for responsive visibility control.
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```ts
|
|
27
|
+
* fields: {
|
|
28
|
+
* visibility: createResponsiveVisibilityField({ label: 'Visibility' }),
|
|
29
|
+
* }
|
|
30
|
+
* ```
|
|
31
|
+
*/
|
|
32
|
+
export declare function createResponsiveVisibilityField(config?: CreateResponsiveVisibilityFieldConfig): CustomField<VisibilityValue | null>;
|
|
33
|
+
export {};
|
|
34
|
+
//# sourceMappingURL=ResponsiveVisibilityField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResponsiveVisibilityField.d.ts","sourceRoot":"","sources":["../../src/fields/ResponsiveVisibilityField.tsx"],"names":[],"mappings":"AAEA;;;;;;GAMG;AAEH,OAAO,KAAgD,MAAM,OAAO,CAAA;AACpE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AASjD,OAAO,KAAK,EAAc,eAAe,EAAE,MAAM,UAAU,CAAA;AAO3D,UAAU,8BAA8B;IACtC,KAAK,EAAE,eAAe,GAAG,IAAI,CAAA;IAC7B,QAAQ,EAAE,CAAC,KAAK,EAAE,eAAe,GAAG,IAAI,KAAK,IAAI,CAAA;IACjD,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AA6ID,iBAAS,8BAA8B,CAAC,EACtC,KAAK,EACL,QAAQ,EACR,KAAK,EACL,QAAQ,GACT,EAAE,8BAA8B,2CA+DhC;AAED,eAAO,MAAM,yBAAyB,kEAAuC,CAAA;AAM7E,UAAU,qCAAqC;IAC7C,KAAK,CAAC,EAAE,MAAM,CAAA;CACf;AAED;;;;;;;;;GASG;AACH,wBAAgB,+BAA+B,CAC7C,MAAM,GAAE,qCAA0C,GACjD,WAAW,CAAC,eAAe,GAAG,IAAI,CAAC,CAarC"}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
3
|
+
/**
|
|
4
|
+
* ResponsiveVisibilityField - Show/hide elements at different breakpoints
|
|
5
|
+
*
|
|
6
|
+
* Provides a compact visual interface for toggling element visibility
|
|
7
|
+
* at each breakpoint (xs, sm, md, lg, xl). Simple independent toggles
|
|
8
|
+
* like Elementor/Divi - each breakpoint is just on or off.
|
|
9
|
+
*/
|
|
10
|
+
import { useCallback, memo } from 'react';
|
|
11
|
+
import { Smartphone, Tablet, Laptop, Monitor, Eye, EyeOff, } from 'lucide-react';
|
|
12
|
+
import { BREAKPOINTS, DEFAULT_VISIBILITY } from './shared';
|
|
13
|
+
// =============================================================================
|
|
14
|
+
// Breakpoint Icons
|
|
15
|
+
// =============================================================================
|
|
16
|
+
const BREAKPOINT_ICONS = {
|
|
17
|
+
xs: Smartphone,
|
|
18
|
+
sm: Smartphone,
|
|
19
|
+
md: Tablet,
|
|
20
|
+
lg: Laptop,
|
|
21
|
+
xl: Monitor,
|
|
22
|
+
};
|
|
23
|
+
// =============================================================================
|
|
24
|
+
// Styles
|
|
25
|
+
// =============================================================================
|
|
26
|
+
const styles = {
|
|
27
|
+
container: {
|
|
28
|
+
display: 'flex',
|
|
29
|
+
flexDirection: 'column',
|
|
30
|
+
gap: '8px',
|
|
31
|
+
},
|
|
32
|
+
header: {
|
|
33
|
+
display: 'flex',
|
|
34
|
+
alignItems: 'center',
|
|
35
|
+
justifyContent: 'space-between',
|
|
36
|
+
},
|
|
37
|
+
label: {
|
|
38
|
+
fontSize: '14px',
|
|
39
|
+
fontWeight: 500,
|
|
40
|
+
color: 'var(--theme-elevation-800)',
|
|
41
|
+
},
|
|
42
|
+
warningBadge: {
|
|
43
|
+
fontSize: '12px',
|
|
44
|
+
color: 'var(--theme-warning-500)',
|
|
45
|
+
display: 'flex',
|
|
46
|
+
alignItems: 'center',
|
|
47
|
+
gap: '4px',
|
|
48
|
+
},
|
|
49
|
+
toggleGrid: {
|
|
50
|
+
display: 'flex',
|
|
51
|
+
gap: '4px',
|
|
52
|
+
},
|
|
53
|
+
toggleButton: {
|
|
54
|
+
position: 'relative',
|
|
55
|
+
display: 'flex',
|
|
56
|
+
flexDirection: 'column',
|
|
57
|
+
alignItems: 'center',
|
|
58
|
+
justifyContent: 'center',
|
|
59
|
+
gap: '2px',
|
|
60
|
+
padding: '8px',
|
|
61
|
+
borderRadius: '6px',
|
|
62
|
+
flex: 1,
|
|
63
|
+
minWidth: '52px',
|
|
64
|
+
cursor: 'pointer',
|
|
65
|
+
transition: 'all 0.15s',
|
|
66
|
+
border: '1px solid',
|
|
67
|
+
},
|
|
68
|
+
toggleVisible: {
|
|
69
|
+
backgroundColor: 'rgba(16, 185, 129, 0.15)',
|
|
70
|
+
color: 'rgb(16, 185, 129)',
|
|
71
|
+
borderColor: 'rgba(16, 185, 129, 0.4)',
|
|
72
|
+
},
|
|
73
|
+
toggleHidden: {
|
|
74
|
+
backgroundColor: 'rgba(239, 68, 68, 0.15)',
|
|
75
|
+
color: 'rgb(239, 68, 68)',
|
|
76
|
+
borderColor: 'rgba(239, 68, 68, 0.4)',
|
|
77
|
+
},
|
|
78
|
+
toggleDisabled: {
|
|
79
|
+
opacity: 0.5,
|
|
80
|
+
cursor: 'not-allowed',
|
|
81
|
+
},
|
|
82
|
+
toggleLabel: {
|
|
83
|
+
fontSize: '10px',
|
|
84
|
+
fontWeight: 500,
|
|
85
|
+
},
|
|
86
|
+
toggleIcon: {
|
|
87
|
+
position: 'absolute',
|
|
88
|
+
top: '4px',
|
|
89
|
+
right: '4px',
|
|
90
|
+
},
|
|
91
|
+
helpText: {
|
|
92
|
+
fontSize: '12px',
|
|
93
|
+
color: 'var(--theme-elevation-500)',
|
|
94
|
+
},
|
|
95
|
+
};
|
|
96
|
+
function VisibilityToggle({ breakpoint, label, minWidth, isVisible, onClick, disabled, }) {
|
|
97
|
+
const DeviceIcon = BREAKPOINT_ICONS[breakpoint];
|
|
98
|
+
return (_jsxs("button", { type: "button", onClick: onClick, disabled: disabled, title: `${label}${minWidth ? ` (${minWidth}px+)` : ''}: ${isVisible ? 'Visible' : 'Hidden'}`, style: {
|
|
99
|
+
...styles.toggleButton,
|
|
100
|
+
...(isVisible ? styles.toggleVisible : styles.toggleHidden),
|
|
101
|
+
...(disabled ? styles.toggleDisabled : {}),
|
|
102
|
+
}, children: [_jsx(DeviceIcon, { style: { width: '16px', height: '16px' } }), _jsx("span", { style: styles.toggleLabel, children: label }), _jsx("div", { style: styles.toggleIcon, children: isVisible ? (_jsx(Eye, { style: { width: '12px', height: '12px' } })) : (_jsx(EyeOff, { style: { width: '12px', height: '12px' } })) })] }));
|
|
103
|
+
}
|
|
104
|
+
// =============================================================================
|
|
105
|
+
// ResponsiveVisibilityField Component
|
|
106
|
+
// =============================================================================
|
|
107
|
+
function ResponsiveVisibilityFieldInner({ value, onChange, label, readOnly, }) {
|
|
108
|
+
// Get visibility for a breakpoint (simple lookup, no cascade)
|
|
109
|
+
const getVisibility = useCallback((breakpoint) => {
|
|
110
|
+
const val = value ?? DEFAULT_VISIBILITY;
|
|
111
|
+
// All breakpoints have explicit values, default to true if undefined
|
|
112
|
+
return val[breakpoint] ?? true;
|
|
113
|
+
}, [value]);
|
|
114
|
+
// Toggle visibility for a breakpoint (simple toggle, no cascade)
|
|
115
|
+
const toggleVisibility = useCallback((breakpoint) => {
|
|
116
|
+
const currentVisible = getVisibility(breakpoint);
|
|
117
|
+
const newValue = {
|
|
118
|
+
...(value ?? DEFAULT_VISIBILITY),
|
|
119
|
+
[breakpoint]: !currentVisible,
|
|
120
|
+
};
|
|
121
|
+
onChange(newValue);
|
|
122
|
+
}, [value, onChange, getVisibility]);
|
|
123
|
+
// Check if any breakpoint is hidden
|
|
124
|
+
const hasHiddenBreakpoints = BREAKPOINTS.some((bp) => !getVisibility(bp.key));
|
|
125
|
+
return (_jsxs("div", { className: "puck-field", style: styles.container, children: [_jsxs("div", { style: styles.header, children: [label && (_jsx("label", { style: styles.label, children: label })), hasHiddenBreakpoints && (_jsxs("span", { style: styles.warningBadge, children: [_jsx(EyeOff, { style: { width: '12px', height: '12px' } }), "Partially hidden"] }))] }), _jsx("div", { style: styles.toggleGrid, children: BREAKPOINTS.map((bp) => (_jsx(VisibilityToggle, { breakpoint: bp.key, label: bp.label, minWidth: bp.minWidth, isVisible: getVisibility(bp.key), onClick: () => toggleVisibility(bp.key), disabled: readOnly }, bp.key))) }), _jsx("p", { style: styles.helpText, children: "Toggle visibility per screen size. Each breakpoint is independent." })] }));
|
|
126
|
+
}
|
|
127
|
+
export const ResponsiveVisibilityField = memo(ResponsiveVisibilityFieldInner);
|
|
128
|
+
/**
|
|
129
|
+
* Creates a Puck custom field for responsive visibility control.
|
|
130
|
+
*
|
|
131
|
+
* @example
|
|
132
|
+
* ```ts
|
|
133
|
+
* fields: {
|
|
134
|
+
* visibility: createResponsiveVisibilityField({ label: 'Visibility' }),
|
|
135
|
+
* }
|
|
136
|
+
* ```
|
|
137
|
+
*/
|
|
138
|
+
export function createResponsiveVisibilityField(config = {}) {
|
|
139
|
+
return {
|
|
140
|
+
type: 'custom',
|
|
141
|
+
label: config.label,
|
|
142
|
+
render: ({ value, onChange, readOnly }) => (_jsx(ResponsiveVisibilityField, { value: value, onChange: onChange, label: config.label, readOnly: readOnly })),
|
|
143
|
+
};
|
|
144
|
+
}
|
|
145
|
+
//# sourceMappingURL=ResponsiveVisibilityField.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ResponsiveVisibilityField.js","sourceRoot":"","sources":["../../src/fields/ResponsiveVisibilityField.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAEZ;;;;;;GAMG;AAEH,OAAc,EAAE,WAAW,EAAE,IAAI,EAAsB,MAAM,OAAO,CAAA;AAEpE,OAAO,EACL,UAAU,EACV,MAAM,EACN,MAAM,EACN,OAAO,EACP,GAAG,EACH,MAAM,GACP,MAAM,cAAc,CAAA;AAErB,OAAO,EAAE,WAAW,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAA;AAa1D,gFAAgF;AAChF,mBAAmB;AACnB,gFAAgF;AAEhF,MAAM,gBAAgB,GAA2F;IAC/G,EAAE,EAAE,UAAU;IACd,EAAE,EAAE,UAAU;IACd,EAAE,EAAE,MAAM;IACV,EAAE,EAAE,MAAM;IACV,EAAE,EAAE,OAAO;CACZ,CAAA;AAED,gFAAgF;AAChF,SAAS;AACT,gFAAgF;AAEhF,MAAM,MAAM,GAAG;IACb,SAAS,EAAE;QACT,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,GAAG,EAAE,KAAK;KACM;IAClB,MAAM,EAAE;QACN,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,eAAe;KACf;IAClB,KAAK,EAAE;QACL,QAAQ,EAAE,MAAM;QAChB,UAAU,EAAE,GAAG;QACf,KAAK,EAAE,4BAA4B;KACnB;IAClB,YAAY,EAAE;QACZ,QAAQ,EAAE,MAAM;QAChB,KAAK,EAAE,0BAA0B;QACjC,OAAO,EAAE,MAAM;QACf,UAAU,EAAE,QAAQ;QACpB,GAAG,EAAE,KAAK;KACM;IAClB,UAAU,EAAE;QACV,OAAO,EAAE,MAAM;QACf,GAAG,EAAE,KAAK;KACM;IAClB,YAAY,EAAE;QACZ,QAAQ,EAAE,UAAU;QACpB,OAAO,EAAE,MAAM;QACf,aAAa,EAAE,QAAQ;QACvB,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,GAAG,EAAE,KAAK;QACV,OAAO,EAAE,KAAK;QACd,YAAY,EAAE,KAAK;QACnB,IAAI,EAAE,CAAC;QACP,QAAQ,EAAE,MAAM;QAChB,MAAM,EAAE,SAAS;QACjB,UAAU,EAAE,WAAW;QACvB,MAAM,EAAE,WAAW;KACH;IAClB,aAAa,EAAE;QACb,eAAe,EAAE,0BAA0B;QAC3C,KAAK,EAAE,mBAAmB;QAC1B,WAAW,EAAE,yBAAyB;KACtB;IAClB,YAAY,EAAE;QACZ,eAAe,EAAE,yBAAyB;QAC1C,KAAK,EAAE,kBAAkB;QACzB,WAAW,EAAE,wBAAwB;KACrB;IAClB,cAAc,EAAE;QACd,OAAO,EAAE,GAAG;QACZ,MAAM,EAAE,aAAa;KACL;IAClB,WAAW,EAAE;QACX,QAAQ,EAAE,MAAM;QAChB,UAAU,EAAE,GAAG;KACC;IAClB,UAAU,EAAE;QACV,QAAQ,EAAE,UAAU;QACpB,GAAG,EAAE,KAAK;QACV,KAAK,EAAE,KAAK;KACI;IAClB,QAAQ,EAAE;QACR,QAAQ,EAAE,MAAM;QAChB,KAAK,EAAE,4BAA4B;KACnB;CACnB,CAAA;AAeD,SAAS,gBAAgB,CAAC,EACxB,UAAU,EACV,KAAK,EACL,QAAQ,EACR,SAAS,EACT,OAAO,EACP,QAAQ,GACc;IACtB,MAAM,UAAU,GAAG,gBAAgB,CAAC,UAAU,CAAC,CAAA;IAE/C,OAAO,CACL,kBACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,GAAG,KAAK,GAAG,QAAQ,CAAC,CAAC,CAAC,KAAK,QAAQ,MAAM,CAAC,CAAC,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,EAAE,EAC5F,KAAK,EAAE;YACL,GAAG,MAAM,CAAC,YAAY;YACtB,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,aAAa,CAAC,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC;YAC3D,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,cAAc,CAAC,CAAC,CAAC,EAAE,CAAC;SAC3C,aAED,KAAC,UAAU,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAI,EACxD,eAAM,KAAK,EAAE,MAAM,CAAC,WAAW,YAAG,KAAK,GAAQ,EAC/C,cAAK,KAAK,EAAE,MAAM,CAAC,UAA2B,YAC3C,SAAS,CAAC,CAAC,CAAC,CACX,KAAC,GAAG,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAI,CAClD,CAAC,CAAC,CAAC,CACF,KAAC,MAAM,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAI,CACrD,GACG,IACC,CACV,CAAA;AACH,CAAC;AAED,gFAAgF;AAChF,sCAAsC;AACtC,gFAAgF;AAEhF,SAAS,8BAA8B,CAAC,EACtC,KAAK,EACL,QAAQ,EACR,KAAK,EACL,QAAQ,GACuB;IAC/B,8DAA8D;IAC9D,MAAM,aAAa,GAAG,WAAW,CAC/B,CAAC,UAAsB,EAAW,EAAE;QAClC,MAAM,GAAG,GAAG,KAAK,IAAI,kBAAkB,CAAA;QACvC,qEAAqE;QACrE,OAAO,GAAG,CAAC,UAAU,CAAC,IAAI,IAAI,CAAA;IAChC,CAAC,EACD,CAAC,KAAK,CAAC,CACR,CAAA;IAED,iEAAiE;IACjE,MAAM,gBAAgB,GAAG,WAAW,CAClC,CAAC,UAAsB,EAAE,EAAE;QACzB,MAAM,cAAc,GAAG,aAAa,CAAC,UAAU,CAAC,CAAA;QAChD,MAAM,QAAQ,GAAoB;YAChC,GAAG,CAAC,KAAK,IAAI,kBAAkB,CAAC;YAChC,CAAC,UAAU,CAAC,EAAE,CAAC,cAAc;SAC9B,CAAA;QACD,QAAQ,CAAC,QAAQ,CAAC,CAAA;IACpB,CAAC,EACD,CAAC,KAAK,EAAE,QAAQ,EAAE,aAAa,CAAC,CACjC,CAAA;IAED,oCAAoC;IACpC,MAAM,oBAAoB,GAAG,WAAW,CAAC,IAAI,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,aAAa,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,CAAA;IAE7E,OAAO,CACL,eAAK,SAAS,EAAC,YAAY,EAAC,KAAK,EAAE,MAAM,CAAC,SAAS,aAEjD,eAAK,KAAK,EAAE,MAAM,CAAC,MAAM,aACtB,KAAK,IAAI,CACR,gBAAO,KAAK,EAAE,MAAM,CAAC,KAAK,YAAG,KAAK,GAAS,CAC5C,EACA,oBAAoB,IAAI,CACvB,gBAAM,KAAK,EAAE,MAAM,CAAC,YAAY,aAC9B,KAAC,MAAM,IAAC,KAAK,EAAE,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAI,wBAE/C,CACR,IACG,EAGN,cAAK,KAAK,EAAE,MAAM,CAAC,UAAU,YAC1B,WAAW,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CACvB,KAAC,gBAAgB,IAEf,UAAU,EAAE,EAAE,CAAC,GAAG,EAClB,KAAK,EAAE,EAAE,CAAC,KAAK,EACf,QAAQ,EAAE,EAAE,CAAC,QAAQ,EACrB,SAAS,EAAE,aAAa,CAAC,EAAE,CAAC,GAAG,CAAC,EAChC,OAAO,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,EAAE,CAAC,GAAG,CAAC,EACvC,QAAQ,EAAE,QAAQ,IANb,EAAE,CAAC,GAAG,CAOX,CACH,CAAC,GACE,EAGN,YAAG,KAAK,EAAE,MAAM,CAAC,QAAQ,mFAErB,IACA,CACP,CAAA;AACH,CAAC;AAED,MAAM,CAAC,MAAM,yBAAyB,GAAG,IAAI,CAAC,8BAA8B,CAAC,CAAA;AAU7E;;;;;;;;;GASG;AACH,MAAM,UAAU,+BAA+B,CAC7C,SAAgD,EAAE;IAElD,OAAO;QACL,IAAI,EAAE,QAAQ;QACd,KAAK,EAAE,MAAM,CAAC,KAAK;QACnB,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC,CACzC,KAAC,yBAAyB,IACxB,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,MAAM,CAAC,KAAK,EACnB,QAAQ,EAAE,QAAQ,GAClB,CACH;KACF,CAAA;AACH,CAAC"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SizeField - Custom Puck field for button/element sizing
|
|
3
|
+
*
|
|
4
|
+
* Provides preset size options (sm, default, lg) with a "custom" mode
|
|
5
|
+
* that reveals detailed controls for height, padding, and font size.
|
|
6
|
+
*/
|
|
7
|
+
import React from 'react';
|
|
8
|
+
import type { CustomField } from '@measured/puck';
|
|
9
|
+
export type SizeMode = 'sm' | 'default' | 'lg' | 'custom';
|
|
10
|
+
export type SizeUnit = 'px' | 'rem';
|
|
11
|
+
export interface SizeValue {
|
|
12
|
+
mode: SizeMode;
|
|
13
|
+
/** Height in units (only used when mode === 'custom') */
|
|
14
|
+
height?: number;
|
|
15
|
+
/** Horizontal padding in units (only used when mode === 'custom') */
|
|
16
|
+
paddingX?: number;
|
|
17
|
+
/** Vertical padding in units (only used when mode === 'custom') */
|
|
18
|
+
paddingY?: number;
|
|
19
|
+
/** Font size in units (only used when mode === 'custom') */
|
|
20
|
+
fontSize?: number;
|
|
21
|
+
/** Unit for all values */
|
|
22
|
+
unit?: SizeUnit;
|
|
23
|
+
}
|
|
24
|
+
interface SizeFieldProps {
|
|
25
|
+
value: SizeValue | null;
|
|
26
|
+
onChange: (value: SizeValue | null) => void;
|
|
27
|
+
label?: string;
|
|
28
|
+
readOnly?: boolean;
|
|
29
|
+
/** Show height input (default: true) */
|
|
30
|
+
showHeight?: boolean;
|
|
31
|
+
/** Show font size input (default: true) */
|
|
32
|
+
showFontSize?: boolean;
|
|
33
|
+
}
|
|
34
|
+
declare function SizeFieldInner({ value, onChange, label, readOnly, showHeight, showFontSize, }: SizeFieldProps): import("react/jsx-runtime").JSX.Element;
|
|
35
|
+
export declare const SizeField: React.MemoExoticComponent<typeof SizeFieldInner>;
|
|
36
|
+
/**
|
|
37
|
+
* Convert SizeValue to CSS properties object
|
|
38
|
+
*/
|
|
39
|
+
export declare function sizeValueToCSS(size: SizeValue | null | undefined): React.CSSProperties | undefined;
|
|
40
|
+
/**
|
|
41
|
+
* Get Tailwind classes for preset size modes
|
|
42
|
+
*/
|
|
43
|
+
export declare function getSizeClasses(size: SizeValue | null | undefined, sizeMap: Record<string, string>): string;
|
|
44
|
+
interface CreateSizeFieldConfig {
|
|
45
|
+
label?: string;
|
|
46
|
+
showHeight?: boolean;
|
|
47
|
+
showFontSize?: boolean;
|
|
48
|
+
}
|
|
49
|
+
/**
|
|
50
|
+
* Creates a Puck field configuration for size control
|
|
51
|
+
*/
|
|
52
|
+
export declare function createSizeField(config?: CreateSizeFieldConfig): CustomField<SizeValue | null>;
|
|
53
|
+
export {};
|
|
54
|
+
//# sourceMappingURL=SizeField.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SizeField.d.ts","sourceRoot":"","sources":["../../src/fields/SizeField.tsx"],"names":[],"mappings":"AAEA;;;;;GAKG;AAEH,OAAO,KAAgD,MAAM,OAAO,CAAA;AACpE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAA;AAOjD,MAAM,MAAM,QAAQ,GAAG,IAAI,GAAG,SAAS,GAAG,IAAI,GAAG,QAAQ,CAAA;AACzD,MAAM,MAAM,QAAQ,GAAG,IAAI,GAAG,KAAK,CAAA;AAEnC,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,QAAQ,CAAA;IACd,yDAAyD;IACzD,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,qEAAqE;IACrE,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,mEAAmE;IACnE,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,4DAA4D;IAC5D,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,0BAA0B;IAC1B,IAAI,CAAC,EAAE,QAAQ,CAAA;CAChB;AAED,UAAU,cAAc;IACtB,KAAK,EAAE,SAAS,GAAG,IAAI,CAAA;IACvB,QAAQ,EAAE,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,KAAK,IAAI,CAAA;IAC3C,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,wCAAwC;IACxC,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,2CAA2C;IAC3C,YAAY,CAAC,EAAE,OAAO,CAAA;CACvB;AAqKD,iBAAS,cAAc,CAAC,EACtB,KAAK,EACL,QAAQ,EACR,KAAc,EACd,QAAQ,EACR,UAAiB,EACjB,YAAmB,GACpB,EAAE,cAAc,2CAuKhB;AAED,eAAO,MAAM,SAAS,kDAAuB,CAAA;AAM7C;;GAEG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,GAAG,SAAS,GAAG,KAAK,CAAC,aAAa,GAAG,SAAS,CAqBlG;AAED;;GAEG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,GAAG,SAAS,EAAE,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,MAAM,CAI1G;AAMD,UAAU,qBAAqB;IAC7B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,YAAY,CAAC,EAAE,OAAO,CAAA;CACvB;AAED;;GAEG;AACH,wBAAgB,eAAe,CAC7B,MAAM,GAAE,qBAA0B,GACjC,WAAW,CAAC,SAAS,GAAG,IAAI,CAAC,CAe/B"}
|