@wordpress/block-library 7.19.0 → 8.0.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 (761) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/build/audio/edit.native.js +1 -3
  3. package/build/audio/edit.native.js.map +1 -1
  4. package/build/audio/index.js +2 -1
  5. package/build/audio/index.js.map +1 -1
  6. package/build/avatar/edit.js +1 -0
  7. package/build/avatar/edit.js.map +1 -1
  8. package/build/avatar/user-control.js +1 -0
  9. package/build/avatar/user-control.js.map +1 -1
  10. package/build/block/edit.js +14 -2
  11. package/build/block/edit.js.map +1 -1
  12. package/build/block/edit.native.js +14 -6
  13. package/build/block/edit.native.js.map +1 -1
  14. package/build/block/index.js +1 -2
  15. package/build/block/index.js.map +1 -1
  16. package/build/button/edit.native.js.map +1 -1
  17. package/build/code/transforms.js +1 -1
  18. package/build/code/transforms.js.map +1 -1
  19. package/build/columns/edit.js +1 -0
  20. package/build/columns/edit.js.map +1 -1
  21. package/build/columns/edit.native.js +13 -30
  22. package/build/columns/edit.native.js.map +1 -1
  23. package/build/comment-author-avatar/edit.js +1 -0
  24. package/build/comment-author-avatar/edit.js.map +1 -1
  25. package/build/cover/edit/inspector-controls.js +2 -0
  26. package/build/cover/edit/inspector-controls.js.map +1 -1
  27. package/build/cover/edit.native.js +24 -16
  28. package/build/cover/edit.native.js.map +1 -1
  29. package/build/embed/embed-controls.native.js +1 -0
  30. package/build/embed/embed-controls.native.js.map +1 -1
  31. package/build/embed/embed-preview.native.js +1 -3
  32. package/build/embed/embed-preview.native.js.map +1 -1
  33. package/build/file/inspector.js +1 -0
  34. package/build/file/inspector.js.map +1 -1
  35. package/build/gallery/edit.js +25 -13
  36. package/build/gallery/edit.js.map +1 -1
  37. package/build/gallery/gallery.native.js +1 -3
  38. package/build/gallery/gallery.native.js.map +1 -1
  39. package/build/gallery/shared.js +4 -10
  40. package/build/gallery/shared.js.map +1 -1
  41. package/build/gallery/transforms.js +1 -7
  42. package/build/gallery/transforms.js.map +1 -1
  43. package/build/gallery/use-get-media.js +1 -1
  44. package/build/gallery/use-get-media.js.map +1 -1
  45. package/build/gallery/use-get-media.native.js +3 -1
  46. package/build/gallery/use-get-media.native.js.map +1 -1
  47. package/build/gallery/v1/edit.js +22 -15
  48. package/build/gallery/v1/edit.js.map +1 -1
  49. package/build/gallery/v1/gallery.native.js +1 -3
  50. package/build/gallery/v1/gallery.native.js.map +1 -1
  51. package/build/gallery/v1/shared.js +4 -1
  52. package/build/gallery/v1/shared.js.map +1 -1
  53. package/build/group/edit.js +1 -2
  54. package/build/group/edit.js.map +1 -1
  55. package/build/group/index.js +3 -1
  56. package/build/group/index.js.map +1 -1
  57. package/build/group/placeholder.js +5 -26
  58. package/build/group/placeholder.js.map +1 -1
  59. package/build/heading/deprecated.js +152 -69
  60. package/build/heading/deprecated.js.map +1 -1
  61. package/build/heading/index.js +1 -2
  62. package/build/heading/index.js.map +1 -1
  63. package/build/heading/transforms.js +1 -2
  64. package/build/heading/transforms.js.map +1 -1
  65. package/build/html/index.js +1 -1
  66. package/build/image/edit.js +8 -5
  67. package/build/image/edit.js.map +1 -1
  68. package/build/image/edit.native.js +3 -2
  69. package/build/image/edit.native.js.map +1 -1
  70. package/build/image/image.js +12 -8
  71. package/build/image/image.js.map +1 -1
  72. package/build/index.js +3 -1
  73. package/build/index.js.map +1 -1
  74. package/build/latest-comments/edit.js +1 -0
  75. package/build/latest-comments/edit.js.map +1 -1
  76. package/build/latest-posts/edit.js +2 -0
  77. package/build/latest-posts/edit.js.map +1 -1
  78. package/build/list/transforms.js +1 -9
  79. package/build/list/transforms.js.map +1 -1
  80. package/build/list/utils.js +5 -2
  81. package/build/list/utils.js.map +1 -1
  82. package/build/list-item/index.js +4 -1
  83. package/build/list-item/index.js.map +1 -1
  84. package/build/list-item/transforms.js +22 -0
  85. package/build/list-item/transforms.js.map +1 -0
  86. package/build/list-item/utils.js +77 -1
  87. package/build/list-item/utils.js.map +1 -1
  88. package/build/media-text/edit.js +4 -2
  89. package/build/media-text/edit.js.map +1 -1
  90. package/build/navigation/edit/are-blocks-dirty.js +52 -0
  91. package/build/navigation/edit/are-blocks-dirty.js.map +1 -0
  92. package/build/navigation/edit/index.js +95 -116
  93. package/build/navigation/edit/index.js.map +1 -1
  94. package/build/navigation/edit/menu-inspector-controls.js +72 -0
  95. package/build/navigation/edit/menu-inspector-controls.js.map +1 -0
  96. package/build/navigation/edit/navigation-menu-selector.js +5 -10
  97. package/build/navigation/edit/navigation-menu-selector.js.map +1 -1
  98. package/build/navigation/edit/unsaved-inner-blocks.js +11 -7
  99. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  100. package/build/navigation/view-modal.js +6 -2
  101. package/build/navigation/view-modal.js.map +1 -1
  102. package/build/navigation-link/edit.js +42 -298
  103. package/build/navigation-link/edit.js.map +1 -1
  104. package/build/navigation-link/link-ui.js +222 -0
  105. package/build/navigation-link/link-ui.js.map +1 -0
  106. package/build/navigation-link/transforms.js +12 -0
  107. package/build/navigation-link/transforms.js.map +1 -1
  108. package/build/navigation-link/update-attributes.js +108 -0
  109. package/build/navigation-link/update-attributes.js.map +1 -0
  110. package/build/navigation-submenu/edit.js +42 -173
  111. package/build/navigation-submenu/edit.js.map +1 -1
  112. package/build/page-list/constants.js +15 -0
  113. package/build/page-list/constants.js.map +1 -0
  114. package/build/page-list/convert-to-links-modal.js +22 -86
  115. package/build/page-list/convert-to-links-modal.js.map +1 -1
  116. package/build/page-list/convert-to-navigation-links.js +76 -0
  117. package/build/page-list/convert-to-navigation-links.js.map +1 -0
  118. package/build/page-list/edit.js +142 -78
  119. package/build/page-list/edit.js.map +1 -1
  120. package/build/page-list/index.js +6 -1
  121. package/build/page-list/index.js.map +1 -1
  122. package/build/page-list-item/edit.js +87 -0
  123. package/build/page-list-item/edit.js.map +1 -0
  124. package/build/page-list-item/index.js +85 -0
  125. package/build/page-list-item/index.js.map +1 -0
  126. package/build/page-list-item/init.js +16 -0
  127. package/build/page-list-item/init.js.map +1 -0
  128. package/build/paragraph/index.js +1 -7
  129. package/build/paragraph/index.js.map +1 -1
  130. package/build/post-author/edit.js +3 -2
  131. package/build/post-author/edit.js.map +1 -1
  132. package/build/post-featured-image/overlay.js +1 -0
  133. package/build/post-featured-image/overlay.js.map +1 -1
  134. package/build/post-template/index.js +8 -0
  135. package/build/post-template/index.js.map +1 -1
  136. package/build/preformatted/transforms.js +3 -1
  137. package/build/preformatted/transforms.js.map +1 -1
  138. package/build/query/deprecated.js +192 -21
  139. package/build/query/deprecated.js.map +1 -1
  140. package/build/query/edit/inspector-controls/index.js +1 -0
  141. package/build/query/edit/inspector-controls/index.js.map +1 -1
  142. package/build/query/edit/query-placeholder.js +3 -19
  143. package/build/query/edit/query-placeholder.js.map +1 -1
  144. package/build/query/index.js +0 -8
  145. package/build/query/index.js.map +1 -1
  146. package/build/query/utils.js +0 -8
  147. package/build/query/utils.js.map +1 -1
  148. package/build/rss/edit.js +3 -0
  149. package/build/rss/edit.js.map +1 -1
  150. package/build/search/edit.native.js +22 -22
  151. package/build/search/edit.native.js.map +1 -1
  152. package/build/search/index.js +9 -1
  153. package/build/search/index.js.map +1 -1
  154. package/build/site-logo/edit.js +17 -9
  155. package/build/site-logo/edit.js.map +1 -1
  156. package/build/site-logo/index.js +1 -0
  157. package/build/site-logo/index.js.map +1 -1
  158. package/build/site-title/index.js +1 -0
  159. package/build/site-title/index.js.map +1 -1
  160. package/build/social-link/social-list.js +4 -12
  161. package/build/social-link/social-list.js.map +1 -1
  162. package/build/table/edit.js +3 -1
  163. package/build/table/edit.js.map +1 -1
  164. package/build/table/index.js +17 -1
  165. package/build/table/index.js.map +1 -1
  166. package/build/table/save.js +4 -2
  167. package/build/table/save.js.map +1 -1
  168. package/build/table/state.js +24 -12
  169. package/build/table/state.js.map +1 -1
  170. package/build/table/transforms.js +3 -2
  171. package/build/table/transforms.js.map +1 -1
  172. package/build/table-of-contents/edit.js +2 -2
  173. package/build/table-of-contents/edit.js.map +1 -1
  174. package/build/tag-cloud/edit.js +2 -1
  175. package/build/tag-cloud/edit.js.map +1 -1
  176. package/build/template-part/edit/selection-modal.js +5 -2
  177. package/build/template-part/edit/selection-modal.js.map +1 -1
  178. package/build/template-part/edit/utils/hooks.js +2 -6
  179. package/build/template-part/edit/utils/hooks.js.map +1 -1
  180. package/build/text-columns/edit.js +1 -0
  181. package/build/text-columns/edit.js.map +1 -1
  182. package/build/utils/transformation-categories.native.js +1 -1
  183. package/build/utils/transformation-categories.native.js.map +1 -1
  184. package/build/video/edit.js +1 -1
  185. package/build/video/edit.js.map +1 -1
  186. package/build/video/edit.native.js +1 -3
  187. package/build/video/edit.native.js.map +1 -1
  188. package/build-module/audio/edit.native.js +1 -2
  189. package/build-module/audio/edit.native.js.map +1 -1
  190. package/build-module/audio/index.js +2 -1
  191. package/build-module/audio/index.js.map +1 -1
  192. package/build-module/avatar/edit.js +1 -0
  193. package/build-module/avatar/edit.js.map +1 -1
  194. package/build-module/avatar/user-control.js +1 -0
  195. package/build-module/avatar/user-control.js.map +1 -1
  196. package/build-module/block/edit.js +14 -2
  197. package/build-module/block/edit.js.map +1 -1
  198. package/build-module/block/edit.native.js +14 -6
  199. package/build-module/block/edit.native.js.map +1 -1
  200. package/build-module/block/index.js +1 -2
  201. package/build-module/block/index.js.map +1 -1
  202. package/build-module/button/edit.native.js +2 -1
  203. package/build-module/button/edit.native.js.map +1 -1
  204. package/build-module/code/transforms.js +1 -1
  205. package/build-module/code/transforms.js.map +1 -1
  206. package/build-module/columns/edit.js +1 -0
  207. package/build-module/columns/edit.js.map +1 -1
  208. package/build-module/columns/edit.native.js +13 -29
  209. package/build-module/columns/edit.native.js.map +1 -1
  210. package/build-module/comment-author-avatar/edit.js +1 -0
  211. package/build-module/comment-author-avatar/edit.js.map +1 -1
  212. package/build-module/cover/edit/inspector-controls.js +2 -0
  213. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  214. package/build-module/cover/edit.native.js +22 -14
  215. package/build-module/cover/edit.native.js.map +1 -1
  216. package/build-module/embed/embed-controls.native.js +2 -1
  217. package/build-module/embed/embed-controls.native.js.map +1 -1
  218. package/build-module/embed/embed-preview.native.js +1 -2
  219. package/build-module/embed/embed-preview.native.js.map +1 -1
  220. package/build-module/file/inspector.js +1 -0
  221. package/build-module/file/inspector.js.map +1 -1
  222. package/build-module/gallery/edit.js +25 -12
  223. package/build-module/gallery/edit.js.map +1 -1
  224. package/build-module/gallery/gallery.native.js +1 -2
  225. package/build-module/gallery/gallery.native.js.map +1 -1
  226. package/build-module/gallery/shared.js +5 -11
  227. package/build-module/gallery/shared.js.map +1 -1
  228. package/build-module/gallery/transforms.js +1 -6
  229. package/build-module/gallery/transforms.js.map +1 -1
  230. package/build-module/gallery/use-get-media.js +1 -1
  231. package/build-module/gallery/use-get-media.js.map +1 -1
  232. package/build-module/gallery/use-get-media.native.js +3 -1
  233. package/build-module/gallery/use-get-media.native.js.map +1 -1
  234. package/build-module/gallery/v1/edit.js +23 -16
  235. package/build-module/gallery/v1/edit.js.map +1 -1
  236. package/build-module/gallery/v1/gallery.native.js +1 -2
  237. package/build-module/gallery/v1/gallery.native.js.map +1 -1
  238. package/build-module/gallery/v1/shared.js +5 -2
  239. package/build-module/gallery/v1/shared.js.map +1 -1
  240. package/build-module/group/edit.js +1 -3
  241. package/build-module/group/edit.js.map +1 -1
  242. package/build-module/group/index.js +3 -1
  243. package/build-module/group/index.js.map +1 -1
  244. package/build-module/group/placeholder.js +5 -26
  245. package/build-module/group/placeholder.js.map +1 -1
  246. package/build-module/heading/deprecated.js +152 -69
  247. package/build-module/heading/deprecated.js.map +1 -1
  248. package/build-module/heading/index.js +1 -2
  249. package/build-module/heading/index.js.map +1 -1
  250. package/build-module/heading/transforms.js +1 -2
  251. package/build-module/heading/transforms.js.map +1 -1
  252. package/build-module/html/index.js +1 -1
  253. package/build-module/image/edit.js +9 -6
  254. package/build-module/image/edit.js.map +1 -1
  255. package/build-module/image/edit.native.js +2 -1
  256. package/build-module/image/edit.native.js.map +1 -1
  257. package/build-module/image/image.js +13 -9
  258. package/build-module/image/image.js.map +1 -1
  259. package/build-module/index.js +2 -1
  260. package/build-module/index.js.map +1 -1
  261. package/build-module/latest-comments/edit.js +1 -0
  262. package/build-module/latest-comments/edit.js.map +1 -1
  263. package/build-module/latest-posts/edit.js +2 -0
  264. package/build-module/latest-posts/edit.js.map +1 -1
  265. package/build-module/list/transforms.js +1 -9
  266. package/build-module/list/transforms.js.map +1 -1
  267. package/build-module/list/utils.js +5 -2
  268. package/build-module/list/utils.js.map +1 -1
  269. package/build-module/list-item/index.js +3 -1
  270. package/build-module/list-item/index.js.map +1 -1
  271. package/build-module/list-item/transforms.js +13 -0
  272. package/build-module/list-item/transforms.js.map +1 -0
  273. package/build-module/list-item/utils.js +78 -1
  274. package/build-module/list-item/utils.js.map +1 -1
  275. package/build-module/media-text/edit.js +5 -3
  276. package/build-module/media-text/edit.js.map +1 -1
  277. package/build-module/navigation/edit/are-blocks-dirty.js +44 -0
  278. package/build-module/navigation/edit/are-blocks-dirty.js.map +1 -0
  279. package/build-module/navigation/edit/index.js +95 -117
  280. package/build-module/navigation/edit/index.js.map +1 -1
  281. package/build-module/navigation/edit/menu-inspector-controls.js +59 -0
  282. package/build-module/navigation/edit/menu-inspector-controls.js.map +1 -0
  283. package/build-module/navigation/edit/navigation-menu-selector.js +6 -11
  284. package/build-module/navigation/edit/navigation-menu-selector.js.map +1 -1
  285. package/build-module/navigation/edit/unsaved-inner-blocks.js +9 -6
  286. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  287. package/build-module/navigation/view-modal.js +6 -2
  288. package/build-module/navigation/view-modal.js.map +1 -1
  289. package/build-module/navigation-link/edit.js +46 -299
  290. package/build-module/navigation-link/edit.js.map +1 -1
  291. package/build-module/navigation-link/link-ui.js +206 -0
  292. package/build-module/navigation-link/link-ui.js.map +1 -0
  293. package/build-module/navigation-link/transforms.js +12 -0
  294. package/build-module/navigation-link/transforms.js.map +1 -1
  295. package/build-module/navigation-link/update-attributes.js +97 -0
  296. package/build-module/navigation-link/update-attributes.js.map +1 -0
  297. package/build-module/navigation-submenu/edit.js +47 -175
  298. package/build-module/navigation-submenu/edit.js.map +1 -1
  299. package/build-module/page-list/constants.js +6 -0
  300. package/build-module/page-list/constants.js.map +1 -0
  301. package/build-module/page-list/convert-to-links-modal.js +20 -81
  302. package/build-module/page-list/convert-to-links-modal.js.map +1 -1
  303. package/build-module/page-list/convert-to-navigation-links.js +66 -0
  304. package/build-module/page-list/convert-to-navigation-links.js.map +1 -0
  305. package/build-module/page-list/edit.js +144 -82
  306. package/build-module/page-list/edit.js.map +1 -1
  307. package/build-module/page-list/index.js +6 -1
  308. package/build-module/page-list/index.js.map +1 -1
  309. package/build-module/page-list-item/edit.js +74 -0
  310. package/build-module/page-list-item/edit.js.map +1 -0
  311. package/build-module/page-list-item/index.js +68 -0
  312. package/build-module/page-list-item/index.js.map +1 -0
  313. package/build-module/page-list-item/init.js +6 -0
  314. package/build-module/page-list-item/init.js.map +1 -0
  315. package/build-module/paragraph/index.js +1 -7
  316. package/build-module/paragraph/index.js.map +1 -1
  317. package/build-module/post-author/edit.js +3 -2
  318. package/build-module/post-author/edit.js.map +1 -1
  319. package/build-module/post-featured-image/overlay.js +1 -0
  320. package/build-module/post-featured-image/overlay.js.map +1 -1
  321. package/build-module/post-template/index.js +8 -0
  322. package/build-module/post-template/index.js.map +1 -1
  323. package/build-module/preformatted/transforms.js +3 -1
  324. package/build-module/preformatted/transforms.js.map +1 -1
  325. package/build-module/query/deprecated.js +185 -21
  326. package/build-module/query/deprecated.js.map +1 -1
  327. package/build-module/query/edit/inspector-controls/index.js +1 -0
  328. package/build-module/query/edit/inspector-controls/index.js.map +1 -1
  329. package/build-module/query/edit/query-placeholder.js +3 -19
  330. package/build-module/query/edit/query-placeholder.js.map +1 -1
  331. package/build-module/query/index.js +0 -8
  332. package/build-module/query/index.js.map +1 -1
  333. package/build-module/query/utils.js +0 -8
  334. package/build-module/query/utils.js.map +1 -1
  335. package/build-module/rss/edit.js +3 -0
  336. package/build-module/rss/edit.js.map +1 -1
  337. package/build-module/search/edit.native.js +20 -20
  338. package/build-module/search/edit.native.js.map +1 -1
  339. package/build-module/search/index.js +8 -1
  340. package/build-module/search/index.js.map +1 -1
  341. package/build-module/site-logo/edit.js +17 -8
  342. package/build-module/site-logo/edit.js.map +1 -1
  343. package/build-module/site-logo/index.js +1 -0
  344. package/build-module/site-logo/index.js.map +1 -1
  345. package/build-module/site-title/index.js +1 -0
  346. package/build-module/site-title/index.js.map +1 -1
  347. package/build-module/social-link/social-list.js +2 -11
  348. package/build-module/social-link/social-list.js.map +1 -1
  349. package/build-module/table/edit.js +3 -1
  350. package/build-module/table/edit.js.map +1 -1
  351. package/build-module/table/index.js +17 -1
  352. package/build-module/table/index.js.map +1 -1
  353. package/build-module/table/save.js +4 -2
  354. package/build-module/table/save.js.map +1 -1
  355. package/build-module/table/state.js +25 -13
  356. package/build-module/table/state.js.map +1 -1
  357. package/build-module/table/transforms.js +3 -2
  358. package/build-module/table/transforms.js.map +1 -1
  359. package/build-module/table-of-contents/edit.js +2 -2
  360. package/build-module/table-of-contents/edit.js.map +1 -1
  361. package/build-module/tag-cloud/edit.js +3 -2
  362. package/build-module/tag-cloud/edit.js.map +1 -1
  363. package/build-module/template-part/edit/selection-modal.js +6 -3
  364. package/build-module/template-part/edit/selection-modal.js.map +1 -1
  365. package/build-module/template-part/edit/utils/hooks.js +3 -7
  366. package/build-module/template-part/edit/utils/hooks.js.map +1 -1
  367. package/build-module/text-columns/edit.js +1 -0
  368. package/build-module/text-columns/edit.js.map +1 -1
  369. package/build-module/utils/transformation-categories.native.js +1 -1
  370. package/build-module/utils/transformation-categories.native.js.map +1 -1
  371. package/build-module/video/edit.js +1 -1
  372. package/build-module/video/edit.js.map +1 -1
  373. package/build-module/video/edit.native.js +1 -2
  374. package/build-module/video/edit.native.js.map +1 -1
  375. package/build-style/archives/editor-rtl.css +12 -0
  376. package/build-style/archives/editor.css +12 -0
  377. package/build-style/archives/style-rtl.css +12 -0
  378. package/build-style/archives/style.css +12 -0
  379. package/build-style/audio/editor-rtl.css +12 -0
  380. package/build-style/audio/editor.css +12 -0
  381. package/build-style/audio/style-rtl.css +12 -0
  382. package/build-style/audio/style.css +12 -0
  383. package/build-style/audio/theme-rtl.css +12 -0
  384. package/build-style/audio/theme.css +12 -0
  385. package/build-style/avatar/editor-rtl.css +12 -0
  386. package/build-style/avatar/editor.css +12 -0
  387. package/build-style/avatar/style-rtl.css +12 -0
  388. package/build-style/avatar/style.css +12 -0
  389. package/build-style/block/editor-rtl.css +22 -0
  390. package/build-style/block/editor.css +22 -0
  391. package/build-style/button/editor-rtl.css +12 -0
  392. package/build-style/button/editor.css +12 -0
  393. package/build-style/button/style-rtl.css +12 -0
  394. package/build-style/button/style.css +12 -0
  395. package/build-style/buttons/editor-rtl.css +12 -0
  396. package/build-style/buttons/editor.css +12 -0
  397. package/build-style/buttons/style-rtl.css +12 -0
  398. package/build-style/buttons/style.css +12 -0
  399. package/build-style/calendar/style-rtl.css +12 -0
  400. package/build-style/calendar/style.css +12 -0
  401. package/build-style/categories/editor-rtl.css +12 -0
  402. package/build-style/categories/editor.css +12 -0
  403. package/build-style/categories/style-rtl.css +12 -0
  404. package/build-style/categories/style.css +12 -0
  405. package/build-style/classic-rtl.css +12 -0
  406. package/build-style/classic.css +12 -0
  407. package/build-style/code/editor-rtl.css +12 -0
  408. package/build-style/code/editor.css +12 -0
  409. package/build-style/code/style-rtl.css +12 -0
  410. package/build-style/code/style.css +12 -0
  411. package/build-style/code/theme-rtl.css +12 -0
  412. package/build-style/code/theme.css +12 -0
  413. package/build-style/columns/editor-rtl.css +12 -0
  414. package/build-style/columns/editor.css +12 -0
  415. package/build-style/columns/style-rtl.css +12 -0
  416. package/build-style/columns/style.css +12 -0
  417. package/build-style/comment-author-avatar/editor-rtl.css +12 -0
  418. package/build-style/comment-author-avatar/editor.css +12 -0
  419. package/build-style/comment-content/style-rtl.css +12 -0
  420. package/build-style/comment-content/style.css +12 -0
  421. package/build-style/comment-template/style-rtl.css +12 -0
  422. package/build-style/comment-template/style.css +12 -0
  423. package/build-style/comments/editor-rtl.css +12 -0
  424. package/build-style/comments/editor.css +12 -0
  425. package/build-style/comments/style-rtl.css +12 -0
  426. package/build-style/comments/style.css +12 -0
  427. package/build-style/comments-pagination/editor-rtl.css +12 -0
  428. package/build-style/comments-pagination/editor.css +12 -0
  429. package/build-style/comments-pagination/style-rtl.css +12 -0
  430. package/build-style/comments-pagination/style.css +12 -0
  431. package/build-style/comments-pagination-numbers/editor-rtl.css +12 -0
  432. package/build-style/comments-pagination-numbers/editor.css +12 -0
  433. package/build-style/comments-title/editor-rtl.css +12 -0
  434. package/build-style/comments-title/editor.css +12 -0
  435. package/build-style/common-rtl.css +17 -1
  436. package/build-style/common.css +17 -1
  437. package/build-style/cover/editor-rtl.css +12 -0
  438. package/build-style/cover/editor.css +12 -0
  439. package/build-style/cover/style-rtl.css +14 -1
  440. package/build-style/cover/style.css +14 -1
  441. package/build-style/editor-elements-rtl.css +12 -0
  442. package/build-style/editor-elements.css +12 -0
  443. package/build-style/editor-rtl.css +39 -20
  444. package/build-style/editor.css +39 -20
  445. package/build-style/elements-rtl.css +12 -0
  446. package/build-style/elements.css +12 -0
  447. package/build-style/embed/editor-rtl.css +12 -0
  448. package/build-style/embed/editor.css +12 -0
  449. package/build-style/embed/style-rtl.css +12 -0
  450. package/build-style/embed/style.css +12 -0
  451. package/build-style/embed/theme-rtl.css +12 -0
  452. package/build-style/embed/theme.css +12 -0
  453. package/build-style/file/editor-rtl.css +12 -0
  454. package/build-style/file/editor.css +12 -0
  455. package/build-style/file/style-rtl.css +12 -0
  456. package/build-style/file/style.css +12 -0
  457. package/build-style/freeform/editor-rtl.css +12 -0
  458. package/build-style/freeform/editor.css +12 -0
  459. package/build-style/gallery/editor-rtl.css +13 -1
  460. package/build-style/gallery/editor.css +13 -1
  461. package/build-style/gallery/style-rtl.css +16 -2
  462. package/build-style/gallery/style.css +16 -2
  463. package/build-style/gallery/theme-rtl.css +12 -0
  464. package/build-style/gallery/theme.css +12 -0
  465. package/build-style/group/editor-rtl.css +12 -0
  466. package/build-style/group/editor.css +12 -0
  467. package/build-style/group/style-rtl.css +12 -0
  468. package/build-style/group/style.css +12 -0
  469. package/build-style/group/theme-rtl.css +12 -0
  470. package/build-style/group/theme.css +12 -0
  471. package/build-style/heading/style-rtl.css +12 -0
  472. package/build-style/heading/style.css +12 -0
  473. package/build-style/html/editor-rtl.css +12 -0
  474. package/build-style/html/editor.css +12 -0
  475. package/build-style/image/editor-rtl.css +12 -9
  476. package/build-style/image/editor.css +12 -9
  477. package/build-style/image/style-rtl.css +12 -0
  478. package/build-style/image/style.css +12 -0
  479. package/build-style/image/theme-rtl.css +12 -0
  480. package/build-style/image/theme.css +12 -0
  481. package/build-style/latest-comments/style-rtl.css +12 -0
  482. package/build-style/latest-comments/style.css +12 -0
  483. package/build-style/latest-posts/editor-rtl.css +12 -0
  484. package/build-style/latest-posts/editor.css +12 -0
  485. package/build-style/latest-posts/style-rtl.css +12 -0
  486. package/build-style/latest-posts/style.css +12 -0
  487. package/build-style/list/style-rtl.css +12 -0
  488. package/build-style/list/style.css +12 -0
  489. package/build-style/media-text/editor-rtl.css +12 -0
  490. package/build-style/media-text/editor.css +12 -0
  491. package/build-style/media-text/style-rtl.css +12 -0
  492. package/build-style/media-text/style.css +12 -0
  493. package/build-style/more/editor-rtl.css +12 -0
  494. package/build-style/more/editor.css +12 -0
  495. package/build-style/navigation/editor-rtl.css +12 -0
  496. package/build-style/navigation/editor.css +12 -0
  497. package/build-style/navigation/style-rtl.css +12 -0
  498. package/build-style/navigation/style.css +12 -0
  499. package/build-style/navigation-link/editor-rtl.css +12 -0
  500. package/build-style/navigation-link/editor.css +12 -0
  501. package/build-style/navigation-link/style-rtl.css +12 -0
  502. package/build-style/navigation-link/style.css +12 -0
  503. package/build-style/navigation-submenu/editor-rtl.css +12 -0
  504. package/build-style/navigation-submenu/editor.css +12 -0
  505. package/build-style/nextpage/editor-rtl.css +12 -0
  506. package/build-style/nextpage/editor.css +12 -0
  507. package/build-style/page-list/editor-rtl.css +12 -0
  508. package/build-style/page-list/editor.css +12 -0
  509. package/build-style/page-list/style-rtl.css +12 -0
  510. package/build-style/page-list/style.css +12 -0
  511. package/build-style/paragraph/editor-rtl.css +12 -0
  512. package/build-style/paragraph/editor.css +12 -0
  513. package/build-style/paragraph/style-rtl.css +12 -0
  514. package/build-style/paragraph/style.css +12 -0
  515. package/build-style/post-author/style-rtl.css +12 -0
  516. package/build-style/post-author/style.css +12 -0
  517. package/build-style/post-comments-form/editor-rtl.css +12 -0
  518. package/build-style/post-comments-form/editor.css +12 -0
  519. package/build-style/post-comments-form/style-rtl.css +12 -0
  520. package/build-style/post-comments-form/style.css +12 -0
  521. package/build-style/post-date/style-rtl.css +12 -0
  522. package/build-style/post-date/style.css +12 -0
  523. package/build-style/post-excerpt/editor-rtl.css +12 -0
  524. package/build-style/post-excerpt/editor.css +12 -0
  525. package/build-style/post-excerpt/style-rtl.css +12 -0
  526. package/build-style/post-excerpt/style.css +12 -0
  527. package/build-style/post-featured-image/editor-rtl.css +12 -0
  528. package/build-style/post-featured-image/editor.css +12 -0
  529. package/build-style/post-featured-image/style-rtl.css +12 -0
  530. package/build-style/post-featured-image/style.css +12 -0
  531. package/build-style/post-navigation-link/style-rtl.css +12 -0
  532. package/build-style/post-navigation-link/style.css +12 -0
  533. package/build-style/post-template/editor-rtl.css +12 -0
  534. package/build-style/post-template/editor.css +12 -0
  535. package/build-style/post-template/style-rtl.css +12 -0
  536. package/build-style/post-template/style.css +12 -0
  537. package/build-style/post-terms/style-rtl.css +12 -0
  538. package/build-style/post-terms/style.css +12 -0
  539. package/build-style/post-title/style-rtl.css +12 -0
  540. package/build-style/post-title/style.css +12 -0
  541. package/build-style/preformatted/style-rtl.css +12 -0
  542. package/build-style/preformatted/style.css +12 -0
  543. package/build-style/pullquote/editor-rtl.css +12 -0
  544. package/build-style/pullquote/editor.css +12 -0
  545. package/build-style/pullquote/style-rtl.css +12 -0
  546. package/build-style/pullquote/style.css +12 -0
  547. package/build-style/pullquote/theme-rtl.css +12 -0
  548. package/build-style/pullquote/theme.css +12 -0
  549. package/build-style/query/editor-rtl.css +12 -0
  550. package/build-style/query/editor.css +12 -0
  551. package/build-style/query-pagination/editor-rtl.css +12 -0
  552. package/build-style/query-pagination/editor.css +12 -0
  553. package/build-style/query-pagination/style-rtl.css +12 -0
  554. package/build-style/query-pagination/style.css +12 -0
  555. package/build-style/query-pagination-numbers/editor-rtl.css +12 -0
  556. package/build-style/query-pagination-numbers/editor.css +12 -0
  557. package/build-style/query-title/style-rtl.css +12 -0
  558. package/build-style/query-title/style.css +12 -0
  559. package/build-style/quote/style-rtl.css +12 -0
  560. package/build-style/quote/style.css +12 -0
  561. package/build-style/quote/theme-rtl.css +12 -0
  562. package/build-style/quote/theme.css +12 -0
  563. package/build-style/read-more/style-rtl.css +12 -0
  564. package/build-style/read-more/style.css +12 -0
  565. package/build-style/reset-rtl.css +12 -0
  566. package/build-style/reset.css +12 -0
  567. package/build-style/rss/editor-rtl.css +12 -0
  568. package/build-style/rss/editor.css +12 -0
  569. package/build-style/rss/style-rtl.css +12 -0
  570. package/build-style/rss/style.css +12 -0
  571. package/build-style/search/editor-rtl.css +12 -0
  572. package/build-style/search/editor.css +12 -0
  573. package/build-style/search/style-rtl.css +12 -0
  574. package/build-style/search/style.css +12 -0
  575. package/build-style/search/theme-rtl.css +12 -0
  576. package/build-style/search/theme.css +12 -0
  577. package/build-style/separator/editor-rtl.css +12 -0
  578. package/build-style/separator/editor.css +12 -0
  579. package/build-style/separator/style-rtl.css +12 -0
  580. package/build-style/separator/style.css +12 -0
  581. package/build-style/separator/theme-rtl.css +12 -0
  582. package/build-style/separator/theme.css +12 -0
  583. package/build-style/shortcode/editor-rtl.css +13 -1
  584. package/build-style/shortcode/editor.css +13 -1
  585. package/build-style/site-logo/editor-rtl.css +12 -0
  586. package/build-style/site-logo/editor.css +12 -0
  587. package/build-style/site-logo/style-rtl.css +12 -0
  588. package/build-style/site-logo/style.css +12 -0
  589. package/build-style/site-tagline/editor-rtl.css +12 -0
  590. package/build-style/site-tagline/editor.css +12 -0
  591. package/build-style/site-title/editor-rtl.css +12 -0
  592. package/build-style/site-title/editor.css +12 -0
  593. package/build-style/site-title/style-rtl.css +12 -0
  594. package/build-style/site-title/style.css +12 -0
  595. package/build-style/social-link/editor-rtl.css +12 -0
  596. package/build-style/social-link/editor.css +12 -0
  597. package/build-style/social-links/editor-rtl.css +12 -0
  598. package/build-style/social-links/editor.css +12 -0
  599. package/build-style/social-links/style-rtl.css +12 -0
  600. package/build-style/social-links/style.css +12 -0
  601. package/build-style/spacer/editor-rtl.css +12 -0
  602. package/build-style/spacer/editor.css +12 -0
  603. package/build-style/spacer/style-rtl.css +12 -0
  604. package/build-style/spacer/style.css +12 -0
  605. package/build-style/style-rtl.css +23 -5
  606. package/build-style/style.css +23 -5
  607. package/build-style/table/editor-rtl.css +12 -8
  608. package/build-style/table/editor.css +12 -8
  609. package/build-style/table/style-rtl.css +12 -0
  610. package/build-style/table/style.css +12 -0
  611. package/build-style/table/theme-rtl.css +12 -0
  612. package/build-style/table/theme.css +12 -0
  613. package/build-style/tag-cloud/style-rtl.css +12 -0
  614. package/build-style/tag-cloud/style.css +12 -0
  615. package/build-style/template-part/editor-rtl.css +27 -1
  616. package/build-style/template-part/editor.css +27 -1
  617. package/build-style/template-part/theme-rtl.css +12 -0
  618. package/build-style/template-part/theme.css +12 -0
  619. package/build-style/text-columns/editor-rtl.css +12 -0
  620. package/build-style/text-columns/editor.css +12 -0
  621. package/build-style/text-columns/style-rtl.css +12 -0
  622. package/build-style/text-columns/style.css +12 -0
  623. package/build-style/theme-rtl.css +12 -0
  624. package/build-style/theme.css +12 -0
  625. package/build-style/verse/style-rtl.css +12 -0
  626. package/build-style/verse/style.css +12 -0
  627. package/build-style/video/editor-rtl.css +12 -0
  628. package/build-style/video/editor.css +12 -0
  629. package/build-style/video/style-rtl.css +14 -1
  630. package/build-style/video/style.css +14 -1
  631. package/build-style/video/theme-rtl.css +12 -0
  632. package/build-style/video/theme.css +12 -0
  633. package/package.json +32 -30
  634. package/src/audio/edit.native.js +1 -2
  635. package/src/audio/index.js +1 -0
  636. package/src/avatar/edit.js +1 -0
  637. package/src/avatar/user-control.js +1 -0
  638. package/src/block/block.json +1 -2
  639. package/src/block/edit.js +14 -3
  640. package/src/block/edit.native.js +24 -12
  641. package/src/block/editor.scss +17 -0
  642. package/src/block/index.php +1 -2
  643. package/src/block/test/edit.native.js +28 -32
  644. package/src/button/edit.native.js +1 -0
  645. package/src/buttons/test/edit.native.js +40 -51
  646. package/src/code/transforms.js +3 -1
  647. package/src/columns/edit.js +1 -0
  648. package/src/columns/edit.native.js +18 -26
  649. package/src/comment-author-avatar/edit.js +1 -0
  650. package/src/cover/edit/inspector-controls.js +2 -0
  651. package/src/cover/edit.native.js +32 -19
  652. package/src/cover/test/edit.native.js +73 -126
  653. package/src/embed/embed-controls.native.js +1 -0
  654. package/src/embed/embed-preview.native.js +1 -2
  655. package/src/embed/test/index.native.js +237 -231
  656. package/src/file/inspector.js +1 -0
  657. package/src/file/test/__snapshots__/edit.native.js.snap +2 -6
  658. package/src/gallery/edit.js +15 -5
  659. package/src/gallery/gallery.native.js +1 -2
  660. package/src/gallery/shared.js +7 -11
  661. package/src/gallery/transforms.js +1 -6
  662. package/src/gallery/use-get-media.js +1 -1
  663. package/src/gallery/use-get-media.native.js +2 -1
  664. package/src/gallery/v1/edit.js +8 -7
  665. package/src/gallery/v1/gallery.native.js +1 -2
  666. package/src/gallery/v1/shared.js +7 -2
  667. package/src/group/block.json +3 -1
  668. package/src/group/edit.js +2 -6
  669. package/src/group/placeholder.js +6 -25
  670. package/src/group/test/__snapshots__/edit.native.js.snap +1 -1
  671. package/src/heading/block.json +1 -2
  672. package/src/heading/deprecated.js +209 -136
  673. package/src/heading/index.php +52 -0
  674. package/src/heading/test/__snapshots__/index.native.js.snap +7 -0
  675. package/src/heading/test/index.native.js +44 -0
  676. package/src/home-link/index.php +1 -1
  677. package/src/html/block.json +1 -1
  678. package/src/image/edit.js +7 -2
  679. package/src/image/edit.native.js +2 -1
  680. package/src/image/editor.scss +0 -11
  681. package/src/image/image.js +13 -8
  682. package/src/image/test/edit.native.js +14 -10
  683. package/src/index.js +2 -0
  684. package/src/latest-comments/edit.js +1 -0
  685. package/src/latest-posts/edit.js +2 -0
  686. package/src/list/test/edit.native.js +53 -45
  687. package/src/list/transforms.js +0 -11
  688. package/src/list/utils.js +6 -2
  689. package/src/list-item/index.js +2 -0
  690. package/src/list-item/transforms.js +17 -0
  691. package/src/list-item/utils.js +10 -1
  692. package/src/media-text/edit.js +5 -3
  693. package/src/missing/test/edit-integration.native.js +10 -12
  694. package/src/navigation/edit/are-blocks-dirty.js +51 -0
  695. package/src/navigation/edit/index.js +230 -298
  696. package/src/navigation/edit/menu-inspector-controls.js +78 -0
  697. package/src/navigation/edit/navigation-menu-selector.js +5 -16
  698. package/src/navigation/edit/test/are-blocks-dirty.js +121 -0
  699. package/src/navigation/edit/unsaved-inner-blocks.js +12 -7
  700. package/src/navigation/index.php +57 -10
  701. package/src/navigation/view-modal.js +11 -1
  702. package/src/navigation-link/edit.js +58 -329
  703. package/src/navigation-link/index.php +32 -0
  704. package/src/navigation-link/link-ui.js +213 -0
  705. package/src/navigation-link/test/edit.js +23 -82
  706. package/src/navigation-link/transforms.js +14 -0
  707. package/src/navigation-link/update-attributes.js +99 -0
  708. package/src/navigation-submenu/edit.js +57 -177
  709. package/src/navigation-submenu/index.php +40 -0
  710. package/src/page-list/block.json +6 -1
  711. package/src/page-list/constants.js +8 -0
  712. package/src/page-list/convert-to-links-modal.js +19 -76
  713. package/src/page-list/convert-to-navigation-links.js +60 -0
  714. package/src/page-list/edit.js +179 -118
  715. package/src/page-list/index.php +9 -0
  716. package/src/page-list/test/convert-to-links-modal.js +28 -34
  717. package/src/page-list-item/block.json +51 -0
  718. package/src/page-list-item/edit.js +94 -0
  719. package/src/page-list-item/index.js +24 -0
  720. package/src/page-list-item/init.js +6 -0
  721. package/src/paragraph/index.js +0 -6
  722. package/src/post-author/edit.js +3 -2
  723. package/src/post-content/index.php +1 -2
  724. package/src/post-featured-image/index.php +7 -2
  725. package/src/post-featured-image/overlay.js +1 -0
  726. package/src/post-template/block.json +8 -0
  727. package/src/preformatted/transforms.js +4 -1
  728. package/src/query/block.json +0 -8
  729. package/src/query/deprecated.js +257 -86
  730. package/src/query/edit/inspector-controls/index.js +1 -0
  731. package/src/query/edit/query-placeholder.js +4 -16
  732. package/src/rss/edit.js +3 -0
  733. package/src/search/edit.native.js +31 -27
  734. package/src/search/index.js +5 -1
  735. package/src/shortcode/test/edit.native.js +15 -18
  736. package/src/site-logo/edit.js +13 -5
  737. package/src/site-logo/index.js +1 -0
  738. package/src/site-title/index.js +1 -0
  739. package/src/social-link/social-list.js +2 -7
  740. package/src/social-link/test/index.native.js +10 -16
  741. package/src/social-links/test/edit.native.js +4 -3
  742. package/src/spacer/test/index.native.js +39 -36
  743. package/src/table/block.json +15 -0
  744. package/src/table/edit.js +2 -1
  745. package/src/table/editor.scss +0 -4
  746. package/src/table/index.js +1 -0
  747. package/src/table/save.js +5 -1
  748. package/src/table/state.js +22 -7
  749. package/src/table/transforms.js +2 -1
  750. package/src/table-of-contents/edit.js +2 -2
  751. package/src/tag-cloud/edit.js +3 -2
  752. package/src/template-part/edit/selection-modal.js +4 -3
  753. package/src/template-part/edit/utils/hooks.js +7 -3
  754. package/src/template-part/editor.scss +20 -2
  755. package/src/template-part/index.php +1 -2
  756. package/src/text-columns/edit.js +1 -0
  757. package/src/utils/transformation-categories.native.js +1 -0
  758. package/src/video/edit.js +1 -1
  759. package/src/video/edit.native.js +1 -2
  760. package/test/babel-plugin.js +35 -35
  761. package/tsconfig.tsbuildinfo +1 -1
