Skip to content

feat: Improve ion-reorder accessibility #29296

Open
@dpalou

Description

@dpalou

Prerequisites

Describe the Feature Request

I'm not an accessibility expert so I might be wrong, but I think ion-reorder is not accessible. Some of the things that could be improved are:

  • According to WCAG 2.2 Success Criterion 2.5.7: Dragging Movements (Level AA), there should be an alternative using a "single pointer mode of operation without the need for the dexterity required to drag elements". I'm not sure what this means though. maybe there should be some arrows or similar to move the elements with clicks.
  • Along with the previous point, maybe users should be able to move the elements using keyboard. I guess that if some arrows are added and they're clickable by keyboard, this point would be fulfilled too.
  • When ion-reorder is just an "icon" (not using "Reorder Wrapper"), it would be nice if Ionic automatically calculated the aria-label of ion-reorder based on the item contents (unless it already has an aria-label, aria-labelledby or similar). I think other Ionic components do something similar. Also, I guess the aria-label should also explain how to move the item.
  • When using Talkback and selecting the item's label (again, not using "Reorder Wrapper"), Talkback says "double tap to activate" but there is nothing to activate there.
  • When an item is repositioned, I guess there should be some message in an "aria-live" element.

Describe the Use Case

As a visual impaired user, I want to be able to use ion-reorder easily (using Talkback/Voiceover or a keyboard).

Describe Preferred Solution

No response

Describe Alternatives

No response

Related Code

This is the template I used, in case it's helpful:

<ion-reorder-group [disabled]="dragDisabled" (ionItemReorder)="handleReorder($event.detail)">
    @for (item of items; track $index) {
      <ion-card>
          <ion-item class="ion-text-wrap">
              <ion-label [id]="item.id">
                  {{ item.label }}
              </ion-label>
              <ion-reorder [attr.aria-labelledby]="item.id" slot="end" />
          </ion-item>
      </ion-card>
    }
</ion-reorder-group>

Additional Information

No response

Metadata

Metadata

Assignees

No one assigned

    Labels

    type: feature requesta new feature, enhancement, or improvement

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions