@wordpress/block-library 9.13.1-next.cd6172eb0.0 → 9.15.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 (787) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/LICENSE.md +1 -1
  3. package/build/archives/edit.js +83 -36
  4. package/build/archives/edit.js.map +1 -1
  5. package/build/avatar/user-control.js +1 -0
  6. package/build/avatar/user-control.js.map +1 -1
  7. package/build/block/deprecated.js +1 -0
  8. package/build/block/deprecated.js.map +1 -1
  9. package/build/block/edit.js +1 -0
  10. package/build/block/edit.js.map +1 -1
  11. package/build/button/deprecated.js +183 -1
  12. package/build/button/deprecated.js.map +1 -1
  13. package/build/button/edit.js +49 -27
  14. package/build/button/edit.js.map +1 -1
  15. package/build/button/index.js +8 -2
  16. package/build/button/index.js.map +1 -1
  17. package/build/button/save.js +8 -5
  18. package/build/button/save.js.map +1 -1
  19. package/build/buttons/transforms.js +1 -0
  20. package/build/buttons/transforms.js.map +1 -1
  21. package/build/categories/edit.js +1 -0
  22. package/build/categories/edit.js.map +1 -1
  23. package/build/column/column-preview.native.js +1 -0
  24. package/build/column/column-preview.native.js.map +1 -1
  25. package/build/column/edit.js +33 -13
  26. package/build/column/edit.js.map +1 -1
  27. package/build/columns/columnCalculations.native.js +1 -0
  28. package/build/columns/columnCalculations.native.js.map +1 -1
  29. package/build/columns/deprecated.js +1 -0
  30. package/build/columns/deprecated.js.map +1 -1
  31. package/build/columns/edit.js +51 -27
  32. package/build/columns/edit.js.map +1 -1
  33. package/build/columns/edit.native.js +1 -0
  34. package/build/columns/edit.native.js.map +1 -1
  35. package/build/columns/transforms.js +1 -0
  36. package/build/columns/transforms.js.map +1 -1
  37. package/build/columns/utils.js +1 -0
  38. package/build/columns/utils.js.map +1 -1
  39. package/build/comment-template/edit.js +1 -0
  40. package/build/comment-template/edit.js.map +1 -1
  41. package/build/comment-template/hooks.js +1 -0
  42. package/build/comment-template/hooks.js.map +1 -1
  43. package/build/comment-template/util.js +1 -0
  44. package/build/comment-template/util.js.map +1 -1
  45. package/build/comments/index.js +1 -0
  46. package/build/comments/index.js.map +1 -1
  47. package/build/cover/edit/index.js +9 -3
  48. package/build/cover/edit/index.js.map +1 -1
  49. package/build/cover/edit.native.js +1 -1
  50. package/build/cover/edit.native.js.map +1 -1
  51. package/build/details/edit.js +29 -7
  52. package/build/details/edit.js.map +1 -1
  53. package/build/details/transforms.js +1 -0
  54. package/build/details/transforms.js.map +1 -1
  55. package/build/embed/embed-placeholder.native.js +1 -0
  56. package/build/embed/embed-placeholder.native.js.map +1 -1
  57. package/build/embed/util.js +1 -0
  58. package/build/embed/util.js.map +1 -1
  59. package/build/embed/variations.js +1 -0
  60. package/build/embed/variations.js.map +1 -1
  61. package/build/embed/wp-embed-preview.js +1 -0
  62. package/build/embed/wp-embed-preview.js.map +1 -1
  63. package/build/file/transforms.js +1 -0
  64. package/build/file/transforms.js.map +1 -1
  65. package/build/footnotes/edit.js +1 -0
  66. package/build/footnotes/edit.js.map +1 -1
  67. package/build/form/index.js +1 -2
  68. package/build/form/index.js.map +1 -1
  69. package/build/form/view.js +10 -5
  70. package/build/form/view.js.map +1 -1
  71. package/build/freeform/modal.js +1 -0
  72. package/build/freeform/modal.js.map +1 -1
  73. package/build/gallery/deprecated.js +1 -0
  74. package/build/gallery/deprecated.js.map +1 -1
  75. package/build/gallery/edit.js +1 -0
  76. package/build/gallery/edit.js.map +1 -1
  77. package/build/gallery/shared.js +1 -0
  78. package/build/gallery/shared.js.map +1 -1
  79. package/build/gallery/transforms.js +1 -0
  80. package/build/gallery/transforms.js.map +1 -1
  81. package/build/gallery/use-get-media.js +1 -0
  82. package/build/gallery/use-get-media.js.map +1 -1
  83. package/build/gallery/use-get-media.native.js +1 -0
  84. package/build/gallery/use-get-media.native.js.map +1 -1
  85. package/build/gallery/use-get-new-images.js +1 -0
  86. package/build/gallery/use-get-new-images.js.map +1 -1
  87. package/build/gallery/use-image-sizes.js +1 -0
  88. package/build/gallery/use-image-sizes.js.map +1 -1
  89. package/build/group/placeholder.js +1 -0
  90. package/build/group/placeholder.js.map +1 -1
  91. package/build/group/transforms.js +1 -0
  92. package/build/group/transforms.js.map +1 -1
  93. package/build/heading/transforms.js +1 -0
  94. package/build/heading/transforms.js.map +1 -1
  95. package/build/html/preview.js +1 -0
  96. package/build/html/preview.js.map +1 -1
  97. package/build/image/edit.js +1 -0
  98. package/build/image/edit.js.map +1 -1
  99. package/build/image/edit.native.js +1 -0
  100. package/build/image/edit.native.js.map +1 -1
  101. package/build/image/image.js +2 -1
  102. package/build/image/image.js.map +1 -1
  103. package/build/image/transforms.js +2 -0
  104. package/build/image/transforms.js.map +1 -1
  105. package/build/image/utils.js +1 -0
  106. package/build/image/utils.js.map +1 -1
  107. package/build/image/view.js +1 -3
  108. package/build/image/view.js.map +1 -1
  109. package/build/index.js +2 -1
  110. package/build/index.js.map +1 -1
  111. package/build/index.native.js +1 -0
  112. package/build/index.native.js.map +1 -1
  113. package/build/latest-posts/deprecated.js +12 -0
  114. package/build/latest-posts/deprecated.js.map +1 -1
  115. package/build/latest-posts/edit.js +1 -0
  116. package/build/latest-posts/edit.js.map +1 -1
  117. package/build/latest-posts/index.js +12 -0
  118. package/build/latest-posts/index.js.map +1 -1
  119. package/build/list/transforms.js +1 -0
  120. package/build/list/transforms.js.map +1 -1
  121. package/build/list/utils.js +1 -0
  122. package/build/list/utils.js.map +1 -1
  123. package/build/list-item/hooks/use-indent-list-item.js +1 -0
  124. package/build/list-item/hooks/use-indent-list-item.js.map +1 -1
  125. package/build/list-item/transforms.js +1 -0
  126. package/build/list-item/transforms.js.map +1 -1
  127. package/build/loginout/edit.js +42 -13
  128. package/build/loginout/edit.js.map +1 -1
  129. package/build/media-text/edit.js +60 -31
  130. package/build/media-text/edit.js.map +1 -1
  131. package/build/more/edit.js +28 -7
  132. package/build/more/edit.js.map +1 -1
  133. package/build/more/save.js +1 -0
  134. package/build/more/save.js.map +1 -1
  135. package/build/navigation/deprecated.js +1 -0
  136. package/build/navigation/deprecated.js.map +1 -1
  137. package/build/navigation/edit/index.js +1 -0
  138. package/build/navigation/edit/index.js.map +1 -1
  139. package/build/navigation/edit/navigation-menu-selector.js +5 -3
  140. package/build/navigation/edit/navigation-menu-selector.js.map +1 -1
  141. package/build/navigation/edit/use-generate-default-navigation-title.js +1 -0
  142. package/build/navigation/edit/use-generate-default-navigation-title.js.map +1 -1
  143. package/build/navigation/menu-items-to-blocks.js +1 -0
  144. package/build/navigation/menu-items-to-blocks.js.map +1 -1
  145. package/build/navigation/use-template-part-area-label.js +1 -0
  146. package/build/navigation/use-template-part-area-label.js.map +1 -1
  147. package/build/navigation/view.js +1 -0
  148. package/build/navigation/view.js.map +1 -1
  149. package/build/navigation-link/edit.js +96 -57
  150. package/build/navigation-link/edit.js.map +1 -1
  151. package/build/navigation-link/hooks.js +1 -0
  152. package/build/navigation-link/hooks.js.map +1 -1
  153. package/build/navigation-link/link-ui.js +3 -3
  154. package/build/navigation-link/link-ui.js.map +1 -1
  155. package/build/navigation-submenu/edit.js +105 -54
  156. package/build/navigation-submenu/edit.js.map +1 -1
  157. package/build/page-list/edit.js +45 -25
  158. package/build/page-list/edit.js.map +1 -1
  159. package/build/page-list/use-convert-to-navigation-links.js +1 -0
  160. package/build/page-list/use-convert-to-navigation-links.js.map +1 -1
  161. package/build/paragraph/edit.js +22 -6
  162. package/build/paragraph/edit.js.map +1 -1
  163. package/build/pattern/edit.js +1 -0
  164. package/build/pattern/edit.js.map +1 -1
  165. package/build/post-author/edit.js +16 -3
  166. package/build/post-author/edit.js.map +1 -1
  167. package/build/post-author/index.js +4 -2
  168. package/build/post-author/index.js.map +1 -1
  169. package/build/post-author-name/edit.js +11 -5
  170. package/build/post-author-name/edit.js.map +1 -1
  171. package/build/post-author-name/index.js +4 -2
  172. package/build/post-author-name/index.js.map +1 -1
  173. package/build/post-comments-form/index.js +6 -1
  174. package/build/post-comments-form/index.js.map +1 -1
  175. package/build/post-comments-link/index.js +8 -1
  176. package/build/post-comments-link/index.js.map +1 -1
  177. package/build/post-date/edit.js +58 -18
  178. package/build/post-date/edit.js.map +1 -1
  179. package/build/post-date/index.js +2 -1
  180. package/build/post-date/index.js.map +1 -1
  181. package/build/post-excerpt/edit.js +42 -18
  182. package/build/post-excerpt/edit.js.map +1 -1
  183. package/build/post-featured-image/dimension-controls.js +18 -19
  184. package/build/post-featured-image/dimension-controls.js.map +1 -1
  185. package/build/post-featured-image/edit.js +45 -11
  186. package/build/post-featured-image/edit.js.map +1 -1
  187. package/build/post-featured-image/index.js +6 -3
  188. package/build/post-featured-image/index.js.map +1 -1
  189. package/build/post-navigation-link/edit.js +1 -0
  190. package/build/post-navigation-link/edit.js.map +1 -1
  191. package/build/post-navigation-link/index.js +11 -7
  192. package/build/post-navigation-link/index.js.map +1 -1
  193. package/build/post-navigation-link/variations.js +3 -2
  194. package/build/post-navigation-link/variations.js.map +1 -1
  195. package/build/post-template/edit.js +1 -0
  196. package/build/post-template/edit.js.map +1 -1
  197. package/build/post-template/index.js +12 -2
  198. package/build/post-template/index.js.map +1 -1
  199. package/build/post-terms/edit.js +1 -0
  200. package/build/post-terms/edit.js.map +1 -1
  201. package/build/post-terms/hooks.js +1 -0
  202. package/build/post-terms/hooks.js.map +1 -1
  203. package/build/post-title/index.js +6 -3
  204. package/build/post-title/index.js.map +1 -1
  205. package/build/pullquote/blockquote.native.js +1 -0
  206. package/build/pullquote/blockquote.native.js.map +1 -1
  207. package/build/pullquote/transforms.js +1 -0
  208. package/build/pullquote/transforms.js.map +1 -1
  209. package/build/query/deprecated.js +1 -0
  210. package/build/query/deprecated.js.map +1 -1
  211. package/build/query/edit/inspector-controls/author-control.js +1 -0
  212. package/build/query/edit/inspector-controls/author-control.js.map +1 -1
  213. package/build/query/edit/inspector-controls/format-controls.js +1 -0
  214. package/build/query/edit/inspector-controls/format-controls.js.map +1 -1
  215. package/build/query/edit/inspector-controls/index.js +1 -0
  216. package/build/query/edit/inspector-controls/index.js.map +1 -1
  217. package/build/query/edit/inspector-controls/parent-control.js +1 -0
  218. package/build/query/edit/inspector-controls/parent-control.js.map +1 -1
  219. package/build/query/edit/inspector-controls/taxonomy-controls.js +1 -0
  220. package/build/query/edit/inspector-controls/taxonomy-controls.js.map +1 -1
  221. package/build/query/utils.js +1 -0
  222. package/build/query/utils.js.map +1 -1
  223. package/build/query-no-results/index.js +11 -10
  224. package/build/query-no-results/index.js.map +1 -1
  225. package/build/query-pagination/edit.js +47 -17
  226. package/build/query-pagination/edit.js.map +1 -1
  227. package/build/query-pagination/query-pagination-label-control.js +1 -1
  228. package/build/query-pagination/query-pagination-label-control.js.map +1 -1
  229. package/build/query-pagination-numbers/edit.js +33 -15
  230. package/build/query-pagination-numbers/edit.js.map +1 -1
  231. package/build/query-title/variations.js +1 -0
  232. package/build/query-title/variations.js.map +1 -1
  233. package/build/query-total/edit.js +90 -0
  234. package/build/query-total/edit.js.map +1 -0
  235. package/build/query-total/icons.js +46 -0
  236. package/build/query-total/icons.js.map +1 -0
  237. package/build/query-total/index.js +81 -0
  238. package/build/query-total/index.js.map +1 -0
  239. package/build/query-total/init.js +12 -0
  240. package/build/query-total/init.js.map +1 -0
  241. package/build/quote/deprecated.js +1 -0
  242. package/build/quote/deprecated.js.map +1 -1
  243. package/build/quote/transforms.js +1 -0
  244. package/build/quote/transforms.js.map +1 -1
  245. package/build/read-more/index.js +7 -1
  246. package/build/read-more/index.js.map +1 -1
  247. package/build/site-logo/index.js +4 -2
  248. package/build/site-logo/index.js.map +1 -1
  249. package/build/site-title/edit.js +41 -12
  250. package/build/site-title/edit.js.map +1 -1
  251. package/build/site-title/index.js +4 -2
  252. package/build/site-title/index.js.map +1 -1
  253. package/build/social-link/edit.js +19 -3
  254. package/build/social-link/edit.js.map +1 -1
  255. package/build/social-link/social-list.js +1 -0
  256. package/build/social-link/social-list.js.map +1 -1
  257. package/build/social-link/variations.js +1 -0
  258. package/build/social-link/variations.js.map +1 -1
  259. package/build/social-links/edit.js +42 -12
  260. package/build/social-links/edit.js.map +1 -1
  261. package/build/social-links/edit.native.js +1 -0
  262. package/build/social-links/edit.native.js.map +1 -1
  263. package/build/spacer/controls.js +35 -12
  264. package/build/spacer/controls.js.map +1 -1
  265. package/build/table/deprecated.js +1 -0
  266. package/build/table/deprecated.js.map +1 -1
  267. package/build/table/edit.js +49 -15
  268. package/build/table/edit.js.map +1 -1
  269. package/build/table/index.js +4 -1
  270. package/build/table/index.js.map +1 -1
  271. package/build/table/save.js +1 -0
  272. package/build/table/save.js.map +1 -1
  273. package/build/table/state.js +1 -0
  274. package/build/table/state.js.map +1 -1
  275. package/build/table/transforms.js +1 -0
  276. package/build/table/transforms.js.map +1 -1
  277. package/build/table-of-contents/edit.js +1 -1
  278. package/build/table-of-contents/edit.js.map +1 -1
  279. package/build/table-of-contents/index.js +24 -23
  280. package/build/table-of-contents/index.js.map +1 -1
  281. package/build/table-of-contents/list.js +1 -0
  282. package/build/table-of-contents/list.js.map +1 -1
  283. package/build/table-of-contents/utils.js +1 -0
  284. package/build/table-of-contents/utils.js.map +1 -1
  285. package/build/tag-cloud/edit.js +57 -11
  286. package/build/tag-cloud/edit.js.map +1 -1
  287. package/build/template-part/edit/advanced-controls.js +1 -0
  288. package/build/template-part/edit/advanced-controls.js.map +1 -1
  289. package/build/template-part/edit/import-controls.js +1 -0
  290. package/build/template-part/edit/import-controls.js.map +1 -1
  291. package/build/template-part/edit/selection-modal.js +1 -0
  292. package/build/template-part/edit/selection-modal.js.map +1 -1
  293. package/build/template-part/edit/utils/hooks.js +1 -0
  294. package/build/template-part/edit/utils/hooks.js.map +1 -1
  295. package/build/template-part/edit/utils/transformers.js +1 -0
  296. package/build/template-part/edit/utils/transformers.js.map +1 -1
  297. package/build/template-part/variations.js +1 -0
  298. package/build/template-part/variations.js.map +1 -1
  299. package/build/text-columns/edit.js +1 -0
  300. package/build/text-columns/edit.js.map +1 -1
  301. package/build/text-columns/save.js +1 -0
  302. package/build/text-columns/save.js.map +1 -1
  303. package/build/text-columns/transforms.js +1 -0
  304. package/build/text-columns/transforms.js.map +1 -1
  305. package/build/utils/get-transformed-metadata.js +1 -0
  306. package/build/utils/get-transformed-metadata.js.map +1 -1
  307. package/build/utils/search-patterns.js +1 -0
  308. package/build/utils/search-patterns.js.map +1 -1
  309. package/build/utils/transformation-categories.native.js +1 -0
  310. package/build/utils/transformation-categories.native.js.map +1 -1
  311. package/build/video/edit-common-settings.js +90 -30
  312. package/build/video/edit-common-settings.js.map +1 -1
  313. package/build/video/edit.js +20 -49
  314. package/build/video/edit.js.map +1 -1
  315. package/build/video/poster-image.js +81 -0
  316. package/build/video/poster-image.js.map +1 -0
  317. package/build/video/tracks-editor.js +2 -1
  318. package/build/video/tracks-editor.js.map +1 -1
  319. package/build/video/tracks.js +1 -0
  320. package/build/video/tracks.js.map +1 -1
  321. package/build-module/archives/edit.js +84 -37
  322. package/build-module/archives/edit.js.map +1 -1
  323. package/build-module/avatar/user-control.js +1 -0
  324. package/build-module/avatar/user-control.js.map +1 -1
  325. package/build-module/block/deprecated.js +1 -0
  326. package/build-module/block/deprecated.js.map +1 -1
  327. package/build-module/block/edit.js +1 -0
  328. package/build-module/block/edit.js.map +1 -1
  329. package/build-module/button/deprecated.js +184 -2
  330. package/build-module/button/deprecated.js.map +1 -1
  331. package/build-module/button/edit.js +50 -28
  332. package/build-module/button/edit.js.map +1 -1
  333. package/build-module/button/index.js +8 -2
  334. package/build-module/button/index.js.map +1 -1
  335. package/build-module/button/save.js +9 -6
  336. package/build-module/button/save.js.map +1 -1
  337. package/build-module/buttons/transforms.js +1 -0
  338. package/build-module/buttons/transforms.js.map +1 -1
  339. package/build-module/categories/edit.js +1 -0
  340. package/build-module/categories/edit.js.map +1 -1
  341. package/build-module/column/column-preview.native.js +1 -0
  342. package/build-module/column/column-preview.native.js.map +1 -1
  343. package/build-module/column/edit.js +34 -14
  344. package/build-module/column/edit.js.map +1 -1
  345. package/build-module/columns/columnCalculations.native.js +1 -0
  346. package/build-module/columns/columnCalculations.native.js.map +1 -1
  347. package/build-module/columns/deprecated.js +1 -0
  348. package/build-module/columns/deprecated.js.map +1 -1
  349. package/build-module/columns/edit.js +53 -29
  350. package/build-module/columns/edit.js.map +1 -1
  351. package/build-module/columns/edit.native.js +1 -0
  352. package/build-module/columns/edit.native.js.map +1 -1
  353. package/build-module/columns/transforms.js +1 -0
  354. package/build-module/columns/transforms.js.map +1 -1
  355. package/build-module/columns/utils.js +1 -0
  356. package/build-module/columns/utils.js.map +1 -1
  357. package/build-module/comment-template/edit.js +1 -0
  358. package/build-module/comment-template/edit.js.map +1 -1
  359. package/build-module/comment-template/hooks.js +1 -0
  360. package/build-module/comment-template/hooks.js.map +1 -1
  361. package/build-module/comment-template/util.js +1 -0
  362. package/build-module/comment-template/util.js.map +1 -1
  363. package/build-module/comments/index.js +1 -0
  364. package/build-module/comments/index.js.map +1 -1
  365. package/build-module/cover/edit/index.js +9 -3
  366. package/build-module/cover/edit/index.js.map +1 -1
  367. package/build-module/cover/edit.native.js +2 -2
  368. package/build-module/cover/edit.native.js.map +1 -1
  369. package/build-module/details/edit.js +30 -8
  370. package/build-module/details/edit.js.map +1 -1
  371. package/build-module/details/transforms.js +1 -0
  372. package/build-module/details/transforms.js.map +1 -1
  373. package/build-module/embed/embed-placeholder.native.js +1 -0
  374. package/build-module/embed/embed-placeholder.native.js.map +1 -1
  375. package/build-module/embed/util.js +1 -0
  376. package/build-module/embed/util.js.map +1 -1
  377. package/build-module/embed/variations.js +1 -0
  378. package/build-module/embed/variations.js.map +1 -1
  379. package/build-module/embed/wp-embed-preview.js +1 -0
  380. package/build-module/embed/wp-embed-preview.js.map +1 -1
  381. package/build-module/file/transforms.js +1 -0
  382. package/build-module/file/transforms.js.map +1 -1
  383. package/build-module/footnotes/edit.js +1 -0
  384. package/build-module/footnotes/edit.js.map +1 -1
  385. package/build-module/form/index.js +1 -2
  386. package/build-module/form/index.js.map +1 -1
  387. package/build-module/form/view.js +10 -5
  388. package/build-module/form/view.js.map +1 -1
  389. package/build-module/freeform/modal.js +1 -0
  390. package/build-module/freeform/modal.js.map +1 -1
  391. package/build-module/gallery/deprecated.js +1 -0
  392. package/build-module/gallery/deprecated.js.map +1 -1
  393. package/build-module/gallery/edit.js +1 -0
  394. package/build-module/gallery/edit.js.map +1 -1
  395. package/build-module/gallery/shared.js +1 -0
  396. package/build-module/gallery/shared.js.map +1 -1
  397. package/build-module/gallery/transforms.js +1 -0
  398. package/build-module/gallery/transforms.js.map +1 -1
  399. package/build-module/gallery/use-get-media.js +1 -0
  400. package/build-module/gallery/use-get-media.js.map +1 -1
  401. package/build-module/gallery/use-get-media.native.js +1 -0
  402. package/build-module/gallery/use-get-media.native.js.map +1 -1
  403. package/build-module/gallery/use-get-new-images.js +1 -0
  404. package/build-module/gallery/use-get-new-images.js.map +1 -1
  405. package/build-module/gallery/use-image-sizes.js +1 -0
  406. package/build-module/gallery/use-image-sizes.js.map +1 -1
  407. package/build-module/group/placeholder.js +1 -0
  408. package/build-module/group/placeholder.js.map +1 -1
  409. package/build-module/group/transforms.js +1 -0
  410. package/build-module/group/transforms.js.map +1 -1
  411. package/build-module/heading/transforms.js +1 -0
  412. package/build-module/heading/transforms.js.map +1 -1
  413. package/build-module/html/preview.js +1 -0
  414. package/build-module/html/preview.js.map +1 -1
  415. package/build-module/image/edit.js +1 -0
  416. package/build-module/image/edit.js.map +1 -1
  417. package/build-module/image/edit.native.js +1 -0
  418. package/build-module/image/edit.native.js.map +1 -1
  419. package/build-module/image/image.js +2 -1
  420. package/build-module/image/image.js.map +1 -1
  421. package/build-module/image/transforms.js +2 -0
  422. package/build-module/image/transforms.js.map +1 -1
  423. package/build-module/image/utils.js +1 -0
  424. package/build-module/image/utils.js.map +1 -1
  425. package/build-module/image/view.js +1 -3
  426. package/build-module/image/view.js.map +1 -1
  427. package/build-module/index.js +2 -1
  428. package/build-module/index.js.map +1 -1
  429. package/build-module/index.native.js +1 -0
  430. package/build-module/index.native.js.map +1 -1
  431. package/build-module/latest-posts/deprecated.js +12 -0
  432. package/build-module/latest-posts/deprecated.js.map +1 -1
  433. package/build-module/latest-posts/edit.js +1 -0
  434. package/build-module/latest-posts/edit.js.map +1 -1
  435. package/build-module/latest-posts/index.js +12 -0
  436. package/build-module/latest-posts/index.js.map +1 -1
  437. package/build-module/list/transforms.js +1 -0
  438. package/build-module/list/transforms.js.map +1 -1
  439. package/build-module/list/utils.js +1 -0
  440. package/build-module/list/utils.js.map +1 -1
  441. package/build-module/list-item/hooks/use-indent-list-item.js +1 -0
  442. package/build-module/list-item/hooks/use-indent-list-item.js.map +1 -1
  443. package/build-module/list-item/transforms.js +1 -0
  444. package/build-module/list-item/transforms.js.map +1 -1
  445. package/build-module/loginout/edit.js +42 -14
  446. package/build-module/loginout/edit.js.map +1 -1
  447. package/build-module/media-text/edit.js +60 -31
  448. package/build-module/media-text/edit.js.map +1 -1
  449. package/build-module/more/edit.js +28 -8
  450. package/build-module/more/edit.js.map +1 -1
  451. package/build-module/more/save.js +1 -0
  452. package/build-module/more/save.js.map +1 -1
  453. package/build-module/navigation/deprecated.js +1 -0
  454. package/build-module/navigation/deprecated.js.map +1 -1
  455. package/build-module/navigation/edit/index.js +1 -0
  456. package/build-module/navigation/edit/index.js.map +1 -1
  457. package/build-module/navigation/edit/navigation-menu-selector.js +5 -3
  458. package/build-module/navigation/edit/navigation-menu-selector.js.map +1 -1
  459. package/build-module/navigation/edit/use-generate-default-navigation-title.js +1 -0
  460. package/build-module/navigation/edit/use-generate-default-navigation-title.js.map +1 -1
  461. package/build-module/navigation/menu-items-to-blocks.js +1 -0
  462. package/build-module/navigation/menu-items-to-blocks.js.map +1 -1
  463. package/build-module/navigation/use-template-part-area-label.js +1 -0
  464. package/build-module/navigation/use-template-part-area-label.js.map +1 -1
  465. package/build-module/navigation/view.js +1 -0
  466. package/build-module/navigation/view.js.map +1 -1
  467. package/build-module/navigation-link/edit.js +97 -58
  468. package/build-module/navigation-link/edit.js.map +1 -1
  469. package/build-module/navigation-link/hooks.js +1 -0
  470. package/build-module/navigation-link/hooks.js.map +1 -1
  471. package/build-module/navigation-link/link-ui.js +1 -1
  472. package/build-module/navigation-link/link-ui.js.map +1 -1
  473. package/build-module/navigation-submenu/edit.js +106 -55
  474. package/build-module/navigation-submenu/edit.js.map +1 -1
  475. package/build-module/page-list/edit.js +46 -26
  476. package/build-module/page-list/edit.js.map +1 -1
  477. package/build-module/page-list/use-convert-to-navigation-links.js +1 -0
  478. package/build-module/page-list/use-convert-to-navigation-links.js.map +1 -1
  479. package/build-module/paragraph/edit.js +23 -8
  480. package/build-module/paragraph/edit.js.map +1 -1
  481. package/build-module/pattern/edit.js +1 -0
  482. package/build-module/pattern/edit.js.map +1 -1
  483. package/build-module/post-author/edit.js +17 -4
  484. package/build-module/post-author/edit.js.map +1 -1
  485. package/build-module/post-author/index.js +4 -2
  486. package/build-module/post-author/index.js.map +1 -1
  487. package/build-module/post-author-name/edit.js +12 -6
  488. package/build-module/post-author-name/edit.js.map +1 -1
  489. package/build-module/post-author-name/index.js +4 -2
  490. package/build-module/post-author-name/index.js.map +1 -1
  491. package/build-module/post-comments-form/index.js +6 -1
  492. package/build-module/post-comments-form/index.js.map +1 -1
  493. package/build-module/post-comments-link/index.js +8 -1
  494. package/build-module/post-comments-link/index.js.map +1 -1
  495. package/build-module/post-date/edit.js +59 -19
  496. package/build-module/post-date/edit.js.map +1 -1
  497. package/build-module/post-date/index.js +2 -1
  498. package/build-module/post-date/index.js.map +1 -1
  499. package/build-module/post-excerpt/edit.js +44 -20
  500. package/build-module/post-excerpt/edit.js.map +1 -1
  501. package/build-module/post-featured-image/dimension-controls.js +19 -20
  502. package/build-module/post-featured-image/dimension-controls.js.map +1 -1
  503. package/build-module/post-featured-image/edit.js +47 -13
  504. package/build-module/post-featured-image/edit.js.map +1 -1
  505. package/build-module/post-featured-image/index.js +6 -3
  506. package/build-module/post-featured-image/index.js.map +1 -1
  507. package/build-module/post-navigation-link/edit.js +1 -0
  508. package/build-module/post-navigation-link/edit.js.map +1 -1
  509. package/build-module/post-navigation-link/index.js +12 -7
  510. package/build-module/post-navigation-link/index.js.map +1 -1
  511. package/build-module/post-navigation-link/variations.js +3 -2
  512. package/build-module/post-navigation-link/variations.js.map +1 -1
  513. package/build-module/post-template/edit.js +1 -0
  514. package/build-module/post-template/edit.js.map +1 -1
  515. package/build-module/post-template/index.js +12 -2
  516. package/build-module/post-template/index.js.map +1 -1
  517. package/build-module/post-terms/edit.js +1 -0
  518. package/build-module/post-terms/edit.js.map +1 -1
  519. package/build-module/post-terms/hooks.js +1 -0
  520. package/build-module/post-terms/hooks.js.map +1 -1
  521. package/build-module/post-title/index.js +6 -3
  522. package/build-module/post-title/index.js.map +1 -1
  523. package/build-module/pullquote/blockquote.native.js +1 -0
  524. package/build-module/pullquote/blockquote.native.js.map +1 -1
  525. package/build-module/pullquote/transforms.js +1 -0
  526. package/build-module/pullquote/transforms.js.map +1 -1
  527. package/build-module/query/deprecated.js +1 -0
  528. package/build-module/query/deprecated.js.map +1 -1
  529. package/build-module/query/edit/inspector-controls/author-control.js +1 -0
  530. package/build-module/query/edit/inspector-controls/author-control.js.map +1 -1
  531. package/build-module/query/edit/inspector-controls/format-controls.js +1 -0
  532. package/build-module/query/edit/inspector-controls/format-controls.js.map +1 -1
  533. package/build-module/query/edit/inspector-controls/index.js +1 -0
  534. package/build-module/query/edit/inspector-controls/index.js.map +1 -1
  535. package/build-module/query/edit/inspector-controls/parent-control.js +1 -0
  536. package/build-module/query/edit/inspector-controls/parent-control.js.map +1 -1
  537. package/build-module/query/edit/inspector-controls/taxonomy-controls.js +1 -0
  538. package/build-module/query/edit/inspector-controls/taxonomy-controls.js.map +1 -1
  539. package/build-module/query/utils.js +1 -0
  540. package/build-module/query/utils.js.map +1 -1
  541. package/build-module/query-no-results/index.js +11 -10
  542. package/build-module/query-no-results/index.js.map +1 -1
  543. package/build-module/query-pagination/edit.js +49 -19
  544. package/build-module/query-pagination/edit.js.map +1 -1
  545. package/build-module/query-pagination/query-pagination-label-control.js +1 -1
  546. package/build-module/query-pagination/query-pagination-label-control.js.map +1 -1
  547. package/build-module/query-pagination-numbers/edit.js +34 -16
  548. package/build-module/query-pagination-numbers/edit.js.map +1 -1
  549. package/build-module/query-title/variations.js +1 -0
  550. package/build-module/query-title/variations.js.map +1 -1
  551. package/build-module/query-total/edit.js +83 -0
  552. package/build-module/query-total/edit.js.map +1 -0
  553. package/build-module/query-total/icons.js +39 -0
  554. package/build-module/query-total/icons.js.map +1 -0
  555. package/build-module/query-total/index.js +74 -0
  556. package/build-module/query-total/index.js.map +1 -0
  557. package/build-module/query-total/init.js +6 -0
  558. package/build-module/query-total/init.js.map +1 -0
  559. package/build-module/quote/deprecated.js +1 -0
  560. package/build-module/quote/deprecated.js.map +1 -1
  561. package/build-module/quote/transforms.js +1 -0
  562. package/build-module/quote/transforms.js.map +1 -1
  563. package/build-module/read-more/index.js +7 -1
  564. package/build-module/read-more/index.js.map +1 -1
  565. package/build-module/site-logo/index.js +4 -2
  566. package/build-module/site-logo/index.js.map +1 -1
  567. package/build-module/site-title/edit.js +42 -13
  568. package/build-module/site-title/edit.js.map +1 -1
  569. package/build-module/site-title/index.js +4 -2
  570. package/build-module/site-title/index.js.map +1 -1
  571. package/build-module/social-link/edit.js +20 -4
  572. package/build-module/social-link/edit.js.map +1 -1
  573. package/build-module/social-link/social-list.js +1 -0
  574. package/build-module/social-link/social-list.js.map +1 -1
  575. package/build-module/social-link/variations.js +1 -0
  576. package/build-module/social-link/variations.js.map +1 -1
  577. package/build-module/social-links/edit.js +43 -13
  578. package/build-module/social-links/edit.js.map +1 -1
  579. package/build-module/social-links/edit.native.js +1 -0
  580. package/build-module/social-links/edit.native.js.map +1 -1
  581. package/build-module/spacer/controls.js +36 -13
  582. package/build-module/spacer/controls.js.map +1 -1
  583. package/build-module/table/deprecated.js +1 -0
  584. package/build-module/table/deprecated.js.map +1 -1
  585. package/build-module/table/edit.js +50 -16
  586. package/build-module/table/edit.js.map +1 -1
  587. package/build-module/table/index.js +4 -1
  588. package/build-module/table/index.js.map +1 -1
  589. package/build-module/table/save.js +1 -0
  590. package/build-module/table/save.js.map +1 -1
  591. package/build-module/table/state.js +1 -0
  592. package/build-module/table/state.js.map +1 -1
  593. package/build-module/table/transforms.js +1 -0
  594. package/build-module/table/transforms.js.map +1 -1
  595. package/build-module/table-of-contents/edit.js +1 -1
  596. package/build-module/table-of-contents/edit.js.map +1 -1
  597. package/build-module/table-of-contents/index.js +26 -25
  598. package/build-module/table-of-contents/index.js.map +1 -1
  599. package/build-module/table-of-contents/list.js +1 -0
  600. package/build-module/table-of-contents/list.js.map +1 -1
  601. package/build-module/table-of-contents/utils.js +1 -0
  602. package/build-module/table-of-contents/utils.js.map +1 -1
  603. package/build-module/tag-cloud/edit.js +58 -12
  604. package/build-module/tag-cloud/edit.js.map +1 -1
  605. package/build-module/template-part/edit/advanced-controls.js +1 -0
  606. package/build-module/template-part/edit/advanced-controls.js.map +1 -1
  607. package/build-module/template-part/edit/import-controls.js +1 -0
  608. package/build-module/template-part/edit/import-controls.js.map +1 -1
  609. package/build-module/template-part/edit/selection-modal.js +1 -0
  610. package/build-module/template-part/edit/selection-modal.js.map +1 -1
  611. package/build-module/template-part/edit/utils/hooks.js +1 -0
  612. package/build-module/template-part/edit/utils/hooks.js.map +1 -1
  613. package/build-module/template-part/edit/utils/transformers.js +1 -0
  614. package/build-module/template-part/edit/utils/transformers.js.map +1 -1
  615. package/build-module/template-part/variations.js +1 -0
  616. package/build-module/template-part/variations.js.map +1 -1
  617. package/build-module/text-columns/edit.js +1 -0
  618. package/build-module/text-columns/edit.js.map +1 -1
  619. package/build-module/text-columns/save.js +1 -0
  620. package/build-module/text-columns/save.js.map +1 -1
  621. package/build-module/text-columns/transforms.js +1 -0
  622. package/build-module/text-columns/transforms.js.map +1 -1
  623. package/build-module/utils/get-transformed-metadata.js +1 -0
  624. package/build-module/utils/get-transformed-metadata.js.map +1 -1
  625. package/build-module/utils/search-patterns.js +1 -0
  626. package/build-module/utils/search-patterns.js.map +1 -1
  627. package/build-module/utils/transformation-categories.native.js +1 -0
  628. package/build-module/utils/transformation-categories.native.js.map +1 -1
  629. package/build-module/video/edit-common-settings.js +91 -31
  630. package/build-module/video/edit-common-settings.js.map +1 -1
  631. package/build-module/video/edit.js +24 -53
  632. package/build-module/video/edit.js.map +1 -1
  633. package/build-module/video/poster-image.js +74 -0
  634. package/build-module/video/poster-image.js.map +1 -0
  635. package/build-module/video/tracks-editor.js +2 -1
  636. package/build-module/video/tracks-editor.js.map +1 -1
  637. package/build-module/video/tracks.js +1 -0
  638. package/build-module/video/tracks.js.map +1 -1
  639. package/build-style/button/style-rtl.css +3 -3
  640. package/build-style/button/style.css +3 -3
  641. package/build-style/comment-template/style-rtl.css +0 -1
  642. package/build-style/comment-template/style.css +0 -1
  643. package/build-style/comments/editor-rtl.css +1 -1
  644. package/build-style/comments/editor.css +1 -1
  645. package/build-style/comments/style-rtl.css +1 -1
  646. package/build-style/comments/style.css +1 -1
  647. package/build-style/common-rtl.css +17 -17
  648. package/build-style/common.css +17 -17
  649. package/build-style/editor-rtl.css +45 -60
  650. package/build-style/editor.css +45 -60
  651. package/build-style/form-input/style-rtl.css +0 -2
  652. package/build-style/form-input/style.css +0 -2
  653. package/build-style/freeform/editor-rtl.css +4 -8
  654. package/build-style/freeform/editor.css +4 -8
  655. package/build-style/gallery/style-rtl.css +2 -2
  656. package/build-style/gallery/style.css +2 -2
  657. package/build-style/heading/style-rtl.css +11 -11
  658. package/build-style/heading/style.css +11 -11
  659. package/build-style/image/style-rtl.css +1 -1
  660. package/build-style/image/style.css +1 -1
  661. package/build-style/latest-comments/style-rtl.css +4 -4
  662. package/build-style/latest-comments/style.css +4 -4
  663. package/build-style/latest-posts/style-rtl.css +2 -1
  664. package/build-style/latest-posts/style.css +2 -1
  665. package/build-style/more/editor-rtl.css +1 -1
  666. package/build-style/more/editor.css +1 -1
  667. package/build-style/nextpage/editor-rtl.css +1 -1
  668. package/build-style/nextpage/editor.css +1 -1
  669. package/build-style/post-comments-form/style-rtl.css +2 -2
  670. package/build-style/post-comments-form/style.css +2 -2
  671. package/build-style/{post-template/editor.css → post-comments-link/style-rtl.css} +2 -4
  672. package/build-style/{post-template/editor-rtl.css → post-comments-link/style.css} +2 -4
  673. package/build-style/post-featured-image/editor-rtl.css +27 -27
  674. package/build-style/post-featured-image/editor.css +27 -27
  675. package/build-style/post-template/style-rtl.css +1 -0
  676. package/build-style/post-template/style.css +1 -0
  677. package/build-style/query-total/style-rtl.css +103 -0
  678. package/build-style/query-total/style.css +103 -0
  679. package/build-style/read-more/style-rtl.css +2 -3
  680. package/build-style/read-more/style.css +2 -3
  681. package/build-style/social-link/editor-rtl.css +2 -2
  682. package/build-style/social-link/editor.css +2 -2
  683. package/build-style/social-links/editor-rtl.css +2 -2
  684. package/build-style/social-links/editor.css +2 -2
  685. package/build-style/social-links/style-rtl.css +2 -2
  686. package/build-style/social-links/style.css +2 -2
  687. package/build-style/style-rtl.css +59 -53
  688. package/build-style/style.css +59 -53
  689. package/build-style/tag-cloud/editor-rtl.css +0 -5
  690. package/build-style/tag-cloud/editor.css +0 -5
  691. package/build-style/text-columns/style-rtl.css +3 -3
  692. package/build-style/text-columns/style.css +3 -3
  693. package/package.json +36 -35
  694. package/src/archives/edit.js +94 -36
  695. package/src/audio/test/__snapshots__/edit.native.js.snap +1 -1
  696. package/src/block/index.php +20 -0
  697. package/src/button/block.json +17 -2
  698. package/src/button/deprecated.js +189 -0
  699. package/src/button/edit.js +61 -32
  700. package/src/button/save.js +6 -1
  701. package/src/column/edit.js +34 -13
  702. package/src/columns/edit.js +71 -40
  703. package/src/comments/index.js +1 -0
  704. package/src/cover/edit/index.js +12 -5
  705. package/src/cover/edit.native.js +5 -2
  706. package/src/cover/test/edit.js +5 -7
  707. package/src/details/edit.js +40 -11
  708. package/src/editor.scss +0 -1
  709. package/src/file/test/__snapshots__/edit.native.js.snap +1 -1
  710. package/src/form/block.json +1 -2
  711. package/src/form/index.php +1 -20
  712. package/src/form/view.js +18 -5
  713. package/src/image/image.js +1 -1
  714. package/src/image/index.php +1 -1
  715. package/src/image/transforms.js +1 -0
  716. package/src/image/view.js +1 -3
  717. package/src/index.js +2 -0
  718. package/src/latest-posts/block.json +12 -0
  719. package/src/latest-posts/style.scss +2 -1
  720. package/src/loginout/edit.js +56 -20
  721. package/src/media-text/edit.js +57 -28
  722. package/src/more/edit.js +39 -12
  723. package/src/navigation/edit/navigation-menu-selector.js +9 -2
  724. package/src/navigation/index.php +2 -2
  725. package/src/navigation-link/edit.js +101 -67
  726. package/src/navigation-link/index.php +16 -1
  727. package/src/navigation-link/link-ui.js +1 -1
  728. package/src/navigation-submenu/edit.js +113 -63
  729. package/src/page-list/edit.js +52 -31
  730. package/src/paragraph/edit.js +29 -5
  731. package/src/post-author/block.json +4 -2
  732. package/src/post-author/edit.js +17 -3
  733. package/src/post-author/index.php +4 -0
  734. package/src/post-author-name/block.json +4 -2
  735. package/src/post-author-name/edit.js +17 -4
  736. package/src/post-author-name/index.php +4 -0
  737. package/src/post-comments-form/block.json +6 -1
  738. package/src/post-comments-link/block.json +8 -1
  739. package/src/post-comments-link/style.scss +4 -0
  740. package/src/post-content/index.php +23 -0
  741. package/src/post-date/block.json +2 -1
  742. package/src/post-date/edit.js +79 -25
  743. package/src/post-excerpt/edit.js +59 -22
  744. package/src/post-featured-image/block.json +6 -3
  745. package/src/post-featured-image/dimension-controls.js +18 -21
  746. package/src/post-featured-image/edit.js +67 -10
  747. package/src/post-navigation-link/block.json +0 -6
  748. package/src/post-navigation-link/index.js +11 -0
  749. package/src/post-navigation-link/variations.js +2 -2
  750. package/src/post-template/block.json +12 -2
  751. package/src/post-template/style.scss +2 -0
  752. package/src/post-title/block.json +6 -3
  753. package/src/query-no-results/block.json +1 -11
  754. package/src/query-no-results/index.js +11 -0
  755. package/src/query-pagination/edit.js +57 -15
  756. package/src/query-pagination/query-pagination-label-control.js +1 -3
  757. package/src/query-pagination-numbers/edit.js +41 -19
  758. package/src/query-pagination-previous/index.php +21 -14
  759. package/src/query-total/block.json +52 -0
  760. package/src/query-total/edit.js +81 -0
  761. package/src/query-total/icons.js +43 -0
  762. package/src/query-total/index.js +18 -0
  763. package/src/query-total/index.php +88 -0
  764. package/src/query-total/init.js +6 -0
  765. package/src/query-total/style.scss +4 -0
  766. package/src/read-more/index.js +6 -0
  767. package/src/site-logo/block.json +4 -2
  768. package/src/site-title/block.json +4 -2
  769. package/src/site-title/edit.js +52 -15
  770. package/src/social-link/edit.js +21 -6
  771. package/src/social-links/edit.js +52 -15
  772. package/src/spacer/controls.js +42 -15
  773. package/src/style.scss +2 -0
  774. package/src/table/block.json +4 -1
  775. package/src/table/edit.js +58 -20
  776. package/src/table-of-contents/block.json +0 -52
  777. package/src/table-of-contents/edit.js +1 -1
  778. package/src/table-of-contents/index.js +53 -0
  779. package/src/tag-cloud/edit.js +60 -8
  780. package/src/tag-cloud/editor.scss +0 -8
  781. package/src/video/edit-common-settings.js +97 -39
  782. package/src/video/edit.js +29 -75
  783. package/src/video/poster-image.js +86 -0
  784. package/src/video/tracks-editor.js +1 -1
  785. package/tsconfig.json +0 -2
  786. package/tsconfig.tsbuildinfo +1 -1
  787. package/src/post-template/editor.scss +0 -7
