@wordpress/block-editor 12.4.0 → 12.6.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 (524) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/README.md +1 -0
  3. package/build/components/block-draggable/index.js +6 -3
  4. package/build/components/block-draggable/index.js.map +1 -1
  5. package/build/components/block-draggable/index.native.js +2 -2
  6. package/build/components/block-draggable/index.native.js.map +1 -1
  7. package/build/components/block-edit/edit.js +25 -13
  8. package/build/components/block-edit/edit.js.map +1 -1
  9. package/build/components/block-heading-level-dropdown/heading-level-icon.js +10 -2
  10. package/build/components/block-heading-level-dropdown/heading-level-icon.js.map +1 -1
  11. package/build/components/block-heading-level-dropdown/index.native.js +4 -3
  12. package/build/components/block-heading-level-dropdown/index.native.js.map +1 -1
  13. package/build/components/block-list/block-outline.native.js +14 -18
  14. package/build/components/block-list/block-outline.native.js.map +1 -1
  15. package/build/components/block-list/block.native.js +21 -42
  16. package/build/components/block-list/block.native.js.map +1 -1
  17. package/build/components/block-lock/toolbar.js +25 -6
  18. package/build/components/block-lock/toolbar.js.map +1 -1
  19. package/build/components/block-mover/index.native.js +1 -1
  20. package/build/components/block-mover/index.native.js.map +1 -1
  21. package/build/components/block-parent-selector/index.js +8 -5
  22. package/build/components/block-parent-selector/index.js.map +1 -1
  23. package/build/components/block-removal-warning-modal/index.js +15 -25
  24. package/build/components/block-removal-warning-modal/index.js.map +1 -1
  25. package/build/components/block-settings/button.native.js +2 -2
  26. package/build/components/block-settings/button.native.js.map +1 -1
  27. package/build/components/{block-mobile-toolbar/block-actions-menu.native.js → block-toolbar/block-toolbar-menu.native.js} +10 -11
  28. package/build/components/block-toolbar/block-toolbar-menu.native.js.map +1 -0
  29. package/build/components/block-toolbar/index.js +12 -8
  30. package/build/components/block-toolbar/index.js.map +1 -1
  31. package/build/components/block-toolbar/index.native.js +62 -3
  32. package/build/components/block-toolbar/index.native.js.map +1 -1
  33. package/build/components/block-tools/block-contextual-toolbar.js +7 -11
  34. package/build/components/block-tools/block-contextual-toolbar.js.map +1 -1
  35. package/build/components/colors-gradients/control.js +4 -2
  36. package/build/components/colors-gradients/control.js.map +1 -1
  37. package/build/components/dimensions-tool/aspect-ratio-tool.js +99 -0
  38. package/build/components/dimensions-tool/aspect-ratio-tool.js.map +1 -0
  39. package/build/components/dimensions-tool/index.js +207 -0
  40. package/build/components/dimensions-tool/index.js.map +1 -0
  41. package/build/components/dimensions-tool/scale-tool.js +111 -0
  42. package/build/components/dimensions-tool/scale-tool.js.map +1 -0
  43. package/build/components/dimensions-tool/width-height-tool.js +125 -0
  44. package/build/components/dimensions-tool/width-height-tool.js.map +1 -0
  45. package/build/components/global-styles/color-panel.js +22 -16
  46. package/build/components/global-styles/color-panel.js.map +1 -1
  47. package/build/components/global-styles/dimensions-panel.js +13 -2
  48. package/build/components/global-styles/dimensions-panel.js.map +1 -1
  49. package/build/components/global-styles/filters-panel.js +1 -1
  50. package/build/components/global-styles/filters-panel.js.map +1 -1
  51. package/build/components/global-styles/get-block-css-selector.js +4 -8
  52. package/build/components/global-styles/get-block-css-selector.js.map +1 -1
  53. package/build/components/global-styles/hooks.js +15 -25
  54. package/build/components/global-styles/hooks.js.map +1 -1
  55. package/build/components/global-styles/typography-panel.js +52 -5
  56. package/build/components/global-styles/typography-panel.js.map +1 -1
  57. package/build/components/global-styles/use-global-styles-output.js +12 -18
  58. package/build/components/global-styles/use-global-styles-output.js.map +1 -1
  59. package/build/components/global-styles/utils.js +6 -6
  60. package/build/components/global-styles/utils.js.map +1 -1
  61. package/build/components/iframe/index.js +36 -48
  62. package/build/components/iframe/index.js.map +1 -1
  63. package/build/components/iframe/use-compatibility-styles.js +5 -0
  64. package/build/components/iframe/use-compatibility-styles.js.map +1 -1
  65. package/build/components/image-editor/aspect-ratio-dropdown.js +1 -1
  66. package/build/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
  67. package/build/components/image-editor/use-save-image.js +1 -2
  68. package/build/components/image-editor/use-save-image.js.map +1 -1
  69. package/build/components/image-size-control/index.js +6 -0
  70. package/build/components/image-size-control/index.js.map +1 -1
  71. package/build/components/index.js +9 -0
  72. package/build/components/index.js.map +1 -1
  73. package/build/components/inner-blocks/index.js +3 -1
  74. package/build/components/inner-blocks/index.js.map +1 -1
  75. package/build/components/inner-blocks/index.native.js +3 -1
  76. package/build/components/inner-blocks/index.native.js.map +1 -1
  77. package/build/components/inner-blocks/use-nested-settings-update.js +33 -7
  78. package/build/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  79. package/build/components/inserter/block-patterns-explorer/patterns-list.js +2 -2
  80. package/build/components/inserter/block-patterns-explorer/patterns-list.js.map +1 -1
  81. package/build/components/inserter/block-patterns-tab.js +7 -35
  82. package/build/components/inserter/block-patterns-tab.js.map +1 -1
  83. package/build/components/inserter/hooks/use-block-types-state.js +3 -4
  84. package/build/components/inserter/hooks/use-block-types-state.js.map +1 -1
  85. package/build/components/inserter/hooks/use-patterns-state.js +9 -3
  86. package/build/components/inserter/hooks/use-patterns-state.js.map +1 -1
  87. package/build/components/inserter/index.js +2 -4
  88. package/build/components/inserter/index.js.map +1 -1
  89. package/build/components/inserter/index.native.js +21 -32
  90. package/build/components/inserter/index.native.js.map +1 -1
  91. package/build/components/inserter/media-tab/hooks.js +2 -21
  92. package/build/components/inserter/media-tab/hooks.js.map +1 -1
  93. package/build/components/inserter/reusable-block-rename-hint.js +82 -0
  94. package/build/components/inserter/reusable-block-rename-hint.js.map +1 -0
  95. package/build/components/inserter/reusable-blocks-tab.js +6 -2
  96. package/build/components/inserter/reusable-blocks-tab.js.map +1 -1
  97. package/build/components/inserter/reusable-blocks-tab.native.js +2 -2
  98. package/build/components/inserter/reusable-blocks-tab.native.js.map +1 -1
  99. package/build/components/inserter/tabs.native.js +1 -1
  100. package/build/components/inserter/tabs.native.js.map +1 -1
  101. package/build/components/inserter-draggable-blocks/index.js +9 -1
  102. package/build/components/inserter-draggable-blocks/index.js.map +1 -1
  103. package/build/components/link-control/constants.js +1 -1
  104. package/build/components/link-control/constants.js.map +1 -1
  105. package/build/components/link-control/index.js +21 -16
  106. package/build/components/link-control/index.js.map +1 -1
  107. package/build/components/link-control/search-create-button.js +5 -21
  108. package/build/components/link-control/search-create-button.js.map +1 -1
  109. package/build/components/link-control/search-input.js +4 -4
  110. package/build/components/link-control/search-input.js.map +1 -1
  111. package/build/components/link-control/search-item.js +13 -30
  112. package/build/components/link-control/search-item.js.map +1 -1
  113. package/build/components/link-control/search-results.js +2 -2
  114. package/build/components/link-control/search-results.js.map +1 -1
  115. package/build/components/link-control/settings-drawer.js +2 -3
  116. package/build/components/link-control/settings-drawer.js.map +1 -1
  117. package/build/components/list-view/appender.js +2 -6
  118. package/build/components/list-view/appender.js.map +1 -1
  119. package/build/components/list-view/use-list-view-client-ids.js +2 -2
  120. package/build/components/list-view/use-list-view-client-ids.js.map +1 -1
  121. package/build/components/media-placeholder/index.native.js +65 -31
  122. package/build/components/media-placeholder/index.native.js.map +1 -1
  123. package/build/components/preview-options/index.js +2 -2
  124. package/build/components/preview-options/index.js.map +1 -1
  125. package/build/components/provider/index.js +5 -2
  126. package/build/components/provider/index.js.map +1 -1
  127. package/build/components/provider/use-block-sync.js +21 -0
  128. package/build/components/provider/use-block-sync.js.map +1 -1
  129. package/build/components/resolution-tool/index.js +55 -0
  130. package/build/components/resolution-tool/index.js.map +1 -0
  131. package/build/components/rich-text/content.js +0 -36
  132. package/build/components/rich-text/content.js.map +1 -1
  133. package/build/components/rich-text/get-rich-text-values.js +118 -0
  134. package/build/components/rich-text/get-rich-text-values.js.map +1 -0
  135. package/build/components/spacing-sizes-control/hooks/use-spacing-sizes.js +1 -1
  136. package/build/components/spacing-sizes-control/hooks/use-spacing-sizes.js.map +1 -1
  137. package/build/components/spacing-sizes-control/input-controls/axial.js +6 -2
  138. package/build/components/spacing-sizes-control/input-controls/axial.js.map +1 -1
  139. package/build/components/spacing-sizes-control/input-controls/separated.js +5 -1
  140. package/build/components/spacing-sizes-control/input-controls/separated.js.map +1 -1
  141. package/build/components/spacing-sizes-control/input-controls/single.js +5 -1
  142. package/build/components/spacing-sizes-control/input-controls/single.js.map +1 -1
  143. package/build/components/spacing-sizes-control/utils.js +1 -1
  144. package/build/components/spacing-sizes-control/utils.js.map +1 -1
  145. package/build/components/url-input/index.js +4 -2
  146. package/build/components/url-input/index.js.map +1 -1
  147. package/build/components/use-block-display-information/index.js +7 -3
  148. package/build/components/use-block-display-information/index.js.map +1 -1
  149. package/build/components/use-block-drop-zone/index.native.js +49 -8
  150. package/build/components/use-block-drop-zone/index.native.js.map +1 -1
  151. package/build/components/use-setting/index.js +5 -9
  152. package/build/components/use-setting/index.js.map +1 -1
  153. package/build/components/writing-flow/use-tab-nav.js +10 -27
  154. package/build/components/writing-flow/use-tab-nav.js.map +1 -1
  155. package/build/components/writing-mode-control/index.js +70 -0
  156. package/build/components/writing-mode-control/index.js.map +1 -0
  157. package/build/hooks/behaviors.js +25 -20
  158. package/build/hooks/behaviors.js.map +1 -1
  159. package/build/hooks/margin.js +1 -1
  160. package/build/hooks/margin.js.map +1 -1
  161. package/build/hooks/padding.js +1 -1
  162. package/build/hooks/padding.js.map +1 -1
  163. package/build/hooks/supports.js +7 -1
  164. package/build/hooks/supports.js.map +1 -1
  165. package/build/hooks/typography.js +2 -1
  166. package/build/hooks/typography.js.map +1 -1
  167. package/build/hooks/utils.js +5 -9
  168. package/build/hooks/utils.js.map +1 -1
  169. package/build/private-apis.js +16 -3
  170. package/build/private-apis.js.map +1 -1
  171. package/build/private-apis.native.js +3 -0
  172. package/build/private-apis.native.js.map +1 -1
  173. package/build/store/actions.js +196 -2
  174. package/build/store/actions.js.map +1 -1
  175. package/build/store/defaults.js +1 -0
  176. package/build/store/defaults.js.map +1 -1
  177. package/build/store/index.js +10 -1
  178. package/build/store/index.js.map +1 -1
  179. package/build/store/private-actions.js +46 -40
  180. package/build/store/private-actions.js.map +1 -1
  181. package/build/store/private-selectors.js +8 -9
  182. package/build/store/private-selectors.js.map +1 -1
  183. package/build/store/reducer.js +22 -9
  184. package/build/store/reducer.js.map +1 -1
  185. package/build/store/selectors.js +52 -23
  186. package/build/store/selectors.js.map +1 -1
  187. package/build/utils/object.js +38 -2
  188. package/build/utils/object.js.map +1 -1
  189. package/build-module/components/block-draggable/index.js +6 -3
  190. package/build-module/components/block-draggable/index.js.map +1 -1
  191. package/build-module/components/block-draggable/index.native.js +2 -2
  192. package/build-module/components/block-draggable/index.native.js.map +1 -1
  193. package/build-module/components/block-edit/edit.js +27 -10
  194. package/build-module/components/block-edit/edit.js.map +1 -1
  195. package/build-module/components/block-heading-level-dropdown/heading-level-icon.js +9 -2
  196. package/build-module/components/block-heading-level-dropdown/heading-level-icon.js.map +1 -1
  197. package/build-module/components/block-heading-level-dropdown/index.native.js +4 -3
  198. package/build-module/components/block-heading-level-dropdown/index.native.js.map +1 -1
  199. package/build-module/components/block-list/block-outline.native.js +14 -18
  200. package/build-module/components/block-list/block-outline.native.js.map +1 -1
  201. package/build-module/components/block-list/block.native.js +24 -43
  202. package/build-module/components/block-list/block.native.js.map +1 -1
  203. package/build-module/components/block-lock/toolbar.js +25 -7
  204. package/build-module/components/block-lock/toolbar.js.map +1 -1
  205. package/build-module/components/block-mover/index.native.js +3 -3
  206. package/build-module/components/block-mover/index.native.js.map +1 -1
  207. package/build-module/components/block-parent-selector/index.js +7 -5
  208. package/build-module/components/block-parent-selector/index.js.map +1 -1
  209. package/build-module/components/block-removal-warning-modal/index.js +17 -24
  210. package/build-module/components/block-removal-warning-modal/index.js.map +1 -1
  211. package/build-module/components/block-settings/button.native.js +3 -3
  212. package/build-module/components/block-settings/button.native.js.map +1 -1
  213. package/build-module/components/{block-mobile-toolbar/block-actions-menu.native.js → block-toolbar/block-toolbar-menu.native.js} +13 -13
  214. package/build-module/components/block-toolbar/block-toolbar-menu.native.js.map +1 -0
  215. package/build-module/components/block-toolbar/index.js +12 -8
  216. package/build-module/components/block-toolbar/index.js.map +1 -1
  217. package/build-module/components/block-toolbar/index.native.js +60 -4
  218. package/build-module/components/block-toolbar/index.native.js.map +1 -1
  219. package/build-module/components/block-tools/block-contextual-toolbar.js +8 -11
  220. package/build-module/components/block-tools/block-contextual-toolbar.js.map +1 -1
  221. package/build-module/components/colors-gradients/control.js +3 -2
  222. package/build-module/components/colors-gradients/control.js.map +1 -1
  223. package/build-module/components/dimensions-tool/aspect-ratio-tool.js +87 -0
  224. package/build-module/components/dimensions-tool/aspect-ratio-tool.js.map +1 -0
  225. package/build-module/components/dimensions-tool/index.js +195 -0
  226. package/build-module/components/dimensions-tool/index.js.map +1 -0
  227. package/build-module/components/dimensions-tool/scale-tool.js +103 -0
  228. package/build-module/components/dimensions-tool/scale-tool.js.map +1 -0
  229. package/build-module/components/dimensions-tool/width-height-tool.js +122 -0
  230. package/build-module/components/dimensions-tool/width-height-tool.js.map +1 -0
  231. package/build-module/components/global-styles/color-panel.js +22 -16
  232. package/build-module/components/global-styles/color-panel.js.map +1 -1
  233. package/build-module/components/global-styles/dimensions-panel.js +13 -2
  234. package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
  235. package/build-module/components/global-styles/filters-panel.js +2 -2
  236. package/build-module/components/global-styles/filters-panel.js.map +1 -1
  237. package/build-module/components/global-styles/get-block-css-selector.js +4 -8
  238. package/build-module/components/global-styles/get-block-css-selector.js.map +1 -1
  239. package/build-module/components/global-styles/hooks.js +14 -24
  240. package/build-module/components/global-styles/hooks.js.map +1 -1
  241. package/build-module/components/global-styles/typography-panel.js +51 -5
  242. package/build-module/components/global-styles/typography-panel.js.map +1 -1
  243. package/build-module/components/global-styles/use-global-styles-output.js +13 -18
  244. package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
  245. package/build-module/components/global-styles/utils.js +5 -5
  246. package/build-module/components/global-styles/utils.js.map +1 -1
  247. package/build-module/components/iframe/index.js +37 -49
  248. package/build-module/components/iframe/index.js.map +1 -1
  249. package/build-module/components/iframe/use-compatibility-styles.js +5 -0
  250. package/build-module/components/iframe/use-compatibility-styles.js.map +1 -1
  251. package/build-module/components/image-editor/aspect-ratio-dropdown.js +1 -1
  252. package/build-module/components/image-editor/aspect-ratio-dropdown.js.map +1 -1
  253. package/build-module/components/image-editor/use-save-image.js +1 -2
  254. package/build-module/components/image-editor/use-save-image.js.map +1 -1
  255. package/build-module/components/image-size-control/index.js +5 -0
  256. package/build-module/components/image-size-control/index.js.map +1 -1
  257. package/build-module/components/index.js +1 -0
  258. package/build-module/components/index.js.map +1 -1
  259. package/build-module/components/inner-blocks/index.js +3 -1
  260. package/build-module/components/inner-blocks/index.js.map +1 -1
  261. package/build-module/components/inner-blocks/index.native.js +3 -1
  262. package/build-module/components/inner-blocks/index.native.js.map +1 -1
  263. package/build-module/components/inner-blocks/use-nested-settings-update.js +30 -7
  264. package/build-module/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  265. package/build-module/components/inserter/block-patterns-explorer/patterns-list.js +2 -2
  266. package/build-module/components/inserter/block-patterns-explorer/patterns-list.js.map +1 -1
  267. package/build-module/components/inserter/block-patterns-tab.js +7 -33
  268. package/build-module/components/inserter/block-patterns-tab.js.map +1 -1
  269. package/build-module/components/inserter/hooks/use-block-types-state.js +3 -4
  270. package/build-module/components/inserter/hooks/use-block-types-state.js.map +1 -1
  271. package/build-module/components/inserter/hooks/use-patterns-state.js +9 -3
  272. package/build-module/components/inserter/hooks/use-patterns-state.js.map +1 -1
  273. package/build-module/components/inserter/index.js +2 -4
  274. package/build-module/components/inserter/index.js.map +1 -1
  275. package/build-module/components/inserter/index.native.js +22 -33
  276. package/build-module/components/inserter/index.native.js.map +1 -1
  277. package/build-module/components/inserter/media-tab/hooks.js +2 -21
  278. package/build-module/components/inserter/media-tab/hooks.js.map +1 -1
  279. package/build-module/components/inserter/reusable-block-rename-hint.js +67 -0
  280. package/build-module/components/inserter/reusable-block-rename-hint.js.map +1 -0
  281. package/build-module/components/inserter/reusable-blocks-tab.js +5 -2
  282. package/build-module/components/inserter/reusable-blocks-tab.js.map +1 -1
  283. package/build-module/components/inserter/reusable-blocks-tab.native.js +2 -2
  284. package/build-module/components/inserter/reusable-blocks-tab.native.js.map +1 -1
  285. package/build-module/components/inserter/tabs.native.js +1 -1
  286. package/build-module/components/inserter/tabs.native.js.map +1 -1
  287. package/build-module/components/inserter-draggable-blocks/index.js +9 -2
  288. package/build-module/components/inserter-draggable-blocks/index.js.map +1 -1
  289. package/build-module/components/link-control/constants.js +1 -1
  290. package/build-module/components/link-control/constants.js.map +1 -1
  291. package/build-module/components/link-control/index.js +21 -16
  292. package/build-module/components/link-control/index.js.map +1 -1
  293. package/build-module/components/link-control/search-create-button.js +7 -20
  294. package/build-module/components/link-control/search-create-button.js.map +1 -1
  295. package/build-module/components/link-control/search-input.js +4 -4
  296. package/build-module/components/link-control/search-input.js.map +1 -1
  297. package/build-module/components/link-control/search-item.js +14 -28
  298. package/build-module/components/link-control/search-item.js.map +1 -1
  299. package/build-module/components/link-control/search-results.js +3 -3
  300. package/build-module/components/link-control/search-results.js.map +1 -1
  301. package/build-module/components/link-control/settings-drawer.js +4 -5
  302. package/build-module/components/link-control/settings-drawer.js.map +1 -1
  303. package/build-module/components/list-view/appender.js +2 -6
  304. package/build-module/components/list-view/appender.js.map +1 -1
  305. package/build-module/components/list-view/use-list-view-client-ids.js +2 -2
  306. package/build-module/components/list-view/use-list-view-client-ids.js.map +1 -1
  307. package/build-module/components/media-placeholder/index.native.js +66 -33
  308. package/build-module/components/media-placeholder/index.native.js.map +1 -1
  309. package/build-module/components/preview-options/index.js +2 -2
  310. package/build-module/components/preview-options/index.js.map +1 -1
  311. package/build-module/components/provider/index.js +5 -2
  312. package/build-module/components/provider/index.js.map +1 -1
  313. package/build-module/components/provider/use-block-sync.js +21 -0
  314. package/build-module/components/provider/use-block-sync.js.map +1 -1
  315. package/build-module/components/resolution-tool/index.js +45 -0
  316. package/build-module/components/resolution-tool/index.js.map +1 -0
  317. package/build-module/components/rich-text/content.js +1 -36
  318. package/build-module/components/rich-text/content.js.map +1 -1
  319. package/build-module/components/rich-text/get-rich-text-values.js +105 -0
  320. package/build-module/components/rich-text/get-rich-text-values.js.map +1 -0
  321. package/build-module/components/spacing-sizes-control/hooks/use-spacing-sizes.js +1 -1
  322. package/build-module/components/spacing-sizes-control/hooks/use-spacing-sizes.js.map +1 -1
  323. package/build-module/components/spacing-sizes-control/input-controls/axial.js +7 -3
  324. package/build-module/components/spacing-sizes-control/input-controls/axial.js.map +1 -1
  325. package/build-module/components/spacing-sizes-control/input-controls/separated.js +6 -2
  326. package/build-module/components/spacing-sizes-control/input-controls/separated.js.map +1 -1
  327. package/build-module/components/spacing-sizes-control/input-controls/single.js +6 -2
  328. package/build-module/components/spacing-sizes-control/input-controls/single.js.map +1 -1
  329. package/build-module/components/spacing-sizes-control/utils.js +1 -1
  330. package/build-module/components/spacing-sizes-control/utils.js.map +1 -1
  331. package/build-module/components/url-input/index.js +4 -2
  332. package/build-module/components/url-input/index.js.map +1 -1
  333. package/build-module/components/use-block-display-information/index.js +7 -3
  334. package/build-module/components/use-block-display-information/index.js.map +1 -1
  335. package/build-module/components/use-block-drop-zone/index.native.js +50 -8
  336. package/build-module/components/use-block-drop-zone/index.native.js.map +1 -1
  337. package/build-module/components/use-setting/index.js +5 -9
  338. package/build-module/components/use-setting/index.js.map +1 -1
  339. package/build-module/components/writing-flow/use-tab-nav.js +8 -26
  340. package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
  341. package/build-module/components/writing-mode-control/index.js +57 -0
  342. package/build-module/components/writing-mode-control/index.js.map +1 -0
  343. package/build-module/hooks/behaviors.js +26 -20
  344. package/build-module/hooks/behaviors.js.map +1 -1
  345. package/build-module/hooks/margin.js +1 -1
  346. package/build-module/hooks/margin.js.map +1 -1
  347. package/build-module/hooks/padding.js +1 -1
  348. package/build-module/hooks/padding.js.map +1 -1
  349. package/build-module/hooks/supports.js +7 -1
  350. package/build-module/hooks/supports.js.map +1 -1
  351. package/build-module/hooks/typography.js +2 -1
  352. package/build-module/hooks/typography.js.map +1 -1
  353. package/build-module/hooks/utils.js +6 -9
  354. package/build-module/hooks/utils.js.map +1 -1
  355. package/build-module/private-apis.js +11 -2
  356. package/build-module/private-apis.js.map +1 -1
  357. package/build-module/private-apis.native.js +2 -0
  358. package/build-module/private-apis.native.js.map +1 -1
  359. package/build-module/store/actions.js +193 -3
  360. package/build-module/store/actions.js.map +1 -1
  361. package/build-module/store/defaults.js +1 -0
  362. package/build-module/store/defaults.js.map +1 -1
  363. package/build-module/store/index.js +10 -1
  364. package/build-module/store/index.js.map +1 -1
  365. package/build-module/store/private-actions.js +45 -36
  366. package/build-module/store/private-actions.js.map +1 -1
  367. package/build-module/store/private-selectors.js +5 -5
  368. package/build-module/store/private-selectors.js.map +1 -1
  369. package/build-module/store/reducer.js +22 -9
  370. package/build-module/store/reducer.js.map +1 -1
  371. package/build-module/store/selectors.js +49 -21
  372. package/build-module/store/selectors.js.map +1 -1
  373. package/build-module/utils/object.js +34 -2
  374. package/build-module/utils/object.js.map +1 -1
  375. package/build-style/content-rtl.css +4 -0
  376. package/build-style/content.css +4 -0
  377. package/build-style/style-rtl.css +137 -129
  378. package/build-style/style.css +137 -129
  379. package/package.json +33 -32
  380. package/src/components/alignment-control/test/__snapshots__/index.js.snap +6 -6
  381. package/src/components/block-alignment-control/test/__snapshots__/index.js.snap +5 -5
  382. package/src/components/block-controls/README.md +89 -0
  383. package/src/components/block-draggable/index.js +13 -4
  384. package/src/components/block-draggable/index.native.js +7 -3
  385. package/src/components/block-draggable/style.scss +1 -0
  386. package/src/components/block-draggable/test/index.native.js +0 -54
  387. package/src/components/block-edit/edit.js +26 -9
  388. package/src/components/block-edit/test/edit.js +1 -1
  389. package/src/components/block-heading-level-dropdown/heading-level-icon.js +6 -1
  390. package/src/components/block-heading-level-dropdown/index.native.js +8 -4
  391. package/src/components/block-inspector/style.scss +2 -1
  392. package/src/components/block-list/block-outline.native.js +26 -25
  393. package/src/components/block-list/block.native.js +24 -38
  394. package/src/components/block-list/block.native.scss +18 -40
  395. package/src/components/block-list/style.native.scss +3 -3
  396. package/src/components/block-lock/toolbar.js +34 -6
  397. package/src/components/block-mover/index.native.js +3 -3
  398. package/src/components/block-mover/test/__snapshots__/index.native.js.snap +16 -6
  399. package/src/components/block-parent-selector/index.js +13 -8
  400. package/src/components/block-removal-warning-modal/index.js +17 -33
  401. package/src/components/block-settings/button.native.js +12 -6
  402. package/src/components/{block-mobile-toolbar/block-actions-menu.native.js → block-toolbar/block-toolbar-menu.native.js} +19 -18
  403. package/src/components/block-toolbar/index.js +11 -9
  404. package/src/components/block-toolbar/index.native.js +86 -6
  405. package/src/components/{block-mobile-toolbar/test/block-actions-menu.native.js → block-toolbar/test/block-toolbar-menu.native.js} +20 -54
  406. package/src/components/block-toolbar/test/index.native.js +42 -0
  407. package/src/components/block-tools/block-contextual-toolbar.js +5 -11
  408. package/src/components/block-tools/style.scss +73 -26
  409. package/src/components/button-block-appender/styles.native.scss +2 -2
  410. package/src/components/caption/README.md +49 -0
  411. package/src/components/colors-gradients/control.js +3 -2
  412. package/src/components/default-block-appender/content.scss +11 -0
  413. package/src/components/dimensions-tool/aspect-ratio-tool.js +124 -0
  414. package/src/components/dimensions-tool/index.js +212 -0
  415. package/src/components/dimensions-tool/scale-tool.js +124 -0
  416. package/src/components/dimensions-tool/stories/aspect-ratio-tool.js +52 -0
  417. package/src/components/dimensions-tool/stories/index.js +54 -0
  418. package/src/components/dimensions-tool/stories/scale-tool.js +48 -0
  419. package/src/components/dimensions-tool/stories/width-height-tool.js +54 -0
  420. package/src/components/dimensions-tool/test/index.js +641 -0
  421. package/src/components/dimensions-tool/width-height-tool.js +113 -0
  422. package/src/components/font-family/README.md +71 -0
  423. package/src/components/global-styles/color-panel.js +24 -17
  424. package/src/components/global-styles/dimensions-panel.js +8 -2
  425. package/src/components/global-styles/filters-panel.js +2 -2
  426. package/src/components/global-styles/get-block-css-selector.js +5 -9
  427. package/src/components/global-styles/hooks.js +22 -26
  428. package/src/components/global-styles/typography-panel.js +57 -5
  429. package/src/components/global-styles/use-global-styles-output.js +36 -18
  430. package/src/components/global-styles/utils.js +15 -6
  431. package/src/components/iframe/index.js +30 -56
  432. package/src/components/iframe/use-compatibility-styles.js +5 -0
  433. package/src/components/image-editor/aspect-ratio-dropdown.js +1 -1
  434. package/src/components/image-editor/use-save-image.js +0 -1
  435. package/src/components/image-size-control/index.js +6 -0
  436. package/src/components/index.js +1 -0
  437. package/src/components/inner-blocks/README.md +10 -0
  438. package/src/components/inner-blocks/index.js +4 -0
  439. package/src/components/inner-blocks/index.native.js +4 -0
  440. package/src/components/inner-blocks/use-nested-settings-update.js +32 -5
  441. package/src/components/inserter/block-patterns-explorer/patterns-list.js +8 -2
  442. package/src/components/inserter/block-patterns-tab.js +8 -56
  443. package/src/components/inserter/hooks/use-block-types-state.js +3 -4
  444. package/src/components/inserter/hooks/use-patterns-state.js +35 -19
  445. package/src/components/inserter/index.js +2 -3
  446. package/src/components/inserter/index.native.js +17 -36
  447. package/src/components/inserter/media-tab/hooks.js +2 -22
  448. package/src/components/inserter/reusable-block-rename-hint.js +69 -0
  449. package/src/components/inserter/reusable-blocks-tab.js +5 -1
  450. package/src/components/inserter/reusable-blocks-tab.native.js +2 -2
  451. package/src/components/inserter/style.native.scss +10 -15
  452. package/src/components/inserter/style.scss +28 -0
  453. package/src/components/inserter/tabs.native.js +5 -1
  454. package/src/components/inserter-draggable-blocks/index.js +13 -2
  455. package/src/components/link-control/constants.js +1 -1
  456. package/src/components/link-control/index.js +36 -29
  457. package/src/components/link-control/search-create-button.js +8 -26
  458. package/src/components/link-control/search-input.js +4 -3
  459. package/src/components/link-control/search-item.js +21 -43
  460. package/src/components/link-control/search-results.js +48 -46
  461. package/src/components/link-control/settings-drawer.js +6 -5
  462. package/src/components/link-control/style.scss +58 -123
  463. package/src/components/link-control/test/index.js +161 -123
  464. package/src/components/list-view/appender.js +5 -6
  465. package/src/components/list-view/style.scss +1 -2
  466. package/src/components/list-view/use-list-view-client-ids.js +2 -2
  467. package/src/components/media-placeholder/index.native.js +108 -59
  468. package/src/components/media-placeholder/styles.native.scss +59 -24
  469. package/src/components/media-replace-flow/test/index.js +1 -1
  470. package/src/components/panel-color-settings/README.md +98 -0
  471. package/src/components/preview-options/README.md +18 -17
  472. package/src/components/preview-options/index.js +2 -2
  473. package/src/components/provider/index.js +9 -2
  474. package/src/components/provider/test/use-block-sync.js +21 -6
  475. package/src/components/provider/use-block-sync.js +19 -0
  476. package/src/components/recursion-provider/README.md +101 -0
  477. package/src/components/resolution-tool/index.js +56 -0
  478. package/src/components/resolution-tool/stories/index.js +48 -0
  479. package/src/components/rich-text/content.js +1 -46
  480. package/src/components/rich-text/get-rich-text-values.js +105 -0
  481. package/src/components/spacing-sizes-control/hooks/use-spacing-sizes.js +1 -1
  482. package/src/components/spacing-sizes-control/input-controls/axial.js +17 -2
  483. package/src/components/spacing-sizes-control/input-controls/separated.js +17 -2
  484. package/src/components/spacing-sizes-control/input-controls/single.js +12 -2
  485. package/src/components/spacing-sizes-control/utils.js +1 -1
  486. package/src/components/text-transform-control/README.md +44 -0
  487. package/src/components/url-input/index.js +2 -0
  488. package/src/components/use-block-display-information/index.js +12 -5
  489. package/src/components/use-block-drop-zone/index.native.js +65 -28
  490. package/src/components/use-setting/index.js +8 -8
  491. package/src/components/writing-flow/use-tab-nav.js +10 -33
  492. package/src/components/writing-mode-control/index.js +68 -0
  493. package/src/components/writing-mode-control/style.scss +18 -0
  494. package/src/hooks/behaviors.js +25 -16
  495. package/src/hooks/margin.js +4 -1
  496. package/src/hooks/padding.js +4 -1
  497. package/src/hooks/supports.js +7 -0
  498. package/src/hooks/typography.js +2 -0
  499. package/src/hooks/utils.js +8 -7
  500. package/src/private-apis.js +13 -1
  501. package/src/private-apis.native.js +2 -0
  502. package/src/store/actions.js +195 -3
  503. package/src/store/defaults.js +1 -0
  504. package/src/store/index.js +10 -0
  505. package/src/store/private-actions.js +39 -39
  506. package/src/store/private-selectors.js +5 -8
  507. package/src/store/reducer.js +22 -9
  508. package/src/store/selectors.js +87 -25
  509. package/src/store/test/actions.js +114 -0
  510. package/src/store/test/private-actions.js +56 -0
  511. package/src/store/test/private-selectors.js +5 -5
  512. package/src/store/test/reducer.js +14 -7
  513. package/src/store/test/selectors.js +1 -1
  514. package/src/utils/object.js +32 -2
  515. package/src/utils/test/object.js +36 -0
  516. package/build/components/block-mobile-toolbar/block-actions-menu.native.js.map +0 -1
  517. package/build/components/block-mobile-toolbar/index.native.js +0 -135
  518. package/build/components/block-mobile-toolbar/index.native.js.map +0 -1
  519. package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js.map +0 -1
  520. package/build-module/components/block-mobile-toolbar/index.native.js +0 -116
  521. package/build-module/components/block-mobile-toolbar/index.native.js.map +0 -1
  522. package/src/components/block-mobile-toolbar/index.native.js +0 -127
  523. package/src/components/block-mobile-toolbar/style.native.scss +0 -16
  524. /package/src/components/{block-mobile-toolbar/test/__snapshots__/block-actions-menu.native.js.snap → block-toolbar/test/__snapshots__/block-toolbar-menu.native.js.snap} +0 -0
