@wordpress/edit-site 5.19.0 → 5.19.1

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 (443) hide show
  1. package/build/components/add-new-pattern/index.js +3 -3
  2. package/build/components/add-new-pattern/index.js.map +1 -1
  3. package/build/components/block-editor/block-editor-provider/default-block-editor-provider.js +73 -0
  4. package/build/components/block-editor/block-editor-provider/default-block-editor-provider.js.map +1 -0
  5. package/build/components/block-editor/block-editor-provider/index.js +31 -0
  6. package/build/components/block-editor/block-editor-provider/index.js.map +1 -0
  7. package/build/components/block-editor/{providers → block-editor-provider}/navigation-block-editor-provider.js +2 -1
  8. package/build/components/block-editor/block-editor-provider/navigation-block-editor-provider.js.map +1 -0
  9. package/build/components/block-editor/block-editor-provider/use-page-content-blocks.js +76 -0
  10. package/build/components/block-editor/block-editor-provider/use-page-content-blocks.js.map +1 -0
  11. package/build/components/block-editor/index.js +2 -9
  12. package/build/components/block-editor/index.js.map +1 -1
  13. package/build/components/block-editor/site-editor-canvas.js +1 -1
  14. package/build/components/block-editor/site-editor-canvas.js.map +1 -1
  15. package/build/components/create-template-part-modal/index.js +8 -12
  16. package/build/components/create-template-part-modal/index.js.map +1 -1
  17. package/build/components/editor/index.js +4 -1
  18. package/build/components/editor/index.js.map +1 -1
  19. package/build/components/global-styles/font-family-item.js +2 -2
  20. package/build/components/global-styles/font-family-item.js.map +1 -1
  21. package/build/components/global-styles/font-library-modal/collection-font-details.js +49 -0
  22. package/build/components/global-styles/font-library-modal/collection-font-details.js.map +1 -0
  23. package/build/components/global-styles/font-library-modal/collection-font-variant.js +55 -0
  24. package/build/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -0
  25. package/build/components/global-styles/font-library-modal/context.js +26 -2
  26. package/build/components/global-styles/font-library-modal/context.js.map +1 -1
  27. package/build/components/global-styles/font-library-modal/font-card.js +7 -4
  28. package/build/components/global-styles/font-library-modal/font-card.js.map +1 -1
  29. package/build/components/global-styles/font-library-modal/font-collection.js +172 -0
  30. package/build/components/global-styles/font-library-modal/font-collection.js.map +1 -0
  31. package/build/components/global-styles/font-library-modal/font-demo.js +30 -13
  32. package/build/components/global-styles/font-library-modal/font-demo.js.map +1 -1
  33. package/build/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js +41 -0
  34. package/build/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js.map +1 -0
  35. package/build/components/global-styles/font-library-modal/index.js +25 -7
  36. package/build/components/global-styles/font-library-modal/index.js.map +1 -1
  37. package/build/components/global-styles/font-library-modal/installed-fonts.js +2 -2
  38. package/build/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  39. package/build/components/global-styles/font-library-modal/library-font-card.js +0 -5
  40. package/build/components/global-styles/font-library-modal/library-font-card.js.map +1 -1
  41. package/build/components/global-styles/font-library-modal/library-font-details.js +2 -1
  42. package/build/components/global-styles/font-library-modal/library-font-details.js.map +1 -1
  43. package/build/components/global-styles/font-library-modal/resolvers.js +16 -0
  44. package/build/components/global-styles/font-library-modal/resolvers.js.map +1 -1
  45. package/build/components/global-styles/font-library-modal/tab-layout.js +2 -2
  46. package/build/components/global-styles/font-library-modal/tab-layout.js.map +1 -1
  47. package/build/components/global-styles/font-library-modal/utils/constants.js +1 -7
  48. package/build/components/global-styles/font-library-modal/utils/constants.js.map +1 -1
  49. package/build/components/global-styles/font-library-modal/utils/filter-fonts.js +21 -0
  50. package/build/components/global-styles/font-library-modal/utils/filter-fonts.js.map +1 -0
  51. package/build/components/global-styles/font-library-modal/utils/fonts-outline.js +20 -0
  52. package/build/components/global-styles/font-library-modal/utils/fonts-outline.js.map +1 -0
  53. package/build/components/global-styles/font-library-modal/utils/index.js +2 -52
  54. package/build/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  55. package/build/components/global-styles/font-library-modal/utils/preview-styles.js +76 -0
  56. package/build/components/global-styles/font-library-modal/utils/preview-styles.js.map +1 -0
  57. package/build/components/global-styles/font-library-modal/utils/sort-font-faces.js +36 -0
  58. package/build/components/global-styles/font-library-modal/utils/sort-font-faces.js.map +1 -0
  59. package/build/components/global-styles/screen-typography.js +1 -1
  60. package/build/components/global-styles/screen-typography.js.map +1 -1
  61. package/build/components/header-edit-mode/document-actions/index.js +9 -8
  62. package/build/components/header-edit-mode/document-actions/index.js.map +1 -1
  63. package/build/components/header-edit-mode/index.js +4 -1
  64. package/build/components/header-edit-mode/index.js.map +1 -1
  65. package/build/components/layout/index.js +5 -1
  66. package/build/components/layout/index.js.map +1 -1
  67. package/build/components/list/added-by.js +13 -8
  68. package/build/components/list/added-by.js.map +1 -1
  69. package/build/components/list/index.js +2 -1
  70. package/build/components/list/index.js.map +1 -1
  71. package/build/components/page-content-focus-manager/disable-non-page-content-blocks.js +2 -3
  72. package/build/components/page-content-focus-manager/disable-non-page-content-blocks.js.map +1 -1
  73. package/build/components/page-patterns/duplicate-menu-item.js +5 -5
  74. package/build/components/page-patterns/duplicate-menu-item.js.map +1 -1
  75. package/build/components/page-patterns/grid-item.js +5 -5
  76. package/build/components/page-patterns/grid-item.js.map +1 -1
  77. package/build/components/page-patterns/index.js +1 -1
  78. package/build/components/page-patterns/index.js.map +1 -1
  79. package/build/components/page-patterns/search-items.js +1 -1
  80. package/build/components/page-patterns/search-items.js.map +1 -1
  81. package/build/components/page-patterns/use-patterns.js +28 -34
  82. package/build/components/page-patterns/use-patterns.js.map +1 -1
  83. package/build/components/page-template-parts/add-new-template-part.js +3 -2
  84. package/build/components/page-template-parts/add-new-template-part.js.map +1 -1
  85. package/build/components/page-template-parts/index.js +2 -1
  86. package/build/components/page-template-parts/index.js.map +1 -1
  87. package/build/components/page-templates/index.js +3 -2
  88. package/build/components/page-templates/index.js.map +1 -1
  89. package/build/components/save-hub/index.js +2 -1
  90. package/build/components/save-hub/index.js.map +1 -1
  91. package/build/components/secondary-sidebar/list-view-sidebar.js +24 -17
  92. package/build/components/secondary-sidebar/list-view-sidebar.js.map +1 -1
  93. package/build/components/sidebar-edit-mode/page-panels/edit-template.js +21 -3
  94. package/build/components/sidebar-edit-mode/page-panels/edit-template.js.map +1 -1
  95. package/build/components/sidebar-edit-mode/page-panels/hooks.js +2 -1
  96. package/build/components/sidebar-edit-mode/page-panels/hooks.js.map +1 -1
  97. package/build/components/sidebar-edit-mode/settings-header/index.js +2 -6
  98. package/build/components/sidebar-edit-mode/settings-header/index.js.map +1 -1
  99. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js +9 -2
  100. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +1 -1
  101. package/build/components/sidebar-navigation-screen-navigation-menu/edit-button.js +2 -1
  102. package/build/components/sidebar-navigation-screen-navigation-menu/edit-button.js.map +1 -1
  103. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +2 -1
  104. package/build/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  105. package/build/components/sidebar-navigation-screen-navigation-menus/index.js +3 -2
  106. package/build/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  107. package/build/components/sidebar-navigation-screen-page/page-details.js +2 -1
  108. package/build/components/sidebar-navigation-screen-page/page-details.js.map +1 -1
  109. package/build/components/sidebar-navigation-screen-pages/index.js +5 -4
  110. package/build/components/sidebar-navigation-screen-pages/index.js.map +1 -1
  111. package/build/components/sidebar-navigation-screen-pattern/index.js +2 -1
  112. package/build/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  113. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js +3 -2
  114. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js.map +1 -1
  115. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +2 -1
  116. package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  117. package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +2 -1
  118. package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js.map +1 -1
  119. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js +8 -7
  120. package/build/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  121. package/build/components/sidebar-navigation-screen-patterns/index.js +3 -3
  122. package/build/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  123. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +7 -2
  124. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  125. package/build/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +7 -2
  126. package/build/components/sidebar-navigation-screen-patterns/use-template-part-areas.js.map +1 -1
  127. package/build/components/sidebar-navigation-screen-template/home-template-details.js +2 -1
  128. package/build/components/sidebar-navigation-screen-template/home-template-details.js.map +1 -1
  129. package/build/components/sidebar-navigation-screen-templates/index.js +4 -3
  130. package/build/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  131. package/build/components/sidebar-navigation-screen-templates-browse/index.js +3 -2
  132. package/build/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  133. package/build/components/start-template-options/index.js +20 -2
  134. package/build/components/start-template-options/index.js.map +1 -1
  135. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -4
  136. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  137. package/build/components/sync-state-with-url/use-sync-path-with-url.js +4 -3
  138. package/build/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  139. package/build/components/template-actions/index.js +2 -1
  140. package/build/components/template-actions/index.js.map +1 -1
  141. package/build/components/template-actions/rename-menu-item.js +8 -3
  142. package/build/components/template-actions/rename-menu-item.js.map +1 -1
  143. package/build/hooks/commands/use-edit-mode-commands.js +4 -3
  144. package/build/hooks/commands/use-edit-mode-commands.js.map +1 -1
  145. package/build/hooks/navigation-menu-edit.js +2 -1
  146. package/build/hooks/navigation-menu-edit.js.map +1 -1
  147. package/build/hooks/template-part-edit.js +2 -1
  148. package/build/hooks/template-part-edit.js.map +1 -1
  149. package/build/store/actions.js +10 -9
  150. package/build/store/actions.js.map +1 -1
  151. package/build/store/constants.js +1 -9
  152. package/build/store/constants.js.map +1 -1
  153. package/build/store/private-actions.js +21 -1
  154. package/build/store/private-actions.js.map +1 -1
  155. package/build/store/private-selectors.js +23 -0
  156. package/build/store/private-selectors.js.map +1 -1
  157. package/build/store/reducer.js +19 -1
  158. package/build/store/reducer.js.map +1 -1
  159. package/build/store/selectors.js +3 -2
  160. package/build/store/selectors.js.map +1 -1
  161. package/build/utils/constants.js +22 -3
  162. package/build/utils/constants.js.map +1 -1
  163. package/build/utils/is-template-removable.js +1 -1
  164. package/build/utils/is-template-removable.js.map +1 -1
  165. package/build/utils/is-template-revertable.js +1 -1
  166. package/build/utils/is-template-revertable.js.map +1 -1
  167. package/build/utils/template-part-create.js +6 -1
  168. package/build/utils/template-part-create.js.map +1 -1
  169. package/build-module/components/add-new-pattern/index.js +3 -3
  170. package/build-module/components/add-new-pattern/index.js.map +1 -1
  171. package/build-module/components/block-editor/block-editor-provider/default-block-editor-provider.js +65 -0
  172. package/build-module/components/block-editor/block-editor-provider/default-block-editor-provider.js.map +1 -0
  173. package/build-module/components/block-editor/block-editor-provider/index.js +23 -0
  174. package/build-module/components/block-editor/block-editor-provider/index.js.map +1 -0
  175. package/build-module/components/block-editor/{providers → block-editor-provider}/navigation-block-editor-provider.js +2 -1
  176. package/build-module/components/block-editor/block-editor-provider/navigation-block-editor-provider.js.map +1 -0
  177. package/build-module/components/block-editor/block-editor-provider/use-page-content-blocks.js +70 -0
  178. package/build-module/components/block-editor/block-editor-provider/use-page-content-blocks.js.map +1 -0
  179. package/build-module/components/block-editor/index.js +1 -8
  180. package/build-module/components/block-editor/index.js.map +1 -1
  181. package/build-module/components/block-editor/site-editor-canvas.js +2 -2
  182. package/build-module/components/block-editor/site-editor-canvas.js.map +1 -1
  183. package/build-module/components/create-template-part-modal/index.js +8 -12
  184. package/build-module/components/create-template-part-modal/index.js.map +1 -1
  185. package/build-module/components/editor/index.js +4 -1
  186. package/build-module/components/editor/index.js.map +1 -1
  187. package/build-module/components/global-styles/font-family-item.js +2 -2
  188. package/build-module/components/global-styles/font-family-item.js.map +1 -1
  189. package/build-module/components/global-styles/font-library-modal/collection-font-details.js +40 -0
  190. package/build-module/components/global-styles/font-library-modal/collection-font-details.js.map +1 -0
  191. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js +45 -0
  192. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -0
  193. package/build-module/components/global-styles/font-library-modal/context.js +27 -3
  194. package/build-module/components/global-styles/font-library-modal/context.js.map +1 -1
  195. package/build-module/components/global-styles/font-library-modal/font-card.js +8 -5
  196. package/build-module/components/global-styles/font-library-modal/font-card.js.map +1 -1
  197. package/build-module/components/global-styles/font-library-modal/font-collection.js +164 -0
  198. package/build-module/components/global-styles/font-library-modal/font-collection.js.map +1 -0
  199. package/build-module/components/global-styles/font-library-modal/font-demo.js +30 -13
  200. package/build-module/components/global-styles/font-library-modal/font-demo.js.map +1 -1
  201. package/build-module/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js +33 -0
  202. package/build-module/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js.map +1 -0
  203. package/build-module/components/global-styles/font-library-modal/index.js +26 -7
  204. package/build-module/components/global-styles/font-library-modal/index.js.map +1 -1
  205. package/build-module/components/global-styles/font-library-modal/installed-fonts.js +2 -2
  206. package/build-module/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  207. package/build-module/components/global-styles/font-library-modal/library-font-card.js +0 -5
  208. package/build-module/components/global-styles/font-library-modal/library-font-card.js.map +1 -1
  209. package/build-module/components/global-styles/font-library-modal/library-font-details.js +2 -1
  210. package/build-module/components/global-styles/font-library-modal/library-font-details.js.map +1 -1
  211. package/build-module/components/global-styles/font-library-modal/resolvers.js +14 -0
  212. package/build-module/components/global-styles/font-library-modal/resolvers.js.map +1 -1
  213. package/build-module/components/global-styles/font-library-modal/tab-layout.js +2 -2
  214. package/build-module/components/global-styles/font-library-modal/tab-layout.js.map +1 -1
  215. package/build-module/components/global-styles/font-library-modal/utils/constants.js +1 -6
  216. package/build-module/components/global-styles/font-library-modal/utils/constants.js.map +1 -1
  217. package/build-module/components/global-styles/font-library-modal/utils/filter-fonts.js +15 -0
  218. package/build-module/components/global-styles/font-library-modal/utils/filter-fonts.js.map +1 -0
  219. package/build-module/components/global-styles/font-library-modal/utils/fonts-outline.js +13 -0
  220. package/build-module/components/global-styles/font-library-modal/utils/fonts-outline.js.map +1 -0
  221. package/build-module/components/global-styles/font-library-modal/utils/index.js +2 -51
  222. package/build-module/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  223. package/build-module/components/global-styles/font-library-modal/utils/preview-styles.js +68 -0
  224. package/build-module/components/global-styles/font-library-modal/utils/preview-styles.js.map +1 -0
  225. package/build-module/components/global-styles/font-library-modal/utils/sort-font-faces.js +30 -0
  226. package/build-module/components/global-styles/font-library-modal/utils/sort-font-faces.js.map +1 -0
  227. package/build-module/components/global-styles/screen-typography.js +1 -1
  228. package/build-module/components/global-styles/screen-typography.js.map +1 -1
  229. package/build-module/components/header-edit-mode/document-actions/index.js +9 -8
  230. package/build-module/components/header-edit-mode/document-actions/index.js.map +1 -1
  231. package/build-module/components/header-edit-mode/index.js +4 -1
  232. package/build-module/components/header-edit-mode/index.js.map +1 -1
  233. package/build-module/components/layout/index.js +5 -1
  234. package/build-module/components/layout/index.js.map +1 -1
  235. package/build-module/components/list/added-by.js +13 -8
  236. package/build-module/components/list/added-by.js.map +1 -1
  237. package/build-module/components/list/index.js +2 -1
  238. package/build-module/components/list/index.js.map +1 -1
  239. package/build-module/components/page-content-focus-manager/disable-non-page-content-blocks.js +2 -3
  240. package/build-module/components/page-content-focus-manager/disable-non-page-content-blocks.js.map +1 -1
  241. package/build-module/components/page-patterns/duplicate-menu-item.js +5 -5
  242. package/build-module/components/page-patterns/duplicate-menu-item.js.map +1 -1
  243. package/build-module/components/page-patterns/grid-item.js +5 -5
  244. package/build-module/components/page-patterns/grid-item.js.map +1 -1
  245. package/build-module/components/page-patterns/index.js +1 -1
  246. package/build-module/components/page-patterns/index.js.map +1 -1
  247. package/build-module/components/page-patterns/search-items.js +2 -2
  248. package/build-module/components/page-patterns/search-items.js.map +1 -1
  249. package/build-module/components/page-patterns/use-patterns.js +28 -35
  250. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  251. package/build-module/components/page-template-parts/add-new-template-part.js +3 -2
  252. package/build-module/components/page-template-parts/add-new-template-part.js.map +1 -1
  253. package/build-module/components/page-template-parts/index.js +2 -1
  254. package/build-module/components/page-template-parts/index.js.map +1 -1
  255. package/build-module/components/page-templates/index.js +3 -2
  256. package/build-module/components/page-templates/index.js.map +1 -1
  257. package/build-module/components/save-hub/index.js +2 -1
  258. package/build-module/components/save-hub/index.js.map +1 -1
  259. package/build-module/components/secondary-sidebar/list-view-sidebar.js +26 -19
  260. package/build-module/components/secondary-sidebar/list-view-sidebar.js.map +1 -1
  261. package/build-module/components/sidebar-edit-mode/page-panels/edit-template.js +21 -3
  262. package/build-module/components/sidebar-edit-mode/page-panels/edit-template.js.map +1 -1
  263. package/build-module/components/sidebar-edit-mode/page-panels/hooks.js +2 -1
  264. package/build-module/components/sidebar-edit-mode/page-panels/hooks.js.map +1 -1
  265. package/build-module/components/sidebar-edit-mode/settings-header/index.js +2 -6
  266. package/build-module/components/sidebar-edit-mode/settings-header/index.js.map +1 -1
  267. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js +9 -2
  268. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +1 -1
  269. package/build-module/components/sidebar-navigation-screen-navigation-menu/edit-button.js +2 -1
  270. package/build-module/components/sidebar-navigation-screen-navigation-menu/edit-button.js.map +1 -1
  271. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +3 -1
  272. package/build-module/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js.map +1 -1
  273. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js +3 -2
  274. package/build-module/components/sidebar-navigation-screen-navigation-menus/index.js.map +1 -1
  275. package/build-module/components/sidebar-navigation-screen-page/page-details.js +2 -1
  276. package/build-module/components/sidebar-navigation-screen-page/page-details.js.map +1 -1
  277. package/build-module/components/sidebar-navigation-screen-pages/index.js +5 -4
  278. package/build-module/components/sidebar-navigation-screen-pages/index.js.map +1 -1
  279. package/build-module/components/sidebar-navigation-screen-pattern/index.js +2 -1
  280. package/build-module/components/sidebar-navigation-screen-pattern/index.js.map +1 -1
  281. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js +3 -2
  282. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js.map +1 -1
  283. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +2 -1
  284. package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
  285. package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +2 -1
  286. package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js.map +1 -1
  287. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js +8 -7
  288. package/build-module/components/sidebar-navigation-screen-pattern/use-pattern-details.js.map +1 -1
  289. package/build-module/components/sidebar-navigation-screen-patterns/index.js +4 -4
  290. package/build-module/components/sidebar-navigation-screen-patterns/index.js.map +1 -1
  291. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +8 -3
  292. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  293. package/build-module/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +7 -2
  294. package/build-module/components/sidebar-navigation-screen-patterns/use-template-part-areas.js.map +1 -1
  295. package/build-module/components/sidebar-navigation-screen-template/home-template-details.js +2 -1
  296. package/build-module/components/sidebar-navigation-screen-template/home-template-details.js.map +1 -1
  297. package/build-module/components/sidebar-navigation-screen-templates/index.js +4 -3
  298. package/build-module/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  299. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js +3 -2
  300. package/build-module/components/sidebar-navigation-screen-templates-browse/index.js.map +1 -1
  301. package/build-module/components/start-template-options/index.js +20 -2
  302. package/build-module/components/start-template-options/index.js.map +1 -1
  303. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -4
  304. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  305. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js +4 -3
  306. package/build-module/components/sync-state-with-url/use-sync-path-with-url.js.map +1 -1
  307. package/build-module/components/template-actions/index.js +2 -1
  308. package/build-module/components/template-actions/index.js.map +1 -1
  309. package/build-module/components/template-actions/rename-menu-item.js +8 -3
  310. package/build-module/components/template-actions/rename-menu-item.js.map +1 -1
  311. package/build-module/hooks/commands/use-edit-mode-commands.js +4 -3
  312. package/build-module/hooks/commands/use-edit-mode-commands.js.map +1 -1
  313. package/build-module/hooks/navigation-menu-edit.js +2 -1
  314. package/build-module/hooks/navigation-menu-edit.js.map +1 -1
  315. package/build-module/hooks/template-part-edit.js +2 -1
  316. package/build-module/hooks/template-part-edit.js.map +1 -1
  317. package/build-module/store/actions.js +10 -10
  318. package/build-module/store/actions.js.map +1 -1
  319. package/build-module/store/constants.js +0 -4
  320. package/build-module/store/constants.js.map +1 -1
  321. package/build-module/store/private-actions.js +19 -0
  322. package/build-module/store/private-actions.js.map +1 -1
  323. package/build-module/store/private-selectors.js +22 -0
  324. package/build-module/store/private-selectors.js.map +1 -1
  325. package/build-module/store/reducer.js +18 -1
  326. package/build-module/store/reducer.js.map +1 -1
  327. package/build-module/store/selectors.js +3 -3
  328. package/build-module/store/selectors.js.map +1 -1
  329. package/build-module/utils/constants.js +17 -1
  330. package/build-module/utils/constants.js.map +1 -1
  331. package/build-module/utils/is-template-removable.js +2 -2
  332. package/build-module/utils/is-template-removable.js.map +1 -1
  333. package/build-module/utils/is-template-revertable.js +2 -2
  334. package/build-module/utils/is-template-revertable.js.map +1 -1
  335. package/build-module/utils/template-part-create.js +6 -1
  336. package/build-module/utils/template-part-create.js.map +1 -1
  337. package/build-style/style-rtl.css +23 -0
  338. package/build-style/style.css +23 -0
  339. package/package.json +40 -40
  340. package/src/components/add-new-pattern/index.js +3 -3
  341. package/src/components/block-editor/block-editor-provider/default-block-editor-provider.js +70 -0
  342. package/src/components/block-editor/block-editor-provider/index.js +29 -0
  343. package/src/components/block-editor/{providers → block-editor-provider}/navigation-block-editor-provider.js +2 -1
  344. package/src/components/block-editor/block-editor-provider/test/use-page-content-blocks.js +87 -0
  345. package/src/components/block-editor/block-editor-provider/use-page-content-blocks.js +77 -0
  346. package/src/components/block-editor/index.js +1 -14
  347. package/src/components/block-editor/site-editor-canvas.js +5 -2
  348. package/src/components/create-template-part-modal/index.js +11 -12
  349. package/src/components/editor/index.js +6 -2
  350. package/src/components/global-styles/font-family-item.js +2 -2
  351. package/src/components/global-styles/font-library-modal/collection-font-details.js +56 -0
  352. package/src/components/global-styles/font-library-modal/collection-font-variant.js +45 -0
  353. package/src/components/global-styles/font-library-modal/context.js +33 -2
  354. package/src/components/global-styles/font-library-modal/font-card.js +9 -4
  355. package/src/components/global-styles/font-library-modal/font-collection.js +257 -0
  356. package/src/components/global-styles/font-library-modal/font-demo.js +36 -10
  357. package/src/components/global-styles/font-library-modal/google-fonts-confirm-dialog.js +50 -0
  358. package/src/components/global-styles/font-library-modal/index.js +30 -5
  359. package/src/components/global-styles/font-library-modal/installed-fonts.js +1 -1
  360. package/src/components/global-styles/font-library-modal/library-font-card.js +1 -8
  361. package/src/components/global-styles/font-library-modal/library-font-details.js +2 -3
  362. package/src/components/global-styles/font-library-modal/resolvers.js +16 -0
  363. package/src/components/global-styles/font-library-modal/style.scss +26 -0
  364. package/src/components/global-styles/font-library-modal/tab-layout.js +2 -2
  365. package/src/components/global-styles/font-library-modal/utils/constants.js +1 -9
  366. package/src/components/global-styles/font-library-modal/utils/filter-fonts.js +18 -0
  367. package/src/components/global-styles/font-library-modal/utils/fonts-outline.js +21 -0
  368. package/src/components/global-styles/font-library-modal/utils/index.js +9 -69
  369. package/src/components/global-styles/font-library-modal/utils/preview-styles.js +86 -0
  370. package/src/components/global-styles/font-library-modal/utils/sort-font-faces.js +33 -0
  371. package/src/components/global-styles/font-library-modal/utils/test/filter-fonts.spec.js +69 -0
  372. package/src/components/global-styles/font-library-modal/utils/test/fonts-outline.spec.js +109 -0
  373. package/src/components/global-styles/font-library-modal/utils/test/{getPreviewStyle.spec.js → preview-styles.spec.js} +49 -9
  374. package/src/components/global-styles/font-library-modal/utils/test/sort-font-faces.js +74 -0
  375. package/src/components/global-styles/screen-typography.js +3 -1
  376. package/src/components/header-edit-mode/document-actions/index.js +17 -8
  377. package/src/components/header-edit-mode/index.js +2 -1
  378. package/src/components/layout/index.js +10 -1
  379. package/src/components/list/added-by.js +29 -11
  380. package/src/components/list/index.js +7 -1
  381. package/src/components/page-content-focus-manager/disable-non-page-content-blocks.js +2 -8
  382. package/src/components/page-patterns/duplicate-menu-item.js +5 -5
  383. package/src/components/page-patterns/grid-item.js +5 -5
  384. package/src/components/page-patterns/index.js +1 -1
  385. package/src/components/page-patterns/search-items.js +7 -1
  386. package/src/components/page-patterns/use-patterns.js +190 -134
  387. package/src/components/page-template-parts/add-new-template-part.js +5 -2
  388. package/src/components/page-template-parts/index.js +2 -1
  389. package/src/components/page-templates/index.js +3 -2
  390. package/src/components/save-hub/index.js +2 -1
  391. package/src/components/secondary-sidebar/list-view-sidebar.js +31 -26
  392. package/src/components/sidebar-edit-mode/page-panels/edit-template.js +48 -20
  393. package/src/components/sidebar-edit-mode/page-panels/hooks.js +9 -4
  394. package/src/components/sidebar-edit-mode/page-panels/style.scss +6 -0
  395. package/src/components/sidebar-edit-mode/settings-header/index.js +4 -7
  396. package/src/components/sidebar-edit-mode/template-panel/pattern-categories.js +9 -2
  397. package/src/components/sidebar-navigation-screen-navigation-menu/edit-button.js +2 -1
  398. package/src/components/sidebar-navigation-screen-navigation-menu/use-navigation-menu-handlers.js +3 -1
  399. package/src/components/sidebar-navigation-screen-navigation-menus/index.js +3 -2
  400. package/src/components/sidebar-navigation-screen-page/page-details.js +2 -1
  401. package/src/components/sidebar-navigation-screen-pages/index.js +5 -4
  402. package/src/components/sidebar-navigation-screen-pattern/index.js +2 -1
  403. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js +8 -2
  404. package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +7 -1
  405. package/src/components/sidebar-navigation-screen-pattern/use-navigation-menu-content.js +2 -1
  406. package/src/components/sidebar-navigation-screen-pattern/use-pattern-details.js +18 -8
  407. package/src/components/sidebar-navigation-screen-patterns/index.js +8 -4
  408. package/src/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +16 -3
  409. package/src/components/sidebar-navigation-screen-patterns/use-template-part-areas.js +12 -2
  410. package/src/components/sidebar-navigation-screen-template/home-template-details.js +2 -1
  411. package/src/components/sidebar-navigation-screen-templates/index.js +4 -3
  412. package/src/components/sidebar-navigation-screen-templates-browse/index.js +6 -2
  413. package/src/components/start-template-options/index.js +39 -2
  414. package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +10 -4
  415. package/src/components/sync-state-with-url/use-sync-path-with-url.js +8 -3
  416. package/src/components/template-actions/index.js +2 -1
  417. package/src/components/template-actions/rename-menu-item.js +8 -3
  418. package/src/hooks/commands/use-edit-mode-commands.js +4 -3
  419. package/src/hooks/navigation-menu-edit.js +2 -1
  420. package/src/hooks/template-part-edit.js +2 -1
  421. package/src/store/actions.js +18 -10
  422. package/src/store/constants.js +0 -5
  423. package/src/store/private-actions.js +19 -0
  424. package/src/store/private-selectors.js +22 -0
  425. package/src/store/reducer.js +18 -0
  426. package/src/store/selectors.js +6 -3
  427. package/src/store/test/reducer.js +18 -0
  428. package/src/utils/constants.js +17 -1
  429. package/src/utils/is-template-removable.js +2 -2
  430. package/src/utils/is-template-revertable.js +2 -2
  431. package/src/utils/template-part-create.js +6 -1
  432. package/build/components/block-editor/get-block-editor-provider.js +0 -35
  433. package/build/components/block-editor/get-block-editor-provider.js.map +0 -1
  434. package/build/components/block-editor/providers/default-block-editor-provider.js +0 -49
  435. package/build/components/block-editor/providers/default-block-editor-provider.js.map +0 -1
  436. package/build/components/block-editor/providers/navigation-block-editor-provider.js.map +0 -1
  437. package/build-module/components/block-editor/get-block-editor-provider.js +0 -28
  438. package/build-module/components/block-editor/get-block-editor-provider.js.map +0 -1
  439. package/build-module/components/block-editor/providers/default-block-editor-provider.js +0 -41
  440. package/build-module/components/block-editor/providers/default-block-editor-provider.js.map +0 -1
  441. package/build-module/components/block-editor/providers/navigation-block-editor-provider.js.map +0 -1
  442. package/src/components/block-editor/get-block-editor-provider.js +0 -29
  443. package/src/components/block-editor/providers/default-block-editor-provider.js +0 -44
