@wordpress/edit-site 5.20.1 → 5.21.1-next.f8d8eceb.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 +2 -0
- package/build/components/actions/index.js +121 -0
- package/build/components/actions/index.js.map +1 -0
- package/build/components/add-new-template/add-custom-template-modal-content.js +17 -13
- package/build/components/add-new-template/add-custom-template-modal-content.js.map +1 -1
- package/build/components/block-editor/resize-handle.js +2 -1
- package/build/components/block-editor/resize-handle.js.map +1 -1
- package/build/components/block-editor/use-site-editor-settings.js +12 -4
- package/build/components/block-editor/use-site-editor-settings.js.map +1 -1
- package/build/components/create-template-part-modal/index.js +10 -6
- package/build/components/create-template-part-modal/index.js.map +1 -1
- package/build/components/dataviews/context.js +15 -0
- package/build/components/dataviews/context.js.map +1 -0
- package/build/components/dataviews/dataviews.js +50 -33
- package/build/components/dataviews/dataviews.js.map +1 -1
- package/build/components/dataviews/filters.js +74 -0
- package/build/components/dataviews/filters.js.map +1 -0
- package/build/components/dataviews/in-filter.js +49 -0
- package/build/components/dataviews/in-filter.js.map +1 -0
- package/build/components/dataviews/index.js +0 -7
- package/build/components/dataviews/index.js.map +1 -1
- package/build/components/dataviews/item-actions.js +62 -0
- package/build/components/dataviews/item-actions.js.map +1 -0
- package/build/components/dataviews/pagination.js +74 -45
- package/build/components/dataviews/pagination.js.map +1 -1
- package/build/components/dataviews/{text-filter.js → search.js} +21 -15
- package/build/components/dataviews/search.js.map +1 -0
- package/build/components/dataviews/view-actions.js +94 -56
- package/build/components/dataviews/view-actions.js.map +1 -1
- package/build/components/dataviews/view-grid.js +59 -0
- package/build/components/dataviews/view-grid.js.map +1 -0
- package/build/components/dataviews/view-list.js +283 -0
- package/build/components/dataviews/view-list.js.map +1 -0
- package/build/components/editor/index.js +2 -1
- package/build/components/editor/index.js.map +1 -1
- package/build/components/global-styles/font-library-modal/context.js +16 -10
- package/build/components/global-styles/font-library-modal/context.js.map +1 -1
- package/build/components/global-styles/font-library-modal/font-collection.js +20 -6
- package/build/components/global-styles/font-library-modal/font-collection.js.map +1 -1
- package/build/components/global-styles/screen-block.js +2 -10
- package/build/components/global-styles/screen-block.js.map +1 -1
- package/build/components/global-styles/screen-root.js +1 -2
- package/build/components/global-styles/screen-root.js.map +1 -1
- package/build/components/global-styles/ui.js +3 -4
- package/build/components/global-styles/ui.js.map +1 -1
- package/build/components/layout/index.js +10 -2
- package/build/components/layout/index.js.map +1 -1
- package/build/components/media/index.js +34 -0
- package/build/components/media/index.js.map +1 -0
- package/build/components/page-actions/index.js +0 -2
- package/build/components/page-actions/index.js.map +1 -1
- package/build/components/page-pages/default-views.js +60 -0
- package/build/components/page-pages/default-views.js.map +1 -0
- package/build/components/page-pages/index.js +174 -107
- package/build/components/page-pages/index.js.map +1 -1
- package/build/components/page-patterns/delete-category-menu-item.js +89 -0
- package/build/components/page-patterns/delete-category-menu-item.js.map +1 -0
- package/build/components/page-patterns/duplicate-menu-item.js +52 -131
- package/build/components/page-patterns/duplicate-menu-item.js.map +1 -1
- package/build/components/page-patterns/grid-item.js +1 -0
- package/build/components/page-patterns/grid-item.js.map +1 -1
- package/build/components/page-patterns/header.js +25 -3
- package/build/components/page-patterns/header.js.map +1 -1
- package/build/components/page-patterns/rename-category-menu-item.js +49 -0
- package/build/components/page-patterns/rename-category-menu-item.js.map +1 -0
- package/build/components/page-patterns/rename-menu-item.js +1 -1
- package/build/components/page-patterns/rename-menu-item.js.map +1 -1
- package/build/components/page-patterns/use-patterns.js +1 -0
- package/build/components/page-patterns/use-patterns.js.map +1 -1
- package/build/components/pattern-modal/duplicate.js +65 -0
- package/build/components/pattern-modal/duplicate.js.map +1 -0
- package/build/components/pattern-modal/index.js +24 -0
- package/build/components/pattern-modal/index.js.map +1 -0
- package/build/components/pattern-modal/rename.js +42 -0
- package/build/components/pattern-modal/rename.js.map +1 -0
- package/build/components/sidebar/index.js +3 -1
- package/build/components/sidebar/index.js.map +1 -1
- package/build/components/sidebar-dataviews/index.js +72 -0
- package/build/components/sidebar-dataviews/index.js.map +1 -0
- package/build/components/sidebar-edit-mode/template-panel/last-revision.js +3 -0
- package/build/components/sidebar-edit-mode/template-panel/last-revision.js.map +1 -1
- package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js +2 -2
- package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js.map +1 -1
- package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +2 -3
- package/build/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
- package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-title.js +29 -0
- package/build/components/sidebar-navigation-screen-pattern/use-navigation-menu-title.js.map +1 -0
- package/build/components/sidebar-navigation-screen-template/home-template-details.js +12 -1
- package/build/components/sidebar-navigation-screen-template/home-template-details.js.map +1 -1
- package/build/hooks/commands/use-common-commands.js +1 -2
- package/build/hooks/commands/use-common-commands.js.map +1 -1
- package/build/hooks/commands/use-edit-mode-commands.js +50 -0
- package/build/hooks/commands/use-edit-mode-commands.js.map +1 -1
- package/build/lock-unlock.js +1 -1
- package/build/lock-unlock.js.map +1 -1
- package/build/store/selectors.js +4 -5
- package/build/store/selectors.js.map +1 -1
- package/build-module/components/actions/index.js +108 -0
- package/build-module/components/actions/index.js.map +1 -0
- package/build-module/components/add-new-template/add-custom-template-modal-content.js +16 -12
- package/build-module/components/add-new-template/add-custom-template-modal-content.js.map +1 -1
- package/build-module/components/block-editor/resize-handle.js +2 -1
- package/build-module/components/block-editor/resize-handle.js.map +1 -1
- package/build-module/components/block-editor/use-site-editor-settings.js +12 -4
- package/build-module/components/block-editor/use-site-editor-settings.js.map +1 -1
- package/build-module/components/create-template-part-modal/index.js +10 -6
- package/build-module/components/create-template-part-modal/index.js.map +1 -1
- package/build-module/components/dataviews/context.js +7 -0
- package/build-module/components/dataviews/context.js.map +1 -0
- package/build-module/components/dataviews/dataviews.js +49 -32
- package/build-module/components/dataviews/dataviews.js.map +1 -1
- package/build-module/components/dataviews/filters.js +66 -0
- package/build-module/components/dataviews/filters.js.map +1 -0
- package/build-module/components/dataviews/in-filter.js +41 -0
- package/build-module/components/dataviews/in-filter.js.map +1 -0
- package/build-module/components/dataviews/index.js +0 -1
- package/build-module/components/dataviews/index.js.map +1 -1
- package/build-module/components/dataviews/item-actions.js +55 -0
- package/build-module/components/dataviews/item-actions.js.map +1 -0
- package/build-module/components/dataviews/pagination.js +73 -46
- package/build-module/components/dataviews/pagination.js.map +1 -1
- package/build-module/components/dataviews/search.js +42 -0
- package/build-module/components/dataviews/search.js.map +1 -0
- package/build-module/components/dataviews/view-actions.js +95 -54
- package/build-module/components/dataviews/view-actions.js.map +1 -1
- package/build-module/components/dataviews/view-grid.js +51 -0
- package/build-module/components/dataviews/view-grid.js.map +1 -0
- package/build-module/components/dataviews/view-list.js +274 -0
- package/build-module/components/dataviews/view-list.js.map +1 -0
- package/build-module/components/editor/index.js +2 -1
- package/build-module/components/editor/index.js.map +1 -1
- package/build-module/components/global-styles/font-library-modal/context.js +16 -10
- 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 +20 -6
- package/build-module/components/global-styles/font-library-modal/font-collection.js.map +1 -1
- package/build-module/components/global-styles/screen-block.js +2 -10
- package/build-module/components/global-styles/screen-block.js.map +1 -1
- package/build-module/components/global-styles/screen-root.js +1 -2
- package/build-module/components/global-styles/screen-root.js.map +1 -1
- package/build-module/components/global-styles/ui.js +3 -4
- package/build-module/components/global-styles/ui.js.map +1 -1
- package/build-module/components/layout/index.js +11 -3
- package/build-module/components/layout/index.js.map +1 -1
- package/build-module/components/media/index.js +26 -0
- package/build-module/components/media/index.js.map +1 -0
- package/build-module/components/page-actions/index.js +0 -2
- package/build-module/components/page-actions/index.js.map +1 -1
- package/build-module/components/page-pages/default-views.js +53 -0
- package/build-module/components/page-pages/default-views.js.map +1 -0
- package/build-module/components/page-pages/index.js +175 -110
- package/build-module/components/page-pages/index.js.map +1 -1
- package/build-module/components/page-patterns/delete-category-menu-item.js +82 -0
- package/build-module/components/page-patterns/delete-category-menu-item.js.map +1 -0
- package/build-module/components/page-patterns/duplicate-menu-item.js +54 -133
- package/build-module/components/page-patterns/duplicate-menu-item.js.map +1 -1
- package/build-module/components/page-patterns/grid-item.js +1 -0
- package/build-module/components/page-patterns/grid-item.js.map +1 -1
- package/build-module/components/page-patterns/header.js +26 -4
- package/build-module/components/page-patterns/header.js.map +1 -1
- package/build-module/components/page-patterns/rename-category-menu-item.js +42 -0
- package/build-module/components/page-patterns/rename-category-menu-item.js.map +1 -0
- package/build-module/components/page-patterns/rename-menu-item.js +1 -1
- package/build-module/components/page-patterns/rename-menu-item.js.map +1 -1
- package/build-module/components/page-patterns/use-patterns.js +1 -0
- package/build-module/components/page-patterns/use-patterns.js.map +1 -1
- package/build-module/components/pattern-modal/duplicate.js +57 -0
- package/build-module/components/pattern-modal/duplicate.js.map +1 -0
- package/build-module/components/pattern-modal/index.js +14 -0
- package/build-module/components/pattern-modal/index.js.map +1 -0
- package/build-module/components/pattern-modal/rename.js +34 -0
- package/build-module/components/pattern-modal/rename.js.map +1 -0
- package/build-module/components/sidebar/index.js +3 -1
- package/build-module/components/sidebar/index.js.map +1 -1
- package/build-module/components/sidebar-dataviews/index.js +64 -0
- package/build-module/components/sidebar-dataviews/index.js.map +1 -0
- package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js +3 -0
- package/build-module/components/sidebar-edit-mode/template-panel/last-revision.js.map +1 -1
- package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js +2 -2
- package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js.map +1 -1
- package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +2 -3
- package/build-module/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js.map +1 -1
- package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-title.js +22 -0
- package/build-module/components/sidebar-navigation-screen-pattern/use-navigation-menu-title.js.map +1 -0
- package/build-module/components/sidebar-navigation-screen-template/home-template-details.js +12 -1
- package/build-module/components/sidebar-navigation-screen-template/home-template-details.js.map +1 -1
- package/build-module/hooks/commands/use-common-commands.js +1 -2
- package/build-module/hooks/commands/use-common-commands.js.map +1 -1
- package/build-module/hooks/commands/use-edit-mode-commands.js +51 -1
- package/build-module/hooks/commands/use-edit-mode-commands.js.map +1 -1
- package/build-module/lock-unlock.js +1 -1
- package/build-module/lock-unlock.js.map +1 -1
- package/build-module/store/selectors.js +4 -5
- package/build-module/store/selectors.js.map +1 -1
- package/build-style/style-rtl.css +48 -11
- package/build-style/style.css +48 -11
- package/package.json +40 -40
- package/src/components/actions/index.js +123 -0
- package/src/components/add-new-template/add-custom-template-modal-content.js +22 -17
- package/src/components/block-editor/resize-handle.js +1 -0
- package/src/components/block-editor/use-site-editor-settings.js +21 -13
- package/src/components/create-template-part-modal/index.js +9 -5
- package/src/components/dataviews/README.md +194 -0
- package/src/components/dataviews/context.js +7 -0
- package/src/components/dataviews/dataviews.js +55 -34
- package/src/components/dataviews/filters.js +75 -0
- package/src/components/dataviews/in-filter.js +45 -0
- package/src/components/dataviews/index.js +0 -1
- package/src/components/dataviews/item-actions.js +69 -0
- package/src/components/dataviews/pagination.js +80 -59
- package/src/components/dataviews/search.js +41 -0
- package/src/components/dataviews/style.scss +18 -3
- package/src/components/dataviews/view-actions.js +108 -63
- package/src/components/dataviews/view-grid.js +65 -0
- package/src/components/dataviews/view-list.js +348 -0
- package/src/components/editor/index.js +2 -0
- package/src/components/global-styles/font-library-modal/context.js +17 -11
- package/src/components/global-styles/font-library-modal/font-collection.js +19 -11
- package/src/components/global-styles/screen-block.js +2 -9
- package/src/components/global-styles/screen-root.js +1 -2
- package/src/components/global-styles/style.scss +16 -4
- package/src/components/global-styles/ui.js +1 -2
- package/src/components/layout/index.js +12 -4
- package/src/components/media/index.js +25 -0
- package/src/components/page-actions/index.js +1 -7
- package/src/components/page-pages/default-views.js +58 -0
- package/src/components/page-pages/index.js +181 -108
- package/src/components/page-pages/style.scss +3 -0
- package/src/components/page-patterns/delete-category-menu-item.js +104 -0
- package/src/components/page-patterns/duplicate-menu-item.js +68 -181
- package/src/components/page-patterns/grid-item.js +1 -0
- package/src/components/page-patterns/header.js +42 -6
- package/src/components/page-patterns/rename-category-menu-item.js +45 -0
- package/src/components/page-patterns/rename-menu-item.js +2 -2
- package/src/components/page-patterns/style.scss +8 -0
- package/src/components/page-patterns/use-patterns.js +5 -0
- package/src/components/pattern-modal/duplicate.js +53 -0
- package/src/components/pattern-modal/index.js +19 -0
- package/src/components/pattern-modal/rename.js +29 -0
- package/src/components/sidebar/index.js +2 -0
- package/src/components/sidebar-dataviews/index.js +65 -0
- package/src/components/sidebar-edit-mode/template-panel/last-revision.js +4 -0
- package/src/components/sidebar-navigation-screen/style.scss +17 -5
- package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menu-list-item.js +2 -7
- package/src/components/sidebar-navigation-screen-pattern/template-part-navigation-menu.js +2 -8
- package/src/components/sidebar-navigation-screen-pattern/use-navigation-menu-title.js +32 -0
- package/src/components/sidebar-navigation-screen-template/home-template-details.js +21 -7
- package/src/hooks/commands/use-common-commands.js +1 -2
- package/src/hooks/commands/use-edit-mode-commands.js +43 -0
- package/src/lock-unlock.js +1 -1
- package/src/store/selectors.js +9 -10
- package/src/style.scss +1 -0
- package/build/components/dataviews/list-view.js +0 -89
- package/build/components/dataviews/list-view.js.map +0 -1
- package/build/components/dataviews/text-filter.js.map +0 -1
- package/build-module/components/dataviews/list-view.js +0 -80
- package/build-module/components/dataviews/list-view.js.map +0 -1
- package/build-module/components/dataviews/text-filter.js +0 -36
- package/build-module/components/dataviews/text-filter.js.map +0 -1
- package/src/components/dataviews/list-view.js +0 -106
- package/src/components/dataviews/text-filter.js +0 -37
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import { __ } from '@wordpress/i18n';
|
|
5
|
+
import { useEffect, useRef } from '@wordpress/element';
|
|
6
|
+
import { SearchControl } from '@wordpress/components';
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* Internal dependencies
|
|
10
|
+
*/
|
|
11
|
+
import useDebouncedInput from '../../utils/use-debounced-input';
|
|
12
|
+
|
|
13
|
+
export default function Search( { label, view, onChangeView } ) {
|
|
14
|
+
const [ search, setSearch, debouncedSearch ] = useDebouncedInput(
|
|
15
|
+
view.search
|
|
16
|
+
);
|
|
17
|
+
useEffect( () => {
|
|
18
|
+
setSearch( view.search );
|
|
19
|
+
}, [ view ] );
|
|
20
|
+
const onChangeViewRef = useRef( onChangeView );
|
|
21
|
+
useEffect( () => {
|
|
22
|
+
onChangeViewRef.current = onChangeView;
|
|
23
|
+
}, [ onChangeView ] );
|
|
24
|
+
useEffect( () => {
|
|
25
|
+
onChangeViewRef.current( ( currentView ) => ( {
|
|
26
|
+
...currentView,
|
|
27
|
+
page: 1,
|
|
28
|
+
search: debouncedSearch,
|
|
29
|
+
} ) );
|
|
30
|
+
}, [ debouncedSearch ] );
|
|
31
|
+
const searchLabel = label || __( 'Filter list' );
|
|
32
|
+
return (
|
|
33
|
+
<SearchControl
|
|
34
|
+
onChange={ setSearch }
|
|
35
|
+
value={ search }
|
|
36
|
+
label={ searchLabel }
|
|
37
|
+
placeholder={ searchLabel }
|
|
38
|
+
size="compact"
|
|
39
|
+
/>
|
|
40
|
+
);
|
|
41
|
+
}
|
|
@@ -1,6 +1,16 @@
|
|
|
1
1
|
.dataviews-wrapper {
|
|
2
2
|
width: 100%;
|
|
3
|
+
height: 100%;
|
|
4
|
+
overflow: auto;
|
|
3
5
|
padding: $grid-unit-40;
|
|
6
|
+
|
|
7
|
+
> div {
|
|
8
|
+
min-height: 100%;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
|
|
12
|
+
.dataviews-pagination {
|
|
13
|
+
margin-top: auto;
|
|
4
14
|
}
|
|
5
15
|
|
|
6
16
|
.dataviews-list-view {
|
|
@@ -30,7 +40,12 @@
|
|
|
30
40
|
}
|
|
31
41
|
}
|
|
32
42
|
|
|
33
|
-
.
|
|
34
|
-
|
|
35
|
-
|
|
43
|
+
.dataviews-view-grid__media {
|
|
44
|
+
width: 100%;
|
|
45
|
+
min-height: 200px;
|
|
46
|
+
|
|
47
|
+
> * {
|
|
48
|
+
max-width: 100%;
|
|
49
|
+
object-fit: cover;
|
|
50
|
+
}
|
|
36
51
|
}
|
|
@@ -4,9 +4,7 @@
|
|
|
4
4
|
import {
|
|
5
5
|
Button,
|
|
6
6
|
Icon,
|
|
7
|
-
SelectControl,
|
|
8
7
|
privateApis as componentsPrivateApis,
|
|
9
|
-
__experimentalInputControlPrefixWrapper as InputControlPrefixWrapper,
|
|
10
8
|
} from '@wordpress/components';
|
|
11
9
|
import {
|
|
12
10
|
chevronRightSmall,
|
|
@@ -31,44 +29,68 @@ const {
|
|
|
31
29
|
DropdownSubMenuTriggerV2,
|
|
32
30
|
} = unlock( componentsPrivateApis );
|
|
33
31
|
|
|
34
|
-
|
|
32
|
+
const availableViews = [
|
|
33
|
+
{
|
|
34
|
+
id: 'list',
|
|
35
|
+
label: __( 'List' ),
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
id: 'grid',
|
|
39
|
+
label: __( 'Grid' ),
|
|
40
|
+
},
|
|
41
|
+
];
|
|
35
42
|
|
|
36
|
-
|
|
37
|
-
const
|
|
43
|
+
function ViewTypeMenu( { view, onChangeView } ) {
|
|
44
|
+
const activeView = availableViews.find( ( v ) => view.type === v.id );
|
|
38
45
|
return (
|
|
39
|
-
<
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
className="dataviews__per-page-control-prefix"
|
|
46
|
+
<DropdownSubMenuV2
|
|
47
|
+
trigger={
|
|
48
|
+
<DropdownSubMenuTriggerV2
|
|
49
|
+
suffix={
|
|
50
|
+
<>
|
|
51
|
+
{ activeView.label }
|
|
52
|
+
<Icon icon={ chevronRightSmall } />
|
|
53
|
+
</>
|
|
54
|
+
}
|
|
49
55
|
>
|
|
50
|
-
{
|
|
51
|
-
</
|
|
56
|
+
{ __( 'Layout' ) }
|
|
57
|
+
</DropdownSubMenuTriggerV2>
|
|
52
58
|
}
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
59
|
+
>
|
|
60
|
+
{ availableViews.map( ( availableView ) => {
|
|
61
|
+
return (
|
|
62
|
+
<DropdownMenuItemV2
|
|
63
|
+
key={ availableView.id }
|
|
64
|
+
prefix={
|
|
65
|
+
availableView.id === view.type && (
|
|
66
|
+
<Icon icon={ check } />
|
|
67
|
+
)
|
|
68
|
+
}
|
|
69
|
+
onSelect={ ( event ) => {
|
|
70
|
+
// We need to handle this on DropDown component probably..
|
|
71
|
+
event.preventDefault();
|
|
72
|
+
onChangeView( { ...view, type: availableView.id } );
|
|
73
|
+
} }
|
|
74
|
+
// TODO: check about role and a11y.
|
|
75
|
+
role="menuitemcheckbox"
|
|
76
|
+
>
|
|
77
|
+
{ availableView.label }
|
|
78
|
+
</DropdownMenuItemV2>
|
|
79
|
+
);
|
|
80
|
+
} ) }
|
|
81
|
+
</DropdownSubMenuV2>
|
|
60
82
|
);
|
|
61
83
|
}
|
|
62
84
|
|
|
63
|
-
|
|
64
|
-
|
|
85
|
+
const PAGE_SIZE_VALUES = [ 5, 20, 50 ];
|
|
86
|
+
function PageSizeMenu( { view, onChangeView } ) {
|
|
65
87
|
return (
|
|
66
88
|
<DropdownSubMenuV2
|
|
67
89
|
trigger={
|
|
68
90
|
<DropdownSubMenuTriggerV2
|
|
69
91
|
suffix={
|
|
70
92
|
<>
|
|
71
|
-
{
|
|
93
|
+
{ view.perPage }
|
|
72
94
|
<Icon icon={ chevronRightSmall } />
|
|
73
95
|
</>
|
|
74
96
|
}
|
|
@@ -83,12 +105,12 @@ function PageSizeMenu( { dataView } ) {
|
|
|
83
105
|
<DropdownMenuItemV2
|
|
84
106
|
key={ size }
|
|
85
107
|
prefix={
|
|
86
|
-
|
|
108
|
+
view.perPage === size && <Icon icon={ check } />
|
|
87
109
|
}
|
|
88
110
|
onSelect={ ( event ) => {
|
|
89
111
|
// We need to handle this on DropDown component probably..
|
|
90
112
|
event.preventDefault();
|
|
91
|
-
|
|
113
|
+
onChangeView( { ...view, perPage: size, page: 1 } );
|
|
92
114
|
} }
|
|
93
115
|
// TODO: check about role and a11y.
|
|
94
116
|
role="menuitemcheckbox"
|
|
@@ -101,11 +123,11 @@ function PageSizeMenu( { dataView } ) {
|
|
|
101
123
|
);
|
|
102
124
|
}
|
|
103
125
|
|
|
104
|
-
function FieldsVisibilityMenu( {
|
|
105
|
-
const
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
if ( !
|
|
126
|
+
function FieldsVisibilityMenu( { view, onChangeView, fields } ) {
|
|
127
|
+
const hidableFields = fields.filter(
|
|
128
|
+
( field ) => field.enableHiding !== false
|
|
129
|
+
);
|
|
130
|
+
if ( ! hidableFields?.length ) {
|
|
109
131
|
return null;
|
|
110
132
|
}
|
|
111
133
|
return (
|
|
@@ -118,20 +140,31 @@ function FieldsVisibilityMenu( { dataView } ) {
|
|
|
118
140
|
</DropdownSubMenuTriggerV2>
|
|
119
141
|
}
|
|
120
142
|
>
|
|
121
|
-
{
|
|
143
|
+
{ hidableFields?.map( ( field ) => {
|
|
122
144
|
return (
|
|
123
145
|
<DropdownMenuItemV2
|
|
124
146
|
key={ field.id }
|
|
125
147
|
prefix={
|
|
126
|
-
field.
|
|
148
|
+
! view.hiddenFields?.includes( field.id ) && (
|
|
149
|
+
<Icon icon={ check } />
|
|
150
|
+
)
|
|
127
151
|
}
|
|
128
152
|
onSelect={ ( event ) => {
|
|
129
153
|
event.preventDefault();
|
|
130
|
-
|
|
154
|
+
onChangeView( {
|
|
155
|
+
...view,
|
|
156
|
+
hiddenFields: view.hiddenFields?.includes(
|
|
157
|
+
field.id
|
|
158
|
+
)
|
|
159
|
+
? view.hiddenFields.filter(
|
|
160
|
+
( id ) => id !== field.id
|
|
161
|
+
)
|
|
162
|
+
: [ ...view.hiddenFields, field.id ],
|
|
163
|
+
} );
|
|
131
164
|
} }
|
|
132
165
|
role="menuitemcheckbox"
|
|
133
166
|
>
|
|
134
|
-
{ field.
|
|
167
|
+
{ field.header }
|
|
135
168
|
</DropdownMenuItemV2>
|
|
136
169
|
);
|
|
137
170
|
} ) }
|
|
@@ -144,15 +177,15 @@ const sortingItemsInfo = {
|
|
|
144
177
|
asc: { icon: arrowUp, label: __( 'Sort ascending' ) },
|
|
145
178
|
desc: { icon: arrowDown, label: __( 'Sort descending' ) },
|
|
146
179
|
};
|
|
147
|
-
function SortMenu( {
|
|
148
|
-
const sortableFields =
|
|
149
|
-
|
|
150
|
-
|
|
180
|
+
function SortMenu( { fields, view, onChangeView } ) {
|
|
181
|
+
const sortableFields = fields.filter(
|
|
182
|
+
( field ) => field.enableSorting !== false
|
|
183
|
+
);
|
|
151
184
|
if ( ! sortableFields?.length ) {
|
|
152
185
|
return null;
|
|
153
186
|
}
|
|
154
|
-
const currentSortedField =
|
|
155
|
-
field.
|
|
187
|
+
const currentSortedField = fields.find(
|
|
188
|
+
( field ) => field.id === view.sort?.field
|
|
156
189
|
);
|
|
157
190
|
return (
|
|
158
191
|
<DropdownSubMenuV2
|
|
@@ -160,7 +193,7 @@ function SortMenu( { dataView } ) {
|
|
|
160
193
|
<DropdownSubMenuTriggerV2
|
|
161
194
|
suffix={
|
|
162
195
|
<>
|
|
163
|
-
{ currentSortedField?.
|
|
196
|
+
{ currentSortedField?.header }
|
|
164
197
|
<Icon icon={ chevronRightSmall } />
|
|
165
198
|
</>
|
|
166
199
|
}
|
|
@@ -170,7 +203,7 @@ function SortMenu( { dataView } ) {
|
|
|
170
203
|
}
|
|
171
204
|
>
|
|
172
205
|
{ sortableFields?.map( ( field ) => {
|
|
173
|
-
const sortedDirection =
|
|
206
|
+
const sortedDirection = view.sort?.direction;
|
|
174
207
|
return (
|
|
175
208
|
<DropdownSubMenuV2
|
|
176
209
|
key={ field.id }
|
|
@@ -178,37 +211,41 @@ function SortMenu( { dataView } ) {
|
|
|
178
211
|
<DropdownSubMenuTriggerV2
|
|
179
212
|
suffix={ <Icon icon={ chevronRightSmall } /> }
|
|
180
213
|
>
|
|
181
|
-
{ field.
|
|
214
|
+
{ field.header }
|
|
182
215
|
</DropdownSubMenuTriggerV2>
|
|
183
216
|
}
|
|
184
217
|
side="left"
|
|
185
218
|
>
|
|
186
219
|
{ Object.entries( sortingItemsInfo ).map(
|
|
187
220
|
( [ direction, info ] ) => {
|
|
221
|
+
const isActive =
|
|
222
|
+
currentSortedField &&
|
|
223
|
+
sortedDirection === direction &&
|
|
224
|
+
field.id === currentSortedField.id;
|
|
188
225
|
return (
|
|
189
226
|
<DropdownMenuItemV2
|
|
190
227
|
key={ direction }
|
|
191
228
|
prefix={ <Icon icon={ info.icon } /> }
|
|
192
229
|
suffix={
|
|
193
|
-
|
|
194
|
-
<Icon icon={ check } />
|
|
195
|
-
)
|
|
230
|
+
isActive && <Icon icon={ check } />
|
|
196
231
|
}
|
|
197
232
|
onSelect={ ( event ) => {
|
|
198
233
|
event.preventDefault();
|
|
199
234
|
if (
|
|
200
235
|
sortedDirection === direction
|
|
201
236
|
) {
|
|
202
|
-
|
|
237
|
+
onChangeView( {
|
|
238
|
+
...view,
|
|
239
|
+
sort: undefined,
|
|
240
|
+
} );
|
|
203
241
|
} else {
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
'desc',
|
|
242
|
+
onChangeView( {
|
|
243
|
+
...view,
|
|
244
|
+
sort: {
|
|
245
|
+
field: field.id,
|
|
246
|
+
direction,
|
|
210
247
|
},
|
|
211
|
-
|
|
248
|
+
} );
|
|
212
249
|
}
|
|
213
250
|
} }
|
|
214
251
|
>
|
|
@@ -224,11 +261,10 @@ function SortMenu( { dataView } ) {
|
|
|
224
261
|
);
|
|
225
262
|
}
|
|
226
263
|
|
|
227
|
-
export default function ViewActions( {
|
|
264
|
+
export default function ViewActions( { fields, view, onChangeView } ) {
|
|
228
265
|
return (
|
|
229
266
|
<DropdownMenuV2
|
|
230
267
|
label={ __( 'Actions' ) }
|
|
231
|
-
className={ className }
|
|
232
268
|
trigger={
|
|
233
269
|
<Button variant="tertiary" icon={ blockTable }>
|
|
234
270
|
{ __( 'View' ) }
|
|
@@ -237,9 +273,18 @@ export default function ViewActions( { dataView, className } ) {
|
|
|
237
273
|
}
|
|
238
274
|
>
|
|
239
275
|
<DropdownMenuGroupV2>
|
|
240
|
-
<
|
|
241
|
-
<
|
|
242
|
-
|
|
276
|
+
<ViewTypeMenu view={ view } onChangeView={ onChangeView } />
|
|
277
|
+
<SortMenu
|
|
278
|
+
fields={ fields }
|
|
279
|
+
view={ view }
|
|
280
|
+
onChangeView={ onChangeView }
|
|
281
|
+
/>
|
|
282
|
+
<FieldsVisibilityMenu
|
|
283
|
+
fields={ fields }
|
|
284
|
+
view={ view }
|
|
285
|
+
onChangeView={ onChangeView }
|
|
286
|
+
/>
|
|
287
|
+
<PageSizeMenu view={ view } onChangeView={ onChangeView } />
|
|
243
288
|
</DropdownMenuGroupV2>
|
|
244
289
|
</DropdownMenuV2>
|
|
245
290
|
);
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* WordPress dependencies
|
|
3
|
+
*/
|
|
4
|
+
import {
|
|
5
|
+
__experimentalGrid as Grid,
|
|
6
|
+
__experimentalHStack as HStack,
|
|
7
|
+
__experimentalVStack as VStack,
|
|
8
|
+
FlexBlock,
|
|
9
|
+
Placeholder,
|
|
10
|
+
} from '@wordpress/components';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Internal dependencies
|
|
14
|
+
*/
|
|
15
|
+
import ItemActions from './item-actions';
|
|
16
|
+
|
|
17
|
+
export function ViewGrid( { data, fields, view, actions } ) {
|
|
18
|
+
const mediaField = fields.find(
|
|
19
|
+
( field ) => field.id === view.layout.mediaField
|
|
20
|
+
);
|
|
21
|
+
const visibleFields = fields.filter(
|
|
22
|
+
( field ) =>
|
|
23
|
+
! view.hiddenFields.includes( field.id ) &&
|
|
24
|
+
field.id !== view.layout.mediaField
|
|
25
|
+
);
|
|
26
|
+
return (
|
|
27
|
+
<Grid gap={ 8 } columns={ 2 } alignment="top">
|
|
28
|
+
{ data.map( ( item, index ) => {
|
|
29
|
+
return (
|
|
30
|
+
<VStack key={ index }>
|
|
31
|
+
<div className="dataviews-view-grid__media">
|
|
32
|
+
{ mediaField?.render( { item, view } ) || (
|
|
33
|
+
<Placeholder
|
|
34
|
+
withIllustration
|
|
35
|
+
style={ {
|
|
36
|
+
width: '100%',
|
|
37
|
+
minHeight: '200px',
|
|
38
|
+
} }
|
|
39
|
+
/>
|
|
40
|
+
) }
|
|
41
|
+
</div>
|
|
42
|
+
|
|
43
|
+
<HStack justify="space-between" alignment="top">
|
|
44
|
+
<FlexBlock>
|
|
45
|
+
<VStack>
|
|
46
|
+
{ visibleFields.map( ( field ) => (
|
|
47
|
+
<div key={ field.id }>
|
|
48
|
+
{ field.render( { item, view } ) }
|
|
49
|
+
</div>
|
|
50
|
+
) ) }
|
|
51
|
+
</VStack>
|
|
52
|
+
</FlexBlock>
|
|
53
|
+
<FlexBlock>
|
|
54
|
+
<ItemActions
|
|
55
|
+
item={ item }
|
|
56
|
+
actions={ actions }
|
|
57
|
+
/>
|
|
58
|
+
</FlexBlock>
|
|
59
|
+
</HStack>
|
|
60
|
+
</VStack>
|
|
61
|
+
);
|
|
62
|
+
} ) }
|
|
63
|
+
</Grid>
|
|
64
|
+
);
|
|
65
|
+
}
|