@wordpress/block-editor 7.0.2 → 8.0.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 (801) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/README.md +45 -1
  3. package/build/components/autocomplete/index.js +1 -1
  4. package/build/components/autocomplete/index.js.map +1 -1
  5. package/build/components/block-actions/index.js +8 -4
  6. package/build/components/block-actions/index.js.map +1 -1
  7. package/build/components/block-alignment-control/ui.js +61 -14
  8. package/build/components/block-alignment-control/ui.js.map +1 -1
  9. package/build/components/block-alignment-control/use-available-alignments.js +25 -3
  10. package/build/components/block-alignment-control/use-available-alignments.js.map +1 -1
  11. package/build/components/block-controls/fill.js +2 -2
  12. package/build/components/block-controls/fill.js.map +1 -1
  13. package/build/components/block-controls/hook.js +3 -3
  14. package/build/components/block-controls/hook.js.map +1 -1
  15. package/build/components/block-icon/index.js +5 -1
  16. package/build/components/block-icon/index.js.map +1 -1
  17. package/build/components/block-icon/index.native.js +9 -11
  18. package/build/components/block-icon/index.native.js.map +1 -1
  19. package/build/components/block-inspector/index.js +8 -0
  20. package/build/components/block-inspector/index.js.map +1 -1
  21. package/build/components/block-list/block-html.js +5 -0
  22. package/build/components/block-list/block-html.js.map +1 -1
  23. package/build/components/block-list/block.js +12 -5
  24. package/build/components/block-list/block.js.map +1 -1
  25. package/build/components/block-list/block.native.js +4 -3
  26. package/build/components/block-list/block.native.js.map +1 -1
  27. package/build/components/block-list/index.native.js +1 -1
  28. package/build/components/block-list/index.native.js.map +1 -1
  29. package/build/components/block-list/use-block-props/use-multi-selection.js +21 -8
  30. package/build/components/block-list/use-block-props/use-multi-selection.js.map +1 -1
  31. package/build/components/block-list-appender/index.js +9 -1
  32. package/build/components/block-list-appender/index.js.map +1 -1
  33. package/build/components/block-mover/index.js +4 -4
  34. package/build/components/block-mover/index.js.map +1 -1
  35. package/build/components/block-mover/index.native.js +4 -4
  36. package/build/components/block-mover/index.native.js.map +1 -1
  37. package/build/components/block-navigation/dropdown.js +0 -1
  38. package/build/components/block-navigation/dropdown.js.map +1 -1
  39. package/build/components/block-patterns-list/index.js +1 -8
  40. package/build/components/block-patterns-list/index.js.map +1 -1
  41. package/build/components/block-preview/auto.js +1 -1
  42. package/build/components/block-preview/auto.js.map +1 -1
  43. package/build/components/block-settings/container.native.js +5 -2
  44. package/build/components/block-settings/container.native.js.map +1 -1
  45. package/build/components/block-settings-menu/block-settings-dropdown.js +26 -5
  46. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  47. package/build/components/block-settings-menu-controls/index.js +10 -3
  48. package/build/components/block-settings-menu-controls/index.js.map +1 -1
  49. package/build/components/block-styles/preview.native.js +2 -2
  50. package/build/components/block-styles/preview.native.js.map +1 -1
  51. package/build/components/block-switcher/block-styles-menu.js +1 -1
  52. package/build/components/block-switcher/block-styles-menu.js.map +1 -1
  53. package/build/components/block-switcher/index.js +10 -3
  54. package/build/components/block-switcher/index.js.map +1 -1
  55. package/build/components/block-title/index.js +3 -2
  56. package/build/components/block-title/index.js.map +1 -1
  57. package/build/components/block-tools/block-popover.js +2 -4
  58. package/build/components/block-tools/block-popover.js.map +1 -1
  59. package/build/components/block-tools/index.js +4 -1
  60. package/build/components/block-tools/index.js.map +1 -1
  61. package/build/components/block-tools/insertion-point.js +96 -7
  62. package/build/components/block-tools/insertion-point.js.map +1 -1
  63. package/build/components/border-radius-control/index.js.map +1 -1
  64. package/build/components/border-radius-control/utils.js +17 -8
  65. package/build/components/border-radius-control/utils.js.map +1 -1
  66. package/build/components/colors/utils.js +11 -3
  67. package/build/components/colors/utils.js.map +1 -1
  68. package/build/components/colors-gradients/control.js +22 -57
  69. package/build/components/colors-gradients/control.js.map +1 -1
  70. package/build/components/colors-gradients/panel-color-gradient-settings.js +83 -7
  71. package/build/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
  72. package/build/components/contrast-checker/index.js +18 -12
  73. package/build/components/contrast-checker/index.js.map +1 -1
  74. package/build/components/copy-handler/index.js +9 -3
  75. package/build/components/copy-handler/index.js.map +1 -1
  76. package/build/components/default-block-appender/index.js +2 -2
  77. package/build/components/default-block-appender/index.js.map +1 -1
  78. package/build/components/duotone-control/index.js +41 -39
  79. package/build/components/duotone-control/index.js.map +1 -1
  80. package/build/components/editor-styles/index.js +9 -3
  81. package/build/components/editor-styles/index.js.map +1 -1
  82. package/build/components/font-appearance-control/index.js +32 -21
  83. package/build/components/font-appearance-control/index.js.map +1 -1
  84. package/build/components/iframe/index.js +6 -4
  85. package/build/components/iframe/index.js.map +1 -1
  86. package/build/components/image-editor/aspect-ratio-dropdown.js +126 -0
  87. package/build/components/image-editor/aspect-ratio-dropdown.js.map +1 -0
  88. package/build/components/image-editor/constants.js +16 -0
  89. package/build/components/image-editor/constants.js.map +1 -0
  90. package/build/components/image-editor/context.js +59 -0
  91. package/build/components/image-editor/context.js.map +1 -0
  92. package/build/components/image-editor/cropper.js +83 -0
  93. package/build/components/image-editor/cropper.js.map +1 -0
  94. package/build/components/image-editor/form-controls.js +36 -0
  95. package/build/components/image-editor/form-controls.js.map +1 -0
  96. package/build/components/image-editor/index.js +60 -0
  97. package/build/components/image-editor/index.js.map +1 -0
  98. package/build/components/image-editor/rotation-button.js +37 -0
  99. package/build/components/image-editor/rotation-button.js.map +1 -0
  100. package/build/components/image-editor/use-save-image.js +84 -0
  101. package/build/components/image-editor/use-save-image.js.map +1 -0
  102. package/build/components/image-editor/use-transform-image.js +135 -0
  103. package/build/components/image-editor/use-transform-image.js.map +1 -0
  104. package/build/components/image-editor/zoom-dropdown.js +55 -0
  105. package/build/components/image-editor/zoom-dropdown.js.map +1 -0
  106. package/build/components/image-size-control/use-dimension-handler.js +14 -3
  107. package/build/components/image-size-control/use-dimension-handler.js.map +1 -1
  108. package/build/components/index.js +36 -20
  109. package/build/components/index.js.map +1 -1
  110. package/build/components/index.native.js +2 -2
  111. package/build/components/index.native.js.map +1 -1
  112. package/build/components/inner-blocks/button-block-appender.js +11 -1
  113. package/build/components/inner-blocks/button-block-appender.js.map +1 -1
  114. package/build/components/inner-blocks/index.js +8 -5
  115. package/build/components/inner-blocks/index.js.map +1 -1
  116. package/build/components/inner-blocks/index.native.js +4 -3
  117. package/build/components/inner-blocks/index.native.js.map +1 -1
  118. package/build/components/inner-blocks/use-nested-settings-update.js +24 -13
  119. package/build/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  120. package/build/components/inserter/block-patterns-explorer/explorer.js +62 -0
  121. package/build/components/inserter/block-patterns-explorer/explorer.js.map +1 -0
  122. package/build/components/inserter/block-patterns-explorer/patterns-list.js +111 -0
  123. package/build/components/inserter/block-patterns-explorer/patterns-list.js.map +1 -0
  124. package/build/components/inserter/block-patterns-explorer/sidebar.js +78 -0
  125. package/build/components/inserter/block-patterns-explorer/sidebar.js.map +1 -0
  126. package/build/components/inserter/block-patterns-tab.js +74 -35
  127. package/build/components/inserter/block-patterns-tab.js.map +1 -1
  128. package/build/components/inserter/block-types-tab.native.js +3 -11
  129. package/build/components/inserter/block-types-tab.native.js.map +1 -1
  130. package/build/components/inserter/hooks/use-block-type-impressions.native.js +4 -7
  131. package/build/components/inserter/hooks/use-block-type-impressions.native.js.map +1 -1
  132. package/build/components/inserter/hooks/use-clipboard-block.native.js +5 -4
  133. package/build/components/inserter/hooks/use-clipboard-block.native.js.map +1 -1
  134. package/build/components/inserter/index.js +12 -4
  135. package/build/components/inserter/index.js.map +1 -1
  136. package/build/components/inserter/index.native.js +1 -7
  137. package/build/components/inserter/index.native.js.map +1 -1
  138. package/build/components/inserter/library.js +2 -0
  139. package/build/components/inserter/library.js.map +1 -1
  140. package/build/components/inserter/menu.js +2 -1
  141. package/build/components/inserter/menu.js.map +1 -1
  142. package/build/components/inserter/menu.native.js +11 -15
  143. package/build/components/inserter/menu.native.js.map +1 -1
  144. package/build/components/inserter/pattern-panel.js +19 -10
  145. package/build/components/inserter/pattern-panel.js.map +1 -1
  146. package/build/components/inserter/preview-panel.js +1 -1
  147. package/build/components/inserter/preview-panel.js.map +1 -1
  148. package/build/components/inserter/quick-inserter.js +2 -1
  149. package/build/components/inserter/quick-inserter.js.map +1 -1
  150. package/build/components/inserter/reusable-blocks-tab.native.js +5 -6
  151. package/build/components/inserter/reusable-blocks-tab.native.js.map +1 -1
  152. package/build/components/inserter/search-results.native.js +6 -11
  153. package/build/components/inserter/search-results.native.js.map +1 -1
  154. package/build/components/inserter/utils.native.js +44 -0
  155. package/build/components/inserter/utils.native.js.map +1 -0
  156. package/build/components/inspector-controls/block-support-slot-container.js +28 -0
  157. package/build/components/inspector-controls/block-support-slot-container.js.map +1 -0
  158. package/build/components/inspector-controls/block-support-tools-panel.js +78 -0
  159. package/build/components/inspector-controls/block-support-tools-panel.js.map +1 -0
  160. package/build/components/inspector-controls/fill.js +16 -1
  161. package/build/components/inspector-controls/fill.js.map +1 -1
  162. package/build/components/inspector-controls/groups.js +5 -1
  163. package/build/components/inspector-controls/groups.js.map +1 -1
  164. package/build/components/inspector-controls/slot.js +15 -0
  165. package/build/components/inspector-controls/slot.js.map +1 -1
  166. package/build/components/letter-spacing-control/index.js +9 -6
  167. package/build/components/letter-spacing-control/index.js.map +1 -1
  168. package/build/components/link-control/index.js +93 -34
  169. package/build/components/link-control/index.js.map +1 -1
  170. package/build/components/link-control/link-preview.js +45 -15
  171. package/build/components/link-control/link-preview.js.map +1 -1
  172. package/build/components/link-control/search-input.js +25 -7
  173. package/build/components/link-control/search-input.js.map +1 -1
  174. package/build/components/list-view/block-contents.js +1 -20
  175. package/build/components/list-view/block-contents.js.map +1 -1
  176. package/build/components/list-view/block.js +54 -69
  177. package/build/components/list-view/block.js.map +1 -1
  178. package/build/components/list-view/branch.js +102 -76
  179. package/build/components/list-view/branch.js.map +1 -1
  180. package/build/components/list-view/index.js +45 -20
  181. package/build/components/list-view/index.js.map +1 -1
  182. package/build/components/list-view/leaf.js +2 -2
  183. package/build/components/list-view/leaf.js.map +1 -1
  184. package/build/components/list-view/list-item.js +3 -2
  185. package/build/components/list-view/list-item.js.map +1 -1
  186. package/build/components/list-view/use-list-view-client-ids.js +13 -54
  187. package/build/components/list-view/use-list-view-client-ids.js.map +1 -1
  188. package/build/components/media-placeholder/index.js +29 -20
  189. package/build/components/media-placeholder/index.js.map +1 -1
  190. package/build/components/media-replace-flow/index.js +5 -3
  191. package/build/components/media-replace-flow/index.js.map +1 -1
  192. package/build/components/navigable-toolbar/index.js +1 -4
  193. package/build/components/navigable-toolbar/index.js.map +1 -1
  194. package/build/components/observe-typing/index.js +1 -1
  195. package/build/components/observe-typing/index.js.map +1 -1
  196. package/build/components/plain-text/index.native.js +30 -1
  197. package/build/components/plain-text/index.native.js.map +1 -1
  198. package/build/components/rich-text/embed-handler-picker.native.js +66 -0
  199. package/build/components/rich-text/embed-handler-picker.native.js.map +1 -0
  200. package/build/components/rich-text/format-edit.js +28 -2
  201. package/build/components/rich-text/format-edit.js.map +1 -1
  202. package/build/components/rich-text/format-toolbar/index.js +32 -11
  203. package/build/components/rich-text/format-toolbar/index.js.map +1 -1
  204. package/build/components/rich-text/index.js +5 -1
  205. package/build/components/rich-text/index.js.map +1 -1
  206. package/build/components/rich-text/index.native.js +41 -2
  207. package/build/components/rich-text/index.native.js.map +1 -1
  208. package/build/components/rich-text/use-paste-handler.js +28 -9
  209. package/build/components/rich-text/use-paste-handler.js.map +1 -1
  210. package/build/components/rich-text/utils.js +22 -0
  211. package/build/components/rich-text/utils.js.map +1 -1
  212. package/build/components/typewriter/index.js +1 -1
  213. package/build/components/typewriter/index.js.map +1 -1
  214. package/build/components/url-input/index.js +25 -11
  215. package/build/components/url-input/index.js.map +1 -1
  216. package/build/components/use-moving-animation/index.js +13 -10
  217. package/build/components/use-moving-animation/index.js.map +1 -1
  218. package/build/components/use-on-block-drop/index.js +2 -1
  219. package/build/components/use-on-block-drop/index.js.map +1 -1
  220. package/build/components/use-setting/index.js +48 -9
  221. package/build/components/use-setting/index.js.map +1 -1
  222. package/build/components/writing-flow/use-multi-selection.js +6 -0
  223. package/build/components/writing-flow/use-multi-selection.js.map +1 -1
  224. package/build/components/writing-flow/use-tab-nav.js +10 -1
  225. package/build/components/writing-flow/use-tab-nav.js.map +1 -1
  226. package/build/hooks/align.js +13 -10
  227. package/build/hooks/align.js.map +1 -1
  228. package/build/hooks/anchor.js +1 -1
  229. package/build/hooks/anchor.js.map +1 -1
  230. package/build/hooks/border.js +5 -5
  231. package/build/hooks/border.js.map +1 -1
  232. package/build/hooks/color-panel.js +5 -2
  233. package/build/hooks/color-panel.js.map +1 -1
  234. package/build/hooks/color.js +1 -1
  235. package/build/hooks/color.js.map +1 -1
  236. package/build/hooks/dimensions.js +23 -27
  237. package/build/hooks/dimensions.js.map +1 -1
  238. package/build/hooks/duotone.js +60 -16
  239. package/build/hooks/duotone.js.map +1 -1
  240. package/build/hooks/font-appearance.js +49 -6
  241. package/build/hooks/font-appearance.js.map +1 -1
  242. package/build/hooks/font-family.js +123 -32
  243. package/build/hooks/font-family.js.map +1 -1
  244. package/build/hooks/font-size.js +51 -9
  245. package/build/hooks/font-size.js.map +1 -1
  246. package/build/hooks/gap.js +2 -1
  247. package/build/hooks/gap.js.map +1 -1
  248. package/build/hooks/index.js +10 -0
  249. package/build/hooks/index.js.map +1 -1
  250. package/build/hooks/index.native.js +8 -0
  251. package/build/hooks/index.native.js.map +1 -1
  252. package/build/hooks/letter-spacing.js +44 -7
  253. package/build/hooks/letter-spacing.js.map +1 -1
  254. package/build/hooks/line-height.js +45 -8
  255. package/build/hooks/line-height.js.map +1 -1
  256. package/build/hooks/lock.js +43 -0
  257. package/build/hooks/lock.js.map +1 -0
  258. package/build/hooks/margin.js +1 -1
  259. package/build/hooks/margin.js.map +1 -1
  260. package/build/hooks/padding.js +1 -1
  261. package/build/hooks/padding.js.map +1 -1
  262. package/build/hooks/style.js +7 -4
  263. package/build/hooks/style.js.map +1 -1
  264. package/build/hooks/text-decoration.js +42 -6
  265. package/build/hooks/text-decoration.js.map +1 -1
  266. package/build/hooks/text-transform.js +42 -6
  267. package/build/hooks/text-transform.js.map +1 -1
  268. package/build/hooks/typography.js +108 -8
  269. package/build/hooks/typography.js.map +1 -1
  270. package/build/hooks/use-cached-truthy.js +29 -0
  271. package/build/hooks/use-cached-truthy.js.map +1 -0
  272. package/build/index.js +7 -0
  273. package/build/index.js.map +1 -1
  274. package/build/layouts/flex.js +160 -34
  275. package/build/layouts/flex.js.map +1 -1
  276. package/build/layouts/flow.js +75 -8
  277. package/build/layouts/flow.js.map +1 -1
  278. package/build/store/actions.js +323 -265
  279. package/build/store/actions.js.map +1 -1
  280. package/build/store/defaults.native.js +13 -1
  281. package/build/store/defaults.native.js.map +1 -1
  282. package/build/store/index.js +1 -3
  283. package/build/store/index.js.map +1 -1
  284. package/build/store/reducer.js +33 -22
  285. package/build/store/reducer.js.map +1 -1
  286. package/build/store/selectors.js +172 -38
  287. package/build/store/selectors.js.map +1 -1
  288. package/build/utils/index.js +10 -1
  289. package/build/utils/index.js.map +1 -1
  290. package/build/utils/parse-css-unit-to-px.js +51 -1
  291. package/build/utils/parse-css-unit-to-px.js.map +1 -1
  292. package/build/utils/transform-styles/transforms/wrap.js +16 -0
  293. package/build/utils/transform-styles/transforms/wrap.js.map +1 -1
  294. package/build-module/components/autocomplete/index.js +2 -2
  295. package/build-module/components/autocomplete/index.js.map +1 -1
  296. package/build-module/components/block-actions/index.js +8 -4
  297. package/build-module/components/block-actions/index.js.map +1 -1
  298. package/build-module/components/block-alignment-control/ui.js +64 -17
  299. package/build-module/components/block-alignment-control/ui.js.map +1 -1
  300. package/build-module/components/block-alignment-control/use-available-alignments.js +25 -3
  301. package/build-module/components/block-alignment-control/use-available-alignments.js.map +1 -1
  302. package/build-module/components/block-controls/fill.js +2 -2
  303. package/build-module/components/block-controls/fill.js.map +1 -1
  304. package/build-module/components/block-controls/hook.js +3 -3
  305. package/build-module/components/block-controls/hook.js.map +1 -1
  306. package/build-module/components/block-icon/index.js +5 -1
  307. package/build-module/components/block-icon/index.js.map +1 -1
  308. package/build-module/components/block-icon/index.native.js +10 -11
  309. package/build-module/components/block-icon/index.native.js.map +1 -1
  310. package/build-module/components/block-inspector/index.js +8 -0
  311. package/build-module/components/block-inspector/index.js.map +1 -1
  312. package/build-module/components/block-list/block-html.js +5 -0
  313. package/build-module/components/block-list/block-html.js.map +1 -1
  314. package/build-module/components/block-list/block.js +12 -5
  315. package/build-module/components/block-list/block.js.map +1 -1
  316. package/build-module/components/block-list/block.native.js +4 -3
  317. package/build-module/components/block-list/block.native.js.map +1 -1
  318. package/build-module/components/block-list/index.native.js +1 -1
  319. package/build-module/components/block-list/index.native.js.map +1 -1
  320. package/build-module/components/block-list/use-block-props/use-multi-selection.js +21 -8
  321. package/build-module/components/block-list/use-block-props/use-multi-selection.js.map +1 -1
  322. package/build-module/components/block-list-appender/index.js +9 -1
  323. package/build-module/components/block-list-appender/index.js.map +1 -1
  324. package/build-module/components/block-mover/index.js +4 -4
  325. package/build-module/components/block-mover/index.js.map +1 -1
  326. package/build-module/components/block-mover/index.native.js +4 -4
  327. package/build-module/components/block-mover/index.native.js.map +1 -1
  328. package/build-module/components/block-navigation/dropdown.js +0 -1
  329. package/build-module/components/block-navigation/dropdown.js.map +1 -1
  330. package/build-module/components/block-patterns-list/index.js +1 -6
  331. package/build-module/components/block-patterns-list/index.js.map +1 -1
  332. package/build-module/components/block-preview/auto.js +1 -1
  333. package/build-module/components/block-preview/auto.js.map +1 -1
  334. package/build-module/components/block-settings/container.native.js +6 -3
  335. package/build-module/components/block-settings/container.native.js.map +1 -1
  336. package/build-module/components/block-settings-menu/block-settings-dropdown.js +28 -7
  337. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  338. package/build-module/components/block-settings-menu-controls/index.js +10 -3
  339. package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
  340. package/build-module/components/block-styles/preview.native.js +2 -2
  341. package/build-module/components/block-styles/preview.native.js.map +1 -1
  342. package/build-module/components/block-switcher/block-styles-menu.js +1 -1
  343. package/build-module/components/block-switcher/block-styles-menu.js.map +1 -1
  344. package/build-module/components/block-switcher/index.js +10 -3
  345. package/build-module/components/block-switcher/index.js.map +1 -1
  346. package/build-module/components/block-title/index.js +3 -2
  347. package/build-module/components/block-title/index.js.map +1 -1
  348. package/build-module/components/block-tools/block-popover.js +3 -5
  349. package/build-module/components/block-tools/block-popover.js.map +1 -1
  350. package/build-module/components/block-tools/index.js +4 -1
  351. package/build-module/components/block-tools/index.js.map +1 -1
  352. package/build-module/components/block-tools/insertion-point.js +96 -8
  353. package/build-module/components/block-tools/insertion-point.js.map +1 -1
  354. package/build-module/components/border-radius-control/index.js.map +1 -1
  355. package/build-module/components/border-radius-control/utils.js +16 -9
  356. package/build-module/components/border-radius-control/utils.js.map +1 -1
  357. package/build-module/components/colors/utils.js +9 -3
  358. package/build-module/components/colors/utils.js.map +1 -1
  359. package/build-module/components/colors-gradients/control.js +26 -63
  360. package/build-module/components/colors-gradients/control.js.map +1 -1
  361. package/build-module/components/colors-gradients/panel-color-gradient-settings.js +84 -7
  362. package/build-module/components/colors-gradients/panel-color-gradient-settings.js.map +1 -1
  363. package/build-module/components/contrast-checker/index.js +13 -10
  364. package/build-module/components/contrast-checker/index.js.map +1 -1
  365. package/build-module/components/copy-handler/index.js +9 -3
  366. package/build-module/components/copy-handler/index.js.map +1 -1
  367. package/build-module/components/default-block-appender/index.js +2 -2
  368. package/build-module/components/default-block-appender/index.js.map +1 -1
  369. package/build-module/components/duotone-control/index.js +43 -39
  370. package/build-module/components/duotone-control/index.js.map +1 -1
  371. package/build-module/components/editor-styles/index.js +7 -3
  372. package/build-module/components/editor-styles/index.js.map +1 -1
  373. package/build-module/components/font-appearance-control/index.js +28 -21
  374. package/build-module/components/font-appearance-control/index.js.map +1 -1
  375. package/build-module/components/iframe/index.js +6 -4
  376. package/build-module/components/iframe/index.js.map +1 -1
  377. package/build-module/components/image-editor/aspect-ratio-dropdown.js +115 -0
  378. package/build-module/components/image-editor/aspect-ratio-dropdown.js.map +1 -0
  379. package/build-module/components/image-editor/constants.js +7 -0
  380. package/build-module/components/image-editor/constants.js.map +1 -0
  381. package/build-module/components/image-editor/context.js +44 -0
  382. package/build-module/components/image-editor/context.js.map +1 -0
  383. package/build-module/components/image-editor/cropper.js +69 -0
  384. package/build-module/components/image-editor/cropper.js.map +1 -0
  385. package/build-module/components/image-editor/form-controls.js +26 -0
  386. package/build-module/components/image-editor/form-controls.js.map +1 -0
  387. package/build-module/components/image-editor/index.js +37 -0
  388. package/build-module/components/image-editor/index.js.map +1 -0
  389. package/build-module/components/image-editor/rotation-button.js +26 -0
  390. package/build-module/components/image-editor/rotation-button.js.map +1 -0
  391. package/build-module/components/image-editor/use-save-image.js +70 -0
  392. package/build-module/components/image-editor/use-save-image.js.map +1 -0
  393. package/build-module/components/image-editor/use-transform-image.js +127 -0
  394. package/build-module/components/image-editor/use-transform-image.js.map +1 -0
  395. package/build-module/components/image-editor/zoom-dropdown.js +43 -0
  396. package/build-module/components/image-editor/zoom-dropdown.js.map +1 -0
  397. package/build-module/components/image-size-control/use-dimension-handler.js +13 -2
  398. package/build-module/components/image-size-control/use-dimension-handler.js.map +1 -1
  399. package/build-module/components/index.js +4 -3
  400. package/build-module/components/index.js.map +1 -1
  401. package/build-module/components/index.native.js +1 -1
  402. package/build-module/components/index.native.js.map +1 -1
  403. package/build-module/components/inner-blocks/button-block-appender.js +10 -1
  404. package/build-module/components/inner-blocks/button-block-appender.js.map +1 -1
  405. package/build-module/components/inner-blocks/index.js +9 -6
  406. package/build-module/components/inner-blocks/index.js.map +1 -1
  407. package/build-module/components/inner-blocks/index.native.js +5 -4
  408. package/build-module/components/inner-blocks/index.native.js.map +1 -1
  409. package/build-module/components/inner-blocks/use-nested-settings-update.js +24 -13
  410. package/build-module/components/inner-blocks/use-nested-settings-update.js.map +1 -1
  411. package/build-module/components/inserter/block-patterns-explorer/explorer.js +50 -0
  412. package/build-module/components/inserter/block-patterns-explorer/explorer.js.map +1 -0
  413. package/build-module/components/inserter/block-patterns-explorer/patterns-list.js +92 -0
  414. package/build-module/components/inserter/block-patterns-explorer/patterns-list.js.map +1 -0
  415. package/build-module/components/inserter/block-patterns-explorer/sidebar.js +69 -0
  416. package/build-module/components/inserter/block-patterns-explorer/sidebar.js.map +1 -0
  417. package/build-module/components/inserter/block-patterns-tab.js +75 -36
  418. package/build-module/components/inserter/block-patterns-tab.js.map +1 -1
  419. package/build-module/components/inserter/block-types-tab.native.js +2 -10
  420. package/build-module/components/inserter/block-types-tab.native.js.map +1 -1
  421. package/build-module/components/inserter/hooks/use-block-type-impressions.native.js +4 -7
  422. package/build-module/components/inserter/hooks/use-block-type-impressions.native.js.map +1 -1
  423. package/build-module/components/inserter/hooks/use-clipboard-block.native.js +5 -4
  424. package/build-module/components/inserter/hooks/use-clipboard-block.native.js.map +1 -1
  425. package/build-module/components/inserter/index.js +12 -4
  426. package/build-module/components/inserter/index.js.map +1 -1
  427. package/build-module/components/inserter/index.native.js +1 -7
  428. package/build-module/components/inserter/index.native.js.map +1 -1
  429. package/build-module/components/inserter/library.js +2 -0
  430. package/build-module/components/inserter/library.js.map +1 -1
  431. package/build-module/components/inserter/menu.js +2 -1
  432. package/build-module/components/inserter/menu.js.map +1 -1
  433. package/build-module/components/inserter/menu.native.js +10 -15
  434. package/build-module/components/inserter/menu.native.js.map +1 -1
  435. package/build-module/components/inserter/pattern-panel.js +21 -13
  436. package/build-module/components/inserter/pattern-panel.js.map +1 -1
  437. package/build-module/components/inserter/preview-panel.js +1 -1
  438. package/build-module/components/inserter/preview-panel.js.map +1 -1
  439. package/build-module/components/inserter/quick-inserter.js +2 -1
  440. package/build-module/components/inserter/quick-inserter.js.map +1 -1
  441. package/build-module/components/inserter/reusable-blocks-tab.native.js +4 -5
  442. package/build-module/components/inserter/reusable-blocks-tab.native.js.map +1 -1
  443. package/build-module/components/inserter/search-results.native.js +5 -10
  444. package/build-module/components/inserter/search-results.native.js.map +1 -1
  445. package/build-module/components/inserter/utils.native.js +35 -0
  446. package/build-module/components/inserter/utils.native.js.map +1 -0
  447. package/build-module/components/inspector-controls/block-support-slot-container.js +18 -0
  448. package/build-module/components/inspector-controls/block-support-slot-container.js.map +1 -0
  449. package/build-module/components/inspector-controls/block-support-tools-panel.js +67 -0
  450. package/build-module/components/inspector-controls/block-support-tools-panel.js.map +1 -0
  451. package/build-module/components/inspector-controls/fill.js +16 -2
  452. package/build-module/components/inspector-controls/fill.js.map +1 -1
  453. package/build-module/components/inspector-controls/groups.js +5 -1
  454. package/build-module/components/inspector-controls/groups.js.map +1 -1
  455. package/build-module/components/inspector-controls/slot.js +13 -0
  456. package/build-module/components/inspector-controls/slot.js.map +1 -1
  457. package/build-module/components/letter-spacing-control/index.js +9 -6
  458. package/build-module/components/letter-spacing-control/index.js.map +1 -1
  459. package/build-module/components/link-control/index.js +93 -35
  460. package/build-module/components/link-control/index.js.map +1 -1
  461. package/build-module/components/link-control/link-preview.js +46 -17
  462. package/build-module/components/link-control/link-preview.js.map +1 -1
  463. package/build-module/components/link-control/search-input.js +24 -7
  464. package/build-module/components/link-control/search-input.js.map +1 -1
  465. package/build-module/components/list-view/block-contents.js +1 -18
  466. package/build-module/components/list-view/block-contents.js.map +1 -1
  467. package/build-module/components/list-view/block.js +56 -71
  468. package/build-module/components/list-view/block.js.map +1 -1
  469. package/build-module/components/list-view/branch.js +102 -78
  470. package/build-module/components/list-view/branch.js.map +1 -1
  471. package/build-module/components/list-view/index.js +48 -23
  472. package/build-module/components/list-view/index.js.map +1 -1
  473. package/build-module/components/list-view/leaf.js +2 -2
  474. package/build-module/components/list-view/leaf.js.map +1 -1
  475. package/build-module/components/list-view/list-item.js +3 -2
  476. package/build-module/components/list-view/list-item.js.map +1 -1
  477. package/build-module/components/list-view/use-list-view-client-ids.js +13 -54
  478. package/build-module/components/list-view/use-list-view-client-ids.js.map +1 -1
  479. package/build-module/components/media-placeholder/index.js +29 -20
  480. package/build-module/components/media-placeholder/index.js.map +1 -1
  481. package/build-module/components/media-replace-flow/index.js +5 -3
  482. package/build-module/components/media-replace-flow/index.js.map +1 -1
  483. package/build-module/components/navigable-toolbar/index.js +1 -4
  484. package/build-module/components/navigable-toolbar/index.js.map +1 -1
  485. package/build-module/components/observe-typing/index.js +1 -1
  486. package/build-module/components/observe-typing/index.js.map +1 -1
  487. package/build-module/components/plain-text/index.native.js +29 -2
  488. package/build-module/components/plain-text/index.native.js.map +1 -1
  489. package/build-module/components/rich-text/embed-handler-picker.native.js +54 -0
  490. package/build-module/components/rich-text/embed-handler-picker.native.js.map +1 -0
  491. package/build-module/components/rich-text/format-edit.js +28 -3
  492. package/build-module/components/rich-text/format-edit.js.map +1 -1
  493. package/build-module/components/rich-text/format-toolbar/index.js +29 -11
  494. package/build-module/components/rich-text/format-toolbar/index.js.map +1 -1
  495. package/build-module/components/rich-text/index.js +4 -1
  496. package/build-module/components/rich-text/index.js.map +1 -1
  497. package/build-module/components/rich-text/index.native.js +41 -3
  498. package/build-module/components/rich-text/index.native.js.map +1 -1
  499. package/build-module/components/rich-text/use-paste-handler.js +28 -9
  500. package/build-module/components/rich-text/use-paste-handler.js.map +1 -1
  501. package/build-module/components/rich-text/utils.js +20 -0
  502. package/build-module/components/rich-text/utils.js.map +1 -1
  503. package/build-module/components/typewriter/index.js +1 -1
  504. package/build-module/components/typewriter/index.js.map +1 -1
  505. package/build-module/components/url-input/index.js +25 -11
  506. package/build-module/components/url-input/index.js.map +1 -1
  507. package/build-module/components/use-moving-animation/index.js +13 -10
  508. package/build-module/components/use-moving-animation/index.js.map +1 -1
  509. package/build-module/components/use-on-block-drop/index.js +3 -2
  510. package/build-module/components/use-on-block-drop/index.js.map +1 -1
  511. package/build-module/components/use-setting/index.js +48 -9
  512. package/build-module/components/use-setting/index.js.map +1 -1
  513. package/build-module/components/writing-flow/use-multi-selection.js +6 -0
  514. package/build-module/components/writing-flow/use-multi-selection.js.map +1 -1
  515. package/build-module/components/writing-flow/use-tab-nav.js +10 -1
  516. package/build-module/components/writing-flow/use-tab-nav.js.map +1 -1
  517. package/build-module/hooks/align.js +13 -10
  518. package/build-module/hooks/align.js.map +1 -1
  519. package/build-module/hooks/anchor.js +1 -1
  520. package/build-module/hooks/anchor.js.map +1 -1
  521. package/build-module/hooks/border.js +5 -5
  522. package/build-module/hooks/border.js.map +1 -1
  523. package/build-module/hooks/color-panel.js +6 -3
  524. package/build-module/hooks/color-panel.js.map +1 -1
  525. package/build-module/hooks/color.js +1 -1
  526. package/build-module/hooks/color.js.map +1 -1
  527. package/build-module/hooks/dimensions.js +24 -27
  528. package/build-module/hooks/dimensions.js.map +1 -1
  529. package/build-module/hooks/duotone.js +59 -16
  530. package/build-module/hooks/duotone.js.map +1 -1
  531. package/build-module/hooks/font-appearance.js +45 -6
  532. package/build-module/hooks/font-appearance.js.map +1 -1
  533. package/build-module/hooks/font-family.js +117 -33
  534. package/build-module/hooks/font-family.js.map +1 -1
  535. package/build-module/hooks/font-size.js +47 -9
  536. package/build-module/hooks/font-size.js.map +1 -1
  537. package/build-module/hooks/gap.js +2 -1
  538. package/build-module/hooks/gap.js.map +1 -1
  539. package/build-module/hooks/index.js +2 -0
  540. package/build-module/hooks/index.js.map +1 -1
  541. package/build-module/hooks/index.native.js +1 -0
  542. package/build-module/hooks/index.native.js.map +1 -1
  543. package/build-module/hooks/letter-spacing.js +40 -7
  544. package/build-module/hooks/letter-spacing.js.map +1 -1
  545. package/build-module/hooks/line-height.js +41 -8
  546. package/build-module/hooks/line-height.js.map +1 -1
  547. package/build-module/hooks/lock.js +33 -0
  548. package/build-module/hooks/lock.js.map +1 -0
  549. package/build-module/hooks/margin.js +1 -1
  550. package/build-module/hooks/margin.js.map +1 -1
  551. package/build-module/hooks/padding.js +1 -1
  552. package/build-module/hooks/padding.js.map +1 -1
  553. package/build-module/hooks/style.js +7 -4
  554. package/build-module/hooks/style.js.map +1 -1
  555. package/build-module/hooks/text-decoration.js +38 -6
  556. package/build-module/hooks/text-decoration.js.map +1 -1
  557. package/build-module/hooks/text-transform.js +38 -6
  558. package/build-module/hooks/text-transform.js.map +1 -1
  559. package/build-module/hooks/typography.js +117 -17
  560. package/build-module/hooks/typography.js.map +1 -1
  561. package/build-module/hooks/use-cached-truthy.js +21 -0
  562. package/build-module/hooks/use-cached-truthy.js.map +1 -0
  563. package/build-module/index.js +1 -1
  564. package/build-module/index.js.map +1 -1
  565. package/build-module/layouts/flex.js +163 -38
  566. package/build-module/layouts/flex.js.map +1 -1
  567. package/build-module/layouts/flow.js +74 -8
  568. package/build-module/layouts/flow.js.map +1 -1
  569. package/build-module/store/actions.js +286 -241
  570. package/build-module/store/actions.js.map +1 -1
  571. package/build-module/store/defaults.native.js +12 -1
  572. package/build-module/store/defaults.native.js.map +1 -1
  573. package/build-module/store/index.js +1 -2
  574. package/build-module/store/index.js.map +1 -1
  575. package/build-module/store/reducer.js +33 -22
  576. package/build-module/store/reducer.js.map +1 -1
  577. package/build-module/store/selectors.js +160 -34
  578. package/build-module/store/selectors.js.map +1 -1
  579. package/build-module/utils/index.js +1 -0
  580. package/build-module/utils/index.js.map +1 -1
  581. package/build-module/utils/parse-css-unit-to-px.js +48 -1
  582. package/build-module/utils/parse-css-unit-to-px.js.map +1 -1
  583. package/build-module/utils/transform-styles/transforms/wrap.js +16 -0
  584. package/build-module/utils/transform-styles/transforms/wrap.js.map +1 -1
  585. package/build-style/style-rtl.css +267 -144
  586. package/build-style/style.css +267 -144
  587. package/package.json +28 -27
  588. package/src/components/autocomplete/index.js +5 -2
  589. package/src/components/block-actions/index.js +9 -5
  590. package/src/components/block-alignment-control/style.scss +5 -0
  591. package/src/components/block-alignment-control/test/__snapshots__/index.js.snap +15 -1
  592. package/src/components/block-alignment-control/test/index.native.js +37 -0
  593. package/src/components/block-alignment-control/ui.js +98 -27
  594. package/src/components/block-alignment-control/use-available-alignments.js +31 -10
  595. package/src/components/block-controls/fill.js +5 -2
  596. package/src/components/block-controls/hook.js +3 -3
  597. package/src/components/block-draggable/style.scss +19 -4
  598. package/src/components/block-icon/index.js +4 -1
  599. package/src/components/block-icon/index.native.js +10 -16
  600. package/src/components/block-inspector/index.js +10 -0
  601. package/src/components/block-list/block-html.js +5 -0
  602. package/src/components/block-list/block.js +11 -3
  603. package/src/components/block-list/block.native.js +5 -3
  604. package/src/components/block-list/index.native.js +1 -1
  605. package/src/components/block-list/style.scss +15 -0
  606. package/src/components/block-list/use-block-props/use-multi-selection.js +27 -7
  607. package/src/components/block-list-appender/index.js +8 -0
  608. package/src/components/block-mover/index.js +4 -4
  609. package/src/components/block-mover/index.native.js +4 -4
  610. package/src/components/block-mover/test/__snapshots__/index.native.js.snap +10 -6
  611. package/src/components/block-mover/test/index.native.js +26 -28
  612. package/src/components/block-navigation/dropdown.js +0 -1
  613. package/src/components/block-patterns-list/index.js +1 -8
  614. package/src/components/block-patterns-list/style.scss +22 -12
  615. package/src/components/block-preview/README.md +1 -1
  616. package/src/components/block-preview/auto.js +1 -1
  617. package/src/components/block-preview/style.scss +0 -17
  618. package/src/components/block-settings/container.native.js +7 -0
  619. package/src/components/block-settings-menu/block-settings-dropdown.js +26 -13
  620. package/src/components/block-settings-menu-controls/index.js +9 -6
  621. package/src/components/block-styles/preview.native.js +2 -2
  622. package/src/components/block-switcher/block-styles-menu.js +1 -1
  623. package/src/components/block-switcher/index.js +7 -3
  624. package/src/components/block-switcher/test/__snapshots__/index.js.snap +1 -1
  625. package/src/components/block-switcher/test/index.js +3 -0
  626. package/src/components/block-title/index.js +5 -2
  627. package/src/components/block-tools/block-popover.js +3 -5
  628. package/src/components/block-tools/index.js +5 -2
  629. package/src/components/block-tools/insertion-point.js +97 -9
  630. package/src/components/block-tools/style.scss +4 -35
  631. package/src/components/block-types-list/style.scss +0 -3
  632. package/src/components/border-radius-control/index.js +1 -0
  633. package/src/components/border-radius-control/test/utils.js +216 -0
  634. package/src/components/border-radius-control/utils.js +18 -10
  635. package/src/components/color-palette/test/__snapshots__/control.js.snap +128 -71
  636. package/src/components/colors/test/utils.js +41 -0
  637. package/src/components/colors/utils.js +9 -5
  638. package/src/components/colors-gradients/control.js +70 -110
  639. package/src/components/colors-gradients/panel-color-gradient-settings.js +79 -7
  640. package/src/components/colors-gradients/style.scss +10 -18
  641. package/src/components/colors-gradients/test/control.js +41 -66
  642. package/src/components/contrast-checker/index.js +14 -10
  643. package/src/components/copy-handler/index.js +6 -1
  644. package/src/components/default-block-appender/index.js +2 -2
  645. package/src/components/default-block-appender/test/__snapshots__/index.js.snap +3 -3
  646. package/src/components/duotone-control/index.js +49 -41
  647. package/src/components/duotone-control/style.scss +27 -12
  648. package/src/components/editor-styles/index.js +7 -4
  649. package/src/components/font-appearance-control/index.js +41 -33
  650. package/src/components/font-appearance-control/style.scss +1 -1
  651. package/src/components/iframe/index.js +4 -4
  652. package/src/components/image-editor/aspect-ratio-dropdown.js +129 -0
  653. package/src/components/image-editor/constants.js +6 -0
  654. package/src/components/image-editor/context.js +56 -0
  655. package/src/components/image-editor/cropper.js +74 -0
  656. package/src/components/image-editor/form-controls.js +22 -0
  657. package/src/components/image-editor/index.js +52 -0
  658. package/src/components/image-editor/rotation-button.js +24 -0
  659. package/src/components/image-editor/use-save-image.js +97 -0
  660. package/src/components/image-editor/use-transform-image.js +162 -0
  661. package/src/components/image-editor/zoom-dropdown.js +40 -0
  662. package/src/components/image-size-control/use-dimension-handler.js +18 -1
  663. package/src/components/index.js +7 -6
  664. package/src/components/index.native.js +1 -4
  665. package/src/components/inner-blocks/button-block-appender.js +9 -0
  666. package/src/components/inner-blocks/index.js +8 -4
  667. package/src/components/inner-blocks/index.native.js +7 -4
  668. package/src/components/inner-blocks/use-nested-settings-update.js +26 -11
  669. package/src/components/inserter/block-patterns-explorer/explorer.js +50 -0
  670. package/src/components/inserter/block-patterns-explorer/patterns-list.js +122 -0
  671. package/src/components/inserter/block-patterns-explorer/sidebar.js +73 -0
  672. package/src/components/inserter/block-patterns-tab.js +107 -73
  673. package/src/components/inserter/block-types-tab.native.js +3 -15
  674. package/src/components/inserter/hooks/use-block-type-impressions.native.js +14 -21
  675. package/src/components/inserter/hooks/use-clipboard-block.native.js +3 -2
  676. package/src/components/inserter/index.js +15 -3
  677. package/src/components/inserter/index.native.js +2 -19
  678. package/src/components/inserter/library.js +2 -0
  679. package/src/components/inserter/menu.js +4 -1
  680. package/src/components/inserter/menu.native.js +9 -14
  681. package/src/components/inserter/pattern-panel.js +33 -16
  682. package/src/components/inserter/preview-panel.js +1 -1
  683. package/src/components/inserter/quick-inserter.js +1 -1
  684. package/src/components/inserter/reusable-blocks-tab.native.js +4 -6
  685. package/src/components/inserter/search-results.native.js +5 -15
  686. package/src/components/inserter/style.scss +80 -16
  687. package/src/components/inserter/test/block-types-tab.native.js +1 -1
  688. package/src/components/inserter/test/fixtures/index.native.js +12 -0
  689. package/src/components/inserter/utils.native.js +35 -0
  690. package/src/components/inserter-list-item/style.scss +4 -2
  691. package/src/components/inspector-controls/block-support-slot-container.js +10 -0
  692. package/src/components/inspector-controls/block-support-tools-panel.js +60 -0
  693. package/src/components/inspector-controls/fill.js +23 -2
  694. package/src/components/inspector-controls/groups.js +8 -0
  695. package/src/components/inspector-controls/slot.js +15 -0
  696. package/src/components/letter-spacing-control/index.js +12 -6
  697. package/src/components/link-control/README.md +47 -14
  698. package/src/components/link-control/index.js +102 -31
  699. package/src/components/link-control/link-preview.js +53 -20
  700. package/src/components/link-control/search-input.js +21 -7
  701. package/src/components/link-control/style.scss +66 -19
  702. package/src/components/link-control/test/index.js +311 -4
  703. package/src/components/list-view/block-contents.js +17 -38
  704. package/src/components/list-view/block.js +73 -84
  705. package/src/components/list-view/branch.js +123 -94
  706. package/src/components/list-view/index.js +82 -30
  707. package/src/components/list-view/leaf.js +2 -2
  708. package/src/components/list-view/list-item.js +5 -4
  709. package/src/components/list-view/style.scss +70 -33
  710. package/src/components/list-view/use-list-view-client-ids.js +9 -68
  711. package/src/components/media-placeholder/index.js +26 -19
  712. package/src/components/media-replace-flow/README.md +7 -0
  713. package/src/components/media-replace-flow/index.js +4 -1
  714. package/src/components/media-upload/README.md +1 -1
  715. package/src/components/navigable-toolbar/index.js +1 -4
  716. package/src/components/observe-typing/index.js +3 -2
  717. package/src/components/plain-text/index.native.js +26 -4
  718. package/src/components/rich-text/embed-handler-picker.native.js +68 -0
  719. package/src/components/rich-text/format-edit.js +36 -2
  720. package/src/components/rich-text/format-toolbar/index.js +25 -6
  721. package/src/components/rich-text/index.js +12 -8
  722. package/src/components/rich-text/index.native.js +35 -1
  723. package/src/components/rich-text/use-paste-handler.js +30 -12
  724. package/src/components/rich-text/utils.js +16 -0
  725. package/src/components/skip-to-selected-block/README.md +39 -0
  726. package/src/components/typewriter/index.js +3 -2
  727. package/src/components/url-input/index.js +26 -10
  728. package/src/components/use-moving-animation/index.js +9 -8
  729. package/src/components/use-on-block-drop/index.js +5 -1
  730. package/src/components/use-setting/index.js +49 -11
  731. package/src/components/writing-flow/use-multi-selection.js +6 -0
  732. package/src/components/writing-flow/use-tab-nav.js +17 -3
  733. package/src/hooks/align.js +19 -10
  734. package/src/hooks/anchor.js +2 -2
  735. package/src/hooks/border.js +8 -11
  736. package/src/hooks/color-panel.js +4 -1
  737. package/src/hooks/color.js +7 -4
  738. package/src/hooks/dimensions.js +48 -59
  739. package/src/hooks/duotone.js +68 -19
  740. package/src/hooks/font-appearance.js +38 -7
  741. package/src/hooks/font-family.js +129 -33
  742. package/src/hooks/font-size.js +42 -6
  743. package/src/hooks/gap.js +2 -1
  744. package/src/hooks/index.js +2 -0
  745. package/src/hooks/index.native.js +1 -0
  746. package/src/hooks/layout.scss +8 -0
  747. package/src/hooks/letter-spacing.js +35 -7
  748. package/src/hooks/line-height.js +37 -9
  749. package/src/hooks/lock.js +34 -0
  750. package/src/hooks/margin.js +1 -1
  751. package/src/hooks/padding.js +1 -1
  752. package/src/hooks/style.js +15 -11
  753. package/src/hooks/text-decoration.js +34 -6
  754. package/src/hooks/text-transform.js +34 -6
  755. package/src/hooks/typography.js +165 -15
  756. package/src/hooks/typography.scss +16 -0
  757. package/src/hooks/use-cached-truthy.js +20 -0
  758. package/src/index.js +1 -0
  759. package/src/layouts/flex.js +179 -50
  760. package/src/layouts/flow.js +54 -8
  761. package/src/store/actions.js +239 -377
  762. package/src/store/defaults.native.js +12 -0
  763. package/src/store/index.js +1 -2
  764. package/src/store/reducer.js +54 -18
  765. package/src/store/selectors.js +173 -47
  766. package/src/store/test/actions.js +407 -705
  767. package/src/store/test/reducer.js +22 -54
  768. package/src/store/test/selectors.js +79 -21
  769. package/src/style.scss +2 -1
  770. package/src/utils/index.js +1 -0
  771. package/src/utils/parse-css-unit-to-px.js +43 -1
  772. package/src/utils/test/parse-css-unit-to-px.js +148 -165
  773. package/src/utils/transform-styles/transforms/test/wrap.js +1 -1
  774. package/src/utils/transform-styles/transforms/wrap.js +16 -0
  775. package/tsconfig.tsbuildinfo +1 -1
  776. package/build/components/duotone-control/duotone-picker-popover.js +0 -44
  777. package/build/components/duotone-control/duotone-picker-popover.js.map +0 -1
  778. package/build/components/list-view/block-slot.js +0 -121
  779. package/build/components/list-view/block-slot.js.map +0 -1
  780. package/build/components/list-view/editor.js +0 -35
  781. package/build/components/list-view/editor.js.map +0 -1
  782. package/build/components/text-decoration-and-transform/index.js +0 -39
  783. package/build/components/text-decoration-and-transform/index.js.map +0 -1
  784. package/build/store/controls.js +0 -44
  785. package/build/store/controls.js.map +0 -1
  786. package/build-module/components/duotone-control/duotone-picker-popover.js +0 -35
  787. package/build-module/components/duotone-control/duotone-picker-popover.js.map +0 -1
  788. package/build-module/components/list-view/block-slot.js +0 -96
  789. package/build-module/components/list-view/block-slot.js.map +0 -1
  790. package/build-module/components/list-view/editor.js +0 -25
  791. package/build-module/components/list-view/editor.js.map +0 -1
  792. package/build-module/components/text-decoration-and-transform/index.js +0 -30
  793. package/build-module/components/text-decoration-and-transform/index.js.map +0 -1
  794. package/build-module/store/controls.js +0 -32
  795. package/build-module/store/controls.js.map +0 -1
  796. package/src/components/duotone-control/duotone-picker-popover.js +0 -36
  797. package/src/components/list-view/block-slot.js +0 -120
  798. package/src/components/list-view/editor.js +0 -29
  799. package/src/components/text-decoration-and-transform/index.js +0 -36
  800. package/src/components/text-decoration-and-transform/style.scss +0 -3
  801. package/src/store/controls.js +0 -39
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@wordpress/block-editor",
3
- "version": "7.0.2",
3
+ "version": "8.0.1",
4
4
  "description": "Generic block editor.",
