@wordpress/block-library 7.7.0 → 7.8.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 (489) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/build/audio/index.js +6 -1
  3. package/build/audio/index.js.map +1 -1
  4. package/build/avatar/hooks.js +2 -2
  5. package/build/avatar/hooks.js.map +1 -1
  6. package/build/block/edit.js.map +1 -1
  7. package/build/block/edit.native.js.map +1 -1
  8. package/build/button/deprecated.js.map +1 -1
  9. package/build/button/edit.js.map +1 -1
  10. package/build/button/edit.native.js.map +1 -1
  11. package/build/button/index.js +24 -1
  12. package/build/button/index.js.map +1 -1
  13. package/build/button/save.js.map +1 -1
  14. package/build/buttons/deprecated.js.map +1 -1
  15. package/build/buttons/edit.js.map +1 -1
  16. package/build/buttons/edit.native.js.map +1 -1
  17. package/build/column/deprecated.js.map +1 -1
  18. package/build/column/edit.js.map +1 -1
  19. package/build/column/edit.native.js.map +1 -1
  20. package/build/columns/deprecated.js.map +1 -1
  21. package/build/columns/edit.js +1 -1
  22. package/build/columns/edit.js.map +1 -1
  23. package/build/columns/edit.native.js +1 -1
  24. package/build/columns/edit.native.js.map +1 -1
  25. package/build/columns/index.js.map +1 -1
  26. package/build/columns/utils.js +1 -1
  27. package/build/columns/utils.js.map +1 -1
  28. package/build/comment-author-name/edit.js +4 -2
  29. package/build/comment-author-name/edit.js.map +1 -1
  30. package/build/comment-date/edit.js +1 -1
  31. package/build/comment-date/edit.js.map +1 -1
  32. package/build/comments-title/edit.js +1 -1
  33. package/build/comments-title/edit.js.map +1 -1
  34. package/build/cover/controls.native.js.map +1 -1
  35. package/build/cover/deprecated.js.map +1 -1
  36. package/build/cover/edit/block-controls.js +3 -10
  37. package/build/cover/edit/block-controls.js.map +1 -1
  38. package/build/cover/edit/index.js +21 -28
  39. package/build/cover/edit/index.js.map +1 -1
  40. package/build/cover/edit/inspector-controls.js +34 -6
  41. package/build/cover/edit/inspector-controls.js.map +1 -1
  42. package/build/cover/edit.native.js.map +1 -1
  43. package/build/cover/save.js.map +1 -1
  44. package/build/cover/transforms.js.map +1 -1
  45. package/build/embed/deprecated.js +6 -1
  46. package/build/embed/deprecated.js.map +1 -1
  47. package/build/embed/edit.js.map +1 -1
  48. package/build/embed/edit.native.js.map +1 -1
  49. package/build/embed/embed-controls.native.js.map +1 -1
  50. package/build/embed/index.js +6 -1
  51. package/build/embed/index.js.map +1 -1
  52. package/build/embed/transforms.js +6 -1
  53. package/build/embed/transforms.js.map +1 -1
  54. package/build/embed/util.js +6 -1
  55. package/build/embed/util.js.map +1 -1
  56. package/build/file/edit.js.map +1 -1
  57. package/build/file/edit.native.js.map +1 -1
  58. package/build/file/index.js.map +1 -1
  59. package/build/gallery/edit.js +1 -1
  60. package/build/gallery/edit.js.map +1 -1
  61. package/build/gallery/gallery.native.js.map +1 -1
  62. package/build/gallery/index.js.map +1 -1
  63. package/build/gallery/shared.js +27 -10
  64. package/build/gallery/shared.js.map +1 -1
  65. package/build/gallery/v1/edit.js.map +1 -1
  66. package/build/gallery/v1/gallery-image.js.map +1 -1
  67. package/build/gallery/v1/gallery-image.native.js.map +1 -1
  68. package/build/heading/autogenerate-anchors.js +7 -2
  69. package/build/heading/autogenerate-anchors.js.map +1 -1
  70. package/build/heading/deprecated.js.map +1 -1
  71. package/build/heading/edit.js.map +1 -1
  72. package/build/image/deprecated.js.map +1 -1
  73. package/build/image/edit.native.js.map +1 -1
  74. package/build/image/image.js.map +1 -1
  75. package/build/image/index.js +5 -0
  76. package/build/image/index.js.map +1 -1
  77. package/build/image/transforms.js.map +1 -1
  78. package/build/image/utils.js +2 -1
  79. package/build/image/utils.js.map +1 -1
  80. package/build/index.js +1 -1
  81. package/build/index.js.map +1 -1
  82. package/build/latest-comments/edit.js.map +1 -1
  83. package/build/latest-posts/edit.js +1 -1
  84. package/build/latest-posts/edit.js.map +1 -1
  85. package/build/latest-posts/edit.native.js.map +1 -1
  86. package/build/list/index.js.map +1 -1
  87. package/build/list/v2/edit.js.map +1 -1
  88. package/build/list-item/hooks/use-backspace.js.map +1 -1
  89. package/build/list-item/hooks/use-enter.js.map +1 -1
  90. package/build/list-item/hooks/use-indent-list-item.js.map +1 -1
  91. package/build/list-item/hooks/use-outdent-list-item.js.map +1 -1
  92. package/build/list-item/hooks/use-space.js.map +1 -1
  93. package/build/media-text/deprecated.js +5 -3
  94. package/build/media-text/deprecated.js.map +1 -1
  95. package/build/media-text/edit.native.js.map +1 -1
  96. package/build/media-text/media-container.js +3 -3
  97. package/build/media-text/media-container.js.map +1 -1
  98. package/build/media-text/media-container.native.js.map +1 -1
  99. package/build/media-text/save.js +3 -1
  100. package/build/media-text/save.js.map +1 -1
  101. package/build/missing/edit.native.js.map +1 -1
  102. package/build/navigation/deprecated.js.map +1 -1
  103. package/build/navigation/edit/index.js.map +1 -1
  104. package/build/navigation/edit/navigation-menu-delete-control.js.map +1 -1
  105. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  106. package/build/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  107. package/build/navigation/use-navigation-entities.js.map +1 -1
  108. package/build/navigation/use-navigation-menu.js +130 -38
  109. package/build/navigation/use-navigation-menu.js.map +1 -1
  110. package/build/navigation/use-template-part-area-label.js +4 -1
  111. package/build/navigation/use-template-part-area-label.js.map +1 -1
  112. package/build/navigation-link/edit.js +14 -8
  113. package/build/navigation-link/edit.js.map +1 -1
  114. package/build/navigation-submenu/edit.js.map +1 -1
  115. package/build/page-list/convert-to-links-modal.js.map +1 -1
  116. package/build/page-list/edit.js.map +1 -1
  117. package/build/paragraph/deprecated.js +1 -1
  118. package/build/paragraph/deprecated.js.map +1 -1
  119. package/build/pattern/edit.js.map +1 -1
  120. package/build/post-author/edit.js.map +1 -1
  121. package/build/post-content/edit.js.map +1 -1
  122. package/build/post-featured-image/edit.js +10 -24
  123. package/build/post-featured-image/edit.js.map +1 -1
  124. package/build/post-navigation-link/index.js +4 -0
  125. package/build/post-navigation-link/index.js.map +1 -1
  126. package/build/pullquote/deprecated.js.map +1 -1
  127. package/build/query/edit/index.js +5 -1
  128. package/build/query/edit/index.js.map +1 -1
  129. package/build/query/edit/inspector-controls/parent-control.js.map +1 -1
  130. package/build/query/edit/query-toolbar.js +16 -2
  131. package/build/query/edit/query-toolbar.js.map +1 -1
  132. package/build/quote/v2/edit.js.map +1 -1
  133. package/build/search/edit.js.map +1 -1
  134. package/build/search/edit.native.js.map +1 -1
  135. package/build/separator/use-deprecated-opacity.js.map +1 -1
  136. package/build/shortcode/edit.native.js.map +1 -1
  137. package/build/site-logo/edit.js +3 -12
  138. package/build/site-logo/edit.js.map +1 -1
  139. package/build/social-links/deprecated.js.map +1 -1
  140. package/build/social-links/edit.native.js.map +1 -1
  141. package/build/spacer/controls.js.map +1 -1
  142. package/build/table/deprecated.js.map +1 -1
  143. package/build/table/index.js +6 -1
  144. package/build/table/index.js.map +1 -1
  145. package/build/table/state.js.map +1 -1
  146. package/build/table-of-contents/edit.js.map +1 -1
  147. package/build/tag-cloud/edit.js.map +1 -1
  148. package/build/template-part/edit/advanced-controls.js +4 -1
  149. package/build/template-part/edit/advanced-controls.js.map +1 -1
  150. package/build/template-part/edit/index.js.map +1 -1
  151. package/build/template-part/edit/utils/hooks.js +4 -1
  152. package/build/template-part/edit/utils/hooks.js.map +1 -1
  153. package/build/transformationCategories.native.js.map +1 -1
  154. package/build/video/edit-common-settings.js.map +1 -1
  155. package/build/video/edit.native.js +43 -0
  156. package/build/video/edit.native.js.map +1 -1
  157. package/build/video/index.js +6 -1
  158. package/build/video/index.js.map +1 -1
  159. package/build-module/audio/index.js +6 -1
  160. package/build-module/audio/index.js.map +1 -1
  161. package/build-module/avatar/hooks.js +2 -2
  162. package/build-module/avatar/hooks.js.map +1 -1
  163. package/build-module/block/edit.js.map +1 -1
  164. package/build-module/block/edit.native.js.map +1 -1
  165. package/build-module/button/deprecated.js.map +1 -1
  166. package/build-module/button/edit.js.map +1 -1
  167. package/build-module/button/edit.native.js.map +1 -1
  168. package/build-module/button/index.js +24 -1
  169. package/build-module/button/index.js.map +1 -1
  170. package/build-module/button/save.js.map +1 -1
  171. package/build-module/buttons/deprecated.js.map +1 -1
  172. package/build-module/buttons/edit.js.map +1 -1
  173. package/build-module/buttons/edit.native.js.map +1 -1
  174. package/build-module/column/deprecated.js.map +1 -1
  175. package/build-module/column/edit.js.map +1 -1
  176. package/build-module/column/edit.native.js.map +1 -1
  177. package/build-module/columns/deprecated.js.map +1 -1
  178. package/build-module/columns/edit.js +2 -2
  179. package/build-module/columns/edit.js.map +1 -1
  180. package/build-module/columns/edit.native.js +2 -2
  181. package/build-module/columns/edit.native.js.map +1 -1
  182. package/build-module/columns/index.js.map +1 -1
  183. package/build-module/columns/utils.js +2 -2
  184. package/build-module/columns/utils.js.map +1 -1
  185. package/build-module/comment-author-name/edit.js +4 -2
  186. package/build-module/comment-author-name/edit.js.map +1 -1
  187. package/build-module/comment-date/edit.js +1 -1
  188. package/build-module/comment-date/edit.js.map +1 -1
  189. package/build-module/comments-title/edit.js +1 -1
  190. package/build-module/comments-title/edit.js.map +1 -1
  191. package/build-module/cover/controls.native.js.map +1 -1
  192. package/build-module/cover/deprecated.js.map +1 -1
  193. package/build-module/cover/edit/block-controls.js +3 -8
  194. package/build-module/cover/edit/block-controls.js.map +1 -1
  195. package/build-module/cover/edit/index.js +22 -29
  196. package/build-module/cover/edit/index.js.map +1 -1
  197. package/build-module/cover/edit/inspector-controls.js +32 -7
  198. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  199. package/build-module/cover/edit.native.js.map +1 -1
  200. package/build-module/cover/save.js.map +1 -1
  201. package/build-module/cover/transforms.js.map +1 -1
  202. package/build-module/embed/deprecated.js +6 -1
  203. package/build-module/embed/deprecated.js.map +1 -1
  204. package/build-module/embed/edit.js.map +1 -1
  205. package/build-module/embed/edit.native.js.map +1 -1
  206. package/build-module/embed/embed-controls.native.js.map +1 -1
  207. package/build-module/embed/index.js +6 -1
  208. package/build-module/embed/index.js.map +1 -1
  209. package/build-module/embed/transforms.js +6 -1
  210. package/build-module/embed/transforms.js.map +1 -1
  211. package/build-module/embed/util.js +6 -1
  212. package/build-module/embed/util.js.map +1 -1
  213. package/build-module/file/edit.js.map +1 -1
  214. package/build-module/file/edit.native.js.map +1 -1
  215. package/build-module/file/index.js.map +1 -1
  216. package/build-module/gallery/edit.js +2 -2
  217. package/build-module/gallery/edit.js.map +1 -1
  218. package/build-module/gallery/gallery.native.js.map +1 -1
  219. package/build-module/gallery/index.js.map +1 -1
  220. package/build-module/gallery/shared.js +25 -8
  221. package/build-module/gallery/shared.js.map +1 -1
  222. package/build-module/gallery/v1/edit.js.map +1 -1
  223. package/build-module/gallery/v1/gallery-image.js.map +1 -1
  224. package/build-module/gallery/v1/gallery-image.native.js.map +1 -1
  225. package/build-module/heading/autogenerate-anchors.js +5 -2
  226. package/build-module/heading/autogenerate-anchors.js.map +1 -1
  227. package/build-module/heading/deprecated.js.map +1 -1
  228. package/build-module/heading/edit.js.map +1 -1
  229. package/build-module/image/deprecated.js.map +1 -1
  230. package/build-module/image/edit.native.js.map +1 -1
  231. package/build-module/image/image.js.map +1 -1
  232. package/build-module/image/index.js +5 -0
  233. package/build-module/image/index.js.map +1 -1
  234. package/build-module/image/transforms.js.map +1 -1
  235. package/build-module/image/utils.js +2 -2
  236. package/build-module/image/utils.js.map +1 -1
  237. package/build-module/index.js +1 -1
  238. package/build-module/index.js.map +1 -1
  239. package/build-module/latest-comments/edit.js.map +1 -1
  240. package/build-module/latest-posts/edit.js +2 -2
  241. package/build-module/latest-posts/edit.js.map +1 -1
  242. package/build-module/latest-posts/edit.native.js.map +1 -1
  243. package/build-module/list/index.js.map +1 -1
  244. package/build-module/list/v2/edit.js.map +1 -1
  245. package/build-module/list-item/hooks/use-backspace.js.map +1 -1
  246. package/build-module/list-item/hooks/use-enter.js.map +1 -1
  247. package/build-module/list-item/hooks/use-indent-list-item.js.map +1 -1
  248. package/build-module/list-item/hooks/use-outdent-list-item.js.map +1 -1
  249. package/build-module/list-item/hooks/use-space.js.map +1 -1
  250. package/build-module/media-text/deprecated.js +3 -1
  251. package/build-module/media-text/deprecated.js.map +1 -1
  252. package/build-module/media-text/edit.native.js.map +1 -1
  253. package/build-module/media-text/media-container.js +3 -1
  254. package/build-module/media-text/media-container.js.map +1 -1
  255. package/build-module/media-text/media-container.native.js.map +1 -1
  256. package/build-module/media-text/save.js +4 -1
  257. package/build-module/media-text/save.js.map +1 -1
  258. package/build-module/missing/edit.native.js.map +1 -1
  259. package/build-module/navigation/deprecated.js.map +1 -1
  260. package/build-module/navigation/edit/index.js.map +1 -1
  261. package/build-module/navigation/edit/navigation-menu-delete-control.js.map +1 -1
  262. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  263. package/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  264. package/build-module/navigation/use-navigation-entities.js.map +1 -1
  265. package/build-module/navigation/use-navigation-menu.js +130 -38
  266. package/build-module/navigation/use-navigation-menu.js.map +1 -1
  267. package/build-module/navigation/use-template-part-area-label.js +4 -1
  268. package/build-module/navigation/use-template-part-area-label.js.map +1 -1
  269. package/build-module/navigation-link/edit.js +14 -8
  270. package/build-module/navigation-link/edit.js.map +1 -1
  271. package/build-module/navigation-submenu/edit.js.map +1 -1
  272. package/build-module/page-list/convert-to-links-modal.js.map +1 -1
  273. package/build-module/page-list/edit.js.map +1 -1
  274. package/build-module/paragraph/deprecated.js +2 -2
  275. package/build-module/paragraph/deprecated.js.map +1 -1
  276. package/build-module/pattern/edit.js.map +1 -1
  277. package/build-module/post-author/edit.js.map +1 -1
  278. package/build-module/post-content/edit.js.map +1 -1
  279. package/build-module/post-featured-image/edit.js +10 -23
  280. package/build-module/post-featured-image/edit.js.map +1 -1
  281. package/build-module/post-navigation-link/index.js +4 -0
  282. package/build-module/post-navigation-link/index.js.map +1 -1
  283. package/build-module/pullquote/deprecated.js.map +1 -1
  284. package/build-module/query/edit/index.js +5 -1
  285. package/build-module/query/edit/index.js.map +1 -1
  286. package/build-module/query/edit/inspector-controls/parent-control.js.map +1 -1
  287. package/build-module/query/edit/query-toolbar.js +14 -2
  288. package/build-module/query/edit/query-toolbar.js.map +1 -1
  289. package/build-module/quote/v2/edit.js.map +1 -1
  290. package/build-module/search/edit.js.map +1 -1
  291. package/build-module/search/edit.native.js.map +1 -1
  292. package/build-module/separator/use-deprecated-opacity.js.map +1 -1
  293. package/build-module/shortcode/edit.native.js.map +1 -1
  294. package/build-module/site-logo/edit.js +3 -11
  295. package/build-module/site-logo/edit.js.map +1 -1
  296. package/build-module/social-links/deprecated.js.map +1 -1
  297. package/build-module/social-links/edit.native.js.map +1 -1
  298. package/build-module/spacer/controls.js.map +1 -1
  299. package/build-module/table/deprecated.js.map +1 -1
  300. package/build-module/table/index.js +6 -1
  301. package/build-module/table/index.js.map +1 -1
  302. package/build-module/table/state.js.map +1 -1
  303. package/build-module/table-of-contents/edit.js.map +1 -1
  304. package/build-module/tag-cloud/edit.js.map +1 -1
  305. package/build-module/template-part/edit/advanced-controls.js +4 -1
  306. package/build-module/template-part/edit/advanced-controls.js.map +1 -1
  307. package/build-module/template-part/edit/index.js.map +1 -1
  308. package/build-module/template-part/edit/utils/hooks.js +4 -1
  309. package/build-module/template-part/edit/utils/hooks.js.map +1 -1
  310. package/build-module/transformationCategories.native.js.map +1 -1
  311. package/build-module/video/edit-common-settings.js.map +1 -1
  312. package/build-module/video/edit.native.js +42 -1
  313. package/build-module/video/edit.native.js.map +1 -1
  314. package/build-module/video/index.js +6 -1
  315. package/build-module/video/index.js.map +1 -1
  316. package/build-style/audio/style-rtl.css +0 -3
  317. package/build-style/audio/style.css +0 -3
  318. package/build-style/button/style-rtl.css +0 -5
  319. package/build-style/button/style.css +0 -5
  320. package/build-style/common-rtl.css +1 -3
  321. package/build-style/common.css +1 -3
  322. package/build-style/cover/editor-rtl.css +11 -0
  323. package/build-style/cover/editor.css +11 -0
  324. package/build-style/cover/style-rtl.css +1 -2
  325. package/build-style/cover/style.css +1 -2
  326. package/build-style/editor-rtl.css +11 -39
  327. package/build-style/editor.css +11 -39
  328. package/build-style/embed/style-rtl.css +0 -1
  329. package/build-style/embed/style.css +0 -1
  330. package/build-style/file/style-rtl.css +9 -7
  331. package/build-style/file/style.css +9 -7
  332. package/build-style/gallery/style-rtl.css +2 -4
  333. package/build-style/gallery/style.css +2 -4
  334. package/build-style/image/style-rtl.css +0 -3
  335. package/build-style/image/style.css +0 -3
  336. package/build-style/post-featured-image/editor-rtl.css +0 -27
  337. package/build-style/post-featured-image/editor.css +0 -27
  338. package/build-style/search/style-rtl.css +4 -4
  339. package/build-style/search/style.css +4 -4
  340. package/build-style/site-logo/editor-rtl.css +0 -12
  341. package/build-style/site-logo/editor.css +0 -12
  342. package/build-style/style-rtl.css +18 -38
  343. package/build-style/style.css +18 -38
  344. package/build-style/table/style-rtl.css +0 -1
  345. package/build-style/table/style.css +0 -1
  346. package/build-style/video/style-rtl.css +1 -5
  347. package/build-style/video/style.css +1 -5
  348. package/package.json +30 -29
  349. package/src/audio/block.json +6 -1
  350. package/src/audio/index.js +1 -2
  351. package/src/audio/style.scss +0 -2
  352. package/src/avatar/hooks.js +9 -6
  353. package/src/block/edit.js +4 -6
  354. package/src/block/edit.native.js +12 -16
  355. package/src/block/test/edit.native.js +5 -8
  356. package/src/button/block.json +24 -1
  357. package/src/button/deprecated.js +10 -46
  358. package/src/button/edit.js +4 -10
  359. package/src/button/edit.native.js +2 -3
  360. package/src/button/save.js +2 -10
  361. package/src/button/style.scss +0 -5
  362. package/src/buttons/deprecated.js +4 -6
  363. package/src/buttons/edit.js +3 -3
  364. package/src/buttons/edit.native.js +7 -11
  365. package/src/column/deprecated.js +2 -1
  366. package/src/column/edit.js +2 -3
  367. package/src/column/edit.native.js +2 -2
  368. package/src/columns/deprecated.js +4 -2
  369. package/src/columns/edit.js +6 -7
  370. package/src/columns/edit.native.js +12 -16
  371. package/src/columns/index.js +1 -2
  372. package/src/columns/utils.js +5 -3
  373. package/src/comment-author-name/edit.js +2 -2
  374. package/src/comment-date/edit.js +1 -1
  375. package/src/comments-title/edit.js +1 -1
  376. package/src/comments-title/index.php +1 -1
  377. package/src/cover/controls.native.js +2 -4
  378. package/src/cover/deprecated.js +10 -15
  379. package/src/cover/edit/block-controls.js +11 -20
  380. package/src/cover/edit/index.js +58 -55
  381. package/src/cover/edit/inspector-controls.js +38 -7
  382. package/src/cover/edit.native.js +8 -13
  383. package/src/cover/editor.scss +13 -0
  384. package/src/cover/save.js +2 -3
  385. package/src/cover/test/edit.native.js +4 -7
  386. package/src/cover/transforms.js +2 -7
  387. package/src/embed/block.json +6 -1
  388. package/src/embed/edit.js +38 -40
  389. package/src/embed/edit.native.js +46 -49
  390. package/src/embed/embed-controls.native.js +2 -3
  391. package/src/embed/style.scss +0 -1
  392. package/src/embed/test/index.native.js +24 -50
  393. package/src/file/edit.js +2 -4
  394. package/src/file/edit.native.js +14 -25
  395. package/src/file/index.js +1 -2
  396. package/src/file/style.scss +15 -14
  397. package/src/gallery/edit.js +8 -6
  398. package/src/gallery/gallery.native.js +2 -4
  399. package/src/gallery/index.js +2 -4
  400. package/src/gallery/shared.js +22 -9
  401. package/src/gallery/test/index.native.js +18 -34
  402. package/src/gallery/v1/edit.js +15 -20
  403. package/src/gallery/v1/gallery-image.js +6 -11
  404. package/src/gallery/v1/gallery-image.native.js +8 -17
  405. package/src/heading/autogenerate-anchors.js +8 -5
  406. package/src/heading/deprecated.js +6 -21
  407. package/src/heading/edit.js +2 -3
  408. package/src/image/block.json +5 -0
  409. package/src/image/deprecated.js +6 -29
  410. package/src/image/edit.native.js +14 -26
  411. package/src/image/image.js +31 -38
  412. package/src/image/style.scss +0 -2
  413. package/src/image/transforms.js +4 -3
  414. package/src/image/utils.js +2 -2
  415. package/src/index.js +1 -1
  416. package/src/latest-comments/edit.js +2 -6
  417. package/src/latest-posts/edit.js +6 -7
  418. package/src/latest-posts/edit.native.js +10 -15
  419. package/src/list/index.js +1 -2
  420. package/src/list/test/migrate.js +1 -2
  421. package/src/list/v2/edit.js +6 -9
  422. package/src/list-item/hooks/use-backspace.js +2 -3
  423. package/src/list-item/hooks/use-enter.js +2 -3
  424. package/src/list-item/hooks/use-indent-list-item.js +2 -3
  425. package/src/list-item/hooks/use-outdent-list-item.js +2 -3
  426. package/src/list-item/hooks/use-space.js +2 -3
  427. package/src/media-text/deprecated.js +6 -3
  428. package/src/media-text/edit.native.js +2 -5
  429. package/src/media-text/media-container.js +1 -1
  430. package/src/media-text/media-container.native.js +6 -9
  431. package/src/media-text/save.js +2 -1
  432. package/src/missing/edit.native.js +2 -3
  433. package/src/missing/test/edit-integration.native.js +2 -3
  434. package/src/missing/test/edit.native.js +6 -9
  435. package/src/navigation/deprecated.js +2 -5
  436. package/src/navigation/edit/index.js +24 -36
  437. package/src/navigation/edit/navigation-menu-delete-control.js +2 -3
  438. package/src/navigation/edit/unsaved-inner-blocks.js +31 -30
  439. package/src/navigation/edit/use-convert-classic-menu-to-block-menu.js +2 -3
  440. package/src/navigation/test/use-navigation-menu.js +236 -0
  441. package/src/navigation/use-navigation-entities.js +11 -13
  442. package/src/navigation/use-navigation-menu.js +152 -82
  443. package/src/navigation/use-template-part-area-label.js +8 -7
  444. package/src/navigation-link/edit.js +24 -20
  445. package/src/navigation-link/test/edit.js +2 -4
  446. package/src/navigation-submenu/edit.js +10 -20
  447. package/src/page-list/convert-to-links-modal.js +51 -54
  448. package/src/page-list/edit.js +6 -6
  449. package/src/page-list/test/convert-to-links-modal.js +6 -12
  450. package/src/paragraph/deprecated.js +2 -2
  451. package/src/pattern/edit.js +2 -4
  452. package/src/post-author/edit.js +2 -3
  453. package/src/post-content/edit.js +2 -3
  454. package/src/post-featured-image/edit.js +14 -30
  455. package/src/post-featured-image/editor.scss +0 -29
  456. package/src/post-navigation-link/block.json +4 -0
  457. package/src/pullquote/deprecated.js +2 -1
  458. package/src/query/edit/index.js +10 -10
  459. package/src/query/edit/inspector-controls/parent-control.js +2 -3
  460. package/src/query/edit/query-toolbar.js +25 -5
  461. package/src/quote/v2/edit.js +4 -6
  462. package/src/quote/v2/test/migrate.js +1 -2
  463. package/src/search/edit.js +6 -12
  464. package/src/search/edit.native.js +4 -6
  465. package/src/search/style.scss +2 -1
  466. package/src/separator/use-deprecated-opacity.js +2 -4
  467. package/src/shortcode/edit.native.js +4 -3
  468. package/src/shortcode/test/edit.native.js +2 -5
  469. package/src/site-logo/edit.js +3 -17
  470. package/src/site-logo/editor.scss +0 -14
  471. package/src/social-links/deprecated.js +4 -2
  472. package/src/social-links/edit.native.js +3 -5
  473. package/src/spacer/controls.js +2 -3
  474. package/src/spacer/test/index.native.js +10 -21
  475. package/src/table/block.json +6 -1
  476. package/src/table/deprecated.js +4 -8
  477. package/src/table/state.js +2 -4
  478. package/src/table/style.scss +0 -1
  479. package/src/table-of-contents/edit.js +6 -10
  480. package/src/tag-cloud/edit.js +4 -7
  481. package/src/template-part/edit/advanced-controls.js +4 -4
  482. package/src/template-part/edit/index.js +6 -10
  483. package/src/template-part/edit/utils/hooks.js +8 -7
  484. package/src/transformationCategories.native.js +3 -3
  485. package/src/video/block.json +6 -1
  486. package/src/video/edit-common-settings.js +2 -8
  487. package/src/video/edit.native.js +38 -16
  488. package/src/video/index.js +1 -2
  489. package/src/video/style.scss +0 -2
