Skip to content

🎨 Palette: Accessibility improvements for Checkbox and Radio controls#173

Open
mknoufi wants to merge 1 commit into
mainfrom
palette/custom-checkbox-radio-a11y-200396649432273131
Open

🎨 Palette: Accessibility improvements for Checkbox and Radio controls#173
mknoufi wants to merge 1 commit into
mainfrom
palette/custom-checkbox-radio-a11y-200396649432273131

Conversation

@mknoufi
Copy link
Copy Markdown
Owner

@mknoufi mknoufi commented May 13, 2026

User description

🎨 Palette: Accessibility improvements for Checkbox and Radio controls

💡 What:
Added explicit accessibilityRole, accessibilityState, accessibilityLabel, and accessibilityHint props to the custom Checkbox and Radio components in the design system.

🎯 Why:
These custom components were built using a generic TouchableOpacity, which provides no semantic meaning or state context to screen readers out of the box. By explicitly identifying them as checkboxes/radios and tracking their state (checked, disabled), screen reader users can now successfully navigate and interact with forms that use these controls.

♿ Accessibility:

  • Added accessibilityRole="checkbox" to Checkbox.tsx.
  • Added accessibilityRole="radio" to Radio.tsx.
  • Bound accessibilityState={{ checked, disabled }} to both controls so their active status is announced dynamically.
  • Implemented pass-through support for custom accessibilityLabel and accessibilityHint props, with a safe fallback to the component's visual text label.

PR created automatically by Jules for task 200396649432273131 started by @mknoufi


CodeAnt-AI Description

Make custom checkbox and radio controls readable and usable with screen readers

What Changed

  • Checkbox and radio options now announce their role and checked state correctly to screen readers
  • Disabled controls are announced as disabled, so users know when they cannot be selected
  • Each control can now use a custom accessibility label and hint, with the visible text used as a fallback when no label is provided

Impact

✅ Clearer form controls for screen reader users
✅ Fewer accessibility errors in custom inputs
✅ Easier selection of checkbox and radio options

💡 Usage Guide

Checking Your Pull Request

Every time you make a pull request, our system automatically looks through it. We check for security issues, mistakes in how you're setting up your infrastructure, and common code problems. We do this to make sure your changes are solid and won't cause any trouble later.

Talking to CodeAnt AI

Got a question or need a hand with something in your pull request? You can easily get in touch with CodeAnt AI right here. Just type the following in a comment on your pull request, and replace "Your question here" with whatever you want to ask:

@codeant-ai ask: Your question here

This lets you have a chat with CodeAnt AI about your pull request, making it easier to understand and improve your code.

Example

@codeant-ai ask: Can you suggest a safer alternative to storing this secret?

Preserve Org Learnings with CodeAnt

You can record team preferences so CodeAnt AI applies them in future reviews. Reply directly to the specific CodeAnt AI suggestion (in the same thread) and replace "Your feedback here" with your input:

@codeant-ai: Your feedback here

This helps CodeAnt AI learn and adapt to your team's coding style and standards.

Example

@codeant-ai: Do not flag unused imports.

Retrigger review

Ask CodeAnt AI to review the PR again, by typing:

@codeant-ai: review

Check Your Repository Health

To analyze the health of your code repository, visit our dashboard at https://app.codeant.ai. This tool helps you identify potential issues and areas for improvement in your codebase, ensuring your repository maintains high standards of code health.

…components

- Modified `Checkbox` and `Radio` core components to accept and apply `accessibilityLabel` and `accessibilityHint`.
- Added `accessibilityRole="checkbox"` and `accessibilityRole="radio"` respectively to the underlying `TouchableOpacity`.
- Added dynamic `accessibilityState` mapping to track `checked` and `disabled` states for screen readers.
- Recorded a learning in `.Jules/palette.md` noting that custom React Native UI components built using `TouchableOpacity` fail to behave natively for screen readers without explicitly mapping roles and states.

Co-authored-by: mknoufi <209227354+mknoufi@users.noreply.github.com>
@google-labs-jules
Copy link
Copy Markdown
Contributor

👋 Jules, reporting for duty! I'm here to lend a hand with this pull request.

When you start a review, I'll add a 👀 emoji to each comment to let you know I've read it. I'll focus on feedback directed at me and will do my best to stay out of conversations between you and other bots or reviewers to keep the noise down.

I'll push a commit with your requested changes shortly after. Please note there might be a delay between these steps, but rest assured I'm on the job!

For more direct control, you can switch me to Reactive Mode. When this mode is on, I will only act on comments where you specifically mention me with @jules. You can find this option in the Pull Request section of your global Jules UI settings. You can always switch back!

New to Jules? Learn more at jules.google/docs.


For security, I will only act on instructions from the user who triggered this task.

@qodo-code-review
Copy link
Copy Markdown

Qodo reviews are paused for this user.

Troubleshooting steps vary by plan Learn more →

On a Teams plan?
Reviews resume once this user has a paid seat and their Git account is linked in Qodo.
Link Git account →

Using GitHub Enterprise Server, GitLab Self-Managed, or Bitbucket Data Center?
These require an Enterprise plan - Contact us
Contact us →

@codeant-ai
Copy link
Copy Markdown

codeant-ai Bot commented May 13, 2026

CodeAnt AI is reviewing your PR.


Thanks for using CodeAnt! 🎉

We're free for open-source projects. if you're enjoying it, help us grow by sharing.

Share on X ·
Reddit ·
LinkedIn

@codeant-ai codeant-ai Bot added the size:S This PR changes 10-29 lines, ignoring generated files label May 13, 2026
Copy link
Copy Markdown

@chatgpt-codex-connector chatgpt-codex-connector Bot left a comment

Choose a reason for hiding this comment

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

💡 Codex Review

Here are some automated review suggestions for this pull request.

Reviewed commit: a9d7e737bf

ℹ️ About Codex in GitHub

Your team has set up Codex to review pull requests in this repo. Reviews are triggered when you

  • Open a pull request for review
  • Mark a draft as ready
  • Comment "@codex review".

If Codex has suggestions, it will comment; otherwise it will react with 👍.

Codex can also answer questions or update the PR. Try commenting "@codex address that feedback".

disabled={disabled}
activeOpacity={0.7}
accessibilityRole="checkbox"
accessibilityState={{ checked: checked || indeterminate, disabled }}
Copy link
Copy Markdown

Choose a reason for hiding this comment

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

P2 Badge Use mixed accessibility state for indeterminate checkbox

When indeterminate is true, this sets accessibilityState.checked to true via checked || indeterminate, so screen readers will announce the control as simply checked instead of mixed. In React Native, mixed checkboxes should expose checked: "mixed"; otherwise users relying on assistive tech cannot distinguish partially selected state from fully selected state.

Useful? React with 👍 / 👎.

@sonarqubecloud
Copy link
Copy Markdown

@codeant-ai
Copy link
Copy Markdown

codeant-ai Bot commented May 13, 2026

CodeAnt AI finished reviewing your PR.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:S This PR changes 10-29 lines, ignoring generated files

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant