-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Data views: Add ability to display fields as a badge in grid layout #60284
Conversation
The following accounts have interacted with this PR and/or linked issues. I will continue to update these lists as activity occurs. You can also manually ask me to refresh this list by adding the If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.
To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook. |
Size Change: +375 B (0%) Total Size: 1.73 MB
ℹ️ View Unchanged
|
Flaky tests detected in 1a4c96a. 🔍 Workflow run URL: https://github.com/WordPress/gutenberg/actions/runs/8468074865
|
@@ -68,6 +68,8 @@ const defaultConfigPerViewType = { | |||
[ LAYOUT_GRID ]: { | |||
mediaField: 'preview', | |||
primaryField: 'title', | |||
displayAsBadgeFields: [ 'sync-status' ], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think we should declare a badge fields once and has nothing to do with asColumnFields
. Let me refactor the code a bit..
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
In terms of naming, I think we should remove the displayAs
prefix everywhere. We already use badgeFields
in the UI component below, and there's no difference from the existing primaryField
and mediaField
(all of this is about "marking" a set of fields and display them differently).
The same applies to columnFields
, that can be changed in a different PR.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sounds fine to me.
@@ -111,6 +111,11 @@ | |||
.dataviews-pagination { | |||
z-index: z-index(".edit-site-patterns__dataviews-list-pagination"); | |||
} | |||
|
|||
.dataviews-view-grid__field-sync-status.is-badge:has(.edit-site-patterns__field-sync-status-fully) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I'd prefer if we don't target dataviews classes in consumer code, as it implies it's a public API. Can we instead add a specific class in the sync-status
field? We have access to the view type there.
I've noticed that we do this for pagination, pattern actions, and templates/parts actions. cc @ntsekouras
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Personally I don't think it's bad to use a specific class with a field's id suffix and I wouldn't worry right now about indicating public API, since we can have breaking changes in the DataViews package.
Having said that, I agree with you that we don't need this right now. I updated the code.
Thanks for the updates y'all. @jasmussen I removed the separator: Note: The above is just an example. Page fields still display with their labels: Status can potentially be a badge, but should be visually aligned with the designs shared in #60289 (comment) which makes it follow-up territory. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
For me this is good to land, thanks! Unless someone has any explicit concerns, let's 🚢 with a green CI
It will probably need a rebase though..
@@ -111,6 +111,11 @@ | |||
.dataviews-pagination { | |||
z-index: z-index(".edit-site-patterns__dataviews-list-pagination"); | |||
} | |||
|
|||
.is-badge:has(.edit-site-patterns__field-sync-status-fully) { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Wouldn't this work?
.is-badge:has(.edit-site-patterns__field-sync-status-fully) { | |
.edit-site-patterns__field-sync-status-fully { |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
packages/dataviews/src/view-grid.js
Outdated
key={ field.id } | ||
className={ classnames( | ||
'dataviews-view-grid__field-value', | ||
'is-badge' |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It sounds like we may remove the is-badge
class? It's only used in packages/edit-site/src/components/page-patterns/style.scss
but it seems to be unnecessary?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've left a couple of comments related to the is-badge
class that seems unnecessary? Other than that, it's 👍 The grid layout is getting interesting!
Oh, there's also the follow-up to rename displayAsColumnFields
to columnFields
everywhere.
@@ -73,6 +73,7 @@ const defaultConfigPerViewType = { | |||
[ LAYOUT_GRID ]: { | |||
mediaField: 'preview', | |||
primaryField: 'title', | |||
badgeFields: [ 'sync-status' ], |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We're starting to have several kind of displays for fields: primary, media, badge (maybe others in other layouts). It would be good to check if we can consolidate somehow. Maybe visibleFields
could support arrays as fields: [ [ { field: 'preview', display: 'media' }], { field: 'title', display: 'primary' }], { field: 'sync-status', display: 'badge' }, 'anyrandomfield' ]
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I also wonder if want to show the "badge" in the same way in other views. Meaning maybe the field itself (sync status) display as a badge in its render function rather than this begin a config.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes I think so too. I'll create an issue to track this.
…ordPress#60284) Co-authored-by: jameskoster <[email protected]> Co-authored-by: ntsekouras <[email protected]> Co-authored-by: oandregal <[email protected]> Co-authored-by: jasmussen <[email protected]>
What?
This PR does a few things which can be boiled down to three main changes:
Why?
Follow-up to #60083, which introduced the ability to arrange fields in a 'column' layout and forced the display of field labels.
This change is for fields where the label is not necessary, IE it can be interpreted from the value alone.
Of the current field set across all data views, 'sync status' in patterns is an appropriate consumer: There is no need for the verbose: "Sync status: Synced" when "Synced" alone will do.
As data views expand to other areas (e.g. Media Library: #55238) this affordance will become more useful. Media is a good example because media files have many fields that do not require a label (size, file name, type, dimensions, etc.). This PR will make it possible to implement the following mockup:
How?
displayAsBadgeFields
parameter toGridItem
, similar todisplayAsColumnFields
HStack
above all other fields.field.id
as a classname on all field outputs.defaultConfigPerViewType
in the Patterns page to specific thatsync-status
is a badge field.sync-status
field render to include class name based on valueTwo other minor tweaks:
Testing Instructions
Before
After
For more advanced testing you can temporarily swap fields in the Pages data view to display as badges by opening
packages/edit-site/src/components/sidebar-dataviews/default-views.js
and updatingDEFAULT_CONFIG_PER_VIEW_TYPE
like so:Then:
badges.mp4
Note: It may be desirable to display Status as a badge with different styling for different values, similar to sync status. We can explore that in a follow up.