-
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
Block Library: Move Column resizing to Columns #16077
Conversation
I guess that logic has changed for Column block causing some e2e test failures related to Block Navigation feature: https://travis-ci.com/WordPress/gutenberg/jobs/206834450#L874
|
}; | ||
|
||
forEach( nextColumnWidths, ( nextColumnWidth, columnClientId ) => { | ||
updateBlockAttributes( columnClientId, { width: nextColumnWidth } ); |
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 would be great to make updateBlockAttributes
more flexible or introduce some other action for batch updates like this one. In the case when there are 6 columns, it might trigger re-render 6 times for every atomic block update. Regardless of performance considerations, I anticipate that with nested blocks starting to be more and more popular we need to start thinking about batching actions to make APIs simpler to use.
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.
Another issue here might be that we add a number of Undo levels for each change (already affects master).
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 feels like we need to start working on undo transactions soon. This has came up in other PRs recently.
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 feels like we need to start working on undo transactions soon. This has came up in other PRs recently.
Yeah, it's similar to #8119, but I wonder if there might be some simple near-term solution:
wp.data.dispatch( 'core/editor' ).transact( () => {
wp.data.dispatch( 'core/block-editor' ).updateBlockAttributes( /* ... */ );
wp.data.dispatch( 'core/block-editor' ).updateBlockAttributes( /* ... */ );
} );
// `'START_TRANSACTION'`
// `'UPDATE_BLOCK_ATTRIBUTES'`
// `'UPDATE_BLOCK_ATTRIBUTES'`
// `'END_TRANSACTION'`
(or just startTransaction
+ endTransaction
/ toggleTransaction
actions)
Probably worth a separate issue for tracking and discussion.
Looking at the process today and how it can be improved. User selects a block and chooses a variation to start with. Lets say that I choose 2 columns. With the new suggestion Andrew added above (as I see it). Thinking out loud... Bottom line is making it easier on the user to select the width. Sidebar controls is a very good idea and I also think we need direct manipulation of each column when the parent column block is selected. Clicking into each column the percentage block could go away. Slack Design channel discussion: https://wordpress.slack.com/archives/C02S78ZAL/p1581442639343500 |
It's fallen quite out of date. I know there's a lot of interest in improving this experience, and some people (e.g. @ItsJonQ) actively looking at this block. At least in this particular proposal, I think it really depends on some separate exploration of nested block selection. The implementation also conflicts a bit with #19515, which removed automatic resizing of sibling column blocks. I'll close this, but the tracking issue remains open at #15660 for further discussion and exploration. |
Closes #15660
This pull request seeks to move management of the individual Column widths to be managed at the Columns wrapper. The goal here, in combination with #16024 and toward #7694, is to eliminate the "Column" block as a necessary stop for user interaction.
Accessibility Notes:
The current implementation renders a
fieldset
for each column. At the moment, there is only the width field within these groups. However, as part of #7694, it will be necessary to incorporate column vertical alignment into the Columns sidebar as well. With each column possibly having multiple fields to manage in the block inspector, the fieldset grouping felt appropriate. Guidance here would be appreciated.Implementation Notes:
The implementation of the widths assignment is ported directly from the Column block, with minor adaptation to receive
clientId
as an argument of the function.This nicely allows for a re-consolidation of the width sizing utility functions (previously, the "Column" block implementation penetrated the block abstraction into the implementation of the "Columns" block).
Testing Instructions:
Repeat testing instructions from #15499, managing column width from the Columns block instead of the Column block.