@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
@@ -1,57 +1,294 @@
1
- import { createElement } from "react";
1
+ import { createElement, Fragment } from "react";
2
+ /**
3
+ * External dependencies
4
+ */
5
+ import removeAccents from 'remove-accents';
6
+
2
7
  /**
3
8
  * WordPress dependencies
4
9
  */
5
- import { VisuallyHidden, __experimentalHeading as Heading, __experimentalText as Text, __experimentalVStack as VStack } from '@wordpress/components';
10
+ import { Icon, __experimentalView as View, __experimentalText as Text, __experimentalHStack as HStack, __experimentalVStack as VStack, VisuallyHidden } from '@wordpress/components';
6
11
  import { __ } from '@wordpress/i18n';
12
+ import { useState, useMemo, useCallback } from '@wordpress/element';
7
13
  import { useEntityRecords } from '@wordpress/core-data';
8
14
  import { decodeEntities } from '@wordpress/html-entities';
15
+ import { ENTER, SPACE } from '@wordpress/keycodes';
16
+ import { parse } from '@wordpress/blocks';
17
+ import { BlockPreview, privateApis as blockEditorPrivateApis } from '@wordpress/block-editor';
18
+ import { DataViews, sortByTextFields, getPaginationResults } from '@wordpress/dataviews';
19
+ import { privateApis as routerPrivateApis } from '@wordpress/router';
9
20
 
10
21
  /**
11
22
  * Internal dependencies
12
23
  */
13
24
  import Page from '../page';
14
- import Table from '../table';
15
25
  import Link from '../routes/link';
16
- import AddedBy from '../list/added-by';
17
- import TemplateActions from '../template-actions';
18
26
  import AddNewTemplate from '../add-new-template';
