@wordpress/block-library 7.10.0 → 7.12.2-next.d6164808d3.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 (1048) hide show
  1. package/CHANGELOG.md +11 -1
  2. package/build/archives/edit.js +7 -0
  3. package/build/archives/edit.js.map +1 -1
  4. package/build/archives/index.js +9 -1
  5. package/build/archives/index.js.map +1 -1
  6. package/build/audio/index.js +4 -0
  7. package/build/audio/index.js.map +1 -1
  8. package/build/block/edit.js +4 -2
  9. package/build/block/edit.js.map +1 -1
  10. package/build/block/edit.native.js +4 -2
  11. package/build/block/edit.native.js.map +1 -1
  12. package/build/button/deprecated.js +14 -5
  13. package/build/button/deprecated.js.map +1 -1
  14. package/build/button/edit.js +2 -1
  15. package/build/button/edit.js.map +1 -1
  16. package/build/button/index.js +1 -1
  17. package/build/buttons/edit.js +1 -1
  18. package/build/buttons/edit.js.map +1 -1
  19. package/build/calendar/edit.js +12 -5
  20. package/build/calendar/edit.js.map +1 -1
  21. package/build/categories/edit.js +3 -1
  22. package/build/categories/edit.js.map +1 -1
  23. package/build/categories/index.js +14 -1
  24. package/build/categories/index.js.map +1 -1
  25. package/build/code/index.js +4 -2
  26. package/build/code/index.js.map +1 -1
  27. package/build/column/index.js +13 -0
  28. package/build/column/index.js.map +1 -1
  29. package/build/columns/deprecated.js +16 -5
  30. package/build/columns/deprecated.js.map +1 -1
  31. package/build/columns/edit.js +6 -2
  32. package/build/columns/edit.js.map +1 -1
  33. package/build/columns/edit.native.js +9 -4
  34. package/build/columns/edit.native.js.map +1 -1
  35. package/build/columns/index.js +13 -0
  36. package/build/columns/index.js.map +1 -1
  37. package/build/comment-author-name/index.js +5 -1
  38. package/build/comment-author-name/index.js.map +1 -1
  39. package/build/comment-content/index.js +5 -1
  40. package/build/comment-content/index.js.map +1 -1
  41. package/build/comment-date/index.js +1 -0
  42. package/build/comment-date/index.js.map +1 -1
  43. package/build/comment-edit-link/index.js +5 -1
  44. package/build/comment-edit-link/index.js.map +1 -1
  45. package/build/comment-reply-link/index.js +5 -1
  46. package/build/comment-reply-link/index.js.map +1 -1
  47. package/build/comment-template/index.js +14 -1
  48. package/build/comment-template/index.js.map +1 -1
  49. package/build/comments/edit/comments-legacy.js +73 -0
  50. package/build/comments/edit/comments-legacy.js.map +1 -0
  51. package/build/comments/{edit.js → edit/index.js} +17 -38
  52. package/build/comments/edit/index.js.map +1 -0
  53. package/build/comments/edit/placeholder.js +117 -0
  54. package/build/comments/edit/placeholder.js.map +1 -0
  55. package/build/comments/edit/template.js +39 -0
  56. package/build/comments/edit/template.js.map +1 -0
  57. package/build/comments/index.js +19 -1
  58. package/build/comments/index.js.map +1 -1
  59. package/build/comments/save.js +12 -4
  60. package/build/comments/save.js.map +1 -1
  61. package/build/comments-pagination/index.js +13 -0
  62. package/build/comments-pagination/index.js.map +1 -1
  63. package/build/comments-pagination-next/index.js +4 -2
  64. package/build/comments-pagination-next/index.js.map +1 -1
  65. package/build/comments-pagination-numbers/edit.js +5 -1
  66. package/build/comments-pagination-numbers/edit.js.map +1 -1
  67. package/build/comments-pagination-numbers/index.js +14 -1
  68. package/build/comments-pagination-numbers/index.js.map +1 -1
  69. package/build/comments-pagination-previous/index.js +4 -2
  70. package/build/comments-pagination-previous/index.js.map +1 -1
  71. package/build/comments-title/deprecated.js +4 -2
  72. package/build/comments-title/deprecated.js.map +1 -1
  73. package/build/comments-title/index.js +4 -2
  74. package/build/comments-title/index.js.map +1 -1
  75. package/build/cover/deprecated.js +20 -5
  76. package/build/cover/deprecated.js.map +1 -1
  77. package/build/cover/edit/resizable-cover.js +6 -0
  78. package/build/cover/edit/resizable-cover.js.map +1 -1
  79. package/build/cover/index.js +13 -0
  80. package/build/cover/index.js.map +1 -1
  81. package/build/cover/shared.js +1 -1
  82. package/build/cover/shared.js.map +1 -1
  83. package/build/cover/transforms.js +3 -2
  84. package/build/cover/transforms.js.map +1 -1
  85. package/build/embed/embed-placeholder.native.js +1 -3
  86. package/build/embed/embed-placeholder.native.js.map +1 -1
  87. package/build/embed/icons.js +1 -1
  88. package/build/embed/icons.js.map +1 -1
  89. package/build/gallery/deprecated.js +6 -1
  90. package/build/gallery/deprecated.js.map +1 -1
  91. package/build/gallery/edit.js +17 -4
  92. package/build/gallery/edit.js.map +1 -1
  93. package/build/gallery/index.js +5 -0
  94. package/build/gallery/index.js.map +1 -1
  95. package/build/gallery/transforms.js +20 -7
  96. package/build/gallery/transforms.js.map +1 -1
  97. package/build/gallery/use-get-media.native.js +59 -0
  98. package/build/gallery/use-get-media.native.js.map +1 -0
  99. package/build/gallery/utils.js +7 -6
  100. package/build/gallery/utils.js.map +1 -1
  101. package/build/group/deprecated.js +108 -12
  102. package/build/group/deprecated.js.map +1 -1
  103. package/build/group/edit.js +23 -1
  104. package/build/group/edit.js.map +1 -1
  105. package/build/group/index.js +11 -2
  106. package/build/group/index.js.map +1 -1
  107. package/build/group/transforms.js +5 -0
  108. package/build/group/transforms.js.map +1 -1
  109. package/build/group/variations.js +9 -9
  110. package/build/group/variations.js.map +1 -1
  111. package/build/heading/deprecated.js +5 -3
  112. package/build/heading/deprecated.js.map +1 -1
  113. package/build/heading/index.js +3 -1
  114. package/build/heading/index.js.map +1 -1
  115. package/build/heading/transforms.js +3 -1
  116. package/build/heading/transforms.js.map +1 -1
  117. package/build/home-link/edit.js +8 -4
  118. package/build/home-link/edit.js.map +1 -1
  119. package/build/image/deprecated.js +77 -9
  120. package/build/image/deprecated.js.map +1 -1
  121. package/build/image/edit.js +16 -2
  122. package/build/image/edit.js.map +1 -1
  123. package/build/image/edit.native.js +18 -8
  124. package/build/image/edit.native.js.map +1 -1
  125. package/build/image/image.js +27 -20
  126. package/build/image/image.js.map +1 -1
  127. package/build/image/index.js +20 -8
  128. package/build/image/index.js.map +1 -1
  129. package/build/image/save.js +8 -2
  130. package/build/image/save.js.map +1 -1
  131. package/build/index.js +1 -3
  132. package/build/index.js.map +1 -1
  133. package/build/index.native.js +16 -10
  134. package/build/index.native.js.map +1 -1
  135. package/build/list/index.js +6 -0
  136. package/build/list/index.js.map +1 -1
  137. package/build/list/transforms.js +4 -63
  138. package/build/list/transforms.js.map +1 -1
  139. package/build/list/v2/edit.js +16 -5
  140. package/build/list/v2/edit.js.map +1 -1
  141. package/build/list/v2/tag-name.js +31 -0
  142. package/build/list/v2/tag-name.js.map +1 -0
  143. package/build/list/v2/tag-name.native.js +32 -0
  144. package/build/list/v2/tag-name.native.js.map +1 -0
  145. package/build/list/v2/transforms.js +1 -38
  146. package/build/list/v2/transforms.js.map +1 -1
  147. package/build/list-item/edit.js +18 -10
  148. package/build/list-item/edit.js.map +1 -1
  149. package/build/list-item/edit.native.js +158 -0
  150. package/build/list-item/edit.native.js.map +1 -0
  151. package/build/list-item/hooks/index.js +12 -4
  152. package/build/list-item/hooks/index.js.map +1 -1
  153. package/build/list-item/hooks/use-copy.js +42 -0
  154. package/build/list-item/hooks/use-copy.js.map +1 -0
  155. package/build/list-item/hooks/use-merge.js +174 -0
  156. package/build/list-item/hooks/use-merge.js.map +1 -0
  157. package/build/list-item/hooks/use-outdent-list-item.js +86 -50
  158. package/build/list-item/hooks/use-outdent-list-item.js.map +1 -1
  159. package/build/list-item/icons.native.js +53 -0
  160. package/build/list-item/icons.native.js.map +1 -0
  161. package/build/list-item/list-style-type.native.js +139 -0
  162. package/build/list-item/list-style-type.native.js.map +1 -0
  163. package/build/list-item/utils.js +125 -1
  164. package/build/list-item/utils.js.map +1 -1
  165. package/build/media-text/deprecated.js +270 -17
  166. package/build/media-text/deprecated.js.map +1 -1
  167. package/build/media-text/edit.js +4 -3
  168. package/build/media-text/edit.js.map +1 -1
  169. package/build/media-text/index.js +13 -0
  170. package/build/media-text/index.js.map +1 -1
  171. package/build/media-text/media-container.js +1 -1
  172. package/build/media-text/media-container.js.map +1 -1
  173. package/build/media-text/save.js +13 -0
  174. package/build/media-text/save.js.map +1 -1
  175. package/build/more/save.js +1 -7
  176. package/build/more/save.js.map +1 -1
  177. package/build/navigation/deprecated.js +6 -1
  178. package/build/navigation/deprecated.js.map +1 -1
  179. package/build/navigation/edit/index.js +180 -154
  180. package/build/navigation/edit/index.js.map +1 -1
  181. package/build/navigation/edit/navigation-menu-selector.js +11 -14
  182. package/build/navigation/edit/navigation-menu-selector.js.map +1 -1
  183. package/build/navigation/edit/placeholder/index.js +4 -2
  184. package/build/navigation/edit/placeholder/index.js.map +1 -1
  185. package/build/navigation/edit/responsive-wrapper.js +13 -3
  186. package/build/navigation/edit/responsive-wrapper.js.map +1 -1
  187. package/build/navigation/edit/unsaved-inner-blocks.js +2 -1
  188. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  189. package/build/navigation/edit/use-convert-classic-menu-to-block-menu.js +4 -7
  190. package/build/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  191. package/build/navigation/edit/use-create-navigation-menu.js +5 -1
  192. package/build/navigation/edit/use-create-navigation-menu.js.map +1 -1
  193. package/build/navigation/edit/use-inner-blocks.js +43 -0
  194. package/build/navigation/edit/use-inner-blocks.js.map +1 -0
  195. package/build/navigation/edit/utils.js +28 -0
  196. package/build/navigation/edit/utils.js.map +1 -0
  197. package/build/navigation/menu-items-to-blocks.js +1 -7
  198. package/build/navigation/menu-items-to-blocks.js.map +1 -1
  199. package/build/navigation/use-navigation-menu.js +15 -10
  200. package/build/navigation/use-navigation-menu.js.map +1 -1
  201. package/build/navigation-link/edit.js +11 -12
  202. package/build/navigation-link/edit.js.map +1 -1
  203. package/build/navigation-submenu/edit.js +6 -7
  204. package/build/navigation-submenu/edit.js.map +1 -1
  205. package/build/page-list/edit.js +15 -4
  206. package/build/page-list/edit.js.map +1 -1
  207. package/build/paragraph/deprecated.js +18 -10
  208. package/build/paragraph/deprecated.js.map +1 -1
  209. package/build/paragraph/edit.js +8 -11
  210. package/build/paragraph/edit.js.map +1 -1
  211. package/build/paragraph/index.js +5 -0
  212. package/build/paragraph/index.js.map +1 -1
  213. package/build/paragraph/transforms.js +5 -0
  214. package/build/paragraph/transforms.js.map +1 -1
  215. package/build/post-author/edit.js +5 -2
  216. package/build/post-author/edit.js.map +1 -1
  217. package/build/post-author/index.js +4 -2
  218. package/build/post-author/index.js.map +1 -1
  219. package/build/post-author-biography/edit.js +7 -1
  220. package/build/post-author-biography/edit.js.map +1 -1
  221. package/build/post-author-biography/index.js +1 -0
  222. package/build/post-author-biography/index.js.map +1 -1
  223. package/build/post-author-name/index.js +5 -1
  224. package/build/post-author-name/index.js.map +1 -1
  225. package/build/post-comments-count/edit.js +11 -1
  226. package/build/post-comments-count/edit.js.map +1 -1
  227. package/build/post-comments-count/index.js +4 -1
  228. package/build/post-comments-count/index.js.map +1 -1
  229. package/build/post-comments-form/edit.js +4 -45
  230. package/build/post-comments-form/edit.js.map +1 -1
  231. package/build/post-comments-form/form.js +47 -3
  232. package/build/post-comments-form/form.js.map +1 -1
  233. package/build/post-comments-link/index.js +4 -2
  234. package/build/post-comments-link/index.js.map +1 -1
  235. package/build/post-content/edit.js +4 -2
  236. package/build/post-content/edit.js.map +1 -1
  237. package/build/post-date/edit.js +9 -2
  238. package/build/post-date/edit.js.map +1 -1
  239. package/build/post-date/index.js +9 -0
  240. package/build/post-date/index.js.map +1 -1
  241. package/build/post-featured-image/edit.js +43 -14
  242. package/build/post-featured-image/edit.js.map +1 -1
  243. package/build/post-featured-image/index.js +21 -0
  244. package/build/post-featured-image/index.js.map +1 -1
  245. package/build/post-navigation-link/index.js +3 -2
  246. package/build/post-navigation-link/index.js.map +1 -1
  247. package/build/post-template/edit.js +8 -4
  248. package/build/post-template/edit.js.map +1 -1
  249. package/build/post-template/index.js +14 -1
  250. package/build/post-template/index.js.map +1 -1
  251. package/build/post-terms/edit.js +3 -2
  252. package/build/post-terms/edit.js.map +1 -1
  253. package/build/post-terms/index.js +5 -3
  254. package/build/post-terms/index.js.map +1 -1
  255. package/build/post-title/index.js +2 -1
  256. package/build/post-title/index.js.map +1 -1
  257. package/build/preformatted/index.js +4 -2
  258. package/build/preformatted/index.js.map +1 -1
  259. package/build/pullquote/deprecated.js +135 -25
  260. package/build/pullquote/deprecated.js.map +1 -1
  261. package/build/pullquote/edit.js +1 -1
  262. package/build/pullquote/edit.js.map +1 -1
  263. package/build/pullquote/edit.native.js +0 -1
  264. package/build/pullquote/edit.native.js.map +1 -1
  265. package/build/pullquote/index.js +13 -6
  266. package/build/pullquote/index.js.map +1 -1
  267. package/build/pullquote/save.js +2 -2
  268. package/build/pullquote/save.js.map +1 -1
  269. package/build/pullquote/transforms.js +14 -33
  270. package/build/pullquote/transforms.js.map +1 -1
  271. package/build/query/deprecated.js +10 -9
  272. package/build/query/deprecated.js.map +1 -1
  273. package/build/query/edit/index.js +19 -8
  274. package/build/query/edit/index.js.map +1 -1
  275. package/build/query/edit/inspector-controls/index.js +42 -9
  276. package/build/query/edit/inspector-controls/index.js.map +1 -1
  277. package/build/query/edit/inspector-controls/taxonomy-controls.js +22 -14
  278. package/build/query/edit/inspector-controls/taxonomy-controls.js.map +1 -1
  279. package/build/query/edit/query-placeholder.js +6 -1
  280. package/build/query/edit/query-placeholder.js.map +1 -1
  281. package/build/query/utils.js +35 -9
  282. package/build/query/utils.js.map +1 -1
  283. package/build/query-no-results/edit.js +2 -2
  284. package/build/query-no-results/edit.js.map +1 -1
  285. package/build/query-pagination-next/edit.js +2 -1
  286. package/build/query-pagination-next/edit.js.map +1 -1
  287. package/build/query-pagination-previous/edit.js +2 -1
  288. package/build/query-pagination-previous/edit.js.map +1 -1
  289. package/build/query-title/edit.js +30 -8
  290. package/build/query-title/edit.js.map +1 -1
  291. package/build/query-title/index.js +11 -2
  292. package/build/query-title/index.js.map +1 -1
  293. package/build/query-title/variations.js +10 -0
  294. package/build/query-title/variations.js.map +1 -1
  295. package/build/quote/deprecated.js +176 -37
  296. package/build/quote/deprecated.js.map +1 -1
  297. package/build/quote/edit.js +76 -39
  298. package/build/quote/edit.js.map +1 -1
  299. package/build/quote/index.js +9 -45
  300. package/build/quote/index.js.map +1 -1
  301. package/build/quote/save.js +1 -5
  302. package/build/quote/save.js.map +1 -1
  303. package/build/quote/transforms.js +96 -159
  304. package/build/quote/transforms.js.map +1 -1
  305. package/build/separator/deprecated.js +3 -4
  306. package/build/separator/deprecated.js.map +1 -1
  307. package/build/separator/edit.js +1 -1
  308. package/build/separator/edit.js.map +1 -1
  309. package/build/separator/index.js +1 -0
  310. package/build/separator/index.js.map +1 -1
  311. package/build/social-link/icons/index.js +13 -0
  312. package/build/social-link/icons/index.js.map +1 -1
  313. package/build/social-link/icons/reddit.js +1 -1
  314. package/build/social-link/icons/reddit.js.map +1 -1
  315. package/build/social-link/icons/whatsapp.js +25 -0
  316. package/build/social-link/icons/whatsapp.js.map +1 -0
  317. package/build/social-link/variations.js +7 -0
  318. package/build/social-link/variations.js.map +1 -1
  319. package/build/social-links/edit.js +3 -1
  320. package/build/social-links/edit.js.map +1 -1
  321. package/build/spacer/index.js +7 -1
  322. package/build/spacer/index.js.map +1 -1
  323. package/build/table/index.js +4 -0
  324. package/build/table/index.js.map +1 -1
  325. package/build/table/state.js +9 -3
  326. package/build/table/state.js.map +1 -1
  327. package/build/table-of-contents/index.js +11 -1
  328. package/build/table-of-contents/index.js.map +1 -1
  329. package/build/tag-cloud/index.js +5 -1
  330. package/build/tag-cloud/index.js.map +1 -1
  331. package/build/template-part/edit/index.js +21 -10
  332. package/build/template-part/edit/index.js.map +1 -1
  333. package/build/template-part/edit/selection-modal.js +33 -13
  334. package/build/template-part/edit/selection-modal.js.map +1 -1
  335. package/build/template-part/edit/utils/search.js +94 -0
  336. package/build/template-part/edit/utils/search.js.map +1 -0
  337. package/build/template-part/index.js +2 -2
  338. package/build/template-part/index.js.map +1 -1
  339. package/build/term-description/index.js +4 -0
  340. package/build/term-description/index.js.map +1 -1
  341. package/build/text-columns/edit.js +3 -1
  342. package/build/text-columns/edit.js.map +1 -1
  343. package/build/text-columns/save.js +3 -1
  344. package/build/text-columns/save.js.map +1 -1
  345. package/build/verse/index.js +1 -0
  346. package/build/verse/index.js.map +1 -1
  347. package/build/video/index.js +4 -0
  348. package/build/video/index.js.map +1 -1
  349. package/build-module/archives/edit.js +7 -0
  350. package/build-module/archives/edit.js.map +1 -1
  351. package/build-module/archives/index.js +9 -1
  352. package/build-module/archives/index.js.map +1 -1
  353. package/build-module/audio/index.js +4 -0
  354. package/build-module/audio/index.js.map +1 -1
  355. package/build-module/block/edit.js +5 -3
  356. package/build-module/block/edit.js.map +1 -1
  357. package/build-module/block/edit.native.js +5 -3
  358. package/build-module/block/edit.native.js.map +1 -1
  359. package/build-module/button/deprecated.js +14 -4
  360. package/build-module/button/deprecated.js.map +1 -1
  361. package/build-module/button/edit.js +2 -1
  362. package/build-module/button/edit.js.map +1 -1
  363. package/build-module/button/index.js +1 -1
  364. package/build-module/buttons/edit.js +2 -2
  365. package/build-module/buttons/edit.js.map +1 -1
  366. package/build-module/calendar/edit.js +12 -4
  367. package/build-module/calendar/edit.js.map +1 -1
  368. package/build-module/categories/edit.js +4 -2
  369. package/build-module/categories/edit.js.map +1 -1
  370. package/build-module/categories/index.js +14 -1
  371. package/build-module/categories/index.js.map +1 -1
  372. package/build-module/code/index.js +4 -2
  373. package/build-module/code/index.js.map +1 -1
  374. package/build-module/column/index.js +13 -0
  375. package/build-module/column/index.js.map +1 -1
  376. package/build-module/columns/deprecated.js +16 -4
  377. package/build-module/columns/deprecated.js.map +1 -1
  378. package/build-module/columns/edit.js +7 -3
  379. package/build-module/columns/edit.js.map +1 -1
  380. package/build-module/columns/edit.native.js +10 -5
  381. package/build-module/columns/edit.native.js.map +1 -1
  382. package/build-module/columns/index.js +13 -0
  383. package/build-module/columns/index.js.map +1 -1
  384. package/build-module/comment-author-name/index.js +5 -1
  385. package/build-module/comment-author-name/index.js.map +1 -1
  386. package/build-module/comment-content/index.js +5 -1
  387. package/build-module/comment-content/index.js.map +1 -1
  388. package/build-module/comment-date/index.js +1 -0
  389. package/build-module/comment-date/index.js.map +1 -1
  390. package/build-module/comment-edit-link/index.js +5 -1
  391. package/build-module/comment-edit-link/index.js.map +1 -1
  392. package/build-module/comment-reply-link/index.js +5 -1
  393. package/build-module/comment-reply-link/index.js.map +1 -1
  394. package/build-module/comment-template/index.js +14 -1
  395. package/build-module/comment-template/index.js.map +1 -1
  396. package/build-module/comments/edit/comments-legacy.js +59 -0
  397. package/build-module/comments/edit/comments-legacy.js.map +1 -0
  398. package/build-module/comments/edit/index.js +37 -0
  399. package/build-module/comments/edit/index.js.map +1 -0
  400. package/build-module/comments/edit/placeholder.js +102 -0
  401. package/build-module/comments/edit/placeholder.js.map +1 -0
  402. package/build-module/comments/edit/template.js +32 -0
  403. package/build-module/comments/edit/template.js.map +1 -0
  404. package/build-module/comments/index.js +19 -1
  405. package/build-module/comments/index.js.map +1 -1
  406. package/build-module/comments/save.js +9 -4
  407. package/build-module/comments/save.js.map +1 -1
  408. package/build-module/comments-pagination/index.js +13 -0
  409. package/build-module/comments-pagination/index.js.map +1 -1
  410. package/build-module/comments-pagination-next/index.js +4 -2
  411. package/build-module/comments-pagination-next/index.js.map +1 -1
  412. package/build-module/comments-pagination-numbers/edit.js +5 -1
  413. package/build-module/comments-pagination-numbers/edit.js.map +1 -1
  414. package/build-module/comments-pagination-numbers/index.js +14 -1
  415. package/build-module/comments-pagination-numbers/index.js.map +1 -1
  416. package/build-module/comments-pagination-previous/index.js +4 -2
  417. package/build-module/comments-pagination-previous/index.js.map +1 -1
  418. package/build-module/comments-title/deprecated.js +4 -2
  419. package/build-module/comments-title/deprecated.js.map +1 -1
  420. package/build-module/comments-title/index.js +4 -2
  421. package/build-module/comments-title/index.js.map +1 -1
  422. package/build-module/cover/deprecated.js +20 -4
  423. package/build-module/cover/deprecated.js.map +1 -1
  424. package/build-module/cover/edit/resizable-cover.js +6 -0
  425. package/build-module/cover/edit/resizable-cover.js.map +1 -1
  426. package/build-module/cover/index.js +13 -0
  427. package/build-module/cover/index.js.map +1 -1
  428. package/build-module/cover/shared.js +1 -1
  429. package/build-module/cover/shared.js.map +1 -1
  430. package/build-module/cover/transforms.js +3 -2
  431. package/build-module/cover/transforms.js.map +1 -1
  432. package/build-module/embed/embed-placeholder.native.js +1 -2
  433. package/build-module/embed/embed-placeholder.native.js.map +1 -1
  434. package/build-module/embed/icons.js +1 -1
  435. package/build-module/embed/icons.js.map +1 -1
  436. package/build-module/gallery/deprecated.js +7 -2
  437. package/build-module/gallery/deprecated.js.map +1 -1
  438. package/build-module/gallery/edit.js +17 -4
  439. package/build-module/gallery/edit.js.map +1 -1
  440. package/build-module/gallery/index.js +5 -0
  441. package/build-module/gallery/index.js.map +1 -1
  442. package/build-module/gallery/transforms.js +20 -7
  443. package/build-module/gallery/transforms.js.map +1 -1
  444. package/build-module/gallery/use-get-media.native.js +50 -0
  445. package/build-module/gallery/use-get-media.native.js.map +1 -0
  446. package/build-module/gallery/utils.js +7 -6
  447. package/build-module/gallery/utils.js.map +1 -1
  448. package/build-module/group/deprecated.js +109 -12
  449. package/build-module/group/deprecated.js.map +1 -1
  450. package/build-module/group/edit.js +25 -2
  451. package/build-module/group/edit.js.map +1 -1
  452. package/build-module/group/index.js +11 -2
  453. package/build-module/group/index.js.map +1 -1
  454. package/build-module/group/transforms.js +5 -0
  455. package/build-module/group/transforms.js.map +1 -1
  456. package/build-module/group/variations.js +10 -10
  457. package/build-module/group/variations.js.map +1 -1
  458. package/build-module/heading/deprecated.js +5 -2
  459. package/build-module/heading/deprecated.js.map +1 -1
  460. package/build-module/heading/index.js +3 -1
  461. package/build-module/heading/index.js.map +1 -1
  462. package/build-module/heading/transforms.js +3 -1
  463. package/build-module/heading/transforms.js.map +1 -1
  464. package/build-module/home-link/edit.js +10 -6
  465. package/build-module/home-link/edit.js.map +1 -1
  466. package/build-module/image/deprecated.js +77 -9
  467. package/build-module/image/deprecated.js.map +1 -1
  468. package/build-module/image/edit.js +19 -5
  469. package/build-module/image/edit.js.map +1 -1
  470. package/build-module/image/edit.native.js +18 -8
  471. package/build-module/image/edit.native.js.map +1 -1
  472. package/build-module/image/image.js +29 -22
  473. package/build-module/image/image.js.map +1 -1
  474. package/build-module/image/index.js +20 -8
  475. package/build-module/image/index.js.map +1 -1
  476. package/build-module/image/save.js +9 -3
  477. package/build-module/image/save.js.map +1 -1
  478. package/build-module/index.js +1 -2
  479. package/build-module/index.js.map +1 -1
  480. package/build-module/index.native.js +15 -9
  481. package/build-module/index.native.js.map +1 -1
  482. package/build-module/list/index.js +1 -1
  483. package/build-module/list/index.js.map +1 -1
  484. package/build-module/list/transforms.js +4 -63
  485. package/build-module/list/transforms.js.map +1 -1
  486. package/build-module/list/v2/edit.js +15 -5
  487. package/build-module/list/v2/edit.js.map +1 -1
  488. package/build-module/list/v2/tag-name.js +21 -0
  489. package/build-module/list/v2/tag-name.js.map +1 -0
  490. package/build-module/list/v2/tag-name.native.js +21 -0
  491. package/build-module/list/v2/tag-name.native.js.map +1 -0
  492. package/build-module/list/v2/transforms.js +3 -39
  493. package/build-module/list/v2/transforms.js.map +1 -1
  494. package/build-module/list-item/edit.js +18 -14
  495. package/build-module/list-item/edit.js.map +1 -1
  496. package/build-module/list-item/edit.native.js +141 -0
  497. package/build-module/list-item/edit.native.js.map +1 -0
  498. package/build-module/list-item/hooks/index.js +2 -1
  499. package/build-module/list-item/hooks/index.js.map +1 -1
  500. package/build-module/list-item/hooks/use-copy.js +32 -0
  501. package/build-module/list-item/hooks/use-copy.js.map +1 -0
  502. package/build-module/list-item/hooks/use-merge.js +160 -0
  503. package/build-module/list-item/hooks/use-merge.js.map +1 -0
  504. package/build-module/list-item/hooks/use-outdent-list-item.js +82 -46
  505. package/build-module/list-item/hooks/use-outdent-list-item.js.map +1 -1
  506. package/build-module/list-item/icons.native.js +37 -0
  507. package/build-module/list-item/icons.native.js.map +1 -0
  508. package/build-module/list-item/list-style-type.native.js +126 -0
  509. package/build-module/list-item/list-style-type.native.js.map +1 -0
  510. package/build-module/list-item/utils.js +123 -2
  511. package/build-module/list-item/utils.js.map +1 -1
  512. package/build-module/media-text/deprecated.js +273 -19
  513. package/build-module/media-text/deprecated.js.map +1 -1
  514. package/build-module/media-text/edit.js +4 -3
  515. package/build-module/media-text/edit.js.map +1 -1
  516. package/build-module/media-text/index.js +13 -0
  517. package/build-module/media-text/index.js.map +1 -1
  518. package/build-module/media-text/media-container.js +1 -1
  519. package/build-module/media-text/media-container.js.map +1 -1
  520. package/build-module/media-text/save.js +13 -0
  521. package/build-module/media-text/save.js.map +1 -1
  522. package/build-module/more/save.js +1 -6
  523. package/build-module/more/save.js.map +1 -1
  524. package/build-module/navigation/deprecated.js +7 -2
  525. package/build-module/navigation/deprecated.js.map +1 -1
  526. package/build-module/navigation/edit/index.js +178 -154
  527. package/build-module/navigation/edit/index.js.map +1 -1
  528. package/build-module/navigation/edit/navigation-menu-selector.js +12 -15
  529. package/build-module/navigation/edit/navigation-menu-selector.js.map +1 -1
  530. package/build-module/navigation/edit/placeholder/index.js +4 -2
  531. package/build-module/navigation/edit/placeholder/index.js.map +1 -1
  532. package/build-module/navigation/edit/responsive-wrapper.js +12 -3
  533. package/build-module/navigation/edit/responsive-wrapper.js.map +1 -1
  534. package/build-module/navigation/edit/unsaved-inner-blocks.js +2 -1
  535. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  536. package/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js +4 -7
  537. package/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  538. package/build-module/navigation/edit/use-create-navigation-menu.js +5 -1
  539. package/build-module/navigation/edit/use-create-navigation-menu.js.map +1 -1
  540. package/build-module/navigation/edit/use-inner-blocks.js +33 -0
  541. package/build-module/navigation/edit/use-inner-blocks.js.map +1 -0
  542. package/build-module/navigation/edit/utils.js +21 -0
  543. package/build-module/navigation/edit/utils.js.map +1 -0
  544. package/build-module/navigation/menu-items-to-blocks.js +1 -6
  545. package/build-module/navigation/menu-items-to-blocks.js.map +1 -1
  546. package/build-module/navigation/use-navigation-menu.js +15 -10
  547. package/build-module/navigation/use-navigation-menu.js.map +1 -1
  548. package/build-module/navigation-link/edit.js +12 -13
  549. package/build-module/navigation-link/edit.js.map +1 -1
  550. package/build-module/navigation-submenu/edit.js +7 -8
  551. package/build-module/navigation-submenu/edit.js.map +1 -1
  552. package/build-module/page-list/edit.js +15 -3
  553. package/build-module/page-list/edit.js.map +1 -1
  554. package/build-module/paragraph/deprecated.js +18 -9
  555. package/build-module/paragraph/deprecated.js.map +1 -1
  556. package/build-module/paragraph/edit.js +9 -12
  557. package/build-module/paragraph/edit.js.map +1 -1
  558. package/build-module/paragraph/index.js +5 -0
  559. package/build-module/paragraph/index.js.map +1 -1
  560. package/build-module/paragraph/transforms.js +5 -0
  561. package/build-module/paragraph/transforms.js.map +1 -1
  562. package/build-module/post-author/edit.js +5 -2
  563. package/build-module/post-author/edit.js.map +1 -1
  564. package/build-module/post-author/index.js +4 -2
  565. package/build-module/post-author/index.js.map +1 -1
  566. package/build-module/post-author-biography/edit.js +6 -1
  567. package/build-module/post-author-biography/edit.js.map +1 -1
  568. package/build-module/post-author-biography/index.js +1 -0
  569. package/build-module/post-author-biography/index.js.map +1 -1
  570. package/build-module/post-author-name/index.js +5 -1
  571. package/build-module/post-author-name/index.js.map +1 -1
  572. package/build-module/post-comments-count/edit.js +10 -1
  573. package/build-module/post-comments-count/edit.js.map +1 -1
  574. package/build-module/post-comments-count/index.js +4 -1
  575. package/build-module/post-comments-count/index.js.map +1 -1
  576. package/build-module/post-comments-form/edit.js +5 -42
  577. package/build-module/post-comments-form/edit.js.map +1 -1
  578. package/build-module/post-comments-form/form.js +46 -5
  579. package/build-module/post-comments-form/form.js.map +1 -1
  580. package/build-module/post-comments-link/index.js +4 -2
  581. package/build-module/post-comments-link/index.js.map +1 -1
  582. package/build-module/post-content/edit.js +5 -3
  583. package/build-module/post-content/edit.js.map +1 -1
  584. package/build-module/post-date/edit.js +9 -2
  585. package/build-module/post-date/edit.js.map +1 -1
  586. package/build-module/post-date/index.js +9 -0
  587. package/build-module/post-date/index.js.map +1 -1
  588. package/build-module/post-featured-image/edit.js +45 -16
  589. package/build-module/post-featured-image/edit.js.map +1 -1
  590. package/build-module/post-featured-image/index.js +21 -0
  591. package/build-module/post-featured-image/index.js.map +1 -1
  592. package/build-module/post-navigation-link/index.js +3 -2
  593. package/build-module/post-navigation-link/index.js.map +1 -1
  594. package/build-module/post-template/edit.js +8 -4
  595. package/build-module/post-template/edit.js.map +1 -1
  596. package/build-module/post-template/index.js +14 -1
  597. package/build-module/post-template/index.js.map +1 -1
  598. package/build-module/post-terms/edit.js +3 -2
  599. package/build-module/post-terms/edit.js.map +1 -1
  600. package/build-module/post-terms/index.js +5 -3
  601. package/build-module/post-terms/index.js.map +1 -1
  602. package/build-module/post-title/index.js +2 -1
  603. package/build-module/post-title/index.js.map +1 -1
  604. package/build-module/preformatted/index.js +4 -2
  605. package/build-module/preformatted/index.js.map +1 -1
  606. package/build-module/pullquote/deprecated.js +134 -25
  607. package/build-module/pullquote/deprecated.js.map +1 -1
  608. package/build-module/pullquote/edit.js +1 -1
  609. package/build-module/pullquote/edit.js.map +1 -1
  610. package/build-module/pullquote/edit.native.js +0 -1
  611. package/build-module/pullquote/edit.native.js.map +1 -1
  612. package/build-module/pullquote/index.js +13 -6
  613. package/build-module/pullquote/index.js.map +1 -1
  614. package/build-module/pullquote/save.js +2 -2
  615. package/build-module/pullquote/save.js.map +1 -1
  616. package/build-module/pullquote/transforms.js +15 -34
  617. package/build-module/pullquote/transforms.js.map +1 -1
  618. package/build-module/query/deprecated.js +10 -8
  619. package/build-module/query/deprecated.js.map +1 -1
  620. package/build-module/query/edit/index.js +23 -12
  621. package/build-module/query/edit/index.js.map +1 -1
  622. package/build-module/query/edit/inspector-controls/index.js +42 -9
  623. package/build-module/query/edit/inspector-controls/index.js.map +1 -1
  624. package/build-module/query/edit/inspector-controls/taxonomy-controls.js +17 -12
  625. package/build-module/query/edit/inspector-controls/taxonomy-controls.js.map +1 -1
  626. package/build-module/query/edit/query-placeholder.js +6 -1
  627. package/build-module/query/edit/query-placeholder.js.map +1 -1
  628. package/build-module/query/utils.js +32 -7
  629. package/build-module/query/utils.js.map +1 -1
  630. package/build-module/query-no-results/edit.js +3 -3
  631. package/build-module/query-no-results/edit.js.map +1 -1
  632. package/build-module/query-pagination-next/edit.js +2 -1
  633. package/build-module/query-pagination-next/edit.js.map +1 -1
  634. package/build-module/query-pagination-previous/edit.js +2 -1
  635. package/build-module/query-pagination-previous/edit.js.map +1 -1
  636. package/build-module/query-title/edit.js +30 -9
  637. package/build-module/query-title/edit.js.map +1 -1
  638. package/build-module/query-title/index.js +11 -2
  639. package/build-module/query-title/index.js.map +1 -1
  640. package/build-module/query-title/variations.js +10 -0
  641. package/build-module/query-title/variations.js.map +1 -1
  642. package/build-module/quote/deprecated.js +171 -37
  643. package/build-module/quote/deprecated.js.map +1 -1
  644. package/build-module/quote/edit.js +77 -43
  645. package/build-module/quote/edit.js.map +1 -1
  646. package/build-module/quote/index.js +9 -39
  647. package/build-module/quote/index.js.map +1 -1
  648. package/build-module/quote/save.js +4 -8
  649. package/build-module/quote/save.js.map +1 -1
  650. package/build-module/quote/transforms.js +96 -158
  651. package/build-module/quote/transforms.js.map +1 -1
  652. package/build-module/separator/deprecated.js +3 -3
  653. package/build-module/separator/deprecated.js.map +1 -1
  654. package/build-module/separator/edit.js +1 -1
  655. package/build-module/separator/edit.js.map +1 -1
  656. package/build-module/separator/index.js +1 -0
  657. package/build-module/separator/index.js.map +1 -1
  658. package/build-module/social-link/icons/index.js +1 -0
  659. package/build-module/social-link/icons/index.js.map +1 -1
  660. package/build-module/social-link/icons/reddit.js +1 -1
  661. package/build-module/social-link/icons/reddit.js.map +1 -1
  662. package/build-module/social-link/icons/whatsapp.js +15 -0
  663. package/build-module/social-link/icons/whatsapp.js.map +1 -0
  664. package/build-module/social-link/variations.js +8 -1
  665. package/build-module/social-link/variations.js.map +1 -1
  666. package/build-module/social-links/edit.js +3 -1
  667. package/build-module/social-links/edit.js.map +1 -1
  668. package/build-module/spacer/index.js +7 -1
  669. package/build-module/spacer/index.js.map +1 -1
  670. package/build-module/table/index.js +4 -0
  671. package/build-module/table/index.js.map +1 -1
  672. package/build-module/table/state.js +10 -4
  673. package/build-module/table/state.js.map +1 -1
  674. package/build-module/table-of-contents/index.js +11 -1
  675. package/build-module/table-of-contents/index.js.map +1 -1
  676. package/build-module/tag-cloud/index.js +5 -1
  677. package/build-module/tag-cloud/index.js.map +1 -1
  678. package/build-module/template-part/edit/index.js +24 -13
  679. package/build-module/template-part/edit/index.js.map +1 -1
  680. package/build-module/template-part/edit/selection-modal.js +33 -15
  681. package/build-module/template-part/edit/selection-modal.js.map +1 -1
  682. package/build-module/template-part/edit/utils/search.js +84 -0
  683. package/build-module/template-part/edit/utils/search.js.map +1 -0
  684. package/build-module/template-part/index.js +2 -2
  685. package/build-module/template-part/index.js.map +1 -1
  686. package/build-module/term-description/index.js +4 -0
  687. package/build-module/term-description/index.js.map +1 -1
  688. package/build-module/text-columns/edit.js +4 -2
  689. package/build-module/text-columns/edit.js.map +1 -1
  690. package/build-module/text-columns/save.js +4 -2
  691. package/build-module/text-columns/save.js.map +1 -1
  692. package/build-module/verse/index.js +1 -0
  693. package/build-module/verse/index.js.map +1 -1
  694. package/build-module/video/index.js +4 -0
  695. package/build-module/video/index.js.map +1 -1
  696. package/build-style/audio/style-rtl.css +3 -0
  697. package/build-style/audio/style.css +3 -0
  698. package/build-style/button/style-rtl.css +7 -7
  699. package/build-style/button/style.css +7 -7
  700. package/build-style/comments/editor-rtl.css +122 -0
  701. package/build-style/comments/editor.css +122 -0
  702. package/build-style/{post-comments → comments}/style-rtl.css +1 -0
  703. package/build-style/{post-comments → comments}/style.css +1 -0
  704. package/build-style/common-rtl.css +7 -0
  705. package/build-style/common.css +7 -0
  706. package/build-style/cover/style-rtl.css +2 -2
  707. package/build-style/cover/style.css +2 -2
  708. package/build-style/editor-elements-rtl.css +85 -0
  709. package/build-style/editor-elements.css +85 -0
  710. package/build-style/editor-rtl.css +266 -132
  711. package/build-style/editor.css +266 -132
  712. package/build-style/gallery/style-rtl.css +7 -2
  713. package/build-style/gallery/style.css +7 -2
  714. package/build-style/group/editor-rtl.css +27 -8
  715. package/build-style/group/editor.css +27 -8
  716. package/build-style/image/editor-rtl.css +25 -5
  717. package/build-style/image/editor.css +25 -5
  718. package/build-style/image/style-rtl.css +33 -3
  719. package/build-style/image/style.css +33 -3
  720. package/build-style/latest-posts/editor-rtl.css +3 -0
  721. package/build-style/latest-posts/editor.css +3 -0
  722. package/build-style/navigation/editor-rtl.css +8 -4
  723. package/build-style/navigation/editor.css +8 -4
  724. package/build-style/navigation/style-rtl.css +17 -19
  725. package/build-style/navigation/style.css +17 -19
  726. package/build-style/paragraph/editor-rtl.css +1 -1
  727. package/build-style/paragraph/editor.css +1 -1
  728. package/build-style/post-comments-form/style-rtl.css +0 -1
  729. package/build-style/post-comments-form/style.css +0 -1
  730. package/build-style/{post-comments/editor-rtl.css → post-date/style-rtl.css} +2 -2
  731. package/build-style/{post-comments/editor.css → post-date/style.css} +2 -2
  732. package/build-style/post-featured-image/editor-rtl.css +45 -43
  733. package/build-style/post-featured-image/editor.css +45 -43
  734. package/build-style/post-featured-image/style-rtl.css +1 -0
  735. package/build-style/post-featured-image/style.css +1 -0
  736. package/build-style/post-title/style-rtl.css +1 -0
  737. package/build-style/post-title/style.css +1 -0
  738. package/build-style/pullquote/editor-rtl.css +0 -12
  739. package/build-style/pullquote/editor.css +0 -12
  740. package/build-style/pullquote/style-rtl.css +1 -8
  741. package/build-style/pullquote/style.css +1 -8
  742. package/build-style/query/editor-rtl.css +7 -0
  743. package/build-style/query/editor.css +7 -0
  744. package/build-style/query-pagination/style-rtl.css +6 -0
  745. package/build-style/query-pagination/style.css +6 -0
  746. package/build-style/query-title/style-rtl.css +79 -0
  747. package/build-style/query-title/style.css +79 -0
  748. package/build-style/search/style-rtl.css +2 -0
  749. package/build-style/search/style.css +2 -0
  750. package/build-style/site-logo/editor-rtl.css +3 -52
  751. package/build-style/site-logo/editor.css +3 -52
  752. package/build-style/social-link/editor-rtl.css +1 -0
  753. package/build-style/social-link/editor.css +1 -0
  754. package/build-style/social-links/style-rtl.css +10 -2
  755. package/build-style/social-links/style.css +10 -2
  756. package/build-style/style-rtl.css +221 -162
  757. package/build-style/style.css +221 -162
  758. package/build-style/tag-cloud/style-rtl.css +1 -0
  759. package/build-style/tag-cloud/style.css +1 -0
  760. package/build-style/template-part/editor-rtl.css +14 -3
  761. package/build-style/template-part/editor.css +14 -3
  762. package/build-style/video/style-rtl.css +3 -0
  763. package/build-style/video/style.css +3 -0
  764. package/package.json +30 -30
  765. package/src/archives/block.json +9 -1
  766. package/src/archives/edit.js +12 -1
  767. package/src/archives/index.php +5 -3
  768. package/src/audio/block.json +4 -0
  769. package/src/audio/style.scss +2 -0
  770. package/src/audio/test/__snapshots__/edit.native.js.snap +16 -2
  771. package/src/block/edit.js +4 -4
  772. package/src/block/edit.native.js +4 -4
  773. package/src/button/block.json +1 -1
  774. package/src/button/deprecated.js +21 -22
  775. package/src/button/edit.js +1 -0
  776. package/src/button/style.scss +9 -7
  777. package/src/buttons/edit.js +1 -5
  778. package/src/calendar/edit.js +11 -4
  779. package/src/calendar/index.php +2 -2
  780. package/src/categories/block.json +14 -1
  781. package/src/categories/edit.js +2 -2
  782. package/src/code/block.json +4 -2
  783. package/src/column/block.json +13 -0
  784. package/src/columns/block.json +13 -0
  785. package/src/columns/deprecated.js +10 -4
  786. package/src/columns/edit.js +7 -3
  787. package/src/columns/edit.native.js +11 -5
  788. package/src/comment-author-name/block.json +5 -1
  789. package/src/comment-content/block.json +5 -1
  790. package/src/comment-date/block.json +1 -0
  791. package/src/comment-edit-link/block.json +5 -1
  792. package/src/comment-reply-link/block.json +5 -1
  793. package/src/comment-template/block.json +14 -1
  794. package/src/comments/block.json +19 -1
  795. package/src/comments/edit/comments-legacy.js +71 -0
  796. package/src/comments/edit/index.js +35 -0
  797. package/src/comments/edit/placeholder.js +124 -0
  798. package/src/comments/{edit.js → edit/template.js} +1 -28
  799. package/src/comments/editor.scss +9 -0
  800. package/src/comments/index.php +220 -0
  801. package/src/comments/save.js +8 -7
  802. package/src/{post-comments → comments}/style.scss +7 -0
  803. package/src/comments-pagination/block.json +13 -0
  804. package/src/comments-pagination-next/block.json +4 -2
  805. package/src/comments-pagination-numbers/block.json +14 -1
  806. package/src/comments-pagination-numbers/edit.js +12 -3
  807. package/src/comments-pagination-previous/block.json +4 -2
  808. package/src/comments-title/block.json +4 -2
  809. package/src/common.scss +2 -0
  810. package/src/cover/block.json +13 -0
  811. package/src/cover/deprecated.js +11 -4
  812. package/src/cover/edit/resizable-cover.js +6 -0
  813. package/src/cover/index.php +2 -2
  814. package/src/cover/shared.js +2 -1
  815. package/src/cover/style.scss +2 -2
  816. package/src/cover/transforms.js +2 -2
  817. package/src/editor-elements.scss +10 -0
  818. package/src/editor.scss +2 -1
  819. package/src/embed/embed-placeholder.native.js +2 -3
  820. package/src/embed/icons.js +1 -1
  821. package/src/file/test/__snapshots__/edit.native.js.snap +32 -4
  822. package/src/gallery/block.json +5 -0
  823. package/src/gallery/deprecated.js +4 -2
  824. package/src/gallery/edit.js +26 -4
  825. package/src/gallery/style.scss +10 -1
  826. package/src/gallery/transforms.js +18 -5
  827. package/src/gallery/use-get-media.native.js +44 -0
  828. package/src/gallery/utils.js +11 -7
  829. package/src/group/block.json +11 -2
  830. package/src/group/deprecated.js +89 -2
  831. package/src/group/edit.js +15 -2
  832. package/src/group/editor.scss +28 -3
  833. package/src/group/transforms.js +7 -0
  834. package/src/group/variations.js +6 -5
  835. package/src/heading/block.json +3 -1
  836. package/src/heading/deprecated.js +4 -2
  837. package/src/home-link/edit.js +19 -20
  838. package/src/home-link/index.php +8 -17
  839. package/src/image/block.json +20 -8
  840. package/src/image/deprecated.js +86 -0
  841. package/src/image/edit.js +25 -2
  842. package/src/image/edit.native.js +18 -7
  843. package/src/image/editor.scss +48 -7
  844. package/src/image/image.js +26 -16
  845. package/src/image/index.php +1 -1
  846. package/src/image/save.js +10 -1
  847. package/src/image/style.scss +39 -3
  848. package/src/image/test/edit.native.js +6 -10
  849. package/src/index.js +0 -2
  850. package/src/index.native.js +26 -17
  851. package/src/latest-posts/editor.scss +5 -0
  852. package/src/list/index.js +1 -1
  853. package/src/list/test/__snapshots__/edit.native.js.snap +133 -0
  854. package/src/list/test/edit.native.js +511 -7
  855. package/src/list/transforms.js +0 -47
  856. package/src/list/v2/edit.js +12 -4
  857. package/src/list/v2/tag-name.js +13 -0
  858. package/src/list/v2/tag-name.native.js +12 -0
  859. package/src/list/v2/transforms.js +3 -49
  860. package/src/list-item/edit.js +13 -14
  861. package/src/list-item/edit.native.js +148 -0
  862. package/src/list-item/hooks/index.js +2 -1
  863. package/src/list-item/hooks/use-copy.js +36 -0
  864. package/src/list-item/hooks/use-merge.js +141 -0
  865. package/src/list-item/hooks/use-outdent-list-item.js +72 -74
  866. package/src/list-item/icons.native.js +34 -0
  867. package/src/list-item/list-style-type.native.js +146 -0
  868. package/src/list-item/style.native.scss +49 -0
  869. package/src/list-item/utils.js +27 -3
  870. package/src/media-text/block.json +13 -0
  871. package/src/media-text/deprecated.js +584 -290
  872. package/src/media-text/edit.js +3 -1
  873. package/src/media-text/media-container.js +3 -1
  874. package/src/media-text/save.js +18 -0
  875. package/src/media-text/test/media-container.js +24 -0
  876. package/src/more/save.js +3 -6
  877. package/src/navigation/deprecated.js +4 -2
  878. package/src/navigation/edit/index.js +234 -237
  879. package/src/navigation/edit/navigation-menu-selector.js +12 -26
  880. package/src/navigation/edit/placeholder/index.js +4 -2
  881. package/src/navigation/edit/responsive-wrapper.js +24 -3
  882. package/src/navigation/edit/unsaved-inner-blocks.js +3 -1
  883. package/src/navigation/edit/use-convert-classic-menu-to-block-menu.js +31 -37
  884. package/src/navigation/edit/use-create-navigation-menu.js +4 -0
  885. package/src/navigation/edit/use-inner-blocks.js +39 -0
  886. package/src/navigation/edit/utils.js +30 -0
  887. package/src/navigation/editor.scss +3 -2
  888. package/src/navigation/index.php +17 -16
  889. package/src/navigation/menu-items-to-blocks.js +3 -6
  890. package/src/navigation/style.scss +13 -22
  891. package/src/navigation/use-navigation-menu.js +20 -13
  892. package/src/navigation-link/edit.js +13 -16
  893. package/src/navigation-link/index.php +1 -1
  894. package/src/navigation-submenu/edit.js +10 -13
  895. package/src/navigation-submenu/index.php +1 -1
  896. package/src/page-list/edit.js +15 -2
  897. package/src/page-list/index.php +4 -4
  898. package/src/paragraph/block.json +5 -0
  899. package/src/paragraph/deprecated.js +33 -35
  900. package/src/paragraph/edit.js +9 -14
  901. package/src/paragraph/editor.scss +5 -3
  902. package/src/post-author/block.json +4 -2
  903. package/src/post-author/edit.js +6 -3
  904. package/src/post-author-biography/block.json +1 -0
  905. package/src/post-author-biography/edit.js +4 -1
  906. package/src/post-author-name/block.json +5 -1
  907. package/src/post-comments-count/block.json +4 -1
  908. package/src/post-comments-count/edit.js +10 -2
  909. package/src/post-comments-form/edit.js +2 -71
  910. package/src/post-comments-form/form.js +80 -5
  911. package/src/post-comments-form/index.php +1 -1
  912. package/src/post-comments-form/style.scss +0 -1
  913. package/src/post-comments-link/block.json +4 -2
  914. package/src/post-content/edit.js +4 -4
  915. package/src/post-date/block.json +9 -0
  916. package/src/post-date/edit.js +12 -2
  917. package/src/post-date/index.php +10 -2
  918. package/src/post-date/style.scss +4 -0
  919. package/src/post-featured-image/block.json +21 -0
  920. package/src/post-featured-image/edit.js +66 -14
  921. package/src/post-featured-image/editor.scss +44 -53
  922. package/src/post-featured-image/index.php +64 -5
  923. package/src/post-featured-image/style.scss +1 -0
  924. package/src/post-navigation-link/block.json +3 -2
  925. package/src/post-template/block.json +15 -1
  926. package/src/post-template/edit.js +6 -1
  927. package/src/post-template/index.php +7 -4
  928. package/src/post-terms/block.json +5 -3
  929. package/src/post-terms/edit.js +3 -2
  930. package/src/post-title/block.json +2 -1
  931. package/src/post-title/index.php +2 -1
  932. package/src/post-title/style.scss +2 -0
  933. package/src/preformatted/block.json +4 -2
  934. package/src/preformatted/test/__snapshots__/edit.native.js.snap +16 -2
  935. package/src/pullquote/block.json +11 -4
  936. package/src/pullquote/deprecated.js +490 -412
  937. package/src/pullquote/edit.js +1 -1
  938. package/src/pullquote/edit.native.js +0 -1
  939. package/src/pullquote/editor.scss +0 -16
  940. package/src/pullquote/index.js +1 -3
  941. package/src/pullquote/save.js +1 -1
  942. package/src/pullquote/style.scss +0 -11
  943. package/src/pullquote/transforms.js +17 -33
  944. package/src/query/deprecated.js +4 -9
  945. package/src/query/edit/index.js +28 -15
  946. package/src/query/edit/inspector-controls/index.js +129 -65
  947. package/src/query/edit/inspector-controls/taxonomy-controls.js +18 -11
  948. package/src/query/edit/query-placeholder.js +17 -2
  949. package/src/query/editor.scss +9 -0
  950. package/src/query/utils.js +29 -7
  951. package/src/query-no-results/edit.js +3 -6
  952. package/src/query-pagination/style.scss +14 -0
  953. package/src/query-pagination-next/edit.js +1 -0
  954. package/src/query-pagination-previous/edit.js +1 -0
  955. package/src/query-title/block.json +11 -2
  956. package/src/query-title/edit.js +51 -7
  957. package/src/query-title/index.php +28 -2
  958. package/src/query-title/style.scss +4 -0
  959. package/src/query-title/variations.js +13 -0
  960. package/src/quote/deprecated.js +215 -100
  961. package/src/quote/edit.js +77 -52
  962. package/src/quote/index.js +10 -33
  963. package/src/quote/save.js +5 -5
  964. package/src/quote/{v2/test → test}/migrate.js +2 -7
  965. package/src/quote/transforms.js +98 -146
  966. package/src/search/index.php +1 -1
  967. package/src/search/style.scss +2 -0
  968. package/src/search/test/__snapshots__/edit.native.js.snap +56 -7
  969. package/src/separator/block.json +1 -0
  970. package/src/separator/deprecated.js +2 -3
  971. package/src/separator/edit.js +1 -1
  972. package/src/separator/test/edit.js +5 -3
  973. package/src/site-logo/editor.scss +8 -66
  974. package/src/site-title/index.php +8 -9
  975. package/src/social-link/editor.scss +3 -0
  976. package/src/social-link/icons/index.js +1 -0
  977. package/src/social-link/icons/reddit.js +1 -1
  978. package/src/social-link/icons/whatsapp.js +10 -0
  979. package/src/social-link/index.php +6 -2
  980. package/src/social-link/socials-with-bg.scss +6 -1
  981. package/src/social-link/socials-without-bg.scss +6 -1
  982. package/src/social-link/variations.js +7 -0
  983. package/src/social-links/edit.js +2 -0
  984. package/src/spacer/block.json +7 -1
  985. package/src/style.scss +3 -2
  986. package/src/table/block.json +4 -0
  987. package/src/table/state.js +21 -19
  988. package/src/table-of-contents/block.json +11 -1
  989. package/src/tag-cloud/block.json +5 -1
  990. package/src/tag-cloud/style.scss +1 -0
  991. package/src/template-part/edit/index.js +40 -27
  992. package/src/template-part/edit/selection-modal.js +68 -40
  993. package/src/template-part/edit/utils/search.js +76 -0
  994. package/src/template-part/editor.scss +21 -9
  995. package/src/template-part/index.js +3 -2
  996. package/src/template-part/index.php +56 -2
  997. package/src/term-description/block.json +4 -0
  998. package/src/text-columns/edit.js +2 -2
  999. package/src/text-columns/save.js +2 -2
  1000. package/src/verse/block.json +1 -0
  1001. package/src/video/block.json +4 -0
  1002. package/src/video/style.scss +2 -0
  1003. package/build/comments/edit.js.map +0 -1
  1004. package/build/list-item/hooks/use-backspace.js +0 -59
  1005. package/build/list-item/hooks/use-backspace.js.map +0 -1
  1006. package/build/post-comments/edit.js +0 -184
  1007. package/build/post-comments/edit.js.map +0 -1
  1008. package/build/post-comments/index.js +0 -72
  1009. package/build/post-comments/index.js.map +0 -1
  1010. package/build/quote/v2/deprecated.js +0 -133
  1011. package/build/quote/v2/deprecated.js.map +0 -1
  1012. package/build/quote/v2/edit.js +0 -139
  1013. package/build/quote/v2/edit.js.map +0 -1
  1014. package/build/quote/v2/index.js +0 -49
  1015. package/build/quote/v2/index.js.map +0 -1
  1016. package/build/quote/v2/save.js +0 -43
  1017. package/build/quote/v2/save.js.map +0 -1
  1018. package/build/quote/v2/transforms.js +0 -156
  1019. package/build/quote/v2/transforms.js.map +0 -1
  1020. package/build-module/comments/edit.js +0 -59
  1021. package/build-module/comments/edit.js.map +0 -1
  1022. package/build-module/list-item/hooks/use-backspace.js +0 -44
  1023. package/build-module/list-item/hooks/use-backspace.js.map +0 -1
  1024. package/build-module/post-comments/edit.js +0 -171
  1025. package/build-module/post-comments/edit.js.map +0 -1
  1026. package/build-module/post-comments/index.js +0 -59
  1027. package/build-module/post-comments/index.js.map +0 -1
  1028. package/build-module/quote/v2/deprecated.js +0 -116
  1029. package/build-module/quote/v2/deprecated.js.map +0 -1
  1030. package/build-module/quote/v2/edit.js +0 -122
  1031. package/build-module/quote/v2/edit.js.map +0 -1
  1032. package/build-module/quote/v2/index.js +0 -33
  1033. package/build-module/quote/v2/index.js.map +0 -1
  1034. package/build-module/quote/v2/save.js +0 -30
  1035. package/build-module/quote/v2/save.js.map +0 -1
  1036. package/build-module/quote/v2/transforms.js +0 -147
  1037. package/build-module/quote/v2/transforms.js.map +0 -1
  1038. package/src/list-item/hooks/use-backspace.js +0 -51
  1039. package/src/post-comments/block.json +0 -45
  1040. package/src/post-comments/edit.js +0 -247
  1041. package/src/post-comments/editor.scss +0 -3
  1042. package/src/post-comments/index.js +0 -18
  1043. package/src/post-comments/index.php +0 -87
  1044. package/src/quote/v2/deprecated.js +0 -107
  1045. package/src/quote/v2/edit.js +0 -139
  1046. package/src/quote/v2/index.js +0 -36
  1047. package/src/quote/v2/save.js +0 -26
  1048. package/src/quote/v2/transforms.js +0 -155
