@wordpress/edit-site 5.25.0 → 5.26.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 (433) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/LICENSE.md +1 -1
  3. package/build/components/block-editor/back-button.js +3 -2
  4. package/build/components/block-editor/back-button.js.map +1 -1
  5. package/build/components/block-editor/resizable-editor.js +2 -2
  6. package/build/components/block-editor/resizable-editor.js.map +1 -1
  7. package/build/components/block-editor/use-post-link-props.js +27 -0
  8. package/build/components/block-editor/use-post-link-props.js.map +1 -0
  9. package/build/components/block-editor/use-site-editor-settings.js +7 -24
  10. package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
  11. package/build/components/create-template-part-modal/index.js +15 -7
  12. package/build/components/create-template-part-modal/index.js.map +1 -1
  13. package/build/components/editor/index.js +15 -16
  14. package/build/components/editor/index.js.map +1 -1
  15. package/build/components/editor-canvas-container/index.js +9 -7
  16. package/build/components/editor-canvas-container/index.js.map +1 -1
  17. package/build/components/global-styles/font-library-modal/collection-font-variant.js +5 -2
  18. package/build/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -1
  19. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js +3 -3
  20. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +1 -1
  21. package/build/components/global-styles/font-library-modal/context.js +5 -5
  22. package/build/components/global-styles/font-library-modal/context.js.map +1 -1
  23. package/build/components/global-styles/font-library-modal/font-collection.js +8 -4
  24. package/build/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  25. package/build/components/global-styles/font-library-modal/index.js +38 -21
  26. package/build/components/global-styles/font-library-modal/index.js.map +1 -1
  27. package/build/components/global-styles/font-library-modal/installed-fonts.js +2 -2
  28. package/build/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  29. package/build/components/global-styles/font-library-modal/library-font-variant.js +5 -2
  30. package/build/components/global-styles/font-library-modal/library-font-variant.js.map +1 -1
  31. package/build/components/global-styles/font-library-modal/local-fonts.js +26 -10
  32. package/build/components/global-styles/font-library-modal/local-fonts.js.map +1 -1
  33. package/build/components/global-styles/font-library-modal/resolvers.js +6 -6
  34. package/build/components/global-styles/font-library-modal/resolvers.js.map +1 -1
  35. package/build/components/global-styles/font-library-modal/{tab-layout.js → tab-panel-layout.js} +4 -4
  36. package/build/components/global-styles/font-library-modal/tab-panel-layout.js.map +1 -0
  37. package/build/components/global-styles/font-library-modal/utils/index.js +35 -38
  38. package/build/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  39. package/build/components/global-styles/preview.js +43 -1
  40. package/build/components/global-styles/preview.js.map +1 -1
  41. package/build/components/global-styles/screen-color-palette.js +16 -12
  42. package/build/components/global-styles/screen-color-palette.js.map +1 -1
  43. package/build/components/global-styles/screen-revisions/index.js +52 -52
  44. package/build/components/global-styles/screen-revisions/index.js.map +1 -1
  45. package/build/components/global-styles/screen-revisions/revisions-buttons.js +26 -35
  46. package/build/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  47. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js +40 -22
  48. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  49. package/build/components/global-styles/ui.js +13 -62
  50. package/build/components/global-styles/ui.js.map +1 -1
  51. package/build/components/header-edit-mode/document-tools/index.js +8 -106
  52. package/build/components/header-edit-mode/document-tools/index.js.map +1 -1
  53. package/build/components/header-edit-mode/index.js +7 -11
  54. package/build/components/header-edit-mode/index.js.map +1 -1
  55. package/build/components/header-edit-mode/mode-switcher/index.js +0 -2
  56. package/build/components/header-edit-mode/mode-switcher/index.js.map +1 -1
  57. package/build/components/header-edit-mode/more-menu/index.js +10 -7
  58. package/build/components/header-edit-mode/more-menu/index.js.map +1 -1
  59. package/build/components/keyboard-shortcuts/edit-mode.js +0 -23
  60. package/build/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  61. package/build/components/keyboard-shortcuts/register.js +0 -36
  62. package/build/components/keyboard-shortcuts/register.js.map +1 -1
  63. package/build/components/layout/index.js +6 -13
  64. package/build/components/layout/index.js.map +1 -1
  65. package/build/components/page-main/index.js +4 -4
  66. package/build/components/page-main/index.js.map +1 -1
  67. package/build/components/page-pages/index.js +84 -37
  68. package/build/components/page-pages/index.js.map +1 -1
  69. package/build/components/page-patterns/dataviews-pattern-actions.js +305 -0
  70. package/build/components/page-patterns/dataviews-pattern-actions.js.map +1 -0
  71. package/build/components/page-patterns/dataviews-patterns.js +307 -0
  72. package/build/components/page-patterns/dataviews-patterns.js.map +1 -0
  73. package/build/components/page-patterns/duplicate-menu-item.js +1 -1
  74. package/build/components/page-patterns/duplicate-menu-item.js.map +1 -1
  75. package/build/components/page-patterns/grid-item.js +4 -3
  76. package/build/components/page-patterns/grid-item.js.map +1 -1
  77. package/build/components/page-patterns/patterns-list.js +2 -1
  78. package/build/components/page-patterns/patterns-list.js.map +1 -1
  79. package/build/components/page-patterns/use-patterns.js +23 -13
  80. package/build/components/page-patterns/use-patterns.js.map +1 -1
  81. package/build/components/page-templates/index.js +312 -36
  82. package/build/components/page-templates/index.js.map +1 -1
  83. package/build/components/{page-patterns/pagination.js → pagination/index.js} +25 -12
  84. package/build/components/pagination/index.js.map +1 -0
  85. package/build/components/{page-pages/side-editor.js → post-preview/index.js} +8 -4
  86. package/build/components/post-preview/index.js.map +1 -0
  87. package/build/components/preferences-modal/enable-feature.js +3 -2
  88. package/build/components/preferences-modal/enable-feature.js.map +1 -1
  89. package/build/components/preferences-modal/enable-panel-option.js +33 -0
  90. package/build/components/preferences-modal/enable-panel-option.js.map +1 -0
  91. package/build/components/preferences-modal/index.js +57 -9
  92. package/build/components/preferences-modal/index.js.map +1 -1
  93. package/build/components/revisions/index.js +3 -7
  94. package/build/components/revisions/index.js.map +1 -1
  95. package/build/components/routes/link.js +6 -2
  96. package/build/components/routes/link.js.map +1 -1
  97. package/build/components/save-button/index.js +6 -3
  98. package/build/components/save-button/index.js.map +1 -1
  99. package/build/components/sidebar/index.js +3 -11
  100. package/build/components/sidebar/index.js.map +1 -1
  101. package/build/components/sidebar-dataviews/add-new-view.js +2 -2
  102. package/build/components/sidebar-dataviews/add-new-view.js.map +1 -1
  103. package/build/components/sidebar-dataviews/default-views.js +18 -5
  104. package/build/components/sidebar-dataviews/default-views.js.map +1 -1
  105. package/build/components/sidebar-dataviews/index.js +3 -3
  106. package/build/components/sidebar-dataviews/index.js.map +1 -1
  107. package/build/components/sidebar-edit-mode/default-sidebar.js +1 -5
  108. package/build/components/sidebar-edit-mode/default-sidebar.js.map +1 -1
  109. package/build/components/sidebar-edit-mode/global-styles-sidebar.js +62 -10
  110. package/build/components/sidebar-edit-mode/global-styles-sidebar.js.map +1 -1
  111. package/build/components/sidebar-edit-mode/page-panels/index.js +1 -1
  112. package/build/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  113. package/build/components/sidebar-edit-mode/plugin-sidebar/index.js +0 -4
  114. package/build/components/sidebar-edit-mode/plugin-sidebar/index.js.map +1 -1
  115. package/build/components/sidebar-edit-mode/template-panel/index.js +4 -13
  116. package/build/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  117. package/build/components/sidebar-navigation-screen-details-footer/index.js +1 -1
  118. package/build/components/sidebar-navigation-screen-details-footer/index.js.map +1 -1
  119. package/build/components/sidebar-navigation-screen-global-styles/index.js +5 -2
  120. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  121. package/build/components/sidebar-navigation-screen-page/index.js +4 -1
  122. package/build/components/sidebar-navigation-screen-page/index.js.map +1 -1
  123. package/build/components/sidebar-navigation-screen-pages-dataviews/index.js +69 -0
  124. package/build/components/sidebar-navigation-screen-pages-dataviews/index.js.map +1 -0
  125. package/build/components/style-book/index.js +38 -8
  126. package/build/components/style-book/index.js.map +1 -1
  127. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +1 -1
  128. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  129. package/build/hooks/commands/use-edit-mode-commands.js +11 -6
  130. package/build/hooks/commands/use-edit-mode-commands.js.map +1 -1
  131. package/build/index.js +12 -7
  132. package/build/index.js.map +1 -1
  133. package/build/store/actions.js +39 -44
  134. package/build/store/actions.js.map +1 -1
  135. package/build/store/private-actions.js +6 -2
  136. package/build/store/private-actions.js.map +1 -1
  137. package/build/store/reducer.js +0 -46
  138. package/build/store/reducer.js.map +1 -1
  139. package/build/store/selectors.js +32 -41
  140. package/build/store/selectors.js.map +1 -1
  141. package/build/utils/get-is-list-page.js +1 -1
  142. package/build/utils/get-is-list-page.js.map +1 -1
  143. package/build-module/components/block-editor/back-button.js +4 -3
  144. package/build-module/components/block-editor/back-button.js.map +1 -1
  145. package/build-module/components/block-editor/resizable-editor.js +2 -2
  146. package/build-module/components/block-editor/resizable-editor.js.map +1 -1
  147. package/build-module/components/block-editor/use-post-link-props.js +20 -0
  148. package/build-module/components/block-editor/use-post-link-props.js.map +1 -0
  149. package/build-module/components/block-editor/use-site-editor-settings.js +8 -25
  150. package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
  151. package/build-module/components/create-template-part-modal/index.js +14 -7
  152. package/build-module/components/create-template-part-modal/index.js.map +1 -1
  153. package/build-module/components/editor/index.js +16 -17
  154. package/build-module/components/editor/index.js.map +1 -1
  155. package/build-module/components/editor-canvas-container/index.js +9 -7
  156. package/build-module/components/editor-canvas-container/index.js.map +1 -1
  157. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js +5 -2
  158. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -1
  159. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js +3 -3
  160. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +1 -1
  161. package/build-module/components/global-styles/font-library-modal/context.js +7 -7
  162. package/build-module/components/global-styles/font-library-modal/context.js.map +1 -1
  163. package/build-module/components/global-styles/font-library-modal/font-collection.js +8 -4
  164. package/build-module/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  165. package/build-module/components/global-styles/font-library-modal/index.js +39 -22
  166. package/build-module/components/global-styles/font-library-modal/index.js.map +1 -1
  167. package/build-module/components/global-styles/font-library-modal/installed-fonts.js +2 -2
  168. package/build-module/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  169. package/build-module/components/global-styles/font-library-modal/library-font-variant.js +5 -2
  170. package/build-module/components/global-styles/font-library-modal/library-font-variant.js.map +1 -1
  171. package/build-module/components/global-styles/font-library-modal/local-fonts.js +27 -11
  172. package/build-module/components/global-styles/font-library-modal/local-fonts.js.map +1 -1
  173. package/build-module/components/global-styles/font-library-modal/resolvers.js +5 -5
  174. package/build-module/components/global-styles/font-library-modal/resolvers.js.map +1 -1
  175. package/build-module/components/global-styles/font-library-modal/{tab-layout.js → tab-panel-layout.js} +4 -4
  176. package/build-module/components/global-styles/font-library-modal/tab-panel-layout.js.map +1 -0
  177. package/build-module/components/global-styles/font-library-modal/utils/index.js +34 -36
  178. package/build-module/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  179. package/build-module/components/global-styles/preview.js +45 -3
  180. package/build-module/components/global-styles/preview.js.map +1 -1
  181. package/build-module/components/global-styles/screen-color-palette.js +17 -13
  182. package/build-module/components/global-styles/screen-color-palette.js.map +1 -1
  183. package/build-module/components/global-styles/screen-revisions/index.js +53 -53
  184. package/build-module/components/global-styles/screen-revisions/index.js.map +1 -1
  185. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js +27 -36
  186. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  187. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js +40 -22
  188. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  189. package/build-module/components/global-styles/ui.js +15 -64
  190. package/build-module/components/global-styles/ui.js.map +1 -1
  191. package/build-module/components/header-edit-mode/document-tools/index.js +13 -110
  192. package/build-module/components/header-edit-mode/document-tools/index.js.map +1 -1
  193. package/build-module/components/header-edit-mode/index.js +7 -11
  194. package/build-module/components/header-edit-mode/index.js.map +1 -1
  195. package/build-module/components/header-edit-mode/mode-switcher/index.js +0 -2
  196. package/build-module/components/header-edit-mode/mode-switcher/index.js.map +1 -1
  197. package/build-module/components/header-edit-mode/more-menu/index.js +10 -7
  198. package/build-module/components/header-edit-mode/more-menu/index.js.map +1 -1
  199. package/build-module/components/keyboard-shortcuts/edit-mode.js +0 -23
  200. package/build-module/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  201. package/build-module/components/keyboard-shortcuts/register.js +0 -36
  202. package/build-module/components/keyboard-shortcuts/register.js.map +1 -1
  203. package/build-module/components/layout/index.js +6 -13
  204. package/build-module/components/layout/index.js.map +1 -1
  205. package/build-module/components/page-main/index.js +4 -4
  206. package/build-module/components/page-main/index.js.map +1 -1
  207. package/build-module/components/page-pages/index.js +83 -36
  208. package/build-module/components/page-pages/index.js.map +1 -1
  209. package/build-module/components/page-patterns/dataviews-pattern-actions.js +292 -0
  210. package/build-module/components/page-patterns/dataviews-pattern-actions.js.map +1 -0
  211. package/build-module/components/page-patterns/dataviews-patterns.js +299 -0
  212. package/build-module/components/page-patterns/dataviews-patterns.js.map +1 -0
  213. package/build-module/components/page-patterns/duplicate-menu-item.js +1 -1
  214. package/build-module/components/page-patterns/duplicate-menu-item.js.map +1 -1
  215. package/build-module/components/page-patterns/grid-item.js +4 -3
  216. package/build-module/components/page-patterns/grid-item.js.map +1 -1
  217. package/build-module/components/page-patterns/patterns-list.js +2 -1
  218. package/build-module/components/page-patterns/patterns-list.js.map +1 -1
  219. package/build-module/components/page-patterns/use-patterns.js +23 -13
  220. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  221. package/build-module/components/page-templates/index.js +314 -38
  222. package/build-module/components/page-templates/index.js.map +1 -1
  223. package/build-module/components/{page-patterns/pagination.js → pagination/index.js} +24 -12
  224. package/build-module/components/pagination/index.js.map +1 -0
  225. package/build-module/components/{page-pages/side-editor.js → post-preview/index.js} +7 -3
  226. package/build-module/components/post-preview/index.js.map +1 -0
  227. package/build-module/components/preferences-modal/enable-feature.js +3 -2
  228. package/build-module/components/preferences-modal/enable-feature.js.map +1 -1
  229. package/build-module/components/preferences-modal/enable-panel-option.js +26 -0
  230. package/build-module/components/preferences-modal/enable-panel-option.js.map +1 -0
  231. package/build-module/components/preferences-modal/index.js +57 -9
  232. package/build-module/components/preferences-modal/index.js.map +1 -1
  233. package/build-module/components/revisions/index.js +4 -8
  234. package/build-module/components/revisions/index.js.map +1 -1
  235. package/build-module/components/routes/link.js +5 -2
  236. package/build-module/components/routes/link.js.map +1 -1
  237. package/build-module/components/save-button/index.js +6 -3
  238. package/build-module/components/save-button/index.js.map +1 -1
  239. package/build-module/components/sidebar/index.js +3 -11
  240. package/build-module/components/sidebar/index.js.map +1 -1
  241. package/build-module/components/sidebar-dataviews/add-new-view.js +1 -1
  242. package/build-module/components/sidebar-dataviews/add-new-view.js.map +1 -1
  243. package/build-module/components/sidebar-dataviews/default-views.js +17 -5
  244. package/build-module/components/sidebar-dataviews/default-views.js.map +1 -1
  245. package/build-module/components/sidebar-dataviews/index.js +2 -2
  246. package/build-module/components/sidebar-dataviews/index.js.map +1 -1
  247. package/build-module/components/sidebar-edit-mode/default-sidebar.js +1 -5
  248. package/build-module/components/sidebar-edit-mode/default-sidebar.js.map +1 -1
  249. package/build-module/components/sidebar-edit-mode/global-styles-sidebar.js +64 -12
  250. package/build-module/components/sidebar-edit-mode/global-styles-sidebar.js.map +1 -1
  251. package/build-module/components/sidebar-edit-mode/page-panels/index.js +2 -2
  252. package/build-module/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  253. package/build-module/components/sidebar-edit-mode/plugin-sidebar/index.js +0 -4
  254. package/build-module/components/sidebar-edit-mode/plugin-sidebar/index.js.map +1 -1
  255. package/build-module/components/sidebar-edit-mode/template-panel/index.js +6 -15
  256. package/build-module/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  257. package/build-module/components/sidebar-navigation-screen-details-footer/index.js +1 -1
  258. package/build-module/components/sidebar-navigation-screen-details-footer/index.js.map +1 -1
  259. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +5 -2
  260. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  261. package/build-module/components/sidebar-navigation-screen-page/index.js +4 -1
  262. package/build-module/components/sidebar-navigation-screen-page/index.js.map +1 -1
  263. package/build-module/components/sidebar-navigation-screen-pages-dataviews/index.js +61 -0
  264. package/build-module/components/sidebar-navigation-screen-pages-dataviews/index.js.map +1 -0
  265. package/build-module/components/style-book/index.js +40 -10
  266. package/build-module/components/style-book/index.js.map +1 -1
  267. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +1 -1
  268. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  269. package/build-module/hooks/commands/use-edit-mode-commands.js +11 -6
  270. package/build-module/hooks/commands/use-edit-mode-commands.js.map +1 -1
  271. package/build-module/index.js +12 -7
  272. package/build-module/index.js.map +1 -1
  273. package/build-module/store/actions.js +36 -41
  274. package/build-module/store/actions.js.map +1 -1
  275. package/build-module/store/private-actions.js +6 -2
  276. package/build-module/store/private-actions.js.map +1 -1
  277. package/build-module/store/reducer.js +0 -44
  278. package/build-module/store/reducer.js.map +1 -1
  279. package/build-module/store/selectors.js +30 -38
  280. package/build-module/store/selectors.js.map +1 -1
  281. package/build-module/utils/get-is-list-page.js +1 -1
  282. package/build-module/utils/get-is-list-page.js.map +1 -1
  283. package/build-style/style-rtl.css +357 -268
  284. package/build-style/style.css +357 -268
  285. package/package.json +42 -42
  286. package/src/components/add-new-template/style.scss +2 -1
  287. package/src/components/block-editor/back-button.js +4 -2
  288. package/src/components/block-editor/resizable-editor.js +1 -1
  289. package/src/components/block-editor/style.scss +1 -2
  290. package/src/components/block-editor/use-post-link-props.js +20 -0
  291. package/src/components/block-editor/use-site-editor-settings.js +10 -41
  292. package/src/components/code-editor/style.scss +0 -4
  293. package/src/components/create-template-part-modal/index.js +83 -82
  294. package/src/components/editor/index.js +24 -31
  295. package/src/components/editor-canvas-container/index.js +8 -6
  296. package/src/components/global-styles/font-library-modal/collection-font-variant.js +7 -2
  297. package/src/components/global-styles/font-library-modal/confirm-delete-dialog.js +3 -3
  298. package/src/components/global-styles/font-library-modal/context.js +7 -7
  299. package/src/components/global-styles/font-library-modal/font-collection.js +10 -5
  300. package/src/components/global-styles/font-library-modal/index.js +44 -24
  301. package/src/components/global-styles/font-library-modal/installed-fonts.js +3 -3
  302. package/src/components/global-styles/font-library-modal/library-font-variant.js +7 -2
  303. package/src/components/global-styles/font-library-modal/local-fonts.js +53 -26
  304. package/src/components/global-styles/font-library-modal/resolvers.js +5 -5
  305. package/src/components/global-styles/font-library-modal/style.scss +5 -2
  306. package/src/components/global-styles/font-library-modal/{tab-layout.js → tab-panel-layout.js} +9 -3
  307. package/src/components/global-styles/font-library-modal/utils/index.js +21 -23
  308. package/src/components/global-styles/font-library-modal/utils/test/makeFormDataFromFontFamily.spec.js +58 -0
  309. package/src/components/global-styles/preview.js +55 -3
  310. package/src/components/global-styles/screen-color-palette.js +16 -26
  311. package/src/components/global-styles/screen-revisions/index.js +91 -92
  312. package/src/components/global-styles/screen-revisions/revisions-buttons.js +37 -38
  313. package/src/components/global-styles/screen-revisions/style.scss +77 -20
  314. package/src/components/global-styles/screen-revisions/test/use-global-styles-revisions.js +67 -0
  315. package/src/components/global-styles/screen-revisions/use-global-styles-revisions.js +73 -46
  316. package/src/components/global-styles/ui.js +13 -74
  317. package/src/components/header-edit-mode/document-tools/index.js +33 -165
  318. package/src/components/header-edit-mode/index.js +6 -17
  319. package/src/components/header-edit-mode/mode-switcher/index.js +0 -4
  320. package/src/components/header-edit-mode/more-menu/index.js +9 -7
  321. package/src/components/header-edit-mode/style.scss +0 -47
  322. package/src/components/keyboard-shortcuts/edit-mode.js +1 -26
  323. package/src/components/keyboard-shortcuts/register.js +0 -43
  324. package/src/components/layout/index.js +8 -27
  325. package/src/components/layout/style.scss +10 -3
  326. package/src/components/list/style.scss +0 -5
  327. package/src/components/page/style.scss +1 -1
  328. package/src/components/page-main/index.js +8 -8
  329. package/src/components/page-pages/index.js +112 -41
  330. package/src/components/page-pages/style.scss +3 -2
  331. package/src/components/page-patterns/dataviews-pattern-actions.js +329 -0
  332. package/src/components/page-patterns/dataviews-patterns.js +380 -0
  333. package/src/components/page-patterns/duplicate-menu-item.js +1 -1
  334. package/src/components/page-patterns/grid-item.js +3 -2
  335. package/src/components/page-patterns/patterns-list.js +2 -1
  336. package/src/components/page-patterns/style.scss +89 -26
  337. package/src/components/page-patterns/use-patterns.js +24 -15
  338. package/src/components/page-templates/index.js +399 -64
  339. package/src/components/{page-patterns/pagination.js → pagination/index.js} +21 -10
  340. package/src/components/pagination/style.scss +5 -0
  341. package/src/components/post-preview/index.js +16 -0
  342. package/src/components/preferences-modal/enable-feature.js +9 -5
  343. package/src/components/preferences-modal/enable-panel-option.js +23 -0
  344. package/src/components/preferences-modal/index.js +107 -22
  345. package/src/components/revisions/index.js +8 -15
  346. package/src/components/routes/link.js +11 -3
  347. package/src/components/save-button/index.js +16 -3
  348. package/src/components/sidebar/index.js +6 -13
  349. package/src/components/sidebar-dataviews/add-new-view.js +1 -1
  350. package/src/components/sidebar-dataviews/default-views.js +23 -6
  351. package/src/components/sidebar-dataviews/index.js +2 -2
  352. package/src/components/sidebar-edit-mode/default-sidebar.js +0 -12
  353. package/src/components/sidebar-edit-mode/global-styles-sidebar.js +85 -14
  354. package/src/components/sidebar-edit-mode/page-panels/index.js +15 -1
  355. package/src/components/sidebar-edit-mode/plugin-sidebar/index.js +0 -12
  356. package/src/components/sidebar-edit-mode/style.scss +0 -10
  357. package/src/components/sidebar-edit-mode/template-panel/index.js +44 -40
  358. package/src/components/sidebar-edit-mode/template-panel/style.scss +0 -4
  359. package/src/components/sidebar-navigation-screen-details-footer/index.js +1 -1
  360. package/src/components/sidebar-navigation-screen-global-styles/index.js +3 -2
  361. package/src/components/sidebar-navigation-screen-page/index.js +2 -1
  362. package/src/components/sidebar-navigation-screen-pages-dataviews/index.js +77 -0
  363. package/src/components/site-hub/style.scss +5 -2
  364. package/src/components/style-book/index.js +65 -21
  365. package/src/components/style-book/style.scss +3 -3
  366. package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +4 -1
  367. package/src/hooks/commands/use-edit-mode-commands.js +8 -12
  368. package/src/index.js +11 -5
  369. package/src/store/actions.js +35 -45
  370. package/src/store/private-actions.js +7 -3
  371. package/src/store/reducer.js +0 -44
  372. package/src/store/selectors.js +32 -38
  373. package/src/store/test/actions.js +11 -39
  374. package/src/store/test/reducer.js +1 -82
  375. package/src/store/test/selectors.js +0 -24
  376. package/src/style.scss +1 -1
  377. package/src/utils/get-is-list-page.js +2 -3
  378. package/build/components/global-styles/font-library-modal/tab-layout.js.map +0 -1
  379. package/build/components/global-styles/screen-revisions/get-revision-changes.js +0 -146
  380. package/build/components/global-styles/screen-revisions/get-revision-changes.js.map +0 -1
  381. package/build/components/header-edit-mode/undo-redo/redo.js +0 -41
  382. package/build/components/header-edit-mode/undo-redo/redo.js.map +0 -1
  383. package/build/components/header-edit-mode/undo-redo/undo.js +0 -40
  384. package/build/components/header-edit-mode/undo-redo/undo.js.map +0 -1
  385. package/build/components/page-pages/side-editor.js.map +0 -1
  386. package/build/components/page-patterns/pagination.js.map +0 -1
  387. package/build/components/page-templates/dataviews-templates.js +0 -317
  388. package/build/components/page-templates/dataviews-templates.js.map +0 -1
  389. package/build/components/secondary-sidebar/inserter-sidebar.js +0 -60
  390. package/build/components/secondary-sidebar/inserter-sidebar.js.map +0 -1
  391. package/build/components/secondary-sidebar/list-view-sidebar.js +0 -109
  392. package/build/components/secondary-sidebar/list-view-sidebar.js.map +0 -1
  393. package/build/components/sidebar-edit-mode/sidebar-fixed-bottom.js +0 -35
  394. package/build/components/sidebar-edit-mode/sidebar-fixed-bottom.js.map +0 -1
  395. package/build/components/sidebar-edit-mode/template-panel/last-revision.js +0 -73
  396. package/build/components/sidebar-edit-mode/template-panel/last-revision.js.map +0 -1
  397. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js +0 -219
  398. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +0 -1
  399. package/build-module/components/global-styles/font-library-modal/tab-layout.js.map +0 -1
  400. package/build-module/components/global-styles/screen-revisions/get-revision-changes.js +0 -139
  401. package/build-module/components/global-styles/screen-revisions/get-revision-changes.js.map +0 -1
  402. package/build-module/components/header-edit-mode/undo-redo/redo.js +0 -33
  403. package/build-module/components/header-edit-mode/undo-redo/redo.js.map +0 -1
  404. package/build-module/components/header-edit-mode/undo-redo/undo.js +0 -32
  405. package/build-module/components/header-edit-mode/undo-redo/undo.js.map +0 -1
  406. package/build-module/components/page-pages/side-editor.js.map +0 -1
  407. package/build-module/components/page-patterns/pagination.js.map +0 -1
  408. package/build-module/components/page-templates/dataviews-templates.js +0 -309
  409. package/build-module/components/page-templates/dataviews-templates.js.map +0 -1
  410. package/build-module/components/secondary-sidebar/inserter-sidebar.js +0 -53
  411. package/build-module/components/secondary-sidebar/inserter-sidebar.js.map +0 -1
  412. package/build-module/components/secondary-sidebar/list-view-sidebar.js +0 -102
  413. package/build-module/components/secondary-sidebar/list-view-sidebar.js.map +0 -1
  414. package/build-module/components/sidebar-edit-mode/sidebar-fixed-bottom.js +0 -27
  415. package/build-module/components/sidebar-edit-mode/sidebar-fixed-bottom.js.map +0 -1
  416. package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js +0 -65
  417. package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js.map +0 -1
  418. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js +0 -209
  419. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +0 -1
  420. package/src/components/global-styles/font-library-modal/utils/test/makeFormDataFromFontFamilies.spec.js +0 -62
  421. package/src/components/global-styles/font-library-modal/utils/test/wpKebabCase.spec.js +0 -28
  422. package/src/components/global-styles/screen-revisions/get-revision-changes.js +0 -171
  423. package/src/components/global-styles/screen-revisions/test/get-revision-changes.js +0 -191
  424. package/src/components/header-edit-mode/undo-redo/redo.js +0 -38
  425. package/src/components/header-edit-mode/undo-redo/undo.js +0 -34
  426. package/src/components/page-pages/side-editor.js +0 -14
  427. package/src/components/page-templates/dataviews-templates.js +0 -360
  428. package/src/components/secondary-sidebar/inserter-sidebar.js +0 -66
  429. package/src/components/secondary-sidebar/list-view-sidebar.js +0 -123
  430. package/src/components/secondary-sidebar/style.scss +0 -65
  431. package/src/components/sidebar-edit-mode/sidebar-fixed-bottom.js +0 -26
  432. package/src/components/sidebar-edit-mode/template-panel/last-revision.js +0 -82
  433. package/src/components/sidebar-edit-mode/template-panel/pattern-categories.js +0 -279