19
- import { TEMPLATE_POST_TYPE } from '../../utils/constants';
20
- export default function PageTemplates() {
27
+ import { useAddedBy, AvatarImage } from '../list/added-by';
28
+ import { TEMPLATE_POST_TYPE, ENUMERATION_TYPE, OPERATOR_IN, OPERATOR_NOT_IN, LAYOUT_GRID, LAYOUT_TABLE, LAYOUT_LIST } from '../../utils/constants';
29
+ import { useResetTemplateAction, deleteTemplateAction, renameTemplateAction } from './template-actions';
30
+ import { postRevisionsAction } from '../actions';
31
+ import usePatternSettings from '../page-patterns/use-pattern-settings';
32
+ import { unlock } from '../../lock-unlock';
33
+ import PostPreview from '../post-preview';
34
+ const {
35
+ ExperimentalBlockEditorProvider,
36
+ useGlobalStyle
37
+ } = unlock(blockEditorPrivateApis);
38
+ const {
39
+ useHistory
40
+ } = unlock(routerPrivateApis);
41
+ const EMPTY_ARRAY = [];
42
+ const defaultConfigPerViewType = {
43
+ [LAYOUT_TABLE]: {},
44
+ [LAYOUT_GRID]: {
45
+ mediaField: 'preview',
46
+ primaryField: 'title'
47
+ },
48
+ [LAYOUT_LIST]: {
49
+ primaryField: 'title',
50
+ mediaField: 'preview'
51
+ }
52
+ };
53
+ const DEFAULT_VIEW = {
54
+ type: LAYOUT_TABLE,
55
+ search: '',
56
+ page: 1,
57
+ perPage: 20,
58
+ // All fields are visible by default, so it's
59
+ // better to keep track of the hidden ones.
60
+ hiddenFields: ['preview'],
61
+ layout: {},
62
+ filters: []
63
+ };
64
+ function normalizeSearchInput(input = '') {
65
+ return removeAccents(input.trim().toLowerCase());
66
+ }
67
+ function TemplateTitle({
68
+ item,
69
+ viewType
70
+ }) {
71
+ if (viewType === LAYOUT_LIST) {
72
+ return createElement(Fragment, null, decodeEntities(item.title?.rendered) || __('(no title)'));
73
+ }
74
+ return createElement(VStack, {
75
+ spacing: 1
76
+ }, createElement(View, {
77
+ as: "span",
78
+ className: "dataviews-view-grid__title-field"
79
+ }, createElement(Link, {
80
+ params: {
81
+ postId: item.id,
82
+ postType: item.type,
83
+ canvas: 'edit'
84
+ }
85
+ }, decodeEntities(item.title?.rendered) || __('(no title)'))));
86
+ }
87
+ function AuthorField({
88
+ item,
89
+ viewType
90
+ }) {
21
91
  const {
22
- records: templates
92
+ text,
93
+ icon,
94
+ imageUrl
95
+ } = useAddedBy(item.type, item.id);
96
+ const withIcon = viewType !== LAYOUT_LIST;
97
+ return createElement(HStack, {
98
+ alignment: "left",
99
+ spacing: 1
100
+ }, withIcon && imageUrl && createElement(AvatarImage, {
101
+ imageUrl: imageUrl
102
+ }), withIcon && !imageUrl && createElement("div", {
103
+ className: "edit-site-list-added-by__icon"
104
+ }, createElement(Icon, {
105
+ icon: icon
106
+ })), createElement("span", null, text));
107
+ }
108
+ function TemplatePreview({
109
+ content,
110
+ viewType
111
+ }) {
112
+ const settings = usePatternSettings();
113
+ const [backgroundColor = 'white'] = useGlobalStyle('color.background');
114
+ const blocks = useMemo(() => {
115
+ return parse(content);
116
+ }, [content]);
117
+ if (!blocks?.length) {
118
+ return null;
119
+ }
120
+ // Wrap everything in a block editor provider to ensure 'styles' that are needed
121
+ // for the previews are synced between the site editor store and the block editor store.
122
+ // Additionally we need to have the `__experimentalBlockPatterns` setting in order to
123
+ // render patterns inside the previews.
124
+ // TODO: Same approach is used in the patterns list and it becomes obvious that some of
125
+ // the block editor settings are needed in context where we don't have the block editor.
126
+ // Explore how we can solve this in a better way.
127
+ return createElement(ExperimentalBlockEditorProvider, {
128
+ settings: settings
129
+ }, createElement("div", {
130
+ className: `page-templates-preview-field is-viewtype-${viewType}`,
131
+ style: {
132
+ backgroundColor
133
+ }
134
+ }, createElement(BlockPreview, {
135
+ blocks: blocks
136
+ })));
137
+ }
138
+ export default function DataviewsTemplates() {
139
+ const [templateId, setTemplateId] = useState(null);
140
+ const [view, setView] = useState(DEFAULT_VIEW);
141
+ const {
142
+ records: allTemplates,
143
+ isResolving: isLoadingData
23
144
  } = useEntityRecords('postType', TEMPLATE_POST_TYPE, {
24
145
  per_page: -1
25
146
  });
26
- const columns = [{
147
+ const history = useHistory();
148
+ const onSelectionChange = useCallback(items => setTemplateId(items?.length === 1 ? items[0].id : null), [setTemplateId]);
149
+ const authors = useMemo(() => {
150
+ if (!allTemplates) {
151
+ return EMPTY_ARRAY;
152
+ }
153
+ const authorsSet = new Set();
154
+ allTemplates.forEach(template => {
155
+ authorsSet.add(template.author_text);
156
+ });
157
+ return Array.from(authorsSet).map(author => ({
158
+ value: author,
159
+ label: author
160
+ }));
161
+ }, [allTemplates]);
162
+ const fields = useMemo(() => [{
163
+ header: __('Preview'),
164
+ id: 'preview',
165
+ render: ({
166
+ item
167
+ }) => {
168
+ return createElement(TemplatePreview, {
169
+ content: item.content.raw,
170
+ viewType: view.type
171
+ });
172
+ },
173
+ minWidth: 120,
174
+ maxWidth: 120,
175
+ enableSorting: false
176
+ }, {
27
177
  header: __('Template'),
28
- cell: template => createElement(VStack, null, createElement(Heading, {
29
- as: "h3",
30
- level: 5
31
- }, createElement(Link, {
32
- params: {
33
- postId: template.id,
34
- postType: template.type,
35
- canvas: 'edit'
36
- }
37
- }, decodeEntities(template.title?.rendered || template.slug))), template.description && createElement(Text, {
38
- variant: "muted"
39
- }, decodeEntities(template.description))),
40
- maxWidth: 400
178
+ id: 'title',
179
+ getValue: ({
180
+ item
181
+ }) => item.title?.rendered,
182
+ render: ({
183
+ item
184
+ }) => createElement(TemplateTitle, {
185
+ item: item,
186
+ viewType: view.type
187
+ }),
188
+ maxWidth: 400,
189
+ enableHiding: false
41
190
  }, {
42
- header: __('Added by'),
43
- cell: template => createElement(AddedBy, {
44
- postType: template.type,
45
- postId: template.id
46
- })
191
+ header: __('Description'),
192
+ id: 'description',
193
+ getValue: ({
194
+ item
195
+ }) => item.description,
196
+ render: ({
197
+ item
198
+ }) => {
199
+ return item.description ? decodeEntities(item.description) : createElement(Fragment, null, createElement(Text, {
200
+ variant: "muted",
201
+ "aria-hidden": "true"
202
+ }, "\u2014"), createElement(VisuallyHidden, null, __('No description.')));
203
+ },
204
+ maxWidth: 200,
205
+ enableSorting: false
47
206
  }, {
48
- header: createElement(VisuallyHidden, null, __('Actions')),
49
- cell: template => createElement(TemplateActions, {
50
- postType: template.type,
51
- postId: template.id
52
- })
53
- }];
54
- return createElement(Page, {
207
+ header: __('Author'),
208
+ id: 'author',
209
+ getValue: ({
210
+ item
211
+ }) => item.author_text,
212
+ render: ({
213
+ item
214
+ }) => {
215
+ return createElement(AuthorField, {
216
+ viewType: view.type,
217
+ item: item
218
+ });
219
+ },
220
+ enableHiding: false,
221
+ type: ENUMERATION_TYPE,
222
+ elements: authors
223
+ }], [authors, view.type]);
224
+ const {
225
+ data,
226
+ paginationInfo
227
+ } = useMemo(() => {
228
+ if (!allTemplates) {
229
+ return {
230
+ data: EMPTY_ARRAY,
231
+ paginationInfo: {
232
+ totalItems: 0,
233
+ totalPages: 0
234
+ }
235
+ };
236
+ }
237
+ let filteredTemplates = [...allTemplates];
238
+ // Handle global search.
239
+ if (view.search) {
240
+ const normalizedSearch = normalizeSearchInput(view.search);
241
+ filteredTemplates = filteredTemplates.filter(item => {
242
+ const title = item.title?.rendered || item.slug;
243
+ return normalizeSearchInput(title).includes(normalizedSearch) || normalizeSearchInput(item.description).includes(normalizedSearch);
244
+ });
245
+ }
246
+
247
+ // Handle filters.
248
+ if (view.filters.length > 0) {
249
+ view.filters.forEach(filter => {
250
+ if (filter.field === 'author' && filter.operator === OPERATOR_IN && !!filter.value) {
251
+ filteredTemplates = filteredTemplates.filter(item => {
252
+ return item.author_text === filter.value;
253
+ });
254
+ } else if (filter.field === 'author' && filter.operator === OPERATOR_NOT_IN && !!filter.value) {
255
+ filteredTemplates = filteredTemplates.filter(item => {
256
+ return item.author_text !== filter.value;
257
+ });
258
+ }
259
+ });
260
+ }
261
+
262
+ // Handle sorting.
263
+ if (view.sort) {
264
+ filteredTemplates = sortByTextFields({
265
+ data: filteredTemplates,
266
+ view,
267
+ fields,
268
+ textFields: ['title']
269
+ });
270
+ }
271
+ // Handle pagination.
272
+ return getPaginationResults({
273
+ data: filteredTemplates,
274
+ view
275
+ });
276
+ }, [allTemplates, view, fields]);
277
+ const resetTemplateAction = useResetTemplateAction();
278
+ const actions = useMemo(() => [resetTemplateAction, deleteTemplateAction, renameTemplateAction, postRevisionsAction], [resetTemplateAction]);
279
+ const onChangeView = useCallback(newView => {
280
+ if (newView.type !== view.type) {
281
+ newView = {
282
+ ...newView,
283
+ layout: {
284
+ ...defaultConfigPerViewType[newView.type]
285
+ }
286
+ };
287
+ }
288
+ setView(newView);
289
+ }, [view.type, setView]);
290
+ return createElement(Fragment, null, createElement(Page, {
291
+ className: view.type === LAYOUT_LIST ? 'edit-site-template-pages-list-view' : null,
55
292
  title: __('Templates'),
56
293
  actions: createElement(AddNewTemplate, {
57
294
  templateType: TEMPLATE_POST_TYPE,
@@ -60,9 +297,48 @@ export default function PageTemplates() {
60
297
  variant: 'primary'
61
298
  }
62
299
  })
63
- }, templates && createElement(Table, {
64
- data: templates,
65
- columns: columns
66
- }));
300
+ }, createElement(DataViews, {
301
+ paginationInfo: paginationInfo,
302
+ fields: fields,
303
+ actions: actions,
304
+ data: data,
305
+ isLoading: isLoadingData,
306
+ view: view,
307
+ onChangeView: onChangeView,
308
+ onSelectionChange: onSelectionChange,
309
+ deferredRendering: !view.hiddenFields?.includes('preview')
310
+ })), view.type === LAYOUT_LIST && createElement(Page, null, createElement("div", {
311
+ className: "edit-site-template-pages-preview",
312
+ tabIndex: 0,
313
+ role: "button",
314
+ onKeyDown: event => {
315
+ const {
316
+ keyCode
317
+ } = event;
318
+ if (keyCode === ENTER || keyCode === SPACE) {
319
+ history.push({
320
+ postId: templateId,
321
+ postType: TEMPLATE_POST_TYPE,
322
+ canvas: 'edit'
323
+ });
324
+ }
325
+ },
326
+ onClick: () => history.push({
327
+ postId: templateId,
328
+ postType: TEMPLATE_POST_TYPE,
329
+ canvas: 'edit'
330
+ })
331
+ }, templateId !== null ? createElement(PostPreview, {
332
+ postId: templateId,
333
+ postType: TEMPLATE_POST_TYPE
334
+ }) : createElement("div", {
335
+ style: {
336
+ display: 'flex',
337
+ flexDirection: 'column',
338
+ justifyContent: 'center',
339
+ textAlign: 'center',
340
+ height: '100%'
341
+ }
342
+ }, createElement("p", null, __('Select a template to preview'))))));
67
343
  }
68
344
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"names":["VisuallyHidden","__experimentalHeading","Heading","__experimentalText","Text","__experimentalVStack","VStack","__","useEntityRecords","decodeEntities","Page","Table","Link","AddedBy","TemplateActions","AddNewTemplate","TEMPLATE_POST_TYPE","PageTemplates","records","templates","per_page","columns","header","cell","template","createElement","as","level","params","postId","id","postType","type","canvas","title","rendered","slug","description","variant","maxWidth","actions","templateType","showIcon","toggleProps","data"],"sources":["@wordpress/edit-site/src/components/page-templates/index.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport {\n\tVisuallyHidden,\n\t__experimentalHeading as Heading,\n\t__experimentalText as Text,\n\t__experimentalVStack as VStack,\n} from '@wordpress/components';\nimport { __ } from '@wordpress/i18n';\nimport { useEntityRecords } from '@wordpress/core-data';\nimport { decodeEntities } from '@wordpress/html-entities';\n\n/**\n * Internal dependencies\n */\nimport Page from '../page';\nimport Table from '../table';\nimport Link from '../routes/link';\nimport AddedBy from '../list/added-by';\nimport TemplateActions from '../template-actions';\nimport AddNewTemplate from '../add-new-template';\nimport { TEMPLATE_POST_TYPE } from '../../utils/constants';\n\nexport default function PageTemplates() {\n\tconst { records: templates } = useEntityRecords(\n\t\t'postType',\n\t\tTEMPLATE_POST_TYPE,\n\t\t{\n\t\t\tper_page: -1,\n\t\t}\n\t);\n\n\tconst columns = [\n\t\t{\n\t\t\theader: __( 'Template' ),\n\t\t\tcell: ( template ) => (\n\t\t\t\t<VStack>\n\t\t\t\t\t<Heading as=\"h3\" level={ 5 }>\n\t\t\t\t\t\t<Link\n\t\t\t\t\t\t\tparams={ {\n\t\t\t\t\t\t\t\tpostId: template.id,\n\t\t\t\t\t\t\t\tpostType: template.type,\n\t\t\t\t\t\t\t\tcanvas: 'edit',\n\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ decodeEntities(\n\t\t\t\t\t\t\t\ttemplate.title?.rendered || template.slug\n\t\t\t\t\t\t\t) }\n\t\t\t\t\t\t</Link>\n\t\t\t\t\t</Heading>\n\t\t\t\t\t{ template.description && (\n\t\t\t\t\t\t<Text variant=\"muted\">\n\t\t\t\t\t\t\t{ decodeEntities( template.description ) }\n\t\t\t\t\t\t</Text>\n\t\t\t\t\t) }\n\t\t\t\t</VStack>\n\t\t\t),\n\t\t\tmaxWidth: 400,\n\t\t},\n\t\t{\n\t\t\theader: __( 'Added by' ),\n\t\t\tcell: ( template ) => (\n\t\t\t\t<AddedBy postType={ template.type } postId={ template.id } />\n\t\t\t),\n\t\t},\n\t\t{\n\t\t\theader: <VisuallyHidden>{ __( 'Actions' ) }</VisuallyHidden>,\n\t\t\tcell: ( template ) => (\n\t\t\t\t<TemplateActions\n\t\t\t\t\tpostType={ template.type }\n\t\t\t\t\tpostId={ template.id }\n\t\t\t\t/>\n\t\t\t),\n\t\t},\n\t];\n\n\treturn (\n\t\t<Page\n\t\t\ttitle={ __( 'Templates' ) }\n\t\t\tactions={\n\t\t\t\t<AddNewTemplate\n\t\t\t\t\ttemplateType={ TEMPLATE_POST_TYPE }\n\t\t\t\t\tshowIcon={ false }\n\t\t\t\t\ttoggleProps={ { variant: 'primary' } }\n\t\t\t\t/>\n\t\t\t}\n\t\t>\n\t\t\t{ templates && <Table data={ templates } columns={ columns } /> }\n\t\t</Page>\n\t);\n}\n"],"mappings":";AAAA;AACA;AACA;AACA,SACCA,cAAc,EACdC,qBAAqB,IAAIC,OAAO,EAChCC,kBAAkB,IAAIC,IAAI,EAC1BC,oBAAoB,IAAIC,MAAM,QACxB,uBAAuB;AAC9B,SAASC,EAAE,QAAQ,iBAAiB;AACpC,SAASC,gBAAgB,QAAQ,sBAAsB;AACvD,SAASC,cAAc,QAAQ,0BAA0B;;AAEzD;AACA;AACA;AACA,OAAOC,IAAI,MAAM,SAAS;AAC1B,OAAOC,KAAK,MAAM,UAAU;AAC5B,OAAOC,IAAI,MAAM,gBAAgB;AACjC,OAAOC,OAAO,MAAM,kBAAkB;AACtC,OAAOC,eAAe,MAAM,qBAAqB;AACjD,OAAOC,cAAc,MAAM,qBAAqB;AAChD,SAASC,kBAAkB,QAAQ,uBAAuB;AAE1D,eAAe,SAASC,aAAaA,CAAA,EAAG;EACvC,MAAM;IAAEC,OAAO,EAAEC;EAAU,CAAC,GAAGX,gBAAgB,CAC9C,UAAU,EACVQ,kBAAkB,EAClB;IACCI,QAAQ,EAAE,CAAC;EACZ,CACD,CAAC;EAED,MAAMC,OAAO,GAAG,CACf;IACCC,MAAM,EAAEf,EAAE,CAAE,UAAW,CAAC;IACxBgB,IAAI,EAAIC,QAAQ,IACfC,aAAA,CAACnB,MAAM,QACNmB,aAAA,CAACvB,OAAO;MAACwB,EAAE,EAAC,IAAI;MAACC,KAAK,EAAG;IAAG,GAC3BF,aAAA,CAACb,IAAI;MACJgB,MAAM,EAAG;QACRC,MAAM,EAAEL,QAAQ,CAACM,EAAE;QACnBC,QAAQ,EAAEP,QAAQ,CAACQ,IAAI;QACvBC,MAAM,EAAE;MACT;IAAG,GAEDxB,cAAc,CACfe,QAAQ,CAACU,KAAK,EAAEC,QAAQ,IAAIX,QAAQ,CAACY,IACtC,CACK,CACE,CAAC,EACRZ,QAAQ,CAACa,WAAW,IACrBZ,aAAA,CAACrB,IAAI;MAACkC,OAAO,EAAC;IAAO,GAClB7B,cAAc,CAAEe,QAAQ,CAACa,WAAY,CAClC,CAEA,CACR;IACDE,QAAQ,EAAE;EACX,CAAC,EACD;IACCjB,MAAM,EAAEf,EAAE,CAAE,UAAW,CAAC;IACxBgB,IAAI,EAAIC,QAAQ,IACfC,aAAA,CAACZ,OAAO;MAACkB,QAAQ,EAAGP,QAAQ,CAACQ,IAAM;MAACH,MAAM,EAAGL,QAAQ,CAACM;IAAI,CAAE;EAE9D,CAAC,EACD;IACCR,MAAM,EAAEG,aAAA,CAACzB,cAAc,QAAGO,EAAE,CAAE,SAAU,CAAmB,CAAC;IAC5DgB,IAAI,EAAIC,QAAQ,IACfC,aAAA,CAACX,eAAe;MACfiB,QAAQ,EAAGP,QAAQ,CAACQ,IAAM;MAC1BH,MAAM,EAAGL,QAAQ,CAACM;IAAI,CACtB;EAEH,CAAC,CACD;EAED,OACCL,aAAA,CAACf,IAAI;IACJwB,KAAK,EAAG3B,EAAE,CAAE,WAAY,CAAG;IAC3BiC,OAAO,EACNf,aAAA,CAACV,cAAc;MACd0B,YAAY,EAAGzB,kBAAoB;MACnC0B,QAAQ,EAAG,KAAO;MAClBC,WAAW,EAAG;QAAEL,OAAO,EAAE;MAAU;IAAG,CACtC;EACD,GAECnB,SAAS,IAAIM,aAAA,CAACd,KAAK;IAACiC,IAAI,EAAGzB,SAAW;IAACE,OAAO,EAAGA;EAAS,CAAE,CACzD,CAAC;AAET"}
1
+ {"version":3,"names":["removeAccents","Icon","__experimentalView","View","__experimentalText","Text","__experimentalHStack","HStack","__experimentalVStack","VStack","VisuallyHidden","__","useState","useMemo","useCallback","useEntityRecords","decodeEntities","ENTER","SPACE","parse","BlockPreview","privateApis","blockEditorPrivateApis","DataViews","sortByTextFields","getPaginationResults","routerPrivateApis","Page","Link","AddNewTemplate","useAddedBy","AvatarImage","TEMPLATE_POST_TYPE","ENUMERATION_TYPE","OPERATOR_IN","OPERATOR_NOT_IN","LAYOUT_GRID","LAYOUT_TABLE","LAYOUT_LIST","useResetTemplateAction","deleteTemplateAction","renameTemplateAction","postRevisionsAction","usePatternSettings","unlock","PostPreview","ExperimentalBlockEditorProvider","useGlobalStyle","useHistory","EMPTY_ARRAY","defaultConfigPerViewType","mediaField","primaryField","DEFAULT_VIEW","type","search","page","perPage","hiddenFields","layout","filters","normalizeSearchInput","input","trim","toLowerCase","TemplateTitle","item","viewType","createElement","Fragment","title","rendered","spacing","as","className","params","postId","id","postType","canvas","AuthorField","text","icon","imageUrl","withIcon","alignment","TemplatePreview","content","settings","backgroundColor","blocks","length","style","DataviewsTemplates","templateId","setTemplateId","view","setView","records","allTemplates","isResolving","isLoadingData","per_page","history","onSelectionChange","items","authors","authorsSet","Set","forEach","template","add","author_text","Array","from","map","author","value","label","fields","header","render","raw","minWidth","maxWidth","enableSorting","getValue","enableHiding","description","variant","elements","data","paginationInfo","totalItems","totalPages","filteredTemplates","normalizedSearch","filter","slug","includes","field","operator","sort","textFields","resetTemplateAction","actions","onChangeView","newView","templateType","showIcon","toggleProps","isLoading","deferredRendering","tabIndex","role","onKeyDown","event","keyCode","push","onClick","display","flexDirection","justifyContent","textAlign","height"],"sources":["@wordpress/edit-site/src/components/page-templates/index.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport removeAccents from 'remove-accents';\n\n/**\n * WordPress dependencies\n */\nimport {\n\tIcon,\n\t__experimentalView as View,\n\t__experimentalText as Text,\n\t__experimentalHStack as HStack,\n\t__experimentalVStack as VStack,\n\tVisuallyHidden,\n} from '@wordpress/components';\nimport { __ } from '@wordpress/i18n';\nimport { useState, useMemo, useCallback } from '@wordpress/element';\nimport { useEntityRecords } from '@wordpress/core-data';\nimport { decodeEntities } from '@wordpress/html-entities';\nimport { ENTER, SPACE } from '@wordpress/keycodes';\nimport { parse } from '@wordpress/blocks';\nimport {\n\tBlockPreview,\n\tprivateApis as blockEditorPrivateApis,\n} from '@wordpress/block-editor';\nimport {\n\tDataViews,\n\tsortByTextFields,\n\tgetPaginationResults,\n} from '@wordpress/dataviews';\nimport { privateApis as routerPrivateApis } from '@wordpress/router';\n\n/**\n * Internal dependencies\n */\nimport Page from '../page';\nimport Link from '../routes/link';\nimport AddNewTemplate from '../add-new-template';\nimport { useAddedBy, AvatarImage } from '../list/added-by';\nimport {\n\tTEMPLATE_POST_TYPE,\n\tENUMERATION_TYPE,\n\tOPERATOR_IN,\n\tOPERATOR_NOT_IN,\n\tLAYOUT_GRID,\n\tLAYOUT_TABLE,\n\tLAYOUT_LIST,\n} from '../../utils/constants';\nimport {\n\tuseResetTemplateAction,\n\tdeleteTemplateAction,\n\trenameTemplateAction,\n} from './template-actions';\nimport { postRevisionsAction } from '../actions';\nimport usePatternSettings from '../page-patterns/use-pattern-settings';\nimport { unlock } from '../../lock-unlock';\nimport PostPreview from '../post-preview';\n\nconst { ExperimentalBlockEditorProvider, useGlobalStyle } = unlock(\n\tblockEditorPrivateApis\n);\nconst { useHistory } = unlock( routerPrivateApis );\n\nconst EMPTY_ARRAY = [];\n\nconst defaultConfigPerViewType = {\n\t[ LAYOUT_TABLE ]: {},\n\t[ LAYOUT_GRID ]: {\n\t\tmediaField: 'preview',\n\t\tprimaryField: 'title',\n\t},\n\t[ LAYOUT_LIST ]: {\n\t\tprimaryField: 'title',\n\t\tmediaField: 'preview',\n\t},\n};\n\nconst DEFAULT_VIEW = {\n\ttype: LAYOUT_TABLE,\n\tsearch: '',\n\tpage: 1,\n\tperPage: 20,\n\t// All fields are visible by default, so it's\n\t// better to keep track of the hidden ones.\n\thiddenFields: [ 'preview' ],\n\tlayout: {},\n\tfilters: [],\n};\n\nfunction normalizeSearchInput( input = '' ) {\n\treturn removeAccents( input.trim().toLowerCase() );\n}\n\nfunction TemplateTitle( { item, viewType } ) {\n\tif ( viewType === LAYOUT_LIST ) {\n\t\treturn (\n\t\t\t<>\n\t\t\t\t{ decodeEntities( item.title?.rendered ) || __( '(no title)' ) }\n\t\t\t</>\n\t\t);\n\t}\n\n\treturn (\n\t\t<VStack spacing={ 1 }>\n\t\t\t<View as=\"span\" className=\"dataviews-view-grid__title-field\">\n\t\t\t\t<Link\n\t\t\t\t\tparams={ {\n\t\t\t\t\t\tpostId: item.id,\n\t\t\t\t\t\tpostType: item.type,\n\t\t\t\t\t\tcanvas: 'edit',\n\t\t\t\t\t} }\n\t\t\t\t>\n\t\t\t\t\t{ decodeEntities( item.title?.rendered ) ||\n\t\t\t\t\t\t__( '(no title)' ) }\n\t\t\t\t</Link>\n\t\t\t</View>\n\t\t</VStack>\n\t);\n}\n\nfunction AuthorField( { item, viewType } ) {\n\tconst { text, icon, imageUrl } = useAddedBy( item.type, item.id );\n\tconst withIcon = viewType !== LAYOUT_LIST;\n\n\treturn (\n\t\t<HStack alignment=\"left\" spacing={ 1 }>\n\t\t\t{ withIcon && imageUrl && <AvatarImage imageUrl={ imageUrl } /> }\n\t\t\t{ withIcon && ! imageUrl && (\n\t\t\t\t<div className=\"edit-site-list-added-by__icon\">\n\t\t\t\t\t<Icon icon={ icon } />\n\t\t\t\t</div>\n\t\t\t) }\n\t\t\t<span>{ text }</span>\n\t\t</HStack>\n\t);\n}\n\nfunction TemplatePreview( { content, viewType } ) {\n\tconst settings = usePatternSettings();\n\tconst [ backgroundColor = 'white' ] = useGlobalStyle( 'color.background' );\n\tconst blocks = useMemo( () => {\n\t\treturn parse( content );\n\t}, [ content ] );\n\tif ( ! blocks?.length ) {\n\t\treturn null;\n\t}\n\t// Wrap everything in a block editor provider to ensure 'styles' that are needed\n\t// for the previews are synced between the site editor store and the block editor store.\n\t// Additionally we need to have the `__experimentalBlockPatterns` setting in order to\n\t// render patterns inside the previews.\n\t// TODO: Same approach is used in the patterns list and it becomes obvious that some of\n\t// the block editor settings are needed in context where we don't have the block editor.\n\t// Explore how we can solve this in a better way.\n\treturn (\n\t\t<ExperimentalBlockEditorProvider settings={ settings }>\n\t\t\t<div\n\t\t\t\tclassName={ `page-templates-preview-field is-viewtype-${ viewType }` }\n\t\t\t\tstyle={ { backgroundColor } }\n\t\t\t>\n\t\t\t\t<BlockPreview blocks={ blocks } />\n\t\t\t</div>\n\t\t</ExperimentalBlockEditorProvider>\n\t);\n}\n\nexport default function DataviewsTemplates() {\n\tconst [ templateId, setTemplateId ] = useState( null );\n\tconst [ view, setView ] = useState( DEFAULT_VIEW );\n\tconst { records: allTemplates, isResolving: isLoadingData } =\n\t\tuseEntityRecords( 'postType', TEMPLATE_POST_TYPE, {\n\t\t\tper_page: -1,\n\t\t} );\n\tconst history = useHistory();\n\n\tconst onSelectionChange = useCallback(\n\t\t( items ) =>\n\t\t\tsetTemplateId( items?.length === 1 ? items[ 0 ].id : null ),\n\t\t[ setTemplateId ]\n\t);\n\n\tconst authors = useMemo( () => {\n\t\tif ( ! allTemplates ) {\n\t\t\treturn EMPTY_ARRAY;\n\t\t}\n\t\tconst authorsSet = new Set();\n\t\tallTemplates.forEach( ( template ) => {\n\t\t\tauthorsSet.add( template.author_text );\n\t\t} );\n\t\treturn Array.from( authorsSet ).map( ( author ) => ( {\n\t\t\tvalue: author,\n\t\t\tlabel: author,\n\t\t} ) );\n\t}, [ allTemplates ] );\n\n\tconst fields = useMemo(\n\t\t() => [\n\t\t\t{\n\t\t\t\theader: __( 'Preview' ),\n\t\t\t\tid: 'preview',\n\t\t\t\trender: ( { item } ) => {\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<TemplatePreview\n\t\t\t\t\t\t\tcontent={ item.content.raw }\n\t\t\t\t\t\t\tviewType={ view.type }\n\t\t\t\t\t\t/>\n\t\t\t\t\t);\n\t\t\t\t},\n\t\t\t\tminWidth: 120,\n\t\t\t\tmaxWidth: 120,\n\t\t\t\tenableSorting: false,\n\t\t\t},\n\t\t\t{\n\t\t\t\theader: __( 'Template' ),\n\t\t\t\tid: 'title',\n\t\t\t\tgetValue: ( { item } ) => item.title?.rendered,\n\t\t\t\trender: ( { item } ) => (\n\t\t\t\t\t<TemplateTitle item={ item } viewType={ view.type } />\n\t\t\t\t),\n\t\t\t\tmaxWidth: 400,\n\t\t\t\tenableHiding: false,\n\t\t\t},\n\t\t\t{\n\t\t\t\theader: __( 'Description' ),\n\t\t\t\tid: 'description',\n\t\t\t\tgetValue: ( { item } ) => item.description,\n\t\t\t\trender: ( { item } ) => {\n\t\t\t\t\treturn item.description ? (\n\t\t\t\t\t\tdecodeEntities( item.description )\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<>\n\t\t\t\t\t\t\t<Text variant=\"muted\" aria-hidden=\"true\">\n\t\t\t\t\t\t\t\t&#8212;\n\t\t\t\t\t\t\t</Text>\n\t\t\t\t\t\t\t<VisuallyHidden>\n\t\t\t\t\t\t\t\t{ __( 'No description.' ) }\n\t\t\t\t\t\t\t</VisuallyHidden>\n\t\t\t\t\t\t</>\n\t\t\t\t\t);\n\t\t\t\t},\n\t\t\t\tmaxWidth: 200,\n\t\t\t\tenableSorting: false,\n\t\t\t},\n\t\t\t{\n\t\t\t\theader: __( 'Author' ),\n\t\t\t\tid: 'author',\n\t\t\t\tgetValue: ( { item } ) => item.author_text,\n\t\t\t\trender: ( { item } ) => {\n\t\t\t\t\treturn <AuthorField viewType={ view.type } item={ item } />;\n\t\t\t\t},\n\t\t\t\tenableHiding: false,\n\t\t\t\ttype: ENUMERATION_TYPE,\n\t\t\t\telements: authors,\n\t\t\t},\n\t\t],\n\t\t[ authors, view.type ]\n\t);\n\n\tconst { data, paginationInfo } = useMemo( () => {\n\t\tif ( ! allTemplates ) {\n\t\t\treturn {\n\t\t\t\tdata: EMPTY_ARRAY,\n\t\t\t\tpaginationInfo: { totalItems: 0, totalPages: 0 },\n\t\t\t};\n\t\t}\n\t\tlet filteredTemplates = [ ...allTemplates ];\n\t\t// Handle global search.\n\t\tif ( view.search ) {\n\t\t\tconst normalizedSearch = normalizeSearchInput( view.search );\n\t\t\tfilteredTemplates = filteredTemplates.filter( ( item ) => {\n\t\t\t\tconst title = item.title?.rendered || item.slug;\n\t\t\t\treturn (\n\t\t\t\t\tnormalizeSearchInput( title ).includes(\n\t\t\t\t\t\tnormalizedSearch\n\t\t\t\t\t) ||\n\t\t\t\t\tnormalizeSearchInput( item.description ).includes(\n\t\t\t\t\t\tnormalizedSearch\n\t\t\t\t\t)\n\t\t\t\t);\n\t\t\t} );\n\t\t}\n\n\t\t// Handle filters.\n\t\tif ( view.filters.length > 0 ) {\n\t\t\tview.filters.forEach( ( filter ) => {\n\t\t\t\tif (\n\t\t\t\t\tfilter.field === 'author' &&\n\t\t\t\t\tfilter.operator === OPERATOR_IN &&\n\t\t\t\t\t!! filter.value\n\t\t\t\t) {\n\t\t\t\t\tfilteredTemplates = filteredTemplates.filter( ( item ) => {\n\t\t\t\t\t\treturn item.author_text === filter.value;\n\t\t\t\t\t} );\n\t\t\t\t} else if (\n\t\t\t\t\tfilter.field === 'author' &&\n\t\t\t\t\tfilter.operator === OPERATOR_NOT_IN &&\n\t\t\t\t\t!! filter.value\n\t\t\t\t) {\n\t\t\t\t\tfilteredTemplates = filteredTemplates.filter( ( item ) => {\n\t\t\t\t\t\treturn item.author_text !== filter.value;\n\t\t\t\t\t} );\n\t\t\t\t}\n\t\t\t} );\n\t\t}\n\n\t\t// Handle sorting.\n\t\tif ( view.sort ) {\n\t\t\tfilteredTemplates = sortByTextFields( {\n\t\t\t\tdata: filteredTemplates,\n\t\t\t\tview,\n\t\t\t\tfields,\n\t\t\t\ttextFields: [ 'title' ],\n\t\t\t} );\n\t\t}\n\t\t// Handle pagination.\n\t\treturn getPaginationResults( {\n\t\t\tdata: filteredTemplates,\n\t\t\tview,\n\t\t} );\n\t}, [ allTemplates, view, fields ] );\n\n\tconst resetTemplateAction = useResetTemplateAction();\n\tconst actions = useMemo(\n\t\t() => [\n\t\t\tresetTemplateAction,\n\t\t\tdeleteTemplateAction,\n\t\t\trenameTemplateAction,\n\t\t\tpostRevisionsAction,\n\t\t],\n\t\t[ resetTemplateAction ]\n\t);\n\n\tconst onChangeView = useCallback(\n\t\t( newView ) => {\n\t\t\tif ( newView.type !== view.type ) {\n\t\t\t\tnewView = {\n\t\t\t\t\t...newView,\n\t\t\t\t\tlayout: {\n\t\t\t\t\t\t...defaultConfigPerViewType[ newView.type ],\n\t\t\t\t\t},\n\t\t\t\t};\n\t\t\t}\n\n\t\t\tsetView( newView );\n\t\t},\n\t\t[ view.type, setView ]\n\t);\n\n\treturn (\n\t\t<>\n\t\t\t<Page\n\t\t\t\tclassName={\n\t\t\t\t\tview.type === LAYOUT_LIST\n\t\t\t\t\t\t? 'edit-site-template-pages-list-view'\n\t\t\t\t\t\t: null\n\t\t\t\t}\n\t\t\t\ttitle={ __( 'Templates' ) }\n\t\t\t\tactions={\n\t\t\t\t\t<AddNewTemplate\n\t\t\t\t\t\ttemplateType={ TEMPLATE_POST_TYPE }\n\t\t\t\t\t\tshowIcon={ false }\n\t\t\t\t\t\ttoggleProps={ { variant: 'primary' } }\n\t\t\t\t\t/>\n\t\t\t\t}\n\t\t\t>\n\t\t\t\t<DataViews\n\t\t\t\t\tpaginationInfo={ paginationInfo }\n\t\t\t\t\tfields={ fields }\n\t\t\t\t\tactions={ actions }\n\t\t\t\t\tdata={ data }\n\t\t\t\t\tisLoading={ isLoadingData }\n\t\t\t\t\tview={ view }\n\t\t\t\t\tonChangeView={ onChangeView }\n\t\t\t\t\tonSelectionChange={ onSelectionChange }\n\t\t\t\t\tdeferredRendering={\n\t\t\t\t\t\t! view.hiddenFields?.includes( 'preview' )\n\t\t\t\t\t}\n\t\t\t\t/>\n\t\t\t</Page>\n\t\t\t{ view.type === LAYOUT_LIST && (\n\t\t\t\t<Page>\n\t\t\t\t\t<div\n\t\t\t\t\t\tclassName=\"edit-site-template-pages-preview\"\n\t\t\t\t\t\ttabIndex={ 0 }\n\t\t\t\t\t\trole=\"button\"\n\t\t\t\t\t\tonKeyDown={ ( event ) => {\n\t\t\t\t\t\t\tconst { keyCode } = event;\n\t\t\t\t\t\t\tif ( keyCode === ENTER || keyCode === SPACE ) {\n\t\t\t\t\t\t\t\thistory.push( {\n\t\t\t\t\t\t\t\t\tpostId: templateId,\n\t\t\t\t\t\t\t\t\tpostType: TEMPLATE_POST_TYPE,\n\t\t\t\t\t\t\t\t\tcanvas: 'edit',\n\t\t\t\t\t\t\t\t} );\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t} }\n\t\t\t\t\t\tonClick={ () =>\n\t\t\t\t\t\t\thistory.push( {\n\t\t\t\t\t\t\t\tpostId: templateId,\n\t\t\t\t\t\t\t\tpostType: TEMPLATE_POST_TYPE,\n\t\t\t\t\t\t\t\tcanvas: 'edit',\n\t\t\t\t\t\t\t} )\n\t\t\t\t\t\t}\n\t\t\t\t\t>\n\t\t\t\t\t\t{ templateId !== null ? (\n\t\t\t\t\t\t\t<PostPreview\n\t\t\t\t\t\t\t\tpostId={ templateId }\n\t\t\t\t\t\t\t\tpostType={ TEMPLATE_POST_TYPE }\n\t\t\t\t\t\t\t/>\n\t\t\t\t\t\t) : (\n\t\t\t\t\t\t\t<div\n\t\t\t\t\t\t\t\tstyle={ {\n\t\t\t\t\t\t\t\t\tdisplay: 'flex',\n\t\t\t\t\t\t\t\t\tflexDirection: 'column',\n\t\t\t\t\t\t\t\t\tjustifyContent: 'center',\n\t\t\t\t\t\t\t\t\ttextAlign: 'center',\n\t\t\t\t\t\t\t\t\theight: '100%',\n\t\t\t\t\t\t\t\t} }\n\t\t\t\t\t\t\t>\n\t\t\t\t\t\t\t\t<p>{ __( 'Select a template to preview' ) }</p>\n\t\t\t\t\t\t\t</div>\n\t\t\t\t\t\t) }\n\t\t\t\t\t</div>\n\t\t\t\t</Page>\n\t\t\t) }\n\t\t</>\n\t);\n}\n"],"mappings":"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"}
@@ -1,4 +1,9 @@
1
1
  import { createElement } from "react";
