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

feat: update focus states for Dropdown, Combobox & Multiselect #18230

Merged
merged 20 commits into from
Jan 23, 2025

Conversation

annawen1
Copy link
Member

@annawen1 annawen1 commented Dec 9, 2024

Closes #18071

Update focus states depending on if there are selected items and if user clicks/enters or presses arrow down for the following components:

  • Dropdown
  • Fluid Dropdown
  • ComboBox
  • Fluid ComboBox
  • Multiselect
  • Fluid MultiSelect
  • Filterable Multiselect
  • Select all

Following this figma kit

Changelog

Changed

  • adjust focus styles
  • add focus classnames
  • added new tests to make sure focus state is correct

Removed

  • console.log
  • removed initial selected items from the default stories for the test cases

Testing / Reviewing

Go to deploy preview check the click/enter/arrow-down interactions for the above mentioned components and make sure it follows this figma kit

Copy link

netlify bot commented Dec 9, 2024

Deploy Preview for v11-carbon-web-components ready!

Name Link
🔨 Latest commit 36e8e41
🔍 Latest deploy log https://app.netlify.com/sites/v11-carbon-web-components/deploys/679226527e75bb0008d15c1f
😎 Deploy Preview https://deploy-preview-18230--v11-carbon-web-components.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link

netlify bot commented Dec 9, 2024

Deploy Preview for carbon-elements ready!

Name Link
🔨 Latest commit 36e8e41
🔍 Latest deploy log https://app.netlify.com/sites/carbon-elements/deploys/6792265208a2a400083c14ca
😎 Deploy Preview https://deploy-preview-18230--carbon-elements.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link

netlify bot commented Dec 9, 2024

Deploy Preview for v11-carbon-react ready!

Built without sensitive environment variables

Name Link
🔨 Latest commit 36e8e41
🔍 Latest deploy log https://app.netlify.com/sites/v11-carbon-react/deploys/67922652c8c8d00009b9abaf
😎 Deploy Preview https://deploy-preview-18230--v11-carbon-react.netlify.app
📱 Preview on mobile
Toggle QR Code...

QR Code

Use your smartphone camera to open QR code link.

To edit notification comments on pull requests, go to your Netlify site configuration.

Copy link

codecov bot commented Dec 9, 2024

Codecov Report

Attention: Patch coverage is 76.92308% with 3 lines in your changes missing coverage. Please review.

Project coverage is 84.15%. Comparing base (02d6f94) to head (36e8e41).
Report is 1 commits behind head on main.

Files with missing lines Patch % Lines
...ackages/react/src/components/Dropdown/Dropdown.tsx 60.00% 2 Missing ⚠️
...c/components/MultiSelect/FilterableMultiSelect.tsx 0.00% 1 Missing ⚠️
Additional details and impacted files
@@            Coverage Diff             @@
##             main   #18230      +/-   ##
==========================================
- Coverage   84.17%   84.15%   -0.02%     
==========================================
  Files         408      408              
  Lines       14435    14443       +8     
  Branches     4690     4641      -49     
==========================================
+ Hits        12150    12155       +5     
- Misses       2120     2124       +4     
+ Partials      165      164       -1     

☔ View full report in Codecov by Sentry.
📢 Have feedback on the report? Share it here.

@annawen1 annawen1 marked this pull request as ready for review December 17, 2024 19:48
@annawen1 annawen1 requested a review from a team as a code owner December 17, 2024 19:48
Copy link
Contributor

@Kritvi-bhatia17 Kritvi-bhatia17 left a comment

Choose a reason for hiding this comment

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

Hi @annawen1,
Thank you for working on this! I have a few small points I wanted to share and discuss. Please let me know if you'd prefer to connect over a call to go over these in more detail:

Fluid Dropdown

There seems to be a bug where the focus stroke doesn’t reappear after using the down arrow key.

Screen Recording 2024-12-26 at 7 13 56 PM

Combo box & Multiselect

  1. Just wanted to crosscheck if the focus stroke is 2px in situations like these:

image

  1. Is the focus state supposed to move dynamically with the cursor, similar to the dropdown?

Screen Recording 2024-12-24 at 2 53 52 PM
Screen Recording 2024-12-24 at 2 53 06 PM

  1. For both fluid and default filterable multi-select and filterable with layer multi-select, the down arrow key doesn’t appear to function as expected.
image
  1. In fluid filterable and filterable with layer multi-select, the tab and enter key interactions don’t align with what’s specified in the Figma kit:

image

@annawen1
Copy link
Member Author

annawen1 commented Jan 13, 2025

@Kritvi-bhatia17 I believe all the issues are now resolved except for

ComboBox & Multiselect
Is the focus state supposed to move dynamically with the cursor, similar to the dropdown?

For that we can open a new ticket to confirm and address

Copy link
Contributor

@Kritvi-bhatia17 Kritvi-bhatia17 left a comment

Choose a reason for hiding this comment

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

Hi Anna! Thanks for fixing everything—this looks great!

Just one last point: in the case of the default and fluid filterable multi-select, when I open the menu and click on it again, the focus border changes from 2px to 1px, and the menu doesn’t close (unlike the combobox). Not sure if this is a bug. Oh I checked the current storybook aswell I think that is also present over there so maybe can be solved separately, up to you to decided.

Screen.Recording.2025-01-16.at.9.09.33.PM.mov

Also, a quick question—should I review the web components Storybook as well, or just focus on the Carbon v11 Storybook?

@annawen1
Copy link
Member Author

annawen1 commented Jan 21, 2025

Hi Anna! Thanks for fixing everything—this looks great!

Just one last point: in the case of the default and fluid filterable multi-select, when I open the menu and click on it again, the focus border changes from 2px to 1px, and the menu doesn’t close (unlike the combobox). Not sure if this is a bug. Oh I checked the current storybook aswell I think that is also present over there so maybe can be solved separately, up to you to decided.

Screen.Recording.2025-01-16.at.9.09.33.PM.mov
Also, a quick question—should I review the web components Storybook as well, or just focus on the Carbon v11 Storybook?

@Kritvi-bhatia17 oh! Hmm I think we can open a separate ticket for that since it's an existing issue, I don't want it to hold up the rest of the work in this PR. The changes are only in the React Carbon v11 Storybook for now, the parity work should help to bridge that gap with web-components

Copy link
Contributor

@Kritvi-bhatia17 Kritvi-bhatia17 left a comment

Choose a reason for hiding this comment

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

Looks good! Thanks for fixing it all 🚀

@annawen1 annawen1 added this pull request to the merge queue Jan 23, 2025
Merged via the queue into carbon-design-system:main with commit eee39f8 Jan 23, 2025
37 checks passed
@annawen1 annawen1 deleted the chore/focus-states branch January 23, 2025 14:50
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.

[Bug]: Update Dropdown, Combobox & Multiselect focus states
4 participants