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

Add CheckboxGroup and RadioGroup components #830

Merged
merged 32 commits into from
Dec 3, 2024

Conversation

joshfarrant
Copy link
Contributor

@joshfarrant joshfarrant commented Nov 25, 2024

Summary

Adds CheckboxGroup and RadioGroup components which, for the time being, are just implementations of the new private ControlGroup component. These components allow us to group Radio and Checkbox components using a <fieldset> and label them with a <legend>, providing a more accessible and semantic way to group related form elements.

List of notable changes:

  • Adds ControlGroup component (alternate name suggestions welcome)
  • Adds CheckboxGroup and RadioGroup components, tests, and stories

Still to do (in future PRs)

  • Add documentation for the new components
  • Consume new components in our existing documentation and stories

What should reviewers focus on?

  • There were some spacing inconsistencies between the Figma file I was using for reference and our actual form element sizes in Primer Brand.
    • Specifically, font sizes varied between the two. Figma has the font sizes of the Radio and Checkbox labels, as well as the validation, at 14px, but in PB they're all 16px. Could you advise which way to go with this please @danielguillan, as well as giving the design of the components a quick check too please?
  • I used the new(ish) CSF3 in the stories. The only difference is the fact that stories now export objects with a render function, rather than exporting components. Although I didn't use it here, this has the added benefit of letting you create/update component stories from within the Storybook UI and save the new stories to disk. Happy to revert this if we'd prefer to keep things consistent, but at some point it might be a good idea to update all stories to CSF3 as one less thing to worry about for future Storybook upgrades.

Steps to test:

  1. Take a look at the Storybook

Supporting resources (related issues, external links, etc):

Contributor checklist:

  • All new and existing CI checks pass
  • Tests prove that the feature works and covers both happy and unhappy paths
  • Any drop in coverage, breaking changes or regressions have been documented above
  • UI Changes contain new visual snapshots (generated by adding update snapshots label to the PR)
  • All developer debugging and non-functional logging has been removed
  • Related issues have been referenced in the PR description

Reviewer checklist:

  • Check that pull request and proposed changes adhere to our contribution guidelines and code of conduct
  • Check that tests prove the feature works and covers both happy and unhappy paths
  • Check that there aren't other open Pull Requests for the same update/change

Screenshots:

Please try to provide before and after screenshots or videos

RadioGroup CheckboxGroup

image

image

Copy link

changeset-bot bot commented Nov 25, 2024

🦋 Changeset detected

Latest commit: b535c93

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

This PR includes changesets to release 6 packages
Name Type
@primer/react-brand Minor
@primer/brand-primitives Minor
@primer/brand-e2e Minor
@primer/brand-fonts Minor
@primer/brand-config Minor
@primer/brand-storybook 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

Copy link
Contributor

github-actions bot commented Nov 25, 2024

🟢 No design token changes found

Choose a reason for hiding this comment

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

Copilot reviewed 16 out of 26 changed files in this pull request and generated no suggestions.

Files not reviewed (10)
  • packages/react/src/forms/InputGroup/InputGroup.module.css: Language not supported
  • packages/react/src/forms/RadioGroup/RadioGroup.tsx: Evaluated as low risk
  • packages/react/src/forms/CheckboxGroup/CheckboxGroup.stories.tsx: Evaluated as low risk
  • packages/react/src/forms/CheckboxGroup/CheckboxGroup.test.tsx: Evaluated as low risk
  • packages/react/src/forms/index.ts: Evaluated as low risk
  • packages/react/src/forms/CheckboxGroup/index.ts: Evaluated as low risk
  • .changeset/popular-seas-yawn.md: Evaluated as low risk
  • packages/react/src/forms/InputGroup/index.ts: Evaluated as low risk
  • packages/react/src/forms/RadioGroup/RadioGroup.stories.tsx: Evaluated as low risk
  • packages/react/src/forms/RadioGroup/index.ts: Evaluated as low risk
Comments skipped due to low confidence (3)

packages/react/src/forms/CheckboxGroup/CheckboxGroup.visual.spec.ts:8

  • Consider removing the eslint-disable comment and ensuring that the code adheres to the i18n-text/no-en rule.
// eslint-disable-next-line i18n-text/no-en

packages/react/src/forms/InputGroup/InputGroup.tsx:20

  • The error message should be more concise and specific, e.g., 'useInputGroup must be used within an InputGroupProvider.'
throw new Error('useInputGroup must be used within an InputGroupProvider. Did you forget to wrap your component in a <InputGroupProvider>?')

packages/react/src/forms/CheckboxGroup/CheckboxGroup.tsx:14

  • [nitpick] Consider adding a comment explaining that CheckboxGroup is currently just an alias for InputGroup to provide context for future maintainers.
export const CheckboxGroup = InputGroup

Tip: Copilot only keeps its highest confidence comments to reduce noise and keep you focused. Learn more

Copy link
Contributor

github-actions bot commented Nov 25, 2024

🟢 No visual differences found

Our visual comparison tests did not find any differences in the UI.

@joshfarrant joshfarrant force-pushed the joshfarrant/checkbox-radio-group branch from 5be3a2e to 810a183 Compare November 26, 2024 12:02
}

.ControlGroup__validation--animate-in {
animation: 170ms ControlGroupValidationFadeIn cubic-bezier(0.44, 0.74, 0.36, 1);
Copy link
Collaborator

@rezrah rezrah Dec 3, 2024

Choose a reason for hiding this comment

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

Non-blocking:

Appreciate these are probably from FormControl. We have newer animation-specific variables now, but none that match directly to this.

@joshfarrant, how close are these values to what's above? Can we sub them out? Can also do this in a separate PR.

Screenshot 2024-12-03 at 11 55 34

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Yes this was pulled from FormControl. You can see the three curves below.

Our curve:
image

vs default:
image

vs glide:
image

I'd say that glide is probably the closest. Happy to switch this out

Copy link
Contributor Author

Choose a reason for hiding this comment

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

I've just gone ahead and updated it to brand-animation-duration-glide

expect(results).toHaveNoViolations()
})

describe('aria-describedby', () => {
Copy link
Collaborator

Choose a reason for hiding this comment

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

Nit and more of a style preference: do we need the nested describe block? Could we instead rename the title of each test case to be more descriptive?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Not required at all, but I quite like it as it

  • Keeps test names more focussed
  • Logically groups related tests in the code
  • Groups tests in the output

image

Happy to remove it if you don't like it though

Copy link
Collaborator

Choose a reason for hiding this comment

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

Yeah this is more style and consistency thing. Having it all in one title means the purpose of test case can be understood in isolation, and without context. Nested describes assume that it's also labelled appropriately enough, which might not always be the case. I got caught out here for example, as I was reading the titles without realising they were referring to a specific aspect of the component aria-describedby. As it's not how we write our test cases everywhere else, I'd prefer to keep it consistent for readability reasons, though we can fix this later too so non-blocking.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

Cool, updated 👍

Copy link
Collaborator

@rezrah rezrah left a comment

Choose a reason for hiding this comment

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

Thanks @joshfarrant, these new components are great ✨

@joshfarrant joshfarrant merged commit 1f9eb72 into main Dec 3, 2024
18 checks passed
@joshfarrant joshfarrant deleted the joshfarrant/checkbox-radio-group branch December 3, 2024 14:03
@primer-css primer-css mentioned this pull request Dec 3, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants