@wordpress/block-library 9.48.0 → 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 (951) hide show
  1. package/CHANGELOG.md +18 -1
  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/transforms.cjs +65 -0
  13. package/build/columns/transforms.cjs.map +2 -2
  14. package/build/columns/utils.cjs.map +1 -1
  15. package/build/comments/edit/comments-legacy.cjs +1 -1
  16. package/build/comments/edit/comments-legacy.cjs.map +1 -1
  17. package/build/comments/edit/placeholder.cjs +4 -4
  18. package/build/comments/edit/placeholder.cjs.map +1 -1
  19. package/build/comments-pagination-next/edit.cjs +2 -2
  20. package/build/comments-pagination-next/edit.cjs.map +1 -1
  21. package/build/comments-pagination-previous/edit.cjs +2 -2
  22. package/build/comments-pagination-previous/edit.cjs.map +1 -1
  23. package/build/cover/deprecated.cjs +3 -3
  24. package/build/cover/deprecated.cjs.map +2 -2
  25. package/build/cover/edit/block-controls.cjs +13 -0
  26. package/build/cover/edit/block-controls.cjs.map +2 -2
  27. package/build/cover/edit/index.cjs +61 -2
  28. package/build/cover/edit/index.cjs.map +3 -3
  29. package/build/cover/edit/inspector-controls.cjs +93 -35
  30. package/build/cover/edit/inspector-controls.cjs.map +2 -2
  31. package/build/details/edit.cjs +1 -1
  32. package/build/details/edit.cjs.map +2 -2
  33. package/build/embed/embed-placeholder.cjs +1 -1
  34. package/build/embed/embed-placeholder.cjs.map +2 -2
  35. package/build/file/edit.cjs +3 -11
  36. package/build/file/edit.cjs.map +2 -2
  37. package/build/file/index.cjs +3 -1
  38. package/build/file/index.cjs.map +3 -3
  39. package/build/file/transforms.cjs +11 -32
  40. package/build/file/transforms.cjs.map +2 -2
  41. package/build/file/variations.cjs +38 -0
  42. package/build/file/variations.cjs.map +7 -0
  43. package/build/footnotes/edit.cjs +1 -1
  44. package/build/footnotes/edit.cjs.map +2 -2
  45. package/build/form-input/edit.cjs +1 -1
  46. package/build/form-input/edit.cjs.map +2 -2
  47. package/build/freeform/edit.cjs +1 -1
  48. package/build/freeform/edit.cjs.map +1 -1
  49. package/build/gallery/edit.cjs +212 -331
  50. package/build/gallery/edit.cjs.map +2 -2
  51. package/build/gallery/transforms.cjs +43 -0
  52. package/build/gallery/transforms.cjs.map +2 -2
  53. package/build/heading/edit.cjs +0 -1
  54. package/build/heading/edit.cjs.map +2 -2
  55. package/build/home-link/edit.cjs +1 -1
  56. package/build/home-link/edit.cjs.map +2 -2
  57. package/build/html/index.cjs +1 -1
  58. package/build/html/index.cjs.map +2 -2
  59. package/build/html/modal.cjs +3 -3
  60. package/build/html/modal.cjs.map +2 -2
  61. package/build/icon/block.json +12 -0
  62. package/build/icon/edit.cjs +90 -39
  63. package/build/icon/edit.cjs.map +3 -3
  64. package/build/icon/index.cjs +3 -1
  65. package/build/icon/index.cjs.map +3 -3
  66. package/build/{tab/save.cjs → icon/variations.cjs} +14 -15
  67. package/build/icon/variations.cjs.map +7 -0
  68. package/build/image/block.json +1 -0
  69. package/build/image/edit.cjs +4 -3
  70. package/build/image/edit.cjs.map +2 -2
  71. package/build/image/image.cjs +91 -27
  72. package/build/image/image.cjs.map +2 -2
  73. package/build/image/index.cjs +1 -1
  74. package/build/image/index.cjs.map +2 -2
  75. package/build/image/transforms.cjs +9 -3
  76. package/build/image/transforms.cjs.map +2 -2
  77. package/build/index.cjs +1 -3
  78. package/build/index.cjs.map +2 -2
  79. package/build/latest-posts/edit.cjs +1 -1
  80. package/build/latest-posts/edit.cjs.map +1 -1
  81. package/build/list/edit.cjs +1 -8
  82. package/build/list/edit.cjs.map +2 -2
  83. package/build/list/ordered-list-settings.cjs +1 -44
  84. package/build/list/ordered-list-settings.cjs.map +2 -2
  85. package/build/list-item/hooks/use-merge.cjs +47 -24
  86. package/build/list-item/hooks/use-merge.cjs.map +2 -2
  87. package/build/math/edit.cjs +1 -1
  88. package/build/math/index.cjs +1 -1
  89. package/build/math/index.cjs.map +1 -1
  90. package/build/media-text/constants.cjs +1 -1
  91. package/build/media-text/constants.cjs.map +2 -2
  92. package/build/media-text/index.cjs +1 -1
  93. package/build/media-text/index.cjs.map +2 -2
  94. package/build/missing/edit.cjs +2 -2
  95. package/build/missing/edit.cjs.map +1 -1
  96. package/build/navigation/edit/index.cjs +29 -34
  97. package/build/navigation/edit/index.cjs.map +2 -2
  98. package/build/navigation/edit/navigation-menu-selector.cjs +1 -1
  99. package/build/navigation/edit/navigation-menu-selector.cjs.map +2 -2
  100. package/build/navigation/edit/placeholder/index.cjs +1 -1
  101. package/build/navigation/edit/placeholder/index.cjs.map +2 -2
  102. package/build/navigation-link/edit.cjs +1 -2
  103. package/build/navigation-link/edit.cjs.map +2 -2
  104. package/build/navigation-submenu/block.json +7 -0
  105. package/build/navigation-submenu/edit.cjs +3 -2
  106. package/build/navigation-submenu/edit.cjs.map +2 -2
  107. package/build/page-list/block.json +2 -5
  108. package/build/page-list/edit.cjs +1 -11
  109. package/build/page-list/edit.cjs.map +2 -2
  110. package/build/paragraph/deprecated.cjs +1 -0
  111. package/build/paragraph/deprecated.cjs.map +2 -2
  112. package/build/paragraph/edit.cjs +10 -1
  113. package/build/paragraph/edit.cjs.map +3 -3
  114. package/build/playlist/block.json +12 -0
  115. package/build/playlist/edit.cjs +27 -1
  116. package/build/playlist/edit.cjs.map +2 -2
  117. package/build/playlist/save.cjs +8 -1
  118. package/build/playlist/save.cjs.map +2 -2
  119. package/build/playlist/view.cjs +1 -0
  120. package/build/playlist/view.cjs.map +2 -2
  121. package/build/post-author/edit.cjs +1 -1
  122. package/build/post-author/edit.cjs.map +2 -2
  123. package/build/post-author/utils.cjs +1 -1
  124. package/build/post-author/utils.cjs.map +2 -2
  125. package/build/post-date/edit.cjs +2 -2
  126. package/build/post-date/edit.cjs.map +2 -2
  127. package/build/post-excerpt/edit.cjs +2 -2
  128. package/build/post-excerpt/edit.cjs.map +2 -2
  129. package/build/post-featured-image/block.json +1 -0
  130. package/build/post-featured-image/dimension-controls.cjs +90 -178
  131. package/build/post-featured-image/dimension-controls.cjs.map +3 -3
  132. package/build/post-featured-image/edit.cjs +47 -17
  133. package/build/post-featured-image/edit.cjs.map +2 -2
  134. package/build/post-navigation-link/edit.cjs +2 -2
  135. package/build/post-navigation-link/edit.cjs.map +2 -2
  136. package/build/post-time-to-read/edit.cjs +1 -1
  137. package/build/post-time-to-read/edit.cjs.map +1 -1
  138. package/build/post-time-to-read/index.cjs +1 -1
  139. package/build/post-time-to-read/index.cjs.map +2 -2
  140. package/build/post-time-to-read/variations.cjs +1 -1
  141. package/build/post-time-to-read/variations.cjs.map +2 -2
  142. package/build/preformatted/edit.cjs +1 -1
  143. package/build/preformatted/edit.cjs.map +2 -2
  144. package/build/pullquote/block.json +1 -3
  145. package/build/pullquote/deprecated.cjs +114 -9
  146. package/build/pullquote/deprecated.cjs.map +3 -3
  147. package/build/pullquote/edit.cjs +43 -66
  148. package/build/pullquote/edit.cjs.map +3 -3
  149. package/build/pullquote/save.cjs +5 -26
  150. package/build/pullquote/save.cjs.map +3 -3
  151. package/build/query/edit/inspector-controls/enhanced-pagination-control.cjs +1 -1
  152. package/build/query/edit/inspector-controls/enhanced-pagination-control.cjs.map +1 -1
  153. package/build/query/edit/inspector-controls/order-control.cjs +2 -2
  154. package/build/query/edit/inspector-controls/order-control.cjs.map +2 -2
  155. package/build/query/utils.cjs +2 -2
  156. package/build/query/utils.cjs.map +2 -2
  157. package/build/query-pagination-next/edit.cjs +2 -2
  158. package/build/query-pagination-next/edit.cjs.map +1 -1
  159. package/build/query-pagination-previous/edit.cjs +2 -2
  160. package/build/query-pagination-previous/edit.cjs.map +1 -1
  161. package/build/query-title/edit.cjs +1 -1
  162. package/build/query-title/edit.cjs.map +2 -2
  163. package/build/query-total/edit.cjs +1 -1
  164. package/build/query-total/edit.cjs.map +2 -2
  165. package/build/quote/edit.cjs +4 -9
  166. package/build/quote/edit.cjs.map +2 -2
  167. package/build/quote/index.cjs +1 -1
  168. package/build/quote/index.cjs.map +2 -2
  169. package/build/read-more/edit.cjs +1 -1
  170. package/build/read-more/edit.cjs.map +2 -2
  171. package/build/rss/edit.cjs +1 -1
  172. package/build/rss/edit.cjs.map +2 -2
  173. package/build/search/edit.cjs +3 -3
  174. package/build/search/edit.cjs.map +2 -2
  175. package/build/shortcode/edit.cjs +1 -1
  176. package/build/shortcode/edit.cjs.map +2 -2
  177. package/build/shortcode/transforms.cjs +2 -2
  178. package/build/shortcode/transforms.cjs.map +2 -2
  179. package/build/site-tagline/edit.cjs +1 -1
  180. package/build/site-tagline/edit.cjs.map +2 -2
  181. package/build/site-title/edit.cjs +1 -1
  182. package/build/site-title/edit.cjs.map +2 -2
  183. package/build/tab-list/block.json +34 -21
  184. package/build/tab-list/edit.cjs +116 -12
  185. package/build/tab-list/edit.cjs.map +3 -3
  186. package/build/tab-list/save.cjs +33 -3
  187. package/build/tab-list/save.cjs.map +3 -3
  188. package/build/tab-panel/add-tab-toolbar-control.cjs +19 -8
  189. package/build/tab-panel/add-tab-toolbar-control.cjs.map +2 -2
  190. package/build/tab-panel/block.json +2 -6
  191. package/build/tab-panel/remove-tab-toolbar-control.cjs +9 -14
  192. package/build/tab-panel/remove-tab-toolbar-control.cjs.map +2 -2
  193. package/build/tab-panels/block.json +2 -27
  194. package/build/table/index.cjs +1 -1
  195. package/build/table/index.cjs.map +2 -2
  196. package/build/tabs/block.json +3 -17
  197. package/build/tabs/edit.cjs +7 -21
  198. package/build/tabs/edit.cjs.map +3 -3
  199. package/build/tabs/index.cjs +6 -10
  200. package/build/tabs/index.cjs.map +2 -2
  201. package/build/tabs/use-tab-list-items-sync.cjs +53 -0
  202. package/build/tabs/use-tab-list-items-sync.cjs.map +7 -0
  203. package/build/tabs/view.cjs +2 -10
  204. package/build/tabs/view.cjs.map +2 -2
  205. package/build/terms-query/edit/inspector-controls/order-control.cjs +2 -2
  206. package/build/terms-query/edit/inspector-controls/order-control.cjs.map +2 -2
  207. package/build/utils/style-state.cjs +164 -0
  208. package/build/utils/style-state.cjs.map +7 -0
  209. package/build/utils/waveform-player.cjs +42 -9
  210. package/build/utils/waveform-player.cjs.map +2 -2
  211. package/build/utils/waveform-utils.cjs +6 -4
  212. package/build/utils/waveform-utils.cjs.map +2 -2
  213. package/build/verse/edit.cjs +1 -1
  214. package/build/verse/edit.cjs.map +2 -2
  215. package/build/video/edit-common-settings.cjs +3 -6
  216. package/build/video/edit-common-settings.cjs.map +2 -2
  217. package/build-module/breadcrumbs/edit.mjs +1 -1
  218. package/build-module/breadcrumbs/edit.mjs.map +1 -1
  219. package/build-module/button/edit.mjs +1 -1
  220. package/build-module/button/edit.mjs.map +2 -2
  221. package/build-module/categories/edit.mjs +1 -1
  222. package/build-module/categories/edit.mjs.map +1 -1
  223. package/build-module/code/edit.mjs +1 -1
  224. package/build-module/code/edit.mjs.map +2 -2
  225. package/build-module/code/index.mjs +1 -1
  226. package/build-module/code/index.mjs.map +1 -1
  227. package/build-module/columns/transforms.mjs +65 -0
  228. package/build-module/columns/transforms.mjs.map +2 -2
  229. package/build-module/columns/utils.mjs.map +1 -1
  230. package/build-module/comments/edit/comments-legacy.mjs +1 -1
  231. package/build-module/comments/edit/comments-legacy.mjs.map +1 -1
  232. package/build-module/comments/edit/placeholder.mjs +4 -4
  233. package/build-module/comments/edit/placeholder.mjs.map +1 -1
  234. package/build-module/comments-pagination-next/edit.mjs +2 -2
  235. package/build-module/comments-pagination-next/edit.mjs.map +1 -1
  236. package/build-module/comments-pagination-previous/edit.mjs +2 -2
  237. package/build-module/comments-pagination-previous/edit.mjs.map +1 -1
  238. package/build-module/cover/deprecated.mjs +3 -3
  239. package/build-module/cover/deprecated.mjs.map +2 -2
  240. package/build-module/cover/edit/block-controls.mjs +15 -2
  241. package/build-module/cover/edit/block-controls.mjs.map +2 -2
  242. package/build-module/cover/edit/index.mjs +64 -3
  243. package/build-module/cover/edit/index.mjs.map +2 -2
  244. package/build-module/cover/edit/inspector-controls.mjs +98 -35
  245. package/build-module/cover/edit/inspector-controls.mjs.map +2 -2
  246. package/build-module/details/edit.mjs +1 -1
  247. package/build-module/details/edit.mjs.map +2 -2
  248. package/build-module/embed/embed-placeholder.mjs +1 -1
  249. package/build-module/embed/embed-placeholder.mjs.map +2 -2
  250. package/build-module/file/edit.mjs +5 -13
  251. package/build-module/file/edit.mjs.map +2 -2
  252. package/build-module/file/index.mjs +3 -1
  253. package/build-module/file/index.mjs.map +2 -2
  254. package/build-module/file/transforms.mjs +11 -32
  255. package/build-module/file/transforms.mjs.map +2 -2
  256. package/build-module/file/variations.mjs +17 -0
  257. package/build-module/file/variations.mjs.map +7 -0
  258. package/build-module/footnotes/edit.mjs +1 -1
  259. package/build-module/footnotes/edit.mjs.map +2 -2
  260. package/build-module/form-input/edit.mjs +1 -1
  261. package/build-module/form-input/edit.mjs.map +2 -2
  262. package/build-module/freeform/edit.mjs +1 -1
  263. package/build-module/freeform/edit.mjs.map +1 -1
  264. package/build-module/gallery/edit.mjs +214 -334
  265. package/build-module/gallery/edit.mjs.map +2 -2
  266. package/build-module/gallery/transforms.mjs +43 -0
  267. package/build-module/gallery/transforms.mjs.map +2 -2
  268. package/build-module/heading/edit.mjs +1 -2
  269. package/build-module/heading/edit.mjs.map +2 -2
  270. package/build-module/home-link/edit.mjs +1 -1
  271. package/build-module/home-link/edit.mjs.map +2 -2
  272. package/build-module/html/index.mjs +1 -1
  273. package/build-module/html/index.mjs.map +2 -2
  274. package/build-module/html/modal.mjs +3 -3
  275. package/build-module/html/modal.mjs.map +2 -2
  276. package/build-module/icon/block.json +12 -0
  277. package/build-module/icon/edit.mjs +94 -40
  278. package/build-module/icon/edit.mjs.map +2 -2
  279. package/build-module/icon/index.mjs +3 -1
  280. package/build-module/icon/index.mjs.map +2 -2
  281. package/build-module/icon/variations.mjs +13 -0
  282. package/build-module/icon/variations.mjs.map +7 -0
  283. package/build-module/image/block.json +1 -0
  284. package/build-module/image/edit.mjs +4 -3
  285. package/build-module/image/edit.mjs.map +2 -2
  286. package/build-module/image/image.mjs +96 -27
  287. package/build-module/image/image.mjs.map +2 -2
  288. package/build-module/image/index.mjs +1 -1
  289. package/build-module/image/index.mjs.map +2 -2
  290. package/build-module/image/transforms.mjs +9 -3
  291. package/build-module/image/transforms.mjs.map +2 -2
  292. package/build-module/index.mjs +1 -3
  293. package/build-module/index.mjs.map +2 -2
  294. package/build-module/latest-posts/edit.mjs +1 -1
  295. package/build-module/latest-posts/edit.mjs.map +1 -1
  296. package/build-module/list/edit.mjs +2 -9
  297. package/build-module/list/edit.mjs.map +2 -2
  298. package/build-module/list/ordered-list-settings.mjs +1 -45
  299. package/build-module/list/ordered-list-settings.mjs.map +2 -2
  300. package/build-module/list-item/hooks/use-merge.mjs +48 -25
  301. package/build-module/list-item/hooks/use-merge.mjs.map +2 -2
  302. package/build-module/math/edit.mjs +1 -1
  303. package/build-module/math/index.mjs +1 -1
  304. package/build-module/math/index.mjs.map +1 -1
  305. package/build-module/media-text/constants.mjs +1 -1
  306. package/build-module/media-text/constants.mjs.map +2 -2
  307. package/build-module/media-text/index.mjs +1 -1
  308. package/build-module/media-text/index.mjs.map +2 -2
  309. package/build-module/missing/edit.mjs +2 -2
  310. package/build-module/missing/edit.mjs.map +1 -1
  311. package/build-module/navigation/edit/index.mjs +30 -41
  312. package/build-module/navigation/edit/index.mjs.map +2 -2
  313. package/build-module/navigation/edit/navigation-menu-selector.mjs +1 -1
  314. package/build-module/navigation/edit/navigation-menu-selector.mjs.map +2 -2
  315. package/build-module/navigation/edit/placeholder/index.mjs +1 -1
  316. package/build-module/navigation/edit/placeholder/index.mjs.map +2 -2
  317. package/build-module/navigation-link/edit.mjs +1 -2
  318. package/build-module/navigation-link/edit.mjs.map +2 -2
  319. package/build-module/navigation-submenu/block.json +7 -0
  320. package/build-module/navigation-submenu/edit.mjs +3 -2
  321. package/build-module/navigation-submenu/edit.mjs.map +2 -2
  322. package/build-module/page-list/block.json +2 -5
  323. package/build-module/page-list/edit.mjs +1 -11
  324. package/build-module/page-list/edit.mjs.map +2 -2
  325. package/build-module/paragraph/deprecated.mjs +1 -0
  326. package/build-module/paragraph/deprecated.mjs.map +2 -2
  327. package/build-module/paragraph/edit.mjs +12 -2
  328. package/build-module/paragraph/edit.mjs.map +2 -2
  329. package/build-module/playlist/block.json +12 -0
  330. package/build-module/playlist/edit.mjs +27 -1
  331. package/build-module/playlist/edit.mjs.map +2 -2
  332. package/build-module/playlist/save.mjs +8 -1
  333. package/build-module/playlist/save.mjs.map +2 -2
  334. package/build-module/playlist/view.mjs +1 -0
  335. package/build-module/playlist/view.mjs.map +2 -2
  336. package/build-module/post-author/edit.mjs +1 -1
  337. package/build-module/post-author/edit.mjs.map +2 -2
  338. package/build-module/post-author/utils.mjs +1 -1
  339. package/build-module/post-author/utils.mjs.map +2 -2
  340. package/build-module/post-date/edit.mjs +2 -2
  341. package/build-module/post-date/edit.mjs.map +2 -2
  342. package/build-module/post-excerpt/edit.mjs +2 -2
  343. package/build-module/post-excerpt/edit.mjs.map +2 -2
  344. package/build-module/post-featured-image/block.json +1 -0
  345. package/build-module/post-featured-image/dimension-controls.mjs +99 -187
  346. package/build-module/post-featured-image/dimension-controls.mjs.map +2 -2
  347. package/build-module/post-featured-image/edit.mjs +47 -17
  348. package/build-module/post-featured-image/edit.mjs.map +2 -2
  349. package/build-module/post-navigation-link/edit.mjs +2 -2
  350. package/build-module/post-navigation-link/edit.mjs.map +2 -2
  351. package/build-module/post-time-to-read/edit.mjs +1 -1
  352. package/build-module/post-time-to-read/edit.mjs.map +1 -1
  353. package/build-module/post-time-to-read/index.mjs +1 -1
  354. package/build-module/post-time-to-read/index.mjs.map +2 -2
  355. package/build-module/post-time-to-read/variations.mjs +2 -2
  356. package/build-module/post-time-to-read/variations.mjs.map +2 -2
  357. package/build-module/preformatted/edit.mjs +1 -1
  358. package/build-module/preformatted/edit.mjs.map +2 -2
  359. package/build-module/pullquote/block.json +1 -3
  360. package/build-module/pullquote/deprecated.mjs +114 -9
  361. package/build-module/pullquote/deprecated.mjs.map +2 -2
  362. package/build-module/pullquote/edit.mjs +44 -72
  363. package/build-module/pullquote/edit.mjs.map +2 -2
  364. package/build-module/pullquote/save.mjs +5 -16
  365. package/build-module/pullquote/save.mjs.map +2 -2
  366. package/build-module/query/edit/inspector-controls/enhanced-pagination-control.mjs +1 -1
  367. package/build-module/query/edit/inspector-controls/enhanced-pagination-control.mjs.map +1 -1
  368. package/build-module/query/edit/inspector-controls/order-control.mjs +2 -2
  369. package/build-module/query/edit/inspector-controls/order-control.mjs.map +2 -2
  370. package/build-module/query/utils.mjs +2 -2
  371. package/build-module/query/utils.mjs.map +2 -2
  372. package/build-module/query-pagination-next/edit.mjs +2 -2
  373. package/build-module/query-pagination-next/edit.mjs.map +1 -1
  374. package/build-module/query-pagination-previous/edit.mjs +2 -2
  375. package/build-module/query-pagination-previous/edit.mjs.map +1 -1
  376. package/build-module/query-title/edit.mjs +1 -1
  377. package/build-module/query-title/edit.mjs.map +2 -2
  378. package/build-module/query-total/edit.mjs +1 -1
  379. package/build-module/query-total/edit.mjs.map +2 -2
  380. package/build-module/quote/edit.mjs +5 -10
  381. package/build-module/quote/edit.mjs.map +2 -2
  382. package/build-module/quote/index.mjs +1 -1
  383. package/build-module/quote/index.mjs.map +2 -2
  384. package/build-module/read-more/edit.mjs +1 -1
  385. package/build-module/read-more/edit.mjs.map +2 -2
  386. package/build-module/rss/edit.mjs +1 -1
  387. package/build-module/rss/edit.mjs.map +2 -2
  388. package/build-module/search/edit.mjs +3 -3
  389. package/build-module/search/edit.mjs.map +2 -2
  390. package/build-module/shortcode/edit.mjs +1 -1
  391. package/build-module/shortcode/edit.mjs.map +2 -2
  392. package/build-module/shortcode/transforms.mjs +2 -2
  393. package/build-module/shortcode/transforms.mjs.map +2 -2
  394. package/build-module/site-tagline/edit.mjs +1 -1
  395. package/build-module/site-tagline/edit.mjs.map +2 -2
  396. package/build-module/site-title/edit.mjs +1 -1
  397. package/build-module/site-title/edit.mjs.map +2 -2
  398. package/build-module/tab-list/block.json +34 -21
  399. package/build-module/tab-list/edit.mjs +122 -15
  400. package/build-module/tab-list/edit.mjs.map +2 -2
  401. package/build-module/tab-list/save.mjs +29 -4
  402. package/build-module/tab-list/save.mjs.map +2 -2
  403. package/build-module/tab-panel/add-tab-toolbar-control.mjs +19 -8
  404. package/build-module/tab-panel/add-tab-toolbar-control.mjs.map +2 -2
  405. package/build-module/tab-panel/block.json +2 -6
  406. package/build-module/tab-panel/remove-tab-toolbar-control.mjs +9 -14
  407. package/build-module/tab-panel/remove-tab-toolbar-control.mjs.map +2 -2
  408. package/build-module/tab-panels/block.json +2 -27
  409. package/build-module/table/index.mjs +1 -1
  410. package/build-module/table/index.mjs.map +2 -2
  411. package/build-module/tabs/block.json +3 -17
  412. package/build-module/tabs/edit.mjs +7 -21
  413. package/build-module/tabs/edit.mjs.map +2 -2
  414. package/build-module/tabs/index.mjs +6 -10
  415. package/build-module/tabs/index.mjs.map +2 -2
  416. package/build-module/tabs/use-tab-list-items-sync.mjs +32 -0
  417. package/build-module/tabs/use-tab-list-items-sync.mjs.map +7 -0
  418. package/build-module/tabs/view.mjs +2 -10
  419. package/build-module/tabs/view.mjs.map +2 -2
  420. package/build-module/terms-query/edit/inspector-controls/order-control.mjs +2 -2
  421. package/build-module/terms-query/edit/inspector-controls/order-control.mjs.map +2 -2
  422. package/build-module/utils/style-state.mjs +132 -0
  423. package/build-module/utils/style-state.mjs.map +7 -0
  424. package/build-module/utils/waveform-player.mjs +44 -11
  425. package/build-module/utils/waveform-player.mjs.map +2 -2
  426. package/build-module/utils/waveform-utils.mjs +6 -4
  427. package/build-module/utils/waveform-utils.mjs.map +2 -2
  428. package/build-module/verse/edit.mjs +1 -1
  429. package/build-module/verse/edit.mjs.map +2 -2
  430. package/build-module/video/edit-common-settings.mjs +4 -7
  431. package/build-module/video/edit-common-settings.mjs.map +2 -2
  432. package/build-style/comment-template/style-rtl.css +1 -0
  433. package/build-style/comment-template/style.css +1 -0
  434. package/build-style/common-rtl.css +30 -10
  435. package/build-style/common.css +30 -10
  436. package/build-style/cover/style-rtl.css +2 -1
  437. package/build-style/cover/style.css +2 -1
  438. package/build-style/editor-rtl.css +34 -27
  439. package/build-style/editor.css +34 -27
  440. package/build-style/form-input/style-rtl.css +2 -0
  441. package/build-style/form-input/style.css +2 -0
  442. package/build-style/gallery/style-rtl.css +4 -2
  443. package/build-style/gallery/style.css +4 -2
  444. package/build-style/icon/style-rtl.css +9 -0
  445. package/build-style/icon/style.css +9 -0
  446. package/build-style/media-text/style-rtl.css +2 -1
  447. package/build-style/media-text/style.css +2 -1
  448. package/build-style/playlist/style-rtl.css +3 -0
  449. package/build-style/playlist/style.css +3 -0
  450. package/build-style/query/editor-rtl.css +8 -4
  451. package/build-style/query/editor.css +8 -4
  452. package/build-style/read-more/style-rtl.css +1 -0
  453. package/build-style/read-more/style.css +1 -0
  454. package/build-style/reset-rtl.css +3 -1
  455. package/build-style/reset.css +3 -1
  456. package/build-style/search/style-rtl.css +3 -1
  457. package/build-style/search/style.css +3 -1
  458. package/build-style/site-logo/editor-rtl.css +2 -1
  459. package/build-style/site-logo/editor.css +2 -1
  460. package/build-style/style-rtl.css +64 -41
  461. package/build-style/style.css +64 -41
  462. package/build-style/tab-list/editor-rtl.css +12 -4
  463. package/build-style/tab-list/editor.css +12 -4
  464. package/build-style/{tab → tab-list}/style-rtl.css +5 -3
  465. package/build-style/{tab → tab-list}/style.css +5 -3
  466. package/build-style/tab-panel/style-rtl.css +0 -17
  467. package/build-style/tab-panel/style.css +0 -17
  468. package/build-style/template-part/editor-rtl.css +8 -4
  469. package/build-style/template-part/editor.css +8 -4
  470. package/build-style/video/style-rtl.css +2 -1
  471. package/build-style/video/style.css +2 -1
  472. package/package.json +55 -48
  473. package/src/accordion/README.md +97 -0
  474. package/src/accordion-heading/README.md +81 -0
  475. package/src/accordion-item/README.md +85 -0
  476. package/src/accordion-panel/README.md +74 -0
  477. package/src/archives/README.md +56 -0
  478. package/src/audio/README.md +55 -0
  479. package/src/avatar/README.md +74 -0
  480. package/src/avatar/index.php +2 -2
  481. package/src/block/README.md +56 -0
  482. package/src/block/index.php +2 -26
  483. package/src/breadcrumbs/README.md +67 -0
  484. package/src/button/README.md +93 -0
  485. package/src/buttons/README.md +80 -0
  486. package/src/calendar/README.md +51 -0
  487. package/src/categories/README.md +69 -0
  488. package/src/code/README.md +55 -0
  489. package/src/column/README.md +72 -0
  490. package/src/columns/README.md +90 -0
  491. package/src/columns/test/transforms.js +164 -0
  492. package/src/columns/transforms.js +74 -0
  493. package/src/comment-author-avatar/README.md +63 -0
  494. package/src/comment-author-avatar/index.php +3 -3
  495. package/src/comment-author-name/README.md +67 -0
  496. package/src/comment-author-name/index.php +1 -1
  497. package/src/comment-content/README.md +61 -0
  498. package/src/comment-date/README.md +67 -0
  499. package/src/comment-date/index.php +1 -1
  500. package/src/comment-edit-link/README.md +67 -0
  501. package/src/comment-reply-link/README.md +63 -0
  502. package/src/comment-template/README.md +60 -0
  503. package/src/comments/README.md +88 -0
  504. package/src/comments-pagination/README.md +77 -0
  505. package/src/comments-pagination-next/README.md +64 -0
  506. package/src/comments-pagination-numbers/README.md +64 -0
  507. package/src/comments-pagination-previous/README.md +64 -0
  508. package/src/comments-title/README.md +70 -0
  509. package/src/common.scss +63 -10
  510. package/src/cover/README.md +111 -0
  511. package/src/cover/edit/block-controls.js +14 -2
  512. package/src/cover/edit/index.js +86 -0
  513. package/src/cover/edit/inspector-controls.js +124 -54
  514. package/src/details/README.md +65 -0
  515. package/src/editor.scss +0 -1
  516. package/src/embed/README.md +56 -0
  517. package/src/file/README.md +60 -0
  518. package/src/file/edit.js +3 -16
  519. package/src/file/index.js +2 -0
  520. package/src/file/transforms.js +12 -31
  521. package/src/file/variations.js +17 -0
  522. package/src/footnotes/README.md +64 -0
  523. package/src/form/README.md +90 -0
  524. package/src/form-input/README.md +74 -0
  525. package/src/form-submission-notification/README.md +50 -0
  526. package/src/form-submit-button/README.md +54 -0
  527. package/src/freeform/README.md +49 -0
  528. package/src/gallery/README.md +115 -0
  529. package/src/gallery/edit.js +214 -351
  530. package/src/gallery/test/transforms.js +155 -0
  531. package/src/gallery/transforms.js +47 -0
  532. package/src/group/README.md +80 -0
  533. package/src/heading/README.md +60 -0
  534. package/src/heading/edit.js +1 -2
  535. package/src/home-link/README.md +66 -0
  536. package/src/home-link/index.php +3 -15
  537. package/src/html/README.md +48 -0
  538. package/src/icon/README.md +66 -0
  539. package/src/icon/block.json +12 -0
  540. package/src/icon/edit.js +86 -36
  541. package/src/icon/index.js +3 -1
  542. package/src/icon/index.php +23 -0
  543. package/src/icon/style.scss +12 -0
  544. package/src/icon/variations.js +9 -0
  545. package/src/image/README.md +103 -0
  546. package/src/image/block.json +1 -0
  547. package/src/image/edit.js +8 -3
  548. package/src/image/image.js +120 -54
  549. package/src/image/index.php +4 -5
  550. package/src/image/transforms.js +34 -8
  551. package/src/index.js +4 -11
  552. package/src/latest-comments/README.md +57 -0
  553. package/src/latest-posts/README.md +71 -0
  554. package/src/list/README.md +70 -0
  555. package/src/list/edit.js +2 -9
  556. package/src/list/ordered-list-settings.js +46 -92
  557. package/src/list-item/README.md +71 -0
  558. package/src/list-item/hooks/use-merge.js +53 -46
  559. package/src/loginout/README.md +56 -0
  560. package/src/math/README.md +50 -0
  561. package/src/media-text/README.md +92 -0
  562. package/src/missing/README.md +55 -0
  563. package/src/more/README.md +49 -0
  564. package/src/navigation/README.md +115 -0
  565. package/src/navigation/edit/index.js +33 -40
  566. package/src/navigation/index.php +58 -0
  567. package/src/navigation-link/README.md +93 -0
  568. package/src/navigation-link/edit.js +0 -1
  569. package/src/navigation-link/index.php +1 -15
  570. package/src/navigation-overlay-close/README.md +48 -0
  571. package/src/navigation-submenu/README.md +89 -0
  572. package/src/navigation-submenu/block.json +7 -0
  573. package/src/navigation-submenu/edit.js +1 -0
  574. package/src/navigation-submenu/index.php +1 -17
  575. package/src/nextpage/README.md +50 -0
  576. package/src/page-list/README.md +84 -0
  577. package/src/page-list/block.json +2 -5
  578. package/src/page-list/edit.js +0 -11
  579. package/src/page-list/index.php +4 -16
  580. package/src/page-list-item/README.md +77 -0
  581. package/src/paragraph/README.md +70 -0
  582. package/src/paragraph/deprecated.js +1 -0
  583. package/src/paragraph/edit.js +13 -1
  584. package/src/pattern/README.md +45 -0
  585. package/src/playlist/README.md +86 -0
  586. package/src/playlist/block.json +12 -0
  587. package/src/playlist/edit.js +27 -0
  588. package/src/playlist/index.php +10 -3
  589. package/src/playlist/save.js +9 -1
  590. package/src/playlist/style.scss +7 -0
  591. package/src/playlist/view.js +1 -0
  592. package/src/playlist-track/README.md +69 -0
  593. package/src/post-author/README.md +78 -0
  594. package/src/post-author-biography/README.md +59 -0
  595. package/src/post-author-name/README.md +63 -0
  596. package/src/post-author-name/index.php +1 -1
  597. package/src/post-comment/README.md +61 -0
  598. package/src/post-comments-count/README.md +58 -0
  599. package/src/post-comments-form/README.md +59 -0
  600. package/src/post-comments-link/README.md +60 -0
  601. package/src/post-content/README.md +71 -0
  602. package/src/post-date/README.md +65 -0
  603. package/src/post-date/edit.js +2 -2
  604. package/src/post-date/index.php +1 -1
  605. package/src/post-excerpt/README.md +66 -0
  606. package/src/post-featured-image/README.md +86 -0
  607. package/src/post-featured-image/block.json +1 -0
  608. package/src/post-featured-image/dimension-controls.js +105 -184
  609. package/src/post-featured-image/edit.js +53 -21
  610. package/src/post-featured-image/index.php +25 -23
  611. package/src/post-navigation-link/README.md +63 -0
  612. package/src/post-template/README.md +71 -0
  613. package/src/post-terms/README.md +65 -0
  614. package/src/post-time-to-read/README.md +63 -0
  615. package/src/post-time-to-read/index.js +1 -1
  616. package/src/post-time-to-read/variations.js +2 -2
  617. package/src/post-title/README.md +69 -0
  618. package/src/preformatted/README.md +50 -0
  619. package/src/pullquote/README.md +64 -0
  620. package/src/pullquote/block.json +1 -3
  621. package/src/pullquote/deprecated.js +121 -9
  622. package/src/pullquote/edit.js +8 -38
  623. package/src/pullquote/save.js +2 -13
  624. package/src/query/README.md +64 -0
  625. package/src/query-no-results/README.md +65 -0
  626. package/src/query-pagination/README.md +79 -0
  627. package/src/query-pagination-next/README.md +67 -0
  628. package/src/query-pagination-numbers/README.md +65 -0
  629. package/src/query-pagination-previous/README.md +67 -0
  630. package/src/query-title/README.md +65 -0
  631. package/src/query-total/README.md +66 -0
  632. package/src/quote/README.md +75 -0
  633. package/src/quote/edit.js +3 -9
  634. package/src/read-more/README.md +61 -0
  635. package/src/read-more/index.php +2 -2
  636. package/src/rss/README.md +62 -0
  637. package/src/search/README.md +66 -0
  638. package/src/search/index.php +1 -1
  639. package/src/separator/README.md +62 -0
  640. package/src/shortcode/README.md +44 -0
  641. package/src/shortcode/transforms.js +2 -2
  642. package/src/site-logo/README.md +72 -0
  643. package/src/site-tagline/README.md +56 -0
  644. package/src/site-title/README.md +57 -0
  645. package/src/social-link/README.md +64 -0
  646. package/src/social-links/README.md +98 -0
  647. package/src/spacer/README.md +53 -0
  648. package/src/style.scss +1 -2
  649. package/src/tab-list/README.md +81 -0
  650. package/src/tab-list/block.json +34 -21
  651. package/src/tab-list/edit.js +147 -15
  652. package/src/tab-list/editor.scss +13 -6
  653. package/src/tab-list/index.php +23 -30
  654. package/src/tab-list/save.js +39 -4
  655. package/src/{tab → tab-list}/style.scss +1 -1
  656. package/src/tab-panel/README.md +72 -0
  657. package/src/tab-panel/add-tab-toolbar-control.js +24 -11
  658. package/src/tab-panel/block.json +2 -6
  659. package/src/tab-panel/remove-tab-toolbar-control.js +10 -14
  660. package/src/tab-panel/style.scss +0 -17
  661. package/src/tab-panels/README.md +59 -0
  662. package/src/tab-panels/block.json +2 -27
  663. package/src/table/README.md +71 -0
  664. package/src/table-of-contents/README.md +61 -0
  665. package/src/tabs/README.md +77 -0
  666. package/src/tabs/block.json +3 -17
  667. package/src/tabs/edit.js +8 -19
  668. package/src/tabs/index.js +6 -10
  669. package/src/tabs/index.php +0 -13
  670. package/src/tabs/use-tab-list-items-sync.js +49 -0
  671. package/src/tabs/view.js +2 -10
  672. package/src/tag-cloud/README.md +62 -0
  673. package/src/template-part/README.md +48 -0
  674. package/src/term-count/README.md +59 -0
  675. package/src/term-description/README.md +60 -0
  676. package/src/term-name/README.md +65 -0
  677. package/src/term-template/README.md +65 -0
  678. package/src/terms-query/README.md +58 -0
  679. package/src/text-columns/README.md +51 -0
  680. package/src/utils/style-state.js +151 -0
  681. package/src/utils/test/style-state.js +307 -0
  682. package/src/utils/test/waveform-player.js +254 -0
  683. package/src/utils/waveform-player.js +90 -18
  684. package/src/utils/waveform-utils.js +15 -11
  685. package/src/verse/README.md +58 -0
  686. package/src/video/README.md +58 -0
  687. package/src/video/edit-common-settings.js +4 -7
  688. package/babel-plugin.cjs +0 -150
  689. package/build/tab/block.json +0 -56
  690. package/build/tab/controls.cjs +0 -46
  691. package/build/tab/controls.cjs.map +0 -7
  692. package/build/tab/edit.cjs +0 -135
  693. package/build/tab/edit.cjs.map +0 -7
  694. package/build/tab/index.cjs +0 -58
  695. package/build/tab/index.cjs.map +0 -7
  696. package/build/tab/save.cjs.map +0 -7
  697. package/build/tabs/use-tab-list-sync.cjs +0 -190
  698. package/build/tabs/use-tab-list-sync.cjs.map +0 -7
  699. package/build-module/tab/block.json +0 -56
  700. package/build-module/tab/controls.mjs +0 -15
  701. package/build-module/tab/controls.mjs.map +0 -7
  702. package/build-module/tab/edit.mjs +0 -108
  703. package/build-module/tab/edit.mjs.map +0 -7
  704. package/build-module/tab/index.mjs +0 -20
  705. package/build-module/tab/index.mjs.map +0 -7
  706. package/build-module/tab/save.mjs +0 -14
  707. package/build-module/tab/save.mjs.map +0 -7
  708. package/build-module/tabs/use-tab-list-sync.mjs +0 -169
  709. package/build-module/tabs/use-tab-list-sync.mjs.map +0 -7
  710. package/build-style/tab/editor-rtl.css +0 -11
  711. package/build-style/tab/editor.css +0 -11
  712. package/build-style/tab-panels/style-rtl.css +0 -4
  713. package/build-style/tab-panels/style.css +0 -4
  714. package/src/audio/edit.native.js +0 -250
  715. package/src/audio/style.native.scss +0 -13
  716. package/src/audio/test/__snapshots__/edit.native.js.snap +0 -546
  717. package/src/audio/test/__snapshots__/transforms.native.js.snap +0 -25
  718. package/src/audio/test/edit.native.js +0 -132
  719. package/src/audio/test/transforms.native.js +0 -43
  720. package/src/audio/transforms.native.js +0 -12
  721. package/src/block/edit-title.native.js +0 -67
  722. package/src/block/edit.native.js +0 -247
  723. package/src/block/editor.native.scss +0 -125
  724. package/src/block/test/__snapshots__/transforms.native.js.snap +0 -15
  725. package/src/block/test/edit.native.js +0 -262
  726. package/src/block/test/transforms.native.js +0 -40
  727. package/src/button/color-background.native.js +0 -41
  728. package/src/button/edit.native.js +0 -567
  729. package/src/button/editor.native.scss +0 -70
  730. package/src/button/rich-text.android.scss +0 -6
  731. package/src/button/rich-text.ios.scss +0 -6
  732. package/src/buttons/edit.native.js +0 -157
  733. package/src/buttons/editor.native.scss +0 -11
  734. package/src/buttons/test/__snapshots__/edit.native.js.snap +0 -99
  735. package/src/buttons/test/__snapshots__/transforms.native.js.snap +0 -31
  736. package/src/buttons/test/edit.native.js +0 -485
  737. package/src/buttons/test/transforms.native.js +0 -48
  738. package/src/buttons/transforms.native.js +0 -12
  739. package/src/code/edit.native.js +0 -70
  740. package/src/code/test/__snapshots__/edit.native.js.snap +0 -13
  741. package/src/code/test/edit.native.js +0 -65
  742. package/src/code/theme.native.scss +0 -22
  743. package/src/code/transforms.native.js +0 -12
  744. package/src/column/column-preview.native.js +0 -58
  745. package/src/column/edit.native.js +0 -273
  746. package/src/column/editor.native.scss +0 -75
  747. package/src/columns/columnCalculations.native.js +0 -178
  748. package/src/columns/edit.native.js +0 -507
  749. package/src/columns/editor.native.scss +0 -17
  750. package/src/columns/test/__snapshots__/edit.native.js.snap +0 -305
  751. package/src/columns/test/__snapshots__/transforms.native.js.snap +0 -61
  752. package/src/columns/test/edit.native.js +0 -496
  753. package/src/columns/test/transforms.native.js +0 -89
  754. package/src/columns/transforms.native.js +0 -12
  755. package/src/cover/controls.native.js +0 -307
  756. package/src/cover/edit.native.js +0 -708
  757. package/src/cover/focal-point-settings-button.native.js +0 -53
  758. package/src/cover/overlay-color-settings.native.js +0 -106
  759. package/src/cover/style.native.scss +0 -220
  760. package/src/cover/test/__snapshots__/edit.native.js.snap +0 -105
  761. package/src/cover/test/__snapshots__/transforms.native.js.snap +0 -73
  762. package/src/cover/test/edit.native.js +0 -701
  763. package/src/cover/test/transforms.native.js +0 -116
  764. package/src/cover/transforms.native.js +0 -12
  765. package/src/cover/use-cover-is-dark.native.js +0 -51
  766. package/src/embed/edit.native.js +0 -345
  767. package/src/embed/embed-controls.native.js +0 -65
  768. package/src/embed/embed-link-settings.native.js +0 -99
  769. package/src/embed/embed-loading.native.js +0 -29
  770. package/src/embed/embed-no-preview.native.js +0 -230
  771. package/src/embed/embed-placeholder.native.js +0 -178
  772. package/src/embed/embed-preview.native.js +0 -157
  773. package/src/embed/styles.native.scss +0 -196
  774. package/src/embed/test/__snapshots__/index.native.js.snap +0 -191
  775. package/src/embed/test/__snapshots__/transforms.native.js.snap +0 -23
  776. package/src/embed/test/index.native.js +0 -1125
  777. package/src/embed/test/transforms.native.js +0 -44
  778. package/src/embed/transforms.native.js +0 -12
  779. package/src/embed/wp-embed-preview.native.js +0 -80
  780. package/src/file/edit.native.js +0 -605
  781. package/src/file/style.native.scss +0 -79
  782. package/src/file/test/__snapshots__/edit.native.js.snap +0 -580
  783. package/src/file/test/__snapshots__/transforms.native.js.snap +0 -19
  784. package/src/file/test/edit.native.js +0 -93
  785. package/src/file/test/transforms.native.js +0 -43
  786. package/src/file/transforms.native.js +0 -12
  787. package/src/freeform/edit.native.js +0 -13
  788. package/src/freeform/test/__snapshots__/index.native.js.snap +0 -7
  789. package/src/freeform/test/__snapshots__/transforms.native.js.snap +0 -19
  790. package/src/freeform/test/index.native.js +0 -57
  791. package/src/freeform/test/transforms.native.js +0 -39
  792. package/src/gallery/gallery-styles.native.scss +0 -8
  793. package/src/gallery/gallery.native.js +0 -124
  794. package/src/gallery/styles.native.scss +0 -7
  795. package/src/gallery/test/__snapshots__/index.native.js.snap +0 -177
  796. package/src/gallery/test/__snapshots__/transforms.native.js.snap +0 -53
  797. package/src/gallery/test/helpers.native.js +0 -106
  798. package/src/gallery/test/index.native.js +0 -700
  799. package/src/gallery/test/transforms.native.js +0 -53
  800. package/src/gallery/test/use-get-media.native.js +0 -24
  801. package/src/gallery/transforms.native.js +0 -12
  802. package/src/gallery/use-get-media.native.js +0 -49
  803. package/src/group/edit.native.js +0 -137
  804. package/src/group/editor.native.scss +0 -56
  805. package/src/group/test/__snapshots__/edit.native.js.snap +0 -19
  806. package/src/group/test/__snapshots__/transforms.native.js.snap +0 -35
  807. package/src/group/test/edit.native.js +0 -100
  808. package/src/group/test/transforms.native.js +0 -73
  809. package/src/heading/edit.native.js +0 -159
  810. package/src/heading/test/__snapshots__/index.native.js.snap +0 -43
  811. package/src/heading/test/__snapshots__/transforms.native.js.snap +0 -47
  812. package/src/heading/test/index.native.js +0 -257
  813. package/src/heading/test/transforms.native.js +0 -46
  814. package/src/heading/transforms.native.js +0 -12
  815. package/src/html/transforms.native.js +0 -11
  816. package/src/image/edit.native.js +0 -959
  817. package/src/image/styles.native.scss +0 -70
  818. package/src/image/test/__snapshots__/transforms.native.js.snap +0 -49
  819. package/src/image/test/edit.native.js +0 -459
  820. package/src/image/test/transforms.native.js +0 -49
  821. package/src/image/transforms.native.js +0 -12
  822. package/src/index.native.js +0 -274
  823. package/src/latest-posts/edit.native.js +0 -294
  824. package/src/latest-posts/style.native.scss +0 -47
  825. package/src/latest-posts/test/__snapshots__/edit.native.js.snap +0 -3
  826. package/src/latest-posts/test/__snapshots__/transforms.native.js.snap +0 -15
  827. package/src/latest-posts/test/edit.native.js +0 -49
  828. package/src/latest-posts/test/transforms.native.js +0 -61
  829. package/src/list/tag-name.native.js +0 -12
  830. package/src/list/test/__snapshots__/edit.native.js.snap +0 -121
  831. package/src/list/test/__snapshots__/transforms.native.js.snap +0 -85
  832. package/src/list/test/edit.native.js +0 -602
  833. package/src/list/test/transforms.native.js +0 -56
  834. package/src/list/transforms.native.js +0 -12
  835. package/src/list-item/edit.native.js +0 -175
  836. package/src/list-item/hooks/use-enter.native.js +0 -81
  837. package/src/list-item/icons.native.js +0 -34
  838. package/src/list-item/list-style-type.native.js +0 -146
  839. package/src/list-item/style.native.scss +0 -57
  840. package/src/media-text/edit.native.js +0 -417
  841. package/src/media-text/icon-retry.native.js +0 -11
  842. package/src/media-text/media-container.native.js +0 -393
  843. package/src/media-text/style.native.scss +0 -191
  844. package/src/media-text/test/__snapshots__/transforms.native.js.snap +0 -73
  845. package/src/media-text/test/edit.native.js +0 -58
  846. package/src/media-text/test/transforms.native.js +0 -116
  847. package/src/media-text/transforms.native.js +0 -12
  848. package/src/missing/edit.native.js +0 -294
  849. package/src/missing/style.native.scss +0 -79
  850. package/src/missing/test/__snapshots__/edit.native.js.snap +0 -110
  851. package/src/missing/test/edit-integration.native.js +0 -168
  852. package/src/missing/test/edit.native.js +0 -81
  853. package/src/more/edit.native.js +0 -36
  854. package/src/more/editor.native.scss +0 -21
  855. package/src/more/test/__snapshots__/edit.native.js.snap +0 -7
  856. package/src/more/test/__snapshots__/transforms.native.js.snap +0 -19
  857. package/src/more/test/edit.native.js +0 -41
  858. package/src/more/test/transforms.native.js +0 -42
  859. package/src/more/transforms.native.js +0 -12
  860. package/src/navigation-link/shared/build-css-font-sizes.php +0 -43
  861. package/src/nextpage/edit.native.js +0 -58
  862. package/src/nextpage/editor.native.scss +0 -21
  863. package/src/nextpage/test/__snapshots__/transforms.native.js.snap +0 -19
  864. package/src/nextpage/test/transforms.native.js +0 -42
  865. package/src/nextpage/transforms.native.js +0 -12
  866. package/src/paragraph/edit.native.js +0 -116
  867. package/src/paragraph/test/__snapshots__/edit.native.js.snap +0 -88
  868. package/src/paragraph/test/__snapshots__/transforms.native.js.snap +0 -65
  869. package/src/paragraph/test/edit.native.js +0 -999
  870. package/src/paragraph/test/transforms.native.js +0 -51
  871. package/src/paragraph/transforms.native.js +0 -12
  872. package/src/preformatted/edit.native.js +0 -48
  873. package/src/preformatted/styles.native.scss +0 -30
  874. package/src/preformatted/test/__snapshots__/edit.native.js.snap +0 -95
  875. package/src/preformatted/test/__snapshots__/transforms.native.js.snap +0 -37
  876. package/src/preformatted/test/edit.native.js +0 -111
  877. package/src/preformatted/test/transforms.native.js +0 -47
  878. package/src/preformatted/transforms.native.js +0 -12
  879. package/src/pullquote/blockquote.native.js +0 -39
  880. package/src/pullquote/blockquote.native.scss +0 -8
  881. package/src/pullquote/edit.native.js +0 -128
  882. package/src/pullquote/figure.native.js +0 -33
  883. package/src/pullquote/figure.native.scss +0 -16
  884. package/src/pullquote/test/__snapshots__/transforms.native.js.snap +0 -47
  885. package/src/pullquote/test/edit.native.js +0 -73
  886. package/src/pullquote/test/transforms.native.js +0 -46
  887. package/src/pullquote/transforms.native.js +0 -12
  888. package/src/quote/test/__snapshots__/transforms.native.js.snap +0 -49
  889. package/src/quote/test/edit.native.js +0 -94
  890. package/src/quote/test/transforms.native.js +0 -69
  891. package/src/quote/transforms.native.js +0 -12
  892. package/src/search/edit.native.js +0 -486
  893. package/src/search/style.native.scss +0 -99
  894. package/src/search/test/__snapshots__/edit.native.js.snap +0 -827
  895. package/src/search/test/__snapshots__/transforms.native.js.snap +0 -15
  896. package/src/search/test/edit.native.js +0 -170
  897. package/src/search/test/transforms.native.js +0 -40
  898. package/src/separator/separator-settings.native.js +0 -3
  899. package/src/separator/test/__snapshots__/edit.native.js.snap +0 -7
  900. package/src/separator/test/__snapshots__/transforms.native.js.snap +0 -25
  901. package/src/separator/test/edit.native.js +0 -41
  902. package/src/separator/test/transforms.native.js +0 -42
  903. package/src/separator/transforms.native.js +0 -12
  904. package/src/shortcode/edit.native.js +0 -77
  905. package/src/shortcode/style.native.scss +0 -44
  906. package/src/shortcode/test/__snapshots__/edit.native.js.snap +0 -9
  907. package/src/shortcode/test/__snapshots__/transforms.native.js.snap +0 -19
  908. package/src/shortcode/test/edit.native.js +0 -70
  909. package/src/shortcode/test/transforms.native.js +0 -42
  910. package/src/shortcode/transforms.native.js +0 -12
  911. package/src/social-link/edit.native.js +0 -219
  912. package/src/social-link/editor.native.scss +0 -18
  913. package/src/social-links/edit.native.js +0 -147
  914. package/src/social-links/editor.native.scss +0 -25
  915. package/src/social-links/test/__snapshots__/edit.native.js.snap +0 -57
  916. package/src/social-links/test/__snapshots__/transforms.native.js.snap +0 -31
  917. package/src/social-links/test/edit.native.js +0 -266
  918. package/src/social-links/test/transforms.native.js +0 -53
  919. package/src/spacer/controls.native.js +0 -86
  920. package/src/spacer/edit.native.js +0 -110
  921. package/src/spacer/editor.native.scss +0 -18
  922. package/src/spacer/save.native.js +0 -18
  923. package/src/spacer/test/__snapshots__/index.native.js.snap +0 -43
  924. package/src/spacer/test/__snapshots__/transforms.native.js.snap +0 -25
  925. package/src/spacer/test/index.native.js +0 -257
  926. package/src/spacer/test/transforms.native.js +0 -42
  927. package/src/tab/block.json +0 -56
  928. package/src/tab/controls.js +0 -19
  929. package/src/tab/edit.js +0 -141
  930. package/src/tab/editor.scss +0 -14
  931. package/src/tab/index.js +0 -24
  932. package/src/tab/index.php +0 -70
  933. package/src/tab/save.js +0 -13
  934. package/src/tab-panels/style.scss +0 -4
  935. package/src/table/transforms.native.js +0 -11
  936. package/src/tabs/use-tab-list-sync.js +0 -237
  937. package/src/text-columns/transforms.native.js +0 -12
  938. package/src/utils/init-block.native.js +0 -40
  939. package/src/utils/transformation-categories.native.js +0 -47
  940. package/src/verse/test/__snapshots__/edit.native.js.snap +0 -13
  941. package/src/verse/test/__snapshots__/transforms.native.js.snap +0 -31
  942. package/src/verse/test/edit.native.js +0 -118
  943. package/src/verse/test/transforms.native.js +0 -46
  944. package/src/verse/transforms.native.js +0 -12
  945. package/src/video/edit.native.js +0 -406
  946. package/src/video/icon-retry.native.js +0 -11
  947. package/src/video/style.native.scss +0 -81
  948. package/src/video/test/__snapshots__/transforms.native.js.snap +0 -41
  949. package/src/video/test/edit.native.js +0 -53
  950. package/src/video/test/transforms.native.js +0 -49
  951. package/src/video/transforms.native.js +0 -12
@@ -1,959 +0,0 @@
1
- /**
2
- * External dependencies
3
- */
4
- import {
5
- ActivityIndicator,
6
- Image as RNImage,
7
- TouchableWithoutFeedback,
8
- View,
9
- } from 'react-native';
10
- import { useRoute } from '@react-navigation/native';
11
-
12
- /**
13
- * WordPress dependencies
14
- */
15
- import { Component, useEffect } from '@wordpress/element';
16
- import {
17
- requestMediaImport,
18
- mediaUploadSync,
19
- requestImageFailedRetryDialog,
20
- requestImageUploadCancelDialog,
21
- requestImageFullscreenPreview,
22
- setFeaturedImage,
23
- } from '@wordpress/react-native-bridge';
24
- import {
25
- Icon as WCIcon,
26
- PanelBody,
27
- ToolbarButton,
28
- ToolbarGroup,
29
- Image,
30
- WIDE_ALIGNMENTS,
31
- LinkSettingsNavigation,
32
- BottomSheet,
33
- BottomSheetTextControl,
34
- BottomSheetSelectControl,
35
- FooterMessageControl,
36
- FooterMessageLink,
37
- WCBadge,
38
- } from '@wordpress/components';
39
- import {
40
- BlockCaption,
41
- MediaPlaceholder,
42
- MediaUpload,
43
- MediaUploadProgress,
44
- MEDIA_TYPE_IMAGE,
45
- BlockControls,
46
- InspectorControls,
47
- BlockStyles,
48
- store as blockEditorStore,
49
- blockSettingsScreens,
50
- RichText,
51
- } from '@wordpress/block-editor';
52
- import { __, _x, sprintf } from '@wordpress/i18n';
53
- import { getProtocol, hasQueryArg, isURL } from '@wordpress/url';
54
- import { doAction, hasAction } from '@wordpress/hooks';
55
- import { compose, withPreferredColorScheme } from '@wordpress/compose';
56
- import { withSelect, withDispatch } from '@wordpress/data';
57
- import {
58
- image as placeholderIcon,
59
- replace,
60
- fullscreen,
61
- textColor,
62
- } from '@wordpress/icons';
63
- import { store as coreStore } from '@wordpress/core-data';
64
- import { store as noticesStore } from '@wordpress/notices';
65
- // eslint-disable-next-line no-restricted-imports
66
- import { store as editPostStore } from '@wordpress/edit-post';
67
-
68
- /**
69
- * Internal dependencies
70
- */
71
- import styles from './styles.scss';
72
- import { getUpdatedLinkTargetSettings } from './utils';
73
-
74
- import {
75
- LINK_DESTINATION_NONE,
76
- LINK_DESTINATION_CUSTOM,
77
- LINK_DESTINATION_ATTACHMENT,
78
- LINK_DESTINATION_MEDIA,
79
- MEDIA_ID_NO_FEATURED_IMAGE_SET,
80
- } from './constants';
81
-
82
- const getUrlForSlug = ( image, sizeSlug ) => {
83
- if ( ! sizeSlug ) {
84
- return undefined;
85
- }
86
- return image?.media_details?.sizes?.[ sizeSlug ]?.source_url;
87
- };
88
-
89
- function LinkSettings( {
90
- attributes,
91
- image,
92
- isLinkSheetVisible,
93
- setMappedAttributes,
94
- } ) {
95
- const route = useRoute();
96
- const { href: url, label, linkDestination, linkTarget, rel } = attributes;
97
-
98
- // Persist attributes passed from child screen.
99
- useEffect( () => {
100
- const { inputValue: newUrl } = route.params || {};
101
-
102
- let newLinkDestination;
103
- switch ( newUrl ) {
104
- case attributes.url:
105
- newLinkDestination = LINK_DESTINATION_MEDIA;
106
- break;
107
- case image?.link:
108
- newLinkDestination = LINK_DESTINATION_ATTACHMENT;
109
- break;
110
- case '':
111
- newLinkDestination = LINK_DESTINATION_NONE;
112
- break;
113
- default:
114
- newLinkDestination = LINK_DESTINATION_CUSTOM;
115
- break;
116
- }
117
-
118
- setMappedAttributes( {
119
- url: newUrl,
120
- linkDestination: newLinkDestination,
121
- } );
122
- }, [ route.params?.inputValue ] );
123
-
124
- let valueMask;
125
- switch ( linkDestination ) {
126
- case LINK_DESTINATION_MEDIA:
127
- valueMask = __( 'Media File' );
128
- break;
129
- case LINK_DESTINATION_ATTACHMENT:
130
- valueMask = __( 'Attachment Page' );
131
- break;
132
- case LINK_DESTINATION_CUSTOM:
133
- valueMask = __( 'Custom URL' );
134
- break;
135
- default:
136
- valueMask = __( 'None' );
137
- break;
138
- }
139
-
140
- const linkSettingsOptions = {
141
- url: {
142
- valueMask,
143
- autoFocus: false,
144
- autoFill: false,
145
- },
146
- openInNewTab: {
147
- label: __( 'Open in new tab' ),
148
- },
149
- linkRel: {
150
- label: __( 'Link relation' ),
151
- placeholder: _x( 'None', 'Link rel attribute value placeholder' ),
152
- },
153
- };
154
-
155
- return (
156
- <PanelBody title={ __( 'Link Settings' ) }>
157
- <LinkSettingsNavigation
158
- isVisible={ isLinkSheetVisible }
159
- url={ url }
160
- rel={ rel }
161
- label={ label }
162
- linkTarget={ linkTarget }
163
- setAttributes={ setMappedAttributes }
164
- withBottomSheet={ false }
165
- hasPicker
166
- options={ linkSettingsOptions }
167
- showIcon={ false }
168
- onLinkCellPressed={ ( { navigation } ) => {
169
- navigation.navigate(
170
- blockSettingsScreens.imageLinkDestinations,
171
- {
172
- inputValue: attributes.href,
173
- linkDestination: attributes.linkDestination,
174
- imageUrl: attributes.url,
175
- attachmentPageUrl: image?.link,
176
- }
177
- );
178
- } }
179
- />
180
- </PanelBody>
181
- );
182
- }
183
-
184
- const UPLOAD_STATE_IDLE = 0;
185
- const UPLOAD_STATE_UPLOADING = 1;
186
- const UPLOAD_STATE_SUCCEEDED = 2;
187
- const UPLOAD_STATE_FAILED = 3;
188
-
189
- export class ImageEdit extends Component {
190
- constructor( props ) {
191
- super( props );
192
-
193
- this.state = {
194
- isCaptionSelected: false,
195
- uploadStatus: UPLOAD_STATE_IDLE,
196
- };
197
-
198
- this.replacedFeaturedImage = false;
199
-
200
- this.finishMediaUploadWithSuccess =
201
- this.finishMediaUploadWithSuccess.bind( this );
202
- this.finishMediaUploadWithFailure =
203
- this.finishMediaUploadWithFailure.bind( this );
204
- this.mediaUploadStateReset = this.mediaUploadStateReset.bind( this );
205
- this.onSelectMediaUploadOption =
206
- this.onSelectMediaUploadOption.bind( this );
207
- this.updateMediaProgress = this.updateMediaProgress.bind( this );
208
- this.updateImageURL = this.updateImageURL.bind( this );
209
- this.onSetNewTab = this.onSetNewTab.bind( this );
210
- this.onSetSizeSlug = this.onSetSizeSlug.bind( this );
211
- this.onImagePressed = this.onImagePressed.bind( this );
212
- this.onSetFeatured = this.onSetFeatured.bind( this );
213
- this.onFocusCaption = this.onFocusCaption.bind( this );
214
- this.onSelectURL = this.onSelectURL.bind( this );
215
- this.accessibilityLabelCreator =
216
- this.accessibilityLabelCreator.bind( this );
217
- this.setMappedAttributes = this.setMappedAttributes.bind( this );
218
- this.onSizeChangeValue = this.onSizeChangeValue.bind( this );
219
- }
220
-
221
- componentDidMount() {
222
- const { attributes, setAttributes } = this.props;
223
- // This will warn when we have `id` defined, while `url` is undefined.
224
- // This may help track this issue: https://github.com/wordpress-mobile/WordPress-Android/issues/9768
225
- // where a cancelled image upload was resulting in a subsequent crash.
226
- if ( attributes.id && ! attributes.url ) {
227
- // eslint-disable-next-line no-console
228
- console.warn( 'Attributes has id with no url.' );
229
- }
230
-
231
- // Detect any pasted image and start an upload.
232
- if (
233
- ! attributes.id &&
234
- attributes.url &&
235
- getProtocol( attributes.url ) === 'file:'
236
- ) {
237
- requestMediaImport( attributes.url, ( id, url ) => {
238
- if ( url ) {
239
- setAttributes( { id, url } );
240
- }
241
- } );
242
- }
243
-
244
- // Make sure we mark any temporary images as failed if they failed while
245
- // the editor wasn't open.
246
- if (
247
- attributes.id &&
248
- attributes.url &&
249
- getProtocol( attributes.url ) === 'file:'
250
- ) {
251
- mediaUploadSync();
252
- }
253
- }
254
-
255
- componentWillUnmount() {
256
- // This action will only exist if the user pressed the trash button on the block holder.
257
- if (
258
- hasAction( 'blocks.onRemoveBlockCheckUpload' ) &&
259
- this.state.uploadStatus === UPLOAD_STATE_UPLOADING
260
- ) {
261
- doAction(
262
- 'blocks.onRemoveBlockCheckUpload',
263
- this.props.attributes.id
264
- );
265
- }
266
- }
267
-
268
- componentDidUpdate( previousProps ) {
269
- const { image, attributes, setAttributes, featuredImageId } =
270
- this.props;
271
- const { url } = attributes;
272
- if ( ! previousProps.image && image ) {
273
- if ( ! hasQueryArg( url, 'w' ) && attributes?.sizeSlug ) {
274
- const updatedUrl =
275
- getUrlForSlug( image, attributes.sizeSlug ) ||
276
- image.source_url;
277
-
278
- setAttributes( { url: updatedUrl } );
279
- }
280
- }
281
-
282
- const { id } = attributes;
283
- const { id: previousId } = previousProps.attributes;
284
-
285
- // The media changed and the previous media was set as the Featured Image,
286
- // we must keep track of the previous media's featured status to act on it
287
- // once the new media has a finalized ID.
288
- if (
289
- !! id &&
290
- id !== previousId &&
291
- !! featuredImageId &&
292
- featuredImageId === previousId
293
- ) {
294
- this.replacedFeaturedImage = true;
295
- }
296
-
297
- // The media changed and now has a finalized ID (e.g. upload completed), we
298
- // should attempt to replace the featured image if applicable.
299
- if (
300
- this.replacedFeaturedImage &&
301
- !! image &&
302
- this.canImageBeFeatured()
303
- ) {
304
- this.replacedFeaturedImage = false;
305
- setFeaturedImage( id );
306
- }
307
-
308
- const { align } = attributes;
309
- const { __unstableMarkNextChangeAsNotPersistent } = this.props;
310
-
311
- // Update the attributes if the align is wide or full
312
- if ( [ 'wide', 'full' ].includes( align ) ) {
313
- __unstableMarkNextChangeAsNotPersistent();
314
- setAttributes( {
315
- width: undefined,
316
- height: undefined,
317
- aspectRatio: undefined,
318
- scale: undefined,
319
- } );
320
- }
321
- }
322
-
323
- static getDerivedStateFromProps( props, state ) {
324
- // Avoid a UI flicker in the toolbar by insuring that isCaptionSelected
325
- // is updated immediately any time the isSelected prop becomes false.
326
- return {
327
- isCaptionSelected: props.isSelected && state.isCaptionSelected,
328
- };
329
- }
330
-
331
- accessibilityLabelCreator( caption ) {
332
- // Checks if caption is empty.
333
- return RichText.isEmpty( caption )
334
- ? /* translators: accessibility text. Empty image caption. */
335
- 'Image caption. Empty'
336
- : sprintf(
337
- /* translators: accessibility text. %s: image caption. */
338
- __( 'Image caption. %s' ),
339
- caption
340
- );
341
- }
342
-
343
- onImagePressed() {
344
- const { attributes, image } = this.props;
345
-
346
- if ( this.state.uploadStatus === UPLOAD_STATE_UPLOADING ) {
347
- requestImageUploadCancelDialog( attributes.id );
348
- } else if (
349
- attributes.id &&
350
- getProtocol( attributes.url ) === 'file:'
351
- ) {
352
- requestImageFailedRetryDialog( attributes.id );
353
- } else if ( ! this.state.isCaptionSelected ) {
354
- requestImageFullscreenPreview(
355
- attributes.url,
356
- image && image.source_url
357
- );
358
- }
359
-
360
- this.setState( {
361
- isCaptionSelected: false,
362
- } );
363
- }
364
-
365
- updateMediaProgress( payload ) {
366
- const { setAttributes } = this.props;
367
- if ( payload.mediaUrl ) {
368
- setAttributes( { url: payload.mediaUrl } );
369
- }
370
-
371
- if ( this.state.uploadStatus !== UPLOAD_STATE_UPLOADING ) {
372
- this.setState( { uploadStatus: UPLOAD_STATE_UPLOADING } );
373
- }
374
- }
375
-
376
- finishMediaUploadWithSuccess( payload ) {
377
- const { setAttributes } = this.props;
378
-
379
- setAttributes( { url: payload.mediaUrl, id: payload.mediaServerId } );
380
- this.setState( { uploadStatus: UPLOAD_STATE_SUCCEEDED } );
381
- }
382
-
383
- finishMediaUploadWithFailure( payload ) {
384
- const { setAttributes } = this.props;
385
-
386
- setAttributes( { id: payload.mediaId } );
387
- this.setState( { uploadStatus: UPLOAD_STATE_FAILED } );
388
- }
389
-
390
- mediaUploadStateReset() {
391
- const { setAttributes } = this.props;
392
-
393
- setAttributes( { id: null, url: null } );
394
- this.setState( { uploadStatus: UPLOAD_STATE_IDLE } );
395
- }
396
-
397
- updateImageURL( url ) {
398
- this.props.setAttributes( {
399
- url,
400
- width: undefined,
401
- height: undefined,
402
- } );
403
- }
404
-
405
- onSetNewTab( value ) {
406
- const updatedLinkTarget = getUpdatedLinkTargetSettings(
407
- value,
408
- this.props.attributes
409
- );
410
- this.props.setAttributes( updatedLinkTarget );
411
- }
412
-
413
- onSetSizeSlug( sizeSlug ) {
414
- const { image, setAttributes } = this.props;
415
-
416
- const url = getUrlForSlug( image, sizeSlug );
417
- if ( ! url ) {
418
- return null;
419
- }
420
- setAttributes( {
421
- url,
422
- width: undefined,
423
- height: undefined,
424
- sizeSlug,
425
- } );
426
- }
427
-
428
- onSelectMediaUploadOption( media ) {
429
- const { imageDefaultSize } = this.props;
430
- const { id, url, destination } = this.props.attributes;
431
- const mediaAttributes = {
432
- id: media.id,
433
- url: media.url,
434
- caption: media.caption,
435
- alt: media.alt,
436
- };
437
-
438
- let additionalAttributes;
439
- // Reset the dimension attributes if changing to a different image.
440
- if ( ! media.id || media.id !== id ) {
441
- additionalAttributes = {
442
- width: undefined,
443
- height: undefined,
444
- sizeSlug: imageDefaultSize,
445
- };
446
- } else {
447
- // Keep the same url when selecting the same file, so "Image Size" option is not changed.
448
- additionalAttributes = { url };
449
- }
450
-
451
- let href;
452
- switch ( destination ) {
453
- case LINK_DESTINATION_MEDIA:
454
- href = media.url;
455
- break;
456
- case LINK_DESTINATION_ATTACHMENT:
457
- href = media.link;
458
- break;
459
- }
460
- mediaAttributes.href = href;
461
-
462
- this.props.setAttributes( {
463
- ...mediaAttributes,
464
- ...additionalAttributes,
465
- } );
466
- }
467
-
468
- onSelectURL( newURL ) {
469
- const { createErrorNotice, imageDefaultSize, setAttributes } =
470
- this.props;
471
-
472
- if ( isURL( newURL ) ) {
473
- this.setState( {
474
- isFetchingImage: true,
475
- } );
476
-
477
- // Use RN's Image.getSize to determine if URL is a valid image
478
- RNImage.getSize(
479
- newURL,
480
- () => {
481
- setAttributes( {
482
- url: newURL,
483
- id: undefined,
484
- width: undefined,
485
- height: undefined,
486
- sizeSlug: imageDefaultSize,
487
- } );
488
- this.setState( {
489
- isFetchingImage: false,
490
- } );
491
- },
492
- () => {
493
- createErrorNotice( __( 'Image file not found.' ) );
494
- this.setState( {
495
- isFetchingImage: false,
496
- } );
497
- }
498
- );
499
- } else {
500
- createErrorNotice( __( 'Invalid URL.' ) );
501
- }
502
- }
503
-
504
- onFocusCaption() {
505
- if ( this.props.onFocus ) {
506
- this.props.onFocus();
507
- }
508
- if ( ! this.state.isCaptionSelected ) {
509
- this.setState( {
510
- isCaptionSelected: true,
511
- } );
512
- }
513
- }
514
-
515
- getPlaceholderIcon() {
516
- return (
517
- <WCIcon
518
- icon={ placeholderIcon }
519
- { ...this.props.getStylesFromColorScheme(
520
- styles.iconPlaceholder,
521
- styles.iconPlaceholderDark
522
- ) }
523
- />
524
- );
525
- }
526
-
527
- showLoadingIndicator() {
528
- return (
529
- <View style={ styles.image__loading }>
530
- <ActivityIndicator animating />
531
- </View>
532
- );
533
- }
534
-
535
- getWidth() {
536
- const { attributes } = this.props;
537
- const { align, width } = attributes;
538
-
539
- return Object.values( WIDE_ALIGNMENTS.alignments ).includes( align )
540
- ? '100%'
541
- : width;
542
- }
543
-
544
- setMappedAttributes( { url: href, linkDestination, ...restAttributes } ) {
545
- const { setAttributes } = this.props;
546
- if ( ! href && ! linkDestination ) {
547
- linkDestination = LINK_DESTINATION_NONE;
548
- } else if ( ! linkDestination ) {
549
- linkDestination = LINK_DESTINATION_CUSTOM;
550
- }
551
-
552
- return href === undefined || href === this.props.attributes.href
553
- ? setAttributes( restAttributes )
554
- : setAttributes( {
555
- ...restAttributes,
556
- linkDestination,
557
- href,
558
- } );
559
- }
560
-
561
- getAltTextSettings() {
562
- const {
563
- attributes: { alt },
564
- } = this.props;
565
-
566
- const updateAlt = ( newAlt ) => {
567
- this.props.setAttributes( { alt: newAlt } );
568
- };
569
-
570
- return (
571
- <BottomSheetTextControl
572
- initialValue={ alt }
573
- onChange={ updateAlt }
574
- placeholder={ __( 'Add alt text' ) }
575
- label={ __( 'Alt Text' ) }
576
- icon={ textColor }
577
- footerNote={
578
- <>
579
- { __(
580
- 'Describe the purpose of the image. Leave empty if decorative.'
581
- ) }{ ' ' }
582
- <FooterMessageLink
583
- href={
584
- // translators: Localized tutorial, if one exists. W3C Web Accessibility Initiative link has list of existing translations.
585
- __(
586
- 'https://www.w3.org/WAI/tutorials/images/decision-tree/'
587
- )
588
- }
589
- value={ __( 'What is alt text?' ) }
590
- />
591
- </>
592
- }
593
- />
594
- );
595
- }
596
-
597
- onSizeChangeValue( newValue ) {
598
- this.onSetSizeSlug( newValue );
599
- }
600
-
601
- onSetFeatured( mediaId ) {
602
- const { closeSettingsBottomSheet } = this.props;
603
- setFeaturedImage( mediaId );
604
- closeSettingsBottomSheet();
605
- }
606
-
607
- getFeaturedButtonPanel( isFeaturedImage ) {
608
- const { attributes, getStylesFromColorScheme } = this.props;
609
-
610
- const setFeaturedButtonStyle = getStylesFromColorScheme(
611
- styles.setFeaturedButton,
612
- styles.setFeaturedButtonDark
613
- );
614
-
615
- const removeFeaturedButton = () => (
616
- <BottomSheet.Cell
617
- label={ __( 'Remove as Featured Image' ) }
618
- labelStyle={ [
619
- setFeaturedButtonStyle,
620
- styles.removeFeaturedButton,
621
- ] }
622
- cellContainerStyle={ styles.setFeaturedButtonCellContainer }
623
- separatorType="none"
624
- onPress={ () =>
625
- this.onSetFeatured( MEDIA_ID_NO_FEATURED_IMAGE_SET )
626
- }
627
- />
628
- );
629
-
630
- const setFeaturedButton = () => (
631
- <BottomSheet.Cell
632
- label={ __( 'Set as Featured Image' ) }
633
- labelStyle={ setFeaturedButtonStyle }
634
- cellContainerStyle={ styles.setFeaturedButtonCellContainer }
635
- separatorType="none"
636
- onPress={ () => this.onSetFeatured( attributes.id ) }
637
- />
638
- );
639
-
640
- return isFeaturedImage ? removeFeaturedButton() : setFeaturedButton();
641
- }
642
-
643
- /**
644
- * Featured images must be set to a successfully uploaded self-hosted image,
645
- * which has an ID.
646
- *
647
- * @return {boolean} Boolean indicating whether or not the current may be set as featured.
648
- */
649
- canImageBeFeatured() {
650
- const {
651
- attributes: { id },
652
- } = this.props;
653
- return (
654
- typeof id !== 'undefined' &&
655
- this.state.uploadStatus !== UPLOAD_STATE_UPLOADING &&
656
- this.state.uploadStatus !== UPLOAD_STATE_FAILED
657
- );
658
- }
659
-
660
- isGif( url ) {
661
- return url.toLowerCase().includes( '.gif' );
662
- }
663
-
664
- render() {
665
- const { isCaptionSelected, isFetchingImage } = this.state;
666
- const {
667
- attributes,
668
- isSelected,
669
- image,
670
- clientId,
671
- imageDefaultSize,
672
- context,
673
- featuredImageId,
674
- wasBlockJustInserted,
675
- shouldUseFastImage,
676
- } = this.props;
677
- const { align, url, alt, id, sizeSlug, className } = attributes;
678
- const hasImageContext = context
679
- ? Object.keys( context ).length > 0
680
- : false;
681
-
682
- const imageSizes = Array.isArray( this.props.imageSizes )
683
- ? this.props.imageSizes
684
- : [];
685
- // Only map available image sizes for the user to choose.
686
- const sizeOptions = imageSizes
687
- .filter( ( { slug } ) => getUrlForSlug( image, slug ) )
688
- .map( ( { name, slug } ) => ( { value: slug, label: name } ) );
689
-
690
- let selectedSizeOption = sizeSlug || imageDefaultSize;
691
- let sizeOptionsValid = sizeOptions.find(
692
- ( option ) => option.value === selectedSizeOption
693
- );
694
-
695
- if ( ! sizeOptionsValid ) {
696
- // Default to 'full' size if the default large size is not available.
697
- sizeOptionsValid = sizeOptions.find(
698
- ( option ) => option.value === 'full'
699
- );
700
- selectedSizeOption = 'full';
701
- }
702
-
703
- const canImageBeFeatured = this.canImageBeFeatured();
704
- const isFeaturedImage =
705
- canImageBeFeatured && featuredImageId === attributes.id;
706
-
707
- const getToolbarEditButton = ( open ) => (
708
- <BlockControls>
709
- <ToolbarGroup>
710
- <ToolbarButton
711
- title={ __( 'Edit image' ) }
712
- icon={ replace }
713
- onClick={ open }
714
- />
715
- </ToolbarGroup>
716
- </BlockControls>
717
- );
718
-
719
- const getInspectorControls = () => (
720
- <InspectorControls>
721
- <PanelBody title={ __( 'Settings' ) } />
722
- <PanelBody style={ styles.panelBody }>
723
- <BlockStyles clientId={ clientId } url={ url } />
724
- </PanelBody>
725
- <PanelBody>
726
- { image && sizeOptionsValid && (
727
- <BottomSheetSelectControl
728
- icon={ fullscreen }
729
- label={ __( 'Size' ) }
730
- options={ sizeOptions }
731
- onChange={ this.onSizeChangeValue }
732
- value={ selectedSizeOption }
733
- />
734
- ) }
735
- { this.getAltTextSettings() }
736
- </PanelBody>
737
- <LinkSettings
738
- attributes={ this.props.attributes }
739
- image={ this.props.image }
740
- isLinkSheetVisible={ this.state.isLinkSheetVisible }
741
- setMappedAttributes={ this.setMappedAttributes }
742
- />
743
- <PanelBody
744
- title={ __( 'Featured Image' ) }
745
- titleStyle={ styles.featuredImagePanelTitle }
746
- >
747
- { canImageBeFeatured &&
748
- this.getFeaturedButtonPanel( isFeaturedImage ) }
749
- <FooterMessageControl
750
- label={ __(
751
- 'Changes to featured image will not be affected by the undo/redo buttons.'
752
- ) }
753
- cellContainerStyle={
754
- styles.setFeaturedButtonCellContainer
755
- }
756
- />
757
- </PanelBody>
758
- </InspectorControls>
759
- );
760
-
761
- if ( ! url ) {
762
- return (
763
- <View style={ styles.content }>
764
- { isFetchingImage && this.showLoadingIndicator() }
765
- <MediaPlaceholder
766
- allowedTypes={ [ MEDIA_TYPE_IMAGE ] }
767
- onSelect={ this.onSelectMediaUploadOption }
768
- onSelectURL={ this.onSelectURL }
769
- icon={ this.getPlaceholderIcon() }
770
- onFocus={ this.props.onFocus }
771
- autoOpenMediaUpload={
772
- isSelected && wasBlockJustInserted
773
- }
774
- />
775
- </View>
776
- );
777
- }
778
-
779
- const alignToFlex = {
780
- left: 'flex-start',
781
- center: 'center',
782
- right: 'flex-end',
783
- full: 'center',
784
- wide: 'center',
785
- };
786
-
787
- const additionalImageProps = {
788
- height: '100%',
789
- resizeMode: context?.imageCrop ? 'cover' : 'contain',
790
- };
791
-
792
- const imageContainerStyles = [
793
- context?.fixedHeight && styles.fixedHeight,
794
- ];
795
-
796
- const isGif = this.isGif( url );
797
- const badgeLabelShown = isFeaturedImage || isGif;
798
- let badgeLabelText = '';
799
- if ( isFeaturedImage ) {
800
- badgeLabelText = __( 'Featured' );
801
- } else if ( isGif ) {
802
- badgeLabelText = __( 'GIF' );
803
- }
804
-
805
- const getImageComponent = ( openMediaOptions, getMediaOptions ) => (
806
- <WCBadge label={ badgeLabelText } show={ badgeLabelShown }>
807
- <TouchableWithoutFeedback
808
- accessible={ ! isSelected }
809
- onPress={ this.onImagePressed }
810
- disabled={ ! isSelected }
811
- >
812
- <View style={ styles.content }>
813
- { isSelected && getInspectorControls() }
814
- { isSelected && getMediaOptions() }
815
- { ! this.state.isCaptionSelected &&
816
- getToolbarEditButton( openMediaOptions ) }
817
- <MediaUploadProgress
818
- enablePausedUploads
819
- coverUrl={ url }
820
- mediaId={ id }
821
- onUpdateMediaProgress={ this.updateMediaProgress }
822
- onFinishMediaUploadWithSuccess={
823
- this.finishMediaUploadWithSuccess
824
- }
825
- onFinishMediaUploadWithFailure={
826
- this.finishMediaUploadWithFailure
827
- }
828
- onMediaUploadStateReset={
829
- this.mediaUploadStateReset
830
- }
831
- renderContent={ ( {
832
- isUploadPaused,
833
- isUploadInProgress,
834
- isUploadFailed,
835
- retryMessage,
836
- } ) => {
837
- return (
838
- <View style={ imageContainerStyles }>
839
- { isFetchingImage &&
840
- this.showLoadingIndicator() }
841
- <Image
842
- align={
843
- align && alignToFlex[ align ]
844
- }
845
- alt={ alt }
846
- isSelected={
847
- isSelected &&
848
- ! isCaptionSelected
849
- }
850
- isUploadFailed={ isUploadFailed }
851
- isUploadPaused={ isUploadPaused }
852
- isUploadInProgress={
853
- isUploadInProgress
854
- }
855
- shouldUseFastImage={
856
- shouldUseFastImage
857
- }
858
- onSelectMediaUploadOption={
859
- this.onSelectMediaUploadOption
860
- }
861
- openMediaOptions={
862
- openMediaOptions
863
- }
864
- retryMessage={ retryMessage }
865
- url={ url }
866
- shapeStyle={
867
- styles[ className ] || className
868
- }
869
- width={ this.getWidth() }
870
- { ...( hasImageContext
871
- ? additionalImageProps
872
- : {} ) }
873
- />
874
- </View>
875
- );
876
- } }
877
- />
878
- </View>
879
- </TouchableWithoutFeedback>
880
- <BlockCaption
881
- clientId={ this.props.clientId }
882
- isSelected={ this.state.isCaptionSelected }
883
- accessible={ ! this.state.isCaptionSelected }
884
- accessibilityLabelCreator={ this.accessibilityLabelCreator }
885
- onFocus={ this.onFocusCaption }
886
- onBlur={ this.props.onBlur } // Always assign onBlur as props.
887
- insertBlocksAfter={ this.props.insertBlocksAfter }
888
- />
889
- </WCBadge>
890
- );
891
-
892
- return (
893
- <MediaUpload
894
- allowedTypes={ [ MEDIA_TYPE_IMAGE ] }
895
- isReplacingMedia
896
- onSelect={ this.onSelectMediaUploadOption }
897
- onSelectURL={ this.onSelectURL }
898
- render={ ( { open, getMediaOptions } ) => {
899
- return getImageComponent( open, getMediaOptions );
900
- } }
901
- />
902
- );
903
- }
904
- }
905
-
906
- export default compose( [
907
- withSelect( ( select, props ) => {
908
- const { getEntityRecord } = select( coreStore );
909
- const { getSettings, wasBlockJustInserted } =
910
- select( blockEditorStore );
911
- const { getEditedPostAttribute } = select( 'core/editor' );
912
- const {
913
- attributes: { id, url },
914
- isSelected,
915
- clientId,
916
- } = props;
917
- const { imageSizes, imageDefaultSize, capabilities } = getSettings();
918
- const isNotFileUrl = id && getProtocol( url ) !== 'file:';
919
- const featuredImageId = getEditedPostAttribute( 'featured_media' );
920
-
921
- const shouldGetMedia =
922
- ( isSelected && isNotFileUrl ) ||
923
- // Edge case to update the image after uploading if the block gets unselected
924
- // Check if it's the original image and not the resized one with queryparams.
925
- ( ! isSelected &&
926
- isNotFileUrl &&
927
- url &&
928
- ! hasQueryArg( url, 'w' ) );
929
- const image = shouldGetMedia
930
- ? getEntityRecord( 'postType', 'attachment', id )
931
- : null;
932
-
933
- return {
934
- image,
935
- imageSizes,
936
- imageDefaultSize,
937
- shouldUseFastImage: capabilities?.shouldUseFastImage === true,
938
- featuredImageId,
939
- wasBlockJustInserted: wasBlockJustInserted(
940
- clientId,
941
- 'inserter_menu'
942
- ),
943
- };
944
- } ),
945
- withDispatch( ( dispatch ) => {
946
- const { createErrorNotice } = dispatch( noticesStore );
947
- const { __unstableMarkNextChangeAsNotPersistent } =
948
- dispatch( blockEditorStore );
949
-
950
- return {
951
- __unstableMarkNextChangeAsNotPersistent,
952
- createErrorNotice,
953
- closeSettingsBottomSheet() {
954
- dispatch( editPostStore ).closeGeneralSidebar();
955
- },
956
- };
957
- } ),
958
- withPreferredColorScheme,
959
- ] )( ImageEdit );