@wordpress/block-editor 12.0.0 → 12.2.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 (627) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/README.md +1 -1
  3. package/build/autocompleters/block.js +13 -5
  4. package/build/autocompleters/block.js.map +1 -1
  5. package/build/components/block-breadcrumb/index.js +6 -3
  6. package/build/components/block-breadcrumb/index.js.map +1 -1
  7. package/build/components/block-controls/slot.js +12 -4
  8. package/build/components/block-controls/slot.js.map +1 -1
  9. package/build/components/block-controls/slot.native.js +10 -1
  10. package/build/components/block-controls/slot.native.js.map +1 -1
  11. package/build/components/block-draggable/index.js +11 -7
  12. package/build/components/block-draggable/index.js.map +1 -1
  13. package/build/components/block-draggable/use-scroll-when-dragging.js +2 -2
  14. package/build/components/block-draggable/use-scroll-when-dragging.js.map +1 -1
  15. package/build/components/block-editing-mode/index.js +84 -0
  16. package/build/components/block-editing-mode/index.js.map +1 -0
  17. package/build/components/block-list/block-invalid-warning.native.js +15 -7
  18. package/build/components/block-list/block-invalid-warning.native.js.map +1 -1
  19. package/build/components/block-list/block-list-block-context.js +15 -0
  20. package/build/components/block-list/block-list-block-context.js.map +1 -0
  21. package/build/components/block-list/block-list-item-cell.native.js +15 -2
  22. package/build/components/block-list/block-list-item-cell.native.js.map +1 -1
  23. package/build/components/block-list/block-list-item.native.js +158 -195
  24. package/build/components/block-list/block-list-item.native.js.map +1 -1
  25. package/build/components/block-list/block-outline.native.js +57 -0
  26. package/build/components/block-list/block-outline.native.js.map +1 -0
  27. package/build/components/block-list/block.js +29 -37
  28. package/build/components/block-list/block.js.map +1 -1
  29. package/build/components/block-list/block.native.js +347 -311
  30. package/build/components/block-list/block.native.js.map +1 -1
  31. package/build/components/block-list/index.native.js +260 -357
  32. package/build/components/block-list/index.native.js.map +1 -1
  33. package/build/components/block-list/insertion-point.native.js +4 -2
  34. package/build/components/block-list/insertion-point.native.js.map +1 -1
  35. package/build/components/block-list/use-block-props/index.js +2 -2
  36. package/build/components/block-list/use-block-props/index.js.map +1 -1
  37. package/build/components/block-list/use-in-between-inserter.js +7 -5
  38. package/build/components/block-list/use-in-between-inserter.js.map +1 -1
  39. package/build/components/block-list-appender/index.js +15 -1
  40. package/build/components/block-list-appender/index.js.map +1 -1
  41. package/build/components/block-mobile-toolbar/block-actions-menu.native.js +19 -4
  42. package/build/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
  43. package/build/components/block-settings-menu/block-settings-dropdown.js +8 -10
  44. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  45. package/build/components/block-settings-menu-controls/index.js +15 -4
  46. package/build/components/block-settings-menu-controls/index.js.map +1 -1
  47. package/build/components/block-styles/preview-panel.js +1 -2
  48. package/build/components/block-styles/preview-panel.js.map +1 -1
  49. package/build/components/block-switcher/block-transformations-menu.js +8 -0
  50. package/build/components/block-switcher/block-transformations-menu.js.map +1 -1
  51. package/build/components/block-switcher/block-variation-transformations.js +125 -0
  52. package/build/components/block-switcher/block-variation-transformations.js.map +1 -0
  53. package/build/components/block-switcher/index.js +34 -12
  54. package/build/components/block-switcher/index.js.map +1 -1
  55. package/build/components/block-switcher/pattern-transformations-menu.js +3 -3
  56. package/build/components/block-switcher/pattern-transformations-menu.js.map +1 -1
  57. package/build/components/block-toolbar/index.js +9 -7
  58. package/build/components/block-toolbar/index.js.map +1 -1
  59. package/build/components/block-tools/block-contextual-toolbar.js +22 -65
  60. package/build/components/block-tools/block-contextual-toolbar.js.map +1 -1
  61. package/build/components/block-tools/insertion-point.js +11 -5
  62. package/build/components/block-tools/insertion-point.js.map +1 -1
  63. package/build/components/block-tools/selected-block-popover.js +3 -8
  64. package/build/components/block-tools/selected-block-popover.js.map +1 -1
  65. package/build/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +3 -2
  66. package/build/components/colors-gradients/use-multiple-origin-colors-and-gradients.js.map +1 -1
  67. package/build/components/convert-to-group-buttons/index.js +7 -2
  68. package/build/components/convert-to-group-buttons/index.js.map +1 -1
  69. package/build/components/convert-to-group-buttons/index.native.js +87 -3
  70. package/build/components/convert-to-group-buttons/index.native.js.map +1 -1
  71. package/build/components/convert-to-group-buttons/use-convert-to-group-button-props.js +23 -37
  72. package/build/components/convert-to-group-buttons/use-convert-to-group-button-props.js.map +1 -1
  73. package/build/components/global-styles/advanced-panel.js +86 -0
  74. package/build/components/global-styles/advanced-panel.js.map +1 -0
  75. package/build/components/global-styles/color-panel.js +4 -1
  76. package/build/components/global-styles/color-panel.js.map +1 -1
  77. package/build/components/global-styles/dimensions-panel.js +9 -8
  78. package/build/components/global-styles/dimensions-panel.js.map +1 -1
  79. package/build/components/global-styles/hooks.js +1 -2
  80. package/build/components/global-styles/hooks.js.map +1 -1
  81. package/build/components/global-styles/index.js +24 -0
  82. package/build/components/global-styles/index.js.map +1 -1
  83. package/build/components/global-styles/typography-panel.js +1 -1
  84. package/build/components/global-styles/typography-panel.js.map +1 -1
  85. package/build/components/global-styles/use-global-styles-output.js +27 -4
  86. package/build/components/global-styles/use-global-styles-output.js.map +1 -1
  87. package/build/components/global-styles/utils.js +30 -0
  88. package/build/components/global-styles/utils.js.map +1 -1
  89. package/build/components/iframe/index.js +14 -7
  90. package/build/components/iframe/index.js.map +1 -1
  91. package/build/components/image-editor/use-save-image.js +24 -8
  92. package/build/components/image-editor/use-save-image.js.map +1 -1
  93. package/build/components/inner-blocks/index.js +2 -1
  94. package/build/components/inner-blocks/index.js.map +1 -1
  95. package/build/components/inner-blocks/index.native.js +7 -7
  96. package/build/components/inner-blocks/index.native.js.map +1 -1
  97. package/build/components/inner-blocks/use-nested-settings-update.js +13 -5
  98. package/build/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  99. package/build/components/inserter/index.js +3 -7
  100. package/build/components/inserter/index.js.map +1 -1
  101. package/build/components/inserter/quick-inserter.js +2 -4
  102. package/build/components/inserter/quick-inserter.js.map +1 -1
  103. package/build/components/inserter/search-results.js +19 -6
  104. package/build/components/inserter/search-results.js.map +1 -1
  105. package/build/components/inserter-draggable-blocks/index.js +5 -0
  106. package/build/components/inserter-draggable-blocks/index.js.map +1 -1
  107. package/build/components/inspector-controls/fill.js +1 -1
  108. package/build/components/inspector-controls/fill.js.map +1 -1
  109. package/build/components/inspector-controls/fill.native.js +1 -1
  110. package/build/components/inspector-controls/fill.native.js.map +1 -1
  111. package/build/components/inspector-controls/slot.js +3 -6
  112. package/build/components/inspector-controls/slot.js.map +1 -1
  113. package/build/components/inspector-controls/slot.native.js +1 -1
  114. package/build/components/inspector-controls/slot.native.js.map +1 -1
  115. package/build/components/line-height-control/index.js +7 -2
  116. package/build/components/line-height-control/index.js.map +1 -1
  117. package/build/components/link-control/use-internal-input-value.js +9 -8
  118. package/build/components/link-control/use-internal-input-value.js.map +1 -1
  119. package/build/components/list-view/appender.js +6 -1
  120. package/build/components/list-view/appender.js.map +1 -1
  121. package/build/components/list-view/block-contents.js +9 -2
  122. package/build/components/list-view/block-contents.js.map +1 -1
  123. package/build/components/list-view/block-select-button.js +2 -1
  124. package/build/components/list-view/block-select-button.js.map +1 -1
  125. package/build/components/list-view/block.js +25 -29
  126. package/build/components/list-view/block.js.map +1 -1
  127. package/build/components/list-view/branch.js +1 -3
  128. package/build/components/list-view/branch.js.map +1 -1
  129. package/build/components/list-view/index.js +43 -22
  130. package/build/components/list-view/index.js.map +1 -1
  131. package/build/components/list-view/use-list-view-client-ids.js +27 -3
  132. package/build/components/list-view/use-list-view-client-ids.js.map +1 -1
  133. package/build/components/list-view/use-list-view-drop-zone.js +163 -11
  134. package/build/components/list-view/use-list-view-drop-zone.js.map +1 -1
  135. package/build/components/media-placeholder/index.js +68 -7
  136. package/build/components/media-placeholder/index.js.map +1 -1
  137. package/build/components/multi-selection-inspector/index.js +2 -2
  138. package/build/components/multi-selection-inspector/index.js.map +1 -1
  139. package/build/components/preview-options/index.js +6 -1
  140. package/build/components/preview-options/index.js.map +1 -1
  141. package/build/components/publish-date-time-picker/index.js +0 -2
  142. package/build/components/publish-date-time-picker/index.js.map +1 -1
  143. package/build/components/spacing-sizes-control/spacing-input-control.js +1 -1
  144. package/build/components/spacing-sizes-control/spacing-input-control.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-drop-zone/index.js +25 -15
  148. package/build/components/use-block-drop-zone/index.js.map +1 -1
  149. package/build/components/use-resize-canvas/index.js +8 -1
  150. package/build/components/use-resize-canvas/index.js.map +1 -1
  151. package/build/components/writing-flow/use-arrow-nav.js +13 -7
  152. package/build/components/writing-flow/use-arrow-nav.js.map +1 -1
  153. package/build/hooks/align.js +4 -8
  154. package/build/hooks/align.js.map +1 -1
  155. package/build/hooks/behaviors.js +115 -0
  156. package/build/hooks/behaviors.js.map +1 -0
  157. package/build/hooks/border.js +1 -1
  158. package/build/hooks/border.js.map +1 -1
  159. package/build/hooks/color.js +1 -1
  160. package/build/hooks/color.js.map +1 -1
  161. package/build/hooks/content-lock-ui.js +8 -12
  162. package/build/hooks/content-lock-ui.js.map +1 -1
  163. package/build/hooks/dimensions.js +0 -30
  164. package/build/hooks/dimensions.js.map +1 -1
  165. package/build/hooks/duotone.js +5 -9
  166. package/build/hooks/duotone.js.map +1 -1
  167. package/build/hooks/index.js +2 -0
  168. package/build/hooks/index.js.map +1 -1
  169. package/build/hooks/index.native.js +8 -0
  170. package/build/hooks/index.native.js.map +1 -1
  171. package/build/hooks/layout.js +10 -11
  172. package/build/hooks/layout.js.map +1 -1
  173. package/build/hooks/position.js +1 -1
  174. package/build/hooks/position.js.map +1 -1
  175. package/build/hooks/style.js +1 -1
  176. package/build/hooks/style.js.map +1 -1
  177. package/build/hooks/use-editor-wrapper-styles.native.js +255 -0
  178. package/build/hooks/use-editor-wrapper-styles.native.js.map +1 -0
  179. package/build/hooks/use-typography-props.js +14 -10
  180. package/build/hooks/use-typography-props.js.map +1 -1
  181. package/build/index.native.js +31 -0
  182. package/build/index.native.js.map +1 -0
  183. package/build/private-apis.js +4 -7
  184. package/build/private-apis.js.map +1 -1
  185. package/build/store/private-actions.js +46 -0
  186. package/build/store/private-actions.js.map +1 -1
  187. package/build/store/private-selectors.js +88 -0
  188. package/build/store/private-selectors.js.map +1 -1
  189. package/build/store/reducer.js +36 -1
  190. package/build/store/reducer.js.map +1 -1
  191. package/build/store/selectors.js +28 -18
  192. package/build/store/selectors.js.map +1 -1
  193. package/build/utils/order-inserter-block-items.js +41 -0
  194. package/build/utils/order-inserter-block-items.js.map +1 -0
  195. package/build/utils/use-should-contextual-toolbar-show.js +16 -12
  196. package/build/utils/use-should-contextual-toolbar-show.js.map +1 -1
  197. package/build-module/autocompleters/block.js +12 -5
  198. package/build-module/autocompleters/block.js.map +1 -1
  199. package/build-module/components/block-breadcrumb/index.js +5 -3
  200. package/build-module/components/block-breadcrumb/index.js.map +1 -1
  201. package/build-module/components/block-controls/slot.js +11 -4
  202. package/build-module/components/block-controls/slot.js.map +1 -1
  203. package/build-module/components/block-controls/slot.native.js +9 -1
  204. package/build-module/components/block-controls/slot.native.js.map +1 -1
  205. package/build-module/components/block-draggable/index.js +10 -6
  206. package/build-module/components/block-draggable/index.js.map +1 -1
  207. package/build-module/components/block-draggable/use-scroll-when-dragging.js +2 -2
  208. package/build-module/components/block-draggable/use-scroll-when-dragging.js.map +1 -1
  209. package/build-module/components/block-editing-mode/index.js +72 -0
  210. package/build-module/components/block-editing-mode/index.js.map +1 -0
  211. package/build-module/components/block-list/block-invalid-warning.native.js +16 -8
  212. package/build-module/components/block-list/block-invalid-warning.native.js.map +1 -1
  213. package/build-module/components/block-list/block-list-block-context.js +6 -0
  214. package/build-module/components/block-list/block-list-block-context.js.map +1 -0
  215. package/build-module/components/block-list/block-list-item-cell.native.js +13 -2
  216. package/build-module/components/block-list/block-list-item-cell.native.js.map +1 -1
  217. package/build-module/components/block-list/block-list-item.native.js +160 -190
  218. package/build-module/components/block-list/block-list-item.native.js.map +1 -1
  219. package/build-module/components/block-list/block-outline.native.js +44 -0
  220. package/build-module/components/block-list/block-outline.native.js.map +1 -0
  221. package/build-module/components/block-list/block.js +26 -34
  222. package/build-module/components/block-list/block.js.map +1 -1
  223. package/build-module/components/block-list/block.native.js +345 -310
  224. package/build-module/components/block-list/block.native.js.map +1 -1
  225. package/build-module/components/block-list/index.native.js +263 -355
  226. package/build-module/components/block-list/index.native.js.map +1 -1
  227. package/build-module/components/block-list/insertion-point.native.js +4 -2
  228. package/build-module/components/block-list/insertion-point.native.js.map +1 -1
  229. package/build-module/components/block-list/use-block-props/index.js +1 -1
  230. package/build-module/components/block-list/use-block-props/index.js.map +1 -1
  231. package/build-module/components/block-list/use-in-between-inserter.js +6 -5
  232. package/build-module/components/block-list/use-in-between-inserter.js.map +1 -1
  233. package/build-module/components/block-list-appender/index.js +15 -1
  234. package/build-module/components/block-list-appender/index.js.map +1 -1
  235. package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js +18 -4
  236. package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
  237. package/build-module/components/block-settings-menu/block-settings-dropdown.js +8 -9
  238. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  239. package/build-module/components/block-settings-menu-controls/index.js +13 -5
  240. package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
  241. package/build-module/components/block-styles/preview-panel.js +1 -2
  242. package/build-module/components/block-styles/preview-panel.js.map +1 -1
  243. package/build-module/components/block-switcher/block-transformations-menu.js +7 -0
  244. package/build-module/components/block-switcher/block-transformations-menu.js.map +1 -1
  245. package/build-module/components/block-switcher/block-variation-transformations.js +108 -0
  246. package/build-module/components/block-switcher/block-variation-transformations.js.map +1 -0
  247. package/build-module/components/block-switcher/index.js +33 -12
  248. package/build-module/components/block-switcher/index.js.map +1 -1
  249. package/build-module/components/block-switcher/pattern-transformations-menu.js +3 -3
  250. package/build-module/components/block-switcher/pattern-transformations-menu.js.map +1 -1
  251. package/build-module/components/block-toolbar/index.js +8 -7
  252. package/build-module/components/block-toolbar/index.js.map +1 -1
  253. package/build-module/components/block-tools/block-contextual-toolbar.js +22 -65
  254. package/build-module/components/block-tools/block-contextual-toolbar.js.map +1 -1
  255. package/build-module/components/block-tools/insertion-point.js +11 -5
  256. package/build-module/components/block-tools/insertion-point.js.map +1 -1
  257. package/build-module/components/block-tools/selected-block-popover.js +3 -7
  258. package/build-module/components/block-tools/selected-block-popover.js.map +1 -1
  259. package/build-module/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +3 -2
  260. package/build-module/components/colors-gradients/use-multiple-origin-colors-and-gradients.js.map +1 -1
  261. package/build-module/components/convert-to-group-buttons/index.js +7 -2
  262. package/build-module/components/convert-to-group-buttons/index.js.map +1 -1
  263. package/build-module/components/convert-to-group-buttons/index.native.js +76 -1
  264. package/build-module/components/convert-to-group-buttons/index.native.js.map +1 -1
  265. package/build-module/components/convert-to-group-buttons/use-convert-to-group-button-props.js +22 -36
  266. package/build-module/components/convert-to-group-buttons/use-convert-to-group-button-props.js.map +1 -1
  267. package/build-module/components/global-styles/advanced-panel.js +74 -0
  268. package/build-module/components/global-styles/advanced-panel.js.map +1 -0
  269. package/build-module/components/global-styles/color-panel.js +5 -2
  270. package/build-module/components/global-styles/color-panel.js.map +1 -1
  271. package/build-module/components/global-styles/dimensions-panel.js +9 -8
  272. package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
  273. package/build-module/components/global-styles/hooks.js +1 -2
  274. package/build-module/components/global-styles/hooks.js.map +1 -1
  275. package/build-module/components/global-styles/index.js +3 -1
  276. package/build-module/components/global-styles/index.js.map +1 -1
  277. package/build-module/components/global-styles/typography-panel.js +1 -1
  278. package/build-module/components/global-styles/typography-panel.js.map +1 -1
  279. package/build-module/components/global-styles/use-global-styles-output.js +25 -4
  280. package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
  281. package/build-module/components/global-styles/utils.js +25 -0
  282. package/build-module/components/global-styles/utils.js.map +1 -1
  283. package/build-module/components/iframe/index.js +15 -8
  284. package/build-module/components/iframe/index.js.map +1 -1
  285. package/build-module/components/image-editor/use-save-image.js +24 -8
  286. package/build-module/components/image-editor/use-save-image.js.map +1 -1
  287. package/build-module/components/inner-blocks/index.js +2 -1
  288. package/build-module/components/inner-blocks/index.js.map +1 -1
  289. package/build-module/components/inner-blocks/index.native.js +7 -6
  290. package/build-module/components/inner-blocks/index.native.js.map +1 -1
  291. package/build-module/components/inner-blocks/use-nested-settings-update.js +13 -5
  292. package/build-module/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  293. package/build-module/components/inserter/index.js +3 -7
  294. package/build-module/components/inserter/index.js.map +1 -1
  295. package/build-module/components/inserter/quick-inserter.js +2 -4
  296. package/build-module/components/inserter/quick-inserter.js.map +1 -1
  297. package/build-module/components/inserter/search-results.js +16 -6
  298. package/build-module/components/inserter/search-results.js.map +1 -1
  299. package/build-module/components/inserter-draggable-blocks/index.js +4 -0
  300. package/build-module/components/inserter-draggable-blocks/index.js.map +1 -1
  301. package/build-module/components/inspector-controls/fill.js +1 -1
  302. package/build-module/components/inspector-controls/fill.js.map +1 -1
  303. package/build-module/components/inspector-controls/fill.native.js +1 -1
  304. package/build-module/components/inspector-controls/fill.native.js.map +1 -1
  305. package/build-module/components/inspector-controls/slot.js +4 -7
  306. package/build-module/components/inspector-controls/slot.js.map +1 -1
  307. package/build-module/components/inspector-controls/slot.native.js +1 -1
  308. package/build-module/components/inspector-controls/slot.native.js.map +1 -1
  309. package/build-module/components/line-height-control/index.js +7 -2
  310. package/build-module/components/line-height-control/index.js.map +1 -1
  311. package/build-module/components/link-control/use-internal-input-value.js +9 -8
  312. package/build-module/components/link-control/use-internal-input-value.js.map +1 -1
  313. package/build-module/components/list-view/appender.js +6 -2
  314. package/build-module/components/list-view/appender.js.map +1 -1
  315. package/build-module/components/list-view/block-contents.js +9 -3
  316. package/build-module/components/list-view/block-contents.js.map +1 -1
  317. package/build-module/components/list-view/block-select-button.js +2 -1
  318. package/build-module/components/list-view/block-select-button.js.map +1 -1
  319. package/build-module/components/list-view/block.js +24 -29
  320. package/build-module/components/list-view/block.js.map +1 -1
  321. package/build-module/components/list-view/branch.js +1 -3
  322. package/build-module/components/list-view/branch.js.map +1 -1
  323. package/build-module/components/list-view/index.js +44 -23
  324. package/build-module/components/list-view/index.js.map +1 -1
  325. package/build-module/components/list-view/use-list-view-client-ids.js +26 -3
  326. package/build-module/components/list-view/use-list-view-client-ids.js.map +1 -1
  327. package/build-module/components/list-view/use-list-view-drop-zone.js +160 -11
  328. package/build-module/components/list-view/use-list-view-drop-zone.js.map +1 -1
  329. package/build-module/components/media-placeholder/index.js +66 -7
  330. package/build-module/components/media-placeholder/index.js.map +1 -1
  331. package/build-module/components/multi-selection-inspector/index.js +2 -2
  332. package/build-module/components/multi-selection-inspector/index.js.map +1 -1
  333. package/build-module/components/preview-options/index.js +7 -2
  334. package/build-module/components/preview-options/index.js.map +1 -1
  335. package/build-module/components/publish-date-time-picker/index.js +0 -2
  336. package/build-module/components/publish-date-time-picker/index.js.map +1 -1
  337. package/build-module/components/spacing-sizes-control/spacing-input-control.js +1 -1
  338. package/build-module/components/spacing-sizes-control/spacing-input-control.js.map +1 -1
  339. package/build-module/components/url-input/index.js +4 -2
  340. package/build-module/components/url-input/index.js.map +1 -1
  341. package/build-module/components/use-block-drop-zone/index.js +25 -16
  342. package/build-module/components/use-block-drop-zone/index.js.map +1 -1
  343. package/build-module/components/use-resize-canvas/index.js +8 -1
  344. package/build-module/components/use-resize-canvas/index.js.map +1 -1
  345. package/build-module/components/writing-flow/use-arrow-nav.js +13 -7
  346. package/build-module/components/writing-flow/use-arrow-nav.js.map +1 -1
  347. package/build-module/hooks/align.js +4 -7
  348. package/build-module/hooks/align.js.map +1 -1
  349. package/build-module/hooks/behaviors.js +97 -0
  350. package/build-module/hooks/behaviors.js.map +1 -0
  351. package/build-module/hooks/border.js +1 -1
  352. package/build-module/hooks/border.js.map +1 -1
  353. package/build-module/hooks/color.js +1 -1
  354. package/build-module/hooks/color.js.map +1 -1
  355. package/build-module/hooks/content-lock-ui.js +8 -11
  356. package/build-module/hooks/content-lock-ui.js.map +1 -1
  357. package/build-module/hooks/dimensions.js +0 -28
  358. package/build-module/hooks/dimensions.js.map +1 -1
  359. package/build-module/hooks/duotone.js +4 -7
  360. package/build-module/hooks/duotone.js.map +1 -1
  361. package/build-module/hooks/index.js +1 -0
  362. package/build-module/hooks/index.js.map +1 -1
  363. package/build-module/hooks/index.native.js +1 -0
  364. package/build-module/hooks/index.native.js.map +1 -1
  365. package/build-module/hooks/layout.js +9 -11
  366. package/build-module/hooks/layout.js.map +1 -1
  367. package/build-module/hooks/position.js +1 -1
  368. package/build-module/hooks/position.js.map +1 -1
  369. package/build-module/hooks/style.js +1 -1
  370. package/build-module/hooks/style.js.map +1 -1
  371. package/build-module/hooks/use-editor-wrapper-styles.native.js +242 -0
  372. package/build-module/hooks/use-editor-wrapper-styles.native.js.map +1 -0
  373. package/build-module/hooks/use-typography-props.js +14 -10
  374. package/build-module/hooks/use-typography-props.js.map +1 -1
  375. package/build-module/index.native.js +6 -0
  376. package/build-module/index.native.js.map +1 -0
  377. package/build-module/private-apis.js +3 -5
  378. package/build-module/private-apis.js.map +1 -1
  379. package/build-module/store/private-actions.js +42 -0
  380. package/build-module/store/private-actions.js.map +1 -1
  381. package/build-module/store/private-selectors.js +79 -0
  382. package/build-module/store/private-selectors.js.map +1 -1
  383. package/build-module/store/reducer.js +34 -1
  384. package/build-module/store/reducer.js.map +1 -1
  385. package/build-module/store/selectors.js +26 -17
  386. package/build-module/store/selectors.js.map +1 -1
  387. package/build-module/utils/order-inserter-block-items.js +32 -0
  388. package/build-module/utils/order-inserter-block-items.js.map +1 -0
  389. package/build-module/utils/use-should-contextual-toolbar-show.js +16 -12
  390. package/build-module/utils/use-should-contextual-toolbar-show.js.map +1 -1
  391. package/build-style/content-rtl.css +32 -14
  392. package/build-style/content.css +32 -14
  393. package/build-style/default-editor-styles-rtl.css +1 -1
  394. package/build-style/default-editor-styles.css +1 -1
  395. package/build-style/style-rtl.css +56 -77
  396. package/build-style/style.css +57 -77
  397. package/package.json +32 -31
  398. package/src/autocompleters/block.js +15 -7
  399. package/src/components/block-breadcrumb/index.js +11 -3
  400. package/src/components/block-breadcrumb/style.scss +2 -1
  401. package/src/components/block-controls/slot.js +8 -4
  402. package/src/components/block-controls/slot.native.js +6 -1
  403. package/src/components/block-draggable/index.js +10 -6
  404. package/src/components/block-draggable/use-scroll-when-dragging.js +8 -2
  405. package/src/components/block-editing-mode/index.js +71 -0
  406. package/src/components/block-list/block-invalid-warning.native.js +17 -9
  407. package/src/components/block-list/block-list-block-context.js +6 -0
  408. package/src/components/block-list/block-list-item-cell.native.js +10 -1
  409. package/src/components/block-list/block-list-item.native.js +180 -208
  410. package/src/components/block-list/block-outline.native.js +58 -0
  411. package/src/components/block-list/block.js +38 -56
  412. package/src/components/block-list/block.native.js +531 -501
  413. package/src/components/block-list/content.scss +5 -6
  414. package/src/components/block-list/index.native.js +324 -382
  415. package/src/components/block-list/insertion-point.native.js +2 -2
  416. package/src/components/block-list/test/block-invalid-warning.native.js +48 -0
  417. package/src/components/block-list/test/index.native.js +205 -0
  418. package/src/components/block-list/use-block-props/index.js +1 -1
  419. package/src/components/block-list/use-in-between-inserter.js +7 -3
  420. package/src/components/block-list-appender/index.js +22 -4
  421. package/src/components/block-mobile-toolbar/block-actions-menu.native.js +26 -1
  422. package/src/components/block-mover/style.scss +1 -0
  423. package/src/components/block-pattern-setup/style.scss +1 -4
  424. package/src/components/block-patterns-list/style.scss +1 -4
  425. package/src/components/block-settings-menu/block-settings-dropdown.js +10 -17
  426. package/src/components/block-settings-menu-controls/index.js +24 -4
  427. package/src/components/block-styles/preview-panel.js +1 -3
  428. package/src/components/block-styles/style.scss +4 -4
  429. package/src/components/block-switcher/block-transformations-menu.js +12 -0
  430. package/src/components/block-switcher/block-variation-transformations.js +115 -0
  431. package/src/components/block-switcher/index.js +38 -5
  432. package/src/components/block-switcher/pattern-transformations-menu.js +5 -5
  433. package/src/components/block-switcher/style.scss +6 -5
  434. package/src/components/block-toolbar/index.js +10 -11
  435. package/src/components/block-tools/block-contextual-toolbar.js +32 -67
  436. package/src/components/block-tools/insertion-point.js +23 -9
  437. package/src/components/block-tools/selected-block-popover.js +3 -5
  438. package/src/components/block-tools/style.scss +8 -0
  439. package/src/components/button-block-appender/content.scss +22 -0
  440. package/src/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +16 -2
  441. package/src/components/convert-to-group-buttons/index.js +9 -2
  442. package/src/components/convert-to-group-buttons/index.native.js +79 -1
  443. package/src/components/convert-to-group-buttons/use-convert-to-group-button-props.js +32 -38
  444. package/src/components/global-styles/advanced-panel.js +82 -0
  445. package/src/components/global-styles/color-panel.js +6 -1
  446. package/src/components/global-styles/dimensions-panel.js +9 -8
  447. package/src/components/global-styles/hooks.js +1 -5
  448. package/src/components/global-styles/index.js +6 -1
  449. package/src/components/global-styles/style.scss +17 -0
  450. package/src/components/global-styles/test/utils.js +57 -1
  451. package/src/components/global-styles/typography-panel.js +1 -1
  452. package/src/components/global-styles/use-global-styles-output.js +21 -3
  453. package/src/components/global-styles/utils.js +27 -0
  454. package/src/components/iframe/index.js +22 -12
  455. package/src/components/image-editor/use-save-image.js +20 -9
  456. package/src/components/inner-blocks/README.md +5 -0
  457. package/src/components/inner-blocks/index.js +2 -0
  458. package/src/components/inner-blocks/index.native.js +16 -6
  459. package/src/components/inner-blocks/use-nested-settings-update.js +20 -3
  460. package/src/components/inserter/index.js +1 -9
  461. package/src/components/inserter/quick-inserter.js +0 -2
  462. package/src/components/inserter/search-results.js +32 -6
  463. package/src/components/inserter-draggable-blocks/index.js +4 -0
  464. package/src/components/inspector-controls/fill.js +1 -1
  465. package/src/components/inspector-controls/fill.native.js +1 -1
  466. package/src/components/inspector-controls/slot.js +4 -9
  467. package/src/components/inspector-controls/slot.native.js +1 -1
  468. package/src/components/line-height-control/index.js +7 -2
  469. package/src/components/line-height-control/stories/index.js +1 -1
  470. package/src/components/link-control/test/index.js +42 -0
  471. package/src/components/link-control/use-internal-input-value.js +8 -7
  472. package/src/components/list-view/appender.js +3 -2
  473. package/src/components/list-view/block-contents.js +32 -20
  474. package/src/components/list-view/block-select-button.js +5 -1
  475. package/src/components/list-view/block.js +34 -37
  476. package/src/components/list-view/branch.js +1 -7
  477. package/src/components/list-view/index.js +42 -17
  478. package/src/components/list-view/style.scss +7 -7
  479. package/src/components/list-view/test/use-list-view-drop-zone.js +88 -12
  480. package/src/components/list-view/use-list-view-client-ids.js +21 -4
  481. package/src/components/list-view/use-list-view-drop-zone.js +194 -11
  482. package/src/components/media-placeholder/index.js +74 -1
  483. package/src/components/multi-selection-inspector/index.js +2 -2
  484. package/src/components/preview-options/index.js +9 -2
  485. package/src/components/publish-date-time-picker/index.js +0 -2
  486. package/src/components/spacing-sizes-control/spacing-input-control.js +1 -0
  487. package/src/components/url-input/README.md +6 -0
  488. package/src/components/url-input/index.js +2 -2
  489. package/src/components/use-block-drop-zone/index.js +31 -17
  490. package/src/components/use-resize-canvas/index.js +9 -1
  491. package/src/components/writing-flow/test/index.js +15 -0
  492. package/src/components/writing-flow/use-arrow-nav.js +17 -4
  493. package/src/hooks/align.js +5 -12
  494. package/src/hooks/behaviors.js +104 -0
  495. package/src/hooks/border.js +2 -1
  496. package/src/hooks/color.js +2 -1
  497. package/src/hooks/content-lock-ui.js +3 -15
  498. package/src/hooks/dimensions.js +0 -40
  499. package/src/hooks/duotone.js +4 -11
  500. package/src/hooks/index.js +1 -0
  501. package/src/hooks/index.native.js +1 -0
  502. package/src/hooks/layout.js +14 -20
  503. package/src/hooks/position.js +2 -1
  504. package/src/hooks/style.js +2 -1
  505. package/src/hooks/test/use-editor-wrapper-styles.native.js +282 -0
  506. package/src/hooks/test/use-typography-props.js +47 -2
  507. package/src/hooks/use-editor-wrapper-styles.native.js +250 -0
  508. package/src/hooks/use-editor-wrapper-styles.native.scss +11 -0
  509. package/src/hooks/use-typography-props.js +10 -11
  510. package/src/index.native.js +6 -0
  511. package/src/private-apis.js +2 -4
  512. package/src/store/private-actions.js +39 -0
  513. package/src/store/private-selectors.js +95 -0
  514. package/src/store/reducer.js +27 -0
  515. package/src/store/selectors.js +25 -15
  516. package/src/store/test/private-actions.js +32 -1
  517. package/src/store/test/private-selectors.js +158 -0
  518. package/src/store/test/reducer.js +48 -0
  519. package/src/style.scss +0 -3
  520. package/src/utils/order-inserter-block-items.js +26 -0
  521. package/src/utils/use-should-contextual-toolbar-show.js +19 -9
  522. package/tsconfig.json +1 -0
  523. package/tsconfig.tsbuildinfo +1 -1
  524. package/build/components/block-list/block-list-compact.native.js +0 -75
  525. package/build/components/block-list/block-list-compact.native.js.map +0 -1
  526. package/build/components/off-canvas-editor/appender.js +0 -125
  527. package/build/components/off-canvas-editor/appender.js.map +0 -1
  528. package/build/components/off-canvas-editor/block-contents.js +0 -141
  529. package/build/components/off-canvas-editor/block-contents.js.map +0 -1
  530. package/build/components/off-canvas-editor/block-select-button.js +0 -126
  531. package/build/components/off-canvas-editor/block-select-button.js.map +0 -1
  532. package/build/components/off-canvas-editor/block.js +0 -297
  533. package/build/components/off-canvas-editor/block.js.map +0 -1
  534. package/build/components/off-canvas-editor/branch.js +0 -197
  535. package/build/components/off-canvas-editor/branch.js.map +0 -1
  536. package/build/components/off-canvas-editor/context.js +0 -19
  537. package/build/components/off-canvas-editor/context.js.map +0 -1
  538. package/build/components/off-canvas-editor/drop-indicator.js +0 -118
  539. package/build/components/off-canvas-editor/drop-indicator.js.map +0 -1
  540. package/build/components/off-canvas-editor/expander.js +0 -41
  541. package/build/components/off-canvas-editor/expander.js.map +0 -1
  542. package/build/components/off-canvas-editor/index.js +0 -236
  543. package/build/components/off-canvas-editor/index.js.map +0 -1
  544. package/build/components/off-canvas-editor/leaf-more-menu.js +0 -146
  545. package/build/components/off-canvas-editor/leaf-more-menu.js.map +0 -1
  546. package/build/components/off-canvas-editor/leaf.js +0 -60
  547. package/build/components/off-canvas-editor/leaf.js.map +0 -1
  548. package/build/components/off-canvas-editor/link-ui.js +0 -186
  549. package/build/components/off-canvas-editor/link-ui.js.map +0 -1
  550. package/build/components/off-canvas-editor/update-attributes.js +0 -108
  551. package/build/components/off-canvas-editor/update-attributes.js.map +0 -1
  552. package/build/components/off-canvas-editor/use-block-selection.js +0 -139
  553. package/build/components/off-canvas-editor/use-block-selection.js.map +0 -1
  554. package/build/components/off-canvas-editor/use-inserted-block.js +0 -58
  555. package/build/components/off-canvas-editor/use-inserted-block.js.map +0 -1
  556. package/build/components/off-canvas-editor/use-list-view-client-ids.js +0 -33
  557. package/build/components/off-canvas-editor/use-list-view-client-ids.js.map +0 -1
  558. package/build/components/off-canvas-editor/use-list-view-drop-zone.js +0 -235
  559. package/build/components/off-canvas-editor/use-list-view-drop-zone.js.map +0 -1
  560. package/build/components/off-canvas-editor/use-list-view-expand-selected-item.js +0 -60
  561. package/build/components/off-canvas-editor/use-list-view-expand-selected-item.js.map +0 -1
  562. package/build/components/off-canvas-editor/utils.js +0 -60
  563. package/build/components/off-canvas-editor/utils.js.map +0 -1
  564. package/build-module/components/block-list/block-list-compact.native.js +0 -60
  565. package/build-module/components/block-list/block-list-compact.native.js.map +0 -1
  566. package/build-module/components/off-canvas-editor/appender.js +0 -108
  567. package/build-module/components/off-canvas-editor/appender.js.map +0 -1
  568. package/build-module/components/off-canvas-editor/block-contents.js +0 -121
  569. package/build-module/components/off-canvas-editor/block-contents.js.map +0 -1
  570. package/build-module/components/off-canvas-editor/block-select-button.js +0 -107
  571. package/build-module/components/off-canvas-editor/block-select-button.js.map +0 -1
  572. package/build-module/components/off-canvas-editor/block.js +0 -273
  573. package/build-module/components/off-canvas-editor/block.js.map +0 -1
  574. package/build-module/components/off-canvas-editor/branch.js +0 -179
  575. package/build-module/components/off-canvas-editor/branch.js.map +0 -1
  576. package/build-module/components/off-canvas-editor/context.js +0 -7
  577. package/build-module/components/off-canvas-editor/context.js.map +0 -1
  578. package/build-module/components/off-canvas-editor/drop-indicator.js +0 -111
  579. package/build-module/components/off-canvas-editor/drop-indicator.js.map +0 -1
  580. package/build-module/components/off-canvas-editor/expander.js +0 -32
  581. package/build-module/components/off-canvas-editor/expander.js.map +0 -1
  582. package/build-module/components/off-canvas-editor/index.js +0 -213
  583. package/build-module/components/off-canvas-editor/index.js.map +0 -1
  584. package/build-module/components/off-canvas-editor/leaf-more-menu.js +0 -128
  585. package/build-module/components/off-canvas-editor/leaf-more-menu.js.map +0 -1
  586. package/build-module/components/off-canvas-editor/leaf.js +0 -45
  587. package/build-module/components/off-canvas-editor/leaf.js.map +0 -1
  588. package/build-module/components/off-canvas-editor/link-ui.js +0 -166
  589. package/build-module/components/off-canvas-editor/link-ui.js.map +0 -1
  590. package/build-module/components/off-canvas-editor/update-attributes.js +0 -97
  591. package/build-module/components/off-canvas-editor/update-attributes.js.map +0 -1
  592. package/build-module/components/off-canvas-editor/use-block-selection.js +0 -124
  593. package/build-module/components/off-canvas-editor/use-block-selection.js.map +0 -1
  594. package/build-module/components/off-canvas-editor/use-inserted-block.js +0 -47
  595. package/build-module/components/off-canvas-editor/use-inserted-block.js.map +0 -1
  596. package/build-module/components/off-canvas-editor/use-list-view-client-ids.js +0 -24
  597. package/build-module/components/off-canvas-editor/use-list-view-client-ids.js.map +0 -1
  598. package/build-module/components/off-canvas-editor/use-list-view-drop-zone.js +0 -220
  599. package/build-module/components/off-canvas-editor/use-list-view-drop-zone.js.map +0 -1
  600. package/build-module/components/off-canvas-editor/use-list-view-expand-selected-item.js +0 -50
  601. package/build-module/components/off-canvas-editor/use-list-view-expand-selected-item.js.map +0 -1
  602. package/build-module/components/off-canvas-editor/utils.js +0 -44
  603. package/build-module/components/off-canvas-editor/utils.js.map +0 -1
  604. package/src/components/block-list/block-list-compact.native.js +0 -63
  605. package/src/components/off-canvas-editor/README.md +0 -5
  606. package/src/components/off-canvas-editor/appender.js +0 -124
  607. package/src/components/off-canvas-editor/block-contents.js +0 -156
  608. package/src/components/off-canvas-editor/block-select-button.js +0 -128
  609. package/src/components/off-canvas-editor/block.js +0 -347
  610. package/src/components/off-canvas-editor/branch.js +0 -238
  611. package/src/components/off-canvas-editor/context.js +0 -8
  612. package/src/components/off-canvas-editor/drop-indicator.js +0 -126
  613. package/src/components/off-canvas-editor/expander.js +0 -26
  614. package/src/components/off-canvas-editor/index.js +0 -271
  615. package/src/components/off-canvas-editor/leaf-more-menu.js +0 -157
  616. package/src/components/off-canvas-editor/leaf.js +0 -52
  617. package/src/components/off-canvas-editor/link-ui.js +0 -167
  618. package/src/components/off-canvas-editor/style.scss +0 -34
  619. package/src/components/off-canvas-editor/test/use-inserted-block.js +0 -108
  620. package/src/components/off-canvas-editor/test/utils.js +0 -50
  621. package/src/components/off-canvas-editor/update-attributes.js +0 -99
  622. package/src/components/off-canvas-editor/use-block-selection.js +0 -169
  623. package/src/components/off-canvas-editor/use-inserted-block.js +0 -47
  624. package/src/components/off-canvas-editor/use-list-view-client-ids.js +0 -29
  625. package/src/components/off-canvas-editor/use-list-view-drop-zone.js +0 -260
  626. package/src/components/off-canvas-editor/use-list-view-expand-selected-item.js +0 -58
  627. package/src/components/off-canvas-editor/utils.js +0 -58
