@wordpress/block-library 7.5.0 → 7.6.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 (527) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/README.md +3 -2
  3. package/babel-plugin.js +154 -0
  4. package/build/audio/edit.js +1 -1
  5. package/build/audio/edit.js.map +1 -1
  6. package/build/block/edit.js +10 -9
  7. package/build/block/edit.js.map +1 -1
  8. package/build/button/index.js +1 -0
  9. package/build/button/index.js.map +1 -1
  10. package/build/categories/edit.js +1 -1
  11. package/build/categories/edit.js.map +1 -1
  12. package/build/categories/index.js +1 -1
  13. package/build/comment-author-avatar/index.js +1 -0
  14. package/build/comment-author-avatar/index.js.map +1 -1
  15. package/build/comments-title/deprecated.js +110 -0
  16. package/build/comments-title/deprecated.js.map +1 -0
  17. package/build/comments-title/edit.js +35 -37
  18. package/build/comments-title/edit.js.map +1 -1
  19. package/build/comments-title/index.js +5 -8
  20. package/build/comments-title/index.js.map +1 -1
  21. package/build/cover/controls.native.js +2 -3
  22. package/build/cover/controls.native.js.map +1 -1
  23. package/build/cover/edit/block-controls.js +115 -0
  24. package/build/cover/edit/block-controls.js.map +1 -0
  25. package/build/cover/edit/cover-placeholder.js +49 -0
  26. package/build/cover/edit/cover-placeholder.js.map +1 -0
  27. package/build/cover/edit/index.js +333 -0
  28. package/build/cover/edit/index.js.map +1 -0
  29. package/build/cover/edit/inspector-controls.js +224 -0
  30. package/build/cover/edit/inspector-controls.js.map +1 -0
  31. package/build/cover/edit/resizable-cover.js +67 -0
  32. package/build/cover/edit/resizable-cover.js.map +1 -0
  33. package/build/cover/{use-cover-is-dark.js → edit/use-cover-is-dark.js} +0 -0
  34. package/build/cover/edit/use-cover-is-dark.js.map +1 -0
  35. package/build/cover/edit.native.js +0 -1
  36. package/build/cover/edit.native.js.map +1 -1
  37. package/build/cover/focal-point-settings-button.native.js.map +1 -1
  38. package/build/cover/shared.js +9 -0
  39. package/build/cover/shared.js.map +1 -1
  40. package/build/embed/embed-preview.js +1 -1
  41. package/build/embed/embed-preview.js.map +1 -1
  42. package/build/file/edit.native.js +0 -1
  43. package/build/file/edit.native.js.map +1 -1
  44. package/build/gallery/edit.js +2 -1
  45. package/build/gallery/edit.js.map +1 -1
  46. package/build/gallery/gallery.js +1 -1
  47. package/build/gallery/gallery.js.map +1 -1
  48. package/build/gallery/shared.js +2 -2
  49. package/build/gallery/shared.js.map +1 -1
  50. package/build/gallery/use-get-media.js +2 -1
  51. package/build/gallery/use-get-media.js.map +1 -1
  52. package/build/gallery/use-short-code-transform.js +19 -18
  53. package/build/gallery/use-short-code-transform.js.map +1 -1
  54. package/build/gallery/v1/gallery.js +1 -1
  55. package/build/gallery/v1/gallery.js.map +1 -1
  56. package/build/heading/edit.js +6 -2
  57. package/build/heading/edit.js.map +1 -1
  58. package/build/heading/index.js +1 -0
  59. package/build/heading/index.js.map +1 -1
  60. package/build/heading/transforms.js +1 -0
  61. package/build/heading/transforms.js.map +1 -1
  62. package/build/image/edit.js +5 -2
  63. package/build/image/edit.js.map +1 -1
  64. package/build/image/edit.native.js +0 -1
  65. package/build/image/edit.native.js.map +1 -1
  66. package/build/image/image.js +1 -1
  67. package/build/image/image.js.map +1 -1
  68. package/build/index.js +46 -10
  69. package/build/index.js.map +1 -1
  70. package/build/is-block-metadata-experimental.js +18 -0
  71. package/build/is-block-metadata-experimental.js.map +1 -0
  72. package/build/latest-posts/edit.js +30 -4
  73. package/build/latest-posts/edit.js.map +1 -1
  74. package/build/list/transforms.js +6 -0
  75. package/build/list/transforms.js.map +1 -1
  76. package/build/list/v2/edit.js +2 -1
  77. package/build/list/v2/edit.js.map +1 -1
  78. package/build/list/v2/migrate.js +1 -0
  79. package/build/list/v2/migrate.js.map +1 -1
  80. package/build/list/v2/transforms.js +46 -9
  81. package/build/list/v2/transforms.js.map +1 -1
  82. package/build/list-item/edit.js +7 -9
  83. package/build/list-item/edit.js.map +1 -1
  84. package/build/list-item/hooks/index.js +24 -0
  85. package/build/list-item/hooks/index.js.map +1 -1
  86. package/build/list-item/hooks/use-backspace.js +59 -0
  87. package/build/list-item/hooks/use-backspace.js.map +1 -0
  88. package/build/list-item/hooks/use-enter.js +6 -9
  89. package/build/list-item/hooks/use-enter.js.map +1 -1
  90. package/build/list-item/hooks/use-indent-list-item.js +33 -39
  91. package/build/list-item/hooks/use-indent-list-item.js.map +1 -1
  92. package/build/list-item/hooks/use-space.js +54 -0
  93. package/build/list-item/hooks/use-space.js.map +1 -0
  94. package/build/list-item/hooks/use-split.js +30 -0
  95. package/build/list-item/hooks/use-split.js.map +1 -0
  96. package/build/list-item/index.js +1 -0
  97. package/build/list-item/index.js.map +1 -1
  98. package/build/list-item/utils.js +1 -1
  99. package/build/list-item/utils.js.map +1 -1
  100. package/build/media-text/edit.native.js +2 -1
  101. package/build/media-text/edit.native.js.map +1 -1
  102. package/build/media-text/media-container.native.js +2 -4
  103. package/build/media-text/media-container.native.js.map +1 -1
  104. package/build/media-text/transforms.js +137 -8
  105. package/build/media-text/transforms.js.map +1 -1
  106. package/build/navigation/edit/index.js +86 -81
  107. package/build/navigation/edit/index.js.map +1 -1
  108. package/build/navigation/edit/inner-blocks.js +1 -5
  109. package/build/navigation/edit/inner-blocks.js.map +1 -1
  110. package/build/navigation/use-navigation-entities.js +3 -3
  111. package/build/navigation/use-navigation-entities.js.map +1 -1
  112. package/build/navigation-link/fallback-variations.js +1 -1
  113. package/build/navigation-link/fallback-variations.js.map +1 -1
  114. package/build/navigation-link/hooks.js +1 -1
  115. package/build/navigation-link/hooks.js.map +1 -1
  116. package/build/page-list/convert-to-links-modal.js +1 -1
  117. package/build/page-list/convert-to-links-modal.js.map +1 -1
  118. package/build/page-list/edit.js +1 -1
  119. package/build/page-list/edit.js.map +1 -1
  120. package/build/post-author/edit.js +1 -1
  121. package/build/post-author/edit.js.map +1 -1
  122. package/build/post-author-name/index.js +1 -0
  123. package/build/post-author-name/index.js.map +1 -1
  124. package/build/post-comment/index.js +1 -0
  125. package/build/post-comment/index.js.map +1 -1
  126. package/build/post-comments/edit.js +34 -16
  127. package/build/post-comments/edit.js.map +1 -1
  128. package/build/post-comments-count/index.js +1 -0
  129. package/build/post-comments-count/index.js.map +1 -1
  130. package/build/post-comments-form/form.js +1 -1
  131. package/build/post-comments-form/form.js.map +1 -1
  132. package/build/post-comments-link/index.js +1 -0
  133. package/build/post-comments-link/index.js.map +1 -1
  134. package/build/post-featured-image/edit.js +1 -1
  135. package/build/post-featured-image/edit.js.map +1 -1
  136. package/build/post-template/edit.js +7 -2
  137. package/build/post-template/edit.js.map +1 -1
  138. package/build/post-terms/edit.js +11 -2
  139. package/build/post-terms/edit.js.map +1 -1
  140. package/build/post-terms/hooks.js +33 -0
  141. package/build/post-terms/hooks.js.map +1 -0
  142. package/build/post-terms/index.js +12 -5
  143. package/build/post-terms/index.js.map +1 -1
  144. package/build/post-title/index.js +1 -1
  145. package/build/post-title/index.js.map +1 -1
  146. package/build/pullquote/edit.js +1 -1
  147. package/build/pullquote/edit.js.map +1 -1
  148. package/build/pullquote/edit.native.js +1 -1
  149. package/build/pullquote/edit.native.js.map +1 -1
  150. package/build/query/edit/inspector-controls/index.js +26 -17
  151. package/build/query/edit/inspector-controls/index.js.map +1 -1
  152. package/build/query/edit/inspector-controls/parent-control.js +148 -0
  153. package/build/query/edit/inspector-controls/parent-control.js.map +1 -0
  154. package/build/query/edit/inspector-controls/sticky-control.js +41 -0
  155. package/build/query/edit/inspector-controls/sticky-control.js.map +1 -0
  156. package/build/query/index.js +2 -1
  157. package/build/query/index.js.map +1 -1
  158. package/build/query/utils.js +28 -2
  159. package/build/query/utils.js.map +1 -1
  160. package/build/query-title/index.js +1 -1
  161. package/build/query-title/index.js.map +1 -1
  162. package/build/query-title/variations.js +1 -1
  163. package/build/query-title/variations.js.map +1 -1
  164. package/build/quote/edit.js +3 -2
  165. package/build/quote/edit.js.map +1 -1
  166. package/build/quote/v2/edit.js +1 -1
  167. package/build/quote/v2/edit.js.map +1 -1
  168. package/build/search/edit.js +1 -0
  169. package/build/search/edit.js.map +1 -1
  170. package/build/site-logo/edit.js +1 -1
  171. package/build/site-logo/edit.js.map +1 -1
  172. package/build/table/edit.js +15 -2
  173. package/build/table/edit.js.map +1 -1
  174. package/build/table-of-contents/edit.js +138 -66
  175. package/build/table-of-contents/edit.js.map +1 -1
  176. package/build/table-of-contents/index.js +13 -3
  177. package/build/table-of-contents/index.js.map +1 -1
  178. package/build/table-of-contents/list.js +16 -9
  179. package/build/table-of-contents/list.js.map +1 -1
  180. package/build/table-of-contents/save.js +40 -0
  181. package/build/table-of-contents/save.js.map +1 -0
  182. package/build/table-of-contents/utils.js +11 -77
  183. package/build/table-of-contents/utils.js.map +1 -1
  184. package/build/template-part/edit/index.js +7 -3
  185. package/build/template-part/edit/index.js.map +1 -1
  186. package/build/template-part/edit/inner-blocks.js +3 -8
  187. package/build/template-part/edit/inner-blocks.js.map +1 -1
  188. package/build/video/edit.js +1 -1
  189. package/build/video/edit.js.map +1 -1
  190. package/build-module/audio/edit.js +2 -2
  191. package/build-module/audio/edit.js.map +1 -1
  192. package/build-module/block/edit.js +11 -10
  193. package/build-module/block/edit.js.map +1 -1
  194. package/build-module/button/index.js +1 -0
  195. package/build-module/button/index.js.map +1 -1
  196. package/build-module/categories/edit.js +1 -1
  197. package/build-module/categories/edit.js.map +1 -1
  198. package/build-module/categories/index.js +1 -1
  199. package/build-module/comment-author-avatar/index.js +1 -0
  200. package/build-module/comment-author-avatar/index.js.map +1 -1
  201. package/build-module/comments-title/deprecated.js +102 -0
  202. package/build-module/comments-title/deprecated.js.map +1 -0
  203. package/build-module/comments-title/edit.js +38 -40
  204. package/build-module/comments-title/edit.js.map +1 -1
  205. package/build-module/comments-title/index.js +4 -8
  206. package/build-module/comments-title/index.js.map +1 -1
  207. package/build-module/cover/controls.native.js +2 -3
  208. package/build-module/cover/controls.native.js.map +1 -1
  209. package/build-module/cover/edit/block-controls.js +104 -0
  210. package/build-module/cover/edit/block-controls.js.map +1 -0
  211. package/build-module/cover/edit/cover-placeholder.js +38 -0
  212. package/build-module/cover/edit/cover-placeholder.js.map +1 -0
  213. package/build-module/cover/edit/index.js +307 -0
  214. package/build-module/cover/edit/index.js.map +1 -0
  215. package/build-module/cover/edit/inspector-controls.js +215 -0
  216. package/build-module/cover/edit/inspector-controls.js.map +1 -0
  217. package/build-module/cover/edit/resizable-cover.js +55 -0
  218. package/build-module/cover/edit/resizable-cover.js.map +1 -0
  219. package/build-module/cover/{use-cover-is-dark.js → edit/use-cover-is-dark.js} +0 -0
  220. package/build-module/cover/edit/use-cover-is-dark.js.map +1 -0
  221. package/build-module/cover/edit.native.js +0 -1
  222. package/build-module/cover/edit.native.js.map +1 -1
  223. package/build-module/cover/focal-point-settings-button.native.js.map +1 -1
  224. package/build-module/cover/shared.js +7 -0
  225. package/build-module/cover/shared.js.map +1 -1
  226. package/build-module/embed/embed-preview.js +2 -2
  227. package/build-module/embed/embed-preview.js.map +1 -1
  228. package/build-module/file/edit.native.js +0 -1
  229. package/build-module/file/edit.native.js.map +1 -1
  230. package/build-module/gallery/edit.js +2 -1
  231. package/build-module/gallery/edit.js.map +1 -1
  232. package/build-module/gallery/gallery.js +2 -2
  233. package/build-module/gallery/gallery.js.map +1 -1
  234. package/build-module/gallery/shared.js +2 -2
  235. package/build-module/gallery/shared.js.map +1 -1
  236. package/build-module/gallery/use-get-media.js +2 -1
  237. package/build-module/gallery/use-get-media.js.map +1 -1
  238. package/build-module/gallery/use-short-code-transform.js +19 -18
  239. package/build-module/gallery/use-short-code-transform.js.map +1 -1
  240. package/build-module/gallery/v1/gallery.js +2 -2
  241. package/build-module/gallery/v1/gallery.js.map +1 -1
  242. package/build-module/heading/edit.js +6 -2
  243. package/build-module/heading/edit.js.map +1 -1
  244. package/build-module/heading/index.js +1 -0
  245. package/build-module/heading/index.js.map +1 -1
  246. package/build-module/heading/transforms.js +1 -0
  247. package/build-module/heading/transforms.js.map +1 -1
  248. package/build-module/image/edit.js +6 -3
  249. package/build-module/image/edit.js.map +1 -1
  250. package/build-module/image/edit.native.js +0 -1
  251. package/build-module/image/edit.native.js.map +1 -1
  252. package/build-module/image/image.js +2 -2
  253. package/build-module/image/image.js.map +1 -1
  254. package/build-module/index.js +42 -10
  255. package/build-module/index.js.map +1 -1
  256. package/build-module/is-block-metadata-experimental.js +16 -0
  257. package/build-module/is-block-metadata-experimental.js.map +1 -0
  258. package/build-module/latest-posts/edit.js +29 -5
  259. package/build-module/latest-posts/edit.js.map +1 -1
  260. package/build-module/list/transforms.js +6 -0
  261. package/build-module/list/transforms.js.map +1 -1
  262. package/build-module/list/v2/edit.js +2 -1
  263. package/build-module/list/v2/edit.js.map +1 -1
  264. package/build-module/list/v2/migrate.js +1 -3
  265. package/build-module/list/v2/migrate.js.map +1 -1
  266. package/build-module/list/v2/transforms.js +46 -9
  267. package/build-module/list/v2/transforms.js.map +1 -1
  268. package/build-module/list-item/edit.js +8 -9
  269. package/build-module/list-item/edit.js.map +1 -1
  270. package/build-module/list-item/hooks/index.js +3 -0
  271. package/build-module/list-item/hooks/index.js.map +1 -1
  272. package/build-module/list-item/hooks/use-backspace.js +44 -0
  273. package/build-module/list-item/hooks/use-backspace.js.map +1 -0
  274. package/build-module/list-item/hooks/use-enter.js +6 -9
  275. package/build-module/list-item/hooks/use-enter.js.map +1 -1
  276. package/build-module/list-item/hooks/use-indent-list-item.js +33 -38
  277. package/build-module/list-item/hooks/use-indent-list-item.js.map +1 -1
  278. package/build-module/list-item/hooks/use-space.js +40 -0
  279. package/build-module/list-item/hooks/use-space.js.map +1 -0
  280. package/build-module/list-item/hooks/use-split.js +19 -0
  281. package/build-module/list-item/hooks/use-split.js.map +1 -0
  282. package/build-module/list-item/index.js +1 -0
  283. package/build-module/list-item/index.js.map +1 -1
  284. package/build-module/list-item/utils.js +1 -1
  285. package/build-module/list-item/utils.js.map +1 -1
  286. package/build-module/media-text/edit.native.js +2 -1
  287. package/build-module/media-text/edit.native.js.map +1 -1
  288. package/build-module/media-text/media-container.native.js +2 -4
  289. package/build-module/media-text/media-container.native.js.map +1 -1
  290. package/build-module/media-text/transforms.js +137 -8
  291. package/build-module/media-text/transforms.js.map +1 -1
  292. package/build-module/navigation/edit/index.js +87 -82
  293. package/build-module/navigation/edit/index.js.map +1 -1
  294. package/build-module/navigation/edit/inner-blocks.js +2 -6
  295. package/build-module/navigation/edit/inner-blocks.js.map +1 -1
  296. package/build-module/navigation/use-navigation-entities.js +1 -1
  297. package/build-module/navigation/use-navigation-entities.js.map +1 -1
  298. package/build-module/navigation-link/fallback-variations.js +1 -1
  299. package/build-module/navigation-link/fallback-variations.js.map +1 -1
  300. package/build-module/navigation-link/hooks.js +2 -2
  301. package/build-module/navigation-link/hooks.js.map +1 -1
  302. package/build-module/page-list/convert-to-links-modal.js +1 -1
  303. package/build-module/page-list/convert-to-links-modal.js.map +1 -1
  304. package/build-module/page-list/edit.js +1 -1
  305. package/build-module/page-list/edit.js.map +1 -1
  306. package/build-module/post-author/edit.js +1 -1
  307. package/build-module/post-author/edit.js.map +1 -1
  308. package/build-module/post-author-name/index.js +1 -0
  309. package/build-module/post-author-name/index.js.map +1 -1
  310. package/build-module/post-comment/index.js +1 -0
  311. package/build-module/post-comment/index.js.map +1 -1
  312. package/build-module/post-comments/edit.js +35 -16
  313. package/build-module/post-comments/edit.js.map +1 -1
  314. package/build-module/post-comments-count/index.js +1 -0
  315. package/build-module/post-comments-count/index.js.map +1 -1
  316. package/build-module/post-comments-form/form.js +1 -1
  317. package/build-module/post-comments-form/form.js.map +1 -1
  318. package/build-module/post-comments-link/index.js +1 -0
  319. package/build-module/post-comments-link/index.js.map +1 -1
  320. package/build-module/post-featured-image/edit.js +1 -1
  321. package/build-module/post-featured-image/edit.js.map +1 -1
  322. package/build-module/post-template/edit.js +7 -2
  323. package/build-module/post-template/edit.js.map +1 -1
  324. package/build-module/post-terms/edit.js +10 -3
  325. package/build-module/post-terms/edit.js.map +1 -1
  326. package/build-module/post-terms/hooks.js +25 -0
  327. package/build-module/post-terms/hooks.js.map +1 -0
  328. package/build-module/post-terms/index.js +10 -8
  329. package/build-module/post-terms/index.js.map +1 -1
  330. package/build-module/post-title/index.js +1 -1
  331. package/build-module/post-title/index.js.map +1 -1
  332. package/build-module/pullquote/edit.js +2 -2
  333. package/build-module/pullquote/edit.js.map +1 -1
  334. package/build-module/pullquote/edit.native.js +2 -2
  335. package/build-module/pullquote/edit.native.js.map +1 -1
  336. package/build-module/query/edit/inspector-controls/index.js +24 -17
  337. package/build-module/query/edit/inspector-controls/index.js.map +1 -1
  338. package/build-module/query/edit/inspector-controls/parent-control.js +135 -0
  339. package/build-module/query/edit/inspector-controls/parent-control.js.map +1 -0
  340. package/build-module/query/edit/inspector-controls/sticky-control.js +31 -0
  341. package/build-module/query/edit/inspector-controls/sticky-control.js.map +1 -0
  342. package/build-module/query/index.js +2 -1
  343. package/build-module/query/index.js.map +1 -1
  344. package/build-module/query/utils.js +21 -0
  345. package/build-module/query/utils.js.map +1 -1
  346. package/build-module/query-title/index.js +1 -1
  347. package/build-module/query-title/index.js.map +1 -1
  348. package/build-module/query-title/variations.js +2 -2
  349. package/build-module/query-title/variations.js.map +1 -1
  350. package/build-module/quote/edit.js +4 -3
  351. package/build-module/quote/edit.js.map +1 -1
  352. package/build-module/quote/v2/edit.js +2 -2
  353. package/build-module/quote/v2/edit.js.map +1 -1
  354. package/build-module/search/edit.js +1 -0
  355. package/build-module/search/edit.js.map +1 -1
  356. package/build-module/site-logo/edit.js +1 -1
  357. package/build-module/site-logo/edit.js.map +1 -1
  358. package/build-module/table/edit.js +17 -4
  359. package/build-module/table/edit.js.map +1 -1
  360. package/build-module/table-of-contents/edit.js +136 -68
  361. package/build-module/table-of-contents/edit.js.map +1 -1
  362. package/build-module/table-of-contents/index.js +12 -3
  363. package/build-module/table-of-contents/index.js.map +1 -1
  364. package/build-module/table-of-contents/list.js +18 -10
  365. package/build-module/table-of-contents/list.js.map +1 -1
  366. package/build-module/table-of-contents/save.js +28 -0
  367. package/build-module/table-of-contents/save.js.map +1 -0
  368. package/build-module/table-of-contents/utils.js +11 -73
  369. package/build-module/table-of-contents/utils.js.map +1 -1
  370. package/build-module/template-part/edit/index.js +8 -4
  371. package/build-module/template-part/edit/index.js.map +1 -1
  372. package/build-module/template-part/edit/inner-blocks.js +4 -9
  373. package/build-module/template-part/edit/inner-blocks.js.map +1 -1
  374. package/build-module/video/edit.js +2 -2
  375. package/build-module/video/edit.js.map +1 -1
  376. package/build-style/editor-rtl.css +4 -6
  377. package/build-style/editor.css +4 -6
  378. package/build-style/image/editor-rtl.css +1 -1
  379. package/build-style/image/editor.css +1 -1
  380. package/build-style/post-comments/style-rtl.css +22 -0
  381. package/build-style/post-comments/style.css +22 -0
  382. package/build-style/post-comments-form/style-rtl.css +1 -3
  383. package/build-style/post-comments-form/style.css +1 -3
  384. package/build-style/separator/editor-rtl.css +1 -0
  385. package/build-style/separator/editor.css +1 -0
  386. package/build-style/style-rtl.css +23 -3
  387. package/build-style/style.css +23 -3
  388. package/build-style/video/editor-rtl.css +2 -5
  389. package/build-style/video/editor.css +2 -5
  390. package/build-types/table-of-contents/list.d.ts +12 -0
  391. package/build-types/table-of-contents/list.d.ts.map +1 -0
  392. package/build-types/table-of-contents/utils.d.ts +24 -0
  393. package/build-types/table-of-contents/utils.d.ts.map +1 -0
  394. package/package.json +30 -29
  395. package/src/audio/edit.js +4 -2
  396. package/src/avatar/block.json +0 -1
  397. package/src/avatar/index.php +2 -2
  398. package/src/block/edit.js +39 -42
  399. package/src/block/test/edit.native.js +1 -1
  400. package/src/button/block.json +1 -0
  401. package/src/categories/block.json +1 -1
  402. package/src/categories/edit.js +1 -1
  403. package/src/comment-author-avatar/block.json +1 -0
  404. package/src/comments-title/block.json +0 -6
  405. package/src/comments-title/deprecated.js +34 -0
  406. package/src/comments-title/edit.js +44 -100
  407. package/src/comments-title/index.js +3 -1
  408. package/src/comments-title/index.php +41 -23
  409. package/src/cover/controls.native.js +1 -2
  410. package/src/cover/edit/block-controls.js +119 -0
  411. package/src/cover/edit/cover-placeholder.js +39 -0
  412. package/src/cover/edit/index.js +381 -0
  413. package/src/cover/edit/inspector-controls.js +286 -0
  414. package/src/cover/edit/resizable-cover.js +55 -0
  415. package/src/cover/{use-cover-is-dark.js → edit/use-cover-is-dark.js} +0 -0
  416. package/src/cover/edit.native.js +0 -1
  417. package/src/cover/editor.scss +1 -1
  418. package/src/cover/focal-point-settings-button.native.js +1 -1
  419. package/src/cover/index.php +20 -37
  420. package/src/cover/shared.js +4 -0
  421. package/src/cover/test/block-controls.js +62 -0
  422. package/src/embed/embed-preview.js +4 -2
  423. package/src/file/edit.native.js +0 -1
  424. package/src/gallery/edit.js +2 -1
  425. package/src/gallery/gallery.js +2 -2
  426. package/src/gallery/shared.js +3 -2
  427. package/src/gallery/use-get-media.js +2 -1
  428. package/src/gallery/use-short-code-transform.js +19 -16
  429. package/src/gallery/v1/gallery.js +2 -2
  430. package/src/heading/block.json +1 -0
  431. package/src/heading/edit.js +5 -2
  432. package/src/image/edit.js +9 -1
  433. package/src/image/edit.native.js +0 -1
  434. package/src/image/editor.scss +1 -1
  435. package/src/image/image.js +8 -2
  436. package/src/image/test/edit.native.js +7 -7
  437. package/src/index.js +50 -27
  438. package/src/is-block-metadata-experimental.js +19 -0
  439. package/src/latest-posts/edit.js +27 -2
  440. package/src/latest-posts/index.php +12 -6
  441. package/src/list/transforms.js +7 -0
  442. package/src/list/v2/edit.js +1 -0
  443. package/src/list/v2/migrate.js +1 -1
  444. package/src/list/v2/transforms.js +35 -0
  445. package/src/list-item/block.json +2 -1
  446. package/src/list-item/edit.js +17 -10
  447. package/src/list-item/hooks/index.js +3 -0
  448. package/src/list-item/hooks/use-backspace.js +52 -0
  449. package/src/list-item/hooks/use-enter.js +9 -16
  450. package/src/list-item/hooks/use-indent-list-item.js +50 -63
  451. package/src/list-item/hooks/use-space.js +48 -0
  452. package/src/list-item/hooks/use-split.js +24 -0
  453. package/src/list-item/utils.js +1 -1
  454. package/src/media-text/edit.native.js +3 -1
  455. package/src/media-text/media-container.native.js +2 -4
  456. package/src/media-text/transforms.js +154 -0
  457. package/src/navigation/edit/index.js +175 -169
  458. package/src/navigation/edit/inner-blocks.js +1 -8
  459. package/src/navigation/index.php +40 -0
  460. package/src/navigation/use-navigation-entities.js +1 -1
  461. package/src/navigation-link/fallback-variations.js +1 -1
  462. package/src/navigation-link/hooks.js +2 -2
  463. package/src/navigation-link/test/__snapshots__/hooks.js.snap +4 -4
  464. package/src/page-list/convert-to-links-modal.js +1 -1
  465. package/src/page-list/edit.js +1 -4
  466. package/src/post-author/edit.js +24 -22
  467. package/src/post-author-name/block.json +1 -0
  468. package/src/post-comment/block.json +1 -0
  469. package/src/post-comments/edit.js +54 -22
  470. package/src/post-comments/style.scss +26 -0
  471. package/src/post-comments-count/block.json +1 -0
  472. package/src/post-comments-form/form.js +1 -4
  473. package/src/post-comments-form/style.scss +1 -4
  474. package/src/post-comments-link/block.json +1 -0
  475. package/src/post-featured-image/edit.js +1 -1
  476. package/src/post-template/edit.js +5 -0
  477. package/src/post-template/index.php +30 -0
  478. package/src/post-terms/edit.js +19 -0
  479. package/src/post-terms/hooks.js +27 -0
  480. package/src/post-terms/index.js +14 -7
  481. package/src/post-terms/index.php +40 -2
  482. package/src/post-title/index.js +1 -1
  483. package/src/pullquote/edit.js +2 -2
  484. package/src/pullquote/edit.native.js +2 -2
  485. package/src/query/block.json +2 -1
  486. package/src/query/edit/inspector-controls/index.js +25 -11
  487. package/src/query/edit/inspector-controls/parent-control.js +133 -0
  488. package/src/query/edit/inspector-controls/sticky-control.js +25 -0
  489. package/src/query/utils.js +22 -0
  490. package/src/query-title/index.js +1 -1
  491. package/src/query-title/variations.js +2 -2
  492. package/src/quote/edit.js +5 -2
  493. package/src/quote/v2/edit.js +4 -2
  494. package/src/search/edit.js +1 -0
  495. package/src/search/index.php +1 -1
  496. package/src/separator/editor.scss +1 -0
  497. package/src/site-logo/edit.js +1 -1
  498. package/src/table/edit.js +19 -4
  499. package/src/table-of-contents/block.json +9 -2
  500. package/src/table-of-contents/edit.js +155 -75
  501. package/src/table-of-contents/index.js +2 -0
  502. package/src/table-of-contents/list.tsx +46 -0
  503. package/src/table-of-contents/save.js +25 -0
  504. package/src/table-of-contents/utils.ts +71 -0
  505. package/src/tag-cloud/block.json +1 -1
  506. package/src/template-part/edit/index.js +25 -15
  507. package/src/template-part/edit/inner-blocks.js +2 -10
  508. package/src/video/edit.js +4 -2
  509. package/src/video/editor.scss +3 -6
  510. package/test/babel-plugin.js +67 -0
  511. package/tsconfig.json +11 -0
  512. package/tsconfig.tsbuildinfo +1 -0
  513. package/build/cover/edit.js +0 -598
  514. package/build/cover/edit.js.map +0 -1
  515. package/build/cover/use-cover-is-dark.js.map +0 -1
  516. package/build/post-terms/variations.js +0 -37
  517. package/build/post-terms/variations.js.map +0 -1
  518. package/build-module/cover/edit.js +0 -575
  519. package/build-module/cover/edit.js.map +0 -1
  520. package/build-module/cover/use-cover-is-dark.js.map +0 -1
  521. package/build-module/post-terms/variations.js +0 -27
  522. package/build-module/post-terms/variations.js.map +0 -1
  523. package/src/cover/edit.js +0 -757
  524. package/src/post-terms/variations.js +0 -28
  525. package/src/table-of-contents/index.php +0 -346
  526. package/src/table-of-contents/list.js +0 -28
  527. package/src/table-of-contents/utils.js +0 -126
