@wordpress/edit-site 5.24.1 → 5.25.1-next.79a6196f.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 (652) hide show
  1. package/CHANGELOG.md +2 -0
  2. package/LICENSE.md +1 -1
  3. package/build/components/add-new-template/add-custom-template-modal-content.js +2 -3
  4. package/build/components/add-new-template/add-custom-template-modal-content.js.map +1 -1
  5. package/build/components/block-editor/back-button.js +3 -2
  6. package/build/components/block-editor/back-button.js.map +1 -1
  7. package/build/components/block-editor/editor-canvas.js +48 -23
  8. package/build/components/block-editor/editor-canvas.js.map +1 -1
  9. package/build/components/block-editor/resizable-editor.js +2 -2
  10. package/build/components/block-editor/resizable-editor.js.map +1 -1
  11. package/build/components/block-editor/site-editor-canvas.js +5 -54
  12. package/build/components/block-editor/site-editor-canvas.js.map +1 -1
  13. package/build/components/block-editor/use-post-link-props.js +27 -0
  14. package/build/components/block-editor/use-post-link-props.js.map +1 -0
  15. package/build/components/block-editor/use-site-editor-settings.js +15 -23
  16. package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
  17. package/build/components/create-template-part-modal/index.js +15 -7
  18. package/build/components/create-template-part-modal/index.js.map +1 -1
  19. package/build/components/editor/index.js +21 -33
  20. package/build/components/editor/index.js.map +1 -1
  21. package/build/components/editor-canvas-container/index.js +9 -7
  22. package/build/components/editor-canvas-container/index.js.map +1 -1
  23. package/build/components/global-styles/font-library-modal/collection-font-variant.js +11 -7
  24. package/build/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -1
  25. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js +3 -3
  26. package/build/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +1 -1
  27. package/build/components/global-styles/font-library-modal/context.js +6 -6
  28. package/build/components/global-styles/font-library-modal/context.js.map +1 -1
  29. package/build/components/global-styles/font-library-modal/font-collection.js +8 -4
  30. package/build/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  31. package/build/components/global-styles/font-library-modal/index.js +38 -21
  32. package/build/components/global-styles/font-library-modal/index.js.map +1 -1
  33. package/build/components/global-styles/font-library-modal/installed-fonts.js +2 -2
  34. package/build/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  35. package/build/components/global-styles/font-library-modal/library-font-variant.js +11 -7
  36. package/build/components/global-styles/font-library-modal/library-font-variant.js.map +1 -1
  37. package/build/components/global-styles/font-library-modal/local-fonts.js +26 -10
  38. package/build/components/global-styles/font-library-modal/local-fonts.js.map +1 -1
  39. package/build/components/global-styles/font-library-modal/resolvers.js +6 -6
  40. package/build/components/global-styles/font-library-modal/resolvers.js.map +1 -1
  41. package/build/components/global-styles/font-library-modal/{tab-layout.js → tab-panel-layout.js} +4 -4
  42. package/build/components/global-styles/font-library-modal/tab-panel-layout.js.map +1 -0
  43. package/build/components/global-styles/font-library-modal/utils/index.js +35 -38
  44. package/build/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  45. package/build/components/global-styles/preview.js +43 -1
  46. package/build/components/global-styles/preview.js.map +1 -1
  47. package/build/components/global-styles/screen-color-palette.js +16 -12
  48. package/build/components/global-styles/screen-color-palette.js.map +1 -1
  49. package/build/components/global-styles/screen-revisions/index.js +54 -58
  50. package/build/components/global-styles/screen-revisions/index.js.map +1 -1
  51. package/build/components/global-styles/screen-revisions/revisions-buttons.js +56 -15
  52. package/build/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  53. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js +40 -22
  54. package/build/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  55. package/build/components/global-styles/ui.js +13 -62
  56. package/build/components/global-styles/ui.js.map +1 -1
  57. package/build/components/header-edit-mode/document-tools/index.js +15 -106
  58. package/build/components/header-edit-mode/document-tools/index.js.map +1 -1
  59. package/build/components/header-edit-mode/index.js +21 -47
  60. package/build/components/header-edit-mode/index.js.map +1 -1
  61. package/build/components/header-edit-mode/mode-switcher/index.js +0 -2
  62. package/build/components/header-edit-mode/mode-switcher/index.js.map +1 -1
  63. package/build/components/header-edit-mode/more-menu/index.js +19 -14
  64. package/build/components/header-edit-mode/more-menu/index.js.map +1 -1
  65. package/build/components/keyboard-shortcuts/edit-mode.js +0 -23
  66. package/build/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  67. package/build/components/keyboard-shortcuts/register.js +0 -36
  68. package/build/components/keyboard-shortcuts/register.js.map +1 -1
  69. package/build/components/layout/index.js +15 -21
  70. package/build/components/layout/index.js.map +1 -1
  71. package/build/components/page/header.js +2 -1
  72. package/build/components/page/header.js.map +1 -1
  73. package/build/components/page-main/index.js +4 -4
  74. package/build/components/page-main/index.js.map +1 -1
  75. package/build/components/page-pages/index.js +102 -52
  76. package/build/components/page-pages/index.js.map +1 -1
  77. package/build/components/page-patterns/dataviews-pattern-actions.js +305 -0
  78. package/build/components/page-patterns/dataviews-pattern-actions.js.map +1 -0
  79. package/build/components/page-patterns/dataviews-patterns.js +307 -0
  80. package/build/components/page-patterns/dataviews-patterns.js.map +1 -0
  81. package/build/components/page-patterns/duplicate-menu-item.js +1 -1
  82. package/build/components/page-patterns/duplicate-menu-item.js.map +1 -1
  83. package/build/components/page-patterns/grid-item.js +4 -3
  84. package/build/components/page-patterns/grid-item.js.map +1 -1
  85. package/build/components/page-patterns/patterns-list.js +3 -3
  86. package/build/components/page-patterns/patterns-list.js.map +1 -1
  87. package/build/components/page-patterns/rename-menu-item.js +3 -0
  88. package/build/components/page-patterns/rename-menu-item.js.map +1 -1
  89. package/build/components/page-patterns/use-patterns.js +23 -13
  90. package/build/components/page-patterns/use-patterns.js.map +1 -1
  91. package/build/components/page-templates/index.js +312 -36
  92. package/build/components/page-templates/index.js.map +1 -1
  93. package/build/components/{page-patterns/pagination.js → pagination/index.js} +25 -12
  94. package/build/components/pagination/index.js.map +1 -0
  95. package/build/components/{page-pages/side-editor.js → post-preview/index.js} +8 -4
  96. package/build/components/post-preview/index.js.map +1 -0
  97. package/build/components/preferences-modal/enable-feature.js +3 -2
  98. package/build/components/preferences-modal/enable-feature.js.map +1 -1
  99. package/build/components/preferences-modal/enable-panel-option.js +33 -0
  100. package/build/components/preferences-modal/enable-panel-option.js.map +1 -0
  101. package/build/components/preferences-modal/index.js +89 -25
  102. package/build/components/preferences-modal/index.js.map +1 -1
  103. package/build/components/revisions/index.js +3 -7
  104. package/build/components/revisions/index.js.map +1 -1
  105. package/build/components/routes/link.js +6 -2
  106. package/build/components/routes/link.js.map +1 -1
  107. package/build/components/routes/use-title.js +3 -4
  108. package/build/components/routes/use-title.js.map +1 -1
  109. package/build/components/save-button/index.js +8 -4
  110. package/build/components/save-button/index.js.map +1 -1
  111. package/build/components/sidebar/index.js +26 -20
  112. package/build/components/sidebar/index.js.map +1 -1
  113. package/build/components/sidebar-dataviews/add-new-view.js +2 -2
  114. package/build/components/sidebar-dataviews/add-new-view.js.map +1 -1
  115. package/build/components/sidebar-dataviews/dataview-item.js +2 -10
  116. package/build/components/sidebar-dataviews/dataview-item.js.map +1 -1
  117. package/build/components/sidebar-dataviews/default-views.js +19 -6
  118. package/build/components/sidebar-dataviews/default-views.js.map +1 -1
  119. package/build/components/sidebar-dataviews/index.js +3 -3
  120. package/build/components/sidebar-dataviews/index.js.map +1 -1
  121. package/build/components/sidebar-edit-mode/default-sidebar.js +1 -5
  122. package/build/components/sidebar-edit-mode/default-sidebar.js.map +1 -1
  123. package/build/components/sidebar-edit-mode/global-styles-sidebar.js +62 -10
  124. package/build/components/sidebar-edit-mode/global-styles-sidebar.js.map +1 -1
  125. package/build/components/sidebar-edit-mode/page-panels/index.js +10 -4
  126. package/build/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  127. package/build/components/sidebar-edit-mode/page-panels/page-summary.js +1 -2
  128. package/build/components/sidebar-edit-mode/page-panels/page-summary.js.map +1 -1
  129. package/build/components/sidebar-edit-mode/plugin-sidebar/index.js +0 -4
  130. package/build/components/sidebar-edit-mode/plugin-sidebar/index.js.map +1 -1
  131. package/build/components/sidebar-edit-mode/template-panel/index.js +4 -13
  132. package/build/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  133. package/build/components/sidebar-navigation-screen-details-footer/index.js +1 -1
  134. package/build/components/sidebar-navigation-screen-details-footer/index.js.map +1 -1
  135. package/build/components/sidebar-navigation-screen-global-styles/index.js +5 -2
  136. package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  137. package/build/components/sidebar-navigation-screen-navigation-menu/rename-modal.js +3 -0
  138. package/build/components/sidebar-navigation-screen-navigation-menu/rename-modal.js.map +1 -1
  139. package/build/components/sidebar-navigation-screen-page/index.js +4 -1
  140. package/build/components/sidebar-navigation-screen-page/index.js.map +1 -1
  141. package/build/components/sidebar-navigation-screen-pages-dataviews/index.js +69 -0
  142. package/build/components/sidebar-navigation-screen-pages-dataviews/index.js.map +1 -0
  143. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +1 -1
  144. package/build/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  145. package/build/components/sidebar-navigation-screen-template/home-template-details.js +3 -89
  146. package/build/components/sidebar-navigation-screen-template/home-template-details.js.map +1 -1
  147. package/build/components/sidebar-navigation-screen-template/index.js +2 -1
  148. package/build/components/sidebar-navigation-screen-template/index.js.map +1 -1
  149. package/build/components/sidebar-navigation-screen-template/template-areas.js +117 -0
  150. package/build/components/sidebar-navigation-screen-template/template-areas.js.map +1 -0
  151. package/build/components/sidebar-navigation-screen-templates/index.js +63 -8
  152. package/build/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  153. package/build/components/site-hub/index.js +6 -3
  154. package/build/components/site-hub/index.js.map +1 -1
  155. package/build/components/style-book/index.js +38 -8
  156. package/build/components/style-book/index.js.map +1 -1
  157. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +1 -1
  158. package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  159. package/build/components/template-actions/rename-menu-item.js +3 -0
  160. package/build/components/template-actions/rename-menu-item.js.map +1 -1
  161. package/build/components/welcome-guide/styles.js +1 -1
  162. package/build/components/welcome-guide/styles.js.map +1 -1
  163. package/build/hooks/commands/use-common-commands.js +9 -1
  164. package/build/hooks/commands/use-common-commands.js.map +1 -1
  165. package/build/hooks/commands/use-edit-mode-commands.js +11 -6
  166. package/build/hooks/commands/use-edit-mode-commands.js.map +1 -1
  167. package/build/hooks/navigation-menu-edit.js +1 -1
  168. package/build/hooks/navigation-menu-edit.js.map +1 -1
  169. package/build/hooks/template-part-edit.js +1 -1
  170. package/build/hooks/template-part-edit.js.map +1 -1
  171. package/build/index.js +12 -7
  172. package/build/index.js.map +1 -1
  173. package/build/store/actions.js +54 -52
  174. package/build/store/actions.js.map +1 -1
  175. package/build/store/private-actions.js +6 -2
  176. package/build/store/private-actions.js.map +1 -1
  177. package/build/store/reducer.js +0 -64
  178. package/build/store/reducer.js.map +1 -1
  179. package/build/store/selectors.js +44 -47
  180. package/build/store/selectors.js.map +1 -1
  181. package/build/utils/constants.js +15 -1
  182. package/build/utils/constants.js.map +1 -1
  183. package/build/utils/get-is-list-page.js +1 -1
  184. package/build/utils/get-is-list-page.js.map +1 -1
  185. package/build-module/components/add-new-template/add-custom-template-modal-content.js +1 -1
  186. package/build-module/components/add-new-template/add-custom-template-modal-content.js.map +1 -1
  187. package/build-module/components/block-editor/back-button.js +4 -3
  188. package/build-module/components/block-editor/back-button.js.map +1 -1
  189. package/build-module/components/block-editor/editor-canvas.js +50 -25
  190. package/build-module/components/block-editor/editor-canvas.js.map +1 -1
  191. package/build-module/components/block-editor/resizable-editor.js +2 -2
  192. package/build-module/components/block-editor/resizable-editor.js.map +1 -1
  193. package/build-module/components/block-editor/site-editor-canvas.js +8 -56
  194. package/build-module/components/block-editor/site-editor-canvas.js.map +1 -1
  195. package/build-module/components/block-editor/use-post-link-props.js +20 -0
  196. package/build-module/components/block-editor/use-post-link-props.js.map +1 -0
  197. package/build-module/components/block-editor/use-site-editor-settings.js +16 -24
  198. package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
  199. package/build-module/components/create-template-part-modal/index.js +14 -7
  200. package/build-module/components/create-template-part-modal/index.js.map +1 -1
  201. package/build-module/components/editor/index.js +25 -37
  202. package/build-module/components/editor/index.js.map +1 -1
  203. package/build-module/components/editor-canvas-container/index.js +9 -7
  204. package/build-module/components/editor-canvas-container/index.js.map +1 -1
  205. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js +13 -8
  206. package/build-module/components/global-styles/font-library-modal/collection-font-variant.js.map +1 -1
  207. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js +3 -3
  208. package/build-module/components/global-styles/font-library-modal/confirm-delete-dialog.js.map +1 -1
  209. package/build-module/components/global-styles/font-library-modal/context.js +8 -8
  210. package/build-module/components/global-styles/font-library-modal/context.js.map +1 -1
  211. package/build-module/components/global-styles/font-library-modal/font-collection.js +8 -4
  212. package/build-module/components/global-styles/font-library-modal/font-collection.js.map +1 -1
  213. package/build-module/components/global-styles/font-library-modal/index.js +39 -22
  214. package/build-module/components/global-styles/font-library-modal/index.js.map +1 -1
  215. package/build-module/components/global-styles/font-library-modal/installed-fonts.js +2 -2
  216. package/build-module/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
  217. package/build-module/components/global-styles/font-library-modal/library-font-variant.js +13 -8
  218. package/build-module/components/global-styles/font-library-modal/library-font-variant.js.map +1 -1
  219. package/build-module/components/global-styles/font-library-modal/local-fonts.js +27 -11
  220. package/build-module/components/global-styles/font-library-modal/local-fonts.js.map +1 -1
  221. package/build-module/components/global-styles/font-library-modal/resolvers.js +5 -5
  222. package/build-module/components/global-styles/font-library-modal/resolvers.js.map +1 -1
  223. package/build-module/components/global-styles/font-library-modal/{tab-layout.js → tab-panel-layout.js} +4 -4
  224. package/build-module/components/global-styles/font-library-modal/tab-panel-layout.js.map +1 -0
  225. package/build-module/components/global-styles/font-library-modal/utils/index.js +34 -36
  226. package/build-module/components/global-styles/font-library-modal/utils/index.js.map +1 -1
  227. package/build-module/components/global-styles/preview.js +45 -3
  228. package/build-module/components/global-styles/preview.js.map +1 -1
  229. package/build-module/components/global-styles/screen-color-palette.js +17 -13
  230. package/build-module/components/global-styles/screen-color-palette.js.map +1 -1
  231. package/build-module/components/global-styles/screen-revisions/index.js +55 -59
  232. package/build-module/components/global-styles/screen-revisions/index.js.map +1 -1
  233. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js +56 -15
  234. package/build-module/components/global-styles/screen-revisions/revisions-buttons.js.map +1 -1
  235. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js +40 -22
  236. package/build-module/components/global-styles/screen-revisions/use-global-styles-revisions.js.map +1 -1
  237. package/build-module/components/global-styles/ui.js +15 -64
  238. package/build-module/components/global-styles/ui.js.map +1 -1
  239. package/build-module/components/header-edit-mode/document-tools/index.js +19 -109
  240. package/build-module/components/header-edit-mode/document-tools/index.js.map +1 -1
  241. package/build-module/components/header-edit-mode/index.js +25 -51
  242. package/build-module/components/header-edit-mode/index.js.map +1 -1
  243. package/build-module/components/header-edit-mode/mode-switcher/index.js +0 -2
  244. package/build-module/components/header-edit-mode/mode-switcher/index.js.map +1 -1
  245. package/build-module/components/header-edit-mode/more-menu/index.js +20 -15
  246. package/build-module/components/header-edit-mode/more-menu/index.js.map +1 -1
  247. package/build-module/components/keyboard-shortcuts/edit-mode.js +0 -23
  248. package/build-module/components/keyboard-shortcuts/edit-mode.js.map +1 -1
  249. package/build-module/components/keyboard-shortcuts/register.js +0 -36
  250. package/build-module/components/keyboard-shortcuts/register.js.map +1 -1
  251. package/build-module/components/layout/index.js +15 -21
  252. package/build-module/components/layout/index.js.map +1 -1
  253. package/build-module/components/page/header.js +2 -1
  254. package/build-module/components/page/header.js.map +1 -1
  255. package/build-module/components/page-main/index.js +4 -4
  256. package/build-module/components/page-main/index.js.map +1 -1
  257. package/build-module/components/page-pages/index.js +101 -51
  258. package/build-module/components/page-pages/index.js.map +1 -1
  259. package/build-module/components/page-patterns/dataviews-pattern-actions.js +292 -0
  260. package/build-module/components/page-patterns/dataviews-pattern-actions.js.map +1 -0
  261. package/build-module/components/page-patterns/dataviews-patterns.js +299 -0
  262. package/build-module/components/page-patterns/dataviews-patterns.js.map +1 -0
  263. package/build-module/components/page-patterns/duplicate-menu-item.js +1 -1
  264. package/build-module/components/page-patterns/duplicate-menu-item.js.map +1 -1
  265. package/build-module/components/page-patterns/grid-item.js +4 -3
  266. package/build-module/components/page-patterns/grid-item.js.map +1 -1
  267. package/build-module/components/page-patterns/patterns-list.js +3 -3
  268. package/build-module/components/page-patterns/patterns-list.js.map +1 -1
  269. package/build-module/components/page-patterns/rename-menu-item.js +3 -0
  270. package/build-module/components/page-patterns/rename-menu-item.js.map +1 -1
  271. package/build-module/components/page-patterns/use-patterns.js +23 -13
  272. package/build-module/components/page-patterns/use-patterns.js.map +1 -1
  273. package/build-module/components/page-templates/index.js +314 -38
  274. package/build-module/components/page-templates/index.js.map +1 -1
  275. package/build-module/components/{page-patterns/pagination.js → pagination/index.js} +24 -12
  276. package/build-module/components/pagination/index.js.map +1 -0
  277. package/build-module/components/{page-pages/side-editor.js → post-preview/index.js} +7 -3
  278. package/build-module/components/post-preview/index.js.map +1 -0
  279. package/build-module/components/preferences-modal/enable-feature.js +3 -2
  280. package/build-module/components/preferences-modal/enable-feature.js.map +1 -1
  281. package/build-module/components/preferences-modal/enable-panel-option.js +26 -0
  282. package/build-module/components/preferences-modal/enable-panel-option.js.map +1 -0
  283. package/build-module/components/preferences-modal/index.js +90 -26
  284. package/build-module/components/preferences-modal/index.js.map +1 -1
  285. package/build-module/components/revisions/index.js +4 -8
  286. package/build-module/components/revisions/index.js.map +1 -1
  287. package/build-module/components/routes/link.js +5 -2
  288. package/build-module/components/routes/link.js.map +1 -1
  289. package/build-module/components/routes/use-title.js +3 -4
  290. package/build-module/components/routes/use-title.js.map +1 -1
  291. package/build-module/components/save-button/index.js +8 -4
  292. package/build-module/components/save-button/index.js.map +1 -1
  293. package/build-module/components/sidebar/index.js +26 -20
  294. package/build-module/components/sidebar/index.js.map +1 -1
  295. package/build-module/components/sidebar-dataviews/add-new-view.js +1 -1
  296. package/build-module/components/sidebar-dataviews/add-new-view.js.map +1 -1
  297. package/build-module/components/sidebar-dataviews/dataview-item.js +2 -10
  298. package/build-module/components/sidebar-dataviews/dataview-item.js.map +1 -1
  299. package/build-module/components/sidebar-dataviews/default-views.js +17 -5
  300. package/build-module/components/sidebar-dataviews/default-views.js.map +1 -1
  301. package/build-module/components/sidebar-dataviews/index.js +2 -2
  302. package/build-module/components/sidebar-dataviews/index.js.map +1 -1
  303. package/build-module/components/sidebar-edit-mode/default-sidebar.js +1 -5
  304. package/build-module/components/sidebar-edit-mode/default-sidebar.js.map +1 -1
  305. package/build-module/components/sidebar-edit-mode/global-styles-sidebar.js +64 -12
  306. package/build-module/components/sidebar-edit-mode/global-styles-sidebar.js.map +1 -1
  307. package/build-module/components/sidebar-edit-mode/page-panels/index.js +10 -4
  308. package/build-module/components/sidebar-edit-mode/page-panels/index.js.map +1 -1
  309. package/build-module/components/sidebar-edit-mode/page-panels/page-summary.js +2 -3
  310. package/build-module/components/sidebar-edit-mode/page-panels/page-summary.js.map +1 -1
  311. package/build-module/components/sidebar-edit-mode/plugin-sidebar/index.js +0 -4
  312. package/build-module/components/sidebar-edit-mode/plugin-sidebar/index.js.map +1 -1
  313. package/build-module/components/sidebar-edit-mode/template-panel/index.js +6 -15
  314. package/build-module/components/sidebar-edit-mode/template-panel/index.js.map +1 -1
  315. package/build-module/components/sidebar-navigation-screen-details-footer/index.js +1 -1
  316. package/build-module/components/sidebar-navigation-screen-details-footer/index.js.map +1 -1
  317. package/build-module/components/sidebar-navigation-screen-global-styles/index.js +5 -2
  318. package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
  319. package/build-module/components/sidebar-navigation-screen-navigation-menu/rename-modal.js +3 -0
  320. package/build-module/components/sidebar-navigation-screen-navigation-menu/rename-modal.js.map +1 -1
  321. package/build-module/components/sidebar-navigation-screen-page/index.js +4 -1
  322. package/build-module/components/sidebar-navigation-screen-page/index.js.map +1 -1
  323. package/build-module/components/sidebar-navigation-screen-pages-dataviews/index.js +61 -0
  324. package/build-module/components/sidebar-navigation-screen-pages-dataviews/index.js.map +1 -0
  325. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +1 -1
  326. package/build-module/components/sidebar-navigation-screen-patterns/use-pattern-categories.js.map +1 -1
  327. package/build-module/components/sidebar-navigation-screen-template/home-template-details.js +5 -90
  328. package/build-module/components/sidebar-navigation-screen-template/home-template-details.js.map +1 -1
  329. package/build-module/components/sidebar-navigation-screen-template/index.js +2 -1
  330. package/build-module/components/sidebar-navigation-screen-template/index.js.map +1 -1
  331. package/build-module/components/sidebar-navigation-screen-template/template-areas.js +109 -0
  332. package/build-module/components/sidebar-navigation-screen-template/template-areas.js.map +1 -0
  333. package/build-module/components/sidebar-navigation-screen-templates/index.js +64 -9
  334. package/build-module/components/sidebar-navigation-screen-templates/index.js.map +1 -1
  335. package/build-module/components/site-hub/index.js +6 -3
  336. package/build-module/components/site-hub/index.js.map +1 -1
  337. package/build-module/components/style-book/index.js +40 -10
  338. package/build-module/components/style-book/index.js.map +1 -1
  339. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +1 -1
  340. package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
  341. package/build-module/components/template-actions/rename-menu-item.js +3 -0
  342. package/build-module/components/template-actions/rename-menu-item.js.map +1 -1
  343. package/build-module/components/welcome-guide/styles.js +1 -1
  344. package/build-module/components/welcome-guide/styles.js.map +1 -1
  345. package/build-module/hooks/commands/use-common-commands.js +9 -1
  346. package/build-module/hooks/commands/use-common-commands.js.map +1 -1
  347. package/build-module/hooks/commands/use-edit-mode-commands.js +11 -6
  348. package/build-module/hooks/commands/use-edit-mode-commands.js.map +1 -1
  349. package/build-module/hooks/navigation-menu-edit.js +1 -1
  350. package/build-module/hooks/navigation-menu-edit.js.map +1 -1
  351. package/build-module/hooks/template-part-edit.js +1 -1
  352. package/build-module/hooks/template-part-edit.js.map +1 -1
  353. package/build-module/index.js +12 -7
  354. package/build-module/index.js.map +1 -1
  355. package/build-module/store/actions.js +49 -47
  356. package/build-module/store/actions.js.map +1 -1
  357. package/build-module/store/private-actions.js +6 -2
  358. package/build-module/store/private-actions.js.map +1 -1
  359. package/build-module/store/reducer.js +0 -61
  360. package/build-module/store/reducer.js.map +1 -1
  361. package/build-module/store/selectors.js +40 -41
  362. package/build-module/store/selectors.js.map +1 -1
  363. package/build-module/utils/constants.js +8 -0
  364. package/build-module/utils/constants.js.map +1 -1
  365. package/build-module/utils/get-is-list-page.js +1 -1
  366. package/build-module/utils/get-is-list-page.js.map +1 -1
  367. package/build-style/style-rtl.css +607 -561
  368. package/build-style/style.css +607 -561
  369. package/package.json +42 -42
  370. package/src/components/add-new-template/add-custom-template-modal-content.js +1 -1
  371. package/src/components/add-new-template/style.scss +2 -1
  372. package/src/components/block-editor/back-button.js +4 -2
  373. package/src/components/block-editor/editor-canvas.js +63 -47
  374. package/src/components/block-editor/resizable-editor.js +1 -1
  375. package/src/components/block-editor/site-editor-canvas.js +32 -96
  376. package/src/components/block-editor/style.scss +7 -14
  377. package/src/components/block-editor/use-post-link-props.js +20 -0
  378. package/src/components/block-editor/use-site-editor-settings.js +38 -58
  379. package/src/components/code-editor/style.scss +0 -4
  380. package/src/components/create-template-part-modal/index.js +83 -82
  381. package/src/components/editor/index.js +34 -47
  382. package/src/components/editor-canvas-container/index.js +8 -6
  383. package/src/components/global-styles/font-library-modal/collection-font-variant.js +18 -7
  384. package/src/components/global-styles/font-library-modal/confirm-delete-dialog.js +3 -3
  385. package/src/components/global-styles/font-library-modal/context.js +8 -8
  386. package/src/components/global-styles/font-library-modal/font-collection.js +10 -5
  387. package/src/components/global-styles/font-library-modal/index.js +44 -24
  388. package/src/components/global-styles/font-library-modal/installed-fonts.js +3 -3
  389. package/src/components/global-styles/font-library-modal/library-font-variant.js +18 -7
  390. package/src/components/global-styles/font-library-modal/local-fonts.js +53 -26
  391. package/src/components/global-styles/font-library-modal/resolvers.js +5 -5
  392. package/src/components/global-styles/font-library-modal/style.scss +5 -2
  393. package/src/components/global-styles/font-library-modal/{tab-layout.js → tab-panel-layout.js} +9 -3
  394. package/src/components/global-styles/font-library-modal/utils/index.js +21 -23
  395. package/src/components/global-styles/font-library-modal/utils/test/makeFormDataFromFontFamily.spec.js +58 -0
  396. package/src/components/global-styles/preview.js +55 -3
  397. package/src/components/global-styles/screen-color-palette.js +16 -26
  398. package/src/components/global-styles/screen-revisions/index.js +93 -101
  399. package/src/components/global-styles/screen-revisions/revisions-buttons.js +85 -17
  400. package/src/components/global-styles/screen-revisions/style.scss +86 -21
  401. package/src/components/global-styles/screen-revisions/test/use-global-styles-revisions.js +67 -0
  402. package/src/components/global-styles/screen-revisions/use-global-styles-revisions.js +73 -46
  403. package/src/components/global-styles/ui.js +13 -74
  404. package/src/components/header-edit-mode/document-tools/index.js +35 -167
  405. package/src/components/header-edit-mode/index.js +33 -78
  406. package/src/components/header-edit-mode/mode-switcher/index.js +0 -4
  407. package/src/components/header-edit-mode/more-menu/index.js +25 -27
  408. package/src/components/header-edit-mode/style.scss +46 -68
  409. package/src/components/keyboard-shortcuts/edit-mode.js +1 -26
  410. package/src/components/keyboard-shortcuts/register.js +0 -43
  411. package/src/components/layout/index.js +29 -47
  412. package/src/components/layout/style.scss +10 -3
  413. package/src/components/page/header.js +2 -1
  414. package/src/components/page/style.scss +3 -3
  415. package/src/components/page-main/index.js +8 -8
  416. package/src/components/page-pages/index.js +157 -62
  417. package/src/components/page-pages/style.scss +4 -1
  418. package/src/components/page-patterns/dataviews-pattern-actions.js +329 -0
  419. package/src/components/page-patterns/dataviews-patterns.js +380 -0
  420. package/src/components/page-patterns/duplicate-menu-item.js +1 -1
  421. package/src/components/page-patterns/grid-item.js +3 -2
  422. package/src/components/page-patterns/patterns-list.js +7 -3
  423. package/src/components/page-patterns/rename-menu-item.js +7 -1
  424. package/src/components/page-patterns/style.scss +89 -26
  425. package/src/components/page-patterns/use-patterns.js +24 -15
  426. package/src/components/page-templates/index.js +399 -64
  427. package/src/components/{page-patterns/pagination.js → pagination/index.js} +21 -10
  428. package/src/components/pagination/style.scss +5 -0
  429. package/src/components/post-preview/index.js +16 -0
  430. package/src/components/preferences-modal/enable-feature.js +9 -5
  431. package/src/components/preferences-modal/enable-panel-option.js +23 -0
  432. package/src/components/preferences-modal/index.js +151 -40
  433. package/src/components/revisions/index.js +8 -15
  434. package/src/components/routes/link.js +11 -3
  435. package/src/components/routes/use-title.js +3 -10
  436. package/src/components/save-button/index.js +17 -3
  437. package/src/components/sidebar/index.js +45 -35
  438. package/src/components/sidebar/style.scss +10 -12
  439. package/src/components/sidebar-dataviews/add-new-view.js +1 -1
  440. package/src/components/sidebar-dataviews/dataview-item.js +3 -7
  441. package/src/components/sidebar-dataviews/default-views.js +23 -6
  442. package/src/components/sidebar-dataviews/index.js +2 -2
  443. package/src/components/sidebar-edit-mode/default-sidebar.js +0 -12
  444. package/src/components/sidebar-edit-mode/global-styles-sidebar.js +85 -14
  445. package/src/components/sidebar-edit-mode/page-panels/index.js +53 -25
  446. package/src/components/sidebar-edit-mode/page-panels/page-summary.js +2 -2
  447. package/src/components/sidebar-edit-mode/page-panels/style.scss +1 -42
  448. package/src/components/sidebar-edit-mode/plugin-sidebar/index.js +0 -12
  449. package/src/components/sidebar-edit-mode/style.scss +0 -10
  450. package/src/components/sidebar-edit-mode/template-panel/index.js +44 -40
  451. package/src/components/sidebar-edit-mode/template-panel/style.scss +0 -4
  452. package/src/components/sidebar-navigation-screen-details-footer/index.js +1 -1
  453. package/src/components/sidebar-navigation-screen-global-styles/index.js +3 -2
  454. package/src/components/sidebar-navigation-screen-navigation-menu/rename-modal.js +7 -1
  455. package/src/components/sidebar-navigation-screen-page/index.js +2 -1
  456. package/src/components/sidebar-navigation-screen-pages-dataviews/index.js +77 -0
  457. package/src/components/sidebar-navigation-screen-patterns/use-pattern-categories.js +1 -1
  458. package/src/components/sidebar-navigation-screen-template/home-template-details.js +1 -96
  459. package/src/components/sidebar-navigation-screen-template/index.js +8 -2
  460. package/src/components/sidebar-navigation-screen-template/template-areas.js +135 -0
  461. package/src/components/sidebar-navigation-screen-templates/index.js +85 -28
  462. package/src/components/sidebar-navigation-screen-templates/style.scss +9 -0
  463. package/src/components/site-hub/index.js +4 -5
  464. package/src/components/site-hub/style.scss +5 -2
  465. package/src/components/style-book/index.js +65 -21
  466. package/src/components/style-book/style.scss +3 -3
  467. package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +4 -1
  468. package/src/components/template-actions/rename-menu-item.js +7 -1
  469. package/src/components/welcome-guide/styles.js +1 -1
  470. package/src/hooks/commands/use-common-commands.js +10 -5
  471. package/src/hooks/commands/use-edit-mode-commands.js +8 -12
  472. package/src/hooks/navigation-menu-edit.js +1 -1
  473. package/src/hooks/template-part-edit.js +1 -1
  474. package/src/index.js +11 -5
  475. package/src/store/actions.js +50 -50
  476. package/src/store/private-actions.js +7 -3
  477. package/src/store/reducer.js +0 -62
  478. package/src/store/selectors.js +47 -41
  479. package/src/store/test/actions.js +11 -39
  480. package/src/store/test/reducer.js +1 -82
  481. package/src/store/test/selectors.js +0 -24
  482. package/src/style.scss +3 -3
  483. package/src/utils/constants.js +8 -0
  484. package/src/utils/get-is-list-page.js +2 -3
  485. package/build/components/dataviews/add-filter.js +0 -91
  486. package/build/components/dataviews/add-filter.js.map +0 -1
  487. package/build/components/dataviews/constants.js +0 -14
  488. package/build/components/dataviews/constants.js.map +0 -1
  489. package/build/components/dataviews/dataviews.js +0 -99
  490. package/build/components/dataviews/dataviews.js.map +0 -1
  491. package/build/components/dataviews/filter-summary.js +0 -62
  492. package/build/components/dataviews/filter-summary.js.map +0 -1
  493. package/build/components/dataviews/filters.js +0 -63
  494. package/build/components/dataviews/filters.js.map +0 -1
  495. package/build/components/dataviews/index.js +0 -21
  496. package/build/components/dataviews/index.js.map +0 -1
  497. package/build/components/dataviews/item-actions.js +0 -184
  498. package/build/components/dataviews/item-actions.js.map +0 -1
  499. package/build/components/dataviews/pagination.js +0 -123
  500. package/build/components/dataviews/pagination.js.map +0 -1
  501. package/build/components/dataviews/reset-filters.js +0 -33
  502. package/build/components/dataviews/reset-filters.js.map +0 -1
  503. package/build/components/dataviews/search.js +0 -51
  504. package/build/components/dataviews/search.js.map +0 -1
  505. package/build/components/dataviews/view-actions.js +0 -244
  506. package/build/components/dataviews/view-actions.js.map +0 -1
  507. package/build/components/dataviews/view-grid.js +0 -82
  508. package/build/components/dataviews/view-grid.js.map +0 -1
  509. package/build/components/dataviews/view-list.js +0 -399
  510. package/build/components/dataviews/view-list.js.map +0 -1
  511. package/build/components/dataviews/view-side-by-side.js +0 -20
  512. package/build/components/dataviews/view-side-by-side.js.map +0 -1
  513. package/build/components/global-styles/font-library-modal/tab-layout.js.map +0 -1
  514. package/build/components/header-edit-mode/document-actions/index.js +0 -172
  515. package/build/components/header-edit-mode/document-actions/index.js.map +0 -1
  516. package/build/components/header-edit-mode/undo-redo/redo.js +0 -41
  517. package/build/components/header-edit-mode/undo-redo/redo.js.map +0 -1
  518. package/build/components/header-edit-mode/undo-redo/undo.js +0 -40
  519. package/build/components/header-edit-mode/undo-redo/undo.js.map +0 -1
  520. package/build/components/page-content-focus-notifications/back-to-page-notification.js +0 -61
  521. package/build/components/page-content-focus-notifications/back-to-page-notification.js.map +0 -1
  522. package/build/components/page-content-focus-notifications/edit-template-notification.js +0 -102
  523. package/build/components/page-content-focus-notifications/edit-template-notification.js.map +0 -1
  524. package/build/components/page-content-focus-notifications/index.js +0 -22
  525. package/build/components/page-content-focus-notifications/index.js.map +0 -1
  526. package/build/components/page-pages/side-editor.js.map +0 -1
  527. package/build/components/page-patterns/pagination.js.map +0 -1
  528. package/build/components/page-templates/dataviews-templates.js +0 -316
  529. package/build/components/page-templates/dataviews-templates.js.map +0 -1
  530. package/build/components/secondary-sidebar/inserter-sidebar.js +0 -60
  531. package/build/components/secondary-sidebar/inserter-sidebar.js.map +0 -1
  532. package/build/components/secondary-sidebar/list-view-sidebar.js +0 -109
  533. package/build/components/secondary-sidebar/list-view-sidebar.js.map +0 -1
  534. package/build/components/sidebar-edit-mode/page-panels/edit-template.js +0 -101
  535. package/build/components/sidebar-edit-mode/page-panels/edit-template.js.map +0 -1
  536. package/build/components/sidebar-edit-mode/page-panels/hooks.js +0 -79
  537. package/build/components/sidebar-edit-mode/page-panels/hooks.js.map +0 -1
  538. package/build/components/sidebar-edit-mode/page-panels/reset-default-template.js +0 -48
  539. package/build/components/sidebar-edit-mode/page-panels/reset-default-template.js.map +0 -1
  540. package/build/components/sidebar-edit-mode/page-panels/swap-template-button.js +0 -84
  541. package/build/components/sidebar-edit-mode/page-panels/swap-template-button.js.map +0 -1
  542. package/build/components/sidebar-edit-mode/sidebar-fixed-bottom.js +0 -35
  543. package/build/components/sidebar-edit-mode/sidebar-fixed-bottom.js.map +0 -1
  544. package/build/components/sidebar-edit-mode/template-panel/last-revision.js +0 -73
  545. package/build/components/sidebar-edit-mode/template-panel/last-revision.js.map +0 -1
  546. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js +0 -219
  547. package/build/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +0 -1
  548. package/build/utils/use-debounced-input.js +0 -22
  549. package/build/utils/use-debounced-input.js.map +0 -1
  550. package/build-module/components/dataviews/add-filter.js +0 -84
  551. package/build-module/components/dataviews/add-filter.js.map +0 -1
  552. package/build-module/components/dataviews/constants.js +0 -6
  553. package/build-module/components/dataviews/constants.js.map +0 -1
  554. package/build-module/components/dataviews/dataviews.js +0 -90
  555. package/build-module/components/dataviews/dataviews.js.map +0 -1
  556. package/build-module/components/dataviews/filter-summary.js +0 -55
  557. package/build-module/components/dataviews/filter-summary.js.map +0 -1
  558. package/build-module/components/dataviews/filters.js +0 -55
  559. package/build-module/components/dataviews/filters.js.map +0 -1
  560. package/build-module/components/dataviews/index.js +0 -2
  561. package/build-module/components/dataviews/index.js.map +0 -1
  562. package/build-module/components/dataviews/item-actions.js +0 -177
  563. package/build-module/components/dataviews/item-actions.js.map +0 -1
  564. package/build-module/components/dataviews/pagination.js +0 -115
  565. package/build-module/components/dataviews/pagination.js.map +0 -1
  566. package/build-module/components/dataviews/reset-filters.js +0 -26
  567. package/build-module/components/dataviews/reset-filters.js.map +0 -1
  568. package/build-module/components/dataviews/search.js +0 -43
  569. package/build-module/components/dataviews/search.js.map +0 -1
  570. package/build-module/components/dataviews/view-actions.js +0 -237
  571. package/build-module/components/dataviews/view-actions.js.map +0 -1
  572. package/build-module/components/dataviews/view-grid.js +0 -74
  573. package/build-module/components/dataviews/view-grid.js.map +0 -1
  574. package/build-module/components/dataviews/view-list.js +0 -390
  575. package/build-module/components/dataviews/view-list.js.map +0 -1
  576. package/build-module/components/dataviews/view-side-by-side.js +0 -12
  577. package/build-module/components/dataviews/view-side-by-side.js.map +0 -1
  578. package/build-module/components/global-styles/font-library-modal/tab-layout.js.map +0 -1
  579. package/build-module/components/header-edit-mode/document-actions/index.js +0 -164
  580. package/build-module/components/header-edit-mode/document-actions/index.js.map +0 -1
  581. package/build-module/components/header-edit-mode/undo-redo/redo.js +0 -33
  582. package/build-module/components/header-edit-mode/undo-redo/redo.js.map +0 -1
  583. package/build-module/components/header-edit-mode/undo-redo/undo.js +0 -32
  584. package/build-module/components/header-edit-mode/undo-redo/undo.js.map +0 -1
  585. package/build-module/components/page-content-focus-notifications/back-to-page-notification.js +0 -54
  586. package/build-module/components/page-content-focus-notifications/back-to-page-notification.js.map +0 -1
  587. package/build-module/components/page-content-focus-notifications/edit-template-notification.js +0 -96
  588. package/build-module/components/page-content-focus-notifications/edit-template-notification.js.map +0 -1
  589. package/build-module/components/page-content-focus-notifications/index.js +0 -14
  590. package/build-module/components/page-content-focus-notifications/index.js.map +0 -1
  591. package/build-module/components/page-pages/side-editor.js.map +0 -1
  592. package/build-module/components/page-patterns/pagination.js.map +0 -1
  593. package/build-module/components/page-templates/dataviews-templates.js +0 -308
  594. package/build-module/components/page-templates/dataviews-templates.js.map +0 -1
  595. package/build-module/components/secondary-sidebar/inserter-sidebar.js +0 -53
  596. package/build-module/components/secondary-sidebar/inserter-sidebar.js.map +0 -1
  597. package/build-module/components/secondary-sidebar/list-view-sidebar.js +0 -102
  598. package/build-module/components/secondary-sidebar/list-view-sidebar.js.map +0 -1
  599. package/build-module/components/sidebar-edit-mode/page-panels/edit-template.js +0 -93
  600. package/build-module/components/sidebar-edit-mode/page-panels/edit-template.js.map +0 -1
  601. package/build-module/components/sidebar-edit-mode/page-panels/hooks.js +0 -69
  602. package/build-module/components/sidebar-edit-mode/page-panels/hooks.js.map +0 -1
  603. package/build-module/components/sidebar-edit-mode/page-panels/reset-default-template.js +0 -41
  604. package/build-module/components/sidebar-edit-mode/page-panels/reset-default-template.js.map +0 -1
  605. package/build-module/components/sidebar-edit-mode/page-panels/swap-template-button.js +0 -77
  606. package/build-module/components/sidebar-edit-mode/page-panels/swap-template-button.js.map +0 -1
  607. package/build-module/components/sidebar-edit-mode/sidebar-fixed-bottom.js +0 -27
  608. package/build-module/components/sidebar-edit-mode/sidebar-fixed-bottom.js.map +0 -1
  609. package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js +0 -65
  610. package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js.map +0 -1
  611. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js +0 -209
  612. package/build-module/components/sidebar-edit-mode/template-panel/pattern-categories.js.map +0 -1
  613. package/build-module/utils/use-debounced-input.js +0 -15
  614. package/build-module/utils/use-debounced-input.js.map +0 -1
  615. package/src/components/dataviews/README.md +0 -191
  616. package/src/components/dataviews/add-filter.js +0 -108
  617. package/src/components/dataviews/constants.js +0 -5
  618. package/src/components/dataviews/dataviews.js +0 -99
  619. package/src/components/dataviews/filter-summary.js +0 -79
  620. package/src/components/dataviews/filters.js +0 -65
  621. package/src/components/dataviews/index.js +0 -1
  622. package/src/components/dataviews/item-actions.js +0 -208
  623. package/src/components/dataviews/pagination.js +0 -144
  624. package/src/components/dataviews/reset-filters.js +0 -26
  625. package/src/components/dataviews/search.js +0 -42
  626. package/src/components/dataviews/style.scss +0 -131
  627. package/src/components/dataviews/view-actions.js +0 -319
  628. package/src/components/dataviews/view-grid.js +0 -90
  629. package/src/components/dataviews/view-list.js +0 -512
  630. package/src/components/dataviews/view-side-by-side.js +0 -9
  631. package/src/components/global-styles/font-library-modal/utils/test/makeFormDataFromFontFamilies.spec.js +0 -62
  632. package/src/components/global-styles/font-library-modal/utils/test/wpKebabCase.spec.js +0 -28
  633. package/src/components/header-edit-mode/document-actions/index.js +0 -204
  634. package/src/components/header-edit-mode/document-actions/style.scss +0 -145
  635. package/src/components/header-edit-mode/undo-redo/redo.js +0 -38
  636. package/src/components/header-edit-mode/undo-redo/undo.js +0 -34
  637. package/src/components/page-content-focus-notifications/back-to-page-notification.js +0 -58
  638. package/src/components/page-content-focus-notifications/edit-template-notification.js +0 -104
  639. package/src/components/page-content-focus-notifications/index.js +0 -14
  640. package/src/components/page-pages/side-editor.js +0 -14
  641. package/src/components/page-templates/dataviews-templates.js +0 -345
  642. package/src/components/secondary-sidebar/inserter-sidebar.js +0 -66
  643. package/src/components/secondary-sidebar/list-view-sidebar.js +0 -123
  644. package/src/components/secondary-sidebar/style.scss +0 -65
  645. package/src/components/sidebar-edit-mode/page-panels/edit-template.js +0 -108
  646. package/src/components/sidebar-edit-mode/page-panels/hooks.js +0 -99
  647. package/src/components/sidebar-edit-mode/page-panels/reset-default-template.js +0 -45
  648. package/src/components/sidebar-edit-mode/page-panels/swap-template-button.js +0 -83
  649. package/src/components/sidebar-edit-mode/sidebar-fixed-bottom.js +0 -26
  650. package/src/components/sidebar-edit-mode/template-panel/last-revision.js +0 -82
  651. package/src/components/sidebar-edit-mode/template-panel/pattern-categories.js +0 -279
  652. package/src/utils/use-debounced-input.js +0 -18
@@ -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';
@@ -12,14 +13,27 @@ import { useState, useMemo, useCallback, useEffect } from '@wordpress/element';
12
13
  import { dateI18n, getDate, getSettings } from '@wordpress/date';
13
14
  import { privateApis as routerPrivateApis } from '@wordpress/router';
14
15
  import { useSelect, useDispatch } from '@wordpress/data';
16
+ import { DataViews } from '@wordpress/dataviews';
17
+ import { ENTER, SPACE } from '@wordpress/keycodes';
15
18
 
16
19
  /**
17
20
  * Internal dependencies
18
21
  */
19
22
  import Page from '../page';
20
23
  import Link from '../routes/link';
21
- import { DataViews, viewTypeSupportsMap } from '../dataviews';
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';
28
+ import {
29
+ ENUMERATION_TYPE,
30
+ LAYOUT_GRID,
31
+ LAYOUT_TABLE,
32
+ LAYOUT_LIST,
33
+ OPERATOR_IN,
34
+ OPERATOR_NOT_IN,
35
+ } from '../../utils/constants';
36
+
23
37
  import {
24
38
  trashPostAction,
25
39
  usePermanentlyDeletePostAction,
@@ -28,20 +42,13 @@ import {
28
42
  viewPostAction,
29
43
  useEditPostAction,
30
44
  } from '../actions';
31
- import SideEditor from './side-editor';
45
+ import PostPreview from '../post-preview';
46
+ import AddNewPageModal from '../add-new-page';
32
47
  import Media from '../media';
33
48
  import { unlock } from '../../lock-unlock';
34
- import { ENUMERATION_TYPE, OPERATOR_IN } from '../dataviews/constants';
35
- const { useLocation } = unlock( routerPrivateApis );
49
+ const { useLocation, useHistory } = unlock( routerPrivateApis );
36
50
 
37
51
  const EMPTY_ARRAY = [];
38
- const defaultConfigPerViewType = {
39
- list: {},
40
- grid: {
41
- mediaField: 'featured-image',
42
- primaryField: 'title',
43
- },
44
- };
45
52
 
46
53
  function useView( type ) {
47
54
  const {
@@ -117,7 +124,25 @@ const DEFAULT_STATUSES = 'draft,future,pending,private,publish'; // All but 'tra
117
124
  export default function PagePages() {
118
125
  const postType = 'page';
119
126
  const [ view, setView ] = useView( postType );
120
- const [ selection, setSelection ] = useState( [] );
127
+ const [ pageId, setPageId ] = useState( null );
128
+ const history = useHistory();
129
+
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
+ );
121
146
 
122
147
  const queryArgs = useMemo( () => {
123
148
  const filters = {};
@@ -133,6 +158,11 @@ export default function PagePages() {
133
158
  filter.operator === OPERATOR_IN
134
159
  ) {
135
160
  filters.author = filter.value;
161
+ } else if (
162
+ filter.field === 'author' &&
163
+ filter.operator === OPERATOR_NOT_IN
164
+ ) {
165
+ filters.author_exclude = filter.value;
136
166
  }
137
167
  } );
138
168
  // We want to provide a different default item for the status filter
@@ -175,15 +205,15 @@ export default function PagePages() {
175
205
  id: 'featured-image',
176
206
  header: __( 'Featured Image' ),
177
207
  getValue: ( { item } ) => item.featured_media,
178
- render: ( { item, view: currentView } ) =>
208
+ render: ( { item } ) =>
179
209
  !! item.featured_media ? (
180
210
  <Media
181
211
  className="edit-site-page-pages__featured-image"
182
212
  id={ item.featured_media }
183
213
  size={
184
- currentView.type === 'list'
185
- ? [ 'thumbnail', 'medium', 'large', 'full' ]
186
- : [ 'large', 'full', 'medium', 'thumbnail' ]
214
+ view.type === LAYOUT_GRID
215
+ ? [ 'large', 'full', 'medium', 'thumbnail' ]
216
+ : [ 'thumbnail', 'medium', 'large', 'full' ]
187
217
  }
188
218
  />
189
219
  ) : null,
@@ -192,31 +222,33 @@ export default function PagePages() {
192
222
  {
193
223
  header: __( 'Title' ),
194
224
  id: 'title',
195
- getValue: ( { item } ) => item.title?.rendered || item.slug,
196
- render: ( { item, view: { type } } ) => {
225
+ getValue: ( { item } ) => item.title?.rendered,
226
+ render: ( { item } ) => {
197
227
  return (
198
228
  <VStack spacing={ 1 }>
199
- <Heading as="h3" level={ 5 }>
200
- <Link
201
- params={ {
202
- postId: item.id,
203
- postType: item.type,
204
- canvas: 'edit',
205
- } }
206
- onClick={ ( event ) => {
207
- if (
208
- viewTypeSupportsMap[ type ].preview
209
- ) {
210
- event.preventDefault();
211
- setSelection( [ item.id ] );
212
- }
213
- } }
214
- >
215
- { decodeEntities(
216
- item.title?.rendered || item.slug
217
- ) || __( '(no title)' ) }
218
- </Link>
219
- </Heading>
229
+ <View
230
+ as="span"
231
+ className="dataviews-view-grid__title-field"
232
+ >
233
+ { [ LAYOUT_TABLE, LAYOUT_GRID ].includes(
234
+ view.type
235
+ ) ? (
236
+ <Link
237
+ params={ {
238
+ postId: item.id,
239
+ postType: item.type,
240
+ canvas: 'edit',
241
+ } }
242
+ >
243
+ { decodeEntities(
244
+ item.title?.rendered
245
+ ) || __( '(no title)' ) }
246
+ </Link>
247
+ ) : (
248
+ decodeEntities( item.title?.rendered ) ||
249
+ __( '(no title)' )
250
+ ) }
251
+ </View>
220
252
  </VStack>
221
253
  );
222
254
  },
@@ -243,6 +275,9 @@ export default function PagePages() {
243
275
  type: ENUMERATION_TYPE,
244
276
  elements: STATUSES,
245
277
  enableSorting: false,
278
+ filterBy: {
279
+ operators: [ OPERATOR_IN ],
280
+ },
246
281
  },
247
282
  {
248
283
  header: __( 'Date' ),
@@ -257,7 +292,7 @@ export default function PagePages() {
257
292
  },
258
293
  },
259
294
  ],
260
- [ authors ]
295
+ [ authors, view.type ]
261
296
  );
262
297
 
263
298
  const permanentlyDeletePostAction = usePermanentlyDeletePostAction();
@@ -275,50 +310,110 @@ export default function PagePages() {
275
310
  [ permanentlyDeletePostAction, restorePostAction, editPostAction ]
276
311
  );
277
312
  const onChangeView = useCallback(
278
- ( viewUpdater ) => {
279
- let updatedView =
280
- typeof viewUpdater === 'function'
281
- ? viewUpdater( view )
282
- : viewUpdater;
283
- if ( updatedView.type !== view.type ) {
284
- updatedView = {
285
- ...updatedView,
313
+ ( newView ) => {
314
+ if ( newView.type !== view.type ) {
315
+ newView = {
316
+ ...newView,
286
317
  layout: {
287
- ...defaultConfigPerViewType[ updatedView.type ],
318
+ ...DEFAULT_CONFIG_PER_VIEW_TYPE[ newView.type ],
288
319
  },
289
320
  };
290
321
  }
291
322
 
292
- setView( updatedView );
323
+ setView( newView );
324
+ },
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();
293
347
  },
294
- [ view, setView ]
348
+ [ history ]
295
349
  );
296
350
 
297
351
  // TODO: we need to handle properly `data={ data || EMPTY_ARRAY }` for when `isLoading`.
298
352
  return (
299
353
  <>
300
- <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
+ >
301
375
  <DataViews
302
376
  paginationInfo={ paginationInfo }
303
377
  fields={ fields }
304
378
  actions={ actions }
305
379
  data={ pages || EMPTY_ARRAY }
306
- getItemId={ ( item ) => item.id }
307
380
  isLoading={ isLoadingPages || isLoadingAuthors }
308
381
  view={ view }
309
382
  onChangeView={ onChangeView }
383
+ onSelectionChange={ onSelectionChange }
384
+ onDetailsChange={ onDetailsChange }
310
385
  />
311
386
  </Page>
312
- { viewTypeSupportsMap[ view.type ].preview && (
387
+ { view.type === LAYOUT_LIST && (
313
388
  <Page>
314
- <div className="edit-site-page-pages-preview">
315
- { selection.length === 1 && (
316
- <SideEditor
317
- postId={ selection[ 0 ] }
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
+ >
411
+ { pageId !== null ? (
412
+ <PostPreview
413
+ postId={ pageId }
318
414
  postType={ postType }
319
415
  />
320
- ) }
321
- { selection.length !== 1 && (
416
+ ) : (
322
417
  <div
323
418
  style={ {
324
419
  display: 'flex',
@@ -1,3 +1,6 @@
1
1
  .edit-site-page-pages__featured-image {
2
- border-radius: $radius-block-ui;
2
+ border-radius: $grid-unit-05;
3
+ width: $grid-unit-50;
4
+ height: $grid-unit-50;
5
+ display: block;
3
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
+ };