2
+ /**
3
+ * External dependencies
4
+ */
5
+ import classnames from 'classnames';
6
+
2
7
  /**
3
8
  * WordPress dependencies
4
9
  */
@@ -8,15 +13,22 @@ export default function Pagination({
8
13
  currentPage,
9
14
  numPages,
10
15
  changePage,
11
- totalItems
16
+ totalItems,
17
+ className,
18
+ disabled = false,
19
+ buttonVariant = 'tertiary',
20
+ label = __('Pagination Navigation')
12
21
  }) {
13
22
  return createElement(HStack, {
14
23
  expanded: false,
24
+ as: "nav",
25
+ "aria-label": label,
15
26
  spacing: 3,
16
27
  justify: "flex-start",
17
- className: "edit-site-patterns__grid-pagination"
28
+ className: classnames('edit-site-pagination', className)
18
29
  }, createElement(Text, {
19
- variant: "muted"
30
+ variant: "muted",
31
+ className: "edit-site-pagination__total"
20
32
  },
21
33
  // translators: %s: Total number of patterns.
22
34
  sprintf(
@@ -25,14 +37,14 @@ export default function Pagination({
25
37
  expanded: false,
26
38
  spacing: 1
27
39
  }, createElement(Button, {
28
- variant: "tertiary",
40
+ variant: buttonVariant,
29
41
  onClick: () => changePage(1),
30
- disabled: currentPage === 1,
42
+ disabled: disabled || currentPage === 1,
31
43
  "aria-label": __('First page')
32
44
  }, "\xAB"), createElement(Button, {
33
- variant: "tertiary",
45
+ variant: buttonVariant,
34
46
  onClick: () => changePage(currentPage - 1),
35
- disabled: currentPage === 1,
47
+ disabled: disabled || currentPage === 1,
36
48
  "aria-label": __('Previous page')
37
49
  }, "\u2039")), createElement(Text, {
38
50
  variant: "muted"
@@ -42,15 +54,15 @@ export default function Pagination({
42
54
  expanded: false,
43
55
  spacing: 1
44
56
  }, createElement(Button, {
45
- variant: "tertiary",
57
+ variant: buttonVariant,
46
58
  onClick: () => changePage(currentPage + 1),
47
- disabled: currentPage === numPages,
59
+ disabled: disabled || currentPage === numPages,
48
60
  "aria-label": __('Next page')
49
61
  }, "\u203A"), createElement(Button, {
50
- variant: "tertiary",
62
+ variant: buttonVariant,
51
63
  onClick: () => changePage(numPages),
52
- disabled: currentPage === numPages,
64
+ disabled: disabled || currentPage === numPages,
53
65
  "aria-label": __('Last page')
54
66
  }, "\xBB")));
55
67
  }
56
- //# sourceMappingURL=pagination.js.map
68
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["classnames","__experimentalHStack","HStack","__experimentalText","Text","Button","__","_x","_n","sprintf","Pagination","currentPage","numPages","changePage","totalItems","className","disabled","buttonVariant","label","createElement","expanded","as","spacing","justify","variant","onClick"],"sources":["@wordpress/edit-site/src/components/pagination/index.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport classnames from 'classnames';\n\n/**\n * WordPress dependencies\n */\nimport {\n\t__experimentalHStack as HStack,\n\t__experimentalText as Text,\n\tButton,\n} from '@wordpress/components';\nimport { __, _x, _n, sprintf } from '@wordpress/i18n';\n\nexport default function Pagination( {\n\tcurrentPage,\n\tnumPages,\n\tchangePage,\n\ttotalItems,\n\tclassName,\n\tdisabled = false,\n\tbuttonVariant = 'tertiary',\n\tlabel = __( 'Pagination Navigation' ),\n} ) {\n\treturn (\n\t\t<HStack\n\t\t\texpanded={ false }\n\t\t\tas=\"nav\"\n\t\t\taria-label={ label }\n\t\t\tspacing={ 3 }\n\t\t\tjustify=\"flex-start\"\n\t\t\tclassName={ classnames( 'edit-site-pagination', className ) }\n\t\t>\n\t\t\t<Text variant=\"muted\" className=\"edit-site-pagination__total\">\n\t\t\t\t{\n\t\t\t\t\t// translators: %s: Total number of patterns.\n\t\t\t\t\tsprintf(\n\t\t\t\t\t\t// translators: %s: Total number of patterns.\n\t\t\t\t\t\t_n( '%s item', '%s items', totalItems ),\n\t\t\t\t\t\ttotalItems\n\t\t\t\t\t)\n\t\t\t\t}\n\t\t\t</Text>\n\t\t\t<HStack expanded={ false } spacing={ 1 }>\n\t\t\t\t<Button\n\t\t\t\t\tvariant={ buttonVariant }\n\t\t\t\t\tonClick={ () => changePage( 1 ) }\n\t\t\t\t\tdisabled={ disabled || currentPage === 1 }\n\t\t\t\t\taria-label={ __( 'First page' ) }\n\t\t\t\t>\n\t\t\t\t\t«\n\t\t\t\t</Button>\n\t\t\t\t<Button\n\t\t\t\t\tvariant={ buttonVariant }\n\t\t\t\t\tonClick={ () => changePage( currentPage - 1 ) }\n\t\t\t\t\tdisabled={ disabled || currentPage === 1 }\n\t\t\t\t\taria-label={ __( 'Previous page' ) }\n\t\t\t\t>\n\t\t\t\t\t‹\n\t\t\t\t</Button>\n\t\t\t</HStack>\n\t\t\t<Text variant=\"muted\">\n\t\t\t\t{ sprintf(\n\t\t\t\t\t// translators: %1$s: Current page number, %2$s: Total number of pages.\n\t\t\t\t\t_x( '%1$s of %2$s', 'paging' ),\n\t\t\t\t\tcurrentPage,\n\t\t\t\t\tnumPages\n\t\t\t\t) }\n\t\t\t</Text>\n\t\t\t<HStack expanded={ false } spacing={ 1 }>\n\t\t\t\t<Button\n\t\t\t\t\tvariant={ buttonVariant }\n\t\t\t\t\tonClick={ () => changePage( currentPage + 1 ) }\n\t\t\t\t\tdisabled={ disabled || currentPage === numPages }\n\t\t\t\t\taria-label={ __( 'Next page' ) }\n\t\t\t\t>\n\t\t\t\t\t›\n\t\t\t\t</Button>\n\t\t\t\t<Button\n\t\t\t\t\tvariant={ buttonVariant }\n\t\t\t\t\tonClick={ () => changePage( numPages ) }\n\t\t\t\t\tdisabled={ disabled || currentPage === numPages }\n\t\t\t\t\taria-label={ __( 'Last page' ) }\n\t\t\t\t>\n\t\t\t\t\t»\n\t\t\t\t</Button>\n\t\t\t</HStack>\n\t\t</HStack>\n\t);\n}\n"],"mappings":";AAAA;AACA;AACA;AACA,OAAOA,UAAU,MAAM,YAAY;;AAEnC;AACA;AACA;AACA,SACCC,oBAAoB,IAAIC,MAAM,EAC9BC,kBAAkB,IAAIC,IAAI,EAC1BC,MAAM,QACA,uBAAuB;AAC9B,SAASC,EAAE,EAAEC,EAAE,EAAEC,EAAE,EAAEC,OAAO,QAAQ,iBAAiB;AAErD,eAAe,SAASC,UAAUA,CAAE;EACnCC,WAAW;EACXC,QAAQ;EACRC,UAAU;EACVC,UAAU;EACVC,SAAS;EACTC,QAAQ,GAAG,KAAK;EAChBC,aAAa,GAAG,UAAU;EAC1BC,KAAK,GAAGZ,EAAE,CAAE,uBAAwB;AACrC,CAAC,EAAG;EACH,OACCa,aAAA,CAACjB,MAAM;IACNkB,QAAQ,EAAG,KAAO;IAClBC,EAAE,EAAC,KAAK;IACR,cAAaH,KAAO;IACpBI,OAAO,EAAG,CAAG;IACbC,OAAO,EAAC,YAAY;IACpBR,SAAS,EAAGf,UAAU,CAAE,sBAAsB,EAAEe,SAAU;EAAG,GAE7DI,aAAA,CAACf,IAAI;IAACoB,OAAO,EAAC,OAAO;IAACT,SAAS,EAAC;EAA6B;EAE3D;EACAN,OAAO;EACN;EACAD,EAAE,CAAE,SAAS,EAAE,UAAU,EAAEM,UAAW,CAAC,EACvCA,UACD,CAEI,CAAC,EACPK,aAAA,CAACjB,MAAM;IAACkB,QAAQ,EAAG,KAAO;IAACE,OAAO,EAAG;EAAG,GACvCH,aAAA,CAACd,MAAM;IACNmB,OAAO,EAAGP,aAAe;IACzBQ,OAAO,EAAGA,CAAA,KAAMZ,UAAU,CAAE,CAAE,CAAG;IACjCG,QAAQ,EAAGA,QAAQ,IAAIL,WAAW,KAAK,CAAG;IAC1C,cAAaL,EAAE,CAAE,YAAa;EAAG,GACjC,MAEO,CAAC,EACTa,aAAA,CAACd,MAAM;IACNmB,OAAO,EAAGP,aAAe;IACzBQ,OAAO,EAAGA,CAAA,KAAMZ,UAAU,CAAEF,WAAW,GAAG,CAAE,CAAG;IAC/CK,QAAQ,EAAGA,QAAQ,IAAIL,WAAW,KAAK,CAAG;IAC1C,cAAaL,EAAE,CAAE,eAAgB;EAAG,GACpC,QAEO,CACD,CAAC,EACTa,aAAA,CAACf,IAAI;IAACoB,OAAO,EAAC;EAAO,GAClBf,OAAO;EACR;EACAF,EAAE,CAAE,cAAc,EAAE,QAAS,CAAC,EAC9BI,WAAW,EACXC,QACD,CACK,CAAC,EACPO,aAAA,CAACjB,MAAM;IAACkB,QAAQ,EAAG,KAAO;IAACE,OAAO,EAAG;EAAG,GACvCH,aAAA,CAACd,MAAM;IACNmB,OAAO,EAAGP,aAAe;IACzBQ,OAAO,EAAGA,CAAA,KAAMZ,UAAU,CAAEF,WAAW,GAAG,CAAE,CAAG;IAC/CK,QAAQ,EAAGA,QAAQ,IAAIL,WAAW,KAAKC,QAAU;IACjD,cAAaN,EAAE,CAAE,WAAY;EAAG,GAChC,QAEO,CAAC,EACTa,aAAA,CAACd,MAAM;IACNmB,OAAO,EAAGP,aAAe;IACzBQ,OAAO,EAAGA,CAAA,KAAMZ,UAAU,CAAED,QAAS,CAAG;IACxCI,QAAQ,EAAGA,QAAQ,IAAIL,WAAW,KAAKC,QAAU;IACjD,cAAaN,EAAE,CAAE,WAAY;EAAG,GAChC,MAEO,CACD,CACD,CAAC;AAEX"}
@@ -4,7 +4,8 @@ import { createElement } from "react";
4
4
  */
5
5
  import Editor from '../editor';
6
6
  import { useInitEditedEntity } from '../sync-state-with-url/use-init-edited-entity-from-url';
7
- export default function SideEditor({
7
+ import { useIsSiteEditorLoading } from '../layout/hooks';
8
+ export default function PostPreview({
8
9
  postType,
9
10
  postId
10
11
  }) {
@@ -12,6 +13,9 @@ export default function SideEditor({
12
13
  postId,
13
14
  postType
14
15
  });
15
- return createElement(Editor, null);
16
+ const isEditorLoading = useIsSiteEditorLoading();
17
+ return createElement(Editor, {
18
+ isLoading: isEditorLoading
19
+ });
16
20
  }
17
- //# sourceMappingURL=side-editor.js.map
21
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["Editor","useInitEditedEntity","useIsSiteEditorLoading","PostPreview","postType","postId","isEditorLoading","createElement","isLoading"],"sources":["@wordpress/edit-site/src/components/post-preview/index.js"],"sourcesContent":["/**\n * Internal dependencies\n */\nimport Editor from '../editor';\nimport { useInitEditedEntity } from '../sync-state-with-url/use-init-edited-entity-from-url';\nimport { useIsSiteEditorLoading } from '../layout/hooks';\n\nexport default function PostPreview( { postType, postId } ) {\n\tuseInitEditedEntity( {\n\t\tpostId,\n\t\tpostType,\n\t} );\n\tconst isEditorLoading = useIsSiteEditorLoading();\n\n\treturn <Editor isLoading={ isEditorLoading } />;\n}\n"],"mappings":";AAAA;AACA;AACA;AACA,OAAOA,MAAM,MAAM,WAAW;AAC9B,SAASC,mBAAmB,QAAQ,wDAAwD;AAC5F,SAASC,sBAAsB,QAAQ,iBAAiB;AAExD,eAAe,SAASC,WAAWA,CAAE;EAAEC,QAAQ;EAAEC;AAAO,CAAC,EAAG;EAC3DJ,mBAAmB,CAAE;IACpBI,MAAM;IACND;EACD,CAAE,CAAC;EACH,MAAME,eAAe,GAAGJ,sBAAsB,CAAC,CAAC;EAEhD,OAAOK,aAAA,CAACP,MAAM;IAACQ,SAAS,EAAGF;EAAiB,CAAE,CAAC;AAChD"}
@@ -7,17 +7,18 @@ import { ___unstablePreferencesModalBaseOption as BaseOption } from '@wordpress/
7
7
  import { store as preferencesStore } from '@wordpress/preferences';
8
8
  export default function EnableFeature(props) {
9
9
  const {
10
+ scope = 'core/edit-site',
10
11
  featureName,
11
12
  onToggle = () => {},
12
13
  ...remainingProps
13
14
  } = props;
14
- const isChecked = useSelect(select => !!select(preferencesStore).get('core/edit-site', featureName), [featureName]);
15
+ const isChecked = useSelect(select => !!select(preferencesStore).get(scope, featureName), [scope, featureName]);
15
16
  const {
16
17
  toggle
17
18
  } = useDispatch(preferencesStore);
18
19
  const onChange = () => {
19
20
  onToggle();
20
- toggle('core/edit-site', featureName);
21
+ toggle(scope, featureName);
21
22
  };
22
23
  return createElement(BaseOption, {
23
24
  onChange: onChange,
@@ -1 +1 @@
1
- {"version":3,"names":["useSelect","useDispatch","___unstablePreferencesModalBaseOption","BaseOption","store","preferencesStore","EnableFeature","props","featureName","onToggle","remainingProps","isChecked","select","get","toggle","onChange","createElement"],"sources":["@wordpress/edit-site/src/components/preferences-modal/enable-feature.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useSelect, useDispatch } from '@wordpress/data';\nimport { ___unstablePreferencesModalBaseOption as BaseOption } from '@wordpress/interface';\nimport { store as preferencesStore } from '@wordpress/preferences';\n\nexport default function EnableFeature( props ) {\n\tconst { featureName, onToggle = () => {}, ...remainingProps } = props;\n\tconst isChecked = useSelect(\n\t\t( select ) =>\n\t\t\t!! select( preferencesStore ).get( 'core/edit-site', featureName ),\n\t\t[ featureName ]\n\t);\n\tconst { toggle } = useDispatch( preferencesStore );\n\tconst onChange = () => {\n\t\tonToggle();\n\t\ttoggle( 'core/edit-site', featureName );\n\t};\n\treturn (\n\t\t<BaseOption\n\t\t\tonChange={ onChange }\n\t\t\tisChecked={ isChecked }\n\t\t\t{ ...remainingProps }\n\t\t/>\n\t);\n}\n"],"mappings":";AAAA;AACA;AACA;AACA,SAASA,SAAS,EAAEC,WAAW,QAAQ,iBAAiB;AACxD,SAASC,qCAAqC,IAAIC,UAAU,QAAQ,sBAAsB;AAC1F,SAASC,KAAK,IAAIC,gBAAgB,QAAQ,wBAAwB;AAElE,eAAe,SAASC,aAAaA,CAAEC,KAAK,EAAG;EAC9C,MAAM;IAAEC,WAAW;IAAEC,QAAQ,GAAGA,CAAA,KAAM,CAAC,CAAC;IAAE,GAAGC;EAAe,CAAC,GAAGH,KAAK;EACrE,MAAMI,SAAS,GAAGX,SAAS,CACxBY,MAAM,IACP,CAAC,CAAEA,MAAM,CAAEP,gBAAiB,CAAC,CAACQ,GAAG,CAAE,gBAAgB,EAAEL,WAAY,CAAC,EACnE,CAAEA,WAAW,CACd,CAAC;EACD,MAAM;IAAEM;EAAO,CAAC,GAAGb,WAAW,CAAEI,gBAAiB,CAAC;EAClD,MAAMU,QAAQ,GAAGA,CAAA,KAAM;IACtBN,QAAQ,CAAC,CAAC;IACVK,MAAM,CAAE,gBAAgB,EAAEN,WAAY,CAAC;EACxC,CAAC;EACD,OACCQ,aAAA,CAACb,UAAU;IACVY,QAAQ,EAAGA,QAAU;IACrBJ,SAAS,EAAGA,SAAW;IAAA,GAClBD;EAAc,CACnB,CAAC;AAEJ"}
1
+ {"version":3,"names":["useSelect","useDispatch","___unstablePreferencesModalBaseOption","BaseOption","store","preferencesStore","EnableFeature","props","scope","featureName","onToggle","remainingProps","isChecked","select","get","toggle","onChange","createElement"],"sources":["@wordpress/edit-site/src/components/preferences-modal/enable-feature.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport { useSelect, useDispatch } from '@wordpress/data';\nimport { ___unstablePreferencesModalBaseOption as BaseOption } from '@wordpress/interface';\nimport { store as preferencesStore } from '@wordpress/preferences';\n\nexport default function EnableFeature( props ) {\n\tconst {\n\t\tscope = 'core/edit-site',\n\t\tfeatureName,\n\t\tonToggle = () => {},\n\t\t...remainingProps\n\t} = props;\n\tconst isChecked = useSelect(\n\t\t( select ) => !! select( preferencesStore ).get( scope, featureName ),\n\t\t[ scope, featureName ]\n\t);\n\tconst { toggle } = useDispatch( preferencesStore );\n\tconst onChange = () => {\n\t\tonToggle();\n\t\ttoggle( scope, featureName );\n\t};\n\treturn (\n\t\t<BaseOption\n\t\t\tonChange={ onChange }\n\t\t\tisChecked={ isChecked }\n\t\t\t{ ...remainingProps }\n\t\t/>\n\t);\n}\n"],"mappings":";AAAA;AACA;AACA;AACA,SAASA,SAAS,EAAEC,WAAW,QAAQ,iBAAiB;AACxD,SAASC,qCAAqC,IAAIC,UAAU,QAAQ,sBAAsB;AAC1F,SAASC,KAAK,IAAIC,gBAAgB,QAAQ,wBAAwB;AAElE,eAAe,SAASC,aAAaA,CAAEC,KAAK,EAAG;EAC9C,MAAM;IACLC,KAAK,GAAG,gBAAgB;IACxBC,WAAW;IACXC,QAAQ,GAAGA,CAAA,KAAM,CAAC,CAAC;IACnB,GAAGC;EACJ,CAAC,GAAGJ,KAAK;EACT,MAAMK,SAAS,GAAGZ,SAAS,CACxBa,MAAM,IAAM,CAAC,CAAEA,MAAM,CAAER,gBAAiB,CAAC,CAACS,GAAG,CAAEN,KAAK,EAAEC,WAAY,CAAC,EACrE,CAAED,KAAK,EAAEC,WAAW,CACrB,CAAC;EACD,MAAM;IAAEM;EAAO,CAAC,GAAGd,WAAW,CAAEI,gBAAiB,CAAC;EAClD,MAAMW,QAAQ,GAAGA,CAAA,KAAM;IACtBN,QAAQ,CAAC,CAAC;IACVK,MAAM,CAAEP,KAAK,EAAEC,WAAY,CAAC;EAC7B,CAAC;EACD,OACCQ,aAAA,CAACd,UAAU;IACVa,QAAQ,EAAGA,QAAU;IACrBJ,SAAS,EAAGA,SAAW;IAAA,GAClBD;EAAc,CACnB,CAAC;AAEJ"}
@@ -0,0 +1,26 @@
1
+ /**
2
+ * WordPress dependencies
3
+ */
4
+ import { compose, ifCondition } from '@wordpress/compose';
5
+ import { withSelect, withDispatch } from '@wordpress/data';
6
+ import { ___unstablePreferencesModalBaseOption as BaseOption } from '@wordpress/interface';
7
+ import { store as editorStore } from '@wordpress/editor';
8
+ export default compose(withSelect((select, {
9
+ panelName
10
+ }) => {
11
+ const {
12
+ isEditorPanelEnabled,
13
+ isEditorPanelRemoved
14
+ } = select(editorStore);
15
+ return {
16
+ isRemoved: isEditorPanelRemoved(panelName),
17
+ isChecked: isEditorPanelEnabled(panelName)
18
+ };
19
+ }), ifCondition(({
20
+ isRemoved
21
+ }) => !isRemoved), withDispatch((dispatch, {
22
+ panelName
23
+ }) => ({
24
+ onChange: () => dispatch(editorStore).toggleEditorPanelEnabled(panelName)
25
+ })))(BaseOption);
26
+ //# sourceMappingURL=enable-panel-option.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"names":["compose","ifCondition","withSelect","withDispatch","___unstablePreferencesModalBaseOption","BaseOption","store","editorStore","select","panelName","isEditorPanelEnabled","isEditorPanelRemoved","isRemoved","isChecked","dispatch","onChange","toggleEditorPanelEnabled"],"sources":["@wordpress/edit-site/src/components/preferences-modal/enable-panel-option.js"],"sourcesContent":["/**\n * WordPress dependencies\n */\nimport { compose, ifCondition } from '@wordpress/compose';\nimport { withSelect, withDispatch } from '@wordpress/data';\nimport { ___unstablePreferencesModalBaseOption as BaseOption } from '@wordpress/interface';\nimport { store as editorStore } from '@wordpress/editor';\n\nexport default compose(\n\twithSelect( ( select, { panelName } ) => {\n\t\tconst { isEditorPanelEnabled, isEditorPanelRemoved } =\n\t\t\tselect( editorStore );\n\t\treturn {\n\t\t\tisRemoved: isEditorPanelRemoved( panelName ),\n\t\t\tisChecked: isEditorPanelEnabled( panelName ),\n\t\t};\n\t} ),\n\tifCondition( ( { isRemoved } ) => ! isRemoved ),\n\twithDispatch( ( dispatch, { panelName } ) => ( {\n\t\tonChange: () =>\n\t\t\tdispatch( editorStore ).toggleEditorPanelEnabled( panelName ),\n\t} ) )\n)( BaseOption );\n"],"mappings":"AAAA;AACA;AACA;AACA,SAASA,OAAO,EAAEC,WAAW,QAAQ,oBAAoB;AACzD,SAASC,UAAU,EAAEC,YAAY,QAAQ,iBAAiB;AAC1D,SAASC,qCAAqC,IAAIC,UAAU,QAAQ,sBAAsB;AAC1F,SAASC,KAAK,IAAIC,WAAW,QAAQ,mBAAmB;AAExD,eAAeP,OAAO,CACrBE,UAAU,CAAE,CAAEM,MAAM,EAAE;EAAEC;AAAU,CAAC,KAAM;EACxC,MAAM;IAAEC,oBAAoB;IAAEC;EAAqB,CAAC,GACnDH,MAAM,CAAED,WAAY,CAAC;EACtB,OAAO;IACNK,SAAS,EAAED,oBAAoB,CAAEF,SAAU,CAAC;IAC5CI,SAAS,EAAEH,oBAAoB,CAAED,SAAU;EAC5C,CAAC;AACF,CAAE,CAAC,EACHR,WAAW,CAAE,CAAE;EAAEW;AAAU,CAAC,KAAM,CAAEA,SAAU,CAAC,EAC/CT,YAAY,CAAE,CAAEW,QAAQ,EAAE;EAAEL;AAAU,CAAC,MAAQ;EAC9CM,QAAQ,EAAEA,CAAA,KACTD,QAAQ,CAAEP,WAAY,CAAC,CAACS,wBAAwB,CAAEP,SAAU;AAC9D,CAAC,CAAG,CACL,CAAC,CAAEJ,UAAW,CAAC"}