@wordpress/block-editor 15.19.1-next.v.202605131006.0 → 15.20.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/CHANGELOG.md +15 -1
- package/build/components/block-card/index.cjs +51 -41
- package/build/components/block-card/index.cjs.map +3 -3
- package/build/components/block-heading-level-dropdown/heading-level-icon.cjs.map +3 -3
- package/build/components/block-icon/index.cjs +7 -1
- package/build/components/block-icon/index.cjs.map +3 -3
- package/build/components/block-inspector/index.cjs +156 -11
- package/build/components/block-inspector/index.cjs.map +3 -3
- package/build/components/block-inspector/inspector-pre-tabs-slot-fill.cjs +38 -0
- package/build/components/block-inspector/inspector-pre-tabs-slot-fill.cjs.map +7 -0
- package/build/components/block-list/use-block-props/index.cjs +1 -1
- package/build/components/block-list/use-block-props/index.cjs.map +2 -2
- package/build/components/block-list/use-block-props/use-focus-handler.cjs +3 -4
- package/build/components/block-list/use-block-props/use-focus-handler.cjs.map +3 -3
- package/build/components/block-list/use-block-props/use-is-hovered.cjs +24 -14
- package/build/components/block-list/use-block-props/use-is-hovered.cjs.map +3 -3
- package/build/components/block-lock/modal.cjs.map +3 -3
- package/build/components/block-patterns-list/index.cjs +13 -2
- package/build/components/block-patterns-list/index.cjs.map +2 -2
- package/build/components/block-popover/index.cjs +13 -3
- package/build/components/block-popover/index.cjs.map +2 -2
- package/build/components/block-toolbar/switch-section-style.cjs.map +3 -3
- package/build/components/block-visibility/modal.cjs.map +3 -3
- package/build/components/block-visibility/viewport-visibility-info.cjs.map +3 -3
- package/build/components/colors-gradients/control.cjs +7 -4
- package/build/components/colors-gradients/control.cjs.map +2 -2
- package/build/components/global-styles/advanced-panel.cjs +24 -22
- package/build/components/global-styles/advanced-panel.cjs.map +3 -3
- package/build/components/global-styles/color-panel.cjs +95 -58
- package/build/components/global-styles/color-panel.cjs.map +2 -2
- package/build/components/global-styles/dimensions-panel.cjs +11 -5
- package/build/components/global-styles/dimensions-panel.cjs.map +2 -2
- package/build/components/global-styles/index.cjs +3 -0
- package/build/components/global-styles/index.cjs.map +2 -2
- package/build/components/global-styles/shadow-panel-components.cjs +38 -26
- package/build/components/global-styles/shadow-panel-components.cjs.map +2 -2
- package/build/components/global-styles/state-control-badges.cjs +69 -0
- package/build/components/global-styles/state-control-badges.cjs.map +7 -0
- package/build/components/global-styles/state-control.cjs +54 -63
- package/build/components/global-styles/state-control.cjs.map +3 -3
- package/build/components/iframe/index.cjs +0 -3
- package/build/components/iframe/index.cjs.map +2 -2
- package/build/components/iframe/use-scale-canvas.cjs +4 -1
- package/build/components/iframe/use-scale-canvas.cjs.map +2 -2
- package/build/components/inserter/hooks/use-patterns-state.cjs +4 -6
- package/build/components/inserter/hooks/use-patterns-state.cjs.map +2 -2
- package/build/components/inserter/index.cjs +1 -0
- package/build/components/inserter/index.cjs.map +2 -2
- package/build/components/inserter/media-tab/media-preview.cjs +27 -18
- package/build/components/inserter/media-tab/media-preview.cjs.map +2 -2
- package/build/components/inserter/media-tab/utils.cjs +1 -1
- package/build/components/inserter/media-tab/utils.cjs.map +2 -2
- package/build/components/inserter/panel.cjs.map +3 -3
- package/build/components/inspector-controls/block-support-tools-panel.cjs +10 -2
- package/build/components/inspector-controls/block-support-tools-panel.cjs.map +2 -2
- package/build/components/inspector-controls/fill.cjs +14 -4
- package/build/components/inspector-controls/fill.cjs.map +2 -2
- package/build/components/inspector-controls/groups.cjs +2 -0
- package/build/components/inspector-controls/groups.cjs.map +2 -2
- package/build/components/inspector-controls-tabs/index.cjs +13 -8
- package/build/components/inspector-controls-tabs/index.cjs.map +3 -3
- package/build/components/inspector-controls-tabs/settings-tab.cjs +1 -4
- package/build/components/inspector-controls-tabs/settings-tab.cjs.map +3 -3
- package/build/components/inspector-controls-tabs/styles-tab.cjs +9 -0
- package/build/components/inspector-controls-tabs/styles-tab.cjs.map +3 -3
- package/build/components/inspector-controls-tabs/use-inspector-controls-tabs.cjs +11 -5
- package/build/components/inspector-controls-tabs/use-inspector-controls-tabs.cjs.map +2 -2
- package/build/components/list-view/block-select-button.cjs +20 -8
- package/build/components/list-view/block-select-button.cjs.map +2 -2
- package/build/components/list-view/block.cjs +2 -1
- package/build/components/list-view/block.cjs.map +2 -2
- package/build/components/preset-input-control/custom-value-controls.cjs +10 -1
- package/build/components/preset-input-control/custom-value-controls.cjs.map +2 -2
- package/build/components/preset-input-control/index.cjs.map +3 -3
- package/build/components/provider/use-media-upload-settings.cjs +1 -0
- package/build/components/provider/use-media-upload-settings.cjs.map +2 -2
- package/build/components/rich-text/event-listeners/enter.cjs +9 -2
- package/build/components/rich-text/event-listeners/enter.cjs.map +3 -3
- package/build/components/rich-text/event-listeners/paste-handler.cjs +4 -4
- package/build/components/rich-text/event-listeners/paste-handler.cjs.map +3 -3
- package/build/hooks/background.cjs +13 -3
- package/build/hooks/background.cjs.map +2 -2
- package/build/hooks/block-fields/link/index.cjs.map +3 -3
- package/build/hooks/block-fields/media/index.cjs.map +3 -3
- package/build/hooks/block-style-state.cjs +112 -0
- package/build/hooks/block-style-state.cjs.map +7 -0
- package/build/hooks/border.cjs +13 -3
- package/build/hooks/border.cjs.map +2 -2
- package/build/hooks/color.cjs +28 -9
- package/build/hooks/color.cjs.map +2 -2
- package/build/hooks/dimensions.cjs +15 -6
- package/build/hooks/dimensions.cjs.map +2 -2
- package/build/hooks/layout-child.cjs +147 -61
- package/build/hooks/layout-child.cjs.map +2 -2
- package/build/hooks/layout.cjs +263 -56
- package/build/hooks/layout.cjs.map +3 -3
- package/build/hooks/state-utils.cjs +94 -0
- package/build/hooks/state-utils.cjs.map +7 -0
- package/build/hooks/states.cjs +124 -0
- package/build/hooks/states.cjs.map +7 -0
- package/build/hooks/style.cjs +304 -17
- package/build/hooks/style.cjs.map +3 -3
- package/build/hooks/typography.cjs +14 -5
- package/build/hooks/typography.cjs.map +2 -2
- package/build/layouts/constrained.cjs +128 -55
- package/build/layouts/constrained.cjs.map +3 -3
- package/build/layouts/flex.cjs +119 -31
- package/build/layouts/flex.cjs.map +3 -3
- package/build/layouts/grid.cjs +103 -40
- package/build/layouts/grid.cjs.map +3 -3
- package/build/private-apis.cjs +2 -0
- package/build/private-apis.cjs.map +2 -2
- package/build/store/private-actions.cjs +18 -0
- package/build/store/private-actions.cjs.map +2 -2
- package/build/store/private-keys.cjs +10 -2
- package/build/store/private-keys.cjs.map +2 -2
- package/build/store/private-selectors.cjs +26 -2
- package/build/store/private-selectors.cjs.map +2 -2
- package/build/store/reducer.cjs +70 -1
- package/build/store/reducer.cjs.map +2 -2
- package/build/store/utils.cjs +1 -1
- package/build/store/utils.cjs.map +2 -2
- package/build/utils/color-values.cjs +44 -0
- package/build/utils/color-values.cjs.map +7 -0
- package/build-module/components/block-card/index.mjs +52 -45
- package/build-module/components/block-card/index.mjs.map +2 -2
- package/build-module/components/block-heading-level-dropdown/heading-level-icon.mjs +2 -2
- package/build-module/components/block-heading-level-dropdown/heading-level-icon.mjs.map +2 -2
- package/build-module/components/block-icon/index.mjs +8 -2
- package/build-module/components/block-icon/index.mjs.map +2 -2
- package/build-module/components/block-inspector/index.mjs +166 -13
- package/build-module/components/block-inspector/index.mjs.map +2 -2
- package/build-module/components/block-inspector/inspector-pre-tabs-slot-fill.mjs +12 -0
- package/build-module/components/block-inspector/inspector-pre-tabs-slot-fill.mjs.map +7 -0
- package/build-module/components/block-list/use-block-props/index.mjs +1 -1
- package/build-module/components/block-list/use-block-props/index.mjs.map +2 -2
- package/build-module/components/block-list/use-block-props/use-focus-handler.mjs +7 -5
- package/build-module/components/block-list/use-block-props/use-focus-handler.mjs.map +2 -2
- package/build-module/components/block-list/use-block-props/use-is-hovered.mjs +28 -15
- package/build-module/components/block-list/use-block-props/use-is-hovered.mjs.map +2 -2
- package/build-module/components/block-lock/modal.mjs +4 -4
- package/build-module/components/block-lock/modal.mjs.map +2 -2
- package/build-module/components/block-patterns-list/index.mjs +14 -4
- package/build-module/components/block-patterns-list/index.mjs.map +2 -2
- package/build-module/components/block-popover/index.mjs +13 -3
- package/build-module/components/block-popover/index.mjs.map +2 -2
- package/build-module/components/block-toolbar/switch-section-style.mjs +2 -2
- package/build-module/components/block-toolbar/switch-section-style.mjs.map +2 -2
- package/build-module/components/block-visibility/modal.mjs +2 -2
- package/build-module/components/block-visibility/modal.mjs.map +2 -2
- package/build-module/components/block-visibility/viewport-visibility-info.mjs +2 -2
- package/build-module/components/block-visibility/viewport-visibility-info.mjs.map +2 -2
- package/build-module/components/colors-gradients/control.mjs +7 -4
- package/build-module/components/colors-gradients/control.mjs.map +2 -2
- package/build-module/components/global-styles/advanced-panel.mjs +25 -27
- package/build-module/components/global-styles/advanced-panel.mjs.map +2 -2
- package/build-module/components/global-styles/color-panel.mjs +96 -59
- package/build-module/components/global-styles/color-panel.mjs.map +2 -2
- package/build-module/components/global-styles/dimensions-panel.mjs +14 -5
- package/build-module/components/global-styles/dimensions-panel.mjs.map +2 -2
- package/build-module/components/global-styles/index.mjs +2 -0
- package/build-module/components/global-styles/index.mjs.map +2 -2
- package/build-module/components/global-styles/shadow-panel-components.mjs +39 -28
- package/build-module/components/global-styles/shadow-panel-components.mjs.map +2 -2
- package/build-module/components/global-styles/state-control-badges.mjs +48 -0
- package/build-module/components/global-styles/state-control-badges.mjs.map +7 -0
- package/build-module/components/global-styles/state-control.mjs +57 -71
- package/build-module/components/global-styles/state-control.mjs.map +2 -2
- package/build-module/components/iframe/index.mjs +0 -3
- package/build-module/components/iframe/index.mjs.map +2 -2
- package/build-module/components/iframe/use-scale-canvas.mjs +4 -1
- package/build-module/components/iframe/use-scale-canvas.mjs.map +2 -2
- package/build-module/components/inserter/hooks/use-patterns-state.mjs +8 -7
- package/build-module/components/inserter/hooks/use-patterns-state.mjs.map +2 -2
- package/build-module/components/inserter/index.mjs +1 -0
- package/build-module/components/inserter/index.mjs.map +2 -2
- package/build-module/components/inserter/media-tab/media-preview.mjs +27 -19
- package/build-module/components/inserter/media-tab/media-preview.mjs.map +2 -2
- package/build-module/components/inserter/media-tab/utils.mjs +1 -1
- package/build-module/components/inserter/media-tab/utils.mjs.map +2 -2
- package/build-module/components/inserter/panel.mjs +2 -2
- package/build-module/components/inserter/panel.mjs.map +2 -2
- package/build-module/components/inspector-controls/block-support-tools-panel.mjs +10 -2
- package/build-module/components/inspector-controls/block-support-tools-panel.mjs.map +2 -2
- package/build-module/components/inspector-controls/fill.mjs +18 -5
- package/build-module/components/inspector-controls/fill.mjs.map +2 -2
- package/build-module/components/inspector-controls/groups.mjs +2 -0
- package/build-module/components/inspector-controls/groups.mjs.map +2 -2
- package/build-module/components/inspector-controls-tabs/index.mjs +14 -10
- package/build-module/components/inspector-controls-tabs/index.mjs.map +2 -2
- package/build-module/components/inspector-controls-tabs/settings-tab.mjs +1 -4
- package/build-module/components/inspector-controls-tabs/settings-tab.mjs.map +2 -2
- package/build-module/components/inspector-controls-tabs/styles-tab.mjs +9 -0
- package/build-module/components/inspector-controls-tabs/styles-tab.mjs.map +2 -2
- package/build-module/components/inspector-controls-tabs/use-inspector-controls-tabs.mjs +11 -5
- package/build-module/components/inspector-controls-tabs/use-inspector-controls-tabs.mjs.map +2 -2
- package/build-module/components/list-view/block-select-button.mjs +20 -9
- package/build-module/components/list-view/block-select-button.mjs.map +2 -2
- package/build-module/components/list-view/block.mjs +2 -1
- package/build-module/components/list-view/block.mjs.map +2 -2
- package/build-module/components/preset-input-control/custom-value-controls.mjs +10 -2
- package/build-module/components/preset-input-control/custom-value-controls.mjs.map +2 -2
- package/build-module/components/preset-input-control/index.mjs +2 -2
- package/build-module/components/preset-input-control/index.mjs.map +2 -2
- package/build-module/components/provider/use-media-upload-settings.mjs +1 -0
- package/build-module/components/provider/use-media-upload-settings.mjs.map +2 -2
- package/build-module/components/rich-text/event-listeners/enter.mjs +9 -2
- package/build-module/components/rich-text/event-listeners/enter.mjs.map +2 -2
- package/build-module/components/rich-text/event-listeners/paste-handler.mjs +4 -4
- package/build-module/components/rich-text/event-listeners/paste-handler.mjs.map +2 -2
- package/build-module/hooks/background.mjs +18 -3
- package/build-module/hooks/background.mjs.map +2 -2
- package/build-module/hooks/block-fields/link/index.mjs +3 -3
- package/build-module/hooks/block-fields/link/index.mjs.map +2 -2
- package/build-module/hooks/block-fields/media/index.mjs +3 -3
- package/build-module/hooks/block-fields/media/index.mjs.map +2 -2
- package/build-module/hooks/block-style-state.mjs +79 -0
- package/build-module/hooks/block-style-state.mjs.map +7 -0
- package/build-module/hooks/border.mjs +18 -3
- package/build-module/hooks/border.mjs.map +2 -2
- package/build-module/hooks/color.mjs +33 -9
- package/build-module/hooks/color.mjs.map +2 -2
- package/build-module/hooks/dimensions.mjs +20 -6
- package/build-module/hooks/dimensions.mjs.map +2 -2
- package/build-module/hooks/layout-child.mjs +141 -61
- package/build-module/hooks/layout-child.mjs.map +2 -2
- package/build-module/hooks/layout.mjs +270 -58
- package/build-module/hooks/layout.mjs.map +2 -2
- package/build-module/hooks/state-utils.mjs +64 -0
- package/build-module/hooks/state-utils.mjs.map +7 -0
- package/build-module/hooks/states.mjs +85 -0
- package/build-module/hooks/states.mjs.map +7 -0
- package/build-module/hooks/style.mjs +309 -18
- package/build-module/hooks/style.mjs.map +2 -2
- package/build-module/hooks/typography.mjs +19 -5
- package/build-module/hooks/typography.mjs.map +2 -2
- package/build-module/layouts/constrained.mjs +130 -57
- package/build-module/layouts/constrained.mjs.map +2 -2
- package/build-module/layouts/flex.mjs +123 -35
- package/build-module/layouts/flex.mjs.map +2 -2
- package/build-module/layouts/grid.mjs +105 -42
- package/build-module/layouts/grid.mjs.map +2 -2
- package/build-module/private-apis.mjs +4 -0
- package/build-module/private-apis.mjs.map +2 -2
- package/build-module/store/private-actions.mjs +16 -0
- package/build-module/store/private-actions.mjs.map +2 -2
- package/build-module/store/private-keys.mjs +7 -1
- package/build-module/store/private-keys.mjs.map +2 -2
- package/build-module/store/private-selectors.mjs +25 -2
- package/build-module/store/private-selectors.mjs.map +2 -2
- package/build-module/store/reducer.mjs +69 -1
- package/build-module/store/reducer.mjs.map +2 -2
- package/build-module/store/utils.mjs +5 -2
- package/build-module/store/utils.mjs.map +2 -2
- package/build-module/utils/color-values.mjs +19 -0
- package/build-module/utils/color-values.mjs.map +7 -0
- package/build-style/content-rtl.css +18 -3
- package/build-style/content.css +18 -3
- package/build-style/style-rtl.css +14 -17
- package/build-style/style.css +14 -17
- package/package.json +41 -41
- package/src/components/audio-player/index.native.js +7 -3
- package/src/components/block-card/index.js +67 -60
- package/src/components/block-heading-level-dropdown/heading-level-icon.js +2 -2
- package/src/components/block-icon/index.js +5 -2
- package/src/components/block-icon/index.native.js +2 -2
- package/src/components/block-inspector/index.js +153 -7
- package/src/components/block-inspector/inspector-pre-tabs-slot-fill.js +11 -0
- package/src/components/block-list/block-selection-button.native.js +3 -3
- package/src/components/block-list/content.scss +0 -6
- package/src/components/block-list/use-block-props/index.js +1 -1
- package/src/components/block-list/use-block-props/use-focus-handler.js +8 -6
- package/src/components/block-list/use-block-props/use-is-hovered.js +32 -15
- package/src/components/block-lock/modal.js +4 -4
- package/src/components/block-patterns-list/index.js +14 -5
- package/src/components/block-patterns-list/stories/index.story.jsx +2 -0
- package/src/components/block-patterns-list/style.scss +0 -1
- package/src/components/block-popover/index.js +20 -10
- package/src/components/block-toolbar/switch-section-style.js +2 -2
- package/src/components/block-visibility/modal.js +2 -2
- package/src/components/block-visibility/viewport-visibility-info.js +2 -2
- package/src/components/colors/test/with-colors.js +1 -1
- package/src/components/colors-gradients/control.js +10 -8
- package/src/components/colors-gradients/test/control.js +98 -1
- package/src/components/global-styles/advanced-panel.js +44 -39
- package/src/components/global-styles/color-panel.js +133 -60
- package/src/components/global-styles/dimensions-panel.js +17 -4
- package/src/components/global-styles/index.js +1 -0
- package/src/components/global-styles/shadow-panel-components.js +29 -19
- package/src/components/global-styles/state-control-badges.js +58 -0
- package/src/components/global-styles/state-control.js +28 -36
- package/src/components/global-styles/test/color-panel.js +135 -0
- package/src/components/iframe/index.js +0 -3
- package/src/components/iframe/use-scale-canvas.js +8 -2
- package/src/components/inserter/hooks/use-patterns-state.js +12 -7
- package/src/components/inserter/index.js +1 -0
- package/src/components/inserter/media-tab/media-preview.js +29 -20
- package/src/components/inserter/media-tab/utils.js +1 -1
- package/src/components/inserter/panel.js +2 -2
- package/src/components/inserter/style.scss +1 -0
- package/src/components/inserter-button/index.native.js +5 -2
- package/src/components/inspector-controls/block-support-tools-panel.js +10 -2
- package/src/components/inspector-controls/fill.js +18 -5
- package/src/components/inspector-controls/groups.js +2 -0
- package/src/components/inspector-controls-tabs/index.js +9 -5
- package/src/components/inspector-controls-tabs/settings-tab.js +1 -7
- package/src/components/inspector-controls-tabs/styles-tab.js +6 -0
- package/src/components/inspector-controls-tabs/use-inspector-controls-tabs.js +13 -7
- package/src/components/list-view/block-select-button.js +19 -9
- package/src/components/list-view/block.js +6 -1
- package/src/components/media-replace-flow/style.scss +0 -18
- package/src/components/preset-input-control/custom-value-controls.js +13 -6
- package/src/components/preset-input-control/index.js +2 -2
- package/src/components/provider/use-media-upload-settings.js +1 -0
- package/src/components/rich-text/event-listeners/enter.js +14 -2
- package/src/components/rich-text/event-listeners/paste-handler.js +5 -4
- package/src/components/unsupported-block-details/index.native.js +6 -2
- package/src/components/video-player/index.native.js +2 -2
- package/src/components/warning/index.native.js +2 -2
- package/src/hooks/background.js +59 -37
- package/src/hooks/block-fields/link/index.js +3 -3
- package/src/hooks/block-fields/media/index.js +3 -3
- package/src/hooks/block-style-state.js +127 -0
- package/src/hooks/border.js +25 -6
- package/src/hooks/color.js +40 -18
- package/src/hooks/dimensions.js +32 -11
- package/src/hooks/layout-child.js +179 -62
- package/src/hooks/layout.js +349 -75
- package/src/hooks/layout.scss +6 -0
- package/src/hooks/state-utils.js +158 -0
- package/src/hooks/states.js +109 -0
- package/src/hooks/style.js +456 -19
- package/src/hooks/test/block-style-state.js +270 -0
- package/src/hooks/test/layout.js +185 -0
- package/src/hooks/test/state-utils.js +193 -0
- package/src/hooks/test/style.js +301 -1
- package/src/hooks/typography.js +33 -14
- package/src/layouts/constrained.js +182 -95
- package/src/layouts/flex.js +141 -36
- package/src/layouts/grid.js +122 -32
- package/src/layouts/test/flex.js +57 -20
- package/src/private-apis.js +4 -0
- package/src/store/private-actions.js +32 -0
- package/src/store/private-keys.js +4 -0
- package/src/store/private-selectors.js +44 -2
- package/src/store/reducer.js +105 -1
- package/src/store/test/private-actions.js +26 -0
- package/src/store/test/private-selectors.js +90 -0
- package/src/store/test/reducer.js +363 -0
- package/src/store/utils.js +6 -2
- package/src/utils/color-values.js +28 -0
- package/src/utils/test/color-values.js +78 -0
|
@@ -22,12 +22,36 @@ import { BLOCK_VISIBILITY_VIEWPORTS } from '../components/block-visibility/const
|
|
|
22
22
|
|
|
23
23
|
// Used for generating the instance ID
|
|
24
24
|
const LAYOUT_CHILD_BLOCK_PROPS_REFERENCE = {};
|
|
25
|
+
// Keep in sync with WP_Theme_JSON_Gutenberg::RESPONSIVE_BREAKPOINTS.
|
|
26
|
+
const RESPONSIVE_BREAKPOINTS = {
|
|
27
|
+
mobile: '@media (width <= 480px)',
|
|
28
|
+
tablet: '@media (480px < width <= 782px)',
|
|
29
|
+
};
|
|
25
30
|
|
|
26
|
-
function
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
+
function serializeRule( { selector, declarations } ) {
|
|
32
|
+
return `${ selector } {
|
|
33
|
+
${ Object.entries( declarations )
|
|
34
|
+
.map( ( [ property, value ] ) => `${ property }: ${ value }` )
|
|
35
|
+
.join( '; ' ) };
|
|
36
|
+
}`;
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
export function getChildLayoutStyleRules( {
|
|
40
|
+
selector,
|
|
41
|
+
layout = {},
|
|
42
|
+
viewportOverrides,
|
|
43
|
+
parentLayout = {},
|
|
44
|
+
includeContainerQuery = true,
|
|
45
|
+
} ) {
|
|
46
|
+
const hasViewportOverrides = viewportOverrides !== undefined;
|
|
47
|
+
const effectiveLayout = hasViewportOverrides
|
|
48
|
+
? {
|
|
49
|
+
...layout,
|
|
50
|
+
...viewportOverrides,
|
|
51
|
+
}
|
|
52
|
+
: layout;
|
|
53
|
+
const hasViewportOverride = ( key ) =>
|
|
54
|
+
Object.hasOwn( viewportOverrides || {}, key );
|
|
31
55
|
const {
|
|
32
56
|
selfStretch,
|
|
33
57
|
flexSize,
|
|
@@ -35,66 +59,59 @@ function useBlockPropsChildLayoutStyles( { style } ) {
|
|
|
35
59
|
rowStart,
|
|
36
60
|
columnSpan,
|
|
37
61
|
rowSpan,
|
|
38
|
-
} =
|
|
39
|
-
const parentLayout = useLayout() || {};
|
|
62
|
+
} = effectiveLayout;
|
|
40
63
|
const { columnCount, minimumColumnWidth } = parentLayout;
|
|
41
|
-
const
|
|
42
|
-
const selector = `.wp-container-content-${ id }`;
|
|
64
|
+
const rules = [];
|
|
43
65
|
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
if (
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
if (
|
|
54
|
-
|
|
55
|
-
}
|
|
56
|
-
if ( rowSpan && typeof rowSpan !== 'number' ) {
|
|
57
|
-
throw new Error( 'rowSpan must be a number' );
|
|
66
|
+
const declarations = {};
|
|
67
|
+
if (
|
|
68
|
+
! hasViewportOverrides ||
|
|
69
|
+
hasViewportOverride( 'selfStretch' ) ||
|
|
70
|
+
hasViewportOverride( 'flexSize' )
|
|
71
|
+
) {
|
|
72
|
+
if ( selfStretch === 'fixed' && flexSize ) {
|
|
73
|
+
declarations[ 'flex-basis' ] = flexSize;
|
|
74
|
+
declarations[ 'box-sizing' ] = 'border-box';
|
|
75
|
+
} else if ( selfStretch === 'fill' ) {
|
|
76
|
+
declarations[ 'flex-grow' ] = '1';
|
|
58
77
|
}
|
|
59
78
|
}
|
|
60
79
|
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
flex-grow: 1;
|
|
71
|
-
}`;
|
|
72
|
-
} else if ( columnStart && columnSpan ) {
|
|
73
|
-
css = `${ selector } {
|
|
74
|
-
grid-column: ${ columnStart } / span ${ columnSpan };
|
|
75
|
-
}`;
|
|
80
|
+
if (
|
|
81
|
+
! hasViewportOverrides ||
|
|
82
|
+
hasViewportOverride( 'columnStart' ) ||
|
|
83
|
+
hasViewportOverride( 'columnSpan' )
|
|
84
|
+
) {
|
|
85
|
+
if ( columnStart && columnSpan ) {
|
|
86
|
+
declarations[
|
|
87
|
+
'grid-column'
|
|
88
|
+
] = `${ columnStart } / span ${ columnSpan }`;
|
|
76
89
|
} else if ( columnStart ) {
|
|
77
|
-
|
|
78
|
-
grid-column: ${ columnStart };
|
|
79
|
-
}`;
|
|
90
|
+
declarations[ 'grid-column' ] = `${ columnStart }`;
|
|
80
91
|
} else if ( columnSpan ) {
|
|
81
|
-
|
|
82
|
-
grid-column: span ${ columnSpan };
|
|
83
|
-
}`;
|
|
92
|
+
declarations[ 'grid-column' ] = `span ${ columnSpan }`;
|
|
84
93
|
}
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
if (
|
|
97
|
+
! hasViewportOverrides ||
|
|
98
|
+
hasViewportOverride( 'rowStart' ) ||
|
|
99
|
+
hasViewportOverride( 'rowSpan' )
|
|
100
|
+
) {
|
|
85
101
|
if ( rowStart && rowSpan ) {
|
|
86
|
-
|
|
87
|
-
grid-row: ${ rowStart } / span ${ rowSpan };
|
|
88
|
-
}`;
|
|
102
|
+
declarations[ 'grid-row' ] = `${ rowStart } / span ${ rowSpan }`;
|
|
89
103
|
} else if ( rowStart ) {
|
|
90
|
-
|
|
91
|
-
grid-row: ${ rowStart };
|
|
92
|
-
}`;
|
|
104
|
+
declarations[ 'grid-row' ] = `${ rowStart }`;
|
|
93
105
|
} else if ( rowSpan ) {
|
|
94
|
-
|
|
95
|
-
grid-row: span ${ rowSpan };
|
|
96
|
-
}`;
|
|
106
|
+
declarations[ 'grid-row' ] = `span ${ rowSpan }`;
|
|
97
107
|
}
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
if ( Object.keys( declarations ).length ) {
|
|
111
|
+
rules.push( { selector, declarations } );
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if ( includeContainerQuery && ! hasViewportOverrides ) {
|
|
98
115
|
/**
|
|
99
116
|
* If minimumColumnWidth is set on the parent, or if no
|
|
100
117
|
* columnCount is set, the grid is responsive so a
|
|
@@ -147,18 +164,118 @@ function useBlockPropsChildLayoutStyles( { style } ) {
|
|
|
147
164
|
const gridColumnValue =
|
|
148
165
|
columnSpan && columnSpan > 1 ? '1/-1' : 'auto';
|
|
149
166
|
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
${
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
167
|
+
rules.push( {
|
|
168
|
+
rulesGroup: `@container (max-width: ${ Math.max(
|
|
169
|
+
containerQueryValue,
|
|
170
|
+
minimumContainerQueryValue
|
|
171
|
+
) }${ parentColumnUnit })`,
|
|
172
|
+
selector,
|
|
173
|
+
declarations: {
|
|
174
|
+
'grid-column': gridColumnValue,
|
|
175
|
+
'grid-row': 'auto',
|
|
176
|
+
},
|
|
177
|
+
} );
|
|
159
178
|
}
|
|
160
179
|
}
|
|
161
180
|
|
|
181
|
+
return rules;
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
export function getChildLayoutStyles( {
|
|
185
|
+
selector,
|
|
186
|
+
layout = {},
|
|
187
|
+
parentLayout = {},
|
|
188
|
+
includeContainerQuery = true,
|
|
189
|
+
} ) {
|
|
190
|
+
return getChildLayoutStyleRules( {
|
|
191
|
+
selector,
|
|
192
|
+
layout,
|
|
193
|
+
parentLayout,
|
|
194
|
+
includeContainerQuery,
|
|
195
|
+
} )
|
|
196
|
+
.map( ( rule ) => {
|
|
197
|
+
const serializedRule = serializeRule( rule );
|
|
198
|
+
return rule.rulesGroup
|
|
199
|
+
? `${ rule.rulesGroup } {
|
|
200
|
+
${ serializedRule }
|
|
201
|
+
}`
|
|
202
|
+
: serializedRule;
|
|
203
|
+
} )
|
|
204
|
+
.join( '' );
|
|
205
|
+
}
|
|
206
|
+
|
|
207
|
+
export function getResponsiveChildLayoutStyles( {
|
|
208
|
+
style = {},
|
|
209
|
+
selector,
|
|
210
|
+
parentLayout = {},
|
|
211
|
+
} ) {
|
|
212
|
+
const baseLayout = style?.layout ?? {};
|
|
213
|
+
|
|
214
|
+
return Object.entries( RESPONSIVE_BREAKPOINTS )
|
|
215
|
+
.map( ( [ viewport, mediaQuery ] ) => {
|
|
216
|
+
const viewportLayout = style?.[ viewport ]?.layout;
|
|
217
|
+
if ( ! viewportLayout || ! Object.keys( viewportLayout ).length ) {
|
|
218
|
+
return '';
|
|
219
|
+
}
|
|
220
|
+
|
|
221
|
+
const viewportRules = getChildLayoutStyleRules( {
|
|
222
|
+
selector,
|
|
223
|
+
layout: baseLayout,
|
|
224
|
+
viewportOverrides: viewportLayout,
|
|
225
|
+
parentLayout,
|
|
226
|
+
includeContainerQuery: false,
|
|
227
|
+
} );
|
|
228
|
+
const css = viewportRules.map( serializeRule ).join( '' );
|
|
229
|
+
|
|
230
|
+
return css ? `${ mediaQuery }{${ css }}` : '';
|
|
231
|
+
} )
|
|
232
|
+
.filter( Boolean )
|
|
233
|
+
.join( '' );
|
|
234
|
+
}
|
|
235
|
+
|
|
236
|
+
function useBlockPropsChildLayoutStyles( { style } ) {
|
|
237
|
+
const shouldRenderChildLayoutStyles = useSelect( ( select ) => {
|
|
238
|
+
return ! select( blockEditorStore ).getSettings().disableLayoutStyles;
|
|
239
|
+
} );
|
|
240
|
+
const layout = style?.layout ?? {};
|
|
241
|
+
const { columnStart, rowStart, columnSpan, rowSpan } = layout;
|
|
242
|
+
const parentLayout = useLayout() || {};
|
|
243
|
+
const id = useInstanceId( LAYOUT_CHILD_BLOCK_PROPS_REFERENCE );
|
|
244
|
+
const selector = `.wp-container-content-${ id }`;
|
|
245
|
+
|
|
246
|
+
// Check that the grid layout attributes are of the correct type, so that we don't accidentally
|
|
247
|
+
// write code that stores a string attribute instead of a number.
|
|
248
|
+
if ( process.env.NODE_ENV === 'development' ) {
|
|
249
|
+
if ( columnStart && typeof columnStart !== 'number' ) {
|
|
250
|
+
throw new Error( 'columnStart must be a number' );
|
|
251
|
+
}
|
|
252
|
+
if ( rowStart && typeof rowStart !== 'number' ) {
|
|
253
|
+
throw new Error( 'rowStart must be a number' );
|
|
254
|
+
}
|
|
255
|
+
if ( columnSpan && typeof columnSpan !== 'number' ) {
|
|
256
|
+
throw new Error( 'columnSpan must be a number' );
|
|
257
|
+
}
|
|
258
|
+
if ( rowSpan && typeof rowSpan !== 'number' ) {
|
|
259
|
+
throw new Error( 'rowSpan must be a number' );
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
|
|
263
|
+
let css = '';
|
|
264
|
+
if ( shouldRenderChildLayoutStyles ) {
|
|
265
|
+
css = [
|
|
266
|
+
getChildLayoutStyles( {
|
|
267
|
+
selector,
|
|
268
|
+
layout,
|
|
269
|
+
parentLayout,
|
|
270
|
+
} ),
|
|
271
|
+
getResponsiveChildLayoutStyles( {
|
|
272
|
+
style,
|
|
273
|
+
selector,
|
|
274
|
+
parentLayout,
|
|
275
|
+
} ),
|
|
276
|
+
].join( '' );
|
|
277
|
+
}
|
|
278
|
+
|
|
162
279
|
useStyleOverride( { css } );
|
|
163
280
|
|
|
164
281
|
// Only attach a container class if there is generated CSS to be attached.
|