@wordpress/block-editor 12.0.0 → 12.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (311) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/README.md +1 -1
  3. package/build/components/block-controls/slot.js +12 -4
  4. package/build/components/block-controls/slot.js.map +1 -1
  5. package/build/components/block-controls/slot.native.js +10 -1
  6. package/build/components/block-controls/slot.native.js.map +1 -1
  7. package/build/components/block-draggable/index.js +11 -7
  8. package/build/components/block-draggable/index.js.map +1 -1
  9. package/build/components/block-draggable/use-scroll-when-dragging.js +2 -2
  10. package/build/components/block-draggable/use-scroll-when-dragging.js.map +1 -1
  11. package/build/components/block-list/block-invalid-warning.native.js +15 -7
  12. package/build/components/block-list/block-invalid-warning.native.js.map +1 -1
  13. package/build/components/block-list/block-list-item-cell.native.js +15 -2
  14. package/build/components/block-list/block-list-item-cell.native.js.map +1 -1
  15. package/build/components/block-list/block-list-item.native.js +158 -195
  16. package/build/components/block-list/block-list-item.native.js.map +1 -1
  17. package/build/components/block-list/block-outline.native.js +57 -0
  18. package/build/components/block-list/block-outline.native.js.map +1 -0
  19. package/build/components/block-list/block.native.js +343 -299
  20. package/build/components/block-list/block.native.js.map +1 -1
  21. package/build/components/block-list/index.native.js +202 -298
  22. package/build/components/block-list/index.native.js.map +1 -1
  23. package/build/components/block-list/insertion-point.native.js +4 -2
  24. package/build/components/block-list/insertion-point.native.js.map +1 -1
  25. package/build/components/block-mobile-toolbar/block-actions-menu.native.js +1 -1
  26. package/build/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
  27. package/build/components/block-settings-menu/block-settings-dropdown.js +8 -10
  28. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  29. package/build/components/block-settings-menu-controls/index.js +15 -4
  30. package/build/components/block-settings-menu-controls/index.js.map +1 -1
  31. package/build/components/block-tools/block-contextual-toolbar.js +17 -62
  32. package/build/components/block-tools/block-contextual-toolbar.js.map +1 -1
  33. package/build/components/block-tools/selected-block-popover.js +3 -8
  34. package/build/components/block-tools/selected-block-popover.js.map +1 -1
  35. package/build/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +3 -2
  36. package/build/components/colors-gradients/use-multiple-origin-colors-and-gradients.js.map +1 -1
  37. package/build/components/global-styles/advanced-panel.js +86 -0
  38. package/build/components/global-styles/advanced-panel.js.map +1 -0
  39. package/build/components/global-styles/color-panel.js +4 -1
  40. package/build/components/global-styles/color-panel.js.map +1 -1
  41. package/build/components/global-styles/dimensions-panel.js +6 -6
  42. package/build/components/global-styles/dimensions-panel.js.map +1 -1
  43. package/build/components/global-styles/hooks.js +1 -2
  44. package/build/components/global-styles/hooks.js.map +1 -1
  45. package/build/components/global-styles/index.js +24 -0
  46. package/build/components/global-styles/index.js.map +1 -1
  47. package/build/components/global-styles/typography-panel.js +1 -1
  48. package/build/components/global-styles/typography-panel.js.map +1 -1
  49. package/build/components/global-styles/use-global-styles-output.js +27 -4
  50. package/build/components/global-styles/use-global-styles-output.js.map +1 -1
  51. package/build/components/global-styles/utils.js +30 -0
  52. package/build/components/global-styles/utils.js.map +1 -1
  53. package/build/components/image-editor/use-save-image.js +24 -8
  54. package/build/components/image-editor/use-save-image.js.map +1 -1
  55. package/build/components/inserter-draggable-blocks/index.js +5 -0
  56. package/build/components/inserter-draggable-blocks/index.js.map +1 -1
  57. package/build/components/inspector-controls/fill.js +1 -1
  58. package/build/components/inspector-controls/fill.js.map +1 -1
  59. package/build/components/inspector-controls/fill.native.js +1 -1
  60. package/build/components/inspector-controls/fill.native.js.map +1 -1
  61. package/build/components/inspector-controls/slot.js +3 -6
  62. package/build/components/inspector-controls/slot.js.map +1 -1
  63. package/build/components/inspector-controls/slot.native.js +1 -1
  64. package/build/components/inspector-controls/slot.native.js.map +1 -1
  65. package/build/components/line-height-control/index.js +7 -2
  66. package/build/components/line-height-control/index.js.map +1 -1
  67. package/build/components/link-control/use-internal-input-value.js +9 -8
  68. package/build/components/link-control/use-internal-input-value.js.map +1 -1
  69. package/build/components/list-view/block-contents.js +7 -2
  70. package/build/components/list-view/block-contents.js.map +1 -1
  71. package/build/components/list-view/block-select-button.js +2 -1
  72. package/build/components/list-view/block-select-button.js.map +1 -1
  73. package/build/components/list-view/block.js +4 -4
  74. package/build/components/list-view/block.js.map +1 -1
  75. package/build/components/list-view/index.js +32 -18
  76. package/build/components/list-view/index.js.map +1 -1
  77. package/build/components/list-view/use-list-view-drop-zone.js +163 -11
  78. package/build/components/list-view/use-list-view-drop-zone.js.map +1 -1
  79. package/build/components/media-placeholder/index.js +68 -7
  80. package/build/components/media-placeholder/index.js.map +1 -1
  81. package/build/components/multi-selection-inspector/index.js +2 -2
  82. package/build/components/multi-selection-inspector/index.js.map +1 -1
  83. package/build/components/off-canvas-editor/leaf-more-menu.js +3 -1
  84. package/build/components/off-canvas-editor/leaf-more-menu.js.map +1 -1
  85. package/build/components/preview-options/index.js +6 -1
  86. package/build/components/preview-options/index.js.map +1 -1
  87. package/build/components/spacing-sizes-control/spacing-input-control.js +1 -1
  88. package/build/components/spacing-sizes-control/spacing-input-control.js.map +1 -1
  89. package/build/components/url-input/index.js +1 -2
  90. package/build/components/url-input/index.js.map +1 -1
  91. package/build/hooks/align.js +1 -1
  92. package/build/hooks/align.js.map +1 -1
  93. package/build/hooks/border.js +1 -1
  94. package/build/hooks/border.js.map +1 -1
  95. package/build/hooks/color.js +1 -1
  96. package/build/hooks/color.js.map +1 -1
  97. package/build/hooks/content-lock-ui.js +8 -12
  98. package/build/hooks/content-lock-ui.js.map +1 -1
  99. package/build/hooks/duotone.js +1 -1
  100. package/build/hooks/duotone.js.map +1 -1
  101. package/build/hooks/index.native.js +8 -0
  102. package/build/hooks/index.native.js.map +1 -1
  103. package/build/hooks/layout.js +2 -2
  104. package/build/hooks/layout.js.map +1 -1
  105. package/build/hooks/position.js +1 -1
  106. package/build/hooks/position.js.map +1 -1
  107. package/build/hooks/style.js +1 -1
  108. package/build/hooks/style.js.map +1 -1
  109. package/build/hooks/use-editor-wrapper-styles.native.js +255 -0
  110. package/build/hooks/use-editor-wrapper-styles.native.js.map +1 -0
  111. package/build/hooks/use-typography-props.js +14 -10
  112. package/build/hooks/use-typography-props.js.map +1 -1
  113. package/build/index.native.js +31 -0
  114. package/build/index.native.js.map +1 -0
  115. package/build/utils/use-should-contextual-toolbar-show.js +16 -12
  116. package/build/utils/use-should-contextual-toolbar-show.js.map +1 -1
  117. package/build-module/components/block-controls/slot.js +11 -4
  118. package/build-module/components/block-controls/slot.js.map +1 -1
  119. package/build-module/components/block-controls/slot.native.js +9 -1
  120. package/build-module/components/block-controls/slot.native.js.map +1 -1
  121. package/build-module/components/block-draggable/index.js +10 -6
  122. package/build-module/components/block-draggable/index.js.map +1 -1
  123. package/build-module/components/block-draggable/use-scroll-when-dragging.js +2 -2
  124. package/build-module/components/block-draggable/use-scroll-when-dragging.js.map +1 -1
  125. package/build-module/components/block-list/block-invalid-warning.native.js +16 -8
  126. package/build-module/components/block-list/block-invalid-warning.native.js.map +1 -1
  127. package/build-module/components/block-list/block-list-item-cell.native.js +13 -2
  128. package/build-module/components/block-list/block-list-item-cell.native.js.map +1 -1
  129. package/build-module/components/block-list/block-list-item.native.js +160 -190
  130. package/build-module/components/block-list/block-list-item.native.js.map +1 -1
  131. package/build-module/components/block-list/block-outline.native.js +44 -0
  132. package/build-module/components/block-list/block-outline.native.js.map +1 -0
  133. package/build-module/components/block-list/block.native.js +341 -298
  134. package/build-module/components/block-list/block.native.js.map +1 -1
  135. package/build-module/components/block-list/index.native.js +203 -293
  136. package/build-module/components/block-list/index.native.js.map +1 -1
  137. package/build-module/components/block-list/insertion-point.native.js +4 -2
  138. package/build-module/components/block-list/insertion-point.native.js.map +1 -1
  139. package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js +1 -1
  140. package/build-module/components/block-mobile-toolbar/block-actions-menu.native.js.map +1 -1
  141. package/build-module/components/block-settings-menu/block-settings-dropdown.js +8 -9
  142. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  143. package/build-module/components/block-settings-menu-controls/index.js +13 -5
  144. package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
  145. package/build-module/components/block-tools/block-contextual-toolbar.js +18 -62
  146. package/build-module/components/block-tools/block-contextual-toolbar.js.map +1 -1
  147. package/build-module/components/block-tools/selected-block-popover.js +3 -7
  148. package/build-module/components/block-tools/selected-block-popover.js.map +1 -1
  149. package/build-module/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +3 -2
  150. package/build-module/components/colors-gradients/use-multiple-origin-colors-and-gradients.js.map +1 -1
  151. package/build-module/components/global-styles/advanced-panel.js +74 -0
  152. package/build-module/components/global-styles/advanced-panel.js.map +1 -0
  153. package/build-module/components/global-styles/color-panel.js +5 -2
  154. package/build-module/components/global-styles/color-panel.js.map +1 -1
  155. package/build-module/components/global-styles/dimensions-panel.js +6 -6
  156. package/build-module/components/global-styles/dimensions-panel.js.map +1 -1
  157. package/build-module/components/global-styles/hooks.js +1 -2
  158. package/build-module/components/global-styles/hooks.js.map +1 -1
  159. package/build-module/components/global-styles/index.js +3 -1
  160. package/build-module/components/global-styles/index.js.map +1 -1
  161. package/build-module/components/global-styles/typography-panel.js +1 -1
  162. package/build-module/components/global-styles/typography-panel.js.map +1 -1
  163. package/build-module/components/global-styles/use-global-styles-output.js +25 -4
  164. package/build-module/components/global-styles/use-global-styles-output.js.map +1 -1
  165. package/build-module/components/global-styles/utils.js +25 -0
  166. package/build-module/components/global-styles/utils.js.map +1 -1
  167. package/build-module/components/image-editor/use-save-image.js +24 -8
  168. package/build-module/components/image-editor/use-save-image.js.map +1 -1
  169. package/build-module/components/inserter-draggable-blocks/index.js +4 -0
  170. package/build-module/components/inserter-draggable-blocks/index.js.map +1 -1
  171. package/build-module/components/inspector-controls/fill.js +1 -1
  172. package/build-module/components/inspector-controls/fill.js.map +1 -1
  173. package/build-module/components/inspector-controls/fill.native.js +1 -1
  174. package/build-module/components/inspector-controls/fill.native.js.map +1 -1
  175. package/build-module/components/inspector-controls/slot.js +4 -7
  176. package/build-module/components/inspector-controls/slot.js.map +1 -1
  177. package/build-module/components/inspector-controls/slot.native.js +1 -1
  178. package/build-module/components/inspector-controls/slot.native.js.map +1 -1
  179. package/build-module/components/line-height-control/index.js +7 -2
  180. package/build-module/components/line-height-control/index.js.map +1 -1
  181. package/build-module/components/link-control/use-internal-input-value.js +9 -8
  182. package/build-module/components/link-control/use-internal-input-value.js.map +1 -1
  183. package/build-module/components/list-view/block-contents.js +7 -3
  184. package/build-module/components/list-view/block-contents.js.map +1 -1
  185. package/build-module/components/list-view/block-select-button.js +2 -1
  186. package/build-module/components/list-view/block-select-button.js.map +1 -1
  187. package/build-module/components/list-view/block.js +4 -4
  188. package/build-module/components/list-view/block.js.map +1 -1
  189. package/build-module/components/list-view/index.js +32 -18
  190. package/build-module/components/list-view/index.js.map +1 -1
  191. package/build-module/components/list-view/use-list-view-drop-zone.js +160 -11
  192. package/build-module/components/list-view/use-list-view-drop-zone.js.map +1 -1
  193. package/build-module/components/media-placeholder/index.js +66 -7
  194. package/build-module/components/media-placeholder/index.js.map +1 -1
  195. package/build-module/components/multi-selection-inspector/index.js +2 -2
  196. package/build-module/components/multi-selection-inspector/index.js.map +1 -1
  197. package/build-module/components/off-canvas-editor/leaf-more-menu.js +3 -1
  198. package/build-module/components/off-canvas-editor/leaf-more-menu.js.map +1 -1
  199. package/build-module/components/preview-options/index.js +7 -2
  200. package/build-module/components/preview-options/index.js.map +1 -1
  201. package/build-module/components/spacing-sizes-control/spacing-input-control.js +1 -1
  202. package/build-module/components/spacing-sizes-control/spacing-input-control.js.map +1 -1
  203. package/build-module/components/url-input/index.js +1 -2
  204. package/build-module/components/url-input/index.js.map +1 -1
  205. package/build-module/hooks/align.js +1 -1
  206. package/build-module/hooks/align.js.map +1 -1
  207. package/build-module/hooks/border.js +1 -1
  208. package/build-module/hooks/border.js.map +1 -1
  209. package/build-module/hooks/color.js +1 -1
  210. package/build-module/hooks/color.js.map +1 -1
  211. package/build-module/hooks/content-lock-ui.js +8 -11
  212. package/build-module/hooks/content-lock-ui.js.map +1 -1
  213. package/build-module/hooks/duotone.js +1 -1
  214. package/build-module/hooks/duotone.js.map +1 -1
  215. package/build-module/hooks/index.native.js +1 -0
  216. package/build-module/hooks/index.native.js.map +1 -1
  217. package/build-module/hooks/layout.js +2 -2
  218. package/build-module/hooks/layout.js.map +1 -1
  219. package/build-module/hooks/position.js +1 -1
  220. package/build-module/hooks/position.js.map +1 -1
  221. package/build-module/hooks/style.js +1 -1
  222. package/build-module/hooks/style.js.map +1 -1
  223. package/build-module/hooks/use-editor-wrapper-styles.native.js +242 -0
  224. package/build-module/hooks/use-editor-wrapper-styles.native.js.map +1 -0
  225. package/build-module/hooks/use-typography-props.js +14 -10
  226. package/build-module/hooks/use-typography-props.js.map +1 -1
  227. package/build-module/index.native.js +6 -0
  228. package/build-module/index.native.js.map +1 -0
  229. package/build-module/utils/use-should-contextual-toolbar-show.js +16 -12
  230. package/build-module/utils/use-should-contextual-toolbar-show.js.map +1 -1
  231. package/build-style/content-rtl.css +0 -1
  232. package/build-style/content.css +0 -1
  233. package/build-style/style-rtl.css +37 -13
  234. package/build-style/style.css +37 -13
  235. package/package.json +31 -31
  236. package/src/components/block-breadcrumb/style.scss +2 -1
  237. package/src/components/block-controls/slot.js +8 -4
  238. package/src/components/block-controls/slot.native.js +6 -1
  239. package/src/components/block-draggable/index.js +10 -6
  240. package/src/components/block-draggable/use-scroll-when-dragging.js +8 -2
  241. package/src/components/block-list/block-invalid-warning.native.js +17 -9
  242. package/src/components/block-list/block-list-item-cell.native.js +10 -1
  243. package/src/components/block-list/block-list-item.native.js +180 -208
  244. package/src/components/block-list/block-outline.native.js +58 -0
  245. package/src/components/block-list/block.native.js +564 -523
  246. package/src/components/block-list/content.scss +0 -1
  247. package/src/components/block-list/index.native.js +229 -298
  248. package/src/components/block-list/insertion-point.native.js +2 -2
  249. package/src/components/block-list/test/block-invalid-warning.native.js +48 -0
  250. package/src/components/block-list/test/index.native.js +205 -0
  251. package/src/components/block-mobile-toolbar/block-actions-menu.native.js +3 -1
  252. package/src/components/block-pattern-setup/style.scss +1 -4
  253. package/src/components/block-patterns-list/style.scss +1 -4
  254. package/src/components/block-settings-menu/block-settings-dropdown.js +10 -17
  255. package/src/components/block-settings-menu-controls/index.js +24 -4
  256. package/src/components/block-styles/style.scss +4 -4
  257. package/src/components/block-tools/block-contextual-toolbar.js +28 -62
  258. package/src/components/block-tools/selected-block-popover.js +3 -5
  259. package/src/components/block-tools/style.scss +8 -0
  260. package/src/components/colors-gradients/use-multiple-origin-colors-and-gradients.js +16 -2
  261. package/src/components/global-styles/advanced-panel.js +82 -0
  262. package/src/components/global-styles/color-panel.js +6 -1
  263. package/src/components/global-styles/dimensions-panel.js +6 -6
  264. package/src/components/global-styles/hooks.js +1 -5
  265. package/src/components/global-styles/index.js +6 -1
  266. package/src/components/global-styles/style.scss +14 -0
  267. package/src/components/global-styles/test/utils.js +57 -1
  268. package/src/components/global-styles/typography-panel.js +1 -1
  269. package/src/components/global-styles/use-global-styles-output.js +21 -3
  270. package/src/components/global-styles/utils.js +27 -0
  271. package/src/components/image-editor/use-save-image.js +20 -9
  272. package/src/components/inserter-draggable-blocks/index.js +4 -0
  273. package/src/components/inspector-controls/fill.js +1 -1
  274. package/src/components/inspector-controls/fill.native.js +1 -1
  275. package/src/components/inspector-controls/slot.js +4 -9
  276. package/src/components/inspector-controls/slot.native.js +1 -1
  277. package/src/components/line-height-control/index.js +7 -2
  278. package/src/components/line-height-control/stories/index.js +1 -1
  279. package/src/components/link-control/test/index.js +42 -0
  280. package/src/components/link-control/use-internal-input-value.js +8 -7
  281. package/src/components/list-view/block-contents.js +26 -20
  282. package/src/components/list-view/block-select-button.js +5 -1
  283. package/src/components/list-view/block.js +5 -2
  284. package/src/components/list-view/index.js +26 -14
  285. package/src/components/list-view/style.scss +5 -2
  286. package/src/components/list-view/test/use-list-view-drop-zone.js +88 -12
  287. package/src/components/list-view/use-list-view-drop-zone.js +194 -11
  288. package/src/components/media-placeholder/index.js +74 -1
  289. package/src/components/multi-selection-inspector/index.js +2 -2
  290. package/src/components/off-canvas-editor/leaf-more-menu.js +2 -1
  291. package/src/components/preview-options/index.js +9 -2
  292. package/src/components/spacing-sizes-control/spacing-input-control.js +1 -0
  293. package/src/components/url-input/index.js +1 -2
  294. package/src/hooks/align.js +2 -1
  295. package/src/hooks/border.js +2 -1
  296. package/src/hooks/color.js +2 -1
  297. package/src/hooks/content-lock-ui.js +3 -15
  298. package/src/hooks/duotone.js +1 -0
  299. package/src/hooks/index.native.js +1 -0
  300. package/src/hooks/layout.js +4 -2
  301. package/src/hooks/position.js +2 -1
  302. package/src/hooks/style.js +2 -1
  303. package/src/hooks/test/use-editor-wrapper-styles.native.js +282 -0
  304. package/src/hooks/test/use-typography-props.js +47 -2
  305. package/src/hooks/use-editor-wrapper-styles.native.js +250 -0
  306. package/src/hooks/use-editor-wrapper-styles.native.scss +11 -0
  307. package/src/hooks/use-typography-props.js +10 -11
  308. package/src/index.native.js +6 -0
  309. package/src/utils/use-should-contextual-toolbar-show.js +19 -9
  310. package/tsconfig.json +1 -0
  311. package/tsconfig.tsbuildinfo +1 -1
