fix(#5645): Use correct key value to block Space keypress in BtnDisabled#5660
Open
JohnnyMendesC wants to merge 1 commit into
Open
fix(#5645): Use correct key value to block Space keypress in BtnDisabled#5660JohnnyMendesC wants to merge 1 commit into
JohnnyMendesC wants to merge 1 commit into
Conversation
…nDisabledDirective
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment
Add this suggestion to a batch that can be applied as a single commit.This suggestion is invalid because no changes were made to the code.Suggestions cannot be applied while the pull request is closed.Suggestions cannot be applied while viewing a subset of changes.Only one suggestion per line can be applied in a batch.Add this suggestion to a batch that can be applied as a single commit.Applying suggestions on deleted lines is not supported.You must change the existing code in this line in order to create a valid suggestion.Outdated suggestions cannot be applied.This suggestion has been applied or marked resolved.Suggestions cannot be applied from pending reviews.Suggestions cannot be applied on multi-line comments.Suggestions cannot be applied while the pull request is queued to merge.Suggestion cannot be applied right now. Please check back later.
References
Description
Fixes a global accessibility bug in
BtnDisabledDirectivewhere it failed to intercept and block the space bar keypress on visually disabled buttons due to an incorrectKeyboardEvent.keyvalue check.Instructions for Reviewers
The
dsBtnDisableddirective is intended to make HTML elements non-interactive while keeping them discoverable to screen readers (usingaria-disabled="true"). However, the directive'sHostListenerwas checking for the literal stringevent.key === 'Space'instead of the standard web browser value' '. This allowed keyboard-only users to bypass the directive using the Space bar and trigger actions unintentionally.List of changes in this PR:
keydownlistener inBtnDisabledDirectiveto correctly intercept standard browser space character events (event.key === ' ').disabled-directive.spec.tsunit test mocks to use the correct space character string.How to Test
Automated test:
npm run test -- --include='src/app/shared/disabled-directive.spec.ts'Manual test:
Because many components implement internal TypeScript safeguards (e.g.,
if (form.invalid) return;), this bug is often silently masked in production.To easily verify this fix without complex data setup, I created a clean
.patchthat adds an isolated dummy button to the Home Page.Step 1: Apply the Test Patch
Save the code below as
test.patchand apply it locally usinggit apply test.patch(or manually apply the changes):Click to expand the test.patch code
Step 2: Verify Behavior
Checklist
This checklist provides a reminder of what we are going to look for when reviewing your PR. You do not need to complete this checklist prior creating your PR (draft PRs are always welcome).
However, reviewers may request that you complete any actions in this list if you have not done so. If you are unsure about an item in the checklist, don't hesitate to ask. We're here to help!
mainbranch of code (unless it is a backport or is fixing an issue specific to an older branch).npm run lintnpm run check-circ-deps)package.json), I've made sure their licenses align with the DSpace BSD License based on the Licensing of Contributions documentation.