@wordpress/block-library 9.48.1 → 10.0.1-next.v.202606191442.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 (480) hide show
  1. package/CHANGELOG.md +11 -0
  2. package/build/breadcrumbs/edit.cjs +1 -1
  3. package/build/breadcrumbs/edit.cjs.map +1 -1
  4. package/build/button/edit.cjs +1 -1
  5. package/build/button/edit.cjs.map +2 -2
  6. package/build/categories/edit.cjs +1 -1
  7. package/build/categories/edit.cjs.map +1 -1
  8. package/build/code/edit.cjs +1 -1
  9. package/build/code/edit.cjs.map +2 -2
  10. package/build/code/index.cjs +1 -1
  11. package/build/code/index.cjs.map +1 -1
  12. package/build/columns/utils.cjs.map +1 -1
  13. package/build/comments/edit/comments-legacy.cjs +1 -1
  14. package/build/comments/edit/comments-legacy.cjs.map +1 -1
  15. package/build/comments/edit/placeholder.cjs +4 -4
  16. package/build/comments/edit/placeholder.cjs.map +1 -1
  17. package/build/comments-pagination-next/edit.cjs +2 -2
  18. package/build/comments-pagination-next/edit.cjs.map +1 -1
  19. package/build/comments-pagination-previous/edit.cjs +2 -2
  20. package/build/comments-pagination-previous/edit.cjs.map +1 -1
  21. package/build/cover/deprecated.cjs +3 -3
  22. package/build/cover/deprecated.cjs.map +2 -2
  23. package/build/cover/edit/block-controls.cjs +13 -0
  24. package/build/cover/edit/block-controls.cjs.map +2 -2
  25. package/build/cover/edit/index.cjs +61 -2
  26. package/build/cover/edit/index.cjs.map +3 -3
  27. package/build/cover/edit/inspector-controls.cjs +93 -35
  28. package/build/cover/edit/inspector-controls.cjs.map +2 -2
  29. package/build/details/edit.cjs +1 -1
  30. package/build/details/edit.cjs.map +2 -2
  31. package/build/embed/embed-placeholder.cjs +1 -1
  32. package/build/embed/embed-placeholder.cjs.map +2 -2
  33. package/build/file/edit.cjs +3 -11
  34. package/build/file/edit.cjs.map +2 -2
  35. package/build/file/index.cjs +3 -1
  36. package/build/file/index.cjs.map +3 -3
  37. package/build/file/transforms.cjs +11 -32
  38. package/build/file/transforms.cjs.map +2 -2
  39. package/build/file/variations.cjs +38 -0
  40. package/build/file/variations.cjs.map +7 -0
  41. package/build/footnotes/edit.cjs +1 -1
  42. package/build/footnotes/edit.cjs.map +2 -2
  43. package/build/form-input/edit.cjs +1 -1
  44. package/build/form-input/edit.cjs.map +2 -2
  45. package/build/freeform/edit.cjs +1 -1
  46. package/build/freeform/edit.cjs.map +1 -1
  47. package/build/gallery/edit.cjs +2 -2
  48. package/build/gallery/edit.cjs.map +2 -2
  49. package/build/home-link/edit.cjs +1 -1
  50. package/build/home-link/edit.cjs.map +2 -2
  51. package/build/html/index.cjs +1 -1
  52. package/build/html/index.cjs.map +2 -2
  53. package/build/html/modal.cjs +3 -3
  54. package/build/html/modal.cjs.map +2 -2
  55. package/build/icon/block.json +12 -0
  56. package/build/icon/edit.cjs +90 -39
  57. package/build/icon/edit.cjs.map +3 -3
  58. package/build/icon/index.cjs +3 -1
  59. package/build/icon/index.cjs.map +3 -3
  60. package/build/{tab/save.cjs → icon/variations.cjs} +14 -15
  61. package/build/icon/variations.cjs.map +7 -0
  62. package/build/image/block.json +1 -0
  63. package/build/image/edit.cjs +4 -3
  64. package/build/image/edit.cjs.map +2 -2
  65. package/build/image/image.cjs +91 -27
  66. package/build/image/image.cjs.map +2 -2
  67. package/build/image/index.cjs +1 -1
  68. package/build/image/index.cjs.map +2 -2
  69. package/build/image/transforms.cjs +9 -3
  70. package/build/image/transforms.cjs.map +2 -2
  71. package/build/index.cjs +1 -3
  72. package/build/index.cjs.map +2 -2
  73. package/build/latest-posts/edit.cjs +1 -1
  74. package/build/latest-posts/edit.cjs.map +1 -1
  75. package/build/math/edit.cjs +1 -1
  76. package/build/math/index.cjs +1 -1
  77. package/build/math/index.cjs.map +1 -1
  78. package/build/media-text/constants.cjs +1 -1
  79. package/build/media-text/constants.cjs.map +2 -2
  80. package/build/media-text/index.cjs +1 -1
  81. package/build/media-text/index.cjs.map +2 -2
  82. package/build/missing/edit.cjs +2 -2
  83. package/build/missing/edit.cjs.map +1 -1
  84. package/build/navigation/edit/index.cjs +14 -8
  85. package/build/navigation/edit/index.cjs.map +2 -2
  86. package/build/navigation/edit/navigation-menu-selector.cjs +1 -1
  87. package/build/navigation/edit/navigation-menu-selector.cjs.map +2 -2
  88. package/build/navigation/edit/placeholder/index.cjs +1 -1
  89. package/build/navigation/edit/placeholder/index.cjs.map +2 -2
  90. package/build/navigation-link/edit.cjs +1 -1
  91. package/build/navigation-link/edit.cjs.map +2 -2
  92. package/build/navigation-submenu/block.json +7 -0
  93. package/build/navigation-submenu/edit.cjs +1 -1
  94. package/build/navigation-submenu/edit.cjs.map +2 -2
  95. package/build/page-list/block.json +2 -5
  96. package/build/page-list/edit.cjs +1 -11
  97. package/build/page-list/edit.cjs.map +2 -2
  98. package/build/post-author/edit.cjs +1 -1
  99. package/build/post-author/edit.cjs.map +2 -2
  100. package/build/post-author/utils.cjs +1 -1
  101. package/build/post-author/utils.cjs.map +2 -2
  102. package/build/post-date/edit.cjs +2 -2
  103. package/build/post-date/edit.cjs.map +2 -2
  104. package/build/post-excerpt/edit.cjs +2 -2
  105. package/build/post-excerpt/edit.cjs.map +2 -2
  106. package/build/post-featured-image/block.json +1 -0
  107. package/build/post-featured-image/dimension-controls.cjs +90 -178
  108. package/build/post-featured-image/dimension-controls.cjs.map +3 -3
  109. package/build/post-featured-image/edit.cjs +47 -17
  110. package/build/post-featured-image/edit.cjs.map +2 -2
  111. package/build/post-navigation-link/edit.cjs +2 -2
  112. package/build/post-navigation-link/edit.cjs.map +2 -2
  113. package/build/post-time-to-read/edit.cjs +1 -1
  114. package/build/post-time-to-read/edit.cjs.map +1 -1
  115. package/build/preformatted/edit.cjs +1 -1
  116. package/build/preformatted/edit.cjs.map +2 -2
  117. package/build/pullquote/block.json +1 -3
  118. package/build/pullquote/deprecated.cjs +114 -9
  119. package/build/pullquote/deprecated.cjs.map +3 -3
  120. package/build/pullquote/edit.cjs +43 -61
  121. package/build/pullquote/edit.cjs.map +3 -3
  122. package/build/pullquote/save.cjs +5 -26
  123. package/build/pullquote/save.cjs.map +3 -3
  124. package/build/query/edit/inspector-controls/enhanced-pagination-control.cjs +1 -1
  125. package/build/query/edit/inspector-controls/enhanced-pagination-control.cjs.map +1 -1
  126. package/build/query/edit/inspector-controls/order-control.cjs +2 -2
  127. package/build/query/edit/inspector-controls/order-control.cjs.map +2 -2
  128. package/build/query/utils.cjs +2 -2
  129. package/build/query/utils.cjs.map +2 -2
  130. package/build/query-pagination-next/edit.cjs +2 -2
  131. package/build/query-pagination-next/edit.cjs.map +1 -1
  132. package/build/query-pagination-previous/edit.cjs +2 -2
  133. package/build/query-pagination-previous/edit.cjs.map +1 -1
  134. package/build/query-title/edit.cjs +1 -1
  135. package/build/query-title/edit.cjs.map +2 -2
  136. package/build/query-total/edit.cjs +1 -1
  137. package/build/query-total/edit.cjs.map +2 -2
  138. package/build/quote/index.cjs +1 -1
  139. package/build/quote/index.cjs.map +2 -2
  140. package/build/read-more/edit.cjs +1 -1
  141. package/build/read-more/edit.cjs.map +2 -2
  142. package/build/rss/edit.cjs +1 -1
  143. package/build/rss/edit.cjs.map +2 -2
  144. package/build/search/edit.cjs +3 -3
  145. package/build/search/edit.cjs.map +2 -2
  146. package/build/shortcode/edit.cjs +1 -1
  147. package/build/shortcode/edit.cjs.map +2 -2
  148. package/build/site-tagline/edit.cjs +1 -1
  149. package/build/site-tagline/edit.cjs.map +2 -2
  150. package/build/site-title/edit.cjs +1 -1
  151. package/build/site-title/edit.cjs.map +2 -2
  152. package/build/tab-list/block.json +34 -21
  153. package/build/tab-list/edit.cjs +116 -12
  154. package/build/tab-list/edit.cjs.map +3 -3
  155. package/build/tab-list/save.cjs +33 -3
  156. package/build/tab-list/save.cjs.map +3 -3
  157. package/build/tab-panel/add-tab-toolbar-control.cjs +19 -8
  158. package/build/tab-panel/add-tab-toolbar-control.cjs.map +2 -2
  159. package/build/tab-panel/block.json +2 -6
  160. package/build/tab-panel/remove-tab-toolbar-control.cjs +9 -14
  161. package/build/tab-panel/remove-tab-toolbar-control.cjs.map +2 -2
  162. package/build/tab-panels/block.json +2 -27
  163. package/build/table/index.cjs +1 -1
  164. package/build/table/index.cjs.map +2 -2
  165. package/build/tabs/block.json +3 -17
  166. package/build/tabs/edit.cjs +7 -21
  167. package/build/tabs/edit.cjs.map +3 -3
  168. package/build/tabs/index.cjs +6 -10
  169. package/build/tabs/index.cjs.map +2 -2
  170. package/build/tabs/use-tab-list-items-sync.cjs +53 -0
  171. package/build/tabs/use-tab-list-items-sync.cjs.map +7 -0
  172. package/build/tabs/view.cjs +2 -10
  173. package/build/tabs/view.cjs.map +2 -2
  174. package/build/terms-query/edit/inspector-controls/order-control.cjs +2 -2
  175. package/build/terms-query/edit/inspector-controls/order-control.cjs.map +2 -2
  176. package/build/utils/style-state.cjs +164 -0
  177. package/build/utils/style-state.cjs.map +7 -0
  178. package/build/utils/waveform-player.cjs +1 -1
  179. package/build/verse/edit.cjs +1 -1
  180. package/build/verse/edit.cjs.map +2 -2
  181. package/build-module/breadcrumbs/edit.mjs +1 -1
  182. package/build-module/breadcrumbs/edit.mjs.map +1 -1
  183. package/build-module/button/edit.mjs +1 -1
  184. package/build-module/button/edit.mjs.map +2 -2
  185. package/build-module/categories/edit.mjs +1 -1
  186. package/build-module/categories/edit.mjs.map +1 -1
  187. package/build-module/code/edit.mjs +1 -1
  188. package/build-module/code/edit.mjs.map +2 -2
  189. package/build-module/code/index.mjs +1 -1
  190. package/build-module/code/index.mjs.map +1 -1
  191. package/build-module/columns/utils.mjs.map +1 -1
  192. package/build-module/comments/edit/comments-legacy.mjs +1 -1
  193. package/build-module/comments/edit/comments-legacy.mjs.map +1 -1
  194. package/build-module/comments/edit/placeholder.mjs +4 -4
  195. package/build-module/comments/edit/placeholder.mjs.map +1 -1
  196. package/build-module/comments-pagination-next/edit.mjs +2 -2
  197. package/build-module/comments-pagination-next/edit.mjs.map +1 -1
  198. package/build-module/comments-pagination-previous/edit.mjs +2 -2
  199. package/build-module/comments-pagination-previous/edit.mjs.map +1 -1
  200. package/build-module/cover/deprecated.mjs +3 -3
  201. package/build-module/cover/deprecated.mjs.map +2 -2
  202. package/build-module/cover/edit/block-controls.mjs +15 -2
  203. package/build-module/cover/edit/block-controls.mjs.map +2 -2
  204. package/build-module/cover/edit/index.mjs +64 -3
  205. package/build-module/cover/edit/index.mjs.map +2 -2
  206. package/build-module/cover/edit/inspector-controls.mjs +98 -35
  207. package/build-module/cover/edit/inspector-controls.mjs.map +2 -2
  208. package/build-module/details/edit.mjs +1 -1
  209. package/build-module/details/edit.mjs.map +2 -2
  210. package/build-module/embed/embed-placeholder.mjs +1 -1
  211. package/build-module/embed/embed-placeholder.mjs.map +2 -2
  212. package/build-module/file/edit.mjs +5 -13
  213. package/build-module/file/edit.mjs.map +2 -2
  214. package/build-module/file/index.mjs +3 -1
  215. package/build-module/file/index.mjs.map +2 -2
  216. package/build-module/file/transforms.mjs +11 -32
  217. package/build-module/file/transforms.mjs.map +2 -2
  218. package/build-module/file/variations.mjs +17 -0
  219. package/build-module/file/variations.mjs.map +7 -0
  220. package/build-module/footnotes/edit.mjs +1 -1
  221. package/build-module/footnotes/edit.mjs.map +2 -2
  222. package/build-module/form-input/edit.mjs +1 -1
  223. package/build-module/form-input/edit.mjs.map +2 -2
  224. package/build-module/freeform/edit.mjs +1 -1
  225. package/build-module/freeform/edit.mjs.map +1 -1
  226. package/build-module/gallery/edit.mjs +2 -2
  227. package/build-module/gallery/edit.mjs.map +2 -2
  228. package/build-module/home-link/edit.mjs +1 -1
  229. package/build-module/home-link/edit.mjs.map +2 -2
  230. package/build-module/html/index.mjs +1 -1
  231. package/build-module/html/index.mjs.map +2 -2
  232. package/build-module/html/modal.mjs +3 -3
  233. package/build-module/html/modal.mjs.map +2 -2
  234. package/build-module/icon/block.json +12 -0
  235. package/build-module/icon/edit.mjs +94 -40
  236. package/build-module/icon/edit.mjs.map +2 -2
  237. package/build-module/icon/index.mjs +3 -1
  238. package/build-module/icon/index.mjs.map +2 -2
  239. package/build-module/icon/variations.mjs +13 -0
  240. package/build-module/icon/variations.mjs.map +7 -0
  241. package/build-module/image/block.json +1 -0
  242. package/build-module/image/edit.mjs +4 -3
  243. package/build-module/image/edit.mjs.map +2 -2
  244. package/build-module/image/image.mjs +96 -27
  245. package/build-module/image/image.mjs.map +2 -2
  246. package/build-module/image/index.mjs +1 -1
  247. package/build-module/image/index.mjs.map +2 -2
  248. package/build-module/image/transforms.mjs +9 -3
  249. package/build-module/image/transforms.mjs.map +2 -2
  250. package/build-module/index.mjs +1 -3
  251. package/build-module/index.mjs.map +2 -2
  252. package/build-module/latest-posts/edit.mjs +1 -1
  253. package/build-module/latest-posts/edit.mjs.map +1 -1
  254. package/build-module/math/edit.mjs +1 -1
  255. package/build-module/math/index.mjs +1 -1
  256. package/build-module/math/index.mjs.map +1 -1
  257. package/build-module/media-text/constants.mjs +1 -1
  258. package/build-module/media-text/constants.mjs.map +2 -2
  259. package/build-module/media-text/index.mjs +1 -1
  260. package/build-module/media-text/index.mjs.map +2 -2
  261. package/build-module/missing/edit.mjs +2 -2
  262. package/build-module/missing/edit.mjs.map +1 -1
  263. package/build-module/navigation/edit/index.mjs +14 -8
  264. package/build-module/navigation/edit/index.mjs.map +2 -2
  265. package/build-module/navigation/edit/navigation-menu-selector.mjs +1 -1
  266. package/build-module/navigation/edit/navigation-menu-selector.mjs.map +2 -2
  267. package/build-module/navigation/edit/placeholder/index.mjs +1 -1
  268. package/build-module/navigation/edit/placeholder/index.mjs.map +2 -2
  269. package/build-module/navigation-link/edit.mjs +1 -1
  270. package/build-module/navigation-link/edit.mjs.map +2 -2
  271. package/build-module/navigation-submenu/block.json +7 -0
  272. package/build-module/navigation-submenu/edit.mjs +1 -1
  273. package/build-module/navigation-submenu/edit.mjs.map +2 -2
  274. package/build-module/page-list/block.json +2 -5
  275. package/build-module/page-list/edit.mjs +1 -11
  276. package/build-module/page-list/edit.mjs.map +2 -2
  277. package/build-module/post-author/edit.mjs +1 -1
  278. package/build-module/post-author/edit.mjs.map +2 -2
  279. package/build-module/post-author/utils.mjs +1 -1
  280. package/build-module/post-author/utils.mjs.map +2 -2
  281. package/build-module/post-date/edit.mjs +2 -2
  282. package/build-module/post-date/edit.mjs.map +2 -2
  283. package/build-module/post-excerpt/edit.mjs +2 -2
  284. package/build-module/post-excerpt/edit.mjs.map +2 -2
  285. package/build-module/post-featured-image/block.json +1 -0
  286. package/build-module/post-featured-image/dimension-controls.mjs +99 -187
  287. package/build-module/post-featured-image/dimension-controls.mjs.map +2 -2
  288. package/build-module/post-featured-image/edit.mjs +47 -17
  289. package/build-module/post-featured-image/edit.mjs.map +2 -2
  290. package/build-module/post-navigation-link/edit.mjs +2 -2
  291. package/build-module/post-navigation-link/edit.mjs.map +2 -2
  292. package/build-module/post-time-to-read/edit.mjs +1 -1
  293. package/build-module/post-time-to-read/edit.mjs.map +1 -1
  294. package/build-module/preformatted/edit.mjs +1 -1
  295. package/build-module/preformatted/edit.mjs.map +2 -2
  296. package/build-module/pullquote/block.json +1 -3
  297. package/build-module/pullquote/deprecated.mjs +114 -9
  298. package/build-module/pullquote/deprecated.mjs.map +2 -2
  299. package/build-module/pullquote/edit.mjs +44 -67
  300. package/build-module/pullquote/edit.mjs.map +2 -2
  301. package/build-module/pullquote/save.mjs +5 -16
  302. package/build-module/pullquote/save.mjs.map +2 -2
  303. package/build-module/query/edit/inspector-controls/enhanced-pagination-control.mjs +1 -1
  304. package/build-module/query/edit/inspector-controls/enhanced-pagination-control.mjs.map +1 -1
  305. package/build-module/query/edit/inspector-controls/order-control.mjs +2 -2
  306. package/build-module/query/edit/inspector-controls/order-control.mjs.map +2 -2
  307. package/build-module/query/utils.mjs +2 -2
  308. package/build-module/query/utils.mjs.map +2 -2
  309. package/build-module/query-pagination-next/edit.mjs +2 -2
  310. package/build-module/query-pagination-next/edit.mjs.map +1 -1
  311. package/build-module/query-pagination-previous/edit.mjs +2 -2
  312. package/build-module/query-pagination-previous/edit.mjs.map +1 -1
  313. package/build-module/query-title/edit.mjs +1 -1
  314. package/build-module/query-title/edit.mjs.map +2 -2
  315. package/build-module/query-total/edit.mjs +1 -1
  316. package/build-module/query-total/edit.mjs.map +2 -2
  317. package/build-module/quote/index.mjs +1 -1
  318. package/build-module/quote/index.mjs.map +2 -2
  319. package/build-module/read-more/edit.mjs +1 -1
  320. package/build-module/read-more/edit.mjs.map +2 -2
  321. package/build-module/rss/edit.mjs +1 -1
  322. package/build-module/rss/edit.mjs.map +2 -2
  323. package/build-module/search/edit.mjs +3 -3
  324. package/build-module/search/edit.mjs.map +2 -2
  325. package/build-module/shortcode/edit.mjs +1 -1
  326. package/build-module/shortcode/edit.mjs.map +2 -2
  327. package/build-module/site-tagline/edit.mjs +1 -1
  328. package/build-module/site-tagline/edit.mjs.map +2 -2
  329. package/build-module/site-title/edit.mjs +1 -1
  330. package/build-module/site-title/edit.mjs.map +2 -2
  331. package/build-module/tab-list/block.json +34 -21
  332. package/build-module/tab-list/edit.mjs +122 -15
  333. package/build-module/tab-list/edit.mjs.map +2 -2
  334. package/build-module/tab-list/save.mjs +29 -4
  335. package/build-module/tab-list/save.mjs.map +2 -2
  336. package/build-module/tab-panel/add-tab-toolbar-control.mjs +19 -8
  337. package/build-module/tab-panel/add-tab-toolbar-control.mjs.map +2 -2
  338. package/build-module/tab-panel/block.json +2 -6
  339. package/build-module/tab-panel/remove-tab-toolbar-control.mjs +9 -14
  340. package/build-module/tab-panel/remove-tab-toolbar-control.mjs.map +2 -2
  341. package/build-module/tab-panels/block.json +2 -27
  342. package/build-module/table/index.mjs +1 -1
  343. package/build-module/table/index.mjs.map +2 -2
  344. package/build-module/tabs/block.json +3 -17
  345. package/build-module/tabs/edit.mjs +7 -21
  346. package/build-module/tabs/edit.mjs.map +2 -2
  347. package/build-module/tabs/index.mjs +6 -10
  348. package/build-module/tabs/index.mjs.map +2 -2
  349. package/build-module/tabs/use-tab-list-items-sync.mjs +32 -0
  350. package/build-module/tabs/use-tab-list-items-sync.mjs.map +7 -0
  351. package/build-module/tabs/view.mjs +2 -10
  352. package/build-module/tabs/view.mjs.map +2 -2
  353. package/build-module/terms-query/edit/inspector-controls/order-control.mjs +2 -2
  354. package/build-module/terms-query/edit/inspector-controls/order-control.mjs.map +2 -2
  355. package/build-module/utils/style-state.mjs +132 -0
  356. package/build-module/utils/style-state.mjs.map +7 -0
  357. package/build-module/utils/waveform-player.mjs +1 -1
  358. package/build-module/verse/edit.mjs +1 -1
  359. package/build-module/verse/edit.mjs.map +2 -2
  360. package/build-style/editor-rtl.css +12 -16
  361. package/build-style/editor.css +12 -16
  362. package/build-style/icon/style-rtl.css +9 -0
  363. package/build-style/icon/style.css +9 -0
  364. package/build-style/style-rtl.css +11 -24
  365. package/build-style/style.css +11 -24
  366. package/build-style/tab-list/editor-rtl.css +12 -4
  367. package/build-style/tab-list/editor.css +12 -4
  368. package/build-style/{tab → tab-list}/style-rtl.css +2 -2
  369. package/build-style/{tab → tab-list}/style.css +2 -2
  370. package/build-style/tab-panel/style-rtl.css +0 -17
  371. package/build-style/tab-panel/style.css +0 -17
  372. package/package.json +48 -45
  373. package/src/avatar/index.php +2 -2
  374. package/src/block/index.php +2 -26
  375. package/src/comment-author-avatar/index.php +3 -3
  376. package/src/comment-author-name/index.php +1 -1
  377. package/src/comment-date/index.php +1 -1
  378. package/src/cover/edit/block-controls.js +14 -2
  379. package/src/cover/edit/index.js +86 -0
  380. package/src/cover/edit/inspector-controls.js +124 -54
  381. package/src/editor.scss +0 -1
  382. package/src/file/edit.js +3 -16
  383. package/src/file/index.js +2 -0
  384. package/src/file/transforms.js +12 -31
  385. package/src/file/variations.js +17 -0
  386. package/src/gallery/edit.js +13 -13
  387. package/src/icon/README.md +3 -0
  388. package/src/icon/block.json +12 -0
  389. package/src/icon/edit.js +86 -36
  390. package/src/icon/index.js +3 -1
  391. package/src/icon/index.php +23 -0
  392. package/src/icon/style.scss +12 -0
  393. package/src/icon/variations.js +9 -0
  394. package/src/image/README.md +1 -0
  395. package/src/image/block.json +1 -0
  396. package/src/image/edit.js +8 -3
  397. package/src/image/image.js +120 -54
  398. package/src/image/index.php +0 -1
  399. package/src/image/transforms.js +34 -8
  400. package/src/index.js +4 -11
  401. package/src/navigation/edit/index.js +23 -10
  402. package/src/navigation/index.php +58 -0
  403. package/src/navigation-submenu/README.md +5 -0
  404. package/src/navigation-submenu/block.json +7 -0
  405. package/src/page-list/README.md +1 -1
  406. package/src/page-list/block.json +2 -5
  407. package/src/page-list/edit.js +0 -11
  408. package/src/page-list/index.php +1 -1
  409. package/src/post-date/edit.js +2 -2
  410. package/src/post-featured-image/README.md +1 -0
  411. package/src/post-featured-image/block.json +1 -0
  412. package/src/post-featured-image/dimension-controls.js +105 -184
  413. package/src/post-featured-image/edit.js +53 -21
  414. package/src/post-featured-image/index.php +24 -22
  415. package/src/pullquote/README.md +1 -1
  416. package/src/pullquote/block.json +1 -3
  417. package/src/pullquote/deprecated.js +121 -9
  418. package/src/pullquote/edit.js +7 -31
  419. package/src/pullquote/save.js +2 -13
  420. package/src/search/index.php +1 -1
  421. package/src/style.scss +1 -2
  422. package/src/tab-list/README.md +19 -17
  423. package/src/tab-list/block.json +34 -21
  424. package/src/tab-list/edit.js +147 -15
  425. package/src/tab-list/editor.scss +13 -6
  426. package/src/tab-list/index.php +23 -30
  427. package/src/tab-list/save.js +39 -4
  428. package/src/{tab → tab-list}/style.scss +1 -1
  429. package/src/tab-panel/README.md +0 -3
  430. package/src/tab-panel/add-tab-toolbar-control.js +24 -11
  431. package/src/tab-panel/block.json +2 -6
  432. package/src/tab-panel/remove-tab-toolbar-control.js +10 -14
  433. package/src/tab-panel/style.scss +0 -17
  434. package/src/tab-panels/README.md +0 -16
  435. package/src/tab-panels/block.json +2 -27
  436. package/src/tabs/README.md +1 -7
  437. package/src/tabs/block.json +3 -17
  438. package/src/tabs/edit.js +8 -19
  439. package/src/tabs/index.js +6 -10
  440. package/src/tabs/index.php +0 -13
  441. package/src/tabs/use-tab-list-items-sync.js +49 -0
  442. package/src/tabs/view.js +2 -10
  443. package/src/utils/style-state.js +151 -0
  444. package/src/utils/test/style-state.js +307 -0
  445. package/babel-plugin.cjs +0 -150
  446. package/build/tab/block.json +0 -56
  447. package/build/tab/controls.cjs +0 -46
  448. package/build/tab/controls.cjs.map +0 -7
  449. package/build/tab/edit.cjs +0 -135
  450. package/build/tab/edit.cjs.map +0 -7
  451. package/build/tab/index.cjs +0 -58
  452. package/build/tab/index.cjs.map +0 -7
  453. package/build/tab/save.cjs.map +0 -7
  454. package/build/tabs/use-tab-list-sync.cjs +0 -190
  455. package/build/tabs/use-tab-list-sync.cjs.map +0 -7
  456. package/build-module/tab/block.json +0 -56
  457. package/build-module/tab/controls.mjs +0 -15
  458. package/build-module/tab/controls.mjs.map +0 -7
  459. package/build-module/tab/edit.mjs +0 -108
  460. package/build-module/tab/edit.mjs.map +0 -7
  461. package/build-module/tab/index.mjs +0 -20
  462. package/build-module/tab/index.mjs.map +0 -7
  463. package/build-module/tab/save.mjs +0 -14
  464. package/build-module/tab/save.mjs.map +0 -7
  465. package/build-module/tabs/use-tab-list-sync.mjs +0 -169
  466. package/build-module/tabs/use-tab-list-sync.mjs.map +0 -7
  467. package/build-style/tab/editor-rtl.css +0 -11
  468. package/build-style/tab/editor.css +0 -11
  469. package/build-style/tab-panels/style-rtl.css +0 -4
  470. package/build-style/tab-panels/style.css +0 -4
  471. package/src/tab/README.md +0 -69
  472. package/src/tab/block.json +0 -56
  473. package/src/tab/controls.js +0 -19
  474. package/src/tab/edit.js +0 -141
  475. package/src/tab/editor.scss +0 -14
  476. package/src/tab/index.js +0 -24
  477. package/src/tab/index.php +0 -70
  478. package/src/tab/save.js +0 -13
  479. package/src/tab-panels/style.scss +0 -4
  480. package/src/tabs/use-tab-list-sync.js +0 -237
@@ -8,14 +8,15 @@
8
8
  /**
9
9
  * Render callback for core/tab-list.
10
10
  *
11
- * Re-renders each tab inner block with per-item context (index, id,
12
- * label) injected from the tabs-list, so the tab render callback
13
- * can add the correct IAPI directives for each button.
11
+ * Injects IAPI directives into the saved button HTML. The buttons already
12
+ * carry color/border/padding styles from save.js; this callback adds
13
+ * tab-specific attributes (id, aria-controls, context) and interactivity
14
+ * directives using data from the tabs-list context.
14
15
  *
15
16
  * @since 7.0.0
16
17
  *
17
18
  * @param array $attributes Block attributes.
18
- * @param string $content Block content (rendered inner blocks from save.js).
19
+ * @param string $content Block content (rendered buttons from save.js).
19
20
  * @param \WP_Block $block WP_Block instance.
20
21
  *
21
22
  * @return string Updated HTML.
@@ -27,41 +28,33 @@ function block_core_tab_list_render_callback( array $attributes, string $content
27
28
  return $content;
28
29
  }
29
30
 
30
- // Re-render each tab with per-item context (index, id, label).
31
- // Match by position so items align with their corresponding tabs.
32
- $buttons_html = '';
33
- $tab_position = 0;
31
+ $tag_processor = new WP_HTML_Tag_Processor( $content );
32
+ $tab_index = 0;
34
33
 
35
- foreach ( $block->parsed_block['innerBlocks'] ?? array() as $parsed_tab ) {
36
- if ( 'core/tab' !== ( $parsed_tab['blockName'] ?? '' ) ) {
37
- continue;
38
- }
39
-
40
- $tab = $tabs_list[ $tab_position ] ?? null;
41
- $tab_index = $tab_position;
42
- ++$tab_position;
34
+ while ( $tag_processor->next_tag( 'button' ) ) {
35
+ $tab = $tabs_list[ $tab_index ] ?? null;
43
36
 
44
- // Skip tabs with no matching tab panel.
45
37
  if ( null === $tab ) {
46
- continue;
38
+ break;
47
39
  }
48
40
 
49
- $item_context = array_merge(
50
- $block->context,
51
- array(
52
- 'core/tab-index' => $tab_index,
53
- 'core/tab-id' => $tab['id'] ?? '',
54
- 'core/tab-label' => $tab['label'] ?? '',
55
- )
41
+ $tab_id = $tab['id'] ?? 'tab-' . $tab_index;
42
+
43
+ $tag_processor->set_attribute( 'id', 'tab__' . $tab_id );
44
+ $tag_processor->set_attribute( 'aria-controls', $tab_id );
45
+ $tag_processor->set_attribute( 'data-wp-on--click', 'actions.handleTabClick' );
46
+ $tag_processor->set_attribute( 'data-wp-on--keydown', 'actions.handleTabKeyDown' );
47
+ $tag_processor->set_attribute( 'data-wp-bind--aria-selected', 'state.isActiveTab' );
48
+ $tag_processor->set_attribute( 'data-wp-bind--tabindex', 'state.tabIndexAttribute' );
49
+ $tag_processor->set_attribute(
50
+ 'data-wp-context',
51
+ wp_json_encode( array( 'tabIndex' => $tab_index ) )
56
52
  );
57
53
 
58
- $tab_block = new WP_Block( $parsed_tab, $item_context );
59
- $buttons_html .= $tab_block->render();
54
+ ++$tab_index;
60
55
  }
61
56
 
62
- // Rebuild the wrapper using get_block_wrapper_attributes().
63
- $wrapper_attributes = get_block_wrapper_attributes( array( 'role' => 'tablist' ) );
64
- return sprintf( '<div %s>%s</div>', $wrapper_attributes, $buttons_html );
57
+ return $tag_processor->get_updated_html();
65
58
  }
66
59
 
67
60
  /**
@@ -1,14 +1,49 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import clsx from 'clsx';
5
+
1
6
  /**
2
7
  * WordPress dependencies
3
8
  */
4
- import { useBlockProps, useInnerBlocksProps } from '@wordpress/block-editor';
9
+ import {
10
+ useBlockProps,
11
+ __experimentalGetBorderClassesAndStyles as getBorderClassesAndStyles,
12
+ __experimentalGetColorClassesAndStyles as getColorClassesAndStyles,
13
+ __experimentalGetSpacingClassesAndStyles as getSpacingClassesAndStyles,
14
+ } from '@wordpress/block-editor';
5
15
 
6
- export default function save() {
16
+ export default function save( { attributes } ) {
17
+ const { tabs } = attributes;
7
18
  const blockProps = useBlockProps.save( {
8
19
  role: 'tablist',
9
20
  } );
10
21
 
11
- const innerBlocksProps = useInnerBlocksProps.save( blockProps );
22
+ const colorProps = getColorClassesAndStyles( attributes );
23
+ const borderProps = getBorderClassesAndStyles( attributes );
24
+ const spacingProps = getSpacingClassesAndStyles( attributes );
25
+
26
+ const buttonClassName = clsx( colorProps.className, borderProps.className );
27
+
28
+ const buttonStyle = {
29
+ ...colorProps.style,
30
+ ...borderProps.style,
31
+ ...spacingProps.style,
32
+ };
12
33
 
13
- return <div { ...innerBlocksProps } />;
34
+ return (
35
+ <div { ...blockProps }>
36
+ { tabs.map( ( tab, index ) => (
37
+ <button
38
+ key={ index }
39
+ className={ buttonClassName || undefined }
40
+ style={ buttonStyle }
41
+ type="button"
42
+ role="tab"
43
+ >
44
+ { tab.label }
45
+ </button>
46
+ ) ) }
47
+ </div>
48
+ );
14
49
  }
@@ -1,4 +1,4 @@
1
- .wp-block-tab {
1
+ :where(.wp-block-tab-list button) {
2
2
  box-sizing: border-box;
3
3
  color: inherit;
4
4
  display: block;
@@ -29,7 +29,6 @@ _Defined via the [`supports`](https://developer.wordpress.org/block-editor/refer
29
29
 
30
30
  - [`anchor`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#anchor): `true`
31
31
  - [`html`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#html): `false`
32
- - [`reusable`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#reusable): `false`
33
32
  - [`color`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color):
34
33
  - [`background`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-background): `true`
35
34
  - [`text`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-text): `true`
@@ -37,10 +36,8 @@ _Defined via the [`supports`](https://developer.wordpress.org/block-editor/refer
37
36
  - [`spacing`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#spacing):
38
37
  - `blockGap`: `true`
39
38
  - `padding`: `true`
40
- - `margin`: `false`
41
39
  - [`typography`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#typography):
42
40
  - [`fontSize`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#typography-fontsize): `true`
43
- - [`renaming`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#renaming): `true`
44
41
  - [`visibility`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#visibility): `false`
45
42
 
46
43
  ## Context
@@ -12,22 +12,28 @@ import { useDispatch, useSelect } from '@wordpress/data';
12
12
 
13
13
  /**
14
14
  * "Add tab" button in the block toolbar for the tabs block.
15
- * Inserts a new core/tab-panel into the tab-panels and a new core/tab
16
- * into the tab-list, keeping both in sync.
15
+ * Inserts a new core/tab-panel into the tab-panels. The tab-list items
16
+ * attribute is kept in sync automatically via useTabListItemsSync.
17
17
  *
18
18
  * @param {Object} props
19
19
  * @param {string} props.tabsClientId The client ID of the parent tabs block.
20
20
  * @return {React.JSX.Element} The toolbar control element.
21
21
  */
22
22
  export default function AddTabToolbarControl( { tabsClientId } ) {
23
- const { insertBlock } = useDispatch( blockEditorStore );
23
+ const {
24
+ insertBlock,
25
+ updateBlockAttributes,
26
+ selectBlock,
27
+ __unstableMarkNextChangeAsNotPersistent,
28
+ } = useDispatch( blockEditorStore );
24
29
 
25
- const { tabPanelsClientId, tabsListClientId } = useSelect(
30
+ const { tabPanelsClientId, tabCount, tabListClientId } = useSelect(
26
31
  ( select ) => {
27
32
  if ( ! tabsClientId ) {
28
33
  return {
29
34
  tabPanelsClientId: null,
30
- tabsListClientId: null,
35
+ tabCount: 0,
36
+ tabListClientId: null,
31
37
  };
32
38
  }
33
39
  const { getBlocks } = select( blockEditorStore );
@@ -40,7 +46,8 @@ export default function AddTabToolbarControl( { tabsClientId } ) {
40
46
  );
41
47
  return {
42
48
  tabPanelsClientId: tabPanels?.clientId || null,
43
- tabsListClientId: tabList?.clientId || null,
49
+ tabCount: tabPanels?.innerBlocks?.length || 0,
50
+ tabListClientId: tabList?.clientId || null,
44
51
  };
45
52
  },
46
53
  [ tabsClientId ]
@@ -54,12 +61,18 @@ export default function AddTabToolbarControl( { tabsClientId } ) {
54
61
  const newTabPanelBlock = createBlock( 'core/tab-panel', {
55
62
  label: __( 'Tab' ),
56
63
  } );
57
- insertBlock( newTabPanelBlock, undefined, tabPanelsClientId );
64
+ insertBlock( newTabPanelBlock, undefined, tabPanelsClientId, false );
58
65
 
59
- // Insert a corresponding tab into the tab-list.
60
- if ( tabsListClientId ) {
61
- const newTabBlock = createBlock( 'core/tab', {} );
62
- insertBlock( newTabBlock, undefined, tabsListClientId );
66
+ // Switch editor active tab to the new tab.
67
+ const newIndex = tabCount;
68
+ __unstableMarkNextChangeAsNotPersistent();
69
+ updateBlockAttributes( tabsClientId, {
70
+ editorActiveTabIndex: newIndex,
71
+ } );
72
+
73
+ // Select the tab-list block so focus stays in the menu area.
74
+ if ( tabListClientId ) {
75
+ selectBlock( tabListClientId );
63
76
  }
64
77
  };
65
78
 
@@ -22,7 +22,6 @@
22
22
  "supports": {
23
23
  "anchor": true,
24
24
  "html": false,
25
- "reusable": false,
26
25
  "color": {
27
26
  "background": true,
28
27
  "text": true,
@@ -34,8 +33,7 @@
34
33
  "layout": true,
35
34
  "spacing": {
36
35
  "blockGap": true,
37
- "padding": true,
38
- "margin": false
36
+ "padding": true
39
37
  },
40
38
  "typography": {
41
39
  "fontSize": true,
@@ -45,12 +43,10 @@
45
43
  "__experimentalFontFamily": true
46
44
  }
47
45
  },
48
- "renaming": true,
49
46
  "visibility": false
50
47
  },
51
48
  "providesContext": {
52
49
  "core/tab-label": "label"
53
50
  },
54
- "editorScript": "file:./index.js",
55
- "style": "file:./style-index.css"
51
+ "style": "wp-block-tab-panel"
56
52
  }
@@ -11,8 +11,8 @@ import { useDispatch, useSelect } from '@wordpress/data';
11
11
 
12
12
  /**
13
13
  * "Remove Tab" button in the block toolbar for the tabs block.
14
- * Removes the currently active core/tab-panel and its corresponding
15
- * core/tab, keeping both in sync.
14
+ * Removes the currently active core/tab-panel. The tab-list items
15
+ * attribute is kept in sync automatically via useTabListItemsSync.
16
16
  *
17
17
  * @param {Object} props
18
18
  * @param {string} props.tabsClientId The client ID of the parent tabs block.
@@ -28,17 +28,17 @@ export default function RemoveTabToolbarControl( { tabsClientId } ) {
28
28
 
29
29
  const {
30
30
  activeTabPanelClientId,
31
- activeTabClientId,
32
31
  tabCount,
33
32
  editorActiveTabIndex,
33
+ tabListClientId,
34
34
  } = useSelect(
35
35
  ( select ) => {
36
36
  if ( ! tabsClientId ) {
37
37
  return {
38
38
  activeTabPanelClientId: null,
39
- activeTabClientId: null,
40
39
  tabCount: 0,
41
40
  editorActiveTabIndex: 0,
41
+ tabListClientId: null,
42
42
  };
43
43
  }
44
44
  const { getBlocks, getBlockAttributes } =
@@ -56,15 +56,13 @@ export default function RemoveTabToolbarControl( { tabsClientId } ) {
56
56
  ( block ) => block.name === 'core/tab-list'
57
57
  );
58
58
  const tabPanelBlocks = tabPanels?.innerBlocks || [];
59
- const tabs = tabList?.innerBlocks || [];
60
59
  const activeTabPanel = tabPanelBlocks[ activeIndex ];
61
- const activeTab = tabs[ activeIndex ];
62
60
 
63
61
  return {
64
62
  activeTabPanelClientId: activeTabPanel?.clientId || null,
65
- activeTabClientId: activeTab?.clientId || null,
66
- tabCount: tabs.length,
63
+ tabCount: tabPanelBlocks.length,
67
64
  editorActiveTabIndex: activeIndex,
65
+ tabListClientId: tabList?.clientId || null,
68
66
  };
69
67
  },
70
68
  [ tabsClientId ]
@@ -86,14 +84,12 @@ export default function RemoveTabToolbarControl( { tabsClientId } ) {
86
84
  editorActiveTabIndex: newActiveIndex,
87
85
  } );
88
86
 
89
- // Remove the tab panel and corresponding tab
87
+ // Remove the tab panel.
90
88
  removeBlock( activeTabPanelClientId, false );
91
- if ( activeTabClientId ) {
92
- removeBlock( activeTabClientId, false );
93
- }
94
89
 
95
- if ( tabsClientId ) {
96
- selectBlock( tabsClientId );
90
+ // Select the tab-list so focus moves to the new active tab button.
91
+ if ( tabListClientId ) {
92
+ selectBlock( tabListClientId );
97
93
  }
98
94
  };
99
95
 
@@ -1,23 +1,6 @@
1
1
  .wp-block-tab-panel {
2
- max-width: 100%;
3
- flex-basis: 100%;
4
- flex-grow: 1;
5
- box-sizing: border-box;
6
-
7
- & > *:first-child {
8
- margin-top: 0;
9
- }
10
- & > *:last-child {
11
- margin-bottom: 0;
12
- }
13
-
14
2
  &[hidden],
15
3
  &:empty {
16
4
  display: none !important;
17
5
  }
18
6
  }
19
-
20
- .wp-block-tab-panel.wp-block.has-background,
21
- .wp-block-tab-panel:not(.wp-block).has-background {
22
- padding: var(--wp--preset--spacing--30);
23
- }
@@ -28,34 +28,18 @@ _This block has no custom attributes._
28
28
 
29
29
  _Defined via the [`supports`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/) property in block.json._
30
30
 
31
- - [`anchor`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#anchor): `false`
32
31
  - [`html`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#html): `false`
33
- - [`reusable`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#reusable): `false`
34
32
  - [`visibility`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#visibility): `false`
35
33
  - [`lock`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#lock): `false`
36
- - [`dimensions`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#dimensions):
37
- - `aspectRatio`: `false`
38
- - `height`: `false`
39
- - `minHeight`: `false`
40
- - `width`: `false`
41
34
  - [`color`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color):
42
35
  - [`background`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-background): `true`
43
36
  - [`text`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-text): `true`
44
37
  - [`heading`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-heading): `true`
45
38
  - [`link`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-link): `true`
46
39
  - [`spacing`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#spacing):
47
- - `blockGap`: `false`
48
40
  - `padding`: `true`
49
- - `margin`: `true`
50
41
  - [`typography`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#typography):
51
42
  - [`fontSize`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#typography-fontsize): `true`
52
- - [`layout`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout):
53
- - [`default`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-default): `{"type":"flex","flexWrap":"nowrap","justifyContent":"stretch","orientation":"vertical"}`
54
- - [`allowSwitching`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowswitching): `false`
55
- - [`allowVerticalAlignment`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowverticalalignment): `false`
56
- - [`allowOrientation`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-alloworientation): `false`
57
- - [`allowJustification`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowjustification): `true`
58
- - [`allowSizingOnChildren`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowsizingonchildren): `false`
59
43
 
60
44
  ## Block Markup
61
45
 
@@ -11,17 +11,9 @@
11
11
  "allowedBlocks": [ "core/tab-panel" ],
12
12
  "attributes": {},
13
13
  "supports": {
14
- "anchor": false,
15
14
  "html": false,
16
- "reusable": false,
17
15
  "visibility": false,
18
16
  "lock": false,
19
- "dimensions": {
20
- "aspectRatio": false,
21
- "height": false,
22
- "minHeight": false,
23
- "width": false
24
- },
25
17
  "color": {
26
18
  "background": true,
27
19
  "text": true,
@@ -33,34 +25,17 @@
33
25
  }
34
26
  },
35
27
  "spacing": {
36
- "blockGap": false,
37
- "padding": true,
38
- "margin": true
28
+ "padding": true
39
29
  },
40
30
  "typography": {
41
31
  "fontSize": true,
42
32
  "__experimentalFontFamily": true
43
33
  },
44
- "layout": {
45
- "default": {
46
- "type": "flex",
47
- "flexWrap": "nowrap",
48
- "justifyContent": "stretch",
49
- "orientation": "vertical"
50
- },
51
- "allowSwitching": false,
52
- "allowVerticalAlignment": false,
53
- "allowOrientation": false,
54
- "allowJustification": true,
55
- "allowSizingOnChildren": false
56
- },
57
34
  "__experimentalBorder": {
58
35
  "radius": true,
59
36
  "color": true,
60
37
  "width": true,
61
38
  "style": true
62
39
  }
63
- },
64
- "editorScript": "file:./index.js",
65
- "style": "file:./style-index.css"
40
+ }
66
41
  }
@@ -35,12 +35,7 @@ _Defined via the [`supports`](https://developer.wordpress.org/block-editor/refer
35
35
  - [`text`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-text): `true`
36
36
  - [`background`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#color-background): `true`
37
37
  - [`layout`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout):
38
- - [`default`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-default): `{"type":"flex","flexWrap":"nowrap","justifyContent":"stretch","verticalAlignment":"stretch","orientation":"vertical"}`
39
- - [`allowSwitching`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowswitching): `false`
40
- - [`allowVerticalAlignment`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowverticalalignment): `true`
41
- - [`allowJustification`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowjustification): `true`
42
- - [`allowOrientation`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-alloworientation): `true`
43
- - [`allowSizingOnChildren`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowsizingonchildren): `true`
38
+ - [`allowEditing`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#layout-allowediting): `false`
44
39
  - [`html`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#html): `false`
45
40
  - [`interactivity`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#interactivity): `true`
46
41
  - [`spacing`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#spacing):
@@ -49,7 +44,6 @@ _Defined via the [`supports`](https://developer.wordpress.org/block-editor/refer
49
44
  - `padding`: `true`
50
45
  - [`typography`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#typography):
51
46
  - [`fontSize`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#typography-fontsize): `true`
52
- - [`renaming`](https://developer.wordpress.org/block-editor/reference-guides/block-api/block-supports/#renaming): `true`
53
47
 
54
48
  ## Context
55
49
 
@@ -30,18 +30,7 @@
30
30
  }
31
31
  },
32
32
  "layout": {
33
- "default": {
34
- "type": "flex",
35
- "flexWrap": "nowrap",
36
- "justifyContent": "stretch",
37
- "verticalAlignment": "stretch",
38
- "orientation": "vertical"
39
- },
40
- "allowSwitching": false,
41
- "allowVerticalAlignment": true,
42
- "allowJustification": true,
43
- "allowOrientation": true,
44
- "allowSizingOnChildren": true
33
+ "allowEditing": false
45
34
  },
46
35
  "html": false,
47
36
  "interactivity": true,
@@ -53,16 +42,13 @@
53
42
  "typography": {
54
43
  "fontSize": true,
55
44
  "__experimentalFontFamily": true
56
- },
57
- "renaming": true
45
+ }
58
46
  },
59
47
  "providesContext": {
60
48
  "core/tabs-activeTabIndex": "activeTabIndex",
61
49
  "core/tabs-editorActiveTabIndex": "editorActiveTabIndex"
62
50
  },
63
51
  "usesContext": [ "core/tabs-list", "core/tabs-id" ],
64
- "editorScript": "file:./index.js",
65
- "editorStyle": "file:./index.css",
66
- "style": "file:./style-index.css",
52
+ "style": "wp-block-tabs",
67
53
  "viewScriptModule": "@wordpress/block-library/tabs/view"
68
54
  }
package/src/tabs/edit.js CHANGED
@@ -14,7 +14,7 @@ import { useMemo } from '@wordpress/element';
14
14
  * Internal dependencies
15
15
  */
16
16
  import Controls from './controls';
17
- import useTabListSync from './use-tab-list-sync';
17
+ import useTabListItemsSync from './use-tab-list-items-sync';
18
18
 
19
19
  const EMPTY_ARRAY = [];
20
20
 
@@ -32,15 +32,15 @@ const EMPTY_ARRAY = [];
32
32
  */
33
33
  const TABS_TEMPLATE = [ [ 'core/tab-list' ], [ 'core/tab-panels' ] ];
34
34
 
35
- function Edit( { clientId, attributes, setAttributes } ) {
35
+ function Edit( { clientId, attributes } ) {
36
36
  const { anchor, activeTabIndex, editorActiveTabIndex } = attributes;
37
37
 
38
- const { tabPanels, tabPanelsClientId, tabs, tabListClientId } = useSelect(
38
+ const { tabPanels, tabListClientId } = useSelect(
39
39
  ( select ) => {
40
40
  const { getBlocks } = select( blockEditorStore );
41
41
  const innerBlocks = getBlocks( clientId );
42
42
 
43
- const tabPanelBlocks = innerBlocks.find(
43
+ const tabPanelsBlock = innerBlocks.find(
44
44
  ( block ) => block.name === 'core/tab-panels'
45
45
  );
46
46
  const tabList = innerBlocks.find(
@@ -48,21 +48,14 @@ function Edit( { clientId, attributes, setAttributes } ) {
48
48
  );
49
49
 
50
50
  return {
51
- tabPanels: tabPanelBlocks?.innerBlocks ?? EMPTY_ARRAY,
52
- tabPanelsClientId: tabPanelBlocks?.clientId ?? null,
53
- tabs: tabList?.innerBlocks ?? EMPTY_ARRAY,
51
+ tabPanels: tabPanelsBlock?.innerBlocks ?? EMPTY_ARRAY,
54
52
  tabListClientId: tabList?.clientId ?? null,
55
53
  };
56
54
  },
57
55
  [ clientId ]
58
56
  );
59
57
 
60
- useTabListSync( {
61
- tabPanels,
62
- tabs,
63
- tabPanelsClientId,
64
- tabListClientId,
65
- } );
58
+ useTabListItemsSync( { tabPanels, tabListClientId } );
66
59
 
67
60
  /**
68
61
  * Memoize context value to prevent unnecessary re-renders.
@@ -70,7 +63,7 @@ function Edit( { clientId, attributes, setAttributes } ) {
70
63
  const contextValue = useMemo( () => {
71
64
  /**
72
65
  * Compute tabs list from innerblocks to provide via context.
73
- * This traverses the tab-panel block to find all tab blocks
66
+ * This traverses the tab-panels block to find all tab-panel blocks
74
67
  * and extracts their label and anchor for the tab-list to consume.
75
68
  */
76
69
  const tabList = tabPanels.map( ( tab, index ) => ( {
@@ -100,11 +93,7 @@ function Edit( { clientId, attributes, setAttributes } ) {
100
93
  return (
101
94
  <BlockContextProvider value={ contextValue }>
102
95
  <div { ...innerBlockProps }>
103
- <Controls
104
- clientId={ clientId }
105
- attributes={ attributes }
106
- setAttributes={ setAttributes }
107
- />
96
+ <Controls clientId={ clientId } />
108
97
  { innerBlockProps.children }
109
98
  </div>
110
99
  </BlockContextProvider>
package/src/tabs/index.js CHANGED
@@ -22,16 +22,12 @@ export const settings = {
22
22
  innerBlocks: [
23
23
  {
24
24
  name: 'core/tab-list',
25
- innerBlocks: [
26
- {
27
- name: 'core/tab',
28
- attributes: { anchor: 'tab-1-button' },
29
- },
30
- {
31
- name: 'core/tab',
32
- attributes: { anchor: 'tab-2-button' },
33
- },
34
- ],
25
+ attributes: {
26
+ tabs: [
27
+ { label: __( 'Tab 1' ) },
28
+ { label: __( 'Tab 2' ) },
29
+ ],
30
+ },
35
31
  },
36
32
  {
37
33
  name: 'core/tab-panels',
@@ -96,30 +96,17 @@ function block_core_tabs_render_block_callback( array $attributes, string $conte
96
96
  return '';
97
97
  }
98
98
 
99
- $is_vertical = false;
100
-
101
99
  $tag_processor = new WP_HTML_Tag_Processor( $content );
102
100
 
103
101
  $tag_processor->next_tag( array( 'class_name' => 'wp-block-tabs' ) );
104
102
  $tag_processor->set_attribute( 'data-wp-interactive', 'core/tabs/private' );
105
103
 
106
- // Inspect inside the tab-list to see if its vertical or not.
107
- $tag_processor->set_bookmark( 'core/tabs_wrapper' );
108
- while ( $tag_processor->next_tag( array( 'class_name' => 'wp-block-tabs-list' ) ) ) {
109
- if ( $tag_processor->has_class( 'is-vertical' ) ) {
110
- $is_vertical = true;
111
- break;
112
- }
113
- }
114
- $tag_processor->seek( 'core/tabs_wrapper' );
115
-
116
104
  $tag_processor->set_attribute(
117
105
  'data-wp-context',
118
106
  wp_json_encode(
119
107
  array(
120
108
  'tabsId' => $tabs_id,
121
109
  'activeTabIndex' => $active_tab_index,
122
- 'isVertical' => $is_vertical,
123
110
  )
124
111
  )
125
112
  );