@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
@@ -2,11 +2,6 @@
2
2
  .block-editor-color-gradient-control__color-indicator {
3
3
  margin-bottom: $grid-unit-15;
4
4
  }
5
-
6
- .block-editor-color-gradient-control__button-tabs {
7
- display: block;
8
- margin-bottom: $grid-unit-15;
9
- }
10
5
  }
11
6
 
12
7
  .block-editor-panel-color-gradient-settings {
@@ -28,21 +23,18 @@
28
23
  // @wordpress/components/src/circular-option-picker/style.scss
29
24
  $swatch-size: 28px;
30
25
 
31
- // Optimize fit of six swatches per line using calc() to create variable
32
- // spacing that mimics a "justified/space-between" layout and works with
33
- // or without scrollbars
34
26
  @media screen and (min-width: $break-medium) {
35
- // Overrides the default negative margin
36
27
  .components-circular-option-picker__swatches {
37
- margin-right: 0;
38
- }
39
- // Figures the spacing
40
- .components-circular-option-picker__option-wrapper {
41
- margin-right: calc((100% - (#{$swatch-size} * 6)) / 5);
42
- }
43
- // Removes the right margin on every sixth swatch
44
- .components-circular-option-picker__option-wrapper:nth-child(6n + 6) {
45
- margin-right: 0;
28
+ display: grid;
29
+ grid-template-columns: repeat(6, $swatch-size);
30
+ justify-content: space-between;
46
31
  }
47
32
  }
33
+
34
+ // This shouldn't be needed but there's a rule in the inspector controls
35
+ // overriding this causing too much spacing.
36
+ // That generic rule should ideally be removed.
37
+ .block-editor-block-inspector & .components-base-control {
38
+ margin-bottom: inherit;
39
+ }
48
40
  }
@@ -1,6 +1,7 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
+ import { render, screen } from '@testing-library/react';
4
5
  import { create, act } from 'react-test-renderer';
5
6
  import { noop } from 'lodash';
6
7
 
@@ -9,85 +10,64 @@ import { noop } from 'lodash';
9
10
  */
10
11
  import ColorGradientControl from '../control';
11
12
 
12
- const getButtonWithTestPredicate = ( text ) => ( element ) => {
13
+ const getButtonWithAriaLabelStartPredicate = ( ariaLabelStart ) => (
14
+ element
15
+ ) => {
13
16
  return (
14
17
  element.type === 'button' &&
15
- element.children[ 0 ] === text &&
16
- element.children.length === 1
18
+ element.props[ 'aria-label' ] &&
19
+ element.props[ 'aria-label' ].startsWith( ariaLabelStart )
17
20
  );
18
21
  };
19
22
 
20
- const getButtonWithAriaLabelStartPredicate = ( ariaLabelStart ) => (
21
- element
22
- ) => {
23
+ const getTabWithTestPredicate = ( text ) => ( element ) => {
23
24
  return (
24
25
  element.type === 'button' &&
25
26
  element.props[ 'aria-label' ] &&
26
- element.props[ 'aria-label' ].startsWith( ariaLabelStart )
27
+ element.props[ 'aria-label' ] === text
27
28
  );
28
29
  };
29
30
 
30
- const colorTabButtonPredicate = getButtonWithTestPredicate( 'Solid' );
31
- const gradientTabButtonPredicate = getButtonWithTestPredicate( 'Gradient' );
31
+ const colorTabButtonPredicate = getTabWithTestPredicate( 'Solid' );
32
+ const gradientTabButtonPredicate = getTabWithTestPredicate( 'Gradient' );
32
33
 
33
34
  describe( 'ColorPaletteControl', () => {
34
35
  it( 'renders tabs if it is possible to select a color and a gradient rendering a color picker at the start', async () => {
35
- let wrapper;
36
-
37
- await act( async () => {
38
- wrapper = create(
39
- <ColorGradientControl
40
- label="Test Color Gradient"
41
- colorValue="#f00"
42
- colors={ [
43
- { color: '#f00', name: 'red' },
44
- { color: '#0f0', name: 'green' },
45
- ] }
46
- gradients={ [
47
- {
48
- gradient:
49
- 'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%',
50
- name: 'Vivid cyan blue to vivid purple',
51
- slug: 'vivid-cyan-blue-to-vivid-purple',
52
- },
53
- {
54
- gradient:
55
- 'linear-gradient(135deg,rgb(122,220,180) 0%,rgb(0,208,130) 100%)',
56
- name: 'Light green cyan to vivid green cyan',
57
- slug: 'light-green-cyan-to-vivid-green-cyan',
58
- },
59
- ] }
60
- disableCustomColors={ false }
61
- disableCustomGradients={ false }
62
- onColorChange={ noop }
63
- onGradientChange={ noop }
64
- />
65
- );
66
- } );
36
+ render(
37
+ <ColorGradientControl
38
+ label="Test Color Gradient"
39
+ colorValue="#f00"
40
+ colors={ [
41
+ { color: '#f00', name: 'red' },
42
+ { color: '#0f0', name: 'green' },
43
+ ] }
44
+ gradients={ [
45
+ {
46
+ gradient:
47
+ 'linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%',
48
+ name: 'Vivid cyan blue to vivid purple',
49
+ slug: 'vivid-cyan-blue-to-vivid-purple',
50
+ },
51
+ {
52
+ gradient:
53
+ 'linear-gradient(135deg,rgb(122,220,180) 0%,rgb(0,208,130) 100%)',
54
+ name: 'Light green cyan to vivid green cyan',
55
+ slug: 'light-green-cyan-to-vivid-green-cyan',
56
+ },
57
+ ] }
58
+ disableCustomColors={ false }
59
+ disableCustomGradients={ false }
60
+ onColorChange={ noop }
61
+ onGradientChange={ noop }
62
+ />
63
+ );
67
64
 
68
65
  // Is showing the two tab buttons.
69
- expect( wrapper.root.findAll( colorTabButtonPredicate ) ).toHaveLength(
70
- 1
71
- );
72
- expect(
73
- wrapper.root.findAll( gradientTabButtonPredicate )
74
- ).toHaveLength( 1 );
66
+ expect( screen.queryByLabelText( 'Solid' ) ).toBeInTheDocument();
67
+ expect( screen.queryByLabelText( 'Gradient' ) ).toBeInTheDocument();
75
68
 
76
69
  // Is showing the two predefined Colors.
77
- expect(
78
- wrapper.root.findAll(
79
- ( element ) =>
80
- element.type === 'button' &&
81
- element.props &&
82
- element.props[ 'aria-label' ] &&
83
- element.props[ 'aria-label' ].startsWith( 'Color:' )
84
- )
85
- ).toHaveLength( 2 );
86
-
87
- // Is showing the custom color picker.
88
- expect(
89
- wrapper.root.findAll( getButtonWithTestPredicate( 'Custom color' ) )
90
- ).toHaveLength( 1 );
70
+ expect( screen.getAllByLabelText( /^Color:/ ) ).toHaveLength( 2 );
91
71
  } );
92
72
 
93
73
  it( 'renders the color picker and does not render tabs if it is only possible to select a color', async () => {
@@ -125,11 +105,6 @@ describe( 'ColorPaletteControl', () => {
125
105
  getButtonWithAriaLabelStartPredicate( 'Color:' )
126
106
  )
127
107
  ).toHaveLength( 2 );
128
-
129
- // Is showing the custom color picker.
130
- expect(
131
- wrapper.root.findAll( getButtonWithTestPredicate( 'Custom color' ) )
132
- ).toHaveLength( 1 );
133
108
  } );
134
109
 
135
110
  it( 'renders the gradient picker and does not render tabs if it is only possible to select a gradient', async () => {
@@ -1,7 +1,9 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import tinycolor from 'tinycolor2';
4
+ import { colord, extend } from 'colord';
5
+ import namesPlugin from 'colord/plugins/names';
6
+ import a11yPlugin from 'colord/plugins/a11y';
5
7
 
6
8
  /**
7
9
  * WordPress dependencies
@@ -11,14 +13,16 @@ import { __ } from '@wordpress/i18n';
11
13
  import { Notice } from '@wordpress/components';
12
14
  import { useEffect } from '@wordpress/element';
13
15
 
16
+ extend( [ namesPlugin, a11yPlugin ] );
17
+
14
18
  function ContrastCheckerMessage( {
15
- tinyBackgroundColor,
16
- tinyTextColor,
19
+ colordBackgroundColor,
20
+ colordTextColor,
17
21
  backgroundColor,
18
22
  textColor,
19
23
  } ) {
20
24
  const msg =
21
- tinyBackgroundColor.getBrightness() < tinyTextColor.getBrightness()
25
+ colordBackgroundColor.brightness() < colordTextColor.brightness()
22
26
  ? __(
23
27
  'This color combination may be hard for people to read. Try using a darker background color and/or a brighter text color.'
24
28
  )
@@ -61,16 +65,16 @@ function ContrastChecker( {
61
65
  ) {
62
66
  return null;
63
67
  }
64
- const tinyBackgroundColor = tinycolor(
68
+ const colordBackgroundColor = colord(
65
69
  backgroundColor || fallbackBackgroundColor
66
70
  );
67
- const tinyTextColor = tinycolor( textColor || fallbackTextColor );
71
+ const colordTextColor = colord( textColor || fallbackTextColor );
68
72
  const hasTransparency =
69
- tinyBackgroundColor.getAlpha() !== 1 || tinyTextColor.getAlpha() !== 1;
73
+ colordBackgroundColor.alpha() !== 1 || colordTextColor.alpha() !== 1;
70
74
 
71
75
  if (
72
76
  hasTransparency ||
73
- tinycolor.isReadable( tinyBackgroundColor, tinyTextColor, {
77
+ colordTextColor.isReadable( colordBackgroundColor, {
74
78
  level: 'AA',
75
79
  size:
76
80
  isLargeText || ( isLargeText !== false && fontSize >= 24 )
@@ -85,8 +89,8 @@ function ContrastChecker( {
85
89
  <ContrastCheckerMessage
86
90
  backgroundColor={ backgroundColor }
87
91
  textColor={ textColor }
88
- tinyBackgroundColor={ tinyBackgroundColor }
89
- tinyTextColor={ tinyTextColor }
92
+ colordBackgroundColor={ colordBackgroundColor }
93
+ colordTextColor={ colordTextColor }
90
94
  />
91
95
  );
92
96
  }
@@ -31,7 +31,7 @@ export function useNotifyCopy() {
31
31
  let notice = '';
32
32
  if ( selectedBlockClientIds.length === 1 ) {
33
33
  const clientId = selectedBlockClientIds[ 0 ];
34
- const { title } = getBlockType( getBlockName( clientId ) );
34
+ const title = getBlockType( getBlockName( clientId ) )?.title;
35
35
  notice =
36
36
  eventType === 'copy'
37
37
  ? sprintf(
@@ -113,6 +113,7 @@ export function useClipboardHandler() {
113
113
  return;
114
114
  }
115
115
 
116
+ const eventDefaultPrevented = event.defaultPrevented;
116
117
  event.preventDefault();
117
118
 
118
119
  if ( event.type === 'copy' || event.type === 'cut' ) {
@@ -130,6 +131,10 @@ export function useClipboardHandler() {
130
131
  if ( event.type === 'cut' ) {
131
132
  removeBlocks( selectedBlockClientIds );
132
133
  } else if ( event.type === 'paste' ) {
134
+ if ( eventDefaultPrevented ) {
135
+ // This was likely already handled in rich-text/use-paste-handler.js
136
+ return;
137
+ }
133
138
  const {
134
139
  __experimentalCanUserUseUnfilteredHTML: canUserUseUnfilteredHTML,
135
140
  } = getSettings();
@@ -59,8 +59,8 @@ export function DefaultBlockAppender( {
59
59
  // eslint-disable-next-line jsx-a11y/no-noninteractive-element-to-interactive-role
60
60
  role="button"
61
61
  aria-label={ __( 'Add block' ) }
62
- // The wp-block className is important for editor styles.
63
- className="wp-block block-editor-default-block-appender__content"
62
+ // A wrapping container for this one already has the wp-block className.
63
+ className="block-editor-default-block-appender__content"
64
64
  onFocus={ onAppend }
65
65
  >
66
66
  { showPrompt ? value : ZWNBSP }
@@ -7,7 +7,7 @@ exports[`DefaultBlockAppender should append a default block when input focused 1
7
7
  >
8
8
  <p
9
9
  aria-label="Add block"
10
- className="wp-block block-editor-default-block-appender__content"
10
+ className="block-editor-default-block-appender__content"
11
11
  contentEditable={true}
12
12
  onFocus={
13
13
  [MockFunction] {
@@ -43,7 +43,7 @@ exports[`DefaultBlockAppender should match snapshot 1`] = `
43
43
  >
44
44
  <p
45
45
  aria-label="Add block"
46
- className="wp-block block-editor-default-block-appender__content"
46
+ className="block-editor-default-block-appender__content"
47
47
  contentEditable={true}
48
48
  onFocus={[MockFunction]}
49
49
  role="button"
@@ -67,7 +67,7 @@ exports[`DefaultBlockAppender should optionally show without prompt 1`] = `
67
67
  >
68
68
  <p
69
69
  aria-label="Add block"
70
- className="wp-block block-editor-default-block-appender__content"
70
+ className="block-editor-default-block-appender__content"
71
71
  contentEditable={true}
72
72
  onFocus={[MockFunction]}
73
73
  role="button"
@@ -1,16 +1,16 @@
1
1
  /**
2
2
  * WordPress dependencies
3
3
  */
4
- import { ToolbarButton, DuotoneSwatch } from '@wordpress/components';
5
- import { useState } from '@wordpress/element';
4
+ import {
5
+ Dropdown,
6
+ DuotonePicker,
7
+ DuotoneSwatch,
8
+ MenuGroup,
9
+ ToolbarButton,
10
+ } from '@wordpress/components';
6
11
  import { __ } from '@wordpress/i18n';
7
12
  import { DOWN } from '@wordpress/keycodes';
8
13
 
9
- /**
10
- * Internal dependencies
11
- */
12
- import DuotonePickerPopover from './duotone-picker-popover';
13
-
14
14
  function DuotoneControl( {
15
15
  colorPalette,
16
16
  duotonePalette,
@@ -19,42 +19,50 @@ function DuotoneControl( {
19
19
  value,
20
20
  onChange,
21
21
  } ) {
22
- const [ isOpen, setIsOpen ] = useState( false );
23
-
24
- const onToggle = () => {
25
- setIsOpen( ( prev ) => ! prev );
26
- };
27
-
28
- const openOnArrowDown = ( event ) => {
29
- if ( ! isOpen && event.keyCode === DOWN ) {
30
- event.preventDefault();
31
- onToggle();
32
- }
33
- };
34
-
35
22
  return (
36
- <>
37
- <ToolbarButton
38
- showTooltip
39
- onClick={ onToggle }
40
- aria-haspopup="true"
41
- aria-expanded={ isOpen }
42
- onKeyDown={ openOnArrowDown }
43
- label={ __( 'Apply duotone filter' ) }
44
- icon={ <DuotoneSwatch values={ value } /> }
45
- />
46
- { isOpen && (
47
- <DuotonePickerPopover
48
- value={ value }
49
- onChange={ onChange }
50
- onToggle={ onToggle }
51
- duotonePalette={ duotonePalette }
52
- colorPalette={ colorPalette }
53
- disableCustomColors={ disableCustomColors }
54
- disableCustomDuotone={ disableCustomDuotone }
55
- />
23
+ <Dropdown
24
+ popoverProps={ {
25
+ className: 'block-editor-duotone-control__popover',
26
+ headerTitle: __( 'Duotone' ),
27
+ isAlternate: true,
28
+ } }
29
+ renderToggle={ ( { isOpen, onToggle } ) => {
30
+ const openOnArrowDown = ( event ) => {
31
+ if ( ! isOpen && event.keyCode === DOWN ) {
32
+ event.preventDefault();
33
+ onToggle();
34
+ }
35
+ };
36
+ return (
37
+ <ToolbarButton
38
+ showTooltip
39
+ onClick={ onToggle }
40
+ aria-haspopup="true"
41
+ aria-expanded={ isOpen }
42
+ onKeyDown={ openOnArrowDown }
43
+ label={ __( 'Apply duotone filter' ) }
44
+ icon={ <DuotoneSwatch values={ value } /> }
45
+ />
46
+ );
47
+ } }
48
+ renderContent={ () => (
49
+ <MenuGroup label={ __( 'Duotone' ) }>
50
+ <div className="block-editor-duotone-control__description">
51
+ { __(
52
+ 'Create a two-tone color effect without losing your original image.'
53
+ ) }
54
+ </div>
55
+ <DuotonePicker
56
+ colorPalette={ colorPalette }
57
+ duotonePalette={ duotonePalette }
58
+ disableCustomColors={ disableCustomColors }
59
+ disableCustomDuotone={ disableCustomDuotone }
60
+ value={ value }
61
+ onChange={ onChange }
62
+ />
63
+ </MenuGroup>
56
64
  ) }
57
- </>
65
+ />
58
66
  );
59
67
  }
60
68
 
@@ -1,23 +1,38 @@
1
+ // Must equal $color-palette-circle-size and $color-palette-circle-spacing from:
2
+ // @wordpress/components/src/circular-option-picker/style.scss
3
+ $swatch-size: 28px;
4
+ $swatch-gap: 12px;
5
+
6
+ $popover-width: $sidebar-width;
7
+ $popover-padding: $grid-unit-20;
8
+
9
+ $swatch-columns: math.floor(math.div($popover-width + $swatch-gap - 2 * $popover-padding, $swatch-size + $swatch-gap));
10
+
1
11
  .block-editor-duotone-control__popover {
2
- .components-popover__content {
3
- border: $border-width solid $gray-900;
4
- min-width: 214px;
12
+ > .components-popover__content > div {
13
+ padding: $popover-padding;
14
+ width: $popover-width;
5
15
  }
6
16
 
7
- .components-circular-option-picker {
8
- padding: $grid-unit-15;
17
+ .components-menu-group__label {
18
+ padding: 0;
9
19
  }
10
20
 
11
- .components-menu-group__label {
12
- padding: $grid-unit-15 $grid-unit-15 0 $grid-unit-15;
13
- width: 100%;
14
- box-sizing: border-box;
21
+ .components-custom-gradient-picker__gradient-bar {
22
+ margin: $grid-unit-20 0 $grid-unit-15;
23
+ }
24
+
25
+ .components-circular-option-picker__swatches {
26
+ display: grid;
27
+ grid-template-columns: repeat($swatch-columns, $swatch-size);
28
+ gap: $swatch-gap;
29
+ justify-content: space-between;
15
30
  }
16
31
  }
17
32
 
18
- .block-editor-duotone-control__popover > .components-popover__content {
19
- // Matches 8 swatches in width.
20
- width: 334px;
33
+ .block-editor-duotone-control__description {
34
+ margin: $grid-unit-20 0;
35
+ font-size: $helptext-font-size;
21
36
  }
22
37
 
23
38
  // Better align the popover under the swatch.
@@ -1,7 +1,9 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import tinycolor from 'tinycolor2';
4
+ import { colord, extend } from 'colord';
5
+ import namesPlugin from 'colord/plugins/names';
6
+ import a11yPlugin from 'colord/plugins/a11y';
5
7
 
6
8
  /**
7
9
  * WordPress dependencies
@@ -14,6 +16,7 @@ import { useCallback, useMemo } from '@wordpress/element';
14
16
  import transformStyles from '../../utils/transform-styles';
15
17
 
16
18
  const EDITOR_STYLES_SELECTOR = '.editor-styles-wrapper';
19
+ extend( [ namesPlugin, a11yPlugin ] );
17
20
 
18
21
  function useDarkThemeBodyClassName( styles ) {
19
22
  return useCallback(
@@ -48,11 +51,11 @@ function useDarkThemeBodyClassName( styles ) {
48
51
  .getComputedStyle( canvas, null )
49
52
  .getPropertyValue( 'background-color' );
50
53
  }
51
-
54
+ const colordBackgroundColor = colord( backgroundColor );
52
55
  // If background is transparent, it should be treated as light color.
53
56
  if (
54
- tinycolor( backgroundColor ).getLuminance() > 0.5 ||
55
- tinycolor( backgroundColor ).getAlpha() === 0
57
+ colordBackgroundColor.luminance() > 0.5 ||
58
+ colordBackgroundColor.alpha() === 0
56
59
  ) {
57
60
  body.classList.remove( 'is-dark-theme' );
58
61
  } else {
@@ -55,6 +55,26 @@ const FONT_WEIGHTS = [
55
55
  },
56
56
  ];
57
57
 
58
+ /**
59
+ * Adjusts font appearance field label in case either font styles or weights
60
+ * are disabled.
61
+ *
62
+ * @param {boolean} hasFontStyles Whether font styles are enabled and present.
63
+ * @param {boolean} hasFontWeights Whether font weights are enabled and present.
64
+ * @return {string} A label representing what font appearance is being edited.
65
+ */
66
+ export const getFontAppearanceLabel = ( hasFontStyles, hasFontWeights ) => {
67
+ if ( ! hasFontStyles ) {
68
+ return __( 'Font weight' );
69
+ }
70
+
71
+ if ( ! hasFontWeights ) {
72
+ return __( 'Font style' );
73
+ }
74
+
75
+ return __( 'Appearance' );
76
+ };
77
+
58
78
  /**
59
79
  * Control to display unified font style and weight options.
60
80
  *
@@ -70,6 +90,7 @@ export default function FontAppearanceControl( props ) {
70
90
  value: { fontStyle, fontWeight },
71
91
  } = props;
72
92
  const hasStylesOrWeights = hasFontStyles || hasFontWeights;
93
+ const label = getFontAppearanceLabel( hasFontStyles, hasFontWeights );
73
94
  const defaultOption = {
74
95
  key: 'default',
75
96
  name: __( 'Default' ),
@@ -143,25 +164,14 @@ export default function FontAppearanceControl( props ) {
143
164
  return hasFontStyles ? styleOptions() : weightOptions();
144
165
  }, [ props.options ] );
145
166
 
146
- // Find current selection by comparing font style & weight against options.
147
- const currentSelection = selectOptions.find(
148
- ( option ) =>
149
- option.style.fontStyle === fontStyle &&
150
- option.style.fontWeight === fontWeight
151
- );
152
-
153
- // Adjusts field label in case either styles or weights are disabled.
154
- const getLabel = () => {
155
- if ( ! hasFontStyles ) {
156
- return __( 'Font weight' );
157
- }
158
-
159
- if ( ! hasFontWeights ) {
160
- return __( 'Font style' );
161
- }
162
-
163
- return __( 'Appearance' );
164
- };
167
+ // Find current selection by comparing font style & weight against options,
168
+ // and fall back to the Default option if there is no matching option.
169
+ const currentSelection =
170
+ selectOptions.find(
171
+ ( option ) =>
172
+ option.style.fontStyle === fontStyle &&
173
+ option.style.fontWeight === fontWeight
174
+ ) || selectOptions[ 0 ];
165
175
 
166
176
  // Adjusts screen reader description based on styles or weights.
167
177
  const getDescribedBy = () => {
@@ -193,19 +203,17 @@ export default function FontAppearanceControl( props ) {
193
203
  };
194
204
 
195
205
  return (
196
- <fieldset className="components-font-appearance-control">
197
- { hasStylesOrWeights && (
198
- <CustomSelectControl
199
- className="components-font-appearance-control__select"
200
- label={ getLabel() }
201
- describedBy={ getDescribedBy() }
202
- options={ selectOptions }
203
- value={ currentSelection }
204
- onChange={ ( { selectedItem } ) =>
205
- onChange( selectedItem.style )
206
- }
207
- />
208
- ) }
209
- </fieldset>
206
+ hasStylesOrWeights && (
207
+ <CustomSelectControl
208
+ className="components-font-appearance-control"
209
+ label={ label }
210
+ describedBy={ getDescribedBy() }
211
+ options={ selectOptions }
212
+ value={ currentSelection }
213
+ onChange={ ( { selectedItem } ) =>
214
+ onChange( selectedItem.style )
215
+ }
216
+ />
217
+ )
210
218
  );
211
219
  }
@@ -1,4 +1,4 @@
1
- .components-font-appearance-control__select {
1
+ .components-font-appearance-control {
2
2
  margin-bottom: 24px;
3
3
 
4
4
  ul {
@@ -76,7 +76,7 @@ function styleSheetsCompat( doc ) {
76
76
 
77
77
  if ( isMatch && ! doc.getElementById( ownerNode.id ) ) {
78
78
  // eslint-disable-next-line no-console
79
- console.error(
79
+ console.warn(
80
80
  `Stylesheet ${ ownerNode.id } was not properly added.
81
81
  For blocks, use the block API's style (https://developer.wordpress.org/block-editor/reference-guides/block-api/block-metadata/#style) or editorStyle (https://developer.wordpress.org/block-editor/reference-guides/block-api/block-metadata/#editor-style).
82
82
  For themes, use add_editor_style (https://developer.wordpress.org/block-editor/how-to-guides/themes/theme-support/#editor-styles).`,
@@ -134,7 +134,7 @@ function bubbleEvents( doc ) {
134
134
  }
135
135
  }
136
136
 
137
- const eventTypes = [ 'keydown', 'keypress', 'dragover' ];
137
+ const eventTypes = [ 'dragover' ];
138
138
 
139
139
  for ( const name of eventTypes ) {
140
140
  doc.addEventListener( name, bubbleEvent );
@@ -168,8 +168,8 @@ function Iframe( { contentRef, children, head, tabIndex = 0, ...props }, ref ) {
168
168
  const [ , forceRender ] = useReducer( () => ( {} ) );
169
169
  const [ iframeDocument, setIframeDocument ] = useState();
170
170
  const [ bodyClasses, setBodyClasses ] = useState( [] );
171
- const styles = useParsedAssets( window.__editorAssets.styles );
172
- const scripts = useParsedAssets( window.__editorAssets.scripts );
171
+ const styles = useParsedAssets( window.__editorAssets?.styles );
172
+ const scripts = useParsedAssets( window.__editorAssets?.scripts );
173
173
  const clearerRef = useBlockSelectionClearer();
174
174
  const [ before, writingFlowRef, after ] = useWritingFlow();
175
175
  const setRef = useRefEffect( ( node ) => {