@wordpress/block-library 8.22.0 → 8.24.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 +4 -0
- package/build/block/edit.js +11 -13
- package/build/block/edit.js.map +1 -1
- package/build/block/edit.native.js +3 -4
- package/build/block/edit.native.js.map +1 -1
- package/build/button/edit.js +61 -9
- package/build/button/edit.js.map +1 -1
- package/build/code/transforms.js +20 -7
- package/build/code/transforms.js.map +1 -1
- package/build/column/edit.js +1 -1
- package/build/column/edit.js.map +1 -1
- package/build/column/edit.native.js +1 -1
- package/build/column/edit.native.js.map +1 -1
- package/build/comments/edit/comments-inspector-controls.js +1 -0
- package/build/comments/edit/comments-inspector-controls.js.map +1 -1
- package/build/cover/edit/index.js +2 -1
- package/build/cover/edit/index.js.map +1 -1
- package/build/cover/edit/inspector-controls.js +1 -0
- package/build/cover/edit/inspector-controls.js.map +1 -1
- package/build/details/edit.js +1 -2
- package/build/details/edit.js.map +1 -1
- package/build/file/edit.js +8 -9
- package/build/file/edit.js.map +1 -1
- package/build/file/view.js +4 -6
- package/build/file/view.js.map +1 -1
- package/build/form/index.js +1 -1
- package/build/form/index.js.map +1 -1
- package/build/form-submit-button/edit.js +2 -1
- package/build/form-submit-button/edit.js.map +1 -1
- package/build/gallery/gap-styles.js +12 -7
- package/build/gallery/gap-styles.js.map +1 -1
- package/build/group/edit.js +4 -7
- package/build/group/edit.js.map +1 -1
- package/build/html/transforms.js +7 -2
- package/build/html/transforms.js.map +1 -1
- package/build/image/deprecated.js +8 -0
- package/build/image/deprecated.js.map +1 -1
- package/build/image/edit.js +17 -18
- package/build/image/edit.js.map +1 -1
- package/build/image/edit.native.js +22 -15
- package/build/image/edit.native.js.map +1 -1
- package/build/image/image.js +35 -27
- package/build/image/image.js.map +1 -1
- package/build/image/index.js +2 -3
- package/build/image/index.js.map +1 -1
- package/build/image/view.js +234 -266
- package/build/image/view.js.map +1 -1
- package/build/missing/index.js +1 -1
- package/build/navigation/edit/overlay-menu-preview.js +1 -1
- package/build/navigation/edit/overlay-menu-preview.js.map +1 -1
- package/build/navigation/use-template-part-area-label.js +2 -1
- package/build/navigation/use-template-part-area-label.js.map +1 -1
- package/build/navigation/view.js +153 -176
- package/build/navigation/view.js.map +1 -1
- package/build/navigation-link/edit.js +1 -1
- package/build/navigation-link/edit.js.map +1 -1
- package/build/navigation-link/index.js +2 -1
- package/build/navigation-link/index.js.map +1 -1
- package/build/pattern/edit.js +2 -4
- package/build/pattern/edit.js.map +1 -1
- package/build/post-author/edit.js +0 -1
- package/build/post-author/edit.js.map +1 -1
- package/build/post-featured-image/edit.js +21 -6
- package/build/post-featured-image/edit.js.map +1 -1
- package/build/post-template/edit.js +2 -8
- package/build/post-template/edit.js.map +1 -1
- package/build/post-template/index.js +1 -1
- package/build/post-terms/edit.js +0 -2
- package/build/post-terms/edit.js.map +1 -1
- package/build/preformatted/transforms.js +1 -4
- package/build/preformatted/transforms.js.map +1 -1
- package/build/query/edit/query-content.js +1 -0
- package/build/query/edit/query-content.js.map +1 -1
- package/build/query/view.js +52 -60
- package/build/query/view.js.map +1 -1
- package/build/quote/index.js +6 -0
- package/build/quote/index.js.map +1 -1
- package/build/search/view.js +66 -74
- package/build/search/view.js.map +1 -1
- package/build/template-part/edit/advanced-controls.js +1 -0
- package/build/template-part/edit/advanced-controls.js.map +1 -1
- package/build/template-part/edit/index.js +3 -7
- package/build/template-part/edit/index.js.map +1 -1
- package/build/template-part/index.js +6 -2
- package/build/template-part/index.js.map +1 -1
- package/build/template-part/variations.js +5 -1
- package/build/template-part/variations.js.map +1 -1
- package/build/utils/remove-anchor-tag.js +17 -0
- package/build/utils/remove-anchor-tag.js.map +1 -0
- package/build-module/block/edit.js +11 -13
- package/build-module/block/edit.js.map +1 -1
- package/build-module/block/edit.native.js +3 -4
- package/build-module/block/edit.native.js.map +1 -1
- package/build-module/button/edit.js +65 -13
- package/build-module/button/edit.js.map +1 -1
- package/build-module/code/transforms.js +20 -7
- package/build-module/code/transforms.js.map +1 -1
- package/build-module/column/edit.js +1 -1
- package/build-module/column/edit.js.map +1 -1
- package/build-module/column/edit.native.js +1 -1
- package/build-module/column/edit.native.js.map +1 -1
- package/build-module/comments/edit/comments-inspector-controls.js +1 -0
- package/build-module/comments/edit/comments-inspector-controls.js.map +1 -1
- package/build-module/cover/edit/index.js +2 -1
- package/build-module/cover/edit/index.js.map +1 -1
- package/build-module/cover/edit/inspector-controls.js +1 -0
- package/build-module/cover/edit/inspector-controls.js.map +1 -1
- package/build-module/details/edit.js +1 -2
- package/build-module/details/edit.js.map +1 -1
- package/build-module/file/edit.js +8 -9
- package/build-module/file/edit.js.map +1 -1
- package/build-module/file/view.js +5 -7
- package/build-module/file/view.js.map +1 -1
- package/build-module/form/index.js +1 -1
- package/build-module/form/index.js.map +1 -1
- package/build-module/form-submit-button/edit.js +2 -1
- package/build-module/form-submit-button/edit.js.map +1 -1
- package/build-module/gallery/gap-styles.js +13 -8
- package/build-module/gallery/gap-styles.js.map +1 -1
- package/build-module/group/edit.js +4 -7
- package/build-module/group/edit.js.map +1 -1
- package/build-module/html/transforms.js +7 -2
- package/build-module/html/transforms.js.map +1 -1
- package/build-module/image/deprecated.js +8 -0
- package/build-module/image/deprecated.js.map +1 -1
- package/build-module/image/edit.js +18 -19
- package/build-module/image/edit.js.map +1 -1
- package/build-module/image/edit.native.js +23 -16
- package/build-module/image/edit.native.js.map +1 -1
- package/build-module/image/image.js +36 -28
- package/build-module/image/image.js.map +1 -1
- package/build-module/image/index.js +2 -3
- package/build-module/image/index.js.map +1 -1
- package/build-module/image/view.js +235 -267
- package/build-module/image/view.js.map +1 -1
- package/build-module/missing/index.js +1 -1
- package/build-module/navigation/edit/overlay-menu-preview.js +1 -1
- package/build-module/navigation/edit/overlay-menu-preview.js.map +1 -1
- package/build-module/navigation/use-template-part-area-label.js +2 -1
- package/build-module/navigation/use-template-part-area-label.js.map +1 -1
- package/build-module/navigation/view.js +154 -177
- package/build-module/navigation/view.js.map +1 -1
- package/build-module/navigation-link/edit.js +2 -2
- package/build-module/navigation-link/edit.js.map +1 -1
- package/build-module/navigation-link/index.js +2 -1
- package/build-module/navigation-link/index.js.map +1 -1
- package/build-module/pattern/edit.js +2 -4
- package/build-module/pattern/edit.js.map +1 -1
- package/build-module/post-author/edit.js +0 -1
- package/build-module/post-author/edit.js.map +1 -1
- package/build-module/post-featured-image/edit.js +21 -6
- package/build-module/post-featured-image/edit.js.map +1 -1
- package/build-module/post-template/edit.js +2 -8
- package/build-module/post-template/edit.js.map +1 -1
- package/build-module/post-template/index.js +1 -1
- package/build-module/post-terms/edit.js +0 -2
- package/build-module/post-terms/edit.js.map +1 -1
- package/build-module/preformatted/transforms.js +1 -4
- package/build-module/preformatted/transforms.js.map +1 -1
- package/build-module/query/edit/query-content.js +1 -0
- package/build-module/query/edit/query-content.js.map +1 -1
- package/build-module/query/view.js +53 -61
- package/build-module/query/view.js.map +1 -1
- package/build-module/quote/index.js +6 -0
- package/build-module/quote/index.js.map +1 -1
- package/build-module/search/view.js +67 -75
- package/build-module/search/view.js.map +1 -1
- package/build-module/template-part/edit/advanced-controls.js +1 -0
- package/build-module/template-part/edit/advanced-controls.js.map +1 -1
- package/build-module/template-part/edit/index.js +5 -9
- package/build-module/template-part/edit/index.js.map +1 -1
- package/build-module/template-part/index.js +6 -2
- package/build-module/template-part/index.js.map +1 -1
- package/build-module/template-part/variations.js +5 -1
- package/build-module/template-part/variations.js.map +1 -1
- package/build-module/utils/remove-anchor-tag.js +11 -0
- package/build-module/utils/remove-anchor-tag.js.map +1 -0
- package/build-style/cover/style-rtl.css +14 -14
- package/build-style/cover/style.css +14 -14
- package/build-style/editor-rtl.css +15 -6
- package/build-style/editor.css +15 -6
- package/build-style/gallery/style-rtl.css +28 -0
- package/build-style/gallery/style.css +28 -0
- package/build-style/image/style-rtl.css +19 -13
- package/build-style/image/style.css +19 -13
- package/build-style/post-featured-image/editor-rtl.css +9 -0
- package/build-style/post-featured-image/editor.css +9 -0
- package/build-style/quote/style-rtl.css +3 -0
- package/build-style/quote/style.css +3 -0
- package/build-style/read-more/style-rtl.css +2 -2
- package/build-style/read-more/style.css +2 -2
- package/build-style/style-rtl.css +66 -29
- package/build-style/style.css +66 -29
- package/package.json +32 -32
- package/src/block/edit.js +20 -20
- package/src/block/edit.native.js +5 -13
- package/src/button/edit.js +76 -10
- package/src/buttons/test/__snapshots__/edit.native.js.snap +0 -6
- package/src/buttons/test/edit.native.js +0 -27
- package/src/code/transforms.js +14 -8
- package/src/column/edit.js +1 -1
- package/src/column/edit.native.js +1 -1
- package/src/comments/edit/comments-inspector-controls.js +1 -0
- package/src/cover/edit/index.js +1 -0
- package/src/cover/edit/inspector-controls.js +1 -0
- package/src/cover/style.scss +1 -1
- package/src/cover/test/edit.js +1 -1
- package/src/details/edit.js +0 -1
- package/src/editor.scss +6 -6
- package/src/file/edit.js +11 -10
- package/src/file/index.php +30 -11
- package/src/file/view.js +5 -7
- package/src/form/index.js +1 -1
- package/src/form-submit-button/edit.js +1 -0
- package/src/gallery/gap-styles.js +10 -9
- package/src/gallery/style.scss +1 -0
- package/src/group/edit.js +4 -11
- package/src/heading/test/__snapshots__/index.native.js.snap +6 -0
- package/src/heading/test/index.native.js +40 -0
- package/src/html/transforms.js +5 -2
- package/src/image/block.json +2 -3
- package/src/image/deprecated.js +8 -0
- package/src/image/edit.js +16 -21
- package/src/image/edit.native.js +17 -18
- package/src/image/image.js +48 -51
- package/src/image/index.php +57 -49
- package/src/image/style.scss +18 -13
- package/src/image/view.js +281 -324
- package/src/missing/block.json +1 -1
- package/src/navigation/edit/overlay-menu-preview.js +1 -1
- package/src/navigation/index.php +46 -402
- package/src/navigation/use-template-part-area-label.js +4 -2
- package/src/navigation/view.js +159 -192
- package/src/navigation-link/block.json +2 -1
- package/src/navigation-link/edit.js +2 -2
- package/src/navigation-link/index.php +57 -0
- package/src/paragraph/test/__snapshots__/transforms.native.js.snap +6 -0
- package/src/paragraph/test/edit.native.js +37 -1
- package/src/paragraph/test/transforms.native.js +1 -0
- package/src/pattern/edit.js +7 -4
- package/src/pattern/index.php +6 -1
- package/src/post-author/edit.js +0 -1
- package/src/post-featured-image/edit.js +38 -5
- package/src/post-featured-image/editor.scss +19 -0
- package/src/post-template/block.json +0 -1
- package/src/post-template/edit.js +1 -5
- package/src/post-terms/edit.js +0 -2
- package/src/preformatted/transforms.js +1 -4
- package/src/query/edit/query-content.js +1 -0
- package/src/query/index.php +42 -24
- package/src/query/view.js +58 -65
- package/src/query-pagination-next/index.php +3 -3
- package/src/query-pagination-numbers/index.php +1 -1
- package/src/query-pagination-previous/index.php +3 -3
- package/src/quote/block.json +6 -0
- package/src/quote/style.scss +4 -0
- package/src/read-more/style.scss +1 -1
- package/src/search/index.php +40 -40
- package/src/search/view.js +58 -63
- package/src/template-part/edit/advanced-controls.js +1 -0
- package/src/template-part/edit/index.js +7 -14
- package/src/template-part/index.js +4 -3
- package/src/template-part/index.php +4 -4
- package/src/template-part/variations.js +4 -2
- package/src/utils/remove-anchor-tag.js +10 -0
- package/tsconfig.json +1 -0
package/src/search/view.js
CHANGED
|
@@ -1,73 +1,68 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* WordPress dependencies
|
|
3
3
|
*/
|
|
4
|
-
import { store
|
|
4
|
+
import { store, getContext, getElement } from '@wordpress/interactivity';
|
|
5
5
|
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
? '0'
|
|
30
|
-
: '-1';
|
|
31
|
-
},
|
|
32
|
-
},
|
|
6
|
+
const { actions } = store( 'core/search', {
|
|
7
|
+
state: {
|
|
8
|
+
get ariaLabel() {
|
|
9
|
+
const {
|
|
10
|
+
isSearchInputVisible,
|
|
11
|
+
ariaLabelCollapsed,
|
|
12
|
+
ariaLabelExpanded,
|
|
13
|
+
} = getContext();
|
|
14
|
+
return isSearchInputVisible
|
|
15
|
+
? ariaLabelExpanded
|
|
16
|
+
: ariaLabelCollapsed;
|
|
17
|
+
},
|
|
18
|
+
get ariaControls() {
|
|
19
|
+
const { isSearchInputVisible, inputId } = getContext();
|
|
20
|
+
return isSearchInputVisible ? null : inputId;
|
|
21
|
+
},
|
|
22
|
+
get type() {
|
|
23
|
+
const { isSearchInputVisible } = getContext();
|
|
24
|
+
return isSearchInputVisible ? 'submit' : 'button';
|
|
25
|
+
},
|
|
26
|
+
get tabindex() {
|
|
27
|
+
const { isSearchInputVisible } = getContext();
|
|
28
|
+
return isSearchInputVisible ? '0' : '-1';
|
|
33
29
|
},
|
|
34
30
|
},
|
|
35
31
|
actions: {
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
},
|
|
32
|
+
openSearchInput( event ) {
|
|
33
|
+
const ctx = getContext();
|
|
34
|
+
const { ref } = getElement();
|
|
35
|
+
if ( ! ctx.isSearchInputVisible ) {
|
|
36
|
+
event.preventDefault();
|
|
37
|
+
ctx.isSearchInputVisible = true;
|
|
38
|
+
ref.parentElement.querySelector( 'input' ).focus();
|
|
39
|
+
}
|
|
40
|
+
},
|
|
41
|
+
closeSearchInput() {
|
|
42
|
+
const ctx = getContext();
|
|
43
|
+
ctx.isSearchInputVisible = false;
|
|
44
|
+
},
|
|
45
|
+
handleSearchKeydown( event ) {
|
|
46
|
+
const { ref } = getElement();
|
|
47
|
+
// If Escape close the menu.
|
|
48
|
+
if ( event?.key === 'Escape' ) {
|
|
49
|
+
actions.closeSearchInput();
|
|
50
|
+
ref.querySelector( 'button' ).focus();
|
|
51
|
+
}
|
|
52
|
+
},
|
|
53
|
+
handleSearchFocusout( event ) {
|
|
54
|
+
const { ref } = getElement();
|
|
55
|
+
// If focus is outside search form, and in the document, close menu
|
|
56
|
+
// event.target === The element losing focus
|
|
57
|
+
// event.relatedTarget === The element receiving focus (if any)
|
|
58
|
+
// When focusout is outside the document,
|
|
59
|
+
// `window.document.activeElement` doesn't change.
|
|
60
|
+
if (
|
|
61
|
+
! ref.contains( event.relatedTarget ) &&
|
|
62
|
+
event.target !== window.document.activeElement
|
|
63
|
+
) {
|
|
64
|
+
actions.closeSearchInput();
|
|
65
|
+
}
|
|
71
66
|
},
|
|
72
67
|
},
|
|
73
68
|
} );
|
|
@@ -4,7 +4,6 @@
|
|
|
4
4
|
import { useSelect } from '@wordpress/data';
|
|
5
5
|
import {
|
|
6
6
|
BlockSettingsMenuControls,
|
|
7
|
-
BlockTitle,
|
|
8
7
|
useBlockProps,
|
|
9
8
|
Warning,
|
|
10
9
|
store as blockEditorStore,
|
|
@@ -14,7 +13,7 @@ import {
|
|
|
14
13
|
import { Spinner, Modal, MenuItem } from '@wordpress/components';
|
|
15
14
|
import { __, sprintf } from '@wordpress/i18n';
|
|
16
15
|
import { store as coreStore } from '@wordpress/core-data';
|
|
17
|
-
import { useState
|
|
16
|
+
import { useState } from '@wordpress/element';
|
|
18
17
|
|
|
19
18
|
/**
|
|
20
19
|
* Internal dependencies
|
|
@@ -35,7 +34,11 @@ export default function TemplatePartEdit( {
|
|
|
35
34
|
setAttributes,
|
|
36
35
|
clientId,
|
|
37
36
|
} ) {
|
|
38
|
-
const
|
|
37
|
+
const currentTheme = useSelect(
|
|
38
|
+
( select ) => select( coreStore ).getCurrentTheme()?.stylesheet,
|
|
39
|
+
[]
|
|
40
|
+
);
|
|
41
|
+
const { slug, theme = currentTheme, tagName, layout = {} } = attributes;
|
|
39
42
|
const templatePartId = createTemplatePartId( theme, slug );
|
|
40
43
|
const hasAlreadyRendered = useHasRecursion( templatePartId );
|
|
41
44
|
const [ isTemplatePartSelectionOpen, setIsTemplatePartSelectionOpen ] =
|
|
@@ -174,17 +177,7 @@ export default function TemplatePartEdit( {
|
|
|
174
177
|
}
|
|
175
178
|
aria-haspopup="dialog"
|
|
176
179
|
>
|
|
177
|
-
{
|
|
178
|
-
__( 'Replace <BlockTitle />' ),
|
|
179
|
-
{
|
|
180
|
-
BlockTitle: (
|
|
181
|
-
<BlockTitle
|
|
182
|
-
clientId={ clientId }
|
|
183
|
-
maximumLength={ 25 }
|
|
184
|
-
/>
|
|
185
|
-
),
|
|
186
|
-
}
|
|
187
|
-
) }
|
|
180
|
+
{ __( 'Replace' ) }
|
|
188
181
|
</MenuItem>
|
|
189
182
|
);
|
|
190
183
|
} }
|
|
@@ -32,10 +32,11 @@ export const settings = {
|
|
|
32
32
|
return;
|
|
33
33
|
}
|
|
34
34
|
|
|
35
|
-
const
|
|
35
|
+
const { getCurrentTheme, getEntityRecord } = select( coreDataStore );
|
|
36
|
+
const entity = getEntityRecord(
|
|
36
37
|
'postType',
|
|
37
38
|
'wp_template_part',
|
|
38
|
-
theme + '//' + slug
|
|
39
|
+
( theme || getCurrentTheme()?.stylesheet ) + '//' + slug
|
|
39
40
|
);
|
|
40
41
|
if ( ! entity ) {
|
|
41
42
|
return;
|
|
@@ -60,7 +61,7 @@ export const init = () => {
|
|
|
60
61
|
const DISALLOWED_PARENTS = [ 'core/post-template', 'core/post-content' ];
|
|
61
62
|
addFilter(
|
|
62
63
|
'blockEditor.__unstableCanInsertBlockType',
|
|
63
|
-
'removeTemplatePartsFromPostTemplates',
|
|
64
|
+
'core/block-library/removeTemplatePartsFromPostTemplates',
|
|
64
65
|
(
|
|
65
66
|
canInsert,
|
|
66
67
|
blockType,
|
|
@@ -43,10 +43,10 @@ function render_block_core_template_part( $attributes ) {
|
|
|
43
43
|
if ( $template_part_post ) {
|
|
44
44
|
// A published post might already exist if this template part was customized elsewhere
|
|
45
45
|
// or if it's part of a customized template.
|
|
46
|
-
$
|
|
47
|
-
$
|
|
48
|
-
if (
|
|
49
|
-
$area = $
|
|
46
|
+
$block_template = _build_block_template_result_from_post( $template_part_post );
|
|
47
|
+
$content = $block_template->content;
|
|
48
|
+
if ( isset( $block_template->area ) ) {
|
|
49
|
+
$area = $block_template->area;
|
|
50
50
|
}
|
|
51
51
|
/**
|
|
52
52
|
* Fires when a block template part is loaded from a template post stored in the database.
|
|
@@ -35,10 +35,12 @@ export function enhanceTemplatePartVariations( settings, name ) {
|
|
|
35
35
|
// Find a matching variation from the created template part
|
|
36
36
|
// by checking the entity's `area` property.
|
|
37
37
|
if ( ! slug ) return false;
|
|
38
|
-
const
|
|
38
|
+
const { getCurrentTheme, getEntityRecord } =
|
|
39
|
+
select( coreDataStore );
|
|
40
|
+
const entity = getEntityRecord(
|
|
39
41
|
'postType',
|
|
40
42
|
'wp_template_part',
|
|
41
|
-
`${ theme }//${ slug }`
|
|
43
|
+
`${ theme || getCurrentTheme()?.stylesheet }//${ slug }`
|
|
42
44
|
);
|
|
43
45
|
|
|
44
46
|
if ( entity?.slug ) {
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Removes anchor tags from a string.
|
|
3
|
+
*
|
|
4
|
+
* @param {string} value The value to remove anchor tags from.
|
|
5
|
+
*
|
|
6
|
+
* @return {string} The value with anchor tags removed.
|
|
7
|
+
*/
|
|
8
|
+
export default function removeAnchorTag( value ) {
|
|
9
|
+
return value.replace( /<\/?a[^>]*>/g, '' );
|
|
10
|
+
}
|