From 4b6be6522b8cb368511a8dbf3573a87a95b7acc1 Mon Sep 17 00:00:00 2001 From: Riad Benguella Date: Wed, 21 Aug 2024 11:56:12 +0200 Subject: [PATCH] DataViews: Support defining field headers/names as React elements. (#64642) Co-authored-by: youknowriad Co-authored-by: oandregal Co-authored-by: jameskoster --- packages/dataviews/CHANGELOG.md | 8 +++++++- .../src/components/dataviews/stories/fixtures.js | 14 +++++++++++++- .../components/dataviews/stories/index.story.js | 8 +++++++- .../dataviews/src/dataviews-layouts/grid/index.tsx | 2 +- .../dataviews-layouts/table/column-header-menu.tsx | 4 ++-- packages/dataviews/src/normalize-fields.ts | 1 + packages/dataviews/src/types.ts | 9 +++++++++ 7 files changed, 40 insertions(+), 6 deletions(-) diff --git a/packages/dataviews/CHANGELOG.md b/packages/dataviews/CHANGELOG.md index cc6f4df9428b0..d51cf9c969016 100644 --- a/packages/dataviews/CHANGELOG.md +++ b/packages/dataviews/CHANGELOG.md @@ -2,7 +2,13 @@ ## Unreleased -- The "move left/move right" controls in the table layout (popup displayed on cliking header) are always visible. ([#64646](https://github.com/WordPress/gutenberg/pull/64646)). Before this, its visibility depending on filters, enableSorting, and enableHiding. +## New features + +- Support using a component for field headers or names by providing a `header` property in the field object. The string `label` property (or `id`) is still mandatory. ([#64642](https://github.com/WordPress/gutenberg/pull/64642)). + +## Internal + +- The "move left/move right" controls in the table layout (popup displayed on cliking header) are always visible. ([#64646](https://github.com/WordPress/gutenberg/pull/64646)). Before this, its visibility depending on filters, enableSorting, and enableHiding. ## 4.1.0 (2024-08-07) diff --git a/packages/dataviews/src/components/dataviews/stories/fixtures.js b/packages/dataviews/src/components/dataviews/stories/fixtures.js index f89cea81e6f15..50401d97b026b 100644 --- a/packages/dataviews/src/components/dataviews/stories/fixtures.js +++ b/packages/dataviews/src/components/dataviews/stories/fixtures.js @@ -1,7 +1,7 @@ /** * WordPress dependencies */ -import { trash } from '@wordpress/icons'; +import { trash, image, Icon, category } from '@wordpress/icons'; import { Button, __experimentalText as Text, @@ -173,6 +173,12 @@ export const fields = [ { label: 'Image', id: 'image', + header: ( + + + Image + + ), render: ( { item } ) => { return ( @@ -217,6 +223,12 @@ export const fields = [ { label: 'Categories', id: 'categories', + header: ( + + + Categories + + ), elements: [ { value: 'Space', label: 'Space' }, { value: 'NASA', label: 'NASA' }, diff --git a/packages/dataviews/src/components/dataviews/stories/index.story.js b/packages/dataviews/src/components/dataviews/stories/index.story.js index 9ce1c29573e55..376b14a464666 100644 --- a/packages/dataviews/src/components/dataviews/stories/index.story.js +++ b/packages/dataviews/src/components/dataviews/stories/index.story.js @@ -8,7 +8,7 @@ import { useState, useMemo } from '@wordpress/element'; */ import DataViews from '../index'; import { DEFAULT_VIEW, actions, data, fields } from './fixtures'; -import { LAYOUT_GRID, LAYOUT_TABLE } from '../../../constants'; +import { LAYOUT_GRID, LAYOUT_LIST, LAYOUT_TABLE } from '../../../constants'; import { filterSortAndPaginate } from '../../../filter-and-sort-data-view'; const meta = { @@ -61,5 +61,11 @@ Default.args = { primaryField: 'title', }, }, + [ LAYOUT_LIST ]: { + layout: { + mediaField: 'image', + primaryField: 'title', + }, + }, }, }; diff --git a/packages/dataviews/src/dataviews-layouts/grid/index.tsx b/packages/dataviews/src/dataviews-layouts/grid/index.tsx index c8cac31bf7db8..230ffe0dc50b5 100644 --- a/packages/dataviews/src/dataviews-layouts/grid/index.tsx +++ b/packages/dataviews/src/dataviews-layouts/grid/index.tsx @@ -145,7 +145,7 @@ function GridItem< Item >( { > <> - { field.label } + { field.header } ( ); const index = view.fields?.indexOf( fieldId ) as number; if ( !! combinedField ) { - return combinedField.label; + return combinedField.header || combinedField.label; } const field = fields.find( ( f ) => f.id === fieldId ); if ( ! field ) { @@ -102,7 +102,7 @@ const _HeaderMenu = forwardRef( function HeaderMenu< Item >( ref={ ref } variant="tertiary" > - { field.label } + { field.header } { view.sort && isSorted && (