@wordpress/block-library 7.19.0 → 8.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (761) hide show
  1. package/CHANGELOG.md +6 -0
  2. package/build/audio/edit.native.js +1 -3
  3. package/build/audio/edit.native.js.map +1 -1
  4. package/build/audio/index.js +2 -1
  5. package/build/audio/index.js.map +1 -1
  6. package/build/avatar/edit.js +1 -0
  7. package/build/avatar/edit.js.map +1 -1
  8. package/build/avatar/user-control.js +1 -0
  9. package/build/avatar/user-control.js.map +1 -1
  10. package/build/block/edit.js +14 -2
  11. package/build/block/edit.js.map +1 -1
  12. package/build/block/edit.native.js +14 -6
  13. package/build/block/edit.native.js.map +1 -1
  14. package/build/block/index.js +1 -2
  15. package/build/block/index.js.map +1 -1
  16. package/build/button/edit.native.js.map +1 -1
  17. package/build/code/transforms.js +1 -1
  18. package/build/code/transforms.js.map +1 -1
  19. package/build/columns/edit.js +1 -0
  20. package/build/columns/edit.js.map +1 -1
  21. package/build/columns/edit.native.js +13 -30
  22. package/build/columns/edit.native.js.map +1 -1
  23. package/build/comment-author-avatar/edit.js +1 -0
  24. package/build/comment-author-avatar/edit.js.map +1 -1
  25. package/build/cover/edit/inspector-controls.js +2 -0
  26. package/build/cover/edit/inspector-controls.js.map +1 -1
  27. package/build/cover/edit.native.js +24 -16
  28. package/build/cover/edit.native.js.map +1 -1
  29. package/build/embed/embed-controls.native.js +1 -0
  30. package/build/embed/embed-controls.native.js.map +1 -1
  31. package/build/embed/embed-preview.native.js +1 -3
  32. package/build/embed/embed-preview.native.js.map +1 -1
  33. package/build/file/inspector.js +1 -0
  34. package/build/file/inspector.js.map +1 -1
  35. package/build/gallery/edit.js +25 -13
  36. package/build/gallery/edit.js.map +1 -1
  37. package/build/gallery/gallery.native.js +1 -3
  38. package/build/gallery/gallery.native.js.map +1 -1
  39. package/build/gallery/shared.js +4 -10
  40. package/build/gallery/shared.js.map +1 -1
  41. package/build/gallery/transforms.js +1 -7
  42. package/build/gallery/transforms.js.map +1 -1
  43. package/build/gallery/use-get-media.js +1 -1
  44. package/build/gallery/use-get-media.js.map +1 -1
  45. package/build/gallery/use-get-media.native.js +3 -1
  46. package/build/gallery/use-get-media.native.js.map +1 -1
  47. package/build/gallery/v1/edit.js +22 -15
  48. package/build/gallery/v1/edit.js.map +1 -1
  49. package/build/gallery/v1/gallery.native.js +1 -3
  50. package/build/gallery/v1/gallery.native.js.map +1 -1
  51. package/build/gallery/v1/shared.js +4 -1
  52. package/build/gallery/v1/shared.js.map +1 -1
  53. package/build/group/edit.js +1 -2
  54. package/build/group/edit.js.map +1 -1
  55. package/build/group/index.js +3 -1
  56. package/build/group/index.js.map +1 -1
  57. package/build/group/placeholder.js +5 -26
  58. package/build/group/placeholder.js.map +1 -1
  59. package/build/heading/deprecated.js +152 -69
  60. package/build/heading/deprecated.js.map +1 -1
  61. package/build/heading/index.js +1 -2
  62. package/build/heading/index.js.map +1 -1
  63. package/build/heading/transforms.js +1 -2
  64. package/build/heading/transforms.js.map +1 -1
  65. package/build/html/index.js +1 -1
  66. package/build/image/edit.js +8 -5
  67. package/build/image/edit.js.map +1 -1
  68. package/build/image/edit.native.js +3 -2
  69. package/build/image/edit.native.js.map +1 -1
  70. package/build/image/image.js +12 -8
  71. package/build/image/image.js.map +1 -1
  72. package/build/index.js +3 -1
  73. package/build/index.js.map +1 -1
  74. package/build/latest-comments/edit.js +1 -0
  75. package/build/latest-comments/edit.js.map +1 -1
  76. package/build/latest-posts/edit.js +2 -0
  77. package/build/latest-posts/edit.js.map +1 -1
  78. package/build/list/transforms.js +1 -9
  79. package/build/list/transforms.js.map +1 -1
  80. package/build/list/utils.js +5 -2
  81. package/build/list/utils.js.map +1 -1
  82. package/build/list-item/index.js +4 -1
  83. package/build/list-item/index.js.map +1 -1
  84. package/build/list-item/transforms.js +22 -0
  85. package/build/list-item/transforms.js.map +1 -0
  86. package/build/list-item/utils.js +77 -1
  87. package/build/list-item/utils.js.map +1 -1
  88. package/build/media-text/edit.js +4 -2
  89. package/build/media-text/edit.js.map +1 -1
  90. package/build/navigation/edit/are-blocks-dirty.js +52 -0
  91. package/build/navigation/edit/are-blocks-dirty.js.map +1 -0
  92. package/build/navigation/edit/index.js +95 -116
  93. package/build/navigation/edit/index.js.map +1 -1
  94. package/build/navigation/edit/menu-inspector-controls.js +72 -0
  95. package/build/navigation/edit/menu-inspector-controls.js.map +1 -0
  96. package/build/navigation/edit/navigation-menu-selector.js +5 -10
  97. package/build/navigation/edit/navigation-menu-selector.js.map +1 -1
  98. package/build/navigation/edit/unsaved-inner-blocks.js +11 -7
  99. package/build/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  100. package/build/navigation/view-modal.js +6 -2
  101. package/build/navigation/view-modal.js.map +1 -1
  102. package/build/navigation-link/edit.js +42 -298
  103. package/build/navigation-link/edit.js.map +1 -1
  104. package/build/navigation-link/link-ui.js +222 -0
  105. package/build/navigation-link/link-ui.js.map +1 -0
  106. package/build/navigation-link/transforms.js +12 -0
  107. package/build/navigation-link/transforms.js.map +1 -1
  108. package/build/navigation-link/update-attributes.js +108 -0
  109. package/build/navigation-link/update-attributes.js.map +1 -0
  110. package/build/navigation-submenu/edit.js +42 -173
  111. package/build/navigation-submenu/edit.js.map +1 -1
  112. package/build/page-list/constants.js +15 -0
  113. package/build/page-list/constants.js.map +1 -0
  114. package/build/page-list/convert-to-links-modal.js +22 -86
  115. package/build/page-list/convert-to-links-modal.js.map +1 -1
  116. package/build/page-list/convert-to-navigation-links.js +76 -0
  117. package/build/page-list/convert-to-navigation-links.js.map +1 -0
  118. package/build/page-list/edit.js +142 -78
  119. package/build/page-list/edit.js.map +1 -1
  120. package/build/page-list/index.js +6 -1
  121. package/build/page-list/index.js.map +1 -1
  122. package/build/page-list-item/edit.js +87 -0
  123. package/build/page-list-item/edit.js.map +1 -0
  124. package/build/page-list-item/index.js +85 -0
  125. package/build/page-list-item/index.js.map +1 -0
  126. package/build/page-list-item/init.js +16 -0
  127. package/build/page-list-item/init.js.map +1 -0
  128. package/build/paragraph/index.js +1 -7
  129. package/build/paragraph/index.js.map +1 -1
  130. package/build/post-author/edit.js +3 -2
  131. package/build/post-author/edit.js.map +1 -1
  132. package/build/post-featured-image/overlay.js +1 -0
  133. package/build/post-featured-image/overlay.js.map +1 -1
  134. package/build/post-template/index.js +8 -0
  135. package/build/post-template/index.js.map +1 -1
  136. package/build/preformatted/transforms.js +3 -1
  137. package/build/preformatted/transforms.js.map +1 -1
  138. package/build/query/deprecated.js +192 -21
  139. package/build/query/deprecated.js.map +1 -1
  140. package/build/query/edit/inspector-controls/index.js +1 -0
  141. package/build/query/edit/inspector-controls/index.js.map +1 -1
  142. package/build/query/edit/query-placeholder.js +3 -19
  143. package/build/query/edit/query-placeholder.js.map +1 -1
  144. package/build/query/index.js +0 -8
  145. package/build/query/index.js.map +1 -1
  146. package/build/query/utils.js +0 -8
  147. package/build/query/utils.js.map +1 -1
  148. package/build/rss/edit.js +3 -0
  149. package/build/rss/edit.js.map +1 -1
  150. package/build/search/edit.native.js +22 -22
  151. package/build/search/edit.native.js.map +1 -1
  152. package/build/search/index.js +9 -1
  153. package/build/search/index.js.map +1 -1
  154. package/build/site-logo/edit.js +17 -9
  155. package/build/site-logo/edit.js.map +1 -1
  156. package/build/site-logo/index.js +1 -0
  157. package/build/site-logo/index.js.map +1 -1
  158. package/build/site-title/index.js +1 -0
  159. package/build/site-title/index.js.map +1 -1
  160. package/build/social-link/social-list.js +4 -12
  161. package/build/social-link/social-list.js.map +1 -1
  162. package/build/table/edit.js +3 -1
  163. package/build/table/edit.js.map +1 -1
  164. package/build/table/index.js +17 -1
  165. package/build/table/index.js.map +1 -1
  166. package/build/table/save.js +4 -2
  167. package/build/table/save.js.map +1 -1
  168. package/build/table/state.js +24 -12
  169. package/build/table/state.js.map +1 -1
  170. package/build/table/transforms.js +3 -2
  171. package/build/table/transforms.js.map +1 -1
  172. package/build/table-of-contents/edit.js +2 -2
  173. package/build/table-of-contents/edit.js.map +1 -1
  174. package/build/tag-cloud/edit.js +2 -1
  175. package/build/tag-cloud/edit.js.map +1 -1
  176. package/build/template-part/edit/selection-modal.js +5 -2
  177. package/build/template-part/edit/selection-modal.js.map +1 -1
  178. package/build/template-part/edit/utils/hooks.js +2 -6
  179. package/build/template-part/edit/utils/hooks.js.map +1 -1
  180. package/build/text-columns/edit.js +1 -0
  181. package/build/text-columns/edit.js.map +1 -1
  182. package/build/utils/transformation-categories.native.js +1 -1
  183. package/build/utils/transformation-categories.native.js.map +1 -1
  184. package/build/video/edit.js +1 -1
  185. package/build/video/edit.js.map +1 -1
  186. package/build/video/edit.native.js +1 -3
  187. package/build/video/edit.native.js.map +1 -1
  188. package/build-module/audio/edit.native.js +1 -2
  189. package/build-module/audio/edit.native.js.map +1 -1
  190. package/build-module/audio/index.js +2 -1
  191. package/build-module/audio/index.js.map +1 -1
  192. package/build-module/avatar/edit.js +1 -0
  193. package/build-module/avatar/edit.js.map +1 -1
  194. package/build-module/avatar/user-control.js +1 -0
  195. package/build-module/avatar/user-control.js.map +1 -1
  196. package/build-module/block/edit.js +14 -2
  197. package/build-module/block/edit.js.map +1 -1
  198. package/build-module/block/edit.native.js +14 -6
  199. package/build-module/block/edit.native.js.map +1 -1
  200. package/build-module/block/index.js +1 -2
  201. package/build-module/block/index.js.map +1 -1
  202. package/build-module/button/edit.native.js +2 -1
  203. package/build-module/button/edit.native.js.map +1 -1
  204. package/build-module/code/transforms.js +1 -1
  205. package/build-module/code/transforms.js.map +1 -1
  206. package/build-module/columns/edit.js +1 -0
  207. package/build-module/columns/edit.js.map +1 -1
  208. package/build-module/columns/edit.native.js +13 -29
  209. package/build-module/columns/edit.native.js.map +1 -1
  210. package/build-module/comment-author-avatar/edit.js +1 -0
  211. package/build-module/comment-author-avatar/edit.js.map +1 -1
  212. package/build-module/cover/edit/inspector-controls.js +2 -0
  213. package/build-module/cover/edit/inspector-controls.js.map +1 -1
  214. package/build-module/cover/edit.native.js +22 -14
  215. package/build-module/cover/edit.native.js.map +1 -1
  216. package/build-module/embed/embed-controls.native.js +2 -1
  217. package/build-module/embed/embed-controls.native.js.map +1 -1
  218. package/build-module/embed/embed-preview.native.js +1 -2
  219. package/build-module/embed/embed-preview.native.js.map +1 -1
  220. package/build-module/file/inspector.js +1 -0
  221. package/build-module/file/inspector.js.map +1 -1
  222. package/build-module/gallery/edit.js +25 -12
  223. package/build-module/gallery/edit.js.map +1 -1
  224. package/build-module/gallery/gallery.native.js +1 -2
  225. package/build-module/gallery/gallery.native.js.map +1 -1
  226. package/build-module/gallery/shared.js +5 -11
  227. package/build-module/gallery/shared.js.map +1 -1
  228. package/build-module/gallery/transforms.js +1 -6
  229. package/build-module/gallery/transforms.js.map +1 -1
  230. package/build-module/gallery/use-get-media.js +1 -1
  231. package/build-module/gallery/use-get-media.js.map +1 -1
  232. package/build-module/gallery/use-get-media.native.js +3 -1
  233. package/build-module/gallery/use-get-media.native.js.map +1 -1
  234. package/build-module/gallery/v1/edit.js +23 -16
  235. package/build-module/gallery/v1/edit.js.map +1 -1
  236. package/build-module/gallery/v1/gallery.native.js +1 -2
  237. package/build-module/gallery/v1/gallery.native.js.map +1 -1
  238. package/build-module/gallery/v1/shared.js +5 -2
  239. package/build-module/gallery/v1/shared.js.map +1 -1
  240. package/build-module/group/edit.js +1 -3
  241. package/build-module/group/edit.js.map +1 -1
  242. package/build-module/group/index.js +3 -1
  243. package/build-module/group/index.js.map +1 -1
  244. package/build-module/group/placeholder.js +5 -26
  245. package/build-module/group/placeholder.js.map +1 -1
  246. package/build-module/heading/deprecated.js +152 -69
  247. package/build-module/heading/deprecated.js.map +1 -1
  248. package/build-module/heading/index.js +1 -2
  249. package/build-module/heading/index.js.map +1 -1
  250. package/build-module/heading/transforms.js +1 -2
  251. package/build-module/heading/transforms.js.map +1 -1
  252. package/build-module/html/index.js +1 -1
  253. package/build-module/image/edit.js +9 -6
  254. package/build-module/image/edit.js.map +1 -1
  255. package/build-module/image/edit.native.js +2 -1
  256. package/build-module/image/edit.native.js.map +1 -1
  257. package/build-module/image/image.js +13 -9
  258. package/build-module/image/image.js.map +1 -1
  259. package/build-module/index.js +2 -1
  260. package/build-module/index.js.map +1 -1
  261. package/build-module/latest-comments/edit.js +1 -0
  262. package/build-module/latest-comments/edit.js.map +1 -1
  263. package/build-module/latest-posts/edit.js +2 -0
  264. package/build-module/latest-posts/edit.js.map +1 -1
  265. package/build-module/list/transforms.js +1 -9
  266. package/build-module/list/transforms.js.map +1 -1
  267. package/build-module/list/utils.js +5 -2
  268. package/build-module/list/utils.js.map +1 -1
  269. package/build-module/list-item/index.js +3 -1
  270. package/build-module/list-item/index.js.map +1 -1
  271. package/build-module/list-item/transforms.js +13 -0
  272. package/build-module/list-item/transforms.js.map +1 -0
  273. package/build-module/list-item/utils.js +78 -1
  274. package/build-module/list-item/utils.js.map +1 -1
  275. package/build-module/media-text/edit.js +5 -3
  276. package/build-module/media-text/edit.js.map +1 -1
  277. package/build-module/navigation/edit/are-blocks-dirty.js +44 -0
  278. package/build-module/navigation/edit/are-blocks-dirty.js.map +1 -0
  279. package/build-module/navigation/edit/index.js +95 -117
  280. package/build-module/navigation/edit/index.js.map +1 -1
  281. package/build-module/navigation/edit/menu-inspector-controls.js +59 -0
  282. package/build-module/navigation/edit/menu-inspector-controls.js.map +1 -0
  283. package/build-module/navigation/edit/navigation-menu-selector.js +6 -11
  284. package/build-module/navigation/edit/navigation-menu-selector.js.map +1 -1
  285. package/build-module/navigation/edit/unsaved-inner-blocks.js +9 -6
  286. package/build-module/navigation/edit/unsaved-inner-blocks.js.map +1 -1
  287. package/build-module/navigation/view-modal.js +6 -2
  288. package/build-module/navigation/view-modal.js.map +1 -1
  289. package/build-module/navigation-link/edit.js +46 -299
  290. package/build-module/navigation-link/edit.js.map +1 -1
  291. package/build-module/navigation-link/link-ui.js +206 -0
  292. package/build-module/navigation-link/link-ui.js.map +1 -0
  293. package/build-module/navigation-link/transforms.js +12 -0
  294. package/build-module/navigation-link/transforms.js.map +1 -1
  295. package/build-module/navigation-link/update-attributes.js +97 -0
  296. package/build-module/navigation-link/update-attributes.js.map +1 -0
  297. package/build-module/navigation-submenu/edit.js +47 -175
  298. package/build-module/navigation-submenu/edit.js.map +1 -1
  299. package/build-module/page-list/constants.js +6 -0
  300. package/build-module/page-list/constants.js.map +1 -0
  301. package/build-module/page-list/convert-to-links-modal.js +20 -81
  302. package/build-module/page-list/convert-to-links-modal.js.map +1 -1
  303. package/build-module/page-list/convert-to-navigation-links.js +66 -0
  304. package/build-module/page-list/convert-to-navigation-links.js.map +1 -0
  305. package/build-module/page-list/edit.js +144 -82
  306. package/build-module/page-list/edit.js.map +1 -1
  307. package/build-module/page-list/index.js +6 -1
  308. package/build-module/page-list/index.js.map +1 -1
  309. package/build-module/page-list-item/edit.js +74 -0
  310. package/build-module/page-list-item/edit.js.map +1 -0
  311. package/build-module/page-list-item/index.js +68 -0
  312. package/build-module/page-list-item/index.js.map +1 -0
  313. package/build-module/page-list-item/init.js +6 -0
  314. package/build-module/page-list-item/init.js.map +1 -0
  315. package/build-module/paragraph/index.js +1 -7
  316. package/build-module/paragraph/index.js.map +1 -1
  317. package/build-module/post-author/edit.js +3 -2
  318. package/build-module/post-author/edit.js.map +1 -1
  319. package/build-module/post-featured-image/overlay.js +1 -0
  320. package/build-module/post-featured-image/overlay.js.map +1 -1
  321. package/build-module/post-template/index.js +8 -0
  322. package/build-module/post-template/index.js.map +1 -1
  323. package/build-module/preformatted/transforms.js +3 -1
  324. package/build-module/preformatted/transforms.js.map +1 -1
  325. package/build-module/query/deprecated.js +185 -21
  326. package/build-module/query/deprecated.js.map +1 -1
  327. package/build-module/query/edit/inspector-controls/index.js +1 -0
  328. package/build-module/query/edit/inspector-controls/index.js.map +1 -1
  329. package/build-module/query/edit/query-placeholder.js +3 -19
  330. package/build-module/query/edit/query-placeholder.js.map +1 -1
  331. package/build-module/query/index.js +0 -8
  332. package/build-module/query/index.js.map +1 -1
  333. package/build-module/query/utils.js +0 -8
  334. package/build-module/query/utils.js.map +1 -1
  335. package/build-module/rss/edit.js +3 -0
  336. package/build-module/rss/edit.js.map +1 -1
  337. package/build-module/search/edit.native.js +20 -20
  338. package/build-module/search/edit.native.js.map +1 -1
  339. package/build-module/search/index.js +8 -1
  340. package/build-module/search/index.js.map +1 -1
  341. package/build-module/site-logo/edit.js +17 -8
  342. package/build-module/site-logo/edit.js.map +1 -1
  343. package/build-module/site-logo/index.js +1 -0
  344. package/build-module/site-logo/index.js.map +1 -1
  345. package/build-module/site-title/index.js +1 -0
  346. package/build-module/site-title/index.js.map +1 -1
  347. package/build-module/social-link/social-list.js +2 -11
  348. package/build-module/social-link/social-list.js.map +1 -1
  349. package/build-module/table/edit.js +3 -1
  350. package/build-module/table/edit.js.map +1 -1
  351. package/build-module/table/index.js +17 -1
  352. package/build-module/table/index.js.map +1 -1
  353. package/build-module/table/save.js +4 -2
  354. package/build-module/table/save.js.map +1 -1
  355. package/build-module/table/state.js +25 -13
  356. package/build-module/table/state.js.map +1 -1
  357. package/build-module/table/transforms.js +3 -2
  358. package/build-module/table/transforms.js.map +1 -1
  359. package/build-module/table-of-contents/edit.js +2 -2
  360. package/build-module/table-of-contents/edit.js.map +1 -1
  361. package/build-module/tag-cloud/edit.js +3 -2
  362. package/build-module/tag-cloud/edit.js.map +1 -1
  363. package/build-module/template-part/edit/selection-modal.js +6 -3
  364. package/build-module/template-part/edit/selection-modal.js.map +1 -1
  365. package/build-module/template-part/edit/utils/hooks.js +3 -7
  366. package/build-module/template-part/edit/utils/hooks.js.map +1 -1
  367. package/build-module/text-columns/edit.js +1 -0
  368. package/build-module/text-columns/edit.js.map +1 -1
  369. package/build-module/utils/transformation-categories.native.js +1 -1
  370. package/build-module/utils/transformation-categories.native.js.map +1 -1
  371. package/build-module/video/edit.js +1 -1
  372. package/build-module/video/edit.js.map +1 -1
  373. package/build-module/video/edit.native.js +1 -2
  374. package/build-module/video/edit.native.js.map +1 -1
  375. package/build-style/archives/editor-rtl.css +12 -0
  376. package/build-style/archives/editor.css +12 -0
  377. package/build-style/archives/style-rtl.css +12 -0
  378. package/build-style/archives/style.css +12 -0
  379. package/build-style/audio/editor-rtl.css +12 -0
  380. package/build-style/audio/editor.css +12 -0
  381. package/build-style/audio/style-rtl.css +12 -0
  382. package/build-style/audio/style.css +12 -0
  383. package/build-style/audio/theme-rtl.css +12 -0
  384. package/build-style/audio/theme.css +12 -0
  385. package/build-style/avatar/editor-rtl.css +12 -0
  386. package/build-style/avatar/editor.css +12 -0
  387. package/build-style/avatar/style-rtl.css +12 -0
  388. package/build-style/avatar/style.css +12 -0
  389. package/build-style/block/editor-rtl.css +22 -0
  390. package/build-style/block/editor.css +22 -0
  391. package/build-style/button/editor-rtl.css +12 -0
  392. package/build-style/button/editor.css +12 -0
  393. package/build-style/button/style-rtl.css +12 -0
  394. package/build-style/button/style.css +12 -0
  395. package/build-style/buttons/editor-rtl.css +12 -0
  396. package/build-style/buttons/editor.css +12 -0
  397. package/build-style/buttons/style-rtl.css +12 -0
  398. package/build-style/buttons/style.css +12 -0
  399. package/build-style/calendar/style-rtl.css +12 -0
  400. package/build-style/calendar/style.css +12 -0
  401. package/build-style/categories/editor-rtl.css +12 -0
  402. package/build-style/categories/editor.css +12 -0
  403. package/build-style/categories/style-rtl.css +12 -0
  404. package/build-style/categories/style.css +12 -0
  405. package/build-style/classic-rtl.css +12 -0
  406. package/build-style/classic.css +12 -0
  407. package/build-style/code/editor-rtl.css +12 -0
  408. package/build-style/code/editor.css +12 -0
  409. package/build-style/code/style-rtl.css +12 -0
  410. package/build-style/code/style.css +12 -0
  411. package/build-style/code/theme-rtl.css +12 -0
  412. package/build-style/code/theme.css +12 -0
  413. package/build-style/columns/editor-rtl.css +12 -0
  414. package/build-style/columns/editor.css +12 -0
  415. package/build-style/columns/style-rtl.css +12 -0
  416. package/build-style/columns/style.css +12 -0
  417. package/build-style/comment-author-avatar/editor-rtl.css +12 -0
  418. package/build-style/comment-author-avatar/editor.css +12 -0
  419. package/build-style/comment-content/style-rtl.css +12 -0
  420. package/build-style/comment-content/style.css +12 -0
  421. package/build-style/comment-template/style-rtl.css +12 -0
  422. package/build-style/comment-template/style.css +12 -0
  423. package/build-style/comments/editor-rtl.css +12 -0
  424. package/build-style/comments/editor.css +12 -0
  425. package/build-style/comments/style-rtl.css +12 -0
  426. package/build-style/comments/style.css +12 -0
  427. package/build-style/comments-pagination/editor-rtl.css +12 -0
  428. package/build-style/comments-pagination/editor.css +12 -0
  429. package/build-style/comments-pagination/style-rtl.css +12 -0
  430. package/build-style/comments-pagination/style.css +12 -0
  431. package/build-style/comments-pagination-numbers/editor-rtl.css +12 -0
  432. package/build-style/comments-pagination-numbers/editor.css +12 -0
  433. package/build-style/comments-title/editor-rtl.css +12 -0
  434. package/build-style/comments-title/editor.css +12 -0
  435. package/build-style/common-rtl.css +17 -1
  436. package/build-style/common.css +17 -1
  437. package/build-style/cover/editor-rtl.css +12 -0
  438. package/build-style/cover/editor.css +12 -0
  439. package/build-style/cover/style-rtl.css +14 -1
  440. package/build-style/cover/style.css +14 -1
  441. package/build-style/editor-elements-rtl.css +12 -0
  442. package/build-style/editor-elements.css +12 -0
  443. package/build-style/editor-rtl.css +39 -20
  444. package/build-style/editor.css +39 -20
  445. package/build-style/elements-rtl.css +12 -0
  446. package/build-style/elements.css +12 -0
  447. package/build-style/embed/editor-rtl.css +12 -0
  448. package/build-style/embed/editor.css +12 -0
  449. package/build-style/embed/style-rtl.css +12 -0
  450. package/build-style/embed/style.css +12 -0
  451. package/build-style/embed/theme-rtl.css +12 -0
  452. package/build-style/embed/theme.css +12 -0
  453. package/build-style/file/editor-rtl.css +12 -0
  454. package/build-style/file/editor.css +12 -0
  455. package/build-style/file/style-rtl.css +12 -0
  456. package/build-style/file/style.css +12 -0
  457. package/build-style/freeform/editor-rtl.css +12 -0
  458. package/build-style/freeform/editor.css +12 -0
  459. package/build-style/gallery/editor-rtl.css +13 -1
  460. package/build-style/gallery/editor.css +13 -1
  461. package/build-style/gallery/style-rtl.css +16 -2
  462. package/build-style/gallery/style.css +16 -2
  463. package/build-style/gallery/theme-rtl.css +12 -0
  464. package/build-style/gallery/theme.css +12 -0
  465. package/build-style/group/editor-rtl.css +12 -0
  466. package/build-style/group/editor.css +12 -0
  467. package/build-style/group/style-rtl.css +12 -0
  468. package/build-style/group/style.css +12 -0
  469. package/build-style/group/theme-rtl.css +12 -0
  470. package/build-style/group/theme.css +12 -0
  471. package/build-style/heading/style-rtl.css +12 -0
  472. package/build-style/heading/style.css +12 -0
  473. package/build-style/html/editor-rtl.css +12 -0
  474. package/build-style/html/editor.css +12 -0
  475. package/build-style/image/editor-rtl.css +12 -9
  476. package/build-style/image/editor.css +12 -9
  477. package/build-style/image/style-rtl.css +12 -0
  478. package/build-style/image/style.css +12 -0
  479. package/build-style/image/theme-rtl.css +12 -0
  480. package/build-style/image/theme.css +12 -0
  481. package/build-style/latest-comments/style-rtl.css +12 -0
  482. package/build-style/latest-comments/style.css +12 -0
  483. package/build-style/latest-posts/editor-rtl.css +12 -0
  484. package/build-style/latest-posts/editor.css +12 -0
  485. package/build-style/latest-posts/style-rtl.css +12 -0
  486. package/build-style/latest-posts/style.css +12 -0
  487. package/build-style/list/style-rtl.css +12 -0
  488. package/build-style/list/style.css +12 -0
  489. package/build-style/media-text/editor-rtl.css +12 -0
  490. package/build-style/media-text/editor.css +12 -0
  491. package/build-style/media-text/style-rtl.css +12 -0
  492. package/build-style/media-text/style.css +12 -0
  493. package/build-style/more/editor-rtl.css +12 -0
  494. package/build-style/more/editor.css +12 -0
  495. package/build-style/navigation/editor-rtl.css +12 -0
  496. package/build-style/navigation/editor.css +12 -0
  497. package/build-style/navigation/style-rtl.css +12 -0
  498. package/build-style/navigation/style.css +12 -0
  499. package/build-style/navigation-link/editor-rtl.css +12 -0
  500. package/build-style/navigation-link/editor.css +12 -0
  501. package/build-style/navigation-link/style-rtl.css +12 -0
  502. package/build-style/navigation-link/style.css +12 -0
  503. package/build-style/navigation-submenu/editor-rtl.css +12 -0
  504. package/build-style/navigation-submenu/editor.css +12 -0
  505. package/build-style/nextpage/editor-rtl.css +12 -0
  506. package/build-style/nextpage/editor.css +12 -0
  507. package/build-style/page-list/editor-rtl.css +12 -0
  508. package/build-style/page-list/editor.css +12 -0
  509. package/build-style/page-list/style-rtl.css +12 -0
  510. package/build-style/page-list/style.css +12 -0
  511. package/build-style/paragraph/editor-rtl.css +12 -0
  512. package/build-style/paragraph/editor.css +12 -0
  513. package/build-style/paragraph/style-rtl.css +12 -0
  514. package/build-style/paragraph/style.css +12 -0
  515. package/build-style/post-author/style-rtl.css +12 -0
  516. package/build-style/post-author/style.css +12 -0
  517. package/build-style/post-comments-form/editor-rtl.css +12 -0
  518. package/build-style/post-comments-form/editor.css +12 -0
  519. package/build-style/post-comments-form/style-rtl.css +12 -0
  520. package/build-style/post-comments-form/style.css +12 -0
  521. package/build-style/post-date/style-rtl.css +12 -0
  522. package/build-style/post-date/style.css +12 -0
  523. package/build-style/post-excerpt/editor-rtl.css +12 -0
  524. package/build-style/post-excerpt/editor.css +12 -0
  525. package/build-style/post-excerpt/style-rtl.css +12 -0
  526. package/build-style/post-excerpt/style.css +12 -0
  527. package/build-style/post-featured-image/editor-rtl.css +12 -0
  528. package/build-style/post-featured-image/editor.css +12 -0
  529. package/build-style/post-featured-image/style-rtl.css +12 -0
  530. package/build-style/post-featured-image/style.css +12 -0
  531. package/build-style/post-navigation-link/style-rtl.css +12 -0
  532. package/build-style/post-navigation-link/style.css +12 -0
  533. package/build-style/post-template/editor-rtl.css +12 -0
  534. package/build-style/post-template/editor.css +12 -0
  535. package/build-style/post-template/style-rtl.css +12 -0
  536. package/build-style/post-template/style.css +12 -0
  537. package/build-style/post-terms/style-rtl.css +12 -0
  538. package/build-style/post-terms/style.css +12 -0
  539. package/build-style/post-title/style-rtl.css +12 -0
  540. package/build-style/post-title/style.css +12 -0
  541. package/build-style/preformatted/style-rtl.css +12 -0
  542. package/build-style/preformatted/style.css +12 -0
  543. package/build-style/pullquote/editor-rtl.css +12 -0
  544. package/build-style/pullquote/editor.css +12 -0
  545. package/build-style/pullquote/style-rtl.css +12 -0
  546. package/build-style/pullquote/style.css +12 -0
  547. package/build-style/pullquote/theme-rtl.css +12 -0
  548. package/build-style/pullquote/theme.css +12 -0
  549. package/build-style/query/editor-rtl.css +12 -0
  550. package/build-style/query/editor.css +12 -0
  551. package/build-style/query-pagination/editor-rtl.css +12 -0
  552. package/build-style/query-pagination/editor.css +12 -0
  553. package/build-style/query-pagination/style-rtl.css +12 -0
  554. package/build-style/query-pagination/style.css +12 -0
  555. package/build-style/query-pagination-numbers/editor-rtl.css +12 -0
  556. package/build-style/query-pagination-numbers/editor.css +12 -0
  557. package/build-style/query-title/style-rtl.css +12 -0
  558. package/build-style/query-title/style.css +12 -0
  559. package/build-style/quote/style-rtl.css +12 -0
  560. package/build-style/quote/style.css +12 -0
  561. package/build-style/quote/theme-rtl.css +12 -0
  562. package/build-style/quote/theme.css +12 -0
  563. package/build-style/read-more/style-rtl.css +12 -0
  564. package/build-style/read-more/style.css +12 -0
  565. package/build-style/reset-rtl.css +12 -0
  566. package/build-style/reset.css +12 -0
  567. package/build-style/rss/editor-rtl.css +12 -0
  568. package/build-style/rss/editor.css +12 -0
  569. package/build-style/rss/style-rtl.css +12 -0
  570. package/build-style/rss/style.css +12 -0
  571. package/build-style/search/editor-rtl.css +12 -0
  572. package/build-style/search/editor.css +12 -0
  573. package/build-style/search/style-rtl.css +12 -0
  574. package/build-style/search/style.css +12 -0
  575. package/build-style/search/theme-rtl.css +12 -0
  576. package/build-style/search/theme.css +12 -0
  577. package/build-style/separator/editor-rtl.css +12 -0
  578. package/build-style/separator/editor.css +12 -0
  579. package/build-style/separator/style-rtl.css +12 -0
  580. package/build-style/separator/style.css +12 -0
  581. package/build-style/separator/theme-rtl.css +12 -0
  582. package/build-style/separator/theme.css +12 -0
  583. package/build-style/shortcode/editor-rtl.css +13 -1
  584. package/build-style/shortcode/editor.css +13 -1
  585. package/build-style/site-logo/editor-rtl.css +12 -0
  586. package/build-style/site-logo/editor.css +12 -0
  587. package/build-style/site-logo/style-rtl.css +12 -0
  588. package/build-style/site-logo/style.css +12 -0
  589. package/build-style/site-tagline/editor-rtl.css +12 -0
  590. package/build-style/site-tagline/editor.css +12 -0
  591. package/build-style/site-title/editor-rtl.css +12 -0
  592. package/build-style/site-title/editor.css +12 -0
  593. package/build-style/site-title/style-rtl.css +12 -0
  594. package/build-style/site-title/style.css +12 -0
  595. package/build-style/social-link/editor-rtl.css +12 -0
  596. package/build-style/social-link/editor.css +12 -0
  597. package/build-style/social-links/editor-rtl.css +12 -0
  598. package/build-style/social-links/editor.css +12 -0
  599. package/build-style/social-links/style-rtl.css +12 -0
  600. package/build-style/social-links/style.css +12 -0
  601. package/build-style/spacer/editor-rtl.css +12 -0
  602. package/build-style/spacer/editor.css +12 -0
  603. package/build-style/spacer/style-rtl.css +12 -0
  604. package/build-style/spacer/style.css +12 -0
  605. package/build-style/style-rtl.css +23 -5
  606. package/build-style/style.css +23 -5
  607. package/build-style/table/editor-rtl.css +12 -8
  608. package/build-style/table/editor.css +12 -8
  609. package/build-style/table/style-rtl.css +12 -0
  610. package/build-style/table/style.css +12 -0
  611. package/build-style/table/theme-rtl.css +12 -0
  612. package/build-style/table/theme.css +12 -0
  613. package/build-style/tag-cloud/style-rtl.css +12 -0
  614. package/build-style/tag-cloud/style.css +12 -0
  615. package/build-style/template-part/editor-rtl.css +27 -1
  616. package/build-style/template-part/editor.css +27 -1
  617. package/build-style/template-part/theme-rtl.css +12 -0
  618. package/build-style/template-part/theme.css +12 -0
  619. package/build-style/text-columns/editor-rtl.css +12 -0
  620. package/build-style/text-columns/editor.css +12 -0
  621. package/build-style/text-columns/style-rtl.css +12 -0
  622. package/build-style/text-columns/style.css +12 -0
  623. package/build-style/theme-rtl.css +12 -0
  624. package/build-style/theme.css +12 -0
  625. package/build-style/verse/style-rtl.css +12 -0
  626. package/build-style/verse/style.css +12 -0
  627. package/build-style/video/editor-rtl.css +12 -0
  628. package/build-style/video/editor.css +12 -0
  629. package/build-style/video/style-rtl.css +14 -1
  630. package/build-style/video/style.css +14 -1
  631. package/build-style/video/theme-rtl.css +12 -0
  632. package/build-style/video/theme.css +12 -0
  633. package/package.json +32 -30
  634. package/src/audio/edit.native.js +1 -2
  635. package/src/audio/index.js +1 -0
  636. package/src/avatar/edit.js +1 -0
  637. package/src/avatar/user-control.js +1 -0
  638. package/src/block/block.json +1 -2
  639. package/src/block/edit.js +14 -3
  640. package/src/block/edit.native.js +24 -12
  641. package/src/block/editor.scss +17 -0
  642. package/src/block/index.php +1 -2
  643. package/src/block/test/edit.native.js +28 -32
  644. package/src/button/edit.native.js +1 -0
  645. package/src/buttons/test/edit.native.js +40 -51
  646. package/src/code/transforms.js +3 -1
  647. package/src/columns/edit.js +1 -0
  648. package/src/columns/edit.native.js +18 -26
  649. package/src/comment-author-avatar/edit.js +1 -0
  650. package/src/cover/edit/inspector-controls.js +2 -0
  651. package/src/cover/edit.native.js +32 -19
  652. package/src/cover/test/edit.native.js +73 -126
  653. package/src/embed/embed-controls.native.js +1 -0
  654. package/src/embed/embed-preview.native.js +1 -2
  655. package/src/embed/test/index.native.js +237 -231
  656. package/src/file/inspector.js +1 -0
  657. package/src/file/test/__snapshots__/edit.native.js.snap +2 -6
  658. package/src/gallery/edit.js +15 -5
  659. package/src/gallery/gallery.native.js +1 -2
  660. package/src/gallery/shared.js +7 -11
  661. package/src/gallery/transforms.js +1 -6
  662. package/src/gallery/use-get-media.js +1 -1
  663. package/src/gallery/use-get-media.native.js +2 -1
  664. package/src/gallery/v1/edit.js +8 -7
  665. package/src/gallery/v1/gallery.native.js +1 -2
  666. package/src/gallery/v1/shared.js +7 -2
  667. package/src/group/block.json +3 -1
  668. package/src/group/edit.js +2 -6
  669. package/src/group/placeholder.js +6 -25
  670. package/src/group/test/__snapshots__/edit.native.js.snap +1 -1
  671. package/src/heading/block.json +1 -2
  672. package/src/heading/deprecated.js +209 -136
  673. package/src/heading/index.php +52 -0
  674. package/src/heading/test/__snapshots__/index.native.js.snap +7 -0
  675. package/src/heading/test/index.native.js +44 -0
  676. package/src/home-link/index.php +1 -1
  677. package/src/html/block.json +1 -1
  678. package/src/image/edit.js +7 -2
  679. package/src/image/edit.native.js +2 -1
  680. package/src/image/editor.scss +0 -11
  681. package/src/image/image.js +13 -8
  682. package/src/image/test/edit.native.js +14 -10
  683. package/src/index.js +2 -0
  684. package/src/latest-comments/edit.js +1 -0
  685. package/src/latest-posts/edit.js +2 -0
  686. package/src/list/test/edit.native.js +53 -45
  687. package/src/list/transforms.js +0 -11
  688. package/src/list/utils.js +6 -2
  689. package/src/list-item/index.js +2 -0
  690. package/src/list-item/transforms.js +17 -0
  691. package/src/list-item/utils.js +10 -1
  692. package/src/media-text/edit.js +5 -3
  693. package/src/missing/test/edit-integration.native.js +10 -12
  694. package/src/navigation/edit/are-blocks-dirty.js +51 -0
  695. package/src/navigation/edit/index.js +230 -298
  696. package/src/navigation/edit/menu-inspector-controls.js +78 -0
  697. package/src/navigation/edit/navigation-menu-selector.js +5 -16
  698. package/src/navigation/edit/test/are-blocks-dirty.js +121 -0
  699. package/src/navigation/edit/unsaved-inner-blocks.js +12 -7
  700. package/src/navigation/index.php +57 -10
  701. package/src/navigation/view-modal.js +11 -1
  702. package/src/navigation-link/edit.js +58 -329
  703. package/src/navigation-link/index.php +32 -0
  704. package/src/navigation-link/link-ui.js +213 -0
  705. package/src/navigation-link/test/edit.js +23 -82
  706. package/src/navigation-link/transforms.js +14 -0
  707. package/src/navigation-link/update-attributes.js +99 -0
  708. package/src/navigation-submenu/edit.js +57 -177
  709. package/src/navigation-submenu/index.php +40 -0
  710. package/src/page-list/block.json +6 -1
  711. package/src/page-list/constants.js +8 -0
  712. package/src/page-list/convert-to-links-modal.js +19 -76
  713. package/src/page-list/convert-to-navigation-links.js +60 -0
  714. package/src/page-list/edit.js +179 -118
  715. package/src/page-list/index.php +9 -0
  716. package/src/page-list/test/convert-to-links-modal.js +28 -34
  717. package/src/page-list-item/block.json +51 -0
  718. package/src/page-list-item/edit.js +94 -0
  719. package/src/page-list-item/index.js +24 -0
  720. package/src/page-list-item/init.js +6 -0
  721. package/src/paragraph/index.js +0 -6
  722. package/src/post-author/edit.js +3 -2
  723. package/src/post-content/index.php +1 -2
  724. package/src/post-featured-image/index.php +7 -2
  725. package/src/post-featured-image/overlay.js +1 -0
  726. package/src/post-template/block.json +8 -0
  727. package/src/preformatted/transforms.js +4 -1
  728. package/src/query/block.json +0 -8
  729. package/src/query/deprecated.js +257 -86
  730. package/src/query/edit/inspector-controls/index.js +1 -0
  731. package/src/query/edit/query-placeholder.js +4 -16
  732. package/src/rss/edit.js +3 -0
  733. package/src/search/edit.native.js +31 -27
  734. package/src/search/index.js +5 -1
  735. package/src/shortcode/test/edit.native.js +15 -18
  736. package/src/site-logo/edit.js +13 -5
  737. package/src/site-logo/index.js +1 -0
  738. package/src/site-title/index.js +1 -0
  739. package/src/social-link/social-list.js +2 -7
  740. package/src/social-link/test/index.native.js +10 -16
  741. package/src/social-links/test/edit.native.js +4 -3
  742. package/src/spacer/test/index.native.js +39 -36
  743. package/src/table/block.json +15 -0
  744. package/src/table/edit.js +2 -1
  745. package/src/table/editor.scss +0 -4
  746. package/src/table/index.js +1 -0
  747. package/src/table/save.js +5 -1
  748. package/src/table/state.js +22 -7
  749. package/src/table/transforms.js +2 -1
  750. package/src/table-of-contents/edit.js +2 -2
  751. package/src/tag-cloud/edit.js +3 -2
  752. package/src/template-part/edit/selection-modal.js +4 -3
  753. package/src/template-part/edit/utils/hooks.js +7 -3
  754. package/src/template-part/editor.scss +20 -2
  755. package/src/template-part/index.php +1 -2
  756. package/src/text-columns/edit.js +1 -0
  757. package/src/utils/transformation-categories.native.js +1 -0
  758. package/src/video/edit.js +1 -1
  759. package/src/video/edit.native.js +1 -2
  760. package/test/babel-plugin.js +35 -35
  761. package/tsconfig.tsbuildinfo +1 -1
@@ -14,18 +14,18 @@ import {
14
14
  useMemo,
15
15
  } from '@wordpress/element';
16
16
  import {
17
- __experimentalOffCanvasEditor as OffCanvasEditor,
18
17
  InspectorControls,
19
18
  useBlockProps,
20
19
  __experimentalRecursionProvider as RecursionProvider,
21
20
  __experimentalUseHasRecursion as useHasRecursion,
22
21
  store as blockEditorStore,
23
22
  withColors,
24
- PanelColorSettings,
25
23
  ContrastChecker,
26
24
  getColorClassName,
27
25
  Warning,
26
+ __experimentalColorGradientSettingsDropdown as ColorGradientSettingsDropdown,
28
27
  __experimentalUseBlockOverlayActive as useBlockOverlayActive,
28
+ __experimentalUseMultipleOriginColorsAndGradients as useMultipleOriginColorsAndGradients,
29
29
  } from '@wordpress/block-editor';
30
30
  import { EntityProvider, store as coreStore } from '@wordpress/core-data';
31
31
 
@@ -37,8 +37,6 @@ import {
37
37
  __experimentalToggleGroupControlOption as ToggleGroupControlOption,
38
38
  Button,
39
39
  Spinner,
40
- __experimentalHStack as HStack,
41
- __experimentalHeading as Heading,
42
40
  } from '@wordpress/components';