5
5
  "author": "The WordPress Contributors",
6
6
  "license": "GPL-2.0-or-later",
@@ -32,32 +32,34 @@
32
32
  ],
33
33
  "dependencies": {
34
34
  "@babel/runtime": "^7.13.10",
35
- "@wordpress/a11y": "^3.2.2",
35
+ "@react-spring/web": "^9.2.4",
36
+ "@wordpress/a11y": "^3.2.3",
37
+ "@wordpress/api-fetch": "^5.2.5",
36
38
  "@wordpress/blob": "^3.2.1",
37
- "@wordpress/block-serialization-default-parser": "^4.2.1",
38
- "@wordpress/blocks": "^11.1.0",
39
- "@wordpress/components": "^17.0.0",
40
- "@wordpress/compose": "^5.0.2",
41
- "@wordpress/data": "^6.1.0",
42
- "@wordpress/data-controls": "^2.2.3",
43
- "@wordpress/deprecated": "^3.2.1",
44
- "@wordpress/dom": "^3.2.3",
45
- "@wordpress/element": "^4.0.1",
46
- "@wordpress/hooks": "^3.2.0",
47
- "@wordpress/html-entities": "^3.2.1",
48
- "@wordpress/i18n": "^4.2.2",
49
- "@wordpress/icons": "^5.0.2",
39
+ "@wordpress/block-serialization-default-parser": "^4.2.2",
40
+ "@wordpress/blocks": "^11.1.3",
41
+ "@wordpress/components": "^19.0.1",
42
+ "@wordpress/compose": "^5.0.5",
43
+ "@wordpress/data": "^6.1.3",
44
+ "@wordpress/deprecated": "^3.2.2",
45
+ "@wordpress/dom": "^3.2.6",
46
+ "@wordpress/element": "^4.0.3",
47
+ "@wordpress/hooks": "^3.2.1",
48
+ "@wordpress/html-entities": "^3.2.2",
49
+ "@wordpress/i18n": "^4.2.3",
50
+ "@wordpress/icons": "^6.1.0",
50
51
  "@wordpress/is-shallow-equal": "^4.2.0",
51
- "@wordpress/keyboard-shortcuts": "^3.0.2",
52
- "@wordpress/keycodes": "^3.2.2",
53
- "@wordpress/notices": "^3.2.3",
54
- "@wordpress/rich-text": "^5.0.2",
55
- "@wordpress/shortcode": "^3.2.1",
56
- "@wordpress/token-list": "^2.2.0",
57
- "@wordpress/url": "^3.2.2",
58
- "@wordpress/warning": "^2.2.1",
59
- "@wordpress/wordcount": "^3.2.1",
52
+ "@wordpress/keyboard-shortcuts": "^3.0.5",
53
+ "@wordpress/keycodes": "^3.2.3",
54
+ "@wordpress/notices": "^3.2.6",
55
+ "@wordpress/rich-text": "^5.0.5",
56
+ "@wordpress/shortcode": "^3.2.2",
57
+ "@wordpress/token-list": "^2.2.1",
58
+ "@wordpress/url": "^3.3.0",
59
+ "@wordpress/warning": "^2.2.2",
60
+ "@wordpress/wordcount": "^3.2.2",
60
61
  "classnames": "^2.3.1",
62
+ "colord": "^2.7.0",
61
63
  "css-mediaquery": "^0.1.2",
62
64
  "diff": "^4.0.2",
63
65
  "dom-scroll-into-view": "^1.2.1",
@@ -65,14 +67,13 @@
65
67
  "lodash": "^4.17.21",
66
68
  "memize": "^1.1.0",
67
69
  "react-autosize-textarea": "^7.1.0",
68
- "react-spring": "^8.0.19",
70
+ "react-easy-crop": "^3.0.0",
69
71
  "redux-multi": "^0.1.12",
70
72
  "rememo": "^3.0.0",
71
- "tinycolor2": "^1.4.2",
72
73
  "traverse": "^0.6.6"
73
74
  },