@@ -7,9 +7,9 @@ import { privateApis as routerPrivateApis } from '@wordpress/router';
7
7
  * Internal dependencies
8
8
  */
9
9
  import PagePatterns from '../page-patterns';
10
+ import DataviewsPatterns from '../page-patterns/dataviews-patterns';
10
11
  import PageTemplateParts from '../page-template-parts';
11
12
  import PageTemplates from '../page-templates';
12
- import DataviewsTemplates from '../page-templates/dataviews-templates';
13
13
  import PagePages from '../page-pages';
14
14
  import { unlock } from '../../lock-unlock';
15
15
 
@@ -21,16 +21,16 @@ export default function PageMain() {
21
21
  } = useLocation();
22
22
 
23
23
  if ( path === '/wp_template/all' ) {
24
- return window?.__experimentalAdminViews ? (
25
- <DataviewsTemplates />
26
- ) : (
27
- <PageTemplates />
28
- );
24
+ return <PageTemplates />;
29
25
  } else if ( path === '/wp_template_part/all' ) {
30
26
  return <PageTemplateParts />;
31
27
  } else if ( path === '/patterns' ) {
32
- return <PagePatterns />;
33
- } else if ( window?.__experimentalAdminViews && path === '/pages' ) {
28
+ return window?.__experimentalAdminViews ? (
29
+ <DataviewsPatterns />
30
+ ) : (
31
+ <PagePatterns />
32
+ );
33
+ } else if ( window?.__experimentalAdminViews && path === '/page' ) {
34
34
  return <PagePages />;
35
35
  }