@@ -16,31 +16,36 @@
16
16
  "type": "string",
17
17
  "source": "attribute",
18
18
  "selector": "img",
19
- "attribute": "src"
19
+ "attribute": "src",
20
+ "__experimentalRole": "content"
20
21
  },
21
22
  "alt": {
22
23
  "type": "string",
23
24
  "source": "attribute",
24
25
  "selector": "img",
25
26
  "attribute": "alt",
26
- "default": ""
27
+ "default": "",
28
+ "__experimentalRole": "content"
27
29
  },
28
30
  "caption": {
29
31
  "type": "string",
30
32
  "source": "html",
31
- "selector": "figcaption"
33
+ "selector": "figcaption",
34
+ "__experimentalRole": "content"
32
35
  },
33
36
  "title": {
34
37
  "type": "string",
35
38
  "source": "attribute",
36
39
  "selector": "img",
37
- "attribute": "title"
40
+ "attribute": "title",
41
+ "__experimentalRole": "content"
38
42
  },
39
43
  "href": {
40
44
  "type": "string",
41
45
  "source": "attribute",
42
46
  "selector": "figure > a",
43
- "attribute": "href"
47
+ "attribute": "href",
48
+ "__experimentalRole": "content"
44
49
  },
45
50
  "rel": {
46
51
  "type": "string",
@@ -55,7 +60,8 @@
55
60
  "attribute": "class"
56
61
  },
