Skip to content
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 BlockAlignmentMatrixControl Component #67292

Conversation

Sukhendu2002
Copy link
Contributor

@Sukhendu2002 Sukhendu2002 commented Nov 26, 2024

Part of #67165

What?

This PR will add stories for BlockAlignmentMatrixControl component in the Storybook.

Testing Instructions

  1. Run npm run storybook:dev
  2. Open the storybook on http://localhost:50240/
  3. Check the BlockAlignmentMatrixControl stories.

Screenshots or screencast

Screenshot 2024-12-02 at 5 35 09 PM

@Sukhendu2002 Sukhendu2002 marked this pull request as ready for review November 26, 2024 06:52
Copy link

github-actions bot commented Nov 26, 2024

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 props-bot label.

If you're merging code through a pull request on GitHub, copy and paste the following into the bottom of the merge commit message.

Co-authored-by: Sukhendu2002 <[email protected]>
Co-authored-by: t-hamano <[email protected]>
Co-authored-by: ciampo <[email protected]>

To understand the WordPress project's expectations around crediting contributors, please review the Contributor Attribution page in the Core Handbook.

@akasunil akasunil added [Type] Developer Documentation Documentation for developers Storybook Storybook and its stories for components labels Nov 28, 2024
@miminari miminari requested review from ciampo and removed request for ellatrix November 28, 2024 23:35
@ciampo ciampo requested a review from a team December 4, 2024 17:17
@ciampo ciampo removed their request for review December 13, 2024 16:06
@ciampo
Copy link
Contributor

ciampo commented Dec 13, 2024

Thank you for the ping. We @WordPress/gutenberg-components will try to get to reviewing this soon, but in the meantime I'll add a few more folks in case they have capacity for a first round of review before us.

@ciampo ciampo requested review from t-hamano and Mamaduka December 13, 2024 16:08
Copy link
Contributor

@t-hamano t-hamano left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Thanks for the PR! Thanks for noticing that the props in the README weren't complete 😅

| `label` | `string` | `Change matrix alignment` | concise description of tool's functionality. |
| `onChange` | `function` | `noop` | the function to execute upon a user's change of the matrix state |
| `value` | `string` | `center` | describes the content alignment location and can be `top`, `right`, `bottom`, `left`, `topRight`, `bottomRight`, `bottomLeft`, `topLeft` |
| `label` | `string` | `Change matrix alignment` | Label for the control. |
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

In the block-editor package, there are no strict rules for the format of props, but the table format is not used outside of this component.

The following format, which is the most widely used, may be a good choice.

### Props

### `propName`

-   **Type:** `String`
-   **Default:** `none`
-   **Options:** `one`, `two`, `three`

Prop description goes here.

### `onChange`

-   **Type:** `Function`

Prop description goes here.

control: 'text',
table: {
type: { summary: 'string' },
defaultValue: { summary: 'center center' },
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
defaultValue: { summary: 'center center' },
defaultValue: { summary: "'center'" },

I think the default value is "center".

| `value` | `string` | `center` | describes the content alignment location and can be `top`, `right`, `bottom`, `left`, `topRight`, `bottomRight`, `bottomLeft`, `topLeft` |
| `label` | `string` | `Change matrix alignment` | Label for the control. |
| `onChange` | `function` | `noop` | Function to execute upon a user's change of the matrix state. |
| `value` | `string` | `center` | Describes the content alignment location and can be `center center`, `center left`, `center right`, `top center`, `top left`, `top right`, `bottom center`, `bottom left`, `bottom right`. |
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

"center" should also be acceptable:

export type AlignmentMatrixControlValue =
| 'top left'
| 'top center'
| 'top right'
| 'center left'
| 'center'
| 'center center'
| 'center right'
| 'bottom left'
| 'bottom center'
| 'bottom right';

description: 'Disables the control.',
},
value: {
control: 'text',
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
control: 'text',
control: { type: null },

Since the value prop is controlled by useState, I don't think a text field is necessary.

control: 'text',
table: {
type: { summary: 'string' },
defaultValue: { summary: 'Change matrix alignment' },
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
defaultValue: { summary: 'Change matrix alignment' },
defaultValue: { summary: "'Change matrix alignment'" },

It might be better to explicitly state that it is a string type.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Storybook Storybook and its stories for components [Type] Developer Documentation Documentation for developers
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants