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

[Hackathon 2024][Niobium][iOS] Use Button Instead of .onTapGesture for Clickable Views in SwiftUI #104

Open
LaurentBnpp opened this issue May 30, 2024 · 0 comments
Assignees
Labels
accessibility Hackathon 2024 New issues tagged during the hackathon 2024 spotter Techno: iOS

Comments

@LaurentBnpp
Copy link

LaurentBnpp commented May 30, 2024

Rule title

Use Button Instead of .onTapGesture for Clickable Views in SwiftUI

Language and platform

Swift (5.3+), SwiftUI (iOS 13+, macOS 10.15+, tvOS 13+, watchOS 6+, visionOS 1+)

Rule description

We need to detect in the code whether tapping on a SwiftUI view uses a Button rather than the .onTapGesture modifier. This is because the modifier does not allow certain accessibility features to function correctly. For example, keyboard navigation that allows interaction components to be traversed will not work on an element that uses the gesture.

Bad example

            HStack {
                Text("View with gesture")
                Image(systemName: "hand.thumbsdown")
            }
            .onTapGesture {
                print("Pas glop")
            }

Good example

        Button(action: {
              print("Glop")
          }, label: {
              HStack {
                  Text("Regular button")
                  Image(systemName: "hand.thumbsup")
              }
          })

Rule short description

Avoid usage of .onTapGesture modifier to provide good accessibility experience.

Rule justification

Using Button instead of .onTapGesture for clickable views in SwiftUI is crucial for ensuring compatibility with accessibility tools like keyboard navigation. This is in line with the RGAA (General Accessibility Framework for Administrations) guidelines, which emphasize the importance of making digital services accessible to all users, including those with disabilities.

RGAA rule

Example
The blue frame in the gif below corresponds to the selection made by user using the keyboard. It's important to note that functionality only works with components that the Button rather than relying solely on the .onTapGesture modifier.

Simulator Screen Recording - iPhone 15 - 2024-05-29 at 16 34 22

Severity / Remediation Cost

Severity: Blocker.
For certains users, keyboard or selection control is only way to navigate within an application. Consequently, if this issue occurs, a user may become completely blocked on the screen or be unable to access a particular feature (and it's legal obligation).

Remediation Cost: Easy
It requires a minor code adjustment to replace .onTapGesture with Button.

Implementation principle

During the static analysis of the source code, we need to detect instances where .onTapGesture is used for creating clickable views. If Button is not used in these instances, it indicates a potential issue.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
accessibility Hackathon 2024 New issues tagged during the hackathon 2024 spotter Techno: iOS
Projects
None yet
Development

No branches or pull requests

2 participants