@@ -12,9 +12,8 @@ import { useState } from '@wordpress/element';
12
12
  import { __, sprintf } from '@wordpress/i18n';
13
13
 
14
14
  export default function NavigationMenuDeleteControl( { onDelete } ) {
15
- const [ isConfirmModalVisible, setIsConfirmModalVisible ] = useState(
16
- false
17
- );
15
+ const [ isConfirmModalVisible, setIsConfirmModalVisible ] =
16
+ useState( false );
18
17
  const id = useEntityId( 'postType', 'wp_navigation' );
19
18
  const [ title ] = useEntityProp( 'postType', 'wp_navigation', 'title' );
20
19
  const { deleteEntityRecord } = useDispatch( coreStore );
@@ -88,39 +88,40 @@ export default function UnsavedInnerBlocks( {
88
88
  __experimentalDirectInsert: shouldDirectInsert,
89
89
  } );
90
90
 
91
- const {
92
- isSaving,
93
- draftNavigationMenus,
94
- hasResolvedDraftNavigationMenus,
95
- } = useSelect(
96
- ( select ) => {
97
- if ( isDisabled ) {
98
- return EMPTY_OBJECT;
99
- }
100
-
101
- const {
102
- getEntityRecords,
103
- hasFinishedResolution,
104
- isSavingEntityRecord,
105
- } = select( coreStore );
106
-
107
- return {
108
- isSaving: isSavingEntityRecord( 'postType', 'wp_navigation' ),
109
- draftNavigationMenus: getEntityRecords( ...DRAFT_MENU_PARAMS ),
110
- hasResolvedDraftNavigationMenus: hasFinishedResolution(
111
- 'getEntityRecords',
112
- DRAFT_MENU_PARAMS
113
- ),
114
- };
115
- },
116
- [ isDisabled ]
117
- );
91
+ const { isSaving, draftNavigationMenus, hasResolvedDraftNavigationMenus } =
92
+ useSelect(
93
+ ( select ) => {
94
+ if ( isDisabled ) {
95
+ return EMPTY_OBJECT;
96
+ }
97
+
98
+ const {
99
+ getEntityRecords,
100
+ hasFinishedResolution,
101
+ isSavingEntityRecord,
102
+ } = select( coreStore );
103
+
104
+ return {
105
+ isSaving: isSavingEntityRecord(
106
+ 'postType',
107
+ 'wp_navigation'
108
+ ),
109
+ draftNavigationMenus: getEntityRecords(
110
+ ...DRAFT_MENU_PARAMS
111
+ ),
112
+ hasResolvedDraftNavigationMenus: hasFinishedResolution(
113
+ 'getEntityRecords',
114
+ DRAFT_MENU_PARAMS
115
+ ),
116
+ };
117
+ },
118
+ [ isDisabled ]
119
+ );
118
120
 
119
121
  const { hasResolvedNavigationMenus, navigationMenus } = useNavigationMenu();
120
122
 
121
- const { create: createNavigationMenu } = useCreateNavigationMenu(
122
- clientId
123
- );
123
+ const { create: createNavigationMenu } =
124
+ useCreateNavigationMenu( clientId );
124
125
 
125
126
  // Automatically save the uncontrolled blocks.
126
127
  useEffect( () => {
@@ -18,9 +18,8 @@ export const CLASSIC_MENU_CONVERSION_PENDING = 'pending';
18
18
  export const CLASSIC_MENU_CONVERSION_IDLE = 'idle';
19
19
 
20
20
  function useConvertClassicToBlockMenu( clientId ) {
21
- const { create: createNavigationMenu } = useCreateNavigationMenu(
22
- clientId
23
- );
21
+ const { create: createNavigationMenu } =
22
+ useCreateNavigationMenu( clientId );
24
23
  const registry = useRegistry();
25
24
 
26
25
  const [ status, setStatus ] = useState( CLASSIC_MENU_CONVERSION_IDLE );
@@ -0,0 +1,236 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { createRegistry, useSelect } from '@wordpress/data';
5
+ import { store as coreStore } from '@wordpress/core-data';
6
+
7
+ /**
8
+ * Internal dependencies
9
+ */
10
+ import useNavigationMenu from '../use-navigation-menu';
11
+
12
+ function createRegistryWithStores() {
13
+ // Create a registry and register used stores.
14
+ const registry = createRegistry();
15
+ registry.register( coreStore );
16
+
17
+ const navigationConfig = {
18
+ kind: 'postType',
19
+ name: 'wp_navigation',
20
+ baseURL: '/wp/v2/navigation',
21
+ rawAttributes: [ 'title', 'excerpt', 'content' ],
22
+ };
23
+ // Register post type entity.
24
+ registry.dispatch( coreStore ).addEntities( [ navigationConfig ] );
25
+ return registry;
26
+ }
27
+
28
+ jest.mock( '@wordpress/data/src/components/use-select', () => {
29
+ // This allows us to tweak the returned value on each test.
30
+ const mock = jest.fn();
31
+ return mock;
32
+ } );
33
+
34
+ function resolveRecords( registry, menus ) {
35
+ const dispatch = registry.dispatch( coreStore );
36
+ dispatch.startResolution( 'getEntityRecords', [
37
+ 'postType',
38
+ 'wp_navigation',
39
+ { per_page: -1, status: 'publish' },
40
+ ] );
41
+ dispatch.finishResolution( 'getEntityRecords', [
42
+ 'postType',
43
+ 'wp_navigation',
44
+ { per_page: -1, status: 'publish' },
45
+ ] );
46
+ dispatch.receiveEntityRecords( 'postType', 'wp_navigation', menus, {
47
+ per_page: -1,
48
+ status: 'publish',
49
+ } );
50
+ }
51
+
52
+ function resolveCreatePermission( registry, allowed ) {
53
+ const dispatch = registry.dispatch( coreStore );
54
+ dispatch.receiveUserPermission( 'create/navigation', allowed );
55
+ dispatch.startResolution( 'canUser', [ 'create', 'navigation' ] );
56
+ dispatch.finishResolution( 'canUser', [ 'create', 'navigation' ] );
57
+ }
58
+
59
+ function resolveUpdatePermission( registry, ref, allowed ) {
60
+ const dispatch = registry.dispatch( coreStore );
61
+ dispatch.receiveUserPermission( `update/navigation/${ ref }`, allowed );
62
+ dispatch.startResolution( 'canUser', [ 'update', 'navigation', ref ] );
63
+ dispatch.finishResolution( 'canUser', [ 'update', 'navigation', ref ] );
64
+ }
65
+
66
+ function resolveDeletePermission( registry, ref, allowed ) {
67
+ const dispatch = registry.dispatch( coreStore );
68
+ dispatch.receiveUserPermission( `delete/navigation/${ ref }`, allowed );
69
+ dispatch.startResolution( 'canUser', [ 'delete', 'navigation', ref ] );
70
+ dispatch.finishResolution( 'canUser', [ 'delete', 'navigation', ref ] );
71
+ }
72
+
73
+ describe( 'useNavigationMenus', () => {
74
+ const navigationMenu1 = { id: 1, title: 'Menu 1', status: 'publish' };
75
+ const navigationMenu2 = { id: 2, title: 'Menu 2', status: 'publish' };
76
+ const navigationMenu3 = { id: 3, title: 'Menu 3', status: 'publish' };
77
+ const navigationMenus = [
78
+ navigationMenu1,
79
+ navigationMenu2,
80
+ navigationMenu3,
81
+ ];
82
+
83
+ let registry;
84
+ beforeEach( () => {
85
+ registry = createRegistryWithStores();
86
+ useSelect.mockImplementation( ( fn ) => fn( registry.select ) );
87
+ } );
88
+
89
+ it( 'Should return no information when no data is resolved', () => {
90
+ expect( useNavigationMenu() ).toEqual( {
91
+ navigationMenus: null,
92
+ canSwitchNavigationMenu: false,
93
+ canUserCreateNavigationMenu: false,
94
+ canUserDeleteNavigationMenu: false,
95
+ canUserUpdateNavigationMenu: false,
96
+ hasResolvedCanUserCreateNavigationMenu: false,
97
+ hasResolvedCanUserDeleteNavigationMenu: false,
98
+ hasResolvedCanUserUpdateNavigationMenu: false,
99
+ hasResolvedNavigationMenus: false,
100
+ isNavigationMenuMissing: true,
101
+ isNavigationMenuResolved: false,
102
+ isResolvingCanUserCreateNavigationMenu: false,
103
+ isResolvingNavigationMenus: false,
104
+ } );
105
+ } );
106
+
107
+ it( 'Should return information about all menus when ref is missing', () => {
108
+ resolveRecords( registry, navigationMenus );
109
+ resolveCreatePermission( registry, true );
110
+ expect( useNavigationMenu() ).toEqual( {
111
+ navigationMenus,
112
+ canSwitchNavigationMenu: true,
113
+ canUserCreateNavigationMenu: true,
114
+ canUserDeleteNavigationMenu: false,
115
+ canUserUpdateNavigationMenu: false,
116
+ hasResolvedCanUserCreateNavigationMenu: true,
117
+ hasResolvedCanUserDeleteNavigationMenu: false,
118
+ hasResolvedCanUserUpdateNavigationMenu: false,
119
+ hasResolvedNavigationMenus: true,
120
+ isNavigationMenuMissing: true,
121
+ isNavigationMenuResolved: false,
122
+ isResolvingCanUserCreateNavigationMenu: false,
123
+ isResolvingNavigationMenus: false,
124
+ } );
125
+ } );
126
+
127
+ it( 'Should return information about a specific menu when ref is given', () => {
128
+ resolveRecords( registry, navigationMenus );
129
+ expect( useNavigationMenu( 1 ) ).toEqual( {
130
+ navigationMenu: navigationMenu1,
131
+ navigationMenus,
132
+ canSwitchNavigationMenu: true,
133
+ canUserCreateNavigationMenu: false,
134
+ canUserDeleteNavigationMenu: false,
135
+ canUserUpdateNavigationMenu: false,
136
+ hasResolvedCanUserCreateNavigationMenu: false,
137
+ hasResolvedCanUserDeleteNavigationMenu: false,
138
+ hasResolvedCanUserUpdateNavigationMenu: false,
139
+ hasResolvedNavigationMenus: true,
140
+ isNavigationMenuMissing: false,
141
+ isNavigationMenuResolved: false,
142
+ isResolvingCanUserCreateNavigationMenu: false,
143
+ isResolvingNavigationMenus: false,
144
+ } );
145
+ } );
146
+
147
+ it( 'Should return null for the menu when menu status is "draft"', () => {
148
+ const navigationMenuDraft = { id: 4, title: 'Menu 3', status: 'draft' };
149
+ const testMenus = [ ...navigationMenus, navigationMenuDraft ];
150
+ resolveRecords( registry, testMenus );
151
+ expect( useNavigationMenu( 4 ) ).toEqual( {
152
+ navigationMenu: null,
153
+ navigationMenus: testMenus,
154
+ canSwitchNavigationMenu: true,
155
+ canUserCreateNavigationMenu: false,
156
+ canUserDeleteNavigationMenu: false,
157
+ canUserUpdateNavigationMenu: false,
158
+ hasResolvedCanUserCreateNavigationMenu: false,
159
+ hasResolvedCanUserDeleteNavigationMenu: false,
160
+ hasResolvedCanUserUpdateNavigationMenu: false,
161
+ hasResolvedNavigationMenus: true,
162
+ isNavigationMenuMissing: false,
163
+ isNavigationMenuResolved: false,
164
+ isResolvingCanUserCreateNavigationMenu: false,
165
+ isResolvingNavigationMenus: false,
166
+ } );
167
+ } );
168
+
169
+ it( 'Should return correct permissions (create, update)', () => {
170
+ resolveRecords( registry, navigationMenus );
171
+ resolveCreatePermission( registry, true );
172
+ resolveUpdatePermission( registry, 1, true );
173
+ expect( useNavigationMenu( 1 ) ).toEqual( {
174
+ navigationMenu: navigationMenu1,
175
+ navigationMenus,
176
+ canSwitchNavigationMenu: true,
177
+ canUserCreateNavigationMenu: true,
178
+ canUserDeleteNavigationMenu: false,
179
+ canUserUpdateNavigationMenu: true,
180
+ hasResolvedCanUserCreateNavigationMenu: true,
181
+ hasResolvedCanUserDeleteNavigationMenu: false,
182
+ hasResolvedCanUserUpdateNavigationMenu: true,
183
+ hasResolvedNavigationMenus: true,
184
+ isNavigationMenuMissing: false,
185
+ isNavigationMenuResolved: false,
186
+ isResolvingCanUserCreateNavigationMenu: false,
187
+ isResolvingNavigationMenus: false,
188
+ } );
189
+ } );
190
+
191
+ it( 'Should return correct permissions (delete only)', () => {
192
+ resolveRecords( registry, navigationMenus );
193
+ resolveDeletePermission( registry, 1, true );
194
+ expect( useNavigationMenu( 1 ) ).toEqual( {
195
+ navigationMenu: navigationMenu1,
196
+ navigationMenus,
197
+ canSwitchNavigationMenu: true,
198
+ canUserCreateNavigationMenu: false,
199
+ canUserDeleteNavigationMenu: true,
200
+ canUserUpdateNavigationMenu: false,
201
+ hasResolvedCanUserCreateNavigationMenu: false,
202
+ hasResolvedCanUserDeleteNavigationMenu: true,
203
+ hasResolvedCanUserUpdateNavigationMenu: false,
204
+ hasResolvedNavigationMenus: true,
205
+ isNavigationMenuMissing: false,
206
+ isNavigationMenuResolved: false,
207
+ isResolvingCanUserCreateNavigationMenu: false,
208
+ isResolvingNavigationMenus: false,
209
+ } );
210
+ } );
211
+
212
+ it( 'Should return correct permissions (no permissions)', () => {
213
+ const requestedMenu = navigationMenu1;
214
+ // Note the "delete" permission is resolved for menu 2, but we're requesting
215
+ // the details of menu 1.
216
+ resolveDeletePermission( registry, navigationMenu2, true );
217
+ resolveRecords( registry, navigationMenus );
218
+
219
+ expect( useNavigationMenu( requestedMenu.id ) ).toEqual( {
220
+ navigationMenu: requestedMenu,
221
+ navigationMenus,
222
+ canSwitchNavigationMenu: true,
223
+ canUserCreateNavigationMenu: false,
224
+ canUserDeleteNavigationMenu: false,
225
+ canUserUpdateNavigationMenu: false,
226
+ hasResolvedCanUserCreateNavigationMenu: false,
227
+ hasResolvedCanUserDeleteNavigationMenu: false,
228
+ hasResolvedCanUserUpdateNavigationMenu: false,
229
+ hasResolvedNavigationMenus: true,
230
+ isNavigationMenuMissing: false,
231
+ isNavigationMenuResolved: false,
232
+ isResolvingCanUserCreateNavigationMenu: false,
233
+ isResolvingNavigationMenus: false,
234
+ } );
235
+ } );
236
+ } );
@@ -43,19 +43,17 @@ export default function useNavigationEntities( menuId ) {
43
43
  context: 'view',
44
44
  } );
45
45
 
46
- const {
47
- records: menuItems,
48
- hasResolved: hasResolvedMenuItems,
49
- } = useEntityRecords(
50
- 'root',
51
- 'menuItem',
52
- {
53
- menus: menuId,
54
- per_page: -1,
55
- context: 'view',
56
- },
57
- { enabled: !! menuId }
58
- );
46
+ const { records: menuItems, hasResolved: hasResolvedMenuItems } =
47
+ useEntityRecords(
48
+ 'root',
49
+ 'menuItem',
50
+ {
51
+ menus: menuId,
52
+ per_page: -1,
53
+ context: 'view',
54
+ },
55
+ { enabled: !! menuId }
56
+ );
59
57
 
60
58
  return {
61
59
  pages,
@@ -8,93 +8,163 @@ export default function useNavigationMenu( ref ) {
8
8
  return useSelect(
9
9
  ( select ) => {
10
10
  const {
11
- getEntityRecord,
12
- getEditedEntityRecord,
13
- getEntityRecords,
14
- hasFinishedResolution,
15
- isResolving,
16
- canUser,
17
- } = select( coreStore );
18
-
19
- const navigationMenuSingleArgs = [
20
- 'postType',
21
- 'wp_navigation',
22
- ref,
23
- ];
24
- const rawNavigationMenu = ref
25
- ? getEntityRecord( ...navigationMenuSingleArgs )
26
- : null;
27
- let navigationMenu = ref
28
- ? getEditedEntityRecord( ...navigationMenuSingleArgs )
29
- : null;
30
-
31
- // getEditedEntityRecord will return the post regardless of status.
32
- // Therefore if the found post is not published then we should ignore it.
33
- if ( navigationMenu?.status !== 'publish' ) {
34
- navigationMenu = null;
35
- }
36
-
37
- const hasResolvedNavigationMenu = ref
38
- ? hasFinishedResolution(
39
- 'getEditedEntityRecord',
40
- navigationMenuSingleArgs
41
- )
42
- : false;
43
-
44
- const navigationMenuMultipleArgs = [
45
- 'postType',
46
- 'wp_navigation',
47
- { per_page: -1, status: 'publish' },
48
- ];
49
- const navigationMenus = getEntityRecords(
50
- ...navigationMenuMultipleArgs
51
- );
52
-
53
- const canSwitchNavigationMenu = ref
54
- ? navigationMenus?.length > 1
55
- : navigationMenus?.length > 0;
11
+ navigationMenus,
12
+ isResolvingNavigationMenus,
13
+ hasResolvedNavigationMenus,
14
+ } = selectNavigationMenus( select, ref );
56
15
 
57
- return {
58
- isNavigationMenuResolved: hasResolvedNavigationMenu,
59
- isNavigationMenuMissing:
60
- ! ref ||
61
- ( hasResolvedNavigationMenu && ! rawNavigationMenu ),
62
- canSwitchNavigationMenu,
63
- isResolvingNavigationMenus: isResolving(
64
- 'getEntityRecords',
65
- navigationMenuMultipleArgs
66
- ),
67
- hasResolvedNavigationMenus: hasFinishedResolution(
68
- 'getEntityRecords',
69
- navigationMenuMultipleArgs
70
- ),
16
+ const {
71
17
  navigationMenu,
18
+ isNavigationMenuResolved,
19
+ isNavigationMenuMissing,
20
+ } = selectExistingMenu( select, ref );
21
+
22
+ const {
23
+ canUserCreateNavigationMenu,
24
+ isResolvingCanUserCreateNavigationMenu,
25
+ hasResolvedCanUserCreateNavigationMenu,
26
+ } = selectMenuCreatePermissions( select );
27
+
28
+ const {
29
+ canUserUpdateNavigationMenu,
30
+ hasResolvedCanUserUpdateNavigationMenu,
31
+ } = selectMenuUpdatePermissions( select, ref );
32
+
33
+ const {
34
+ canUserDeleteNavigationMenu,
35
+ hasResolvedCanUserDeleteNavigationMenu,
36
+ } = selectMenuDeletePermissions( select, ref );
37
+
38
+ return {
72
39
  navigationMenus,
73
- canUserUpdateNavigationMenu: ref
74
- ? canUser( 'update', 'navigation', ref )
75
- : undefined,
76
- hasResolvedCanUserUpdateNavigationMenu: hasFinishedResolution(
77
- 'canUser',
78
- [ 'update', 'navigation', ref ]
79
- ),
80
- canUserDeleteNavigationMenu: ref
81
- ? canUser( 'delete', 'navigation', ref )
82
- : undefined,
83
- hasResolvedCanUserDeleteNavigationMenu: hasFinishedResolution(
84
- 'canUser',
85
- [ 'delete', 'navigation', ref ]
86
- ),
87
- canUserCreateNavigationMenu: canUser( 'create', 'navigation' ),
88
- isResolvingCanUserCreateNavigationMenu: isResolving(
89
- 'canUser',
90
- [ 'create', 'navigation' ]
91
- ),
92
- hasResolvedCanUserCreateNavigationMenu: hasFinishedResolution(
93
- 'canUser',
94
- [ 'create', 'navigation' ]
95
- ),
40
+ isResolvingNavigationMenus,
41
+ hasResolvedNavigationMenus,
42
+
43
+ navigationMenu,
44
+ isNavigationMenuResolved,
45
+ isNavigationMenuMissing,
46
+
47
+ canUserCreateNavigationMenu,
48
+ isResolvingCanUserCreateNavigationMenu,
49
+ hasResolvedCanUserCreateNavigationMenu,
50
+
51
+ canUserUpdateNavigationMenu,
52
+ hasResolvedCanUserUpdateNavigationMenu,
53
+
54
+ canUserDeleteNavigationMenu,
55
+ hasResolvedCanUserDeleteNavigationMenu,
56
+
57
+ canSwitchNavigationMenu: ref
58
+ ? navigationMenus?.length > 1
59
+ : navigationMenus?.length > 0,
96
60
  };
97
61
  },
98
62
  [ ref ]
99
63
  );
100
64
  }
65
+
66
+ function selectNavigationMenus( select ) {
67
+ const { getEntityRecords, hasFinishedResolution, isResolving } =
68
+ select( coreStore );
69
+
70
+ const args = [
71
+ 'postType',
72
+ 'wp_navigation',
73
+ { per_page: -1, status: 'publish' },
74
+ ];
75
+ return {
76
+ navigationMenus: getEntityRecords( ...args ),
77
+ isResolvingNavigationMenus: isResolving( 'getEntityRecords', args ),
78
+ hasResolvedNavigationMenus: hasFinishedResolution(
79
+ 'getEntityRecords',
80
+ args
81
+ ),
82
+ };
83
+ }
84
+
85
+ function selectExistingMenu( select, ref ) {
86
+ if ( ! ref ) {
87
+ return {
88
+ isNavigationMenuResolved: false,
89
+ isNavigationMenuMissing: true,
90
+ };
91
+ }
92
+
93
+ const { getEntityRecord, getEditedEntityRecord, hasFinishedResolution } =
94
+ select( coreStore );
95
+
96
+ const args = [ 'postType', 'wp_navigation', ref ];
97
+ const navigationMenu = getEntityRecord( ...args );
98
+ const editedNavigationMenu = getEditedEntityRecord( ...args );
99
+ const hasResolvedNavigationMenu = hasFinishedResolution(
100
+ 'getEditedEntityRecord',
101
+ args
102
+ );
103
+
104
+ return {
105
+ isNavigationMenuResolved: hasResolvedNavigationMenu,
106
+ isNavigationMenuMissing: hasResolvedNavigationMenu && ! navigationMenu,
107
+
108
+ // getEditedEntityRecord will return the post regardless of status.
109
+ // Therefore if the found post is not published then we should ignore it.
110
+ navigationMenu:
111
+ editedNavigationMenu.status === 'publish'
112
+ ? editedNavigationMenu
113
+ : null,
114
+ };
115
+ }
116
+
117
+ function selectMenuCreatePermissions( select ) {
118
+ const { hasFinishedResolution, isResolving, canUser } = select( coreStore );
119
+
120
+ const args = [ 'create', 'navigation' ];
121
+ return {
122
+ canUserCreateNavigationMenu: !! canUser( ...args ),
123
+ isResolvingCanUserCreateNavigationMenu: !! isResolving(
124
+ 'canUser',
125
+ args
126
+ ),
127
+ hasResolvedCanUserCreateNavigationMenu: !! hasFinishedResolution(
128
+ 'canUser',
129
+ args
130
+ ),
131
+ };
132
+ }
133
+
134
+ function selectMenuUpdatePermissions( select, ref ) {
135
+ if ( ! ref ) {
136
+ return {
137
+ canUserUpdateNavigationMenu: false,
138
+ hasResolvedCanUserUpdateNavigationMenu: false,
139
+ };
140
+ }
141
+
142
+ const { hasFinishedResolution, canUser } = select( coreStore );
143
+ const args = [ 'update', 'navigation', ref ];
144
+ return {
145
+ canUserUpdateNavigationMenu: !! canUser( ...args ),
146
+ hasResolvedCanUserUpdateNavigationMenu: !! hasFinishedResolution(
147
+ 'canUser',
148
+ args
149
+ ),
150
+ };
151
+ }
152
+
153
+ function selectMenuDeletePermissions( select, ref ) {
154
+ if ( ! ref ) {
155
+ return {
156
+ canUserDeleteNavigationMenu: false,
157
+ hasResolvedCanUserDeleteNavigationMenu: false,
158
+ };
159
+ }
160
+
161
+ const { hasFinishedResolution, canUser } = select( coreStore );
162
+ const args = [ 'delete', 'navigation', ref ];
163
+ return {
164
+ canUserDeleteNavigationMenu: !! canUser( ...args ),
165
+ hasResolvedCanUserDeleteNavigationMenu: !! hasFinishedResolution(
166
+ 'canUser',
167
+ args
168
+ ),
169
+ };
170
+ }
@@ -21,9 +21,8 @@ export default function useTemplatePartAreaLabel( clientId ) {
21
21
  return;
22
22
  }
23
23
 
24
- const { getBlock, getBlockParentsByBlockName } = select(
25
- blockEditorStore
26
- );
24
+ const { getBlock, getBlockParentsByBlockName } =
25
+ select( blockEditorStore );
27
26
 
28
27
  const withAscendingResults = true;
29
28
  const parentTemplatePartClientIds = getBlockParentsByBlockName(
@@ -40,10 +39,12 @@ export default function useTemplatePartAreaLabel( clientId ) {
40
39
  // Blocks can be loaded into a *non-post* block editor.
41
40
  // This code is lifted from this file:
42
41
  // packages/block-library/src/template-part/edit/advanced-controls.js
43
- // eslint-disable-next-line @wordpress/data-no-store-string-literals
44
- const definedAreas = select(
45
- 'core/editor'
46
- ).__experimentalGetDefaultTemplatePartAreas();
42
+ /* eslint-disable @wordpress/data-no-store-string-literals */
43
+ const definedAreas =
44
+ select(
45
+ 'core/editor'
46
+ ).__experimentalGetDefaultTemplatePartAreas();
47
+ /* eslint-enable @wordpress/data-no-store-string-literals */
47
48
  const { getEditedEntityRecord } = select( coreStore );
48
49
 
49
50
  for ( const templatePartClientId of parentTemplatePartClientIds ) {