@wordpress/block-editor 11.1.0 → 11.3.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 (765) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/LICENSE.md +1 -1
  3. package/README.md +28 -4
  4. package/build/components/alignment-control/ui.js +1 -1
  5. package/build/components/alignment-control/ui.js.map +1 -1
  6. package/build/components/autocomplete/index.js +2 -7
  7. package/build/components/autocomplete/index.js.map +1 -1
  8. package/build/components/block-actions/index.js +9 -0
  9. package/build/components/block-actions/index.js.map +1 -1
  10. package/build/components/block-alignment-matrix-control/index.js +2 -2
  11. package/build/components/block-alignment-matrix-control/index.js.map +1 -1
  12. package/build/components/block-card/index.js +2 -4
  13. package/build/components/block-card/index.js.map +1 -1
  14. package/build/components/block-edit/index.js +8 -0
  15. package/build/components/block-edit/index.js.map +1 -1
  16. package/build/components/block-inspector/index.js +18 -15
  17. package/build/components/block-inspector/index.js.map +1 -1
  18. package/build/components/block-list/use-in-between-inserter.js +5 -0
  19. package/build/components/block-list/use-in-between-inserter.js.map +1 -1
  20. package/build/components/block-lock/modal.js +0 -1
  21. package/build/components/block-lock/modal.js.map +1 -1
  22. package/build/components/block-mover/mover-description.js +2 -2
  23. package/build/components/block-mover/mover-description.js.map +1 -1
  24. package/build/components/block-navigation/dropdown.js +3 -1
  25. package/build/components/block-navigation/dropdown.js.map +1 -1
  26. package/build/components/block-pattern-setup/index.js +1 -1
  27. package/build/components/block-pattern-setup/index.js.map +1 -1
  28. package/build/components/block-pattern-setup/use-patterns-setup.js +2 -2
  29. package/build/components/block-pattern-setup/use-patterns-setup.js.map +1 -1
  30. package/build/components/block-patterns-list/index.js +31 -3
  31. package/build/components/block-patterns-list/index.js.map +1 -1
  32. package/build/components/block-preview/auto.js +9 -14
  33. package/build/components/block-preview/auto.js.map +1 -1
  34. package/build/components/block-preview/index.js +32 -8
  35. package/build/components/block-preview/index.js.map +1 -1
  36. package/build/components/block-selection-clearer/index.js +1 -1
  37. package/build/components/block-selection-clearer/index.js.map +1 -1
  38. package/build/components/block-settings/container.native.js +7 -33
  39. package/build/components/block-settings/container.native.js.map +1 -1
  40. package/build/components/block-settings-menu/block-settings-dropdown.js +12 -3
  41. package/build/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  42. package/build/components/block-settings-menu-controls/index.js +2 -8
  43. package/build/components/block-settings-menu-controls/index.js.map +1 -1
  44. package/build/components/block-styles/index.js +3 -1
  45. package/build/components/block-styles/index.js.map +1 -1
  46. package/build/components/block-switcher/utils.js +1 -1
  47. package/build/components/block-switcher/utils.js.map +1 -1
  48. package/build/components/block-tools/selected-block-popover.js +55 -47
  49. package/build/components/block-tools/selected-block-popover.js.map +1 -1
  50. package/build/components/block-tools/use-block-toolbar-popover-props.js +43 -10
  51. package/build/components/block-tools/use-block-toolbar-popover-props.js.map +1 -1
  52. package/build/components/block-vertical-alignment-control/icons.js +15 -1
  53. package/build/components/block-vertical-alignment-control/icons.js.map +1 -1
  54. package/build/components/block-vertical-alignment-control/ui.js +9 -4
  55. package/build/components/block-vertical-alignment-control/ui.js.map +1 -1
  56. package/build/components/color-style-selector/index.js +3 -1
  57. package/build/components/color-style-selector/index.js.map +1 -1
  58. package/build/components/date-format-picker/index.js +3 -4
  59. package/build/components/date-format-picker/index.js.map +1 -1
  60. package/build/components/default-style-picker/index.js +1 -0
  61. package/build/components/default-style-picker/index.js.map +1 -1
  62. package/build/components/font-family/index.js +1 -7
  63. package/build/components/font-family/index.js.map +1 -1
  64. package/build/components/font-sizes/fluid-utils.js +1 -1
  65. package/build/components/font-sizes/fluid-utils.js.map +1 -1
  66. package/build/components/font-sizes/utils.js +1 -1
  67. package/build/components/font-sizes/utils.js.map +1 -1
  68. package/build/components/font-sizes/with-font-sizes.js +5 -8
  69. package/build/components/font-sizes/with-font-sizes.js.map +1 -1
  70. package/build/components/global-styles/context.js +22 -0
  71. package/build/components/global-styles/context.js.map +1 -0
  72. package/build/components/global-styles/hooks.js +142 -0
  73. package/build/components/global-styles/hooks.js.map +1 -0
  74. package/build/components/global-styles/index.js +42 -0
  75. package/build/components/global-styles/index.js.map +1 -0
  76. package/build/components/global-styles/typography-utils.js +92 -0
  77. package/build/components/global-styles/typography-utils.js.map +1 -0
  78. package/build/components/global-styles/use-global-styles-output.js +974 -0
  79. package/build/components/global-styles/use-global-styles-output.js.map +1 -0
  80. package/build/components/global-styles/utils.js +340 -0
  81. package/build/components/global-styles/utils.js.map +1 -0
  82. package/build/components/height-control/index.js +13 -1
  83. package/build/components/height-control/index.js.map +1 -1
  84. package/build/components/iframe/index.js +37 -8
  85. package/build/components/iframe/index.js.map +1 -1
  86. package/build/components/iframe/use-compatibility-styles.js +6 -1
  87. package/build/components/iframe/use-compatibility-styles.js.map +1 -1
  88. package/build/components/image-editor/constants.js +1 -1
  89. package/build/components/image-editor/constants.js.map +1 -1
  90. package/build/components/image-editor/context.js +1 -2
  91. package/build/components/image-editor/context.js.map +1 -1
  92. package/build/components/image-editor/cropper.js +3 -1
  93. package/build/components/image-editor/cropper.js.map +1 -1
  94. package/build/components/image-editor/index.js +13 -9
  95. package/build/components/image-editor/index.js.map +1 -1
  96. package/build/components/image-editor/use-transform-image.js +11 -35
  97. package/build/components/image-editor/use-transform-image.js.map +1 -1
  98. package/build/components/image-size-control/index.js +2 -7
  99. package/build/components/image-size-control/index.js.map +1 -1
  100. package/build/components/index.js +8 -24
  101. package/build/components/index.js.map +1 -1
  102. package/build/components/inner-blocks/index.js +22 -32
  103. package/build/components/inner-blocks/index.js.map +1 -1
  104. package/build/components/inner-blocks/index.native.js +8 -23
  105. package/build/components/inner-blocks/index.native.js.map +1 -1
  106. package/build/components/inner-blocks/use-block-context.js +53 -0
  107. package/build/components/inner-blocks/use-block-context.js.map +1 -0
  108. package/build/components/inserter/block-patterns-explorer/explorer.js +0 -1
  109. package/build/components/inserter/block-patterns-explorer/explorer.js.map +1 -1
  110. package/build/components/inserter/block-patterns-tab.js +11 -5
  111. package/build/components/inserter/block-patterns-tab.js.map +1 -1
  112. package/build/components/inserter/block-types-tab.js +2 -2
  113. package/build/components/inserter/block-types-tab.js.map +1 -1
  114. package/build/components/inserter/hooks/use-patterns-state.js +1 -7
  115. package/build/components/inserter/hooks/use-patterns-state.js.map +1 -1
  116. package/build/components/inserter/index.js +8 -6
  117. package/build/components/inserter/index.js.map +1 -1
  118. package/build/components/inserter/media-tab/hooks.js +142 -56
  119. package/build/components/inserter/media-tab/hooks.js.map +1 -1
  120. package/build/components/inserter/media-tab/media-list.js +74 -21
  121. package/build/components/inserter/media-tab/media-list.js.map +1 -1
  122. package/build/components/inserter/media-tab/media-panel.js +11 -13
  123. package/build/components/inserter/media-tab/media-panel.js.map +1 -1
  124. package/build/components/inserter/media-tab/media-tab.js +6 -3
  125. package/build/components/inserter/media-tab/media-tab.js.map +1 -1
  126. package/build/components/inserter/media-tab/utils.js +26 -15
  127. package/build/components/inserter/media-tab/utils.js.map +1 -1
  128. package/build/components/inserter/menu.js +12 -5
  129. package/build/components/inserter/menu.js.map +1 -1
  130. package/build/components/inserter/preview-panel.js +5 -3
  131. package/build/components/inserter/preview-panel.js.map +1 -1
  132. package/build/components/inserter/search-results.js +2 -7
  133. package/build/components/inserter/search-results.js.map +1 -1
  134. package/build/components/inserter-list-item/index.js +1 -9
  135. package/build/components/inserter-list-item/index.js.map +1 -1
  136. package/build/components/inspector-controls/fill.js +15 -2
  137. package/build/components/inspector-controls/fill.js.map +1 -1
  138. package/build/components/inspector-controls/fill.native.js +14 -1
  139. package/build/components/inspector-controls/fill.native.js.map +1 -1
  140. package/build/components/inspector-controls/groups.js +7 -1
  141. package/build/components/inspector-controls/groups.js.map +1 -1
  142. package/build/components/inspector-controls/index.js +2 -2
  143. package/build/components/inspector-controls/index.js.map +1 -1
  144. package/build/components/inspector-controls/slot.js +14 -1
  145. package/build/components/inspector-controls/slot.js.map +1 -1
  146. package/build/components/inspector-controls/slot.native.js +14 -1
  147. package/build/components/inspector-controls/slot.native.js.map +1 -1
  148. package/build/components/inspector-controls-tabs/advanced-controls-panel.js +1 -1
  149. package/build/components/inspector-controls-tabs/advanced-controls-panel.js.map +1 -1
  150. package/build/components/inspector-controls-tabs/index.js +2 -2
  151. package/build/components/inspector-controls-tabs/index.js.map +1 -1
  152. package/build/components/inspector-controls-tabs/position-controls-panel.js +46 -0
  153. package/build/components/inspector-controls-tabs/position-controls-panel.js.map +1 -0
  154. package/build/components/inspector-controls-tabs/settings-tab.js +3 -1
  155. package/build/components/inspector-controls-tabs/settings-tab.js.map +1 -1
  156. package/build/components/inspector-controls-tabs/styles-tab.js +6 -4
  157. package/build/components/inspector-controls-tabs/styles-tab.js.map +1 -1
  158. package/build/components/inspector-controls-tabs/use-inspector-controls-tabs.js +20 -22
  159. package/build/components/inspector-controls-tabs/use-inspector-controls-tabs.js.map +1 -1
  160. package/build/components/justify-content-control/ui.js +8 -1
  161. package/build/components/justify-content-control/ui.js.map +1 -1
  162. package/build/components/link-control/index.js +45 -17
  163. package/build/components/link-control/index.js.map +1 -1
  164. package/build/components/link-control/search-input.js +1 -0
  165. package/build/components/link-control/search-input.js.map +1 -1
  166. package/build/components/list-view/block.js +1 -1
  167. package/build/components/list-view/block.js.map +1 -1
  168. package/build/components/list-view/use-list-view-drop-zone.js +1 -1
  169. package/build/components/list-view/use-list-view-drop-zone.js.map +1 -1
  170. package/build/components/media-upload/index.native.js +4 -1
  171. package/build/components/media-upload/index.native.js.map +1 -1
  172. package/build/components/off-canvas-editor/appender.js +49 -38
  173. package/build/components/off-canvas-editor/appender.js.map +1 -1
  174. package/build/components/off-canvas-editor/block-contents.js +38 -5
  175. package/build/components/off-canvas-editor/block-contents.js.map +1 -1
  176. package/build/components/off-canvas-editor/block-select-button.js +10 -4
  177. package/build/components/off-canvas-editor/block-select-button.js.map +1 -1
  178. package/build/components/off-canvas-editor/block.js +13 -52
  179. package/build/components/off-canvas-editor/block.js.map +1 -1
  180. package/build/components/off-canvas-editor/branch.js +25 -10
  181. package/build/components/off-canvas-editor/branch.js.map +1 -1
  182. package/build/components/off-canvas-editor/index.js +15 -17
  183. package/build/components/off-canvas-editor/index.js.map +1 -1
  184. package/build/components/off-canvas-editor/link-ui.js +2 -2
  185. package/build/components/off-canvas-editor/link-ui.js.map +1 -1
  186. package/build/components/off-canvas-editor/use-list-view-drop-zone.js +1 -1
  187. package/build/components/off-canvas-editor/use-list-view-drop-zone.js.map +1 -1
  188. package/build/components/provider/index.js +22 -8
  189. package/build/components/provider/index.js.map +1 -1
  190. package/build/components/provider/index.native.js +5 -6
  191. package/build/components/provider/index.native.js.map +1 -1
  192. package/build/components/rich-text/use-before-input-rules.js +11 -3
  193. package/build/components/rich-text/use-before-input-rules.js.map +1 -1
  194. package/build/components/rich-text/use-enter.js +4 -5
  195. package/build/components/rich-text/use-enter.js.map +1 -1
  196. package/build/components/rich-text/utils.js +1 -1
  197. package/build/components/rich-text/utils.js.map +1 -1
  198. package/build/components/spacing-sizes-control/utils.js +2 -8
  199. package/build/components/spacing-sizes-control/utils.js.map +1 -1
  200. package/build/components/tool-selector/index.js +3 -1
  201. package/build/components/tool-selector/index.js.map +1 -1
  202. package/build/components/url-input/button.js +1 -0
  203. package/build/components/url-input/button.js.map +1 -1
  204. package/build/components/url-input/index.js +15 -1
  205. package/build/components/url-input/index.js.map +1 -1
  206. package/build/components/url-popover/image-url-input-ui.js +7 -8
  207. package/build/components/url-popover/image-url-input-ui.js.map +1 -1
  208. package/build/components/url-popover/link-editor.js +1 -0
  209. package/build/components/url-popover/link-editor.js.map +1 -1
  210. package/build/components/use-block-display-information/index.js +1 -1
  211. package/build/components/use-block-display-information/index.js.map +1 -1
  212. package/build/components/use-paste-styles/index.js +188 -0
  213. package/build/components/use-paste-styles/index.js.map +1 -0
  214. package/build/components/writing-flow/use-arrow-nav.js +22 -29
  215. package/build/components/writing-flow/use-arrow-nav.js.map +1 -1
  216. package/build/experiments.js +45 -0
  217. package/build/experiments.js.map +1 -0
  218. package/build/experiments.native.js +40 -0
  219. package/build/experiments.native.js.map +1 -0
  220. package/build/hooks/anchor.js +2 -1
  221. package/build/hooks/anchor.js.map +1 -1
  222. package/build/hooks/border.js +1 -1
  223. package/build/hooks/border.js.map +1 -1
  224. package/build/hooks/child-layout.js +5 -1
  225. package/build/hooks/child-layout.js.map +1 -1
  226. package/build/hooks/color-panel.js +1 -1
  227. package/build/hooks/color-panel.js.map +1 -1
  228. package/build/hooks/color.js +3 -3
  229. package/build/hooks/color.js.map +1 -1
  230. package/build/hooks/custom-class-name.js +2 -1
  231. package/build/hooks/custom-class-name.js.map +1 -1
  232. package/build/hooks/dimensions.js +7 -5
  233. package/build/hooks/dimensions.js.map +1 -1
  234. package/build/hooks/index.js +2 -0
  235. package/build/hooks/index.js.map +1 -1
  236. package/build/hooks/margin.js +1 -0
  237. package/build/hooks/margin.js.map +1 -1
  238. package/build/hooks/metadata.js +1 -1
  239. package/build/hooks/metadata.js.map +1 -1
  240. package/build/hooks/padding.js +1 -0
  241. package/build/hooks/padding.js.map +1 -1
  242. package/build/hooks/position.js +395 -0
  243. package/build/hooks/position.js.map +1 -0
  244. package/build/hooks/supports.js +328 -0
  245. package/build/hooks/supports.js.map +1 -0
  246. package/build/hooks/typography.js +1 -1
  247. package/build/hooks/typography.js.map +1 -1
  248. package/build/hooks/use-color-props.js +3 -3
  249. package/build/hooks/use-color-props.js.map +1 -1
  250. package/build/hooks/utils.js +69 -3
  251. package/build/hooks/utils.js.map +1 -1
  252. package/build/index.js +10 -1
  253. package/build/index.js.map +1 -1
  254. package/build/layouts/constrained.js +3 -0
  255. package/build/layouts/constrained.js.map +1 -1
  256. package/build/layouts/flex.js +59 -9
  257. package/build/layouts/flex.js.map +1 -1
  258. package/build/layouts/flow.js +0 -18
  259. package/build/layouts/flow.js.map +1 -1
  260. package/build/store/actions.js +3 -30
  261. package/build/store/actions.js.map +1 -1
  262. package/build/store/defaults.js +5 -2
  263. package/build/store/defaults.js.map +1 -1
  264. package/build/store/index.js +11 -2
  265. package/build/store/index.js.map +1 -1
  266. package/build/store/private-actions.js +78 -0
  267. package/build/store/private-actions.js.map +1 -0
  268. package/build/store/private-selectors.js +18 -0
  269. package/build/store/private-selectors.js.map +1 -0
  270. package/build/store/reducer.js +7 -3
  271. package/build/store/reducer.js.map +1 -1
  272. package/build/store/selectors.js +68 -40
  273. package/build/store/selectors.js.map +1 -1
  274. package/build/utils/block-variation-transforms.js +1 -1
  275. package/build/utils/block-variation-transforms.js.map +1 -1
  276. package/build/utils/parse-css-unit-to-px.js +1 -1
  277. package/build/utils/parse-css-unit-to-px.js.map +1 -1
  278. package/build/utils/transform-styles/index.js +1 -7
  279. package/build/utils/transform-styles/index.js.map +1 -1
  280. package/build-module/components/alignment-control/ui.js +1 -1
  281. package/build-module/components/alignment-control/ui.js.map +1 -1
  282. package/build-module/components/autocomplete/index.js +2 -6
  283. package/build-module/components/autocomplete/index.js.map +1 -1
  284. package/build-module/components/block-actions/index.js +6 -0
  285. package/build-module/components/block-actions/index.js.map +1 -1
  286. package/build-module/components/block-alignment-matrix-control/index.js +2 -2
  287. package/build-module/components/block-alignment-matrix-control/index.js.map +1 -1
  288. package/build-module/components/block-card/index.js +2 -4
  289. package/build-module/components/block-card/index.js.map +1 -1
  290. package/build-module/components/block-edit/index.js +7 -0
  291. package/build-module/components/block-edit/index.js.map +1 -1
  292. package/build-module/components/block-inspector/index.js +17 -15
  293. package/build-module/components/block-inspector/index.js.map +1 -1
  294. package/build-module/components/block-list/use-in-between-inserter.js +5 -0
  295. package/build-module/components/block-list/use-in-between-inserter.js.map +1 -1
  296. package/build-module/components/block-lock/modal.js +0 -1
  297. package/build-module/components/block-lock/modal.js.map +1 -1
  298. package/build-module/components/block-mover/mover-description.js +2 -2
  299. package/build-module/components/block-mover/mover-description.js.map +1 -1
  300. package/build-module/components/block-navigation/dropdown.js +3 -1
  301. package/build-module/components/block-navigation/dropdown.js.map +1 -1
  302. package/build-module/components/block-pattern-setup/index.js +1 -1
  303. package/build-module/components/block-pattern-setup/index.js.map +1 -1
  304. package/build-module/components/block-pattern-setup/use-patterns-setup.js +2 -2
  305. package/build-module/components/block-pattern-setup/use-patterns-setup.js.map +1 -1
  306. package/build-module/components/block-patterns-list/index.js +32 -3
  307. package/build-module/components/block-patterns-list/index.js.map +1 -1
  308. package/build-module/components/block-preview/auto.js +9 -14
  309. package/build-module/components/block-preview/auto.js.map +1 -1
  310. package/build-module/components/block-preview/index.js +31 -8
  311. package/build-module/components/block-preview/index.js.map +1 -1
  312. package/build-module/components/block-selection-clearer/index.js +1 -1
  313. package/build-module/components/block-selection-clearer/index.js.map +1 -1
  314. package/build-module/components/block-settings/container.native.js +6 -30
  315. package/build-module/components/block-settings/container.native.js.map +1 -1
  316. package/build-module/components/block-settings-menu/block-settings-dropdown.js +12 -3
  317. package/build-module/components/block-settings-menu/block-settings-dropdown.js.map +1 -1
  318. package/build-module/components/block-settings-menu-controls/index.js +2 -7
  319. package/build-module/components/block-settings-menu-controls/index.js.map +1 -1
  320. package/build-module/components/block-styles/index.js +2 -1
  321. package/build-module/components/block-styles/index.js.map +1 -1
  322. package/build-module/components/block-switcher/utils.js +1 -1
  323. package/build-module/components/block-switcher/utils.js.map +1 -1
  324. package/build-module/components/block-tools/selected-block-popover.js +55 -48
  325. package/build-module/components/block-tools/selected-block-popover.js.map +1 -1
  326. package/build-module/components/block-tools/use-block-toolbar-popover-props.js +42 -11
  327. package/build-module/components/block-tools/use-block-toolbar-popover-props.js.map +1 -1
  328. package/build-module/components/block-vertical-alignment-control/icons.js +12 -0
  329. package/build-module/components/block-vertical-alignment-control/icons.js.map +1 -1
  330. package/build-module/components/block-vertical-alignment-control/ui.js +10 -5
  331. package/build-module/components/block-vertical-alignment-control/ui.js.map +1 -1
  332. package/build-module/components/color-style-selector/index.js +3 -1
  333. package/build-module/components/color-style-selector/index.js.map +1 -1
  334. package/build-module/components/date-format-picker/index.js +4 -5
  335. package/build-module/components/date-format-picker/index.js.map +1 -1
  336. package/build-module/components/default-style-picker/index.js +1 -0
  337. package/build-module/components/default-style-picker/index.js.map +1 -1
  338. package/build-module/components/font-family/index.js +1 -6
  339. package/build-module/components/font-family/index.js.map +1 -1
  340. package/build-module/components/font-sizes/fluid-utils.js +1 -1
  341. package/build-module/components/font-sizes/fluid-utils.js.map +1 -1
  342. package/build-module/components/font-sizes/utils.js +1 -1
  343. package/build-module/components/font-sizes/utils.js.map +1 -1
  344. package/build-module/components/font-sizes/with-font-sizes.js +5 -7
  345. package/build-module/components/font-sizes/with-font-sizes.js.map +1 -1
  346. package/build-module/components/global-styles/context.js +12 -0
  347. package/build-module/components/global-styles/context.js.map +1 -0
  348. package/build-module/components/global-styles/hooks.js +121 -0
  349. package/build-module/components/global-styles/hooks.js.map +1 -0
  350. package/build-module/components/global-styles/index.js +4 -0
  351. package/build-module/components/global-styles/index.js.map +1 -0
  352. package/build-module/components/global-styles/typography-utils.js +84 -0
  353. package/build-module/components/global-styles/typography-utils.js.map +1 -0
  354. package/build-module/components/global-styles/use-global-styles-output.js +930 -0
  355. package/build-module/components/global-styles/use-global-styles-output.js.map +1 -0
  356. package/build-module/components/global-styles/utils.js +321 -0
  357. package/build-module/components/global-styles/utils.js.map +1 -0
  358. package/build-module/components/height-control/index.js +14 -1
  359. package/build-module/components/height-control/index.js.map +1 -1
  360. package/build-module/components/iframe/index.js +36 -9
  361. package/build-module/components/iframe/index.js.map +1 -1
  362. package/build-module/components/iframe/use-compatibility-styles.js +6 -1
  363. package/build-module/components/iframe/use-compatibility-styles.js.map +1 -1
  364. package/build-module/components/image-editor/constants.js +1 -1
  365. package/build-module/components/image-editor/constants.js.map +1 -1
  366. package/build-module/components/image-editor/context.js +1 -2
  367. package/build-module/components/image-editor/context.js.map +1 -1
  368. package/build-module/components/image-editor/cropper.js +3 -1
  369. package/build-module/components/image-editor/cropper.js.map +1 -1
  370. package/build-module/components/image-editor/index.js +13 -3
  371. package/build-module/components/image-editor/index.js.map +1 -1
  372. package/build-module/components/image-editor/use-transform-image.js +12 -37
  373. package/build-module/components/image-editor/use-transform-image.js.map +1 -1
  374. package/build-module/components/image-size-control/index.js +2 -6
  375. package/build-module/components/image-size-control/index.js.map +1 -1
  376. package/build-module/components/index.js +2 -3
  377. package/build-module/components/index.js.map +1 -1
  378. package/build-module/components/inner-blocks/index.js +21 -32
  379. package/build-module/components/inner-blocks/index.js.map +1 -1
  380. package/build-module/components/inner-blocks/index.native.js +9 -22
  381. package/build-module/components/inner-blocks/index.native.js.map +1 -1
  382. package/build-module/components/inner-blocks/use-block-context.js +43 -0
  383. package/build-module/components/inner-blocks/use-block-context.js.map +1 -0
  384. package/build-module/components/inserter/block-patterns-explorer/explorer.js +0 -1
  385. package/build-module/components/inserter/block-patterns-explorer/explorer.js.map +1 -1
  386. package/build-module/components/inserter/block-patterns-tab.js +11 -5
  387. package/build-module/components/inserter/block-patterns-tab.js.map +1 -1
  388. package/build-module/components/inserter/block-types-tab.js +3 -3
  389. package/build-module/components/inserter/block-types-tab.js.map +1 -1
  390. package/build-module/components/inserter/hooks/use-patterns-state.js +1 -6
  391. package/build-module/components/inserter/hooks/use-patterns-state.js.map +1 -1
  392. package/build-module/components/inserter/index.js +8 -6
  393. package/build-module/components/inserter/index.js.map +1 -1
  394. package/build-module/components/inserter/media-tab/hooks.js +145 -56
  395. package/build-module/components/inserter/media-tab/hooks.js.map +1 -1
  396. package/build-module/components/inserter/media-tab/media-list.js +74 -24
  397. package/build-module/components/inserter/media-tab/media-list.js.map +1 -1
  398. package/build-module/components/inserter/media-tab/media-panel.js +14 -14
  399. package/build-module/components/inserter/media-tab/media-panel.js.map +1 -1
  400. package/build-module/components/inserter/media-tab/media-tab.js +7 -4
  401. package/build-module/components/inserter/media-tab/media-tab.js.map +1 -1
  402. package/build-module/components/inserter/media-tab/utils.js +27 -15
  403. package/build-module/components/inserter/media-tab/utils.js.map +1 -1
  404. package/build-module/components/inserter/menu.js +12 -5
  405. package/build-module/components/inserter/menu.js.map +1 -1
  406. package/build-module/components/inserter/preview-panel.js +5 -3
  407. package/build-module/components/inserter/preview-panel.js.map +1 -1
  408. package/build-module/components/inserter/search-results.js +2 -6
  409. package/build-module/components/inserter/search-results.js.map +1 -1
  410. package/build-module/components/inserter-list-item/index.js +1 -9
  411. package/build-module/components/inserter-list-item/index.js.map +1 -1
  412. package/build-module/components/inspector-controls/fill.js +14 -2
  413. package/build-module/components/inspector-controls/fill.js.map +1 -1
  414. package/build-module/components/inspector-controls/fill.native.js +13 -1
  415. package/build-module/components/inspector-controls/fill.native.js.map +1 -1
  416. package/build-module/components/inspector-controls/groups.js +7 -1
  417. package/build-module/components/inspector-controls/groups.js.map +1 -1
  418. package/build-module/components/inspector-controls/index.js +2 -2
  419. package/build-module/components/inspector-controls/index.js.map +1 -1
  420. package/build-module/components/inspector-controls/slot.js +13 -1
  421. package/build-module/components/inspector-controls/slot.js.map +1 -1
  422. package/build-module/components/inspector-controls/slot.native.js +13 -1
  423. package/build-module/components/inspector-controls/slot.native.js.map +1 -1
  424. package/build-module/components/inspector-controls-tabs/advanced-controls-panel.js +1 -1
  425. package/build-module/components/inspector-controls-tabs/advanced-controls-panel.js.map +1 -1
  426. package/build-module/components/inspector-controls-tabs/index.js +2 -2
  427. package/build-module/components/inspector-controls-tabs/index.js.map +1 -1
  428. package/build-module/components/inspector-controls-tabs/position-controls-panel.js +33 -0
  429. package/build-module/components/inspector-controls-tabs/position-controls-panel.js.map +1 -0
  430. package/build-module/components/inspector-controls-tabs/settings-tab.js +2 -1
  431. package/build-module/components/inspector-controls-tabs/settings-tab.js.map +1 -1
  432. package/build-module/components/inspector-controls-tabs/styles-tab.js +6 -4
  433. package/build-module/components/inspector-controls-tabs/styles-tab.js.map +1 -1
  434. package/build-module/components/inspector-controls-tabs/use-inspector-controls-tabs.js +20 -22
  435. package/build-module/components/inspector-controls-tabs/use-inspector-controls-tabs.js.map +1 -1
  436. package/build-module/components/justify-content-control/ui.js +9 -2
  437. package/build-module/components/justify-content-control/ui.js.map +1 -1
  438. package/build-module/components/link-control/index.js +45 -16
  439. package/build-module/components/link-control/index.js.map +1 -1
  440. package/build-module/components/link-control/search-input.js +1 -0
  441. package/build-module/components/link-control/search-input.js.map +1 -1
  442. package/build-module/components/list-view/block.js +1 -1
  443. package/build-module/components/list-view/block.js.map +1 -1
  444. package/build-module/components/list-view/use-list-view-drop-zone.js +1 -1
  445. package/build-module/components/list-view/use-list-view-drop-zone.js.map +1 -1
  446. package/build-module/components/media-upload/index.native.js +4 -1
  447. package/build-module/components/media-upload/index.native.js.map +1 -1
  448. package/build-module/components/off-canvas-editor/appender.js +46 -36
  449. package/build-module/components/off-canvas-editor/appender.js.map +1 -1
  450. package/build-module/components/off-canvas-editor/block-contents.js +37 -7
  451. package/build-module/components/off-canvas-editor/block-contents.js.map +1 -1
  452. package/build-module/components/off-canvas-editor/block-select-button.js +9 -4
  453. package/build-module/components/off-canvas-editor/block-select-button.js.map +1 -1
  454. package/build-module/components/off-canvas-editor/block.js +15 -52
  455. package/build-module/components/off-canvas-editor/block.js.map +1 -1
  456. package/build-module/components/off-canvas-editor/branch.js +23 -11
  457. package/build-module/components/off-canvas-editor/branch.js.map +1 -1
  458. package/build-module/components/off-canvas-editor/index.js +15 -16
  459. package/build-module/components/off-canvas-editor/index.js.map +1 -1
  460. package/build-module/components/off-canvas-editor/link-ui.js +2 -2
  461. package/build-module/components/off-canvas-editor/link-ui.js.map +1 -1
  462. package/build-module/components/off-canvas-editor/use-list-view-drop-zone.js +1 -1
  463. package/build-module/components/off-canvas-editor/use-list-view-drop-zone.js.map +1 -1
  464. package/build-module/components/provider/index.js +17 -8
  465. package/build-module/components/provider/index.js.map +1 -1
  466. package/build-module/components/provider/index.native.js +4 -4
  467. package/build-module/components/provider/index.native.js.map +1 -1
  468. package/build-module/components/rich-text/use-before-input-rules.js +10 -2
  469. package/build-module/components/rich-text/use-before-input-rules.js.map +1 -1
  470. package/build-module/components/rich-text/use-enter.js +4 -5
  471. package/build-module/components/rich-text/use-enter.js.map +1 -1
  472. package/build-module/components/rich-text/utils.js +1 -1
  473. package/build-module/components/rich-text/utils.js.map +1 -1
  474. package/build-module/components/spacing-sizes-control/utils.js +2 -7
  475. package/build-module/components/spacing-sizes-control/utils.js.map +1 -1
  476. package/build-module/components/tool-selector/index.js +3 -1
  477. package/build-module/components/tool-selector/index.js.map +1 -1
  478. package/build-module/components/url-input/button.js +1 -0
  479. package/build-module/components/url-input/button.js.map +1 -1
  480. package/build-module/components/url-input/index.js +14 -1
  481. package/build-module/components/url-input/index.js.map +1 -1
  482. package/build-module/components/url-popover/image-url-input-ui.js +8 -8
  483. package/build-module/components/url-popover/image-url-input-ui.js.map +1 -1
  484. package/build-module/components/url-popover/link-editor.js +1 -0
  485. package/build-module/components/url-popover/link-editor.js.map +1 -1
  486. package/build-module/components/use-block-display-information/index.js +1 -1
  487. package/build-module/components/use-block-display-information/index.js.map +1 -1
  488. package/build-module/components/use-paste-styles/index.js +174 -0
  489. package/build-module/components/use-paste-styles/index.js.map +1 -0
  490. package/build-module/components/writing-flow/use-arrow-nav.js +22 -29
  491. package/build-module/components/writing-flow/use-arrow-nav.js.map +1 -1
  492. package/build-module/experiments.js +25 -0
  493. package/build-module/experiments.js.map +1 -0
  494. package/build-module/experiments.native.js +23 -0
  495. package/build-module/experiments.native.js.map +1 -0
  496. package/build-module/hooks/anchor.js +2 -1
  497. package/build-module/hooks/anchor.js.map +1 -1
  498. package/build-module/hooks/border.js +1 -1
  499. package/build-module/hooks/border.js.map +1 -1
  500. package/build-module/hooks/child-layout.js +5 -1
  501. package/build-module/hooks/child-layout.js.map +1 -1
  502. package/build-module/hooks/color-panel.js +1 -1
  503. package/build-module/hooks/color-panel.js.map +1 -1
  504. package/build-module/hooks/color.js +3 -3
  505. package/build-module/hooks/color.js.map +1 -1
  506. package/build-module/hooks/custom-class-name.js +2 -1
  507. package/build-module/hooks/custom-class-name.js.map +1 -1
  508. package/build-module/hooks/dimensions.js +6 -5
  509. package/build-module/hooks/dimensions.js.map +1 -1
  510. package/build-module/hooks/index.js +1 -0
  511. package/build-module/hooks/index.js.map +1 -1
  512. package/build-module/hooks/margin.js +1 -0
  513. package/build-module/hooks/margin.js.map +1 -1
  514. package/build-module/hooks/metadata.js +1 -1
  515. package/build-module/hooks/metadata.js.map +1 -1
  516. package/build-module/hooks/padding.js +1 -0
  517. package/build-module/hooks/padding.js.map +1 -1
  518. package/build-module/hooks/position.js +354 -0
  519. package/build-module/hooks/position.js.map +1 -0
  520. package/build-module/hooks/supports.js +257 -0
  521. package/build-module/hooks/supports.js.map +1 -0
  522. package/build-module/hooks/typography.js +1 -1
  523. package/build-module/hooks/typography.js.map +1 -1
  524. package/build-module/hooks/use-color-props.js +3 -3
  525. package/build-module/hooks/use-color-props.js.map +1 -1
  526. package/build-module/hooks/utils.js +70 -4
  527. package/build-module/hooks/utils.js.map +1 -1
  528. package/build-module/index.js +1 -0
  529. package/build-module/index.js.map +1 -1
  530. package/build-module/layouts/constrained.js +3 -0
  531. package/build-module/layouts/constrained.js.map +1 -1
  532. package/build-module/layouts/flex.js +60 -10
  533. package/build-module/layouts/flex.js.map +1 -1
  534. package/build-module/layouts/flow.js +0 -18
  535. package/build-module/layouts/flow.js.map +1 -1
  536. package/build-module/store/actions.js +2 -26
  537. package/build-module/store/actions.js.map +1 -1
  538. package/build-module/store/defaults.js +5 -2
  539. package/build-module/store/defaults.js.map +1 -1
  540. package/build-module/store/index.js +8 -2
  541. package/build-module/store/index.js.map +1 -1
  542. package/build-module/store/private-actions.js +66 -0
  543. package/build-module/store/private-actions.js.map +1 -0
  544. package/build-module/store/private-selectors.js +11 -0
  545. package/build-module/store/private-selectors.js.map +1 -0
  546. package/build-module/store/reducer.js +7 -3
  547. package/build-module/store/reducer.js.map +1 -1
  548. package/build-module/store/selectors.js +55 -30
  549. package/build-module/store/selectors.js.map +1 -1
  550. package/build-module/utils/block-variation-transforms.js +1 -1
  551. package/build-module/utils/block-variation-transforms.js.map +1 -1
  552. package/build-module/utils/parse-css-unit-to-px.js +1 -1
  553. package/build-module/utils/parse-css-unit-to-px.js.map +1 -1
  554. package/build-module/utils/transform-styles/index.js +1 -6
  555. package/build-module/utils/transform-styles/index.js.map +1 -1
  556. package/build-style/content-rtl.css +340 -3
  557. package/build-style/content.css +340 -3
  558. package/build-style/style-rtl.css +125 -272
  559. package/build-style/style.css +125 -272
  560. package/package.json +30 -29
  561. package/src/components/alignment-control/test/__snapshots__/index.js.snap +3 -3
  562. package/src/components/alignment-control/test/index.js +5 -15
  563. package/src/components/alignment-control/ui.js +1 -1
  564. package/src/components/autocomplete/index.js +3 -6
  565. package/src/components/block-actions/index.js +5 -0
  566. package/src/components/block-alignment-control/test/index.js +3 -11
  567. package/src/components/block-alignment-matrix-control/index.js +1 -2
  568. package/src/components/block-card/index.js +1 -4
  569. package/src/components/block-content-overlay/content.scss +4 -4
  570. package/src/components/block-edit/index.js +15 -1
  571. package/src/components/block-icon/content.scss +31 -0
  572. package/src/components/block-inspector/index.js +15 -17
  573. package/src/components/block-list/use-in-between-inserter.js +5 -0
  574. package/src/components/block-lock/modal.js +0 -1
  575. package/src/components/block-mover/mover-description.js +2 -2
  576. package/src/components/block-mover/stories/index.js +3 -3
  577. package/src/components/block-navigation/dropdown.js +1 -1
  578. package/src/components/block-pattern-setup/index.js +1 -4
  579. package/src/components/block-pattern-setup/use-patterns-setup.js +2 -5
  580. package/src/components/block-patterns-list/index.js +29 -3
  581. package/src/components/block-preview/README.md +9 -9
  582. package/src/components/block-preview/auto.js +10 -14
  583. package/src/components/block-preview/content.scss +23 -0
  584. package/src/components/block-preview/index.js +40 -10
  585. package/src/components/block-preview/style.scss +0 -23
  586. package/src/components/block-selection-clearer/index.js +1 -1
  587. package/src/components/block-selection-clearer/test/index.js +6 -6
  588. package/src/components/block-settings/container.native.js +7 -26
  589. package/src/components/block-settings-menu/block-settings-dropdown.js +14 -2
  590. package/src/components/block-settings-menu-controls/index.js +2 -10
  591. package/src/components/block-styles/index.js +4 -1
  592. package/src/components/block-switcher/test/index.js +43 -44
  593. package/src/components/block-switcher/utils.js +1 -1
  594. package/src/components/block-tools/selected-block-popover.js +77 -80
  595. package/src/components/block-tools/style.scss +0 -1
  596. package/src/components/block-tools/use-block-toolbar-popover-props.js +68 -12
  597. package/src/components/block-variation-picker/{style.scss → content.scss} +0 -0
  598. package/src/components/block-vertical-alignment-control/icons.js +12 -0
  599. package/src/components/block-vertical-alignment-control/test/index.js +3 -11
  600. package/src/components/block-vertical-alignment-control/ui.js +16 -6
  601. package/src/components/button-block-appender/{style.scss → content.scss} +0 -0
  602. package/src/components/color-style-selector/index.js +1 -1
  603. package/src/components/colors/test/with-colors.js +2 -8
  604. package/src/components/date-format-picker/index.js +23 -24
  605. package/src/components/date-format-picker/style.scss +0 -6
  606. package/src/components/default-block-appender/content.scss +18 -0
  607. package/src/components/default-block-appender/test/index.js +2 -8
  608. package/src/components/default-style-picker/index.js +1 -0
  609. package/src/components/font-family/index.js +1 -6
  610. package/src/components/font-sizes/fluid-utils.js +1 -1
  611. package/src/components/font-sizes/utils.js +1 -1
  612. package/src/components/font-sizes/with-font-sizes.js +33 -33
  613. package/src/components/global-styles/README.md +77 -0
  614. package/src/components/global-styles/context.js +15 -0
  615. package/src/components/global-styles/hooks.js +145 -0
  616. package/src/components/global-styles/index.js +7 -0
  617. package/src/components/global-styles/test/typography-utils.js +393 -0
  618. package/src/components/global-styles/test/use-global-styles-output.js +814 -0
  619. package/src/components/global-styles/test/utils.js +206 -0
  620. package/src/components/global-styles/typography-utils.js +87 -0
  621. package/src/components/global-styles/use-global-styles-output.js +1088 -0
  622. package/src/components/global-styles/utils.js +373 -0
  623. package/src/components/height-control/README.md +55 -0
  624. package/src/components/height-control/index.js +13 -1
  625. package/src/components/iframe/index.js +52 -19
  626. package/src/components/iframe/use-compatibility-styles.js +6 -0
  627. package/src/components/image-editor/constants.js +1 -1
  628. package/src/components/image-editor/context.js +5 -9
  629. package/src/components/image-editor/cropper.js +3 -1
  630. package/src/components/image-editor/index.js +13 -4
  631. package/src/components/image-editor/use-transform-image.js +14 -55
  632. package/src/components/image-size-control/index.js +2 -6
  633. package/src/components/index.js +2 -6
  634. package/src/components/inner-blocks/index.js +29 -33
  635. package/src/components/inner-blocks/index.native.js +27 -47
  636. package/src/components/inner-blocks/use-block-context.js +47 -0
  637. package/src/components/inserter/block-patterns-explorer/explorer.js +0 -1
  638. package/src/components/inserter/block-patterns-tab.js +14 -4
  639. package/src/components/inserter/block-types-tab.js +3 -4
  640. package/src/components/inserter/hooks/use-patterns-state.js +1 -6
  641. package/src/components/inserter/index.js +46 -42
  642. package/src/components/inserter/media-tab/hooks.js +167 -65
  643. package/src/components/inserter/media-tab/media-list.js +94 -26
  644. package/src/components/inserter/media-tab/media-panel.js +9 -20
  645. package/src/components/inserter/media-tab/media-tab.js +12 -4
  646. package/src/components/inserter/media-tab/utils.js +20 -10
  647. package/src/components/inserter/menu.js +9 -4
  648. package/src/components/inserter/preview-panel.js +4 -2
  649. package/src/components/inserter/search-results.js +2 -6
  650. package/src/components/inserter/stories/index.js +9 -9
  651. package/src/components/inserter/style.scss +58 -11
  652. package/src/components/inserter/test/__snapshots__/index.native.js.snap +117 -0
  653. package/src/components/inserter/test/index.native.js +255 -1
  654. package/src/components/inserter-list-item/index.js +0 -7
  655. package/src/components/inspector-controls/README.md +3 -7
  656. package/src/components/inspector-controls/fill.js +15 -1
  657. package/src/components/inspector-controls/fill.native.js +14 -1
  658. package/src/components/inspector-controls/groups.js +5 -0
  659. package/src/components/inspector-controls/index.js +2 -6
  660. package/src/components/inspector-controls/slot.js +14 -1
  661. package/src/components/inspector-controls/slot.native.js +14 -1
  662. package/src/components/inspector-controls-tabs/advanced-controls-panel.js +1 -1
  663. package/src/components/inspector-controls-tabs/index.js +2 -4
  664. package/src/components/inspector-controls-tabs/position-controls-panel.js +37 -0
  665. package/src/components/inspector-controls-tabs/settings-tab.js +2 -0
  666. package/src/components/inspector-controls-tabs/style.scss +15 -0
  667. package/src/components/inspector-controls-tabs/styles-tab.js +5 -7
  668. package/src/components/inspector-controls-tabs/use-inspector-controls-tabs.js +24 -18
  669. package/src/components/justify-content-control/ui.js +9 -0
  670. package/src/components/link-control/index.js +59 -23
  671. package/src/components/link-control/search-input.js +1 -0
  672. package/src/components/link-control/style.scss +8 -24
  673. package/src/components/link-control/test/index.js +134 -5
  674. package/src/components/list-view/block.js +1 -1
  675. package/src/components/list-view/style.scss +13 -3
  676. package/src/components/list-view/use-list-view-drop-zone.js +1 -1
  677. package/src/components/media-replace-flow/test/index.js +4 -12
  678. package/src/components/media-upload/index.native.js +2 -2
  679. package/src/components/off-canvas-editor/README.md +2 -2
  680. package/src/components/off-canvas-editor/appender.js +82 -76
  681. package/src/components/off-canvas-editor/block-contents.js +84 -23
  682. package/src/components/off-canvas-editor/block-select-button.js +12 -1
  683. package/src/components/off-canvas-editor/block.js +31 -102
  684. package/src/components/off-canvas-editor/branch.js +32 -5
  685. package/src/components/off-canvas-editor/index.js +19 -24
  686. package/src/components/off-canvas-editor/link-ui.js +2 -2
  687. package/src/components/off-canvas-editor/style.scss +5 -1
  688. package/src/components/off-canvas-editor/use-list-view-drop-zone.js +1 -1
  689. package/src/components/provider/index.js +33 -11
  690. package/src/components/provider/index.native.js +4 -3
  691. package/src/components/provider/test/experimental-provider.js +94 -0
  692. package/src/components/provider/test/use-block-sync.js +10 -0
  693. package/src/components/responsive-block-control/test/index.js +1 -5
  694. package/src/components/rich-text/use-before-input-rules.js +10 -2
  695. package/src/components/rich-text/use-enter.js +4 -4
  696. package/src/components/rich-text/utils.js +1 -1
  697. package/src/components/spacing-sizes-control/utils.js +2 -7
  698. package/src/components/tool-selector/index.js +1 -1
  699. package/src/components/url-input/README.md +5 -0
  700. package/src/components/url-input/button.js +1 -0
  701. package/src/components/url-input/index.js +15 -1
  702. package/src/components/url-input/test/button.js +24 -24
  703. package/src/components/url-popover/image-url-input-ui.js +7 -8
  704. package/src/components/url-popover/link-editor.js +1 -0
  705. package/src/components/url-popover/style.scss +0 -10
  706. package/src/components/use-block-display-information/index.js +1 -1
  707. package/src/components/use-paste-styles/index.js +230 -0
  708. package/src/components/warning/{style.scss → content.scss} +0 -0
  709. package/src/components/warning/test/index.js +1 -5
  710. package/src/components/writing-flow/use-arrow-nav.js +20 -28
  711. package/src/content.scss +8 -0
  712. package/src/experiments.js +27 -0
  713. package/src/experiments.native.js +25 -0
  714. package/src/hooks/anchor.js +2 -1
  715. package/src/hooks/border.js +1 -1
  716. package/src/hooks/child-layout.js +6 -1
  717. package/src/hooks/color-panel.js +1 -1
  718. package/src/hooks/color.js +3 -3
  719. package/src/hooks/custom-class-name.js +2 -1
  720. package/src/hooks/dimensions.js +6 -6
  721. package/src/hooks/index.js +1 -0
  722. package/src/hooks/layout.scss +4 -0
  723. package/src/hooks/margin.js +1 -0
  724. package/src/hooks/metadata.js +1 -2
  725. package/src/hooks/padding.js +1 -0
  726. package/src/hooks/position.js +391 -0
  727. package/src/hooks/position.scss +18 -0
  728. package/src/hooks/supports.js +302 -0
  729. package/src/hooks/test/__snapshots__/align.native.js.snap +73 -0
  730. package/src/hooks/test/align.native.js +133 -0
  731. package/src/hooks/test/utils.js +104 -0
  732. package/src/hooks/typography.js +1 -1
  733. package/src/hooks/use-color-props.js +3 -3
  734. package/src/hooks/utils.js +68 -2
  735. package/src/index.js +1 -0
  736. package/src/layouts/constrained.js +3 -0
  737. package/src/layouts/flex.js +66 -14
  738. package/src/layouts/flow.js +0 -9
  739. package/src/store/actions.js +2 -26
  740. package/src/store/defaults.js +7 -2
  741. package/src/store/index.js +8 -2
  742. package/src/store/private-actions.js +65 -0
  743. package/src/store/private-selectors.js +10 -0
  744. package/src/store/reducer.js +8 -3
  745. package/src/store/selectors.js +108 -57
  746. package/src/store/test/actions.js +0 -18
  747. package/src/store/test/private-actions.js +22 -0
  748. package/src/store/test/private-selectors.js +24 -0
  749. package/src/store/test/reducer.js +45 -3
  750. package/src/store/test/selectors.js +64 -39
  751. package/src/style.scss +5 -6
  752. package/src/utils/block-variation-transforms.js +1 -1
  753. package/src/utils/parse-css-unit-to-px.js +3 -1
  754. package/src/utils/test/parse-css-unit-to-px.js +16 -24
  755. package/src/utils/transform-styles/index.js +1 -6
  756. package/build/components/inner-blocks/get-block-context.js +0 -45
  757. package/build/components/inner-blocks/get-block-context.js.map +0 -1
  758. package/build/components/off-canvas-editor/block-edit-button.js +0 -50
  759. package/build/components/off-canvas-editor/block-edit-button.js.map +0 -1
  760. package/build-module/components/inner-blocks/get-block-context.js +0 -37
  761. package/build-module/components/inner-blocks/get-block-context.js.map +0 -1
  762. package/build-module/components/off-canvas-editor/block-edit-button.js +0 -35
  763. package/build-module/components/off-canvas-editor/block-edit-button.js.map +0 -1
  764. package/src/components/inner-blocks/get-block-context.js +0 -39
  765. package/src/components/off-canvas-editor/block-edit-button.js +0 -27
@@ -0,0 +1,302 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { getBlockSupport, hasBlockSupport } from '@wordpress/blocks';
5
+ import { Platform } from '@wordpress/element';
6
+
7
+ const ALIGN_SUPPORT_KEY = 'align';
8
+ const ALIGN_WIDE_SUPPORT_KEY = 'alignWide';
9
+ const BORDER_SUPPORT_KEY = '__experimentalBorder';
10
+ const COLOR_SUPPORT_KEY = 'color';
11
+ const CUSTOM_CLASS_NAME_SUPPORT_KEY = 'customClassName';
12
+ const FONT_FAMILY_SUPPORT_KEY = 'typography.__experimentalFontFamily';
13
+ const FONT_SIZE_SUPPORT_KEY = 'typography.fontSize';
14
+ const LINE_HEIGHT_SUPPORT_KEY = 'typography.lineHeight';
15
+ /**
16
+ * Key within block settings' support array indicating support for font style.
17
+ */
18
+ const FONT_STYLE_SUPPORT_KEY = 'typography.__experimentalFontStyle';
19
+ /**
20
+ * Key within block settings' support array indicating support for font weight.
21
+ */
22
+ const FONT_WEIGHT_SUPPORT_KEY = 'typography.__experimentalFontWeight';
23
+ /**
24
+ * Key within block settings' supports array indicating support for text
25
+ * decorations e.g. settings found in `block.json`.
26
+ */
27
+ const TEXT_DECORATION_SUPPORT_KEY = 'typography.__experimentalTextDecoration';
28
+ /**
29
+ * Key within block settings' supports array indicating support for text
30
+ * transforms e.g. settings found in `block.json`.
31
+ */
32
+ const TEXT_TRANSFORM_SUPPORT_KEY = 'typography.__experimentalTextTransform';
33
+ /**
34
+ * Key within block settings' supports array indicating support for letter-spacing
35
+ * e.g. settings found in `block.json`.
36
+ */
37
+ const LETTER_SPACING_SUPPORT_KEY = 'typography.__experimentalLetterSpacing';
38
+ const LAYOUT_SUPPORT_KEY = '__experimentalLayout';
39
+ const TYPOGRAPHY_SUPPORT_KEYS = [
40
+ LINE_HEIGHT_SUPPORT_KEY,
41
+ FONT_SIZE_SUPPORT_KEY,
42
+ FONT_STYLE_SUPPORT_KEY,
43
+ FONT_WEIGHT_SUPPORT_KEY,
44
+ FONT_FAMILY_SUPPORT_KEY,
45
+ TEXT_DECORATION_SUPPORT_KEY,
46
+ TEXT_TRANSFORM_SUPPORT_KEY,
47
+ LETTER_SPACING_SUPPORT_KEY,
48
+ ];
49
+ const SPACING_SUPPORT_KEY = 'spacing';
50
+ const styleSupportKeys = [
51
+ ...TYPOGRAPHY_SUPPORT_KEYS,
52
+ BORDER_SUPPORT_KEY,
53
+ COLOR_SUPPORT_KEY,
54
+ SPACING_SUPPORT_KEY,
55
+ ];
56
+
57
+ /**
58
+ * Returns true if the block defines support for align.
59
+ *
60
+ * @param {string|Object} nameOrType Block name or type object.
61
+ * @return {boolean} Whether the block supports the feature.
62
+ */
63
+ export const hasAlignSupport = ( nameOrType ) =>
64
+ hasBlockSupport( nameOrType, ALIGN_SUPPORT_KEY );
65
+
66
+ /**
67
+ * Returns the block support value for align, if defined.
68
+ *
69
+ * @param {string|Object} nameOrType Block name or type object.
70
+ * @return {unknown} The block support value.
71
+ */
72
+ export const getAlignSupport = ( nameOrType ) =>
73
+ getBlockSupport( nameOrType, ALIGN_SUPPORT_KEY );
74
+
75
+ /**
76
+ * Returns true if the block defines support for align wide.
77
+ *
78
+ * @param {string|Object} nameOrType Block name or type object.
79
+ * @return {boolean} Whether the block supports the feature.
80
+ */
81
+ export const hasAlignWideSupport = ( nameOrType ) =>
82
+ hasBlockSupport( nameOrType, ALIGN_WIDE_SUPPORT_KEY );
83
+
84
+ /**
85
+ * Returns the block support value for align wide, if defined.
86
+ *
87
+ * @param {string|Object} nameOrType Block name or type object.
88
+ * @return {unknown} The block support value.
89
+ */
90
+ export const getAlignWideSupport = ( nameOrType ) =>
91
+ getBlockSupport( nameOrType, ALIGN_WIDE_SUPPORT_KEY );
92
+
93
+ /**
94
+ * Determine whether there is block support for border properties.
95
+ *
96
+ * @param {string|Object} nameOrType Block name or type object.
97
+ * @param {string} feature Border feature to check support for.
98
+ *
99
+ * @return {boolean} Whether there is support.
100
+ */
101
+ export function hasBorderSupport( nameOrType, feature = 'any' ) {
102
+ if ( Platform.OS !== 'web' ) {
103
+ return false;
104
+ }
105
+
106
+ const support = getBlockSupport( nameOrType, BORDER_SUPPORT_KEY );
107
+
108
+ if ( support === true ) {
109
+ return true;
110
+ }
111
+
112
+ if ( feature === 'any' ) {
113
+ return !! (
114
+ support?.color ||
115
+ support?.radius ||
116
+ support?.width ||
117
+ support?.style
118
+ );
119
+ }
120
+
121
+ return !! support?.[ feature ];
122
+ }
123
+
124
+ /**
125
+ * Get block support for border properties.
126
+ *
127
+ * @param {string|Object} nameOrType Block name or type object.
128
+ * @param {string} feature Border feature to get.
129
+ *
130
+ * @return {unknown} The block support.
131
+ */
132
+ export const getBorderSupport = ( nameOrType, feature ) =>
133
+ getBlockSupport( nameOrType, [ BORDER_SUPPORT_KEY, feature ] );
134
+
135
+ /**
136
+ * Returns true if the block defines support for color.
137
+ *
138
+ * @param {string|Object} nameOrType Block name or type object.
139
+ * @return {boolean} Whether the block supports the feature.
140
+ */
141
+ export const hasColorSupport = ( nameOrType ) => {
142
+ const colorSupport = getBlockSupport( nameOrType, COLOR_SUPPORT_KEY );
143
+ return (
144
+ colorSupport &&
145
+ ( colorSupport.link === true ||
146
+ colorSupport.gradient === true ||
147
+ colorSupport.background !== false ||
148
+ colorSupport.text !== false )
149
+ );
150
+ };
151
+
152
+ /**
153
+ * Returns true if the block defines support for link color.
154
+ *
155
+ * @param {string|Object} nameOrType Block name or type object.
156
+ * @return {boolean} Whether the block supports the feature.
157
+ */
158
+ export const hasLinkColorSupport = ( nameOrType ) => {
159
+ if ( Platform.OS !== 'web' ) {
160
+ return false;
161
+ }
162
+
163
+ const colorSupport = getBlockSupport( nameOrType, COLOR_SUPPORT_KEY );
164
+
165
+ return (
166
+ colorSupport !== null &&
167
+ typeof colorSupport === 'object' &&
168
+ !! colorSupport.link
169
+ );
170
+ };
171
+
172
+ /**
173
+ * Returns true if the block defines support for gradient color.
174
+ *
175
+ * @param {string|Object} nameOrType Block name or type object.
176
+ * @return {boolean} Whether the block supports the feature.
177
+ */
178
+ export const hasGradientSupport = ( nameOrType ) => {
179
+ const colorSupport = getBlockSupport( nameOrType, COLOR_SUPPORT_KEY );
180
+
181
+ return (
182
+ colorSupport !== null &&
183
+ typeof colorSupport === 'object' &&
184
+ !! colorSupport.gradients
185
+ );
186
+ };
187
+
188
+ /**
189
+ * Returns true if the block defines support for background color.
190
+ *
191
+ * @param {string|Object} nameOrType Block name or type object.
192
+ * @return {boolean} Whether the block supports the feature.
193
+ */
194
+ export const hasBackgroundColorSupport = ( nameOrType ) => {
195
+ const colorSupport = getBlockSupport( nameOrType, COLOR_SUPPORT_KEY );
196
+
197
+ return colorSupport && colorSupport.background !== false;
198
+ };
199
+
200
+ /**
201
+ * Returns true if the block defines support for background color.
202
+ *
203
+ * @param {string|Object} nameOrType Block name or type object.
204
+ * @return {boolean} Whether the block supports the feature.
205
+ */
206
+ export const hasTextColorSupport = ( nameOrType ) => {
207
+ const colorSupport = getBlockSupport( nameOrType, COLOR_SUPPORT_KEY );
208
+
209
+ return colorSupport && colorSupport.text !== false;
210
+ };
211
+
212
+ /**
213
+ * Get block support for color properties.
214
+ *
215
+ * @param {string|Object} nameOrType Block name or type object.
216
+ * @param {string} feature Color feature to get.
217
+ *
218
+ * @return {unknown} The block support.
219
+ */
220
+ export const getColorSupport = ( nameOrType, feature ) =>
221
+ getBlockSupport( nameOrType, [ COLOR_SUPPORT_KEY, feature ] );
222
+
223
+ /**
224
+ * Returns true if the block defines support for custom class name.
225
+ *
226
+ * @param {string|Object} nameOrType Block name or type object.
227
+ * @return {boolean} Whether the block supports the feature.
228
+ */
229
+ export const hasCustomClassNameSupport = ( nameOrType ) =>
230
+ hasBlockSupport( nameOrType, CUSTOM_CLASS_NAME_SUPPORT_KEY, true );
231
+
232
+ /**
233
+ * Returns the block support value for custom class name, if defined.
234
+ *
235
+ * @param {string|Object} nameOrType Block name or type object.
236
+ * @return {unknown} The block support value.
237
+ */
238
+ export const getCustomClassNameSupport = ( nameOrType ) =>
239
+ getBlockSupport( nameOrType, CUSTOM_CLASS_NAME_SUPPORT_KEY, true );
240
+
241
+ /**
242
+ * Returns true if the block defines support for font family.
243
+ *
244
+ * @param {string|Object} nameOrType Block name or type object.
245
+ * @return {boolean} Whether the block supports the feature.
246
+ */
247
+ export const hasFontFamilySupport = ( nameOrType ) =>
248
+ hasBlockSupport( nameOrType, FONT_FAMILY_SUPPORT_KEY );
249
+
250
+ /**
251
+ * Returns the block support value for font family, if defined.
252
+ *
253
+ * @param {string|Object} nameOrType Block name or type object.
254
+ * @return {unknown} The block support value.
255
+ */
256
+ export const getFontFamilySupport = ( nameOrType ) =>
257
+ getBlockSupport( nameOrType, FONT_FAMILY_SUPPORT_KEY );
258
+
259
+ /**
260
+ * Returns true if the block defines support for font size.
261
+ *
262
+ * @param {string|Object} nameOrType Block name or type object.
263
+ * @return {boolean} Whether the block supports the feature.
264
+ */
265
+ export const hasFontSizeSupport = ( nameOrType ) =>
266
+ hasBlockSupport( nameOrType, FONT_SIZE_SUPPORT_KEY );
267
+
268
+ /**
269
+ * Returns the block support value for font size, if defined.
270
+ *
271
+ * @param {string|Object} nameOrType Block name or type object.
272
+ * @return {unknown} The block support value.
273
+ */
274
+ export const getFontSizeSupport = ( nameOrType ) =>
275
+ getBlockSupport( nameOrType, FONT_SIZE_SUPPORT_KEY );
276
+
277
+ /**
278
+ * Returns true if the block defines support for layout.
279
+ *
280
+ * @param {string|Object} nameOrType Block name or type object.
281
+ * @return {boolean} Whether the block supports the feature.
282
+ */
283
+ export const hasLayoutSupport = ( nameOrType ) =>
284
+ hasBlockSupport( nameOrType, LAYOUT_SUPPORT_KEY );
285
+
286
+ /**
287
+ * Returns the block support value for layout, if defined.
288
+ *
289
+ * @param {string|Object} nameOrType Block name or type object.
290
+ * @return {unknown} The block support value.
291
+ */
292
+ export const getLayoutSupport = ( nameOrType ) =>
293
+ getBlockSupport( nameOrType, LAYOUT_SUPPORT_KEY );
294
+
295
+ /**
296
+ * Returns true if the block defines support for style.
297
+ *
298
+ * @param {string|Object} nameOrType Block name or type object.
299
+ * @return {boolean} Whether the block supports the feature.
300
+ */
301
+ export const hasStyleSupport = ( nameOrType ) =>
302
+ styleSupportKeys.some( ( key ) => hasBlockSupport( nameOrType, key ) );
@@ -0,0 +1,73 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Align options for group block sets Full width option 1`] = `
4
+ "<!-- wp:group {\\"align\\":\\"full\\",\\"layout\\":{\\"type\\":\\"constrained\\"}} -->
5
+ <div class=\\"wp-block-group alignfull\\"></div>
6
+ <!-- /wp:group -->"
7
+ `;
8
+
9
+ exports[`Align options for group block sets None option 1`] = `
10
+ "<!-- wp:group {\\"layout\\":{\\"type\\":\\"constrained\\"}} -->
11
+ <div class=\\"wp-block-group\\"></div>
12
+ <!-- /wp:group -->"
13
+ `;
14
+
15
+ exports[`Align options for group block sets Wide width option 1`] = `
16
+ "<!-- wp:group {\\"align\\":\\"wide\\",\\"layout\\":{\\"type\\":\\"constrained\\"}} -->
17
+ <div class=\\"wp-block-group alignwide\\"></div>
18
+ <!-- /wp:group -->"
19
+ `;
20
+
21
+ exports[`Align options for media block sets Align center option 1`] = `
22
+ "<!-- wp:image {\\"align\\":\\"center\\",\\"id\\":1,\\"sizeSlug\\":\\"large\\",\\"linkDestination\\":\\"none\\"} -->
23
+ <figure class=\\"wp-block-image aligncenter size-large\\"><img src=\\"https://test-site.files.wordpress.com/local-image-1.jpeg\\" alt=\\"\\" class=\\"wp-image-1\\"/></figure>
24
+ <!-- /wp:image -->"
25
+ `;
26
+
27
+ exports[`Align options for media block sets Align left option 1`] = `
28
+ "<!-- wp:image {\\"align\\":\\"left\\",\\"id\\":1,\\"sizeSlug\\":\\"large\\",\\"linkDestination\\":\\"none\\"} -->
29
+ <figure class=\\"wp-block-image alignleft size-large\\"><img src=\\"https://test-site.files.wordpress.com/local-image-1.jpeg\\" alt=\\"\\" class=\\"wp-image-1\\"/></figure>
30
+ <!-- /wp:image -->"
31
+ `;
32
+
33
+ exports[`Align options for media block sets Align right option 1`] = `
34
+ "<!-- wp:image {\\"align\\":\\"right\\",\\"id\\":1,\\"sizeSlug\\":\\"large\\",\\"linkDestination\\":\\"none\\"} -->
35
+ <figure class=\\"wp-block-image alignright size-large\\"><img src=\\"https://test-site.files.wordpress.com/local-image-1.jpeg\\" alt=\\"\\" class=\\"wp-image-1\\"/></figure>
36
+ <!-- /wp:image -->"
37
+ `;
38
+
39
+ exports[`Align options for media block sets Full width option 1`] = `
40
+ "<!-- wp:image {\\"align\\":\\"full\\",\\"id\\":1,\\"sizeSlug\\":\\"large\\",\\"linkDestination\\":\\"none\\"} -->
41
+ <figure class=\\"wp-block-image alignfull size-large\\"><img src=\\"https://test-site.files.wordpress.com/local-image-1.jpeg\\" alt=\\"\\" class=\\"wp-image-1\\"/></figure>
42
+ <!-- /wp:image -->"
43
+ `;
44
+
45
+ exports[`Align options for media block sets None option 1`] = `
46
+ "<!-- wp:image {\\"id\\":1,\\"sizeSlug\\":\\"large\\",\\"linkDestination\\":\\"none\\"} -->
47
+ <figure class=\\"wp-block-image size-large\\"><img src=\\"https://test-site.files.wordpress.com/local-image-1.jpeg\\" alt=\\"\\" class=\\"wp-image-1\\"/></figure>
48
+ <!-- /wp:image -->"
49
+ `;
50
+
51
+ exports[`Align options for media block sets Wide width option 1`] = `
52
+ "<!-- wp:image {\\"align\\":\\"wide\\",\\"id\\":1,\\"sizeSlug\\":\\"large\\",\\"linkDestination\\":\\"none\\"} -->
53
+ <figure class=\\"wp-block-image alignwide size-large\\"><img src=\\"https://test-site.files.wordpress.com/local-image-1.jpeg\\" alt=\\"\\" class=\\"wp-image-1\\"/></figure>
54
+ <!-- /wp:image -->"
55
+ `;
56
+
57
+ exports[`Align options for text block sets Align text center option 1`] = `
58
+ "<!-- wp:paragraph {\\"align\\":\\"center\\"} -->
59
+ <p class=\\"has-text-align-center\\"></p>
60
+ <!-- /wp:paragraph -->"
61
+ `;
62
+
63
+ exports[`Align options for text block sets Align text left option 1`] = `
64
+ "<!-- wp:paragraph {\\"align\\":\\"left\\"} -->
65
+ <p class=\\"has-text-align-left\\"></p>
66
+ <!-- /wp:paragraph -->"
67
+ `;
68
+
69
+ exports[`Align options for text block sets Align text right option 1`] = `
70
+ "<!-- wp:paragraph {\\"align\\":\\"right\\"} -->
71
+ <p class=\\"has-text-align-right\\"></p>
72
+ <!-- /wp:paragraph -->"
73
+ `;
@@ -0,0 +1,133 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import {
5
+ addBlock,
6
+ getEditorHtml,
7
+ initializeEditor,
8
+ getBlock,
9
+ fireEvent,
10
+ within,
11
+ } from 'test/helpers';
12
+
13
+ /**
14
+ * WordPress dependencies
15
+ */
16
+ import { getBlockTypes, unregisterBlockType } from '@wordpress/blocks';
17
+ import { registerCoreBlocks } from '@wordpress/block-library';
18
+
19
+ const imageHTML = `<!-- wp:image {"id":1,"sizeSlug":"large","linkDestination":"none"} -->
20
+ <figure class="wp-block-image size-large"><img src="https://test-site.files.wordpress.com/local-image-1.jpeg" alt="" class="wp-image-1"/></figure>
21
+ <!-- /wp:image -->`;
22
+
23
+ beforeAll( () => {
24
+ // Register all core blocks
25
+ registerCoreBlocks();
26
+ } );
27
+
28
+ afterAll( () => {
29
+ // Clean up registered blocks
30
+ getBlockTypes().forEach( ( block ) => {
31
+ unregisterBlockType( block.name );
32
+ } );
33
+ } );
34
+
35
+ describe( 'Align options', () => {
36
+ describe( 'for media block', () => {
37
+ [
38
+ 'None',
39
+ 'Align left',
40
+ 'Align center',
41
+ 'Align right',
42
+ 'Wide width',
43
+ 'Full width',
44
+ ].forEach( ( alignmentOption ) =>
45
+ it( `sets ${ alignmentOption } option`, async () => {
46
+ const screen = await initializeEditor( {
47
+ initialHtml: imageHTML,
48
+ } );
49
+ const { getByLabelText } = screen;
50
+
51
+ // Get Image block
52
+ const imageBlock = await getBlock( screen, 'Image' );
53
+ expect( imageBlock ).toBeVisible();
54
+ fireEvent.press( imageBlock );
55
+
56
+ // Open alignments menu
57
+ const alignmentButtons = getByLabelText( 'Align' );
58
+ fireEvent.press( alignmentButtons );
59
+
60
+ // Select alignment option.
61
+ fireEvent.press( await getByLabelText( alignmentOption ) );
62
+
63
+ expect( getEditorHtml() ).toMatchSnapshot();
64
+ } )
65
+ );
66
+ } );
67
+
68
+ describe( 'for text block', () => {
69
+ [ 'Align text left', 'Align text center', 'Align text right' ].forEach(
70
+ ( alignmentOption ) =>
71
+ it( `sets ${ alignmentOption } option`, async () => {
72
+ const screen = await initializeEditor();
73
+ const { getByLabelText } = screen;
74
+
75
+ // Add Paragraph block
76
+ await addBlock( screen, 'Paragraph' );
77
+
78
+ // Get Paragraph block
79
+ const paragraphBlock = await getBlock(
80
+ screen,
81
+ 'Paragraph'
82
+ );
83
+ expect( paragraphBlock ).toBeVisible();
84
+
85
+ // Open alignments menu
86
+ const alignmentButtons = getByLabelText( 'Align text' );
87
+ fireEvent.press( alignmentButtons );
88
+
89
+ // Select alignment option.
90
+ fireEvent.press( await getByLabelText( alignmentOption ) );
91
+
92
+ expect( getEditorHtml() ).toMatchSnapshot();
93
+ } )
94
+ );
95
+ } );
96
+
97
+ describe( 'for group block', () => {
98
+ [ 'None', 'Wide width', 'Full width' ].forEach( ( alignmentOption ) =>
99
+ it( `sets ${ alignmentOption } option`, async () => {
100
+ const screen = await initializeEditor();
101
+ const { getByLabelText } = screen;
102
+
103
+ // Add Group block
104
+ await addBlock( screen, 'Group' );
105
+
106
+ // Get Paragraph block
107
+ const groupBlock = await getBlock( screen, 'Group' );
108
+ expect( groupBlock ).toBeVisible();
109
+
110
+ // Trigger inner blocks layout
111
+ const innerBlockListWrapper = await within(
112
+ groupBlock
113
+ ).findByTestId( 'block-list-wrapper' );
114
+ fireEvent( innerBlockListWrapper, 'layout', {
115
+ nativeEvent: {
116
+ layout: {
117
+ width: 300,
118
+ },
119
+ },
120
+ } );
121
+
122
+ // Open alignments menu
123
+ const alignmentButtons = getByLabelText( 'Align' );
124
+ fireEvent.press( alignmentButtons );
125
+
126
+ // Select alignment option.
127
+ fireEvent.press( await getByLabelText( alignmentOption ) );
128
+
129
+ expect( getEditorHtml() ).toMatchSnapshot();
130
+ } )
131
+ );
132
+ } );
133
+ } );
@@ -7,9 +7,113 @@ import { applyFilters } from '@wordpress/hooks';
7
7
  * Internal dependencies
8
8
  */
9
9
  import '../anchor';
10
+ import { immutableSet } from '../utils';
10
11
 
11
12
  const noop = () => {};
12
13
 
14
+ describe( 'immutableSet', () => {
15
+ describe( 'handling falsy values properly', () => {
16
+ it( 'should create a new object if `undefined` is passed', () => {
17
+ const result = immutableSet( undefined, 'test', 1 );
18
+
19
+ expect( result ).toEqual( { test: 1 } );
20
+ } );
21
+
22
+ it( 'should create a new object if `null` is passed', () => {
23
+ const result = immutableSet( null, 'test', 1 );
24
+
25
+ expect( result ).toEqual( { test: 1 } );
26
+ } );
27
+
28
+ it( 'should create a new object if `false` is passed', () => {
29
+ const result = immutableSet( false, 'test', 1 );
30
+
31
+ expect( result ).toEqual( { test: 1 } );
32
+ } );
33
+
34
+ it( 'should create a new object if `0` is passed', () => {
35
+ const result = immutableSet( 0, 'test', 1 );
36
+
37
+ expect( result ).toEqual( { test: 1 } );
38
+ } );
39
+
40
+ it( 'should create a new object if an empty string is passed', () => {
41
+ const result = immutableSet( '', 'test', 1 );
42
+
43
+ expect( result ).toEqual( { test: 1 } );
44
+ } );
45
+
46
+ it( 'should create a new object if a NaN is passed', () => {
47
+ const result = immutableSet( NaN, 'test', 1 );
48
+
49
+ expect( result ).toEqual( { test: 1 } );
50
+ } );
51
+ } );
52
+
53
+ describe( 'manages data assignment properly', () => {
54
+ it( 'assigns value properly when it does not exist', () => {
55
+ const result = immutableSet( {}, 'test', 1 );
56
+
57
+ expect( result ).toEqual( { test: 1 } );
58
+ } );
59
+
60
+ it( 'overrides existing values', () => {
61
+ const result = immutableSet( { test: 1 }, 'test', 2 );
62
+
63
+ expect( result ).toEqual( { test: 2 } );
64
+ } );
65
+
66
+ describe( 'with array notation access', () => {
67
+ it( 'assigns values at deeper levels', () => {
68
+ const result = immutableSet( {}, [ 'foo', 'bar', 'baz' ], 5 );
69
+
70
+ expect( result ).toEqual( { foo: { bar: { baz: 5 } } } );
71
+ } );
72
+
73
+ it( 'overrides existing values at deeper levels', () => {
74
+ const result = immutableSet(
75
+ { foo: { bar: { baz: 1 } } },
76
+ [ 'foo', 'bar', 'baz' ],
77
+ 5
78
+ );
79
+
80
+ expect( result ).toEqual( { foo: { bar: { baz: 5 } } } );
81
+ } );
82
+
83
+ it( 'keeps other properties intact', () => {
84
+ const result = immutableSet(
85
+ { foo: { bar: { baz: 1 } } },
86
+ [ 'foo', 'bar', 'test' ],
87
+ 5
88
+ );
89
+
90
+ expect( result ).toEqual( {
91
+ foo: { bar: { baz: 1, test: 5 } },
92
+ } );
93
+ } );
94
+ } );
95
+ } );
96
+
97
+ describe( 'does not mutate the original object', () => {
98
+ it( 'clones the object at the first level', () => {
99
+ const input = {};
100
+ const result = immutableSet( input, 'test', 1 );
101
+
102
+ expect( result ).not.toBe( input );
103
+ } );
104
+
105
+ it( 'clones the object at deeper levels', () => {
106
+ const input = { foo: { bar: { baz: 1 } } };
107
+ const result = immutableSet( input, [ 'foo', 'bar', 'baz' ], 2 );
108
+
109
+ expect( result ).not.toBe( input );
110
+ expect( result.foo ).not.toBe( input.foo );
111
+ expect( result.foo.bar ).not.toBe( input.foo.bar );
112
+ expect( result.foo.bar.baz ).not.toBe( input.foo.bar.baz );
113
+ } );
114
+ } );
115
+ } );
116
+
13
117
  describe( 'anchor', () => {
14
118
  const blockSettings = {
15
119
  save: noop,
@@ -111,7 +111,7 @@ export function TypographyPanel( props ) {
111
111
  } );
112
112
 
113
113
  return (
114
- <InspectorControls __experimentalGroup="typography">
114
+ <InspectorControls group="typography">
115
115
  { ! isFontFamilyDisabled && (
116
116
  <ToolsPanelItem
117
117
  hasValue={ () => hasFontFamilyValue( props ) }
@@ -92,9 +92,9 @@ export function useColorProps( attributes ) {
92
92
  // Some color settings have a special handling for deprecated flags in `useSetting`,
93
93
  // so we can't unwrap them by doing const { ... } = useSetting('color')
94
94
  // until https://github.com/WordPress/gutenberg/issues/37094 is fixed.
95
- const userPalette = useSetting( 'color.palette.custom' ) || [];
96
- const themePalette = useSetting( 'color.palette.theme' ) || [];
97
- const defaultPalette = useSetting( 'color.palette.default' ) || [];
95
+ const userPalette = useSetting( 'color.palette.custom' );
96
+ const themePalette = useSetting( 'color.palette.theme' );
97
+ const defaultPalette = useSetting( 'color.palette.default' );
98
98
  const gradientsPerOrigin = useSetting( 'color.gradients' ) || EMPTY_OBJECT;
99
99
  const colors = useMemo(
100
100
  () => [