@wordpress/block-library 7.3.10 → 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 (752) hide show
  1. package/CHANGELOG.md +10 -0
  2. package/README.md +3 -2
  3. package/babel-plugin.js +154 -0
  4. package/build/archives/edit.js +1 -1
  5. package/build/archives/edit.js.map +1 -1
  6. package/build/audio/edit.js +5 -17
  7. package/build/audio/edit.js.map +1 -1
  8. package/build/audio/edit.native.js +1 -1
  9. package/build/audio/edit.native.js.map +1 -1
  10. package/build/block/edit.js +10 -9
  11. package/build/block/edit.js.map +1 -1
  12. package/build/button/edit.native.js +7 -3
  13. package/build/button/edit.native.js.map +1 -1
  14. package/build/button/index.js +1 -0
  15. package/build/button/index.js.map +1 -1
  16. package/build/categories/edit.js +9 -4
  17. package/build/categories/edit.js.map +1 -1
  18. package/build/categories/index.js +5 -1
  19. package/build/categories/index.js.map +1 -1
  20. package/build/column/index.js +10 -0
  21. package/build/column/index.js.map +1 -1
  22. package/build/comment-author-avatar/index.js +1 -0
  23. package/build/comment-author-avatar/index.js.map +1 -1
  24. package/build/comment-template/edit.js +1 -3
  25. package/build/comment-template/edit.js.map +1 -1
  26. package/build/{comments-query-loop → comments}/edit/comments-inspector-controls.js +0 -0
  27. package/{build-module/comments-query-loop → build/comments}/edit/comments-inspector-controls.js.map +1 -1
  28. package/build/{comments-query-loop → comments}/edit.js +2 -2
  29. package/build/comments/edit.js.map +1 -0
  30. package/build/{comments-query-loop → comments}/index.js +1 -1
  31. package/build/comments/index.js.map +1 -0
  32. package/build/{comments-query-loop → comments}/save.js +2 -2
  33. package/build/comments/save.js.map +1 -0
  34. package/build/comments-title/index.js +1 -1
  35. package/build/comments-title/index.js.map +1 -1
  36. package/build/cover/controls.native.js +2 -3
  37. package/build/cover/controls.native.js.map +1 -1
  38. package/build/cover/edit/block-controls.js +115 -0
  39. package/build/cover/edit/block-controls.js.map +1 -0
  40. package/build/cover/edit/cover-placeholder.js +49 -0
  41. package/build/cover/edit/cover-placeholder.js.map +1 -0
  42. package/build/cover/edit/index.js +333 -0
  43. package/build/cover/edit/index.js.map +1 -0
  44. package/build/cover/edit/inspector-controls.js +224 -0
  45. package/build/cover/edit/inspector-controls.js.map +1 -0
  46. package/build/cover/edit/resizable-cover.js +67 -0
  47. package/build/cover/edit/resizable-cover.js.map +1 -0
  48. package/build/cover/edit/use-cover-is-dark.js +81 -0
  49. package/build/cover/edit/use-cover-is-dark.js.map +1 -0
  50. package/build/cover/edit.native.js +36 -16
  51. package/build/cover/edit.native.js.map +1 -1
  52. package/build/cover/focal-point-settings-button.native.js.map +1 -1
  53. package/build/cover/shared.js +9 -0
  54. package/build/cover/shared.js.map +1 -1
  55. package/build/cover/transforms.js +77 -6
  56. package/build/cover/transforms.js.map +1 -1
  57. package/build/cover/use-cover-is-dark.native.js +60 -0
  58. package/build/cover/use-cover-is-dark.native.js.map +1 -0
  59. package/build/embed/edit.js +12 -18
  60. package/build/embed/edit.js.map +1 -1
  61. package/build/embed/edit.native.js +1 -7
  62. package/build/embed/edit.native.js.map +1 -1
  63. package/build/embed/embed-preview.js +1 -1
  64. package/build/embed/embed-preview.js.map +1 -1
  65. package/build/embed/util.js +29 -4
  66. package/build/embed/util.js.map +1 -1
  67. package/build/file/edit.native.js +0 -1
  68. package/build/file/edit.native.js.map +1 -1
  69. package/build/file/inspector.js +2 -4
  70. package/build/file/inspector.js.map +1 -1
  71. package/build/gallery/edit.js +3 -2
  72. package/build/gallery/edit.js.map +1 -1
  73. package/build/gallery/gallery.js +1 -1
  74. package/build/gallery/gallery.js.map +1 -1
  75. package/build/gallery/shared.js +2 -2
  76. package/build/gallery/shared.js.map +1 -1
  77. package/build/gallery/use-get-media.js +2 -1
  78. package/build/gallery/use-get-media.js.map +1 -1
  79. package/build/gallery/use-short-code-transform.js +19 -18
  80. package/build/gallery/use-short-code-transform.js.map +1 -1
  81. package/build/gallery/v1/edit.js +1 -1
  82. package/build/gallery/v1/edit.js.map +1 -1
  83. package/build/gallery/v1/gallery.js +1 -1
  84. package/build/gallery/v1/gallery.js.map +1 -1
  85. package/build/group/index.js +1 -0
  86. package/build/group/index.js.map +1 -1
  87. package/build/heading/edit.js +6 -2
  88. package/build/heading/edit.js.map +1 -1
  89. package/build/heading/index.js +1 -0
  90. package/build/heading/index.js.map +1 -1
  91. package/build/heading/transforms.js +9 -4
  92. package/build/heading/transforms.js.map +1 -1
  93. package/build/html/edit.js +2 -2
  94. package/build/html/edit.js.map +1 -1
  95. package/build/image/edit.js +9 -8
  96. package/build/image/edit.js.map +1 -1
  97. package/build/image/edit.native.js +1 -2
  98. package/build/image/edit.native.js.map +1 -1
  99. package/build/image/image.js +2 -2
  100. package/build/image/image.js.map +1 -1
  101. package/build/index.js +48 -12
  102. package/build/index.js.map +1 -1
  103. package/build/index.native.js +14 -3
  104. package/build/index.native.js.map +1 -1
  105. package/build/is-block-metadata-experimental.js +18 -0
  106. package/build/is-block-metadata-experimental.js.map +1 -0
  107. package/build/latest-comments/edit.js +1 -1
  108. package/build/latest-comments/edit.js.map +1 -1
  109. package/build/latest-posts/edit.js +30 -4
  110. package/build/latest-posts/edit.js.map +1 -1
  111. package/build/latest-posts/edit.native.js +49 -0
  112. package/build/latest-posts/edit.native.js.map +1 -1
  113. package/build/list/transforms.js +6 -0
  114. package/build/list/transforms.js.map +1 -1
  115. package/build/list/v2/edit.js +2 -1
  116. package/build/list/v2/edit.js.map +1 -1
  117. package/build/list/v2/migrate.js +1 -0
  118. package/build/list/v2/migrate.js.map +1 -1
  119. package/build/list/v2/transforms.js +46 -9
  120. package/build/list/v2/transforms.js.map +1 -1
  121. package/build/list-item/edit.js +7 -9
  122. package/build/list-item/edit.js.map +1 -1
  123. package/build/list-item/hooks/index.js +24 -0
  124. package/build/list-item/hooks/index.js.map +1 -1
  125. package/build/list-item/hooks/use-backspace.js +59 -0
  126. package/build/list-item/hooks/use-backspace.js.map +1 -0
  127. package/build/list-item/hooks/use-enter.js +6 -9
  128. package/build/list-item/hooks/use-enter.js.map +1 -1
  129. package/build/list-item/hooks/use-indent-list-item.js +33 -39
  130. package/build/list-item/hooks/use-indent-list-item.js.map +1 -1
  131. package/build/list-item/hooks/use-space.js +54 -0
  132. package/build/list-item/hooks/use-space.js.map +1 -0
  133. package/build/list-item/hooks/use-split.js +30 -0
  134. package/build/list-item/hooks/use-split.js.map +1 -0
  135. package/build/list-item/index.js +1 -0
  136. package/build/list-item/index.js.map +1 -1
  137. package/build/list-item/utils.js +1 -1
  138. package/build/list-item/utils.js.map +1 -1
  139. package/build/loginout/edit.js +1 -1
  140. package/build/loginout/edit.js.map +1 -1
  141. package/build/media-text/edit.js +1 -2
  142. package/build/media-text/edit.js.map +1 -1
  143. package/build/media-text/edit.native.js +3 -2
  144. package/build/media-text/edit.native.js.map +1 -1
  145. package/build/media-text/media-container.native.js +2 -4
  146. package/build/media-text/media-container.native.js.map +1 -1
  147. package/build/media-text/transforms.js +137 -8
  148. package/build/media-text/transforms.js.map +1 -1
  149. package/build/navigation/edit/index.js +86 -81
  150. package/build/navigation/edit/index.js.map +1 -1
  151. package/build/navigation/edit/inner-blocks.js +1 -5
  152. package/build/navigation/edit/inner-blocks.js.map +1 -1
  153. package/build/navigation/edit/unsaved-inner-blocks.js +5 -4
  154. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  155. package/build/navigation/index.js +1 -1
  156. package/build/navigation/use-navigation-entities.js +3 -3
  157. package/build/navigation/use-navigation-entities.js.map +1 -1
  158. package/build/navigation/view-modal.js +62 -0
  159. package/build/navigation/view-modal.js.map +1 -0
  160. package/build/navigation/view.js +1 -34
  161. package/build/navigation/view.js.map +1 -1
  162. package/build/navigation-link/edit.js +1 -1
  163. package/build/navigation-link/edit.js.map +1 -1
  164. package/build/navigation-link/fallback-variations.js +1 -1
  165. package/build/navigation-link/fallback-variations.js.map +1 -1
  166. package/build/navigation-link/hooks.js +1 -1
  167. package/build/navigation-link/hooks.js.map +1 -1
  168. package/build/page-list/convert-to-links-modal.js +1 -1
  169. package/build/page-list/convert-to-links-modal.js.map +1 -1
  170. package/build/page-list/edit.js +1 -1
  171. package/build/page-list/edit.js.map +1 -1
  172. package/build/paragraph/edit.js +10 -0
  173. package/build/paragraph/edit.js.map +1 -1
  174. package/build/paragraph/edit.native.js +6 -2
  175. package/build/paragraph/edit.native.js.map +1 -1
  176. package/build/paragraph/use-enter.js +94 -0
  177. package/build/paragraph/use-enter.js.map +1 -0
  178. package/build/post-author/edit.js +2 -2
  179. package/build/post-author/edit.js.map +1 -1
  180. package/build/post-author-name/index.js +1 -0
  181. package/build/post-author-name/index.js.map +1 -1
  182. package/build/post-comment/index.js +2 -1
  183. package/build/post-comment/index.js.map +1 -1
  184. package/build/post-comments/edit.js +14 -35
  185. package/build/post-comments/edit.js.map +1 -1
  186. package/build/post-comments/index.js +1 -1
  187. package/build/post-comments-count/index.js +1 -0
  188. package/build/post-comments-count/index.js.map +1 -1
  189. package/build/post-comments-form/edit.js +37 -24
  190. package/build/post-comments-form/edit.js.map +1 -1
  191. package/build/post-comments-form/form.js +48 -0
  192. package/build/post-comments-form/form.js.map +1 -0
  193. package/build/post-comments-link/index.js +1 -0
  194. package/build/post-comments-link/index.js.map +1 -1
  195. package/build/post-excerpt/edit.js +1 -1
  196. package/build/post-excerpt/edit.js.map +1 -1
  197. package/build/post-featured-image/edit.js +1 -1
  198. package/build/post-featured-image/edit.js.map +1 -1
  199. package/build/post-template/edit.js +7 -2
  200. package/build/post-template/edit.js.map +1 -1
  201. package/build/post-terms/edit.js +35 -4
  202. package/build/post-terms/edit.js.map +1 -1
  203. package/build/post-terms/hooks.js +33 -0
  204. package/build/post-terms/hooks.js.map +1 -0
  205. package/build/post-terms/index.js +20 -5
  206. package/build/post-terms/index.js.map +1 -1
  207. package/build/post-title/index.js +1 -1
  208. package/build/post-title/index.js.map +1 -1
  209. package/build/pullquote/edit.js +1 -1
  210. package/build/pullquote/edit.js.map +1 -1
  211. package/build/pullquote/edit.native.js +1 -1
  212. package/build/pullquote/edit.native.js.map +1 -1
  213. package/build/query/edit/inspector-controls/index.js +26 -17
  214. package/build/query/edit/inspector-controls/index.js.map +1 -1
  215. package/build/query/edit/inspector-controls/parent-control.js +148 -0
  216. package/build/query/edit/inspector-controls/parent-control.js.map +1 -0
  217. package/build/query/edit/inspector-controls/sticky-control.js +41 -0
  218. package/build/query/edit/inspector-controls/sticky-control.js.map +1 -0
  219. package/build/query/index.js +2 -1
  220. package/build/query/index.js.map +1 -1
  221. package/build/query/utils.js +28 -2
  222. package/build/query/utils.js.map +1 -1
  223. package/build/query-title/index.js +1 -1
  224. package/build/query-title/index.js.map +1 -1
  225. package/build/query-title/variations.js +1 -1
  226. package/build/query-title/variations.js.map +1 -1
  227. package/build/quote/edit.js +3 -2
  228. package/build/quote/edit.js.map +1 -1
  229. package/build/quote/index.js +7 -0
  230. package/build/quote/index.js.map +1 -1
  231. package/build/quote/v2/edit.js +12 -4
  232. package/build/quote/v2/edit.js.map +1 -1
  233. package/build/rss/edit.js +1 -1
  234. package/build/rss/edit.js.map +1 -1
  235. package/build/search/edit.js +12 -9
  236. package/build/search/edit.js.map +1 -1
  237. package/build/separator/index.js +3 -0
  238. package/build/separator/index.js.map +1 -1
  239. package/build/site-logo/edit.js +1 -1
  240. package/build/site-logo/edit.js.map +1 -1
  241. package/build/spacer/constants.js +9 -0
  242. package/build/spacer/constants.js.map +1 -0
  243. package/build/spacer/controls.js +3 -3
  244. package/build/spacer/controls.js.map +1 -1
  245. package/build/spacer/controls.native.js +2 -2
  246. package/build/spacer/controls.native.js.map +1 -1
  247. package/build/spacer/edit.js +5 -6
  248. package/build/spacer/edit.js.map +1 -1
  249. package/build/table/edit.js +23 -4
  250. package/build/table/edit.js.map +1 -1
  251. package/build/table-of-contents/edit.js +138 -66
  252. package/build/table-of-contents/edit.js.map +1 -1
  253. package/build/table-of-contents/index.js +13 -3
  254. package/build/table-of-contents/index.js.map +1 -1
  255. package/build/table-of-contents/list.js +16 -9
  256. package/build/table-of-contents/list.js.map +1 -1
  257. package/build/table-of-contents/save.js +40 -0
  258. package/build/table-of-contents/save.js.map +1 -0
  259. package/build/table-of-contents/utils.js +11 -77
  260. package/build/table-of-contents/utils.js.map +1 -1
  261. package/build/tag-cloud/edit.js +1 -1
  262. package/build/tag-cloud/edit.js.map +1 -1
  263. package/build/template-part/edit/index.js +7 -3
  264. package/build/template-part/edit/index.js.map +1 -1
  265. package/build/template-part/edit/inner-blocks.js +3 -8
  266. package/build/template-part/edit/inner-blocks.js.map +1 -1
  267. package/build/video/edit.js +5 -9
  268. package/build/video/edit.js.map +1 -1
  269. package/build/video/edit.native.js +1 -1
  270. package/build/video/edit.native.js.map +1 -1
  271. package/build-module/archives/edit.js +1 -1
  272. package/build-module/archives/edit.js.map +1 -1
  273. package/build-module/audio/edit.js +6 -18
  274. package/build-module/audio/edit.js.map +1 -1
  275. package/build-module/audio/edit.native.js +1 -1
  276. package/build-module/audio/edit.native.js.map +1 -1
  277. package/build-module/block/edit.js +11 -10
  278. package/build-module/block/edit.js.map +1 -1
  279. package/build-module/button/edit.native.js +7 -3
  280. package/build-module/button/edit.native.js.map +1 -1
  281. package/build-module/button/index.js +1 -0
  282. package/build-module/button/index.js.map +1 -1
  283. package/build-module/categories/edit.js +9 -4
  284. package/build-module/categories/edit.js.map +1 -1
  285. package/build-module/categories/index.js +5 -1
  286. package/build-module/categories/index.js.map +1 -1
  287. package/build-module/column/index.js +10 -0
  288. package/build-module/column/index.js.map +1 -1
  289. package/build-module/comment-author-avatar/index.js +1 -0
  290. package/build-module/comment-author-avatar/index.js.map +1 -1
  291. package/build-module/comment-template/edit.js +1 -3
  292. package/build-module/comment-template/edit.js.map +1 -1
  293. package/build-module/{comments-query-loop → comments}/edit/comments-inspector-controls.js +0 -0
  294. package/build-module/comments/edit/comments-inspector-controls.js.map +1 -0
  295. package/build-module/{comments-query-loop → comments}/edit.js +1 -1
  296. package/build-module/comments/edit.js.map +1 -0
  297. package/build-module/{comments-query-loop → comments}/index.js +1 -1
  298. package/build-module/comments/index.js.map +1 -0
  299. package/build-module/{comments-query-loop → comments}/save.js +1 -1
  300. package/build-module/comments/save.js.map +1 -0
  301. package/build-module/comments-title/index.js +1 -1
  302. package/build-module/comments-title/index.js.map +1 -1
  303. package/build-module/cover/controls.native.js +2 -3
  304. package/build-module/cover/controls.native.js.map +1 -1
  305. package/build-module/cover/edit/block-controls.js +104 -0
  306. package/build-module/cover/edit/block-controls.js.map +1 -0
  307. package/build-module/cover/edit/cover-placeholder.js +38 -0
  308. package/build-module/cover/edit/cover-placeholder.js.map +1 -0
  309. package/build-module/cover/edit/index.js +307 -0
  310. package/build-module/cover/edit/index.js.map +1 -0
  311. package/build-module/cover/edit/inspector-controls.js +215 -0
  312. package/build-module/cover/edit/inspector-controls.js.map +1 -0
  313. package/build-module/cover/edit/resizable-cover.js +55 -0
  314. package/build-module/cover/edit/resizable-cover.js.map +1 -0
  315. package/build-module/cover/edit/use-cover-is-dark.js +70 -0
  316. package/build-module/cover/edit/use-cover-is-dark.js.map +1 -0
  317. package/build-module/cover/edit.native.js +35 -17
  318. package/build-module/cover/edit.native.js.map +1 -1
  319. package/build-module/cover/focal-point-settings-button.native.js.map +1 -1
  320. package/build-module/cover/shared.js +7 -0
  321. package/build-module/cover/shared.js.map +1 -1
  322. package/build-module/cover/transforms.js +74 -6
  323. package/build-module/cover/transforms.js.map +1 -1
  324. package/build-module/cover/use-cover-is-dark.native.js +51 -0
  325. package/build-module/cover/use-cover-is-dark.native.js.map +1 -0
  326. package/build-module/embed/edit.js +13 -19
  327. package/build-module/embed/edit.js.map +1 -1
  328. package/build-module/embed/edit.native.js +2 -8
  329. package/build-module/embed/edit.native.js.map +1 -1
  330. package/build-module/embed/embed-preview.js +2 -2
  331. package/build-module/embed/embed-preview.js.map +1 -1
  332. package/build-module/embed/util.js +25 -3
  333. package/build-module/embed/util.js.map +1 -1
  334. package/build-module/file/edit.native.js +0 -1
  335. package/build-module/file/edit.native.js.map +1 -1
  336. package/build-module/file/inspector.js +2 -4
  337. package/build-module/file/inspector.js.map +1 -1
  338. package/build-module/gallery/edit.js +3 -2
  339. package/build-module/gallery/edit.js.map +1 -1
  340. package/build-module/gallery/gallery.js +2 -2
  341. package/build-module/gallery/gallery.js.map +1 -1
  342. package/build-module/gallery/shared.js +2 -2
  343. package/build-module/gallery/shared.js.map +1 -1
  344. package/build-module/gallery/use-get-media.js +2 -1
  345. package/build-module/gallery/use-get-media.js.map +1 -1
  346. package/build-module/gallery/use-short-code-transform.js +19 -18
  347. package/build-module/gallery/use-short-code-transform.js.map +1 -1
  348. package/build-module/gallery/v1/edit.js +1 -1
  349. package/build-module/gallery/v1/edit.js.map +1 -1
  350. package/build-module/gallery/v1/gallery.js +2 -2
  351. package/build-module/gallery/v1/gallery.js.map +1 -1
  352. package/build-module/group/index.js +1 -0
  353. package/build-module/group/index.js.map +1 -1
  354. package/build-module/heading/edit.js +6 -2
  355. package/build-module/heading/edit.js.map +1 -1
  356. package/build-module/heading/index.js +1 -0
  357. package/build-module/heading/index.js.map +1 -1
  358. package/build-module/heading/transforms.js +9 -4
  359. package/build-module/heading/transforms.js.map +1 -1
  360. package/build-module/html/edit.js +2 -2
  361. package/build-module/html/edit.js.map +1 -1
  362. package/build-module/image/edit.js +10 -9
  363. package/build-module/image/edit.js.map +1 -1
  364. package/build-module/image/edit.native.js +1 -2
  365. package/build-module/image/edit.native.js.map +1 -1
  366. package/build-module/image/image.js +3 -3
  367. package/build-module/image/image.js.map +1 -1
  368. package/build-module/index.js +43 -11
  369. package/build-module/index.js.map +1 -1
  370. package/build-module/index.native.js +14 -3
  371. package/build-module/index.native.js.map +1 -1
  372. package/build-module/is-block-metadata-experimental.js +16 -0
  373. package/build-module/is-block-metadata-experimental.js.map +1 -0
  374. package/build-module/latest-comments/edit.js +1 -1
  375. package/build-module/latest-comments/edit.js.map +1 -1
  376. package/build-module/latest-posts/edit.js +29 -5
  377. package/build-module/latest-posts/edit.js.map +1 -1
  378. package/build-module/latest-posts/edit.native.js +51 -2
  379. package/build-module/latest-posts/edit.native.js.map +1 -1
  380. package/build-module/list/transforms.js +6 -0
  381. package/build-module/list/transforms.js.map +1 -1
  382. package/build-module/list/v2/edit.js +2 -1
  383. package/build-module/list/v2/edit.js.map +1 -1
  384. package/build-module/list/v2/migrate.js +1 -3
  385. package/build-module/list/v2/migrate.js.map +1 -1
  386. package/build-module/list/v2/transforms.js +46 -9
  387. package/build-module/list/v2/transforms.js.map +1 -1
  388. package/build-module/list-item/edit.js +8 -9
  389. package/build-module/list-item/edit.js.map +1 -1
  390. package/build-module/list-item/hooks/index.js +3 -0
  391. package/build-module/list-item/hooks/index.js.map +1 -1
  392. package/build-module/list-item/hooks/use-backspace.js +44 -0
  393. package/build-module/list-item/hooks/use-backspace.js.map +1 -0
  394. package/build-module/list-item/hooks/use-enter.js +6 -9
  395. package/build-module/list-item/hooks/use-enter.js.map +1 -1
  396. package/build-module/list-item/hooks/use-indent-list-item.js +33 -38
  397. package/build-module/list-item/hooks/use-indent-list-item.js.map +1 -1
  398. package/build-module/list-item/hooks/use-space.js +40 -0
  399. package/build-module/list-item/hooks/use-space.js.map +1 -0
  400. package/build-module/list-item/hooks/use-split.js +19 -0
  401. package/build-module/list-item/hooks/use-split.js.map +1 -0
  402. package/build-module/list-item/index.js +1 -0
  403. package/build-module/list-item/index.js.map +1 -1
  404. package/build-module/list-item/utils.js +1 -1
  405. package/build-module/list-item/utils.js.map +1 -1
  406. package/build-module/loginout/edit.js +1 -1
  407. package/build-module/loginout/edit.js.map +1 -1
  408. package/build-module/media-text/edit.js +1 -2
  409. package/build-module/media-text/edit.js.map +1 -1
  410. package/build-module/media-text/edit.native.js +3 -2
  411. package/build-module/media-text/edit.native.js.map +1 -1
  412. package/build-module/media-text/media-container.native.js +2 -4
  413. package/build-module/media-text/media-container.native.js.map +1 -1
  414. package/build-module/media-text/transforms.js +137 -8
  415. package/build-module/media-text/transforms.js.map +1 -1
  416. package/build-module/navigation/edit/index.js +87 -82
  417. package/build-module/navigation/edit/index.js.map +1 -1
  418. package/build-module/navigation/edit/inner-blocks.js +2 -6
  419. package/build-module/navigation/edit/inner-blocks.js.map +1 -1
  420. package/build-module/navigation/edit/unsaved-inner-blocks.js +5 -4
  421. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  422. package/build-module/navigation/index.js +1 -1
  423. package/build-module/navigation/use-navigation-entities.js +1 -1
  424. package/build-module/navigation/use-navigation-entities.js.map +1 -1
  425. package/build-module/navigation/view-modal.js +56 -0
  426. package/build-module/navigation/view-modal.js.map +1 -0
  427. package/build-module/navigation/view.js +1 -30
  428. package/build-module/navigation/view.js.map +1 -1
  429. package/build-module/navigation-link/edit.js +1 -1
  430. package/build-module/navigation-link/edit.js.map +1 -1
  431. package/build-module/navigation-link/fallback-variations.js +1 -1
  432. package/build-module/navigation-link/fallback-variations.js.map +1 -1
  433. package/build-module/navigation-link/hooks.js +2 -2
  434. package/build-module/navigation-link/hooks.js.map +1 -1
  435. package/build-module/page-list/convert-to-links-modal.js +1 -1
  436. package/build-module/page-list/convert-to-links-modal.js.map +1 -1
  437. package/build-module/page-list/edit.js +1 -1
  438. package/build-module/page-list/edit.js.map +1 -1
  439. package/build-module/paragraph/edit.js +9 -0
  440. package/build-module/paragraph/edit.js.map +1 -1
  441. package/build-module/paragraph/edit.native.js +6 -2
  442. package/build-module/paragraph/edit.native.js.map +1 -1
  443. package/build-module/paragraph/use-enter.js +81 -0
  444. package/build-module/paragraph/use-enter.js.map +1 -0
  445. package/build-module/post-author/edit.js +2 -2
  446. package/build-module/post-author/edit.js.map +1 -1
  447. package/build-module/post-author-name/index.js +1 -0
  448. package/build-module/post-author-name/index.js.map +1 -1
  449. package/build-module/post-comment/index.js +2 -1
  450. package/build-module/post-comment/index.js.map +1 -1
  451. package/build-module/post-comments/edit.js +13 -35
  452. package/build-module/post-comments/edit.js.map +1 -1
  453. package/build-module/post-comments/index.js +1 -1
  454. package/build-module/post-comments-count/index.js +1 -0
  455. package/build-module/post-comments-count/index.js.map +1 -1
  456. package/build-module/post-comments-form/edit.js +38 -26
  457. package/build-module/post-comments-form/edit.js.map +1 -1
  458. package/build-module/post-comments-form/form.js +39 -0
  459. package/build-module/post-comments-form/form.js.map +1 -0
  460. package/build-module/post-comments-link/index.js +1 -0
  461. package/build-module/post-comments-link/index.js.map +1 -1
  462. package/build-module/post-excerpt/edit.js +1 -1
  463. package/build-module/post-excerpt/edit.js.map +1 -1
  464. package/build-module/post-featured-image/edit.js +1 -1
  465. package/build-module/post-featured-image/edit.js.map +1 -1
  466. package/build-module/post-template/edit.js +7 -2
  467. package/build-module/post-template/edit.js.map +1 -1
  468. package/build-module/post-terms/edit.js +35 -6
  469. package/build-module/post-terms/edit.js.map +1 -1
  470. package/build-module/post-terms/hooks.js +25 -0
  471. package/build-module/post-terms/hooks.js.map +1 -0
  472. package/build-module/post-terms/index.js +18 -8
  473. package/build-module/post-terms/index.js.map +1 -1
  474. package/build-module/post-title/index.js +1 -1
  475. package/build-module/post-title/index.js.map +1 -1
  476. package/build-module/pullquote/edit.js +2 -2
  477. package/build-module/pullquote/edit.js.map +1 -1
  478. package/build-module/pullquote/edit.native.js +2 -2
  479. package/build-module/pullquote/edit.native.js.map +1 -1
  480. package/build-module/query/edit/inspector-controls/index.js +24 -17
  481. package/build-module/query/edit/inspector-controls/index.js.map +1 -1
  482. package/build-module/query/edit/inspector-controls/parent-control.js +135 -0
  483. package/build-module/query/edit/inspector-controls/parent-control.js.map +1 -0
  484. package/build-module/query/edit/inspector-controls/sticky-control.js +31 -0
  485. package/build-module/query/edit/inspector-controls/sticky-control.js.map +1 -0
  486. package/build-module/query/index.js +2 -1
  487. package/build-module/query/index.js.map +1 -1
  488. package/build-module/query/utils.js +21 -0
  489. package/build-module/query/utils.js.map +1 -1
  490. package/build-module/query-title/index.js +1 -1
  491. package/build-module/query-title/index.js.map +1 -1
  492. package/build-module/query-title/variations.js +2 -2
  493. package/build-module/query-title/variations.js.map +1 -1
  494. package/build-module/quote/edit.js +4 -3
  495. package/build-module/quote/edit.js.map +1 -1
  496. package/build-module/quote/index.js +2 -1
  497. package/build-module/quote/index.js.map +1 -1
  498. package/build-module/quote/v2/edit.js +12 -5
  499. package/build-module/quote/v2/edit.js.map +1 -1
  500. package/build-module/rss/edit.js +1 -1
  501. package/build-module/rss/edit.js.map +1 -1
  502. package/build-module/search/edit.js +12 -9
  503. package/build-module/search/edit.js.map +1 -1
  504. package/build-module/separator/index.js +3 -0
  505. package/build-module/separator/index.js.map +1 -1
  506. package/build-module/site-logo/edit.js +1 -1
  507. package/build-module/site-logo/edit.js.map +1 -1
  508. package/build-module/spacer/constants.js +2 -0
  509. package/build-module/spacer/constants.js.map +1 -0
  510. package/build-module/spacer/controls.js +2 -2
  511. package/build-module/spacer/controls.js.map +1 -1
  512. package/build-module/spacer/controls.native.js +1 -1
  513. package/build-module/spacer/controls.native.js.map +1 -1
  514. package/build-module/spacer/edit.js +1 -1
  515. package/build-module/spacer/edit.js.map +1 -1
  516. package/build-module/table/edit.js +26 -7
  517. package/build-module/table/edit.js.map +1 -1
  518. package/build-module/table-of-contents/edit.js +136 -68
  519. package/build-module/table-of-contents/edit.js.map +1 -1
  520. package/build-module/table-of-contents/index.js +12 -3
  521. package/build-module/table-of-contents/index.js.map +1 -1
  522. package/build-module/table-of-contents/list.js +18 -10
  523. package/build-module/table-of-contents/list.js.map +1 -1
  524. package/build-module/table-of-contents/save.js +28 -0
  525. package/build-module/table-of-contents/save.js.map +1 -0
  526. package/build-module/table-of-contents/utils.js +11 -73
  527. package/build-module/table-of-contents/utils.js.map +1 -1
  528. package/build-module/tag-cloud/edit.js +1 -1
  529. package/build-module/tag-cloud/edit.js.map +1 -1
  530. package/build-module/template-part/edit/index.js +8 -4
  531. package/build-module/template-part/edit/index.js.map +1 -1
  532. package/build-module/template-part/edit/inner-blocks.js +4 -9
  533. package/build-module/template-part/edit/inner-blocks.js.map +1 -1
  534. package/build-module/video/edit.js +6 -10
  535. package/build-module/video/edit.js.map +1 -1
  536. package/build-module/video/edit.native.js +1 -1
  537. package/build-module/video/edit.native.js.map +1 -1
  538. package/build-style/{comments-query-loop → comments}/editor-rtl.css +0 -0
  539. package/build-style/{comments-query-loop → comments}/editor.css +0 -0
  540. package/build-style/common-rtl.css +32 -0
  541. package/build-style/common.css +32 -0
  542. package/build-style/cover/style-rtl.css +0 -4
  543. package/build-style/cover/style.css +0 -4
  544. package/build-style/editor-rtl.css +16 -10
  545. package/build-style/editor.css +16 -10
  546. package/build-style/image/editor-rtl.css +1 -1
  547. package/build-style/image/editor.css +1 -1
  548. package/build-style/navigation/style-rtl.css +3 -0
  549. package/build-style/navigation/style.css +3 -0
  550. package/build-style/separator/editor-rtl.css +1 -0
  551. package/build-style/separator/editor.css +1 -0
  552. package/build-style/style-rtl.css +73 -4
  553. package/build-style/style.css +73 -4
  554. package/build-style/table/editor-rtl.css +8 -0
  555. package/build-style/table/editor.css +8 -0
  556. package/build-style/table/style-rtl.css +38 -0
  557. package/build-style/table/style.css +38 -0
  558. package/build-style/video/editor-rtl.css +2 -5
  559. package/build-style/video/editor.css +2 -5
  560. package/build-types/table-of-contents/list.d.ts +12 -0
  561. package/build-types/table-of-contents/list.d.ts.map +1 -0
  562. package/build-types/table-of-contents/utils.d.ts +24 -0
  563. package/build-types/table-of-contents/utils.d.ts.map +1 -0
  564. package/package.json +30 -29
  565. package/src/archives/edit.js +1 -1
  566. package/src/audio/edit.js +7 -10
  567. package/src/audio/edit.native.js +1 -1
  568. package/src/avatar/block.json +0 -1
  569. package/src/avatar/index.php +2 -2
  570. package/src/block/edit.js +39 -42
  571. package/src/block/test/edit.native.js +1 -1
  572. package/src/button/block.json +1 -0
  573. package/src/button/edit.native.js +6 -3
  574. package/src/categories/block.json +5 -1
  575. package/src/categories/edit.js +9 -3
  576. package/src/categories/index.php +1 -0
  577. package/src/column/block.json +10 -0
  578. package/src/comment-author-avatar/block.json +1 -0
  579. package/src/comment-template/edit.js +1 -5
  580. package/src/{comments-query-loop → comments}/block.json +1 -1
  581. package/src/{comments-query-loop → comments}/edit/comments-inspector-controls.js +0 -0
  582. package/src/{comments-query-loop → comments}/edit.js +1 -1
  583. package/src/{comments-query-loop → comments}/editor.scss +0 -0
  584. package/src/{comments-query-loop → comments}/index.js +0 -0
  585. package/src/{comments-query-loop → comments}/save.js +1 -3
  586. package/src/comments-title/index.js +1 -1
  587. package/src/common.scss +24 -1
  588. package/src/cover/controls.native.js +1 -2
  589. package/src/cover/edit/block-controls.js +119 -0
  590. package/src/cover/edit/cover-placeholder.js +39 -0
  591. package/src/cover/edit/index.js +381 -0
  592. package/src/cover/edit/inspector-controls.js +286 -0
  593. package/src/cover/edit/resizable-cover.js +55 -0
  594. package/src/cover/edit/use-cover-is-dark.js +71 -0
  595. package/src/cover/edit.native.js +40 -14
  596. package/src/cover/editor.scss +1 -1
  597. package/src/cover/focal-point-settings-button.native.js +1 -1
  598. package/src/cover/shared.js +4 -0
  599. package/src/cover/style.native.scss +4 -0
  600. package/src/cover/style.scss +0 -4
  601. package/src/cover/test/__snapshots__/edit.native.js.snap +6 -6
  602. package/src/cover/test/block-controls.js +62 -0
  603. package/src/cover/test/transforms.js +301 -0
  604. package/src/cover/transforms.js +112 -7
  605. package/src/cover/use-cover-is-dark.native.js +51 -0
  606. package/src/editor.scss +1 -1
  607. package/src/embed/edit.js +19 -24
  608. package/src/embed/edit.native.js +9 -14
  609. package/src/embed/embed-preview.js +4 -2
  610. package/src/embed/util.js +34 -2
  611. package/src/file/edit.native.js +0 -1
  612. package/src/file/inspector.js +1 -3
  613. package/src/gallery/edit.js +3 -2
  614. package/src/gallery/gallery.js +2 -2
  615. package/src/gallery/shared.js +3 -2
  616. package/src/gallery/use-get-media.js +2 -1
  617. package/src/gallery/use-short-code-transform.js +19 -16
  618. package/src/gallery/v1/edit.js +1 -1
  619. package/src/gallery/v1/gallery.js +2 -2
  620. package/src/group/block.json +1 -0
  621. package/src/heading/block.json +1 -0
  622. package/src/heading/edit.js +5 -2
  623. package/src/heading/transforms.js +4 -3
  624. package/src/html/edit.js +2 -2
  625. package/src/image/edit.js +11 -5
  626. package/src/image/edit.native.js +1 -2
  627. package/src/image/editor.scss +1 -1
  628. package/src/image/image.js +9 -3
  629. package/src/image/test/edit.native.js +7 -7
  630. package/src/index.js +52 -30
  631. package/src/index.native.js +12 -2
  632. package/src/is-block-metadata-experimental.js +19 -0
  633. package/src/latest-comments/edit.js +1 -1
  634. package/src/latest-posts/edit.js +27 -2
  635. package/src/latest-posts/edit.native.js +56 -1
  636. package/src/list/transforms.js +7 -0
  637. package/src/list/v2/edit.js +1 -0
  638. package/src/list/v2/migrate.js +1 -1
  639. package/src/list/v2/transforms.js +35 -0
  640. package/src/list-item/block.json +2 -1
  641. package/src/list-item/edit.js +17 -10
  642. package/src/list-item/hooks/index.js +3 -0
  643. package/src/list-item/hooks/use-backspace.js +52 -0
  644. package/src/list-item/hooks/use-enter.js +9 -16
  645. package/src/list-item/hooks/use-indent-list-item.js +50 -63
  646. package/src/list-item/hooks/use-space.js +48 -0
  647. package/src/list-item/hooks/use-split.js +24 -0
  648. package/src/list-item/utils.js +1 -1
  649. package/src/loginout/edit.js +1 -1
  650. package/src/media-text/edit.js +1 -2
  651. package/src/media-text/edit.native.js +4 -2
  652. package/src/media-text/media-container.native.js +2 -4
  653. package/src/media-text/transforms.js +154 -0
  654. package/src/navigation/block.json +1 -1
  655. package/src/navigation/edit/index.js +175 -169
  656. package/src/navigation/edit/inner-blocks.js +1 -8
  657. package/src/navigation/edit/unsaved-inner-blocks.js +5 -4
  658. package/src/navigation/index.php +5 -0
  659. package/src/navigation/style.scss +3 -0
  660. package/src/navigation/use-navigation-entities.js +1 -1
  661. package/src/navigation/view-modal.js +68 -0
  662. package/src/navigation/view.js +0 -35
  663. package/src/navigation-link/edit.js +1 -1
  664. package/src/navigation-link/fallback-variations.js +1 -1
  665. package/src/navigation-link/hooks.js +2 -2
  666. package/src/navigation-link/test/__snapshots__/hooks.js.snap +4 -4
  667. package/src/page-list/convert-to-links-modal.js +1 -1
  668. package/src/page-list/edit.js +1 -4
  669. package/src/paragraph/edit.js +6 -0
  670. package/src/paragraph/edit.native.js +13 -1
  671. package/src/paragraph/use-enter.js +103 -0
  672. package/src/post-author/edit.js +25 -23
  673. package/src/post-author-name/block.json +1 -0
  674. package/src/post-comment/block.json +2 -1
  675. package/src/post-comments/block.json +1 -1
  676. package/src/post-comments/edit.js +13 -43
  677. package/src/post-comments/index.php +2 -0
  678. package/src/post-comments-count/block.json +1 -0
  679. package/src/post-comments-form/edit.js +50 -58
  680. package/src/post-comments-form/form.js +40 -0
  681. package/src/post-comments-link/block.json +1 -0
  682. package/src/post-excerpt/edit.js +1 -1
  683. package/src/post-featured-image/edit.js +1 -1
  684. package/src/post-template/edit.js +5 -0
  685. package/src/post-terms/block.json +8 -0
  686. package/src/post-terms/edit.js +47 -1
  687. package/src/post-terms/hooks.js +27 -0
  688. package/src/post-terms/index.js +14 -7
  689. package/src/post-terms/index.php +50 -2
  690. package/src/post-title/index.js +1 -1
  691. package/src/pullquote/edit.js +2 -2
  692. package/src/pullquote/edit.native.js +2 -2
  693. package/src/query/block.json +2 -1
  694. package/src/query/edit/inspector-controls/index.js +25 -11
  695. package/src/query/edit/inspector-controls/parent-control.js +133 -0
  696. package/src/query/edit/inspector-controls/sticky-control.js +25 -0
  697. package/src/query/utils.js +22 -0
  698. package/src/query-title/index.js +1 -1
  699. package/src/query-title/variations.js +2 -2
  700. package/src/quote/block.json +1 -0
  701. package/src/quote/edit.js +5 -2
  702. package/src/quote/index.js +1 -1
  703. package/src/quote/v2/edit.js +7 -2
  704. package/src/rss/edit.js +1 -1
  705. package/src/search/edit.js +14 -7
  706. package/src/search/index.php +85 -34
  707. package/src/separator/block.json +3 -0
  708. package/src/separator/editor.scss +1 -0
  709. package/src/site-logo/edit.js +1 -1
  710. package/src/spacer/constants.js +1 -0
  711. package/src/spacer/controls.js +2 -2
  712. package/src/spacer/controls.native.js +1 -1
  713. package/src/spacer/edit.js +1 -2
  714. package/src/table/edit.js +30 -6
  715. package/src/table/editor.scss +13 -0
  716. package/src/table/style.scss +52 -0
  717. package/src/table-of-contents/block.json +9 -2
  718. package/src/table-of-contents/edit.js +155 -75
  719. package/src/table-of-contents/index.js +2 -0
  720. package/src/table-of-contents/list.tsx +46 -0
  721. package/src/table-of-contents/save.js +25 -0
  722. package/src/table-of-contents/utils.ts +71 -0
  723. package/src/tag-cloud/block.json +1 -1
  724. package/src/tag-cloud/edit.js +1 -1
  725. package/src/template-part/edit/index.js +25 -15
  726. package/src/template-part/edit/inner-blocks.js +2 -10
  727. package/src/video/edit.js +8 -7
  728. package/src/video/edit.native.js +1 -1
  729. package/src/video/editor.scss +3 -6
  730. package/test/babel-plugin.js +67 -0
  731. package/tsconfig.json +11 -0
  732. package/tsconfig.tsbuildinfo +1 -0
  733. package/build/comments-query-loop/edit/comments-inspector-controls.js.map +0 -1
  734. package/build/comments-query-loop/edit.js.map +0 -1
  735. package/build/comments-query-loop/index.js.map +0 -1
  736. package/build/comments-query-loop/save.js.map +0 -1
  737. package/build/cover/edit.js +0 -668
  738. package/build/cover/edit.js.map +0 -1
  739. package/build/post-terms/variations.js +0 -37
  740. package/build/post-terms/variations.js.map +0 -1
  741. package/build-module/comments-query-loop/edit.js.map +0 -1
  742. package/build-module/comments-query-loop/index.js.map +0 -1
  743. package/build-module/comments-query-loop/save.js.map +0 -1
  744. package/build-module/cover/edit.js +0 -645
  745. package/build-module/cover/edit.js.map +0 -1
  746. package/build-module/post-terms/variations.js +0 -27
  747. package/build-module/post-terms/variations.js.map +0 -1
  748. package/src/cover/edit.js +0 -827
  749. package/src/post-terms/variations.js +0 -28
  750. package/src/table-of-contents/index.php +0 -346
  751. package/src/table-of-contents/list.js +0 -28
  752. package/src/table-of-contents/utils.js +0 -126