@@ -0,0 +1,213 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { __unstableStripHTML as stripHTML } from '@wordpress/dom';
5
+ import { Popover, Button } from '@wordpress/components';
6
+ import { __, sprintf } from '@wordpress/i18n';
7
+ import {
8
+ __experimentalLinkControl as LinkControl,
9
+ BlockIcon,
10
+ store as blockEditorStore,
11
+ } from '@wordpress/block-editor';
12
+ import { createInterpolateElement } from '@wordpress/element';
13
+ import { store as coreStore } from '@wordpress/core-data';
14
+ import { decodeEntities } from '@wordpress/html-entities';
15
+ import { switchToBlockType } from '@wordpress/blocks';
16
+ import { useSelect, useDispatch } from '@wordpress/data';
17
+
18
+ /**
19
+ * Given the Link block's type attribute, return the query params to give to
20
+ * /wp/v2/search.
21
+ *
22
+ * @param {string} type Link block's type attribute.
23
+ * @param {string} kind Link block's entity of kind (post-type|taxonomy)
24
+ * @return {{ type?: string, subtype?: string }} Search query params.
25
+ */
26
+ export function getSuggestionsQuery( type, kind ) {
27
+ switch ( type ) {
28
+ case 'post':
29
+ case 'page':
30
+ return { type: 'post', subtype: type };
31
+ case 'category':
32
+ return { type: 'term', subtype: 'category' };
33
+ case 'tag':
34
+ return { type: 'term', subtype: 'post_tag' };
35
+ case 'post_format':
36
+ return { type: 'post-format' };
37
+ default:
38
+ if ( kind === 'taxonomy' ) {
39
+ return { type: 'term', subtype: type };
40
+ }
41
+ if ( kind === 'post-type' ) {
42
+ return { type: 'post', subtype: type };
43
+ }
44
+ return {};
45
+ }
46
+ }
47
+
48
+ /**
49
+ * Add transforms to Link Control
50
+ *
51
+ * @param {Object} props Component props.
52
+ * @param {string} props.clientId Block client ID.
53
+ */
54
+ function LinkControlTransforms( { clientId } ) {
55
+ const { getBlock, blockTransforms } = useSelect(
56
+ ( select ) => {
57
+ const {
58
+ getBlock: _getBlock,
59
+ getBlockRootClientId,
60
+ getBlockTransformItems,
61
+ } = select( blockEditorStore );
62
+
63
+ return {
64
+ getBlock: _getBlock,
65
+ blockTransforms: getBlockTransformItems(
66
+ _getBlock( clientId ),
67
+ getBlockRootClientId( clientId )
68
+ ),
69
+ };
70
+ },
71
+ [ clientId ]
72
+ );
73
+
74
+ const { replaceBlock } = useDispatch( blockEditorStore );
75
+
76
+ const featuredBlocks = [
77
+ 'core/page-list',
78
+ 'core/site-logo',
79
+ 'core/social-links',
80
+ 'core/search',
81
+ ];
82
+
83
+ const transforms = blockTransforms.filter( ( item ) => {
84
+ return featuredBlocks.includes( item.name );
85
+ } );
86
+
87
+ if ( ! transforms?.length ) {
88
+ return null;
89
+ }
90
+
91
+ if ( ! clientId ) {
92
+ return null;
93
+ }
94
+
95
+ return (
96
+ <div className="link-control-transform">
97
+ <h3 className="link-control-transform__subheading">
98
+ { __( 'Transform' ) }
99
+ </h3>
100
+ <div className="link-control-transform__items">
101
+ { transforms.map( ( item, index ) => {
102
+ return (
103
+ <Button
104
+ key={ `transform-${ index }` }
105
+ onClick={ () =>
106
+ replaceBlock(
107
+ clientId,
108
+ switchToBlockType(
109
+ getBlock( clientId ),
110
+ item.name
111
+ )
112
+ )
113
+ }
114
+ className="link-control-transform__item"
115
+ >
116
+ <BlockIcon icon={ item.icon } />
117
+ { item.title }
118
+ </Button>
119
+ );
120
+ } ) }
121
+ </div>
122
+ </div>
123
+ );
124
+ }
125
+
126
+ export function LinkUI( props ) {
127
+ const { saveEntityRecord } = useDispatch( coreStore );
128
+
129
+ async function handleCreate( pageTitle ) {
130
+ const postType = props.link.type || 'page';
131
+
132
+ const page = await saveEntityRecord( 'postType', postType, {
133
+ title: pageTitle,
134
+ status: 'draft',
135
+ } );
136
+
137
+ return {
138
+ id: page.id,
139
+ type: postType,
140
+ // Make `title` property consistent with that in `fetchLinkSuggestions` where the `rendered` title (containing HTML entities)
141
+ // is also being decoded. By being consistent in both locations we avoid having to branch in the rendering output code.
142
+ // Ideally in the future we will update both APIs to utilise the "raw" form of the title which is better suited to edit contexts.
143
+ // e.g.
144
+ // - title.raw = "Yes & No"
145
+ // - title.rendered = "Yes &#038; No"
146
+ // - decodeEntities( title.rendered ) = "Yes & No"
147
+ // See:
148
+ // - https://github.com/WordPress/gutenberg/pull/41063
149
+ // - https://github.com/WordPress/gutenberg/blob/a1e1fdc0e6278457e9f4fc0b31ac6d2095f5450b/packages/core-data/src/fetch/__experimental-fetch-link-suggestions.js#L212-L218
150
+ title: decodeEntities( page.title.rendered ),
151
+ url: page.link,
152
+ kind: 'post-type',
153
+ };
154
+ }
155
+
156
+ const { label, url, opensInNewTab, type, kind } = props.link;
157
+ const link = {
158
+ url,
159
+ opensInNewTab,
160
+ title: label && stripHTML( label ),
161
+ };
162
+
163
+ return (
164
+ <Popover
165
+ placement="bottom"
166
+ onClose={ props.onClose }
167
+ anchor={ props.anchor }
168
+ shift
169
+ >
170
+ <LinkControl
171
+ hasTextControl
172
+ hasRichPreviews
173
+ className={ props.className }
174
+ value={ link }
175
+ showInitialSuggestions={ true }
176
+ withCreateSuggestion={ props.hasCreateSuggestion }
177
+ createSuggestion={ handleCreate }
178
+ createSuggestionButtonText={ ( searchTerm ) => {
179
+ let format;
180
+
181
+ if ( type === 'post' ) {
182
+ /* translators: %s: search term. */
183
+ format = __( 'Create draft post: <mark>%s</mark>' );
184
+ } else {
185
+ /* translators: %s: search term. */
186
+ format = __( 'Create draft page: <mark>%s</mark>' );
187
+ }
188
+
189
+ return createInterpolateElement(
190
+ sprintf( format, searchTerm ),
191
+ {
192
+ mark: <mark />,
193
+ }
194
+ );
195
+ } }
196
+ noDirectEntry={ !! type }
197
+ noURLSuggestion={ !! type }
198
+ suggestionsQuery={ getSuggestionsQuery( type, kind ) }
199
+ onChange={ props.onChange }
200
+ onRemove={ props.onRemove }
201
+ renderControlBottom={
202
+ ! url
203
+ ? () => (
204
+ <LinkControlTransforms
205
+ clientId={ props.clientId }
206
+ />
207
+ )
208
+ : null
209
+ }
210
+ />
211
+ </Popover>
212
+ );
213
+ }
@@ -1,10 +1,10 @@
1
1
  /**
2
2
  * Internal dependencies
3
3
  */
