@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
@@ -4,7 +4,8 @@
4
4
  import { parse } from '@wordpress/blocks';
5
5
  import { useSelect } from '@wordpress/data';
6
6
  import { store as coreStore } from '@wordpress/core-data';
7
- import { useMemo } from '@wordpress/element';
7
+ import { store as editorStore } from '@wordpress/editor';
8
+ import { decodeEntities } from '@wordpress/html-entities';
8
9
 
9
10
  /**
10
11
  * Internal dependencies
@@ -15,7 +16,6 @@ import {
15
16
  SYNC_TYPES,
16
17
  TEMPLATE_PARTS,
17
18
  USER_PATTERNS,
18
- USER_PATTERN_CATEGORY,
19
19
  filterOutDuplicatesByName,
20
20
  } from './utils';
21
21
  import { unlock } from '../../lock-unlock';
@@ -31,122 +31,98 @@ const templatePartToPattern = ( templatePart ) => ( {
31
31
  blocks: parse( templatePart.content.raw ),
32
32
  categories: [ templatePart.area ],
33
33
  description: templatePart.description || '',
34
+ isCustom: templatePart.source === 'custom',
34
35
  keywords: templatePart.keywords || [],
36
+ id: createTemplatePartId( templatePart.theme, templatePart.slug ),
35
37
  name: createTemplatePartId( templatePart.theme, templatePart.slug ),
36
- title: templatePart.title.rendered,
38
+ title: decodeEntities( templatePart.title.rendered ),
37
39
  type: templatePart.type,
38
40
  templatePart,
39
41
  } );
40
42
 
41
- const templatePartCategories = [ 'header', 'footer', 'sidebar' ];
42
- const templatePartHasCategory = ( item, category ) => {
43
- if ( category === 'uncategorized' ) {
44
- return ! templatePartCategories.includes( item.templatePart.area );
45
- }
46
-
47
- return item.templatePart.area === category;
48
- };
49
-
50
- const useTemplatePartsAsPatterns = (
51
- categoryId,
52
- postType = TEMPLATE_PARTS,
53
- filterValue = ''
43
+ const selectTemplatePartsAsPatterns = (
44
+ select,
45
+ { categoryId, search = '' } = {}
54
46
  ) => {
55
- const { templateParts, isResolving } = useSelect(
56
- ( select ) => {
57
- if ( postType !== TEMPLATE_PARTS ) {
58
- return {
59
- templateParts: EMPTY_PATTERN_LIST,
60
- isResolving: false,
61
- };
62
- }
63
-
64
- const { getEntityRecords, isResolving: _isResolving } =
65
- select( coreStore );
66
- const query = { per_page: -1 };
67
- const rawTemplateParts = getEntityRecords(
68
- 'postType',
69
- postType,
70
- query
71
- );
72
- const partsAsPatterns = rawTemplateParts?.map( ( templatePart ) =>
73
- templatePartToPattern( templatePart )
74
- );
75
-
76
- return {
77
- templateParts: partsAsPatterns,
78
- isResolving: _isResolving( 'getEntityRecords', [
79
- 'postType',
80
- 'wp_template_part',
81
- query,
82
- ] ),
83
- };
84
- },
85
- [ postType ]
47
+ const { getEntityRecords, getIsResolving } = select( coreStore );
48
+ const { __experimentalGetDefaultTemplatePartAreas } = select( editorStore );
49
+ const query = { per_page: -1 };
50
+ const rawTemplateParts =
51
+ getEntityRecords( 'postType', TEMPLATE_PARTS, query ) ??
52
+ EMPTY_PATTERN_LIST;
53
+ const templateParts = rawTemplateParts.map( ( templatePart ) =>
54
+ templatePartToPattern( templatePart )
86
55
  );
87
56
 
88
- const filteredTemplateParts = useMemo( () => {
89
- if ( ! templateParts ) {
90
- return EMPTY_PATTERN_LIST;
91
- }
57
+ // In the case where a custom template part area has been removed we need
58
+ // the current list of areas to cross check against so orphaned template
59
+ // parts can be treated as uncategorized.
60
+ const knownAreas = __experimentalGetDefaultTemplatePartAreas() || [];
61
+ const templatePartAreas = knownAreas.map( ( area ) => area.area );
92
62
 
93
- return searchItems( templateParts, filterValue, {
94
- categoryId,
95
- hasCategory: templatePartHasCategory,
96
- } );
97
- }, [ templateParts, filterValue, categoryId ] );
98
-
99
- return { templateParts: filteredTemplateParts, isResolving };
100
- };
63
+ const templatePartHasCategory = ( item, category ) => {
64
+ if ( category !== 'uncategorized' ) {
65
+ return item.templatePart.area === category;
66
+ }
101
67
 
102
- const useThemePatterns = (
103
- categoryId,
104
- postType = PATTERNS,
105
- filterValue = ''
106
- ) => {
107
- const blockPatterns = useSelect( ( select ) => {
108
- const { getSettings } = unlock( select( editSiteStore ) );
109
- const settings = getSettings();
110
68
  return (
111
- settings.__experimentalAdditionalBlockPatterns ??
112
- settings.__experimentalBlockPatterns
69
+ item.templatePart.area === category ||
70
+ ! templatePartAreas.includes( item.templatePart.area )
113
71
  );
114
- } );
72
+ };
115
73
 
116
- const restBlockPatterns = useSelect( ( select ) =>
117
- select( coreStore ).getBlockPatterns()
118
- );
74
+ const isResolving = getIsResolving( 'getEntityRecords', [
75
+ 'postType',
76
+ 'wp_template_part',
77
+ query,
78
+ ] );
119
79
 
120
- const patterns = useMemo(
121
- () =>
122
- [ ...( blockPatterns || [] ), ...( restBlockPatterns || [] ) ]
123
- .filter(
124
- ( pattern ) =>
125
- ! CORE_PATTERN_SOURCES.includes( pattern.source )
126
- )
127
- .filter( filterOutDuplicatesByName )
128
- .map( ( pattern ) => ( {
129
- ...pattern,
130
- keywords: pattern.keywords || [],
131
- type: 'pattern',
132
- blocks: parse( pattern.content ),
133
- } ) ),
134
- [ blockPatterns, restBlockPatterns ]
135
- );
80
+ const patterns = searchItems( templateParts, search, {
81
+ categoryId,
82
+ hasCategory: templatePartHasCategory,
83
+ } );
136
84
 
137
- const filteredPatterns = useMemo( () => {
138
- if ( postType !== PATTERNS ) {
139
- return EMPTY_PATTERN_LIST;
140
- }
85
+ return { patterns, isResolving };
86
+ };
141
87
 
142
- return searchItems( patterns, filterValue, {
88
+ const selectThemePatterns = ( select, { categoryId, search = '' } = {} ) => {
89
+ const { getSettings } = unlock( select( editSiteStore ) );
90
+ const settings = getSettings();
91
+ const blockPatterns =
92
+ settings.__experimentalAdditionalBlockPatterns ??
93
+ settings.__experimentalBlockPatterns;
94
+
95
+ const restBlockPatterns = select( coreStore ).getBlockPatterns();
96
+
97
+ let patterns = [
98
+ ...( blockPatterns || [] ),
99
+ ...( restBlockPatterns || [] ),
100
+ ]
101
+ .filter(
102
+ ( pattern ) => ! CORE_PATTERN_SOURCES.includes( pattern.source )
103
+ )
104
+ .filter( filterOutDuplicatesByName )
105
+ .filter( ( pattern ) => pattern.inserter !== false )
106
+ .map( ( pattern ) => ( {
107
+ ...pattern,
108
+ keywords: pattern.keywords || [],
109
+ type: 'pattern',
110
+ blocks: parse( pattern.content ),
111
+ } ) );
112
+
113
+ if ( categoryId ) {
114
+ patterns = searchItems( patterns, search, {
143
115
  categoryId,
144
116
  hasCategory: ( item, currentCategory ) =>
145
117
  item.categories?.includes( currentCategory ),
146
118
  } );
147
- }, [ patterns, filterValue, categoryId, postType ] );
119
+ } else {
120
+ patterns = searchItems( patterns, search, {
121
+ hasCategory: ( item ) => ! item.hasOwnProperty( 'categories' ),
122
+ } );
123
+ }
148
124
 
149
- return filteredPatterns;
125
+ return { patterns, isResolving: false };
150
126
  };
151
127
 
152
128
  const reusableBlockToPattern = ( reusableBlock ) => ( {
@@ -160,88 +136,58 @@ const reusableBlockToPattern = ( reusableBlock ) => ( {
160
136
  reusableBlock,
161
137
  } );
162
138
 
163
- const useUserPatterns = (
164
- categoryId,
165
- categoryType = PATTERNS,
166
- filterValue = ''
167
- ) => {
168
- const postType = categoryType === PATTERNS ? USER_PATTERNS : categoryType;
169
- const unfilteredPatterns = useSelect(
170
- ( select ) => {
171
- if (
172
- postType !== USER_PATTERNS ||
173
- categoryId !== USER_PATTERN_CATEGORY
174
- ) {
175
- return EMPTY_PATTERN_LIST;
176
- }
177
-
178
- const { getEntityRecords } = select( coreStore );
179
- const records = getEntityRecords( 'postType', postType, {
180
- per_page: -1,
181
- } );
182
-
183
- if ( ! records ) {
184
- return EMPTY_PATTERN_LIST;
185
- }
186
-
187
- return records.map( ( record ) =>
188
- reusableBlockToPattern( record )
189
- );
190
- },
191
- [ postType, categoryId ]
192
- );
139
+ const selectUserPatterns = ( select, { search = '', syncStatus } = {} ) => {
140
+ const { getEntityRecords, getIsResolving } = select( coreStore );
193
141
 
194
- const filteredPatterns = useMemo( () => {
195
- if ( ! unfilteredPatterns.length ) {
196
- return EMPTY_PATTERN_LIST;
197
- }
142
+ const query = { per_page: -1 };
143
+ const records = getEntityRecords( 'postType', USER_PATTERNS, query );
198
144
 
199
- return searchItems( unfilteredPatterns, filterValue, {
200
- // We exit user pattern retrieval early if we aren't in the
201
- // catch-all category for user created patterns, so it has
202
- // to be in the category.
203
- hasCategory: () => true,
204
- } );
205
- }, [ unfilteredPatterns, filterValue ] );
145
+ let patterns = records
146
+ ? records.map( ( record ) => reusableBlockToPattern( record ) )
147
+ : EMPTY_PATTERN_LIST;
148
+ const isResolving = getIsResolving( 'getEntityRecords', [
149
+ 'postType',
150
+ USER_PATTERNS,
151
+ query,
152
+ ] );
206
153
 
207
- const patterns = { syncedPatterns: [], unsyncedPatterns: [] };
154
+ if ( syncStatus ) {
155
+ patterns = patterns.filter(
156
+ ( pattern ) => pattern.syncStatus === syncStatus
157
+ );
158
+ }
208
159
 
209
- filteredPatterns.forEach( ( pattern ) => {
210
- if ( pattern.syncStatus === SYNC_TYPES.full ) {
211
- patterns.syncedPatterns.push( pattern );
212
- } else {
213
- patterns.unsyncedPatterns.push( pattern );
214
- }
160
+ patterns = searchItems( patterns, search, {
161
+ // We exit user pattern retrieval early if we aren't in the
162
+ // catch-all category for user created patterns, so it has
163
+ // to be in the category.
164
+ hasCategory: () => true,
215
165
  } );
216
166
 
217
- return patterns;
167
+ return { patterns, isResolving };
218
168
  };
219
169
 
220
- export const usePatterns = ( categoryType, categoryId, filterValue ) => {
221
- const blockPatterns = useThemePatterns(
222
- categoryId,
223
- categoryType,
224
- filterValue
225
- );
226
-
227
- const { syncedPatterns = [], unsyncedPatterns = [] } = useUserPatterns(
228
- categoryId,
229
- categoryType,
230
- filterValue
231
- );
232
-
233
- const { templateParts, isResolving } = useTemplatePartsAsPatterns(
234
- categoryId,
235
- categoryType,
236
- filterValue
170
+ export const usePatterns = (
171
+ categoryType,
172
+ categoryId,
173
+ { search = '', syncStatus }
174
+ ) => {
175
+ return useSelect(
176
+ ( select ) => {
177
+ if ( categoryType === TEMPLATE_PARTS ) {
178
+ return selectTemplatePartsAsPatterns( select, {
179
+ categoryId,
180
+ search,
181
+ } );
182
+ } else if ( categoryType === PATTERNS ) {
183
+ return selectThemePatterns( select, { categoryId, search } );
184
+ } else if ( categoryType === USER_PATTERNS ) {
185
+ return selectUserPatterns( select, { search, syncStatus } );
186
+ }
187
+ return { patterns: EMPTY_PATTERN_LIST, isResolving: false };
188
+ },
189
+ [ categoryId, categoryType, search, syncStatus ]
237
190
  );
238
-
239
- const patterns = {
240
- syncedPatterns: [ ...templateParts, ...syncedPatterns ],
241
- unsyncedPatterns: [ ...blockPatterns, ...unsyncedPatterns ],
242
- };
243
-
244
- return [ patterns, isResolving ];
245
191
  };
246
192
 
247
193
  export default usePatterns;
@@ -0,0 +1,57 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { privateApis as routerPrivateApis } from '@wordpress/router';
5
+ import { useSelect } from '@wordpress/data';
6
+ import { store as coreStore } from '@wordpress/core-data';
7
+ import { useState } from '@wordpress/element';
8
+ import { Button } from '@wordpress/components';
9
+
10
+ /**
11
+ * Internal dependencies
12
+ */
13
+ import { unlock } from '../../lock-unlock';
14
+ import { store as editSiteStore } from '../../store';
15
+ import CreateTemplatePartModal from '../create-template-part-modal';
16
+
17
+ const { useHistory } = unlock( routerPrivateApis );
18
+
19
+ export default function AddNewTemplatePart() {
20
+ const { canCreate, postType } = useSelect( ( select ) => {
21
+ const { supportsTemplatePartsMode } =
22
+ select( editSiteStore ).getSettings();
23
+ return {
24
+ canCreate: ! supportsTemplatePartsMode,
25
+ postType: select( coreStore ).getPostType( 'wp_template_part' ),
26
+ };
27
+ }, [] );
28
+ const [ isModalOpen, setIsModalOpen ] = useState( false );
29
+ const history = useHistory();
30
+
31
+ if ( ! canCreate || ! postType ) {
32
+ return null;
33
+ }
34
+
35
+ return (
36
+ <>
37
+ <Button variant="primary" onClick={ () => setIsModalOpen( true ) }>
38
+ { postType.labels.add_new_item }
39
+ </Button>
40
+ { isModalOpen && (
41
+ <CreateTemplatePartModal
42
+ closeModal={ () => setIsModalOpen( false ) }
43
+ blocks={ [] }
44
+ onCreate={ ( templatePart ) => {
45
+ setIsModalOpen( false );
46
+ history.push( {
47
+ postId: templatePart.id,
48
+ postType: 'wp_template_part',
49
+ canvas: 'edit',
50
+ } );
51
+ } }
52
+ onError={ () => setIsModalOpen( false ) }
53
+ />
54
+ ) }
55
+ </>
56
+ );
57
+ }
@@ -7,8 +7,7 @@ import {
7
7
  __experimentalVStack as VStack,
8
8
  } from '@wordpress/components';
