@wordpress/block-library 7.6.0 → 7.9.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 (774) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/build/audio/edit.js +1 -0
  3. package/build/audio/edit.js.map +1 -1
  4. package/build/audio/index.js +6 -1
  5. package/build/audio/index.js.map +1 -1
  6. package/build/audio/save.js +2 -1
  7. package/build/audio/save.js.map +1 -1
  8. package/build/avatar/hooks.js +2 -2
  9. package/build/avatar/hooks.js.map +1 -1
  10. package/build/block/edit.js.map +1 -1
  11. package/build/block/edit.native.js.map +1 -1
  12. package/build/button/deprecated.js +175 -35
  13. package/build/button/deprecated.js.map +1 -1
  14. package/build/button/edit.js +1 -1
  15. package/build/button/edit.js.map +1 -1
  16. package/build/button/edit.native.js.map +1 -1
  17. package/build/button/save.js +1 -1
  18. package/build/button/save.js.map +1 -1
  19. package/build/buttons/deprecated.js.map +1 -1
  20. package/build/buttons/edit.js.map +1 -1
  21. package/build/buttons/edit.native.js.map +1 -1
  22. package/build/column/deprecated.js.map +1 -1
  23. package/build/column/edit.js.map +1 -1
  24. package/build/column/edit.native.js.map +1 -1
  25. package/build/columns/deprecated.js.map +1 -1
  26. package/build/columns/edit.js +1 -1
  27. package/build/columns/edit.js.map +1 -1
  28. package/build/columns/edit.native.js +1 -1
  29. package/build/columns/edit.native.js.map +1 -1
  30. package/build/columns/index.js +3 -1
  31. package/build/columns/index.js.map +1 -1
  32. package/build/columns/utils.js +1 -1
  33. package/build/columns/utils.js.map +1 -1
  34. package/build/columns/variations.js +2 -2
  35. package/build/columns/variations.js.map +1 -1
  36. package/build/comment-author-name/edit.js +3 -3
  37. package/build/comment-author-name/edit.js.map +1 -1
  38. package/build/comment-author-name/index.js +0 -4
  39. package/build/comment-author-name/index.js.map +1 -1
  40. package/build/comment-date/edit.js +4 -4
  41. package/build/comment-date/edit.js.map +1 -1
  42. package/build/comment-date/index.js +0 -4
  43. package/build/comment-date/index.js.map +1 -1
  44. package/build/comment-edit-link/index.js +0 -4
  45. package/build/comment-edit-link/index.js.map +1 -1
  46. package/build/comment-reply-link/index.js +0 -4
  47. package/build/comment-reply-link/index.js.map +1 -1
  48. package/build/comments/edit.js +10 -2
  49. package/build/comments/edit.js.map +1 -1
  50. package/build/comments-title/deprecated.js +0 -3
  51. package/build/comments-title/deprecated.js.map +1 -1
  52. package/build/comments-title/edit.js +1 -1
  53. package/build/comments-title/edit.js.map +1 -1
  54. package/build/cover/controls.native.js.map +1 -1
  55. package/build/cover/deprecated.js +212 -207
  56. package/build/cover/deprecated.js.map +1 -1
  57. package/build/cover/edit/block-controls.js +3 -10
  58. package/build/cover/edit/block-controls.js.map +1 -1
  59. package/build/cover/edit/index.js +34 -31
  60. package/build/cover/edit/index.js.map +1 -1
  61. package/build/cover/edit/inspector-controls.js +34 -6
  62. package/build/cover/edit/inspector-controls.js.map +1 -1
  63. package/build/cover/edit.native.js.map +1 -1
  64. package/build/cover/index.js +1 -0
  65. package/build/cover/index.js.map +1 -1
  66. package/build/cover/save.js +18 -5
  67. package/build/cover/save.js.map +1 -1
  68. package/build/cover/shared.js +14 -17
  69. package/build/cover/shared.js.map +1 -1
  70. package/build/cover/transforms.js.map +1 -1
  71. package/build/embed/deprecated.js +6 -1
  72. package/build/embed/deprecated.js.map +1 -1
  73. package/build/embed/edit.js.map +1 -1
  74. package/build/embed/edit.native.js.map +1 -1
  75. package/build/embed/embed-controls.native.js.map +1 -1
  76. package/build/embed/embed-preview.js +1 -0
  77. package/build/embed/embed-preview.js.map +1 -1
  78. package/build/embed/icons.js +21 -1
  79. package/build/embed/icons.js.map +1 -1
  80. package/build/embed/index.js +6 -1
  81. package/build/embed/index.js.map +1 -1
  82. package/build/embed/save.js +1 -0
  83. package/build/embed/save.js.map +1 -1
  84. package/build/embed/transforms.js +6 -1
  85. package/build/embed/transforms.js.map +1 -1
  86. package/build/embed/util.js +6 -1
  87. package/build/embed/util.js.map +1 -1
  88. package/build/embed/variations.js +11 -0
  89. package/build/embed/variations.js.map +1 -1
  90. package/build/file/edit.js +1 -1
  91. package/build/file/edit.js.map +1 -1
  92. package/build/file/edit.native.js.map +1 -1
  93. package/build/file/index.js.map +1 -1
  94. package/build/file/save.js +9 -1
  95. package/build/file/save.js.map +1 -1
  96. package/build/gallery/edit.js +1 -1
  97. package/build/gallery/edit.js.map +1 -1
  98. package/build/gallery/gallery.js +1 -1
  99. package/build/gallery/gallery.js.map +1 -1
  100. package/build/gallery/gallery.native.js.map +1 -1
  101. package/build/gallery/gap-styles.js +14 -4
  102. package/build/gallery/gap-styles.js.map +1 -1
  103. package/build/gallery/index.js +1 -1
  104. package/build/gallery/index.js.map +1 -1
  105. package/build/gallery/save.js +1 -1
  106. package/build/gallery/save.js.map +1 -1
  107. package/build/gallery/shared.js +27 -10
  108. package/build/gallery/shared.js.map +1 -1
  109. package/build/gallery/transforms.js +2 -2
  110. package/build/gallery/transforms.js.map +1 -1
  111. package/build/gallery/v1/edit.js +3 -3
  112. package/build/gallery/v1/edit.js.map +1 -1
  113. package/build/gallery/v1/gallery-image.js +1 -0
  114. package/build/gallery/v1/gallery-image.js.map +1 -1
  115. package/build/gallery/v1/gallery-image.native.js.map +1 -1
  116. package/build/gallery/v1/gallery.js +1 -1
  117. package/build/gallery/v1/gallery.js.map +1 -1
  118. package/build/gallery/v1/save.js +10 -2
  119. package/build/gallery/v1/save.js.map +1 -1
  120. package/build/group/index.js +1 -0
  121. package/build/group/index.js.map +1 -1
  122. package/build/heading/autogenerate-anchors.js +7 -2
  123. package/build/heading/autogenerate-anchors.js.map +1 -1
  124. package/build/heading/deprecated.js.map +1 -1
  125. package/build/heading/edit.js.map +1 -1
  126. package/build/html/edit.js +11 -20
  127. package/build/html/edit.js.map +1 -1
  128. package/build/html/preview.js +48 -0
  129. package/build/html/preview.js.map +1 -0
  130. package/build/image/deprecated.js.map +1 -1
  131. package/build/image/edit.js +5 -59
  132. package/build/image/edit.js.map +1 -1
  133. package/build/image/edit.native.js +58 -4
  134. package/build/image/edit.native.js.map +1 -1
  135. package/build/image/image.js +4 -13
  136. package/build/image/image.js.map +1 -1
  137. package/build/image/index.js +5 -0
  138. package/build/image/index.js.map +1 -1
  139. package/build/image/save.js +1 -0
  140. package/build/image/save.js.map +1 -1
  141. package/build/image/transforms.js.map +1 -1
  142. package/build/image/utils.js +2 -1
  143. package/build/image/utils.js.map +1 -1
  144. package/build/index.js +1 -1
  145. package/build/index.js.map +1 -1
  146. package/build/latest-comments/edit.js.map +1 -1
  147. package/build/latest-posts/edit.js +1 -1
  148. package/build/latest-posts/edit.js.map +1 -1
  149. package/build/latest-posts/edit.native.js.map +1 -1
  150. package/build/list/index.js.map +1 -1
  151. package/build/list/v2/edit.js.map +1 -1
  152. package/build/list/v2/transforms.js +33 -17
  153. package/build/list/v2/transforms.js.map +1 -1
  154. package/build/list-item/hooks/use-backspace.js.map +1 -1
  155. package/build/list-item/hooks/use-enter.js +7 -4
  156. package/build/list-item/hooks/use-enter.js.map +1 -1
  157. package/build/list-item/hooks/use-indent-list-item.js.map +1 -1
  158. package/build/list-item/hooks/use-outdent-list-item.js +36 -15
  159. package/build/list-item/hooks/use-outdent-list-item.js.map +1 -1
  160. package/build/list-item/hooks/use-space.js.map +1 -1
  161. package/build/list-item/hooks/use-split.js +17 -3
  162. package/build/list-item/hooks/use-split.js.map +1 -1
  163. package/build/media-text/deprecated.js +5 -3
  164. package/build/media-text/deprecated.js.map +1 -1
  165. package/build/media-text/edit.native.js.map +1 -1
  166. package/build/media-text/media-container.js +3 -3
  167. package/build/media-text/media-container.js.map +1 -1
  168. package/build/media-text/media-container.native.js.map +1 -1
  169. package/build/media-text/save.js +3 -1
  170. package/build/media-text/save.js.map +1 -1
  171. package/build/missing/edit.native.js.map +1 -1
  172. package/build/navigation/deprecated.js.map +1 -1
  173. package/build/navigation/edit/index.js +1 -1
  174. package/build/navigation/edit/index.js.map +1 -1
  175. package/build/navigation/edit/navigation-menu-delete-control.js.map +1 -1
  176. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  177. package/build/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  178. package/build/navigation/index.js +9 -0
  179. package/build/navigation/index.js.map +1 -1
  180. package/build/navigation/use-navigation-entities.js.map +1 -1
  181. package/build/navigation/use-navigation-menu.js +72 -38
  182. package/build/navigation/use-navigation-menu.js.map +1 -1
  183. package/build/navigation/use-template-part-area-label.js +4 -1
  184. package/build/navigation/use-template-part-area-label.js.map +1 -1
  185. package/build/navigation/view.js +5 -3
  186. package/build/navigation/view.js.map +1 -1
  187. package/build/navigation-link/edit.js +44 -12
  188. package/build/navigation-link/edit.js.map +1 -1
  189. package/build/navigation-submenu/edit.js.map +1 -1
  190. package/build/navigation-submenu/view.js +5 -3
  191. package/build/navigation-submenu/view.js.map +1 -1
  192. package/build/page-list/convert-to-links-modal.js.map +1 -1
  193. package/build/page-list/edit.js.map +1 -1
  194. package/build/paragraph/deprecated.js +1 -1
  195. package/build/paragraph/deprecated.js.map +1 -1
  196. package/build/pattern/edit.js.map +1 -1
  197. package/build/post-author/edit.js.map +1 -1
  198. package/build/post-author-name/index.js +3 -0
  199. package/build/post-author-name/index.js.map +1 -1
  200. package/build/post-author-name/transforms.js +41 -0
  201. package/build/post-author-name/transforms.js.map +1 -0
  202. package/build/post-comments-form/edit.js +12 -2
  203. package/build/post-comments-form/edit.js.map +1 -1
  204. package/build/post-comments-form/form.js +11 -1
  205. package/build/post-comments-form/form.js.map +1 -1
  206. package/build/post-content/edit.js.map +1 -1
  207. package/build/post-date/edit.js +13 -7
  208. package/build/post-date/edit.js.map +1 -1
  209. package/build/post-featured-image/edit.js +10 -24
  210. package/build/post-featured-image/edit.js.map +1 -1
  211. package/build/post-navigation-link/index.js +4 -0
  212. package/build/post-navigation-link/index.js.map +1 -1
  213. package/build/pullquote/deprecated.js.map +1 -1
  214. package/build/query/edit/index.js +5 -1
  215. package/build/query/edit/index.js.map +1 -1
  216. package/build/query/edit/inspector-controls/parent-control.js.map +1 -1
  217. package/build/query/edit/query-toolbar.js +16 -2
  218. package/build/query/edit/query-toolbar.js.map +1 -1
  219. package/build/quote/v2/edit.js.map +1 -1
  220. package/build/search/edit.js +1 -1
  221. package/build/search/edit.js.map +1 -1
  222. package/build/search/edit.native.js.map +1 -1
  223. package/build/search/index.js +4 -0
  224. package/build/search/index.js.map +1 -1
  225. package/build/separator/use-deprecated-opacity.js.map +1 -1
  226. package/build/shortcode/edit.native.js +16 -13
  227. package/build/shortcode/edit.native.js.map +1 -1
  228. package/build/site-logo/edit.js +3 -12
  229. package/build/site-logo/edit.js.map +1 -1
  230. package/build/social-links/deprecated.js.map +1 -1
  231. package/build/social-links/edit.js +2 -2
  232. package/build/social-links/edit.js.map +1 -1
  233. package/build/social-links/edit.native.js.map +1 -1
  234. package/build/spacer/controls.js.map +1 -1
  235. package/build/table/deprecated.js.map +1 -1
  236. package/build/table/edit.js +1 -0
  237. package/build/table/edit.js.map +1 -1
  238. package/build/table/index.js +6 -1
  239. package/build/table/index.js.map +1 -1
  240. package/build/table/save.js +2 -1
  241. package/build/table/save.js.map +1 -1
  242. package/build/table/state.js.map +1 -1
  243. package/build/table-of-contents/edit.js +11 -3
  244. package/build/table-of-contents/edit.js.map +1 -1
  245. package/build/tag-cloud/edit.js.map +1 -1
  246. package/build/template-part/edit/advanced-controls.js +4 -1
  247. package/build/template-part/edit/advanced-controls.js.map +1 -1
  248. package/build/template-part/edit/index.js.map +1 -1
  249. package/build/template-part/edit/utils/hooks.js +4 -1
  250. package/build/template-part/edit/utils/hooks.js.map +1 -1
  251. package/build/transformationCategories.native.js.map +1 -1
  252. package/build/video/edit-common-settings.js.map +1 -1
  253. package/build/video/edit.js +1 -0
  254. package/build/video/edit.js.map +1 -1
  255. package/build/video/edit.native.js +43 -0
  256. package/build/video/edit.native.js.map +1 -1
  257. package/build/video/index.js +6 -1
  258. package/build/video/index.js.map +1 -1
  259. package/build/video/save.js +1 -0
  260. package/build/video/save.js.map +1 -1
  261. package/build-module/audio/edit.js +2 -1
  262. package/build-module/audio/edit.js.map +1 -1
  263. package/build-module/audio/index.js +6 -1
  264. package/build-module/audio/index.js.map +1 -1
  265. package/build-module/audio/save.js +3 -2
  266. package/build-module/audio/save.js.map +1 -1
  267. package/build-module/avatar/hooks.js +2 -2
  268. package/build-module/avatar/hooks.js.map +1 -1
  269. package/build-module/block/edit.js.map +1 -1
  270. package/build-module/block/edit.native.js.map +1 -1
  271. package/build-module/button/deprecated.js +175 -35
  272. package/build-module/button/deprecated.js.map +1 -1
  273. package/build-module/button/edit.js +2 -2
  274. package/build-module/button/edit.js.map +1 -1
  275. package/build-module/button/edit.native.js.map +1 -1
  276. package/build-module/button/save.js +2 -2
  277. package/build-module/button/save.js.map +1 -1
  278. package/build-module/buttons/deprecated.js.map +1 -1
  279. package/build-module/buttons/edit.js.map +1 -1
  280. package/build-module/buttons/edit.native.js.map +1 -1
  281. package/build-module/column/deprecated.js.map +1 -1
  282. package/build-module/column/edit.js.map +1 -1
  283. package/build-module/column/edit.native.js.map +1 -1
  284. package/build-module/columns/deprecated.js.map +1 -1
  285. package/build-module/columns/edit.js +2 -2
  286. package/build-module/columns/edit.js.map +1 -1
  287. package/build-module/columns/edit.native.js +2 -2
  288. package/build-module/columns/edit.native.js.map +1 -1
  289. package/build-module/columns/index.js +3 -1
  290. package/build-module/columns/index.js.map +1 -1
  291. package/build-module/columns/utils.js +2 -2
  292. package/build-module/columns/utils.js.map +1 -1
  293. package/build-module/columns/variations.js +2 -2
  294. package/build-module/columns/variations.js.map +1 -1
  295. package/build-module/comment-author-name/edit.js +3 -3
  296. package/build-module/comment-author-name/edit.js.map +1 -1
  297. package/build-module/comment-author-name/index.js +0 -4
  298. package/build-module/comment-author-name/index.js.map +1 -1
  299. package/build-module/comment-date/edit.js +4 -4
  300. package/build-module/comment-date/edit.js.map +1 -1
  301. package/build-module/comment-date/index.js +0 -4
  302. package/build-module/comment-date/index.js.map +1 -1
  303. package/build-module/comment-edit-link/index.js +0 -4
  304. package/build-module/comment-edit-link/index.js.map +1 -1
  305. package/build-module/comment-reply-link/index.js +0 -4
  306. package/build-module/comment-reply-link/index.js.map +1 -1
  307. package/build-module/comments/edit.js +10 -2
  308. package/build-module/comments/edit.js.map +1 -1
  309. package/build-module/comments-title/deprecated.js +0 -3
  310. package/build-module/comments-title/deprecated.js.map +1 -1
  311. package/build-module/comments-title/edit.js +1 -1
  312. package/build-module/comments-title/edit.js.map +1 -1
  313. package/build-module/cover/controls.native.js.map +1 -1
  314. package/build-module/cover/deprecated.js +206 -198
  315. package/build-module/cover/deprecated.js.map +1 -1
  316. package/build-module/cover/edit/block-controls.js +3 -8
  317. package/build-module/cover/edit/block-controls.js.map +1 -1
  318. package/build-module/cover/edit/index.js +36 -33
  319. package/build-module/cover/edit/index.js.map +1 -1
  320. package/build-module/cover/edit/inspector-controls.js +32 -7
  321. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  322. package/build-module/cover/edit.native.js.map +1 -1
  323. package/build-module/cover/index.js +1 -0
  324. package/build-module/cover/index.js.map +1 -1
  325. package/build-module/cover/save.js +19 -6
  326. package/build-module/cover/save.js.map +1 -1
  327. package/build-module/cover/shared.js +11 -12
  328. package/build-module/cover/shared.js.map +1 -1
  329. package/build-module/cover/transforms.js.map +1 -1
  330. package/build-module/embed/deprecated.js +6 -1
  331. package/build-module/embed/deprecated.js.map +1 -1
  332. package/build-module/embed/edit.js.map +1 -1
  333. package/build-module/embed/edit.native.js.map +1 -1
  334. package/build-module/embed/embed-controls.native.js.map +1 -1
  335. package/build-module/embed/embed-preview.js +2 -1
  336. package/build-module/embed/embed-preview.js.map +1 -1
  337. package/build-module/embed/icons.js +19 -0
  338. package/build-module/embed/icons.js.map +1 -1
  339. package/build-module/embed/index.js +6 -1
  340. package/build-module/embed/index.js.map +1 -1
  341. package/build-module/embed/save.js +2 -1
  342. package/build-module/embed/save.js.map +1 -1
  343. package/build-module/embed/transforms.js +6 -1
  344. package/build-module/embed/transforms.js.map +1 -1
  345. package/build-module/embed/util.js +6 -1
  346. package/build-module/embed/util.js.map +1 -1
  347. package/build-module/embed/variations.js +12 -1
  348. package/build-module/embed/variations.js.map +1 -1
  349. package/build-module/file/edit.js +2 -2
  350. package/build-module/file/edit.js.map +1 -1
  351. package/build-module/file/edit.native.js.map +1 -1
  352. package/build-module/file/index.js.map +1 -1
  353. package/build-module/file/save.js +7 -2
  354. package/build-module/file/save.js.map +1 -1
  355. package/build-module/gallery/edit.js +2 -2
  356. package/build-module/gallery/edit.js.map +1 -1
  357. package/build-module/gallery/gallery.js +2 -2
  358. package/build-module/gallery/gallery.js.map +1 -1
  359. package/build-module/gallery/gallery.native.js.map +1 -1
  360. package/build-module/gallery/gap-styles.js +14 -4
  361. package/build-module/gallery/gap-styles.js.map +1 -1
  362. package/build-module/gallery/index.js +1 -1
  363. package/build-module/gallery/index.js.map +1 -1
  364. package/build-module/gallery/save.js +2 -2
  365. package/build-module/gallery/save.js.map +1 -1
  366. package/build-module/gallery/shared.js +25 -8
  367. package/build-module/gallery/shared.js.map +1 -1
  368. package/build-module/gallery/transforms.js +3 -3
  369. package/build-module/gallery/transforms.js.map +1 -1
  370. package/build-module/gallery/v1/edit.js +4 -4
  371. package/build-module/gallery/v1/edit.js.map +1 -1
  372. package/build-module/gallery/v1/gallery-image.js +2 -1
  373. package/build-module/gallery/v1/gallery-image.js.map +1 -1
  374. package/build-module/gallery/v1/gallery-image.native.js.map +1 -1
  375. package/build-module/gallery/v1/gallery.js +2 -2
  376. package/build-module/gallery/v1/gallery.js.map +1 -1
  377. package/build-module/gallery/v1/save.js +8 -3
  378. package/build-module/gallery/v1/save.js.map +1 -1
  379. package/build-module/group/index.js +1 -0
  380. package/build-module/group/index.js.map +1 -1
  381. package/build-module/heading/autogenerate-anchors.js +5 -2
  382. package/build-module/heading/autogenerate-anchors.js.map +1 -1
  383. package/build-module/heading/deprecated.js.map +1 -1
  384. package/build-module/heading/edit.js.map +1 -1
  385. package/build-module/html/edit.js +12 -23
  386. package/build-module/html/edit.js.map +1 -1
  387. package/build-module/html/preview.js +38 -0
  388. package/build-module/html/preview.js.map +1 -0
  389. package/build-module/image/deprecated.js.map +1 -1
  390. package/build-module/image/edit.js +5 -56
  391. package/build-module/image/edit.js.map +1 -1
  392. package/build-module/image/edit.native.js +59 -6
  393. package/build-module/image/edit.native.js.map +1 -1
  394. package/build-module/image/image.js +6 -15
  395. package/build-module/image/image.js.map +1 -1
  396. package/build-module/image/index.js +5 -0
  397. package/build-module/image/index.js.map +1 -1
  398. package/build-module/image/save.js +2 -1
  399. package/build-module/image/save.js.map +1 -1
  400. package/build-module/image/transforms.js.map +1 -1
  401. package/build-module/image/utils.js +2 -2
  402. package/build-module/image/utils.js.map +1 -1
  403. package/build-module/index.js +1 -1
  404. package/build-module/index.js.map +1 -1
  405. package/build-module/latest-comments/edit.js.map +1 -1
  406. package/build-module/latest-posts/edit.js +2 -2
  407. package/build-module/latest-posts/edit.js.map +1 -1
  408. package/build-module/latest-posts/edit.native.js.map +1 -1
  409. package/build-module/list/index.js.map +1 -1
  410. package/build-module/list/v2/edit.js.map +1 -1
  411. package/build-module/list/v2/transforms.js +32 -17
  412. package/build-module/list/v2/transforms.js.map +1 -1
  413. package/build-module/list-item/hooks/use-backspace.js.map +1 -1
  414. package/build-module/list-item/hooks/use-enter.js +7 -4
  415. package/build-module/list-item/hooks/use-enter.js.map +1 -1
  416. package/build-module/list-item/hooks/use-indent-list-item.js.map +1 -1
  417. package/build-module/list-item/hooks/use-outdent-list-item.js +34 -15
  418. package/build-module/list-item/hooks/use-outdent-list-item.js.map +1 -1
  419. package/build-module/list-item/hooks/use-space.js.map +1 -1
  420. package/build-module/list-item/hooks/use-split.js +19 -5
  421. package/build-module/list-item/hooks/use-split.js.map +1 -1
  422. package/build-module/media-text/deprecated.js +3 -1
  423. package/build-module/media-text/deprecated.js.map +1 -1
  424. package/build-module/media-text/edit.native.js.map +1 -1
  425. package/build-module/media-text/media-container.js +3 -1
  426. package/build-module/media-text/media-container.js.map +1 -1
  427. package/build-module/media-text/media-container.native.js.map +1 -1
  428. package/build-module/media-text/save.js +4 -1
  429. package/build-module/media-text/save.js.map +1 -1
  430. package/build-module/missing/edit.native.js.map +1 -1
  431. package/build-module/navigation/deprecated.js.map +1 -1
  432. package/build-module/navigation/edit/index.js +1 -1
  433. package/build-module/navigation/edit/index.js.map +1 -1
  434. package/build-module/navigation/edit/navigation-menu-delete-control.js.map +1 -1
  435. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  436. package/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  437. package/build-module/navigation/index.js +9 -0
  438. package/build-module/navigation/index.js.map +1 -1
  439. package/build-module/navigation/use-navigation-entities.js.map +1 -1
  440. package/build-module/navigation/use-navigation-menu.js +73 -39
  441. package/build-module/navigation/use-navigation-menu.js.map +1 -1
  442. package/build-module/navigation/use-template-part-area-label.js +4 -1
  443. package/build-module/navigation/use-template-part-area-label.js.map +1 -1
  444. package/build-module/navigation/view.js +5 -3
  445. package/build-module/navigation/view.js.map +1 -1
  446. package/build-module/navigation-link/edit.js +44 -13
  447. package/build-module/navigation-link/edit.js.map +1 -1
  448. package/build-module/navigation-submenu/edit.js.map +1 -1
  449. package/build-module/navigation-submenu/view.js +5 -3
  450. package/build-module/navigation-submenu/view.js.map +1 -1
  451. package/build-module/page-list/convert-to-links-modal.js.map +1 -1
  452. package/build-module/page-list/edit.js.map +1 -1
  453. package/build-module/paragraph/deprecated.js +2 -2
  454. package/build-module/paragraph/deprecated.js.map +1 -1
  455. package/build-module/pattern/edit.js.map +1 -1
  456. package/build-module/post-author/edit.js.map +1 -1
  457. package/build-module/post-author-name/index.js +2 -0
  458. package/build-module/post-author-name/index.js.map +1 -1
  459. package/build-module/post-author-name/transforms.js +32 -0
  460. package/build-module/post-author-name/transforms.js.map +1 -0
  461. package/build-module/post-comments-form/edit.js +12 -3
  462. package/build-module/post-comments-form/edit.js.map +1 -1
  463. package/build-module/post-comments-form/form.js +7 -1
  464. package/build-module/post-comments-form/form.js.map +1 -1
  465. package/build-module/post-content/edit.js.map +1 -1
  466. package/build-module/post-date/edit.js +15 -9
  467. package/build-module/post-date/edit.js.map +1 -1
  468. package/build-module/post-featured-image/edit.js +10 -23
  469. package/build-module/post-featured-image/edit.js.map +1 -1
  470. package/build-module/post-navigation-link/index.js +4 -0
  471. package/build-module/post-navigation-link/index.js.map +1 -1
  472. package/build-module/pullquote/deprecated.js.map +1 -1
  473. package/build-module/query/edit/index.js +5 -1
  474. package/build-module/query/edit/index.js.map +1 -1
  475. package/build-module/query/edit/inspector-controls/parent-control.js.map +1 -1
  476. package/build-module/query/edit/query-toolbar.js +14 -2
  477. package/build-module/query/edit/query-toolbar.js.map +1 -1
  478. package/build-module/quote/v2/edit.js.map +1 -1
  479. package/build-module/search/edit.js +2 -2
  480. package/build-module/search/edit.js.map +1 -1
  481. package/build-module/search/edit.native.js.map +1 -1
  482. package/build-module/search/index.js +4 -0
  483. package/build-module/search/index.js.map +1 -1
  484. package/build-module/separator/use-deprecated-opacity.js.map +1 -1
  485. package/build-module/shortcode/edit.native.js +17 -13
  486. package/build-module/shortcode/edit.native.js.map +1 -1
  487. package/build-module/site-logo/edit.js +3 -11
  488. package/build-module/site-logo/edit.js.map +1 -1
  489. package/build-module/social-links/deprecated.js.map +1 -1
  490. package/build-module/social-links/edit.js +2 -2
  491. package/build-module/social-links/edit.js.map +1 -1
  492. package/build-module/social-links/edit.native.js.map +1 -1
  493. package/build-module/spacer/controls.js.map +1 -1
  494. package/build-module/table/deprecated.js.map +1 -1
  495. package/build-module/table/edit.js +2 -1
  496. package/build-module/table/edit.js.map +1 -1
  497. package/build-module/table/index.js +6 -1
  498. package/build-module/table/index.js.map +1 -1
  499. package/build-module/table/save.js +3 -2
  500. package/build-module/table/save.js.map +1 -1
  501. package/build-module/table/state.js.map +1 -1
  502. package/build-module/table-of-contents/edit.js +12 -4
  503. package/build-module/table-of-contents/edit.js.map +1 -1
  504. package/build-module/tag-cloud/edit.js.map +1 -1
  505. package/build-module/template-part/edit/advanced-controls.js +4 -1
  506. package/build-module/template-part/edit/advanced-controls.js.map +1 -1
  507. package/build-module/template-part/edit/index.js.map +1 -1
  508. package/build-module/template-part/edit/utils/hooks.js +4 -1
  509. package/build-module/template-part/edit/utils/hooks.js.map +1 -1
  510. package/build-module/transformationCategories.native.js.map +1 -1
  511. package/build-module/video/edit-common-settings.js.map +1 -1
  512. package/build-module/video/edit.js +2 -1
  513. package/build-module/video/edit.js.map +1 -1
  514. package/build-module/video/edit.native.js +42 -1
  515. package/build-module/video/edit.native.js.map +1 -1
  516. package/build-module/video/index.js +6 -1
  517. package/build-module/video/index.js.map +1 -1
  518. package/build-module/video/save.js +2 -1
  519. package/build-module/video/save.js.map +1 -1
  520. package/build-style/audio/style-rtl.css +0 -3
  521. package/build-style/audio/style.css +0 -3
  522. package/build-style/button/style-rtl.css +5 -5
  523. package/build-style/button/style.css +5 -5
  524. package/build-style/common-rtl.css +1 -3
  525. package/build-style/common.css +1 -3
  526. package/build-style/cover/editor-rtl.css +11 -0
  527. package/build-style/cover/editor.css +11 -0
  528. package/build-style/cover/style-rtl.css +33 -25
  529. package/build-style/cover/style.css +33 -25
  530. package/build-style/editor-rtl.css +14 -39
  531. package/build-style/editor.css +14 -39
  532. package/build-style/embed/style-rtl.css +0 -1
  533. package/build-style/embed/style.css +0 -1
  534. package/build-style/file/style-rtl.css +11 -12
  535. package/build-style/file/style.css +11 -12
  536. package/build-style/gallery/style-rtl.css +2 -4
  537. package/build-style/gallery/style.css +2 -4
  538. package/build-style/image/style-rtl.css +0 -3
  539. package/build-style/image/style.css +0 -3
  540. package/build-style/navigation/style-rtl.css +9 -1
  541. package/build-style/navigation/style.css +9 -1
  542. package/build-style/post-comments/style-rtl.css +2 -1
  543. package/build-style/post-comments/style.css +2 -1
  544. package/build-style/post-comments-form/editor-rtl.css +3 -0
  545. package/build-style/post-comments-form/editor.css +3 -0
  546. package/build-style/post-featured-image/editor-rtl.css +0 -27
  547. package/build-style/post-featured-image/editor.css +0 -27
  548. package/build-style/post-template/style-rtl.css +9 -18
  549. package/build-style/post-template/style.css +9 -18
  550. package/build-style/search/style-rtl.css +9 -11
  551. package/build-style/search/style.css +9 -11
  552. package/build-style/site-logo/editor-rtl.css +0 -12
  553. package/build-style/site-logo/editor.css +0 -12
  554. package/build-style/site-logo/style-rtl.css +4 -0
  555. package/build-style/site-logo/style.css +4 -0
  556. package/build-style/style-rtl.css +86 -93
  557. package/build-style/style.css +86 -93
  558. package/build-style/table/style-rtl.css +0 -1
  559. package/build-style/table/style.css +0 -1
  560. package/build-style/video/style-rtl.css +1 -5
  561. package/build-style/video/style.css +1 -5
  562. package/package.json +30 -29
  563. package/src/audio/block.json +6 -1
  564. package/src/audio/edit.js +4 -0
  565. package/src/audio/index.js +1 -2
  566. package/src/audio/save.js +12 -2
  567. package/src/audio/style.scss +0 -2
  568. package/src/avatar/hooks.js +2 -2
  569. package/src/block/edit.js +4 -6
  570. package/src/block/edit.native.js +12 -16
  571. package/src/block/test/edit.native.js +5 -8
  572. package/src/button/deprecated.js +145 -36
  573. package/src/button/edit.js +7 -11
  574. package/src/button/edit.native.js +2 -3
  575. package/src/button/save.js +5 -11
  576. package/src/button/style.scss +10 -5
  577. package/src/buttons/deprecated.js +4 -6
  578. package/src/buttons/edit.js +3 -3
  579. package/src/buttons/edit.native.js +7 -11
  580. package/src/buttons/test/__snapshots__/edit.native.js.snap +1 -1
  581. package/src/buttons/test/edit.native.js +1 -1
  582. package/src/column/deprecated.js +2 -1
  583. package/src/column/edit.js +2 -3
  584. package/src/column/edit.native.js +2 -2
  585. package/src/columns/block.json +3 -1
  586. package/src/columns/deprecated.js +4 -2
  587. package/src/columns/edit.js +6 -7
  588. package/src/columns/edit.native.js +12 -16
  589. package/src/columns/index.js +1 -2
  590. package/src/columns/utils.js +5 -3
  591. package/src/columns/variations.js +2 -2
  592. package/src/comment-author-name/block.json +0 -4
  593. package/src/comment-author-name/edit.js +3 -12
  594. package/src/comment-date/block.json +0 -4
  595. package/src/comment-date/edit.js +10 -14
  596. package/src/comment-date/index.php +0 -3
  597. package/src/comment-edit-link/block.json +0 -4
  598. package/src/comment-reply-link/block.json +0 -4
  599. package/src/comments/edit.js +24 -4
  600. package/src/comments-title/deprecated.js +0 -2
  601. package/src/comments-title/edit.js +1 -1
  602. package/src/comments-title/index.php +1 -1
  603. package/src/cover/block.json +1 -0
  604. package/src/cover/controls.native.js +2 -4
  605. package/src/cover/deprecated.js +237 -195
  606. package/src/cover/edit/block-controls.js +11 -20
  607. package/src/cover/edit/index.js +81 -66
  608. package/src/cover/edit/inspector-controls.js +38 -7
  609. package/src/cover/edit.native.js +8 -13
  610. package/src/cover/editor.scss +13 -0
  611. package/src/cover/index.php +21 -8
  612. package/src/cover/save.js +28 -16
  613. package/src/cover/shared.js +5 -7
  614. package/src/cover/style.scss +27 -22
  615. package/src/cover/test/edit.native.js +4 -7
  616. package/src/cover/transforms.js +2 -7
  617. package/src/embed/block.json +6 -1
  618. package/src/embed/edit.js +38 -40
  619. package/src/embed/edit.native.js +46 -49
  620. package/src/embed/embed-controls.native.js +2 -3
  621. package/src/embed/embed-preview.js +8 -1
  622. package/src/embed/icons.js +25 -0
  623. package/src/embed/save.js +10 -2
  624. package/src/embed/style.scss +0 -1
  625. package/src/embed/test/__snapshots__/index.native.js.snap +1 -1
  626. package/src/embed/test/index.native.js +24 -50
  627. package/src/embed/variations.js +10 -0
  628. package/src/file/edit.js +9 -5
  629. package/src/file/edit.native.js +14 -25
  630. package/src/file/index.js +1 -2
  631. package/src/file/save.js +14 -2
  632. package/src/file/style.scss +16 -15
  633. package/src/freeform/editor.scss +0 -2
  634. package/src/gallery/block.json +1 -1
  635. package/src/gallery/edit.js +8 -6
  636. package/src/gallery/gallery.js +9 -2
  637. package/src/gallery/gallery.native.js +2 -4
  638. package/src/gallery/gap-styles.js +21 -6
  639. package/src/gallery/index.js +2 -4
  640. package/src/gallery/index.php +27 -12
  641. package/src/gallery/save.js +5 -1
  642. package/src/gallery/shared.js +22 -9
  643. package/src/gallery/test/__snapshots__/index.native.js.snap +2 -2
  644. package/src/gallery/test/helpers.native.js +11 -198
  645. package/src/gallery/test/index.native.js +37 -63
  646. package/src/gallery/transforms.js +3 -3
  647. package/src/gallery/v1/edit.js +18 -24
  648. package/src/gallery/v1/gallery-image.js +10 -11
  649. package/src/gallery/v1/gallery-image.native.js +8 -17
  650. package/src/gallery/v1/gallery.js +8 -2
  651. package/src/gallery/v1/save.js +20 -3
  652. package/src/group/block.json +1 -0
  653. package/src/heading/autogenerate-anchors.js +8 -5
  654. package/src/heading/deprecated.js +6 -21
  655. package/src/heading/edit.js +2 -3
  656. package/src/html/edit.js +10 -40
  657. package/src/html/preview.js +46 -0
  658. package/src/image/block.json +5 -0
  659. package/src/image/deprecated.js +6 -29
  660. package/src/image/edit.js +1 -53
  661. package/src/image/edit.native.js +75 -24
  662. package/src/image/image.js +35 -49
  663. package/src/image/save.js +10 -2
  664. package/src/image/style.scss +0 -2
  665. package/src/image/styles.native.scss +11 -0
  666. package/src/image/test/edit.native.js +51 -19
  667. package/src/image/transforms.js +4 -3
  668. package/src/image/utils.js +2 -2
  669. package/src/index.js +1 -1
  670. package/src/latest-comments/edit.js +2 -6
  671. package/src/latest-posts/edit.js +6 -7
  672. package/src/latest-posts/edit.native.js +10 -15
  673. package/src/list/index.js +1 -2
  674. package/src/list/test/migrate.js +1 -2
  675. package/src/list/v2/edit.js +6 -9
  676. package/src/list/v2/transforms.js +22 -7
  677. package/src/list-item/hooks/use-backspace.js +2 -3
  678. package/src/list-item/hooks/use-enter.js +11 -9
  679. package/src/list-item/hooks/use-indent-list-item.js +2 -3
  680. package/src/list-item/hooks/use-outdent-list-item.js +50 -24
  681. package/src/list-item/hooks/use-space.js +2 -3
  682. package/src/list-item/hooks/use-split.js +18 -9
  683. package/src/media-text/deprecated.js +6 -3
  684. package/src/media-text/edit.native.js +2 -5
  685. package/src/media-text/media-container.js +1 -1
  686. package/src/media-text/media-container.native.js +6 -9
  687. package/src/media-text/save.js +2 -1
  688. package/src/missing/edit.native.js +2 -3
  689. package/src/missing/test/edit-integration.native.js +2 -3
  690. package/src/missing/test/edit.native.js +6 -9
  691. package/src/navigation/block.json +9 -0
  692. package/src/navigation/deprecated.js +2 -5
  693. package/src/navigation/edit/index.js +25 -36
  694. package/src/navigation/edit/navigation-menu-delete-control.js +2 -3
  695. package/src/navigation/edit/unsaved-inner-blocks.js +31 -30
  696. package/src/navigation/edit/use-convert-classic-menu-to-block-menu.js +2 -3
  697. package/src/navigation/style.scss +10 -1
  698. package/src/navigation/test/use-navigation-menu.js +241 -0
  699. package/src/navigation/use-navigation-entities.js +11 -13
  700. package/src/navigation/use-navigation-menu.js +95 -82
  701. package/src/navigation/use-template-part-area-label.js +8 -7
  702. package/src/navigation/view.js +7 -2
  703. package/src/navigation-link/edit.js +59 -25
  704. package/src/navigation-link/test/edit.js +2 -24
  705. package/src/navigation-submenu/edit.js +10 -20
  706. package/src/navigation-submenu/view.js +7 -2
  707. package/src/page-list/convert-to-links-modal.js +51 -54
  708. package/src/page-list/edit.js +6 -6
  709. package/src/page-list/test/convert-to-links-modal.js +6 -12
  710. package/src/paragraph/deprecated.js +2 -2
  711. package/src/pattern/edit.js +2 -4
  712. package/src/post-author/edit.js +2 -3
  713. package/src/post-author/index.php +3 -2
  714. package/src/post-author-name/index.js +2 -0
  715. package/src/post-author-name/index.php +1 -1
  716. package/src/post-author-name/transforms.js +25 -0
  717. package/src/post-comments/index.php +1 -1
  718. package/src/post-comments/style.scss +7 -3
  719. package/src/post-comments-form/edit.js +20 -3
  720. package/src/post-comments-form/editor.scss +4 -0
  721. package/src/post-comments-form/form.js +11 -1
  722. package/src/post-comments-form/index.php +1 -1
  723. package/src/post-content/edit.js +2 -3
  724. package/src/post-date/edit.js +4 -3
  725. package/src/post-featured-image/edit.js +14 -30
  726. package/src/post-featured-image/editor.scss +0 -29
  727. package/src/post-featured-image/index.php +4 -2
  728. package/src/post-navigation-link/block.json +4 -0
  729. package/src/post-template/index.php +15 -3
  730. package/src/post-template/style.scss +1 -7
  731. package/src/pullquote/deprecated.js +2 -1
  732. package/src/query/edit/index.js +10 -10
  733. package/src/query/edit/inspector-controls/parent-control.js +2 -3
  734. package/src/query/edit/query-toolbar.js +25 -5
  735. package/src/query-pagination/index.php +0 -1
  736. package/src/quote/v2/edit.js +4 -6
  737. package/src/quote/v2/test/migrate.js +1 -2
  738. package/src/search/block.json +4 -0
  739. package/src/search/edit.js +9 -13
  740. package/src/search/edit.native.js +4 -6
  741. package/src/search/index.php +38 -23
  742. package/src/search/style.scss +11 -9
  743. package/src/separator/use-deprecated-opacity.js +2 -4
  744. package/src/shortcode/edit.native.js +30 -15
  745. package/src/shortcode/style.native.scss +11 -4
  746. package/src/shortcode/test/__snapshots__/edit.native.js.snap +9 -0
  747. package/src/shortcode/test/edit.native.js +55 -40
  748. package/src/site-logo/edit.js +3 -17
  749. package/src/site-logo/editor.scss +0 -14
  750. package/src/site-logo/style.scss +6 -0
  751. package/src/social-links/deprecated.js +4 -2
  752. package/src/social-links/edit.js +11 -10
  753. package/src/social-links/edit.native.js +3 -5
  754. package/src/spacer/controls.js +2 -3
  755. package/src/spacer/test/index.native.js +10 -21
  756. package/src/table/block.json +6 -1
  757. package/src/table/deprecated.js +4 -8
  758. package/src/table/edit.js +2 -0
  759. package/src/table/save.js +6 -1
  760. package/src/table/state.js +2 -4
  761. package/src/table/style.scss +0 -1
  762. package/src/table-of-contents/edit.js +22 -13
  763. package/src/tag-cloud/edit.js +4 -7
  764. package/src/template-part/edit/advanced-controls.js +4 -4
  765. package/src/template-part/edit/index.js +6 -10
  766. package/src/template-part/edit/utils/hooks.js +8 -7
  767. package/src/transformationCategories.native.js +3 -3
  768. package/src/video/block.json +6 -1
  769. package/src/video/edit-common-settings.js +2 -8
  770. package/src/video/edit.js +4 -0
  771. package/src/video/edit.native.js +38 -16
  772. package/src/video/index.js +1 -2
  773. package/src/video/save.js +10 -2
  774. package/src/video/style.scss +0 -2