43
41
  import { __, sprintf } from '@wordpress/i18n';
44
42
  import { speak } from '@wordpress/a11y';
@@ -53,7 +51,6 @@ import useNavigationEntities from '../use-navigation-entities';
53
51
  import Placeholder from './placeholder';
54
52
  import ResponsiveWrapper from './responsive-wrapper';
55
53
  import NavigationInnerBlocks from './inner-blocks';
56
- import NavigationMenuSelector from './navigation-menu-selector';
57
54
  import NavigationMenuNameControl from './navigation-menu-name-control';
58
55
  import UnsavedInnerBlocks from './unsaved-inner-blocks';
59
56
  import NavigationMenuDeleteControl from './navigation-menu-delete-control';
@@ -69,6 +66,7 @@ import useCreateNavigationMenu from './use-create-navigation-menu';
69
66
  import { useInnerBlocks } from './use-inner-blocks';
70
67
  import { detectColors } from './utils';
71
68
  import ManageMenusButton from './manage-menus-button';
69
+ import MenuInspectorControls from './menu-inspector-controls';
72
70
 
73
71
  function Navigation( {
74
72
  attributes,
@@ -286,18 +284,37 @@ function Navigation( {
286
284
  ! hasResolvedNavigationMenus ||
287
285
  isConvertingClassicMenu ||
288
286
  fallbackNavigationMenus?.length > 0 ||
289
- classicMenus?.length !== 1
287
+ ! classicMenus?.length
290
288
  ) {
291
289
  return;
292
290
  }
293
291
 
294
292
  // If there's non fallback navigation menus and
295
- // only one classic menu then create a new navigation menu based on it.
296
- convertClassicMenu(
297
- classicMenus[ 0 ].id,
298
- classicMenus[ 0 ].name,
299
- 'publish'
293
+ // a classic menu with a `primary` location or slug,
294
+ // then create a new navigation menu based on it.
295
+ // Otherwise, use the most recently created classic menu.
296
+ const primaryMenus = classicMenus.filter(
297
+ ( classicMenu ) =>
298
+ classicMenu.locations.includes( 'primary' ) ||
299
+ classicMenu.slug === 'primary'
300
300
  );
301
+
302
+ if ( primaryMenus.length ) {
303
+ convertClassicMenu(
304
+ primaryMenus[ 0 ].id,
305
+ primaryMenus[ 0 ].name,
306
+ 'publish'
307
+ );
308
+ } else {
309
+ classicMenus.sort( ( a, b ) => {
310
+ return b.id - a.id;
311
+ } );
312
+ convertClassicMenu(
313
+ classicMenus[ 0 ].id,
314
+ classicMenus[ 0 ].name,
315
+ 'publish'
316
+ );
317
+ }
301
318
  }, [ hasResolvedNavigationMenus ] );
302
319
 
303
320
  const navRef = useRef();
@@ -396,6 +413,23 @@ function Navigation( {
396
413
  }
397
414
  };
398
415
 
416
+ const onSelectClassicMenu = async ( classicMenu ) => {
417
+ const navMenu = await convertClassicMenu(
418
+ classicMenu.id,
419
+ classicMenu.name,
420
+ 'draft'
421
+ );
422
+ if ( navMenu ) {
423
+ handleUpdateMenu( navMenu.id, {
424
+ focusNavigationBlock: true,
425
+ } );
426
+ }
427
+ };
428
+
429
+ const onSelectNavigationMenu = ( menuId ) => {
430
+ handleUpdateMenu( menuId );
431
+ };
432
+
399
433
  useEffect( () => {
400
434
  hideClassicMenuConversionNotice();
401
435
  if ( classicMenuConversionStatus === CLASSIC_MENU_CONVERSION_PENDING ) {
@@ -515,144 +549,157 @@ function Navigation( {
515
549
  } );
516
550
  }, [ isDraftNavigationMenu, navigationMenu ] );
517
551
 
552
+ const colorGradientSettings = useMultipleOriginColorsAndGradients();
518
553
  const stylingInspectorControls = (
519
- <InspectorControls>
520
- { hasSubmenuIndicatorSetting && (
521
- <PanelBody title={ __( 'Display' ) }>
522
- { isResponsive && (
523
- <>
524
- <Button
525
- className={ overlayMenuPreviewClasses }
526
- onClick={ () => {
527
- setOverlayMenuPreview(
528
- ! overlayMenuPreview
529
- );
530
- } }
531
- >
532
- { hasIcon && (
533
- <>
534
- <OverlayMenuIcon icon={ icon } />
535
- <Icon icon={ close } />
536
- </>
537
- ) }
538
- { ! hasIcon && (
539
- <>
540
- <span>{ __( 'Menu' ) }</span>
541
- <span>{ __( 'Close' ) }</span>
542
- </>
554
+ <>
555
+ <InspectorControls>
556
+ { hasSubmenuIndicatorSetting && (
557
+ <PanelBody title={ __( 'Display' ) }>
558
+ { isResponsive && (
559
+ <>
560
+ <Button
561
+ className={ overlayMenuPreviewClasses }
562
+ onClick={ () => {
563
+ setOverlayMenuPreview(
564
+ ! overlayMenuPreview
565
+ );
566
+ } }
567
+ >
568
+ { hasIcon && (
569
+ <>
570
+ <OverlayMenuIcon icon={ icon } />
571
+ <Icon icon={ close } />
572
+ </>
573
+ ) }
574
+ { ! hasIcon && (
575
+ <>
576
+ <span>{ __( 'Menu' ) }</span>
577
+ <span>{ __( 'Close' ) }</span>
578
+ </>
579
+ ) }
580
+ </Button>
581
+ { overlayMenuPreview && (
582
+ <OverlayMenuPreview
583
+ setAttributes={ setAttributes }
584
+ hasIcon={ hasIcon }
585
+ icon={ icon }
586
+ />
543
587
  ) }
544
- </Button>
545
- { overlayMenuPreview && (
546
- <OverlayMenuPreview
547
- setAttributes={ setAttributes }
548
- hasIcon={ hasIcon }
549
- icon={ icon }
550
- />
551
- ) }
552
- </>
553
- ) }
554
- <h3>{ __( 'Overlay Menu' ) }</h3>
555
- <ToggleGroupControl
556
- label={ __( 'Configure overlay menu' ) }
557
- value={ overlayMenu }
558
- help={ __(
559
- 'Collapses the navigation options in a menu icon opening an overlay.'
588
+ </>
560
589
  ) }
561
- onChange={ ( value ) =>
562
- setAttributes( { overlayMenu: value } )
563
- }
564
- isBlock
565
- hideLabelFromVision
566
- >
567
- <ToggleGroupControlOption
568
- value="never"
569
- label={ __( 'Off' ) }
570
- />
571
- <ToggleGroupControlOption
572
- value="mobile"
573
- label={ __( 'Mobile' ) }
574
- />
575
- <ToggleGroupControlOption
576
- value="always"
577
- label={ __( 'Always' ) }
578
- />
579
- </ToggleGroupControl>
580
- { hasSubmenus && (
581
- <>
582
- <h3>{ __( 'Submenus' ) }</h3>
583
- <ToggleControl
584
- checked={ openSubmenusOnClick }
585
- onChange={ ( value ) => {
586
- setAttributes( {
587
- openSubmenusOnClick: value,
588
- ...( value && {
589
- showSubmenuIcon: true,
590
- } ), // Make sure arrows are shown when we toggle this on.
591
- } );
592
- } }
593
- label={ __( 'Open on click' ) }
594
- />
595
-
596
- <ToggleControl
597
- checked={ showSubmenuIcon }
598
- onChange={ ( value ) => {
599
- setAttributes( {
600
- showSubmenuIcon: value,
601
- } );
602
- } }
603
- disabled={ attributes.openSubmenusOnClick }
604
- label={ __( 'Show arrow' ) }
590
+ <h3>{ __( 'Overlay Menu' ) }</h3>
591
+ <ToggleGroupControl
592
+ label={ __( 'Configure overlay menu' ) }
593
+ value={ overlayMenu }
594
+ help={ __(
595
+ 'Collapses the navigation options in a menu icon opening an overlay.'
596
+ ) }
597
+ onChange={ ( value ) =>
598
+ setAttributes( { overlayMenu: value } )
599
+ }
600
+ isBlock
601
+ hideLabelFromVision
602
+ >
603
+ <ToggleGroupControlOption
604
+ value="never"
605
+ label={ __( 'Off' ) }
605
606
  />
606
- </>
607
- ) }
608
- </PanelBody>
609
- ) }
610
- { hasColorSettings && (
611
- <PanelColorSettings
612
- __experimentalHasMultipleOrigins
613
- __experimentalIsRenderedInSidebar
614
- title={ __( 'Color' ) }
615
- initialOpen={ false }
616
- colorSettings={ [
617
- {
618
- value: textColor.color,
619
- onChange: setTextColor,
620
- label: __( 'Text' ),
621
- },
622
- {
623
- value: backgroundColor.color,
624
- onChange: setBackgroundColor,
625
- label: __( 'Background' ),
626
- },
627
- {
628
- value: overlayTextColor.color,
629
- onChange: setOverlayTextColor,
630
- label: __( 'Submenu & overlay text' ),
631
- },
632
- {
633
- value: overlayBackgroundColor.color,
634
- onChange: setOverlayBackgroundColor,
635
- label: __( 'Submenu & overlay background' ),
636
- },
637
- ] }
638
- >
639
- { enableContrastChecking && (
640
- <>
641
- <ContrastChecker
642
- backgroundColor={ detectedBackgroundColor }
643
- textColor={ detectedColor }
607
+ <ToggleGroupControlOption
608
+ value="mobile"
609
+ label={ __( 'Mobile' ) }
644
610
  />
645
- <ContrastChecker
646
- backgroundColor={
647
- detectedOverlayBackgroundColor
648
- }
649
- textColor={ detectedOverlayColor }
611
+ <ToggleGroupControlOption
612
+ value="always"
613
+ label={ __( 'Always' ) }
650
614
  />
651
- </>
652
- ) }
653
- </PanelColorSettings>
654
- ) }
655
- </InspectorControls>
615
+ </ToggleGroupControl>
616
+ { hasSubmenus && (
617
+ <>
618
+ <h3>{ __( 'Submenus' ) }</h3>
619
+ <ToggleControl
620
+ checked={ openSubmenusOnClick }
621
+ onChange={ ( value ) => {
622
+ setAttributes( {
623
+ openSubmenusOnClick: value,
624
+ ...( value && {
625
+ showSubmenuIcon: true,
626
+ } ), // Make sure arrows are shown when we toggle this on.
627
+ } );
628
+ } }
629
+ label={ __( 'Open on click' ) }
630
+ />
631
+
632
+ <ToggleControl
633
+ checked={ showSubmenuIcon }
634
+ onChange={ ( value ) => {
635
+ setAttributes( {
636
+ showSubmenuIcon: value,
637
+ } );
638
+ } }
639
+ disabled={ attributes.openSubmenusOnClick }
640
+ label={ __( 'Show arrow' ) }
641
+ />
642
+ </>
643
+ ) }
644
+ </PanelBody>
645
+ ) }
646
+ </InspectorControls>
647
+ <InspectorControls __experimentalGroup="color">
648
+ { hasColorSettings && (
649
+ <>
650
+ <ColorGradientSettingsDropdown
651
+ __experimentalHasMultipleOrigins
652
+ __experimentalIsRenderedInSidebar
653
+ settings={ [
654
+ {
655
+ colorValue: textColor.color,
656
+ label: __( 'Text' ),
657
+ onColorChange: setTextColor,
658
+ resetAllFilter: () => setTextColor(),
659
+ },
660
+ {
661
+ colorValue: backgroundColor.color,
662
+ label: __( 'Background' ),
663
+ onColorChange: setBackgroundColor,
664
+ resetAllFilter: () => setBackgroundColor(),
665
+ },
666
+ {
667
+ colorValue: overlayTextColor.color,
668
+ label: __( 'Submenu & overlay text' ),
669
+ onColorChange: setOverlayTextColor,
670
+ resetAllFilter: () => setOverlayTextColor(),
671
+ },
672
+ {
673
+ colorValue: overlayBackgroundColor.color,
674
+ label: __( 'Submenu & overlay background' ),
675
+ onColorChange: setOverlayBackgroundColor,
676
+ resetAllFilter: () =>
677
+ setOverlayBackgroundColor(),
678
+ },
679
+ ] }
680
+ panelId={ clientId }
681
+ { ...colorGradientSettings }
682
+ gradients={ [] }
683
+ disableCustomGradients={ true }
684
+ />
685
+ { enableContrastChecking && (
686
+ <>
687
+ <ContrastChecker
688
+ backgroundColor={ detectedBackgroundColor }
689
+ textColor={ detectedColor }
690
+ />
691
+ <ContrastChecker
692
+ backgroundColor={
693
+ detectedOverlayBackgroundColor
694
+ }
695
+ textColor={ detectedOverlayColor }
696
+ />
697
+ </>
698
+ ) }
699
+ </>
700
+ ) }
701
+ </InspectorControls>
702
+ </>
656
703
  );
657
704
 
658
705
  // If the block has inner blocks, but no menu id, then these blocks are either:
@@ -663,78 +710,25 @@ function Navigation( {
663
710
  // that automatically saves the menu as an entity when changes are made to the inner blocks.
664
711
  const hasUnsavedBlocks = hasUncontrolledInnerBlocks && ! isEntityAvailable;
665
712
 
666
- const WrappedNavigationMenuSelector = ( { currentMenuId } ) => (
667
- <NavigationMenuSelector
668
- currentMenuId={ currentMenuId }
669
- clientId={ clientId }
670
- onSelectNavigationMenu={ ( menuId ) => {
671
- handleUpdateMenu( menuId );
672
- } }
673
- onSelectClassicMenu={ async ( classicMenu ) => {
674
- const navMenu = await convertClassicMenu(
675
- classicMenu.id,
676
- classicMenu.name,
677
- 'draft'
678
- );
679
- if ( navMenu ) {
680
- handleUpdateMenu( navMenu.id, {
681
- focusNavigationBlock: true,
682
- } );
683
- }
684
- } }
685
- onCreateNew={ createUntitledEmptyNavigationMenu }
686
- createNavigationMenuIsSuccess={ createNavigationMenuIsSuccess }
687
- createNavigationMenuIsError={ createNavigationMenuIsError }
688
- /* translators: %s: The name of a menu. */
689
- actionLabel={ __( "Switch to '%s'" ) }
690
- />
691
- );
692
-
693
713
  const isManageMenusButtonDisabled =
694
714
  ! hasManagePermissions || ! hasResolvedNavigationMenus;
695
715
 
696
716
  if ( hasUnsavedBlocks && ! isCreatingNavigationMenu ) {
697
717
  return (
698
718
  <TagName { ...blockProps }>
699
- <InspectorControls>
700
- <PanelBody
701
- title={
702
- isOffCanvasNavigationEditorEnabled
703
- ? null
704
- : __( 'Menu' )
705
- }
706
- >
707
- { isOffCanvasNavigationEditorEnabled ? (
708
- <>
709
- <HStack className="wp-block-navigation-off-canvas-editor__header">
710
- <Heading
711
- className="wp-block-navigation-off-canvas-editor__title"
712
- level={ 2 }
713
- >
714
- { __( 'Menu' ) }
715
- </Heading>
716
- <WrappedNavigationMenuSelector
717
- currentMenuId={ ref }
718
- />
719
- </HStack>
720
- <OffCanvasEditor
721
- blocks={ innerBlocks }
722
- isExpanded={ true }
723
- selectBlockInCanvas={ false }
724
- />
725
- </>
726
- ) : (
727
- <>
728
- <WrappedNavigationMenuSelector
729
- currentMenuId={ ref }
730
- />
731
- <ManageMenusButton
732
- disabled={ isManageMenusButtonDisabled }
733
- />
734
- </>
735
- ) }
736
- </PanelBody>
737
- </InspectorControls>
719
+ <MenuInspectorControls
720
+ createNavigationMenuIsSuccess={
721
+ createNavigationMenuIsSuccess
722
+ }
723
+ createNavigationMenuIsError={ createNavigationMenuIsError }
724
+ currentMenuId={ ref }
725
+ isNavigationMenuMissing={ isNavigationMenuMissing }
726
+ innerBlocks={ innerBlocks }
727
+ isManageMenusButtonDisabled={ isManageMenusButtonDisabled }
728
+ onCreateNew={ createUntitledEmptyNavigationMenu }
729
+ onSelectClassicMenu={ onSelectClassicMenu }
730
+ onSelectNavigationMenu={ onSelectNavigationMenu }
731
+ />
738
732
  { stylingInspectorControls }
739
733
  <ResponsiveWrapper
740
734
  id={ clientId }
@@ -764,41 +758,18 @@ function Navigation( {
764
758
  if ( ref && isNavigationMenuMissing ) {
765
759
  return (
766
760
  <TagName { ...blockProps }>
767
- <InspectorControls>
768
- <PanelBody
769
- title={
770
- isOffCanvasNavigationEditorEnabled
771
- ? null
772
- : __( 'Menu' )
773
- }
774
- >
775
- { isOffCanvasNavigationEditorEnabled ? (
776
- <>
777
- <HStack className="wp-block-navigation-off-canvas-editor__header">
778
- <Heading
779
- className="wp-block-navigation-off-canvas-editor__title"
780
- level={ 2 }
781
- >
782
- { __( 'Menu' ) }
783
- </Heading>
784
- <WrappedNavigationMenuSelector
785
- currentMenuId={ null }
786
- />
787
- </HStack>
788
- <p>Select or create a menu</p>
789
- </>
790
- ) : (
791
- <>
792
- <WrappedNavigationMenuSelector
793
- currentMenuId={ null }
794
- />
795
- <ManageMenusButton
796
- disabled={ isManageMenusButtonDisabled }
797
- />
798
- </>
799
- ) }
800
- </PanelBody>
801
- </InspectorControls>
761
+ <MenuInspectorControls
762
+ createNavigationMenuIsSuccess={
763
+ createNavigationMenuIsSuccess
764
+ }
765
+ createNavigationMenuIsError={ createNavigationMenuIsError }
766
+ isNavigationMenuMissing={ isNavigationMenuMissing }
767
+ innerBlocks={ innerBlocks }
768
+ isManageMenusButtonDisabled={ isManageMenusButtonDisabled }
769
+ onCreateNew={ createUntitledEmptyNavigationMenu }
770
+ onSelectClassicMenu={ onSelectClassicMenu }
771
+ onSelectNavigationMenu={ onSelectNavigationMenu }
772
+ />
802
773
  <Warning>
803
774
  { __(
804
775
  'Navigation menu has been deleted or is unavailable. '
@@ -849,21 +820,8 @@ function Navigation( {
849
820
  isResolvingCanUserCreateNavigationMenu={
850
821
  isResolvingCanUserCreateNavigationMenu
851
822
  }
852
- onSelectNavigationMenu={ ( menuId ) => {
853
- handleUpdateMenu( menuId );
854
- } }
855
- onSelectClassicMenu={ async ( classicMenu ) => {
856
- const navMenu = await convertClassicMenu(
857
- classicMenu.id,
858
- classicMenu.name,
859
- 'draft'
860
- );
861
- if ( navMenu ) {
862
- handleUpdateMenu( navMenu.id, {
863
- focusNavigationBlock: true,
864
- } );
865
- }
866
- } }
823
+ onSelectNavigationMenu={ onSelectNavigationMenu }
824
+ onSelectClassicMenu={ onSelectClassicMenu }
867
825
  onCreateEmpty={ createUntitledEmptyNavigationMenu }
868
826
  />
869
827
  </TagName>
@@ -873,45 +831,19 @@ function Navigation( {
873
831
  return (
874
832
  <EntityProvider kind="postType" type="wp_navigation" id={ ref }>
875
833
  <RecursionProvider uniqueId={ recursionId }>
876
- <InspectorControls>
877
- <PanelBody
878
- title={
879
- isOffCanvasNavigationEditorEnabled
880
- ? null
881
- : __( 'Menu' )
882
- }
883
- >
884
- { isOffCanvasNavigationEditorEnabled ? (
885
- <>
886
- <HStack className="wp-block-navigation-off-canvas-editor__header">
887
- <Heading
888
- className="wp-block-navigation-off-canvas-editor__title"
889
- level={ 2 }
890
- >
891
- { __( 'Menu' ) }
892
- </Heading>
893
- <WrappedNavigationMenuSelector
894
- currentMenuId={ ref }
895
- />
896
- </HStack>
897
- <OffCanvasEditor
898
- blocks={ innerBlocks }
899
- isExpanded={ true }
900
- selectBlockInCanvas={ false }
901
- />
902
- </>
903
- ) : (
904
- <>
905
- <WrappedNavigationMenuSelector
906
- currentMenuId={ ref }
907
- />
908
- <ManageMenusButton
909
- disabled={ isManageMenusButtonDisabled }
910
- />
911
- </>
912
- ) }
913
- </PanelBody>
914
- </InspectorControls>
834
+ <MenuInspectorControls
835
+ createNavigationMenuIsSuccess={
836
+ createNavigationMenuIsSuccess
837
+ }
838
+ createNavigationMenuIsError={ createNavigationMenuIsError }
839
+ currentMenuId={ ref }
840
+ isNavigationMenuMissing={ isNavigationMenuMissing }
841
+ innerBlocks={ innerBlocks }
842
+ isManageMenusButtonDisabled={ isManageMenusButtonDisabled }
843
+ onCreateNew={ createUntitledEmptyNavigationMenu }
844
+ onSelectClassicMenu={ onSelectClassicMenu }
845
+ onSelectNavigationMenu={ onSelectNavigationMenu }
846
+ />
915
847
  { stylingInspectorControls }
916
848
  { isEntityAvailable && (
917
849
  <InspectorControls __experimentalGroup="advanced">