-
Notifications
You must be signed in to change notification settings - Fork 27
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
Specify AXAPI behaviour for low
, high
, and optimum
meter attributes.
#538
Conversation
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think it is as simple as this. As I understand it <meter>
can have 3 segments,
- (1) below
low
, - (2) between
low
andhigh
- (3) above
high
.
If theoptimum
value fits into (1) then all values within this segment are optimal, values in (2) are suboptimal and values in (3) are critical
If the optimal value is in (2) then values in (1) and (3) are both suboptimal
If it is (3) then values in (1) are critical, (2) suboptimal and (3) optimal.
These correspond to the visual coloring of green (optimal), orange (suboptimal) and red (critical).
If no optimum
value is specified then the optimal segment is segment (2)
Here is the webkit logic https://github.com/WebKit/WebKit/blob/c330ea99229f6bb478dde74497ee652e44a3d7d5/Source/WebCore/html/HTMLMeterElement.cpp#L156
Co-authored-by: James Nurthen <jnurthen@users.noreply.github.com>
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Hi @MReschenberg, I've added comments and recommendations that largely align with @jnurthen's assessment of optimum
treatment.
@@ -11709,7 +11709,7 @@ <h4 id=att-high>`high`</h4> | |||
<tr> | |||
<th><a href="https://developer.apple.com/reference/appkit/nsaccessibility">AX</a></th> | |||
<td> | |||
<div class="general">Not mapped</div> | |||
<div class="general">Expose "optimal value" via `AXValueDescription` if <value> is greater than or equal to <high>. Expose "suboptimal value" if <value> is less than <high> and greater than or equal to <low>.</div> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Relevant WebKit code: https://github.com/WebKit/WebKit/blob/c330ea99229f6bb478dde74497ee652e44a3d7d5/Source/WebCore/html/HTMLMeterElement.cpp#L172
This looks correct for high
. We'll also need to add the case for when the value
is less than "low" (for which this is exposed as "critical value").
@@ -12739,7 +12739,7 @@ <h4 id=att-low>`low`</h4> | |||
<tr> | |||
<th><a href="https://developer.apple.com/reference/appkit/nsaccessibility">AX</a></th> | |||
<td> | |||
<div class="general">Not mapped</div> | |||
<div class="general">Expose "suboptial value" via `AXValueDescription` if <value> is greater than or equal to <low> and less than <high>. If <value> is less than <low>, expose "critical value".</div> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Relevant WebKit code: https://github.com/WebKit/WebKit/blob/c330ea99229f6bb478dde74497ee652e44a3d7d5/Source/WebCore/html/HTMLMeterElement.cpp#L163
For low
:
- If
value
is less than or equal tolow
, thenvalue
is "optimal value" - if
value
is less than or equal tohigh
(but greater thanlow
), thenvalue
is "suboptimal value" - else,
value
is "critical value"
Also, looks like there is a typo for the word "suboptimal" here.
@@ -13995,7 +13995,7 @@ <h4 id=att-optimum>`optimum`</h4> | |||
<tr> | |||
<th><a href="https://developer.apple.com/reference/appkit/nsaccessibility">AX</a></th> | |||
<td> | |||
<div class="general">Not mapped</div> | |||
<div class="general">Expose "optimal value" via `AXValueDescription` if <value> is greater than or equal to <optimum>.</div> |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Relevant WebKit code: https://github.com/WebKit/WebKit/blob/c330ea99229f6bb478dde74497ee652e44a3d7d5/Source/WebCore/html/HTMLMeterElement.cpp#L184
For optimum
:
- If
value
is greater than or equal tolow
ANDvalue
is less than or equal tohigh
thenvalue
is "optimal value" - Else,
value
is "suboptimal value"
Note that in this case, there is no "critical value".
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This issue should have an active test case showing this in a more common use case, like an audio meter bouncing quickly and showing critical peak line clipping.
I’m not sure if this will need new API, or if there is existing API, but I’m reasonably sure AXValueDescription
is not the ideal way to vend this to AT like VO.
Update: dynamic meter test case added to a new WebKit Accessibility bug.
Do you have an alternative attribute in mind? |
Role/Subrole is already |
Closing, this PR has been migrated to the ARIA monorepo: |
Closes #536
Specification based on Safari behaviour/attributes exposed.
Preview | Diff