@@ -85,6 +85,16 @@
85
85
  }
86
86
  },
87
87
  "typography": {
88
+ "__experimentalSkipSerialization": [
89
+ "fontSize",
90
+ "lineHeight",
91
+ "fontFamily",
92
+ "fontWeight",
93
+ "fontStyle",
94
+ "textTransform",
95
+ "textDecoration",
96
+ "letterSpacing"
97
+ ],
88
98
  "fontSize": true,
89
99
  "lineHeight": true,
90
100
  "__experimentalFontFamily": true,
@@ -122,7 +132,6 @@
122
132
  "width": true
123
133
  }
124
134
  },
125
- "__experimentalSelector": ".wp-block-button .wp-block-button__link",
126
135
  "interactivity": {
127
136
  "clientNavigation": true
128
137
  }
@@ -132,5 +141,11 @@
132
141
  { "name": "outline", "label": "Outline" }
133
142
  ],
134
143
  "editorStyle": "wp-block-button-editor",
135
- "style": "wp-block-button"
144
+ "style": "wp-block-button",
145
+ "selectors": {
146
+ "root": ".wp-block-button .wp-block-button__link",
147
+ "typography": {
148
+ "writingMode": ".wp-block-button"
149
+ }
150
+ }
136
151
  }
@@ -14,6 +14,8 @@ import {
14
14
  __experimentalGetBorderClassesAndStyles as getBorderClassesAndStyles,
15
15
  __experimentalGetColorClassesAndStyles as getColorClassesAndStyles,
16
16
  __experimentalGetSpacingClassesAndStyles as getSpacingClassesAndStyles,
17
+ __experimentalGetShadowClassesAndStyles as getShadowClassesAndStyles,
18
+ __experimentalGetElementClassName,
17
19
  } from '@wordpress/block-editor';