@@ -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 );
@@ -0,0 +1,286 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { Fragment, useMemo } from '@wordpress/element';
5
+ import {
6
+ BaseControl,
7
+ Button,
8
+ ExternalLink,
9
+ FocalPointPicker,
10
+ PanelBody,
11
+ PanelRow,
12
+ RangeControl,
13
+ TextareaControl,
14
+ ToggleControl,
15
+ __experimentalUseCustomUnits as useCustomUnits,
16
+ __experimentalToolsPanelItem as ToolsPanelItem,
17
+ __experimentalUnitControl as UnitControl,
18
+ __experimentalParseQuantityAndUnitFromRawValue as parseQuantityAndUnitFromRawValue,
19
+ } from '@wordpress/components';
20
+ import { useInstanceId } from '@wordpress/compose';
21
+ import {
22
+ InspectorControls,
23
+ useSetting,
24
+ __experimentalUseGradient,
25
+ __experimentalPanelColorGradientSettings as PanelColorGradientSettings,
26
+ } from '@wordpress/block-editor';
27
+ import { __ } from '@wordpress/i18n';
28
+
29
+ /**
30
+ * Internal dependencies
31
+ */
32
+ import { COVER_MIN_HEIGHT, mediaPosition } from '../shared';
33
+
34
+ function CoverHeightInput( {
35
+ onChange,
36
+ onUnitChange,
37
+ unit = 'px',
38
+ value = '',
39
+ } ) {
40
+ const instanceId = useInstanceId( UnitControl );
41
+ const inputId = `block-cover-height-input-${ instanceId }`;
42
+ const isPx = unit === 'px';
43
+
44
+ const units = useCustomUnits( {
45
+ availableUnits: useSetting( 'spacing.units' ) || [
46
+ 'px',
47
+ 'em',
48
+ 'rem',
49
+ 'vw',
50
+ 'vh',
51
+ ],
52
+ defaultValues: { px: 430, '%': 20, em: 20, rem: 20, vw: 20, vh: 50 },
53
+ } );
54
+
55
+ const handleOnChange = ( unprocessedValue ) => {
56
+ const inputValue =
57
+ unprocessedValue !== ''
58
+ ? parseFloat( unprocessedValue )
59
+ : undefined;
60
+
61
+ if ( isNaN( inputValue ) && inputValue !== undefined ) {
62
+ return;
63
+ }
64
+ onChange( inputValue );
65
+ };
66
+
67
+ const computedValue = useMemo( () => {
68
+ const [ parsedQuantity ] = parseQuantityAndUnitFromRawValue( value );
69
+ return [ parsedQuantity, unit ].join( '' );
70
+ }, [ unit, value ] );
71
+
72
+ const min = isPx ? COVER_MIN_HEIGHT : 0;
73
+
74
+ return (
75
+ <BaseControl label={ __( 'Minimum height of cover' ) } id={ inputId }>
76
+ <UnitControl
77
+ id={ inputId }
78
+ isResetValueOnUnitChange
79
+ min={ min }
80
+ onChange={ handleOnChange }
81
+ onUnitChange={ onUnitChange }
82
+ style={ { maxWidth: 80 } }
83
+ units={ units }
84
+ value={ computedValue }
85
+ />
86
+ </BaseControl>
87
+ );
88
+ }
89
+ export default function CoverInspectorControls( {
90
+ attributes,
91
+ setAttributes,
92
+ clientId,
93
+ setOverlayColor,
94
+ coverRef,
95
+ currentSettings,
96
+ } ) {
97
+ const {
98
+ useFeaturedImage,
99
+ dimRatio,
100
+ focalPoint,
101
+ hasParallax,
102
+ isRepeated,
103
+ minHeight,
104
+ minHeightUnit,
105
+ alt,
106
+ } = attributes;
107
+ const {
108
+ isVideoBackground,
109
+ isImageBackground,
110
+ mediaElement,
111
+ url,
112
+ isImgElement,
113
+ overlayColor,
114
+ } = currentSettings;
115
+
116
+ const { gradientValue, setGradient } = __experimentalUseGradient();
117
+
118
+ const toggleParallax = () => {
119
+ setAttributes( {
120
+ hasParallax: ! hasParallax,
121
+ ...( ! hasParallax ? { focalPoint: undefined } : {} ),
122
+ } );
123
+ };
124
+
125
+ const toggleIsRepeated = () => {
126
+ setAttributes( {
127
+ isRepeated: ! isRepeated,
128
+ } );
129
+ };
130
+
131
+ const showFocalPointPicker =
132
+ isVideoBackground ||
133
+ ( isImageBackground && ( ! hasParallax || isRepeated ) );
134
+
135
+ const imperativeFocalPointPreview = ( value ) => {
136
+ const [ styleOfRef, property ] = mediaElement.current
137
+ ? [ mediaElement.current.style, 'objectPosition' ]
138
+ : [ coverRef.current.style, 'backgroundPosition' ];
139
+ styleOfRef[ property ] = mediaPosition( value );
140
+ };
141
+ return (
142
+ <>
143
+ <InspectorControls>
144
+ { !! url && (
145
+ <PanelBody title={ __( 'Media settings' ) }>
146
+ { isImageBackground && (
147
+ <Fragment>
148
+ <ToggleControl
149
+ label={ __( 'Fixed background' ) }
150
+ checked={ hasParallax }
151
+ onChange={ toggleParallax }
152
+ />
153
+
154
+ <ToggleControl
155
+ label={ __( 'Repeated background' ) }
156
+ checked={ isRepeated }
157
+ onChange={ toggleIsRepeated }
158
+ />
159
+ </Fragment>
160
+ ) }
161
+ { showFocalPointPicker && (
162
+ <FocalPointPicker
163
+ label={ __( 'Focal point picker' ) }
164
+ url={ url }
165
+ value={ focalPoint }
166
+ onDragStart={ imperativeFocalPointPreview }
167
+ onDrag={ imperativeFocalPointPreview }
168
+ onChange={ ( newFocalPoint ) =>
169
+ setAttributes( {
170
+ focalPoint: newFocalPoint,
171
+ } )
172
+ }
173
+ />
174
+ ) }
175
+ { ! useFeaturedImage &&
176
+ url &&
177
+ isImageBackground &&
178
+ isImgElement && (
179
+ <TextareaControl
180
+ label={ __(
181
+ 'Alt text (alternative text)'
182
+ ) }
183
+ value={ alt }
184
+ onChange={ ( newAlt ) =>
185
+ setAttributes( { alt: newAlt } )
186
+ }
187
+ help={
188
+ <>
189
+ <ExternalLink href="https://www.w3.org/WAI/tutorials/images/decision-tree">
190
+ { __(
191
+ 'Describe the purpose of the image'
192
+ ) }
193
+ </ExternalLink>
194
+ { __(
195
+ 'Leave empty if the image is purely decorative.'
196
+ ) }
197
+ </>
198
+ }
199
+ />
200
+ ) }
201
+ <PanelRow>
202
+ <Button
203
+ variant="secondary"
204
+ isSmall
205
+ className="block-library-cover__reset-button"
206
+ onClick={ () =>
207
+ setAttributes( {
208
+ url: undefined,
209
+ id: undefined,
210
+ backgroundType: undefined,
211
+ focalPoint: undefined,
212
+ hasParallax: undefined,
213
+ isRepeated: undefined,
214
+ useFeaturedImage: false,
215
+ } )
216
+ }
217
+ >
218
+ { __( 'Clear Media' ) }
219
+ </Button>
220
+ </PanelRow>
221
+ </PanelBody>
222
+ ) }
223
+ <PanelColorGradientSettings
224
+ __experimentalHasMultipleOrigins
225
+ __experimentalIsRenderedInSidebar
226
+ title={ __( 'Overlay' ) }
227
+ initialOpen={ true }
228
+ settings={ [
229
+ {
230
+ colorValue: overlayColor.color,
231
+ gradientValue,
232
+ onColorChange: setOverlayColor,
233
+ onGradientChange: setGradient,
234
+ label: __( 'Color' ),
235
+ },
236
+ ] }
237
+ >
238
+ <RangeControl
239
+ label={ __( 'Opacity' ) }
240
+ value={ dimRatio }
241
+ onChange={ ( newDimRation ) =>
242
+ setAttributes( {
243
+ dimRatio: newDimRation,
244
+ } )
245
+ }
246
+ min={ 0 }
247
+ max={ 100 }
248
+ step={ 10 }
249
+ required
250
+ />
251
+ </PanelColorGradientSettings>
252
+ </InspectorControls>
253
+ <InspectorControls __experimentalGroup="dimensions">
254
+ <ToolsPanelItem
255
+ hasValue={ () => !! minHeight }
256
+ label={ __( 'Minimum height' ) }
257
+ onDeselect={ () =>
258
+ setAttributes( {
259
+ minHeight: undefined,
260
+ minHeightUnit: undefined,
261
+ } )
262
+ }
263
+ resetAllFilter={ () => ( {
264
+ minHeight: undefined,
265
+ minHeightUnit: undefined,
266
+ } ) }
267
+ isShownByDefault={ true }
268
+ panelId={ clientId }
269
+ >
270
+ <CoverHeightInput
271
+ value={ minHeight }
272
+ unit={ minHeightUnit }
273
+ onChange={ ( newMinHeight ) =>
274
+ setAttributes( { minHeight: newMinHeight } )
275
+ }
276
+ onUnitChange={ ( nextUnit ) =>
277
+ setAttributes( {
278
+ minHeightUnit: nextUnit,
279
+ } )
280
+ }
281
+ />
282
+ </ToolsPanelItem>
283
+ </InspectorControls>
284
+ </>
285
+ );
286
+ }