@@ -1,3 +1,8 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import createSelector from 'rememo';
5
+
1
6
  /**
2
7
  * WordPress dependencies
3
8
  */
@@ -16,6 +21,8 @@ import {
16
21
  PATTERN_TYPES,
17
22
  PATTERN_SYNC_TYPES,
18
23
  TEMPLATE_PART_POST_TYPE,
24
+ TEMPLATE_ORIGINS,
25
+ TEMPLATE_PART_AREA_DEFAULT_CATEGORY,
19
26
  } from '../../utils/constants';
20
27
  import { unlock } from '../../lock-unlock';
21
28
  import { searchItems } from './search-items';
@@ -32,7 +39,7 @@ const templatePartToPattern = ( templatePart ) => ( {
32
39
  } ),
33
40
  categories: [ templatePart.area ],
34
41
  description: templatePart.description || '',
35
- isCustom: templatePart.source === 'custom',
42
+ isCustom: templatePart.source === TEMPLATE_ORIGINS.custom,
36
43
  keywords: templatePart.keywords || [],
37
44
  id: createTemplatePartId( templatePart.theme, templatePart.slug ),
38
45
  name: createTemplatePartId( templatePart.theme, templatePart.slug ),
@@ -41,108 +48,136 @@ const templatePartToPattern = ( templatePart ) => ( {
41
48
  templatePart,
42
49
  } );