74
75
  "publishConfig": {
75
76
  "access": "public"
76
77
  },
77
- "gitHead": "98c42a7187f788fe3e023f04df7f5dcbdae4e4e7"
78
+ "gitHead": "f89b63995376fe6efe920d858b48268b510920e1"
78
79
  }
@@ -12,7 +12,7 @@ import {
12
12
  __unstableUseAutocompleteProps as useAutocompleteProps,
13
13
  } from '@wordpress/components';
14
14
  import { useMemo } from '@wordpress/element';
15
- import { getDefaultBlockName } from '@wordpress/blocks';
15
+ import { getDefaultBlockName, getBlockSupport } from '@wordpress/blocks';
16
16
 
17
17
  /**
18
18
  * Internal dependencies
@@ -33,7 +33,10 @@ function useCompleters( { completers = EMPTY_ARRAY } ) {
33
33
  return useMemo( () => {
34
34
  let filteredCompleters = completers;
35
35
 
36
- if ( name === getDefaultBlockName() ) {
36
+ if (
37
+ name === getDefaultBlockName() ||
38
+ getBlockSupport( name, '__experimentalSlashInserter', false )
39
+ ) {
37
40
  filteredCompleters = filteredCompleters.concat( [
38
41
  blockAutocompleter,
39
42
  ] );
@@ -28,11 +28,11 @@ export default function BlockActions( {
28
28
  canInsertBlockType,
29
29
  getBlockRootClientId,
30
30
  getBlocksByClientId,
31
- getTemplateLock,
32
- } = useSelect( ( select ) => select( blockEditorStore ), [] );
31
+ canMoveBlocks,
32
+ canRemoveBlocks,
33
+ } = useSelect( blockEditorStore );
33
34
  const { getDefaultBlockName, getGroupingBlockName } = useSelect(
34
- ( select ) => select( blocksStore ),
35
- []
35
+ blocksStore
36
36
  );
37
37
 
38
38
  const blocks = getBlocksByClientId( clientIds );
@@ -50,6 +50,9 @@ export default function BlockActions( {
50
50
  rootClientId
51
51
  );
52
52
 
53
+ const canMove = canMoveBlocks( clientIds, rootClientId );
54
+ const canRemove = canRemoveBlocks( clientIds, rootClientId );
55
+
53
56
  const {
54
57
  removeBlocks,
55
58
  replaceBlocks,
@@ -67,7 +70,8 @@ export default function BlockActions( {
67
70
  return children( {
68
71
  canDuplicate,
69
72
  canInsertDefaultBlock,
70
- isLocked: !! getTemplateLock( rootClientId ),
73
+ canMove,
74
+ canRemove,
71
75
  rootClientId,
72
76
  blocks,
73
77
  onDuplicate() {
@@ -0,0 +1,5 @@
1
+ .block-editor-block-alignment-control__menu-group {
2
+ .components-menu-item__info {
3
+ margin-top: 0;
4
+ }
5
+ }
@@ -4,6 +4,20 @@ exports[`BlockAlignmentUI should match snapshot 1`] = `
4
4
  <ToolbarGroup
5
5
  controls={
6
6
  Array [
7
+ Object {
8
+ "icon": <SVG
9
+ viewBox="0 0 24 24"
10
+ xmlns="http://www.w3.org/2000/svg"
11
+ >
12
+ <Path
13
+ d="M5 15h14V9H5v6zm0 4.8h14v-1.5H5v1.5zM5 4.2v1.5h14V4.2H5z"
14
+ />
15
+ </SVG>,
16
+ "isActive": false,
17
+ "onClick": [Function],
18
+ "role": "menuitemradio",
19
+ "title": "None",
20
+ },
7
21
  Object {
8
22
  "icon": <SVG
9
23
  viewBox="0 0 24 24"
@@ -24,7 +38,7 @@ exports[`BlockAlignmentUI should match snapshot 1`] = `
24
38
  xmlns="http://www.w3.org/2000/svg"
25
39
  >
26
40
  <Path
27
- d="M5 15h14V9H5v6zm0 4.8h14v-1.5H5v1.5zM5 4.2v1.5h14V4.2H5z"
41
+ d="M7 9v6h10V9H7zM5 19.8h14v-1.5H5v1.5zM5 4.3v1.5h14V4.3H5z"
28
42
  />
29
43
  </SVG>,
30
44
  "isActive": false,
@@ -0,0 +1,37 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { render, fireEvent } from 'test/helpers';
5
+
6
+ /**
7
+ * Internal dependencies
8
+ */
9
+ import BlockAlignmentUI from '../ui';
10
+
11
+ it( 'should call onChange with undefined when the control is already active', () => {
12
+ const onChangeMock = jest.fn();
13
+ const screen = render(
14
+ <BlockAlignmentUI value="right" onChange={ onChangeMock } />
15
+ );
16
+ const alignButton = screen.getByA11yLabel( 'Align' );
17
+ fireEvent.press( alignButton );
18
+ const rightAlignmentButton = screen.getByA11yLabel( 'Align right' );
19
+ fireEvent.press( rightAlignmentButton );
20
+
21
+ expect( onChangeMock ).toHaveBeenCalledTimes( 1 );
22
+ expect( onChangeMock ).toHaveBeenCalledWith( undefined );
23
+ } );
24
+
25
+ it( 'should call onChange with alignment value when the control is inactive', () => {
26
+ const onChangeMock = jest.fn();
27
+ const screen = render(
28
+ <BlockAlignmentUI value="left" onChange={ onChangeMock } />
29
+ );
30
+ const alignButton = screen.getByA11yLabel( 'Align' );
31
+ fireEvent.press( alignButton );
32
+ const centerAlignmentButton = screen.getByA11yLabel( 'Align center' );
33
+ fireEvent.press( centerAlignmentButton );
34
+
35
+ expect( onChangeMock ).toHaveBeenCalledTimes( 1 );
36
+ expect( onChangeMock ).toHaveBeenCalledWith( 'center' );
37
+ } );
@@ -1,15 +1,27 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import classNames from 'classnames';
5
+
1
6
  /**
2
7
  * WordPress dependencies
3
8
  */
