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: ensure Announce components work without pre-existing text node #5568

Draft
wants to merge 1 commit into
base: main
Choose a base branch
from

Conversation

khiga8
Copy link
Contributor

@khiga8 khiga8 commented Jan 17, 2025

Closes #5566, https://github.com/github/accessibility-audits/issues/10031, https://github.com/github/accessibility-audits/issues/10017

Right now, announcements are not being triggered when the announce components (Announcement, AriaStatus, AriaAlert) go from being empty, to having text. See linked issue for broken examples.

The announcements do work in instances where these components have pre-existing text that gets updated.

Upon placing a debugger, I noticed we're not hitting the MutationObserver's callback in the failing scenario (where we go from empty to no text). This is because we need to set childList: true to detect when text nodes are added/removed. The current config, subtree: true and characterData: true, will only detect when existing text nodes are updated.

Set to true to monitor the target node (and, if subtree is true, its descendants) for the addition of new child nodes or removal of existing child nodes. The default value is false.

Changelog

Changed

  • Ensures that announcement are triggered when content is added to Announce, AriaAlert, AriaStatus without pre-existing text.

Rollout strategy

  • Patch release
  • Minor release
  • Major release; if selected, include a written rollout or migration plan
  • None; if selected, include a brief description as to why

Testing & Reviewing

Merge checklist

Copy link

changeset-bot bot commented Jan 17, 2025

⚠️ No Changeset found

Latest commit: 967a963

Merging this PR will not cause a version bump for any packages. If these changes should not result in a new version, you're good to go. If these changes should result in a version bump, you need to add a changeset.

This PR includes no changesets

When changesets are added to this PR, you'll see the packages that this PR includes changesets for and the associated semver types

Click here to learn what changesets are, and how to add one.

Click here if you're a maintainer who wants to add a changeset to this PR

Copy link
Contributor

👋 Hi, this pull request contains changes to the source code that github/github depends on. If you are GitHub staff, we recommend testing these changes with github/github using the integration workflow. Thanks!

Copy link
Contributor

size-limit report 📦

Path Size
packages/react/dist/browser.esm.js 104.2 KB (-0.05% 🔽)
packages/react/dist/browser.umd.js 104.58 KB (+0.02% 🔺)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
integration-tests: recommended This change needs to be tested for breaking changes. See https://arc.net/l/quote/tdmpakpm
Projects
None yet
Development

Successfully merging this pull request may close these issues.

AriaAlert and AriaStatus announcements are broken
1 participant