@wordpress/edit-site 5.14.0 → 5.16.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 (461) hide show
  1. package/CHANGELOG.md +4 -0
  2. package/build/components/add-new-page/index.js +1 -6
  3. package/build/components/add-new-page/index.js.map +1 -1
  4. package/build/components/add-new-pattern/index.js +22 -7
  5. package/build/components/add-new-pattern/index.js.map +1 -1
  6. package/build/components/add-new-template/utils.js +10 -8
  7. package/build/components/add-new-template/utils.js.map +1 -1
  8. package/build/components/block-editor/constants.js +1 -1
  9. package/build/components/block-editor/constants.js.map +1 -1
  10. package/build/components/block-editor/editor-canvas.js +1 -1
  11. package/build/components/block-editor/editor-canvas.js.map +1 -1
  12. package/build/components/block-editor/index.js +0 -4
  13. package/build/components/block-editor/index.js.map +1 -1
  14. package/build/components/block-editor/use-site-editor-settings.js +114 -13
  15. package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
  16. package/build/components/code-editor/index.js +60 -28
  17. package/build/components/code-editor/index.js.map +1 -1
  18. package/build/components/create-pattern-modal/index.js +7 -3
  19. package/build/components/create-pattern-modal/index.js.map +1 -1
  20. package/build/components/editor/index.js +5 -5
  21. package/build/components/editor/index.js.map +1 -1
  22. package/build/components/global-styles/global-styles-provider.js +12 -7
  23. package/build/components/global-styles/global-styles-provider.js.map +1 -1
  24. package/build/components/global-styles/screen-block.js +16 -0
  25. package/build/components/global-styles/screen-block.js.map +1 -1
  26. package/build/components/global-styles/screen-revisions/index.js +12 -5
  27. package/build/components/global-styles/screen-revisions/index.js.map +1 -1
  28. package/build/components/global-styles/screen-revisions/revisions-buttons.js +10 -22
  29. package/build/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  30. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js +32 -25
  31. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  32. package/build/components/global-styles/style-variations-container.js +5 -3
  33. package/build/components/global-styles/style-variations-container.js.map +1 -1
  34. package/build/components/header-edit-mode/document-actions/index.js +4 -2
  35. package/build/components/header-edit-mode/document-actions/index.js.map +1 -1
  36. package/build/components/header-edit-mode/index.js +13 -9
  37. package/build/components/header-edit-mode/index.js.map +1 -1
  38. package/build/components/keyboard-shortcuts/edit-mode.js +7 -5
  39. package/build/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  40. package/build/components/layout/index.js +17 -5
  41. package/build/components/layout/index.js.map +1 -1
  42. package/build/components/page/index.js +3 -3
  43. package/build/components/page/index.js.map +1 -1
  44. package/build/components/page-actions/index.js +2 -2
  45. package/build/components/page-actions/index.js.map +1 -1
  46. package/build/components/page-actions/{delete-page-menu-item.js → trash-page-menu-item.js} +8 -16
  47. package/build/components/page-actions/trash-page-menu-item.js.map +1 -0
  48. package/build/components/page-content-focus-manager/disable-non-page-content-blocks.js +5 -5
  49. package/build/components/page-content-focus-manager/disable-non-page-content-blocks.js.map +1 -1
  50. package/build/components/page-patterns/duplicate-menu-item.js +163 -0
  51. package/build/components/page-patterns/duplicate-menu-item.js.map +1 -0
  52. package/build/components/page-patterns/grid-item.js +83 -58
  53. package/build/components/page-patterns/grid-item.js.map +1 -1
  54. package/build/components/page-patterns/grid.js +5 -18
  55. package/build/components/page-patterns/grid.js.map +1 -1
  56. package/build/components/page-patterns/header.js +69 -0
  57. package/build/components/page-patterns/header.js.map +1 -0
  58. package/build/components/page-patterns/index.js +3 -1
  59. package/build/components/page-patterns/index.js.map +1 -1
  60. package/build/components/page-patterns/pagination.js +63 -0
  61. package/build/components/page-patterns/pagination.js.map +1 -0
  62. package/build/components/page-patterns/patterns-list.js +110 -31
  63. package/build/components/page-patterns/patterns-list.js.map +1 -1
  64. package/build/components/page-patterns/rename-menu-item.js +109 -0
  65. package/build/components/page-patterns/rename-menu-item.js.map +1 -0
  66. package/build/components/page-patterns/use-patterns.js +116 -118
  67. package/build/components/page-patterns/use-patterns.js.map +1 -1
  68. package/build/components/page-template-parts/add-new-template-part.js +74 -0
  69. package/build/components/page-template-parts/add-new-template-part.js.map +1 -0
  70. package/build/components/page-template-parts/index.js +3 -25
  71. package/build/components/page-template-parts/index.js.map +1 -1
  72. package/build/components/page-templates/index.js +1 -16
  73. package/build/components/page-templates/index.js.map +1 -1
  74. package/build/components/resizable-frame/index.js +85 -51
  75. package/build/components/resizable-frame/index.js.map +1 -1
  76. package/build/components/save-button/index.js +4 -2
  77. package/build/components/save-button/index.js.map +1 -1
  78. package/build/components/save-hub/index.js +10 -4
  79. package/build/components/save-hub/index.js.map +1 -1
  80. package/build/components/save-panel/index.js +5 -5
  81. package/build/components/save-panel/index.js.map +1 -1
  82. package/build/components/sidebar-edit-mode/page-panels/page-content.js +4 -3
  83. package/build/components/sidebar-edit-mode/page-panels/page-content.js.map +1 -1
  84. package/build/components/sidebar-edit-mode/page-panels/page-status.js +3 -8
  85. package/build/components/sidebar-edit-mode/page-panels/page-status.js.map +1 -1
  86. package/build/components/sidebar-edit-mode/template-panel/index.js +15 -8
  87. package/build/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  88. package/build/components/sidebar-navigation-screen/index.js +31 -15
  89. package/build/components/sidebar-navigation-screen/index.js.map +1 -1
  90. package/build/components/sidebar-navigation-screen-global-styles/index.js +34 -40
  91. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  92. package/build/components/sidebar-navigation-screen-main/index.js +4 -2
  93. package/build/components/sidebar-navigation-screen-main/index.js.map +1 -1
  94. package/build/components/sidebar-navigation-screen-main/template-part-hint.js +45 -0
  95. package/build/components/sidebar-navigation-screen-main/template-part-hint.js.map +1 -0
  96. package/build/components/sidebar-navigation-screen-navigation-menu/index.js +4 -4
  97. package/build/components/sidebar-navigation-screen-navigation-menu/index.js.map +1 -1
  98. package/build/components/sidebar-navigation-screen-navigation-menu/more-menu.js +1 -0
  99. package/build/components/sidebar-navigation-screen-navigation-menu/more-menu.js.map +1 -1
  100. package/build/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +3 -3
  101. package/build/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js.map +1 -1
  102. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +5 -4
  103. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  104. package/build/components/sidebar-navigation-screen-navigation-menus/constants.js +2 -0
  105. package/build/components/sidebar-navigation-screen-navigation-menus/constants.js.map +1 -1
  106. package/build/components/sidebar-navigation-screen-navigation-menus/index.js +4 -4
  107. package/build/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  108. package/build/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +8 -0
  109. package/build/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js.map +1 -1
  110. package/build/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +1 -1
  111. package/build/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js.map +1 -1
  112. package/build/components/sidebar-navigation-screen-page/index.js +2 -3
  113. package/build/components/sidebar-navigation-screen-page/index.js.map +1 -1
  114. package/build/components/sidebar-navigation-screen-page/status-label.js +1 -34
  115. package/build/components/sidebar-navigation-screen-page/status-label.js.map +1 -1
  116. package/build/components/sidebar-navigation-screen-pages/index.js +35 -25
  117. package/build/components/sidebar-navigation-screen-pages/index.js.map +1 -1
  118. package/build/components/sidebar-navigation-screen-pattern/index.js +9 -7
  119. package/build/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  120. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +4 -3
  121. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  122. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js +3 -2
  123. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js.map +1 -1
  124. package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +19 -4
  125. package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js.map +1 -1
  126. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js +55 -28
  127. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  128. package/build/components/sidebar-navigation-screen-patterns/category-item.js +0 -5
  129. package/build/components/sidebar-navigation-screen-patterns/category-item.js.map +1 -1
  130. package/build/components/sidebar-navigation-screen-patterns/index.js +72 -60
  131. package/build/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  132. package/build/components/sidebar-navigation-screen-patterns/use-my-patterns.js +9 -5
  133. package/build/components/sidebar-navigation-screen-patterns/use-my-patterns.js.map +1 -1
  134. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +11 -1
  135. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  136. package/build/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +20 -9
  137. package/build/components/sidebar-navigation-screen-patterns/use-template-part-areas.js.map +1 -1
  138. package/build/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +1 -1
  139. package/build/components/sidebar-navigation-screen-patterns/use-theme-patterns.js.map +1 -1
  140. package/build/components/sidebar-navigation-screen-templates/index.js +1 -10
  141. package/build/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  142. package/build/components/sidebar-navigation-screen-templates-browse/index.js +9 -0
  143. package/build/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  144. package/build/components/site-hub/index.js +29 -13
  145. package/build/components/site-hub/index.js.map +1 -1
  146. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +10 -5
  147. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  148. package/build/components/sync-state-with-url/use-sync-canvas-mode-with-url.js +1 -1
  149. package/build/components/sync-state-with-url/use-sync-canvas-mode-with-url.js.map +1 -1
  150. package/build/components/sync-state-with-url/use-sync-path-with-url.js +15 -12
  151. package/build/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  152. package/build/components/template-actions/index.js +3 -1
  153. package/build/components/template-actions/index.js.map +1 -1
  154. package/build/components/template-actions/rename-menu-item.js +12 -8
  155. package/build/components/template-actions/rename-menu-item.js.map +1 -1
  156. package/build/components/use-edited-entity-record/index.js +6 -1
  157. package/build/components/use-edited-entity-record/index.js.map +1 -1
  158. package/build/hooks/commands/use-common-commands.js +120 -32
  159. package/build/hooks/commands/use-common-commands.js.map +1 -1
  160. package/build/hooks/commands/use-edit-mode-commands.js +65 -7
  161. package/build/hooks/commands/use-edit-mode-commands.js.map +1 -1
  162. package/build/hooks/push-changes-to-global-styles/index.js +138 -57
  163. package/build/hooks/push-changes-to-global-styles/index.js.map +1 -1
  164. package/build/store/private-actions.js +9 -2
  165. package/build/store/private-actions.js.map +1 -1
  166. package/build/utils/normalize-record-key.js +19 -0
  167. package/build/utils/normalize-record-key.js.map +1 -0
  168. package/build/utils/use-activate-theme.js +1 -1
  169. package/build/utils/use-activate-theme.js.map +1 -1
  170. package/build/utils/use-debounced-input.js +5 -7
  171. package/build/utils/use-debounced-input.js.map +1 -1
  172. package/build-module/components/add-new-page/index.js +1 -6
  173. package/build-module/components/add-new-page/index.js.map +1 -1
  174. package/build-module/components/add-new-pattern/index.js +20 -7
  175. package/build-module/components/add-new-pattern/index.js.map +1 -1
  176. package/build-module/components/add-new-template/utils.js +9 -6
  177. package/build-module/components/add-new-template/utils.js.map +1 -1
  178. package/build-module/components/block-editor/constants.js +1 -1
  179. package/build-module/components/block-editor/constants.js.map +1 -1
  180. package/build-module/components/block-editor/editor-canvas.js +1 -1
  181. package/build-module/components/block-editor/editor-canvas.js.map +1 -1
  182. package/build-module/components/block-editor/index.js +0 -4
  183. package/build-module/components/block-editor/index.js.map +1 -1
  184. package/build-module/components/block-editor/use-site-editor-settings.js +116 -14
  185. package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
  186. package/build-module/components/code-editor/index.js +62 -30
  187. package/build-module/components/code-editor/index.js.map +1 -1
  188. package/build-module/components/create-pattern-modal/index.js +6 -3
  189. package/build-module/components/create-pattern-modal/index.js.map +1 -1
  190. package/build-module/components/editor/index.js +5 -5
  191. package/build-module/components/editor/index.js.map +1 -1
  192. package/build-module/components/global-styles/global-styles-provider.js +12 -7
  193. package/build-module/components/global-styles/global-styles-provider.js.map +1 -1
  194. package/build-module/components/global-styles/screen-block.js +16 -0
  195. package/build-module/components/global-styles/screen-block.js.map +1 -1
  196. package/build-module/components/global-styles/screen-revisions/index.js +13 -6
  197. package/build-module/components/global-styles/screen-revisions/index.js.map +1 -1
  198. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js +10 -22
  199. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  200. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js +28 -21
  201. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  202. package/build-module/components/global-styles/style-variations-container.js +5 -3
  203. package/build-module/components/global-styles/style-variations-container.js.map +1 -1
  204. package/build-module/components/header-edit-mode/document-actions/index.js +6 -4
  205. package/build-module/components/header-edit-mode/document-actions/index.js.map +1 -1
  206. package/build-module/components/header-edit-mode/index.js +13 -9
  207. package/build-module/components/header-edit-mode/index.js.map +1 -1
  208. package/build-module/components/keyboard-shortcuts/edit-mode.js +7 -5
  209. package/build-module/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  210. package/build-module/components/layout/index.js +17 -5
  211. package/build-module/components/layout/index.js.map +1 -1
  212. package/build-module/components/page/index.js +3 -3
  213. package/build-module/components/page/index.js.map +1 -1
  214. package/build-module/components/page-actions/index.js +2 -2
  215. package/build-module/components/page-actions/index.js.map +1 -1
  216. package/build-module/components/page-actions/{delete-page-menu-item.js → trash-page-menu-item.js} +8 -17
  217. package/build-module/components/page-actions/trash-page-menu-item.js.map +1 -0
  218. package/build-module/components/page-content-focus-manager/disable-non-page-content-blocks.js +5 -3
  219. package/build-module/components/page-content-focus-manager/disable-non-page-content-blocks.js.map +1 -1
  220. package/build-module/components/page-patterns/duplicate-menu-item.js +147 -0
  221. package/build-module/components/page-patterns/duplicate-menu-item.js.map +1 -0
  222. package/build-module/components/page-patterns/grid-item.js +84 -64
  223. package/build-module/components/page-patterns/grid-item.js.map +1 -1
  224. package/build-module/components/page-patterns/grid.js +5 -17
  225. package/build-module/components/page-patterns/grid.js.map +1 -1
  226. package/build-module/components/page-patterns/header.js +54 -0
  227. package/build-module/components/page-patterns/header.js.map +1 -0
  228. package/build-module/components/page-patterns/index.js +3 -1
  229. package/build-module/components/page-patterns/index.js.map +1 -1
  230. package/build-module/components/page-patterns/pagination.js +54 -0
  231. package/build-module/components/page-patterns/pagination.js.map +1 -0
  232. package/build-module/components/page-patterns/patterns-list.js +111 -34
  233. package/build-module/components/page-patterns/patterns-list.js.map +1 -1
  234. package/build-module/components/page-patterns/rename-menu-item.js +97 -0
  235. package/build-module/components/page-patterns/rename-menu-item.js.map +1 -0
  236. package/build-module/components/page-patterns/use-patterns.js +116 -119
  237. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  238. package/build-module/components/page-template-parts/add-new-template-part.js +58 -0
  239. package/build-module/components/page-template-parts/add-new-template-part.js.map +1 -0
  240. package/build-module/components/page-template-parts/index.js +4 -24
  241. package/build-module/components/page-template-parts/index.js.map +1 -1
  242. package/build-module/components/page-templates/index.js +2 -15
  243. package/build-module/components/page-templates/index.js.map +1 -1
  244. package/build-module/components/resizable-frame/index.js +87 -55
  245. package/build-module/components/resizable-frame/index.js.map +1 -1
  246. package/build-module/components/save-button/index.js +4 -2
  247. package/build-module/components/save-button/index.js.map +1 -1
  248. package/build-module/components/save-hub/index.js +10 -4
  249. package/build-module/components/save-hub/index.js.map +1 -1
  250. package/build-module/components/save-panel/index.js +5 -5
  251. package/build-module/components/save-panel/index.js.map +1 -1
  252. package/build-module/components/sidebar-edit-mode/page-panels/page-content.js +5 -2
  253. package/build-module/components/sidebar-edit-mode/page-panels/page-content.js.map +1 -1
  254. package/build-module/components/sidebar-edit-mode/page-panels/page-status.js +3 -8
  255. package/build-module/components/sidebar-edit-mode/page-panels/page-status.js.map +1 -1
  256. package/build-module/components/sidebar-edit-mode/template-panel/index.js +15 -9
  257. package/build-module/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  258. package/build-module/components/sidebar-navigation-screen/index.js +29 -16
  259. package/build-module/components/sidebar-navigation-screen/index.js.map +1 -1
  260. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +34 -40
  261. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  262. package/build-module/components/sidebar-navigation-screen-main/index.js +4 -3
  263. package/build-module/components/sidebar-navigation-screen-main/index.js.map +1 -1
  264. package/build-module/components/sidebar-navigation-screen-main/template-part-hint.js +33 -0
  265. package/build-module/components/sidebar-navigation-screen-main/template-part-hint.js.map +1 -0
  266. package/build-module/components/sidebar-navigation-screen-navigation-menu/index.js +4 -4
  267. package/build-module/components/sidebar-navigation-screen-navigation-menu/index.js.map +1 -1
  268. package/build-module/components/sidebar-navigation-screen-navigation-menu/more-menu.js +1 -0
  269. package/build-module/components/sidebar-navigation-screen-navigation-menu/more-menu.js.map +1 -1
  270. package/build-module/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +3 -3
  271. package/build-module/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js.map +1 -1
  272. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +5 -4
  273. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  274. package/build-module/components/sidebar-navigation-screen-navigation-menus/constants.js +2 -0
  275. package/build-module/components/sidebar-navigation-screen-navigation-menus/constants.js.map +1 -1
  276. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js +4 -4
  277. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  278. package/build-module/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +7 -0
  279. package/build-module/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js.map +1 -1
  280. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +2 -2
  281. package/build-module/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js.map +1 -1
  282. package/build-module/components/sidebar-navigation-screen-page/index.js +2 -3
  283. package/build-module/components/sidebar-navigation-screen-page/index.js.map +1 -1
  284. package/build-module/components/sidebar-navigation-screen-page/status-label.js +1 -32
  285. package/build-module/components/sidebar-navigation-screen-page/status-label.js.map +1 -1
  286. package/build-module/components/sidebar-navigation-screen-pages/index.js +35 -25
  287. package/build-module/components/sidebar-navigation-screen-pages/index.js.map +1 -1
  288. package/build-module/components/sidebar-navigation-screen-pattern/index.js +8 -7
  289. package/build-module/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  290. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +4 -3
  291. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  292. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js +3 -2
  293. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js.map +1 -1
  294. package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +18 -4
  295. package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js.map +1 -1
  296. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js +53 -28
  297. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  298. package/build-module/components/sidebar-navigation-screen-patterns/category-item.js +0 -5
  299. package/build-module/components/sidebar-navigation-screen-patterns/category-item.js.map +1 -1
  300. package/build-module/components/sidebar-navigation-screen-patterns/index.js +76 -60
  301. package/build-module/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  302. package/build-module/components/sidebar-navigation-screen-patterns/use-my-patterns.js +9 -5
  303. package/build-module/components/sidebar-navigation-screen-patterns/use-my-patterns.js.map +1 -1
  304. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +10 -1
  305. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  306. package/build-module/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +18 -9
  307. package/build-module/components/sidebar-navigation-screen-patterns/use-template-part-areas.js.map +1 -1
  308. package/build-module/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +1 -1
  309. package/build-module/components/sidebar-navigation-screen-patterns/use-theme-patterns.js.map +1 -1
  310. package/build-module/components/sidebar-navigation-screen-templates/index.js +1 -8
  311. package/build-module/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  312. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js +7 -0
  313. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  314. package/build-module/components/site-hub/index.js +28 -13
  315. package/build-module/components/site-hub/index.js.map +1 -1
  316. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +7 -5
  317. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  318. package/build-module/components/sync-state-with-url/use-sync-canvas-mode-with-url.js +1 -1
  319. package/build-module/components/sync-state-with-url/use-sync-canvas-mode-with-url.js.map +1 -1
  320. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js +16 -12
  321. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  322. package/build-module/components/template-actions/index.js +2 -1
  323. package/build-module/components/template-actions/index.js.map +1 -1
  324. package/build-module/components/template-actions/rename-menu-item.js +11 -8
  325. package/build-module/components/template-actions/rename-menu-item.js.map +1 -1
  326. package/build-module/components/use-edited-entity-record/index.js +3 -1
  327. package/build-module/components/use-edited-entity-record/index.js.map +1 -1
  328. package/build-module/hooks/commands/use-common-commands.js +116 -32
  329. package/build-module/hooks/commands/use-common-commands.js.map +1 -1
  330. package/build-module/hooks/commands/use-edit-mode-commands.js +65 -9
  331. package/build-module/hooks/commands/use-edit-mode-commands.js.map +1 -1
  332. package/build-module/hooks/push-changes-to-global-styles/index.js +139 -57
  333. package/build-module/hooks/push-changes-to-global-styles/index.js.map +1 -1
  334. package/build-module/store/private-actions.js +9 -2
  335. package/build-module/store/private-actions.js.map +1 -1
  336. package/build-module/utils/normalize-record-key.js +12 -0
  337. package/build-module/utils/normalize-record-key.js.map +1 -0
  338. package/build-module/utils/use-activate-theme.js +1 -1
  339. package/build-module/utils/use-activate-theme.js.map +1 -1
  340. package/build-module/utils/use-debounced-input.js +5 -7
  341. package/build-module/utils/use-debounced-input.js.map +1 -1
  342. package/build-style/style-rtl.css +281 -103
  343. package/build-style/style.css +281 -103
  344. package/package.json +39 -40
  345. package/src/components/add-new-page/index.js +0 -3
  346. package/src/components/add-new-pattern/index.js +25 -12
  347. package/src/components/add-new-template/utils.js +9 -6
  348. package/src/components/block-editor/constants.js +5 -1
  349. package/src/components/block-editor/editor-canvas.js +1 -1
  350. package/src/components/block-editor/index.js +0 -4
  351. package/src/components/block-editor/use-site-editor-settings.js +119 -20
  352. package/src/components/canvas-spinner/style.scss +14 -0
  353. package/src/components/code-editor/index.js +51 -33
  354. package/src/components/create-pattern-modal/index.js +5 -2
  355. package/src/components/editor/index.js +5 -5
  356. package/src/components/global-styles/global-styles-provider.js +7 -2
  357. package/src/components/global-styles/screen-block.js +15 -0
  358. package/src/components/global-styles/screen-revisions/index.js +64 -58
  359. package/src/components/global-styles/screen-revisions/revisions-buttons.js +17 -31
  360. package/src/components/global-styles/screen-revisions/test/use-global-styles-revisions.js +14 -1
  361. package/src/components/global-styles/screen-revisions/use-global-styles-revisions.js +64 -48
  362. package/src/components/global-styles/style-variations-container.js +2 -0
  363. package/src/components/header-edit-mode/document-actions/index.js +8 -4
  364. package/src/components/header-edit-mode/document-actions/style.scss +45 -28
  365. package/src/components/header-edit-mode/index.js +29 -22
  366. package/src/components/keyboard-shortcuts/edit-mode.js +4 -5
  367. package/src/components/layout/index.js +49 -22
  368. package/src/components/layout/style.scss +4 -3
  369. package/src/components/page/index.js +8 -8
  370. package/src/components/page/style.scss +8 -5
  371. package/src/components/page-actions/index.js +2 -2
  372. package/src/components/page-actions/{delete-page-menu-item.js → trash-page-menu-item.js} +9 -22
  373. package/src/components/page-content-focus-manager/disable-non-page-content-blocks.js +12 -3
  374. package/src/components/page-patterns/duplicate-menu-item.js +196 -0
  375. package/src/components/page-patterns/grid-item.js +189 -133
  376. package/src/components/page-patterns/grid.js +3 -20
  377. package/src/components/page-patterns/header.js +69 -0
  378. package/src/components/page-patterns/index.js +6 -1
  379. package/src/components/page-patterns/pagination.js +80 -0
  380. package/src/components/page-patterns/patterns-list.js +172 -71
  381. package/src/components/page-patterns/rename-menu-item.js +115 -0
  382. package/src/components/page-patterns/style.scss +141 -30
  383. package/src/components/page-patterns/use-patterns.js +115 -169
  384. package/src/components/page-template-parts/add-new-template-part.js +57 -0
  385. package/src/components/page-template-parts/index.js +3 -23
  386. package/src/components/page-templates/index.js +6 -19
  387. package/src/components/resizable-frame/index.js +104 -51
  388. package/src/components/resizable-frame/style.scss +9 -9
  389. package/src/components/save-button/index.js +2 -0
  390. package/src/components/save-hub/index.js +6 -1
  391. package/src/components/save-hub/style.scss +1 -1
  392. package/src/components/save-panel/index.js +10 -4
  393. package/src/components/sidebar-edit-mode/page-panels/page-content.js +7 -5
  394. package/src/components/sidebar-edit-mode/page-panels/page-status.js +2 -5
  395. package/src/components/sidebar-edit-mode/template-panel/index.js +15 -11
  396. package/src/components/sidebar-navigation-item/style.scss +5 -12
  397. package/src/components/sidebar-navigation-screen/index.js +30 -15
  398. package/src/components/sidebar-navigation-screen/style.scss +18 -0
  399. package/src/components/sidebar-navigation-screen-details-panel/style.scss +1 -0
  400. package/src/components/sidebar-navigation-screen-global-styles/index.js +48 -44
  401. package/src/components/sidebar-navigation-screen-main/index.js +44 -40
  402. package/src/components/sidebar-navigation-screen-main/template-part-hint.js +34 -0
  403. package/src/components/sidebar-navigation-screen-navigation-menu/index.js +4 -3
  404. package/src/components/sidebar-navigation-screen-navigation-menu/more-menu.js +1 -0
  405. package/src/components/sidebar-navigation-screen-navigation-menu/single-navigation-menu.js +1 -1
  406. package/src/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +16 -7
  407. package/src/components/sidebar-navigation-screen-navigation-menus/constants.js +2 -0
  408. package/src/components/sidebar-navigation-screen-navigation-menus/index.js +4 -4
  409. package/src/components/sidebar-navigation-screen-navigation-menus/leaf-more-menu.js +27 -15
  410. package/src/components/sidebar-navigation-screen-navigation-menus/navigation-menu-content.js +1 -4
  411. package/src/components/sidebar-navigation-screen-page/index.js +3 -3
  412. package/src/components/sidebar-navigation-screen-page/status-label.js +1 -35
  413. package/src/components/sidebar-navigation-screen-pages/index.js +48 -33
  414. package/src/components/sidebar-navigation-screen-pattern/index.js +5 -2
  415. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +3 -2
  416. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menus.js +2 -1
  417. package/src/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +23 -3
  418. package/src/components/sidebar-navigation-screen-pattern/use-pattern-details.js +74 -43
  419. package/src/components/sidebar-navigation-screen-patterns/category-item.js +5 -13
  420. package/src/components/sidebar-navigation-screen-patterns/index.js +103 -106
  421. package/src/components/sidebar-navigation-screen-patterns/style.scss +20 -0
  422. package/src/components/sidebar-navigation-screen-patterns/use-my-patterns.js +7 -6
  423. package/src/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +9 -0
  424. package/src/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +31 -9
  425. package/src/components/sidebar-navigation-screen-patterns/use-theme-patterns.js +2 -1
  426. package/src/components/sidebar-navigation-screen-templates/index.js +1 -9
  427. package/src/components/sidebar-navigation-screen-templates-browse/index.js +10 -0
  428. package/src/components/site-hub/index.js +48 -29
  429. package/src/components/site-hub/style.scss +14 -2
  430. package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +8 -2
  431. package/src/components/sync-state-with-url/use-sync-canvas-mode-with-url.js +1 -4
  432. package/src/components/sync-state-with-url/use-sync-path-with-url.js +73 -66
  433. package/src/components/table/style.scss +1 -0
  434. package/src/components/template-actions/index.js +2 -1
  435. package/src/components/template-actions/rename-menu-item.js +17 -10
  436. package/src/components/use-edited-entity-record/index.js +6 -1
  437. package/src/hooks/commands/use-common-commands.js +105 -32
  438. package/src/hooks/commands/use-edit-mode-commands.js +94 -23
  439. package/src/hooks/push-changes-to-global-styles/index.js +141 -50
  440. package/src/store/private-actions.js +10 -2
  441. package/src/style.scss +10 -12
  442. package/src/utils/normalize-record-key.js +11 -0
  443. package/src/utils/use-activate-theme.js +1 -1
  444. package/src/utils/use-debounced-input.js +8 -7
  445. package/build/components/code-editor/code-editor-text-area.js +0 -96
  446. package/build/components/code-editor/code-editor-text-area.js.map +0 -1
  447. package/build/components/keyboard-shortcuts/index.js +0 -148
  448. package/build/components/keyboard-shortcuts/index.js.map +0 -1
  449. package/build/components/page-actions/delete-page-menu-item.js.map +0 -1
  450. package/build/components/page-content-focus-manager/constants.js +0 -9
  451. package/build/components/page-content-focus-manager/constants.js.map +0 -1
  452. package/build-module/components/code-editor/code-editor-text-area.js +0 -84
  453. package/build-module/components/code-editor/code-editor-text-area.js.map +0 -1
  454. package/build-module/components/keyboard-shortcuts/index.js +0 -132
  455. package/build-module/components/keyboard-shortcuts/index.js.map +0 -1
  456. package/build-module/components/page-actions/delete-page-menu-item.js.map +0 -1
  457. package/build-module/components/page-content-focus-manager/constants.js +0 -2
  458. package/build-module/components/page-content-focus-manager/constants.js.map +0 -1
  459. package/src/components/code-editor/code-editor-text-area.js +0 -84
  460. package/src/components/keyboard-shortcuts/index.js +0 -137
  461. package/src/components/page-content-focus-manager/constants.js +0 -5
