From 14764be44b94669f16a48dd33e3f03cc0ca9a707 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Andr=C3=A9?= <583546+oandregal@users.noreply.github.com>
Date: Tue, 31 Oct 2023 16:28:12 +0100
Subject: [PATCH] DataViews: extract `search` from filters (#55722)
---
.../src/components/dataviews/README.md | 26 ++++++-------------
.../src/components/dataviews/dataviews.js | 12 +++++++--
.../src/components/dataviews/filters.js | 21 +--------------
.../src/components/dataviews/provider.js | 4 +--
.../src/components/dataviews/text-filter.js | 13 ++++------
.../src/components/page-pages/index.js | 6 +----
6 files changed, 27 insertions(+), 55 deletions(-)
diff --git a/packages/edit-site/src/components/dataviews/README.md b/packages/edit-site/src/components/dataviews/README.md
index 460235c8df3df4..9b9dabec1b2269 100644
--- a/packages/edit-site/src/components/dataviews/README.md
+++ b/packages/edit-site/src/components/dataviews/README.md
@@ -9,7 +9,6 @@ This file documents the DataViews UI component, which provides an API to render
view={ view }
onChangeView={ onChangeView }
fields={ fields }
- filters={ filters }
actions={ [ trashPostAction ] }
paginationInfo={ { totalItems, totalPages } }
/>
@@ -43,12 +42,12 @@ Example:
field: 'date',
direction: 'desc',
},
+ search: '',
filters: {
- search: '',
author: 2,
status: 'publish, draft'
},
- visibleFilters: [ 'search', 'author', 'status' ],
+ visibleFilters: [ 'author', 'status' ],
hiddenFields: [ 'date', 'featured-image' ],
layout: {},
}
@@ -59,6 +58,7 @@ Example:
- `page`: the page that is visible.
- `sort.field`: field used for sorting the dataset.
- `sort.direction`: the direction to use for sorting, one of `asc` or `desc`.
+- `search`: the text search applied to the dataset.
- `filters`: the filters applied to the dataset. See filters section.
- `visibleFilters`: the `id` of the filters that are visible in the UI.
- `hiddenFields`: the `id` of the fields that are hidden in the UI.
@@ -82,6 +82,7 @@ function MyCustomPageList() {
page: view.page,
order: view.sort?.direction,
orderby: view.sort?.field
+ search: view.search,
...view.filters
} ),
[ view ]
@@ -133,10 +134,7 @@ Example:
{ value: 1, label: 'Admin' }
{ value: 2, label: 'User' }
]
- filters: [
- 'enumeration'
- { id: 'author_search', type: 'search', name: __( 'Search by author' ) }
- ],
+ filters: [ 'enumeration' ],
}
]
```
@@ -150,26 +148,18 @@ Example:
## Filters
-Filters describe the conditions a record should match to be listed as part of the dataset.
-
-Filters can be provided globally, as a property of the `DataViews` component, or per field, should they be considered part of a fields' description.
+Filters describe the conditions a record should match to be listed as part of the dataset. Filters are provided per field.
```js
const field = [
{
id: 'author',
- filters: [
- 'enumeration'
- { id: 'author_search', type: 'search', name: __( 'Search by author' ) }
- ],
+ filters: [ 'enumeration' ],
}
];
```
@@ -177,7 +167,7 @@ A filter is an object that may contain the following properties:
- `id`: unique identifier for the filter. Matches the entity query param. Field filters may omit it, in which case the field's `id` will be used.
- `name`: nice looking name for the filter. Field filters may omit it, in which case the field's `header` will be used.
-- `type`: the type of filter. One of `search` or `enumeration`.
+- `type`: the type of filter. Only `enumeration` is supported at the moment.
- `elements`: for filters of type `enumeration`, the list of options to show. A one-dimensional array of object with value/label keys, as in `[ { value: 1, label: "Value name" } ]`.
- `value`: what's serialized into the view's filters.
- `label`: nice-looking name for users.
diff --git a/packages/edit-site/src/components/dataviews/dataviews.js b/packages/edit-site/src/components/dataviews/dataviews.js
index a4e8a5524cceba..b6474692a23285 100644
--- a/packages/edit-site/src/components/dataviews/dataviews.js
+++ b/packages/edit-site/src/components/dataviews/dataviews.js
@@ -14,13 +14,15 @@ import ViewList from './view-list';
import Pagination from './pagination';
import ViewActions from './view-actions';
import Filters from './filters';
+import TextFilter from './text-filter';
import { ViewGrid } from './view-grid';
export default function DataViews( {
view,
onChangeView,
fields,
- filters,
+ search = true,
+ searchLabel = undefined,
actions,
data,
isLoading = false,
@@ -38,8 +40,14 @@ export default function DataViews( {
+ { search && (
+
+ ) }
{
- if ( 'object' !== typeof filter || ! filter?.id || ! filter?.type ) {
- return;
- }
-
- filterIndex[ filter.id ] = filter;
- } );
-
fields.forEach( ( field ) => {
if ( ! field.filters ) {
return;
@@ -67,16 +58,6 @@ export default function Filters( { filters, fields, view, onChangeView } ) {
return null;
}
- if ( filter.type === 'search' ) {
- return (
-
- );
- }
if ( filter.type === 'enumeration' ) {
return (
{
- setSearch( view.filters[ filter.id ] );
+ setSearch( view.search );
}, [ view ] );
const onChangeViewRef = useRef( onChangeView );
useEffect( () => {
@@ -25,13 +25,10 @@ export default function TextFilter( { filter, view, onChangeView } ) {
onChangeViewRef.current( ( currentView ) => ( {
...currentView,
page: 1,
- filters: {
- ...currentView.filters,
- [ filter.id ]: debouncedSearch,
- },
+ search: debouncedSearch,
} ) );
}, [ debouncedSearch ] );
- const searchLabel = filter?.name || __( 'Filter list' );
+ const searchLabel = label || __( 'Filter list' );
return (
[
- { id: 'search', type: 'search', name: __( 'Filter list' ) },
- ] );
-
const trashPostAction = useTrashPostAction();
const editPostAction = useEditPostAction();
const actions = useMemo(
@@ -247,7 +244,6 @@ export default function PagePages() {