18
20
  import { compose } from '@wordpress/compose';
19
21
 
@@ -132,6 +134,192 @@ const blockAttributes = {
132
134
  },
133
135
  };
134
136
 
137
+ const v12 = {
138
+ attributes: {
139
+ tagName: {
140
+ type: 'string',
141
+ enum: [ 'a', 'button' ],
142
+ default: 'a',
143
+ },
144
+ type: {
145
+ type: 'string',
146
+ default: 'button',
147
+ },
148
+ textAlign: {
149
+ type: 'string',
150
+ },
151
+ url: {
152
+ type: 'string',
153
+ source: 'attribute',
154
+ selector: 'a',
155
+ attribute: 'href',
156
+ },
157
+ title: {
158
+ type: 'string',
159
+ source: 'attribute',
160
+ selector: 'a,button',
161
+ attribute: 'title',
162
+ role: 'content',
163
+ },
164
+ text: {
165
+ type: 'rich-text',
166
+ source: 'rich-text',
167
+ selector: 'a,button',
168
+ role: 'content',
169
+ },
170
+ linkTarget: {
171
+ type: 'string',
172
+ source: 'attribute',
173
+ selector: 'a',
174
+ attribute: 'target',
175
+ role: 'content',
176
+ },
177
+ rel: {
178
+ type: 'string',
179
+ source: 'attribute',
180
+ selector: 'a',
181
+ attribute: 'rel',
182
+ role: 'content',
183
+ },
184
+ placeholder: {
185
+ type: 'string',
186
+ },
187
+ backgroundColor: {
188
+ type: 'string',
189
+ },
190
+ textColor: {
191
+ type: 'string',
192
+ },
193
+ gradient: {
194
+ type: 'string',
195
+ },
196
+ width: {
197
+ type: 'number',
198
+ },
199
+ },
200
+ supports: {
201
+ anchor: true,
202
+ align: true,
203
+ alignWide: false,
204
+ color: {
205
+ __experimentalSkipSerialization: true,
206
+ gradients: true,
207
+ __experimentalDefaultControls: {
208
+ background: true,
209
+ text: true,
210
+ },
211
+ },
212
+ typography: {
213
+ fontSize: true,
214
+ lineHeight: true,
215
+ __experimentalFontFamily: true,
216
+ __experimentalFontWeight: true,
217
+ __experimentalFontStyle: true,
218
+ __experimentalTextTransform: true,
219
+ __experimentalTextDecoration: true,
220
+ __experimentalLetterSpacing: true,
221
+ __experimentalWritingMode: true,
222
+ __experimentalDefaultControls: {
223
+ fontSize: true,
224
+ },
225
+ },
226
+ reusable: false,
227
+ shadow: {
228
+ __experimentalSkipSerialization: true,
229
+ },
230
+ spacing: {
231
+ __experimentalSkipSerialization: true,
232
+ padding: [ 'horizontal', 'vertical' ],
233
+ __experimentalDefaultControls: {
234
+ padding: true,
235
+ },
236
+ },
237
+ __experimentalBorder: {
238
+ color: true,
239
+ radius: true,
240
+ style: true,
241
+ width: true,
242
+ __experimentalSkipSerialization: true,
243
+ __experimentalDefaultControls: {
244
+ color: true,
245
+ radius: true,
246
+ style: true,
247
+ width: true,
248
+ },
249
+ },
250
+ __experimentalSelector: '.wp-block-button__link',
251
+ interactivity: {
252
+ clientNavigation: true,
253
+ },
254
+ },
255
+ save( { attributes, className } ) {
256
+ const {
257
+ tagName,
258
+ type,
259
+ textAlign,
260
+ fontSize,
261
+ linkTarget,
262
+ rel,
263
+ style,
264
+ text,
265
+ title,
266
+ url,
267
+ width,
268
+ } = attributes;
269
+
270
+ const TagName = tagName || 'a';
271
+ const isButtonTag = 'button' === TagName;
272
+ const buttonType = type || 'button';
273
+ const borderProps = getBorderClassesAndStyles( attributes );
274
+ const colorProps = getColorClassesAndStyles( attributes );
275
+ const spacingProps = getSpacingClassesAndStyles( attributes );
276
+ const shadowProps = getShadowClassesAndStyles( attributes );
277
+ const buttonClasses = clsx(
278
+ 'wp-block-button__link',
279
+ colorProps.className,
280
+ borderProps.className,
281
+ {
282
+ [ `has-text-align-${ textAlign }` ]: textAlign,
283
+ // For backwards compatibility add style that isn't provided via
284
+ // block support.
285
+ 'no-border-radius': style?.border?.radius === 0,
286
+ },
287
+ __experimentalGetElementClassName( 'button' )
288
+ );
289
+ const buttonStyle = {
290
+ ...borderProps.style,
291
+ ...colorProps.style,
292
+ ...spacingProps.style,
293
+ ...shadowProps.style,
294
+ };
295
+
296
+ // The use of a `title` attribute here is soft-deprecated, but still applied
297
+ // if it had already been assigned, for the sake of backward-compatibility.
298
+ // A title will no longer be assigned for new or updated button block links.
299
+
300
+ const wrapperClasses = clsx( className, {
301
+ [ `has-custom-width wp-block-button__width-${ width }` ]: width,
302
+ [ `has-custom-font-size` ]: fontSize || style?.typography?.fontSize,
303
+ } );
304
+
305
+ return (
306
+ <div { ...useBlockProps.save( { className: wrapperClasses } ) }>
307
+ <RichText.Content
308
+ tagName={ TagName }
309
+ type={ isButtonTag ? buttonType : null }
310
+ className={ buttonClasses }
311
+ href={ isButtonTag ? null : url }
312
+ title={ title }
313
+ style={ buttonStyle }
314
+ value={ text }
315
+ target={ isButtonTag ? null : linkTarget }
316
+ rel={ isButtonTag ? null : rel }
317
+ />
318
+ </div>
319
+ );
320
+ },
321
+ };
322
+
135
323
  const v11 = {
136
324
  attributes: {
137
325
  url: {
@@ -399,6 +587,7 @@ const v10 = {
399
587
  };
400
588
 
401
589
  const deprecated = [
590
+ v12,
402
591
  v11,
403
592
  v10,
404
593
  {
@@ -9,6 +9,7 @@ import clsx from 'clsx';
9
9
  import { NEW_TAB_TARGET, NOFOLLOW_REL } from './constants';
10
10
  import { getUpdatedLinkAttributes } from './get-updated-link-attributes';
11
11
  import removeAnchorTag from '../utils/remove-anchor-tag';
12
+ import { useToolsPanelDropdownMenuProps } from '../utils/hooks';
12
13
 
13
14
  /**
14
15
  * WordPress dependencies
@@ -16,12 +17,13 @@ import removeAnchorTag from '../utils/remove-anchor-tag';
16
17
  import { __ } from '@wordpress/i18n';
17
18
  import { useEffect, useState, useRef, useMemo } from '@wordpress/element';
18
19
  import {
19
- Button,
20
- ButtonGroup,
21
- PanelBody,
22
20
  TextControl,
23
21
  ToolbarButton,
24
22
  Popover,
23
+ __experimentalToolsPanel as ToolsPanel,
24
+ __experimentalToolsPanelItem as ToolsPanelItem,
25
+ __experimentalToggleGroupControl as ToggleGroupControl,
26
+ __experimentalToggleGroupControlOption as ToggleGroupControlOption,
25
27
  } from '@wordpress/components';
26
28
  import {
27
29
  AlignmentControl,
@@ -29,14 +31,16 @@ import {
29
31
  InspectorControls,
30
32
  RichText,
31
33
  useBlockProps,
34
+ LinkControl,
32
35
  __experimentalUseBorderProps as useBorderProps,
33
36
  __experimentalUseColorProps as useColorProps,
34
37
  __experimentalGetSpacingClassesAndStyles as useSpacingProps,
35
38
  __experimentalGetShadowClassesAndStyles as useShadowProps,
36
- __experimentalLinkControl as LinkControl,
37
39
  __experimentalGetElementClassName,
38
40
  store as blockEditorStore,
39
41
  useBlockEditingMode,
42
+ getTypographyClassesAndStyles as useTypographyProps,
43
+ useSettings,
40
44
  } from '@wordpress/block-editor';
41
45
  import { displayShortcut, isKeyboardEvent, ENTER } from '@wordpress/keycodes';
42
46
  import { link, linkOff } from '@wordpress/icons';
@@ -114,35 +118,43 @@ function useEnter( props ) {
114
118
  }
115
119
 
116
120
  function WidthPanel( { selectedWidth, setAttributes } ) {
117
- function handleChange( newWidth ) {
118
- // Check if we are toggling the width off
119
- const width = selectedWidth === newWidth ? undefined : newWidth;
120
-
121
- // Update attributes.
122
- setAttributes( { width } );
123
- }
121
+ const dropdownMenuProps = useToolsPanelDropdownMenuProps();
124
122
 
125
123
  return (
126
- <PanelBody title={ __( 'Settings' ) }>
127
- <ButtonGroup aria-label={ __( 'Button width' ) }>
128
- { [ 25, 50, 75, 100 ].map( ( widthValue ) => {
129
- return (
130
- <Button
131
- key={ widthValue }
132
- size="small"
133
- variant={
134
- widthValue === selectedWidth
135
- ? 'primary'
136
- : undefined
137
- }
138
- onClick={ () => handleChange( widthValue ) }
139
- >
140
- { widthValue }%
141
- </Button>
142
- );
143
- } ) }
144
- </ButtonGroup>
145
- </PanelBody>
124
+ <ToolsPanel
125
+ label={ __( 'Settings' ) }
126
+ resetAll={ () => setAttributes( { width: undefined } ) }
127
+ dropdownMenuProps={ dropdownMenuProps }
128
+ >
129
+ <ToolsPanelItem
130
+ label={ __( 'Width' ) }
131
+ isShownByDefault
132
+ hasValue={ () => !! selectedWidth }
133
+ onDeselect={ () => setAttributes( { width: undefined } ) }
134
+ __nextHasNoMarginBottom
135
+ >
136
+ <ToggleGroupControl
137
+ label={ __( 'Width' ) }
138
+ value={ selectedWidth }
139
+ onChange={ ( newWidth ) =>
140
+ setAttributes( { width: newWidth } )
141
+ }
142
+ isBlock
143
+ __next40pxDefaultSize
144
+ __nextHasNoMarginBottom
145
+ >
146
+ { [ 25, 50, 75, 100 ].map( ( widthValue ) => {
147
+ return (
148
+ <ToggleGroupControlOption
149
+ key={ widthValue }
150
+ value={ widthValue }
151
+ label={ `${ widthValue }%` }
152
+ />
153
+ );
154
+ } ) }
155
+ </ToggleGroupControl>
156
+ </ToolsPanelItem>
157
+ </ToolsPanel>
146
158
  );
147
159
  }
148
160
 
@@ -256,6 +268,19 @@ function ButtonEdit( props ) {
256
268
  [ context, isSelected, metadata?.bindings?.url ]
257
269
  );
258
270
 
271
+ const [ fluidTypographySettings, layout ] = useSettings(
272
+ 'typography.fluid',
273
+ 'layout'
274
+ );
275
+ const typographyProps = useTypographyProps( attributes, {
276
+ typography: {
277
+ fluid: fluidTypographySettings,
278
+ },
279
+ layout: {
280
+ wideSize: layout?.wideSize,
281
+ },
282
+ } );
283
+
259
284
  return (
260
285
  <>
261
286
  <div
@@ -263,7 +288,6 @@ function ButtonEdit( props ) {
263
288
  className={ clsx( blockProps.className, {
264
289
  [ `has-custom-width wp-block-button__width-${ width }` ]:
265
290
  width,
266
- [ `has-custom-font-size` ]: blockProps.style.fontSize,
267
291
  } ) }
268
292
  >
269
293
  <RichText
@@ -282,11 +306,14 @@ function ButtonEdit( props ) {
282
306
  'wp-block-button__link',
283
307
  colorProps.className,
284
308
  borderProps.className,
309
+ typographyProps.className,
285
310
  {
286
311
  [ `has-text-align-${ textAlign }` ]: textAlign,
287
312
  // For backwards compatibility add style that isn't
288
313
  // provided via block support.
289
314
  'no-border-radius': style?.border?.radius === 0,
315
+ [ `has-custom-font-size` ]:
316
+ blockProps.style.fontSize,
290
317
  },
291
318
  __experimentalGetElementClassName( 'button' )
292
319
  ) }
@@ -295,6 +322,8 @@ function ButtonEdit( props ) {
295
322
  ...colorProps.style,
296
323
  ...spacingProps.style,
297
324
  ...shadowProps.style,
325
+ ...typographyProps.style,
326
+ writingMode: undefined,
298
327
  } }
299
328
  onReplace={ onReplace }
300
329
  onMerge={ mergeBlocks }
@@ -14,6 +14,7 @@ import {
14
14
  __experimentalGetSpacingClassesAndStyles as getSpacingClassesAndStyles,
15
15
  __experimentalGetShadowClassesAndStyles as getShadowClassesAndStyles,
16
16
  __experimentalGetElementClassName,
17
+ getTypographyClassesAndStyles,
17
18
  } from '@wordpress/block-editor';
18
19
 
19
20
  export default function save( { attributes, className } ) {
@@ -38,15 +39,18 @@ export default function save( { attributes, className } ) {
38
39
  const colorProps = getColorClassesAndStyles( attributes );
39
40
  const spacingProps = getSpacingClassesAndStyles( attributes );
40
41
  const shadowProps = getShadowClassesAndStyles( attributes );
42
+ const typographyProps = getTypographyClassesAndStyles( attributes );
41
43
  const buttonClasses = clsx(
42
44
  'wp-block-button__link',
43
45
  colorProps.className,
44
46
  borderProps.className,
47
+ typographyProps.className,
45
48
  {
46
49
  [ `has-text-align-${ textAlign }` ]: textAlign,
47
50
  // For backwards compatibility add style that isn't provided via
48
51
  // block support.
49
52
  'no-border-radius': style?.border?.radius === 0,
53
+ [ `has-custom-font-size` ]: fontSize || style?.typography?.fontSize,
50
54
  },
51
55
  __experimentalGetElementClassName( 'button' )
52
56
  );
@@ -55,6 +59,8 @@ export default function save( { attributes, className } ) {
55
59
  ...colorProps.style,
56
60
  ...spacingProps.style,
57
61
  ...shadowProps.style,
62
+ ...typographyProps.style,
63
+ writingMode: undefined,
58
64
  };
59
65
 
60
66
  // The use of a `title` attribute here is soft-deprecated, but still applied
@@ -63,7 +69,6 @@ export default function save( { attributes, className } ) {
63
69
 
64
70
  const wrapperClasses = clsx( className, {
65
71
  [ `has-custom-width wp-block-button__width-${ width }` ]: width,
66
- [ `has-custom-font-size` ]: fontSize || style?.typography?.fontSize,
67
72
  } );
68
73
 
69
74
  return (
@@ -18,31 +18,52 @@ import {
18
18
  } from '@wordpress/block-editor';
19
19
  import {
20
20
  __experimentalUseCustomUnits as useCustomUnits,
21
- PanelBody,
22
21
  __experimentalUnitControl as UnitControl,
22
+ __experimentalToolsPanel as ToolsPanel,
23
+ __experimentalToolsPanelItem as ToolsPanelItem,
23
24
  } from '@wordpress/components';
24
25
  import { useSelect, useDispatch } from '@wordpress/data';
25
26
  import { sprintf, __ } from '@wordpress/i18n';
26
27
 
28
+ /**
29
+ * Internal dependencies
30
+ */
31
+ import { useToolsPanelDropdownMenuProps } from '../utils/hooks';
32
+
27
33
  function ColumnInspectorControls( { width, setAttributes } ) {
28
34
  const [ availableUnits ] = useSettings( 'spacing.units' );
29
35
  const units = useCustomUnits( {
30
36
  availableUnits: availableUnits || [ '%', 'px', 'em', 'rem', 'vw' ],
31
37
  } );
38
+ const dropdownMenuProps = useToolsPanelDropdownMenuProps();
32
39
  return (
33
- <PanelBody title={ __( 'Settings' ) }>
34
- <UnitControl
40
+ <ToolsPanel
41
+ label={ __( 'Settings' ) }
42
+ resetAll={ () => {
43
+ setAttributes( { width: undefined } );
44
+ } }
45
+ dropdownMenuProps={ dropdownMenuProps }
46
+ >
47
+ <ToolsPanelItem
48
+ hasValue={ () => width !== undefined }
35
49
  label={ __( 'Width' ) }
36
- __unstableInputWidth="calc(50% - 8px)"
37
- __next40pxDefaultSize
38
- value={ width || '' }
39
- onChange={ ( nextWidth ) => {
40
- nextWidth = 0 > parseFloat( nextWidth ) ? '0' : nextWidth;
41
- setAttributes( { width: nextWidth } );
42
- } }
43
- units={ units }
44
- />
45
- </PanelBody>
50
+ onDeselect={ () => setAttributes( { width: undefined } ) }
51
+ isShownByDefault
52
+ >
53
+ <UnitControl
54
+ label={ __( 'Width' ) }
55
+ __unstableInputWidth="calc(50% - 8px)"
56
+ __next40pxDefaultSize
57
+ value={ width || '' }
58
+ onChange={ ( nextWidth ) => {
59
+ nextWidth =
60
+ 0 > parseFloat( nextWidth ) ? '0' : nextWidth;
61
+ setAttributes( { width: nextWidth } );
62
+ } }
63
+ units={ units }
64
+ />
65
+ </ToolsPanelItem>
66
+ </ToolsPanel>
46
67
  );
47
68
  }
48
69
 
@@ -9,9 +9,11 @@ import clsx from 'clsx';
9
9
  import { __ } from '@wordpress/i18n';
10
10
  import {
11
11
  Notice,
12
- PanelBody,
13
12
  RangeControl,
14
13
  ToggleControl,
14
+ __experimentalToolsPanel as ToolsPanel,
15
+ __experimentalToolsPanelItem as ToolsPanelItem,
16
+ __experimentalVStack as VStack,
15
17
  } from '@wordpress/components';
16
18
 
17
19
  import {
@@ -39,6 +41,7 @@ import {
39
41
  getRedistributedColumnWidths,
40
42
  toWidthPrecision,
41
43
  } from './utils';
44
+ import { useToolsPanelDropdownMenuProps } from '../utils/hooks';
42
45
 
43
46
  const DEFAULT_BLOCK = {
44
47
  name: 'core/column',
@@ -51,19 +54,15 @@ function ColumnInspectorControls( {
51
54
  } ) {
52
55
  const { count, canInsertColumnBlock, minCount } = useSelect(
53
56
  ( select ) => {
54
- const {
55
- canInsertBlockType,
56
- canRemoveBlock,
57
- getBlocks,
58
- getBlockCount,
59
- } = select( blockEditorStore );
60
- const innerBlocks = getBlocks( clientId );
57
+ const { canInsertBlockType, canRemoveBlock, getBlockOrder } =
58
+ select( blockEditorStore );
59
+ const blockOrder = getBlockOrder( clientId );
61
60
 
62
61
  // Get the indexes of columns for which removal is prevented.
63
62
  // The highest index will be used to determine the minimum column count.
64
- const preventRemovalBlockIndexes = innerBlocks.reduce(
65
- ( acc, block, index ) => {
66
- if ( ! canRemoveBlock( block.clientId ) ) {
63
+ const preventRemovalBlockIndexes = blockOrder.reduce(
64
+ ( acc, blockId, index ) => {
65
+ if ( ! canRemoveBlock( blockId ) ) {
67
66
  acc.push( index );
68
67
  }
69
68
  return acc;
@@ -72,7 +71,7 @@ function ColumnInspectorControls( {
72
71
  );
73
72
 
74
73
  return {
75
- count: getBlockCount( clientId ),
74
+ count: blockOrder.length,
76
75
  canInsertColumnBlock: canInsertBlockType(
77
76
  'core/column',
78
77
  clientId
@@ -148,41 +147,73 @@ function ColumnInspectorControls( {
148
147
  replaceInnerBlocks( clientId, innerBlocks );
149
148
  }
150
149
 
150
+ const dropdownMenuProps = useToolsPanelDropdownMenuProps();
151
+
151
152
  return (
152
- <PanelBody title={ __( 'Settings' ) }>
153
+ <ToolsPanel
154
+ label={ __( 'Settings' ) }
155
+ resetAll={ () => {
156
+ updateColumns( count, minCount );
157
+ setAttributes( {
158
+ isStackedOnMobile: true,
159
+ } );
160
+ } }
161
+ dropdownMenuProps={ dropdownMenuProps }
162
+ >
153
163
  { canInsertColumnBlock && (
154
- <>
155
- <RangeControl
156
- __nextHasNoMarginBottom
157
- __next40pxDefaultSize
158
- label={ __( 'Columns' ) }
159
- value={ count }
160
- onChange={ ( value ) =>
161
- updateColumns( count, Math.max( minCount, value ) )
162
- }
163
- min={ Math.max( 1, minCount ) }
164
- max={ Math.max( 6, count ) }
165
- />
166
- { count > 6 && (
167
- <Notice status="warning" isDismissible={ false }>
168
- { __(
169
- 'This column count exceeds the recommended amount and may cause visual breakage.'
170
- ) }
171
- </Notice>
172
- ) }
173
- </>
164
+ <ToolsPanelItem
165
+ label={ __( 'Columns' ) }
166
+ isShownByDefault
167
+ hasValue={ () => count }
168
+ onDeselect={ () => updateColumns( count, minCount ) }
169
+ >
170
+ <VStack spacing={ 4 }>
171
+ <RangeControl
172
+ __nextHasNoMarginBottom
173
+ __next40pxDefaultSize
174
+ label={ __( 'Columns' ) }
175
+ value={ count }
176
+ onChange={ ( value ) =>
177
+ updateColumns(
178
+ count,
179
+ Math.max( minCount, value )
180
+ )
181
+ }
182
+ min={ Math.max( 1, minCount ) }
183
+ max={ Math.max( 6, count ) }
184
+ />
185
+ { count > 6 && (
186
+ <Notice status="warning" isDismissible={ false }>
187
+ { __(
188
+ 'This column count exceeds the recommended amount and may cause visual breakage.'
189
+ ) }
190
+ </Notice>
191
+ ) }
192
+ </VStack>
193
+ </ToolsPanelItem>
174
194
  ) }
175
- <ToggleControl
176
- __nextHasNoMarginBottom
195
+ <ToolsPanelItem
177
196
  label={ __( 'Stack on mobile' ) }
178
- checked={ isStackedOnMobile }
179
- onChange={ () =>
197
+ isShownByDefault
198
+ hasValue={ () => isStackedOnMobile !== true }
199
+ onDeselect={ () =>
180
200
  setAttributes( {
181
- isStackedOnMobile: ! isStackedOnMobile,
201
+ isStackedOnMobile: true,
182
202
  } )
183
203
  }
184
- />
185
- </PanelBody>
204
+ >
205
+ <ToggleControl
206
+ __nextHasNoMarginBottom
207
+ label={ __( 'Stack on mobile' ) }
208
+ checked={ isStackedOnMobile }
209
+ onChange={ () =>
210
+ setAttributes( {
211
+ isStackedOnMobile: ! isStackedOnMobile,
212
+ } )
213
+ }
214
+ />
215
+ </ToolsPanelItem>
216
+ </ToolsPanel>
186
217
  );
187
218
  }
188
219
 
@@ -17,6 +17,7 @@ export { metadata, name };
17
17
 
18
18
  export const settings = {
19
19
  icon,
20
+ example: {},
20
21
  edit,
21
22
  save,
22
23
  deprecated,