@wordpress/block-editor 8.3.1 → 8.5.1

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 (475) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/README.md +56 -18
  3. package/build/components/alignment-control/index.js +13 -6
  4. package/build/components/alignment-control/index.js.map +1 -1
  5. package/build/components/block-alignment-control/index.js +13 -6
  6. package/build/components/block-alignment-control/index.js.map +1 -1
  7. package/build/components/block-content-overlay/index.js +13 -4
  8. package/build/components/block-content-overlay/index.js.map +1 -1
  9. package/build/components/block-draggable/index.js +2 -3
  10. package/build/components/block-draggable/index.js.map +1 -1
  11. package/build/components/block-icon/index.js +4 -0
  12. package/build/components/block-icon/index.js.map +1 -1
  13. package/build/components/block-inspector/index.js +6 -1
  14. package/build/components/block-inspector/index.js.map +1 -1
  15. package/build/components/block-list/block-html.js +4 -1
  16. package/build/components/block-list/block-html.js.map +1 -1
  17. package/build/components/block-list/block.js +4 -1
  18. package/build/components/block-list/block.js.map +1 -1
  19. package/build/components/block-list/use-block-props/index.js +1 -6
  20. package/build/components/block-list/use-block-props/index.js.map +1 -1
  21. package/build/components/block-list/use-block-props/use-focus-first-element.js +22 -6
  22. package/build/components/block-list/use-block-props/use-focus-first-element.js.map +1 -1
  23. package/build/components/block-list/use-block-props/use-focus-handler.js +7 -1
  24. package/build/components/block-list/use-block-props/use-focus-handler.js.map +1 -1
  25. package/build/components/block-list-appender/index.js +6 -1
  26. package/build/components/block-list-appender/index.js.map +1 -1
  27. package/build/components/block-lock/index.js +40 -0
  28. package/build/components/block-lock/index.js.map +1 -0
  29. package/build/components/block-lock/menu-item.js +52 -0
  30. package/build/components/block-lock/menu-item.js.map +1 -0
  31. package/build/components/block-lock/modal.js +155 -0
  32. package/build/components/block-lock/modal.js.map +1 -0
  33. package/build/components/block-lock/toolbar.js +65 -0
  34. package/build/components/block-lock/toolbar.js.map +1 -0
  35. package/build/components/block-lock/use-block-lock.js +53 -0
  36. package/build/components/block-lock/use-block-lock.js.map +1 -0
  37. package/build/components/block-mover/index.js +4 -0
  38. package/build/components/block-mover/index.js.map +1 -1
  39. package/build/components/block-pattern-setup/index.js +37 -22
  40. package/build/components/block-pattern-setup/index.js.map +1 -1
  41. package/build/components/block-pattern-setup/setup-toolbar.js +1 -1
  42. package/build/components/block-pattern-setup/setup-toolbar.js.map +1 -1
  43. package/build/components/block-preview/auto.js +6 -3
  44. package/build/components/block-preview/auto.js.map +1 -1
  45. package/build/components/block-preview/index.js +4 -2
  46. package/build/components/block-preview/index.js.map +1 -1
  47. package/build/components/block-settings-menu/block-settings-dropdown.js +75 -10
  48. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  49. package/build/components/block-settings-menu-controls/index.js +19 -9
  50. package/build/components/block-settings-menu-controls/index.js.map +1 -1
  51. package/build/components/block-switcher/index.js +8 -3
  52. package/build/components/block-switcher/index.js.map +1 -1
  53. package/build/components/block-title/index.js +2 -2
  54. package/build/components/block-title/index.js.map +1 -1
  55. package/build/components/block-title/use-block-display-title.js +8 -6
  56. package/build/components/block-title/use-block-display-title.js.map +1 -1
  57. package/build/components/block-toolbar/block-name-context.js +17 -0
  58. package/build/components/block-toolbar/block-name-context.js.map +1 -0
  59. package/build/components/block-toolbar/block-toolbar-last-item.js +20 -0
  60. package/build/components/block-toolbar/block-toolbar-last-item.js.map +1 -0
  61. package/build/components/block-toolbar/index.js +24 -5
  62. package/build/components/block-toolbar/index.js.map +1 -1
  63. package/build/components/block-tools/index.js +0 -16
  64. package/build/components/block-tools/index.js.map +1 -1
  65. package/build/components/block-variation-transforms/index.js +92 -47
  66. package/build/components/block-variation-transforms/index.js.map +1 -1
  67. package/build/components/block-vertical-alignment-control/index.js +13 -6
  68. package/build/components/block-vertical-alignment-control/index.js.map +1 -1
  69. package/build/components/border-radius-control/index.js +0 -1
  70. package/build/components/border-radius-control/index.js.map +1 -1
  71. package/build/components/border-radius-control/utils.js +1 -1
  72. package/build/components/border-radius-control/utils.js.map +1 -1
  73. package/build/components/colors-gradients/control.js +3 -1
  74. package/build/components/colors-gradients/control.js.map +1 -1
  75. package/build/components/contrast-checker/index.js +4 -0
  76. package/build/components/contrast-checker/index.js.map +1 -1
  77. package/build/components/convert-to-group-buttons/index.js +8 -0
  78. package/build/components/convert-to-group-buttons/index.js.map +1 -1
  79. package/build/components/convert-to-group-buttons/toolbar.js +105 -0
  80. package/build/components/convert-to-group-buttons/toolbar.js.map +1 -0
  81. package/build/components/copy-handler/index.js +4 -0
  82. package/build/components/copy-handler/index.js.map +1 -1
  83. package/build/components/date-format-picker/index.js +132 -0
  84. package/build/components/date-format-picker/index.js.map +1 -0
  85. package/build/components/font-sizes/font-size-picker.js +4 -0
  86. package/build/components/font-sizes/font-size-picker.js.map +1 -1
  87. package/build/components/iframe/index.js +6 -9
  88. package/build/components/iframe/index.js.map +1 -1
  89. package/build/components/index.js +27 -0
  90. package/build/components/index.js.map +1 -1
  91. package/build/components/justify-content-control/index.js +13 -6
  92. package/build/components/justify-content-control/index.js.map +1 -1
  93. package/build/components/keyboard-shortcuts/index.js +1 -1
  94. package/build/components/keyboard-shortcuts/index.js.map +1 -1
  95. package/build/components/line-height-control/index.js +15 -6
  96. package/build/components/line-height-control/index.js.map +1 -1
  97. package/build/components/list-view/block-select-button.js +18 -23
  98. package/build/components/list-view/block-select-button.js.map +1 -1
  99. package/build/components/list-view/block.js +38 -13
  100. package/build/components/list-view/block.js.map +1 -1
  101. package/build/components/list-view/branch.js +16 -13
  102. package/build/components/list-view/branch.js.map +1 -1
  103. package/build/components/list-view/index.js +7 -1
  104. package/build/components/list-view/index.js.map +1 -1
  105. package/build/components/list-view/use-block-selection.js +9 -2
  106. package/build/components/list-view/use-block-selection.js.map +1 -1
  107. package/build/components/media-replace-flow/index.js +4 -0
  108. package/build/components/media-replace-flow/index.js.map +1 -1
  109. package/build/components/multi-selection-inspector/index.js +1 -1
  110. package/build/components/multi-selection-inspector/index.js.map +1 -1
  111. package/build/components/rich-text/index.js +27 -5
  112. package/build/components/rich-text/index.js.map +1 -1
  113. package/build/components/rich-text/index.native.js +13 -9
  114. package/build/components/rich-text/index.native.js.map +1 -1
  115. package/build/components/rich-text/split-value.js +12 -2
  116. package/build/components/rich-text/split-value.js.map +1 -1
  117. package/build/components/rich-text/use-firefox-compat.js +49 -0
  118. package/build/components/rich-text/use-firefox-compat.js.map +1 -0
  119. package/build/components/rich-text/use-input-rules.js +34 -2
  120. package/build/components/rich-text/use-input-rules.js.map +1 -1
  121. package/build/components/skip-to-selected-block/index.js +4 -0
  122. package/build/components/skip-to-selected-block/index.js.map +1 -1
  123. package/build/components/url-popover/image-url-input-ui.js +11 -27
  124. package/build/components/url-popover/image-url-input-ui.js.map +1 -1
  125. package/build/components/writing-flow/index.js +9 -1
  126. package/build/components/writing-flow/index.js.map +1 -1
  127. package/build/components/writing-flow/use-arrow-nav.js +3 -44
  128. package/build/components/writing-flow/use-arrow-nav.js.map +1 -1
  129. package/build/components/writing-flow/use-click-selection.js +68 -0
  130. package/build/components/writing-flow/use-click-selection.js.map +1 -0
  131. package/build/components/writing-flow/use-drag-selection.js +134 -0
  132. package/build/components/writing-flow/use-drag-selection.js.map +1 -0
  133. package/build/components/writing-flow/use-input.js +116 -0
  134. package/build/components/writing-flow/use-input.js.map +1 -0
  135. package/build/components/writing-flow/use-multi-selection.js +18 -38
  136. package/build/components/writing-flow/use-multi-selection.js.map +1 -1
  137. package/build/components/writing-flow/use-selection-observer.js +161 -0
  138. package/build/components/writing-flow/use-selection-observer.js.map +1 -0
  139. package/build/components/writing-flow/use-tab-nav.js +1 -8
  140. package/build/components/writing-flow/use-tab-nav.js.map +1 -1
  141. package/build/hooks/anchor.js +7 -6
  142. package/build/hooks/anchor.js.map +1 -1
  143. package/build/hooks/border-color.js +3 -3
  144. package/build/hooks/border-color.js.map +1 -1
  145. package/build/hooks/border.js +0 -14
  146. package/build/hooks/border.js.map +1 -1
  147. package/build/hooks/color.js +20 -17
  148. package/build/hooks/color.js.map +1 -1
  149. package/build/hooks/font-family.js +5 -1
  150. package/build/hooks/font-family.js.map +1 -1
  151. package/build/hooks/font-size.js +4 -2
  152. package/build/hooks/font-size.js.map +1 -1
  153. package/build/hooks/gap.js +77 -5
  154. package/build/hooks/gap.js.map +1 -1
  155. package/build/hooks/layout.js +7 -2
  156. package/build/hooks/layout.js.map +1 -1
  157. package/build/hooks/style.js +34 -3
  158. package/build/hooks/style.js.map +1 -1
  159. package/build/hooks/utils.js +29 -0
  160. package/build/hooks/utils.js.map +1 -1
  161. package/build/layouts/flex.js +82 -15
  162. package/build/layouts/flex.js.map +1 -1
  163. package/build/layouts/flow.js +22 -13
  164. package/build/layouts/flow.js.map +1 -1
  165. package/build/store/actions.js +297 -51
  166. package/build/store/actions.js.map +1 -1
  167. package/build/store/defaults.js +5 -1
  168. package/build/store/defaults.js.map +1 -1
  169. package/build/store/reducer.js +25 -13
  170. package/build/store/reducer.js.map +1 -1
  171. package/build/store/selectors.js +197 -23
  172. package/build/store/selectors.js.map +1 -1
  173. package/build/utils/dom.js +2 -1
  174. package/build/utils/dom.js.map +1 -1
  175. package/build-module/components/alignment-control/index.js +12 -4
  176. package/build-module/components/alignment-control/index.js.map +1 -1
  177. package/build-module/components/block-alignment-control/index.js +12 -4
  178. package/build-module/components/block-alignment-control/index.js.map +1 -1
  179. package/build-module/components/block-content-overlay/index.js +13 -4
  180. package/build-module/components/block-content-overlay/index.js.map +1 -1
  181. package/build-module/components/block-draggable/index.js +2 -3
  182. package/build-module/components/block-draggable/index.js.map +1 -1
  183. package/build-module/components/block-icon/index.js +4 -0
  184. package/build-module/components/block-icon/index.js.map +1 -1
  185. package/build-module/components/block-inspector/index.js +6 -1
  186. package/build-module/components/block-inspector/index.js.map +1 -1
  187. package/build-module/components/block-list/block-html.js +5 -2
  188. package/build-module/components/block-list/block-html.js.map +1 -1
  189. package/build-module/components/block-list/block.js +5 -2
  190. package/build-module/components/block-list/block.js.map +1 -1
  191. package/build-module/components/block-list/use-block-props/index.js +1 -4
  192. package/build-module/components/block-list/use-block-props/index.js.map +1 -1
  193. package/build-module/components/block-list/use-block-props/use-focus-first-element.js +22 -6
  194. package/build-module/components/block-list/use-block-props/use-focus-first-element.js.map +1 -1
  195. package/build-module/components/block-list/use-block-props/use-focus-handler.js +7 -1
  196. package/build-module/components/block-list/use-block-props/use-focus-handler.js.map +1 -1
  197. package/build-module/components/block-list-appender/index.js +6 -1
  198. package/build-module/components/block-list-appender/index.js.map +1 -1
  199. package/build-module/components/block-lock/index.js +5 -0
  200. package/build-module/components/block-lock/index.js.map +1 -0
  201. package/build-module/components/block-lock/menu-item.js +39 -0
  202. package/build-module/components/block-lock/menu-item.js.map +1 -0
  203. package/build-module/components/block-lock/modal.js +138 -0
  204. package/build-module/components/block-lock/modal.js.map +1 -0
  205. package/build-module/components/block-lock/toolbar.js +51 -0
  206. package/build-module/components/block-lock/toolbar.js.map +1 -0
  207. package/build-module/components/block-lock/use-block-lock.js +44 -0
  208. package/build-module/components/block-lock/use-block-lock.js.map +1 -0
  209. package/build-module/components/block-mover/index.js +4 -0
  210. package/build-module/components/block-mover/index.js.map +1 -1
  211. package/build-module/components/block-pattern-setup/index.js +39 -24
  212. package/build-module/components/block-pattern-setup/index.js.map +1 -1
  213. package/build-module/components/block-pattern-setup/setup-toolbar.js +1 -1
  214. package/build-module/components/block-pattern-setup/setup-toolbar.js.map +1 -1
  215. package/build-module/components/block-preview/auto.js +6 -3
  216. package/build-module/components/block-preview/auto.js.map +1 -1
  217. package/build-module/components/block-preview/index.js +4 -2
  218. package/build-module/components/block-preview/index.js.map +1 -1
  219. package/build-module/components/block-settings-menu/block-settings-dropdown.js +75 -12
  220. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  221. package/build-module/components/block-settings-menu-controls/index.js +18 -9
  222. package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
  223. package/build-module/components/block-switcher/index.js +9 -4
  224. package/build-module/components/block-switcher/index.js.map +1 -1
  225. package/build-module/components/block-title/index.js +2 -2
  226. package/build-module/components/block-title/index.js.map +1 -1
  227. package/build-module/components/block-title/use-block-display-title.js +8 -6
  228. package/build-module/components/block-title/use-block-display-title.js.map +1 -1
  229. package/build-module/components/block-toolbar/block-name-context.js +9 -0
  230. package/build-module/components/block-toolbar/block-name-context.js.map +1 -0
  231. package/build-module/components/block-toolbar/block-toolbar-last-item.js +11 -0
  232. package/build-module/components/block-toolbar/block-toolbar-last-item.js.map +1 -0
  233. package/build-module/components/block-toolbar/index.js +19 -4
  234. package/build-module/components/block-toolbar/index.js.map +1 -1
  235. package/build-module/components/block-tools/index.js +0 -16
  236. package/build-module/components/block-tools/index.js.map +1 -1
  237. package/build-module/components/block-variation-transforms/index.js +95 -49
  238. package/build-module/components/block-variation-transforms/index.js.map +1 -1
  239. package/build-module/components/block-vertical-alignment-control/index.js +12 -4
  240. package/build-module/components/block-vertical-alignment-control/index.js.map +1 -1
  241. package/build-module/components/border-radius-control/index.js +0 -1
  242. package/build-module/components/border-radius-control/index.js.map +1 -1
  243. package/build-module/components/border-radius-control/utils.js +1 -1
  244. package/build-module/components/border-radius-control/utils.js.map +1 -1
  245. package/build-module/components/colors-gradients/control.js +3 -1
  246. package/build-module/components/colors-gradients/control.js.map +1 -1
  247. package/build-module/components/contrast-checker/index.js +4 -0
  248. package/build-module/components/contrast-checker/index.js.map +1 -1
  249. package/build-module/components/convert-to-group-buttons/index.js +2 -1
  250. package/build-module/components/convert-to-group-buttons/index.js.map +1 -1
  251. package/build-module/components/convert-to-group-buttons/toolbar.js +90 -0
  252. package/build-module/components/convert-to-group-buttons/toolbar.js.map +1 -0
  253. package/build-module/components/copy-handler/index.js +4 -0
  254. package/build-module/components/copy-handler/index.js.map +1 -1
  255. package/build-module/components/date-format-picker/index.js +122 -0
  256. package/build-module/components/date-format-picker/index.js.map +1 -0
  257. package/build-module/components/font-sizes/font-size-picker.js +4 -0
  258. package/build-module/components/font-sizes/font-size-picker.js.map +1 -1
  259. package/build-module/components/iframe/index.js +6 -9
  260. package/build-module/components/iframe/index.js.map +1 -1
  261. package/build-module/components/index.js +3 -0
  262. package/build-module/components/index.js.map +1 -1
  263. package/build-module/components/justify-content-control/index.js +12 -4
  264. package/build-module/components/justify-content-control/index.js.map +1 -1
  265. package/build-module/components/keyboard-shortcuts/index.js +1 -1
  266. package/build-module/components/keyboard-shortcuts/index.js.map +1 -1
  267. package/build-module/components/line-height-control/index.js +14 -5
  268. package/build-module/components/line-height-control/index.js.map +1 -1
  269. package/build-module/components/list-view/block-select-button.js +19 -23
  270. package/build-module/components/list-view/block-select-button.js.map +1 -1
  271. package/build-module/components/list-view/block.js +36 -13
  272. package/build-module/components/list-view/block.js.map +1 -1
  273. package/build-module/components/list-view/branch.js +16 -13
  274. package/build-module/components/list-view/branch.js.map +1 -1
  275. package/build-module/components/list-view/index.js +7 -1
  276. package/build-module/components/list-view/index.js.map +1 -1
  277. package/build-module/components/list-view/use-block-selection.js +10 -3
  278. package/build-module/components/list-view/use-block-selection.js.map +1 -1
  279. package/build-module/components/media-replace-flow/index.js +4 -0
  280. package/build-module/components/media-replace-flow/index.js.map +1 -1
  281. package/build-module/components/multi-selection-inspector/index.js +2 -2
  282. package/build-module/components/multi-selection-inspector/index.js.map +1 -1
  283. package/build-module/components/rich-text/index.js +26 -5
  284. package/build-module/components/rich-text/index.js.map +1 -1
  285. package/build-module/components/rich-text/index.native.js +13 -9
  286. package/build-module/components/rich-text/index.native.js.map +1 -1
  287. package/build-module/components/rich-text/split-value.js +12 -2
  288. package/build-module/components/rich-text/split-value.js.map +1 -1
  289. package/build-module/components/rich-text/use-firefox-compat.js +39 -0
  290. package/build-module/components/rich-text/use-firefox-compat.js.map +1 -0
  291. package/build-module/components/rich-text/use-input-rules.js +35 -4
  292. package/build-module/components/rich-text/use-input-rules.js.map +1 -1
  293. package/build-module/components/skip-to-selected-block/index.js +4 -0
  294. package/build-module/components/skip-to-selected-block/index.js.map +1 -1
  295. package/build-module/components/url-popover/image-url-input-ui.js +12 -28
  296. package/build-module/components/url-popover/image-url-input-ui.js.map +1 -1
  297. package/build-module/components/writing-flow/index.js +5 -1
  298. package/build-module/components/writing-flow/index.js.map +1 -1
  299. package/build-module/components/writing-flow/use-arrow-nav.js +4 -45
  300. package/build-module/components/writing-flow/use-arrow-nav.js.map +1 -1
  301. package/build-module/components/writing-flow/use-click-selection.js +57 -0
  302. package/build-module/components/writing-flow/use-click-selection.js.map +1 -0
  303. package/build-module/components/writing-flow/use-drag-selection.js +124 -0
  304. package/build-module/components/writing-flow/use-drag-selection.js.map +1 -0
  305. package/build-module/components/writing-flow/use-input.js +104 -0
  306. package/build-module/components/writing-flow/use-input.js.map +1 -0
  307. package/build-module/components/writing-flow/use-multi-selection.js +18 -37
  308. package/build-module/components/writing-flow/use-multi-selection.js.map +1 -1
  309. package/build-module/components/writing-flow/use-selection-observer.js +150 -0
  310. package/build-module/components/writing-flow/use-selection-observer.js.map +1 -0
  311. package/build-module/components/writing-flow/use-tab-nav.js +1 -9
  312. package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
  313. package/build-module/hooks/anchor.js +7 -6
  314. package/build-module/hooks/anchor.js.map +1 -1
  315. package/build-module/hooks/border-color.js +5 -5
  316. package/build-module/hooks/border-color.js.map +1 -1
  317. package/build-module/hooks/border.js +0 -12
  318. package/build-module/hooks/border.js.map +1 -1
  319. package/build-module/hooks/color.js +19 -18
  320. package/build-module/hooks/color.js.map +1 -1
  321. package/build-module/hooks/font-family.js +3 -1
  322. package/build-module/hooks/font-family.js.map +1 -1
  323. package/build-module/hooks/font-size.js +4 -3
  324. package/build-module/hooks/font-size.js.map +1 -1
  325. package/build-module/hooks/gap.js +75 -7
  326. package/build-module/hooks/gap.js.map +1 -1
  327. package/build-module/hooks/layout.js +7 -2
  328. package/build-module/hooks/layout.js.map +1 -1
  329. package/build-module/hooks/style.js +33 -3
  330. package/build-module/hooks/style.js.map +1 -1
  331. package/build-module/hooks/utils.js +26 -0
  332. package/build-module/hooks/utils.js.map +1 -1
  333. package/build-module/layouts/flex.js +81 -16
  334. package/build-module/layouts/flex.js.map +1 -1
  335. package/build-module/layouts/flow.js +20 -13
  336. package/build-module/layouts/flow.js.map +1 -1
  337. package/build-module/store/actions.js +286 -49
  338. package/build-module/store/actions.js.map +1 -1
  339. package/build-module/store/defaults.js +5 -1
  340. package/build-module/store/defaults.js.map +1 -1
  341. package/build-module/store/reducer.js +25 -13
  342. package/build-module/store/reducer.js.map +1 -1
  343. package/build-module/store/selectors.js +186 -22
  344. package/build-module/store/selectors.js.map +1 -1
  345. package/build-module/utils/dom.js +2 -1
  346. package/build-module/utils/dom.js.map +1 -1
  347. package/build-style/style-rtl.css +248 -49
  348. package/build-style/style.css +248 -49
  349. package/build-types/utils/dom.d.ts.map +1 -1
  350. package/package.json +28 -27
  351. package/src/components/alignment-control/index.js +9 -4
  352. package/src/components/block-alignment-control/index.js +9 -4
  353. package/src/components/block-content-overlay/index.js +19 -2
  354. package/src/components/block-draggable/index.js +2 -5
  355. package/src/components/block-icon/index.js +3 -0
  356. package/src/components/block-inspector/index.js +4 -0
  357. package/src/components/block-list/block-html.js +8 -4
  358. package/src/components/block-list/block.js +5 -1
  359. package/src/components/block-list/style.scss +4 -5
  360. package/src/components/block-list/use-block-props/index.js +0 -5
  361. package/src/components/block-list/use-block-props/use-focus-first-element.js +27 -6
  362. package/src/components/block-list/use-block-props/use-focus-handler.js +8 -0
  363. package/src/components/block-list-appender/index.js +5 -0
  364. package/src/components/block-lock/index.js +4 -0
  365. package/src/components/block-lock/menu-item.js +39 -0
  366. package/src/components/block-lock/modal.js +194 -0
  367. package/src/components/block-lock/style.scss +70 -0
  368. package/src/components/block-lock/toolbar.js +51 -0
  369. package/src/components/block-lock/use-block-lock.js +49 -0
  370. package/src/components/block-mover/index.js +3 -0
  371. package/src/components/block-mover/style.scss +4 -0
  372. package/src/components/block-pattern-setup/index.js +84 -59
  373. package/src/components/block-pattern-setup/setup-toolbar.js +3 -1
  374. package/src/components/block-pattern-setup/style.scss +32 -26
  375. package/src/components/block-preview/auto.js +10 -1
  376. package/src/components/block-preview/index.js +2 -0
  377. package/src/components/block-settings-menu/block-settings-dropdown.js +109 -9
  378. package/src/components/block-settings-menu-controls/index.js +33 -12
  379. package/src/components/block-switcher/index.js +15 -3
  380. package/src/components/block-switcher/style.scss +15 -4
  381. package/src/components/block-switcher/test/__snapshots__/index.js.snap +15 -13
  382. package/src/components/block-switcher/test/index.js +2 -2
  383. package/src/components/block-title/README.md +6 -1
  384. package/src/components/block-title/index.js +2 -2
  385. package/src/components/block-title/test/index.js +43 -1
  386. package/src/components/block-title/use-block-display-title.js +10 -7
  387. package/src/components/block-toolbar/block-name-context.js +8 -0
  388. package/src/components/block-toolbar/block-toolbar-last-item.js +12 -0
  389. package/src/components/block-toolbar/index.js +24 -2
  390. package/src/components/block-toolbar/style.scss +10 -0
  391. package/src/components/block-tools/index.js +0 -19
  392. package/src/components/block-tools/style.scss +27 -0
  393. package/src/components/block-variation-transforms/index.js +105 -36
  394. package/src/components/block-variation-transforms/style.scss +1 -1
  395. package/src/components/block-vertical-alignment-control/index.js +9 -4
  396. package/src/components/border-radius-control/index.js +0 -1
  397. package/src/components/border-radius-control/test/utils.js +4 -0
  398. package/src/components/border-radius-control/utils.js +2 -1
  399. package/src/components/button-block-appender/style.scss +5 -1
  400. package/src/components/color-palette/test/__snapshots__/control.js.snap +70 -4
  401. package/src/components/colors-gradients/control.js +1 -1
  402. package/src/components/colors-gradients/style.scss +6 -0
  403. package/src/components/contrast-checker/index.js +3 -0
  404. package/src/components/convert-to-group-buttons/index.js +6 -1
  405. package/src/components/convert-to-group-buttons/toolbar.js +87 -0
  406. package/src/components/copy-handler/index.js +3 -0
  407. package/src/components/date-format-picker/README.md +58 -0
  408. package/src/components/date-format-picker/index.js +161 -0
  409. package/src/components/date-format-picker/style.scss +31 -0
  410. package/src/components/font-sizes/font-size-picker.js +3 -0
  411. package/src/components/iframe/index.js +5 -7
  412. package/src/components/index.js +3 -0
  413. package/src/components/justify-content-control/index.js +9 -4
  414. package/src/components/keyboard-shortcuts/index.js +1 -1
  415. package/src/components/line-height-control/index.js +11 -6
  416. package/src/components/link-control/README.md +1 -1
  417. package/src/components/list-view/block-select-button.js +14 -31
  418. package/src/components/list-view/block.js +55 -13
  419. package/src/components/list-view/branch.js +37 -15
  420. package/src/components/list-view/index.js +6 -0
  421. package/src/components/list-view/style.scss +56 -14
  422. package/src/components/list-view/use-block-selection.js +15 -2
  423. package/src/components/media-placeholder/README.md +8 -0
  424. package/src/components/media-replace-flow/index.js +3 -0
  425. package/src/components/multi-selection-inspector/index.js +2 -2
  426. package/src/components/rich-text/index.js +25 -2
  427. package/src/components/rich-text/index.native.js +24 -8
  428. package/src/components/rich-text/split-value.js +5 -1
  429. package/src/components/rich-text/use-firefox-compat.js +39 -0
  430. package/src/components/rich-text/use-input-rules.js +40 -3
  431. package/src/components/skip-to-selected-block/index.js +3 -0
  432. package/src/components/url-input/style.scss +3 -2
  433. package/src/components/url-popover/image-url-input-ui.js +16 -29
  434. package/src/components/writing-flow/index.js +8 -0
  435. package/src/components/writing-flow/readme.md +28 -0
  436. package/src/components/writing-flow/use-arrow-nav.js +4 -53
  437. package/src/components/writing-flow/use-click-selection.js +65 -0
  438. package/src/components/writing-flow/use-drag-selection.js +126 -0
  439. package/src/components/writing-flow/use-input.js +112 -0
  440. package/src/components/writing-flow/use-multi-selection.js +13 -36
  441. package/src/components/writing-flow/use-selection-observer.js +153 -0
  442. package/src/components/writing-flow/use-tab-nav.js +1 -11
  443. package/src/hooks/anchor.js +8 -6
  444. package/src/hooks/border-color.js +5 -5
  445. package/src/hooks/border.js +0 -13
  446. package/src/hooks/color.js +51 -24
  447. package/src/hooks/font-family.js +5 -2
  448. package/src/hooks/font-size.js +10 -7
  449. package/src/hooks/gap.js +91 -12
  450. package/src/hooks/layout.js +11 -1
  451. package/src/hooks/style.js +40 -4
  452. package/src/hooks/test/gap.js +66 -0
  453. package/src/hooks/test/style.js +94 -0
  454. package/src/hooks/test/utils.js +1 -1
  455. package/src/hooks/utils.js +26 -0
  456. package/src/layouts/flex.js +93 -6
  457. package/src/layouts/flow.js +28 -12
  458. package/src/store/actions.js +349 -32
  459. package/src/store/defaults.js +7 -1
  460. package/src/store/reducer.js +25 -10
  461. package/src/store/selectors.js +229 -27
  462. package/src/store/test/selectors.js +305 -5
  463. package/src/style.scss +2 -0
  464. package/src/utils/dom.js +2 -1
  465. package/tsconfig.tsbuildinfo +1 -1
  466. package/build/components/block-list/use-block-props/use-multi-selection.js +0 -205
  467. package/build/components/block-list/use-block-props/use-multi-selection.js.map +0 -1
  468. package/build/components/block-list/use-block-props/use-scroll-into-view.js +0 -77
  469. package/build/components/block-list/use-block-props/use-scroll-into-view.js.map +0 -1
  470. package/build-module/components/block-list/use-block-props/use-multi-selection.js +0 -192
  471. package/build-module/components/block-list/use-block-props/use-multi-selection.js.map +0 -1
  472. package/build-module/components/block-list/use-block-props/use-scroll-into-view.js +0 -63
  473. package/build-module/components/block-list/use-block-props/use-scroll-into-view.js.map +0 -1
  474. package/src/components/block-list/use-block-props/use-multi-selection.js +0 -227
  475. package/src/components/block-list/use-block-props/use-scroll-into-view.js +0 -73
