Skip to content

Feat: Make PictoPy More Accessible – Keyboard Navigation & High Contrast Mode #1157

@Nakshatra480

Description

@Nakshatra480

Describe the feature

Problem

Currently, PictoPy's main interface and controls are difficult to use for people who rely on keyboard navigation or need higher contrast for visibility. Key areas affected include:

  • Sidebar navigation has no visible focus indicator (keyboard users can't tell which section is active).
  • Icon-only buttons (e.g., Face Search, Search) have no visible or screen-reader-friendly labels.
  • The theme menu lacks a "High Contrast" option, making it hard for some users to comfortably view content.

These issues make PictoPy less inclusive and harder to use for anyone with visual impairments or those who depend on assistive technology.

Suggested Solution

  • Add strong visible focus rings to sidebar/menu items and inputs, so keyboard users can see what's focused (see "Recommended Fixes" mockup below).
  • Add accessible labels (aria-label/alt text) for all icon-only buttons. Show tooltip on hover and ensure screen readers announce the action.
  • Add a "High Contrast" option to the theme selector, supporting strong color contrast for all UI elements.
  • Update internal documentation to include new accessibility improvements.

Left: current state with missing focus, missing labels, and no high contrast.

Right: strong focus ring, labeled icons, and new theme option.

Why this is needed

This improves usability for everyone – not just users with disabilities – and aligns PictoPy with accessibility standards (WCAG, ADA). It will also make the project more appealing for broader community adoption.

Add ScreenShots

Image

Record

  • I agree to follow this project's Code of Conduct
  • I want to work on this issue

Metadata

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions