-
-
Notifications
You must be signed in to change notification settings - Fork 5.1k
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
Accessibility: Comply with WCAG 2 #10795
Comments
This pull request improves focus handling in the **Markdown editor**'s toolbar. See laurent22#10795.
I am loving this! I am not sure what the desktop app is programmed in, but I am worried there is an over reliance on ARIA where native controls and functions could be used, such as, the below for example regarding links. I genuinely do not think links need an ARIALABEL if link text/titles are descriptive enough. But I am beyond excited to see this progress so will watch closely! If I knew what the mobile apps and desktop apps were made in, I could better advise but this is a great start! |
The general rule is that if you have to use things like |
Thank you for the feedback! There are cases where links/buttons in Joplin have no text content but have a
Based on this, Related links:
The desktop app is built with Electron and React. The mobile app is built with React Native. |
Thank you for the feedback! Currently, Joplin does use
An alternative to webfont+ |
Yeah, icon fonts are not good for accessibility since they are basically a hack to display images instead of text (as should be expected with fonts normally), so they have issues with screen readers, and they also cause problems when the user wants (or needs due to a particular disability) to use their own font for the whole application or website. SVG icons are much better in this aspect, but as you've said, implementing them would require a major rewrite of the code 🙁. |
This commit announces changes (e.g. "added block code") made by most Markdown commands. Currently: - This is done on both mobile and desktop. - The goal is to give screen reader users a brief description of how an action changed the document. - It's possible that this change will be more annoying than useful (more content read by the screen reader?) Related to laurent22#10795.
Note: This commit and the prior are related to laurent22#10795
See: - https://www.w3.org/WAI/WCAG22/quickref/#target-size-minimum - Joplin's custom scrollbars are thinner than the minimum target size. - laurent22#10795
Summary
[ Progress: Desktop ] | [ Progress: Mobile ]
This issue tracks Joplin's progress towards compliance with the WCAG (Web Content Accessibility Guidelines) v2.2.
About the WCAG
The WCAG (Web Content Accessibility Guidelines) is a set of guidelines for improving web accessibility.
The WCAG is divided into success criteria. Each is labelled with "Level A", "Level AA", or "Level AAA". These correspond to different conformance levels.
Conformance levels
There are three different conformance levels1:
According to WebAIM.org2,
The WCAG's definition of the different conformance levels1 confirms WebAIM's statement that Level AAA is not always achievable:
Note
It is not recommended that Level AAA conformance be required as a general policy for entire sites because it is not possible to satisfy all Level AAA success criteria for some content.
Based on the above, for now, this issue targets Level AA conformance with the WCAG.
This issue: General tasks
Notes: In this issue, different task priorities are marked differently. For example,
Note
The tasks below are a work-in-progress and based on the WCAG 2.2 spec. Completing the tasks below does not guarantee compliance with the spec.
Quick list of general issues
react-native-paper
.role
information (not announced as buttons). (SC 4.1.2)Desktop
Note
Several relevant changes were made shortly before this issue was created:
1. Perceivable
Summary: All non-decorative components of the user interface should be described in a way perceivable to the user.
1.1.1 Non-text content (Level A)
To meet this requirement, all inputs controls and inputs must be labeled.
Tasks:
1.2.1. Audio-only and Video-only, 1.2.2. Captions (Prerecorded), and 1.2.3. Audio Description or Media Alternative (Prerecorded)
Joplin allows users to include prerecorded audio and video in notes. When included as a link (e.g.
[link](:/resourceidhere000000000000000000)
), the generated HTML video element has no associated description.In the desktop app, we should:
video
s andaudio
elements?Also see the spec for related tasks.
1.3 Adaptable
Summary: Content must be presentable in different ways without losing information.
1.3.1. Info and Relationships (Level A)
role=search
?role=main
-- Desktop: Fix errors found by automated accessibility testing #11246role=navigation
-- Desktop: Fix errors found by automated accessibility testing #11246aria-labelledby
(or perhapsaria-label
) for groups and landmarkslabel
elements to label form controlsNote: This is important even if the icons are hidden from a screen reader — some accessibility tools replace fonts on a page for readability. Marking icons created from a font as such should prevent these accessibility tools from treating them as text.
Effect: It's currently impossible or difficult to tell whether some item is a subsection of another.
aria-level
along with thetree
pattern -- Desktop: Accessibility: Add ARIA information to the sidebar's notebook and tag list #11196aria-errormessage
to associate the error message with the input on the "Keyboard shortcuts" page.::before
or::after
to include non-decorative content (see F87)?1.3.2. Meaningful Sequence (Level A)
flex-order
or similar order-changing CSS. Are we usingflex-order
anywhere? See F1.1.3.3. Sensory Characteristics (Level A)
Note: §1.4 covers color guidelines.
This task refers to instructions.
For example, "press the red button in the bottom right corner of the screen to edit" would be bad.
We should:
1.3.4. Orientation (Level AA)
Currently, Joplin doesn't restrict devices to a single orientation. However, it may be difficult to use the desktop app on a phone-sized device in portrait mode. In particular, without moving the sidebars from "View" > "Change application layout".
1.4 Distinguishable
Color for distinguishing content (§1.4.1, A):
Audio control (§1.4.2, A)
At present, all audio should be user-created (and only auto-play if this is set by the user in HTML). Additionally, audio included with
[](:/resourceidhere)
has Electron-provided controls.Minimum contrast (§1.4.3, AA):
Note: It might not be necessary to improve contrast of inactive buttons (despite having low contrast). See discussion and "incidental" in §1.4.3.
Resize text (§1.4.4, AA):
Avoid images of text unless customizable/essential (§1.4.5, AA):
SubNotebooks.png
, which includes text that isn't presented elsewhere.Note: See the WCAG spec for §1.4.6-1.4.9 (all level AAA).
1.4.10: Reflow (AA)
1.4.11: Non-text contrast (AA)
1.4.12: Text spacing (AA)
Users should be able to override Joplin's styles (through OS accessibility settings?) in the following ways and still use the app:
In particular, content should not be clipped.
1.4.13: Content on Hover or Focus (AA)
When content (e.g. tooltips) can be shown by hovering with the mouse pointer, it should also be possible to show them with a keyboard.
At present, this isn't possible with most
title=
tooltips (at least on Linux). However, the WCAG includes an exception that might be relevant here:As an Electron app, however, Joplin is the user agent, and so this might not apply.
2. Operable
2.1.1. Keyboard (A)
2.1.2. No Keyboard Trap (A)
2.1.3. Keyboard (No Exception) (AAA):
Equivalent to §2.1.1, but removes exceptions.
2.1.4. Character Key Shortcuts (A)
If there are unmodified keyboard shortcuts implemented with just a letter/punctuation/special character, then at least one of the following must be true:
Joplin doesn't seem to have character key shortcuts.
2.2. Provide users enough time to read and use content
§2.2.1: This section seems to be mostly concerned with auto-log-out/locking. I don't believe that Joplin puts a time limit on any activities.
2.2.2. Pause, Stop, Hide
This includes:
§2.2.3-2.2.6 (Level AAA): Concerned with interruptions and timing.
2.3. Seizures: Don't design content in a way that is known to cause seizures
2.4. Navigable
2.4.1. Bypass Blocks (Level A)
Joplin currently has menu items and keyboard shortcuts to jump focus to the note list, sidebar, note title, and note editor (Go > Focus > ...).
2.4.2. Page Titled (Level A)
2.4.3. Focus Order (Level A)
Related (§2.4.3): #10817
2.4.4. Link Purpose (In Context) (Level A)
aria-labelledby
attribute?2.4.5. Multiple Ways (Level AA)
2.4.6. Headings and Labels (Level AA)
<h1>
/etc. tag for the "NOTEBOOKS" heading. This heading, however, seems descriptive.2.4.7. Focus Visible (Level AA)
<select>
elements -- Desktop: Accessibility: Make keyboard focus visible for dropdowns #111772.4.9. Link Purpose (Link Only) (Level AAA)
Based on the "sufficient techniques" section and the "ambiguous to users in general", this seems to be primarily targeted at screen reader users (e.g. when cycling through the links available on a page). To meet this, we might start by:
Also to research:
2.4.10. Section Headings (Level AAA)
Given the second note above, this section likely applies mostly to Joplin's welcome notes and settings screen. At present, the welcome notes use headings.
2.4.11. Focus Not Obscured (Minimum) (Level AA)
2.4.12. Focus Not Obscured (Enhanced) (Level AAA)
2.4.12 is equivalent to 2.4.11, but removes exceptions. See the task list for § 2.4.11.
2.4.13. Focus Appearance (Level AAA)
See also §2.4.7.
2.5.1. Pointer Gestures (Level A)
2.5.2. Pointer Cancellation (Level A)
Note dragging: Dragging the note back to its original location cancels the action.
Notebook dragging: Dragging a notebook back to its original location (before lifting the pointer) cancels the action.
[🟡] Clicking on a dialog's dimmed background seems to only be cancellable by dragging the pointer outside the main Joplin window.
Note
A search for
mousedown
andpointerdown
in Joplin's GitHub repository results in very few matches:mousedown
event for the editor's plugin compatibility layer.pointerdown
This suggests (but does not imply) that Joplin desktop doesn't directly handle pointer down events.
2.5.3. Label in Name (Level A)
2.5.4. Motion Actuation (Level A)
Joplin for desktop seems to not have functionality that can be activated by device motion (e.g. accelerometer).
2.5.5. Target Size (Enhanced) (Level AAA)
A non-exhaustive list of items that would need adjustment to implement this:
2.5.6. Concurrent Input Mechanisms (Level AAA)
2.5.7. Dragging Movements (Level AA)
Based on the description of §2.5.1, satisfying 2.5.1 seems to imply that 2.5.7 is also satisfied.
Note that the extended description of this section states:
...and later...
For now, see the checklist for §2.5.1.
2.5.8. Target Size (Minimum) (Level AA)
To change:
3.1.1. Language of Page (Level A)
For HTML, H57 recommends using the
lang
attribute. Among other reasons, this is so thatlang
attribute to match Joplin's current locale -- Desktop: Accessibility: Declare app locale with the HTML lang attribute #11218.3.1.2. Language of Parts (Level AA)
lang="en"
.3.1.3. Unusual words (Level AAA)
3.1.4. Abbreviations (Level AAA)
The WCAG's section on understanding SC 3.1.4. suggests:
Providing the full form of an abbreviation the first time it appears in a document. For example "PDF (Portable Document Format)", or using the
<abbr>
element.Linking to the definition of all instances of an abbreviation.
Providing a glossary.
[🔷] In settings > Markdown, define "WYSIWYG" or replace it with "Rich Text".
[🔷] In settings > Markdown, define PDF.
[🔷] Define "JEX" when used in settings descriptions.
[🔷] Search dialog "regexp".
3.1.5. Reading Level (Level AAA)
The WCAG defines "lower secondary education level" as
The WCAG suggests:
This section focuses on the desktop app's accessibility. As such, this is likely to apply mostly to the settings screen.
3.1.6. Pronunciation
3.2 - Predictable
3.2.1. On Focus (Level A)
Note
The WCAG defines "changes of context" to be:
It includes "focus" and "content that changes the meaning of the web page" as examples.
3.2.2. On Input (Level A)
3.3.3. Error Suggestion (Level AA)
aria-invalid="true"
. This might be sufficient.3.3.4. Error Prevention (Legal, Financial, Data) (Level AA)
This guideline is described as applying to systems that "modify or delete user-controllable data in data storage systems". Joplin manages user data. Checking whether Joplin complies with this guideline might involve:
3.3.5. Help (Level AAA)
This success criterion suggests, for example,
3.3.6. Error Prevention (All) (Level AAA)
This is equivalent to SC 3.3.4, but applies to a larger set of applications.
3.3.7. Redundant Entry (Level A)
The success criterion's extended description also states:
I'm unaware of cases where Joplin requests data re-entry (except in the case of passwords). The success criterion does include search as an example, however. As such,
3.3.8. Accessible Authentication (Minimum) (Level AA)
The guidelines also state that supporting password manager input and allowing copy/paste to reduce re-typing satisfy this criterion.
3.3.9. Accessible Authentication (Enhanced) (Level AAA)
The WCAG states:
Joplin should allow pasting passwords from password managers or other applications when signing in to sync targets that authenticate through the app. Sync targets that authenticate through a web browser (e.g. Joplin Cloud) should also allow using the user's password manager.
§4 - Robust
4.1.2. Name, Role, Value (Level A)
At present, most ARIA-related tasks are listed under SC 1.3.1. In addition to those, issues include:
role=
).aria
information (e.g.aria-controls
).4.1.3. Status Messages (Level AA)
Several status messages need appropriate accessibility information to be exposed:
role=status
could be distracting when navigating with a screen reader. Implement Add a button to hide the synchronisation panel #8611 first.role=log
is one possible alternative.Mobile
Prior accessibility work and related issues: #10122, #10253, #8715
General notes:
react-native-ama
's documentation includes accessibility checklists specific to React Native that might be helpful.TextInput
blocks focus (Keyboard accessibility issues on Android (TextInput but also beyond) facebook/react-native#45801)Uncategorized issues:
navigation
/main
/... regions with React Native — the supported accessibilityrole
s seem much more limited than what's available on web.Important
For now, most of this evaluation focuses on mobile/Android. For keyboard accessibility (unless TalkBack is enabled), React Native has significant issues with its built-in
TextInput
component. As such, these sections may also include web-related information.1.1. Text alternatives
1.1.1. Non-text Content (A)
@react-native-community/slider
(based on the list of props in its README & an attempt to setaccessibilityHint
/accessibilityLabeledBy
).react-native-popup-menu
(related issue).1.2.1 - 1.2.3. Audio and Video (A)
Note: §1.2.4-1.2.9 are all related to audio/video recordings/streams, which is not included in Joplin mobile by default.
1.3.1. Info and Relationships (A)
Note
If it's not possible to convey certain relationships/structure with React Native, it may be permissible to describe the structure in text:
accessibilityRole="heading"
to identify headings.accessibilityRole="button"
on touchable button-like itemsaccessibilityRole="togglebutton"
oraccessibilityRole="checkbox"
on checkbox-like items.accessibilityRole="search"
on search fields (tags dialog search, global search, ...)accessibilityRole=""
Important
After adding/updating
accessbilityRole
s, be sure to check that the change improves screen reader accessibility on at least one platform and doesn't degrade screen reader support on other platforms.Other structure information:
accessibilityState
is ignored on web)....
2.2. Provide users enough time to read and use content
Notes on accessibility testing
Screen reader testing
For items related to screen reader accessibility, I'm testing primarily with the following screen readers:
Mobile: Finding contrast issues
On Android, the Accessibility Scanner may also be helpful in identifying and fixing certain accessibility issues (e.g. contrast, unlabeled content).
Footnotes
https://www.w3.org/WAI/WCAG22/Understanding/conformance#conf-req1 ↩ ↩2
https://webaim.org/standards/wcag/#current ↩
The text was updated successfully, but these errors were encountered: