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

ActionList: Add ActionList.GroupHeading component and update the existing internal Header component for better semantics #3900

Merged
merged 8 commits into from
Nov 10, 2023

Conversation

broccolinisoup
Copy link
Member

@broccolinisoup broccolinisoup commented Nov 3, 2023

Closes #

Changelog

New

As accepted in https://github.com/github/primer/pull/2484, added ActionList.GroupHeading API to be able to generate more accessible semantics for the action list.

Changed

Internal component

Header component in ActionList/Group.tsx renamed to be GroupHeading and exported to be used for the new ActionList.GroupHeading API but still supports the old API<ActionList.Group title="group title" >...</ActionList.Group>

Generated HTML for action list
for list role
<h2 id="list-id">Filter By</h2>
<ul role="list" aria-labelledby="list-id">
  <li>
-  <div role="presentation" aria-hidden="true"><span id="group-heading-path">Path</span></div>
+  <h3 id="group-heading-path">Path</h3>
    <ul aria-labelledby="group-heading-path">
      <li>app/assets/modules</li>
      <li>src/react/components</li>
      <li>memex/shared-ui/components</li>
    </ul>
  </li>
 <li>
    <h3 id="group-heading-advanced">Advanced</h3>
    <ul aria-labelledby="group-heading-advanced">
      <li>Owner</li>
      <li>Symbol</li>
      <li>Exclude archived</li>
    </ul>
  </li>
</ul>
For listbox and menu role
<h2 id="list-id">Reviewers</h2>
<ul role="listbox" aria-labelledby="list-id">
  <li role="none">
     <div role="presentation" aria-hidden="true"><span id="group-heading-everyone">Everyone</span></div>
-    <ul aria-labelledby="group-heading-everyone" role="group">
+    <ul aria-label="Everyone" role="group"> 
      <li role="option">broccolinisoup</li>
      <li role="option">siddharthkp</li>
      <li role="option">pksjce</li>
    </ul>
  </li>
</ul>

Removed

Rollout strategy

  • Patch release
  • Minor release
  • Major release; if selected, include a written rollout or migration plan

Testing & Reviewing

Merge checklist

Take a look at the What we look for in reviews section of the contributing guidelines for more information on how we review PRs.

Copy link

changeset-bot bot commented Nov 3, 2023

🦋 Changeset detected

Latest commit: 11daf88

The changes in this PR will be included in the next version bump.

This PR includes changesets to release 1 package
Name Type
@primer/react Minor

Not sure what this means? Click here to learn what changesets are.

Click here if you're a maintainer who wants to add another changeset to this PR

@broccolinisoup broccolinisoup temporarily deployed to github-pages November 3, 2023 03:19 — with GitHub Actions Inactive
@github-actions github-actions bot temporarily deployed to storybook-preview-3900 November 3, 2023 03:20 Inactive
@broccolinisoup broccolinisoup added the skip changeset This change does not need a changelog label Nov 3, 2023
@broccolinisoup broccolinisoup temporarily deployed to github-pages November 3, 2023 03:52 — with GitHub Actions Inactive
@github-actions github-actions bot temporarily deployed to storybook-preview-3900 November 3, 2023 03:52 Inactive
@broccolinisoup broccolinisoup force-pushed the bs/groupheading-actionlist branch from c91ff68 to e389239 Compare November 3, 2023 04:00
@broccolinisoup broccolinisoup changed the title add group heading ActionList: Add ActionList.GroupHeading component and update the existing internal Header component for better semantics Nov 3, 2023
Copy link
Contributor

github-actions bot commented Nov 3, 2023

size-limit report 📦

Path Size
dist/browser.esm.js 104.2 KB (+0.17% 🔺)
dist/browser.umd.js 104.74 KB (+0.18% 🔺)

@broccolinisoup broccolinisoup temporarily deployed to github-pages November 3, 2023 04:06 — with GitHub Actions Inactive
@github-actions github-actions bot temporarily deployed to storybook-preview-3900 November 3, 2023 04:07 Inactive
@broccolinisoup broccolinisoup removed the skip changeset This change does not need a changelog label Nov 6, 2023
@broccolinisoup broccolinisoup marked this pull request as ready for review November 6, 2023 05:07
@broccolinisoup broccolinisoup requested review from a team and joshblack November 6, 2023 05:07
@github-actions github-actions bot temporarily deployed to storybook-preview-3900 November 6, 2023 05:11 Inactive
@github-actions github-actions bot temporarily deployed to storybook-preview-3900 November 6, 2023 05:15 Inactive
@github-actions github-actions bot temporarily deployed to storybook-preview-3900 November 6, 2023 05:16 Inactive
Copy link
Member

@siddharthkp siddharthkp left a comment

Choose a reason for hiding this comment

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

GroupHeading looks great!

Copy link
Member

@joshblack joshblack left a comment

Choose a reason for hiding this comment

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

Looking great! Just left a couple comments/questions, can't wait to hear what you think 👀

@@ -96,6 +96,146 @@ export const WithVisualListHeading = () => (
</ActionList>
)

export const ListWithNewGroupHeadingAPI = () => (
Copy link
Member

Choose a reason for hiding this comment

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

From a documentation perspective, would it help to have the story name be more like ListWithHeading or something similar? Trying to think of when someone might be looking for how to do X (where X is adding a heading for a list) and having a story name that makes sense to them.

The terminology "NewGroupedHeadingAPI" feels very clear for maintainers but from a user perspective might not make as much sense.

Copy link
Member Author

Choose a reason for hiding this comment

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

Oh sorry I forgot to mention that I added these stories for dev/code review only to make the changes easily viewable. Since we are going to deprecate the title prop on ActionList.Group and our new API for providing group title is ActionList.GroupHeading, I was thinking to update the stories that use title prop with ActionList.GroupHeading such as GroupWithFilledTitle and GroupWithSubtleTitle. Would that be helpful and enough you think for consumers to find how to add group headings? Also do you think we should still keep stories with the title prop at all? 🤔

Copy link
Member Author

Choose a reason for hiding this comment

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

I'm going to take these stories back in this PR. I am thinking to do a follow up one that adds a @deprecated notation to the title prop and update all title usages with the new API in stories and docs. Let me know if there is any concern!


<ActionList.Group>
<ActionList.GroupHeading as="h3">Group 2 Heading</ActionList.GroupHeading>
<ActionList.Item onClick={() => {}}>
Copy link
Member

Choose a reason for hiding this comment

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

I'm not sure what our conventions are, but when would we use an empty handler for events versus using storybook actions?

Copy link
Member Author

Choose a reason for hiding this comment

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

This is a really good question. I am not really sure either. I find storybook actions useful when the story is about the action like the data table action stories you added are great examples for this use case in my opinion. The stories I added or the ones I mentioned here to update are not focusing on actions, they are focusing on semantics, visuals, and having group titles. This is why, I didn't worry about the action itself but I am more than happy to update them to use storybook actions if it is going to be helpful.
Re-thinking about it now, it is probably helpful to log something (storybook actions could be very beneficial in this case) when the click event is trigger at least so empty event handler isn't very helpful here.

What are your thoughts??

src/ActionList/Group.tsx Outdated Show resolved Hide resolved
Comment on lines 83 to 91
<GroupHeading
title={title}
variant={variant}
auxiliaryText={auxiliaryText}
groupHeadingId={groupHeadingId}
as={slots.groupHeading?.props.as}
>
{slots.groupHeading ? slots.groupHeading.props.children : null}
</GroupHeading>
Copy link
Member

Choose a reason for hiding this comment

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

In this case, are GroupHeading and slots.groupHeading the same component? If so, would cloneElement work in this scenario?

Suggested change
<GroupHeading
title={title}
variant={variant}
auxiliaryText={auxiliaryText}
groupHeadingId={groupHeadingId}
as={slots.groupHeading?.props.as}
>
{slots.groupHeading ? slots.groupHeading.props.children : null}
</GroupHeading>
{cloneElement(slots.groupHeading, {
title,
variant,
auxiliaryText,
groupHeadingId,
})}

Copy link
Member Author

Choose a reason for hiding this comment

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

They are the same components yes.

When I tried cloning though it is complaining about slots.groupHeading might be undefined which is a valid case. If ActionList is using the "to-be-deprecated" API which is <ActionList.Group title="Group heading"> , slots.groupHeading is going to be undefined because I use GroupHeading component to render both (title="Group heading" and <ActionList.GoupHeading>Group heading</GroupHeading>),

They are almost the same component except one is taking title prop and the other is taking children prop to render the heading. I can try splitting them up, or if you have any suggestion I would love to hear it!

src/ActionList/Group.tsx Outdated Show resolved Hide resolved
Copy link
Member

@joshblack joshblack left a comment

Choose a reason for hiding this comment

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

Looks great! Just left a comment with that idea from Slack, figured it'd be more helpful than the snippet I shared there 😂

src/ActionList/Group.tsx Outdated Show resolved Hide resolved
@broccolinisoup broccolinisoup added this pull request to the merge queue Nov 10, 2023
Merged via the queue into main with commit 2f9b586 Nov 10, 2023
29 checks passed
@broccolinisoup broccolinisoup deleted the bs/groupheading-actionlist branch November 10, 2023 01:51
@primer primer bot mentioned this pull request Nov 9, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants