@wordpress/edit-site 6.3.0 → 6.5.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.
- package/CHANGELOG.md +4 -0
- package/build/components/add-new-pattern/index.js +14 -3
- package/build/components/add-new-pattern/index.js.map +1 -1
- package/build/components/add-new-post/index.js +2 -1
- package/build/components/add-new-post/index.js.map +1 -1
- package/build/components/add-new-template/index.js +3 -1
- package/build/components/add-new-template/index.js.map +1 -1
- package/build/components/add-new-template/utils.js +2 -2
- package/build/components/add-new-template/utils.js.map +1 -1
- package/build/components/block-editor/use-site-editor-settings.js +1 -82
- package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
- package/build/components/editor/index.js +71 -20
- package/build/components/editor/index.js.map +1 -1
- package/build/components/global-styles/block-preview-panel.js +14 -5
- package/build/components/global-styles/block-preview-panel.js.map +1 -1
- package/build/components/global-styles/font-families.js +40 -22
- package/build/components/global-styles/font-families.js.map +1 -1
- package/build/components/global-styles/font-library-modal/context.js +0 -5
- package/build/components/global-styles/font-library-modal/context.js.map +1 -1
- package/build/components/global-styles/font-library-modal/font-collection.js +25 -5
- package/build/components/global-styles/font-library-modal/font-collection.js.map +1 -1
- package/build/components/global-styles/font-library-modal/index.js +5 -12
- package/build/components/global-styles/font-library-modal/index.js.map +1 -1
- package/build/components/global-styles/font-library-modal/installed-fonts.js +78 -15
- package/build/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
- package/build/components/global-styles/font-library-modal/upload-fonts.js +2 -3
- package/build/components/global-styles/font-library-modal/upload-fonts.js.map +1 -1
- package/build/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js +39 -0
- package/build/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js.map +1 -0
- package/build/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js +39 -0
- package/build/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js.map +1 -0
- package/build/components/global-styles/font-sizes/font-size-preview.js +44 -0
- package/build/components/global-styles/font-sizes/font-size-preview.js.map +1 -0
- package/build/components/global-styles/font-sizes/font-size.js +213 -0
- package/build/components/global-styles/font-sizes/font-size.js.map +1 -0
- package/build/components/global-styles/font-sizes/font-sizes-count.js +50 -0
- package/build/components/global-styles/font-sizes/font-sizes-count.js.map +1 -0
- package/build/components/global-styles/font-sizes/font-sizes.js +163 -0
- package/build/components/global-styles/font-sizes/font-sizes.js.map +1 -0
- package/build/components/global-styles/font-sizes/rename-font-size-dialog.js +67 -0
- package/build/components/global-styles/font-sizes/rename-font-size-dialog.js.map +1 -0
- package/build/components/global-styles/screen-block.js +10 -8
- package/build/components/global-styles/screen-block.js.map +1 -1
- package/build/components/global-styles/screen-style-variations.js +2 -2
- package/build/components/global-styles/screen-style-variations.js.map +1 -1
- package/build/components/global-styles/screen-typeset.js +40 -0
- package/build/components/global-styles/screen-typeset.js.map +1 -0
- package/build/components/global-styles/screen-typography-element.js +14 -0
- package/build/components/global-styles/screen-typography-element.js.map +1 -1
- package/build/components/global-styles/screen-typography.js +5 -6
- package/build/components/global-styles/screen-typography.js.map +1 -1
- package/build/components/global-styles/shadows-edit-panel.js +50 -59
- package/build/components/global-styles/shadows-edit-panel.js.map +1 -1
- package/build/components/global-styles/size-control/index.js +85 -0
- package/build/components/global-styles/size-control/index.js.map +1 -0
- package/build/components/global-styles/style-variations-container.js +3 -0
- package/build/components/global-styles/style-variations-container.js.map +1 -1
- package/build/components/global-styles/typeset-button.js +97 -0
- package/build/components/global-styles/typeset-button.js.map +1 -0
- package/build/components/global-styles/typeset.js +80 -0
- package/build/components/global-styles/typeset.js.map +1 -0
- package/build/components/global-styles/ui.js +12 -0
- package/build/components/global-styles/ui.js.map +1 -1
- package/build/components/global-styles/utils.js +10 -1
- package/build/components/global-styles/utils.js.map +1 -1
- package/build/components/global-styles/variations/variations-color.js.map +1 -1
- package/build/components/global-styles/variations/variations-typography.js +1 -1
- package/build/components/global-styles/variations/variations-typography.js.map +1 -1
- package/build/components/layout/index.js +6 -0
- package/build/components/layout/index.js.map +1 -1
- package/build/components/layout/router.js +14 -6
- package/build/components/layout/router.js.map +1 -1
- package/build/components/page-patterns/fields.js +230 -0
- package/build/components/page-patterns/fields.js.map +1 -0
- package/build/components/page-patterns/header.js +1 -1
- package/build/components/page-patterns/header.js.map +1 -1
- package/build/components/page-patterns/index.js +21 -227
- package/build/components/page-patterns/index.js.map +1 -1
- package/build/components/page-patterns/use-patterns.js +26 -1
- package/build/components/page-patterns/use-patterns.js.map +1 -1
- package/build/components/page-templates/fields.js +169 -0
- package/build/components/page-templates/fields.js.map +1 -0
- package/build/components/page-templates/index.js +38 -198
- package/build/components/page-templates/index.js.map +1 -1
- package/build/components/post-edit/index.js +117 -0
- package/build/components/post-edit/index.js.map +1 -0
- package/build/components/post-fields/index.js +318 -0
- package/build/components/post-fields/index.js.map +1 -0
- package/build/components/post-list/index.js +339 -0
- package/build/components/post-list/index.js.map +1 -0
- package/build/components/posts-app/router.js +3 -3
- package/build/components/posts-app/router.js.map +1 -1
- package/build/components/sidebar-dataviews/add-new-view.js +2 -2
- package/build/components/sidebar-dataviews/add-new-view.js.map +1 -1
- package/build/components/sidebar-dataviews/dataview-item.js +2 -3
- package/build/components/sidebar-dataviews/dataview-item.js.map +1 -1
- package/build/components/sidebar-dataviews/default-views.js +103 -91
- package/build/components/sidebar-dataviews/default-views.js.map +1 -1
- package/build/components/sidebar-dataviews/index.js +2 -2
- package/build/components/sidebar-dataviews/index.js.map +1 -1
- package/build/components/sidebar-navigation-screen-global-styles/content.js +64 -0
- package/build/components/sidebar-navigation-screen-global-styles/content.js.map +1 -0
- package/build/components/sidebar-navigation-screen-global-styles/index.js +2 -47
- package/build/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
- package/build/components/site-hub/index.js +6 -3
- package/build/components/site-hub/index.js.map +1 -1
- package/build/components/style-book/index.js +22 -25
- package/build/components/style-book/index.js.map +1 -1
- package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -0
- package/build/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
- package/build/hooks/push-changes-to-global-styles/index.js +3 -4
- package/build/hooks/push-changes-to-global-styles/index.js.map +1 -1
- package/build/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +2 -4
- package/build/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js.map +1 -1
- package/build/index.js +4 -2
- package/build/index.js.map +1 -1
- package/build/store/selectors.js +34 -6
- package/build/store/selectors.js.map +1 -1
- package/build/utils/get-filtered-template-parts.js +64 -0
- package/build/utils/get-filtered-template-parts.js.map +1 -0
- package/build-module/components/add-new-pattern/index.js +14 -3
- package/build-module/components/add-new-pattern/index.js.map +1 -1
- package/build-module/components/add-new-post/index.js +2 -1
- package/build-module/components/add-new-post/index.js.map +1 -1
- package/build-module/components/add-new-template/index.js +3 -1
- package/build-module/components/add-new-template/index.js.map +1 -1
- package/build-module/components/add-new-template/utils.js +2 -2
- package/build-module/components/add-new-template/utils.js.map +1 -1
- package/build-module/components/block-editor/use-site-editor-settings.js +1 -82
- package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
- package/build-module/components/editor/index.js +73 -22
- package/build-module/components/editor/index.js.map +1 -1
- package/build-module/components/global-styles/block-preview-panel.js +14 -5
- package/build-module/components/global-styles/block-preview-panel.js.map +1 -1
- package/build-module/components/global-styles/font-families.js +42 -24
- package/build-module/components/global-styles/font-families.js.map +1 -1
- package/build-module/components/global-styles/font-library-modal/context.js +0 -5
- package/build-module/components/global-styles/font-library-modal/context.js.map +1 -1
- package/build-module/components/global-styles/font-library-modal/font-collection.js +26 -6
- package/build-module/components/global-styles/font-library-modal/font-collection.js.map +1 -1
- package/build-module/components/global-styles/font-library-modal/index.js +5 -12
- package/build-module/components/global-styles/font-library-modal/index.js.map +1 -1
- package/build-module/components/global-styles/font-library-modal/installed-fonts.js +81 -18
- package/build-module/components/global-styles/font-library-modal/installed-fonts.js.map +1 -1
- package/build-module/components/global-styles/font-library-modal/upload-fonts.js +2 -3
- package/build-module/components/global-styles/font-library-modal/upload-fonts.js.map +1 -1
- package/build-module/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js +32 -0
- package/build-module/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js.map +1 -0
- package/build-module/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js +32 -0
- package/build-module/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js.map +1 -0
- package/build-module/components/global-styles/font-sizes/font-size-preview.js +37 -0
- package/build-module/components/global-styles/font-sizes/font-size-preview.js.map +1 -0
- package/build-module/components/global-styles/font-sizes/font-size.js +207 -0
- package/build-module/components/global-styles/font-sizes/font-size.js.map +1 -0
- package/build-module/components/global-styles/font-sizes/font-sizes-count.js +43 -0
- package/build-module/components/global-styles/font-sizes/font-sizes-count.js.map +1 -0
- package/build-module/components/global-styles/font-sizes/font-sizes.js +157 -0
- package/build-module/components/global-styles/font-sizes/font-sizes.js.map +1 -0
- package/build-module/components/global-styles/font-sizes/rename-font-size-dialog.js +61 -0
- package/build-module/components/global-styles/font-sizes/rename-font-size-dialog.js.map +1 -0
- package/build-module/components/global-styles/screen-block.js +10 -8
- package/build-module/components/global-styles/screen-block.js.map +1 -1
- package/build-module/components/global-styles/screen-style-variations.js +2 -2
- package/build-module/components/global-styles/screen-style-variations.js.map +1 -1
- package/build-module/components/global-styles/screen-typeset.js +34 -0
- package/build-module/components/global-styles/screen-typeset.js.map +1 -0
- package/build-module/components/global-styles/screen-typography-element.js +14 -0
- package/build-module/components/global-styles/screen-typography-element.js.map +1 -1
- package/build-module/components/global-styles/screen-typography.js +5 -6
- package/build-module/components/global-styles/screen-typography.js.map +1 -1
- package/build-module/components/global-styles/shadows-edit-panel.js +51 -60
- package/build-module/components/global-styles/shadows-edit-panel.js.map +1 -1
- package/build-module/components/global-styles/size-control/index.js +79 -0
- package/build-module/components/global-styles/size-control/index.js.map +1 -0
- package/build-module/components/global-styles/style-variations-container.js +3 -0
- package/build-module/components/global-styles/style-variations-container.js.map +1 -1
- package/build-module/components/global-styles/typeset-button.js +89 -0
- package/build-module/components/global-styles/typeset-button.js.map +1 -0
- package/build-module/components/global-styles/typeset.js +71 -0
- package/build-module/components/global-styles/typeset.js.map +1 -0
- package/build-module/components/global-styles/ui.js +12 -0
- package/build-module/components/global-styles/ui.js.map +1 -1
- package/build-module/components/global-styles/utils.js +10 -1
- package/build-module/components/global-styles/utils.js.map +1 -1
- package/build-module/components/global-styles/variations/variations-color.js +1 -1
- package/build-module/components/global-styles/variations/variations-color.js.map +1 -1
- package/build-module/components/global-styles/variations/variations-typography.js +1 -2
- package/build-module/components/global-styles/variations/variations-typography.js.map +1 -1
- package/build-module/components/layout/index.js +6 -0
- package/build-module/components/layout/index.js.map +1 -1
- package/build-module/components/layout/router.js +14 -6
- package/build-module/components/layout/router.js.map +1 -1
- package/build-module/components/page-patterns/fields.js +223 -0
- package/build-module/components/page-patterns/fields.js.map +1 -0
- package/build-module/components/page-patterns/header.js +1 -1
- package/build-module/components/page-patterns/header.js.map +1 -1
- package/build-module/components/page-patterns/index.js +24 -230
- package/build-module/components/page-patterns/index.js.map +1 -1
- package/build-module/components/page-patterns/use-patterns.js +26 -1
- package/build-module/components/page-patterns/use-patterns.js.map +1 -1
- package/build-module/components/page-templates/fields.js +160 -0
- package/build-module/components/page-templates/fields.js.map +1 -0
- package/build-module/components/page-templates/index.js +39 -199
- package/build-module/components/page-templates/index.js.map +1 -1
- package/build-module/components/post-edit/index.js +110 -0
- package/build-module/components/post-edit/index.js.map +1 -0
- package/build-module/components/post-fields/index.js +310 -0
- package/build-module/components/post-fields/index.js.map +1 -0
- package/build-module/components/post-list/index.js +333 -0
- package/build-module/components/post-list/index.js.map +1 -0
- package/build-module/components/posts-app/router.js +3 -3
- package/build-module/components/posts-app/router.js.map +1 -1
- package/build-module/components/sidebar-dataviews/add-new-view.js +2 -2
- package/build-module/components/sidebar-dataviews/add-new-view.js.map +1 -1
- package/build-module/components/sidebar-dataviews/dataview-item.js +2 -3
- package/build-module/components/sidebar-dataviews/dataview-item.js.map +1 -1
- package/build-module/components/sidebar-dataviews/default-views.js +102 -90
- package/build-module/components/sidebar-dataviews/default-views.js.map +1 -1
- package/build-module/components/sidebar-dataviews/index.js +5 -5
- package/build-module/components/sidebar-dataviews/index.js.map +1 -1
- package/build-module/components/sidebar-navigation-screen-global-styles/content.js +57 -0
- package/build-module/components/sidebar-navigation-screen-global-styles/content.js.map +1 -0
- package/build-module/components/sidebar-navigation-screen-global-styles/index.js +2 -47
- package/build-module/components/sidebar-navigation-screen-global-styles/index.js.map +1 -1
- package/build-module/components/site-hub/index.js +7 -4
- package/build-module/components/site-hub/index.js.map +1 -1
- package/build-module/components/style-book/index.js +23 -26
- package/build-module/components/style-book/index.js.map +1 -1
- package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -0
- package/build-module/components/sync-state-with-url/use-init-edited-entity-from-url.js.map +1 -1
- package/build-module/hooks/push-changes-to-global-styles/index.js +3 -4
- package/build-module/hooks/push-changes-to-global-styles/index.js.map +1 -1
- package/build-module/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +2 -3
- package/build-module/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js.map +1 -1
- package/build-module/index.js +4 -2
- package/build-module/index.js.map +1 -1
- package/build-module/store/selectors.js +35 -7
- package/build-module/store/selectors.js.map +1 -1
- package/build-module/utils/get-filtered-template-parts.js +57 -0
- package/build-module/utils/get-filtered-template-parts.js.map +1 -0
- package/build-style/posts-rtl.css +749 -492
- package/build-style/posts.css +749 -492
- package/build-style/style-rtl.css +956 -613
- package/build-style/style.css +956 -613
- package/package.json +41 -41
- package/src/components/add-new-pattern/index.js +16 -5
- package/src/components/add-new-post/index.js +2 -1
- package/src/components/add-new-template/index.js +4 -1
- package/src/components/add-new-template/style.scss +4 -6
- package/src/components/add-new-template/utils.js +10 -6
- package/src/components/block-editor/use-site-editor-settings.js +15 -111
- package/src/components/editor/index.js +80 -22
- package/src/components/editor/style.scss +59 -1
- package/src/components/global-styles/block-preview-panel.js +22 -9
- package/src/components/global-styles/font-families.js +65 -32
- package/src/components/global-styles/font-library-modal/context.js +0 -5
- package/src/components/global-styles/font-library-modal/font-collection.js +34 -10
- package/src/components/global-styles/font-library-modal/index.js +6 -9
- package/src/components/global-styles/font-library-modal/installed-fonts.js +115 -16
- package/src/components/global-styles/font-library-modal/style.scss +9 -0
- package/src/components/global-styles/font-library-modal/upload-fonts.js +2 -2
- package/src/components/global-styles/font-sizes/confirm-delete-font-size-dialog.js +43 -0
- package/src/components/global-styles/font-sizes/confirm-reset-font-sizes-dialog.js +37 -0
- package/src/components/global-styles/font-sizes/font-size-preview.js +43 -0
- package/src/components/global-styles/font-sizes/font-size.js +250 -0
- package/src/components/global-styles/font-sizes/font-sizes-count.js +40 -0
- package/src/components/global-styles/font-sizes/font-sizes.js +263 -0
- package/src/components/global-styles/font-sizes/rename-font-size-dialog.js +70 -0
- package/src/components/global-styles/screen-block.js +12 -14
- package/src/components/global-styles/screen-style-variations.js +2 -2
- package/src/components/global-styles/screen-typeset.js +42 -0
- package/src/components/global-styles/screen-typography-element.js +14 -0
- package/src/components/global-styles/screen-typography.js +7 -6
- package/src/components/global-styles/shadows-edit-panel.js +66 -73
- package/src/components/global-styles/size-control/index.js +86 -0
- package/src/components/global-styles/style-variations-container.js +4 -0
- package/src/components/global-styles/style.scss +17 -10
- package/src/components/global-styles/typeset-button.js +93 -0
- package/src/components/global-styles/typeset.js +73 -0
- package/src/components/global-styles/ui.js +15 -0
- package/src/components/global-styles/utils.js +13 -1
- package/src/components/global-styles/variations/variations-color.js +1 -1
- package/src/components/global-styles/variations/variations-typography.js +1 -2
- package/src/components/layout/index.js +11 -0
- package/src/components/layout/router.js +13 -5
- package/src/components/layout/style.scss +34 -8
- package/src/components/page-patterns/fields.js +251 -0
- package/src/components/page-patterns/header.js +1 -1
- package/src/components/page-patterns/index.js +24 -246
- package/src/components/page-patterns/style.scss +82 -85
- package/src/components/page-patterns/use-patterns.js +31 -1
- package/src/components/page-templates/fields.js +157 -0
- package/src/components/page-templates/index.js +46 -192
- package/src/components/page-templates/style.scss +19 -8
- package/src/components/post-edit/index.js +115 -0
- package/src/components/post-edit/style.scss +9 -0
- package/src/components/post-fields/index.js +357 -0
- package/src/components/post-list/index.js +386 -0
- package/src/components/{posts-app → post-list}/style.scss +12 -9
- package/src/components/posts-app/router.js +3 -3
- package/src/components/sidebar-dataviews/add-new-view.js +2 -4
- package/src/components/sidebar-dataviews/dataview-item.js +2 -2
- package/src/components/sidebar-dataviews/default-views.js +116 -104
- package/src/components/sidebar-dataviews/index.js +4 -3
- package/src/components/sidebar-navigation-screen-global-styles/content.js +55 -0
- package/src/components/sidebar-navigation-screen-global-styles/index.js +1 -55
- package/src/components/site-hub/index.js +11 -2
- package/src/components/site-icon/style.scss +4 -1
- package/src/components/style-book/index.js +27 -32
- package/src/components/sync-state-with-url/use-init-edited-entity-from-url.js +5 -0
- package/src/hooks/push-changes-to-global-styles/index.js +3 -4
- package/src/hooks/use-theme-style-variations/use-theme-style-variations-by-property.js +2 -3
- package/src/index.js +6 -2
- package/src/posts.scss +1 -1
- package/src/store/selectors.js +53 -14
- package/src/store/test/selectors.js +1 -26
- package/src/style.scss +2 -1
- package/src/utils/get-filtered-template-parts.js +61 -0
- package/src/utils/test/get-filtered-template-parts.js +127 -0
- package/build/components/global-styles/screen-background.js +0 -36
- package/build/components/global-styles/screen-background.js.map +0 -1
- package/build/components/posts-app/posts-list.js +0 -568
- package/build/components/posts-app/posts-list.js.map +0 -1
- package/build/utils/clone-deep.js +0 -15
- package/build/utils/clone-deep.js.map +0 -1
- package/build-module/components/global-styles/screen-background.js +0 -30
- package/build-module/components/global-styles/screen-background.js.map +0 -1
- package/build-module/components/posts-app/posts-list.js +0 -560
- package/build-module/components/posts-app/posts-list.js.map +0 -1
- package/build-module/utils/clone-deep.js +0 -9
- package/build-module/utils/clone-deep.js.map +0 -1
- package/src/components/global-styles/screen-background.js +0 -29
- package/src/components/posts-app/posts-list.js +0 -651
- package/src/utils/clone-deep.js +0 -8
|
@@ -0,0 +1,310 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* External dependencies
|
|
3
|
+
*/
|
|
4
|
+
import clsx from 'clsx';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* WordPress dependencies
|
|
8
|
+
*/
|
|
9
|
+
import { __, sprintf } from '@wordpress/i18n';
|
|
10
|
+
import { decodeEntities } from '@wordpress/html-entities';
|
|
11
|
+
import { createInterpolateElement, useMemo, useState } from '@wordpress/element';
|
|
12
|
+
import { dateI18n, getDate, getSettings } from '@wordpress/date';
|
|
13
|
+
import { trash, drafts, published, scheduled, pending, notAllowed, commentAuthorAvatar as authorIcon } from '@wordpress/icons';
|
|
14
|
+
import { __experimentalHStack as HStack, Icon } from '@wordpress/components';
|
|
15
|
+
import { useSelect } from '@wordpress/data';
|
|
16
|
+
import { useEntityRecords, store as coreStore } from '@wordpress/core-data';
|
|
17
|
+
|
|
18
|
+
/**
|
|
19
|
+
* Internal dependencies
|
|
20
|
+
*/
|
|
21
|
+
import { LAYOUT_GRID, LAYOUT_TABLE, LAYOUT_LIST, OPERATOR_IS_ANY } from '../../utils/constants';
|
|
22
|
+
import { default as Link, useLink } from '../routes/link';
|
|
23
|
+
import Media from '../media';
|
|
24
|
+
|
|
25
|
+
// See https://github.com/WordPress/gutenberg/issues/55886
|
|
26
|
+
// We do not support custom statutes at the moment.
|
|
27
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
28
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
29
|
+
const STATUSES = [{
|
|
30
|
+
value: 'draft',
|
|
31
|
+
label: __('Draft'),
|
|
32
|
+
icon: drafts
|
|
33
|
+
}, {
|
|
34
|
+
value: 'future',
|
|
35
|
+
label: __('Scheduled'),
|
|
36
|
+
icon: scheduled
|
|
37
|
+
}, {
|
|
38
|
+
value: 'pending',
|
|
39
|
+
label: __('Pending Review'),
|
|
40
|
+
icon: pending
|
|
41
|
+
}, {
|
|
42
|
+
value: 'private',
|
|
43
|
+
label: __('Private'),
|
|
44
|
+
icon: notAllowed
|
|
45
|
+
}, {
|
|
46
|
+
value: 'publish',
|
|
47
|
+
label: __('Published'),
|
|
48
|
+
icon: published
|
|
49
|
+
}, {
|
|
50
|
+
value: 'trash',
|
|
51
|
+
label: __('Trash'),
|
|
52
|
+
icon: trash
|
|
53
|
+
}];
|
|
54
|
+
const getFormattedDate = dateToDisplay => dateI18n(getSettings().formats.datetimeAbbreviated, getDate(dateToDisplay));
|
|
55
|
+
function FeaturedImage({
|
|
56
|
+
item,
|
|
57
|
+
viewType
|
|
58
|
+
}) {
|
|
59
|
+
const isDisabled = item.status === 'trash';
|
|
60
|
+
const {
|
|
61
|
+
onClick
|
|
62
|
+
} = useLink({
|
|
63
|
+
postId: item.id,
|
|
64
|
+
postType: item.type,
|
|
65
|
+
canvas: 'edit'
|
|
66
|
+
});
|
|
67
|
+
const hasMedia = !!item.featured_media;
|
|
68
|
+
const size = viewType === LAYOUT_GRID ? ['large', 'full', 'medium', 'thumbnail'] : ['thumbnail', 'medium', 'large', 'full'];
|
|
69
|
+
const media = hasMedia ? /*#__PURE__*/_jsx(Media, {
|
|
70
|
+
className: "edit-site-post-list__featured-image",
|
|
71
|
+
id: item.featured_media,
|
|
72
|
+
size: size
|
|
73
|
+
}) : null;
|
|
74
|
+
const renderButton = viewType !== LAYOUT_LIST && !isDisabled;
|
|
75
|
+
return /*#__PURE__*/_jsx("div", {
|
|
76
|
+
className: `edit-site-post-list__featured-image-wrapper is-layout-${viewType}`,
|
|
77
|
+
children: renderButton ? /*#__PURE__*/_jsx("button", {
|
|
78
|
+
className: "edit-site-post-list__featured-image-button",
|
|
79
|
+
type: "button",
|
|
80
|
+
onClick: onClick,
|
|
81
|
+
"aria-label": item.title?.rendered || __('(no title)'),
|
|
82
|
+
children: media
|
|
83
|
+
}) : media
|
|
84
|
+
});
|
|
85
|
+
}
|
|
86
|
+
function PostStatusField({
|
|
87
|
+
item
|
|
88
|
+
}) {
|
|
89
|
+
const status = STATUSES.find(({
|
|
90
|
+
value
|
|
91
|
+
}) => value === item.status);
|
|
92
|
+
const label = status?.label || item.status;
|
|
93
|
+
const icon = status?.icon;
|
|
94
|
+
return /*#__PURE__*/_jsxs(HStack, {
|
|
95
|
+
alignment: "left",
|
|
96
|
+
spacing: 0,
|
|
97
|
+
children: [icon && /*#__PURE__*/_jsx("div", {
|
|
98
|
+
className: "edit-site-post-list__status-icon",
|
|
99
|
+
children: /*#__PURE__*/_jsx(Icon, {
|
|
100
|
+
icon: icon
|
|
101
|
+
})
|
|
102
|
+
}), /*#__PURE__*/_jsx("span", {
|
|
103
|
+
children: label
|
|
104
|
+
})]
|
|
105
|
+
});
|
|
106
|
+
}
|
|
107
|
+
function PostAuthorField({
|
|
108
|
+
item
|
|
109
|
+
}) {
|
|
110
|
+
const {
|
|
111
|
+
text,
|
|
112
|
+
imageUrl
|
|
113
|
+
} = useSelect(select => {
|
|
114
|
+
const {
|
|
115
|
+
getUser
|
|
116
|
+
} = select(coreStore);
|
|
117
|
+
const user = getUser(item.author);
|
|
118
|
+
return {
|
|
119
|
+
imageUrl: user?.avatar_urls?.[48],
|
|
120
|
+
text: user?.name
|
|
121
|
+
};
|
|
122
|
+
}, [item]);
|
|
123
|
+
const [isImageLoaded, setIsImageLoaded] = useState(false);
|
|
124
|
+
return /*#__PURE__*/_jsxs(HStack, {
|
|
125
|
+
alignment: "left",
|
|
126
|
+
spacing: 0,
|
|
127
|
+
children: [!!imageUrl && /*#__PURE__*/_jsx("div", {
|
|
128
|
+
className: clsx('page-templates-author-field__avatar', {
|
|
129
|
+
'is-loaded': isImageLoaded
|
|
130
|
+
}),
|
|
131
|
+
children: /*#__PURE__*/_jsx("img", {
|
|
132
|
+
onLoad: () => setIsImageLoaded(true),
|
|
133
|
+
alt: __('Author avatar'),
|
|
134
|
+
src: imageUrl
|
|
135
|
+
})
|
|
136
|
+
}), !imageUrl && /*#__PURE__*/_jsx("div", {
|
|
137
|
+
className: "page-templates-author-field__icon",
|
|
138
|
+
children: /*#__PURE__*/_jsx(Icon, {
|
|
139
|
+
icon: authorIcon
|
|
140
|
+
})
|
|
141
|
+
}), /*#__PURE__*/_jsx("span", {
|
|
142
|
+
className: "page-templates-author-field__name",
|
|
143
|
+
children: text
|
|
144
|
+
})]
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
function usePostFields(viewType) {
|
|
148
|
+
const {
|
|
149
|
+
records: authors,
|
|
150
|
+
isResolving: isLoadingAuthors
|
|
151
|
+
} = useEntityRecords('root', 'user', {
|
|
152
|
+
per_page: -1
|
|
153
|
+
});
|
|
154
|
+
const {
|
|
155
|
+
frontPageId,
|
|
156
|
+
postsPageId
|
|
157
|
+
} = useSelect(select => {
|
|
158
|
+
const {
|
|
159
|
+
getEntityRecord
|
|
160
|
+
} = select(coreStore);
|
|
161
|
+
const siteSettings = getEntityRecord('root', 'site');
|
|
162
|
+
return {
|
|
163
|
+
frontPageId: siteSettings?.page_on_front,
|
|
164
|
+
postsPageId: siteSettings?.page_for_posts
|
|
165
|
+
};
|
|
166
|
+
}, []);
|
|
167
|
+
const fields = useMemo(() => [{
|
|
168
|
+
id: 'featured-image',
|
|
169
|
+
label: __('Featured Image'),
|
|
170
|
+
getValue: ({
|
|
171
|
+
item
|
|
172
|
+
}) => item.featured_media,
|
|
173
|
+
render: ({
|
|
174
|
+
item
|
|
175
|
+
}) => /*#__PURE__*/_jsx(FeaturedImage, {
|
|
176
|
+
item: item,
|
|
177
|
+
viewType: viewType
|
|
178
|
+
}),
|
|
179
|
+
enableSorting: false
|
|
180
|
+
}, {
|
|
181
|
+
label: __('Title'),
|
|
182
|
+
id: 'title',
|
|
183
|
+
type: 'text',
|
|
184
|
+
getValue: ({
|
|
185
|
+
item
|
|
186
|
+
}) => typeof item.title === 'string' ? item.title : item.title?.raw,
|
|
187
|
+
render: ({
|
|
188
|
+
item
|
|
189
|
+
}) => {
|
|
190
|
+
const addLink = [LAYOUT_TABLE, LAYOUT_GRID].includes(viewType) && item.status !== 'trash';
|
|
191
|
+
const renderedTitle = typeof item.title === 'string' ? item.title : item.title?.rendered;
|
|
192
|
+
const title = addLink ? /*#__PURE__*/_jsx(Link, {
|
|
193
|
+
params: {
|
|
194
|
+
postId: item.id,
|
|
195
|
+
postType: item.type,
|
|
196
|
+
canvas: 'edit'
|
|
197
|
+
},
|
|
198
|
+
children: decodeEntities(renderedTitle) || __('(no title)')
|
|
199
|
+
}) : /*#__PURE__*/_jsx("span", {
|
|
200
|
+
children: decodeEntities(renderedTitle) || __('(no title)')
|
|
201
|
+
});
|
|
202
|
+
let suffix = '';
|
|
203
|
+
if (item.id === frontPageId) {
|
|
204
|
+
suffix = /*#__PURE__*/_jsx("span", {
|
|
205
|
+
className: "edit-site-post-list__title-badge",
|
|
206
|
+
children: __('Homepage')
|
|
207
|
+
});
|
|
208
|
+
} else if (item.id === postsPageId) {
|
|
209
|
+
suffix = /*#__PURE__*/_jsx("span", {
|
|
210
|
+
className: "edit-site-post-list__title-badge",
|
|
211
|
+
children: __('Posts Page')
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
return /*#__PURE__*/_jsxs(HStack, {
|
|
215
|
+
className: "edit-site-post-list__title",
|
|
216
|
+
alignment: "center",
|
|
217
|
+
justify: "flex-start",
|
|
218
|
+
children: [title, suffix]
|
|
219
|
+
});
|
|
220
|
+
},
|
|
221
|
+
enableHiding: false
|
|
222
|
+
}, {
|
|
223
|
+
label: __('Author'),
|
|
224
|
+
id: 'author',
|
|
225
|
+
type: 'integer',
|
|
226
|
+
elements: authors?.map(({
|
|
227
|
+
id,
|
|
228
|
+
name
|
|
229
|
+
}) => ({
|
|
230
|
+
value: id,
|
|
231
|
+
label: name
|
|
232
|
+
})) || [],
|
|
233
|
+
render: PostAuthorField,
|
|
234
|
+
sort: (a, b, direction) => {
|
|
235
|
+
const nameA = a._embedded?.author?.[0]?.name || '';
|
|
236
|
+
const nameB = b._embedded?.author?.[0]?.name || '';
|
|
237
|
+
return direction === 'asc' ? nameA.localeCompare(nameB) : nameB.localeCompare(nameA);
|
|
238
|
+
}
|
|
239
|
+
}, {
|
|
240
|
+
label: __('Status'),
|
|
241
|
+
id: 'status',
|
|
242
|
+
getValue: ({
|
|
243
|
+
item
|
|
244
|
+
}) => {
|
|
245
|
+
var _STATUSES$find$label;
|
|
246
|
+
return (_STATUSES$find$label = STATUSES.find(({
|
|
247
|
+
value
|
|
248
|
+
}) => value === item.status)?.label) !== null && _STATUSES$find$label !== void 0 ? _STATUSES$find$label : item.status;
|
|
249
|
+
},
|
|
250
|
+
elements: STATUSES,
|
|
251
|
+
render: PostStatusField,
|
|
252
|
+
enableSorting: false,
|
|
253
|
+
filterBy: {
|
|
254
|
+
operators: [OPERATOR_IS_ANY]
|
|
255
|
+
}
|
|
256
|
+
}, {
|
|
257
|
+
label: __('Date'),
|
|
258
|
+
id: 'date',
|
|
259
|
+
render: ({
|
|
260
|
+
item
|
|
261
|
+
}) => {
|
|
262
|
+
const isDraftOrPrivate = ['draft', 'private'].includes(item.status);
|
|
263
|
+
if (isDraftOrPrivate) {
|
|
264
|
+
return createInterpolateElement(sprintf( /* translators: %s: page creation date */
|
|
265
|
+
__('<span>Modified: <time>%s</time></span>'), getFormattedDate(item.date)), {
|
|
266
|
+
span: /*#__PURE__*/_jsx("span", {}),
|
|
267
|
+
time: /*#__PURE__*/_jsx("time", {})
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
const isScheduled = item.status === 'future';
|
|
271
|
+
if (isScheduled) {
|
|
272
|
+
return createInterpolateElement(sprintf( /* translators: %s: page creation date */
|
|
273
|
+
__('<span>Scheduled: <time>%s</time></span>'), getFormattedDate(item.date)), {
|
|
274
|
+
span: /*#__PURE__*/_jsx("span", {}),
|
|
275
|
+
time: /*#__PURE__*/_jsx("time", {})
|
|
276
|
+
});
|
|
277
|
+
}
|
|
278
|
+
const isPublished = item.status === 'publish';
|
|
279
|
+
if (isPublished) {
|
|
280
|
+
return createInterpolateElement(sprintf( /* translators: %s: page creation time */
|
|
281
|
+
__('<span>Published: <time>%s</time></span>'), getFormattedDate(item.date)), {
|
|
282
|
+
span: /*#__PURE__*/_jsx("span", {}),
|
|
283
|
+
time: /*#__PURE__*/_jsx("time", {})
|
|
284
|
+
});
|
|
285
|
+
}
|
|
286
|
+
|
|
287
|
+
// Pending posts show the modified date if it's newer.
|
|
288
|
+
const dateToDisplay = getDate(item.modified) > getDate(item.date) ? item.modified : item.date;
|
|
289
|
+
const isPending = item.status === 'pending';
|
|
290
|
+
if (isPending) {
|
|
291
|
+
return createInterpolateElement(sprintf( /* translators: %s: the newest of created or modified date for the page */
|
|
292
|
+
__('<span>Modified: <time>%s</time></span>'), getFormattedDate(dateToDisplay)), {
|
|
293
|
+
span: /*#__PURE__*/_jsx("span", {}),
|
|
294
|
+
time: /*#__PURE__*/_jsx("time", {})
|
|
295
|
+
});
|
|
296
|
+
}
|
|
297
|
+
|
|
298
|
+
// Unknow status.
|
|
299
|
+
return /*#__PURE__*/_jsx("time", {
|
|
300
|
+
children: getFormattedDate(item.date)
|
|
301
|
+
});
|
|
302
|
+
}
|
|
303
|
+
}], [authors, viewType, frontPageId, postsPageId]);
|
|
304
|
+
return {
|
|
305
|
+
isLoading: isLoadingAuthors,
|
|
306
|
+
fields
|
|
307
|
+
};
|
|
308
|
+
}
|
|
309
|
+
export default usePostFields;
|
|
310
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["clsx","__","sprintf","decodeEntities","createInterpolateElement","useMemo","useState","dateI18n","getDate","getSettings","trash","drafts","published","scheduled","pending","notAllowed","commentAuthorAvatar","authorIcon","__experimentalHStack","HStack","Icon","useSelect","useEntityRecords","store","coreStore","LAYOUT_GRID","LAYOUT_TABLE","LAYOUT_LIST","OPERATOR_IS_ANY","default","Link","useLink","Media","jsx","_jsx","jsxs","_jsxs","STATUSES","value","label","icon","getFormattedDate","dateToDisplay","formats","datetimeAbbreviated","FeaturedImage","item","viewType","isDisabled","status","onClick","postId","id","postType","type","canvas","hasMedia","featured_media","size","media","className","renderButton","children","title","rendered","PostStatusField","find","alignment","spacing","PostAuthorField","text","imageUrl","select","getUser","user","author","avatar_urls","name","isImageLoaded","setIsImageLoaded","onLoad","alt","src","usePostFields","records","authors","isResolving","isLoadingAuthors","per_page","frontPageId","postsPageId","getEntityRecord","siteSettings","page_on_front","page_for_posts","fields","getValue","render","enableSorting","raw","addLink","includes","renderedTitle","params","suffix","justify","enableHiding","elements","map","sort","a","b","direction","nameA","_embedded","nameB","localeCompare","_STATUSES$find$label","filterBy","operators","isDraftOrPrivate","date","span","time","isScheduled","isPublished","modified","isPending","isLoading"],"sources":["@wordpress/edit-site/src/components/post-fields/index.js"],"sourcesContent":["/**\n * External dependencies\n */\nimport clsx from 'clsx';\n\n/**\n * WordPress dependencies\n */\nimport { __, sprintf } from '@wordpress/i18n';\nimport { decodeEntities } from '@wordpress/html-entities';\nimport {\n\tcreateInterpolateElement,\n\tuseMemo,\n\tuseState,\n} from '@wordpress/element';\nimport { dateI18n, getDate, getSettings } from '@wordpress/date';\nimport {\n\ttrash,\n\tdrafts,\n\tpublished,\n\tscheduled,\n\tpending,\n\tnotAllowed,\n\tcommentAuthorAvatar as authorIcon,\n} from '@wordpress/icons';\nimport { __experimentalHStack as HStack, Icon } from '@wordpress/components';\nimport { useSelect } from '@wordpress/data';\nimport { useEntityRecords, store as coreStore } from '@wordpress/core-data';\n\n/**\n * Internal dependencies\n */\nimport {\n\tLAYOUT_GRID,\n\tLAYOUT_TABLE,\n\tLAYOUT_LIST,\n\tOPERATOR_IS_ANY,\n} from '../../utils/constants';\nimport { default as Link, useLink } from '../routes/link';\nimport Media from '../media';\n\n// See https://github.com/WordPress/gutenberg/issues/55886\n// We do not support custom statutes at the moment.\nconst STATUSES = [\n\t{ value: 'draft', label: __( 'Draft' ), icon: drafts },\n\t{ value: 'future', label: __( 'Scheduled' ), icon: scheduled },\n\t{ value: 'pending', label: __( 'Pending Review' ), icon: pending },\n\t{ value: 'private', label: __( 'Private' ), icon: notAllowed },\n\t{ value: 'publish', label: __( 'Published' ), icon: published },\n\t{ value: 'trash', label: __( 'Trash' ), icon: trash },\n];\n\nconst getFormattedDate = ( dateToDisplay ) =>\n\tdateI18n(\n\t\tgetSettings().formats.datetimeAbbreviated,\n\t\tgetDate( dateToDisplay )\n\t);\n\nfunction FeaturedImage( { item, viewType } ) {\n\tconst isDisabled = item.status === 'trash';\n\tconst { onClick } = useLink( {\n\t\tpostId: item.id,\n\t\tpostType: item.type,\n\t\tcanvas: 'edit',\n\t} );\n\tconst hasMedia = !! item.featured_media;\n\tconst size =\n\t\tviewType === LAYOUT_GRID\n\t\t\t? [ 'large', 'full', 'medium', 'thumbnail' ]\n\t\t\t: [ 'thumbnail', 'medium', 'large', 'full' ];\n\tconst media = hasMedia ? (\n\t\t<Media\n\t\t\tclassName=\"edit-site-post-list__featured-image\"\n\t\t\tid={ item.featured_media }\n\t\t\tsize={ size }\n\t\t/>\n\t) : null;\n\tconst renderButton = viewType !== LAYOUT_LIST && ! isDisabled;\n\treturn (\n\t\t<div\n\t\t\tclassName={ `edit-site-post-list__featured-image-wrapper is-layout-${ viewType }` }\n\t\t>\n\t\t\t{ renderButton ? (\n\t\t\t\t<button\n\t\t\t\t\tclassName=\"edit-site-post-list__featured-image-button\"\n\t\t\t\t\ttype=\"button\"\n\t\t\t\t\tonClick={ onClick }\n\t\t\t\t\taria-label={ item.title?.rendered || __( '(no title)' ) }\n\t\t\t\t>\n\t\t\t\t\t{ media }\n\t\t\t\t</button>\n\t\t\t) : (\n\t\t\t\tmedia\n\t\t\t) }\n\t\t</div>\n\t);\n}\n\nfunction PostStatusField( { item } ) {\n\tconst status = STATUSES.find( ( { value } ) => value === item.status );\n\tconst label = status?.label || item.status;\n\tconst icon = status?.icon;\n\treturn (\n\t\t<HStack alignment=\"left\" spacing={ 0 }>\n\t\t\t{ icon && (\n\t\t\t\t<div className=\"edit-site-post-list__status-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>{ label }</span>\n\t\t</HStack>\n\t);\n}\n\nfunction PostAuthorField( { item } ) {\n\tconst { text, imageUrl } = useSelect(\n\t\t( select ) => {\n\t\t\tconst { getUser } = select( coreStore );\n\t\t\tconst user = getUser( item.author );\n\t\t\treturn {\n\t\t\t\timageUrl: user?.avatar_urls?.[ 48 ],\n\t\t\t\ttext: user?.name,\n\t\t\t};\n\t\t},\n\t\t[ item ]\n\t);\n\tconst [ isImageLoaded, setIsImageLoaded ] = useState( false );\n\treturn (\n\t\t<HStack alignment=\"left\" spacing={ 0 }>\n\t\t\t{ !! imageUrl && (\n\t\t\t\t<div\n\t\t\t\t\tclassName={ clsx( 'page-templates-author-field__avatar', {\n\t\t\t\t\t\t'is-loaded': isImageLoaded,\n\t\t\t\t\t} ) }\n\t\t\t\t>\n\t\t\t\t\t<img\n\t\t\t\t\t\tonLoad={ () => setIsImageLoaded( true ) }\n\t\t\t\t\t\talt={ __( 'Author avatar' ) }\n\t\t\t\t\t\tsrc={ imageUrl }\n\t\t\t\t\t/>\n\t\t\t\t</div>\n\t\t\t) }\n\t\t\t{ ! imageUrl && (\n\t\t\t\t<div className=\"page-templates-author-field__icon\">\n\t\t\t\t\t<Icon icon={ authorIcon } />\n\t\t\t\t</div>\n\t\t\t) }\n\t\t\t<span className=\"page-templates-author-field__name\">{ text }</span>\n\t\t</HStack>\n\t);\n}\n\nfunction usePostFields( viewType ) {\n\tconst { records: authors, isResolving: isLoadingAuthors } =\n\t\tuseEntityRecords( 'root', 'user', { per_page: -1 } );\n\n\tconst { frontPageId, postsPageId } = useSelect( ( select ) => {\n\t\tconst { getEntityRecord } = select( coreStore );\n\t\tconst siteSettings = getEntityRecord( 'root', 'site' );\n\t\treturn {\n\t\t\tfrontPageId: siteSettings?.page_on_front,\n\t\t\tpostsPageId: siteSettings?.page_for_posts,\n\t\t};\n\t}, [] );\n\n\tconst fields = useMemo(\n\t\t() => [\n\t\t\t{\n\t\t\t\tid: 'featured-image',\n\t\t\t\tlabel: __( 'Featured Image' ),\n\t\t\t\tgetValue: ( { item } ) => item.featured_media,\n\t\t\t\trender: ( { item } ) => (\n\t\t\t\t\t<FeaturedImage item={ item } viewType={ viewType } />\n\t\t\t\t),\n\t\t\t\tenableSorting: false,\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: __( 'Title' ),\n\t\t\t\tid: 'title',\n\t\t\t\ttype: 'text',\n\t\t\t\tgetValue: ( { item } ) =>\n\t\t\t\t\ttypeof item.title === 'string'\n\t\t\t\t\t\t? item.title\n\t\t\t\t\t\t: item.title?.raw,\n\t\t\t\trender: ( { item } ) => {\n\t\t\t\t\tconst addLink =\n\t\t\t\t\t\t[ LAYOUT_TABLE, LAYOUT_GRID ].includes( viewType ) &&\n\t\t\t\t\t\titem.status !== 'trash';\n\t\t\t\t\tconst renderedTitle =\n\t\t\t\t\t\ttypeof item.title === 'string'\n\t\t\t\t\t\t\t? item.title\n\t\t\t\t\t\t\t: item.title?.rendered;\n\t\t\t\t\tconst title = addLink ? (\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: item.id,\n\t\t\t\t\t\t\t\tpostType: item.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( renderedTitle ) ||\n\t\t\t\t\t\t\t\t__( '(no title)' ) }\n\t\t\t\t\t\t</Link>\n\t\t\t\t\t) : (\n\t\t\t\t\t\t<span>\n\t\t\t\t\t\t\t{ decodeEntities( renderedTitle ) ||\n\t\t\t\t\t\t\t\t__( '(no title)' ) }\n\t\t\t\t\t\t</span>\n\t\t\t\t\t);\n\n\t\t\t\t\tlet suffix = '';\n\t\t\t\t\tif ( item.id === frontPageId ) {\n\t\t\t\t\t\tsuffix = (\n\t\t\t\t\t\t\t<span className=\"edit-site-post-list__title-badge\">\n\t\t\t\t\t\t\t\t{ __( 'Homepage' ) }\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t);\n\t\t\t\t\t} else if ( item.id === postsPageId ) {\n\t\t\t\t\t\tsuffix = (\n\t\t\t\t\t\t\t<span className=\"edit-site-post-list__title-badge\">\n\t\t\t\t\t\t\t\t{ __( 'Posts Page' ) }\n\t\t\t\t\t\t\t</span>\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\treturn (\n\t\t\t\t\t\t<HStack\n\t\t\t\t\t\t\tclassName=\"edit-site-post-list__title\"\n\t\t\t\t\t\t\talignment=\"center\"\n\t\t\t\t\t\t\tjustify=\"flex-start\"\n\t\t\t\t\t\t>\n\t\t\t\t\t\t\t{ title }\n\t\t\t\t\t\t\t{ suffix }\n\t\t\t\t\t\t</HStack>\n\t\t\t\t\t);\n\t\t\t\t},\n\t\t\t\tenableHiding: false,\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: __( 'Author' ),\n\t\t\t\tid: 'author',\n\t\t\t\ttype: 'integer',\n\t\t\t\telements:\n\t\t\t\t\tauthors?.map( ( { id, name } ) => ( {\n\t\t\t\t\t\tvalue: id,\n\t\t\t\t\t\tlabel: name,\n\t\t\t\t\t} ) ) || [],\n\t\t\t\trender: PostAuthorField,\n\t\t\t\tsort: ( a, b, direction ) => {\n\t\t\t\t\tconst nameA = a._embedded?.author?.[ 0 ]?.name || '';\n\t\t\t\t\tconst nameB = b._embedded?.author?.[ 0 ]?.name || '';\n\n\t\t\t\t\treturn direction === 'asc'\n\t\t\t\t\t\t? nameA.localeCompare( nameB )\n\t\t\t\t\t\t: nameB.localeCompare( nameA );\n\t\t\t\t},\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: __( 'Status' ),\n\t\t\t\tid: 'status',\n\t\t\t\tgetValue: ( { item } ) =>\n\t\t\t\t\tSTATUSES.find( ( { value } ) => value === item.status )\n\t\t\t\t\t\t?.label ?? item.status,\n\t\t\t\telements: STATUSES,\n\t\t\t\trender: PostStatusField,\n\t\t\t\tenableSorting: false,\n\t\t\t\tfilterBy: {\n\t\t\t\t\toperators: [ OPERATOR_IS_ANY ],\n\t\t\t\t},\n\t\t\t},\n\t\t\t{\n\t\t\t\tlabel: __( 'Date' ),\n\t\t\t\tid: 'date',\n\t\t\t\trender: ( { item } ) => {\n\t\t\t\t\tconst isDraftOrPrivate = [ 'draft', 'private' ].includes(\n\t\t\t\t\t\titem.status\n\t\t\t\t\t);\n\t\t\t\t\tif ( isDraftOrPrivate ) {\n\t\t\t\t\t\treturn createInterpolateElement(\n\t\t\t\t\t\t\tsprintf(\n\t\t\t\t\t\t\t\t/* translators: %s: page creation date */\n\t\t\t\t\t\t\t\t__( '<span>Modified: <time>%s</time></span>' ),\n\t\t\t\t\t\t\t\tgetFormattedDate( item.date )\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tspan: <span />,\n\t\t\t\t\t\t\t\ttime: <time />,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tconst isScheduled = item.status === 'future';\n\t\t\t\t\tif ( isScheduled ) {\n\t\t\t\t\t\treturn createInterpolateElement(\n\t\t\t\t\t\t\tsprintf(\n\t\t\t\t\t\t\t\t/* translators: %s: page creation date */\n\t\t\t\t\t\t\t\t__( '<span>Scheduled: <time>%s</time></span>' ),\n\t\t\t\t\t\t\t\tgetFormattedDate( item.date )\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tspan: <span />,\n\t\t\t\t\t\t\t\ttime: <time />,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\tconst isPublished = item.status === 'publish';\n\t\t\t\t\tif ( isPublished ) {\n\t\t\t\t\t\treturn createInterpolateElement(\n\t\t\t\t\t\t\tsprintf(\n\t\t\t\t\t\t\t\t/* translators: %s: page creation time */\n\t\t\t\t\t\t\t\t__( '<span>Published: <time>%s</time></span>' ),\n\t\t\t\t\t\t\t\tgetFormattedDate( item.date )\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tspan: <span />,\n\t\t\t\t\t\t\t\ttime: <time />,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Pending posts show the modified date if it's newer.\n\t\t\t\t\tconst dateToDisplay =\n\t\t\t\t\t\tgetDate( item.modified ) > getDate( item.date )\n\t\t\t\t\t\t\t? item.modified\n\t\t\t\t\t\t\t: item.date;\n\n\t\t\t\t\tconst isPending = item.status === 'pending';\n\t\t\t\t\tif ( isPending ) {\n\t\t\t\t\t\treturn createInterpolateElement(\n\t\t\t\t\t\t\tsprintf(\n\t\t\t\t\t\t\t\t/* translators: %s: the newest of created or modified date for the page */\n\t\t\t\t\t\t\t\t__( '<span>Modified: <time>%s</time></span>' ),\n\t\t\t\t\t\t\t\tgetFormattedDate( dateToDisplay )\n\t\t\t\t\t\t\t),\n\t\t\t\t\t\t\t{\n\t\t\t\t\t\t\t\tspan: <span />,\n\t\t\t\t\t\t\t\ttime: <time />,\n\t\t\t\t\t\t\t}\n\t\t\t\t\t\t);\n\t\t\t\t\t}\n\n\t\t\t\t\t// Unknow status.\n\t\t\t\t\treturn <time>{ getFormattedDate( item.date ) }</time>;\n\t\t\t\t},\n\t\t\t},\n\t\t],\n\t\t[ authors, viewType, frontPageId, postsPageId ]\n\t);\n\n\treturn {\n\t\tisLoading: isLoadingAuthors,\n\t\tfields,\n\t};\n}\n\nexport default usePostFields;\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,333 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { Button } from '@wordpress/components';
|
|
5
|
+
import { store as coreStore, privateApis as coreDataPrivateApis } from '@wordpress/core-data';
|
|
6
|
+
import { useState, useMemo, useCallback, useEffect } from '@wordpress/element';
|
|
7
|
+
import { privateApis as routerPrivateApis } from '@wordpress/router';
|
|
8
|
+
import { useSelect, useDispatch } from '@wordpress/data';
|
|
9
|
+
import { DataViews, filterSortAndPaginate } from '@wordpress/dataviews';
|
|
10
|
+
import { privateApis as editorPrivateApis } from '@wordpress/editor';
|
|
11
|
+
import { __ } from '@wordpress/i18n';
|
|
12
|
+
import { drawerRight } from '@wordpress/icons';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* Internal dependencies
|
|
16
|
+
*/
|
|
17
|
+
import Page from '../page';
|
|
18
|
+
import { useDefaultViews, defaultLayouts } from '../sidebar-dataviews/default-views';
|
|
19
|
+
import { OPERATOR_IS_ANY, OPERATOR_IS_NONE, LAYOUT_LIST } from '../../utils/constants';
|
|
20
|
+
import AddNewPostModal from '../add-new-post';
|
|
21
|
+
import { unlock } from '../../lock-unlock';
|
|
22
|
+
import { useEditPostAction } from '../dataviews-actions';
|
|
23
|
+
import { usePrevious } from '@wordpress/compose';
|
|
24
|
+
import usePostFields from '../post-fields';
|
|
25
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
26
|
+
import { Fragment as _Fragment } from "react/jsx-runtime";
|
|
27
|
+
import { jsxs as _jsxs } from "react/jsx-runtime";
|
|
28
|
+
const {
|
|
29
|
+
usePostActions
|
|
30
|
+
} = unlock(editorPrivateApis);
|
|
31
|
+
const {
|
|
32
|
+
useLocation,
|
|
33
|
+
useHistory
|
|
34
|
+
} = unlock(routerPrivateApis);
|
|
35
|
+
const {
|
|
36
|
+
useEntityRecordsWithPermissions
|
|
37
|
+
} = unlock(coreDataPrivateApis);
|
|
38
|
+
const EMPTY_ARRAY = [];
|
|
39
|
+
const getDefaultView = (defaultViews, activeView) => {
|
|
40
|
+
return defaultViews.find(({
|
|
41
|
+
slug
|
|
42
|
+
}) => slug === activeView)?.view;
|
|
43
|
+
};
|
|
44
|
+
const getCustomView = editedEntityRecord => {
|
|
45
|
+
if (!editedEntityRecord?.content) {
|
|
46
|
+
return undefined;
|
|
47
|
+
}
|
|
48
|
+
const content = JSON.parse(editedEntityRecord.content);
|
|
49
|
+
if (!content) {
|
|
50
|
+
return undefined;
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
...content,
|
|
54
|
+
layout: defaultLayouts[content.type]?.layout
|
|
55
|
+
};
|
|
56
|
+
};
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* This function abstracts working with default & custom views by
|
|
60
|
+
* providing a [ state, setState ] tuple based on the URL parameters.
|
|
61
|
+
*
|
|
62
|
+
* Consumers use the provided tuple to work with state
|
|
63
|
+
* and don't have to deal with the specifics of default & custom views.
|
|
64
|
+
*
|
|
65
|
+
* @param {string} postType Post type to retrieve default views for.
|
|
66
|
+
* @return {Array} The [ state, setState ] tuple.
|
|
67
|
+
*/
|
|
68
|
+
function useView(postType) {
|
|
69
|
+
const {
|
|
70
|
+
params: {
|
|
71
|
+
activeView = 'all',
|
|
72
|
+
isCustom = 'false',
|
|
73
|
+
layout
|
|
74
|
+
}
|
|
75
|
+
} = useLocation();
|
|
76
|
+
const history = useHistory();
|
|
77
|
+
const defaultViews = useDefaultViews({
|
|
78
|
+
postType
|
|
79
|
+
});
|
|
80
|
+
const {
|
|
81
|
+
editEntityRecord
|
|
82
|
+
} = useDispatch(coreStore);
|
|
83
|
+
const editedEntityRecord = useSelect(select => {
|
|
84
|
+
if (isCustom !== 'true') {
|
|
85
|
+
return undefined;
|
|
86
|
+
}
|
|
87
|
+
const {
|
|
88
|
+
getEditedEntityRecord
|
|
89
|
+
} = select(coreStore);
|
|
90
|
+
return getEditedEntityRecord('postType', 'wp_dataviews', Number(activeView));
|
|
91
|
+
}, [activeView, isCustom]);
|
|
92
|
+
const [view, setView] = useState(() => {
|
|
93
|
+
let initialView;
|
|
94
|
+
if (isCustom === 'true') {
|
|
95
|
+
var _getCustomView;
|
|
96
|
+
initialView = (_getCustomView = getCustomView(editedEntityRecord)) !== null && _getCustomView !== void 0 ? _getCustomView : {
|
|
97
|
+
type: layout !== null && layout !== void 0 ? layout : LAYOUT_LIST
|
|
98
|
+
};
|
|
99
|
+
} else {
|
|
100
|
+
var _getDefaultView;
|
|
101
|
+
initialView = (_getDefaultView = getDefaultView(defaultViews, activeView)) !== null && _getDefaultView !== void 0 ? _getDefaultView : {
|
|
102
|
+
type: layout !== null && layout !== void 0 ? layout : LAYOUT_LIST
|
|
103
|
+
};
|
|
104
|
+
}
|
|
105
|
+
const type = layout !== null && layout !== void 0 ? layout : initialView.type;
|
|
106
|
+
return {
|
|
107
|
+
...initialView,
|
|
108
|
+
type
|
|
109
|
+
};
|
|
110
|
+
});
|
|
111
|
+
const setViewWithUrlUpdate = useCallback(newView => {
|
|
112
|
+
const {
|
|
113
|
+
params
|
|
114
|
+
} = history.getLocationWithParams();
|
|
115
|
+
if (newView.type === LAYOUT_LIST && !params?.layout) {
|
|
116
|
+
// Skip updating the layout URL param if
|
|
117
|
+
// it is not present and the newView.type is LAYOUT_LIST.
|
|
118
|
+
} else if (newView.type !== params?.layout) {
|
|
119
|
+
history.push({
|
|
120
|
+
...params,
|
|
121
|
+
layout: newView.type
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
setView(newView);
|
|
125
|
+
if (isCustom === 'true' && editedEntityRecord?.id) {
|
|
126
|
+
editEntityRecord('postType', 'wp_dataviews', editedEntityRecord?.id, {
|
|
127
|
+
content: JSON.stringify(newView)
|
|
128
|
+
});
|
|
129
|
+
}
|
|
130
|
+
}, [history, isCustom, editEntityRecord, editedEntityRecord?.id]);
|
|
131
|
+
|
|
132
|
+
// When layout URL param changes, update the view type
|
|
133
|
+
// without affecting any other config.
|
|
134
|
+
useEffect(() => {
|
|
135
|
+
setView(prevView => ({
|
|
136
|
+
...prevView,
|
|
137
|
+
type: layout !== null && layout !== void 0 ? layout : LAYOUT_LIST
|
|
138
|
+
}));
|
|
139
|
+
}, [layout]);
|
|
140
|
+
|
|
141
|
+
// When activeView or isCustom URL parameters change, reset the view.
|
|
142
|
+
useEffect(() => {
|
|
143
|
+
let newView;
|
|
144
|
+
if (isCustom === 'true') {
|
|
145
|
+
newView = getCustomView(editedEntityRecord);
|
|
146
|
+
} else {
|
|
147
|
+
newView = getDefaultView(defaultViews, activeView);
|
|
148
|
+
}
|
|
149
|
+
if (newView) {
|
|
150
|
+
const type = layout !== null && layout !== void 0 ? layout : newView.type;
|
|
151
|
+
setView({
|
|
152
|
+
...newView,
|
|
153
|
+
type
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
}, [activeView, isCustom, layout, defaultViews, editedEntityRecord]);
|
|
157
|
+
return [view, setViewWithUrlUpdate, setViewWithUrlUpdate];
|
|
158
|
+
}
|
|
159
|
+
const DEFAULT_STATUSES = 'draft,future,pending,private,publish'; // All but 'trash'.
|
|
160
|
+
|
|
161
|
+
function getItemId(item) {
|
|
162
|
+
return item.id.toString();
|
|
163
|
+
}
|
|
164
|
+
export default function PostList({
|
|
165
|
+
postType
|
|
166
|
+
}) {
|
|
167
|
+
var _postId$split, _data$map, _usePrevious;
|
|
168
|
+
const [view, setView] = useView(postType);
|
|
169
|
+
const history = useHistory();
|
|
170
|
+
const location = useLocation();
|
|
171
|
+
const {
|
|
172
|
+
postId,
|
|
173
|
+
quickEdit = false,
|
|
174
|
+
isCustom,
|
|
175
|
+
activeView = 'all'
|
|
176
|
+
} = location.params;
|
|
177
|
+
const [selection, setSelection] = useState((_postId$split = postId?.split(',')) !== null && _postId$split !== void 0 ? _postId$split : []);
|
|
178
|
+
const onChangeSelection = useCallback(items => {
|
|
179
|
+
var _params$isCustom;
|
|
180
|
+
setSelection(items);
|
|
181
|
+
const {
|
|
182
|
+
params
|
|
183
|
+
} = history.getLocationWithParams();
|
|
184
|
+
if (((_params$isCustom = params.isCustom) !== null && _params$isCustom !== void 0 ? _params$isCustom : 'false') === 'false') {
|
|
185
|
+
history.push({
|
|
186
|
+
...params,
|
|
187
|
+
postId: items.join(',')
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
}, [history]);
|
|
191
|
+
const {
|
|
192
|
+
isLoading: isLoadingFields,
|
|
193
|
+
fields
|
|
194
|
+
} = usePostFields(view.type);
|
|
195
|
+
const queryArgs = useMemo(() => {
|
|
196
|
+
const filters = {};
|
|
197
|
+
view.filters?.forEach(filter => {
|
|
198
|
+
if (filter.field === 'status' && filter.operator === OPERATOR_IS_ANY) {
|
|
199
|
+
filters.status = filter.value;
|
|
200
|
+
}
|
|
201
|
+
if (filter.field === 'author' && filter.operator === OPERATOR_IS_ANY) {
|
|
202
|
+
filters.author = filter.value;
|
|
203
|
+
} else if (filter.field === 'author' && filter.operator === OPERATOR_IS_NONE) {
|
|
204
|
+
filters.author_exclude = filter.value;
|
|
205
|
+
}
|
|
206
|
+
});
|
|
207
|
+
// We want to provide a different default item for the status filter
|
|
208
|
+
// than the REST API provides.
|
|
209
|
+
if (!filters.status || filters.status === '') {
|
|
210
|
+
filters.status = DEFAULT_STATUSES;
|
|
211
|
+
}
|
|
212
|
+
return {
|
|
213
|
+
per_page: view.perPage,
|
|
214
|
+
page: view.page,
|
|
215
|
+
_embed: 'author',
|
|
216
|
+
order: view.sort?.direction,
|
|
217
|
+
orderby: view.sort?.field,
|
|
218
|
+
search: view.search,
|
|
219
|
+
...filters
|
|
220
|
+
};
|
|
221
|
+
}, [view]);
|
|
222
|
+
const {
|
|
223
|
+
records,
|
|
224
|
+
isResolving: isLoadingData,
|
|
225
|
+
totalItems,
|
|
226
|
+
totalPages
|
|
227
|
+
} = useEntityRecordsWithPermissions('postType', postType, queryArgs);
|
|
228
|
+
|
|
229
|
+
// The REST API sort the authors by ID, but we want to sort them by name.
|
|
230
|
+
const data = useMemo(() => {
|
|
231
|
+
if (!isLoadingFields && view?.sort?.field === 'author') {
|
|
232
|
+
return filterSortAndPaginate(records, {
|
|
233
|
+
sort: {
|
|
234
|
+
...view.sort
|
|
235
|
+
}
|
|
236
|
+
}, fields).data;
|
|
237
|
+
}
|
|
238
|
+
return records;
|
|
239
|
+
}, [records, fields, isLoadingFields, view?.sort]);
|
|
240
|
+
const ids = (_data$map = data?.map(record => getItemId(record))) !== null && _data$map !== void 0 ? _data$map : [];
|
|
241
|
+
const prevIds = (_usePrevious = usePrevious(ids)) !== null && _usePrevious !== void 0 ? _usePrevious : [];
|
|
242
|
+
const deletedIds = prevIds.filter(id => !ids.includes(id));
|
|
243
|
+
const postIdWasDeleted = deletedIds.includes(postId);
|
|
244
|
+
useEffect(() => {
|
|
245
|
+
if (postIdWasDeleted) {
|
|
246
|
+
history.push({
|
|
247
|
+
...history.getLocationWithParams().params,
|
|
248
|
+
postId: undefined
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
}, [postIdWasDeleted, history]);
|
|
252
|
+
const paginationInfo = useMemo(() => ({
|
|
253
|
+
totalItems,
|
|
254
|
+
totalPages
|
|
255
|
+
}), [totalItems, totalPages]);
|
|
256
|
+
const {
|
|
257
|
+
labels,
|
|
258
|
+
canCreateRecord
|
|
259
|
+
} = useSelect(select => {
|
|
260
|
+
const {
|
|
261
|
+
getPostType,
|
|
262
|
+
canUser
|
|
263
|
+
} = select(coreStore);
|
|
264
|
+
return {
|
|
265
|
+
labels: getPostType(postType)?.labels,
|
|
266
|
+
canCreateRecord: canUser('create', {
|
|
267
|
+
kind: 'postType',
|
|
268
|
+
name: postType
|
|
269
|
+
})
|
|
270
|
+
};
|
|
271
|
+
}, [postType]);
|
|
272
|
+
const postTypeActions = usePostActions({
|
|
273
|
+
postType,
|
|
274
|
+
context: 'list'
|
|
275
|
+
});
|
|
276
|
+
const editAction = useEditPostAction();
|
|
277
|
+
const actions = useMemo(() => [editAction, ...postTypeActions], [postTypeActions, editAction]);
|
|
278
|
+
const [showAddPostModal, setShowAddPostModal] = useState(false);
|
|
279
|
+
const openModal = () => setShowAddPostModal(true);
|
|
280
|
+
const closeModal = () => setShowAddPostModal(false);
|
|
281
|
+
const handleNewPage = ({
|
|
282
|
+
type,
|
|
283
|
+
id
|
|
284
|
+
}) => {
|
|
285
|
+
history.push({
|
|
286
|
+
postId: id,
|
|
287
|
+
postType: type,
|
|
288
|
+
canvas: 'edit'
|
|
289
|
+
});
|
|
290
|
+
closeModal();
|
|
291
|
+
};
|
|
292
|
+
return /*#__PURE__*/_jsx(Page, {
|
|
293
|
+
title: labels?.name,
|
|
294
|
+
actions: labels?.add_new_item && canCreateRecord && /*#__PURE__*/_jsxs(_Fragment, {
|
|
295
|
+
children: [/*#__PURE__*/_jsx(Button, {
|
|
296
|
+
variant: "primary",
|
|
297
|
+
onClick: openModal,
|
|
298
|
+
__next40pxDefaultSize: true,
|
|
299
|
+
children: labels.add_new_item
|
|
300
|
+
}), showAddPostModal && /*#__PURE__*/_jsx(AddNewPostModal, {
|
|
301
|
+
postType: postType,
|
|
302
|
+
onSave: handleNewPage,
|
|
303
|
+
onClose: closeModal
|
|
304
|
+
})]
|
|
305
|
+
}),
|
|
306
|
+
children: /*#__PURE__*/_jsx(DataViews, {
|
|
307
|
+
paginationInfo: paginationInfo,
|
|
308
|
+
fields: fields,
|
|
309
|
+
actions: actions,
|
|
310
|
+
data: data || EMPTY_ARRAY,
|
|
311
|
+
isLoading: isLoadingData || isLoadingFields,
|
|
312
|
+
view: view,
|
|
313
|
+
onChangeView: setView,
|
|
314
|
+
selection: selection,
|
|
315
|
+
onChangeSelection: onChangeSelection,
|
|
316
|
+
getItemId: getItemId,
|
|
317
|
+
defaultLayouts: defaultLayouts,
|
|
318
|
+
header: window.__experimentalQuickEditDataViews && view.type !== LAYOUT_LIST && postType === 'page' && /*#__PURE__*/_jsx(Button, {
|
|
319
|
+
size: "compact",
|
|
320
|
+
isPressed: quickEdit,
|
|
321
|
+
icon: drawerRight,
|
|
322
|
+
label: !quickEdit ? __('Show quick edit sidebar') : __('Close quick edit sidebar'),
|
|
323
|
+
onClick: () => {
|
|
324
|
+
history.push({
|
|
325
|
+
...location.params,
|
|
326
|
+
quickEdit: quickEdit ? undefined : true
|
|
327
|
+
});
|
|
328
|
+
}
|
|
329
|
+
})
|
|
330
|
+
}, activeView + isCustom)
|
|
331
|
+
});
|
|
332
|
+
}
|
|
333
|
+
//# sourceMappingURL=index.js.map
|