-
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
Storybook: Add stories for AlignmentToolbar and AlignmentControl components #67046
Storybook: Add stories for AlignmentToolbar and AlignmentControl components #67046
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. |
packages/block-editor/src/components/alignment-control/stories/aliginmentToolbar.story.js
Outdated
Show resolved
Hide resolved
packages/block-editor/src/components/alignment-control/stories/index.story.js
Outdated
Show resolved
Hide resolved
@t-hamano Thank you for quick reviewing! |
const Template = ( { onChange, ...args } ) => { | ||
const [ value, setValue ] = useState(); | ||
return ( | ||
<AlignmentToolbar | ||
{ ...args } | ||
onChange={ ( ...changeArgs ) => { | ||
onChange( ...changeArgs ); | ||
setValue( ...changeArgs ); | ||
} } | ||
value={ value } | ||
/> | ||
); | ||
}; | ||
|
||
export const Default = Template.bind(); |
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 is fine, but just as a tip for easier authoring and maintenance, it will be a lot simpler to showcase the component in uncontrolled mode if the component supports it. It will literally be a one-liner 😄
const Template = ( { onChange, ...args } ) => { | |
const [ value, setValue ] = useState(); | |
return ( | |
<AlignmentToolbar | |
{ ...args } | |
onChange={ ( ...changeArgs ) => { | |
onChange( ...changeArgs ); | |
setValue( ...changeArgs ); | |
} } | |
value={ value } | |
/> | |
); | |
}; | |
export const Default = Template.bind(); | |
export const Default = {}; |
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.
Wow, so easy! And more ideal. Thanks for letting me know!
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.
But then we can't reproduce the onChange
moving on Storybook, but that's not a problem, right? Or I guess I might miss something...
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.
The onChange
should still be observable in the Actions panel as before. Is it not working in your environment? The only reason we need to merge the incoming onChange
function is when it's used in controlled mode and you need to call the setValue
as well.
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 my environment, the story of the AlignmentToolbar
component does not work properly. The onChange
event is fired, but the text alignment is not updated. Does this component not support uncontrolled mode?
d5e018c76f3413012303cbe0189ea76b.mp4
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.
Ah right, my bad! I guess it doesn't support uncontrolled. I'd still recommend using CSF 3 format (instead of the Template.bind()
) for new stories though:
export const Default = {
render: function Template( { onChange, ...args } ) {
const [ value, setValue ] = useState();
return (
<AlignmentToolbar
{ ...args }
onChange={ ( ...changeArgs ) => {
onChange( ...changeArgs );
setValue( ...changeArgs );
} }
value={ value }
/>
);
},
};
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.
Thank you two! I updated as you wrote.
…/aliginment-toolbar.story.js Co-authored-by: Lena Morita <lena@jaguchi.com>
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.
🚀
…onents (#67046) * Add stories for AlignmentToolbar and AlignmentControl components * Remove unneccesery args * package.json: remove packageManager entry * Rename the story file and remove unnecessary args from AlignmentControl story * Update packages/block-editor/src/components/alignment-control/stories/aliginment-toolbar.story.js Co-authored-by: Lena Morita <lena@jaguchi.com> * Add render function --------- Co-authored-by: miminari <mimitips@git.wordpress.org> Co-authored-by: t-hamano <wildworks@git.wordpress.org> Co-authored-by: mirka <0mirka00@git.wordpress.org>
What?
This PR will add stories for AlignmentToolbar and AlignmentControl components in the Storybook
Why?
Most of Block Editor components don't have stories.
Block Editor components's Storybook should also be added and updated like the Components.
see #66519
related #22891
How?
I have referred to the TextAlignmentControl story.
AlignmentControl and AlignmentToolbar are based on same component, but there are deliberately generated as a component with a different name, so I created in two separate files.
Testing Instructions
npm run storybook:dev
and please check the AlignmentControl and AlignmentToolbar stories.Testing Instructions for Keyboard
Screenshots or screencast
Kapture.2024-11-16.at.13.37.50.mp4