4
- import { updateNavigationLinkBlockAttributes } from '../edit';
4
+ import { updateAttributes } from '../update-attributes';
5
5
 
6
6
  describe( 'edit', () => {
7
- describe( 'updateNavigationLinkBlockAttributes', () => {
7
+ describe( 'updateAttributes', () => {
8
8
  // Data shapes are linked to fetchLinkSuggestions from
9
9
  // core-data/src/fetch/__experimental-fetch-link-suggestions.js.
10
10
  it( 'can update a post link', () => {
@@ -18,10 +18,7 @@ describe( 'edit', () => {
18
18
  type: 'post',
19
19
  };
20
20
 
21
- updateNavigationLinkBlockAttributes(
22
- linkSuggestion,
23
- setAttributes
24
- );
21
+ updateAttributes( linkSuggestion, setAttributes );
25
22
  expect( setAttributes ).toHaveBeenCalledWith( {
26
23
  id: 1337,
27
24
  label: 'Menu Test',
@@ -42,10 +39,7 @@ describe( 'edit', () => {
42
39
  type: 'page',
43
40
  url: 'http://wordpress.local/sample-page/',
44
41
  };
45
- updateNavigationLinkBlockAttributes(
46
- linkSuggestion,
47
- setAttributes
48
- );
42
+ updateAttributes( linkSuggestion, setAttributes );
49
43
  expect( setAttributes ).toHaveBeenCalledWith( {
50
44
  id: 2,
51
45
  kind: 'post-type',
@@ -66,10 +60,7 @@ describe( 'edit', () => {
66
60
  type: 'post_tag',
67
61
  url: 'http://wordpress.local/tag/bar/',
68
62
  };
69
- updateNavigationLinkBlockAttributes(
70
- linkSuggestion,
71
- setAttributes
72
- );
63
+ updateAttributes( linkSuggestion, setAttributes );
73
64
  expect( setAttributes ).toHaveBeenCalledWith( {
74
65
  id: 15,
75
66
  kind: 'taxonomy',
@@ -90,10 +81,7 @@ describe( 'edit', () => {
90
81
  type: 'category',
91
82
  url: 'http://wordpress.local/category/cats/',
92
83
  };
93
- updateNavigationLinkBlockAttributes(
94
- linkSuggestion,
95
- setAttributes
96
- );
84
+ updateAttributes( linkSuggestion, setAttributes );
97
85
  expect( setAttributes ).toHaveBeenCalledWith( {
98
86
  id: 9,
99
87
  kind: 'taxonomy',
@@ -114,10 +102,7 @@ describe( 'edit', () => {
114
102
  type: 'portfolio',
115
103
  url: 'http://wordpress.local/portfolio/fall/',
116
104
  };
117
- updateNavigationLinkBlockAttributes(
118
- linkSuggestion,
119
- setAttributes
120
- );
105
+ updateAttributes( linkSuggestion, setAttributes );
121
106
  expect( setAttributes ).toHaveBeenCalledWith( {
122
107
  id: 131,
123
108
  kind: 'post-type',
@@ -138,10 +123,7 @@ describe( 'edit', () => {
138
123
  type: 'portfolio_tag',
139
124
  url: 'http://wordpress.local/portfolio_tag/PortfolioTag/',
140
125
  };
141
- updateNavigationLinkBlockAttributes(
142
- linkSuggestion,
143
- setAttributes
144
- );
126
+ updateAttributes( linkSuggestion, setAttributes );
145
127
  expect( setAttributes ).toHaveBeenCalledWith( {
146
128
  id: 4,
147
129
  kind: 'taxonomy',
@@ -162,10 +144,7 @@ describe( 'edit', () => {
162
144
  type: 'portfolio_category',
163
145
  url: 'http://wordpress.local/portfolio_category/Portfolio-category/',
164
146
  };
165
- updateNavigationLinkBlockAttributes(
166
- linkSuggestion,
167
- setAttributes
168
- );
147
+ updateAttributes( linkSuggestion, setAttributes );
169
148
  expect( setAttributes ).toHaveBeenCalledWith( {
170
149
  id: 2,
171
150
  kind: 'taxonomy',
@@ -186,10 +165,7 @@ describe( 'edit', () => {
186
165
  type: 'post-format',
187
166
  url: 'http://wordpress.local/type/video/',
188
167
  };
189
- updateNavigationLinkBlockAttributes(
190
- linkSuggestion,
191
- setAttributes
192
- );
168
+ updateAttributes( linkSuggestion, setAttributes );
193
169
  // post_format returns a slug ID value from the Search API
194
170
  // we do not persist this ID since we expect this value to be a post or term ID.
195
171
  expect( setAttributes ).toHaveBeenCalledWith( {
@@ -208,10 +184,7 @@ describe( 'edit', () => {
208
184
  opensInNewTab: false,
209
185
  url: 'www.wordpress.org',
210
186
  };
211
- updateNavigationLinkBlockAttributes(
212
- linkSuggestion,
213
- setAttributes
214
- );
187
+ updateAttributes( linkSuggestion, setAttributes );
215
188
  expect( setAttributes ).toHaveBeenCalledWith( {
216
189
  opensInNewTab: false,
217
190
  url: 'www.wordpress.org',
@@ -229,10 +202,7 @@ describe( 'edit', () => {
229
202
  type: 'URL',
230
203
  url: 'http://www.wordpress.org',
231
204
  };
232
- updateNavigationLinkBlockAttributes(
233
- linkSuggestion,
234
- setAttributes
235
- );
205
+ updateAttributes( linkSuggestion, setAttributes );
236
206
  expect( setAttributes ).toHaveBeenCalledWith( {
237
207
  opensInNewTab: false,
238
208
  label: 'www.wordpress.org',
@@ -250,10 +220,7 @@ describe( 'edit', () => {
250
220
  type: 'mailto',
251
221
  url: 'mailto:foo@example.com',
252
222
  };
253
- updateNavigationLinkBlockAttributes(
254
- linkSuggestion,
255
- setAttributes
256
- );
223
+ updateAttributes( linkSuggestion, setAttributes );
257
224
  expect( setAttributes ).toHaveBeenCalledWith( {
258
225
  opensInNewTab: false,
259
226
  label: 'mailto:foo@example.com',
@@ -272,10 +239,7 @@ describe( 'edit', () => {
272
239
  type: 'internal',
273
240
  url: '#foo',
274
241
  };
275
- updateNavigationLinkBlockAttributes(
276
- linkSuggestion,
277
- setAttributes
278
- );
242
+ updateAttributes( linkSuggestion, setAttributes );
279
243
  expect( setAttributes ).toHaveBeenCalledWith( {
280
244
  opensInNewTab: false,
281
245
  label: '#foo',
@@ -294,10 +258,7 @@ describe( 'edit', () => {
294
258
  type: 'tel',
295
259
  url: 'tel:5555555',
296
260
  };
297
- updateNavigationLinkBlockAttributes(
298
- linkSuggestion,
299
- setAttributes
300
- );
261
+ updateAttributes( linkSuggestion, setAttributes );
301
262
  expect( setAttributes ).toHaveBeenCalledWith( {
302
263
  opensInNewTab: false,
303
264
  label: 'tel:5555555',
@@ -319,10 +280,7 @@ describe( 'edit', () => {
319
280
  type: 'URL',
320
281
  url: 'https://www.wordpress.org',
321
282
  };
322
- updateNavigationLinkBlockAttributes(
323
- linkSuggestion,
324
- setAttributes
325
- );
283
+ updateAttributes( linkSuggestion, setAttributes );
326
284
  expect( setAttributes ).toHaveBeenCalledWith( {
327
285
  opensInNewTab: false,
328
286
  label: 'www.wordpress.org',
@@ -339,10 +297,7 @@ describe( 'edit', () => {
339
297
  type: 'URL',
340
298
  url: 'wordpress.org',
341
299
  };
342
- updateNavigationLinkBlockAttributes(
343
- linkSuggestion,
344
- setAttributes
345
- );
300
+ updateAttributes( linkSuggestion, setAttributes );
346
301
  expect( setAttributes ).toHaveBeenCalledWith( {
347
302
  opensInNewTab: false,
348
303
  label: 'Custom Title',
@@ -359,10 +314,7 @@ describe( 'edit', () => {
359
314
  type: 'URL',
360
315
  url: 'https://wordpress.org',
361
316
  };
362
- updateNavigationLinkBlockAttributes(
363
- linkSuggestion,
364
- setAttributes
365
- );
317
+ updateAttributes( linkSuggestion, setAttributes );
366
318
  expect( setAttributes ).toHaveBeenCalledWith( {
367
319
  opensInNewTab: false,
368
320
  label: 'Custom Title',
@@ -380,10 +332,7 @@ describe( 'edit', () => {
380
332
  type: 'URL',
381
333
  url: 'http://wordpress.org/?s=<>',
382
334
  };
383
- updateNavigationLinkBlockAttributes(
384
- linkSuggestion,
385
- setAttributes
386
- );
335
+ updateAttributes( linkSuggestion, setAttributes );
387
336
  expect( setAttributes ).toHaveBeenCalledWith( {
388
337
  opensInNewTab: false,
389
338
  label: 'Custom Title',
@@ -408,11 +357,7 @@ describe( 'edit', () => {
408
357
  type: 'post',
409
358
  };
410
359
 
411
- updateNavigationLinkBlockAttributes(
412
- linkSuggestion,
413
- setAttributes,
414
- mockState
415
- );
360
+ updateAttributes( linkSuggestion, setAttributes, mockState );
416
361
  expect( mockState ).toEqual( {
417
362
  id: 1337,
418
363
  label: 'Menu Test',
@@ -422,7 +367,7 @@ describe( 'edit', () => {
422
367
  url: 'https://wordpress.local/menu-test/',
423
368
  } );
424
369
  // Click on the existing link control, and toggle opens new tab.
425
- updateNavigationLinkBlockAttributes(
370
+ updateAttributes(
426
371
  {
427
372
  url: 'https://wordpress.local/menu-test/',
428
373
  opensInNewTab: true,
@@ -453,11 +398,7 @@ describe( 'edit', () => {
453
398
  type: 'post',
454
399
  };
455
400
 
456
- updateNavigationLinkBlockAttributes(
457
- linkSuggestion,
458
- setAttributes,
459
- mockState
460
- );
401
+ updateAttributes( linkSuggestion, setAttributes, mockState );
461
402
  expect( mockState ).toEqual( {
462
403
  id: 1337,
463
404
  label: 'Menu Test',
@@ -467,7 +408,7 @@ describe( 'edit', () => {
467
408
  url: 'https://wordpress.local/menu-test/',
468
409
  } );
469
410
  // Click on the existing link control, and toggle opens new tab.
470
- updateNavigationLinkBlockAttributes(
411
+ updateAttributes(
471
412
  {
472
413
  url: 'https://wordpress.local/foo/',
473
414
  opensInNewTab: false,
@@ -40,6 +40,13 @@ const transforms = {
40
40
  return createBlock( 'core/navigation-link' );
41
41
  },
42
42
  },
43
+ {
44
+ type: 'block',
45
+ blocks: [ 'core/page-list' ],
46
+ transform: () => {
47
+ return createBlock( 'core/navigation-link' );
48
+ },
49
+ },
43
50
  ],
44
51
  to: [
45
52
  {
@@ -91,6 +98,13 @@ const transforms = {
91
98
  } );
92
99
  },
93
100
  },
101
+ {
102
+ type: 'block',
103
+ blocks: [ 'core/page-list' ],
104
+ transform: () => {
105
+ return createBlock( 'core/page-list' );
106
+ },
107
+ },
94
108
  ],
95
109
  };
96
110
 
@@ -0,0 +1,99 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { safeDecodeURI } from '@wordpress/url';
5
+ import { escapeHTML } from '@wordpress/escape-html';
6
+
7
+ /**
8
+ * @typedef {'post-type'|'custom'|'taxonomy'|'post-type-archive'} WPNavigationLinkKind
9
+ */
10
+ /**
11
+ * Navigation Link Block Attributes
12
+ *
13
+ * @typedef {Object} WPNavigationLinkBlockAttributes
14
+ *
15
+ * @property {string} [label] Link text.
16
+ * @property {WPNavigationLinkKind} [kind] Kind is used to differentiate between term and post ids to check post draft status.
17
+ * @property {string} [type] The type such as post, page, tag, category and other custom types.
18
+ * @property {string} [rel] The relationship of the linked URL.
19
+ * @property {number} [id] A post or term id.
20
+ * @property {boolean} [opensInNewTab] Sets link target to _blank when true.
21
+ * @property {string} [url] Link href.
22
+ * @property {string} [title] Link title attribute.
23
+ */
24
+ /**
25
+ * Link Control onChange handler that updates block attributes when a setting is changed.
26
+ *
27
+ * @param {Object} updatedValue New block attributes to update.
28
+ * @param {Function} setAttributes Block attribute update function.
29
+ * @param {WPNavigationLinkBlockAttributes} blockAttributes Current block attributes.
30
+ *
31
+ */
32
+
33
+ export const updateAttributes = (
34
+ updatedValue = {},
35
+ setAttributes,
36
+ blockAttributes = {}
37
+ ) => {
38
+ const {
39
+ label: originalLabel = '',
40
+ kind: originalKind = '',
41
+ type: originalType = '',
42
+ } = blockAttributes;
43
+
44
+ const {
45
+ title: newLabel = '', // the title of any provided Post.
46
+ url: newUrl = '',
47
+ opensInNewTab,
48
+ id,
49
+ kind: newKind = originalKind,
50
+ type: newType = originalType,
51
+ } = updatedValue;
52
+
53
+ const newLabelWithoutHttp = newLabel.replace( /http(s?):\/\//gi, '' );
54
+ const newUrlWithoutHttp = newUrl.replace( /http(s?):\/\//gi, '' );
55
+
56
+ const useNewLabel =
57
+ newLabel &&
58
+ newLabel !== originalLabel &&
59
+ // LinkControl without the title field relies
60
+ // on the check below. Specifically, it assumes that
61
+ // the URL is the same as a title.
62
+ // This logic a) looks suspicious and b) should really
63
+ // live in the LinkControl and not here. It's a great
64
+ // candidate for future refactoring.
65
+ newLabelWithoutHttp !== newUrlWithoutHttp;
66
+
67
+ // Unfortunately this causes the escaping model to be inverted.
68
+ // The escaped content is stored in the block attributes (and ultimately in the database),
69
+ // and then the raw data is "recovered" when outputting into the DOM.
70
+ // It would be preferable to store the **raw** data in the block attributes and escape it in JS.
71
+ // Why? Because there isn't one way to escape data. Depending on the context, you need to do
72
+ // different transforms. It doesn't make sense to me to choose one of them for the purposes of storage.
73
+ // See also:
74
+ // - https://github.com/WordPress/gutenberg/pull/41063
75
+ // - https://github.com/WordPress/gutenberg/pull/18617.
76
+ const label = useNewLabel
77
+ ? escapeHTML( newLabel )
78
+ : originalLabel || escapeHTML( newUrlWithoutHttp );
79
+
80
+ // In https://github.com/WordPress/gutenberg/pull/24670 we decided to use "tag" in favor of "post_tag"
81
+ const type = newType === 'post_tag' ? 'tag' : newType.replace( '-', '_' );
82
+
83
+ const isBuiltInType =
84
+ [ 'post', 'page', 'tag', 'category' ].indexOf( type ) > -1;
85
+
86
+ const isCustomLink =
87
+ ( ! newKind && ! isBuiltInType ) || newKind === 'custom';
88
+ const kind = isCustomLink ? 'custom' : newKind;
89
+
90
+ setAttributes( {
91
+ // Passed `url` may already be encoded. To prevent double encoding, decodeURI is executed to revert to the original string.
92
+ ...( newUrl && { url: encodeURI( safeDecodeURI( newUrl ) ) } ),
93
+ ...( label && { label } ),
94
+ ...( undefined !== opensInNewTab && { opensInNewTab } ),
95
+ ...( id && Number.isInteger( id ) && { id } ),
96
+ ...( kind && { kind } ),
97
+ ...( type && type !== 'URL' && { type } ),
98
+ } );
99
+ };