43
50
 
44
- const selectTemplatePartsAsPatterns = (
45
- select,
46
- { categoryId, search = '' } = {}
47
- ) => {
48
- const { getEntityRecords, getIsResolving } = select( coreStore );
49
- const { __experimentalGetDefaultTemplatePartAreas } = select( editorStore );
50
- const query = { per_page: -1 };
51
- const rawTemplateParts =
52
- getEntityRecords( 'postType', TEMPLATE_PART_POST_TYPE, query ) ??
53
- EMPTY_PATTERN_LIST;
54
- const templateParts = rawTemplateParts.map( ( templatePart ) =>
55
- templatePartToPattern( templatePart )
56
- );
51
+ const selectTemplatePartsAsPatterns = createSelector(
52
+ ( select, categoryId, search = '' ) => {
53
+ const { getEntityRecords, getIsResolving } = select( coreStore );
54
+ const { __experimentalGetDefaultTemplatePartAreas } =
55
+ select( editorStore );
56
+ const query = { per_page: -1 };
57
+ const rawTemplateParts =
58
+ getEntityRecords( 'postType', TEMPLATE_PART_POST_TYPE, query ) ??
59
+ EMPTY_PATTERN_LIST;
60
+ const templateParts = rawTemplateParts.map( ( templatePart ) =>
61
+ templatePartToPattern( templatePart )
62
+ );
57
63
 
58
- // In the case where a custom template part area has been removed we need
59
- // the current list of areas to cross check against so orphaned template
60
- // parts can be treated as uncategorized.
61
- const knownAreas = __experimentalGetDefaultTemplatePartAreas() || [];
62
- const templatePartAreas = knownAreas.map( ( area ) => area.area );
64
+ // In the case where a custom template part area has been removed we need
65
+ // the current list of areas to cross check against so orphaned template
66
+ // parts can be treated as uncategorized.
67
+ const knownAreas = __experimentalGetDefaultTemplatePartAreas() || [];
68
+ const templatePartAreas = knownAreas.map( ( area ) => area.area );
63
69
 
64
- const templatePartHasCategory = ( item, category ) => {
65
- if ( category !== 'uncategorized' ) {
66
- return item.templatePart.area === category;
67
- }
70
+ const templatePartHasCategory = ( item, category ) => {
71
+ if ( category !== TEMPLATE_PART_AREA_DEFAULT_CATEGORY ) {
72
+ return item.templatePart.area === category;
73
+ }
68
74
 
69
- return (
70
- item.templatePart.area === category ||
71
- ! templatePartAreas.includes( item.templatePart.area )
72
- );
73
- };
75
+ return (
76
+ item.templatePart.area === category ||
77
+ ! templatePartAreas.includes( item.templatePart.area )
78
+ );
79
+ };
80
+
81
+ const isResolving = getIsResolving( 'getEntityRecords', [
82
+ 'postType',
83
+ TEMPLATE_PART_POST_TYPE,
84
+ query,
85
+ ] );
74
86
 
75
- const isResolving = getIsResolving( 'getEntityRecords', [
76
- 'postType',
77
- 'wp_template_part',
78
- query,
79
- ] );
87
+ const patterns = searchItems( templateParts, search, {
88
+ categoryId,
89
+ hasCategory: templatePartHasCategory,
90
+ } );
80
91
 
81
- const patterns = searchItems( templateParts, search, {
82
- categoryId,
83
- hasCategory: templatePartHasCategory,
84
- } );
92
+ return { patterns, isResolving };
93
+ },
94
+ ( select ) => [
95
+ select( coreStore ).getEntityRecords(
96
+ 'postType',
97
+ TEMPLATE_PART_POST_TYPE,
98
+ {
99
+ per_page: -1,
100
+ }
101
+ ),
102
+ select( coreStore ).getIsResolving( 'getEntityRecords', [
103
+ 'postType',
104
+ TEMPLATE_PART_POST_TYPE,
105
+ { per_page: -1 },
106
+ ] ),
107
+ select( editorStore ).__experimentalGetDefaultTemplatePartAreas(),
108
+ ]
109
+ );
85
110
 
86
- return { patterns, isResolving };
87
- };
111
+ const selectThemePatterns = createSelector(
112
+ ( select ) => {
113
+ const { getSettings } = unlock( select( editSiteStore ) );
114
+ const settings = getSettings();
115
+ const blockPatterns =
116
+ settings.__experimentalAdditionalBlockPatterns ??
117
+ settings.__experimentalBlockPatterns;
88
118
 
89
- const selectThemePatterns = ( select ) => {
90
- const { getSettings } = unlock( select( editSiteStore ) );
91
- const settings = getSettings();
92
- const blockPatterns =
93
- settings.__experimentalAdditionalBlockPatterns ??
94
- settings.__experimentalBlockPatterns;
119
+ const restBlockPatterns = select( coreStore ).getBlockPatterns();
95
120
 
96
- const restBlockPatterns = select( coreStore ).getBlockPatterns();
121
+ const patterns = [
122
+ ...( blockPatterns || [] ),
123
+ ...( restBlockPatterns || [] ),
124
+ ]
125
+ .filter(
126
+ ( pattern ) => ! PATTERN_CORE_SOURCES.includes( pattern.source )
127
+ )
128
+ .filter( filterOutDuplicatesByName )
129
+ .filter( ( pattern ) => pattern.inserter !== false )
130
+ .map( ( pattern ) => ( {
131
+ ...pattern,
132
+ keywords: pattern.keywords || [],
133
+ type: PATTERN_TYPES.theme,
134
+ blocks: parse( pattern.content, {
135
+ __unstableSkipMigrationLogs: true,
136
+ } ),
137
+ } ) );
97
138
 
98
- const patterns = [
99
- ...( blockPatterns || [] ),
100
- ...( restBlockPatterns || [] ),
139
+ return { patterns, isResolving: false };
140
+ },
141
+ ( select ) => [
142
+ select( coreStore ).getBlockPatterns(),
143
+ unlock( select( editSiteStore ) ).getSettings(),
101
144
  ]
102
- .filter(
103
- ( pattern ) => ! PATTERN_CORE_SOURCES.includes( pattern.source )
104
- )
105
- .filter( filterOutDuplicatesByName )
106
- .filter( ( pattern ) => pattern.inserter !== false )
107
- .map( ( pattern ) => ( {
108
- ...pattern,
109
- keywords: pattern.keywords || [],
110
- type: PATTERN_TYPES.theme,
111
- blocks: parse( pattern.content, {
112
- __unstableSkipMigrationLogs: true,
113
- } ),
114
- } ) );
115
-
116
- return { patterns, isResolving: false };
117
- };
118
- const selectPatterns = (
119
- select,
120
- { categoryId, search = '', syncStatus } = {}
121
- ) => {
122
- const { patterns: themePatterns } = selectThemePatterns( select );
123
- const { patterns: userPatterns } = selectUserPatterns( select );
145
+ );
124
146
 
125
- let patterns = [ ...( themePatterns || [] ), ...( userPatterns || [] ) ];
147
+ const selectPatterns = createSelector(
148
+ ( select, categoryId, syncStatus, search = '' ) => {
149
+ const { patterns: themePatterns } = selectThemePatterns( select );
150
+ const { patterns: userPatterns } = selectUserPatterns( select );
126
151
 
127
- if ( syncStatus ) {
128
- patterns = patterns.filter(
129
- ( pattern ) => pattern.syncStatus === syncStatus
130
- );
131
- }
152
+ let patterns = [
153
+ ...( themePatterns || [] ),
154
+ ...( userPatterns || [] ),
155
+ ];
132
156
 
133
- if ( categoryId ) {
134
- patterns = searchItems( patterns, search, {
135
- categoryId,
136
- hasCategory: ( item, currentCategory ) =>
137
- item.categories?.includes( currentCategory ),
138
- } );
139
- } else {
140
- patterns = searchItems( patterns, search, {
141
- hasCategory: ( item ) => ! item.hasOwnProperty( 'categories' ),
142
- } );
143
- }
144
- return { patterns, isResolving: false };
145
- };
157
+ if ( syncStatus ) {
158
+ patterns = patterns.filter(
159
+ ( pattern ) => pattern.syncStatus === syncStatus
160
+ );
161
+ }
162
+
163
+ if ( categoryId ) {
164
+ patterns = searchItems( patterns, search, {
165
+ categoryId,
166
+ hasCategory: ( item, currentCategory ) =>
167
+ item.categories?.includes( currentCategory ),
168
+ } );
169
+ } else {
170
+ patterns = searchItems( patterns, search, {
171
+ hasCategory: ( item ) => ! item.hasOwnProperty( 'categories' ),
172
+ } );
173
+ }
174
+ return { patterns, isResolving: false };
175
+ },
176
+ ( select ) => [
177
+ selectThemePatterns( select ),
178
+ selectUserPatterns( select ),
179
+ ]
180
+ );
146
181
 
147
182
  const patternBlockToPattern = ( patternBlock, categories ) => ( {
148
183
  blocks: parse( patternBlock.content.raw, {
@@ -164,44 +199,65 @@ const patternBlockToPattern = ( patternBlock, categories ) => ( {
164
199
  patternBlock,
165
200
  } );
166
201
 
167
- const selectUserPatterns = ( select, { search = '', syncStatus } = {} ) => {
168
- const { getEntityRecords, getIsResolving, getUserPatternCategories } =
169
- select( coreStore );
202
+ const selectUserPatterns = createSelector(
203
+ ( select, syncStatus, search = '' ) => {
204
+ const { getEntityRecords, getIsResolving, getUserPatternCategories } =
205
+ select( coreStore );
170
206
 
171
- const query = { per_page: -1 };
172
- const records = getEntityRecords( 'postType', PATTERN_TYPES.user, query );
173
- const userPatternCategories = getUserPatternCategories();
174
- const categories = new Map();
175
- userPatternCategories.forEach( ( userCategory ) =>
176
- categories.set( userCategory.id, userCategory )
177
- );
178
- let patterns = records
179
- ? records.map( ( record ) =>
180
- patternBlockToPattern( record, categories )
181
- )
182
- : EMPTY_PATTERN_LIST;
183
-
184
- const isResolving = getIsResolving( 'getEntityRecords', [
185
- 'postType',
186
- PATTERN_TYPES.user,
187
- query,
188
- ] );
189
-
190
- if ( syncStatus ) {
191
- patterns = patterns.filter(
192
- ( pattern ) => pattern.syncStatus === syncStatus
207
+ const query = { per_page: -1 };
208
+ const records = getEntityRecords(
209
+ 'postType',
210
+ PATTERN_TYPES.user,
211
+ query
193
212
  );
194
- }
213
+ const userPatternCategories = getUserPatternCategories();
214
+ const categories = new Map();
215
+ userPatternCategories.forEach( ( userCategory ) =>
216
+ categories.set( userCategory.id, userCategory )
217
+ );
218
+ let patterns = records
219
+ ? records.map( ( record ) =>
220
+ patternBlockToPattern( record, categories )
221
+ )
222
+ : EMPTY_PATTERN_LIST;
195
223
 
196
- patterns = searchItems( patterns, search, {
197
- // We exit user pattern retrieval early if we aren't in the
198
- // catch-all category for user created patterns, so it has
199
- // to be in the category.
200
- hasCategory: () => true,
201
- } );
224
+ const isResolving = getIsResolving( 'getEntityRecords', [
225
+ 'postType',
226
+ PATTERN_TYPES.user,
227
+ query,
228
+ ] );
202
229
 
203
- return { patterns, isResolving, categories: userPatternCategories };
204
- };
230
+ if ( syncStatus ) {
231
+ patterns = patterns.filter(
232
+ ( pattern ) => pattern.syncStatus === syncStatus
233
+ );
234
+ }
235
+
236
+ patterns = searchItems( patterns, search, {
237
+ // We exit user pattern retrieval early if we aren't in the
238
+ // catch-all category for user created patterns, so it has
239
+ // to be in the category.
240
+ hasCategory: () => true,
241
+ } );
242
+
243
+ return {
244
+ patterns,
245
+ isResolving,
246
+ categories: userPatternCategories,
247
+ };
248
+ },
249
+ ( select ) => [
250
+ select( coreStore ).getEntityRecords( 'postType', PATTERN_TYPES.user, {
251
+ per_page: -1,
252
+ } ),
253
+ select( coreStore ).getIsResolving( 'getEntityRecords', [
254
+ 'postType',
255
+ PATTERN_TYPES.user,
256
+ { per_page: -1 },
257
+ ] ),
258
+ select( coreStore ).getUserPatternCategories(),
259
+ ]
260
+ );
205
261
 
206
262
  export const usePatterns = (
207
263
  categoryType,
@@ -211,20 +267,20 @@ export const usePatterns = (
211
267
  return useSelect(
212
268
  ( select ) => {
213
269
  if ( categoryType === TEMPLATE_PART_POST_TYPE ) {
214
- return selectTemplatePartsAsPatterns( select, {
270
+ return selectTemplatePartsAsPatterns(
271
+ select,
215
272
  categoryId,
216
- search,
217
- } );
273
+ search
274
+ );
218
275
  } else if ( categoryType === PATTERN_TYPES.theme ) {
219
- return selectPatterns( select, {
220
- categoryId,
221
- search,
222
- syncStatus,
223
- } );
276
+ return selectPatterns( select, categoryId, syncStatus, search );
224
277
  } else if ( categoryType === PATTERN_TYPES.user ) {
225
- return selectUserPatterns( select, { search, syncStatus } );
278
+ return selectUserPatterns( select, syncStatus, search );
226
279
  }
227
- return { patterns: EMPTY_PATTERN_LIST, isResolving: false };
280
+ return {
281
+ patterns: EMPTY_PATTERN_LIST,
282
+ isResolving: false,
283
+ };
228
284
  },
229
285
  [ categoryId, categoryType, search, syncStatus ]
230
286
  );
@@ -13,6 +13,7 @@ import { Button } from '@wordpress/components';
13
13
  import { unlock } from '../../lock-unlock';
14
14
  import { store as editSiteStore } from '../../store';
15
15
  import CreateTemplatePartModal from '../create-template-part-modal';
16
+ import { TEMPLATE_PART_POST_TYPE } from '../../utils/constants';
16
17
 
17
18
  const { useHistory } = unlock( routerPrivateApis );
18
19
 
@@ -22,7 +23,9 @@ export default function AddNewTemplatePart() {
22
23
  select( editSiteStore ).getSettings();
23
24
  return {
24
25
  canCreate: ! supportsTemplatePartsMode,
25
- postType: select( coreStore ).getPostType( 'wp_template_part' ),
26
+ postType: select( coreStore ).getPostType(
27
+ TEMPLATE_PART_POST_TYPE
28
+ ),
26
29
  };
27
30
  }, [] );
28
31
  const [ isModalOpen, setIsModalOpen ] = useState( false );
@@ -45,7 +48,7 @@ export default function AddNewTemplatePart() {
45
48
  setIsModalOpen( false );
46
49
  history.push( {
47
50
  postId: templatePart.id,
48
- postType: 'wp_template_part',
51
+ postType: TEMPLATE_PART_POST_TYPE,
49
52
  canvas: 'edit',
50
53
  } );
51
54
  } }
@@ -19,11 +19,12 @@ import Link from '../routes/link';
19
19
  import AddedBy from '../list/added-by';
20
20
  import TemplateActions from '../template-actions';
21
21
  import AddNewTemplatePart from './add-new-template-part';
22
+ import { TEMPLATE_PART_POST_TYPE } from '../../utils/constants';
22
23
 
23
24
  export default function PageTemplateParts() {
24
25
  const { records: templateParts } = useEntityRecords(
25
26
  'postType',
26
- 'wp_template_part',
27
+ TEMPLATE_PART_POST_TYPE,
27
28
  {
28
29
  per_page: -1,
29
30
  }
@@ -20,11 +20,12 @@ import Link from '../routes/link';
20
20
  import AddedBy from '../list/added-by';
21
21
  import TemplateActions from '../template-actions';
22
22
  import AddNewTemplate from '../add-new-template';
23
+ import { TEMPLATE_POST_TYPE } from '../../utils/constants';
23
24
 
24
25
  export default function PageTemplates() {
25
26
  const { records: templates } = useEntityRecords(
26
27
  'postType',
27
- 'wp_template',
28
+ TEMPLATE_POST_TYPE,
28
29
  {
29
30
  per_page: -1,
30
31
  }
@@ -79,7 +80,7 @@ export default function PageTemplates() {
79
80
  title={ __( 'Templates' ) }
80
81
  actions={
81
82
  <AddNewTemplate
82
- templateType={ 'wp_template' }
83
+ templateType={ TEMPLATE_POST_TYPE }
83
84
  showIcon={ false }
84
85
  toggleProps={ { variant: 'primary' } }
85
86
  />
@@ -16,13 +16,14 @@ import { store as noticesStore } from '@wordpress/notices';
16
16
  import SaveButton from '../save-button';
17
17
  import { isPreviewingTheme } from '../../utils/is-previewing-theme';
18
18
  import { unlock } from '../../lock-unlock';
19
+ import { NAVIGATION_POST_TYPE } from '../../utils/constants';
19
20
 
20
21
  const { useLocation } = unlock( routerPrivateApis );
21
22
 
22
23
  const PUBLISH_ON_SAVE_ENTITIES = [
23
24
  {
24
25
  kind: 'postType',
25
- name: 'wp_navigation',
26
+ name: NAVIGATION_POST_TYPE,
26
27
  },
27
28
  ];
28
29
 
@@ -3,13 +3,9 @@
3
3
  */
4
4
  import { privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
5
5
  import { Button } from '@wordpress/components';
6
- import {
7
- useFocusOnMount,
8
- useFocusReturn,
9
- useMergeRefs,
10
- } from '@wordpress/compose';
6
+ import { useFocusOnMount, useMergeRefs } from '@wordpress/compose';
11
7
  import { useDispatch } from '@wordpress/data';
12
- import { useRef, useState } from '@wordpress/element';
8
+ import { useCallback, useRef, useState } from '@wordpress/element';
13
9
  import { __ } from '@wordpress/i18n';
14
10
  import { closeSmall } from '@wordpress/icons';
15
11
  import { ESCAPE } from '@wordpress/keycodes';
@@ -24,20 +20,27 @@ import { unlock } from '../../lock-unlock';
24
20
 
25
21
  const { PrivateListView } = unlock( blockEditorPrivateApis );
26
22
 
27
- export default function ListViewSidebar() {
23
+ export default function ListViewSidebar( { listViewToggleElement } ) {
28
24
  const { setIsListViewOpened } = useDispatch( editSiteStore );
29
25
 
30
26
  // This hook handles focus when the sidebar first renders.
31
27
  const focusOnMountRef = useFocusOnMount( 'firstElement' );
32
- // The next 2 hooks handle focus for when the sidebar closes and returning focus to the element that had focus before sidebar opened.
33
- const headerFocusReturnRef = useFocusReturn();
34
- const contentFocusReturnRef = useFocusReturn();
35
28
 
36
- function closeOnEscape( event ) {
37
- if ( event.keyCode === ESCAPE && ! event.defaultPrevented ) {
38
- setIsListViewOpened( false );
39
- }
40
- }
29
+ // When closing the list view, focus should return to the toggle button.
30
+ const closeListView = useCallback( () => {
31
+ setIsListViewOpened( false );
32
+ listViewToggleElement?.focus();
33
+ }, [ listViewToggleElement, setIsListViewOpened ] );
34
+
35
+ const closeOnEscape = useCallback(
36
+ ( event ) => {
37
+ if ( event.keyCode === ESCAPE && ! event.defaultPrevented ) {
38
+ event.preventDefault();
39
+ closeListView();
40
+ }
41
+ },
42
+ [ closeListView ]
43
+ );
41
44
 
42
45
  // Use internal state instead of a ref to make sure that the component
43
46
  // re-renders when the dropZoneElement updates.
@@ -68,20 +71,26 @@ export default function ListViewSidebar() {
68
71
  listViewFocusArea.focus();
69
72
  }
70
73
 
71
- // This only fires when the sidebar is open because of the conditional rendering. It is the same shortcut to open but that is defined as a global shortcut and only fires when the sidebar is closed.
72
- useShortcut( 'core/edit-site/toggle-list-view', () => {
74
+ const handleToggleListViewShortcut = useCallback( () => {
73
75
  // If the sidebar has focus, it is safe to close.
74
76
  if (
75
77
  sidebarRef.current.contains(
76
78
  sidebarRef.current.ownerDocument.activeElement
77
79
  )
78
80
  ) {
79
- setIsListViewOpened( false );
80
- // If the list view or close button does not have focus, focus should be moved to it.
81
+ closeListView();
81
82
  } else {
83
+ // If the list view or close button does not have focus, focus should be moved to it.
82
84
  handleSidebarFocus();
83
85
  }
84
- } );
86
+ }, [ closeListView ] );
87
+
88
+ // This only fires when the sidebar is open because of the conditional rendering.
89
+ // It is the same shortcut to open but that is defined as a global shortcut and only fires when the sidebar is closed.
90
+ useShortcut(
91
+ 'core/edit-site/toggle-list-view',
92
+ handleToggleListViewShortcut
93
+ );
85
94
 
86
95
  return (
87
96
  // eslint-disable-next-line jsx-a11y/no-static-element-interactions
@@ -90,22 +99,18 @@ export default function ListViewSidebar() {
90
99
  onKeyDown={ closeOnEscape }
91
100
  ref={ sidebarRef }
92
101
  >
93
- <div
94
- className="edit-site-editor__list-view-panel-header"
95
- ref={ headerFocusReturnRef }
96
- >
102
+ <div className="edit-site-editor__list-view-panel-header">
97
103
  <strong>{ __( 'List View' ) }</strong>
98
104
  <Button
99
105
  icon={ closeSmall }
100
106
  label={ __( 'Close' ) }
101
- onClick={ () => setIsListViewOpened( false ) }
107
+ onClick={ closeListView }
102
108
  ref={ sidebarCloseButtonRef }
103
109
  />
104
110
  </div>
105
111
  <div
106
112
  className="edit-site-editor__list-view-panel-content"
107
113
  ref={ useMergeRefs( [
108
- contentFocusReturnRef,
109
114
  focusOnMountRef,
110
115
  setDropZoneElement,
111
116
  listViewRef,
@@ -12,6 +12,7 @@ import {
12
12
  } from '@wordpress/components';
13
13
  import { __ } from '@wordpress/i18n';
14
14
  import { store as coreStore } from '@wordpress/core-data';
15
+ import { check } from '@wordpress/icons';
15
16
 
16
17
  /**
17
18
  * Internal dependencies
@@ -19,6 +20,7 @@ import { store as coreStore } from '@wordpress/core-data';
19
20
  import { store as editSiteStore } from '../../../store';
20
21
  import SwapTemplateButton from './swap-template-button';
21
22
  import ResetDefaultTemplate from './reset-default-template';
23
+ import { unlock } from '../../../lock-unlock';
22
24
 
23
25
  const POPOVER_PROPS = {
24
26
  className: 'edit-site-page-panels-edit-template__dropdown',
@@ -26,28 +28,40 @@ const POPOVER_PROPS = {
26
28
  };
27
29
 
28
30
  export default function EditTemplate() {
29
- const { hasResolved, template } = useSelect( ( select ) => {
30
- const { getEditedPostContext, getEditedPostType, getEditedPostId } =
31
- select( editSiteStore );
32
- const { getEditedEntityRecord, hasFinishedResolution } =
33
- select( coreStore );
34
- const _context = getEditedPostContext();
35
- const queryArgs = [
36
- 'postType',
37
- getEditedPostType(),
38
- getEditedPostId(),
39
- ];
40
- return {
41
- context: _context,
42
- hasResolved: hasFinishedResolution(
43
- 'getEditedEntityRecord',
44
- queryArgs
45
- ),
46
- template: getEditedEntityRecord( ...queryArgs ),
47
- };
48
- }, [] );
31
+ const { hasResolved, template, isTemplateHidden } = useSelect(
32
+ ( select ) => {
33
+ const { getEditedPostContext, getEditedPostType, getEditedPostId } =
34
+ select( editSiteStore );
35
+ const { getCanvasMode, getPageContentFocusType } = unlock(
36
+ select( editSiteStore )
37
+ );
38
+ const { getEditedEntityRecord, hasFinishedResolution } =
39
+ select( coreStore );
40
+ const _context = getEditedPostContext();
41
+ const queryArgs = [
42
+ 'postType',
43
+ getEditedPostType(),
44
+ getEditedPostId(),
45
+ ];
46
+ return {
47
+ context: _context,
48
+ hasResolved: hasFinishedResolution(
49
+ 'getEditedEntityRecord',
50
+ queryArgs
51
+ ),
52
+ template: getEditedEntityRecord( ...queryArgs ),
53
+ isTemplateHidden:
54
+ getCanvasMode() === 'edit' &&
55
+ getPageContentFocusType() === 'hideTemplate',
56
+ };
57
+ },
58
+ []
59
+ );
49
60
 
50
61
  const { setHasPageContentFocus } = useDispatch( editSiteStore );
62
+ // Disable reason: `useDispatch` can't be called conditionally.
63
+ // eslint-disable-next-line @wordpress/no-unused-vars-before-return
64
+ const { setPageContentFocusType } = unlock( useDispatch( editSiteStore ) );
51
65
 
52
66
  if ( ! hasResolved ) {
53
67
  return null;
@@ -83,6 +97,20 @@ export default function EditTemplate() {
83
97
  <SwapTemplateButton onClick={ onClose } />
84
98
  </MenuGroup>
85
99
  <ResetDefaultTemplate onClick={ onClose } />
100
+ <MenuGroup>
101
+ <MenuItem
102
+ icon={ ! isTemplateHidden ? check : undefined }
103
+ onClick={ () => {
104
+ setPageContentFocusType(
105
+ isTemplateHidden
106
+ ? 'disableTemplate'
107
+ : 'hideTemplate'
108
+ );
109
+ } }
110
+ >
111
+ { __( 'Template preview' ) }
112
+ </MenuItem>
113
+ </MenuGroup>
86
114
  </>
87
115
  ) }
88
116
  </DropdownMenu>