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 (