@wordpress/block-library 7.6.0 → 7.9.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (774) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/build/audio/edit.js +1 -0
  3. package/build/audio/edit.js.map +1 -1
  4. package/build/audio/index.js +6 -1
  5. package/build/audio/index.js.map +1 -1
  6. package/build/audio/save.js +2 -1
  7. package/build/audio/save.js.map +1 -1
  8. package/build/avatar/hooks.js +2 -2
  9. package/build/avatar/hooks.js.map +1 -1
  10. package/build/block/edit.js.map +1 -1
  11. package/build/block/edit.native.js.map +1 -1
  12. package/build/button/deprecated.js +175 -35
  13. package/build/button/deprecated.js.map +1 -1
  14. package/build/button/edit.js +1 -1
  15. package/build/button/edit.js.map +1 -1
  16. package/build/button/edit.native.js.map +1 -1
  17. package/build/button/save.js +1 -1
  18. package/build/button/save.js.map +1 -1
  19. package/build/buttons/deprecated.js.map +1 -1
  20. package/build/buttons/edit.js.map +1 -1
  21. package/build/buttons/edit.native.js.map +1 -1
  22. package/build/column/deprecated.js.map +1 -1
  23. package/build/column/edit.js.map +1 -1
  24. package/build/column/edit.native.js.map +1 -1
  25. package/build/columns/deprecated.js.map +1 -1
  26. package/build/columns/edit.js +1 -1
  27. package/build/columns/edit.js.map +1 -1
  28. package/build/columns/edit.native.js +1 -1
  29. package/build/columns/edit.native.js.map +1 -1
  30. package/build/columns/index.js +3 -1
  31. package/build/columns/index.js.map +1 -1
  32. package/build/columns/utils.js +1 -1
  33. package/build/columns/utils.js.map +1 -1
  34. package/build/columns/variations.js +2 -2
  35. package/build/columns/variations.js.map +1 -1
  36. package/build/comment-author-name/edit.js +3 -3
  37. package/build/comment-author-name/edit.js.map +1 -1
  38. package/build/comment-author-name/index.js +0 -4
  39. package/build/comment-author-name/index.js.map +1 -1
  40. package/build/comment-date/edit.js +4 -4
  41. package/build/comment-date/edit.js.map +1 -1
  42. package/build/comment-date/index.js +0 -4
  43. package/build/comment-date/index.js.map +1 -1
  44. package/build/comment-edit-link/index.js +0 -4
  45. package/build/comment-edit-link/index.js.map +1 -1
  46. package/build/comment-reply-link/index.js +0 -4
  47. package/build/comment-reply-link/index.js.map +1 -1
  48. package/build/comments/edit.js +10 -2
  49. package/build/comments/edit.js.map +1 -1
  50. package/build/comments-title/deprecated.js +0 -3
  51. package/build/comments-title/deprecated.js.map +1 -1
  52. package/build/comments-title/edit.js +1 -1
  53. package/build/comments-title/edit.js.map +1 -1
  54. package/build/cover/controls.native.js.map +1 -1
  55. package/build/cover/deprecated.js +212 -207
  56. package/build/cover/deprecated.js.map +1 -1
  57. package/build/cover/edit/block-controls.js +3 -10
  58. package/build/cover/edit/block-controls.js.map +1 -1
  59. package/build/cover/edit/index.js +34 -31
  60. package/build/cover/edit/index.js.map +1 -1
  61. package/build/cover/edit/inspector-controls.js +34 -6
  62. package/build/cover/edit/inspector-controls.js.map +1 -1
  63. package/build/cover/edit.native.js.map +1 -1
  64. package/build/cover/index.js +1 -0
  65. package/build/cover/index.js.map +1 -1
  66. package/build/cover/save.js +18 -5
  67. package/build/cover/save.js.map +1 -1
  68. package/build/cover/shared.js +14 -17
  69. package/build/cover/shared.js.map +1 -1
  70. package/build/cover/transforms.js.map +1 -1
  71. package/build/embed/deprecated.js +6 -1
  72. package/build/embed/deprecated.js.map +1 -1
  73. package/build/embed/edit.js.map +1 -1
  74. package/build/embed/edit.native.js.map +1 -1
  75. package/build/embed/embed-controls.native.js.map +1 -1
  76. package/build/embed/embed-preview.js +1 -0
  77. package/build/embed/embed-preview.js.map +1 -1
  78. package/build/embed/icons.js +21 -1
  79. package/build/embed/icons.js.map +1 -1
  80. package/build/embed/index.js +6 -1
  81. package/build/embed/index.js.map +1 -1
  82. package/build/embed/save.js +1 -0
  83. package/build/embed/save.js.map +1 -1
  84. package/build/embed/transforms.js +6 -1
  85. package/build/embed/transforms.js.map +1 -1
  86. package/build/embed/util.js +6 -1
  87. package/build/embed/util.js.map +1 -1
  88. package/build/embed/variations.js +11 -0
  89. package/build/embed/variations.js.map +1 -1
  90. package/build/file/edit.js +1 -1
  91. package/build/file/edit.js.map +1 -1
  92. package/build/file/edit.native.js.map +1 -1
  93. package/build/file/index.js.map +1 -1
  94. package/build/file/save.js +9 -1
  95. package/build/file/save.js.map +1 -1
  96. package/build/gallery/edit.js +1 -1
  97. package/build/gallery/edit.js.map +1 -1
  98. package/build/gallery/gallery.js +1 -1
  99. package/build/gallery/gallery.js.map +1 -1
  100. package/build/gallery/gallery.native.js.map +1 -1
  101. package/build/gallery/gap-styles.js +14 -4
  102. package/build/gallery/gap-styles.js.map +1 -1
  103. package/build/gallery/index.js +1 -1
  104. package/build/gallery/index.js.map +1 -1
  105. package/build/gallery/save.js +1 -1
  106. package/build/gallery/save.js.map +1 -1
  107. package/build/gallery/shared.js +27 -10
  108. package/build/gallery/shared.js.map +1 -1
  109. package/build/gallery/transforms.js +2 -2
  110. package/build/gallery/transforms.js.map +1 -1
  111. package/build/gallery/v1/edit.js +3 -3
  112. package/build/gallery/v1/edit.js.map +1 -1
  113. package/build/gallery/v1/gallery-image.js +1 -0
  114. package/build/gallery/v1/gallery-image.js.map +1 -1
  115. package/build/gallery/v1/gallery-image.native.js.map +1 -1
  116. package/build/gallery/v1/gallery.js +1 -1
  117. package/build/gallery/v1/gallery.js.map +1 -1
  118. package/build/gallery/v1/save.js +10 -2
  119. package/build/gallery/v1/save.js.map +1 -1
  120. package/build/group/index.js +1 -0
  121. package/build/group/index.js.map +1 -1
  122. package/build/heading/autogenerate-anchors.js +7 -2
  123. package/build/heading/autogenerate-anchors.js.map +1 -1
  124. package/build/heading/deprecated.js.map +1 -1
  125. package/build/heading/edit.js.map +1 -1
  126. package/build/html/edit.js +11 -20
  127. package/build/html/edit.js.map +1 -1
  128. package/build/html/preview.js +48 -0
  129. package/build/html/preview.js.map +1 -0
  130. package/build/image/deprecated.js.map +1 -1
  131. package/build/image/edit.js +5 -59
  132. package/build/image/edit.js.map +1 -1
  133. package/build/image/edit.native.js +58 -4
  134. package/build/image/edit.native.js.map +1 -1
  135. package/build/image/image.js +4 -13
  136. package/build/image/image.js.map +1 -1
  137. package/build/image/index.js +5 -0
  138. package/build/image/index.js.map +1 -1
  139. package/build/image/save.js +1 -0
  140. package/build/image/save.js.map +1 -1
  141. package/build/image/transforms.js.map +1 -1
  142. package/build/image/utils.js +2 -1
  143. package/build/image/utils.js.map +1 -1
  144. package/build/index.js +1 -1
  145. package/build/index.js.map +1 -1
  146. package/build/latest-comments/edit.js.map +1 -1
  147. package/build/latest-posts/edit.js +1 -1
  148. package/build/latest-posts/edit.js.map +1 -1
  149. package/build/latest-posts/edit.native.js.map +1 -1
  150. package/build/list/index.js.map +1 -1
  151. package/build/list/v2/edit.js.map +1 -1
  152. package/build/list/v2/transforms.js +33 -17
  153. package/build/list/v2/transforms.js.map +1 -1
  154. package/build/list-item/hooks/use-backspace.js.map +1 -1
  155. package/build/list-item/hooks/use-enter.js +7 -4
  156. package/build/list-item/hooks/use-enter.js.map +1 -1
  157. package/build/list-item/hooks/use-indent-list-item.js.map +1 -1
  158. package/build/list-item/hooks/use-outdent-list-item.js +36 -15
  159. package/build/list-item/hooks/use-outdent-list-item.js.map +1 -1
  160. package/build/list-item/hooks/use-space.js.map +1 -1
  161. package/build/list-item/hooks/use-split.js +17 -3
  162. package/build/list-item/hooks/use-split.js.map +1 -1
  163. package/build/media-text/deprecated.js +5 -3
  164. package/build/media-text/deprecated.js.map +1 -1
  165. package/build/media-text/edit.native.js.map +1 -1
  166. package/build/media-text/media-container.js +3 -3
  167. package/build/media-text/media-container.js.map +1 -1
  168. package/build/media-text/media-container.native.js.map +1 -1
  169. package/build/media-text/save.js +3 -1
  170. package/build/media-text/save.js.map +1 -1
  171. package/build/missing/edit.native.js.map +1 -1
  172. package/build/navigation/deprecated.js.map +1 -1
  173. package/build/navigation/edit/index.js +1 -1
  174. package/build/navigation/edit/index.js.map +1 -1
  175. package/build/navigation/edit/navigation-menu-delete-control.js.map +1 -1
  176. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  177. package/build/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  178. package/build/navigation/index.js +9 -0
  179. package/build/navigation/index.js.map +1 -1
  180. package/build/navigation/use-navigation-entities.js.map +1 -1
  181. package/build/navigation/use-navigation-menu.js +72 -38
  182. package/build/navigation/use-navigation-menu.js.map +1 -1
  183. package/build/navigation/use-template-part-area-label.js +4 -1
  184. package/build/navigation/use-template-part-area-label.js.map +1 -1
  185. package/build/navigation/view.js +5 -3
  186. package/build/navigation/view.js.map +1 -1
  187. package/build/navigation-link/edit.js +44 -12
  188. package/build/navigation-link/edit.js.map +1 -1
  189. package/build/navigation-submenu/edit.js.map +1 -1
  190. package/build/navigation-submenu/view.js +5 -3
  191. package/build/navigation-submenu/view.js.map +1 -1
  192. package/build/page-list/convert-to-links-modal.js.map +1 -1
  193. package/build/page-list/edit.js.map +1 -1
  194. package/build/paragraph/deprecated.js +1 -1
  195. package/build/paragraph/deprecated.js.map +1 -1
  196. package/build/pattern/edit.js.map +1 -1
  197. package/build/post-author/edit.js.map +1 -1
  198. package/build/post-author-name/index.js +3 -0
  199. package/build/post-author-name/index.js.map +1 -1
  200. package/build/post-author-name/transforms.js +41 -0
  201. package/build/post-author-name/transforms.js.map +1 -0
  202. package/build/post-comments-form/edit.js +12 -2
  203. package/build/post-comments-form/edit.js.map +1 -1
  204. package/build/post-comments-form/form.js +11 -1
  205. package/build/post-comments-form/form.js.map +1 -1
  206. package/build/post-content/edit.js.map +1 -1
  207. package/build/post-date/edit.js +13 -7
  208. package/build/post-date/edit.js.map +1 -1
  209. package/build/post-featured-image/edit.js +10 -24
  210. package/build/post-featured-image/edit.js.map +1 -1
  211. package/build/post-navigation-link/index.js +4 -0
  212. package/build/post-navigation-link/index.js.map +1 -1
  213. package/build/pullquote/deprecated.js.map +1 -1
  214. package/build/query/edit/index.js +5 -1
  215. package/build/query/edit/index.js.map +1 -1
  216. package/build/query/edit/inspector-controls/parent-control.js.map +1 -1
  217. package/build/query/edit/query-toolbar.js +16 -2
  218. package/build/query/edit/query-toolbar.js.map +1 -1
  219. package/build/quote/v2/edit.js.map +1 -1
  220. package/build/search/edit.js +1 -1
  221. package/build/search/edit.js.map +1 -1
  222. package/build/search/edit.native.js.map +1 -1
  223. package/build/search/index.js +4 -0
  224. package/build/search/index.js.map +1 -1
  225. package/build/separator/use-deprecated-opacity.js.map +1 -1
  226. package/build/shortcode/edit.native.js +16 -13
  227. package/build/shortcode/edit.native.js.map +1 -1
  228. package/build/site-logo/edit.js +3 -12
  229. package/build/site-logo/edit.js.map +1 -1
  230. package/build/social-links/deprecated.js.map +1 -1
  231. package/build/social-links/edit.js +2 -2
  232. package/build/social-links/edit.js.map +1 -1
  233. package/build/social-links/edit.native.js.map +1 -1
  234. package/build/spacer/controls.js.map +1 -1
  235. package/build/table/deprecated.js.map +1 -1
  236. package/build/table/edit.js +1 -0
  237. package/build/table/edit.js.map +1 -1
  238. package/build/table/index.js +6 -1
  239. package/build/table/index.js.map +1 -1
  240. package/build/table/save.js +2 -1
  241. package/build/table/save.js.map +1 -1
  242. package/build/table/state.js.map +1 -1
  243. package/build/table-of-contents/edit.js +11 -3
  244. package/build/table-of-contents/edit.js.map +1 -1
  245. package/build/tag-cloud/edit.js.map +1 -1
  246. package/build/template-part/edit/advanced-controls.js +4 -1
  247. package/build/template-part/edit/advanced-controls.js.map +1 -1
  248. package/build/template-part/edit/index.js.map +1 -1
  249. package/build/template-part/edit/utils/hooks.js +4 -1
  250. package/build/template-part/edit/utils/hooks.js.map +1 -1
  251. package/build/transformationCategories.native.js.map +1 -1
  252. package/build/video/edit-common-settings.js.map +1 -1
  253. package/build/video/edit.js +1 -0
  254. package/build/video/edit.js.map +1 -1
  255. package/build/video/edit.native.js +43 -0
  256. package/build/video/edit.native.js.map +1 -1
  257. package/build/video/index.js +6 -1
  258. package/build/video/index.js.map +1 -1
  259. package/build/video/save.js +1 -0
  260. package/build/video/save.js.map +1 -1
  261. package/build-module/audio/edit.js +2 -1
  262. package/build-module/audio/edit.js.map +1 -1
  263. package/build-module/audio/index.js +6 -1
  264. package/build-module/audio/index.js.map +1 -1
  265. package/build-module/audio/save.js +3 -2
  266. package/build-module/audio/save.js.map +1 -1
  267. package/build-module/avatar/hooks.js +2 -2
  268. package/build-module/avatar/hooks.js.map +1 -1
  269. package/build-module/block/edit.js.map +1 -1
  270. package/build-module/block/edit.native.js.map +1 -1
  271. package/build-module/button/deprecated.js +175 -35
  272. package/build-module/button/deprecated.js.map +1 -1
  273. package/build-module/button/edit.js +2 -2
  274. package/build-module/button/edit.js.map +1 -1
  275. package/build-module/button/edit.native.js.map +1 -1
  276. package/build-module/button/save.js +2 -2
  277. package/build-module/button/save.js.map +1 -1
  278. package/build-module/buttons/deprecated.js.map +1 -1
  279. package/build-module/buttons/edit.js.map +1 -1
  280. package/build-module/buttons/edit.native.js.map +1 -1
  281. package/build-module/column/deprecated.js.map +1 -1
  282. package/build-module/column/edit.js.map +1 -1
  283. package/build-module/column/edit.native.js.map +1 -1
  284. package/build-module/columns/deprecated.js.map +1 -1
  285. package/build-module/columns/edit.js +2 -2
  286. package/build-module/columns/edit.js.map +1 -1
  287. package/build-module/columns/edit.native.js +2 -2
  288. package/build-module/columns/edit.native.js.map +1 -1
  289. package/build-module/columns/index.js +3 -1
  290. package/build-module/columns/index.js.map +1 -1
  291. package/build-module/columns/utils.js +2 -2
  292. package/build-module/columns/utils.js.map +1 -1
  293. package/build-module/columns/variations.js +2 -2
  294. package/build-module/columns/variations.js.map +1 -1
  295. package/build-module/comment-author-name/edit.js +3 -3
  296. package/build-module/comment-author-name/edit.js.map +1 -1
  297. package/build-module/comment-author-name/index.js +0 -4
  298. package/build-module/comment-author-name/index.js.map +1 -1
  299. package/build-module/comment-date/edit.js +4 -4
  300. package/build-module/comment-date/edit.js.map +1 -1
  301. package/build-module/comment-date/index.js +0 -4
  302. package/build-module/comment-date/index.js.map +1 -1
  303. package/build-module/comment-edit-link/index.js +0 -4
  304. package/build-module/comment-edit-link/index.js.map +1 -1
  305. package/build-module/comment-reply-link/index.js +0 -4
  306. package/build-module/comment-reply-link/index.js.map +1 -1
  307. package/build-module/comments/edit.js +10 -2
  308. package/build-module/comments/edit.js.map +1 -1
  309. package/build-module/comments-title/deprecated.js +0 -3
  310. package/build-module/comments-title/deprecated.js.map +1 -1
  311. package/build-module/comments-title/edit.js +1 -1
  312. package/build-module/comments-title/edit.js.map +1 -1
  313. package/build-module/cover/controls.native.js.map +1 -1
  314. package/build-module/cover/deprecated.js +206 -198
  315. package/build-module/cover/deprecated.js.map +1 -1
  316. package/build-module/cover/edit/block-controls.js +3 -8
  317. package/build-module/cover/edit/block-controls.js.map +1 -1
  318. package/build-module/cover/edit/index.js +36 -33
  319. package/build-module/cover/edit/index.js.map +1 -1
  320. package/build-module/cover/edit/inspector-controls.js +32 -7
  321. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  322. package/build-module/cover/edit.native.js.map +1 -1
  323. package/build-module/cover/index.js +1 -0
  324. package/build-module/cover/index.js.map +1 -1
  325. package/build-module/cover/save.js +19 -6
  326. package/build-module/cover/save.js.map +1 -1
  327. package/build-module/cover/shared.js +11 -12
  328. package/build-module/cover/shared.js.map +1 -1
  329. package/build-module/cover/transforms.js.map +1 -1
  330. package/build-module/embed/deprecated.js +6 -1
  331. package/build-module/embed/deprecated.js.map +1 -1
  332. package/build-module/embed/edit.js.map +1 -1
  333. package/build-module/embed/edit.native.js.map +1 -1
  334. package/build-module/embed/embed-controls.native.js.map +1 -1
  335. package/build-module/embed/embed-preview.js +2 -1
  336. package/build-module/embed/embed-preview.js.map +1 -1
  337. package/build-module/embed/icons.js +19 -0
  338. package/build-module/embed/icons.js.map +1 -1
  339. package/build-module/embed/index.js +6 -1
  340. package/build-module/embed/index.js.map +1 -1
  341. package/build-module/embed/save.js +2 -1
  342. package/build-module/embed/save.js.map +1 -1
  343. package/build-module/embed/transforms.js +6 -1
  344. package/build-module/embed/transforms.js.map +1 -1
  345. package/build-module/embed/util.js +6 -1
  346. package/build-module/embed/util.js.map +1 -1
  347. package/build-module/embed/variations.js +12 -1
  348. package/build-module/embed/variations.js.map +1 -1
  349. package/build-module/file/edit.js +2 -2
  350. package/build-module/file/edit.js.map +1 -1
  351. package/build-module/file/edit.native.js.map +1 -1
  352. package/build-module/file/index.js.map +1 -1
  353. package/build-module/file/save.js +7 -2
  354. package/build-module/file/save.js.map +1 -1
  355. package/build-module/gallery/edit.js +2 -2
  356. package/build-module/gallery/edit.js.map +1 -1
  357. package/build-module/gallery/gallery.js +2 -2
  358. package/build-module/gallery/gallery.js.map +1 -1
  359. package/build-module/gallery/gallery.native.js.map +1 -1
  360. package/build-module/gallery/gap-styles.js +14 -4
  361. package/build-module/gallery/gap-styles.js.map +1 -1
  362. package/build-module/gallery/index.js +1 -1
  363. package/build-module/gallery/index.js.map +1 -1
  364. package/build-module/gallery/save.js +2 -2
  365. package/build-module/gallery/save.js.map +1 -1
  366. package/build-module/gallery/shared.js +25 -8
  367. package/build-module/gallery/shared.js.map +1 -1
  368. package/build-module/gallery/transforms.js +3 -3
  369. package/build-module/gallery/transforms.js.map +1 -1
  370. package/build-module/gallery/v1/edit.js +4 -4
  371. package/build-module/gallery/v1/edit.js.map +1 -1
  372. package/build-module/gallery/v1/gallery-image.js +2 -1
  373. package/build-module/gallery/v1/gallery-image.js.map +1 -1
  374. package/build-module/gallery/v1/gallery-image.native.js.map +1 -1
  375. package/build-module/gallery/v1/gallery.js +2 -2
  376. package/build-module/gallery/v1/gallery.js.map +1 -1
  377. package/build-module/gallery/v1/save.js +8 -3
  378. package/build-module/gallery/v1/save.js.map +1 -1
  379. package/build-module/group/index.js +1 -0
  380. package/build-module/group/index.js.map +1 -1
  381. package/build-module/heading/autogenerate-anchors.js +5 -2
  382. package/build-module/heading/autogenerate-anchors.js.map +1 -1
  383. package/build-module/heading/deprecated.js.map +1 -1
  384. package/build-module/heading/edit.js.map +1 -1
  385. package/build-module/html/edit.js +12 -23
  386. package/build-module/html/edit.js.map +1 -1
  387. package/build-module/html/preview.js +38 -0
  388. package/build-module/html/preview.js.map +1 -0
  389. package/build-module/image/deprecated.js.map +1 -1
  390. package/build-module/image/edit.js +5 -56
  391. package/build-module/image/edit.js.map +1 -1
  392. package/build-module/image/edit.native.js +59 -6
  393. package/build-module/image/edit.native.js.map +1 -1
  394. package/build-module/image/image.js +6 -15
  395. package/build-module/image/image.js.map +1 -1
  396. package/build-module/image/index.js +5 -0
  397. package/build-module/image/index.js.map +1 -1
  398. package/build-module/image/save.js +2 -1
  399. package/build-module/image/save.js.map +1 -1
  400. package/build-module/image/transforms.js.map +1 -1
  401. package/build-module/image/utils.js +2 -2
  402. package/build-module/image/utils.js.map +1 -1
  403. package/build-module/index.js +1 -1
  404. package/build-module/index.js.map +1 -1
  405. package/build-module/latest-comments/edit.js.map +1 -1
  406. package/build-module/latest-posts/edit.js +2 -2
  407. package/build-module/latest-posts/edit.js.map +1 -1
  408. package/build-module/latest-posts/edit.native.js.map +1 -1
  409. package/build-module/list/index.js.map +1 -1
  410. package/build-module/list/v2/edit.js.map +1 -1
  411. package/build-module/list/v2/transforms.js +32 -17
  412. package/build-module/list/v2/transforms.js.map +1 -1
  413. package/build-module/list-item/hooks/use-backspace.js.map +1 -1
  414. package/build-module/list-item/hooks/use-enter.js +7 -4
  415. package/build-module/list-item/hooks/use-enter.js.map +1 -1
  416. package/build-module/list-item/hooks/use-indent-list-item.js.map +1 -1
  417. package/build-module/list-item/hooks/use-outdent-list-item.js +34 -15
  418. package/build-module/list-item/hooks/use-outdent-list-item.js.map +1 -1
  419. package/build-module/list-item/hooks/use-space.js.map +1 -1
  420. package/build-module/list-item/hooks/use-split.js +19 -5
  421. package/build-module/list-item/hooks/use-split.js.map +1 -1
  422. package/build-module/media-text/deprecated.js +3 -1
  423. package/build-module/media-text/deprecated.js.map +1 -1
  424. package/build-module/media-text/edit.native.js.map +1 -1
  425. package/build-module/media-text/media-container.js +3 -1
  426. package/build-module/media-text/media-container.js.map +1 -1
  427. package/build-module/media-text/media-container.native.js.map +1 -1
  428. package/build-module/media-text/save.js +4 -1
  429. package/build-module/media-text/save.js.map +1 -1
  430. package/build-module/missing/edit.native.js.map +1 -1
  431. package/build-module/navigation/deprecated.js.map +1 -1
  432. package/build-module/navigation/edit/index.js +1 -1
  433. package/build-module/navigation/edit/index.js.map +1 -1
  434. package/build-module/navigation/edit/navigation-menu-delete-control.js.map +1 -1
  435. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  436. package/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  437. package/build-module/navigation/index.js +9 -0
  438. package/build-module/navigation/index.js.map +1 -1
  439. package/build-module/navigation/use-navigation-entities.js.map +1 -1
  440. package/build-module/navigation/use-navigation-menu.js +73 -39
  441. package/build-module/navigation/use-navigation-menu.js.map +1 -1
  442. package/build-module/navigation/use-template-part-area-label.js +4 -1
  443. package/build-module/navigation/use-template-part-area-label.js.map +1 -1
  444. package/build-module/navigation/view.js +5 -3
  445. package/build-module/navigation/view.js.map +1 -1
  446. package/build-module/navigation-link/edit.js +44 -13
  447. package/build-module/navigation-link/edit.js.map +1 -1
  448. package/build-module/navigation-submenu/edit.js.map +1 -1
  449. package/build-module/navigation-submenu/view.js +5 -3
  450. package/build-module/navigation-submenu/view.js.map +1 -1
  451. package/build-module/page-list/convert-to-links-modal.js.map +1 -1
  452. package/build-module/page-list/edit.js.map +1 -1
  453. package/build-module/paragraph/deprecated.js +2 -2
  454. package/build-module/paragraph/deprecated.js.map +1 -1
  455. package/build-module/pattern/edit.js.map +1 -1
  456. package/build-module/post-author/edit.js.map +1 -1
  457. package/build-module/post-author-name/index.js +2 -0
  458. package/build-module/post-author-name/index.js.map +1 -1
  459. package/build-module/post-author-name/transforms.js +32 -0
  460. package/build-module/post-author-name/transforms.js.map +1 -0
  461. package/build-module/post-comments-form/edit.js +12 -3
  462. package/build-module/post-comments-form/edit.js.map +1 -1
  463. package/build-module/post-comments-form/form.js +7 -1
  464. package/build-module/post-comments-form/form.js.map +1 -1
  465. package/build-module/post-content/edit.js.map +1 -1
  466. package/build-module/post-date/edit.js +15 -9
  467. package/build-module/post-date/edit.js.map +1 -1
  468. package/build-module/post-featured-image/edit.js +10 -23
  469. package/build-module/post-featured-image/edit.js.map +1 -1
  470. package/build-module/post-navigation-link/index.js +4 -0
  471. package/build-module/post-navigation-link/index.js.map +1 -1
  472. package/build-module/pullquote/deprecated.js.map +1 -1
  473. package/build-module/query/edit/index.js +5 -1
  474. package/build-module/query/edit/index.js.map +1 -1
  475. package/build-module/query/edit/inspector-controls/parent-control.js.map +1 -1
  476. package/build-module/query/edit/query-toolbar.js +14 -2
  477. package/build-module/query/edit/query-toolbar.js.map +1 -1
  478. package/build-module/quote/v2/edit.js.map +1 -1
  479. package/build-module/search/edit.js +2 -2
  480. package/build-module/search/edit.js.map +1 -1
  481. package/build-module/search/edit.native.js.map +1 -1
  482. package/build-module/search/index.js +4 -0
  483. package/build-module/search/index.js.map +1 -1
  484. package/build-module/separator/use-deprecated-opacity.js.map +1 -1
  485. package/build-module/shortcode/edit.native.js +17 -13
  486. package/build-module/shortcode/edit.native.js.map +1 -1
  487. package/build-module/site-logo/edit.js +3 -11
  488. package/build-module/site-logo/edit.js.map +1 -1
  489. package/build-module/social-links/deprecated.js.map +1 -1
  490. package/build-module/social-links/edit.js +2 -2
  491. package/build-module/social-links/edit.js.map +1 -1
  492. package/build-module/social-links/edit.native.js.map +1 -1
  493. package/build-module/spacer/controls.js.map +1 -1
  494. package/build-module/table/deprecated.js.map +1 -1
  495. package/build-module/table/edit.js +2 -1
  496. package/build-module/table/edit.js.map +1 -1
  497. package/build-module/table/index.js +6 -1
  498. package/build-module/table/index.js.map +1 -1
  499. package/build-module/table/save.js +3 -2
  500. package/build-module/table/save.js.map +1 -1
  501. package/build-module/table/state.js.map +1 -1
  502. package/build-module/table-of-contents/edit.js +12 -4
  503. package/build-module/table-of-contents/edit.js.map +1 -1
  504. package/build-module/tag-cloud/edit.js.map +1 -1
  505. package/build-module/template-part/edit/advanced-controls.js +4 -1
  506. package/build-module/template-part/edit/advanced-controls.js.map +1 -1
  507. package/build-module/template-part/edit/index.js.map +1 -1
  508. package/build-module/template-part/edit/utils/hooks.js +4 -1
  509. package/build-module/template-part/edit/utils/hooks.js.map +1 -1
  510. package/build-module/transformationCategories.native.js.map +1 -1
  511. package/build-module/video/edit-common-settings.js.map +1 -1
  512. package/build-module/video/edit.js +2 -1
  513. package/build-module/video/edit.js.map +1 -1
  514. package/build-module/video/edit.native.js +42 -1
  515. package/build-module/video/edit.native.js.map +1 -1
  516. package/build-module/video/index.js +6 -1
  517. package/build-module/video/index.js.map +1 -1
  518. package/build-module/video/save.js +2 -1
  519. package/build-module/video/save.js.map +1 -1
  520. package/build-style/audio/style-rtl.css +0 -3
  521. package/build-style/audio/style.css +0 -3
  522. package/build-style/button/style-rtl.css +5 -5
  523. package/build-style/button/style.css +5 -5
  524. package/build-style/common-rtl.css +1 -3
  525. package/build-style/common.css +1 -3
  526. package/build-style/cover/editor-rtl.css +11 -0
  527. package/build-style/cover/editor.css +11 -0
  528. package/build-style/cover/style-rtl.css +33 -25
  529. package/build-style/cover/style.css +33 -25
  530. package/build-style/editor-rtl.css +14 -39
  531. package/build-style/editor.css +14 -39
  532. package/build-style/embed/style-rtl.css +0 -1
  533. package/build-style/embed/style.css +0 -1
  534. package/build-style/file/style-rtl.css +11 -12
  535. package/build-style/file/style.css +11 -12
  536. package/build-style/gallery/style-rtl.css +2 -4
  537. package/build-style/gallery/style.css +2 -4
  538. package/build-style/image/style-rtl.css +0 -3
  539. package/build-style/image/style.css +0 -3
  540. package/build-style/navigation/style-rtl.css +9 -1
  541. package/build-style/navigation/style.css +9 -1
  542. package/build-style/post-comments/style-rtl.css +2 -1
  543. package/build-style/post-comments/style.css +2 -1
  544. package/build-style/post-comments-form/editor-rtl.css +3 -0
  545. package/build-style/post-comments-form/editor.css +3 -0
  546. package/build-style/post-featured-image/editor-rtl.css +0 -27
  547. package/build-style/post-featured-image/editor.css +0 -27
  548. package/build-style/post-template/style-rtl.css +9 -18
  549. package/build-style/post-template/style.css +9 -18
  550. package/build-style/search/style-rtl.css +9 -11
  551. package/build-style/search/style.css +9 -11
  552. package/build-style/site-logo/editor-rtl.css +0 -12
  553. package/build-style/site-logo/editor.css +0 -12
  554. package/build-style/site-logo/style-rtl.css +4 -0
  555. package/build-style/site-logo/style.css +4 -0
  556. package/build-style/style-rtl.css +86 -93
  557. package/build-style/style.css +86 -93
  558. package/build-style/table/style-rtl.css +0 -1
  559. package/build-style/table/style.css +0 -1
  560. package/build-style/video/style-rtl.css +1 -5
  561. package/build-style/video/style.css +1 -5
  562. package/package.json +30 -29
  563. package/src/audio/block.json +6 -1
  564. package/src/audio/edit.js +4 -0
  565. package/src/audio/index.js +1 -2
  566. package/src/audio/save.js +12 -2
  567. package/src/audio/style.scss +0 -2
  568. package/src/avatar/hooks.js +2 -2
  569. package/src/block/edit.js +4 -6
  570. package/src/block/edit.native.js +12 -16
  571. package/src/block/test/edit.native.js +5 -8
  572. package/src/button/deprecated.js +145 -36
  573. package/src/button/edit.js +7 -11
  574. package/src/button/edit.native.js +2 -3
  575. package/src/button/save.js +5 -11
  576. package/src/button/style.scss +10 -5
  577. package/src/buttons/deprecated.js +4 -6
  578. package/src/buttons/edit.js +3 -3
  579. package/src/buttons/edit.native.js +7 -11
  580. package/src/buttons/test/__snapshots__/edit.native.js.snap +1 -1
  581. package/src/buttons/test/edit.native.js +1 -1
  582. package/src/column/deprecated.js +2 -1
  583. package/src/column/edit.js +2 -3
  584. package/src/column/edit.native.js +2 -2
  585. package/src/columns/block.json +3 -1
  586. package/src/columns/deprecated.js +4 -2
  587. package/src/columns/edit.js +6 -7
  588. package/src/columns/edit.native.js +12 -16
  589. package/src/columns/index.js +1 -2
  590. package/src/columns/utils.js +5 -3
  591. package/src/columns/variations.js +2 -2
  592. package/src/comment-author-name/block.json +0 -4
  593. package/src/comment-author-name/edit.js +3 -12
  594. package/src/comment-date/block.json +0 -4
  595. package/src/comment-date/edit.js +10 -14
  596. package/src/comment-date/index.php +0 -3
  597. package/src/comment-edit-link/block.json +0 -4
  598. package/src/comment-reply-link/block.json +0 -4
  599. package/src/comments/edit.js +24 -4
  600. package/src/comments-title/deprecated.js +0 -2
  601. package/src/comments-title/edit.js +1 -1
  602. package/src/comments-title/index.php +1 -1
  603. package/src/cover/block.json +1 -0
  604. package/src/cover/controls.native.js +2 -4
  605. package/src/cover/deprecated.js +237 -195
  606. package/src/cover/edit/block-controls.js +11 -20
  607. package/src/cover/edit/index.js +81 -66
  608. package/src/cover/edit/inspector-controls.js +38 -7
  609. package/src/cover/edit.native.js +8 -13
  610. package/src/cover/editor.scss +13 -0
  611. package/src/cover/index.php +21 -8
  612. package/src/cover/save.js +28 -16
  613. package/src/cover/shared.js +5 -7
  614. package/src/cover/style.scss +27 -22
  615. package/src/cover/test/edit.native.js +4 -7
  616. package/src/cover/transforms.js +2 -7
  617. package/src/embed/block.json +6 -1
  618. package/src/embed/edit.js +38 -40
  619. package/src/embed/edit.native.js +46 -49
  620. package/src/embed/embed-controls.native.js +2 -3
  621. package/src/embed/embed-preview.js +8 -1
  622. package/src/embed/icons.js +25 -0
  623. package/src/embed/save.js +10 -2
  624. package/src/embed/style.scss +0 -1
  625. package/src/embed/test/__snapshots__/index.native.js.snap +1 -1
  626. package/src/embed/test/index.native.js +24 -50
  627. package/src/embed/variations.js +10 -0
  628. package/src/file/edit.js +9 -5
  629. package/src/file/edit.native.js +14 -25
  630. package/src/file/index.js +1 -2
  631. package/src/file/save.js +14 -2
  632. package/src/file/style.scss +16 -15
  633. package/src/freeform/editor.scss +0 -2
  634. package/src/gallery/block.json +1 -1
  635. package/src/gallery/edit.js +8 -6
  636. package/src/gallery/gallery.js +9 -2
  637. package/src/gallery/gallery.native.js +2 -4
  638. package/src/gallery/gap-styles.js +21 -6
  639. package/src/gallery/index.js +2 -4
  640. package/src/gallery/index.php +27 -12
  641. package/src/gallery/save.js +5 -1
  642. package/src/gallery/shared.js +22 -9
  643. package/src/gallery/test/__snapshots__/index.native.js.snap +2 -2
  644. package/src/gallery/test/helpers.native.js +11 -198
  645. package/src/gallery/test/index.native.js +37 -63
  646. package/src/gallery/transforms.js +3 -3
  647. package/src/gallery/v1/edit.js +18 -24
  648. package/src/gallery/v1/gallery-image.js +10 -11
  649. package/src/gallery/v1/gallery-image.native.js +8 -17
  650. package/src/gallery/v1/gallery.js +8 -2
  651. package/src/gallery/v1/save.js +20 -3
  652. package/src/group/block.json +1 -0
  653. package/src/heading/autogenerate-anchors.js +8 -5
  654. package/src/heading/deprecated.js +6 -21
  655. package/src/heading/edit.js +2 -3
  656. package/src/html/edit.js +10 -40
  657. package/src/html/preview.js +46 -0
  658. package/src/image/block.json +5 -0
  659. package/src/image/deprecated.js +6 -29
  660. package/src/image/edit.js +1 -53
  661. package/src/image/edit.native.js +75 -24
  662. package/src/image/image.js +35 -49
  663. package/src/image/save.js +10 -2
  664. package/src/image/style.scss +0 -2
  665. package/src/image/styles.native.scss +11 -0
  666. package/src/image/test/edit.native.js +51 -19
  667. package/src/image/transforms.js +4 -3
  668. package/src/image/utils.js +2 -2
  669. package/src/index.js +1 -1
  670. package/src/latest-comments/edit.js +2 -6
  671. package/src/latest-posts/edit.js +6 -7
  672. package/src/latest-posts/edit.native.js +10 -15
  673. package/src/list/index.js +1 -2
  674. package/src/list/test/migrate.js +1 -2
  675. package/src/list/v2/edit.js +6 -9
  676. package/src/list/v2/transforms.js +22 -7
  677. package/src/list-item/hooks/use-backspace.js +2 -3
  678. package/src/list-item/hooks/use-enter.js +11 -9
  679. package/src/list-item/hooks/use-indent-list-item.js +2 -3
  680. package/src/list-item/hooks/use-outdent-list-item.js +50 -24
  681. package/src/list-item/hooks/use-space.js +2 -3
  682. package/src/list-item/hooks/use-split.js +18 -9
  683. package/src/media-text/deprecated.js +6 -3
  684. package/src/media-text/edit.native.js +2 -5
  685. package/src/media-text/media-container.js +1 -1
  686. package/src/media-text/media-container.native.js +6 -9
  687. package/src/media-text/save.js +2 -1
  688. package/src/missing/edit.native.js +2 -3
  689. package/src/missing/test/edit-integration.native.js +2 -3
  690. package/src/missing/test/edit.native.js +6 -9
  691. package/src/navigation/block.json +9 -0
  692. package/src/navigation/deprecated.js +2 -5
  693. package/src/navigation/edit/index.js +25 -36
  694. package/src/navigation/edit/navigation-menu-delete-control.js +2 -3
  695. package/src/navigation/edit/unsaved-inner-blocks.js +31 -30
  696. package/src/navigation/edit/use-convert-classic-menu-to-block-menu.js +2 -3
  697. package/src/navigation/style.scss +10 -1
  698. package/src/navigation/test/use-navigation-menu.js +241 -0
  699. package/src/navigation/use-navigation-entities.js +11 -13
  700. package/src/navigation/use-navigation-menu.js +95 -82
  701. package/src/navigation/use-template-part-area-label.js +8 -7
  702. package/src/navigation/view.js +7 -2
  703. package/src/navigation-link/edit.js +59 -25
  704. package/src/navigation-link/test/edit.js +2 -24
  705. package/src/navigation-submenu/edit.js +10 -20
  706. package/src/navigation-submenu/view.js +7 -2
  707. package/src/page-list/convert-to-links-modal.js +51 -54
  708. package/src/page-list/edit.js +6 -6
  709. package/src/page-list/test/convert-to-links-modal.js +6 -12
  710. package/src/paragraph/deprecated.js +2 -2
  711. package/src/pattern/edit.js +2 -4
  712. package/src/post-author/edit.js +2 -3
  713. package/src/post-author/index.php +3 -2
  714. package/src/post-author-name/index.js +2 -0
  715. package/src/post-author-name/index.php +1 -1
  716. package/src/post-author-name/transforms.js +25 -0
  717. package/src/post-comments/index.php +1 -1
  718. package/src/post-comments/style.scss +7 -3
  719. package/src/post-comments-form/edit.js +20 -3
  720. package/src/post-comments-form/editor.scss +4 -0
  721. package/src/post-comments-form/form.js +11 -1
  722. package/src/post-comments-form/index.php +1 -1
  723. package/src/post-content/edit.js +2 -3
  724. package/src/post-date/edit.js +4 -3
  725. package/src/post-featured-image/edit.js +14 -30
  726. package/src/post-featured-image/editor.scss +0 -29
  727. package/src/post-featured-image/index.php +4 -2
  728. package/src/post-navigation-link/block.json +4 -0
  729. package/src/post-template/index.php +15 -3
  730. package/src/post-template/style.scss +1 -7
  731. package/src/pullquote/deprecated.js +2 -1
  732. package/src/query/edit/index.js +10 -10
  733. package/src/query/edit/inspector-controls/parent-control.js +2 -3
  734. package/src/query/edit/query-toolbar.js +25 -5
  735. package/src/query-pagination/index.php +0 -1
  736. package/src/quote/v2/edit.js +4 -6
  737. package/src/quote/v2/test/migrate.js +1 -2
  738. package/src/search/block.json +4 -0
  739. package/src/search/edit.js +9 -13
  740. package/src/search/edit.native.js +4 -6
  741. package/src/search/index.php +38 -23
  742. package/src/search/style.scss +11 -9
  743. package/src/separator/use-deprecated-opacity.js +2 -4
  744. package/src/shortcode/edit.native.js +30 -15
  745. package/src/shortcode/style.native.scss +11 -4
  746. package/src/shortcode/test/__snapshots__/edit.native.js.snap +9 -0
  747. package/src/shortcode/test/edit.native.js +55 -40
  748. package/src/site-logo/edit.js +3 -17
  749. package/src/site-logo/editor.scss +0 -14
  750. package/src/site-logo/style.scss +6 -0
  751. package/src/social-links/deprecated.js +4 -2
  752. package/src/social-links/edit.js +11 -10
  753. package/src/social-links/edit.native.js +3 -5
  754. package/src/spacer/controls.js +2 -3
  755. package/src/spacer/test/index.native.js +10 -21
  756. package/src/table/block.json +6 -1
  757. package/src/table/deprecated.js +4 -8
  758. package/src/table/edit.js +2 -0
  759. package/src/table/save.js +6 -1
  760. package/src/table/state.js +2 -4
  761. package/src/table/style.scss +0 -1
  762. package/src/table-of-contents/edit.js +22 -13
  763. package/src/tag-cloud/edit.js +4 -7
  764. package/src/template-part/edit/advanced-controls.js +4 -4
  765. package/src/template-part/edit/index.js +6 -10
  766. package/src/template-part/edit/utils/hooks.js +8 -7
  767. package/src/transformationCategories.native.js +3 -3
  768. package/src/video/block.json +6 -1
  769. package/src/video/edit-common-settings.js +2 -8
  770. package/src/video/edit.js +4 -0
  771. package/src/video/edit.native.js +38 -16
  772. package/src/video/index.js +1 -2
  773. package/src/video/save.js +10 -2
  774. package/src/video/style.scss +0 -2