@@ -0,0 +1,115 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { MenuItem } from '@wordpress/components';
5
+ import {
6
+ getBlockMenuDefaultClassName,
7
+ cloneBlock,
8
+ store as blocksStore,
9
+ } from '@wordpress/blocks';
10
+ import { useSelect } from '@wordpress/data';
11
+ import { useState, useMemo } from '@wordpress/element';
12
+
13
+ /**
14
+ * Internal dependencies
15
+ */
16
+ import { store as blockEditorStore } from '../../store';
17
+ import BlockIcon from '../block-icon';
18
+ import PreviewBlockPopover from './preview-block-popover';
19
+
20
+ const EMPTY_OBJECT = {};
21
+
22
+ export function useBlockVariationTransforms( { clientIds, blocks } ) {
23
+ const { activeBlockVariation, blockVariationTransformations } = useSelect(
24
+ ( select ) => {
25
+ const {
26
+ getBlockRootClientId,
27
+ getBlockAttributes,
28
+ canRemoveBlocks,
29
+ } = select( blockEditorStore );
30
+ const { getActiveBlockVariation, getBlockVariations } =
31
+ select( blocksStore );
32
+ const rootClientId = getBlockRootClientId(
33
+ Array.isArray( clientIds ) ? clientIds[ 0 ] : clientIds
34
+ );
35
+ const canRemove = canRemoveBlocks( clientIds, rootClientId );
36
+ // Only handle single selected blocks for now.
37
+ if ( blocks.length !== 1 || ! canRemove ) {
38
+ return EMPTY_OBJECT;
39
+ }
40
+ const [ firstBlock ] = blocks;
41
+ return {
42
+ blockVariationTransformations: getBlockVariations(
43
+ firstBlock.name,
44
+ 'transform'
45
+ ),
46
+ activeBlockVariation: getActiveBlockVariation(
47
+ firstBlock.name,
48
+ getBlockAttributes( firstBlock.clientId )
49
+ ),
50
+ };
51
+ },
52
+ [ clientIds, blocks ]
53
+ );
54
+ const transformations = useMemo( () => {
55
+ return blockVariationTransformations?.filter(
56
+ ( { name } ) => name !== activeBlockVariation?.name
57
+ );
58
+ }, [ blockVariationTransformations, activeBlockVariation ] );
59
+ return transformations;
60
+ }
61
+
62
+ const BlockVariationTransformations = ( {
63
+ transformations,
64
+ onSelect,
65
+ blocks,
66
+ } ) => {
67
+ const [ hoveredTransformItemName, setHoveredTransformItemName ] =
68
+ useState();
69
+ return (
70
+ <>
71
+ { hoveredTransformItemName && (
72
+ <PreviewBlockPopover
73
+ blocks={ cloneBlock(
74
+ blocks[ 0 ],
75
+ transformations.find(
76
+ ( { name } ) => name === hoveredTransformItemName
77
+ ).attributes
78
+ ) }
79
+ />
80
+ ) }
81
+ { transformations?.map( ( item ) => (
82
+ <BlockVariationTranformationItem
83
+ key={ item.name }
84
+ item={ item }
85
+ onSelect={ onSelect }
86
+ setHoveredTransformItemName={ setHoveredTransformItemName }
87
+ />
88
+ ) ) }
89
+ </>
90
+ );
91
+ };
92
+
93
+ function BlockVariationTranformationItem( {
94
+ item,
95
+ onSelect,
96
+ setHoveredTransformItemName,
97
+ } ) {
98
+ const { name, icon, title } = item;
99
+ return (
100
+ <MenuItem
101
+ className={ getBlockMenuDefaultClassName( name ) }
102
+ onClick={ ( event ) => {
103
+ event.preventDefault();
104
+ onSelect( name );
105
+ } }
106
+ onMouseLeave={ () => setHoveredTransformItemName( null ) }
107
+ onMouseEnter={ () => setHoveredTransformItemName( name ) }
108
+ >
109
+ <BlockIcon icon={ icon } showColors />
110
+ { title }
111
+ </MenuItem>
112
+ );
113
+ }
114
+
115
+ export default BlockVariationTransformations;
@@ -24,12 +24,14 @@ import { store as blockEditorStore } from '../../store';
24
24
  import useBlockDisplayInformation from '../use-block-display-information';
