@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
@@ -6,29 +6,51 @@ import classnames from 'classnames';
6
6
  /**
7
7
  * WordPress dependencies
8
8
  */
9
+ import { createBlock } from '@wordpress/blocks';
9
10
  import {
11
+ InspectorControls,
10
12
  BlockControls,
11
13
  useBlockProps,
14
+ useInnerBlocksProps,
12
15
  getColorClassName,
16
+ store as blockEditorStore,
17
+ Warning,
13
18
  } from '@wordpress/block-editor';
14
- import { ToolbarButton, Spinner, Notice } from '@wordpress/components';
15
- import { __ } from '@wordpress/i18n';
16
- import { useMemo, useState, memo } from '@wordpress/element';
17
- import { useSelect } from '@wordpress/data';
18
- import { store as coreStore, useEntityRecords } from '@wordpress/core-data';
19
+ import {
20
+ PanelBody,
21
+ ToolbarButton,
22
+ Spinner,
23
+ Notice,
24
+ ComboboxControl,
25
+ Button,
26
+ } from '@wordpress/components';
27
+ import { __, sprintf } from '@wordpress/i18n';
28
+ import { useMemo, useState, useEffect } from '@wordpress/element';
29
+ import { useEntityRecords } from '@wordpress/core-data';
30
+ import { useSelect, useDispatch } from '@wordpress/data';
19
31
 
20
32
  /**
21
33
  * Internal dependencies
22
34
  */
23
35
  import ConvertToLinksModal from './convert-to-links-modal';
24
- import { ItemSubmenuIcon } from '../navigation-link/icons';
36
+ import { convertToNavigationLinks } from './convert-to-navigation-links';
37
+ import { convertDescription } from './constants';
25
38
 
26
39
  // We only show the edit option when page count is <= MAX_PAGE_COUNT
27
40
  // Performance of Navigation Links is not good past this value.
28
41
  const MAX_PAGE_COUNT = 100;
29
42
 
30
- export default function PageListEdit( { context, clientId } ) {
43
+ export default function PageListEdit( {
44
+ context,
45
+ clientId,
46
+ attributes,
47
+ setAttributes,
48
+ } ) {
49
+ const { parentPageID } = attributes;
50
+ const [ pages ] = useGetPages();
31
51
  const { pagesByParentId, totalPages, hasResolvedPages } = usePageData();
52
+ const { replaceInnerBlocks, __unstableMarkNextChangeAsNotPersistent } =
53
+ useDispatch( blockEditorStore );
32
54
 
33
55
  const isNavigationChild = 'showSubmenuIcon' in context;
34
56
  const allowConvertToLinks =
@@ -52,6 +74,67 @@ export default function PageListEdit( { context, clientId } ) {
52
74
  style: { ...context.style?.color },
53
75
  } );
54
76
 
77
+ const getBlockList = ( parentId = parentPageID ) => {
78
+ const childPages = pagesByParentId.get( parentId );
79
+
80
+ if ( ! childPages?.length ) {
81
+ return [];
82
+ }
83
+
84
+ return childPages.reduce( ( template, page ) => {
85
+ const hasChildren = pagesByParentId.has( page.id );
86
+ const pageProps = {
87
+ id: page.id,
88
+ label: page.title?.rendered,
89
+ title: page.title?.rendered,
90
+ link: page.url,
91
+ hasChildren,
92
+ };
93
+ let item = null;
94
+ const children = getBlockList( page.id );
95
+ item = createBlock( 'core/page-list-item', pageProps, children );
96
+ template.push( item );
97
+
98
+ return template;
99
+ }, [] );
100
+ };
101
+
102
+ const makePagesTree = ( parentId = 0, level = 0 ) => {
103
+ const childPages = pagesByParentId.get( parentId );
104
+
105
+ if ( ! childPages?.length ) {
106
+ return [];
107
+ }
108
+
109
+ return childPages.reduce( ( tree, page ) => {
110
+ const hasChildren = pagesByParentId.has( page.id );
111
+ const item = {
112
+ value: page.id,
113
+ label: '— '.repeat( level ) + page.title.rendered,
114
+ rawName: page.title.rendered,
115
+ };
116
+ tree.push( item );
117
+ if ( hasChildren ) {
118
+ tree.push( ...makePagesTree( page.id, level + 1 ) );
119
+ }
120
+ return tree;
121
+ }, [] );
122
+ };
123
+
124
+ const pagesTree = useMemo( makePagesTree, [ pagesByParentId ] );
125
+
126
+ const blockList = useMemo( getBlockList, [
127
+ pagesByParentId,
128
+ parentPageID,
129
+ ] );
130
+
131
+ const innerBlocksProps = useInnerBlocksProps( blockProps, {
132
+ allowedBlocks: [ 'core/page-list-item' ],
133
+ renderAppender: false,
134
+ __unstableDisableDropZone: true,
135
+ templateLock: 'all',
136
+ } );
137
+
55
138
  const getBlockContent = () => {
56
139
  if ( ! hasResolvedPages ) {
57
140
  return (
@@ -81,21 +164,93 @@ export default function PageListEdit( { context, clientId } ) {
81
164
  );
82
165
  }
83
166
 
84
- if ( totalPages > 0 ) {
167
+ if ( blockList.length === 0 ) {
168
+ const parentPageDetails =
169
+ pages && pages.find( ( page ) => page.id === parentPageID );
85
170
  return (
86
- <ul { ...blockProps }>
87
- <PageItems
88
- context={ context }
89
- pagesByParentId={ pagesByParentId }
90
- />
91
- </ul>
171
+ <div { ...blockProps }>
172
+ <Warning>
173
+ { sprintf(
174
+ // translators: %s: Page title.
175
+ __( '"%s" page has no children.' ),
176
+ parentPageDetails.title.rendered
177
+ ) }
178
+ </Warning>
179
+ </div>
92
180
  );
93
181
  }
182
+
183
+ if ( totalPages > 0 ) {
184
+ return <ul { ...innerBlocksProps }></ul>;
185
+ }
94
186
  };
95
187
 
188
+ useEffect( () => {
189
+ __unstableMarkNextChangeAsNotPersistent();
190
+ if ( blockList ) {
191
+ replaceInnerBlocks( clientId, blockList );
192
+ }
193
+ }, [ clientId, blockList ] );
194
+
195
+ const { replaceBlock, selectBlock } = useDispatch( blockEditorStore );
196
+
197
+ const { parentNavBlockClientId } = useSelect( ( select ) => {
198
+ const { getSelectedBlockClientId, getBlockParentsByBlockName } =
199
+ select( blockEditorStore );
200
+
201
+ const _selectedBlockClientId = getSelectedBlockClientId();
202
+
203
+ return {
204
+ parentNavBlockClientId: getBlockParentsByBlockName(
205
+ _selectedBlockClientId,
206
+ 'core/navigation',
207
+ true
208
+ )[ 0 ],
209
+ };
210
+ }, [] );
211
+
96
212
  return (
97
213
  <>
98
- { allowConvertToLinks && (
214
+ <InspectorControls>
215
+ { isNavigationChild && pages?.length > 0 && (
216
+ <PanelBody title={ __( 'Customize this menu' ) }>
217
+ <p>{ convertDescription }</p>
218
+ <Button
219
+ variant="primary"
220
+ disabled={ ! hasResolvedPages }
221
+ onClick={ () => {
222
+ const navigationLinks =
223
+ convertToNavigationLinks( pages );
224
+
225
+ // Replace the Page List block with the Navigation Links.
226
+ replaceBlock( clientId, navigationLinks );
227
+
228
+ // Select the Navigation block to reveal the changes.
229
+ selectBlock( parentNavBlockClientId );
230
+ } }
231
+ >
232
+ { __( 'Customize' ) }
233
+ </Button>
234
+ </PanelBody>
235
+ ) }
236
+ { pagesTree.length > 0 && (
237
+ <PanelBody>
238
+ <ComboboxControl
239
+ className="editor-page-attributes__parent"
240
+ label={ __( 'Parent page' ) }
241
+ value={ parentPageID }
242
+ options={ pagesTree }
243
+ onChange={ ( value ) =>
244
+ setAttributes( { parentPageID: value ?? 0 } )
245
+ }
246
+ help={ __(
247
+ 'Choose a page to show only its subpages.'
248
+ ) }
249
+ />
250
+ </PanelBody>
251
+ ) }
252
+ </InspectorControls>
253
+ { allowConvertToLinks && totalPages > 0 && (
99
254
  <BlockControls group="other">
100
255
  <ToolbarButton title={ __( 'Edit' ) } onClick={ openModal }>
101
256
  { __( 'Edit' ) }
@@ -114,22 +269,7 @@ export default function PageListEdit( { context, clientId } ) {
114
269
  );
115
270
  }
116
271
 
117
- function useFrontPageId() {
118
- return useSelect( ( select ) => {
119
- const canReadSettings = select( coreStore ).canUser(
120
- 'read',
121
- 'settings'
122
- );
123
- if ( ! canReadSettings ) {
124
- return undefined;
125
- }
126
-
127
- const site = select( coreStore ).getEntityRecord( 'root', 'site' );
128
- return site?.show_on_front === 'page' && site?.page_on_front;
129
- }, [] );
130
- }
131
-
132
- function usePageData() {
272
+ function useGetPages() {
133
273
  const { records: pages, hasResolved: hasResolvedPages } = useEntityRecords(
134
274
  'postType',
135
275
  'page',
@@ -142,10 +282,17 @@ function usePageData() {
142
282
  }
143
283
  );
144
284
 
285
+ return [ pages, hasResolvedPages ];
286
+ }
287
+
288
+ function usePageData( pageId = 0 ) {
289
+ const [ pages, hasResolvedPages ] = useGetPages();
290
+
145
291
  return useMemo( () => {
146
292
  // TODO: Once the REST API supports passing multiple values to
147
293
  // 'orderby', this can be removed.
148
294
  // https://core.trac.wordpress.org/ticket/39037
295
+
149
296
  const sortedPages = [ ...( pages ?? [] ) ].sort( ( a, b ) => {
150
297
  if ( a.menu_order === b.menu_order ) {
151
298
  return a.title.rendered.localeCompare( b.title.rendered );
@@ -167,91 +314,5 @@ function usePageData() {
167
314
  hasResolvedPages,
168
315
  totalPages: pages?.length ?? null,
169
316
  };
170
- }, [ pages, hasResolvedPages ] );
317
+ }, [ pageId, pages, hasResolvedPages ] );
171
318
  }
172
-
173
- const PageItems = memo( function PageItems( {
174
- context,
175
- pagesByParentId,
176
- parentId = 0,
177
- depth = 0,
178
- } ) {
179
- const pages = pagesByParentId.get( parentId );
180
- const frontPageId = useFrontPageId();
181
-
182
- if ( ! pages?.length ) {
183
- return [];
184
- }
185
-
186
- return pages.map( ( page ) => {
187
- const hasChildren = pagesByParentId.has( page.id );
188
- const isNavigationChild = 'showSubmenuIcon' in context;
189
- return (
190
- <li
191
- key={ page.id }
192
- className={ classnames( 'wp-block-pages-list__item', {
193
- 'has-child': hasChildren,
194
- 'wp-block-navigation-item': isNavigationChild,
195
- 'open-on-click': context.openSubmenusOnClick,
196
- 'open-on-hover-click':
197
- ! context.openSubmenusOnClick &&
198
- context.showSubmenuIcon,
199
- 'menu-item-home': page.id === frontPageId,
200
- } ) }
201
- >
202
- { hasChildren && context.openSubmenusOnClick ? (
203
- <>
204
- <button
205
- className="wp-block-navigation-item__content wp-block-navigation-submenu__toggle"
206
- aria-expanded="false"
207
- >
208
- { page.title?.rendered }
209
- </button>
210
- <span className="wp-block-page-list__submenu-icon wp-block-navigation__submenu-icon">
211
- <ItemSubmenuIcon />
212
- </span>
213
- </>
214
- ) : (
215
- <a
216
- className={ classnames(
217
- 'wp-block-pages-list__item__link',
218
- {
219
- 'wp-block-navigation-item__content':
220
- isNavigationChild,
221
- }
222
- ) }
223
- href={ page.link }
224
- >
225
- { page.title?.rendered }
226
- </a>
227
- ) }
228
- { hasChildren && (
229
- <>
230
- { ! context.openSubmenusOnClick &&
231
- context.showSubmenuIcon && (
232
- <button
233
- className="wp-block-navigation-item__content wp-block-navigation-submenu__toggle wp-block-page-list__submenu-icon wp-block-navigation__submenu-icon"
234
- aria-expanded="false"
235
- >
236
- <ItemSubmenuIcon />
237
- </button>
238
- ) }
239
- <ul
240
- className={ classnames( 'submenu-container', {
241
- 'wp-block-navigation__submenu-container':
242
- isNavigationChild,
243
- } ) }
244
- >
245
- <PageItems
246
- context={ context }
247
- pagesByParentId={ pagesByParentId }
248
- parentId={ page.id }
249
- depth={ depth + 1 }
250
- />
251
- </ul>
252
- </>
253
- ) }
254
- </li>
255
- );
256
- } );
257
- } );
@@ -252,6 +252,8 @@ function render_block_core_page_list( $attributes, $content, $block ) {
252
252
  static $block_id = 0;
253
253
  ++$block_id;
254
254
 
255
+ $parent_page_id = $attributes['parentPageID'];
256
+
255
257
  $all_pages = get_pages(
256
258
  array(
257
259
  'sort_column' => 'menu_order,post_title',
@@ -306,6 +308,13 @@ function render_block_core_page_list( $attributes, $content, $block ) {
306
308
 
307
309
  $nested_pages = block_core_page_list_nest_pages( $top_level_pages, $pages_with_children );
308
310
 
311
+ if ( 0 !== $parent_page_id ) {
312
+ $nested_pages = block_core_page_list_nest_pages(
313
+ $pages_with_children[ $parent_page_id ],
314
+ $pages_with_children
315
+ );
316
+ }
317
+
309
318
  $is_navigation_child = array_key_exists( 'showSubmenuIcon', $block->context );
310
319
 
311
320
  $open_submenus_on_click = array_key_exists( 'openSubmenusOnClick', $block->context ) ? $block->context['openSubmenusOnClick'] : false;
@@ -1,10 +1,28 @@
1
1
  /**
2
2
  * Internal dependencies
3
3
  */
4
- import { convertSelectedBlockToNavigationLinks } from '../convert-to-links-modal';
4
+
5
+ import { convertToNavigationLinks } from '../convert-to-navigation-links';
6
+
7
+ // Mock createBlock to avoid creating the blocks in test environment
8
+ // as convertToNavigationLinks calls this method internally.
9
+ jest.mock( '@wordpress/blocks', () => {
10
+ const blocks = jest.requireActual( '@wordpress/blocks' );
11
+
12
+ return {
13
+ ...blocks,
14
+ createBlock( name, attributes, innerBlocks ) {
15
+ return {
16
+ name,
17
+ attributes,
18
+ innerBlocks,
19
+ };
20
+ },
21
+ };
22
+ } );
5
23
 
6
24
  describe( 'page list convert to links', () => {
7
- describe( 'convertSelectedBlockToNavigationLinks', () => {
25
+ describe( 'convertToNavigationLinks', () => {
8
26
  it( 'Can create submenus', () => {
9
27
  const pages = [
10
28
  {
@@ -88,22 +106,10 @@ describe( 'page list convert to links', () => {
88
106
  type: 'page',
89
107
  },
90
108
  ];
91
- const replaceBlock = jest.fn();
92
- const createBlock = jest.fn(
93
- ( name, attributes, innerBlocks ) => ( {
94
- name,
95
- attributes,
96
- innerBlocks,
97
- } )
98
- );
99
- const convertLinks = convertSelectedBlockToNavigationLinks( {
100
- pages,
101
- clientId: 'testId',
102
- replaceBlock,
103
- createBlock,
104
- } );
105
- convertLinks();
106
- expect( replaceBlock.mock.calls?.[ 0 ]?.[ 1 ] ).toEqual( [
109
+
110
+ const convertLinks = convertToNavigationLinks( pages );
111
+
112
+ expect( convertLinks ).toEqual( [
107
113
  {
108
114
  attributes: {
109
115
  id: 2,
@@ -280,22 +286,10 @@ describe( 'page list convert to links', () => {
280
286
  type: 'page',
281
287
  },
282
288
  ];
283
- const replaceBlock = jest.fn();
284
- const createBlock = jest.fn(
285
- ( name, attributes, innerBlocks ) => ( {
286
- name,
287
- attributes,
288
- innerBlocks,
289
- } )
290
- );
291
- const convertLinks = convertSelectedBlockToNavigationLinks( {
292
- pages,
293
- clientId: 'testId',
294
- replaceBlock,
295
- createBlock,
296
- } );
297
- convertLinks();
298
- expect( replaceBlock.mock.calls?.[ 0 ]?.[ 1 ] ).toEqual( [
289
+
290
+ const convertLinks = convertToNavigationLinks( pages );
291
+
292
+ expect( convertLinks ).toEqual( [
299
293
  {
300
294
  attributes: {
301
295
  id: 2,
@@ -0,0 +1,51 @@
1
+ {
2
+ "$schema": "https://schemas.wp.org/trunk/block.json",
3
+ "apiVersion": 2,
4
+ "name": "core/page-list-item",
5
+ "title": "Page List Item",
6
+ "category": "widgets",
7
+ "parent": [ "core/page-list" ],
8
+ "description": "Displays a page inside a list of all pages.",
9
+ "keywords": [ "page", "menu", "navigation" ],
10
+ "textdomain": "default",
11
+ "attributes": {
12
+ "id": {
13
+ "type": "number"
14
+ },
15
+ "label": {
16
+ "type": "string"
17
+ },
18
+ "title": {
19
+ "type": "string"
20
+ },
21
+ "link": {
22
+ "type": "string"
23
+ },
24
+ "hasChildren": {
25
+ "type": "boolean"
26
+ }
27
+ },
28
+ "usesContext": [
29
+ "textColor",
30
+ "customTextColor",
31
+ "backgroundColor",
32
+ "customBackgroundColor",
33
+ "overlayTextColor",
34
+ "customOverlayTextColor",
35
+ "overlayBackgroundColor",
36
+ "customOverlayBackgroundColor",
37
+ "fontSize",
38
+ "customFontSize",
39
+ "showSubmenuIcon",
40
+ "style",
41
+ "openSubmenusOnClick"
42
+ ],
43
+ "supports": {
44
+ "reusable": false,
45
+ "html": false,
46
+ "lock": false,
47
+ "inserter": false
48
+ },
49
+ "editorStyle": "wp-block-page-list-editor",
50
+ "style": "wp-block-page-list"
51
+ }
@@ -0,0 +1,94 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import classnames from 'classnames';
5
+
6
+ /**
7
+ * WordPress dependencies
8
+ */
9
+ import { InnerBlocks } from '@wordpress/block-editor';
10
+ import { useSelect } from '@wordpress/data';
11
+ import { store as coreStore } from '@wordpress/core-data';
12
+
13
+ /**
14
+ * Internal dependencies
15
+ */
16
+ import { ItemSubmenuIcon } from '../navigation-link/icons';
17
+
18
+ function useFrontPageId() {
19
+ return useSelect( ( select ) => {
20
+ const canReadSettings = select( coreStore ).canUser(
21
+ 'read',
22
+ 'settings'
23
+ );
24
+ if ( ! canReadSettings ) {
25
+ return undefined;
26
+ }
27
+
28
+ const site = select( coreStore ).getEntityRecord( 'root', 'site' );
29
+ return site?.show_on_front === 'page' && site?.page_on_front;
30
+ }, [] );
31
+ }
32
+
33
+ export default function PageListItemEdit( { context, attributes } ) {
34
+ const { id, label, link, hasChildren } = attributes;
35
+ const isNavigationChild = 'showSubmenuIcon' in context;
36
+ const frontPageId = useFrontPageId();
37
+ return (
38
+ <li
39
+ key={ id }
40
+ className={ classnames( 'wp-block-pages-list__item', {
41
+ 'has-child': hasChildren,
42
+ 'wp-block-navigation-item': isNavigationChild,
43
+ 'open-on-click': context.openSubmenusOnClick,
44
+ 'open-on-hover-click':
45
+ ! context.openSubmenusOnClick && context.showSubmenuIcon,
46
+ 'menu-item-home': id === frontPageId,
47
+ } ) }
48
+ >
49
+ { hasChildren && context.openSubmenusOnClick ? (
50
+ <>
51
+ <button
52
+ className="wp-block-navigation-item__content wp-block-navigation-submenu__toggle"
53
+ aria-expanded="false"
54
+ >
55
+ { label }
56
+ </button>
57
+ <span className="wp-block-page-list__submenu-icon wp-block-navigation__submenu-icon">
58
+ <ItemSubmenuIcon />
59
+ </span>
60
+ </>
61
+ ) : (
62
+ <a
63
+ className={ classnames( 'wp-block-pages-list__item__link', {
64
+ 'wp-block-navigation-item__content': isNavigationChild,
65
+ } ) }
66
+ href={ link }
67
+ >
68
+ { label }
69
+ </a>
70
+ ) }
71
+ { hasChildren && (
72
+ <>
73
+ { ! context.openSubmenusOnClick &&
74
+ context.showSubmenuIcon && (
75
+ <button
76
+ className="wp-block-navigation-item__content wp-block-navigation-submenu__toggle wp-block-page-list__submenu-icon wp-block-navigation__submenu-icon"
77
+ aria-expanded="false"
78
+ >
79
+ <ItemSubmenuIcon />
80
+ </button>
81
+ ) }
82
+ <ul
83
+ className={ classnames( 'submenu-container', {
84
+ 'wp-block-navigation__submenu-container':
85
+ isNavigationChild,
86
+ } ) }
87
+ >
88
+ <InnerBlocks />
89
+ </ul>
90
+ </>
91
+ ) }
92
+ </li>
93
+ );
94
+ }
@@ -0,0 +1,24 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { pages as icon } from '@wordpress/icons';
5
+
6
+ /**
7
+ * Internal dependencies
8
+ */
9
+ import initBlock from '../utils/init-block';
10
+ import metadata from './block.json';
11
+ import edit from './edit.js';
12
+
13
+ const { name } = metadata;
14
+
15
+ export { metadata, name };
16
+
17
+ export const settings = {
18
+ __experimentalLabel: ( { label } ) => label,
19
+ icon,
20
+ example: {},
21
+ edit,
22
+ };
23
+
24
+ export const init = () => initBlock( { name, metadata, settings } );
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Internal dependencies
3
+ */
4
+ import { init } from './';
5
+
6
+ export default init();
@@ -30,12 +30,6 @@ export const settings = {
30
30
  content: __(
31
31
  'In a village of La Mancha, the name of which I have no desire to call to mind, there lived not long since one of those gentlemen that keep a lance in the lance-rack, an old buckler, a lean hack, and a greyhound for coursing.'
32
32
  ),
33
- style: {
34
- typography: {
35
- fontSize: 28,
36
- },
37
- },
38
- dropCap: true,
39
33
  },
40
34
  },
41
35
  __experimentalLabel( attributes, { context } ) {
@@ -62,7 +62,7 @@ function PostAuthorEdit( {
62
62
  attributes;
63
63
  const avatarSizes = [];
64
64
  const authorName = authorDetails?.name || __( 'Post Author' );
65
- if ( authorDetails ) {
65
+ if ( authorDetails?.avatar_urls ) {
66
66
  Object.keys( authorDetails.avatar_urls ).forEach( ( size ) => {
67
67
  avatarSizes.push( {
68
68
  value: size,
@@ -103,6 +103,7 @@ function PostAuthorEdit( {
103
103
  authorOptions.length &&
104
104
  ( ( showCombobox && (
105
105
  <ComboboxControl
106
+ __nextHasNoMarginBottom
106
107
  label={ __( 'Author' ) }
107
108
  options={ authorOptions }
108
109
  value={ authorId }
@@ -172,7 +173,7 @@ function PostAuthorEdit( {
172
173
  </BlockControls>
173
174
 
174
175
  <div { ...blockProps }>
175
- { showAvatar && authorDetails && (
176
+ { showAvatar && authorDetails?.avatar_urls && (
176
177
  <div className="wp-block-post-author__avatar">
177
178
  <img
178
179
  width={ attributes.avatarSize }
@@ -25,8 +25,7 @@ function render_block_core_post_content( $attributes, $content, $block ) {
25
25
  if ( isset( $seen_ids[ $post_id ] ) ) {
26
26
  // WP_DEBUG_DISPLAY must only be honored when WP_DEBUG. This precedent
27
27
  // is set in `wp_debug_mode()`.
28
- $is_debug = defined( 'WP_DEBUG' ) && WP_DEBUG &&
29
- defined( 'WP_DEBUG_DISPLAY' ) && WP_DEBUG_DISPLAY;
28
+ $is_debug = WP_DEBUG && WP_DEBUG_DISPLAY;
30
29
 
31
30
  return $is_debug ?
32
31
  // translators: Visible only in the front end, this warning takes the place of a faulty block.