@@ -9,7 +9,7 @@ import classnames from 'classnames';
9
9
  import { useViewportMatch } from '@wordpress/compose';
10
10
  import { DropdownMenu, MenuGroup, MenuItem } from '@wordpress/components';
11
11
  import { __ } from '@wordpress/i18n';
12
- import { check } from '@wordpress/icons';
12
+ import { check, desktop, mobile, tablet } from '@wordpress/icons';
13
13
 
14
14
  export default function PreviewOptions( {
15
15
  children,
@@ -38,13 +38,20 @@ export default function PreviewOptions( {
38
38
  const menuProps = {
39
39
  'aria-label': __( 'View options' ),
40
40
  };
41
+
42
+ const deviceIcons = {
43
+ mobile,
44
+ tablet,
45
+ desktop,
46
+ };
47
+
41
48
  return (
42
49
  <DropdownMenu
43
50
  className="block-editor-post-preview__dropdown"
44
51
  popoverProps={ popoverProps }
45
52
  toggleProps={ toggleProps }
46
53
  menuProps={ menuProps }
47
- icon={ null }
54
+ icon={ deviceIcons[ deviceType.toLowerCase() ] }
48
55
  >
49
56
  { () => (
50
57
  <>
@@ -74,6 +74,7 @@ export default function SpacingInputControl( {
74
74
 
75
75
  const previousValue = usePrevious( value );
76
76
  if (
77
+ !! value &&
77
78
  previousValue !== value &&
78
79
  ! isValueSpacingPreset( value ) &&
79
80
  showCustomValueControl !== true
@@ -309,11 +309,10 @@ class URLInput extends Component {
309
309
 
310
310
  // Submitting while loading should trigger onSubmit.
311
311
  case ENTER: {
312
- event.preventDefault();
313
312
  if ( this.props.onSubmit ) {
313
+ event.preventDefault();
314
314
  this.props.onSubmit( null, event );
315
315
  }
316
-
317
316
  break;
318
317
  }
319
318
  }
@@ -205,7 +205,8 @@ export const withDataAlign = createHigherOrderComponent(
205
205
  }
206
206
 
207
207
  return <BlockListBlock { ...props } wrapperProps={ wrapperProps } />;
208
- }
208
+ },
209
+ 'withDataAlign'
209
210
  );
210
211
 
211
212
  /**
@@ -388,7 +388,8 @@ export const withBorderColorPaletteStyles = createHigherOrderComponent(
388
388
  };
389
389
 
390
390
  return <BlockListBlock { ...props } wrapperProps={ wrapperProps } />;
391
- }
391
+ },
392
+ 'withBorderColorPaletteStyles'
392
393
  );
393
394
 
394
395
  addFilter(
@@ -416,7 +416,8 @@ export const withColorPaletteStyles = createHigherOrderComponent(
416
416
  };
417
417
 
418
418
  return <BlockListBlock { ...props } wrapperProps={ wrapperProps } />;
419
- }
419
+ },
420
+ 'withColorPaletteStyles'
420
421
  );
421
422
 
422
423
  const MIGRATION_PATHS = {
@@ -13,10 +13,6 @@ import { useEffect, useRef, useCallback } from '@wordpress/element';
13
13
  */
14
14
  import { store as blockEditorStore } from '../store';
15
15
  import { BlockControls, BlockSettingsMenuControls } from '../components';
16
- /**
17
- * External dependencies
18
- */
19
- import classnames from 'classnames';
20
16
 
21
17
  function StopEditingAsBlocksOnOutsideSelect( {
22
18
  clientId,
@@ -37,7 +33,7 @@ function StopEditingAsBlocksOnOutsideSelect( {
37
33
  if ( ! isBlockOrDescendantSelected ) {
38
34
  stopEditingAsBlock();
39
35
  }
40
- }, [ isBlockOrDescendantSelected ] );
36
+ }, [ isBlockOrDescendantSelected, stopEditingAsBlock ] );
41
37
  return null;
42
38
  }
43
39
 
@@ -91,7 +87,6 @@ export const withBlockControls = createHigherOrderComponent(
91
87
  __unstableSetTemporarilyEditingAsBlocks();
92
88
  }, [
93
89
  props.clientId,
94
- focusModeToRevert,
95
90
  updateSettings,
96
91
  updateBlockListSettings,
97
92
  getBlockListSettings,
@@ -101,7 +96,7 @@ export const withBlockControls = createHigherOrderComponent(
101
96
  ] );
102
97
 
103
98
  if ( ! isContentLocked && ! isEditingAsBlocks ) {
104
- return <BlockEdit { ...props } />;
99
+ return <BlockEdit key="edit" { ...props } />;
105
100
  }
106
101
 
107
102
  const showStopEditingAsBlocks = isEditingAsBlocks && ! isContentLocked;
@@ -156,14 +151,7 @@ export const withBlockControls = createHigherOrderComponent(
156
151
  ) }
157
152
  </BlockSettingsMenuControls>
158
153
  ) }
159
- <BlockEdit
160
- { ...props }
161
- className={ classnames(
162
- props.className,
163
- isEditingAsBlocks &&
164
- 'is-content-locked-editing-as-blocks'
165
- ) }
166
- />
154
+ <BlockEdit key="edit" { ...props } />
167
155
  </>
168
156
  );
169
157
  },
@@ -142,6 +142,7 @@ function DuotonePanel( { attributes, setAttributes, name } ) {
142
142
  value={ { filter: { duotone: duotonePresetOrColors } } }
143
143
  onChange={ ( newDuotone ) => {
144
144
  const newStyle = {
145
+ ...style,
145
146
  color: {
146
147
  ...newDuotone?.filter,
147
148
  },
@@ -15,3 +15,4 @@ export { getBorderClassesAndStyles, useBorderProps } from './use-border-props';
15
15
  export { getColorClassesAndStyles, useColorProps } from './use-color-props';
16
16
  export { getSpacingClassesAndStyles } from './use-spacing-props';
17
17
  export { useCachedTruthy } from './use-cached-truthy';
18
+ export { useEditorWrapperStyles } from './use-editor-wrapper-styles';
@@ -429,7 +429,8 @@ export const withLayoutStyles = createHigherOrderComponent(
429
429
  />
430
430
  </>
431
431
  );
432
- }
432
+ },
433
+ 'withLayoutStyles'
433
434
  );
434
435
 
435
436
  /**
@@ -484,7 +485,8 @@ export const withChildLayoutStyles = createHigherOrderComponent(
484
485
  <BlockListBlock { ...props } className={ className } />
485
486
  </>
486
487
  );
487
- }
488
+ },
489
+ 'withChildLayoutStyles'
488
490
  );
489
491
 
490
492
  addFilter(
@@ -386,7 +386,8 @@ export const withPositionStyles = createHigherOrderComponent(
386
386
  <BlockListBlock { ...props } className={ className } />
387
387
  </>
388
388
  );
389
- }
389
+ },
390
+ 'withPositionStyles'
390
391
  );
391
392
 
392
393
  addFilter(
@@ -447,7 +447,8 @@ const withElementsStyles = createHigherOrderComponent(
447
447
  />
448
448
  </>
449
449
  );
450
- }
450
+ },
451
+ 'withElementsStyles'
451
452
  );
452
453
 
453
454
  addFilter(
@@ -0,0 +1,282 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { renderHook } from '@testing-library/react-native';
5
+
6
+ /**
7
+ * WordPress dependencies
8
+ */
9
+ import { getBlockTypes, unregisterBlockType } from '@wordpress/blocks';
10
+ import { registerCoreBlocks } from '@wordpress/block-library';
11
+
12
+ /**
13
+ * Internal dependencies
14
+ */
15
+ import { useEditorWrapperStyles } from '../use-editor-wrapper-styles';
16
+
17
+ jest.mock( '../use-editor-wrapper-styles.scss', () => ( {
18
+ 'use-editor-wrapper-styles': {
19
+ width: '100%',
20
+ maxWidth: 580,
21
+ alignSelf: 'center',
22
+ },
23
+ 'use-editor-wrapper-styles--reversed': {
24
+ flexDirection: 'column-reverse',
25
+ width: '100%',
26
+ maxWidth: 580,
27
+ },
28
+ } ) );
29
+
30
+ const defaultCanvasStyles = {
31
+ width: '100%',
32
+ maxWidth: 580,
33
+ alignSelf: 'center',
34
+ };
35
+
36
+ describe( 'useEditorWrapperStyles', () => {
37
+ beforeAll( () => {
38
+ // Register all core blocks
39
+ registerCoreBlocks();
40
+ } );
41
+
42
+ afterAll( () => {
43
+ // Clean up registered blocks
44
+ getBlockTypes().forEach( ( block ) => {
45
+ unregisterBlockType( block.name );
46
+ } );
47
+ } );
48
+
49
+ it( 'should return the default wrapper styles when no props are set', () => {
50
+ // Arrange
51
+ jest.spyOn(
52
+ require( 'react-native' ),
53
+ 'useWindowDimensions'
54
+ ).mockReturnValue( { width: 900, height: 600 } );
55
+
56
+ // Act
57
+ const { result } = renderHook( () => useEditorWrapperStyles() );
58
+
59
+ // Assert
60
+ expect( result.current[ 0 ] ).toEqual( [
61
+ expect.objectContaining( defaultCanvasStyles ),
62
+ {},
63
+ ] );
64
+ } );
65
+
66
+ it( 'should return the correct wrapper styles and margin for wide (medium) alignment', () => {
67
+ // Arrange
68
+ jest.spyOn(
69
+ require( 'react-native' ),
70
+ 'useWindowDimensions'
71
+ ).mockReturnValue( { width: 900, height: 600 } );
72
+
73
+ // Act
74
+ const { result } = renderHook( () =>
75
+ useEditorWrapperStyles( {
76
+ align: 'wide',
77
+ blockName: 'core/group',
78
+ blockWidth: 800,
79
+ marginHorizontal: 16,
80
+ } )
81
+ );
82
+
83
+ // Assert
84
+ expect( result.current[ 0 ] ).toEqual( [
85
+ expect.objectContaining( defaultCanvasStyles ),
86
+ expect.objectContaining( {
87
+ maxWidth: 770,
88
+ } ),
89
+ ] );
90
+ expect( result.current[ 1 ] ).toEqual( 16 );
91
+ } );
92
+
93
+ it( 'should return the correct wrapper styles and margin for wide (landscape) alignment', () => {
94
+ // Arrange
95
+ jest.spyOn(
96
+ require( 'react-native' ),
97
+ 'useWindowDimensions'
98
+ ).mockReturnValue( { width: 800, height: 600 } );
99
+
100
+ // Act
101
+ const { result } = renderHook( () =>
102
+ useEditorWrapperStyles( {
103
+ align: 'wide',
104
+ blockName: 'core/group',
105
+ blockWidth: 700,
106
+ marginHorizontal: 16,
107
+ } )
108
+ );
109
+
110
+ // Assert
111
+ expect( result.current[ 0 ] ).toEqual( [
112
+ expect.objectContaining( defaultCanvasStyles ),
113
+ expect.objectContaining( {
114
+ maxWidth: 662,
115
+ } ),
116
+ ] );
117
+ expect( result.current[ 1 ] ).toEqual( 16 );
118
+ } );
119
+
120
+ it( 'should return the correct wrapper styles and margin for wide alignment', () => {
121
+ // Arrange
122
+ jest.spyOn(
123
+ require( 'react-native' ),
124
+ 'useWindowDimensions'
125
+ ).mockReturnValue( { width: 1194, height: 834 } );
126
+
127
+ // Act
128
+ const { result } = renderHook( () =>
129
+ useEditorWrapperStyles( {
130
+ align: 'wide',
131
+ blockName: 'core/group',
132
+ blockWidth: 800,
133
+ marginHorizontal: 16,
134
+ } )
135
+ );
136
+
137
+ // Assert
138
+ expect( result.current[ 0 ] ).toEqual( [
139
+ expect.objectContaining( defaultCanvasStyles ),
140
+ expect.objectContaining( {
141
+ maxWidth: 1054,
142
+ } ),
143
+ ] );
144
+ expect( result.current[ 1 ] ).toEqual( 16 );
145
+ } );
146
+
147
+ it( 'should return the correct wrapper styles and margin for full alignment', () => {
148
+ // Arrange
149
+ jest.spyOn(
150
+ require( 'react-native' ),
151
+ 'useWindowDimensions'
152
+ ).mockReturnValue( { width: 800, height: 600 } );
153
+
154
+ // Act
155
+ const { result } = renderHook( () =>
156
+ useEditorWrapperStyles( {
157
+ align: 'full',
158
+ blockName: 'core/cover',
159
+ blockWidth: 700,
160
+ marginHorizontal: 16,
161
+ } )
162
+ );
163
+
164
+ // Assert
165
+ expect( result.current[ 0 ] ).toEqual( [
166
+ expect.objectContaining( defaultCanvasStyles ),
167
+ expect.objectContaining( {
168
+ maxWidth: '100%',
169
+ } ),
170
+ ] );
171
+ expect( result.current[ 1 ] ).toEqual( 0 );
172
+ } );
173
+
174
+ it( 'should return the correct wrapper styles and margin for left alignment', () => {
175
+ // Arrange
176
+ jest.spyOn(
177
+ require( 'react-native' ),
178
+ 'useWindowDimensions'
179
+ ).mockReturnValue( { width: 800, height: 600 } );
180
+
181
+ // Act
182
+ const { result } = renderHook( () =>
183
+ useEditorWrapperStyles( { align: 'left', marginHorizontal: 16 } )
184
+ );
185
+
186
+ // Assert
187
+ expect( result.current[ 0 ] ).toEqual( [
188
+ expect.objectContaining( defaultCanvasStyles ),
189
+ {},
190
+ ] );
191
+ expect( result.current[ 1 ] ).toEqual( 16 );
192
+ } );
193
+
194
+ it( 'should return the correct wrapper styles and margin for center alignment', () => {
195
+ // Arrange
196
+ jest.spyOn(
197
+ require( 'react-native' ),
198
+ 'useWindowDimensions'
199
+ ).mockReturnValue( { width: 640, height: 960 } );
200
+
201
+ // Act
202
+ const { result } = renderHook( () =>
203
+ useEditorWrapperStyles( { align: 'center', marginHorizontal: 16 } )
204
+ );
205
+
206
+ // Assert
207
+ expect( result.current[ 0 ] ).toEqual( [
208
+ expect.objectContaining( defaultCanvasStyles ),
209
+ {},
210
+ ] );
211
+ expect( result.current[ 1 ] ).toEqual( 16 );
212
+ } );
213
+
214
+ it( 'should return the correct wrapper styles and margin for right alignment', () => {
215
+ // Arrange
216
+ jest.spyOn(
217
+ require( 'react-native' ),
218
+ 'useWindowDimensions'
219
+ ).mockReturnValue( { width: 960, height: 640 } );
220
+
221
+ // Act
222
+ const { result } = renderHook( () =>
223
+ useEditorWrapperStyles( { align: 'right', marginHorizontal: 16 } )
224
+ );
225
+
226
+ // Assert
227
+ expect( result.current[ 0 ] ).toEqual( [
228
+ expect.objectContaining( defaultCanvasStyles ),
229
+ {},
230
+ ] );
231
+ expect( result.current[ 1 ] ).toEqual( 16 );
232
+ } );
233
+
234
+ it( 'should return the correct wrapper styles and margin when reversed is true', () => {
235
+ // Arrange
236
+ jest.spyOn(
237
+ require( 'react-native' ),
238
+ 'useWindowDimensions'
239
+ ).mockReturnValue( { width: 800, height: 600 } );
240
+
241
+ // Act
242
+ const { result } = renderHook( () =>
243
+ useEditorWrapperStyles( { reversed: true, marginHorizontal: 16 } )
244
+ );
245
+
246
+ // Assert
247
+ expect( result.current[ 0 ] ).toEqual( [
248
+ expect.objectContaining( {
249
+ flexDirection: 'column-reverse',
250
+ width: '100%',
251
+ maxWidth: 580,
252
+ } ),
253
+ {},
254
+ ] );
255
+ expect( result.current[ 1 ] ).toEqual( 16 );
256
+ } );
257
+
258
+ it( 'should return the correct wrapper styles and margin when contentResizeMode is set', () => {
259
+ // Arrange
260
+ jest.spyOn(
261
+ require( 'react-native' ),
262
+ 'useWindowDimensions'
263
+ ).mockReturnValue( { width: 800, height: 600 } );
264
+
265
+ // Act
266
+ const { result } = renderHook( () =>
267
+ useEditorWrapperStyles( {
268
+ contentResizeMode: 'stretch',
269
+ marginHorizontal: 16,
270
+ } )
271
+ );
272
+
273
+ // Assert
274
+ expect( result.current[ 0 ] ).toEqual( [
275
+ expect.objectContaining( {
276
+ flex: 1,
277
+ } ),
278
+ {},
279
+ ] );
280
+ expect( result.current[ 1 ] ).toEqual( 16 );
281
+ } );
282
+ } );
@@ -39,7 +39,15 @@ describe( 'getTypographyClassesAndStyles', () => {
39
39
  },
40
40
  },
41
41
  };
42
- expect( getTypographyClassesAndStyles( attributes, true ) ).toEqual( {
42
+ expect(
43
+ getTypographyClassesAndStyles( attributes, {
44
+ typography: {
45
+ fluid: {
46
+ minFontSize: '1rem',
47
+ },
48
+ },
49
+ } )
50
+ ).toEqual( {
43
51
  className: 'has-tofu-font-family',
44
52
  style: {
45
53
  letterSpacing: '22px',
@@ -63,7 +71,11 @@ describe( 'getTypographyClassesAndStyles', () => {
63
71
  };
64
72
  expect(
65
73
  getTypographyClassesAndStyles( attributes, {
66
- minFontSize: '1rem',
74
+ typography: {
75
+ fluid: {
76
+ minFontSize: '1rem',
77
+ },
78
+ },
67
79
  } )
68
80
  ).toEqual( {
69
81
  className: 'has-tofu-font-family',
@@ -75,4 +87,37 @@ describe( 'getTypographyClassesAndStyles', () => {
75
87
  },
76
88
  } );
77
89
  } );
90
+
91
+ it( 'should use layout.wideSize for the maximum viewport value', () => {
92
+ const attributes = {
93
+ fontFamily: 'tofu',
94
+ style: {
95
+ typography: {
96
+ textDecoration: 'underline',
97
+ fontSize: '2rem',
98
+ textTransform: 'uppercase',
99
+ },
100
+ },
101
+ };
102
+ expect(
103
+ getTypographyClassesAndStyles( attributes, {
104
+ typography: {
105
+ fluid: {
106
+ minFontSize: '1rem',
107
+ },
108
+ },
109
+ layout: {
110
+ wideSize: '1000px',
111
+ },
112
+ } )
113
+ ).toEqual( {
114
+ className: 'has-tofu-font-family',
115
+ style: {
116
+ textDecoration: 'underline',
117
+ fontSize:
118
+ 'clamp(1.25rem, 1.25rem + ((1vw - 0.2rem) * 1.765), 2rem)',
119
+ textTransform: 'uppercase',
120
+ },
121
+ } );
122
+ } );
78
123
  } );