@wordpress/block-editor 14.6.0 → 14.7.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.
Files changed (187) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/build/components/block-list/block.js +14 -28
  3. package/build/components/block-list/block.js.map +1 -1
  4. package/build/components/block-patterns-list/index.js +23 -26
  5. package/build/components/block-patterns-list/index.js.map +1 -1
  6. package/build/components/block-popover/index.js +1 -1
  7. package/build/components/block-popover/index.js.map +1 -1
  8. package/build/components/block-preview/async.js +51 -0
  9. package/build/components/block-preview/async.js.map +1 -0
  10. package/build/components/block-preview/index.js +4 -1
  11. package/build/components/block-preview/index.js.map +1 -1
  12. package/build/components/block-toolbar/change-design.js +1 -4
  13. package/build/components/block-toolbar/change-design.js.map +1 -1
  14. package/build/components/block-tools/index.js +12 -9
  15. package/build/components/block-tools/index.js.map +1 -1
  16. package/build/components/block-tools/use-block-toolbar-popover-props.js +1 -1
  17. package/build/components/block-tools/use-block-toolbar-popover-props.js.map +1 -1
  18. package/build/components/block-tools/use-show-block-tools.js +4 -1
  19. package/build/components/block-tools/use-show-block-tools.js.map +1 -1
  20. package/build/components/global-styles/dimensions-panel.js +26 -14
  21. package/build/components/global-styles/dimensions-panel.js.map +1 -1
  22. package/build/components/iframe/get-compatibility-styles.js +4 -4
  23. package/build/components/iframe/get-compatibility-styles.js.map +1 -1
  24. package/build/components/iframe/index.js +16 -0
  25. package/build/components/iframe/index.js.map +1 -1
  26. package/build/components/inserter/block-patterns-explorer/pattern-list.js +2 -2
  27. package/build/components/inserter/block-patterns-explorer/pattern-list.js.map +1 -1
  28. package/build/components/inserter/block-patterns-tab/index.js +1 -2
  29. package/build/components/inserter/block-patterns-tab/index.js.map +1 -1
  30. package/build/components/inserter/block-patterns-tab/pattern-category-previews.js +3 -1
  31. package/build/components/inserter/block-patterns-tab/pattern-category-previews.js.map +1 -1
  32. package/build/components/inserter/block-patterns-tab/use-pattern-categories.js +3 -0
  33. package/build/components/inserter/block-patterns-tab/use-pattern-categories.js.map +1 -1
  34. package/build/components/inserter/block-patterns-tab/utils.js +5 -1
  35. package/build/components/inserter/block-patterns-tab/utils.js.map +1 -1
  36. package/build/components/inserter/hooks/use-block-types-state.js +1 -1
  37. package/build/components/inserter/hooks/use-block-types-state.js.map +1 -1
  38. package/build/components/inserter/hooks/use-patterns-paging.js +0 -5
  39. package/build/components/inserter/hooks/use-patterns-paging.js.map +1 -1
  40. package/build/components/inserter/search-results.js +0 -2
  41. package/build/components/inserter/search-results.js.map +1 -1
  42. package/build/components/media-placeholder/index.js +4 -4
  43. package/build/components/media-placeholder/index.js.map +1 -1
  44. package/build/components/rich-text/index.js +1 -1
  45. package/build/components/rich-text/index.js.map +1 -1
  46. package/build/components/tabbed-sidebar/index.js +1 -1
  47. package/build/components/tabbed-sidebar/index.js.map +1 -1
  48. package/build/components/url-input/index.js +3 -1
  49. package/build/components/url-input/index.js.map +1 -1
  50. package/build/components/use-block-commands/index.js +5 -6
  51. package/build/components/use-block-commands/index.js.map +1 -1
  52. package/build/hooks/font-family.js +1 -1
  53. package/build/hooks/font-family.js.map +1 -1
  54. package/build/hooks/supports.js +6 -6
  55. package/build/hooks/supports.js.map +1 -1
  56. package/build/hooks/typography.js +5 -5
  57. package/build/hooks/typography.js.map +1 -1
  58. package/build/hooks/utils.js +2 -2
  59. package/build/hooks/utils.js.map +1 -1
  60. package/build/lock-unlock.js.map +1 -1
  61. package/build/store/private-selectors.js +2 -2
  62. package/build/store/private-selectors.js.map +1 -1
  63. package/build/store/selectors.js +9 -8
  64. package/build/store/selectors.js.map +1 -1
  65. package/build/store/utils.js +5 -4
  66. package/build/store/utils.js.map +1 -1
  67. package/build/utils/dom.js +27 -22
  68. package/build/utils/dom.js.map +1 -1
  69. package/build-module/components/block-list/block.js +15 -27
  70. package/build-module/components/block-list/block.js.map +1 -1
  71. package/build-module/components/block-patterns-list/index.js +23 -26
  72. package/build-module/components/block-patterns-list/index.js.map +1 -1
  73. package/build-module/components/block-popover/index.js +2 -2
  74. package/build-module/components/block-popover/index.js.map +1 -1
  75. package/build-module/components/block-preview/async.js +44 -0
  76. package/build-module/components/block-preview/async.js.map +1 -0
  77. package/build-module/components/block-preview/index.js +4 -1
  78. package/build-module/components/block-preview/index.js.map +1 -1
  79. package/build-module/components/block-toolbar/change-design.js +1 -4
  80. package/build-module/components/block-toolbar/change-design.js.map +1 -1
  81. package/build-module/components/block-tools/index.js +13 -10
  82. package/build-module/components/block-tools/index.js.map +1 -1
  83. package/build-module/components/block-tools/use-block-toolbar-popover-props.js +2 -2
  84. package/build-module/components/block-tools/use-block-toolbar-popover-props.js.map +1 -1
  85. package/build-module/components/block-tools/use-show-block-tools.js +4 -1
  86. package/build-module/components/block-tools/use-show-block-tools.js.map +1 -1
  87. package/build-module/components/global-styles/dimensions-panel.js +26 -14
  88. package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
  89. package/build-module/components/iframe/get-compatibility-styles.js +4 -4
  90. package/build-module/components/iframe/get-compatibility-styles.js.map +1 -1
  91. package/build-module/components/iframe/index.js +16 -0
  92. package/build-module/components/iframe/index.js.map +1 -1
  93. package/build-module/components/inserter/block-patterns-explorer/pattern-list.js +2 -2
  94. package/build-module/components/inserter/block-patterns-explorer/pattern-list.js.map +1 -1
  95. package/build-module/components/inserter/block-patterns-tab/index.js +1 -2
  96. package/build-module/components/inserter/block-patterns-tab/index.js.map +1 -1
  97. package/build-module/components/inserter/block-patterns-tab/pattern-category-previews.js +4 -2
  98. package/build-module/components/inserter/block-patterns-tab/pattern-category-previews.js.map +1 -1
  99. package/build-module/components/inserter/block-patterns-tab/use-pattern-categories.js +4 -1
  100. package/build-module/components/inserter/block-patterns-tab/use-pattern-categories.js.map +1 -1
  101. package/build-module/components/inserter/block-patterns-tab/utils.js +4 -0
  102. package/build-module/components/inserter/block-patterns-tab/utils.js.map +1 -1
  103. package/build-module/components/inserter/hooks/use-block-types-state.js +1 -1
  104. package/build-module/components/inserter/hooks/use-block-types-state.js.map +1 -1
  105. package/build-module/components/inserter/hooks/use-patterns-paging.js +1 -6
  106. package/build-module/components/inserter/hooks/use-patterns-paging.js.map +1 -1
  107. package/build-module/components/inserter/search-results.js +0 -2
  108. package/build-module/components/inserter/search-results.js.map +1 -1
  109. package/build-module/components/media-placeholder/index.js +4 -4
  110. package/build-module/components/media-placeholder/index.js.map +1 -1
  111. package/build-module/components/rich-text/index.js +1 -1
  112. package/build-module/components/rich-text/index.js.map +1 -1
  113. package/build-module/components/tabbed-sidebar/index.js +1 -1
  114. package/build-module/components/tabbed-sidebar/index.js.map +1 -1
  115. package/build-module/components/url-input/index.js +3 -1
  116. package/build-module/components/url-input/index.js.map +1 -1
  117. package/build-module/components/use-block-commands/index.js +4 -4
  118. package/build-module/components/use-block-commands/index.js.map +1 -1
  119. package/build-module/hooks/font-family.js +1 -1
  120. package/build-module/hooks/font-family.js.map +1 -1
  121. package/build-module/hooks/supports.js +6 -6
  122. package/build-module/hooks/supports.js.map +1 -1
  123. package/build-module/hooks/typography.js +5 -5
  124. package/build-module/hooks/typography.js.map +1 -1
  125. package/build-module/hooks/utils.js +2 -2
  126. package/build-module/hooks/utils.js.map +1 -1
  127. package/build-module/lock-unlock.js.map +1 -1
  128. package/build-module/store/private-selectors.js +2 -2
  129. package/build-module/store/private-selectors.js.map +1 -1
  130. package/build-module/store/selectors.js +9 -8
  131. package/build-module/store/selectors.js.map +1 -1
  132. package/build-module/store/utils.js +3 -3
  133. package/build-module/store/utils.js.map +1 -1
  134. package/build-module/utils/dom.js +25 -21
  135. package/build-module/utils/dom.js.map +1 -1
  136. package/build-style/content-rtl.css +7 -6
  137. package/build-style/content.css +7 -6
  138. package/build-style/style-rtl.css +14 -3
  139. package/build-style/style.css +14 -3
  140. package/build-types/utils/dom.d.ts +7 -9
  141. package/build-types/utils/dom.d.ts.map +1 -1
  142. package/package.json +4 -3
  143. package/src/components/block-canvas/style.scss +1 -1
  144. package/src/components/block-inspector/style.scss +2 -1
  145. package/src/components/block-list/block.js +28 -48
  146. package/src/components/block-patterns-list/README.md +8 -8
  147. package/src/components/block-patterns-list/index.js +35 -51
  148. package/src/components/block-patterns-list/stories/index.story.js +2 -19
  149. package/src/components/block-popover/index.js +4 -4
  150. package/src/components/block-preview/async.js +43 -0
  151. package/src/components/block-preview/index.js +6 -1
  152. package/src/components/block-toolbar/change-design.js +1 -7
  153. package/src/components/block-tools/index.js +26 -10
  154. package/src/components/block-tools/style.scss +12 -0
  155. package/src/components/block-tools/use-block-toolbar-popover-props.js +2 -2
  156. package/src/components/block-tools/use-show-block-tools.js +3 -1
  157. package/src/components/default-block-appender/content.scss +13 -19
  158. package/src/components/global-styles/dimensions-panel.js +22 -16
  159. package/src/components/iframe/get-compatibility-styles.js +4 -9
  160. package/src/components/iframe/index.js +17 -0
  161. package/src/components/inserter/block-patterns-explorer/pattern-list.js +3 -6
  162. package/src/components/inserter/block-patterns-tab/index.js +0 -1
  163. package/src/components/inserter/block-patterns-tab/pattern-category-previews.js +8 -1
  164. package/src/components/inserter/block-patterns-tab/use-pattern-categories.js +8 -0
  165. package/src/components/inserter/block-patterns-tab/utils.js +5 -0
  166. package/src/components/inserter/hooks/use-block-types-state.js +6 -1
  167. package/src/components/inserter/hooks/use-patterns-paging.js +1 -6
  168. package/src/components/inserter/search-results.js +0 -6
  169. package/src/components/media-placeholder/index.js +4 -4
  170. package/src/components/rich-text/index.js +8 -1
  171. package/src/components/tabbed-sidebar/index.js +1 -1
  172. package/src/components/tabbed-sidebar/style.scss +1 -1
  173. package/src/components/url-input/index.js +3 -4
  174. package/src/components/use-block-commands/index.js +245 -234
  175. package/src/hooks/font-family.js +1 -1
  176. package/src/hooks/supports.js +6 -6
  177. package/src/hooks/typography.js +5 -5
  178. package/src/hooks/utils.js +7 -2
  179. package/src/store/private-selectors.js +5 -6
  180. package/src/store/selectors.js +57 -45
  181. package/src/store/test/private-selectors.js +5 -0
  182. package/src/store/utils.js +12 -11
  183. package/src/utils/dom.js +26 -21
  184. package/src/utils/test/dom.js +224 -0
  185. package/tsconfig.json +1 -0
  186. package/tsconfig.tsbuildinfo +1 -1
  187. /package/src/{lock-unlock.js → lock-unlock.ts} +0 -0