@@ -8,86 +8,103 @@ import classnames from 'classnames';
8
8
  */
9
9
  import { BlockPreview } from '@wordpress/block-editor';
10
10
  import {
11
+ Button,
11
12
  __experimentalConfirmDialog as ConfirmDialog,
12
13
  DropdownMenu,
13
14
  MenuGroup,
14
15
  MenuItem,
16
+ __experimentalHeading as Heading,
15
17
  __experimentalHStack as HStack,
16
- __unstableCompositeItem as CompositeItem,
17
18
  Tooltip,
18
19
  Flex,
19
20
  } from '@wordpress/components';
20
21
  import { useDispatch } from '@wordpress/data';
21
- import { useState, useId } from '@wordpress/element';
22
+ import { useState, useId, memo } from '@wordpress/element';
22
23
  import { __, sprintf } from '@wordpress/i18n';
23
24
  import {
24
25
  Icon,
25
26
  header,
26
27
  footer,
27
- symbolFilled,
28
+ symbolFilled as uncategorized,
29
+ symbol,
28
30
  moreHorizontal,
29
31
  lockSmall,
30
32
  } from '@wordpress/icons';
31
33
  import { store as noticesStore } from '@wordpress/notices';
32
34
  import { store as reusableBlocksStore } from '@wordpress/reusable-blocks';