@@ -3,7 +3,6 @@
3
3
  */
4
4
  import {
5
5
  castArray,
6
- flatMap,
7
6
  first,
8
7
  isArray,
9
8
  isBoolean,
@@ -28,10 +27,12 @@ import {
28
27
  hasBlockSupport,
29
28
  getPossibleBlockTransformations,
30
29
  parse,
30
+ switchToBlockType,
31
31
  } from '@wordpress/blocks';
32
32
  import { Platform } from '@wordpress/element';
33
33
  import { applyFilters } from '@wordpress/hooks';
34
34
  import { symbol } from '@wordpress/icons';
35
+ import { __ } from '@wordpress/i18n';
35
36
 
36
37
  /**
37
38
  * A block selection object.
@@ -215,26 +216,35 @@ export const __unstableGetClientIdsTree = createSelector(
215
216
  );
216
217
 
217
218
  /**
218
- * Returns an array containing the clientIds of all descendants
219
- * of the blocks given.
219
+ * Returns an array containing the clientIds of all descendants of the blocks
220
+ * given. Returned ids are ordered first by the order of the ids given, then
221
+ * by the order that they appear in the editor.
220
222
  *
221
223
  * @param {Object} state Global application state.
222
224
  * @param {Array} clientIds Array of blocks to inspect.
223
225
  *
224
226
  * @return {Array} ids of descendants.
225
227
  */
226
- export const getClientIdsOfDescendants = ( state, clientIds ) =>
227
- flatMap( clientIds, ( clientId ) => {
228
- const descendants = getBlockOrder( state, clientId );
229
- return [
230
- ...descendants,
231
- ...getClientIdsOfDescendants( state, descendants ),
232
- ];
233
- } );
228
+ export const getClientIdsOfDescendants = createSelector(
229
+ ( state, clientIds ) => {
230
+ const collectedIds = [];
231
+ for ( const givenId of clientIds ) {
232
+ for ( const descendantId of getBlockOrder( state, givenId ) ) {
233
+ collectedIds.push(
234
+ descendantId,
235
+ ...getClientIdsOfDescendants( state, [ descendantId ] )
236
+ );
237
+ }
238
+ }
239
+ return collectedIds;
240
+ },
241
+ ( state ) => [ state.blocks.order ]
242
+ );
234
243
 
235
244
  /**
236
- * Returns an array containing the clientIds of the top-level blocks
237
- * and their descendants of any depth (for nested blocks).
245
+ * Returns an array containing the clientIds of the top-level blocks and
246
+ * their descendants of any depth (for nested blocks). Ids are returned
247
+ * in the same order that they appear in the editor.
238
248
  *
239
249
  * @param {Object} state Global application state.
240
250
  *
@@ -242,11 +252,14 @@ export const getClientIdsOfDescendants = ( state, clientIds ) =>
242
252
  */
243
253
  export const getClientIdsWithDescendants = createSelector(
244
254
  ( state ) => {
245
- const topLevelIds = getBlockOrder( state );
246
- return [
247
- ...topLevelIds,
248
- ...getClientIdsOfDescendants( state, topLevelIds ),
249
- ];
255
+ const collectedIds = [];
256
+ for ( const topLevelId of getBlockOrder( state ) ) {
257
+ collectedIds.push(
258
+ topLevelId,
259
+ ...getClientIdsOfDescendants( state, [ topLevelId ] )
260
+ );
261
+ }
262
+ return collectedIds;
250
263
  },
251
264
  ( state ) => [ state.blocks.order ]
252
265
  );
@@ -278,6 +291,29 @@ export const getGlobalBlockCount = createSelector(
278
291
  ( state ) => [ state.blocks.order, state.blocks.byClientId ]
279
292
  );
280
293
 
294
+ /**
295
+ * Returns all global blocks that match a blockName. Results include nested blocks.
296
+ *
297
+ * @param {Object} state Global application state.
298
+ * @param {?string} blockName Optional block name, if not specified, returns an empty array.
299
+ *
300
+ * @return {Array} Array of clientIds of blocks with name equal to blockName.
301
+ */
302
+ export const __experimentalGetGlobalBlocksByName = createSelector(
303
+ ( state, blockName ) => {
304
+ if ( ! blockName ) {
305
+ return EMPTY_ARRAY;
306
+ }
307
+ const clientIds = getClientIdsWithDescendants( state );
308
+ const foundBlocks = clientIds.filter( ( clientId ) => {
309
+ const block = state.blocks.byClientId[ clientId ];
310
+ return block.name === blockName;
311
+ } );
312
+ return foundBlocks.length > 0 ? foundBlocks : EMPTY_ARRAY;
313
+ },
314
+ ( state ) => [ state.blocks.order, state.blocks.byClientId ]
315
+ );
316
+
281
317
  /**
282
318
  * Given an array of block client IDs, returns the corresponding array of block
283
319
  * objects.
@@ -872,6 +908,102 @@ export function getMultiSelectedBlocksEndClientId( state ) {
872
908
  return selectionEnd.clientId || null;
873
909
  }
874
910
 
911
+ /**
912
+ * Returns true if the selection is not partial.
913
+ *
914
+ * @param {Object} state Editor state.
915
+ *
916
+ * @return {boolean} Whether the selection is mergeable.
917
+ */
918
+ export function __unstableIsFullySelected( state ) {
919
+ const selectionAnchor = getSelectionStart( state );
920
+ const selectionFocus = getSelectionEnd( state );
921
+ return (
922
+ ! selectionAnchor.attributeKey &&
923
+ ! selectionFocus.attributeKey &&
924
+ typeof selectionAnchor.offset === 'undefined' &&
925
+ typeof selectionFocus.offset === 'undefined'
926
+ );
927
+ }
928
+
929
+ /**
930
+ * Check whether the selection is mergeable.
931
+ *
932
+ * @param {Object} state Editor state.
933
+ * @param {boolean} isForward Whether to merge forwards.
934
+ *
935
+ * @return {boolean} Whether the selection is mergeable.
936
+ */
937
+ export function __unstableIsSelectionMergeable( state, isForward ) {
938
+ const selectionAnchor = getSelectionStart( state );
939
+ const selectionFocus = getSelectionEnd( state );
940
+
941
+ // It's not mergeable if the start and end are within the same block.
942
+ if ( selectionAnchor.clientId === selectionFocus.clientId ) return false;
943
+
944
+ // It's not mergeable if there's no rich text selection.
945
+ if (
946
+ ! selectionAnchor.attributeKey ||
947
+ ! selectionFocus.attributeKey ||
948
+ typeof selectionAnchor.offset === 'undefined' ||
949
+ typeof selectionFocus.offset === 'undefined'
950
+ )
951
+ return false;
952
+
953
+ const anchorRootClientId = getBlockRootClientId(
954
+ state,
955
+ selectionAnchor.clientId
956
+ );
957
+ const focusRootClientId = getBlockRootClientId(
958
+ state,
959
+ selectionFocus.clientId
960
+ );
961
+
962
+ // It's not mergeable if the selection doesn't start and end in the same
963
+ // block list. Maybe in the future it should be allowed.
964
+ if ( anchorRootClientId !== focusRootClientId ) {
965
+ return false;
966
+ }
967
+
968
+ const blockOrder = getBlockOrder( state, anchorRootClientId );
969
+ const anchorIndex = blockOrder.indexOf( selectionAnchor.clientId );
970
+ const focusIndex = blockOrder.indexOf( selectionFocus.clientId );
971
+
972
+ // Reassign selection start and end based on order.
973
+ let selectionStart, selectionEnd;
974
+
975
+ if ( anchorIndex > focusIndex ) {
976
+ selectionStart = selectionFocus;
977
+ selectionEnd = selectionAnchor;
978
+ } else {
979
+ selectionStart = selectionAnchor;
980
+ selectionEnd = selectionFocus;
981
+ }
982
+
983
+ const targetBlockClientId = isForward
984
+ ? selectionEnd.clientId
985
+ : selectionStart.clientId;
986
+ const blockToMergeClientId = isForward
987
+ ? selectionStart.clientId
988
+ : selectionEnd.clientId;
989
+
990
+ const targetBlock = getBlock( state, targetBlockClientId );
991
+ const targetBlockType = getBlockType( targetBlock.name );
992
+
993
+ if ( ! targetBlockType.merge ) return false;
994
+
995
+ const blockToMerge = getBlock( state, blockToMergeClientId );
996
+
997
+ // It's mergeable if the blocks are of the same type.
998
+ if ( blockToMerge.name === targetBlock.name ) return true;
999
+
1000
+ // If the blocks are of a different type, try to transform the block being
1001
+ // merged into the same type of block.
1002
+ const blocksToMerge = switchToBlockType( blockToMerge, targetBlock.name );
1003
+
1004
+ return blocksToMerge && blocksToMerge.length;
1005
+ }
1006
+
875
1007
  /**
876
1008
  * Returns an array containing all block client IDs in the editor in the order
877
1009
  * they appear. Optionally accepts a root client ID of the block list for which
@@ -1261,10 +1393,28 @@ const canInsertBlockTypeUnmemoized = (
1261
1393
  parentName
1262
1394
  );
1263
1395
 
1396
+ let hasBlockAllowedAncestor = true;
1397
+ const blockAllowedAncestorBlocks = blockType.ancestor;
1398
+ if ( blockAllowedAncestorBlocks ) {
1399
+ const ancestors = [
1400
+ rootClientId,
1401
+ ...getBlockParents( state, rootClientId ),
1402
+ ];
1403
+
1404
+ hasBlockAllowedAncestor = some( ancestors, ( ancestorClientId ) =>
1405
+ checkAllowList(
1406
+ blockAllowedAncestorBlocks,
1407
+ getBlockName( state, ancestorClientId )
1408
+ )
1409
+ );
1410
+ }
1411
+
1264
1412
  const canInsert =
1265
- ( hasParentAllowedBlock === null && hasBlockAllowedParent === null ) ||
1266
- hasParentAllowedBlock === true ||
1267
- hasBlockAllowedParent === true;
1413
+ hasBlockAllowedAncestor &&
1414
+ ( ( hasParentAllowedBlock === null &&
1415
+ hasBlockAllowedParent === null ) ||
1416
+ hasParentAllowedBlock === true ||
1417
+ hasBlockAllowedParent === true );
1268
1418
 
1269
1419
  if ( ! canInsert ) {
1270
1420
  return canInsert;
@@ -1354,7 +1504,7 @@ export function canRemoveBlock( state, clientId, rootClientId = null ) {
1354
1504
 
1355
1505
  const { lock } = attributes;
1356
1506
  const parentIsLocked = !! getTemplateLock( state, rootClientId );
1357
- // If we don't have a lock on the blockType level, we differ to the parent templateLock.
1507
+ // If we don't have a lock on the blockType level, we defer to the parent templateLock.
1358
1508
  if ( lock === undefined || lock?.remove === undefined ) {
1359
1509
  return ! parentIsLocked;
1360
1510
  }
@@ -1395,7 +1545,7 @@ export function canMoveBlock( state, clientId, rootClientId = null ) {
1395
1545
 
1396
1546
  const { lock } = attributes;
1397
1547
  const parentIsLocked = getTemplateLock( state, rootClientId ) === 'all';
1398
- // If we don't have a lock on the blockType level, we differ to the parent templateLock.
1548
+ // If we don't have a lock on the blockType level, we defer to the parent templateLock.
1399
1549
  if ( lock === undefined || lock?.move === undefined ) {
1400
1550
  return ! parentIsLocked;
1401
1551
  }
@@ -1419,6 +1569,43 @@ export function canMoveBlocks( state, clientIds, rootClientId = null ) {
1419
1569
  );
1420
1570
  }
1421
1571
 
1572
+ /**
1573
+ * Determines if the given block is allowed to be edited.
1574
+ *
1575
+ * @param {Object} state Editor state.
1576
+ * @param {string} clientId The block client Id.
1577
+ *
1578
+ * @return {boolean} Whether the given block is allowed to be edited.
1579
+ */
1580
+ export function canEditBlock( state, clientId ) {
1581
+ const attributes = getBlockAttributes( state, clientId );
1582
+ if ( attributes === null ) {
1583
+ return true;
1584
+ }
1585
+
1586
+ const { lock } = attributes;
1587
+
1588
+ // When the edit is true, we cannot edit the block.
1589
+ return ! lock?.edit;
1590
+ }
1591
+
1592
+ /**
1593
+ * Determines if the given block type can be locked/unlocked by a user.
1594
+ *
1595
+ * @param {Object} state Editor state.
1596
+ * @param {(string|Object)} nameOrType Block name or type object.
1597
+ *
1598
+ * @return {boolean} Whether a given block type can be locked/unlocked.
1599
+ */
1600
+ export function canLockBlockType( state, nameOrType ) {
1601
+ if ( ! hasBlockSupport( nameOrType, 'lock', true ) ) {
1602
+ return false;
1603
+ }
1604
+
1605
+ // Use block editor settings as the default value.
1606
+ return !! state.settings?.canLockBlocks;
1607
+ }
1608
+
1422
1609
  /**
1423
1610
  * Returns information about how recently and frequently a block has been inserted.
1424
1611
  *
@@ -1744,6 +1931,7 @@ export const getInserterItems = createSelector(
1744
1931
  */
1745
1932
  export const getBlockTransformItems = createSelector(
1746
1933
  ( state, blocks, rootClientId = null ) => {
1934
+ const [ sourceBlock ] = blocks;
1747
1935
  const buildBlockTypeTransformItem = buildBlockTypeItem( state, {
1748
1936
  buildScope: 'transform',
1749
1937
  } );
@@ -1757,20 +1945,32 @@ export const getBlockTransformItems = createSelector(
1757
1945
  blockTypeTransformItems,
1758
1946
  ( { name } ) => name
1759
1947
  );
1948
+
1949
+ // Consider unwraping the highest priority.
1950
+ itemsByName[ '*' ] = {
1951
+ frecency: +Infinity,
1952
+ id: '*',
1953
+ isDisabled: false,
1954
+ name: '*',
1955
+ title: __( 'Unwrap' ),
1956
+ icon: itemsByName[ sourceBlock.name ]?.icon,
1957
+ };
1958
+
1760
1959
  const possibleTransforms = getPossibleBlockTransformations(
1761
1960
  blocks
1762
1961
  ).reduce( ( accumulator, block ) => {
1763
- if ( itemsByName[ block?.name ] ) {
1962
+ if ( block === '*' ) {
1963
+ accumulator.push( itemsByName[ '*' ] );
1964
+ } else if ( itemsByName[ block?.name ] ) {
1764
1965
  accumulator.push( itemsByName[ block.name ] );
1765
1966
  }
1766
1967
  return accumulator;
1767
1968
  }, [] );
1768
- const possibleBlockTransformations = orderBy(
1969
+ return orderBy(
1769
1970
  possibleTransforms,
1770
1971
  ( block ) => itemsByName[ block.name ].frecency,
1771
1972
  'desc'
1772
1973
  );
1773
- return possibleBlockTransformations;
1774
1974
  },
1775
1975
  ( state, rootClientId ) => [
1776
1976
  state.blockListSettings[ rootClientId ],
@@ -1914,7 +2114,9 @@ export const __experimentalGetParsedPattern = createSelector(
1914
2114
  }
1915
2115
  return {
1916
2116
  ...pattern,
1917
- blocks: parse( pattern.content ),
2117
+ blocks: parse( pattern.content, {
2118
+ __unstableSkipMigrationLogs: true,
2119
+ } ),
1918
2120
  };
1919
2121
  },
1920
2122
  ( state ) => [ state.settings.__experimentalBlockPatterns ]