@wordpress/block-library 8.3.6 → 8.5.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 (738) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/build/archives/edit.js +3 -0
  3. package/build/archives/edit.js.map +1 -1
  4. package/build/archives/index.js +1 -0
  5. package/build/archives/index.js.map +1 -1
  6. package/build/audio/edit.js +2 -0
  7. package/build/audio/edit.js.map +1 -1
  8. package/build/avatar/edit.js +5 -9
  9. package/build/avatar/edit.js.map +1 -1
  10. package/build/avatar/index.js +1 -0
  11. package/build/avatar/index.js.map +1 -1
  12. package/build/button/edit.js +3 -1
  13. package/build/button/edit.js.map +1 -1
  14. package/build/button/index.js +17 -6
  15. package/build/button/index.js.map +1 -1
  16. package/build/calendar/index.js +1 -0
  17. package/build/calendar/index.js.map +1 -1
  18. package/build/categories/edit.js +5 -0
  19. package/build/categories/edit.js.map +1 -1
  20. package/build/categories/index.js +1 -0
  21. package/build/categories/index.js.map +1 -1
  22. package/build/columns/edit.js +1 -0
  23. package/build/columns/edit.js.map +1 -1
  24. package/build/columns/utils.js +2 -2
  25. package/build/columns/utils.js.map +1 -1
  26. package/build/comment-author-avatar/index.js +1 -0
  27. package/build/comment-author-avatar/index.js.map +1 -1
  28. package/build/comment-author-name/edit.js +2 -0
  29. package/build/comment-author-name/edit.js.map +1 -1
  30. package/build/comment-author-name/index.js +1 -0
  31. package/build/comment-author-name/index.js.map +1 -1
  32. package/build/comment-content/index.js +1 -0
  33. package/build/comment-content/index.js.map +1 -1
  34. package/build/comment-date/edit.js +1 -0
  35. package/build/comment-date/edit.js.map +1 -1
  36. package/build/comment-date/index.js +1 -0
  37. package/build/comment-date/index.js.map +1 -1
  38. package/build/comment-edit-link/edit.js +1 -0
  39. package/build/comment-edit-link/edit.js.map +1 -1
  40. package/build/comment-edit-link/index.js +1 -0
  41. package/build/comment-edit-link/index.js.map +1 -1
  42. package/build/comment-reply-link/index.js +1 -0
  43. package/build/comment-reply-link/index.js.map +1 -1
  44. package/build/comment-template/index.js +1 -0
  45. package/build/comment-template/index.js.map +1 -1
  46. package/build/comments/index.js +2 -1
  47. package/build/comments/index.js.map +1 -1
  48. package/build/comments-pagination/index.js +1 -0
  49. package/build/comments-pagination/index.js.map +1 -1
  50. package/build/comments-pagination-next/index.js +1 -0
  51. package/build/comments-pagination-next/index.js.map +1 -1
  52. package/build/comments-pagination-numbers/index.js +1 -0
  53. package/build/comments-pagination-numbers/index.js.map +1 -1
  54. package/build/comments-pagination-previous/index.js +1 -0
  55. package/build/comments-pagination-previous/index.js.map +1 -1
  56. package/build/comments-title/edit.js +2 -0
  57. package/build/comments-title/edit.js.map +1 -1
  58. package/build/cover/edit/inspector-controls.js +2 -0
  59. package/build/cover/edit/inspector-controls.js.map +1 -1
  60. package/build/embed/embed-controls.js +1 -0
  61. package/build/embed/embed-controls.js.map +1 -1
  62. package/build/file/index.js +10 -1
  63. package/build/file/index.js.map +1 -1
  64. package/build/file/inspector.js +3 -0
  65. package/build/file/inspector.js.map +1 -1
  66. package/build/freeform/modal.js +1 -1
  67. package/build/freeform/modal.js.map +1 -1
  68. package/build/gallery/edit.js +2 -0
  69. package/build/gallery/edit.js.map +1 -1
  70. package/build/gallery/shared.js +4 -8
  71. package/build/gallery/shared.js.map +1 -1
  72. package/build/gallery/use-image-sizes.js +4 -8
  73. package/build/gallery/use-image-sizes.js.map +1 -1
  74. package/build/gallery/v1/edit.js +8 -3
  75. package/build/gallery/v1/edit.js.map +1 -1
  76. package/build/gallery/v1/gallery-image.js +1 -3
  77. package/build/gallery/v1/gallery-image.js.map +1 -1
  78. package/build/gallery/v1/shared.js +4 -7
  79. package/build/gallery/v1/shared.js.map +1 -1
  80. package/build/home-link/index.js +1 -0
  81. package/build/home-link/index.js.map +1 -1
  82. package/build/image/edit.js +6 -4
  83. package/build/image/edit.js.map +1 -1
  84. package/build/image/image.js +18 -13
  85. package/build/image/image.js.map +1 -1
  86. package/build/image/utils.js +3 -1
  87. package/build/image/utils.js.map +1 -1
  88. package/build/index.js +3 -1
  89. package/build/index.js.map +1 -1
  90. package/build/latest-comments/edit.js +9 -2
  91. package/build/latest-comments/edit.js.map +1 -1
  92. package/build/latest-comments/index.js +14 -0
  93. package/build/latest-comments/index.js.map +1 -1
  94. package/build/latest-posts/deprecated.js +1 -0
  95. package/build/latest-posts/deprecated.js.map +1 -1
  96. package/build/latest-posts/edit.js +4 -0
  97. package/build/latest-posts/edit.js.map +1 -1
  98. package/build/latest-posts/index.js +1 -0
  99. package/build/latest-posts/index.js.map +1 -1
  100. package/build/list/ordered-list-settings.js +1 -0
  101. package/build/list/ordered-list-settings.js.map +1 -1
  102. package/build/list-item/edit.js +2 -2
  103. package/build/list-item/edit.js.map +1 -1
  104. package/build/list-item/hooks/use-outdent-list-item.js +2 -1
  105. package/build/list-item/hooks/use-outdent-list-item.js.map +1 -1
  106. package/build/loginout/edit.js +2 -0
  107. package/build/loginout/edit.js.map +1 -1
  108. package/build/loginout/index.js +1 -0
  109. package/build/loginout/index.js.map +1 -1
  110. package/build/media-text/edit.js +2 -0
  111. package/build/media-text/edit.js.map +1 -1
  112. package/build/more/edit.js +1 -0
  113. package/build/more/edit.js.map +1 -1
  114. package/build/navigation/edit/index.js +80 -54
  115. package/build/navigation/edit/index.js.map +1 -1
  116. package/build/navigation/edit/navigation-menu-selector.js +14 -11
  117. package/build/navigation/edit/navigation-menu-selector.js.map +1 -1
  118. package/build/navigation/edit/overlay-menu-preview.js +1 -0
  119. package/build/navigation/edit/overlay-menu-preview.js.map +1 -1
  120. package/build/navigation/edit/placeholder/index.js +1 -1
  121. package/build/navigation/edit/placeholder/index.js.map +1 -1
  122. package/build/navigation/edit/unsaved-inner-blocks.js +1 -1
  123. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  124. package/build/navigation/edit/use-convert-classic-menu-to-block-menu.js +1 -1
  125. package/build/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  126. package/build/navigation/edit/use-create-navigation-menu.js +1 -1
  127. package/build/navigation/edit/use-create-navigation-menu.js.map +1 -1
  128. package/build/navigation/edit/use-generate-default-navigation-title.js +1 -1
  129. package/build/navigation/edit/use-generate-default-navigation-title.js.map +1 -1
  130. package/build/navigation/edit/use-navigation-notice.js +4 -7
  131. package/build/navigation/edit/use-navigation-notice.js.map +1 -1
  132. package/build/navigation/index.js +1 -0
  133. package/build/navigation/index.js.map +1 -1
  134. package/build/navigation/use-navigation-menu.js +1 -1
  135. package/build/navigation/use-navigation-menu.js.map +1 -1
  136. package/build/navigation-link/edit.js +10 -5
  137. package/build/navigation-link/edit.js.map +1 -1
  138. package/build/navigation-link/link-ui.js +2 -0
  139. package/build/navigation-link/link-ui.js.map +1 -1
  140. package/build/page-list/convert-to-links-modal.js +47 -0
  141. package/build/page-list/convert-to-links-modal.js.map +1 -0
  142. package/build/page-list/edit.js +15 -28
  143. package/build/page-list/edit.js.map +1 -1
  144. package/build/page-list/index.js +1 -0
  145. package/build/page-list/index.js.map +1 -1
  146. package/build/page-list/use-convert-to-navigation-links.js +61 -5
  147. package/build/page-list/use-convert-to-navigation-links.js.map +1 -1
  148. package/build/paragraph/edit.js +1 -0
  149. package/build/paragraph/edit.js.map +1 -1
  150. package/build/post-author/edit.js +4 -0
  151. package/build/post-author/edit.js.map +1 -1
  152. package/build/post-author/index.js +1 -0
  153. package/build/post-author/index.js.map +1 -1
  154. package/build/post-author-biography/index.js +1 -0
  155. package/build/post-author-biography/index.js.map +1 -1
  156. package/build/post-author-name/edit.js +2 -0
  157. package/build/post-author-name/edit.js.map +1 -1
  158. package/build/post-author-name/index.js +1 -0
  159. package/build/post-author-name/index.js.map +1 -1
  160. package/build/post-comments-count/index.js +1 -0
  161. package/build/post-comments-count/index.js.map +1 -1
  162. package/build/post-comments-form/index.js +1 -0
  163. package/build/post-comments-form/index.js.map +1 -1
  164. package/build/post-comments-link/index.js +1 -0
  165. package/build/post-comments-link/index.js.map +1 -1
  166. package/build/post-content/index.js +1 -0
  167. package/build/post-content/index.js.map +1 -1
  168. package/build/post-date/edit.js +2 -0
  169. package/build/post-date/edit.js.map +1 -1
  170. package/build/post-date/index.js +1 -0
  171. package/build/post-date/index.js.map +1 -1
  172. package/build/post-excerpt/edit.js +50 -3
  173. package/build/post-excerpt/edit.js.map +1 -1
  174. package/build/post-excerpt/index.js +5 -0
  175. package/build/post-excerpt/index.js.map +1 -1
  176. package/build/post-featured-image/dimension-controls.js +52 -1
  177. package/build/post-featured-image/dimension-controls.js.map +1 -1
  178. package/build/post-featured-image/edit.js +11 -4
  179. package/build/post-featured-image/edit.js.map +1 -1
  180. package/build/post-featured-image/index.js +4 -0
  181. package/build/post-featured-image/index.js.map +1 -1
  182. package/build/post-navigation-link/edit.js +2 -0
  183. package/build/post-navigation-link/edit.js.map +1 -1
  184. package/build/post-navigation-link/index.js +1 -0
  185. package/build/post-navigation-link/index.js.map +1 -1
  186. package/build/post-template/index.js +1 -0
  187. package/build/post-template/index.js.map +1 -1
  188. package/build/post-terms/index.js +1 -0
  189. package/build/post-terms/index.js.map +1 -1
  190. package/build/post-terms/use-post-terms.js +1 -1
  191. package/build/post-terms/use-post-terms.js.map +1 -1
  192. package/build/post-time-to-read/edit.js +104 -0
  193. package/build/post-time-to-read/edit.js.map +1 -0
  194. package/build/post-time-to-read/icon.js +25 -0
  195. package/build/post-time-to-read/icon.js.map +1 -0
  196. package/build/post-time-to-read/index.js +57 -0
  197. package/build/post-time-to-read/index.js.map +1 -0
  198. package/build/post-title/edit.js +2 -0
  199. package/build/post-title/edit.js.map +1 -1
  200. package/build/post-title/index.js +1 -0
  201. package/build/post-title/index.js.map +1 -1
  202. package/build/query/edit/inspector-controls/index.js +1 -0
  203. package/build/query/edit/inspector-controls/index.js.map +1 -1
  204. package/build/query/index.js +1 -0
  205. package/build/query/index.js.map +1 -1
  206. package/build/query/utils.js +1 -0
  207. package/build/query/utils.js.map +1 -1
  208. package/build/query-no-results/index.js +1 -0
  209. package/build/query-no-results/index.js.map +1 -1
  210. package/build/query-pagination/index.js +1 -0
  211. package/build/query-pagination/index.js.map +1 -1
  212. package/build/query-pagination-next/index.js +1 -0
  213. package/build/query-pagination-next/index.js.map +1 -1
  214. package/build/query-pagination-numbers/index.js +1 -0
  215. package/build/query-pagination-numbers/index.js.map +1 -1
  216. package/build/query-pagination-previous/index.js +1 -0
  217. package/build/query-pagination-previous/index.js.map +1 -1
  218. package/build/query-title/edit.js +2 -0
  219. package/build/query-title/edit.js.map +1 -1
  220. package/build/query-title/index.js +1 -0
  221. package/build/query-title/index.js.map +1 -1
  222. package/build/read-more/edit.js +1 -0
  223. package/build/read-more/edit.js.map +1 -1
  224. package/build/read-more/index.js +1 -0
  225. package/build/read-more/index.js.map +1 -1
  226. package/build/rss/edit.js +3 -0
  227. package/build/rss/edit.js.map +1 -1
  228. package/build/rss/index.js +1 -0
  229. package/build/rss/index.js.map +1 -1
  230. package/build/search/index.js +1 -0
  231. package/build/search/index.js.map +1 -1
  232. package/build/site-logo/edit.js +10 -11
  233. package/build/site-logo/edit.js.map +1 -1
  234. package/build/site-logo/index.js +1 -0
  235. package/build/site-logo/index.js.map +1 -1
  236. package/build/site-tagline/index.js +1 -0
  237. package/build/site-tagline/index.js.map +1 -1
  238. package/build/site-title/edit/index.js +2 -0
  239. package/build/site-title/edit/index.js.map +1 -1
  240. package/build/site-title/index.js +1 -0
  241. package/build/site-title/index.js.map +1 -1
  242. package/build/social-link/index.js +1 -0
  243. package/build/social-link/index.js.map +1 -1
  244. package/build/social-links/edit.js +2 -0
  245. package/build/social-links/edit.js.map +1 -1
  246. package/build/spacer/controls.native.js +10 -8
  247. package/build/spacer/controls.native.js.map +1 -1
  248. package/build/spacer/edit.native.js +43 -5
  249. package/build/spacer/edit.native.js.map +1 -1
  250. package/build/spacer/save.native.js +30 -0
  251. package/build/spacer/save.native.js.map +1 -0
  252. package/build/table/edit.js +6 -3
  253. package/build/table/edit.js.map +1 -1
  254. package/build/table-of-contents/edit.js +1 -0
  255. package/build/table-of-contents/edit.js.map +1 -1
  256. package/build/table-of-contents/utils.js +1 -1
  257. package/build/table-of-contents/utils.js.map +1 -1
  258. package/build/tag-cloud/edit.js +1 -0
  259. package/build/tag-cloud/edit.js.map +1 -1
  260. package/build/tag-cloud/index.js +1 -0
  261. package/build/tag-cloud/index.js.map +1 -1
  262. package/build/template-part/index.js +1 -0
  263. package/build/template-part/index.js.map +1 -1
  264. package/build/term-description/index.js +1 -0
  265. package/build/term-description/index.js.map +1 -1
  266. package/build/verse/index.js +6 -0
  267. package/build/verse/index.js.map +1 -1
  268. package/build/video/edit-common-settings.js +5 -0
  269. package/build/video/edit-common-settings.js.map +1 -1
  270. package/build-module/archives/edit.js +3 -0
  271. package/build-module/archives/edit.js.map +1 -1
  272. package/build-module/archives/index.js +1 -0
  273. package/build-module/archives/index.js.map +1 -1
  274. package/build-module/audio/edit.js +2 -0
  275. package/build-module/audio/edit.js.map +1 -1
  276. package/build-module/avatar/edit.js +5 -8
  277. package/build-module/avatar/edit.js.map +1 -1
  278. package/build-module/avatar/index.js +1 -0
  279. package/build-module/avatar/index.js.map +1 -1
  280. package/build-module/button/edit.js +2 -1
  281. package/build-module/button/edit.js.map +1 -1
  282. package/build-module/button/index.js +17 -6
  283. package/build-module/button/index.js.map +1 -1
  284. package/build-module/calendar/index.js +1 -0
  285. package/build-module/calendar/index.js.map +1 -1
  286. package/build-module/categories/edit.js +5 -0
  287. package/build-module/categories/edit.js.map +1 -1
  288. package/build-module/categories/index.js +1 -0
  289. package/build-module/categories/index.js.map +1 -1
  290. package/build-module/columns/edit.js +1 -0
  291. package/build-module/columns/edit.js.map +1 -1
  292. package/build-module/columns/utils.js +3 -3
  293. package/build-module/columns/utils.js.map +1 -1
  294. package/build-module/comment-author-avatar/index.js +1 -0
  295. package/build-module/comment-author-avatar/index.js.map +1 -1
  296. package/build-module/comment-author-name/edit.js +2 -0
  297. package/build-module/comment-author-name/edit.js.map +1 -1
  298. package/build-module/comment-author-name/index.js +1 -0
  299. package/build-module/comment-author-name/index.js.map +1 -1
  300. package/build-module/comment-content/index.js +1 -0
  301. package/build-module/comment-content/index.js.map +1 -1
  302. package/build-module/comment-date/edit.js +1 -0
  303. package/build-module/comment-date/edit.js.map +1 -1
  304. package/build-module/comment-date/index.js +1 -0
  305. package/build-module/comment-date/index.js.map +1 -1
  306. package/build-module/comment-edit-link/edit.js +1 -0
  307. package/build-module/comment-edit-link/edit.js.map +1 -1
  308. package/build-module/comment-edit-link/index.js +1 -0
  309. package/build-module/comment-edit-link/index.js.map +1 -1
  310. package/build-module/comment-reply-link/index.js +1 -0
  311. package/build-module/comment-reply-link/index.js.map +1 -1
  312. package/build-module/comment-template/index.js +1 -0
  313. package/build-module/comment-template/index.js.map +1 -1
  314. package/build-module/comments/index.js +2 -1
  315. package/build-module/comments/index.js.map +1 -1
  316. package/build-module/comments-pagination/index.js +1 -0
  317. package/build-module/comments-pagination/index.js.map +1 -1
  318. package/build-module/comments-pagination-next/index.js +1 -0
  319. package/build-module/comments-pagination-next/index.js.map +1 -1
  320. package/build-module/comments-pagination-numbers/index.js +1 -0
  321. package/build-module/comments-pagination-numbers/index.js.map +1 -1
  322. package/build-module/comments-pagination-previous/index.js +1 -0
  323. package/build-module/comments-pagination-previous/index.js.map +1 -1
  324. package/build-module/comments-title/edit.js +2 -0
  325. package/build-module/comments-title/edit.js.map +1 -1
  326. package/build-module/cover/edit/inspector-controls.js +2 -0
  327. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  328. package/build-module/embed/embed-controls.js +1 -0
  329. package/build-module/embed/embed-controls.js.map +1 -1
  330. package/build-module/file/index.js +10 -1
  331. package/build-module/file/index.js.map +1 -1
  332. package/build-module/file/inspector.js +3 -0
  333. package/build-module/file/inspector.js.map +1 -1
  334. package/build-module/freeform/modal.js +1 -1
  335. package/build-module/freeform/modal.js.map +1 -1
  336. package/build-module/gallery/edit.js +2 -0
  337. package/build-module/gallery/edit.js.map +1 -1
  338. package/build-module/gallery/shared.js +4 -7
  339. package/build-module/gallery/shared.js.map +1 -1
  340. package/build-module/gallery/use-image-sizes.js +4 -7
  341. package/build-module/gallery/use-image-sizes.js.map +1 -1
  342. package/build-module/gallery/v1/edit.js +9 -4
  343. package/build-module/gallery/v1/edit.js.map +1 -1
  344. package/build-module/gallery/v1/gallery-image.js +1 -2
  345. package/build-module/gallery/v1/gallery-image.js.map +1 -1
  346. package/build-module/gallery/v1/shared.js +4 -6
  347. package/build-module/gallery/v1/shared.js.map +1 -1
  348. package/build-module/home-link/index.js +1 -0
  349. package/build-module/home-link/index.js.map +1 -1
  350. package/build-module/image/edit.js +7 -5
  351. package/build-module/image/edit.js.map +1 -1
  352. package/build-module/image/image.js +19 -14
  353. package/build-module/image/image.js.map +1 -1
  354. package/build-module/image/utils.js +4 -2
  355. package/build-module/image/utils.js.map +1 -1
  356. package/build-module/index.js +2 -1
  357. package/build-module/index.js.map +1 -1
  358. package/build-module/latest-comments/edit.js +9 -2
  359. package/build-module/latest-comments/edit.js.map +1 -1
  360. package/build-module/latest-comments/index.js +14 -0
  361. package/build-module/latest-comments/index.js.map +1 -1
  362. package/build-module/latest-posts/deprecated.js +1 -0
  363. package/build-module/latest-posts/deprecated.js.map +1 -1
  364. package/build-module/latest-posts/edit.js +4 -0
  365. package/build-module/latest-posts/edit.js.map +1 -1
  366. package/build-module/latest-posts/index.js +1 -0
  367. package/build-module/latest-posts/index.js.map +1 -1
  368. package/build-module/list/ordered-list-settings.js +1 -0
  369. package/build-module/list/ordered-list-settings.js.map +1 -1
  370. package/build-module/list-item/edit.js +2 -2
  371. package/build-module/list-item/edit.js.map +1 -1
  372. package/build-module/list-item/hooks/use-outdent-list-item.js +2 -1
  373. package/build-module/list-item/hooks/use-outdent-list-item.js.map +1 -1
  374. package/build-module/loginout/edit.js +2 -0
  375. package/build-module/loginout/edit.js.map +1 -1
  376. package/build-module/loginout/index.js +1 -0
  377. package/build-module/loginout/index.js.map +1 -1
  378. package/build-module/media-text/edit.js +2 -0
  379. package/build-module/media-text/edit.js.map +1 -1
  380. package/build-module/more/edit.js +1 -0
  381. package/build-module/more/edit.js.map +1 -1
  382. package/build-module/navigation/edit/index.js +82 -56
  383. package/build-module/navigation/edit/index.js.map +1 -1
  384. package/build-module/navigation/edit/navigation-menu-selector.js +14 -10
  385. package/build-module/navigation/edit/navigation-menu-selector.js.map +1 -1
  386. package/build-module/navigation/edit/overlay-menu-preview.js +1 -0
  387. package/build-module/navigation/edit/overlay-menu-preview.js.map +1 -1
  388. package/build-module/navigation/edit/placeholder/index.js +1 -1
  389. package/build-module/navigation/edit/placeholder/index.js.map +1 -1
  390. package/build-module/navigation/edit/unsaved-inner-blocks.js +1 -1
  391. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  392. package/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js +1 -1
  393. package/build-module/navigation/edit/use-convert-classic-menu-to-block-menu.js.map +1 -1
  394. package/build-module/navigation/edit/use-create-navigation-menu.js +1 -1
  395. package/build-module/navigation/edit/use-create-navigation-menu.js.map +1 -1
  396. package/build-module/navigation/edit/use-generate-default-navigation-title.js +1 -1
  397. package/build-module/navigation/edit/use-generate-default-navigation-title.js.map +1 -1
  398. package/build-module/navigation/edit/use-navigation-notice.js +5 -8
  399. package/build-module/navigation/edit/use-navigation-notice.js.map +1 -1
  400. package/build-module/navigation/index.js +1 -0
  401. package/build-module/navigation/index.js.map +1 -1
  402. package/build-module/navigation/use-navigation-menu.js +1 -1
  403. package/build-module/navigation/use-navigation-menu.js.map +1 -1
  404. package/build-module/navigation-link/edit.js +10 -5
  405. package/build-module/navigation-link/edit.js.map +1 -1
  406. package/build-module/navigation-link/link-ui.js +2 -0
  407. package/build-module/navigation-link/link-ui.js.map +1 -1
  408. package/build-module/page-list/convert-to-links-modal.js +35 -0
  409. package/build-module/page-list/convert-to-links-modal.js.map +1 -0
  410. package/build-module/page-list/edit.js +15 -29
  411. package/build-module/page-list/edit.js.map +1 -1
  412. package/build-module/page-list/index.js +1 -0
  413. package/build-module/page-list/index.js.map +1 -1
  414. package/build-module/page-list/use-convert-to-navigation-links.js +61 -5
  415. package/build-module/page-list/use-convert-to-navigation-links.js.map +1 -1
  416. package/build-module/paragraph/edit.js +1 -0
  417. package/build-module/paragraph/edit.js.map +1 -1
  418. package/build-module/post-author/edit.js +4 -0
  419. package/build-module/post-author/edit.js.map +1 -1
  420. package/build-module/post-author/index.js +1 -0
  421. package/build-module/post-author/index.js.map +1 -1
  422. package/build-module/post-author-biography/index.js +1 -0
  423. package/build-module/post-author-biography/index.js.map +1 -1
  424. package/build-module/post-author-name/edit.js +2 -0
  425. package/build-module/post-author-name/edit.js.map +1 -1
  426. package/build-module/post-author-name/index.js +1 -0
  427. package/build-module/post-author-name/index.js.map +1 -1
  428. package/build-module/post-comments-count/index.js +1 -0
  429. package/build-module/post-comments-count/index.js.map +1 -1
  430. package/build-module/post-comments-form/index.js +1 -0
  431. package/build-module/post-comments-form/index.js.map +1 -1
  432. package/build-module/post-comments-link/index.js +1 -0
  433. package/build-module/post-comments-link/index.js.map +1 -1
  434. package/build-module/post-content/index.js +1 -0
  435. package/build-module/post-content/index.js.map +1 -1
  436. package/build-module/post-date/edit.js +2 -0
  437. package/build-module/post-date/edit.js.map +1 -1
  438. package/build-module/post-date/index.js +1 -0
  439. package/build-module/post-date/index.js.map +1 -1
  440. package/build-module/post-excerpt/edit.js +53 -5
  441. package/build-module/post-excerpt/edit.js.map +1 -1
  442. package/build-module/post-excerpt/index.js +5 -0
  443. package/build-module/post-excerpt/index.js.map +1 -1
  444. package/build-module/post-featured-image/dimension-controls.js +52 -1
  445. package/build-module/post-featured-image/dimension-controls.js.map +1 -1
  446. package/build-module/post-featured-image/edit.js +11 -4
  447. package/build-module/post-featured-image/edit.js.map +1 -1
  448. package/build-module/post-featured-image/index.js +4 -0
  449. package/build-module/post-featured-image/index.js.map +1 -1
  450. package/build-module/post-navigation-link/edit.js +2 -0
  451. package/build-module/post-navigation-link/edit.js.map +1 -1
  452. package/build-module/post-navigation-link/index.js +1 -0
  453. package/build-module/post-navigation-link/index.js.map +1 -1
  454. package/build-module/post-template/index.js +1 -0
  455. package/build-module/post-template/index.js.map +1 -1
  456. package/build-module/post-terms/index.js +1 -0
  457. package/build-module/post-terms/index.js.map +1 -1
  458. package/build-module/post-terms/use-post-terms.js +1 -1
  459. package/build-module/post-terms/use-post-terms.js.map +1 -1
  460. package/build-module/post-time-to-read/edit.js +90 -0
  461. package/build-module/post-time-to-read/edit.js.map +1 -0
  462. package/build-module/post-time-to-read/icon.js +15 -0
  463. package/build-module/post-time-to-read/icon.js.map +1 -0
  464. package/build-module/post-time-to-read/index.js +40 -0
  465. package/build-module/post-time-to-read/index.js.map +1 -0
  466. package/build-module/post-title/edit.js +2 -0
  467. package/build-module/post-title/edit.js.map +1 -1
  468. package/build-module/post-title/index.js +1 -0
  469. package/build-module/post-title/index.js.map +1 -1
  470. package/build-module/query/edit/inspector-controls/index.js +1 -0
  471. package/build-module/query/edit/inspector-controls/index.js.map +1 -1
  472. package/build-module/query/index.js +1 -0
  473. package/build-module/query/index.js.map +1 -1
  474. package/build-module/query/utils.js +1 -0
  475. package/build-module/query/utils.js.map +1 -1
  476. package/build-module/query-no-results/index.js +1 -0
  477. package/build-module/query-no-results/index.js.map +1 -1
  478. package/build-module/query-pagination/index.js +1 -0
  479. package/build-module/query-pagination/index.js.map +1 -1
  480. package/build-module/query-pagination-next/index.js +1 -0
  481. package/build-module/query-pagination-next/index.js.map +1 -1
  482. package/build-module/query-pagination-numbers/index.js +1 -0
  483. package/build-module/query-pagination-numbers/index.js.map +1 -1
  484. package/build-module/query-pagination-previous/index.js +1 -0
  485. package/build-module/query-pagination-previous/index.js.map +1 -1
  486. package/build-module/query-title/edit.js +2 -0
  487. package/build-module/query-title/edit.js.map +1 -1
  488. package/build-module/query-title/index.js +1 -0
  489. package/build-module/query-title/index.js.map +1 -1
  490. package/build-module/read-more/edit.js +1 -0
  491. package/build-module/read-more/edit.js.map +1 -1
  492. package/build-module/read-more/index.js +1 -0
  493. package/build-module/read-more/index.js.map +1 -1
  494. package/build-module/rss/edit.js +3 -0
  495. package/build-module/rss/edit.js.map +1 -1
  496. package/build-module/rss/index.js +1 -0
  497. package/build-module/rss/index.js.map +1 -1
  498. package/build-module/search/index.js +1 -0
  499. package/build-module/search/index.js.map +1 -1
  500. package/build-module/site-logo/edit.js +10 -11
  501. package/build-module/site-logo/edit.js.map +1 -1
  502. package/build-module/site-logo/index.js +1 -0
  503. package/build-module/site-logo/index.js.map +1 -1
  504. package/build-module/site-tagline/index.js +1 -0
  505. package/build-module/site-tagline/index.js.map +1 -1
  506. package/build-module/site-title/edit/index.js +2 -0
  507. package/build-module/site-title/edit/index.js.map +1 -1
  508. package/build-module/site-title/index.js +1 -0
  509. package/build-module/site-title/index.js.map +1 -1
  510. package/build-module/social-link/index.js +1 -0
  511. package/build-module/social-link/index.js.map +1 -1
  512. package/build-module/social-links/edit.js +2 -0
  513. package/build-module/social-links/edit.js.map +1 -1
  514. package/build-module/spacer/controls.native.js +9 -8
  515. package/build-module/spacer/controls.native.js.map +1 -1
  516. package/build-module/spacer/edit.native.js +39 -7
  517. package/build-module/spacer/edit.native.js.map +1 -1
  518. package/build-module/spacer/save.native.js +22 -0
  519. package/build-module/spacer/save.native.js.map +1 -0
  520. package/build-module/table/edit.js +6 -3
  521. package/build-module/table/edit.js.map +1 -1
  522. package/build-module/table-of-contents/edit.js +1 -0
  523. package/build-module/table-of-contents/edit.js.map +1 -1
  524. package/build-module/table-of-contents/utils.js +1 -1
  525. package/build-module/table-of-contents/utils.js.map +1 -1
  526. package/build-module/tag-cloud/edit.js +1 -0
  527. package/build-module/tag-cloud/edit.js.map +1 -1
  528. package/build-module/tag-cloud/index.js +1 -0
  529. package/build-module/tag-cloud/index.js.map +1 -1
  530. package/build-module/template-part/index.js +1 -0
  531. package/build-module/template-part/index.js.map +1 -1
  532. package/build-module/term-description/index.js +1 -0
  533. package/build-module/term-description/index.js.map +1 -1
  534. package/build-module/verse/index.js +6 -0
  535. package/build-module/verse/index.js.map +1 -1
  536. package/build-module/video/edit-common-settings.js +5 -0
  537. package/build-module/video/edit-common-settings.js.map +1 -1
  538. package/build-style/avatar/style-rtl.css +3 -0
  539. package/build-style/avatar/style.css +3 -0
  540. package/build-style/button/editor-rtl.css +31 -0
  541. package/build-style/button/editor.css +31 -0
  542. package/build-style/button/style-rtl.css +31 -0
  543. package/build-style/button/style.css +31 -0
  544. package/build-style/editor-rtl.css +33 -1
  545. package/build-style/editor.css +33 -1
  546. package/build-style/file/style-rtl.css +1 -0
  547. package/build-style/file/style.css +1 -0
  548. package/build-style/image/editor-rtl.css +1 -0
  549. package/build-style/image/editor.css +1 -0
  550. package/build-style/image/style-rtl.css +6 -2
  551. package/build-style/image/style.css +6 -0
  552. package/build-style/latest-comments/style-rtl.css +18 -5
  553. package/build-style/latest-comments/style.css +18 -5
  554. package/build-style/post-excerpt/editor-rtl.css +1 -1
  555. package/build-style/post-excerpt/editor.css +1 -1
  556. package/build-style/style-rtl.css +59 -7
  557. package/build-style/style.css +59 -5
  558. package/build-types/table-of-contents/utils.d.ts +1 -1
  559. package/package.json +31 -30
  560. package/src/archives/block.json +1 -0
  561. package/src/archives/edit.js +3 -0
  562. package/src/audio/edit.js +2 -0
  563. package/src/audio/test/__snapshots__/edit.native.js.snap +38 -38
  564. package/src/avatar/block.json +1 -0
  565. package/src/avatar/edit.js +2 -4
  566. package/src/avatar/index.php +67 -63
  567. package/src/avatar/style.scss +3 -0
  568. package/src/button/block.json +17 -6
  569. package/src/button/edit.js +2 -1
  570. package/src/button/editor.scss +36 -0
  571. package/src/button/style.scss +37 -1
  572. package/src/buttons/test/__snapshots__/edit.native.js.snap +11 -11
  573. package/src/calendar/block.json +1 -0
  574. package/src/categories/block.json +1 -0
  575. package/src/categories/edit.js +5 -0
  576. package/src/code/test/__snapshots__/edit.native.js.snap +2 -2
  577. package/src/columns/edit.js +1 -0
  578. package/src/columns/test/__snapshots__/edit.native.js.snap +66 -66
  579. package/src/columns/test/utils.js +54 -0
  580. package/src/columns/utils.js +8 -8
  581. package/src/comment-author-avatar/block.json +1 -0
  582. package/src/comment-author-name/block.json +1 -0
  583. package/src/comment-author-name/edit.js +2 -0
  584. package/src/comment-content/block.json +1 -0
  585. package/src/comment-date/block.json +1 -0
  586. package/src/comment-date/edit.js +1 -0
  587. package/src/comment-edit-link/block.json +1 -0
  588. package/src/comment-edit-link/edit.js +1 -0
  589. package/src/comment-reply-link/block.json +1 -0
  590. package/src/comment-template/block.json +1 -0
  591. package/src/comments/block.json +2 -1
  592. package/src/comments-pagination/block.json +1 -0
  593. package/src/comments-pagination-next/block.json +1 -0
  594. package/src/comments-pagination-numbers/block.json +1 -0
  595. package/src/comments-pagination-previous/block.json +1 -0
  596. package/src/comments-title/edit.js +2 -0
  597. package/src/cover/edit/inspector-controls.js +2 -0
  598. package/src/cover/index.php +4 -6
  599. package/src/cover/test/__snapshots__/edit.native.js.snap +36 -36
  600. package/src/embed/embed-controls.js +1 -0
  601. package/src/embed/test/__snapshots__/index.native.js.snap +52 -52
  602. package/src/file/block.json +10 -1
  603. package/src/file/inspector.js +3 -0
  604. package/src/file/style.scss +1 -0
  605. package/src/file/test/__snapshots__/edit.native.js.snap +49 -49
  606. package/src/freeform/modal.js +1 -1
  607. package/src/gallery/edit.js +2 -0
  608. package/src/gallery/shared.js +6 -11
  609. package/src/gallery/test/__snapshots__/index.native.js.snap +71 -71
  610. package/src/gallery/use-image-sizes.js +3 -16
  611. package/src/gallery/v1/edit.js +8 -16
  612. package/src/gallery/v1/gallery-image.js +1 -2
  613. package/src/gallery/v1/shared.js +5 -10
  614. package/src/group/test/__snapshots__/edit.native.js.snap +5 -5
  615. package/src/heading/test/__snapshots__/index.native.js.snap +1 -1
  616. package/src/home-link/block.json +1 -0
  617. package/src/image/edit.js +4 -4
  618. package/src/image/editor.scss +1 -0
  619. package/src/image/image.js +9 -20
  620. package/src/image/index.php +4 -4
  621. package/src/image/style.scss +13 -0
  622. package/src/image/utils.js +2 -2
  623. package/src/index.js +2 -0
  624. package/src/latest-comments/block.json +14 -0
  625. package/src/latest-comments/edit.js +12 -2
  626. package/src/latest-comments/style.scss +25 -7
  627. package/src/latest-posts/block.json +1 -0
  628. package/src/latest-posts/edit.js +4 -0
  629. package/src/list/ordered-list-settings.js +1 -0
  630. package/src/list/test/__snapshots__/edit.native.js.snap +4 -4
  631. package/src/list-item/edit.js +10 -3
  632. package/src/list-item/hooks/use-outdent-list-item.js +2 -1
  633. package/src/loginout/block.json +1 -0
  634. package/src/loginout/edit.js +2 -0
  635. package/src/media-text/edit.js +2 -0
  636. package/src/missing/test/__snapshots__/edit.native.js.snap +1 -1
  637. package/src/more/edit.js +1 -0
  638. package/src/navigation/block.json +1 -0
  639. package/src/navigation/edit/index.js +130 -82
  640. package/src/navigation/edit/navigation-menu-selector.js +12 -26
  641. package/src/navigation/edit/overlay-menu-preview.js +1 -0
  642. package/src/navigation/edit/placeholder/index.js +1 -1
  643. package/src/navigation/edit/test/navigation-menu-selector.js +638 -0
  644. package/src/navigation/edit/unsaved-inner-blocks.js +1 -0
  645. package/src/navigation/edit/use-convert-classic-menu-to-block-menu.js +51 -48
  646. package/src/navigation/edit/use-create-navigation-menu.js +1 -1
  647. package/src/navigation/edit/use-generate-default-navigation-title.js +1 -1
  648. package/src/navigation/edit/use-navigation-notice.js +16 -13
  649. package/src/navigation/index.php +50 -25
  650. package/src/navigation/use-navigation-menu.js +1 -1
  651. package/src/navigation-link/edit.js +10 -5
  652. package/src/navigation-link/link-ui.js +2 -0
  653. package/src/navigation-link/test/__snapshots__/hooks.js.snap +12 -12
  654. package/src/page-list/block.json +1 -0
  655. package/src/page-list/convert-to-links-modal.js +38 -0
  656. package/src/page-list/edit.js +17 -37
  657. package/src/page-list/index.php +4 -4
  658. package/src/page-list/test/convert-to-links-modal.js +134 -0
  659. package/src/page-list/use-convert-to-navigation-links.js +64 -4
  660. package/src/paragraph/edit.js +1 -0
  661. package/src/post-author/block.json +1 -0
  662. package/src/post-author/edit.js +4 -0
  663. package/src/post-author-biography/block.json +1 -0
  664. package/src/post-author-name/block.json +1 -0
  665. package/src/post-author-name/edit.js +2 -0
  666. package/src/post-comments-count/block.json +1 -0
  667. package/src/post-comments-form/block.json +1 -0
  668. package/src/post-comments-link/block.json +1 -0
  669. package/src/post-content/block.json +1 -0
  670. package/src/post-date/block.json +1 -0
  671. package/src/post-date/edit.js +2 -0
  672. package/src/post-excerpt/block.json +5 -0
  673. package/src/post-excerpt/edit.js +73 -7
  674. package/src/post-excerpt/editor.scss +1 -1
  675. package/src/post-excerpt/index.php +29 -5
  676. package/src/post-featured-image/block.json +4 -0
  677. package/src/post-featured-image/dimension-controls.js +64 -2
  678. package/src/post-featured-image/edit.js +20 -6
  679. package/src/post-featured-image/index.php +25 -9
  680. package/src/post-navigation-link/block.json +1 -0
  681. package/src/post-navigation-link/edit.js +2 -0
  682. package/src/post-template/block.json +1 -0
  683. package/src/post-terms/block.json +1 -0
  684. package/src/post-terms/index.php +1 -0
  685. package/src/post-terms/use-post-terms.js +1 -1
  686. package/src/post-time-to-read/block.json +20 -0
  687. package/src/post-time-to-read/edit.js +101 -0
  688. package/src/post-time-to-read/icon.js +15 -0
  689. package/src/post-time-to-read/index.js +17 -0
  690. package/src/post-time-to-read/index.php +62 -0
  691. package/src/post-title/block.json +1 -0
  692. package/src/post-title/edit.js +2 -0
  693. package/src/post-title/index.php +3 -3
  694. package/src/preformatted/test/__snapshots__/edit.native.js.snap +10 -10
  695. package/src/query/block.json +1 -0
  696. package/src/query/edit/inspector-controls/index.js +1 -0
  697. package/src/query-no-results/block.json +1 -0
  698. package/src/query-pagination/block.json +1 -0
  699. package/src/query-pagination-next/block.json +1 -0
  700. package/src/query-pagination-numbers/block.json +1 -0
  701. package/src/query-pagination-previous/block.json +1 -0
  702. package/src/query-title/block.json +1 -0
  703. package/src/query-title/edit.js +2 -0
  704. package/src/read-more/block.json +1 -0
  705. package/src/read-more/edit.js +1 -0
  706. package/src/rss/block.json +1 -0
  707. package/src/rss/edit.js +3 -0
  708. package/src/search/block.json +1 -0
  709. package/src/search/test/__snapshots__/edit.native.js.snap +60 -60
  710. package/src/separator/test/__snapshots__/edit.native.js.snap +1 -1
  711. package/src/site-logo/block.json +1 -0
  712. package/src/site-logo/edit.js +6 -6
  713. package/src/site-logo/index.php +7 -2
  714. package/src/site-tagline/block.json +1 -0
  715. package/src/site-title/block.json +1 -0
  716. package/src/site-title/edit/index.js +2 -0
  717. package/src/social-link/block.json +1 -0
  718. package/src/social-link/index.php +6 -6
  719. package/src/social-links/edit.js +2 -0
  720. package/src/social-links/test/__snapshots__/edit.native.js.snap +16 -16
  721. package/src/spacer/controls.native.js +13 -5
  722. package/src/spacer/edit.native.js +45 -6
  723. package/src/spacer/save.native.js +18 -0
  724. package/src/spacer/test/__snapshots__/index.native.js.snap +21 -9
  725. package/src/spacer/test/index.native.js +81 -0
  726. package/src/table/edit.js +6 -3
  727. package/src/table-of-contents/edit.js +1 -0
  728. package/src/table-of-contents/utils.ts +1 -1
  729. package/src/tag-cloud/block.json +1 -0
  730. package/src/tag-cloud/edit.js +1 -0
  731. package/src/template-part/block.json +1 -0
  732. package/src/template-part/index.php +7 -6
  733. package/src/term-description/block.json +1 -0
  734. package/src/verse/block.json +6 -0
  735. package/src/verse/test/__snapshots__/edit.native.js.snap +2 -2
  736. package/src/video/edit-common-settings.js +5 -0
  737. package/tsconfig.json +2 -1
  738. package/tsconfig.tsbuildinfo +1 -1
