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

bug: Disabled gcds-button Emits Event When Activated via Keyboard Navigation (Enter Key) #720

Closed
3 tasks done
Garry-08 opened this issue Jan 3, 2025 · 4 comments
Closed
3 tasks done
Assignees
Labels
bug Something isn't working development Development tasks

Comments

@Garry-08
Copy link

Garry-08 commented Jan 3, 2025

Prerequisites | Prérequis

GC Design System Components Package and Version | Paquet et version des composants de Système de design GC

cdssnc/gcds-components-vue, version 0.26.2

Current Behavior | Comportement observé

Expected Accessibility Behavior: A disabled gcds-button is focusable for screen readers, which is correct.
But the Issue is in:
Despite the :disabled="region?.isUsed" condition being true, pressing the EnterKey while focusing the disabled button via keyboard navigation still triggers the @gcdsClick event.

Clicking the same button with a mouse does not emit the event, which is the correct behavior.

Expected Behavior | Comportement attendu

Event Behavior: A disabled button should not emit events regardless of how it is interacted with (Tab + Enter or mouse click).

System Info | Information sur le système

Browser: Chrome, Edge
Operating System: Windows 10
IDE: IntelliJ IDEA
Node.js Version: v20.12.2
npm Version: 10.5.0

Steps to Reproduce | Étapes pour reproduire le bogue

<gcds-button
  button-id="delete-button"
  button-role="danger"
  size="small"
  :disabled="region?.isUsed"
  @gcdsClick="openModal"
>
  Delete
</gcds-button>

Code Reproduction URL | URL de reproduction du code

No response

Additional Information | Informations supplémentaires

Improvement Suggestion: Visually differentiate the focused state of disabled buttons (e.g., different border color or opacity) as currently it is same as the enabled button.

@ethanWallace ethanWallace added the bug Something isn't working label Jan 8, 2025
@ethanWallace ethanWallace self-assigned this Jan 8, 2025
@ethanWallace ethanWallace added the development Development tasks label Jan 13, 2025
@dfo-proto
Copy link

dfo-proto commented Jan 16, 2025

@ethanWallace following up on the improvement suggestion. Accessibility best practice is to remove disabled controls from the focus order, to align with the native web behavior of the disabled attribute. I'm wondering if your team encountered something different.

~Oyin

@daine
Copy link
Collaborator

daine commented Jan 20, 2025

@dfo-proto Hi Oyin, we will bring the feedback to the team as it is a design improvement, we'll see how we can iterate on it and provide a better accessible experience. We'll work on that item (i.e. different pull request/release) separate from the reported bug behaviour. Thanks for following up!

cc @SmartMouthWords @adorayi FYI

@ethanWallace
Copy link
Collaborator

Hey @Garry-08, the issue has been addressed in our 0.31.0 release.

@daine
Copy link
Collaborator

daine commented Jan 27, 2025

Closing this ticket as the bug has been fixed. We're actively looking into the suggestions around the focus state of the disabled button.

@daine daine closed this as completed Jan 27, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
bug Something isn't working development Development tasks
Projects
None yet
Development

No branches or pull requests

4 participants