4
9
  import { __ } from '@wordpress/i18n';
5
- import { ToolbarDropdownMenu, ToolbarGroup } from '@wordpress/components';
6
10
  import {
11
+ ToolbarDropdownMenu,
12
+ ToolbarGroup,
13
+ MenuGroup,
14
+ MenuItem,
15
+ } from '@wordpress/components';
16
+ import {
17
+ alignNone,
7
18
  positionCenter,
8
19
  positionLeft,
9
20
  positionRight,
10
21
  stretchFullWidth,
11
22
  stretchWide,
12
23
  } from '@wordpress/icons';
24
+ import { Platform } from '@wordpress/element';
13
25
 
14
26
  /**
15
27
  * Internal dependencies
@@ -17,6 +29,10 @@ import {
17
29
  import useAvailableAlignments from './use-available-alignments';
18
30
 
19
31
  const BLOCK_ALIGNMENTS_CONTROLS = {
32
+ none: {
33
+ icon: alignNone,
34
+ title: __( 'None' ),
35
+ },
20
36
  left: {
21
37
  icon: positionLeft,
22
38
  title: __( 'Align left' ),
@@ -39,7 +55,7 @@ const BLOCK_ALIGNMENTS_CONTROLS = {
39
55
  },
40
56
  };
41
57
 
42
- const DEFAULT_CONTROL = 'center';
58
+ const DEFAULT_CONTROL = 'none';
43
59
 
44
60
  const POPOVER_PROPS = {
45
61
  isAlternate: true,
@@ -53,12 +69,14 @@ function BlockAlignmentUI( {
53
69
  isCollapsed = true,
54
70
  } ) {
55
71
  const enabledControls = useAvailableAlignments( controls );
56
- if ( enabledControls.length === 0 ) {
72
+ const hasEnabledControls = !! enabledControls.length;
73
+
74
+ if ( ! hasEnabledControls ) {
57
75
  return null;
58
76
  }
59
77
 
60
- function applyOrUnset( align ) {
61
- return () => onChange( value === align ? undefined : align );
78
+ function onChangeAlignment( align ) {
79
+ onChange( [ value, 'none' ].includes( align ) ? undefined : align );
62
80
  }
63
81
 
64
82
  const activeAlignmentControl = BLOCK_ALIGNMENTS_CONTROLS[ value ];
@@ -66,29 +84,82 @@ function BlockAlignmentUI( {
66
84
  BLOCK_ALIGNMENTS_CONTROLS[ DEFAULT_CONTROL ];
67
85
 
68
86
  const UIComponent = isToolbar ? ToolbarGroup : ToolbarDropdownMenu;
69
- const extraProps = isToolbar ? { isCollapsed } : {};
87
+ const commonProps = {
88
+ popoverProps: POPOVER_PROPS,
89
+ icon: activeAlignmentControl
90
+ ? activeAlignmentControl.icon
91
+ : defaultAlignmentControl.icon,
92
+ label: __( 'Align' ),
93
+ toggleProps: { describedBy: __( 'Change alignment' ) },
94
+ };
95
+ const extraProps =
96
+ isToolbar || Platform.isNative
97
+ ? {
98
+ isCollapsed: isToolbar ? isCollapsed : undefined,
99
+ controls: enabledControls.map(
100
+ ( { name: controlName } ) => {
101
+ return {
102
+ ...BLOCK_ALIGNMENTS_CONTROLS[ controlName ],
103
+ isActive:
104
+ value === controlName ||
105
+ ( ! value && controlName === 'none' ),
106
+ role: isCollapsed ? 'menuitemradio' : undefined,
107
+ onClick: () => onChangeAlignment( controlName ),
108
+ };
109
+ }
110
+ ),
111
+ }
112
+ : {
113
+ children: ( { onClose } ) => {
114
+ return (
115
+ <>
116
+ <MenuGroup className="block-editor-block-alignment-control__menu-group">
117
+ { enabledControls.map(
118
+ ( { name: controlName, info } ) => {
119
+ const {
120
+ icon,
121
+ title,
122
+ } = BLOCK_ALIGNMENTS_CONTROLS[
123
+ controlName
124
+ ];
125
+ // If no value is provided, mark as selected the `none` option.
126
+ const isSelected =
127
+ controlName === value ||
128
+ ( ! value &&
129
+ controlName === 'none' );
130
+ return (
131
+ <MenuItem
132
+ key={ controlName }
133
+ icon={ icon }
134
+ iconPosition="left"
135
+ className={ classNames(
136
+ 'components-dropdown-menu__menu-item',
137
+ {
138
+ 'is-active': isSelected,
139
+ }
140
+ ) }
141
+ isSelected={ isSelected }
142
+ onClick={ () => {
143
+ onChangeAlignment(
144
+ controlName
145
+ );
146
+ onClose();
147
+ } }
148
+ role="menuitemradio"
149
+ info={ info }
150
+ >
151
+ { title }
152
+ </MenuItem>
153
+ );
154
+ }
155
+ ) }
156
+ </MenuGroup>
157
+ </>
158
+ );
159
+ },
160
+ };
70
161
 
71
- return (
72
- <UIComponent
73
- popoverProps={ POPOVER_PROPS }
74
- icon={
75
- activeAlignmentControl
76
- ? activeAlignmentControl.icon
77
- : defaultAlignmentControl.icon
78
- }
79
- label={ __( 'Align' ) }
80
- toggleProps={ { describedBy: __( 'Change alignment' ) } }
81
- controls={ enabledControls.map( ( control ) => {
82
- return {
83
- ...BLOCK_ALIGNMENTS_CONTROLS[ control ],
84
- isActive: value === control,
85
- role: isCollapsed ? 'menuitemradio' : undefined,
86
- onClick: applyOrUnset( control ),
87
- };
88
- } ) }
89
- { ...extraProps }
90
- />
91
- );
162
+ return <UIComponent { ...commonProps } { ...extraProps } />;
92
163
  }
93
164
 
94
165
  export default BlockAlignmentUI;
@@ -10,10 +10,14 @@ import { useLayout } from '../block-list/layout';
10
10
  import { store as blockEditorStore } from '../../store';
11
11
  import { getLayoutType } from '../../layouts';
12
12
 
13
- const DEFAULT_CONTROLS = [ 'left', 'center', 'right', 'wide', 'full' ];
13
+ const DEFAULT_CONTROLS = [ 'none', 'left', 'center', 'right', 'wide', 'full' ];
14
14
  const WIDE_CONTROLS = [ 'wide', 'full' ];
15
15
 
16
16
  export default function useAvailableAlignments( controls = DEFAULT_CONTROLS ) {
17
+ // Always add the `none` option if not exists.
18
+ if ( ! controls.includes( 'none' ) ) {
19
+ controls = [ 'none', ...controls ];
20
+ }
17
21
  const { wideControlsEnabled = false, themeSupportsLayout } = useSelect(
18
22
  ( select ) => {
19
23
  const { getSettings } = select( blockEditorStore );
@@ -30,9 +34,15 @@ export default function useAvailableAlignments( controls = DEFAULT_CONTROLS ) {
30
34
  const layoutAlignments = layoutType.getAlignments( layout );
31
35
 
32
36
  if ( themeSupportsLayout ) {
33
- return layoutAlignments.filter( ( control ) =>
34
- controls.includes( control )
37
+ const alignments = layoutAlignments.filter(
38
+ ( { name: alignmentName } ) => controls.includes( alignmentName )
35
39
  );
40
+ // While we treat `none` as an alignment, we shouldn't return it if no
41
+ // other alignments exist.
42
+ if ( alignments.length === 1 && alignments[ 0 ].name === 'none' ) {
43
+ return [];
44
+ }
45
+ return alignments;
36
46
  }
37
47
 
38
48
  // Starting here, it's the fallback for themes not supporting the layout config.
@@ -40,13 +50,24 @@ export default function useAvailableAlignments( controls = DEFAULT_CONTROLS ) {
40
50
  return [];
41
51
  }
42
52
  const { alignments: availableAlignments = DEFAULT_CONTROLS } = layout;
43
- const enabledControls = controls.filter(
44
- ( control ) =>
45
- ( layout.alignments || // Ignore the global wideAlignment check if the layout explicitely defines alignments.
46
- wideControlsEnabled ||
47
- ! WIDE_CONTROLS.includes( control ) ) &&
48
- availableAlignments.includes( control )
49
- );
53
+ const enabledControls = controls
54
+ .filter(
55
+ ( control ) =>
56
+ ( layout.alignments || // Ignore the global wideAlignment check if the layout explicitely defines alignments.
57
+ wideControlsEnabled ||
58
+ ! WIDE_CONTROLS.includes( control ) ) &&
59
+ availableAlignments.includes( control )
60
+ )
61
+ .map( ( enabledControl ) => ( { name: enabledControl } ) );
62
+
63
+ // While we treat `none` as an alignment, we shouldn't return it if no
64
+ // other alignments exist.
65
+ if (
66
+ enabledControls.length === 1 &&
67
+ enabledControls[ 0 ].name === 'none'
68
+ ) {
69
+ return [];
70
+ }
50
71
 
51
72
  return enabledControls;
52
73
  }
@@ -21,9 +21,12 @@ export default function BlockControlsFill( {
21
21
  group = 'default',
22
22
  controls,
23
23
  children,
24
- __experimentalExposeToChildren = false,
24
+ __experimentalShareWithChildBlocks = false,
25
25
  } ) {
26
- const Fill = useBlockControlsFill( group, __experimentalExposeToChildren );
26
+ const Fill = useBlockControlsFill(
27
+ group,
28
+ __experimentalShareWithChildBlocks
29
+ );
27
30
  if ( ! Fill ) {
28
31
  return null;
29
32
  }
@@ -12,7 +12,7 @@ import { store as blockEditorStore } from '../../store';
12
12
  import { useBlockEditContext } from '../block-edit/context';
13
13
  import useDisplayBlockControls from '../use-display-block-controls';
14
14
 
15
- export default function useBlockControlsFill( group, exposeToChildren ) {
15
+ export default function useBlockControlsFill( group, shareWithChildBlocks ) {
16
16
  const isDisplayed = useDisplayBlockControls();
17
17
  const { clientId } = useBlockEditContext();
18
18
  const isParentDisplayed = useSelect(
@@ -22,7 +22,7 @@ export default function useBlockControlsFill( group, exposeToChildren ) {
22
22
  );
23
23
  const { hasBlockSupport } = select( blocksStore );
24
24
  return (
25
- exposeToChildren &&
25
+ shareWithChildBlocks &&
26
26
  hasBlockSupport(
27
27
  getBlockName( clientId ),
28
28
  '__experimentalExposeControlsToChildren',
@@ -31,7 +31,7 @@ export default function useBlockControlsFill( group, exposeToChildren ) {
31
31
  hasSelectedInnerBlock( clientId )
32
32
  );
33
33
  },
34
- [ exposeToChildren, clientId ]
34
+ [ shareWithChildBlocks, clientId ]
35
35
  );
36
36
 
37
37
  if ( isDisplayed ) {
@@ -45,8 +45,23 @@
45
45
  }
46
46
  }
47
47
 
48
- // This hides the block being dragged.
49
- // The effect is that the block being dragged appears to be "lifted".
50
- .is-dragging {
51
- display: none !important;
48
+ // This creates a "slot" where the block you're dragging appeared.
49
+ // We use !important as one of the rules are meant to be overriden.
50
+ .block-editor-block-list__layout .is-dragging {
51
+ background-color: currentColor !important;
52
+ opacity: 0.05 !important;
53
+ border-radius: $radius-block-ui !important;
54
+
55
+ // Disabling pointer events during the drag event is necessary,
56
+ // lest the block might affect your drag operation.
57
+ pointer-events: none !important;
58
+
59
+ // Hide the multi selection indicator when dragging.
60
+ &::selection {
61
+ background: transparent !important;
62
+ }
63
+
64
+ &::after {
65
+ content: none !important;
66
+ }
52
67
  }
@@ -8,8 +8,9 @@ import classnames from 'classnames';
8
8
  */
