@wordpress/block-editor 14.8.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/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 +7 -6
- 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/use-scale-canvas.js +68 -47
- package/build/components/iframe/use-scale-canvas.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 +7 -6
- 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/use-scale-canvas.js +68 -47
- package/build-module/components/iframe/use-scale-canvas.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 +17 -4
- package/build-style/content.css +17 -4
- package/build-style/style-rtl.css +21 -16
- package/build-style/style.css +21 -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-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 +8 -6
- package/src/components/block-tools/style.scss +5 -0
- package/src/components/block-vertical-alignment-control/test/__snapshots__/index.js.snap +3 -3
- 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 +6 -1
- package/src/components/iframe/use-scale-canvas.js +103 -81
- 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
|
@@ -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
|
|
@@ -18,6 +18,7 @@ import {
|
|
|
18
18
|
} from '@wordpress/blocks';
|
|
19
19
|
import { useSelect, useDispatch } from '@wordpress/data';
|
|
20
20
|
import { copy } from '@wordpress/icons';
|
|
21
|
+
import { store as preferencesStore } from '@wordpress/preferences';
|
|
21
22
|
|
|
22
23
|
/**
|
|
23
24
|
* Internal dependencies
|
|
@@ -185,21 +186,6 @@ function BlockSwitcherDropdownMenuContents( {
|
|
|
185
186
|
);
|
|
186
187
|
}
|
|
187
188
|
|
|
188
|
-
const BlockIndicator = ( { icon, showTitle, blockTitle } ) => (
|
|
189
|
-
<>
|
|
190
|
-
<BlockIcon
|
|
191
|
-
className="block-editor-block-switcher__toggle"
|
|
192
|
-
icon={ icon }
|
|
193
|
-
showColors
|
|
194
|
-
/>
|
|
195
|
-
{ showTitle && blockTitle && (
|
|
196
|
-
<span className="block-editor-block-switcher__toggle-text">
|
|
197
|
-
{ blockTitle }
|
|
198
|
-
</span>
|
|
199
|
-
) }
|
|
200
|
-
</>
|
|
201
|
-
);
|
|
202
|
-
|
|
203
189
|
export const BlockSwitcher = ( { clientIds } ) => {
|
|
204
190
|
const {
|
|
205
191
|
hasContentOnlyLocking,
|
|
@@ -272,6 +258,11 @@ export const BlockSwitcher = ( { clientIds } ) => {
|
|
|
272
258
|
clientId: clientIds?.[ 0 ],
|
|
273
259
|
maximumLength: 35,
|
|
274
260
|
} );
|
|
261
|
+
const showIconLabels = useSelect(
|
|
262
|
+
( select ) =>
|
|
263
|
+
select( preferencesStore ).get( 'core', 'showIconLabels' ),
|
|
264
|
+
[]
|
|
265
|
+
);
|
|
275
266
|
|
|
276
267
|
if ( invalidBlocks ) {
|
|
277
268
|
return null;
|
|
@@ -282,6 +273,11 @@ export const BlockSwitcher = ( { clientIds } ) => {
|
|
|
282
273
|
? blockTitle
|
|
283
274
|
: __( 'Multiple blocks selected' );
|
|
284
275
|
|
|
276
|
+
const blockIndicatorText =
|
|
277
|
+
( isReusable || isTemplate ) && ! showIconLabels && blockTitle
|
|
278
|
+
? blockTitle
|
|
279
|
+
: undefined;
|
|
280
|
+
|
|
285
281
|
const hideDropdown =
|
|
286
282
|
isDisabled ||
|
|
287
283
|
( ! hasBlockStyles && ! canRemove ) ||
|
|
@@ -295,12 +291,13 @@ export const BlockSwitcher = ( { clientIds } ) => {
|
|
|
295
291
|
className="block-editor-block-switcher__no-switcher-icon"
|
|
296
292
|
title={ blockSwitcherLabel }
|
|
297
293
|
icon={
|
|
298
|
-
<
|
|
294
|
+
<BlockIcon
|
|
295
|
+
className="block-editor-block-switcher__toggle"
|
|
299
296
|
icon={ icon }
|
|
300
|
-
|
|
301
|
-
blockTitle={ blockTitle }
|
|
297
|
+
showColors
|
|
302
298
|
/>
|
|
303
299
|
}
|
|
300
|
+
text={ blockIndicatorText }
|
|
304
301
|
/>
|
|
305
302
|
</ToolbarGroup>
|
|
306
303
|
);
|
|
@@ -329,12 +326,13 @@ export const BlockSwitcher = ( { clientIds } ) => {
|
|
|
329
326
|
className: 'block-editor-block-switcher__popover',
|
|
330
327
|
} }
|
|
331
328
|
icon={
|
|
332
|
-
<
|
|
329
|
+
<BlockIcon
|
|
330
|
+
className="block-editor-block-switcher__toggle"
|
|
333
331
|
icon={ icon }
|
|
334
|
-
|
|
335
|
-
blockTitle={ blockTitle }
|
|
332
|
+
showColors
|
|
336
333
|
/>
|
|
337
334
|
}
|
|
335
|
+
text={ blockIndicatorText }
|
|
338
336
|
toggleProps={ {
|
|
339
337
|
description: blockSwitcherDescription,
|
|
340
338
|
...toggleProps,
|
|
@@ -26,15 +26,6 @@
|
|
|
26
26
|
}
|
|
27
27
|
}
|
|
28
28
|
|
|
29
|
-
.block-editor-block-switcher__toggle-text {
|
|
30
|
-
margin-left: $grid-unit-10;
|
|
31
|
-
|
|
32
|
-
// Account for double label when show-text-buttons is set.
|
|
33
|
-
.show-icon-labels & {
|
|
34
|
-
display: none;
|
|
35
|
-
}
|
|
36
|
-
}
|
|
37
|
-
|
|
38
29
|
.components-button.block-editor-block-switcher__no-switcher-icon {
|
|
39
30
|
display: flex;
|
|
40
31
|
|
|
@@ -31,7 +31,9 @@ const blockLabelMap = {
|
|
|
31
31
|
};
|
|
32
32
|
|
|
33
33
|
jest.mock( '@wordpress/blocks', () => {
|
|
34
|
+
const actualImplementation = jest.requireActual( '@wordpress/blocks' );
|
|
34
35
|
return {
|
|
36
|
+
...actualImplementation,
|
|
35
37
|
isReusableBlock( { title } ) {
|
|
36
38
|
return title === 'Reusable Block';
|
|
37
39
|
},
|
|
@@ -124,6 +124,8 @@ export function PrivateBlockToolbar( {
|
|
|
124
124
|
( id ) => getTemplateLock( id ) === 'contentOnly'
|
|
125
125
|
);
|
|
126
126
|
|
|
127
|
+
const _isZoomOut = isZoomOut();
|
|
128
|
+
|
|
127
129
|
return {
|
|
128
130
|
blockClientId: selectedBlockClientId,
|
|
129
131
|
blockClientIds: selectedBlockClientIds,
|
|
@@ -132,7 +134,7 @@ export function PrivateBlockToolbar( {
|
|
|
132
134
|
shouldShowVisualToolbar: isValid && isVisual,
|
|
133
135
|
toolbarKey: `${ selectedBlockClientId }${ parentClientId }`,
|
|
134
136
|
showParentSelector:
|
|
135
|
-
!
|
|
137
|
+
! _isZoomOut &&
|
|
136
138
|
parentBlockType &&
|
|
137
139
|
getBlockEditingMode( parentClientId ) !== 'disabled' &&
|
|
138
140
|
hasBlockSupport(
|
|
@@ -144,11 +146,11 @@ export function PrivateBlockToolbar( {
|
|
|
144
146
|
isUsingBindings: _isUsingBindings,
|
|
145
147
|
hasParentPattern: _hasParentPattern,
|
|
146
148
|
hasContentOnlyLocking: _hasTemplateLock,
|
|
147
|
-
showShuffleButton:
|
|
148
|
-
showSlots: !
|
|
149
|
-
showGroupButtons: !
|
|
150
|
-
showLockButtons: !
|
|
151
|
-
showSwitchSectionStyleButton:
|
|
149
|
+
showShuffleButton: _isZoomOut,
|
|
150
|
+
showSlots: ! _isZoomOut,
|
|
151
|
+
showGroupButtons: ! _isZoomOut,
|
|
152
|
+
showLockButtons: ! _isZoomOut,
|
|
153
|
+
showSwitchSectionStyleButton: _isZoomOut,
|
|
152
154
|
hasFixedToolbar: getSettings().hasFixedToolbar,
|
|
153
155
|
isNavigationMode: _isNavigationMode(),
|
|
154
156
|
};
|
|
@@ -157,6 +157,11 @@
|
|
|
157
157
|
&:focus::before {
|
|
158
158
|
box-shadow: inset 0 0 0 1px $gray-900, 0 0 0 var(--wp-admin-border-width-focus) var(--wp-admin-theme-color);
|
|
159
159
|
}
|
|
160
|
+
|
|
161
|
+
&:disabled,
|
|
162
|
+
&[aria-disabled="true"] {
|
|
163
|
+
color: $gray-700;
|
|
164
|
+
}
|
|
160
165
|
}
|
|
161
166
|
|
|
162
167
|
.block-editor-block-parent-selector .block-editor-block-parent-selector__button {
|
|
@@ -42,7 +42,7 @@ exports[`BlockVerticalAlignmentUI should match snapshot when controls are visibl
|
|
|
42
42
|
<button
|
|
43
43
|
aria-label="Align top"
|
|
44
44
|
aria-pressed="true"
|
|
45
|
-
class="components-button components-toolbar__control is-pressed has-icon"
|
|
45
|
+
class="components-button components-toolbar__control is-compact is-pressed has-icon"
|
|
46
46
|
data-toolbar-item="true"
|
|
47
47
|
type="button"
|
|
48
48
|
>
|
|
@@ -64,7 +64,7 @@ exports[`BlockVerticalAlignmentUI should match snapshot when controls are visibl
|
|
|
64
64
|
<button
|
|
65
65
|
aria-label="Align middle"
|
|
66
66
|
aria-pressed="false"
|
|
67
|
-
class="components-button components-toolbar__control has-icon"
|
|
67
|
+
class="components-button components-toolbar__control is-compact has-icon"
|
|
68
68
|
data-toolbar-item="true"
|
|
69
69
|
type="button"
|
|
70
70
|
>
|
|
@@ -86,7 +86,7 @@ exports[`BlockVerticalAlignmentUI should match snapshot when controls are visibl
|
|
|
86
86
|
<button
|
|
87
87
|
aria-label="Align bottom"
|
|
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
|
>
|
|
@@ -153,6 +153,7 @@ export default function FontAppearanceControl( props ) {
|
|
|
153
153
|
{ ...otherProps }
|
|
154
154
|
className="components-font-appearance-control"
|
|
155
155
|
__next40pxDefaultSize={ __next40pxDefaultSize }
|
|
156
|
+
__shouldNotWarnDeprecated36pxSize
|
|
156
157
|
label={ label }
|
|
157
158
|
describedBy={ getDescribedBy() }
|
|
158
159
|
options={ selectOptions }
|
|
@@ -1,3 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* External dependencies
|
|
3
|
+
*/
|
|
4
|
+
import clsx from 'clsx';
|
|
5
|
+
|
|
1
6
|
/**
|
|
2
7
|
* WordPress dependencies
|
|
3
8
|
*/
|
|
@@ -18,6 +23,7 @@ export default function FontFamilyControl( {
|
|
|
18
23
|
value = '',
|
|
19
24
|
onChange,
|
|
20
25
|
fontFamilies,
|
|
26
|
+
className,
|
|
21
27
|
...props
|
|
22
28
|
} ) {
|
|
23
29
|
const [ blockLevelFontFamilies ] = useSettings( 'typography.fontFamilies' );
|
|
@@ -55,10 +61,14 @@ export default function FontFamilyControl( {
|
|
|
55
61
|
return (
|
|
56
62
|
<CustomSelectControl
|
|
57
63
|
__next40pxDefaultSize={ __next40pxDefaultSize }
|
|
64
|
+
__shouldNotWarnDeprecated36pxSize
|
|
58
65
|
label={ __( 'Font' ) }
|
|
59
66
|
value={ value }
|
|
60
67
|
onChange={ ( { selectedItem } ) => onChange( selectedItem.key ) }
|
|
61
68
|
options={ options }
|
|
69
|
+
className={ clsx( 'block-editor-font-family-control', className, {
|
|
70
|
+
'is-next-has-no-margin-bottom': __nextHasNoMarginBottom,
|
|
71
|
+
} ) }
|
|
62
72
|
{ ...props }
|
|
63
73
|
/>
|
|
64
74
|
);
|