9
9
  import { __ } from '@wordpress/i18n';
10
- import { useSelect } from '@wordpress/data';
11
- import { store as coreStore, useEntityRecords } from '@wordpress/core-data';
10
+ import { useEntityRecords } from '@wordpress/core-data';
12
11
  import { decodeEntities } from '@wordpress/html-entities';
13
12
 
14
13
  /**
@@ -19,8 +18,7 @@ import Table from '../table';
19
18
  import Link from '../routes/link';
20
19
  import AddedBy from '../list/added-by';
21
20
  import TemplateActions from '../template-actions';
22
- import AddNewTemplate from '../add-new-template';
23
- import { store as editSiteStore } from '../../store';
21
+ import AddNewTemplatePart from './add-new-template-part';
24
22
 
25
23
  export default function PageTemplateParts() {
26
24
  const { records: templateParts } = useEntityRecords(
@@ -31,15 +29,6 @@ export default function PageTemplateParts() {
31
29
  }
32
30
  );
33
31
 
34
- const { canCreate } = useSelect( ( select ) => {
35
- const { supportsTemplatePartsMode } =
36
- select( editSiteStore ).getSettings();
37
- return {
38
- postType: select( coreStore ).getPostType( 'wp_template_part' ),
39
- canCreate: ! supportsTemplatePartsMode,
40
- };
41
- } );
42
-
43
32
  const columns = [
44
33
  {
45
34
  header: __( 'Template Part' ),
@@ -50,7 +39,6 @@ export default function PageTemplateParts() {
50
39
  params={ {
51
40
  postId: templatePart.id,
52
41
  postType: templatePart.type,
53
- canvas: 'view',
54
42
  } }
55
43
  state={ { backPath: '/wp_template_part/all' } }
56
44
  >
@@ -87,15 +75,7 @@ export default function PageTemplateParts() {
87
75
  return (
88
76
  <Page
89
77
  title={ __( 'Template Parts' ) }
90
- actions={
91
- canCreate && (
92
- <AddNewTemplate
93
- templateType={ 'wp_template_part' }
94
- showIcon={ false }
95
- toggleProps={ { variant: 'primary' } }
96
- />
97
- )
98
- }
78
+ actions={ <AddNewTemplatePart /> }
99
79
  >
100
80
  { templateParts && (
101
81
  <Table data={ templateParts } columns={ columns } />
@@ -8,8 +8,7 @@ import {
8
8
  __experimentalVStack as VStack,
9
9
  } from '@wordpress/components';
10
10
  import { __ } from '@wordpress/i18n';
11
- import { useSelect } from '@wordpress/data';
12
- import { store as coreStore, useEntityRecords } from '@wordpress/core-data';
11
+ import { useEntityRecords } from '@wordpress/core-data';
13
12
  import { decodeEntities } from '@wordpress/html-entities';
14
13
 
15
14
  /**
@@ -21,7 +20,6 @@ import Link from '../routes/link';
21
20
  import AddedBy from '../list/added-by';
22
21
  import TemplateActions from '../template-actions';
23
22
  import AddNewTemplate from '../add-new-template';
24
- import { store as editSiteStore } from '../../store';
25
23
 
26
24
  export default function PageTemplates() {
27
25
  const { records: templates } = useEntityRecords(
@@ -32,15 +30,6 @@ export default function PageTemplates() {
32
30
  }
33
31
  );
34
32
 
35
- const { canCreate } = useSelect( ( select ) => {
36
- const { supportsTemplatePartsMode } =
37
- select( editSiteStore ).getSettings();
38
- return {
39
- postType: select( coreStore ).getPostType( 'wp_template' ),
40
- canCreate: ! supportsTemplatePartsMode,
41
- };
42
- } );
43
-
44
33
  const columns = [
45
34
  {
46
35
  header: __( 'Template' ),
@@ -89,13 +78,11 @@ export default function PageTemplates() {
89
78
  <Page
90
79
  title={ __( 'Templates' ) }
91
80
  actions={
92
- canCreate && (
93
- <AddNewTemplate
94
- templateType={ 'wp_template' }
95
- showIcon={ false }
96
- toggleProps={ { variant: 'primary' } }
97
- />
98
- )
81
+ <AddNewTemplate
82
+ templateType={ 'wp_template' }
83
+ showIcon={ false }
84
+ toggleProps={ { variant: 'primary' } }
85
+ />
99
86
  }
100
87
  >
101
88
  { templates && <Table data={ templates } columns={ columns } /> }