-
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
Site Editor: Redesign table views #50766
Conversation
Size Change: +213 B (0%) Total Size: 1.39 MB
ℹ️ View Unchanged
|
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.
Haven't ran this yet but the code is looking real good. I love the design of Table
and a lot of this PR reads like an ad for @wordpress/components
– beautiful 🌈.
Not so sure about FilterBar
. Seems like a lot of complexity for one filterable attribute. Maybe you know something I don't though e.g that lots more are coming. In my mind though we should just have the pages render a SearchControl
.
( select ) => | ||
allTemplateParts?.filter( | ||
( template ) => | ||
! select( coreStore ).isDeletingEntityRecord( |
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.
When do we ever want an entity record that is being deleted to be returned by useEntityRecords
? I am wondering if we can/should move this logic to within useEntityRecords
so as to avoid the awkward useEffect
here.
Same comment applies to PageMainTemplates
.
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.
This was logic copied over from existing list
component. I'm unsure why it was added. @kevin940726 any thoughts on whether this is needed or not?
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.
@noisysocks thanks so much for the thorough review, I'll look at these tomorrow.
Yeah I probably got a bit carried away here :D I might pull FilterBar out into its own branch for later and use SearchControl for now. |
@noisysocks should be ready for a re-review. I removed filtering completely to break down the PR a bit. |
Flaky tests detected in 4956497. 🔍 Workflow run URL: https://github.com/WordPress/gutenberg/actions/runs/5212233092
|
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.
Thanks for trying it out! I like the simplicity of the API and the implementation! I left some questions around accessibility and some observations. I'll test it locally next!
</thead> | ||
<tbody> | ||
{ data.map( ( row, rowIndex ) => ( | ||
<tr key={ rowIndex }> |
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.
Probably not a good idea to use indices as keys?
export default function Header( { title, subTitle, actions } ) { | ||
return ( | ||
<HStack as="header" alignment="left" className="edit-site-page-header"> | ||
<FlexBlock className="edit-site-page-header__page-title"> |
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.
Nit: We can use <hgroup>
to group the heading with its subheading here. It doesn't seem to have any accessibility impact though so it's just a fun TIL moment and don't need to change 😅 .
) | ||
} | ||
> | ||
{ templates && <Table data={ templates } columns={ columns } /> } |
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.
Do we want to render a loading spinner or something like that as a follow-up?
Also for an empty list?
Fixes vertical alignment for custom templates
Pushed a couple of tiny fixes. Also aligned the contents of the last item in each row |
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.
Tested it locally and LGTM! 👍 💯
@kevin940726 would you mind taking one final review of this and approving so we can merge :) |
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.
Lovely 👍
Sorry for the late reply! My only concern left is #50766 (comment) which might come back and bite us from the back 😅 . Otherwise this is good stuff! And I'm perfectly okay if we want to handle that issue separately too :). |
* add page component * hooked up filtering and table * clean up and add new to page component * style updates to templates page * templates page title * template parts using new page component * change page header size * remove tanstack table * remove filter bar for now and simplify code * update package lock * revert package lock * mobile styles for table view * Fix page header z-index * Don't show description wrapper if description is empty Fixes vertical alignment for custom templates * Adjust alignment of last item in each row * fix table padding and scroll --------- Co-authored-by: James Koster <james@jameskoster.co.uk>
This creates a new Page component along with FilterBar and Table components. I've kept the design mostly the same for this PR so that we can focus a follow up PR on updating design to reflect some of the more recent concepts, including the pattern management grid.
Why?
These components are to be used by pages like the existing templates manage and the upcoming library (replacing template parts). It's the first step towards resolving this issue..
How?
Page
component that accepts title, subTitle, actions and childrenTesting Instructions
Testing Instructions for Keyboard