57
62
  "id": {
58
- "type": "number"
63
+ "type": "number",
64
+ "__experimentalRole": "content"
59
65
  },
60
66
  "width": {
61
67
  "type": "number"
@@ -79,14 +85,20 @@
79
85
  "supports": {
80
86
  "anchor": true,
81
87
  "color": {
82
- "__experimentalDuotone": "img",
88
+ "__experimentalDuotone": "img, .components-placeholder",
83
89
  "text": false,
84
90
  "background": false
85
91
  },
86
92
  "__experimentalBorder": {
93
+ "color": true,
87
94
  "radius": true,
95
+ "width": true,
96
+ "__experimentalSelector": "img, .wp-block-image__crop-area",
97
+ "__experimentalSkipSerialization": true,
88
98
  "__experimentalDefaultControls": {
89
- "radius": true
99
+ "color": true,
100
+ "radius": true,
101
+ "width": true
90
102
  }
91
103
  },
92
104
  "__experimentalStyle": {
@@ -31,6 +31,12 @@ const blockAttributes = {
31
31
  source: 'html',
32
32
  selector: 'figcaption',
33
33
  },
34
+ title: {
35
+ type: 'string',
36
+ source: 'attribute',
37
+ selector: 'img',
38
+ attribute: 'title',
39
+ },
34
40
  href: {
35
41
  type: 'string',
36
42
  source: 'attribute',
@@ -58,6 +64,9 @@ const blockAttributes = {
58
64
  height: {
59
65
  type: 'number',
60
66
  },
67
+ sizeSlug: {
68
+ type: 'string',
69
+ },
61
70
  linkDestination: {
62
71
  type: 'string',
63
72
  },
@@ -85,6 +94,83 @@ const blockSupports = {
85
94
  };
86
95
 
87
96
  const deprecated = [
97
+ // The following deprecation moves existing border radius styles onto the
98
+ // inner img element where new border block support styles must be applied.
99
+ // It will also add a new `.has-custom-border` class for existing blocks
100
+ // with border radii set. This class is required to improve caption position
101
+ // and styling when an image within a gallery has a custom border or
102
+ // rounded corners.
103
+ //
104
+ // See: https://github.com/WordPress/gutenberg/pull/31366/
105
+ {
106
+ attributes: blockAttributes,
107
+ supports: blockSupports,
108
+ save( { attributes } ) {
109
+ const {
110
+ url,
111
+ alt,
112
+ caption,
113
+ align,
114
+ href,
115
+ rel,
116
+ linkClass,
117
+ width,
118
+ height,
119
+ id,
120
+ linkTarget,
121
+ sizeSlug,
122
+ title,
123
+ } = attributes;
124
+
125
+ const newRel = isEmpty( rel ) ? undefined : rel;
126
+
127
+ const classes = classnames( {
128
+ [ `align${ align }` ]: align,
129
+ [ `size-${ sizeSlug }` ]: sizeSlug,
130
+ 'is-resized': width || height,
131
+ } );
132
+
133
+ const image = (
134
+ <img
135
+ src={ url }
136
+ alt={ alt }
137
+ className={ id ? `wp-image-${ id }` : null }
138
+ width={ width }
139
+ height={ height }
140
+ title={ title }
141
+ />
142
+ );
143
+
144
+ const figure = (
145
+ <>
146
+ { href ? (
147
+ <a
148
+ className={ linkClass }
149
+ href={ href }
150
+ target={ linkTarget }
151
+ rel={ newRel }
152
+ >
153
+ { image }
154
+ </a>
155
+ ) : (
156
+ image
157
+ ) }
158
+ { ! RichText.isEmpty( caption ) && (
159
+ <RichText.Content
160
+ tagName="figcaption"
161
+ value={ caption }
162
+ />
163
+ ) }
164
+ </>
165
+ );
166
+
167
+ return (
168
+ <figure { ...useBlockProps.save( { className: classes } ) }>
169
+ { figure }
170
+ </figure>
171
+ );
172
+ },
173
+ },
88
174
  {
89
175
  attributes: {
90
176
  ...blockAttributes,
package/src/image/edit.js CHANGED
@@ -2,13 +2,13 @@
2
2
  * External dependencies
3
3
  */
4
4
  import classnames from 'classnames';
5
- import { get, has, omit, pick } from 'lodash';
5
+ import { get, has, isEmpty, omit, pick } from 'lodash';
6
6
 
7
7
  /**
8
8
  * WordPress dependencies
9
9
  */
10
10
  import { getBlobByURL, isBlobURL, revokeBlobURL } from '@wordpress/blob';
11
- import { withNotices } from '@wordpress/components';
11
+ import { withNotices, Placeholder } from '@wordpress/components';
12
12
  import { useSelect } from '@wordpress/data';
13
13
  import {
14
14
  BlockAlignmentControl,
@@ -17,6 +17,7 @@ import {
17
17
  MediaPlaceholder,
18
18
  useBlockProps,
19
19
  store as blockEditorStore,
20
+ __experimentalUseBorderProps as useBorderProps,
20
21
  } from '@wordpress/block-editor';
21
22
  import { useEffect, useRef, useState } from '@wordpress/element';
22
23
  import { __ } from '@wordpress/i18n';
@@ -27,6 +28,23 @@ import { image as icon } from '@wordpress/icons';
27
28
  */
28
29
  import Image from './image';
29
30
 
31
+ // Much of this description is duplicated from MediaPlaceholder.
32
+ const placeholder = ( content ) => {
33
+ return (
34
+ <Placeholder
35
+ className="block-editor-media-placeholder"
36
+ withIllustration={ true }
37
+ icon={ icon }
38
+ label={ __( 'Image' ) }
39
+ instructions={ __(
40
+ 'Upload an image file, pick one from your media library, or add one with a URL.'
41
+ ) }
42
+ >
43
+ { content }
44
+ </Placeholder>
45
+ );
46
+ };
47
+
30
48
  /**
31
49
  * Module constants
32
50
  */
@@ -296,10 +314,14 @@ export function ImageEdit( {
296
314
  />
297
315
  );
298
316
 
317
+ const borderProps = useBorderProps( attributes );
318
+
299
319
  const classes = classnames( className, {
300
320
  'is-transient': temporaryURL,
301
321
  'is-resized': !! width || !! height,
302
322
  [ `size-${ sizeSlug }` ]: sizeSlug,
323
+ 'has-custom-border':
324
+ !! borderProps.className || ! isEmpty( borderProps.style ),
303
325
  } );
304
326
 
305
327
  const blockProps = useBlockProps( {
@@ -339,6 +361,7 @@ export function ImageEdit( {
339
361
  onSelectURL={ onSelectURL }
340
362
  notices={ noticeUI }
341
363
  onError={ onUploadError }
364
+ placeholder={ placeholder }
342
365
  accept="image/*"
343
366
  allowedTypes={ ALLOWED_MEDIA_TYPES }
344
367
  value={ { id, src } }
@@ -268,11 +268,15 @@ export class ImageEdit extends Component {
268
268
  componentDidUpdate( previousProps ) {
269
269
  const { image, attributes, setAttributes, featuredImageId } =
270
270
  this.props;
271
+ const { url } = attributes;
271
272
  if ( ! previousProps.image && image ) {
272
- const url =
273
- getUrlForSlug( image, attributes?.sizeSlug ) ||
274
- image.source_url;
275
- setAttributes( { url } );
273
+ if ( ! hasQueryArg( url, 'w' ) && attributes?.sizeSlug ) {
274
+ const updatedUrl =
275
+ getUrlForSlug( image, attributes.sizeSlug ) ||
276
+ image.source_url;
277
+
278
+ setAttributes( { url: updatedUrl } );
279
+ }
276
280
  }
277
281
 
278
282
  const { id } = attributes;
@@ -574,7 +578,7 @@ export class ImageEdit extends Component {
574
578
  <>
575
579
  { __(
576
580
  'Describe the purpose of the image. Leave empty if the image is purely decorative.'
577
- ) }
581
+ ) }{ ' ' }
578
582
  <FooterMessageLink
579
583
  href={
580
584
  'https://www.w3.org/WAI/tutorials/images/decision-tree/'
@@ -665,6 +669,7 @@ export class ImageEdit extends Component {
665
669
  context,
666
670
  featuredImageId,
667
671
  wasBlockJustInserted,
672
+ shouldUseFastImage,
668
673
  } = this.props;
669
674
  const { align, url, alt, id, sizeSlug, className } = attributes;
670
675
  const hasImageContext = context
@@ -845,6 +850,9 @@ export class ImageEdit extends Component {
845
850
  isUploadInProgress={
846
851
  isUploadInProgress
847
852
  }
853
+ shouldUseFastImage={
854
+ shouldUseFastImage
855
+ }
848
856
  onSelectMediaUploadOption={
849
857
  this.onSelectMediaUploadOption
850
858
  }
@@ -904,7 +912,8 @@ export default compose( [
904
912
  isSelected,
905
913
  clientId,
906
914
  } = props;
907
- const { imageSizes, imageDefaultSize } = getSettings();
915
+ const { imageSizes, imageDefaultSize, shouldUseFastImage } =
916
+ getSettings();
908
917
  const isNotFileUrl = id && getProtocol( url ) !== 'file:';
909
918
  const featuredImageId = getEditedPostAttribute( 'featured_media' );
910
919
 
@@ -916,11 +925,13 @@ export default compose( [
916
925
  isNotFileUrl &&
917
926
  url &&
918
927
  ! hasQueryArg( url, 'w' ) );
928
+ const image = shouldGetMedia ? getMedia( id ) : null;
919
929
 
920
930
  return {
921
- image: shouldGetMedia ? getMedia( id ) : null,
931
+ image,
922
932
  imageSizes,
923
933
  imageDefaultSize,
934
+ shouldUseFastImage,
924
935
  featuredImageId,
925
936
  wasBlockJustInserted: wasBlockJustInserted(
926
937
  clientId,
@@ -1,3 +1,40 @@
1
+ // Provide special styling for the placeholder.
2
+ // @todo: this particular minimal style of placeholder could be componentized further.
3
+ .wp-block-image.wp-block-image {
4
+ // Show Placeholder style on-select.
5
+ &.is-selected .components-placeholder {
6
+ // Block UI appearance.
7
+ color: $gray-900;
8
+ background-color: $white;
9
+ box-shadow: inset 0 0 0 $border-width $gray-900;
10
+ border: none;
11
+
12
+ // Disable any duotone filter applied in the selected state.
13
+ filter: none;
14
+
15
+ // @todo: this should eventually be overridden by a custom border-radius set in the inspector.
16
+ border-radius: $radius-block-ui;
17
+
18
+ > svg {
19
+ opacity: 0;
20
+ }
21
+
22
+ .components-placeholder__illustration {
23
+ display: none;
24
+ }
25
+ }
26
+
27
+ // Remove the transition while we still have a legacy placeholder style.
28
+ // Otherwise the content jumps between the 1px placeholder border, and any inherited custom
29
+ // parent border that may get applied when you deselect.
30
+ .components-placeholder__label,
31
+ .components-placeholder__instructions,
32
+ .components-button {
33
+ transition: none;
34
+ }
35
+ }
36
+
37
+
1
38
  figure.wp-block-image:not(.wp-block) {
2
39
  margin: 0;
3
40
  }
@@ -14,17 +51,12 @@ figure.wp-block-image:not(.wp-block) {
14
51
  display: inline;
15
52
  }
16
53
 
17
- // Shown while image is being uploaded
54
+ // Shown while image is being uploaded.
18
55
  .components-spinner {
19
56
  position: absolute;
20
57
  top: 50%;
21
58
  left: 50%;
22
- margin-top: -9px;
23
- margin-left: -9px;
24
- }
25
-
26
- &:not(.is-style-rounded) > div:not(.components-placeholder) {
27
- border-radius: inherit;
59
+ transform: translate(-50%, -50%);
28
60
  }
29
61
  }
30
62
 
@@ -94,6 +126,15 @@ figure.wp-block-image:not(.wp-block) {
94
126
  position: relative;
95
127
  max-width: 100%;
96
128
  width: 100%;
129
+ overflow: hidden;
130
+
131
+ // This removes the border from the img within the image cropper so it
132
+ // can be applied to the cropper itself. This then allows the image to be
133
+ // cropped within the visual border providing more accurate editing and
134
+ // smoother UX.
135
+ .reactEasyCrop_Container .reactEasyCrop_Image {
136
+ border: none;
137
+ }
97
138
  }
98
139
 
99
140
  .wp-block-image__crop-icon {
@@ -1,7 +1,7 @@
1
1
  /**
2
2
  * External dependencies
3
3
  */
4
- import { get, filter, map, pick, includes } from 'lodash';
4
+ import { get, filter, isEmpty, map, pick, includes } from 'lodash';
5
5
 
6
6
  /**
7
7
  * WordPress dependencies
@@ -30,6 +30,7 @@ import {
30
30
  __experimentalImageEditor as ImageEditor,
31
31
  __experimentalImageEditingProvider as ImageEditingProvider,
32
32
  __experimentalGetElementClassName,
33
+ __experimentalUseBorderProps as useBorderProps,
33
34
  } from '@wordpress/block-editor';
34
35
  import { useEffect, useMemo, useState, useRef } from '@wordpress/element';
35
36
  import { __, sprintf, isRTL } from '@wordpress/i18n';
@@ -57,7 +58,19 @@ import { MIN_SIZE, ALLOWED_MEDIA_TYPES } from './constants';
57
58
 
58
59
  export default function Image( {
59
60
  temporaryURL,
60
- attributes: {
61
+ attributes,
62
+ setAttributes,
63
+ isSelected,
64
+ insertBlocksAfter,
65
+ onReplace,
66
+ onSelectImage,
67
+ onSelectURL,
68
+ onUploadError,
69
+ containerRef,
70
+ context,
71
+ clientId,
72
+ } ) {
73
+ const {
61
74
  url = '',
62
75
  alt,
63
76
  caption,
@@ -72,18 +85,7 @@ export default function Image( {
72
85
  height,
73
86
  linkTarget,
74
87
  sizeSlug,
75
- },
76
- setAttributes,
77
- isSelected,
78
- insertBlocksAfter,
79
- onReplace,
80
- onSelectImage,
81
- onSelectURL,
82
- onUploadError,
83
- containerRef,
84
- context,
85
- clientId,
86
- } ) {
88
+ } = attributes;
87
89
  const imageRef = useRef();
88
90
  const captionRef = useRef();
89
91
  const prevUrl = usePrevious( url );
@@ -186,7 +188,7 @@ export default function Image( {
186
188
 
187
189
  // Get naturalWidth and naturalHeight from image ref, and fall back to loaded natural
188
190
  // width and height. This resolves an issue in Safari where the loaded natural
189
- // witdth and height is otherwise lost when switching between alignments.
191
+ // width and height is otherwise lost when switching between alignments.
190
192
  // See: https://github.com/WordPress/gutenberg/pull/37210.
191
193
  const { naturalWidth, naturalHeight } = useMemo( () => {
192
194
  return {
@@ -429,6 +431,11 @@ export default function Image( {
429
431
  defaultedAlt = __( 'This image has an empty alt attribute' );
430
432
  }
431
433
 
434
+ const borderProps = useBorderProps( attributes );
435
+ const isRounded = attributes.className?.includes( 'is-style-rounded' );
436
+ const hasCustomBorder =
437
+ !! borderProps.className || ! isEmpty( borderProps.style );
438
+
432
439
  let img = (
433
440
  // Disable reason: Image itself is not meant to be interactive, but
434
441
  // should direct focus to block.
@@ -445,6 +452,8 @@ export default function Image( {
445
452
  } );
446
453
  } }
447
454
  ref={ imageRef }
455
+ className={ borderProps.className }
456
+ style={ borderProps.style }
448
457
  />
449
458
  { temporaryURL && <Spinner /> }
450
459
  </>
@@ -466,6 +475,7 @@ export default function Image( {
466
475
  if ( canEditImage && isEditingImage ) {
467
476
  img = (
468
477
  <ImageEditor
478
+ borderProps={ isRounded ? undefined : borderProps }
469
479
  url={ url }
470
480
  width={ width }
471
481
  height={ height }
@@ -530,7 +540,7 @@ export default function Image( {
530
540
  <ResizableBox
531
541
  size={ {
532
542
  width: width ?? 'auto',
533
- height: height ?? 'auto',
543
+ height: height && ! hasCustomBorder ? height : 'auto',
534
544
  } }
535
545
  showHandle={ isSelected }
536
546
  minWidth={ minWidth }
@@ -20,7 +20,7 @@ function render_block_core_image( $attributes, $content ) {
20
20
  // which now wraps Image Blocks within innerBlocks.
21
21
  // The data-id attribute is added in a core/gallery `render_block_data` hook.
22
22
  $data_id_attribute = 'data-id="' . esc_attr( $attributes['data-id'] ) . '"';
23
- if ( false === strpos( $content, $data_id_attribute ) ) {
23
+ if ( ! str_contains( $content, $data_id_attribute ) ) {
24
24
  $content = str_replace( '<img', '<img ' . $data_id_attribute . ' ', $content );
25
25
  }
26
26
  }
package/src/image/save.js CHANGED
@@ -11,6 +11,7 @@ import {
11
11
  RichText,
12
12
  useBlockProps,
13
13
  __experimentalGetElementClassName,
14
+ __experimentalGetBorderClassesAndStyles as getBorderClassesAndStyles,
14
15
  } from '@wordpress/block-editor';
15
16
 
16
17
  export default function save( { attributes } ) {
@@ -31,18 +32,26 @@ export default function save( { attributes } ) {
31
32
  } = attributes;
32
33
 
33
34
  const newRel = isEmpty( rel ) ? undefined : rel;
35
+ const borderProps = getBorderClassesAndStyles( attributes );
34
36
 
35
37
  const classes = classnames( {
36
38
  [ `align${ align }` ]: align,
37
39
  [ `size-${ sizeSlug }` ]: sizeSlug,
38
40
  'is-resized': width || height,
41
+ 'has-custom-border':
42
+ !! borderProps.className || ! isEmpty( borderProps.style ),
43
+ } );
44
+
45
+ const imageClasses = classnames( borderProps.className, {
46
+ [ `wp-image-${ id }` ]: !! id,
39
47
  } );
40
48
 
41
49
  const image = (
42
50
  <img
43
51
  src={ url }
44
52
  alt={ alt }
45
- className={ id ? `wp-image-${ id }` : null }
53
+ className={ imageClasses || undefined }
54
+ style={ borderProps.style }
46
55
  width={ width }
47
56
  height={ height }
48
57
  title={ title }
@@ -3,12 +3,12 @@
3
3
  height: auto;
4
4
  max-width: 100%;
5
5
  vertical-align: bottom;
6
+ box-sizing: border-box;
6
7
  }
7
8
 
8
- &:not(.is-style-rounded) {
9
- > a,
9
+ &.has-custom-border {
10
10
  img {
11
- border-radius: inherit;
11
+ box-sizing: border-box;
12
12
  }
13
13
  }
14
14
 
@@ -97,6 +97,42 @@
97
97
  border-radius: 0;
98
98
  }
99
99
  }
100
+
101
+ // The following is required to overcome WP Core applying styles that clear
102
+ // img borders with a higher specificity than those added by the border
103
+ // block support to provide a default border-style of solid when a border
104
+ // color or width has been set.
105
+ :where(.has-border-color) {
106
+ border-style: solid;
107
+ }
108
+ :where([style*="border-top-color"]) {
109
+ border-top-style: solid;
110
+ }
111
+ :where([style*="border-right-color"]) {
112
+ border-right-style: solid;
113
+ }
114
+ :where([style*="border-bottom-color"]) {
115
+ border-bottom-style: solid;
116
+ }
117
+ :where([style*="border-left-color"]) {
118
+ border-left-style: solid;
119
+ }
120
+
121
+ :where([style*="border-width"]) {
122
+ border-style: solid;
123
+ }
124
+ :where([style*="border-top-width"]) {
125
+ border-top-style: solid;
126
+ }
127
+ :where([style*="border-right-width"]) {
128
+ border-right-style: solid;
129
+ }
130
+ :where([style*="border-bottom-width"]) {
131
+ border-bottom-style: solid;
132
+ }
133
+ :where([style*="border-left-width"]) {
134
+ border-left-style: solid;
135
+ }
100
136
  }
101
137
 
102
138
  .wp-block-image figure {
@@ -7,6 +7,7 @@ import {
7
7
  initializeEditor,
8
8
  getEditorHtml,
9
9
  render,
10
+ waitFor,
10
11
  } from 'test/helpers';
11
12
  import { Image } from 'react-native';
12
13
  import Clipboard from '@react-native-clipboard/clipboard';
@@ -40,16 +41,6 @@ sendMediaUpload.mockImplementation( ( payload ) => {
40
41
  uploadCallBack( payload );
41
42
  } );
42
43
 
43
- /**
44
- * Immediately invoke delayed functions. A better alternative would be using
45
- * fake timers and test the delay itself. However, fake timers does not work
46
- * with our custom waitFor implementation.
47
- */
48
- jest.mock( 'lodash', () => {
49
- const actual = jest.requireActual( 'lodash' );
50
- return { ...actual, delay: ( cb ) => cb() };
51
- } );
52
-
53
44
  function mockGetMedia( media ) {
54
45
  jest.spyOn( select( coreStore ), 'getMedia' ).mockReturnValue( media );
55
46
  }
@@ -157,6 +148,9 @@ describe( 'Image Block', () => {
157
148
  'wordpress.org'
158
149
  );
159
150
  fireEvent.press( screen.getByA11yLabel( 'Apply' ) );
151
+ await waitFor(
152
+ () => new Promise( ( resolve ) => setTimeout( resolve, 100 ) )
153
+ );
160
154
 
161
155
  const expectedHtml = `<!-- wp:image {"id":1,"sizeSlug":"large","linkDestination":"custom","className":"is-style-default"} -->
162
156
  <figure class="wp-block-image size-large is-style-default"><a href="http://wordpress.org"><img src="https://cldup.com/cXyG__fTLN.jpg" alt="" class="wp-image-1"/></a><figcaption class="wp-element-caption">Mountain</figcaption></figure>
@@ -183,6 +177,7 @@ describe( 'Image Block', () => {
183
177
  );
184
178
  fireEvent.press( screen.getByText( 'None' ) );
185
179
  fireEvent.press( screen.getByText( 'Media File' ) );
180
+ await waitFor( () => screen.getByText( 'Custom URL' ) );
186
181
  fireEvent.press( screen.getByText( 'Custom URL' ) );
187
182
  // Await asynchronous fetch of clipboard
188
183
  await act( () => clipboardPromise );
@@ -191,6 +186,7 @@ describe( 'Image Block', () => {
191
186
  'wordpress.org'
192
187
  );
193
188
  fireEvent.press( screen.getByA11yLabel( 'Apply' ) );
189
+ await waitFor( () => screen.getByText( 'Custom URL' ) );
194
190
  fireEvent.press( screen.getByText( 'Custom URL' ) );
195
191
  // Await asynchronous fetch of clipboard
196
192
  await act( () => clipboardPromise );
package/src/index.js CHANGED
@@ -73,7 +73,6 @@ import * as postAuthor from './post-author';
73
73
  import * as postAuthorName from './post-author-name';
74
74
  import * as postAuthorBiography from './post-author-biography';
75
75
  import * as postComment from './post-comment';
76
- import * as postComments from './post-comments';
77
76
  import * as postCommentsCount from './post-comments-count';
78
77
  import * as postCommentsForm from './post-comments-form';
79
78
  import * as postCommentsLink from './post-comments-link';
@@ -228,7 +227,6 @@ const getAllBlocks = () => [
228
227
  commentsPaginationNext,
229
228
  commentsPaginationNumbers,
230
229
  commentsPaginationPrevious,
231
- postComments,
232
230
  postCommentsForm,
233
231
  tableOfContents,
234
232
  homeLink,