@@ -3,29 +3,11 @@
3
3
  }
4
4
 
5
5
  .solidBorderColor {
6
- border-color: $blue-wordpress;
6
+ border-color: $blue-40;
7
7
  }
8
8
 
9
9
  .solidBorderColorDark {
10
- border-color: $blue-30;
11
- }
12
-
13
- .dashedBorderColor {
14
- border-color: $gray;
15
- }
16
-
17
- .dashedBorderColorDark {
18
- border-color: $gray-70;
19
- }
20
-
21
- .borderFullWidth {
22
- left: 0;
23
- right: 0;
24
- }
25
-
26
- .containerBorderFullWidth {
27
- left: -$solid-border-space * 0.5;
28
- right: -$solid-border-space * 0.5;
10
+ border-color: $blue-50;
29
11
  }
30
12
 
31
13
  .dimmed {
@@ -51,32 +33,28 @@
51
33
  min-height: 50px;
52
34
  }
53
35
 
54
- .neutralToolbar {
55
- margin-left: -$block-edge-to-content;
56
- margin-right: -$block-edge-to-content;
57
- }
58
-
59
36
  .solidBorder {
60
37
  position: absolute;
61
- top: -$solid-border-space;
62
- bottom: 0;
63
- left: -$solid-border-space;
64
- right: -$solid-border-space;
65
- border-width: $block-selected-border-width;
66
- border-radius: 4px;
38
+ top: -6px;
39
+ bottom: -6px;
40
+ left: -6px;
41
+ right: -6px;
42
+ border-width: 2px;
43
+ border-radius: 2px;
67
44
  border-style: solid;
68
45
  z-index: 1;
69
46
  }