@@ -10,7 +10,7 @@ import namesPlugin from 'colord/plugins/names';
10
10
  */
11
11
  import { useEntityProp, store as coreStore } from '@wordpress/core-data';
12
12
  import { useEffect, useRef } from '@wordpress/element';
13
- import { Spinner } from '@wordpress/components';
13
+ import { Placeholder, Spinner } from '@wordpress/components';
14
14
  import { compose } from '@wordpress/compose';
15
15
  import {
16
16
  withColors,
@@ -33,7 +33,6 @@ import {
33
33
  attributesFromMedia,
34
34
  IMAGE_BACKGROUND_TYPE,
35
35
  VIDEO_BACKGROUND_TYPE,
36
- backgroundImageStyles,
37
36
  dimRatioToClass,
38
37
  isContentPositionCenter,
39
38
  getPositionClassName,
@@ -121,9 +120,8 @@ function CoverEdit( {
121
120
  ? IMAGE_BACKGROUND_TYPE
122
121
  : attributes.backgroundType;
123
122
 
124
- const { __unstableMarkNextChangeAsNotPersistent } = useDispatch(
125
- blockEditorStore
126
- );
123
+ const { __unstableMarkNextChangeAsNotPersistent } =
124
+ useDispatch( blockEditorStore );
127
125
  const { createErrorNotice } = useDispatch( noticesStore );
128
126
  const { gradientClass, gradientValue } = __experimentalUseGradient();
129
127
  const onSelectMedia = attributesFromMedia( setAttributes, dimRatio );
@@ -158,12 +156,13 @@ function CoverEdit( {
158
156
  const isImgElement = ! ( hasParallax || isRepeated );
159
157
 
160
158
  const style = {
161
- ...( isImageBackground && ! isImgElement
162
- ? backgroundImageStyles( url )
163
- : undefined ),
164
159
  minHeight: minHeightWithUnit || undefined,
165
160
  };
166
161
 
162
+ const backgroundImage = url ? `url(${ url })` : undefined;
163
+
164
+ const backgroundPosition = mediaPosition( focalPoint );
165
+
167
166
  const bgStyle = { backgroundColor: overlayColor.color };
168
167
  const mediaStyle = {
169
168
  objectPosition:
@@ -212,23 +211,31 @@ function CoverEdit( {
212
211
  overlayColor,
213
212
  };
214
213
 
215
- if ( ! hasInnerBlocks && ! hasBackground ) {
214
+ const blockControls = (
215
+ <CoverBlockControls
216
+ attributes={ attributes }
217
+ setAttributes={ setAttributes }
218
+ onSelectMedia={ onSelectMedia }
219
+ currentSettings={ currentSettings }
220
+ />
221
+ );
222
+
223
+ const inspectorControls = (
224
+ <CoverInspectorControls
225
+ attributes={ attributes }
226
+ setAttributes={ setAttributes }
227
+ clientId={ clientId }
228
+ setOverlayColor={ setOverlayColor }
229
+ coverRef={ ref }
230
+ currentSettings={ currentSettings }
231
+ />
232
+ );
233
+
234
+ if ( ! useFeaturedImage && ! hasInnerBlocks && ! hasBackground ) {
216
235
  return (
217
236
  <>
218
- <CoverBlockControls
219
- attributes={ attributes }
220
- setAttributes={ setAttributes }
221
- onSelectMedia={ onSelectMedia }
222
- currentSettings={ currentSettings }
223
- />
224
- <CoverInspectorControls
225
- attributes={ attributes }
226
- setAttributes={ setAttributes }
227
- clientId={ clientId }
228
- setOverlayColor={ setOverlayColor }
229
- coverRef={ ref }
230
- currentSettings={ currentSettings }
231
- />
237
+ { blockControls }
238
+ { inspectorControls }
232
239
  <div
233
240
  { ...blockProps }
234
241
  className={ classnames(
@@ -279,29 +286,16 @@ function CoverEdit( {
279
286
  'is-transient': isUploadingMedia,
280
287
  'has-parallax': hasParallax,
281
288
  'is-repeated': isRepeated,
282
- 'has-custom-content-position': ! isContentPositionCenter(
283
- contentPosition
284
- ),
289
+ 'has-custom-content-position':
290
+ ! isContentPositionCenter( contentPosition ),
285
291
  },
286
292
  getPositionClassName( contentPosition )
287
293
  );
288
294
 
289
295
  return (
290
296
  <>
291
- <CoverBlockControls
292
- attributes={ attributes }
293
- setAttributes={ setAttributes }
294
- onSelectMedia={ onSelectMedia }
295
- currentSettings={ currentSettings }
296
- />
297
- <CoverInspectorControls
298
- attributes={ attributes }
299
- setAttributes={ setAttributes }
300
- clientId={ clientId }
301
- setOverlayColor={ setOverlayColor }
302
- coverRef={ ref }
303
- currentSettings={ currentSettings }
304
- />
297
+ { blockControls }
298
+ { inspectorControls }
305
299
  <div
306
300
  { ...blockProps }
307
301
  className={ classnames( classes, blockProps.className ) }
@@ -324,35 +318,56 @@ function CoverEdit( {
324
318
  showHandle={ isSelected }
325
319
  />
326
320
 
327
- <span
328
- aria-hidden="true"
329
- className={ classnames(
330
- 'wp-block-cover__background',
331
- dimRatioToClass( dimRatio ),
332
- {
333
- [ overlayColor.class ]: overlayColor.class,
334
- 'has-background-dim': dimRatio !== undefined,
335
- // For backwards compatibility. Former versions of the Cover Block applied
336
- // `.wp-block-cover__gradient-background` in the presence of
337
- // media, a gradient and a dim.
338
- 'wp-block-cover__gradient-background':
339
- url && gradientValue && dimRatio !== 0,
340
- 'has-background-gradient': gradientValue,
341
- [ gradientClass ]: gradientClass,
342
- }
343
- ) }
344
- style={ { backgroundImage: gradientValue, ...bgStyle } }
345
- />
321
+ { ( ! useFeaturedImage || url ) && (
322
+ <span
323
+ aria-hidden="true"
324
+ className={ classnames(
325
+ 'wp-block-cover__background',
326
+ dimRatioToClass( dimRatio ),
327
+ {
328
+ [ overlayColor.class ]: overlayColor.class,
329
+ 'has-background-dim': dimRatio !== undefined,
330
+ // For backwards compatibility. Former versions of the Cover Block applied
331
+ // `.wp-block-cover__gradient-background` in the presence of
332
+ // media, a gradient and a dim.
333
+ 'wp-block-cover__gradient-background':
334
+ url && gradientValue && dimRatio !== 0,
335
+ 'has-background-gradient': gradientValue,
336
+ [ gradientClass ]: gradientClass,
337
+ }
338
+ ) }
339
+ style={ { backgroundImage: gradientValue, ...bgStyle } }
340
+ />
341
+ ) }
346
342
 
347
- { url && isImageBackground && isImgElement && (
348
- <img
349
- ref={ mediaElement }
350
- className="wp-block-cover__image-background"
351
- alt={ alt }
352
- src={ url }
353
- style={ mediaStyle }
343
+ { ! url && useFeaturedImage && (
344
+ <Placeholder
345
+ className="wp-block-cover__image--placeholder-image"
346
+ withIllustration={ true }
354
347
  />
355
348
  ) }
349
+
350
+ { url &&
351
+ isImageBackground &&
352
+ ( isImgElement ? (
353
+ <img
354
+ ref={ mediaElement }
355
+ className="wp-block-cover__image-background"
356
+ alt={ alt }
357
+ src={ url }
358
+ style={ mediaStyle }
359
+ />
360
+ ) : (
361
+ <div
362
+ ref={ mediaElement }
363
+ role="img"
364
+ className={ classnames(
365
+ classes,
366
+ 'wp-block-cover__image-background'
367
+ ) }
368
+ style={ { backgroundImage, backgroundPosition } }
369
+ />
370
+ ) ) }
356
371
  { url && isVideoBackground && (
357
372
  <video
358
373
  ref={ mediaElement }
@@ -21,8 +21,9 @@ import { useInstanceId } from '@wordpress/compose';
21
21
  import {
22
22
  InspectorControls,
23
23
  useSetting,
24
+ __experimentalColorGradientSettingsDropdown as ColorGradientSettingsDropdown,
24
25
  __experimentalUseGradient,
25
- __experimentalPanelColorGradientSettings as PanelColorGradientSettings,
26
+ __experimentalUseMultipleOriginColorsAndGradients as useMultipleOriginColorsAndGradients,
26
27
  } from '@wordpress/block-editor';
27
28
  import { __ } from '@wordpress/i18n';
28
29
 
@@ -138,6 +139,9 @@ export default function CoverInspectorControls( {
138
139
  : [ coverRef.current.style, 'backgroundPosition' ];
139
140
  styleOfRef[ property ] = mediaPosition( value );
140
141
  };
142
+
143
+ const colorGradientSettings = useMultipleOriginColorsAndGradients();
144
+
141
145
  return (
142
146
  <>
143
147
  <InspectorControls>
@@ -220,23 +224,50 @@ export default function CoverInspectorControls( {
220
224
  </PanelRow>
221
225
  </PanelBody>
222
226
  ) }
223
- <PanelColorGradientSettings
227
+ </InspectorControls>
228
+ <InspectorControls __experimentalGroup="color">
229
+ <ColorGradientSettingsDropdown
224
230
  __experimentalHasMultipleOrigins
225
231
  __experimentalIsRenderedInSidebar
226
- title={ __( 'Overlay' ) }
227
- initialOpen={ true }
228
232
  settings={ [
229
233
  {
230
234
  colorValue: overlayColor.color,
231
235
  gradientValue,
236
+ label: __( 'Overlay' ),
232
237
  onColorChange: setOverlayColor,
233
238
  onGradientChange: setGradient,
234
- label: __( 'Color' ),
239
+ isShownByDefault: true,
240
+ resetAllFilter: () => ( {
241
+ overlayColor: undefined,
242
+ customOverlayColor: undefined,
243
+ gradient: undefined,
244
+ customGradient: undefined,
245
+ } ),
235
246
  },
236
247
  ] }
248
+ panelId={ clientId }
249
+ { ...colorGradientSettings }
250
+ />
251
+ <ToolsPanelItem
252
+ hasValue={ () => {
253
+ // If there's a media background the dimRatio will be
254
+ // defaulted to 50 whereas it will be 100 for colors.
255
+ return dimRatio === undefined
256
+ ? false
257
+ : dimRatio !== ( url ? 50 : 100 );
258
+ } }
259
+ label={ __( 'Overlay opacity' ) }
260
+ onDeselect={ () =>
261
+ setAttributes( { dimRatio: url ? 50 : 100 } )
262
+ }
263
+ resetAllFilter={ () => ( {
264
+ dimRatio: url ? 50 : 100,
265
+ } ) }
266
+ isShownByDefault
267
+ panelId={ clientId }
237
268
  >
238
269
  <RangeControl
239
- label={ __( 'Opacity' ) }
270
+ label={ __( 'Overlay opacity' ) }
240
271
  value={ dimRatio }
241
272
  onChange={ ( newDimRation ) =>
242
273
  setAttributes( {
@@ -248,7 +279,7 @@ export default function CoverInspectorControls( {
248
279
  step={ 10 }
249
280
  required
250
281
  />
251
- </PanelColorGradientSettings>
282
+ </ToolsPanelItem>
252
283
  </InspectorControls>
253
284
  <InspectorControls __experimentalGroup="dimensions">
254
285
  <ToolsPanelItem
@@ -117,9 +117,8 @@ const Cover = ( {
117
117
  overlayColor,
118
118
  isDark,
119
119
  } = attributes;
120
- const [ isScreenReaderEnabled, setIsScreenReaderEnabled ] = useState(
121
- false
122
- );
120
+ const [ isScreenReaderEnabled, setIsScreenReaderEnabled ] =
121
+ useState( false );
123
122
 
124
123
  useEffect( () => {
125
124
  let isCurrent = true;
@@ -176,10 +175,8 @@ const Cover = ( {
176
175
 
177
176
  const hasOnlyColorBackground = ! url && ( hasBackground || hasInnerBlocks );
178
177
 
179
- const [
180
- isCustomColorPickerShowing,
181
- setCustomColorPickerShowing,
182
- ] = useState( false );
178
+ const [ isCustomColorPickerShowing, setCustomColorPickerShowing ] =
179
+ useState( false );
183
180
 
184
181
  const openMediaOptionsRef = useRef();
185
182
 
@@ -248,9 +245,8 @@ const Cover = ( {
248
245
  openGeneralSidebar();
249
246
  }
250
247
 
251
- const { __unstableMarkNextChangeAsNotPersistent } = useDispatch(
252
- blockEditorStore
253
- );
248
+ const { __unstableMarkNextChangeAsNotPersistent } =
249
+ useDispatch( blockEditorStore );
254
250
  const isCoverDark = useCoverIsDark(
255
251
  isDark,
256
252
  url,
@@ -622,9 +618,8 @@ const Cover = ( {
622
618
 
623
619
  export default compose( [
624
620
  withSelect( ( select, { clientId } ) => {
625
- const { getSelectedBlockClientId, getBlock } = select(
626
- blockEditorStore
627
- );
621
+ const { getSelectedBlockClientId, getBlock } =
622
+ select( blockEditorStore );
628
623
 
629
624
  const selectedBlockClientId = getSelectedBlockClientId();
630
625
 
@@ -62,6 +62,15 @@
62
62
  .wp-block-cover__placeholder-background-options {
63
63
  width: 100%;
64
64
  }
65
+
66
+ .wp-block-cover__image--placeholder-image {
67
+ position: absolute;
68
+ top: 0;
69
+ right: 0;
70
+ bottom: 0;
71
+ left: 0;
72
+ }
73
+
65
74
  }
66
75
 
67
76
  [data-align="left"] > .wp-block-cover,
@@ -98,3 +107,7 @@
98
107
  .block-editor-block-patterns-list__list-item .has-parallax.wp-block-cover {
99
108
  background-attachment: scroll;
100
109
  }
110
+
111
+ .color-block-support-panel__inner-wrapper > :not(.block-editor-tools-panel-color-gradient-settings__item) {
112
+ margin-top: $grid-unit-30;
113
+ }
@@ -32,20 +32,33 @@ function render_block_core_cover( $attributes, $content ) {
32
32
 
33
33
  $image = get_the_post_thumbnail( null, 'post-thumbnail', $attr );
34
34
 
35
- $content = str_replace(
36
- '</span><div',
37
- '</span>' . $image . '<div',
38
- $content
39
- );
40
-
35
+ /*
36
+ * Inserts the featured image between the (1st) cover 'background' `span` and 'inner_container' `div`,
37
+ * and removes eventual withespace characters between the two (typically introduced at template level)
38
+ */
39
+ $inner_container_start = '/<div\b[^>]+wp-block-cover__inner-container[\s|"][^>]*>/U';
40
+ if ( 1 === preg_match( $inner_container_start, $content, $matches, PREG_OFFSET_CAPTURE ) ) {
41
+ $offset = $matches[0][1];
42
+ $content = substr( $content, 0, $offset ) . $image . substr( $content, $offset );
43
+ }
41
44
  } else {
42
45
  if ( in_the_loop() ) {
43
46
  update_post_thumbnail_cache();
44
47
  }
45
48
  $current_featured_image = get_the_post_thumbnail_url();
46
- $content = preg_replace(
49
+
50
+ $styles = 'background-image:url(' . esc_url( $current_featured_image ) . '); ';
51
+
52
+ if ( isset( $attributes['minHeight'] ) ) {
53
+ $height_unit = empty( $attributes['minHeightUnit'] ) ? 'px' : $attributes['minHeightUnit'];
54
+ $height = " min-height:{$attributes['minHeight']}{$height_unit}";
55
+
56
+ $styles .= $height;
57
+ }
58
+
59
+ $content = preg_replace(
47
60
  '/class=\".*?\"/',
48
- '${0} style="background-image:url(' . esc_url( $current_featured_image ) . ')"',
61
+ '${0} style="' . $styles . '"',
49
62
  $content,
50
63
  1
51
64
  );
package/src/cover/save.js CHANGED
@@ -19,10 +19,10 @@ import {
19
19
  import {
20
20
  IMAGE_BACKGROUND_TYPE,
21
21
  VIDEO_BACKGROUND_TYPE,
22
- backgroundImageStyles,
23
22
  dimRatioToClass,
24
23
  isContentPositionCenter,
25
24
  getPositionClassName,
25
+ mediaPosition,
26
26
  } from './shared';
27
27
 
28
28
  export default function save( { attributes } ) {
@@ -61,9 +61,6 @@ export default function save( { attributes } ) {
61
61
  const isImgElement = ! ( hasParallax || isRepeated );
62
62
 
63
63
  const style = {
64
- ...( isImageBackground && ! isImgElement && ! useFeaturedImage
65
- ? backgroundImageStyles( url )
66
- : {} ),
67
64
  minHeight: minHeight || undefined,
68
65
  };
69
66
 
@@ -75,21 +72,33 @@ export default function save( { attributes } ) {
75
72
  const objectPosition =
76
73
  // prettier-ignore
77
74
  focalPoint && isImgElement
78
- ? `${ Math.round( focalPoint.x * 100 ) }% ${ Math.round( focalPoint.y * 100 ) }%`
79
- : undefined;
75
+ ? mediaPosition(focalPoint)
76
+ : undefined;
77
+
78
+ const backgroundImage = url ? `url(${ url })` : undefined;
79
+
80
+ const backgroundPosition = mediaPosition( focalPoint );
80
81
 
81
82
  const classes = classnames(
82
83
  {
83
84
  'is-light': ! isDark,
84
85
  'has-parallax': hasParallax,
85
86
  'is-repeated': isRepeated,
86
- 'has-custom-content-position': ! isContentPositionCenter(
87
- contentPosition
88
- ),
87
+ 'has-custom-content-position':
88
+ ! isContentPositionCenter( contentPosition ),
89
89
  },
90
90
  getPositionClassName( contentPosition )
91
91
  );
92
92
 
93
+ const imgClasses = classnames(
94
+ 'wp-block-cover__image-background',
95
+ id ? `wp-image-${ id }` : null,
96
+ {
97
+ 'has-parallax': hasParallax,
98
+ 'is-repeated': isRepeated,
99
+ }
100
+ );
101
+
93
102
  const gradientValue = gradient || customGradient;
94
103
 
95
104
  return (
@@ -116,20 +125,23 @@ export default function save( { attributes } ) {
116
125
 
117
126
  { ! useFeaturedImage &&
118
127
  isImageBackground &&
119
- isImgElement &&
120
- url && (
128
+ url &&
129
+ ( isImgElement ? (
121
130
  <img
122
- className={ classnames(
123
- 'wp-block-cover__image-background',
124
- id ? `wp-image-${ id }` : null
125
- ) }
131
+ className={ imgClasses }
126
132
  alt={ alt }
127
133
  src={ url }
128
134
  style={ { objectPosition } }
129
135
  data-object-fit="cover"
130
136
  data-object-position={ objectPosition }
131
137
  />
132
- ) }
138
+ ) : (
139
+ <div
140
+ role="img"
141
+ className={ imgClasses }
142
+ style={ { backgroundPosition, backgroundImage } }
143
+ />
144
+ ) ) }
133
145
  { isVideoBackground && url && (
134
146
  <video
135
147
  className={ classnames(
@@ -21,11 +21,13 @@ export const VIDEO_BACKGROUND_TYPE = 'video';
21
21
  export const COVER_MIN_HEIGHT = 50;
22
22
  export const COVER_MAX_HEIGHT = 1000;
23
23
  export const COVER_DEFAULT_HEIGHT = 300;
24
- export function backgroundImageStyles( url ) {
25
- return url ? { backgroundImage: `url(${ url })` } : {};
26
- }
24
+ export const DEFAULT_FOCAL_POINT = { x: 0.5, y: 0.5 };
27
25
  export const ALLOWED_MEDIA_TYPES = [ 'image', 'video' ];
28
26
 
27
+ export function mediaPosition( { x, y } = DEFAULT_FOCAL_POINT ) {
28
+ return `${ Math.round( x * 100 ) }% ${ Math.round( y * 100 ) }%`;
29
+ }
30
+
29
31
  export function dimRatioToClass( ratio ) {
30
32
  return ratio === 50 || ! ratio === undefined
31
33
  ? null
@@ -106,7 +108,3 @@ export function getPositionClassName( contentPosition ) {
106
108
 
107
109
  return POSITION_CLASSNAMES[ contentPosition ];
108
110
  }
109
-
110
- export function mediaPosition( { x, y } ) {
111
- return `${ Math.round( x * 100 ) }% ${ Math.round( y * 100 ) }%`;
112
- }
@@ -12,27 +12,6 @@
12
12
  // This block has customizable padding, border-box makes that more predictable.
13
13
  box-sizing: border-box;
14
14
 
15
- &.has-parallax {
16
- background-attachment: fixed;
17
-
18
- // Mobile Safari does not support fixed background attachment properly.
19
- // See also https://stackoverflow.com/questions/24154666/background-size-cover-not-working-on-ios
20
- // Chrome on Android does not appear to support the attachment at all: https://issuetracker.google.com/issues/36908439
21
- @supports (-webkit-touch-callout: inherit) {
22
- background-attachment: scroll;
23
- }
24
-
25
- // Remove the appearance of scrolling based on OS-level animation preferences.
26
- @media (prefers-reduced-motion: reduce) {
27
- background-attachment: scroll;
28
- }
29
- }
30
-
31
- &.is-repeated {
32
- background-repeat: repeat;
33
- background-size: auto;
34
- }
35
-
36
15
  /**
37
16
  * Set a default background color for has-background-dim _unless_ it includes another
38
17
  * background-color class (e.g. has-green-background-color). The presence of another
@@ -196,7 +175,7 @@
196
175
  }
197
176
 
198
177
  // Extra specificity for in edit mode where other styles would override it otherwise.
199
- img.wp-block-cover__image-background,
178
+ .wp-block-cover__image-background,
200
179
  video.wp-block-cover__video-background {
201
180
  position: absolute;
202
181
  top: 0;
@@ -216,6 +195,32 @@
216
195
  }
217
196
  }
218
197
 
198
+ .wp-block-cover-image,
199
+ .wp-block-cover,
200
+ .wp-block-cover__image-background,
201
+ video.wp-block-cover__video-background {
202
+ &.has-parallax {
203
+ background-attachment: fixed;
204
+
205
+ // Mobile Safari does not support fixed background attachment properly.
206
+ // See also https://stackoverflow.com/questions/24154666/background-size-cover-not-working-on-ios
207
+ // Chrome on Android does not appear to support the attachment at all: https://issuetracker.google.com/issues/36908439
208
+ @supports (-webkit-overflow-scrolling: touch) {
209
+ background-attachment: scroll;
210
+ }
211
+
212
+ // Remove the appearance of scrolling based on OS-level animation preferences.
213
+ @media (prefers-reduced-motion: reduce) {
214
+ background-attachment: scroll;
215
+ }
216
+ }
217
+
218
+ &.is-repeated {
219
+ background-repeat: repeat;
220
+ background-size: auto;
221
+ }
222
+ }
223
+
219
224
  .wp-block-cover__video-background {
220
225
  z-index: z-index(".wp-block-cover__video-background");
221
226
  }
@@ -493,13 +493,10 @@ describe( 'color settings', () => {
493
493
  } );
494
494
 
495
495
  it( 'clears the selected overlay color and mantains the inner blocks', async () => {
496
- const {
497
- getByTestId,
498
- getByA11yLabel,
499
- getByText,
500
- } = await initializeEditor( {
501
- initialHtml: COVER_BLOCK_SOLID_COLOR_HTML,
502
- } );
496
+ const { getByTestId, getByA11yLabel, getByText } =
497
+ await initializeEditor( {
498
+ initialHtml: COVER_BLOCK_SOLID_COLOR_HTML,
499
+ } );
503
500
 
504
501
  // Wait for the block to be created.
505
502
  const coverBlock = await waitFor( () =>
@@ -66,13 +66,8 @@ const transforms = {
66
66
  type: 'block',
67
67
  blocks: [ 'core/group' ],
68
68
  transform: ( attributes, innerBlocks ) => {
69
- const {
70
- align,
71
- anchor,
72
- backgroundColor,
73
- gradient,
74
- style,
75
- } = attributes;
69
+ const { align, anchor, backgroundColor, gradient, style } =
70
+ attributes;
76
71
 
77
72
  // If the Group block being transformed has a Cover block as its
78
73
  // only child return that Cover block.
@@ -35,7 +35,12 @@
35
35
  }
36
36
  },
37
37
  "supports": {
38
- "align": true
38
+ "align": true,
39
+ "__experimentalStyle": {
40
+ "spacing": {
41
+ "margin": "0 0 1em 0"
42
+ }
43
+ }
39
44
  },
40
45
  "editorStyle": "wp-block-embed-editor",
41
46
  "style": "wp-block-embed"