@@ -48,9 +48,8 @@ export default function ReusableBlockEdit( {
48
48
  clientId,
49
49
  isSelected,
50
50
  } ) {
51
- const [ hasAlreadyRendered, RecursionProvider ] = useNoRecursiveRenders(
52
- ref
53
- );
51
+ const [ hasAlreadyRendered, RecursionProvider ] =
52
+ useNoRecursiveRenders( ref );
54
53
 
55
54
  const [ showHelp, setShowHelp ] = useState( false );
56
55
  const infoTextStyle = usePreferredColorSchemeStyle(
@@ -85,18 +84,16 @@ export default function ReusableBlockEdit( {
85
84
  'wp_block',
86
85
  ref
87
86
  );
88
- const hasResolvedBlock = select(
89
- coreStore
90
- ).hasFinishedResolution( 'getEntityRecord', [
91
- 'postType',
92
- 'wp_block',
93
- ref,
94
- ] );
87
+ const hasResolvedBlock = select( coreStore ).hasFinishedResolution(
88
+ 'getEntityRecord',
89
+ [ 'postType', 'wp_block', ref ]
90
+ );
95
91
  return {
96
92
  hasResolved: hasResolvedBlock,
97
- isEditing: select(
98
- reusableBlocksStore
99
- ).__experimentalIsEditingReusableBlock( clientId ),
93
+ isEditing:
94
+ select(
95
+ reusableBlocksStore
96
+ ).__experimentalIsEditingReusableBlock( clientId ),
100
97
  isMissing: hasResolvedBlock && ! persistedBlock,
101
98
  };
102
99
  },
@@ -104,9 +101,8 @@ export default function ReusableBlockEdit( {
104
101
  );
105
102
 
106
103
  const { createSuccessNotice } = useDispatch( noticesStore );
107
- const {
108
- __experimentalConvertBlockToStatic: convertBlockToStatic,
109
- } = useDispatch( reusableBlocksStore );
104
+ const { __experimentalConvertBlockToStatic: convertBlockToStatic } =
105
+ useDispatch( reusableBlocksStore );
110
106
  const { clearSelectedBlock } = useDispatch( blockEditorStore );
111
107
 
112
108
  const [ blocks, onInput, onChange ] = useEntityBlockEditor(
@@ -74,14 +74,11 @@ describe( 'Reusable block', () => {
74
74
  return Promise.resolve( response );
75
75
  } );
76
76
 
77
- const {
78
- getByA11yLabel,
79
- getByTestId,
80
- getByText,
81
- } = await initializeEditor( {
82
- initialHtml: '',
83
- capabilities: { reusableBlock: true },
84
- } );
77
+ const { getByA11yLabel, getByTestId, getByText } =
78
+ await initializeEditor( {
79
+ initialHtml: '',
80
+ capabilities: { reusableBlock: true },
81
+ } );
85
82
 
86
83
  // Open the inserter menu.
87
84
  fireEvent.press( await waitFor( () => getByA11yLabel( 'Add block' ) ) );
@@ -119,6 +119,142 @@ const blockAttributes = {
119
119
  },
120
120
  };
121
121
 
122
+ const v11 = {
123
+ attributes: {
124
+ url: {
125
+ type: 'string',
126
+ source: 'attribute',
127
+ selector: 'a',
128
+ attribute: 'href',
129
+ },
130
+ title: {
131
+ type: 'string',
132
+ source: 'attribute',
133
+ selector: 'a',
134
+ attribute: 'title',
135
+ },
136
+ text: {
137
+ type: 'string',
138
+ source: 'html',
139
+ selector: 'a',
140
+ },
141
+ linkTarget: {
142
+ type: 'string',
143
+ source: 'attribute',
144
+ selector: 'a',
145
+ attribute: 'target',
146
+ },
147
+ rel: {
148
+ type: 'string',
149
+ source: 'attribute',
150
+ selector: 'a',
151
+ attribute: 'rel',
152
+ },
153
+ placeholder: {
154
+ type: 'string',
155
+ },
156
+ backgroundColor: {
157
+ type: 'string',
158
+ },
159
+ textColor: {
160
+ type: 'string',
161
+ },
162
+ gradient: {
163
+ type: 'string',
164
+ },
165
+ width: {
166
+ type: 'number',
167
+ },
168
+ },
169
+ supports: {
170
+ anchor: true,
171
+ align: true,
172
+ alignWide: false,
173
+ color: {
174
+ __experimentalSkipSerialization: true,
175
+ gradients: true,
176
+ __experimentalDefaultControls: {
177
+ background: true,
178
+ text: true,
179
+ },
180
+ },
181
+ typography: {
182
+ fontSize: true,
183
+ __experimentalFontFamily: true,
184
+ __experimentalDefaultControls: {
185
+ fontSize: true,
186
+ },
187
+ },
188
+ reusable: false,
189
+ spacing: {
190
+ __experimentalSkipSerialization: true,
191
+ padding: [ 'horizontal', 'vertical' ],
192
+ __experimentalDefaultControls: {
193
+ padding: true,
194
+ },
195
+ },
196
+ __experimentalBorder: {
197
+ radius: true,
198
+ __experimentalSkipSerialization: true,
199
+ __experimentalDefaultControls: {
200
+ radius: true,
201
+ },
202
+ },
203
+ __experimentalSelector: '.wp-block-button__link',
204
+ },
205
+ save( { attributes, className } ) {
206
+ const { fontSize, linkTarget, rel, style, text, title, url, width } =
207
+ attributes;
208
+
209
+ if ( ! text ) {
210
+ return null;
211
+ }
212
+
213
+ const borderProps = getBorderClassesAndStyles( attributes );
214
+ const colorProps = getColorClassesAndStyles( attributes );
215
+ const spacingProps = getSpacingClassesAndStyles( attributes );
216
+ const buttonClasses = classnames(
217
+ 'wp-block-button__link',
218
+ colorProps.className,
219
+ borderProps.className,
220
+ {
221
+ // For backwards compatibility add style that isn't provided via
222
+ // block support.
223
+ 'no-border-radius': style?.border?.radius === 0,
224
+ }
225
+ );
226
+ const buttonStyle = {
227
+ ...borderProps.style,
228
+ ...colorProps.style,
229
+ ...spacingProps.style,
230
+ };
231
+
232
+ // The use of a `title` attribute here is soft-deprecated, but still applied
233
+ // if it had already been assigned, for the sake of backward-compatibility.
234
+ // A title will no longer be assigned for new or updated button block links.
235
+
236
+ const wrapperClasses = classnames( className, {
237
+ [ `has-custom-width wp-block-button__width-${ width }` ]: width,
238
+ [ `has-custom-font-size` ]: fontSize || style?.typography?.fontSize,
239
+ } );
240
+
241
+ return (
242
+ <div { ...useBlockProps.save( { className: wrapperClasses } ) }>
243
+ <RichText.Content
244
+ tagName="a"
245
+ className={ buttonClasses }
246
+ href={ url }
247
+ title={ title }
248
+ style={ buttonStyle }
249
+ value={ text }
250
+ target={ linkTarget }
251
+ rel={ rel }
252
+ />
253
+ </div>
254
+ );
255
+ },
256
+ };
257
+
122
258
  const v10 = {
123
259
  attributes: {
124
260
  url: {
@@ -193,16 +329,8 @@ const v10 = {
193
329
  __experimentalSelector: '.wp-block-button__link',
194
330
  },
195
331
  save( { attributes, className } ) {
196
- const {
197
- fontSize,
198
- linkTarget,
199
- rel,
200
- style,
201
- text,
202
- title,
203
- url,
204
- width,
205
- } = attributes;
332
+ const { fontSize, linkTarget, rel, style, text, title, url, width } =
333
+ attributes;
206
334
 
207
335
  if ( ! text ) {
208
336
  return null;
@@ -258,6 +386,7 @@ const v10 = {
258
386
  };
259
387
 
260
388
  const deprecated = [
389
+ v11,
261
390
  v10,
262
391
  {
263
392
  supports: {
@@ -413,15 +542,8 @@ const deprecated = [
413
542
  },
414
543
  },
415
544
  save( { attributes, className } ) {
416
- const {
417
- borderRadius,
418
- linkTarget,
419
- rel,
420
- text,
421
- title,
422
- url,
423
- width,
424
- } = attributes;
545
+ const { borderRadius, linkTarget, rel, text, title, url, width } =
546
+ attributes;
425
547
  const colorProps = getColorClassesAndStyles( attributes );
426
548
  const buttonClasses = classnames(
427
549
  'wp-block-button__link',
@@ -508,15 +630,8 @@ const deprecated = [
508
630
  },
509
631
  },
510
632
  save( { attributes, className } ) {
511
- const {
512
- borderRadius,
513
- linkTarget,
514
- rel,
515
- text,
516
- title,
517
- url,
518
- width,
519
- } = attributes;
633
+ const { borderRadius, linkTarget, rel, text, title, url, width } =
634
+ attributes;
520
635
  const colorProps = getColorClassesAndStyles( attributes );
521
636
  const buttonClasses = classnames(
522
637
  'wp-block-button__link',
@@ -595,14 +710,8 @@ const deprecated = [
595
710
  },
596
711
  },
597
712
  save( { attributes } ) {
598
- const {
599
- borderRadius,
600
- linkTarget,
601
- rel,
602
- text,
603
- title,
604
- url,
605
- } = attributes;
713
+ const { borderRadius, linkTarget, rel, text, title, url } =
714
+ attributes;
606
715
  const buttonClasses = classnames( 'wp-block-button__link', {
607
716
  'no-border-radius': borderRadius === 0,
608
717
  } );
@@ -25,6 +25,7 @@ import {
25
25
  __experimentalUseColorProps as useColorProps,
26
26
  __experimentalGetSpacingClassesAndStyles as useSpacingProps,
27
27
  __experimentalLinkControl as LinkControl,
28
+ __experimentalGetElementClassName,
28
29
  } from '@wordpress/block-editor';
29
30
  import { displayShortcut, isKeyboardEvent } from '@wordpress/keycodes';
30
31
  import { link, linkOff } from '@wordpress/icons';
@@ -74,15 +75,8 @@ function ButtonEdit( props ) {
74
75
  onReplace,
75
76
  mergeBlocks,
76
77
  } = props;
77
- const {
78
- linkTarget,
79
- placeholder,
80
- rel,
81
- style,
82
- text,
83
- url,
84
- width,
85
- } = attributes;
78
+ const { linkTarget, placeholder, rel, style, text, url, width } =
79
+ attributes;
86
80
  const onSetLinkRel = useCallback(
87
81
  ( value ) => {
88
82
  setAttributes( { rel: value } );
@@ -156,7 +150,8 @@ function ButtonEdit( props ) {
156
150
  <div
157
151
  { ...blockProps }
158
152
  className={ classnames( blockProps.className, {
159
- [ `has-custom-width wp-block-button__width-${ width }` ]: width,
153
+ [ `has-custom-width wp-block-button__width-${ width }` ]:
154
+ width,
160
155
  [ `has-custom-font-size` ]: blockProps.style.fontSize,
161
156
  } ) }
162
157
  >
@@ -176,7 +171,8 @@ function ButtonEdit( props ) {
176
171
  // For backwards compatibility add style that isn't
177
172
  // provided via block support.
178
173
  'no-border-radius': style?.border?.radius === 0,
179
- }
174
+ },
175
+ __experimentalGetElementClassName( 'button' )
180
176
  ) }
181
177
  style={ {
182
178
  ...borderProps.style,
@@ -95,9 +95,8 @@ function ButtonEdit( props ) {
95
95
  const { editorSidebarOpened, numOfButtons } = useSelect(
96
96
  ( select ) => {
97
97
  const { isEditorSidebarOpened } = select( editPostStore );
98
- const { getBlockCount, getBlockRootClientId } = select(
99
- blockEditorStore
100
- );
98
+ const { getBlockCount, getBlockRootClientId } =
99
+ select( blockEditorStore );
101
100
  const parentId = getBlockRootClientId( clientId );
102
101
  const blockCount = getBlockCount( parentId );
103
102
  const currentIsEditorSidebarOpened = isEditorSidebarOpened();
@@ -12,19 +12,12 @@ import {
12
12
  __experimentalGetBorderClassesAndStyles as getBorderClassesAndStyles,
13
13
  __experimentalGetColorClassesAndStyles as getColorClassesAndStyles,
14
14
  __experimentalGetSpacingClassesAndStyles as getSpacingClassesAndStyles,
15
+ __experimentalGetElementClassName,
15
16
  } from '@wordpress/block-editor';
16
17
 
17
18
  export default function save( { attributes, className } ) {
18
- const {
19
- fontSize,
20
- linkTarget,
21
- rel,
22
- style,
23
- text,
24
- title,
25
- url,
26
- width,
27
- } = attributes;
19
+ const { fontSize, linkTarget, rel, style, text, title, url, width } =
20
+ attributes;
28
21
 
29
22
  if ( ! text ) {
30
23
  return null;
@@ -41,7 +34,8 @@ export default function save( { attributes, className } ) {
41
34
  // For backwards compatibility add style that isn't provided via
42
35
  // block support.
43
36
  'no-border-radius': style?.border?.radius === 0,
44
- }
37
+ },
38
+ __experimentalGetElementClassName( 'button' )
45
39
  );
46
40
  const buttonStyle = {
47
41
  ...borderProps.style,
@@ -4,14 +4,9 @@ $blocks-block__margin: 0.5em;
4
4
  // Prefer the link selector instead of the regular button classname
5
5
  // to support the previous markup in addition to the new one.
6
6
  .wp-block-button__link {
7
- color: $white;
8
- background-color: #32373c;
9
- border-radius: 9999px; // 100% causes an oval, but any explicit but really high value retains the pill shape.
10
7
  box-shadow: none;
11
8
  cursor: pointer;
12
9
  display: inline-block;
13
- font-size: 1.125em;
14
- padding: calc(0.667em + 2px) calc(1.333em + 2px); // The extra 2px are added to size solids the same as the outline versions.
15
10
  text-align: center;
16
11
  text-decoration: none;
17
12
  word-break: break-word; // overflow-wrap doesn't work well if a link is wrapped in the div, so use word-break here.
@@ -34,6 +29,16 @@ $blocks-block__margin: 0.5em;
34
29
  }
35
30
  }
36
31
 
32
+ // These rules are set to zero specificity to keep the default styles for buttons.
33
+ // They are needed for backwards compatibility.
34
+ :where(.wp-block-button__link) {
35
+ // 100% causes an oval, but any explicit but really high value retains the pill shape.
36
+ border-radius: 9999px;
37
+
38
+ // The extra 2px are added to size solids the same as the outline versions.
39
+ padding: calc(0.667em + 2px) calc(1.333em + 2px);
40
+ }
41
+
37
42
  // Increased specificity needed to override margins.
38
43
  .wp-block-buttons > .wp-block-button {
39
44
  &.has-custom-width {
@@ -15,11 +15,8 @@ const migrateWithLayout = ( attributes ) => {
15
15
  return attributes;
16
16
  }
17
17
 
18
- const {
19
- contentJustification,
20
- orientation,
21
- ...updatedAttributes
22
- } = attributes;
18
+ const { contentJustification, orientation, ...updatedAttributes } =
19
+ attributes;
23
20
 
24
21
  if ( contentJustification || orientation ) {
25
22
  Object.assign( updatedAttributes, {
@@ -67,7 +64,8 @@ const deprecated = [
67
64
  <div
68
65
  { ...useBlockProps.save( {
69
66
  className: classnames( {
70
- [ `is-content-justification-${ contentJustification }` ]: contentJustification,
67
+ [ `is-content-justification-${ contentJustification }` ]:
68
+ contentJustification,
71
69
  'is-vertical': orientation === 'vertical',
72
70
  } ),
73
71
  } ) }
@@ -33,9 +33,9 @@ const DEFAULT_BLOCK = {
33
33
  function ButtonsEdit( { attributes: { layout = {} } } ) {
34
34
  const blockProps = useBlockProps();
35
35
  const preferredStyle = useSelect( ( select ) => {
36
- const preferredStyleVariations = select(
37
- blockEditorStore
38
- ).getSettings().__experimentalPreferredStyleVariations;
36
+ const preferredStyleVariations =
37
+ select( blockEditorStore ).getSettings()
38
+ .__experimentalPreferredStyleVariations;
39
39
  return preferredStyleVariations?.value?.[ buttonBlockName ];
40
40
  }, [] );
41
41
 
@@ -49,11 +49,8 @@ export default function ButtonsEdit( {
49
49
 
50
50
  const { isInnerButtonSelected, shouldDelete } = useSelect(
51
51
  ( select ) => {
52
- const {
53
- getBlockCount,
54
- getBlockParents,
55
- getSelectedBlockClientId,
56
- } = select( blockEditorStore );
52
+ const { getBlockCount, getBlockParents, getSelectedBlockClientId } =
53
+ select( blockEditorStore );
57
54
  const selectedBlockClientId = getSelectedBlockClientId();
58
55
  const selectedBlockParents = getBlockParents(
59
56
  selectedBlockClientId,
@@ -73,16 +70,15 @@ export default function ButtonsEdit( {
73
70
  );
74
71
 
75
72
  const preferredStyle = useSelect( ( select ) => {
76
- const preferredStyleVariations = select(
77
- blockEditorStore
78
- ).getSettings().__experimentalPreferredStyleVariations;
73
+ const preferredStyleVariations =
74
+ select( blockEditorStore ).getSettings()
75
+ .__experimentalPreferredStyleVariations;
79
76
  return preferredStyleVariations?.value?.[ buttonBlockName ];
80
77
  }, [] );
81
78
 
82
79
  const { getBlockOrder } = useSelect( blockEditorStore );
83
- const { insertBlock, removeBlock, selectBlock } = useDispatch(
84
- blockEditorStore
85
- );
80
+ const { insertBlock, removeBlock, selectBlock } =
81
+ useDispatch( blockEditorStore );
86
82
 
87
83
  useEffect( () => {
88
84
  const { width } = sizes || {};
@@ -21,7 +21,7 @@ exports[`Buttons block justify content sets Justify items right option 1`] = `
21
21
  exports[`Buttons block when a button is shown adjusts the border radius 1`] = `
22
22
  "<!-- wp:buttons -->
23
23
  <div class=\\"wp-block-buttons\\"><!-- wp:button {\\"style\\":{\\"border\\":{\\"radius\\":\\"6px\\"}}} -->
24
- <div class=\\"wp-block-button\\"><a class=\\"wp-block-button__link\\" href=\\"\\" style=\\"border-radius:6px\\">Hello</a></div>
24
+ <div class=\\"wp-block-button\\"><a class=\\"wp-block-button__link wp-element-button\\" href=\\"\\" style=\\"border-radius:6px\\">Hello</a></div>
25
25
  <!-- /wp:button --></div>
26
26
  <!-- /wp:buttons -->"
27
27
  `;
@@ -32,7 +32,7 @@ describe( 'Buttons block', () => {
32
32
  it( 'adjusts the border radius', async () => {
33
33
  const initialHtml = `<!-- wp:buttons -->
34
34
  <div class="wp-block-buttons"><!-- wp:button {"style":{"border":{"radius":"5px"}}} -->
35
- <div class="wp-block-button"><a class="wp-block-button__link" style="border-radius:5px" >Hello</a></div>
35
+ <div class="wp-block-button"><a class="wp-block-button__link wp-element-button" style="border-radius:5px" >Hello</a></div>
36
36
  <!-- /wp:button --></div>
37
37
  <!-- /wp:buttons -->`;
38
38
  const { getByA11yLabel } = await initializeEditor( {
@@ -33,7 +33,8 @@ const deprecated = [
33
33
  const { verticalAlignment, width } = attributes;
34
34
 
35
35
  const wrapperClasses = classnames( {
36
- [ `is-vertically-aligned-${ verticalAlignment }` ]: verticalAlignment,
36
+ [ `is-vertically-aligned-${ verticalAlignment }` ]:
37
+ verticalAlignment,
37
38
  } );
38
39
 
39
40
  const style = { flexBasis: width + '%' };
@@ -50,9 +50,8 @@ function ColumnEdit( {
50
50
 
51
51
  const { columnsIds, hasChildBlocks, rootClientId } = useSelect(
52
52
  ( select ) => {
53
- const { getBlockOrder, getBlockRootClientId } = select(
54
- blockEditorStore
55
- );
53
+ const { getBlockOrder, getBlockRootClientId } =
54
+ select( blockEditorStore );
56
55
 
57
56
  const rootId = getBlockRootClientId( clientId );
58
57
 
@@ -261,8 +261,8 @@ export default compose( [
261
261
  const selectedColumnIndex = blockOrder.indexOf( clientId );
262
262
  const columns = getBlocks( parentId );
263
263
 
264
- const parentAlignment = getBlockAttributes( parentId )
265
- ?.verticalAlignment;
264
+ const parentAlignment =
265
+ getBlockAttributes( parentId )?.verticalAlignment;
266
266
 
267
267
  return {
268
268
  hasChildren,
@@ -28,7 +28,9 @@
28
28
  }
29
29
  },
30
30
  "spacing": {
31
- "blockGap": true,
31
+ "blockGap": {
32
+ "__experimentalDefault": "2em"
33
+ },
32
34
  "margin": [ "top", "bottom" ],
33
35
  "padding": true,
34
36
  "__experimentalDefaultControls": {
@@ -97,7 +97,8 @@ export default [
97
97
  'has-text-color': textColor || customTextColor,
98
98
  [ backgroundClass ]: backgroundClass,
99
99
  [ textClass ]: textClass,
100
- [ `are-vertically-aligned-${ verticalAlignment }` ]: verticalAlignment,
100
+ [ `are-vertically-aligned-${ verticalAlignment }` ]:
101
+ verticalAlignment,
101
102
  } );
102
103
 
103
104
  const style = {
@@ -204,7 +205,8 @@ export default [
204
205
  const { verticalAlignment, columns } = attributes;
205
206
 
206
207
  const wrapperClasses = classnames( `has-${ columns }-columns`, {
207
- [ `are-vertically-aligned-${ verticalAlignment }` ]: verticalAlignment,
208
+ [ `are-vertically-aligned-${ verticalAlignment }` ]:
209
+ verticalAlignment,
208
210
  } );
209
211
 
210
212
  return (
@@ -2,7 +2,7 @@
2
2
  * External dependencies
3
3
  */
4
4
  import classnames from 'classnames';
5
- import { dropRight, get, times } from 'lodash';
5
+ import { get, times } from 'lodash';
6
6
 
7
7
  /**
8
8
  * WordPress dependencies
@@ -163,9 +163,8 @@ const ColumnsEditContainerWrapper = withDispatch(
163
163
  const { getBlocks } = registry.select( blockEditorStore );
164
164
 
165
165
  let innerBlocks = getBlocks( clientId );
166
- const hasExplicitWidths = hasExplicitPercentColumnWidths(
167
- innerBlocks
168
- );
166
+ const hasExplicitWidths =
167
+ hasExplicitPercentColumnWidths( innerBlocks );
169
168
 
170
169
  // Redistribute available width for existing inner blocks.
171
170
  const isAddingColumn = newColumns > previousColumns;
@@ -199,9 +198,9 @@ const ColumnsEditContainerWrapper = withDispatch(
199
198
  ];
200
199
  } else {
201
200
  // The removed column will be the last of the inner blocks.
202
- innerBlocks = dropRight(
203
- innerBlocks,
204
- previousColumns - newColumns
201
+ innerBlocks = innerBlocks.slice(
202
+ 0,
203
+ -( previousColumns - newColumns )
205
204
  );
206
205
 
207
206
  if ( hasExplicitWidths ) {
@@ -2,7 +2,7 @@
2
2
  * External dependencies
3
3
  */
4
4
  import { View, Dimensions } from 'react-native';
5
- import { dropRight, times, map, compact, delay } from 'lodash';
5
+ import { times, map, compact, delay } from 'lodash';
6
6
  /**
7
7
  * WordPress dependencies
8
8
  */
@@ -347,14 +347,12 @@ const ColumnsEditContainerWrapper = withDispatch(
347
347
  updateColumns( previousColumns, newColumns ) {
348
348
  const { clientId } = ownProps;
349
349
  const { replaceInnerBlocks } = dispatch( blockEditorStore );
350
- const { getBlocks, getBlockAttributes } = registry.select(
351
- blockEditorStore
352
- );
350
+ const { getBlocks, getBlockAttributes } =
351
+ registry.select( blockEditorStore );
353
352
 
354
353
  let innerBlocks = getBlocks( clientId );
355
- const hasExplicitWidths = hasExplicitPercentColumnWidths(
356
- innerBlocks
357
- );
354
+ const hasExplicitWidths =
355
+ hasExplicitPercentColumnWidths( innerBlocks );
358
356
 
359
357
  // Redistribute available width for existing inner blocks.
360
358
  const isAddingColumn = newColumns > previousColumns;
@@ -394,9 +392,9 @@ const ColumnsEditContainerWrapper = withDispatch(
394
392
  ];
395
393
  } else {
396
394
  // The removed column will be the last of the inner blocks.
397
- innerBlocks = dropRight(
398
- innerBlocks,
399
- previousColumns - newColumns
395
+ innerBlocks = innerBlocks.slice(
396
+ 0,
397
+ -( previousColumns - newColumns )
400
398
  );
401
399
 
402
400
  if ( hasExplicitWidths ) {
@@ -414,12 +412,10 @@ const ColumnsEditContainerWrapper = withDispatch(
414
412
  },
415
413
  onAddNextColumn: () => {
416
414
  const { clientId } = ownProps;
417
- const { replaceInnerBlocks, selectBlock } = dispatch(
418
- blockEditorStore
419
- );
420
- const { getBlocks, getBlockAttributes } = registry.select(
421
- blockEditorStore
422
- );
415
+ const { replaceInnerBlocks, selectBlock } =
416
+ dispatch( blockEditorStore );
417
+ const { getBlocks, getBlockAttributes } =
418
+ registry.select( blockEditorStore );
423
419
 
424
420
  // Get verticalAlignment from Columns block to set the same to new Column.
425
421
  const { verticalAlignment } = getBlockAttributes( clientId );
@@ -39,8 +39,7 @@ export const settings = {
39
39
  {
40
40
  name: 'core/image',
41
41
  attributes: {
42
- url:
43
- 'https://s.w.org/images/core/5.3/Windbuchencom.jpg',
42
+ url: 'https://s.w.org/images/core/5.3/Windbuchencom.jpg',
44
43
  },
45
44
  },
46
45
  {