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

ensure direct clicks to the dialog can only close the dialog #2553

Merged

Conversation

keithamus
Copy link
Member

Authors: Please fill out this form carefully and completely.

Reviewers: By approving this Pull Request you are approving the code change, as well as its deployment and mitigation plans.
Please read this description carefully. If you feel there is anything unclear or missing, please ask for updates.

What are you trying to accomplish?

In #2549 we shipped a fix whereby clicking outside of a dialog would close the dialog, even if clicking an element that overflowed the bounds of the dialog - for example clicking an item in an action menu that overflowed.

While v0.17.1 fixes that particular bug it introduced a regression with that fix; because we call .stopPropagation() on the click of the dialog show button, anything which reached into the dialog show button to add a click listener would no longer receive events. Consequently this caused a regression in some of dotcom.

This PR revisits that fix by taking an alternate route; see below.

Screenshots

No visual changes.

Integration

No

List the issues that this change affects.

Closes # (type the GitHub issue number after #)

Risk Assessment

  • Low risk the change is small, highly observable, and easily rolled back.
  • Medium risk changes that are isolated, reduced in scope or could impact few users. The change will not impact library availability.
  • High risk changes are those that could impact customers and SLOs, low or no test coverage, low observability, or slow to rollback.

What approach did you choose and why?

Rather than stopping propagation in the button, this checks that the inner-most click target is the dialog itself, and that that click is out of bounds of the dialogs bounding rect. This means:

  • clicking on the dialog will do nothing (as its inside the bounds)
  • clicking on an item that overflows the dialog will do nothing (as the target won't be the actual dialog element)
  • clicking on the backdrop will close (as the backdrop's target is always the dialog element, but it is outside of the bounds of the dialog rect).

Anything you want to highlight for special attention from reviewers?

Accessibility

  • New axe violation - This change introduces a new axe scan violation. Please describe why the violation cannot be resolved below.

Merge checklist

  • Added/updated tests
  • Added/updated documentation
  • Added/updated previews (Lookbook)
  • Tested in Chrome
  • Tested in Firefox
  • Tested in Safari
  • Tested in Edge

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

@keithamus keithamus requested review from a team and camertron February 1, 2024 09:39
Copy link

changeset-bot bot commented Feb 1, 2024

🦋 Changeset detected

Latest commit: ab41339

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

This PR includes changesets to release 1 package
Name Type
@primer/view-components Patch

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

@keithamus keithamus force-pushed the ensure-direct-clicks-to-the-dialog-can-only-close-the-dialog branch from dd28b8f to 6680225 Compare February 1, 2024 10:34
@camertron camertron merged commit 1ca2f17 into main Feb 1, 2024
29 of 30 checks passed
@camertron camertron deleted the ensure-direct-clicks-to-the-dialog-can-only-close-the-dialog branch February 1, 2024 19:43
@primer primer bot mentioned this pull request Feb 1, 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