36
36
 
@@ -2,8 +2,9 @@
2
2
  * WordPress dependencies
3
3
  */
4
4
  import {
5
- __experimentalHeading as Heading,
5
+ __experimentalView as View,
6
6
  __experimentalVStack as VStack,
7
+ Button,
7
8
  } from '@wordpress/components';
8
9
  import { __ } from '@wordpress/i18n';
9
10
  import { useEntityRecords, store as coreStore } from '@wordpress/core-data';
@@ -13,13 +14,17 @@ import { dateI18n, getDate, getSettings } from '@wordpress/date';
13
14
  import { privateApis as routerPrivateApis } from '@wordpress/router';
14
15
  import { useSelect, useDispatch } from '@wordpress/data';
15
16
  import { DataViews } from '@wordpress/dataviews';
17
+ import { ENTER, SPACE } from '@wordpress/keycodes';
16
18
 
17
19
  /**
18
20
  * Internal dependencies
19
21
  */
20
22
  import Page from '../page';
21
23
  import Link from '../routes/link';
22
- import { default as DEFAULT_VIEWS } from '../sidebar-dataviews/default-views';
24
+ import {
25
+ DEFAULT_VIEWS,
26
+ DEFAULT_CONFIG_PER_VIEW_TYPE,
27
+ } from '../sidebar-dataviews/default-views';
23
28
  import {
24
29
  ENUMERATION_TYPE,
25
30
  LAYOUT_GRID,
@@ -37,23 +42,13 @@ import {
37
42
  viewPostAction,
38
43
  useEditPostAction,
39
44
  } from '../actions';
40
- import SideEditor from './side-editor';
45
+ import PostPreview from '../post-preview';
46
+ import AddNewPageModal from '../add-new-page';
41
47
  import Media from '../media';
42
48
  import { unlock } from '../../lock-unlock';
43
- const { useLocation } = unlock( routerPrivateApis );
49
+ const { useLocation, useHistory } = unlock( routerPrivateApis );
44
50
 
45
51
  const EMPTY_ARRAY = [];
46
- const defaultConfigPerViewType = {
47
- [ LAYOUT_TABLE ]: {},
48
- [ LAYOUT_GRID ]: {
49
- mediaField: 'featured-image',
50
- primaryField: 'title',
51
- },
52
- [ LAYOUT_LIST ]: {
53
- primaryField: 'title',
54
- mediaField: 'featured-image',
55
- },
56
- };
57
52
 
58
53
  function useView( type ) {
59
54
  const {
@@ -130,9 +125,24 @@ export default function PagePages() {
130
125
  const postType = 'page';
131
126
  const [ view, setView ] = useView( postType );
132
127
  const [ pageId, setPageId ] = useState( null );
128
+ const history = useHistory();
133
129
 
134
- const onSelectionChange = ( items ) =>
135
- setPageId( items?.length === 1 ? items[ 0 ].id : null );
130
+ const onSelectionChange = useCallback(
131
+ ( items ) => setPageId( items?.length === 1 ? items[ 0 ].id : null ),
132
+ [ setPageId ]
133
+ );
134
+
135
+ const onDetailsChange = useCallback(
136
+ ( items ) => {
137
+ if ( !! postType && items?.length === 1 ) {
138
+ history.push( {
139
+ postId: items[ 0 ].id,
140
+ postType,
141
+ } );
142
+ }
143
+ },
144
+ [ history, postType ]
145
+ );
136
146
 
137
147
  const queryArgs = useMemo( () => {
138
148
  const filters = {};
@@ -212,11 +222,14 @@ export default function PagePages() {
212
222
  {
213
223
  header: __( 'Title' ),
214
224
  id: 'title',
215
- getValue: ( { item } ) => item.title?.rendered || item.slug,
225
+ getValue: ( { item } ) => item.title?.rendered,
216
226
  render: ( { item } ) => {
217
227
  return (
218
228
  <VStack spacing={ 1 }>
219
- <Heading as="h3" level={ 5 } weight={ 500 }>
229
+ <View
230
+ as="span"
231
+ className="dataviews-view-grid__title-field"
232
+ >
220
233
  { [ LAYOUT_TABLE, LAYOUT_GRID ].includes(
221
234
  view.type
222
235
  ) ? (
@@ -228,15 +241,14 @@ export default function PagePages() {
228
241
  } }
229
242
  >
230
243
  { decodeEntities(
231
- item.title?.rendered || item.slug
244
+ item.title?.rendered
232
245
  ) || __( '(no title)' ) }
233
246
  </Link>
234
247
  ) : (
235
- decodeEntities(
236
- item.title?.rendered || item.slug
237
- ) || __( '(no title)' )
248
+ decodeEntities( item.title?.rendered ) ||
249
+ __( '(no title)' )
238
250
  ) }
239
- </Heading>
251
+ </View>
240
252
  </VStack>
241
253
  );
242
254
  },
@@ -280,7 +292,7 @@ export default function PagePages() {
280
292
  },
281
293
  },
282
294
  ],
283
- [ authors, view ]
295
+ [ authors, view.type ]
284
296
  );
285
297
 
286
298
  const permanentlyDeletePostAction = usePermanentlyDeletePostAction();
@@ -298,47 +310,106 @@ export default function PagePages() {
298
310
  [ permanentlyDeletePostAction, restorePostAction, editPostAction ]
299
311
  );
300
312
  const onChangeView = useCallback(
301
- ( viewUpdater ) => {
302
- let updatedView =
303
- typeof viewUpdater === 'function'
304
- ? viewUpdater( view )
305
- : viewUpdater;
306
- if ( updatedView.type !== view.type ) {
307
- updatedView = {
308
- ...updatedView,
313
+ ( newView ) => {
314
+ if ( newView.type !== view.type ) {
315
+ newView = {
316
+ ...newView,
309
317
  layout: {
310
- ...defaultConfigPerViewType[ updatedView.type ],
318
+ ...DEFAULT_CONFIG_PER_VIEW_TYPE[ newView.type ],
311
319
  },
312
320
  };
313
321
  }
314
322
 
315
- setView( updatedView );
323
+ setView( newView );
316
324
  },
317
- [ view, setView ]
325
+ [ view.type, setView ]
326
+ );
327
+
328
+ const [ showAddPageModal, setShowAddPageModal ] = useState( false );
329
+ const openModal = useCallback( () => {
330
+ if ( ! showAddPageModal ) {
331
+ setShowAddPageModal( true );
332
+ }
333
+ }, [ showAddPageModal ] );
334
+ const closeModal = useCallback( () => {
335
+ if ( showAddPageModal ) {
336
+ setShowAddPageModal( false );
337
+ }
338
+ }, [ showAddPageModal ] );
339
+ const handleNewPage = useCallback(
340
+ ( { type, id } ) => {
341
+ history.push( {
342
+ postId: id,
343
+ postType: type,
344
+ canvas: 'edit',
345
+ } );
346
+ closeModal();
347
+ },
348
+ [ history ]
318
349
  );
319
350
 
320
351
  // TODO: we need to handle properly `data={ data || EMPTY_ARRAY }` for when `isLoading`.
321
352
  return (
322
353
  <>
323
- <Page title={ __( 'Pages' ) }>
354
+ <Page
355
+ className={
356
+ view.type === LAYOUT_LIST
357
+ ? 'edit-site-page-pages-list-view'
358
+ : null
359
+ }
360
+ title={ __( 'Pages' ) }
361
+ actions={
362
+ <>
363
+ <Button variant="primary" onClick={ openModal }>
364
+ { __( 'Add new page' ) }
365
+ </Button>
366
+ { showAddPageModal && (
367
+ <AddNewPageModal
368
+ onSave={ handleNewPage }
369
+ onClose={ closeModal }
370
+ />
371
+ ) }
372
+ </>
373
+ }
374
+ >
324
375
  <DataViews
325
376
  paginationInfo={ paginationInfo }
326
377
  fields={ fields }
327
378
  actions={ actions }
328
379
  data={ pages || EMPTY_ARRAY }
329
- getItemId={ ( item ) => item.id }
330
380
  isLoading={ isLoadingPages || isLoadingAuthors }
331
381
  view={ view }
332
382
  onChangeView={ onChangeView }
333
383
  onSelectionChange={ onSelectionChange }
334
- deferredRendering={ false }
384
+ onDetailsChange={ onDetailsChange }
335
385
  />
336
386
  </Page>
337
387
  { view.type === LAYOUT_LIST && (
338
388
  <Page>
339
- <div className="edit-site-page-pages-preview">
389
+ <div
390
+ className="edit-site-page-pages-preview"
391
+ tabIndex={ 0 }
392
+ role="button"
393
+ onKeyDown={ ( event ) => {
394
+ const { keyCode } = event;
395
+ if ( keyCode === ENTER || keyCode === SPACE ) {
396
+ history.push( {
397
+ postId: pageId,
398
+ postType,
399
+ canvas: 'edit',
400
+ } );
401
+ }
402
+ } }
403
+ onClick={ () =>
404
+ history.push( {
405
+ postId: pageId,
406
+ postType,
407
+ canvas: 'edit',
408
+ } )
409
+ }
410
+ >
340
411
  { pageId !== null ? (
341
- <SideEditor
412
+ <PostPreview
342
413
  postId={ pageId }
343
414
  postType={ postType }
344
415
  />
@@ -1,5 +1,6 @@
1
1
  .edit-site-page-pages__featured-image {
2
2
  border-radius: $grid-unit-05;
3
- width: $grid-unit-40;
4
- height: $grid-unit-40;
3
+ width: $grid-unit-50;
4
+ height: $grid-unit-50;
5
+ display: block;
5
6
  }
@@ -0,0 +1,329 @@
1
+ /**
2
+ * External dependencies
3
+ */
4
+ import { paramCase as kebabCase } from 'change-case';
5
+
6
+ /**
7
+ * WordPress dependencies
8
+ */
9
+ import { getQueryArgs } from '@wordpress/url';
10
+ import { downloadBlob } from '@wordpress/blob';
11
+ import { __, _x, sprintf } from '@wordpress/i18n';
12
+ import {
13
+ Button,
14
+ TextControl,
15
+ __experimentalHStack as HStack,
16
+ __experimentalVStack as VStack,
17
+ __experimentalText as Text,
18
+ } from '@wordpress/components';
19
+ import { store as coreStore } from '@wordpress/core-data';
20
+ import { useDispatch } from '@wordpress/data';
21
+ import { useState } from '@wordpress/element';
22
+ import { store as noticesStore } from '@wordpress/notices';
23
+ import { decodeEntities } from '@wordpress/html-entities';
24
+ import { store as reusableBlocksStore } from '@wordpress/reusable-blocks';
25
+ import { privateApis as routerPrivateApis } from '@wordpress/router';
26
+ import { privateApis as patternsPrivateApis } from '@wordpress/patterns';
27
+
28
+ /**
29
+ * Internal dependencies
30
+ */
31
+ import { unlock } from '../../lock-unlock';
32
+ import { store as editSiteStore } from '../../store';
33
+ import {
34
+ PATTERN_TYPES,
35
+ TEMPLATE_PART_POST_TYPE,
36
+ PATTERN_DEFAULT_CATEGORY,
37
+ } from '../../utils/constants';
38
+ import { CreateTemplatePartModalContents } from '../create-template-part-modal';
39
+
40
+ const { useHistory } = unlock( routerPrivateApis );
41
+ const { CreatePatternModalContents, useDuplicatePatternProps } =
42
+ unlock( patternsPrivateApis );
43
+
44
+ export const exportJSONaction = {
45
+ id: 'export-pattern',
46
+ label: __( 'Export as JSON' ),
47
+ isEligible: ( item ) => item.type === PATTERN_TYPES.user,
48
+ callback: ( item ) => {
49
+ const json = {
50
+ __file: item.type,
51
+ title: item.title || item.name,
52
+ content: item.patternPost.content.raw,
53
+ syncStatus: item.patternPost.wp_pattern_sync_status,
54
+ };
55
+ return downloadBlob(
56
+ `${ kebabCase( item.title || item.name ) }.json`,
57
+ JSON.stringify( json, null, 2 ),
58
+ 'application/json'
59
+ );
60
+ },
61
+ };
62
+
63
+ export const renameAction = {
64
+ id: 'rename-pattern',
65
+ label: __( 'Rename' ),
66
+ isEligible: ( item ) => {
67
+ const isTemplatePart = item.type === TEMPLATE_PART_POST_TYPE;
68
+ const isUserPattern = item.type === PATTERN_TYPES.user;
69
+ const isCustomPattern =
70
+ isUserPattern || ( isTemplatePart && item.isCustom );
71
+ const hasThemeFile = isTemplatePart && item.templatePart.has_theme_file;
72
+ return isCustomPattern && ! hasThemeFile;
73
+ },
74
+ RenderModal: ( { item, closeModal } ) => {
75
+ const [ title, setTitle ] = useState( () => item.title );
76
+ const { editEntityRecord, saveEditedEntityRecord } =
77
+ useDispatch( coreStore );
78
+ const { createSuccessNotice, createErrorNotice } =
79
+ useDispatch( noticesStore );
80
+ async function onRename( event ) {
81
+ event.preventDefault();
82
+ try {
83
+ await editEntityRecord( 'postType', item.type, item.id, {
84
+ title,
85
+ } );
86
+ // Update state before saving rerenders the list.
87
+ setTitle( '' );
88
+ closeModal();
89
+ // Persist edited entity.
90
+ await saveEditedEntityRecord( 'postType', item.type, item.id, {
91
+ throwOnError: true,
92
+ } );
93
+ createSuccessNotice(
94
+ item.type === TEMPLATE_PART_POST_TYPE
95
+ ? __( 'Template part renamed.' )
96
+ : __( 'Pattern renamed.' ),
97
+ { type: 'snackbar' }
98
+ );
99
+ } catch ( error ) {
100
+ const fallbackErrorMessage =
101
+ item.type === TEMPLATE_PART_POST_TYPE
102
+ ? __(
103
+ 'An error occurred while renaming the template part.'
104
+ )
105
+ : __( 'An error occurred while renaming the pattern.' );
106
+ const errorMessage =
107
+ error.message && error.code !== 'unknown_error'
108
+ ? error.message
109
+ : fallbackErrorMessage;
110
+ createErrorNotice( errorMessage, { type: 'snackbar' } );
111
+ }
112
+ }
113
+ return (
114
+ <form onSubmit={ onRename }>
115
+ <VStack spacing="5">
116
+ <TextControl
117
+ __nextHasNoMarginBottom
118
+ __next40pxDefaultSize
119
+ label={ __( 'Name' ) }
120
+ value={ title }
121
+ onChange={ setTitle }
122
+ required
123
+ />
124
+ <HStack justify="right">
125
+ <Button
126
+ __next40pxDefaultSize
127
+ variant="tertiary"
128
+ onClick={ () => {
129
+ closeModal();
130
+ } }
131
+ >
132
+ { __( 'Cancel' ) }
133
+ </Button>
134
+ <Button
135
+ __next40pxDefaultSize
136
+ variant="primary"
137
+ type="submit"
138
+ >
139
+ { __( 'Save' ) }
140
+ </Button>
141
+ </HStack>
142
+ </VStack>
143
+ </form>
144
+ );
145
+ },
146
+ };
147
+
148
+ const canDeleteOrReset = ( item ) => {
149
+ const isTemplatePart = item.type === TEMPLATE_PART_POST_TYPE;
150
+ const isUserPattern = item.type === PATTERN_TYPES.user;
151
+ return isUserPattern || ( isTemplatePart && item.isCustom );
152
+ };
153
+
154
+ export const deleteAction = {
155
+ id: 'delete-pattern',
156
+ label: __( 'Delete' ),
157
+ isEligible: ( item ) => {
158
+ const isTemplatePart = item.type === TEMPLATE_PART_POST_TYPE;
159
+ const hasThemeFile = isTemplatePart && item.templatePart.has_theme_file;
160
+ return canDeleteOrReset( item ) && ! hasThemeFile;
161
+ },
162
+ hideModalHeader: true,
163
+ RenderModal: ( { item, closeModal } ) => {
164
+ const { __experimentalDeleteReusableBlock } =
165
+ useDispatch( reusableBlocksStore );
166
+ const { createErrorNotice, createSuccessNotice } =
167
+ useDispatch( noticesStore );
168
+ const { removeTemplate } = useDispatch( editSiteStore );
169
+
170
+ const deletePattern = async () => {
171
+ try {
172
+ await __experimentalDeleteReusableBlock( item.id );
173
+ createSuccessNotice(
174
+ sprintf(
175
+ // translators: %s: The pattern's title e.g. 'Call to action'.
176
+ __( '"%s" deleted.' ),
177
+ item.title
178
+ ),
179
+ { type: 'snackbar', id: 'edit-site-patterns-success' }
180
+ );
181
+ } catch ( error ) {
182
+ const errorMessage =
183
+ error.message && error.code !== 'unknown_error'
184
+ ? error.message
185
+ : __( 'An error occurred while deleting the pattern.' );
186
+ createErrorNotice( errorMessage, {
187
+ type: 'snackbar',
188
+ id: 'edit-site-patterns-error',
189
+ } );
190
+ }
191
+ };
192
+ const deleteItem = () =>
193
+ item.type === TEMPLATE_PART_POST_TYPE
194
+ ? removeTemplate( item )
195
+ : deletePattern();
196
+ return (
197
+ <VStack spacing="5">
198
+ <Text>
199
+ { sprintf(
200
+ // translators: %s: The pattern or template part's title e.g. 'Call to action'.
201
+ __( 'Are you sure you want to delete "%s"?' ),
202
+ decodeEntities( item.title || item.name )
203
+ ) }
204
+ </Text>
205
+ <HStack justify="right">
206
+ <Button variant="tertiary" onClick={ closeModal }>
207
+ { __( 'Cancel' ) }
208
+ </Button>
209
+ <Button variant="primary" onClick={ deleteItem }>
210
+ { __( 'Delete' ) }
211
+ </Button>
212
+ </HStack>
213
+ </VStack>
214
+ );
215
+ },
216
+ };
217
+
218
+ export const resetAction = {
219
+ id: 'reset-action',
220
+ label: __( 'Clear customizations' ),
221
+ isEligible: ( item ) => {
222
+ const isTemplatePart = item.type === TEMPLATE_PART_POST_TYPE;
223
+ const hasThemeFile = isTemplatePart && item.templatePart.has_theme_file;
224
+ return canDeleteOrReset( item ) && hasThemeFile;
225
+ },
226
+ hideModalHeader: true,
227
+ RenderModal: ( { item, closeModal } ) => {
228
+ const { removeTemplate } = useDispatch( editSiteStore );
229
+ return (
230
+ <VStack spacing="5">
231
+ <Text>
232
+ { __(
233
+ 'Are you sure you want to clear these customizations?'
234
+ ) }
235
+ </Text>
236
+ <HStack justify="right">
237
+ <Button variant="tertiary" onClick={ closeModal }>
238
+ { __( 'Cancel' ) }
239
+ </Button>
240
+ <Button
241
+ variant="primary"
242
+ onClick={ () => removeTemplate( item ) }
243
+ >
244
+ { __( 'Clear' ) }
245
+ </Button>
246
+ </HStack>
247
+ </VStack>
248
+ );
249
+ },
250
+ };
251
+
252
+ export const duplicatePatternAction = {
253
+ id: 'duplicate-pattern',
254
+ label: _x( 'Duplicate', 'action label' ),
255
+ isEligible: ( item ) => item.type !== TEMPLATE_PART_POST_TYPE,
256
+ modalHeader: _x( 'Duplicate pattern', 'action label' ),
257
+ RenderModal: ( { item, closeModal } ) => {
258
+ const { categoryId = PATTERN_DEFAULT_CATEGORY } = getQueryArgs(
259
+ window.location.href
260
+ );
261
+ const isThemePattern = item.type === PATTERN_TYPES.theme;
262
+ const history = useHistory();
263
+ function onPatternSuccess( { pattern } ) {
264
+ history.push( {
265
+ categoryType: PATTERN_TYPES.theme,
266
+ categoryId,
267
+ postType: PATTERN_TYPES.user,
268
+ postId: pattern.id,
269
+ } );
270
+ closeModal();
271
+ }
272
+ const duplicatedProps = useDuplicatePatternProps( {
273
+ pattern: isThemePattern ? item : item.patternPost,
274
+ onSuccess: onPatternSuccess,
275
+ } );
276
+ return (
277
+ <CreatePatternModalContents
278
+ onClose={ closeModal }
279
+ confirmLabel={ _x( 'Duplicate', 'action label' ) }
280
+ { ...duplicatedProps }
281
+ />
282
+ );
283
+ },
284
+ };
285
+
286
+ export const duplicateTemplatePartAction = {
287
+ id: 'duplicate-template-part',
288
+ label: _x( 'Duplicate', 'action label' ),
289
+ isEligible: ( item ) => item.type === TEMPLATE_PART_POST_TYPE,
290
+ modalHeader: _x( 'Duplicate template part', 'action label' ),
291
+ RenderModal: ( { item, closeModal } ) => {
292
+ const { createSuccessNotice } = useDispatch( noticesStore );
293
+ const { categoryId = PATTERN_DEFAULT_CATEGORY } = getQueryArgs(
294
+ window.location.href
295
+ );
296
+ const history = useHistory();
297
+ async function onTemplatePartSuccess( templatePart ) {
298
+ createSuccessNotice(
299
+ sprintf(
300
+ // translators: %s: The new template part's title e.g. 'Call to action (copy)'.
301
+ __( '"%s" duplicated.' ),
302
+ item.title
303
+ ),
304
+ { type: 'snackbar', id: 'edit-site-patterns-success' }
305
+ );
306
+ history.push( {
307
+ postType: TEMPLATE_PART_POST_TYPE,
308
+ postId: templatePart?.id,
309
+ categoryType: TEMPLATE_PART_POST_TYPE,
310
+ categoryId,
311
+ } );
312
+ closeModal();
313
+ }
314
+ return (
315
+ <CreateTemplatePartModalContents
316
+ blocks={ item.blocks }
317
+ defaultArea={ item.templatePart.area }
318
+ defaultTitle={ sprintf(
319
+ /* translators: %s: Existing template part title */
320
+ __( '%s (Copy)' ),
321
+ item.title
322
+ ) }
323
+ onCreate={ onTemplatePartSuccess }
324
+ onError={ closeModal }
325
+ confirmLabel={ _x( 'Duplicate', 'action label' ) }
326
+ />
327
+ );
328
+ },
329
+ };