@wordpress/block-editor 14.7.1-next.082ed6819.0 → 14.8.1-next.cd6172eb0.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 +2 -0
- package/build/autocompleters/block.js +2 -4
- package/build/autocompleters/block.js.map +1 -1
- package/build/autocompleters/link.js +2 -4
- package/build/autocompleters/link.js.map +1 -1
- package/build/components/block-canvas/index.js +3 -6
- package/build/components/block-canvas/index.js.map +1 -1
- package/build/components/block-list/block.js +6 -5
- package/build/components/block-list/block.js.map +1 -1
- package/build/components/block-list/index.js +0 -1
- package/build/components/block-list/index.js.map +1 -1
- package/build/components/block-list/use-block-props/index.js +7 -2
- package/build/components/block-list/use-block-props/index.js.map +1 -1
- package/build/components/block-list/use-block-props/use-firefox-draggable-compatibility.js +34 -0
- package/build/components/block-list/use-block-props/use-firefox-draggable-compatibility.js.map +1 -0
- package/build/components/block-list/use-block-props/use-selected-block-event-handlers.js +98 -5
- package/build/components/block-list/use-block-props/use-selected-block-event-handlers.js.map +1 -1
- package/build/components/block-patterns-list/index.js +13 -4
- package/build/components/block-patterns-list/index.js.map +1 -1
- package/build/components/block-popover/inbetween.js +4 -0
- package/build/components/block-popover/inbetween.js.map +1 -1
- package/build/components/block-settings-menu/block-settings-dropdown.js +7 -4
- package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
- package/build/components/block-settings-menu-controls/index.js +1 -1
- package/build/components/block-settings-menu-controls/index.js.map +1 -1
- package/build/components/block-switcher/index.js +12 -22
- package/build/components/block-switcher/index.js.map +1 -1
- package/build/components/block-switcher/use-transformed-patterns.js +0 -1
- package/build/components/block-switcher/use-transformed-patterns.js.map +1 -1
- package/build/components/block-switcher/utils.js +0 -1
- package/build/components/block-switcher/utils.js.map +1 -1
- package/build/components/block-toolbar/index.js +17 -9
- package/build/components/block-toolbar/index.js.map +1 -1
- package/build/components/block-variation-transforms/index.js +0 -1
- package/build/components/block-variation-transforms/index.js.map +1 -1
- package/build/components/date-format-picker/index.js +0 -1
- package/build/components/date-format-picker/index.js.map +1 -1
- package/build/components/font-appearance-control/index.js +1 -0
- package/build/components/font-appearance-control/index.js.map +1 -1
- package/build/components/font-family/index.js +10 -0
- package/build/components/font-family/index.js.map +1 -1
- package/build/components/global-styles/dimensions-panel.js +17 -16
- package/build/components/global-styles/dimensions-panel.js.map +1 -1
- package/build/components/global-styles/get-global-styles-changes.js +0 -1
- package/build/components/global-styles/get-global-styles-changes.js.map +1 -1
- package/build/components/iframe/index.js +12 -216
- package/build/components/iframe/index.js.map +1 -1
- package/build/components/iframe/use-scale-canvas.js +398 -0
- package/build/components/iframe/use-scale-canvas.js.map +1 -0
- package/build/components/image-editor/use-save-image.js +22 -3
- package/build/components/image-editor/use-save-image.js.map +1 -1
- package/build/components/inserter/block-patterns-tab/index.js +0 -10
- package/build/components/inserter/block-patterns-tab/index.js.map +1 -1
- package/build/components/inserter/menu.js +2 -1
- package/build/components/inserter/menu.js.map +1 -1
- package/build/components/inserter-draggable-blocks/index.js +19 -10
- package/build/components/inserter-draggable-blocks/index.js.map +1 -1
- package/build/components/letter-spacing-control/index.js +10 -0
- package/build/components/letter-spacing-control/index.js.map +1 -1
- package/build/components/line-height-control/index.js +1 -0
- package/build/components/line-height-control/index.js.map +1 -1
- package/build/components/media-placeholder/index.js +18 -18
- package/build/components/media-placeholder/index.js.map +1 -1
- package/build/components/observe-typing/index.js +0 -1
- package/build/components/observe-typing/index.js.map +1 -1
- package/build/components/recursion-provider/index.js +0 -1
- package/build/components/recursion-provider/index.js.map +1 -1
- package/build/components/rich-text/index.js +5 -1
- package/build/components/rich-text/index.js.map +1 -1
- package/build/components/rich-text/native/use-format-types.js +0 -1
- package/build/components/rich-text/native/use-format-types.js.map +1 -1
- package/build/components/rich-text/use-format-types.js +0 -1
- package/build/components/rich-text/use-format-types.js.map +1 -1
- package/build/components/spacing-sizes-control/utils.js +0 -1
- package/build/components/spacing-sizes-control/utils.js.map +1 -1
- package/build/components/typewriter/index.js +0 -1
- package/build/components/typewriter/index.js.map +1 -1
- package/build/components/use-block-drop-zone/index.js +11 -2
- package/build/components/use-block-drop-zone/index.js.map +1 -1
- package/build/components/use-moving-animation/index.js +15 -2
- package/build/components/use-moving-animation/index.js.map +1 -1
- package/build/components/use-resize-canvas/index.js +1 -1
- package/build/components/use-resize-canvas/index.js.map +1 -1
- package/build/components/writing-flow/use-drag-selection.js +11 -0
- package/build/components/writing-flow/use-drag-selection.js.map +1 -1
- package/build/components/writing-flow/use-tab-nav.js +6 -2
- package/build/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build/hooks/block-bindings.js +4 -3
- package/build/hooks/block-bindings.js.map +1 -1
- package/build/hooks/gap.js +1 -1
- package/build/hooks/gap.js.map +1 -1
- package/build/hooks/generated-class-name.js +0 -1
- package/build/hooks/generated-class-name.js.map +1 -1
- package/build/store/private-selectors.js +1 -7
- package/build/store/private-selectors.js.map +1 -1
- package/build/store/reducer.js +478 -2
- package/build/store/reducer.js.map +1 -1
- package/build/store/selectors.js +12 -55
- package/build/store/selectors.js.map +1 -1
- package/build/utils/object.js +0 -1
- package/build/utils/object.js.map +1 -1
- package/build-module/autocompleters/block.js +2 -4
- package/build-module/autocompleters/block.js.map +1 -1
- package/build-module/autocompleters/link.js +2 -4
- package/build-module/autocompleters/link.js.map +1 -1
- package/build-module/components/block-canvas/index.js +3 -6
- package/build-module/components/block-canvas/index.js.map +1 -1
- package/build-module/components/block-list/block.js +8 -7
- package/build-module/components/block-list/block.js.map +1 -1
- package/build-module/components/block-list/index.js +0 -1
- package/build-module/components/block-list/index.js.map +1 -1
- package/build-module/components/block-list/use-block-props/index.js +7 -2
- package/build-module/components/block-list/use-block-props/index.js.map +1 -1
- package/build-module/components/block-list/use-block-props/use-firefox-draggable-compatibility.js +28 -0
- package/build-module/components/block-list/use-block-props/use-firefox-draggable-compatibility.js.map +1 -0
- package/build-module/components/block-list/use-block-props/use-selected-block-event-handlers.js +97 -5
- package/build-module/components/block-list/use-block-props/use-selected-block-event-handlers.js.map +1 -1
- package/build-module/components/block-patterns-list/index.js +13 -4
- package/build-module/components/block-patterns-list/index.js.map +1 -1
- package/build-module/components/block-popover/inbetween.js +4 -0
- package/build-module/components/block-popover/inbetween.js.map +1 -1
- package/build-module/components/block-settings-menu/block-settings-dropdown.js +7 -4
- package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
- package/build-module/components/block-settings-menu-controls/index.js +1 -1
- package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
- package/build-module/components/block-switcher/index.js +13 -23
- package/build-module/components/block-switcher/index.js.map +1 -1
- package/build-module/components/block-switcher/use-transformed-patterns.js +0 -1
- package/build-module/components/block-switcher/use-transformed-patterns.js.map +1 -1
- package/build-module/components/block-switcher/utils.js +0 -1
- package/build-module/components/block-switcher/utils.js.map +1 -1
- package/build-module/components/block-toolbar/index.js +17 -9
- package/build-module/components/block-toolbar/index.js.map +1 -1
- package/build-module/components/block-variation-transforms/index.js +0 -1
- package/build-module/components/block-variation-transforms/index.js.map +1 -1
- package/build-module/components/date-format-picker/index.js +0 -1
- package/build-module/components/date-format-picker/index.js.map +1 -1
- package/build-module/components/font-appearance-control/index.js +1 -0
- package/build-module/components/font-appearance-control/index.js.map +1 -1
- package/build-module/components/font-family/index.js +10 -0
- package/build-module/components/font-family/index.js.map +1 -1
- package/build-module/components/global-styles/dimensions-panel.js +17 -16
- package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
- package/build-module/components/global-styles/get-global-styles-changes.js +0 -1
- package/build-module/components/global-styles/get-global-styles-changes.js.map +1 -1
- package/build-module/components/iframe/index.js +14 -218
- package/build-module/components/iframe/index.js.map +1 -1
- package/build-module/components/iframe/use-scale-canvas.js +392 -0
- package/build-module/components/iframe/use-scale-canvas.js.map +1 -0
- package/build-module/components/image-editor/use-save-image.js +22 -3
- package/build-module/components/image-editor/use-save-image.js.map +1 -1
- package/build-module/components/inserter/block-patterns-tab/index.js +1 -11
- package/build-module/components/inserter/block-patterns-tab/index.js.map +1 -1
- package/build-module/components/inserter/menu.js +2 -1
- package/build-module/components/inserter/menu.js.map +1 -1
- package/build-module/components/inserter-draggable-blocks/index.js +20 -11
- package/build-module/components/inserter-draggable-blocks/index.js.map +1 -1
- package/build-module/components/letter-spacing-control/index.js +9 -0
- package/build-module/components/letter-spacing-control/index.js.map +1 -1
- package/build-module/components/line-height-control/index.js +1 -0
- package/build-module/components/line-height-control/index.js.map +1 -1
- package/build-module/components/media-placeholder/index.js +18 -18
- package/build-module/components/media-placeholder/index.js.map +1 -1
- package/build-module/components/observe-typing/index.js +0 -1
- package/build-module/components/observe-typing/index.js.map +1 -1
- package/build-module/components/recursion-provider/index.js +0 -1
- package/build-module/components/recursion-provider/index.js.map +1 -1
- package/build-module/components/rich-text/index.js +5 -1
- package/build-module/components/rich-text/index.js.map +1 -1
- package/build-module/components/rich-text/native/use-format-types.js +0 -1
- package/build-module/components/rich-text/native/use-format-types.js.map +1 -1
- package/build-module/components/rich-text/use-format-types.js +0 -1
- package/build-module/components/rich-text/use-format-types.js.map +1 -1
- package/build-module/components/spacing-sizes-control/utils.js +0 -1
- package/build-module/components/spacing-sizes-control/utils.js.map +1 -1
- package/build-module/components/typewriter/index.js +0 -1
- package/build-module/components/typewriter/index.js.map +1 -1
- package/build-module/components/use-block-drop-zone/index.js +11 -2
- package/build-module/components/use-block-drop-zone/index.js.map +1 -1
- package/build-module/components/use-moving-animation/index.js +15 -2
- package/build-module/components/use-moving-animation/index.js.map +1 -1
- package/build-module/components/use-resize-canvas/index.js +1 -1
- package/build-module/components/use-resize-canvas/index.js.map +1 -1
- package/build-module/components/writing-flow/use-drag-selection.js +11 -0
- package/build-module/components/writing-flow/use-drag-selection.js.map +1 -1
- package/build-module/components/writing-flow/use-tab-nav.js +6 -2
- package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
- package/build-module/hooks/block-bindings.js +4 -3
- package/build-module/hooks/block-bindings.js.map +1 -1
- package/build-module/hooks/gap.js +1 -1
- package/build-module/hooks/gap.js.map +1 -1
- package/build-module/hooks/generated-class-name.js +0 -1
- package/build-module/hooks/generated-class-name.js.map +1 -1
- package/build-module/store/private-selectors.js +1 -6
- package/build-module/store/private-selectors.js.map +1 -1
- package/build-module/store/reducer.js +479 -3
- package/build-module/store/reducer.js.map +1 -1
- package/build-module/store/selectors.js +12 -55
- package/build-module/store/selectors.js.map +1 -1
- package/build-module/utils/object.js +0 -1
- package/build-module/utils/object.js.map +1 -1
- package/build-style/content-rtl.css +24 -26
- package/build-style/content.css +24 -26
- package/build-style/style-rtl.css +51 -16
- package/build-style/style.css +51 -16
- package/package.json +32 -32
- package/src/autocompleters/block.js +2 -4
- package/src/autocompleters/link.js +2 -4
- package/src/components/alignment-control/stories/aliginment-toolbar.story.js +47 -0
- package/src/components/alignment-control/stories/index.story.js +51 -0
- package/src/components/alignment-control/test/__snapshots__/index.js.snap +5 -5
- package/src/components/block-alignment-control/test/__snapshots__/index.js.snap +4 -4
- package/src/components/block-canvas/index.js +3 -5
- package/src/components/block-canvas/style.scss +2 -1
- package/src/components/block-draggable/content.scss +11 -5
- package/src/components/block-list/block.js +7 -13
- package/src/components/block-list/content.scss +6 -0
- package/src/components/block-list/use-block-props/index.js +7 -0
- package/src/components/block-list/use-block-props/use-firefox-draggable-compatibility.js +25 -0
- package/src/components/block-list/use-block-props/use-selected-block-event-handlers.js +112 -8
- package/src/components/block-patterns-list/index.js +12 -1
- package/src/components/block-patterns-list/style.scss +16 -5
- package/src/components/block-popover/inbetween.js +4 -0
- package/src/components/block-settings-menu/block-settings-dropdown.js +6 -1
- package/src/components/block-settings-menu-controls/index.js +2 -1
- package/src/components/block-switcher/index.js +19 -21
- package/src/components/block-switcher/style.scss +0 -9
- package/src/components/block-title/test/index.js +2 -0
- package/src/components/block-toolbar/index.js +16 -6
- package/src/components/block-tools/style.scss +44 -0
- package/src/components/block-vertical-alignment-control/test/__snapshots__/index.js.snap +3 -3
- package/src/components/color-palette/test/__snapshots__/control.js.snap +2 -2
- package/src/components/font-appearance-control/index.js +1 -0
- package/src/components/font-family/index.js +10 -0
- package/src/components/font-family/style.scss +5 -0
- package/src/components/global-styles/dimensions-panel.js +16 -16
- package/src/components/iframe/content.scss +40 -42
- package/src/components/iframe/index.js +13 -313
- package/src/components/iframe/use-scale-canvas.js +490 -0
- package/src/components/image-editor/use-save-image.js +27 -2
- package/src/components/inserter/block-patterns-tab/index.js +1 -17
- package/src/components/inserter/menu.js +8 -1
- package/src/components/inserter-draggable-blocks/index.js +19 -29
- package/src/components/letter-spacing-control/README.md +2 -1
- package/src/components/letter-spacing-control/index.js +17 -0
- package/src/components/line-height-control/index.js +1 -0
- package/src/components/media-placeholder/index.js +25 -28
- package/src/components/rich-text/index.js +5 -0
- package/src/components/use-block-drop-zone/index.js +18 -1
- package/src/components/use-moving-animation/index.js +15 -0
- package/src/components/use-resize-canvas/index.js +1 -1
- package/src/components/writing-flow/use-drag-selection.js +11 -0
- package/src/components/writing-flow/use-tab-nav.js +9 -6
- package/src/hooks/block-bindings.js +8 -4
- package/src/hooks/gap.js +1 -1
- package/src/store/private-selectors.js +2 -17
- package/src/store/reducer.js +639 -2
- package/src/store/selectors.js +19 -69
- package/src/store/test/private-selectors.js +1 -0
- package/src/store/test/reducer.js +849 -0
- package/src/store/test/selectors.js +4 -110
- package/src/style.scss +1 -0
|
@@ -12,7 +12,7 @@ exports[`AlignmentUI should allow custom alignment controls to be specified 1`]
|
|
|
12
12
|
align="custom-left"
|
|
13
13
|
aria-label="My custom left"
|
|
14
14
|
aria-pressed="false"
|
|
15
|
-
class="components-button components-toolbar__control has-icon"
|
|
15
|
+
class="components-button components-toolbar__control is-compact has-icon"
|
|
16
16
|
data-toolbar-item="true"
|
|
17
17
|
type="button"
|
|
18
18
|
>
|
|
@@ -35,7 +35,7 @@ exports[`AlignmentUI should allow custom alignment controls to be specified 1`]
|
|
|
35
35
|
align="custom-right"
|
|
36
36
|
aria-label="My custom right"
|
|
37
37
|
aria-pressed="true"
|
|
38
|
-
class="components-button components-toolbar__control is-pressed has-icon"
|
|
38
|
+
class="components-button components-toolbar__control is-compact is-pressed has-icon"
|
|
39
39
|
data-toolbar-item="true"
|
|
40
40
|
type="button"
|
|
41
41
|
>
|
|
@@ -100,7 +100,7 @@ exports[`AlignmentUI should match snapshot when controls are visible 1`] = `
|
|
|
100
100
|
align="left"
|
|
101
101
|
aria-label="Align text left"
|
|
102
102
|
aria-pressed="true"
|
|
103
|
-
class="components-button components-toolbar__control is-pressed has-icon"
|
|
103
|
+
class="components-button components-toolbar__control is-compact is-pressed has-icon"
|
|
104
104
|
data-toolbar-item="true"
|
|
105
105
|
type="button"
|
|
106
106
|
>
|
|
@@ -123,7 +123,7 @@ exports[`AlignmentUI should match snapshot when controls are visible 1`] = `
|
|
|
123
123
|
align="center"
|
|
124
124
|
aria-label="Align text center"
|
|
125
125
|
aria-pressed="false"
|
|
126
|
-
class="components-button components-toolbar__control has-icon"
|
|
126
|
+
class="components-button components-toolbar__control is-compact has-icon"
|
|
127
127
|
data-toolbar-item="true"
|
|
128
128
|
type="button"
|
|
129
129
|
>
|
|
@@ -146,7 +146,7 @@ exports[`AlignmentUI should match snapshot when controls are visible 1`] = `
|
|
|
146
146
|
align="right"
|
|
147
147
|
aria-label="Align text right"
|
|
148
148
|
aria-pressed="false"
|
|
149
|
-
class="components-button components-toolbar__control has-icon"
|
|
149
|
+
class="components-button components-toolbar__control is-compact has-icon"
|
|
150
150
|
data-toolbar-item="true"
|
|
151
151
|
type="button"
|
|
152
152
|
>
|
|
@@ -42,7 +42,7 @@ exports[`BlockAlignmentUI should match snapshot when controls are visible 1`] =
|
|
|
42
42
|
<button
|
|
43
43
|
aria-label="None"
|
|
44
44
|
aria-pressed="false"
|
|
45
|
-
class="components-button components-toolbar__control has-icon"
|
|
45
|
+
class="components-button components-toolbar__control is-compact has-icon"
|
|
46
46
|
data-toolbar-item="true"
|
|
47
47
|
type="button"
|
|
48
48
|
>
|
|
@@ -64,7 +64,7 @@ exports[`BlockAlignmentUI should match snapshot when controls are visible 1`] =
|
|
|
64
64
|
<button
|
|
65
65
|
aria-label="Align left"
|
|
66
66
|
aria-pressed="true"
|
|
67
|
-
class="components-button components-toolbar__control is-pressed has-icon"
|
|
67
|
+
class="components-button components-toolbar__control is-compact is-pressed has-icon"
|
|
68
68
|
data-toolbar-item="true"
|
|
69
69
|
type="button"
|
|
70
70
|
>
|
|
@@ -86,7 +86,7 @@ exports[`BlockAlignmentUI should match snapshot when controls are visible 1`] =
|
|
|
86
86
|
<button
|
|
87
87
|
aria-label="Align center"
|
|
88
88
|
aria-pressed="false"
|
|
89
|
-
class="components-button components-toolbar__control has-icon"
|
|
89
|
+
class="components-button components-toolbar__control is-compact has-icon"
|
|
90
90
|
data-toolbar-item="true"
|
|
91
91
|
type="button"
|
|
92
92
|
>
|
|
@@ -108,7 +108,7 @@ exports[`BlockAlignmentUI should match snapshot when controls are visible 1`] =
|
|
|
108
108
|
<button
|
|
109
109
|
aria-label="Align right"
|
|
110
110
|
aria-pressed="false"
|
|
111
|
-
class="components-button components-toolbar__control has-icon"
|
|
111
|
+
class="components-button components-toolbar__control is-compact has-icon"
|
|
112
112
|
data-toolbar-item="true"
|
|
113
113
|
type="button"
|
|
114
114
|
>
|
|
@@ -56,7 +56,8 @@ export function ExperimentalBlockCanvas( {
|
|
|
56
56
|
return (
|
|
57
57
|
<BlockTools
|
|
58
58
|
__unstableContentRef={ localRef }
|
|
59
|
-
|
|
59
|
+
className="block-editor-block-canvas"
|
|
60
|
+
style={ { height } }
|
|
60
61
|
>
|
|
61
62
|
<EditorStyles
|
|
62
63
|
styles={ styles }
|
|
@@ -67,10 +68,6 @@ export function ExperimentalBlockCanvas( {
|
|
|
67
68
|
ref={ contentRef }
|
|
68
69
|
className="editor-styles-wrapper"
|
|
69
70
|
tabIndex={ -1 }
|
|
70
|
-
style={ {
|
|
71
|
-
height: '100%',
|
|
72
|
-
width: '100%',
|
|
73
|
-
} }
|
|
74
71
|
>
|
|
75
72
|
{ children }
|
|
76
73
|
</WritingFlow>
|
|
@@ -81,6 +78,7 @@ export function ExperimentalBlockCanvas( {
|
|
|
81
78
|
return (
|
|
82
79
|
<BlockTools
|
|
83
80
|
__unstableContentRef={ localRef }
|
|
81
|
+
className="block-editor-block-canvas"
|
|
84
82
|
style={ { height, display: 'flex' } }
|
|
85
83
|
>
|
|
86
84
|
<Iframe
|
|
@@ -4,6 +4,7 @@ iframe[name="editor-canvas"] {
|
|
|
4
4
|
height: 100%;
|
|
5
5
|
display: block;
|
|
6
6
|
// Handles transitions between device previews
|
|
7
|
-
|
|
7
|
+
transition: all 400ms cubic-bezier(0.46, 0.03, 0.52, 0.96);
|
|
8
|
+
@include reduce-motion("transition");
|
|
8
9
|
background-color: $gray-300;
|
|
9
10
|
}
|
|
@@ -1,13 +1,12 @@
|
|
|
1
1
|
// This creates a "slot" where the block you're dragging appeared.
|
|
2
2
|
// We use !important as one of the rules are meant to be overridden.
|
|
3
3
|
.block-editor-block-list__layout .is-dragging {
|
|
4
|
-
|
|
5
|
-
opacity: 0.05 !important;
|
|
4
|
+
opacity: 0.1 !important;
|
|
6
5
|
border-radius: $radius-small !important;
|
|
7
6
|
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
7
|
+
iframe {
|
|
8
|
+
pointer-events: none;
|
|
9
|
+
}
|
|
11
10
|
|
|
12
11
|
// Hide the multi selection indicator when dragging.
|
|
13
12
|
&::selection {
|
|
@@ -18,3 +17,10 @@
|
|
|
18
17
|
content: none !important;
|
|
19
18
|
}
|
|
20
19
|
}
|
|
20
|
+
|
|
21
|
+
// Images are draggable by default, so disable drag for them if not explicitly
|
|
22
|
+
// set. This is done so that the block can capture the drag event instead.
|
|
23
|
+
.wp-block img:not([draggable]),
|
|
24
|
+
.wp-block svg:not([draggable]) {
|
|
25
|
+
pointer-events: none;
|
|
26
|
+
}
|
|
@@ -6,13 +6,7 @@ import clsx from 'clsx';
|
|
|
6
6
|
/**
|
|
7
7
|
* WordPress dependencies
|
|
8
8
|
*/
|
|
9
|
-
import {
|
|
10
|
-
memo,
|
|
11
|
-
useCallback,
|
|
12
|
-
RawHTML,
|
|
13
|
-
useContext,
|
|
14
|
-
useMemo,
|
|
15
|
-
} from '@wordpress/element';
|
|
9
|
+
import { memo, RawHTML, useContext, useMemo } from '@wordpress/element';
|
|
16
10
|
import {
|
|
17
11
|
getBlockType,
|
|
18
12
|
getSaveContent,
|
|
@@ -28,7 +22,7 @@ import {
|
|
|
28
22
|
store as blocksStore,
|
|
29
23
|
} from '@wordpress/blocks';
|
|
30
24
|
import { withFilters } from '@wordpress/components';
|
|
31
|
-
import { withDispatch,
|
|
25
|
+
import { withDispatch, useSelect } from '@wordpress/data';
|
|
32
26
|
import { compose } from '@wordpress/compose';
|
|
33
27
|
import { safeHTML } from '@wordpress/dom';
|
|
34
28
|
|
|
@@ -103,6 +97,7 @@ function BlockListBlock( {
|
|
|
103
97
|
wrapperProps,
|
|
104
98
|
setAttributes,
|
|
105
99
|
onReplace,
|
|
100
|
+
onRemove,
|
|
106
101
|
onInsertBlocksAfter,
|
|
107
102
|
onMerge,
|
|
108
103
|
toggleSelection,
|
|
@@ -113,11 +108,6 @@ function BlockListBlock( {
|
|
|
113
108
|
themeSupportsLayout,
|
|
114
109
|
...context
|
|
115
110
|
} = useContext( PrivateBlockContext );
|
|
116
|
-
const { removeBlock } = useDispatch( blockEditorStore );
|
|
117
|
-
const onRemove = useCallback(
|
|
118
|
-
() => removeBlock( clientId ),
|
|
119
|
-
[ clientId, removeBlock ]
|
|
120
|
-
);
|
|
121
111
|
|
|
122
112
|
const parentLayout = useLayout() || {};
|
|
123
113
|
|
|
@@ -537,6 +527,9 @@ const applyWithDispatch = withDispatch( ( dispatch, ownProps, registry ) => {
|
|
|
537
527
|
initialPosition
|
|
538
528
|
);
|
|
539
529
|
},
|
|
530
|
+
onRemove() {
|
|
531
|
+
removeBlock( ownProps.clientId );
|
|
532
|
+
},
|
|
540
533
|
toggleSelection( selectionEnabled ) {
|
|
541
534
|
toggleSelection( selectionEnabled );
|
|
542
535
|
},
|
|
@@ -797,6 +790,7 @@ function BlockListBlockProvider( props ) {
|
|
|
797
790
|
mayDisplayParentControls,
|
|
798
791
|
originalBlockClientId,
|
|
799
792
|
themeSupportsLayout,
|
|
793
|
+
canMove,
|
|
800
794
|
};
|
|
801
795
|
|
|
802
796
|
// Here we separate between the props passed to BlockListBlock and any other
|
|
@@ -427,3 +427,9 @@ _::-webkit-full-page-media, _:future, :root [data-has-multi-selection="true"] .b
|
|
|
427
427
|
// Additional -1px is required to avoid sub pixel rounding errors allowing background to show.
|
|
428
428
|
margin: 0 calc(-1 * var(--wp--style--root--padding-right) - 1px) 0 calc(-1 * var(--wp--style--root--padding-left) - 1px) !important;
|
|
429
429
|
}
|
|
430
|
+
|
|
431
|
+
// This only works in Firefox, Chrome and Safari don't accept a custom cursor
|
|
432
|
+
// during drag.
|
|
433
|
+
.is-dragging {
|
|
434
|
+
cursor: grabbing;
|
|
435
|
+
}
|
|
@@ -30,6 +30,7 @@ import { useIntersectionObserver } from './use-intersection-observer';
|
|
|
30
30
|
import { useScrollIntoView } from './use-scroll-into-view';
|
|
31
31
|
import { useFlashEditableBlocks } from '../../use-flash-editable-blocks';
|
|
32
32
|
import { canBindBlock } from '../../../hooks/use-bindings-attributes';
|
|
33
|
+
import { useFirefoxDraggableCompatibility } from './use-firefox-draggable-compatibility';
|
|
33
34
|
|
|
34
35
|
/**
|
|
35
36
|
* This hook is used to lightly mark an element as a block element. The element
|
|
@@ -100,11 +101,15 @@ export function useBlockProps( props = {}, { __unstableIsHtml } = {} ) {
|
|
|
100
101
|
isTemporarilyEditingAsBlocks,
|
|
101
102
|
defaultClassName,
|
|
102
103
|
isSectionBlock,
|
|
104
|
+
canMove,
|
|
103
105
|
} = useContext( PrivateBlockContext );
|
|
104
106
|
|
|
107
|
+
const canDrag = canMove && ! hasChildSelected;
|
|
108
|
+
|
|
105
109
|
// translators: %s: Type of block (i.e. Text, Image etc)
|
|
106
110
|
const blockLabel = sprintf( __( 'Block: %s' ), blockTitle );
|
|
107
111
|
const htmlSuffix = mode === 'html' && ! __unstableIsHtml ? '-visual' : '';
|
|
112
|
+
const ffDragRef = useFirefoxDraggableCompatibility();
|
|
108
113
|
const mergedRefs = useMergeRefs( [
|
|
109
114
|
props.ref,
|
|
110
115
|
useFocusFirstElement( { clientId, initialPosition } ),
|
|
@@ -120,6 +125,7 @@ export function useBlockProps( props = {}, { __unstableIsHtml } = {} ) {
|
|
|
120
125
|
isEnabled: isSectionBlock,
|
|
121
126
|
} ),
|
|
122
127
|
useScrollIntoView( { isSelected } ),
|
|
128
|
+
canDrag ? ffDragRef : undefined,
|
|
123
129
|
] );
|
|
124
130
|
|
|
125
131
|
const blockEditContext = useBlockEditContext();
|
|
@@ -152,6 +158,7 @@ export function useBlockProps( props = {}, { __unstableIsHtml } = {} ) {
|
|
|
152
158
|
|
|
153
159
|
return {
|
|
154
160
|
tabIndex: blockEditingMode === 'disabled' ? -1 : 0,
|
|
161
|
+
draggable: canDrag ? true : undefined,
|
|
155
162
|
...wrapperProps,
|
|
156
163
|
...props,
|
|
157
164
|
ref: mergedRefs,
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { useRefEffect } from '@wordpress/compose';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* In Firefox, the `draggable` and `contenteditable` attributes don't play well
|
|
8
|
+
* together. When `contenteditable` is within a `draggable` element, selection
|
|
9
|
+
* doesn't get set in the right place. The only solution is to temporarily
|
|
10
|
+
* remove the `draggable` attribute clicking inside `contenteditable` elements.
|
|
11
|
+
*
|
|
12
|
+
* @return {Function} Cleanup function.
|
|
13
|
+
*/
|
|
14
|
+
export function useFirefoxDraggableCompatibility() {
|
|
15
|
+
return useRefEffect( ( node ) => {
|
|
16
|
+
function onDown( event ) {
|
|
17
|
+
node.draggable = ! event.target.isContentEditable;
|
|
18
|
+
}
|
|
19
|
+
const { ownerDocument } = node;
|
|
20
|
+
ownerDocument.addEventListener( 'pointerdown', onDown );
|
|
21
|
+
return () => {
|
|
22
|
+
ownerDocument.removeEventListener( 'pointerdown', onDown );
|
|
23
|
+
};
|
|
24
|
+
}, [] );
|
|
25
|
+
}
|
|
@@ -5,12 +5,15 @@ import { isTextField } from '@wordpress/dom';
|
|
|
5
5
|
import { ENTER, BACKSPACE, DELETE } from '@wordpress/keycodes';
|
|
6
6
|
import { useSelect, useDispatch } from '@wordpress/data';
|
|
7
7
|
import { useRefEffect } from '@wordpress/compose';
|
|
8
|
+
import { createRoot } from '@wordpress/element';
|
|
9
|
+
import { store as blocksStore } from '@wordpress/blocks';
|
|
8
10
|
|
|
9
11
|
/**
|
|
10
12
|
* Internal dependencies
|
|
11
13
|
*/
|
|
12
14
|
import { store as blockEditorStore } from '../../../store';
|
|
13
15
|
import { unlock } from '../../../lock-unlock';
|
|
16
|
+
import BlockDraggableChip from '../../../components/block-draggable/draggable-chip';
|
|
14
17
|
|
|
15
18
|
/**
|
|
16
19
|
* Adds block behaviour:
|
|
@@ -21,12 +24,16 @@ import { unlock } from '../../../lock-unlock';
|
|
|
21
24
|
* @param {string} clientId Block client ID.
|
|
22
25
|
*/
|
|
23
26
|
export function useEventHandlers( { clientId, isSelected } ) {
|
|
24
|
-
const {
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
const {
|
|
28
|
-
|
|
29
|
-
|
|
27
|
+
const { getBlockType } = useSelect( blocksStore );
|
|
28
|
+
const { getBlockRootClientId, isZoomOut, hasMultiSelection, getBlockName } =
|
|
29
|
+
unlock( useSelect( blockEditorStore ) );
|
|
30
|
+
const {
|
|
31
|
+
insertAfterBlock,
|
|
32
|
+
removeBlock,
|
|
33
|
+
resetZoomLevel,
|
|
34
|
+
startDraggingBlocks,
|
|
35
|
+
stopDraggingBlocks,
|
|
36
|
+
} = unlock( useDispatch( blockEditorStore ) );
|
|
30
37
|
|
|
31
38
|
return useRefEffect(
|
|
32
39
|
( node ) => {
|
|
@@ -76,7 +83,102 @@ export function useEventHandlers( { clientId, isSelected } ) {
|
|
|
76
83
|
* @param {DragEvent} event Drag event.
|
|
77
84
|
*/
|
|
78
85
|
function onDragStart( event ) {
|
|
79
|
-
|
|
86
|
+
if (
|
|
87
|
+
node !== event.target ||
|
|
88
|
+
node.isContentEditable ||
|
|
89
|
+
node.ownerDocument.activeElement !== node ||
|
|
90
|
+
hasMultiSelection()
|
|
91
|
+
) {
|
|
92
|
+
event.preventDefault();
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
const data = JSON.stringify( {
|
|
96
|
+
type: 'block',
|
|
97
|
+
srcClientIds: [ clientId ],
|
|
98
|
+
srcRootClientId: getBlockRootClientId( clientId ),
|
|
99
|
+
} );
|
|
100
|
+
event.dataTransfer.effectAllowed = 'move'; // remove "+" cursor
|
|
101
|
+
event.dataTransfer.clearData();
|
|
102
|
+
event.dataTransfer.setData( 'wp-blocks', data );
|
|
103
|
+
const { ownerDocument } = node;
|
|
104
|
+
const { defaultView } = ownerDocument;
|
|
105
|
+
const selection = defaultView.getSelection();
|
|
106
|
+
selection.removeAllRanges();
|
|
107
|
+
|
|
108
|
+
const domNode = document.createElement( 'div' );
|
|
109
|
+
const root = createRoot( domNode );
|
|
110
|
+
root.render(
|
|
111
|
+
<BlockDraggableChip
|
|
112
|
+
icon={ getBlockType( getBlockName( clientId ) ).icon }
|
|
113
|
+
/>
|
|
114
|
+
);
|
|
115
|
+
document.body.appendChild( domNode );
|
|
116
|
+
domNode.style.position = 'absolute';
|
|
117
|
+
domNode.style.top = '0';
|
|
118
|
+
domNode.style.left = '0';
|
|
119
|
+
domNode.style.zIndex = '1000';
|
|
120
|
+
domNode.style.pointerEvents = 'none';
|
|
121
|
+
|
|
122
|
+
// Setting the drag chip as the drag image actually works, but
|
|
123
|
+
// the behaviour is slightly different in every browser. In
|
|
124
|
+
// Safari, it animates, in Firefox it's slightly transparent...
|
|
125
|
+
// So we set a fake drag image and have to reposition it
|
|
126
|
+
// ourselves.
|
|
127
|
+
const dragElement = ownerDocument.createElement( 'div' );
|
|
128
|
+
// Chrome will show a globe icon if the drag element does not
|
|
129
|
+
// have dimensions.
|
|
130
|
+
dragElement.style.width = '1px';
|
|
131
|
+
dragElement.style.height = '1px';
|
|
132
|
+
dragElement.style.position = 'fixed';
|
|
133
|
+
dragElement.style.visibility = 'hidden';
|
|
134
|
+
ownerDocument.body.appendChild( dragElement );
|
|
135
|
+
event.dataTransfer.setDragImage( dragElement, 0, 0 );
|
|
136
|
+
|
|
137
|
+
let offset = { x: 0, y: 0 };
|
|
138
|
+
|
|
139
|
+
if ( document !== ownerDocument ) {
|
|
140
|
+
const frame = defaultView.frameElement;
|
|
141
|
+
if ( frame ) {
|
|
142
|
+
const rect = frame.getBoundingClientRect();
|
|
143
|
+
offset = { x: rect.left, y: rect.top };
|
|
144
|
+
}
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
// chip handle offset
|
|
148
|
+
offset.x -= 58;
|
|
149
|
+
|
|
150
|
+
function over( e ) {
|
|
151
|
+
domNode.style.transform = `translate( ${
|
|
152
|
+
e.clientX + offset.x
|
|
153
|
+
}px, ${ e.clientY + offset.y }px )`;
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
over( event );
|
|
157
|
+
|
|
158
|
+
function end() {
|
|
159
|
+
ownerDocument.removeEventListener( 'dragover', over );
|
|
160
|
+
ownerDocument.removeEventListener( 'dragend', end );
|
|
161
|
+
domNode.remove();
|
|
162
|
+
dragElement.remove();
|
|
163
|
+
stopDraggingBlocks();
|
|
164
|
+
document.body.classList.remove(
|
|
165
|
+
'is-dragging-components-draggable'
|
|
166
|
+
);
|
|
167
|
+
ownerDocument.documentElement.classList.remove(
|
|
168
|
+
'is-dragging'
|
|
169
|
+
);
|
|
170
|
+
}
|
|
171
|
+
|
|
172
|
+
ownerDocument.addEventListener( 'dragover', over );
|
|
173
|
+
ownerDocument.addEventListener( 'dragend', end );
|
|
174
|
+
ownerDocument.addEventListener( 'drop', end );
|
|
175
|
+
|
|
176
|
+
startDraggingBlocks( [ clientId ] );
|
|
177
|
+
// Important because it hides the block toolbar.
|
|
178
|
+
document.body.classList.add(
|
|
179
|
+
'is-dragging-components-draggable'
|
|
180
|
+
);
|
|
181
|
+
ownerDocument.documentElement.classList.add( 'is-dragging' );
|
|
80
182
|
}
|
|
81
183
|
|
|
82
184
|
node.addEventListener( 'keydown', onKeyDown );
|
|
@@ -91,11 +193,13 @@ export function useEventHandlers( { clientId, isSelected } ) {
|
|
|
91
193
|
clientId,
|
|
92
194
|
isSelected,
|
|
93
195
|
getBlockRootClientId,
|
|
94
|
-
getBlockIndex,
|
|
95
196
|
insertAfterBlock,
|
|
96
197
|
removeBlock,
|
|
97
198
|
isZoomOut,
|
|
98
199
|
resetZoomLevel,
|
|
200
|
+
hasMultiSelection,
|
|
201
|
+
startDraggingBlocks,
|
|
202
|
+
stopDraggingBlocks,
|
|
99
203
|
]
|
|
100
204
|
);
|
|
101
205
|
}
|
|
@@ -41,6 +41,7 @@ function BlockPattern( {
|
|
|
41
41
|
onHover,
|
|
42
42
|
showTitlesAsTooltip,
|
|
43
43
|
category,
|
|
44
|
+
isSelected,
|
|
44
45
|
} ) {
|
|
45
46
|
const [ isDragging, setIsDragging ] = useState( false );
|
|
46
47
|
const { blocks, viewportWidth } = pattern;
|
|
@@ -114,6 +115,7 @@ function BlockPattern( {
|
|
|
114
115
|
pattern.type ===
|
|
115
116
|
INSERTER_PATTERN_TYPES.user &&
|
|
116
117
|
! pattern.syncStatus,
|
|
118
|
+
'is-selected': isSelected,
|
|
117
119
|
}
|
|
118
120
|
) }
|
|
119
121
|
/>
|
|
@@ -192,6 +194,7 @@ function BlockPatternsList(
|
|
|
192
194
|
ref
|
|
193
195
|
) {
|
|
194
196
|
const [ activeCompositeId, setActiveCompositeId ] = useState( undefined );
|
|
197
|
+
const [ activePattern, setActivePattern ] = useState( null ); // State to track active pattern
|
|
195
198
|
|
|
196
199
|
useEffect( () => {
|
|
197
200
|
// Reset the active composite item whenever the available patterns change,
|
|
@@ -201,6 +204,11 @@ function BlockPatternsList(
|
|
|
201
204
|
setActiveCompositeId( firstCompositeItemId );
|
|
202
205
|
}, [ blockPatterns ] );
|
|
203
206
|
|
|
207
|
+
const handleClickPattern = ( pattern, blocks ) => {
|
|
208
|
+
setActivePattern( pattern.name );
|
|
209
|
+
onClickPattern( pattern, blocks );
|
|
210
|
+
};
|
|
211
|
+
|
|
204
212
|
return (
|
|
205
213
|
<Composite
|
|
206
214
|
orientation={ orientation }
|
|
@@ -216,11 +224,14 @@ function BlockPatternsList(
|
|
|
216
224
|
key={ pattern.name }
|
|
217
225
|
id={ pattern.name }
|
|
218
226
|
pattern={ pattern }
|
|
219
|
-
onClick={
|
|
227
|
+
onClick={ handleClickPattern }
|
|
220
228
|
onHover={ onHover }
|
|
221
229
|
isDraggable={ isDraggable }
|
|
222
230
|
showTitlesAsTooltip={ showTitlesAsTooltip }
|
|
223
231
|
category={ category }
|
|
232
|
+
isSelected={
|
|
233
|
+
!! activePattern && activePattern === pattern.name
|
|
234
|
+
}
|
|
224
235
|
/>
|
|
225
236
|
) ) }
|
|
226
237
|
{ pagingProps && <BlockPatternsPaging { ...pagingProps } /> }
|
|
@@ -44,19 +44,29 @@
|
|
|
44
44
|
outline: $border-width solid rgba($black, 0.1);
|
|
45
45
|
outline-offset: -$border-width;
|
|
46
46
|
border-radius: $radius-medium;
|
|
47
|
+
|
|
48
|
+
transition: outline 0.1s linear;
|
|
49
|
+
@include reduce-motion("transition");
|
|
47
50
|
}
|
|
48
51
|
}
|
|
49
52
|
|
|
50
|
-
|
|
53
|
+
// Selected
|
|
54
|
+
&.is-selected .block-editor-block-preview__container::after {
|
|
55
|
+
outline-color: $gray-900;
|
|
56
|
+
outline-width: var(--wp-admin-border-width-focus);
|
|
57
|
+
outline-offset: calc(-1 * var(--wp-admin-border-width-focus));
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
// Hover state
|
|
61
|
+
&:hover .block-editor-block-preview__container::after {
|
|
51
62
|
outline-color: rgba($black, 0.3);
|
|
52
63
|
}
|
|
53
64
|
|
|
54
|
-
|
|
65
|
+
// Focused state
|
|
66
|
+
&[data-focus-visible] .block-editor-block-preview__container::after {
|
|
55
67
|
outline-color: var(--wp-admin-theme-color);
|
|
56
68
|
outline-width: var(--wp-admin-border-width-focus);
|
|
57
|
-
outline-offset: calc(
|
|
58
|
-
transition: outline 0.1s linear;
|
|
59
|
-
@include reduce-motion("transition");
|
|
69
|
+
outline-offset: calc(-1 * var(--wp-admin-border-width-focus));
|
|
60
70
|
}
|
|
61
71
|
|
|
62
72
|
.block-editor-patterns__pattern-details:not(:empty) {
|
|
@@ -68,6 +78,7 @@
|
|
|
68
78
|
.block-editor-patterns__pattern-icon-wrapper {
|
|
69
79
|
min-width: 24px;
|
|
70
80
|
height: 24px;
|
|
81
|
+
|
|
71
82
|
.block-editor-patterns__pattern-icon {
|
|
72
83
|
fill: var(--wp-block-synced-color);
|
|
73
84
|
}
|
|
@@ -148,6 +148,10 @@ function BlockPopoverInbetween( {
|
|
|
148
148
|
? nextRect.left - previousRect.right
|
|
149
149
|
: 0;
|
|
150
150
|
}
|
|
151
|
+
|
|
152
|
+
// Avoid a negative width which happens when the next rect
|
|
153
|
+
// is on the next line.
|
|
154
|
+
width = Math.max( width, 0 );
|
|
151
155
|
}
|
|
152
156
|
|
|
153
157
|
return new window.DOMRect( left, top, width, height );
|
|
@@ -57,6 +57,7 @@ export function BlockSettingsDropdown( {
|
|
|
57
57
|
const currentClientId = block?.clientId;
|
|
58
58
|
const count = clientIds.length;
|
|
59
59
|
const firstBlockClientId = clientIds[ 0 ];
|
|
60
|
+
|
|
60
61
|
const {
|
|
61
62
|
firstParentClientId,
|
|
62
63
|
parentBlockType,
|
|
@@ -64,6 +65,7 @@ export function BlockSettingsDropdown( {
|
|
|
64
65
|
selectedBlockClientIds,
|
|
65
66
|
openedBlockSettingsMenu,
|
|
66
67
|
isContentOnly,
|
|
68
|
+
isZoomOut,
|
|
67
69
|
} = useSelect(
|
|
68
70
|
( select ) => {
|
|
69
71
|
const {
|
|
@@ -74,6 +76,7 @@ export function BlockSettingsDropdown( {
|
|
|
74
76
|
getBlockAttributes,
|
|
75
77
|
getOpenedBlockSettingsMenu,
|
|
76
78
|
getBlockEditingMode,
|
|
79
|
+
isZoomOut: _isZoomOut,
|
|
77
80
|
} = unlock( select( blockEditorStore ) );
|
|
78
81
|
|
|
79
82
|
const { getActiveBlockVariation } = select( blocksStore );
|
|
@@ -98,10 +101,12 @@ export function BlockSettingsDropdown( {
|
|
|
98
101
|
openedBlockSettingsMenu: getOpenedBlockSettingsMenu(),
|
|
99
102
|
isContentOnly:
|
|
100
103
|
getBlockEditingMode( firstBlockClientId ) === 'contentOnly',
|
|
104
|
+
isZoomOut: _isZoomOut(),
|
|
101
105
|
};
|
|
102
106
|
},
|
|
103
107
|
[ firstBlockClientId ]
|
|
104
108
|
);
|
|
109
|
+
|
|
105
110
|
const { getBlockOrder, getSelectedBlockClientIds } =
|
|
106
111
|
useSelect( blockEditorStore );
|
|
107
112
|
|
|
@@ -248,7 +253,7 @@ export function BlockSettingsDropdown( {
|
|
|
248
253
|
clientId={ firstBlockClientId }
|
|
249
254
|
/>
|
|
250
255
|
) }
|
|
251
|
-
{ ! isContentOnly && (
|
|
256
|
+
{ ( ! isContentOnly || isZoomOut ) && (
|
|
252
257
|
<CopyMenuItem
|
|
253
258
|
clientIds={ clientIds }
|
|
254
259
|
onCopy={ onCopy }
|
|
@@ -55,7 +55,8 @@ const BlockSettingsMenuControlsSlot = ( { fillProps, clientIds = null } ) => {
|
|
|
55
55
|
const convertToGroupButtonProps =
|
|
56
56
|
useConvertToGroupButtonProps( selectedClientIds );
|
|
57
57
|
const { isGroupable, isUngroupable } = convertToGroupButtonProps;
|
|
58
|
-
const showConvertToGroupButton =
|
|
58
|
+
const showConvertToGroupButton =
|
|
59
|
+
( isGroupable || isUngroupable ) && ! isContentOnly;
|
|
59
60
|
|
|
60
61
|
return (
|
|
61
62
|
<Slot
|