33
- import { DELETE, BACKSPACE } from '@wordpress/keycodes';
34
35
 
35
36
  /**
36
37
  * Internal dependencies
37
38
  */
38
- import { PATTERNS, USER_PATTERNS } from './utils';
39
+ import RenameMenuItem from './rename-menu-item';
40
+ import DuplicateMenuItem from './duplicate-menu-item';
41
+ import { PATTERNS, TEMPLATE_PARTS, USER_PATTERNS, SYNC_TYPES } from './utils';
42
+ import { store as editSiteStore } from '../../store';
39
43
  import { useLink } from '../routes/link';
40
44
 
41
- const THEME_PATTERN_TOOLTIP = __( 'Theme patterns cannot be edited.' );
45
+ const templatePartIcons = { header, footer, uncategorized };
42
46
 
43
- export default function GridItem( { categoryId, composite, icon, item } ) {
47
+ function GridItem( { categoryId, item, ...props } ) {
44
48
  const descriptionId = useId();
45
49
  const [ isDeleteDialogOpen, setIsDeleteDialogOpen ] = useState( false );
46
50
 
51
+ const { removeTemplate } = useDispatch( editSiteStore );
47
52
  const { __experimentalDeleteReusableBlock } =
48
53
  useDispatch( reusableBlocksStore );
49
54
  const { createErrorNotice, createSuccessNotice } =
50
55
  useDispatch( noticesStore );
51
56
 
57
+ const isUserPattern = item.type === USER_PATTERNS;
58
+ const isNonUserPattern = item.type === PATTERNS;
59
+ const isTemplatePart = item.type === TEMPLATE_PARTS;
60
+
52
61
  const { onClick } = useLink( {
53
62
  postType: item.type,
54
- postId: item.type === USER_PATTERNS ? item.id : item.name,
63
+ postId: isUserPattern ? item.id : item.name,
55
64
  categoryId,
56
65
  categoryType: item.type,
57
66
  } );
58
67
 
59
- const onKeyDown = ( event ) => {
60
- if ( DELETE === event.keyCode || BACKSPACE === event.keyCode ) {
61
- setIsDeleteDialogOpen( true );
62
- }
63
- };
64
-
65
68
  const isEmpty = ! item.blocks?.length;
66
69
  const patternClassNames = classnames( 'edit-site-patterns__pattern', {
67
70
  'is-placeholder': isEmpty,
68
71
  } );
69
72
  const previewClassNames = classnames( 'edit-site-patterns__preview', {
70
- 'is-inactive': item.type === PATTERNS,
73
+ 'is-inactive': isNonUserPattern,
71
74
  } );
72
75
 
73
76
  const deletePattern = async () => {
74
77
  try {
75
78
  await __experimentalDeleteReusableBlock( item.id );
76
- createSuccessNotice( __( 'Pattern successfully deleted.' ), {
77
- type: 'snackbar',
78
- } );
79
+ createSuccessNotice(
80
+ sprintf(
81
+ // translators: %s: The pattern's title e.g. 'Call to action'.
82
+ __( '"%s" deleted.' ),
83
+ item.title
84
+ ),
85
+ { type: 'snackbar', id: 'edit-site-patterns-success' }
86
+ );
79
87
  } catch ( error ) {
80
88
  const errorMessage =
81
89
  error.message && error.code !== 'unknown_error'
82
90
  ? error.message
83
91
  : __( 'An error occurred while deleting the pattern.' );
84
- createErrorNotice( errorMessage, { type: 'snackbar' } );
92
+ createErrorNotice( errorMessage, {
93
+ type: 'snackbar',
94
+ id: 'edit-site-patterns-error',
95
+ } );
85
96
  }
86
97
  };
98
+ const deleteItem = () =>
99
+ isTemplatePart ? removeTemplate( item ) : deletePattern();
87
100
 
88
- const isUserPattern = item.type === USER_PATTERNS;
101
+ // Only custom patterns or custom template parts can be renamed or deleted.
102
+ const isCustomPattern =
103
+ isUserPattern || ( isTemplatePart && item.isCustom );
104
+ const hasThemeFile = isTemplatePart && item.templatePart.has_theme_file;
89
105
  const ariaDescriptions = [];
90
- if ( isUserPattern ) {
106
+
107
+ if ( isCustomPattern ) {
91
108
  // User patterns don't have descriptions, but can be edited and deleted, so include some help text.
92
109
  ariaDescriptions.push(
93
110
  __( 'Press Enter to edit, or Delete to delete the pattern.' )
@@ -95,134 +112,173 @@ export default function GridItem( { categoryId, composite, icon, item } ) {
95
112
  } else if ( item.description ) {
96
113
  ariaDescriptions.push( item.description );
97
114
  }
98
- if ( item.type === PATTERNS ) {
99
- ariaDescriptions.push( THEME_PATTERN_TOOLTIP );
100
- }
101
115
 
102
- let itemIcon = icon;
103
- if ( categoryId === 'header' ) {
104
- itemIcon = header;
105
- } else if ( categoryId === 'footer' ) {
106
- itemIcon = footer;
107
- } else if ( categoryId === 'uncategorized' ) {
108
- itemIcon = symbolFilled;
116
+ if ( isNonUserPattern ) {
117
+ ariaDescriptions.push(
118
+ __( 'Theme & plugin patterns cannot be edited.' )
119
+ );
109
120
  }
110
121
 
122
+ const itemIcon =
123
+ templatePartIcons[ categoryId ] ||
124
+ ( item.syncStatus === SYNC_TYPES.full ? symbol : undefined );
125
+
126
+ const confirmButtonText = hasThemeFile ? __( 'Clear' ) : __( 'Delete' );
127
+ const confirmPrompt = hasThemeFile
128
+ ? __( 'Are you sure you want to clear these customizations?' )
129
+ : sprintf(
130
+ // translators: %s: The pattern or template part's title e.g. 'Call to action'.
131
+ __( 'Are you sure you want to delete "%s"?' ),
132
+ item.title
133
+ );
134
+
111
135
  return (
112
- <>
113
- <div className={ patternClassNames }>
114
- <CompositeItem
115
- className={ previewClassNames }
116
- role="option"
117
- as="div"
118
- { ...composite }
119
- onClick={ item.type !== PATTERNS ? onClick : undefined }
120
- onKeyDown={ isUserPattern ? onKeyDown : undefined }
121
- aria-label={ item.title }
122
- aria-describedby={
123
- ariaDescriptions.length
124
- ? ariaDescriptions
125
- .map(
126
- ( _, index ) =>
127
- `${ descriptionId }-${ index }`
128
- )
129
- .join( ' ' )
130
- : undefined
131
- }
136
+ <li className={ patternClassNames }>
137
+ <button
138
+ className={ previewClassNames }
139
+ // Even though still incomplete, passing ids helps performance.
140
+ // @see https://reakit.io/docs/composite/#performance.
141
+ id={ `edit-site-patterns-${ item.name }` }
142
+ { ...props }
143
+ onClick={ item.type !== PATTERNS ? onClick : undefined }
144
+ aria-disabled={ item.type !== PATTERNS ? 'false' : 'true' }
145
+ aria-label={ item.title }
146
+ aria-describedby={
147
+ ariaDescriptions.length
148
+ ? ariaDescriptions
149
+ .map(
150
+ ( _, index ) =>
151
+ `${ descriptionId }-${ index }`
152
+ )
153
+ .join( ' ' )
154
+ : undefined
155
+ }
156
+ >
157
+ { isEmpty && __( 'Empty pattern' ) }
158
+ { ! isEmpty && <BlockPreview blocks={ item.blocks } /> }
159
+ </button>
160
+ { ariaDescriptions.map( ( ariaDescription, index ) => (
161
+ <div
162
+ key={ index }
163
+ hidden
164
+ id={ `${ descriptionId }-${ index }` }
132
165
  >
133
- { isEmpty && __( 'Empty pattern' ) }
134
- { ! isEmpty && <BlockPreview blocks={ item.blocks } /> }
135
- </CompositeItem>
136
- { ariaDescriptions.map( ( ariaDescription, index ) => (
137
- <div
138
- key={ index }
139
- hidden
140
- id={ `${ descriptionId }-${ index }` }
141
- >
142
- { ariaDescription }
143
- </div>
144
- ) ) }
166
+ { ariaDescription }
167
+ </div>
168
+ ) ) }
169
+ <HStack
170
+ className="edit-site-patterns__footer"
171
+ justify="space-between"
172
+ >
145
173
  <HStack
146
- aria-hidden="true"
147
- className="edit-site-patterns__footer"
148
- justify="space-between"
174
+ alignment="center"
175
+ justify="left"
176
+ spacing={ 3 }
177
+ className="edit-site-patterns__pattern-title"
149
178
  >
150
- <HStack
151
- alignment="center"
152
- justify="left"
153
- spacing={ 3 }
154
- className="edit-site-patterns__pattern-title"
155
- >
156
- { icon && (
157
- <Icon
158
- className="edit-site-patterns__pattern-icon"
159
- icon={ itemIcon }
160
- />
161
- ) }
162
- <Flex as="span" gap={ 0 } justify="left">
163
- { item.title }
164
- { item.type === PATTERNS && (
165
- <Tooltip
166
- position="top center"
167
- text={ __(
168
- 'Theme patterns cannot be edited.'
169
- ) }
170
- >
171
- <span className="edit-site-patterns__pattern-lock-icon">
172
- <Icon
173
- style={ { fill: 'currentcolor' } }
174
- icon={ lockSmall }
175
- size={ 24 }
176
- />
177
- </span>
178
- </Tooltip>
179
+ { itemIcon && ! isNonUserPattern && (
180
+ <Tooltip
181
+ position="top center"
182
+ text={ __(
183
+ 'Editing this pattern will also update anywhere it is used'
179
184
  ) }
180
- </Flex>
181
- </HStack>
182
- { item.type === USER_PATTERNS && (
183
- <DropdownMenu
184
- icon={ moreHorizontal }
185
- label={ __( 'Actions' ) }
186
- className="edit-site-patterns__dropdown"
187
- popoverProps={ { placement: 'bottom-end' } }
188
- toggleProps={ {
189
- className: 'edit-site-patterns__button',
190
- isSmall: true,
191
- describedBy: sprintf(
192
- /* translators: %s: pattern name */
193
- __( 'Action menu for %s pattern' ),
194
- item.title
195
- ),
196
- // The dropdown menu is not focusable using the
197
- // keyboard as this would interfere with the grid's
198
- // roving tab index system. Instead, keyboard users
199
- // use keyboard shortcuts to trigger actions.
200
- tabIndex: -1,
201
- } }
202
185
  >
203
- { () => (
204
- <MenuGroup>
205
- <MenuItem
206
- onClick={ () =>
207
- setIsDeleteDialogOpen( true )
208
- }
209
- >
210
- { __( 'Delete' ) }
211
- </MenuItem>
212
- </MenuGroup>
213
- ) }
214
- </DropdownMenu>
186
+ <span>
187
+ <Icon
188
+ className="edit-site-patterns__pattern-icon"
189
+ icon={ itemIcon }
190
+ />
191
+ </span>
192
+ </Tooltip>
215
193
  ) }
194
+ <Flex as="span" gap={ 0 } justify="left">
195
+ { item.type === PATTERNS ? (
196
+ item.title
197
+ ) : (
198
+ <Heading level={ 5 }>
199
+ <Button
200
+ variant="link"
201
+ onClick={ onClick }
202
+ // Required for the grid's roving tab index system.
203
+ // See https://github.com/WordPress/gutenberg/pull/51898#discussion_r1243399243.
204
+ tabIndex="-1"
205
+ >
206
+ { item.title }
207
+ </Button>
208
+ </Heading>
209
+ ) }
210
+ { item.type === PATTERNS && (
211
+ <Tooltip
212
+ position="top center"
213
+ text={ __( 'This pattern cannot be edited.' ) }
214
+ >
215
+ <span className="edit-site-patterns__pattern-lock-icon">
216
+ <Icon icon={ lockSmall } size={ 24 } />
217
+ </span>
218
+ </Tooltip>
219
+ ) }
220
+ </Flex>
216
221
  </HStack>
217
- </div>
222
+ <DropdownMenu
223
+ icon={ moreHorizontal }
224
+ label={ __( 'Actions' ) }
225
+ className="edit-site-patterns__dropdown"
226
+ popoverProps={ { placement: 'bottom-end' } }
227
+ toggleProps={ {
228
+ className: 'edit-site-patterns__button',
229
+ isSmall: true,
230
+ describedBy: sprintf(
231
+ /* translators: %s: pattern name */
232
+ __( 'Action menu for %s pattern' ),
233
+ item.title
234
+ ),
235
+ } }
236
+ >
237
+ { ( { onClose } ) => (
238
+ <MenuGroup>
239
+ { isCustomPattern && ! hasThemeFile && (
240
+ <RenameMenuItem
241
+ item={ item }
242
+ onClose={ onClose }
243
+ />
244
+ ) }
245
+ <DuplicateMenuItem
246
+ categoryId={ categoryId }
247
+ item={ item }
248
+ onClose={ onClose }
249
+ label={
250
+ isNonUserPattern
251
+ ? __( 'Copy to My patterns' )
252
+ : __( 'Duplicate' )
253
+ }
254
+ />
255
+ { isCustomPattern && (
256
+ <MenuItem
257
+ onClick={ () =>
258
+ setIsDeleteDialogOpen( true )
259
+ }
260
+ >
261
+ { hasThemeFile
262
+ ? __( 'Clear customizations' )
263
+ : __( 'Delete' ) }
264
+ </MenuItem>
265
+ ) }
266
+ </MenuGroup>
267
+ ) }
268
+ </DropdownMenu>
269
+ </HStack>
270
+
218
271
  { isDeleteDialogOpen && (
219
272
  <ConfirmDialog
220
- onConfirm={ deletePattern }
273
+ confirmButtonText={ confirmButtonText }
274
+ onConfirm={ deleteItem }
221
275
  onCancel={ () => setIsDeleteDialogOpen( false ) }
222
276
  >
223
- { __( 'Are you sure you want to delete this pattern?' ) }
277
+ { confirmPrompt }
224
278
  </ConfirmDialog>
225
279
  ) }
226
- </>
280
+ </li>
227
281
  );
228
282
  }
283
+
284
+ export default memo( GridItem );
@@ -1,39 +1,22 @@
1
- /**
2
- * WordPress dependencies
3
- */
4
- import {
5
- __unstableComposite as Composite,
6
- __unstableUseCompositeState as useCompositeState,
7
- } from '@wordpress/components';
8
-
9
1
  /**
10
2
  * Internal dependencies
11
3
  */
12
4
  import GridItem from './grid-item';
13
5
 
14
- export default function Grid( { categoryId, label, icon, items } ) {
15
- const composite = useCompositeState( { orientation: 'vertical' } );
16
-
6
+ export default function Grid( { categoryId, items, ...props } ) {
17
7
  if ( ! items?.length ) {
18
8
  return null;
19
9
  }
20
10
 
21
11
  return (
22
- <Composite
23
- { ...composite }
24
- role="listbox"
25
- className="edit-site-patterns__grid"
26
- aria-label={ label }
27
- >
12
+ <ul role="listbox" className="edit-site-patterns__grid" { ...props }>
28
13
  { items.map( ( item ) => (
29
14
  <GridItem
30
15
  key={ item.name }
31
- icon={ icon }
32
16
  item={ item }
33
17
  categoryId={ categoryId }
34
- composite={ composite }
35
18
  />
36
19
  ) ) }
37
- </Composite>
20
+ </ul>
38
21
  );
39
22
  }
@@ -0,0 +1,69 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import {
5
+ __experimentalVStack as VStack,
6
+ __experimentalHeading as Heading,
7
+ __experimentalText as Text,
8
+ } from '@wordpress/components';
9
+ import { __ } from '@wordpress/i18n';
10
+ import { store as editorStore } from '@wordpress/editor';
11
+ import { useSelect } from '@wordpress/data';
12
+
13
+ /**
14
+ * Internal dependencies
15
+ */
16
+ import usePatternCategories from '../sidebar-navigation-screen-patterns/use-pattern-categories';
17
+ import {
18
+ USER_PATTERN_CATEGORY,
19
+ USER_PATTERNS,
20
+ TEMPLATE_PARTS,
21
+ PATTERNS,
22
+ } from './utils';
23
+
24
+ export default function PatternsHeader( {
25
+ categoryId,
26
+ type,
27
+ titleId,
28
+ descriptionId,
29
+ } ) {
30
+ const { patternCategories } = usePatternCategories();
31
+ const templatePartAreas = useSelect(
32
+ ( select ) =>
33
+ select( editorStore ).__experimentalGetDefaultTemplatePartAreas(),
34
+ []
35
+ );
36
+
37
+ let title, description;
38
+ if ( categoryId === USER_PATTERN_CATEGORY && type === USER_PATTERNS ) {
39
+ title = __( 'My Patterns' );
40
+ description = '';
41
+ } else if ( type === TEMPLATE_PARTS ) {
42
+ const templatePartArea = templatePartAreas.find(
43
+ ( area ) => area.area === categoryId
44
+ );
45
+ title = templatePartArea?.label;
46
+ description = templatePartArea?.description;
47
+ } else if ( type === PATTERNS ) {
48
+ const patternCategory = patternCategories.find(
49
+ ( category ) => category.name === categoryId
50
+ );
51
+ title = patternCategory?.label;
52
+ description = patternCategory?.description;
53
+ }
54
+
55
+ if ( ! title ) return null;
56
+
57
+ return (
58
+ <VStack className="edit-site-patterns__section-header">
59
+ <Heading as="h2" level={ 4 } id={ titleId }>
60
+ { title }
61
+ </Heading>
62
+ { description ? (
63
+ <Text variant="muted" as="p" id={ descriptionId }>
64
+ { description }
65
+ </Text>
66
+ ) : null }
67
+ </VStack>
68
+ );
69
+ }
@@ -32,7 +32,12 @@ export default function PagePatterns() {
32
32
  title={ __( 'Patterns content' ) }
33
33
  hideTitleFromUI
34
34
  >
35
- <PatternsList type={ type } categoryId={ category } />
35
+ <PatternsList
36
+ // Reset the states when switching between categories and types.
37
+ key={ `${ type }-${ category }` }
38
+ type={ type }
39
+ categoryId={ category }
40
+ />
36
41
  </Page>
37
42
  </ExperimentalBlockEditorProvider>
38
43
  );
@@ -0,0 +1,80 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import {
5
+ __experimentalHStack as HStack,
6
+ __experimentalText as Text,
7
+ Button,
8
+ } from '@wordpress/components';
9
+ import { __, _x, _n, sprintf } from '@wordpress/i18n';
10
+
11
+ export default function Pagination( {
12
+ currentPage,
13
+ numPages,
14
+ changePage,
15
+ totalItems,
16
+ } ) {
17
+ return (
18
+ <HStack
19
+ expanded={ false }
20
+ spacing={ 3 }
21
+ justify="flex-start"
22
+ className="edit-site-patterns__grid-pagination"
23
+ >
24
+ <Text variant="muted">
25
+ {
26
+ // translators: %s: Total number of patterns.
27
+ sprintf(
28
+ // translators: %s: Total number of patterns.
29
+ _n( '%s item', '%s items', totalItems ),
30
+ totalItems
31
+ )
32
+ }
33
+ </Text>
34
+ <HStack expanded={ false } spacing={ 1 }>
35
+ <Button
36
+ variant="tertiary"
37
+ onClick={ () => changePage( 1 ) }
38
+ disabled={ currentPage === 1 }
39
+ aria-label={ __( 'First page' ) }
40
+ >
41
+ «
42
+ </Button>
43
+ <Button
44
+ variant="tertiary"
45
+ onClick={ () => changePage( currentPage - 1 ) }
46
+ disabled={ currentPage === 1 }
47
+ aria-label={ __( 'Previous page' ) }
48
+ >
49
+
50
+ </Button>
51
+ </HStack>
52
+ <Text variant="muted">
53
+ { sprintf(
54
+ // translators: %1$s: Current page number, %2$s: Total number of pages.
55
+ _x( '%1$s of %2$s', 'paging' ),
56
+ currentPage,
57
+ numPages
58
+ ) }
59
+ </Text>
60
+ <HStack expanded={ false } spacing={ 1 }>
61
+ <Button
62
+ variant="tertiary"
63
+ onClick={ () => changePage( currentPage + 1 ) }
64
+ disabled={ currentPage === numPages }
65
+ aria-label={ __( 'Next page' ) }
66
+ >
67
+
68
+ </Button>
69
+ <Button
70
+ variant="tertiary"
71
+ onClick={ () => changePage( numPages ) }
72
+ disabled={ currentPage === numPages }
73
+ aria-label={ __( 'Last page' ) }
74
+ >
75
+ »
76
+ </Button>
77
+ </HStack>
78
+ </HStack>
79
+ );
80
+ }