@@ -0,0 +1,638 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { render, screen } from '@testing-library/react';
5
+ import userEvent from '@testing-library/user-event';
6
+
7
+ /**
8
+ * Internal dependencies
9
+ */
10
+ import NavigationMenuSelector from '../navigation-menu-selector';
11
+ import useNavigationMenu from '../../use-navigation-menu';
12
+ import useNavigationEntities from '../../use-navigation-entities';
13
+
14
+ jest.mock( '../../use-navigation-menu', () => {
15
+ // This allows us to tweak the returned value on each test.
16
+ const mock = jest.fn();
17
+ return mock;
18
+ } );
19
+
20
+ jest.mock( '../../use-navigation-entities', () => {
21
+ // This allows us to tweak the returned value on each test.
22
+ const mock = jest.fn();
23
+ return mock;
24
+ } );
25
+
26
+ useNavigationEntities.mockReturnValue( {
27
+ menus: [],
28
+ } );
29
+
30
+ const navigationMenu1 = {
31
+ id: 1,
32
+ title: {
33
+ rendered: 'Menu 1',
34
+ },
35
+ status: 'publish',
36
+ };
37
+ const navigationMenu2 = {
38
+ id: 2,
39
+ title: {
40
+ rendered: 'Menu 2',
41
+ },
42
+ status: 'publish',
43
+ };
44
+ const navigationMenu3 = {
45
+ id: 3,
46
+ title: {
47
+ rendered: 'Menu 3',
48
+ },
49
+ status: 'publish',
50
+ };
51
+
52
+ const navigationMenusFixture = [
53
+ navigationMenu1,
54
+ navigationMenu2,
55
+ navigationMenu3,
56
+ ];
57
+
58
+ const classicMenusFixture = [
59
+ {
60
+ id: 1,
61
+ name: 'Classic Menu 1',
62
+ },
63
+ {
64
+ id: 2,
65
+ name: 'Classic Menu 2',
66
+ },
67
+ {
68
+ id: 3,
69
+ name: 'Classic Menu 3',
70
+ },
71
+ ];
72
+
73
+ describe( 'NavigationMenuSelector', () => {
74
+ describe( 'Toggle', () => {
75
+ it( 'should show dropdown toggle with loading message when menus have not resolved', async () => {
76
+ useNavigationMenu.mockReturnValue( {
77
+ navigationMenus: [],
78
+ isResolvingNavigationMenus: true,
79
+ hasResolvedNavigationMenus: false,
80
+ canSwitchNavigationMenu: true,
81
+ } );
82
+
83
+ render( <NavigationMenuSelector /> );
84
+
85
+ expect(
86
+ screen.getByRole( 'button', {
87
+ name: /Loading/,
88
+ } )
89
+ ).toBeInTheDocument();
90
+ } );
91
+
92
+ it( 'should show correct dropdown toggle prompt to choose a menu when navigation menus have resolved', async () => {
93
+ useNavigationMenu.mockReturnValue( {
94
+ navigationMenus: [],
95
+ hasResolvedNavigationMenus: true,
96
+ canUserCreateNavigationMenu: true,
97
+ canSwitchNavigationMenu: true,
98
+ } );
99
+
100
+ render( <NavigationMenuSelector /> );
101
+
102
+ expect(
103
+ screen.getByRole( 'button', {
104
+ name: 'Choose or create a Navigation menu',
105
+ } )
106
+ ).toBeInTheDocument();
107
+ } );
108
+ } );
109
+
110
+ describe( 'Dropdown', () => {
111
+ it( 'should show in loading state with no options when menus have not resolved and user cannot create menus', async () => {
112
+ const user = userEvent.setup();
113
+
114
+ useNavigationMenu.mockReturnValue( {
115
+ navigationMenus: [],
116
+ isResolvingNavigationMenus: true,
117
+ hasResolvedNavigationMenus: false,
118
+ canUserCreateNavigationMenu: false,
119
+ canSwitchNavigationMenu: true,
120
+ } );
121
+
122
+ render( <NavigationMenuSelector /> );
123
+
124
+ const toggleButton = screen.getByRole( 'button' );
125
+ await user.click( toggleButton );
126
+
127
+ expect(
128
+ screen.getByRole( 'menu', {
129
+ name: /Loading/,
130
+ } )
131
+ ).toBeInTheDocument();
132
+
133
+ // Check that all the option groups are *not* present.
134
+ const menusGroup = screen.queryByRole( 'group', { name: 'Menus' } );
135
+ expect( menusGroup ).not.toBeInTheDocument();
136
+
137
+ const classicMenusGroup = screen.queryByRole( 'group', {
138
+ name: 'Import Classic Menus',
139
+ } );
140
+ expect( classicMenusGroup ).not.toBeInTheDocument();
141
+
142
+ const toolsGroup = screen.queryByRole( 'group', {
143
+ name: 'Tools',
144
+ } );
145
+ expect( toolsGroup ).not.toBeInTheDocument();
146
+ } );
147
+
148
+ describe( 'Creating new menus', () => {
149
+ it( 'should show option to create a menu when no menus exist but user can create menus', async () => {
150
+ const user = userEvent.setup();
151
+
152
+ useNavigationMenu.mockReturnValue( {
153
+ navigationMenus: [],
154
+ hasResolvedNavigationMenus: true,
155
+ canUserCreateNavigationMenu: true,
156
+ canSwitchNavigationMenu: true,
157
+ } );
158
+
159
+ render( <NavigationMenuSelector /> );
160
+
161
+ const toggleButton = screen.getByRole( 'button', {
162
+ name: 'Choose or create a Navigation menu',
163
+ } );
164
+
165
+ await user.click( toggleButton );
166
+
167
+ const menuPopover = screen.getByRole( 'menu' );
168
+
169
+ expect( menuPopover ).toHaveAttribute(
170
+ 'aria-label',
171
+ expect.stringContaining(
172
+ 'Choose or create a Navigation menu'
173
+ )
174
+ );
175
+
176
+ // Check that all the option groups are *not* present.
177
+ const menusGroup = screen.queryByRole( 'group', {
178
+ name: 'Menus',
179
+ } );
180
+ expect( menusGroup ).not.toBeInTheDocument();
181
+
182
+ const classicMenusGroup = screen.queryByRole( 'group', {
183
+ name: 'Import Classic Menus',
184
+ } );
185
+ expect( classicMenusGroup ).not.toBeInTheDocument();
186
+
187
+ // Check the Tools Group and Create Menu Button are present.
188
+ const toolsGroup = screen.queryByRole( 'group', {
189
+ name: 'Tools',
190
+ } );
191
+ expect( toolsGroup ).toBeInTheDocument();
192
+
193
+ const createMenuButton = screen.getByRole( 'menuitem', {
194
+ name: 'Create new menu',
195
+ } );
196
+
197
+ expect( createMenuButton ).toBeInTheDocument();
198
+ } );
199
+
200
+ it( 'should not show option to create a menu when user does not have permission to create menus', async () => {
201
+ const user = userEvent.setup();
202
+
203
+ useNavigationMenu.mockReturnValue( {
204
+ navigationMenus: [],
205
+ hasResolvedNavigationMenus: true,
206
+ canUserCreateNavigationMenu: false,
207
+ canSwitchNavigationMenu: true,
208
+ } );
209
+
210
+ render( <NavigationMenuSelector /> );
211
+
212
+ const toggleButton = screen.getByRole( 'button' );
213
+ await user.click( toggleButton );
214
+
215
+ // Check the Tools Group and Create Menu Button are present.
216
+ const toolsGroup = screen.queryByRole( 'group', {
217
+ name: 'Tools',
218
+ } );
219
+ expect( toolsGroup ).not.toBeInTheDocument();
220
+ } );
221
+
222
+ it( 'should call handler callback and close popover when create menu button is clicked', async () => {
223
+ const user = userEvent.setup();
224
+ const handler = jest.fn();
225
+
226
+ useNavigationMenu.mockReturnValue( {
227
+ navigationMenus: [],
228
+ hasResolvedNavigationMenus: true,
229
+ canUserCreateNavigationMenu: true,
230
+ canSwitchNavigationMenu: true,
231
+ } );
232
+
233
+ render( <NavigationMenuSelector onCreateNew={ handler } /> );
234
+
235
+ const toggleButton = screen.getByRole( 'button' );
236
+ await user.click( toggleButton );
237
+
238
+ const createMenuButton = screen.getByRole( 'menuitem', {
239
+ name: 'Create new menu',
240
+ } );
241
+
242
+ await user.click( createMenuButton );
243
+
244
+ expect( handler ).toHaveBeenCalled();
245
+
246
+ expect( screen.queryByRole( 'menu' ) ).not.toBeInTheDocument();
247
+ } );
248
+
249
+ it( 'should handle disabled state of the create menu button during the creation process', async () => {
250
+ const user = userEvent.setup();
251
+ const handler = jest.fn();
252
+
253
+ useNavigationMenu.mockReturnValue( {
254
+ navigationMenus: [],
255
+ hasResolvedNavigationMenus: true,
256
+ canUserCreateNavigationMenu: true,
257
+ canSwitchNavigationMenu: true,
258
+ } );
259
+
260
+ const { rerender } = render(
261
+ <NavigationMenuSelector onCreateNew={ handler } />
262
+ );
263
+
264
+ const toggleButton = screen.getByRole( 'button' );
265
+
266
+ await user.click( toggleButton );
267
+
268
+ await user.click(
269
+ screen.getByRole( 'menuitem', {
270
+ name: 'Create new menu',
271
+ } )
272
+ );
273
+
274
+ // Re-open the dropdown (it's closed when the "Create menu" button is clicked).
275
+ await user.click( toggleButton );
276
+
277
+ // Check the dropdown is open again.
278
+ expect( screen.getByRole( 'menu' ) ).toBeInTheDocument();
279
+
280
+ // Check the "Create menu" button is disabled.
281
+ expect(
282
+ screen.queryByRole( 'menuitem', {
283
+ name: 'Create new menu',
284
+ } )
285
+ ).toBeDisabled();
286
+
287
+ // Simulate the menu being created and component being re-rendered.
288
+ rerender(
289
+ <NavigationMenuSelector
290
+ onCreateNew={ handler }
291
+ createNavigationMenuIsSuccess={ true }
292
+ />
293
+ );
294
+
295
+ // Check the button is enabled again.
296
+ expect(
297
+ screen.queryByRole( 'menuitem', {
298
+ name: 'Create new menu',
299
+ } )
300
+ ).toBeEnabled();
301
+ } );
302
+ } );
303
+
304
+ describe( 'Navigation menus', () => {
305
+ it( 'should not show a list of menus when menus exist but user does not have permission to switch menus', async () => {
306
+ const user = userEvent.setup();
307
+
308
+ useNavigationMenu.mockReturnValue( {
309
+ navigationMenus: navigationMenusFixture,
310
+ hasResolvedNavigationMenus: true,
311
+ canUserCreateNavigationMenu: true,
312
+ canSwitchNavigationMenu: false,
313
+ } );
314
+
315
+ render( <NavigationMenuSelector /> );
316
+
317
+ const toggleButton = screen.getByRole( 'button' );
318
+ await user.click( toggleButton );
319
+
320
+ const menusGroup = screen.queryByRole( 'group', {
321
+ name: 'Menus',
322
+ } );
323
+ expect( menusGroup ).not.toBeInTheDocument();
324
+ } );
325
+
326
+ it( 'should show a list of menus when menus exist', async () => {
327
+ const user = userEvent.setup();
328
+
329
+ useNavigationMenu.mockReturnValue( {
330
+ navigationMenus: navigationMenusFixture,
331
+ hasResolvedNavigationMenus: true,
332
+ canUserCreateNavigationMenu: false,
333
+ canSwitchNavigationMenu: true,
334
+ } );
335
+
336
+ render( <NavigationMenuSelector /> );
337
+
338
+ const toggleButton = screen.getByRole( 'button' );
339
+ await user.click( toggleButton );
340
+
341
+ const menusGroup = screen.queryByRole( 'group', {
342
+ name: 'Menus',
343
+ } );
344
+ expect( menusGroup ).toBeInTheDocument();
345
+
346
+ navigationMenusFixture.forEach( ( item ) => {
347
+ const menuItem = screen.queryByRole( 'menuitemradio', {
348
+ name: item?.title?.rendered,
349
+ } );
350
+ expect( menuItem ).toBeInTheDocument();
351
+ } );
352
+ } );
353
+
354
+ it( 'should render fallback title when menu has no title', async () => {
355
+ const user = userEvent.setup();
356
+
357
+ const menusWithNoTitle = [
358
+ {
359
+ id: 1,
360
+ status: 'publish',
361
+ },
362
+ {
363
+ id: 2,
364
+ status: 'publish',
365
+ },
366
+ ];
367
+
368
+ useNavigationMenu.mockReturnValue( {
369
+ navigationMenus: menusWithNoTitle,
370
+ hasResolvedNavigationMenus: true,
371
+ canUserCreateNavigationMenu: true,
372
+ canSwitchNavigationMenu: true,
373
+ } );
374
+
375
+ render( <NavigationMenuSelector /> );
376
+
377
+ const toggleButton = screen.getByRole( 'button' );
378
+ await user.click( toggleButton );
379
+
380
+ const menusGroup = screen.queryByRole( 'group', {
381
+ name: 'Menus',
382
+ } );
383
+ expect( menusGroup ).toBeInTheDocument();
384
+
385
+ // Check for sequentially named fallback titles.
386
+ expect(
387
+ screen.getByRole( 'menuitemradio', {
388
+ name: '(no title 1)',
389
+ } )
390
+ ).toBeInTheDocument();
391
+
392
+ expect(
393
+ screen.getByRole( 'menuitemradio', {
394
+ name: '(no title 2)',
395
+ } )
396
+ ).toBeInTheDocument();
397
+ } );
398
+
399
+ it( 'should pre-select the correct menu in the menu list if a menu ID is passed', async () => {
400
+ const user = userEvent.setup();
401
+
402
+ useNavigationMenu.mockReturnValue( {
403
+ navigationMenus: navigationMenusFixture,
404
+ hasResolvedNavigationMenus: true,
405
+ canUserCreateNavigationMenu: true,
406
+ canSwitchNavigationMenu: true,
407
+ } );
408
+
409
+ render(
410
+ <NavigationMenuSelector
411
+ currentMenuId={ navigationMenusFixture[ 0 ].id }
412
+ />
413
+ );
414
+
415
+ const toggleButton = screen.getByRole( 'button' );
416
+ await user.click( toggleButton );
417
+
418
+ const menuItem = screen.getByRole( 'menuitemradio', {
419
+ name: navigationMenusFixture[ 0 ].title.rendered,
420
+ } );
421
+
422
+ expect( menuItem ).toBeChecked();
423
+ } );
424
+
425
+ it( 'should call the handler when the navigation menu is selected and disable all options during the import/creation process', async () => {
426
+ const user = userEvent.setup();
427
+
428
+ const handler = jest.fn();
429
+
430
+ useNavigationMenu.mockReturnValue( {
431
+ navigationMenus: navigationMenusFixture,
432
+ hasResolvedNavigationMenus: true,
433
+ canUserCreateNavigationMenu: true,
434
+ canSwitchNavigationMenu: true,
435
+ } );
436
+
437
+ const { rerender } = render(
438
+ <NavigationMenuSelector
439
+ onSelectNavigationMenu={ handler }
440
+ />
441
+ );
442
+ const toggleButton = screen.getByRole( 'button' );
443
+
444
+ await user.click( toggleButton );
445
+
446
+ await user.click(
447
+ screen.getByRole( 'menuitemradio', {
448
+ name: navigationMenusFixture[ 0 ].title.rendered,
449
+ } )
450
+ );
451
+
452
+ expect( handler ).toHaveBeenCalledWith(
453
+ navigationMenusFixture[ 0 ].id
454
+ );
455
+
456
+ // Check the dropdown has been closed.
457
+ expect( screen.queryByRole( 'menu' ) ).not.toBeInTheDocument();
458
+
459
+ // Re-open the dropdown
460
+ await user.click( screen.getByRole( 'button' ) );
461
+
462
+ // Check the dropdown is again open and is in the "loading" state.
463
+ expect(
464
+ screen.getByRole( 'menu', {
465
+ name: /Loading/,
466
+ } )
467
+ ).toBeInTheDocument();
468
+
469
+ // // Check all menu items are present but disabled.
470
+ screen.getAllByRole( 'menuitem' ).forEach( ( item ) => {
471
+ // // Check all menu items are present but disabled.
472
+ expect( item ).toBeDisabled();
473
+ } );
474
+
475
+ // // Simulate the menu being created and component being re-rendered.
476
+ rerender(
477
+ <NavigationMenuSelector
478
+ createNavigationMenuIsSuccess={ true } // classic menu import creates a Navigation menu.
479
+ />
480
+ );
481
+
482
+ // Todo: fix bug where aria label is not updated.
483
+ // expect(
484
+ // screen.getByRole( 'menu', {
485
+ // name: `You are currently editing ${ navigationMenusFixture[ 0 ].title.rendered }`,
486
+ // } )
487
+ // ).toBeInTheDocument();
488
+
489
+ // Check all menu items are re-enabled.
490
+ screen.getAllByRole( 'menuitem' ).forEach( ( item ) => {
491
+ // // Check all menu items are present but disabled.
492
+ expect( item ).toBeEnabled();
493
+ } );
494
+ } );
495
+ } );
496
+
497
+ describe( 'Classic menus', () => {
498
+ it( 'should not show classic menus if there are no classic menus', async () => {
499
+ const user = userEvent.setup();
500
+
501
+ useNavigationEntities.mockReturnValue( {
502
+ menus: [],
503
+ } );
504
+
505
+ render( <NavigationMenuSelector /> );
506
+
507
+ const toggleButton = screen.getByRole( 'button' );
508
+ await user.click( toggleButton );
509
+
510
+ const classicMenusGroup = screen.queryByRole( 'group', {
511
+ name: 'Import Classic Menus',
512
+ } );
513
+ expect( classicMenusGroup ).not.toBeInTheDocument();
514
+ } );
515
+
516
+ it( 'should not show classic menus if there are classic menus but the user does not have permission to create menus', async () => {
517
+ const user = userEvent.setup();
518
+
519
+ useNavigationMenu.mockReturnValue( {
520
+ canUserCreateNavigationMenu: false,
521
+ } );
522
+
523
+ useNavigationEntities.mockReturnValue( {
524
+ menus: classicMenusFixture,
525
+ } );
526
+
527
+ render( <NavigationMenuSelector /> );
528
+
529
+ const toggleButton = screen.getByRole( 'button' );
530
+ await user.click( toggleButton );
531
+
532
+ const classicMenusGroup = screen.queryByRole( 'group', {
533
+ name: 'Import Classic Menus',
534
+ } );
535
+ expect( classicMenusGroup ).not.toBeInTheDocument();
536
+ } );
537
+
538
+ it( 'should show classic menus if there are classic menus and the user has permission to create menus', async () => {
539
+ const user = userEvent.setup();
540
+
541
+ useNavigationMenu.mockReturnValue( {
542
+ canUserCreateNavigationMenu: true,
543
+ } );
544
+
545
+ useNavigationEntities.mockReturnValue( {
546
+ menus: classicMenusFixture,
547
+ } );
548
+
549
+ render( <NavigationMenuSelector /> );
550
+
551
+ const toggleButton = screen.getByRole( 'button' );
552
+ await user.click( toggleButton );
553
+
554
+ const classicMenusGroup = screen.queryByRole( 'group', {
555
+ name: 'Import Classic Menus',
556
+ } );
557
+
558
+ expect( classicMenusGroup ).toBeInTheDocument();
559
+
560
+ // Check for classic menuitems
561
+ classicMenusFixture.forEach( ( item ) => {
562
+ const menuItem = screen.getByRole( 'menuitem', {
563
+ name: `Create from '${ item.name }'`,
564
+ } );
565
+ expect( menuItem ).toBeInTheDocument();
566
+ } );
567
+ } );
568
+
569
+ it( 'should call the handler when the classic menu item is selected and disable all options during the import/creation process', async () => {
570
+ const user = userEvent.setup();
571
+ const handler = jest.fn();
572
+
573
+ useNavigationMenu.mockReturnValue( {
574
+ canUserCreateNavigationMenu: true,
575
+ } );
576
+
577
+ useNavigationEntities.mockReturnValue( {
578
+ menus: classicMenusFixture,
579
+ } );
580
+
581
+ const { rerender } = render(
582
+ <NavigationMenuSelector onSelectClassicMenu={ handler } />
583
+ );
584
+
585
+ const toggleButton = screen.getByRole( 'button' );
586
+
587
+ await user.click( toggleButton );
588
+
589
+ await user.click(
590
+ screen.getByRole( 'menuitem', {
591
+ name: `Create from '${ classicMenusFixture[ 0 ].name }'`,
592
+ } )
593
+ );
594
+
595
+ expect( handler ).toHaveBeenCalled();
596
+
597
+ // Check the dropdown has been closed.
598
+ expect( screen.queryByRole( 'menu' ) ).not.toBeInTheDocument();
599
+
600
+ // // Re-open the dropdown (it's closed when the "Create menu" button is clicked).
601
+ await user.click( screen.getByRole( 'button' ) );
602
+
603
+ // Check the dropdown is open and is in the "loading" state.
604
+ expect(
605
+ screen.getByRole( 'menu', {
606
+ name: /Loading/,
607
+ } )
608
+ ).toBeInTheDocument();
609
+
610
+ // Check all menu items are present but disabled.
611
+ screen.getAllByRole( 'menuitem' ).forEach( ( item ) => {
612
+ // // Check all menu items are present but disabled.
613
+ expect( item ).toBeDisabled();
614
+ } );
615
+
616
+ // Simulate the menu being created and component being re-rendered.
617
+ rerender(
618
+ <NavigationMenuSelector
619
+ createNavigationMenuIsSuccess={ true } // classic menu import creates a Navigation menu.
620
+ />
621
+ );
622
+
623
+ // Todo: fix bug where aria label is not updated.
624
+ // expect(
625
+ // screen.getByRole( 'menu', {
626
+ // name: `You are currently editing ${ classicMenusFixture[ 0 ].name }`,
627
+ // } )
628
+ // ).toBeInTheDocument();
629
+
630
+ // Check all menu items are re-enabled.
631
+ screen.getAllByRole( 'menuitem' ).forEach( ( item ) => {
632
+ // // Check all menu items are present but disabled.
633
+ expect( item ).toBeEnabled();
634
+ } );
635
+ } );
636
+ } );
637
+ } );
638
+ } );
@@ -146,6 +146,7 @@ export default function UnsavedInnerBlocks( {
146
146
 
147
147
  createNavigationMenu( null, blocks );
148
148
  }, [
149
+ createNavigationMenu,
149
150
  isDisabled,
150
151
  isSaving,
151
152
  hasResolvedDraftNavigationMenus,