25
25
  import BlockIcon from '../block-icon';
26
26
  import BlockTransformationsMenu from './block-transformations-menu';
27
+ import { useBlockVariationTransforms } from './block-variation-transformations';
27
28
  import BlockStylesMenu from './block-styles-menu';
28
29
  import PatternTransformationsMenu from './pattern-transformations-menu';
29
30
  import useBlockDisplayTitle from '../block-title/use-block-display-title';
30
31
 
31
32
  export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => {
32
- const { replaceBlocks, multiSelect } = useDispatch( blockEditorStore );
33
+ const { replaceBlocks, multiSelect, updateBlockAttributes } =
34
+ useDispatch( blockEditorStore );
33
35
  const blockInformation = useBlockDisplayInformation( blocks[ 0 ].clientId );
34
36
  const {
35
37
  possibleBlockTransformations,
@@ -43,9 +45,9 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => {
43
45
  getBlockRootClientId,
44
46
  getBlockTransformItems,
45
47
  __experimentalGetPatternTransformItems,
48
+ canRemoveBlocks,
46
49
  } = select( blockEditorStore );
47
50
  const { getBlockStyles, getBlockType } = select( blocksStore );
48
- const { canRemoveBlocks } = select( blockEditorStore );
49
51
  const rootClientId = getBlockRootClientId(
50
52
  Array.isArray( clientIds ) ? clientIds[ 0 ] : clientIds
51
53
  );
@@ -82,6 +84,11 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => {
82
84
  [ clientIds, blocks, blockInformation?.icon ]
83
85
  );
84
86
 
87
+ const blockVariationTransformations = useBlockVariationTransforms( {
88
+ clientIds,
89
+ blocks,
90
+ } );
91
+
85
92
  const blockTitle = useBlockDisplayTitle( {
86
93
  clientId: Array.isArray( clientIds ) ? clientIds[ 0 ] : clientIds,
87
94
  maximumLength: 35,
@@ -105,6 +112,14 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => {
105
112
  selectForMultipleBlocks( newBlocks );
106
113
  }
107
114
 
115
+ function onBlockVariationTransform( name ) {
116
+ updateBlockAttributes( blocks[ 0 ].clientId, {
117
+ ...blockVariationTransformations.find(
118
+ ( { name: variationName } ) => variationName === name
119
+ ).attributes,
120
+ } );
121
+ }
122
+
108
123
  // Pattern transformation through the `Patterns` API.
109
124
  function onPatternTransform( transformedBlocks ) {
110
125
  replaceBlocks( clientIds, transformedBlocks );
@@ -118,8 +133,14 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => {
118
133
  */
119
134
  const hasPossibleBlockTransformations =
120
135
  !! possibleBlockTransformations.length && canRemove && ! isTemplate;
136
+ const hasPossibleBlockVariationTransformations =
137
+ !! blockVariationTransformations?.length;
121
138
  const hasPatternTransformation = !! patterns?.length && canRemove;
122
- if ( ! hasBlockStyles && ! hasPossibleBlockTransformations ) {
139
+ if (
140
+ ! hasBlockStyles &&
141
+ ! hasPossibleBlockTransformations &&
142
+ ! hasPossibleBlockVariationTransformations
143
+ ) {
123
144
  return (
124
145
  <ToolbarGroup>
125
146
  <ToolbarButton
@@ -160,9 +181,12 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => {
160
181
  blocks.length
161
182
  );
162
183
 
184
+ const hasBlockOrBlockVariationTransforms =
185
+ hasPossibleBlockTransformations ||
186
+ hasPossibleBlockVariationTransformations;
163
187
  const showDropDown =
164
188
  hasBlockStyles ||
165
- hasPossibleBlockTransformations ||
189
+ hasBlockOrBlockVariationTransforms ||
166
190
  hasPatternTransformation;
167
191
  return (
168
192
  <ToolbarGroup>
@@ -213,17 +237,26 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => {
213
237
  } }
214
238
  />
215
239
  ) }
216
- { hasPossibleBlockTransformations && (
240
+ { hasBlockOrBlockVariationTransforms && (
217
241
  <BlockTransformationsMenu
218
242
  className="block-editor-block-switcher__transforms__menugroup"
219
243
  possibleBlockTransformations={
220
244
  possibleBlockTransformations
221
245
  }
246
+ possibleBlockVariationTransformations={
247
+ blockVariationTransformations
248
+ }
222
249
  blocks={ blocks }
223
250
  onSelect={ ( name ) => {
224
251
  onBlockTransform( name );
225
252
  onClose();
226
253
  } }
254
+ onSelectVariation={ ( name ) => {
255
+ onBlockVariationTransform(
256
+ name
257
+ );
258
+ onClose();
259
+ } }
227
260
  />
228
261
  ) }
229
262
  { hasBlockStyles && (
@@ -105,15 +105,15 @@ function BlockPattern( { pattern, onSelect, composite } ) {
105
105
  `${ baseClassName }-list__item-description`
106
106
  );
107
107
  return (
108
- <div
109
- className={ `${ baseClassName }-list__list-item` }
110
- aria-label={ pattern.title }
111
- aria-describedby={ pattern.description ? descriptionId : undefined }
112
- >
108
+ <div className={ `${ baseClassName }-list__list-item` }>
113
109
  <CompositeItem
114
110
  role="option"
115
111
  as="div"
116
112
  { ...composite }
113
+ aria-label={ pattern.title }
114
+ aria-describedby={
115
+ pattern.description ? descriptionId : undefined
116
+ }
117
117
  className={ `${ baseClassName }-list__item` }
118
118
  onClick={ () => onSelect( pattern.transformedBlocks ) }
119
119
  >
@@ -109,19 +109,20 @@
109
109
  }
110
110
 
111
111
  .components-popover__content {
112
- box-shadow: none;
112
+ width: 300px;
113
113
  border: $border-width solid $gray-900;
114
114
  background: $white;
115
115
  border-radius: $radius-block-ui;
116
116
  outline: none;
117
+ box-shadow: none;
117
118
  }
118
119
 
119
120
  .block-editor-block-switcher__preview {
120
- width: 300px;
121
- height: auto;
122
- // Subtract margin from max-height.
121
+ // Subtract vertical margin from max-height.
123
122
  max-height: calc(500px - #{$grid-unit-40});
124
- margin: $grid-unit-20;
123
+ margin: $grid-unit-20 0;
124
+ // Use padding to prevent the pattern previews focus style from being cut-off.
125
+ padding: 0 $grid-unit-20;
125
126
  overflow: hidden;
126
127
  }
127
128
  }
@@ -32,6 +32,7 @@ import BlockEditVisuallyButton from '../block-edit-visually-button';
32
32
  import { useShowMoversGestures } from './utils';
33
33
  import { store as blockEditorStore } from '../../store';
34
34
  import __unstableBlockNameContext from './block-name-context';
35
+ import { unlock } from '../../lock-unlock';
35
36
 
36
37
  const BlockToolbar = ( { hideDragHandle } ) => {
37
38
  const {
@@ -42,7 +43,7 @@ const BlockToolbar = ( { hideDragHandle } ) => {
42
43
  isDistractionFree,
43
44
  isValid,
44
45
  isVisual,
45
- isContentLocked,
46
+ blockEditingMode,
46
47
  } = useSelect( ( select ) => {
47
48
  const {
48
49
  getBlockName,
@@ -51,8 +52,8 @@ const BlockToolbar = ( { hideDragHandle } ) => {
51
52
  isBlockValid,
52
53
  getBlockRootClientId,
53
54
  getSettings,
54
- __unstableGetContentLockingParent,
55
- } = select( blockEditorStore );
55
+ getBlockEditingMode,
56
+ } = unlock( select( blockEditorStore ) );
56
57
  const selectedBlockClientIds = getSelectedBlockClientIds();
57
58
  const selectedBlockClientId = selectedBlockClientIds[ 0 ];
58
59
  const blockRootClientId = getBlockRootClientId( selectedBlockClientId );
@@ -73,9 +74,7 @@ const BlockToolbar = ( { hideDragHandle } ) => {
73
74
  isVisual: selectedBlockClientIds.every(
74
75
  ( id ) => getBlockMode( id ) === 'visual'
75
76
  ),
76
- isContentLocked: !! __unstableGetContentLockingParent(
77
- selectedBlockClientId
78
- ),
77
+ blockEditingMode: getBlockEditingMode( selectedBlockClientId ),
79
78
  };
80
79
  }, [] );
81
80
 
@@ -125,12 +124,12 @@ const BlockToolbar = ( { hideDragHandle } ) => {
125
124
 
126
125
  return (
127
126
  <div className={ classes }>
128
- { ! isMultiToolbar && isLargeViewport && ! isContentLocked && (
129
- <BlockParentSelector />
130
- ) }
127
+ { ! isMultiToolbar &&
128
+ isLargeViewport &&
129
+ blockEditingMode === 'default' && <BlockParentSelector /> }
131
130
  <div ref={ nodeRef } { ...showMoversGestures }>
132
131
  { ( shouldShowVisualToolbar || isMultiToolbar ) &&
133
- ! isContentLocked && (
132
+ blockEditingMode === 'default' && (
134
133
  <ToolbarGroup className="block-editor-block-toolbar__block-controls">
135
134
  <BlockSwitcher clientIds={ blockClientIds } />
136
135
  { ! isMultiToolbar && (
@@ -175,7 +174,7 @@ const BlockToolbar = ( { hideDragHandle } ) => {
175
174
  </>
176
175
  ) }
177
176
  <BlockEditVisuallyButton clientIds={ blockClientIds } />
178
- { ! isContentLocked && (
177
+ { blockEditingMode === 'default' && (
179
178
  <BlockSettingsMenu clientIds={ blockClientIds } />
180
179
  ) }
181
180
  </div>
@@ -7,7 +7,7 @@ import classnames from 'classnames';
7
7
  * WordPress dependencies
8
8
  */
9
9
  import { __ } from '@wordpress/i18n';
10
- import { forwardRef, useEffect, useRef, useState } from '@wordpress/element';
10
+ import { useEffect, useRef, useState } from '@wordpress/element';
11
11
  import { hasBlockSupport, store as blocksStore } from '@wordpress/blocks';
12
12
  import { useSelect } from '@wordpress/data';
13
13
  import {
@@ -25,62 +25,22 @@ import NavigableToolbar from '../navigable-toolbar';
25
25
  import BlockToolbar from '../block-toolbar';
26
26
  import { store as blockEditorStore } from '../../store';
27
27
  import BlockIcon from '../block-icon';
28
-
29
- const CollapseFixedToolbarButton = forwardRef( ( { onClick }, ref ) => {
30
- return (
31
- <ToolbarItem
32
- as={ ToolbarButton }
33
- className="block-editor-block-toolbar__collapse-fixed-toolbar"
34
- icon={ levelUp }
35
- onClick={ onClick }
36
- ref={ ref }
37
- label={ __( 'Show document tools' ) }
38
- />
39
- );
40
- } );
41
-
42
- const ExpandFixedToolbarButton = forwardRef( ( { onClick, icon }, ref ) => {
43
- return (
44
- <ToolbarItem
45
- as={ ToolbarButton }
46
- className="block-editor-block-toolbar__expand-fixed-toolbar"
47
- icon={ <BlockIcon icon={ icon } /> }
48
- onClick={ onClick }
49
- ref={ ref }
50
- label={ __( 'Show block tools' ) }
51
- />
52
- );
53
- } );
28
+ import { unlock } from '../../lock-unlock';
54
29
 
55
30
  function BlockContextualToolbar( { focusOnMount, isFixed, ...props } ) {
56
31
  // When the toolbar is fixed it can be collapsed
57
32
  const [ isCollapsed, setIsCollapsed ] = useState( false );
58
- const expandFixedToolbarButtonRef = useRef();
59
- const collapseFixedToolbarButtonRef = useRef();
60
-
61
- // Don't focus the block toolbar just because it mounts
62
- const initialRender = useRef( true );
63
- useEffect( () => {
64
- if ( initialRender.current ) {
65
- initialRender.current = false;
66
- return;
67
- }
68
- if ( isCollapsed && expandFixedToolbarButtonRef.current ) {
69
- expandFixedToolbarButtonRef.current.focus();
70
- }
71
- if ( ! isCollapsed && collapseFixedToolbarButtonRef.current ) {
72
- collapseFixedToolbarButtonRef.current.focus();
73
- }
74
- }, [ isCollapsed ] );
33
+ const toolbarButtonRef = useRef();
75
34
 
35
+ const isLargeViewport = useViewportMatch( 'medium' );
76
36
  const { blockType, hasParents, showParentSelector, selectedBlockClientId } =
77
37
  useSelect( ( select ) => {
78
38
  const {
79
39
  getBlockName,
80
40
  getBlockParents,
81
41
  getSelectedBlockClientIds,
82
- __unstableGetContentLockingParent,
83
- } = select( blockEditorStore );
42
+ getBlockEditingMode,
43
+ } = unlock( select( blockEditorStore ) );
84
44
  const { getBlockType } = select( blocksStore );
85
45
  const selectedBlockClientIds = getSelectedBlockClientIds();
86
46
  const _selectedBlockClientId = selectedBlockClientIds[ 0 ];
@@ -103,9 +63,7 @@ function BlockContextualToolbar( { focusOnMount, isFixed, ...props } ) {
103
63
  true
104
64
  ) &&
105
65
  selectedBlockClientIds.length <= 1 &&
106
- ! __unstableGetContentLockingParent(
107
- _selectedBlockClientId
108
- ),
66
+ getBlockEditingMode( _selectedBlockClientId ) === 'default',
109
67
  };
110
68
  }, [] );
111
69
 
@@ -113,12 +71,11 @@ function BlockContextualToolbar( { focusOnMount, isFixed, ...props } ) {
113
71
  setIsCollapsed( false );
114
72
  }, [ selectedBlockClientId ] );
115
73
 
116
- const isLargeViewport = useViewportMatch( 'medium' );
117
-
118
- if ( blockType ) {
119
- if ( ! hasBlockSupport( blockType, '__experimentalToolbar', true ) ) {
120
- return null;
121
- }
74
+ if (
75
+ blockType &&
76
+ ! hasBlockSupport( blockType, '__experimentalToolbar', true )
77
+ ) {
78
+ return null;
122
79
  }
123
80
 
124
81
  // Shifts the toolbar to make room for the parent block selector.
@@ -144,18 +101,26 @@ function BlockContextualToolbar( { focusOnMount, isFixed, ...props } ) {
144
101
  : 'block-editor-block-toolbar__group-collapse-fixed-toolbar'
145
102
  }
146
103
  >
147
- { isCollapsed ? (
148
- <ExpandFixedToolbarButton
149
- onClick={ () => setIsCollapsed( false ) }
150
- icon={ blockType.icon }
151
- ref={ expandFixedToolbarButtonRef }
152
- />
153
- ) : (
154
- <CollapseFixedToolbarButton
155
- onClick={ () => setIsCollapsed( true ) }
156
- ref={ collapseFixedToolbarButtonRef }
157
- />
158
- ) }
104
+ <ToolbarItem
105
+ as={ ToolbarButton }
106
+ ref={ toolbarButtonRef }
107
+ icon={
108
+ isCollapsed ? (
109
+ <BlockIcon icon={ blockType.icon } />
110
+ ) : (
111
+ levelUp
112
+ )
113
+ }
114
+ onClick={ () => {
115
+ setIsCollapsed( ( collapsed ) => ! collapsed );
116
+ toolbarButtonRef.current.focus();
117
+ } }
118
+ label={
119
+ isCollapsed
120
+ ? __( 'Show block tools' )
121
+ : __( 'Show document tools' )
122
+ }
123
+ />
159
124
  </ToolbarGroup>
160
125
  ) }
161
126
  { ! isCollapsed && <BlockToolbar hideDragHandle={ isFixed } /> }
@@ -198,16 +198,30 @@ function InbetweenInsertionPointPopover( {
198
198
  }
199
199
 
200
200
  export default function InsertionPoint( props ) {
201
- const { insertionPoint, isVisible } = useSelect( ( select ) => {
202
- const { getBlockInsertionPoint, isBlockInsertionPointVisible } =
203
- select( blockEditorStore );
204
- return {
205
- insertionPoint: getBlockInsertionPoint(),
206
- isVisible: isBlockInsertionPointVisible(),
207
- };
208
- }, [] );
201
+ const { insertionPoint, isVisible, isBlockListEmpty } = useSelect(
202
+ ( select ) => {
203
+ const {
204
+ getBlockInsertionPoint,
205
+ isBlockInsertionPointVisible,
206
+ getBlockCount,
207
+ } = select( blockEditorStore );
208
+ const blockInsertionPoint = getBlockInsertionPoint();
209
+ return {
210
+ insertionPoint: blockInsertionPoint,
211
+ isVisible: isBlockInsertionPointVisible(),
212
+ isBlockListEmpty:
213
+ getBlockCount( blockInsertionPoint?.rootClientId ) === 0,
214
+ };
215
+ },
216
+ []
217
+ );
209
218
 
210
- if ( ! isVisible ) {
219
+ if (
220
+ ! isVisible ||
221
+ // Don't render the insertion point if the block list is empty.
222
+ // The insertion point will be represented by the appender instead.
223
+ isBlockListEmpty
224
+ ) {
211
225
  return null;
212
226
  }
213
227
 
@@ -20,8 +20,7 @@ import { store as blockEditorStore } from '../../store';
20
20
  import BlockPopover from '../block-popover';
21
21
  import useBlockToolbarPopoverProps from './use-block-toolbar-popover-props';
22
22
  import Inserter from '../inserter';
23
- import { unlock } from '../../lock-unlock';
24
- import { privateApis } from '../../private-apis';
23
+ import { useShouldContextualToolbarShow } from '../../utils/use-should-contextual-toolbar-show';
25
24
 
26
25
  function selector( select ) {
27
26
  const {
@@ -29,7 +28,7 @@ function selector( select ) {
29
28
  hasMultiSelection,
30
29
  isTyping,
31
30
  getLastMultiSelectedBlockClientId,
32
- } = unlock( select( blockEditorStore ) );
31
+ } = select( blockEditorStore );
33
32
 
34
33
  return {
35
34
  editorMode: __unstableGetEditorMode(),
@@ -54,7 +53,6 @@ function SelectedBlockPopover( {
54
53
  []
55
54
  );
56
55
 
57
- const { useShouldContextualToolbarShow } = unlock( privateApis );
58
56
  const isInsertionPointVisible = useSelect(
59
57
  ( select ) => {
60
58
  const {
@@ -75,7 +73,7 @@ function SelectedBlockPopover( {
75
73
  );
76
74
  const isToolbarForced = useRef( false );
77
75
  const { shouldShowContextualToolbar, canFocusHiddenToolbar } =
78
- useShouldContextualToolbarShow( clientId );
76
+ useShouldContextualToolbarShow();
79
77
 
80
78
  const { stopTyping } = useDispatch( blockEditorStore );
81
79
 
@@ -219,6 +219,14 @@
219
219
  }
220
220
  }
221
221
  }
222
+
223
+ .blocks-widgets-container & {
224
+ margin-left: $grid-unit-80 * 2.4;
225
+
226
+ &.is-collapsed {
227
+ margin-left: $grid-unit-80 * 4.2;
228
+ }
229
+ }
222
230
  }
223
231
 
224
232
  &.is-fixed .block-editor-block-parent-selector {
@@ -32,6 +32,7 @@
32
32
  }
33
33
  }
34
34
 
35
+
35
36
  // When the appender shows up in empty container blocks, such as Group and Columns, add an extra click state.
36
37
  .block-list-appender:only-child {
37
38
  .is-layout-constrained.block-editor-block-list__block:not(.is-selected) > &,
@@ -56,5 +57,26 @@
56
57
  .block-editor-inserter {
57
58
  visibility: hidden;
58
59
  }
60
+
61
+ &.is-drag-over {
62
+ &::after {
63
+ border: none;
64
+ }
65
+
66
+ .block-editor-inserter {
67
+ visibility: visible;
68
+ }
69
+ }
70
+ }
71
+
72
+ &.is-drag-over .block-editor-button-block-appender {
73
+ background-color: var(--wp-admin-theme-color);
74
+ box-shadow: inset 0 0 0 $border-width $light-gray-placeholder;
75
+ color: $light-gray-placeholder;
76
+ transition: background-color 0.2s ease-in-out;
77
+
78
+ @media ( prefers-reduced-motion: reduce ) {
79
+ transition: none;
80
+ }
59
81
  }
60
82
  }
@@ -61,7 +61,12 @@ export default function useMultipleOriginColorsAndGradients() {
61
61
  } );
62
62
  }
63
63
  return result;
64
- }, [ defaultColors, themeColors, customColors ] );
64
+ }, [
65
+ defaultColors,
66
+ themeColors,
67
+ customColors,
68
+ shouldDisplayDefaultColors,
69
+ ] );
65
70
 
66
71
  const customGradients = useSetting( 'color.gradients.custom' );
67
72
  const themeGradients = useSetting( 'color.gradients.theme' );
@@ -103,7 +108,16 @@ export default function useMultipleOriginColorsAndGradients() {
103
108
  } );
104
109
  }
105
110
  return result;
106
- }, [ customGradients, themeGradients, defaultGradients ] );
111
+ }, [
112
+ customGradients,
113
+ themeGradients,
114
+ defaultGradients,
115
+ shouldDisplayDefaultGradients,
116
+ ] );
117
+
118
+ colorGradientSettings.hasColorsOrGradients =
119
+ !! colorGradientSettings.colors.length ||
120
+ !! colorGradientSettings.gradients.length;
107
121
 
108
122
  return colorGradientSettings;
109
123
  }
@@ -17,6 +17,7 @@ function ConvertToGroupButton( {
17
17
  clientIds,
18
18
  isGroupable,
19
19
  isUngroupable,
20
+ onUngroup,
20
21
  blocksSelection,
21
22
  groupingBlockName,
22
23
  onClose = () => {},
@@ -34,10 +35,16 @@ function ConvertToGroupButton( {
34
35
  };
35
36
 
36
37
  const onConvertFromGroup = () => {
37
- const innerBlocks = blocksSelection[ 0 ].innerBlocks;
38
+ let innerBlocks = blocksSelection[ 0 ].innerBlocks;
38
39
  if ( ! innerBlocks.length ) {
39
40
  return;
40
41
  }
42
+ if ( onUngroup ) {
43
+ innerBlocks = onUngroup(
44
+ blocksSelection[ 0 ].attributes,
45
+ blocksSelection[ 0 ].innerBlocks
46
+ );
47
+ }
41
48
  replaceBlocks( clientIds, innerBlocks );
42
49
  };
43
50
 
@@ -66,7 +73,7 @@ function ConvertToGroupButton( {
66
73
  >
67
74
  { _x(
68
75
  'Ungroup',
69
- 'Ungrouping blocks from within a Group block back into individual blocks within the Editor '
76
+ 'Ungrouping blocks from within a grouping block back into individual blocks within the Editor '
70
77
  ) }
71
78
  </MenuItem>
72
79
  ) }