@@ -14,6 +14,7 @@ import {
14
14
  isPatternFiltered,
15
15
  allPatternsCategory,
16
16
  myPatternsCategory,
17
+ starterPatternsCategory,
17
18
  INSERTER_PATTERN_TYPES,
18
19
  } from './utils';
19
20
 
@@ -67,6 +68,13 @@ export function usePatternCategories( rootClientId, sourceFilter = 'all' ) {
67
68
  label: _x( 'Uncategorized' ),
68
69
  } );
69
70
  }
71
+ if (
72
+ filteredPatterns.some( ( pattern ) =>
73
+ pattern.blockTypes?.includes( 'core/post-content' )
74
+ )
75
+ ) {
76
+ categories.unshift( starterPatternsCategory );
77
+ }
70
78
  if (
71
79
  filteredPatterns.some(
72
80
  ( pattern ) => pattern.type === INSERTER_PATTERN_TYPES.user
@@ -25,6 +25,11 @@ export const myPatternsCategory = {
25
25
  label: __( 'My patterns' ),
26
26
  };
27
27
 
28
+ export const starterPatternsCategory = {
29
+ name: 'core/starter-content',
30
+ label: __( 'Starter content' ),
31
+ };
32
+
28
33
  export function isPatternFiltered( pattern, sourceFilter, syncFilter ) {
29
34
  const isUserPattern = pattern.name.startsWith( 'core/block' );
30
35
  const isDirectoryPattern =
@@ -94,7 +94,12 @@ const useBlockTypesState = ( rootClientId, onInsert, isQuick ) => {
94
94
  destinationClientId
95
95
  );
96
96
  },
97
- [ onInsert, getClosestAllowedInsertionPoint, rootClientId ]
97
+ [
98
+ getClosestAllowedInsertionPoint,
99
+ rootClientId,
100
+ onInsert,
101
+ createErrorNotice,
102
+ ]
98
103
  );
99
104
 
100
105
  return [ items, categories, collections, onSelectItem ];
@@ -2,11 +2,10 @@
2
2
  * WordPress dependencies
3
3
  */
4
4
  import { useMemo, useState, useEffect } from '@wordpress/element';
5
- import { useAsyncList, usePrevious } from '@wordpress/compose';
5
+ import { usePrevious } from '@wordpress/compose';
6
6
  import { getScrollContainer } from '@wordpress/dom';
7
7
 
8
8
  const PAGE_SIZE = 20;
9
- const INITIAL_INSERTER_RESULTS = 5;
10
9
 
11
10
  /**
12
11
  * Supplies values needed to page the patterns list client side.
@@ -42,9 +41,6 @@ export default function usePatternsPaging(
42
41
  pageIndex * PAGE_SIZE + PAGE_SIZE
43
42
  );
44
43
  }, [ pageIndex, currentCategoryPatterns ] );
45
- const categoryPatternsAsyncList = useAsyncList( categoryPatterns, {
46
- step: INITIAL_INSERTER_RESULTS,
47
- } );
48
44
  const numPages = Math.ceil( currentCategoryPatterns.length / PAGE_SIZE );
49
45
  const changePage = ( page ) => {
50
46
  const scrollContainer = getScrollContainer(
@@ -68,7 +64,6 @@ export default function usePatternsPaging(
68
64
  return {
69
65
  totalItems,
70
66
  categoryPatterns,
71
- categoryPatternsAsyncList,
72
67
  numPages,
73
68
  changePage,
74
69
  currentPage,
@@ -159,11 +159,6 @@ function InserterSearchResults( {
159
159
  const currentShownBlockTypes = useAsyncList( filteredBlockTypes, {
160
160
  step: INITIAL_INSERTER_RESULTS,
161
161
  } );
162
- const currentShownPatterns = useAsyncList(
163
- currentShownBlockTypes.length === filteredBlockTypes.length
164
- ? filteredBlockPatterns
165
- : EMPTY_ARRAY
166
- );
167
162
 
168
163
  const hasItems =
169
164
  filteredBlockTypes.length > 0 || filteredBlockPatterns.length > 0;
@@ -190,7 +185,6 @@ function InserterSearchResults( {
190
185
  >
191
186
  <div className="block-editor-inserter__quick-inserter-patterns">
192
187
  <BlockPatternsList
193
- shownPatterns={ currentShownPatterns }
194
188
  blockPatterns={ filteredBlockPatterns }
195
189
  onClickPattern={ onClickPattern }
196
190
  onHover={ onHoverPattern }
@@ -317,20 +317,20 @@ export function MediaPlaceholder( {
317
317
 
318
318
  if ( instructions === undefined && mediaUpload ) {
319
319
  instructions = __(
320
- 'Upload a media file or pick one from your media library.'
320
+ 'Drag and drop an image or video, upload, or choose from your library.'
321
321
  );
322
322
 
323
323
  if ( isAudio ) {
324
324
  instructions = __(
325
- 'Upload or drag an audio file here, or pick one from your library.'
325
+ 'Drag and drop an audio file, upload, or choose from your library.'
326
326
  );
327
327
  } else if ( isImage ) {
328
328
  instructions = __(
329
- 'Upload or drag an image file here, or pick one from your library.'
329
+ 'Drag and drop an image, upload, or choose from your library.'
330
330
  );
331
331
  } else if ( isVideo ) {
332
332
  instructions = __(
333
- 'Upload or drag a video file here, or pick one from your library.'
333
+ 'Drag and drop a video, upload, or choose from your library.'
334
334
  );
335
335
  }
336
336
  }
@@ -233,7 +233,14 @@ export function RichTextWrapper(
233
233
  bindingsLabel: _bindingsLabel,
234
234
  };
235
235
  },
236
- [ blockBindings, identifier, blockName, blockContext, adjustedValue ]
236
+ [
237
+ blockBindings,
238
+ identifier,
239
+ blockName,
240
+ adjustedValue,
241
+ clientId,
242
+ blockContext,
243
+ ]
237
244
  );
238
245
 
239
246
  const shouldDisableEditing = readOnly || disableBoundBlock;
@@ -33,7 +33,7 @@ function TabbedSidebar(
33
33
  icon={ closeSmall }
34
34
  label={ closeButtonLabel }
35
35
  onClick={ () => onClose() }
36
- size="small"
36
+ size="compact"
37
37
  />
38
38
 
39
39
  <Tabs.TabList
@@ -11,7 +11,7 @@
11
11
  border-bottom: $border-width solid $gray-300;
12
12
  display: flex;
13
13
  justify-content: space-between;
14
- padding-right: $grid-unit-15;
14
+ padding-right: $grid-unit-10;
15
15
  }
16
16
 
17
17
 
@@ -533,10 +533,9 @@ class URLInput extends Component {
533
533
  <Popover placement="bottom" focusOnMount={ false }>
534
534
  <div
535
535
  { ...suggestionsListProps }
536
- className={ clsx(
537
- 'block-editor-url-input__suggestions',
538
- `${ className }__suggestions`
539
- ) }
536
+ className={ clsx( 'block-editor-url-input__suggestions', {
537
+ [ `${ className }__suggestions` ]: className,
538
+ } ) }
540
539
  >
541
540
  { suggestions.map( ( suggestion, index ) => (
542
541
  <Button