9
9
  import { Icon } from '@wordpress/components';
10
10
  import { blockDefault } from '@wordpress/icons';
11
+ import { memo } from '@wordpress/element';
11
12
 
12
- export default function BlockIcon( { icon, showColors = false, className } ) {
13
+ function BlockIcon( { icon, showColors = false, className } ) {
13
14
  if ( icon?.src === 'block-default' ) {
14
15
  icon = {
15
16
  src: blockDefault,
@@ -35,3 +36,5 @@ export default function BlockIcon( { icon, showColors = false, className } ) {
35
36
  </span>
36
37
  );
37
38
  }
39
+
40
+ export default memo( BlockIcon );
@@ -8,46 +8,40 @@ import { View } from 'react-native';
8
8
  */
9
9
  import { Icon } from '@wordpress/components';
10
10
  import { blockDefault } from '@wordpress/icons';
11
- import { withPreferredColorScheme } from '@wordpress/compose';
11
+ import { usePreferredColorSchemeStyle } from '@wordpress/compose';
12
12
 
13
13
  /**
14
14
  * Internal dependencies
15
15
  */
16
16
  import styles from './style.scss';
17
17
 
18
- export function BlockIcon( {
19
- icon,
20
- fill,
21
- size,
22
- showColors = false,
23
- getStylesFromColorScheme,
24
- } ) {
18
+ export function BlockIcon( { icon, fill, size, showColors = false } ) {
25
19
  if ( icon?.src === 'block-default' ) {
26
20
  icon = {
27
21
  src: blockDefault,
28
22
  };
29
23
  }
30
24
 
25
+ const defaultFill = usePreferredColorSchemeStyle(
26
+ styles.iconPlaceholder,
27
+ styles.iconPlaceholderDark
28
+ )?.fill;
29
+ const iconForeground = showColors ? icon?.foreground : undefined;
30
+
31
31
  const renderedIcon = (
32
32
  <Icon
33
33
  icon={ icon && icon.src ? icon.src : icon }
34
- { ...( fill && { fill } ) }
34
+ fill={ fill || iconForeground || defaultFill }
35
35
  { ...( size && { size } ) }
36
- { ...( ! fill &&
37
- getStylesFromColorScheme(
38
- styles.iconPlaceholder,
39
- styles.iconPlaceholderDark
40
- ) ) }
41
36
  />
42
37
  );
43
38
  const style = showColors
44
39
  ? {
45
40
  backgroundColor: icon && icon.background,
46
- color: icon && icon.foreground,
47
41
  }
48
42
  : {};
49
43
 
50
44
  return <View style={ style }>{ renderedIcon }</View>;
51
45
  }
52
46
 
53
- export default withPreferredColorScheme( BlockIcon );
47
+ export default BlockIcon;
@@ -129,6 +129,16 @@ const BlockInspectorSingleBlock = ( {
129
129
  </div>
130
130
  ) }
131
131
  <InspectorControls.Slot bubblesVirtually={ bubblesVirtually } />
132
+ <InspectorControls.Slot
133
+ __experimentalGroup="typography"
134
+ bubblesVirtually={ bubblesVirtually }
135
+ label={ __( 'Typography' ) }
136
+ />
137
+ <InspectorControls.Slot
138
+ __experimentalGroup="dimensions"
139
+ bubblesVirtually={ bubblesVirtually }
140
+ label={ __( 'Dimensions' ) }
141
+ />
132
142
  <div>
133
143
  <AdvancedControls bubblesVirtually={ bubblesVirtually } />
134
144
  </div>
@@ -30,6 +30,11 @@ function BlockHTML( { clientId } ) {
30
30
  const { updateBlock } = useDispatch( blockEditorStore );
31
31
  const onChange = () => {
32
32
  const blockType = getBlockType( block.name );
33
+
34
+ if ( ! blockType ) {
35
+ return;
36
+ }
37
+
33
38
  const attributes = getBlockAttributes(
34
39
  blockType,
35
40
  html,
@@ -71,6 +71,7 @@ function Block( { children, isHtml, ...props } ) {
71
71
  function BlockListBlock( {
72
72
  mode,
73
73
  isLocked,
74
+ canRemove,
74
75
  clientId,
75
76
  isSelected,
76
77
  isSelectionEnabled,
@@ -99,9 +100,9 @@ function BlockListBlock( {
99
100
  attributes={ attributes }
100
101
  setAttributes={ setAttributes }
101
102
  insertBlocksAfter={ isLocked ? undefined : onInsertBlocksAfter }
102
- onReplace={ isLocked ? undefined : onReplace }
103
- onRemove={ isLocked ? undefined : onRemove }
104
- mergeBlocks={ isLocked ? undefined : onMerge }
103
+ onReplace={ canRemove ? onReplace : undefined }
104
+ onRemove={ canRemove ? onRemove : undefined }
105
+ mergeBlocks={ canRemove ? onMerge : undefined }
105
106
  clientId={ clientId }
106
107
  isSelectionEnabled={ isSelectionEnabled }
107
108
  toggleSelection={ toggleSelection }
@@ -191,10 +192,15 @@ const applyWithSelect = withSelect( ( select, { clientId, rootClientId } ) => {
191
192
  isSelectionEnabled,
192
193
  getTemplateLock,
193
194
  __unstableGetBlockWithoutInnerBlocks,
195
+ canRemoveBlock,
196
+ canMoveBlock,
194
197
  } = select( blockEditorStore );
195
198
  const block = __unstableGetBlockWithoutInnerBlocks( clientId );
196
199
  const isSelected = isBlockSelected( clientId );
197
200
  const templateLock = getTemplateLock( rootClientId );
201
+ const canRemove = canRemoveBlock( clientId, rootClientId );
202
+ const canMove = canMoveBlock( clientId, rootClientId );
203
+
198
204
  // The fallback to `{}` is a temporary fix.
199
205
  // This function should never be called when a block is not present in
200
206
  // the state. It happens now because the order in withSelect rendering
@@ -207,6 +213,8 @@ const applyWithSelect = withSelect( ( select, { clientId, rootClientId } ) => {
207
213
  mode: getBlockMode( clientId ),
208
214
  isSelectionEnabled: isSelectionEnabled(),
209
215
  isLocked: !! templateLock,
216
+ canRemove,
217
+ canMove,
210
218
  // Users of the editor.BlockListBlock filter used to be able to
211
219
  // access the block prop.
212
220
  // Ideally these blocks would rely on the clientId prop only.