@@ -22,9 +22,10 @@ function render_block_core_comments_title( $attributes ) {
22
22
  $show_post_title = ! empty( $attributes['showPostTitle'] ) && $attributes['showPostTitle'];
23
23
  $show_comments_count = ! empty( $attributes['showCommentsCount'] ) && $attributes['showCommentsCount'];
24
24
  $wrapper_attributes = get_block_wrapper_attributes( array( 'class' => $align_class_name ) );
25
- $post_title = $show_post_title ? sprintf( '"%1$s"', get_the_title() ) : null;
26
- $comments_count = number_format_i18n( get_comments_number() );
27
- $tag_name = 'h2';
25
+ $comments_count = get_comments_number();
26
+ /* translators: %s: Post title. */
27
+ $post_title = sprintf( __( '“%s”' ), get_the_title() );
28
+ $tag_name = 'h2';
28
29
  if ( isset( $attributes['level'] ) ) {
29
30
  $tag_name = 'h' . $attributes['level'];
30
31
  }
@@ -33,28 +34,45 @@ function render_block_core_comments_title( $attributes ) {
33
34
  return;
34
35
  }
35
36
 
36
- $single_default_comment_label = $show_post_title ? __( 'Response to' ) : __( 'Response' );
37
37
  if ( $show_comments_count ) {
38
- $single_default_comment_label = $show_post_title ? __( 'One response to' ) : __( 'One response' );
38
+ if ( $show_post_title ) {
39
+ if ( '1' === $comments_count ) {
40
+ /* translators: %s: Post title. */
41
+ $comments_title = sprintf( __( 'One response to %s' ), $post_title );
42
+ } else {
43
+ $comments_title = sprintf(
44
+ /* translators: 1: Number of comments, 2: Post title. */
45
+ _n(
46
+ '%1$s response to %2$s',
47
+ '%1$s responses to %2$s',
48
+ $comments_count
49
+ ),
50
+ number_format_i18n( $comments_count ),
51
+ $post_title
52
+ );
53
+ }
54
+ } elseif ( '1' === $comments_count ) {
55
+ $comments_title = __( 'One response' );
56
+ } else {
57
+ $comments_title = sprintf(
58
+ /* translators: %s: Number of comments. */
59
+ _n( '%s responses', '%s responses', $comments_count ),
60
+ number_format_i18n( $comments_count )
61
+ );
62
+ }
63
+ } elseif ( $show_post_title ) {
64
+ if ( '1' === $comments_count ) {
65
+ /* translators: %s: Post title. */
66
+ $comments_title = sprintf( __( 'Response to %s' ), $post_title );
67
+ } else {
68
+ /* translators: %s: Post title. */
69
+ $comments_title = sprintf( __( 'Responses to %s' ), $post_title );
70
+ }
71
+ } elseif ( '1' === $comments_count ) {
72
+ $comments_title = __( 'Response' );
73
+ } else {
74
+ $comments_title = __( 'Responses' );
39
75
  }
40
- $single_comment_label = ! empty( $attributes['singleCommentLabel'] ) ? $attributes['singleCommentLabel'] : $single_default_comment_label;
41
-
42
- $multiple_default_comment_label = $show_post_title ? __( 'Responses to' ) : __( 'Responses' );
43
- if ( $show_comments_count ) {
44
- $multiple_default_comment_label = $show_post_title ? __( 'responses to' ) : __( 'responses' );
45
- }
46
-
47
- $multiple_comment_label = ! empty( $attributes['multipleCommentsLabel'] ) ? $attributes['multipleCommentsLabel'] : $multiple_default_comment_label;
48
-
49
- $comments_title = '%1$s %2$s %3$s';
50
-
51
- $comments_title = sprintf(
52
- $comments_title,
53
- // If there is only one comment, only display the label.
54
- '1' !== $comments_count && $show_comments_count ? $comments_count : null,
55
- '1' === $comments_count ? $single_comment_label : $multiple_comment_label,
56
- $post_title
57
- );
58
76
 
59
77
  return sprintf(
60
78
  '<%1$s id="comments" %2$s>%3$s</%1$s>',
@@ -167,7 +167,6 @@ function Controls( {
167
167
  styles.mediaPreview,
168
168
  mediaBackground,
169
169
  ] }
170
- onLongPress={ openMediaOptions }
171
170
  >
172
171
  <View style={ styles.mediaInner }>
173
172
  { IMAGE_BACKGROUND_TYPE === backgroundType && (
@@ -217,7 +216,7 @@ function Controls( {
217
216
  } );
218
217
  setDisplayPlaceholder( false );
219
218
  // Avoid invisible, paused video on Android, presumably
220
- // related to https://git.io/Jt6Dr
219
+ // related to https://github.com/react-native-video/react-native-video/issues/1979
221
220
  videoRef?.current.seek( 0 );
222
221
  } }
223
222
  ref={ videoRef }
@@ -0,0 +1,119 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { useState } from '@wordpress/element';
5
+ import { ToolbarButton } from '@wordpress/components';
6
+
7
+ import {
8
+ BlockControls,
9
+ MediaReplaceFlow,
10
+ __experimentalBlockAlignmentMatrixControl as BlockAlignmentMatrixControl,
11
+ __experimentalBlockFullHeightAligmentControl as FullHeightAlignmentControl,
12
+ } from '@wordpress/block-editor';
13
+ import { __ } from '@wordpress/i18n';
14
+ import { postFeaturedImage } from '@wordpress/icons';
15
+
16
+ /**
17
+ * Internal dependencies
18
+ */
19
+ import { ALLOWED_MEDIA_TYPES, IMAGE_BACKGROUND_TYPE } from '../shared';
20
+
21
+ export default function CoverBlockControls( {
22
+ attributes,
23
+ setAttributes,
24
+ onSelectMedia,
25
+ currentSettings,
26
+ } ) {
27
+ const {
28
+ contentPosition,
29
+ id,
30
+ useFeaturedImage,
31
+ dimRatio,
32
+ minHeight,
33
+ minHeightUnit,
34
+ } = attributes;
35
+ const { hasInnerBlocks, url } = currentSettings;
36
+
37
+ const [ prevMinHeightValue, setPrevMinHeightValue ] = useState( minHeight );
38
+ const [ prevMinHeightUnit, setPrevMinHeightUnit ] = useState(
39
+ minHeightUnit
40
+ );
41
+ const isMinFullHeight = minHeightUnit === 'vh' && minHeight === 100;
42
+ const toggleMinFullHeight = () => {
43
+ if ( isMinFullHeight ) {
44
+ // If there aren't previous values, take the default ones.
45
+ if ( prevMinHeightUnit === 'vh' && prevMinHeightValue === 100 ) {
46
+ return setAttributes( {
47
+ minHeight: undefined,
48
+ minHeightUnit: undefined,
49
+ } );
50
+ }
51
+
52
+ // Set the previous values of height.
53
+ return setAttributes( {
54
+ minHeight: prevMinHeightValue,
55
+ minHeightUnit: prevMinHeightUnit,
56
+ } );
57
+ }
58
+
59
+ setPrevMinHeightValue( minHeight );
60
+ setPrevMinHeightUnit( minHeightUnit );
61
+
62
+ // Set full height.
63
+ return setAttributes( {
64
+ minHeight: 100,
65
+ minHeightUnit: 'vh',
66
+ } );
67
+ };
68
+
69
+ const toggleUseFeaturedImage = () => {
70
+ setAttributes( {
71
+ id: undefined,
72
+ url: undefined,
73
+ useFeaturedImage: ! useFeaturedImage,
74
+ dimRatio: dimRatio === 100 ? 50 : dimRatio,
75
+ backgroundType: useFeaturedImage
76
+ ? IMAGE_BACKGROUND_TYPE
77
+ : undefined,
78
+ } );
79
+ };
80
+ return (
81
+ <>
82
+ <BlockControls group="block">
83
+ <BlockAlignmentMatrixControl
84
+ label={ __( 'Change content position' ) }
85
+ value={ contentPosition }
86
+ onChange={ ( nextPosition ) =>
87
+ setAttributes( {
88
+ contentPosition: nextPosition,
89
+ } )
90
+ }
91
+ isDisabled={ ! hasInnerBlocks }
92
+ />
93
+ <FullHeightAlignmentControl
94
+ isActive={ isMinFullHeight }
95
+ onToggle={ toggleMinFullHeight }
96
+ isDisabled={ ! hasInnerBlocks }
97
+ />
98
+ </BlockControls>
99
+ <BlockControls group="other">
100
+ <ToolbarButton
101
+ icon={ postFeaturedImage }
102
+ label={ __( 'Use featured image' ) }
103
+ isPressed={ useFeaturedImage }
104
+ onClick={ toggleUseFeaturedImage }
105
+ />
106
+ { ! useFeaturedImage && (
107
+ <MediaReplaceFlow
108
+ mediaId={ id }
109
+ mediaURL={ url }
110
+ allowedTypes={ ALLOWED_MEDIA_TYPES }
111
+ accept="image/*,video/*"
112
+ onSelect={ onSelectMedia }
113
+ name={ ! url ? __( 'Add Media' ) : __( 'Replace' ) }
114
+ />
115
+ ) }
116
+ </BlockControls>
117
+ </>
118
+ );
119
+ }
@@ -0,0 +1,39 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { BlockIcon, MediaPlaceholder } from '@wordpress/block-editor';
5
+ import { __ } from '@wordpress/i18n';
6
+ import { cover as icon } from '@wordpress/icons';
7
+
8
+ /**
9
+ * Internal dependencies
10
+ */
11
+ import { ALLOWED_MEDIA_TYPES } from '../shared';
12
+
13
+ export default function CoverPlaceholder( {
14
+ disableMediaButtons = false,
15
+ children,
16
+ onSelectMedia,
17
+ onError,
18
+ style,
19
+ } ) {
20
+ return (
21
+ <MediaPlaceholder
22
+ icon={ <BlockIcon icon={ icon } /> }
23
+ labels={ {
24
+ title: __( 'Cover' ),
25
+ instructions: __(
26
+ 'Drag and drop onto this block, upload, or select existing media from your library.'
27
+ ),
28
+ } }
29
+ onSelect={ onSelectMedia }
30
+ accept="image/*,video/*"
31
+ allowedTypes={ ALLOWED_MEDIA_TYPES }
32
+ disableMediaButtons={ disableMediaButtons }
33
+ onError={ onError }
34
+ style={ style }
35
+ >
36
+ { children }
37
+ </MediaPlaceholder>
38
+ );
39
+ }
@@ -0,0 +1,381 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import classnames from 'classnames';
5
+ import { extend } from 'colord';
6
+ import namesPlugin from 'colord/plugins/names';
7
+
8
+ /**
9
+ * WordPress dependencies
10
+ */
11
+ import { useEntityProp, store as coreStore } from '@wordpress/core-data';
12
+ import { useEffect, useRef } from '@wordpress/element';
13
+ import { Spinner } from '@wordpress/components';
14
+ import { compose } from '@wordpress/compose';
15
+ import {
16
+ withColors,
17
+ ColorPalette,
18
+ useBlockProps,
19
+ useSetting,
20
+ useInnerBlocksProps,
21
+ __experimentalUseGradient,
22
+ store as blockEditorStore,
23
+ } from '@wordpress/block-editor';
24
+ import { __ } from '@wordpress/i18n';
25
+ import { useSelect, useDispatch } from '@wordpress/data';
26
+ import { isBlobURL } from '@wordpress/blob';
27
+ import { store as noticesStore } from '@wordpress/notices';
28
+
29
+ /**
30
+ * Internal dependencies
31
+ */
32
+ import {
33
+ attributesFromMedia,
34
+ IMAGE_BACKGROUND_TYPE,
35
+ VIDEO_BACKGROUND_TYPE,
36
+ backgroundImageStyles,
37
+ dimRatioToClass,
38
+ isContentPositionCenter,
39
+ getPositionClassName,
40
+ mediaPosition,
41
+ } from '../shared';
42
+ import useCoverIsDark from './use-cover-is-dark';
43
+ import CoverInspectorControls from './inspector-controls';
44
+ import CoverBlockControls from './block-controls';
45
+ import CoverPlaceholder from './cover-placeholder';
46
+ import ResizableCover from './resizable-cover';
47
+
48
+ extend( [ namesPlugin ] );
49
+
50
+ function getInnerBlocksTemplate( attributes ) {
51
+ return [
52
+ [
53
+ 'core/paragraph',
54
+ {
55
+ align: 'center',
56
+ placeholder: __( 'Write title…' ),
57
+ ...attributes,
58
+ },
59
+ ],
60
+ ];
61
+ }
62
+
63
+ /**
64
+ * Is the URL a temporary blob URL? A blob URL is one that is used temporarily while
65
+ * the media (image or video) is being uploaded and will not have an id allocated yet.
66
+ *
67
+ * @param {number} id The id of the media.
68
+ * @param {string} url The url of the media.
69
+ *
70
+ * @return {boolean} Is the URL a Blob URL.
71
+ */
72
+ const isTemporaryMedia = ( id, url ) => ! id && isBlobURL( url );
73
+
74
+ function CoverEdit( {
75
+ attributes,
76
+ clientId,
77
+ isSelected,
78
+ overlayColor,
79
+ setAttributes,
80
+ setOverlayColor,
81
+ toggleSelection,
82
+ context: { postId, postType },
83
+ } ) {
84
+ const {
85
+ contentPosition,
86
+ id,
87
+ useFeaturedImage,
88
+ dimRatio,
89
+ focalPoint,
90
+ hasParallax,
91
+ isDark,
92
+ isRepeated,
93
+ minHeight,
94
+ minHeightUnit,
95
+ alt,
96
+ allowedBlocks,
97
+ templateLock,
98
+ } = attributes;
99
+
100
+ const [ featuredImage ] = useEntityProp(
101
+ 'postType',
102
+ postType,
103
+ 'featured_media',
104
+ postId
105
+ );
106
+
107
+ const media = useSelect(
108
+ ( select ) =>
109
+ featuredImage &&
110
+ select( coreStore ).getMedia( featuredImage, { context: 'view' } ),
111
+ [ featuredImage ]
112
+ );
113
+ const mediaUrl = media?.source_url;
114
+
115
+ // instead of destructuring the attributes
116
+ // we define the url and background type
117
+ // depending on the value of the useFeaturedImage flag
118
+ // to preview in edit the dynamic featured image
119
+ const url = useFeaturedImage ? mediaUrl : attributes.url;
120
+ const backgroundType = useFeaturedImage
121
+ ? IMAGE_BACKGROUND_TYPE
122
+ : attributes.backgroundType;
123
+
124
+ const { __unstableMarkNextChangeAsNotPersistent } = useDispatch(
125
+ blockEditorStore
126
+ );
127
+ const { createErrorNotice } = useDispatch( noticesStore );
128
+ const { gradientClass, gradientValue } = __experimentalUseGradient();
129
+ const onSelectMedia = attributesFromMedia( setAttributes, dimRatio );
130
+ const isUploadingMedia = isTemporaryMedia( id, url );
131
+
132
+ const onUploadError = ( message ) => {
133
+ createErrorNotice( message, { type: 'snackbar' } );
134
+ };
135
+
136
+ const mediaElement = useRef();
137
+ const isCoverDark = useCoverIsDark(
138
+ url,
139
+ dimRatio,
140
+ overlayColor.color,
141
+ mediaElement
142
+ );
143
+
144
+ useEffect( () => {
145
+ // This side-effect should not create an undo level.
146
+ __unstableMarkNextChangeAsNotPersistent();
147
+ setAttributes( { isDark: isCoverDark } );
148
+ }, [ isCoverDark ] );
149
+
150
+ const isImageBackground = IMAGE_BACKGROUND_TYPE === backgroundType;
151
+ const isVideoBackground = VIDEO_BACKGROUND_TYPE === backgroundType;
152
+
153
+ const minHeightWithUnit =
154
+ minHeight && minHeightUnit
155
+ ? `${ minHeight }${ minHeightUnit }`
156
+ : minHeight;
157
+
158
+ const isImgElement = ! ( hasParallax || isRepeated );
159
+
160
+ const style = {
161
+ ...( isImageBackground && ! isImgElement
162
+ ? backgroundImageStyles( url )
163
+ : undefined ),
164
+ minHeight: minHeightWithUnit || undefined,
165
+ };
166
+
167
+ const bgStyle = { backgroundColor: overlayColor.color };
168
+ const mediaStyle = {
169
+ objectPosition:
170
+ focalPoint && isImgElement
171
+ ? mediaPosition( focalPoint )
172
+ : undefined,
173
+ };
174
+
175
+ const hasBackground = !! ( url || overlayColor.color || gradientValue );
176
+
177
+ const hasInnerBlocks = useSelect(
178
+ ( select ) =>
179
+ select( blockEditorStore ).getBlock( clientId ).innerBlocks.length >
180
+ 0,
181
+ [ clientId ]
182
+ );
183
+
184
+ const ref = useRef();
185
+ const blockProps = useBlockProps( { ref } );
186
+
187
+ // Check for fontSize support before we pass a fontSize attribute to the innerBlocks.
188
+ const hasFontSizes = !! useSetting( 'typography.fontSizes' )?.length;
189
+ const innerBlocksTemplate = getInnerBlocksTemplate( {
190
+ fontSize: hasFontSizes ? 'large' : undefined,
191
+ } );
192
+
193
+ const innerBlocksProps = useInnerBlocksProps(
194
+ {
195
+ className: 'wp-block-cover__inner-container',
196
+ },
197
+ {
198
+ template: innerBlocksTemplate,
199
+ templateInsertUpdatesSelection: true,
200
+ allowedBlocks,
201
+ templateLock,
202
+ }
203
+ );
204
+
205
+ const currentSettings = {
206
+ isVideoBackground,
207
+ isImageBackground,
208
+ mediaElement,
209
+ hasInnerBlocks,
210
+ url,
211
+ isImgElement,
212
+ overlayColor,
213
+ };
214
+
215
+ if ( ! hasInnerBlocks && ! hasBackground ) {
216
+ return (
217
+ <>
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
+ />
232
+ <div
233
+ { ...blockProps }
234
+ className={ classnames(
235
+ 'is-placeholder',
236
+ blockProps.className
237
+ ) }
238
+ >
239
+ <CoverPlaceholder
240
+ onSelectMedia={ onSelectMedia }
241
+ onError={ onUploadError }
242
+ style={ {
243
+ minHeight: minHeightWithUnit || undefined,
244
+ } }
245
+ >
246
+ <div className="wp-block-cover__placeholder-background-options">
247
+ <ColorPalette
248
+ disableCustomColors={ true }
249
+ value={ overlayColor.color }
250
+ onChange={ setOverlayColor }
251
+ clearable={ false }
252
+ />
253
+ </div>
254
+ </CoverPlaceholder>
255
+ <ResizableCover
256
+ className="block-library-cover__resize-container"
257
+ onResizeStart={ () => {
258
+ setAttributes( { minHeightUnit: 'px' } );
259
+ toggleSelection( false );
260
+ } }
261
+ onResize={ ( value ) => {
262
+ setAttributes( { minHeight: value } );
263
+ } }
264
+ onResizeStop={ ( newMinHeight ) => {
265
+ toggleSelection( true );
266
+ setAttributes( { minHeight: newMinHeight } );
267
+ } }
268
+ showHandle={ isSelected }
269
+ />
270
+ </div>
271
+ </>
272
+ );
273
+ }
274
+
275
+ const classes = classnames(
276
+ {
277
+ 'is-dark-theme': isDark,
278
+ 'is-light': ! isDark,
279
+ 'is-transient': isUploadingMedia,
280
+ 'has-parallax': hasParallax,
281
+ 'is-repeated': isRepeated,
282
+ 'has-custom-content-position': ! isContentPositionCenter(
283
+ contentPosition
284
+ ),
285
+ },
286
+ getPositionClassName( contentPosition )
287
+ );
288
+
289
+ return (
290
+ <>
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
+ />
305
+ <div
306
+ { ...blockProps }
307
+ className={ classnames( classes, blockProps.className ) }
308
+ style={ { ...style, ...blockProps.style } }
309
+ data-url={ url }
310
+ >
311
+ <ResizableCover
312
+ className="block-library-cover__resize-container"
313
+ onResizeStart={ () => {
314
+ setAttributes( { minHeightUnit: 'px' } );
315
+ toggleSelection( false );
316
+ } }
317
+ onResize={ ( value ) => {
318
+ setAttributes( { minHeight: value } );
319
+ } }
320
+ onResizeStop={ ( newMinHeight ) => {
321
+ toggleSelection( true );
322
+ setAttributes( { minHeight: newMinHeight } );
323
+ } }
324
+ showHandle={ isSelected }
325
+ />
326
+
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
+ />
346
+
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 }
354
+ />
355
+ ) }
356
+ { url && isVideoBackground && (
357
+ <video
358
+ ref={ mediaElement }
359
+ className="wp-block-cover__video-background"
360
+ autoPlay
361
+ muted
362
+ loop
363
+ src={ url }
364
+ style={ mediaStyle }
365
+ />
366
+ ) }
367
+ { isUploadingMedia && <Spinner /> }
368
+ <CoverPlaceholder
369
+ disableMediaButtons
370
+ onSelectMedia={ onSelectMedia }
371
+ onError={ onUploadError }
372
+ />
373
+ <div { ...innerBlocksProps } />
374
+ </div>
375
+ </>
376
+ );
377
+ }
378
+
379
+ export default compose( [
380
+ withColors( { overlayColor: 'background-color' } ),
381
+ ] )( CoverEdit );