70
47
 
71
- .dashedBorder {
72
- position: absolute;
73
- top: -$dashed-border-space;
74
- bottom: -$dashed-border-space;
75
- left: -$dashed-border-space;
76
- right: -$dashed-border-space;
77
- border-width: $block-selected-border-width;
78
- border-radius: 2px;
79
- border-style: dashed;
48
+ .solidBorderCompact {
49
+ top: 0;
50
+ bottom: 0;
51
+ left: 0;
52
+ right: 0;
53
+ }
54
+
55
+ .solidBorderTextContent {
56
+ left: 0;
57
+ right: 0;
80
58
  }
81
59
 
82
60
  .fullWidthPadding {
@@ -66,12 +66,12 @@
66
66
  }
67
67
 
68
68
  .defaultBlock {
69
- margin: $block-edge-to-content;
69
+ margin: $block-edge-to-content * 0.5 $block-edge-to-content;
70
70
  }
71
71
 
72
72
  .defaultAppender {
73
- margin-top: $block-edge-to-content;
74
- margin-bottom: $block-edge-to-content;
73
+ margin-top: $grid-unit;
74
+ margin-bottom: $grid-unit;
75
75
  width: 100%;
76
76
  }
77
77
 
@@ -3,7 +3,8 @@
3
3
  */
4
4
  import { __ } from '@wordpress/i18n';
5
5
  import { ToolbarButton, ToolbarGroup } from '@wordpress/components';
6
- import { useReducer } from '@wordpress/element';
6
+ import { focus } from '@wordpress/dom';
7
+ import { useReducer, useRef, useEffect } from '@wordpress/element';
7
8
  import { lock } from '@wordpress/icons';
8
9
 
9
10
  /**
@@ -12,7 +13,7 @@ import { lock } from '@wordpress/icons';
12
13
  import BlockLockModal from './modal';
13
14
  import useBlockLock from './use-block-lock';
14
15
 
15
- export default function BlockLockToolbar( { clientId } ) {
16
+ export default function BlockLockToolbar( { clientId, wrapperRef } ) {
16
17
  const { canEdit, canMove, canRemove, canLock } = useBlockLock( clientId );
17
18
 
18
19
  const [ isModalOpen, toggleModal ] = useReducer(
@@ -20,11 +21,37 @@ export default function BlockLockToolbar( { clientId } ) {
20
21
  false
21
22
  );
22
23
 
23
- if ( ! canLock ) {
24
- return null;
25
- }
24
+ const lockButtonRef = useRef( null );
25
+ const isFirstRender = useRef( true );
26
+
27
+ const shouldHideBlockLockUI =
28
+ ! canLock || ( canEdit && canMove && canRemove );
29
+
30
+ // Restore focus manually on the first focusable element in the toolbar
31
+ // when the block lock modal is closed and the block is not locked anymore.
32
+ // See https://github.com/WordPress/gutenberg/issues/51447
33
+ useEffect( () => {
34
+ if ( isFirstRender.current ) {
35
+ isFirstRender.current = false;
36
+ return;
37
+ }
38
+
39
+ if ( ! isModalOpen && shouldHideBlockLockUI ) {
40
+ focus.focusable
41
+ .find( wrapperRef.current, {
42
+ sequential: false,
43
+ } )
44
+ .find(
45
+ ( element ) =>
46
+ element.tagName === 'BUTTON' &&
47
+ element !== lockButtonRef.current
48
+ )
49
+ ?.focus();
50
+ }
51
+ // wrapperRef is a reference object and should be stable
52
+ }, [ isModalOpen, shouldHideBlockLockUI, wrapperRef ] );
26
53
 
27
- if ( canEdit && canMove && canRemove ) {
54
+ if ( shouldHideBlockLockUI ) {
28
55
  return null;
29
56
  }
30
57
 
@@ -35,6 +62,7 @@ export default function BlockLockToolbar( { clientId } ) {
35
62
  icon={ lock }
36
63
  label={ __( 'Unlock' ) }
37
64
  onClick={ toggleModal }
65
+ ref={ lockButtonRef }
38
66
  />
39
67
  </ToolbarGroup>
40
68
  { isModalOpen && (
@@ -7,7 +7,7 @@ import { Platform } from 'react-native';
7
7
  * WordPress dependencies
8
8
  */
9
9
  import { __ } from '@wordpress/i18n';
10
- import { Picker, ToolbarButton } from '@wordpress/components';
10
+ import { Picker, ToolbarButton, ToolbarGroup } from '@wordpress/components';
11
11
  import { withInstanceId, compose } from '@wordpress/compose';
12
12
  import { withSelect, withDispatch } from '@wordpress/data';
13
13
  import { useCallback, useEffect, useRef, useState } from '@wordpress/element';
@@ -107,7 +107,7 @@ export const BlockMover = ( {
107
107
  }
108
108
 
109
109
  return (
110
- <>
110
+ <ToolbarGroup>
111
111
  <ToolbarButton
112
112
  title={ ! isFirst ? backwardButtonTitle : firstBlockTitle }
113
113
  isDisabled={ isFirst }
@@ -136,7 +136,7 @@ export const BlockMover = ( {
136
136
  leftAlign={ true }
137
137
  hideCancelButton={ Platform.OS !== 'ios' }
138
138
  />
139
- </>
139
+ </ToolbarGroup>
140
140
  );
141
141
  };
142
142
 
@@ -43,7 +43,19 @@ exports[`Block Mover Picker moving blocks moves blocks up and down 1`] = `
43
43
  `;
44
44
 
45
45
  exports[`Block Mover Picker should render without crashing and match snapshot 1`] = `
46
- [
46
+ <View
47
+ style={
48
+ [
49
+ {
50
+ "height": 44,
51
+ },
52
+ {
53
+ "borderLeftWidth": 0.5,
54
+ },
55
+ undefined,
56
+ ]
57
+ }
58
+ >
47
59
  <View>
48
60
  <View
49
61
  accessibilityHint="Double tap to move the block to the left"
@@ -99,7 +111,6 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
99
111
  }
100
112
  >
101
113
  <Svg
102
- colorScheme="light"
103
114
  height={24}
104
115
  style={{}}
105
116
  viewBox="0 0 24 24"
@@ -111,7 +122,7 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
111
122
  </View>
112
123
  </View>
113
124
  </View>
114
- </View>,
125
+ </View>
115
126
  <View>
116
127
  <View
117
128
  accessibilityHint="Double tap to move the block to the right"
@@ -167,7 +178,6 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
167
178
  }
168
179
  >
169
180
  <Svg
170
- colorScheme="light"
171
181
  height={24}
172
182
  style={{}}
173
183
  viewBox="0 0 24 24"
@@ -179,6 +189,6 @@ exports[`Block Mover Picker should render without crashing and match snapshot 1`
179
189
  </View>
180
190
  </View>
181
191
  </View>
182
- </View>,
183
- ]
192
+ </View>
193
+ </View>
184
194
  `;
@@ -14,6 +14,7 @@ import useBlockDisplayInformation from '../use-block-display-information';
14
14
  import BlockIcon from '../block-icon';
15
15
  import { useShowMoversGestures } from '../block-toolbar/utils';
16
16
  import { store as blockEditorStore } from '../../store';
17
+ import { unlock } from '../../lock-unlock';
17
18
 
18
19
  /**
19
20
  * Block parent selector component, displaying the hierarchy of the
@@ -24,14 +25,15 @@ import { store as blockEditorStore } from '../../store';
24
25
  export default function BlockParentSelector() {
25
26
  const { selectBlock, toggleBlockHighlight } =
26
27
  useDispatch( blockEditorStore );
27
- const { firstParentClientId, shouldHide, isDistractionFree } = useSelect(
28
+ const { firstParentClientId, isVisible, isDistractionFree } = useSelect(
28
29
  ( select ) => {
29
30
  const {
30
31
  getBlockName,
31
32
  getBlockParents,
32
33
  getSelectedBlockClientId,
33
34
  getSettings,
34
- } = select( blockEditorStore );
35
+ getBlockEditingMode,
36
+ } = unlock( select( blockEditorStore ) );
35
37
  const { hasBlockSupport } = select( blocksStore );
36
38
  const selectedBlockClientId = getSelectedBlockClientId();
37
39
  const parents = getBlockParents( selectedBlockClientId );
@@ -41,11 +43,14 @@ export default function BlockParentSelector() {
41
43
  const settings = getSettings();
42
44
  return {
43
45
  firstParentClientId: _firstParentClientId,
44
- shouldHide: ! hasBlockSupport(
45
- _parentBlockType,
46
- '__experimentalParentSelector',
47
- true
48
- ),
46
+ isVisible:
47
+ _firstParentClientId &&
48
+ getBlockEditingMode( _firstParentClientId ) === 'default' &&
49
+ hasBlockSupport(
50
+ _parentBlockType,
51
+ '__experimentalParentSelector',
52
+ true
53
+ ),
49
54
  isDistractionFree: settings.isDistractionFree,
50
55
  };
51
56
  },
@@ -66,7 +71,7 @@ export default function BlockParentSelector() {
66
71
  },
67
72
  } );
68
73
 
69
- if ( shouldHide || firstParentClientId === undefined ) {
74
+ if ( ! isVisible ) {
70
75
  return null;
71
76
  }
72
77
 
@@ -8,7 +8,7 @@ import {
8
8
  Button,
9
9
  __experimentalHStack as HStack,
10
10
  } from '@wordpress/components';
11
- import { __, _n } from '@wordpress/i18n';
11
+ import { __ } from '@wordpress/i18n';
12
12
 
13
13
  /**
14
14
  * Internal dependencies
@@ -16,38 +16,26 @@ import { __, _n } from '@wordpress/i18n';
16
16
  import { store as blockEditorStore } from '../../store';
17
17
  import { unlock } from '../../lock-unlock';
18
18
 
19
- // In certain editing contexts, we'd like to prevent accidental removal of
20
- // important blocks. For example, in the site editor, the Query Loop block is
21
- // deemed important. In such cases, we'll ask the user for confirmation that
22
- // they intended to remove such block(s).
23
- //
24
- // @see https://github.com/WordPress/gutenberg/pull/51145
25
- export const blockTypePromptMessages = {
26
- 'core/query': __( 'Query Loop displays a list of posts or pages.' ),
27
- 'core/post-content': __(
28
- 'Post Content displays the content of a post or page.'
29
- ),
30
- };
31
-
32
- export function BlockRemovalWarningModal() {
19
+ export function BlockRemovalWarningModal( { rules } ) {
33
20
  const { clientIds, selectPrevious, blockNamesForPrompt } = useSelect(
34
21
  ( select ) =>
35
22
  unlock( select( blockEditorStore ) ).getRemovalPromptData()
36
23
  );
37
24
 
38
25
  const {
39
- clearRemovalPrompt,
40
- toggleRemovalPromptSupport,
26
+ clearBlockRemovalPrompt,
27
+ setBlockRemovalRules,
41
28
  privateRemoveBlocks,
42
29
  } = unlock( useDispatch( blockEditorStore ) );
43
30
 
44
- // Signalling the removal prompt is in place.
31
+ // Load block removal rules, simultaneously signalling that the block
32
+ // removal prompt is in place.
45
33
  useEffect( () => {
46
- toggleRemovalPromptSupport( true );
34
+ setBlockRemovalRules( rules );
47
35
  return () => {
48
- toggleRemovalPromptSupport( false );
36
+ setBlockRemovalRules();
49
37
  };
50
- }, [ toggleRemovalPromptSupport ] );
38
+ }, [ rules, setBlockRemovalRules ] );
51
39
 
52
40
  if ( ! blockNamesForPrompt ) {
53
41
  return;
@@ -55,34 +43,30 @@ export function BlockRemovalWarningModal() {
55
43
 
56
44
  const onConfirmRemoval = () => {
57
45
  privateRemoveBlocks( clientIds, selectPrevious, /* force */ true );
58
- clearRemovalPrompt();
46
+ clearBlockRemovalPrompt();
59
47
  };
60
48
 
61
49
  return (
62
50
  <Modal
63
51
  title={ __( 'Are you sure?' ) }
64
- onRequestClose={ clearRemovalPrompt }
52
+ onRequestClose={ clearBlockRemovalPrompt }
65
53
  >
66
54
  { blockNamesForPrompt.length === 1 ? (
67
- <p>{ blockTypePromptMessages[ blockNamesForPrompt[ 0 ] ] }</p>
55
+ <p>{ rules[ blockNamesForPrompt[ 0 ] ] }</p>
68
56
  ) : (
69
57
  <ul style={ { listStyleType: 'disc', paddingLeft: '1rem' } }>
70
58
  { blockNamesForPrompt.map( ( name ) => (
71
- <li key={ name }>
72
- { blockTypePromptMessages[ name ] }
73
- </li>
59
+ <li key={ name }>{ rules[ name ] }</li>
74
60
  ) ) }
75
61
  </ul>
76
62
  ) }
77
63
  <p>
78
- { _n(
79
- 'Removing this block is not advised.',
80
- 'Removing these blocks is not advised.',
81
- blockNamesForPrompt.length
82
- ) }
64
+ { blockNamesForPrompt.length > 1
65
+ ? __( 'Removing these blocks is not advised.' )
66
+ : __( 'Removing this block is not advised.' ) }
83
67
  </p>
84
68
  <HStack justify="right">
85
- <Button variant="tertiary" onClick={ clearRemovalPrompt }>
69
+ <Button variant="tertiary" onClick={ clearBlockRemovalPrompt }>
86
70
  { __( 'Cancel' ) }
87
71
  </Button>
88
72
  <Button variant="primary" onClick={ onConfirmRemoval }>
@@ -1,7 +1,11 @@
1
1
  /**
2
2
  * WordPress dependencies
3
3
  */
4
- import { createSlotFill, ToolbarButton } from '@wordpress/components';
4
+ import {
5
+ createSlotFill,
6
+ ToolbarButton,
7
+ ToolbarGroup,
8
+ } from '@wordpress/components';
5
9
  import { __ } from '@wordpress/i18n';
6
10
  import { withDispatch } from '@wordpress/data';
7
11
  import { cog } from '@wordpress/icons';
@@ -9,11 +13,13 @@ import { cog } from '@wordpress/icons';
9
13
  const { Fill, Slot } = createSlotFill( 'SettingsToolbarButton' );
10
14
 
11
15
  const SettingsButton = ( { openGeneralSidebar } ) => (
12
- <ToolbarButton
13
- title={ __( 'Open Settings' ) }
14
- icon={ cog }
15
- onClick={ openGeneralSidebar }
16
- />
16
+ <ToolbarGroup>
17
+ <ToolbarButton
18
+ title={ __( 'Open Settings' ) }
19
+ icon={ cog }
20
+ onClick={ openGeneralSidebar }
21
+ />
22
+ </ToolbarGroup>
17
23
  );
18
24
 
19
25
  const SettingsButtonFill = ( props ) => (
@@ -9,6 +9,7 @@ import { Platform, findNodeHandle } from 'react-native';
9
9
  import {
10
10
  getClipboard,
11
11
  setClipboard,
12
+ ToolbarGroup,
12
13
  ToolbarButton,
13
14
  Picker,
14
15
  } from '@wordpress/components';
@@ -99,9 +100,11 @@ const BlockActionsMenu = ( {
99
100
  } = getMoversSetup( isStackedHorizontally, moversOptions );
100
101
 
101
102
  // Check if selected block is Groupable and/or Ungroupable.
102
- const convertToGroupButtonProps = useConvertToGroupButtonProps( [
103
- selectedBlockClientId,
104
- ] );
103
+ const convertToGroupButtonProps = useConvertToGroupButtonProps(
104
+ // `selectedBlockClientId` can be undefined in some cases where this
105
+ // component gets re-rendered right after the block is removed.
106
+ selectedBlockClientId ? [ selectedBlockClientId ] : []
107
+ );
105
108
  const { isGroupable, isUngroupable } = convertToGroupButtonProps;
106
109
  const showConvertToGroupButton =
107
110
  ( isGroupable || isUngroupable ) && canRemove;
@@ -213,16 +216,12 @@ const BlockActionsMenu = ( {
213
216
  id: 'convertToRegularBlocksOption',
214
217
  label:
215
218
  innerBlockCount > 1
216
- ? __( 'Convert to regular blocks' )
217
- : __( 'Convert to regular block' ),
219
+ ? __( 'Detach patterns' )
220
+ : __( 'Detach pattern' ),
218
221
  value: 'convertToRegularBlocksOption',
219
222
  onSelect: () => {
220
- const successNotice =
221
- innerBlockCount > 1
222
- ? /* translators: %s: name of the reusable block */
223
- __( '%s converted to regular blocks' )
224
- : /* translators: %s: name of the reusable block */
225
- __( '%s converted to regular block' );
223
+ /* translators: %s: name of the synced block */
224
+ const successNotice = __( '%s detached' );
226
225
  createSuccessNotice(
227
226
  sprintf(
228
227
  successNotice,
@@ -258,11 +257,13 @@ const BlockActionsMenu = ( {
258
257
  // End early if there are no options to show.
259
258
  if ( ! options.length ) {
260
259
  return (
261
- <ToolbarButton
262
- title={ __( 'Open Block Actions Menu' ) }
263
- icon={ moreHorizontalMobile }
264
- disabled={ true }
265
- />
260
+ <ToolbarGroup>
261
+ <ToolbarButton
262
+ title={ __( 'Open Block Actions Menu' ) }
263
+ icon={ moreHorizontalMobile }
264
+ disabled={ true }
265
+ />
266
+ </ToolbarGroup>
266
267
  );
267
268
  }
268
269
 
@@ -298,7 +299,7 @@ const BlockActionsMenu = ( {
298
299
  anchorNodeRef ? findNodeHandle( anchorNodeRef ) : undefined;
299
300
 
300
301
  return (
301
- <>
302
+ <ToolbarGroup>
302
303
  <ToolbarButton
303
304
  title={ __( 'Open Block Actions Menu' ) }
304
305
  onClick={ onPickerPresent }
@@ -328,7 +329,7 @@ const BlockActionsMenu = ( {
328
329
  selectedBlock={ getBlocksByClientId( selectedBlockClientId ) }
329
330
  selectedBlockClientId={ selectedBlockClientId }
330
331
  />
331
- </>
332
+ </ToolbarGroup>
332
333
  );
333
334
  };
334
335
 
@@ -35,9 +35,9 @@ import __unstableBlockNameContext from './block-name-context';
35
35
  import { unlock } from '../../lock-unlock';
36
36
 
37
37
  const BlockToolbar = ( { hideDragHandle } ) => {
38
+ const { getSelectedBlockClientId } = useSelect( blockEditorStore );
38
39
  const {
39
40
  blockClientIds,
40
- blockClientId,
41
41
  blockType,
42
42
  hasFixedToolbar,
43
43
  isDistractionFree,
@@ -61,7 +61,6 @@ const BlockToolbar = ( { hideDragHandle } ) => {
61
61
 
62
62
  return {
63
63
  blockClientIds: selectedBlockClientIds,
64
- blockClientId: selectedBlockClientId,
65
64
  blockType:
66
65
  selectedBlockClientId &&
67
66
  getBlockType( getBlockName( selectedBlockClientId ) ),
@@ -78,6 +77,8 @@ const BlockToolbar = ( { hideDragHandle } ) => {
78
77
  };
79
78
  }, [] );
80
79
 
80
+ const toolbarWrapperRef = useRef( null );
81
+
81
82
  // Handles highlighting the current block outline on hover or focus of the
82
83
  // block type toolbar area.
83
84
  const { toggleBlockHighlight } = useDispatch( blockEditorStore );
@@ -89,7 +90,7 @@ const BlockToolbar = ( { hideDragHandle } ) => {
89
90
  if ( isFocused && isDistractionFree ) {
90
91
  return;
91
92
  }
92
- toggleBlockHighlight( blockClientId, isFocused );
93
+ toggleBlockHighlight( getSelectedBlockClientId(), isFocused );
93
94
  },
94
95
  }
95
96
  );
@@ -123,18 +124,19 @@ const BlockToolbar = ( { hideDragHandle } ) => {
123
124
  } );
124
125
 
125
126
  return (
126
- <div className={ classes }>
127
+ <div className={ classes } ref={ toolbarWrapperRef }>
127
128
  { ! isMultiToolbar &&
128
129
  isLargeViewport &&
129
130
  blockEditingMode === 'default' && <BlockParentSelector /> }
130
- <div ref={ nodeRef } { ...showMoversGestures }>
131
- { ( shouldShowVisualToolbar || isMultiToolbar ) &&
132
- blockEditingMode === 'default' && (
131
+ { ( shouldShowVisualToolbar || isMultiToolbar ) &&
132
+ blockEditingMode === 'default' && (
133
+ <div ref={ nodeRef } { ...showMoversGestures }>
133
134
  <ToolbarGroup className="block-editor-block-toolbar__block-controls">
134
135
  <BlockSwitcher clientIds={ blockClientIds } />
135
136
  { ! isMultiToolbar && (
136
137
  <BlockLockToolbar
137
138
  clientId={ blockClientIds[ 0 ] }
139
+ wrapperRef={ toolbarWrapperRef }
138
140
  />
139
141
  ) }
140
142
  <BlockMover
@@ -142,8 +144,8 @@ const BlockToolbar = ( { hideDragHandle } ) => {
142
144
  hideDragHandle={ hideDragHandle }
143
145
  />
144
146
  </ToolbarGroup>
145
- ) }
146
- </div>
147
+ </div>
148
+ ) }
147
149
  { shouldShowVisualToolbar && isMultiToolbar && (
148
150
  <BlockGroupToolbar />
149
151
  ) }