Make WordPress Core

Opened 4 years ago

Last modified 6 weeks ago

#51006 accepted enhancement

Add a mechanism for accessible tooltips in core

Reported by: joedolson's profile joedolson Owned by: joedolson's profile joedolson
Milestone: 6.7 Priority: normal
Severity: normal Version:
Component: General Keywords: tooltips 2nd-opinion has-patch
Focuses: ui, accessibility, javascript Cc:

Description

While we've worked hard to eliminate usage of the title attribute across most of WordPress core, there is still an occasional need for that type of contextual information, and the lack of it is a barrier to resolving some issues (e.g. #50921) and removing some of the last instances of the title attribute.

An accessible tooltip will need to meet these criteria:

1) Be available either via the mouse, via the keyboard, or via touch.
2) Be persistent until dismissed
3) Support primary & auxiliary usage, dependent on whether the tooltip is the sole name of the control or an elaboration of existing text.

Useful reference on accessible tooltips: โ€‹https://inclusive-components.design/tooltips-toggletips/

Attachments (1)

2023-03-09_09-19-53.pngโ€‹ (23.7 KB) - added by oglekler 19 months ago.
Proposal for tooltips in settings

Download all attachments as: .zip

Change History (44)

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


4 years ago

This ticket was mentioned in โ€‹Slack in #accessibility by ryokuhi. โ€‹View the logs.


4 years ago

#3 @afercia
4 years ago

  • Keywords tooltips added

This ticket was mentioned in โ€‹Slack in #accessibility by afercia. โ€‹View the logs.


4 years ago

#5 @afercia
4 years ago

  • Milestone changed from Awaiting Review to Future Release

@oglekler
19 months ago

Proposal for tooltips in settings

#6 @oglekler
19 months ago

There are different possibilities for tooltips usage:

  • alternative to title attribute
  • standalone helper

We need them to:

  • Creating clean, more modern design in the admin and reduce visual complexity and clatter.
  • Providing unified tool to plugins and themes developers for tooltips in the admin (right now some of them have their own implementations)
  • Standardizing tooltips usage in WordPress to make sure that they are aria friendly and provide expected behavior in core, themes and plugins

References:
โ€‹https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/tooltip_role
โ€‹https://m2.material.io/components/tooltips#theming

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


18 months ago

#8 @joedolson
18 months ago

  • Milestone changed from Future Release to 6.3
  • Owner set to joedolson
  • Status changed from assigned to accepted

#9 @oglekler
18 months ago

Here is a need for more advanced Tooltip implementation
https://core.trac.wordpress.org/ticket/21583#comment:55
and it looks like it can depend on this one's functionality.

I wonder if Tooltip in jQuery UI is good enough to cover our needs and meet all accessibility requirements, or we need to look for another solution.

Last edited 18 months ago by oglekler (previous) (diff)

This ticket was mentioned in โ€‹Slack in #core by oglekler. โ€‹View the logs.


17 months ago

#11 @davidbaumwald
17 months ago

I apologize if this was discussed elsewhere, but I don't see anything here. Has any consideration been given to using the โ€‹Tooltip component from the block editor?

If not, I feel like this might be something that should be considered, and might be improved if there are a11y issues.

#12 @joedolson
17 months ago

The block editor tooltip doesn't seem very suitable, based on how I see it used - it's hidden from screen readers, it's not dismissable, and depends on aria-label for accessible naming.

We could work on improving that - I think it would require a pretty much total refactor. The way its used in the block editor, the only change that would be needed within that context is making it dismissable; but for broader usage, it would also need to be communicated to screen readers and not be dependent on aria-label for naming.

#14 @oglekler
17 months ago

I believe one of the requirements is an ability to use this tooltip for plugin and theme developers by adding its data in $args parameter of add_settings_field() function and possibly calling it by itself.

@davidbaumwald can we use the Tooltip component this way?

#15 @joedolson
17 months ago

Specifications for an accessible tooltip for WordPress:

Definitions: 'source' refers to the object a tooltip is related to. 'content' refers to the visible text content of the tooltip. 'name' refers to the accessible name of the control itself.

1) Tooltips are primarily supplemental information, and should not override the name of the source. This means they should not depend on something like aria-label on the source.

2) Tooltip content should not require a move of focus.

a) When the tooltip is also the name of the control, rather than supplemental information, it should be associated as a label field, either sourced from aria-label or using aria-labelledby.

b) For supplemental tooltips, the content should be associated with the source using aria-describedby. E.g. <input type="name" aria-describedby="tooltip-1"><div id="tooltip-1">Your full first and last name</div>.

3) If there is interactive content in a tooltip, it must be next in tab sequence after the source and be accessible to a screen reader or keyboard without dismissing the tooltip.

4) All tooltips must be dismissable without removing focus a source. When a tooltip appears on focus, it should be dismissable using esc. This will mean ensuring that the keyboard esc event doesn't trigger unexpected closures when used inside modals or other esc-closable contexts. It will also require a visible close button that can be used by pointer devices to close the tooltip and move focus to the source *without* re-triggering the tooltip.

a) Note: the close button will also need to meet WCAG's requirements for control size.

5) The tooltip should not use role="tooltip", aria-haspopup, or aria-live. The role has no significant support, and as written does not allow interactive content. Tooltips are not popups, and aria-live should not be used for naming and descriptions of static content.

6) Tooltips should be available for touch interactions. This ensures that a) non-hovering pointer AT will be able to get the tooltip information and b) the friction of using controls on mobile will help reduce excessive use of tooltips, since while they should be possible, they should *not* be overused.

7) Tooltips should *not* support formatting such as heading, bold text, italics, etc. These will not be conveyed to screen readers.

8) Interactive content should be strongly discouraged and avoided if at all possible. If the tooltips simply do not support it, that would be entirely adequate.

9) Tooltips should only be supported on interactive sources - buttons, links, inputs, etc.

10) The title attribute should not be used on the source.

11) There should not be a timeout on the tooltip.

#16 @oglekler
16 months ago

This could also be a tooltip: #58312

#17 @oglekler
15 months ago

  • Focuses javascript added
  • Keywords needs-patch added
  • Milestone changed from 6.3 to 6.4

This is an enhancement, and we have zero chances to make it until Beta 1, so, sadly, I am moving this ticket to 6.4.

I believe that this is a significant improvement we can make, so, I am asking all who are browsing this ticket to collaborate working on the one nice patch ๐Ÿ™๐Ÿ™‚

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


14 months ago

This ticket was mentioned in โ€‹Slack in #core by oglekler. โ€‹View the logs.


13 months ago

This ticket was mentioned in โ€‹Slack in #core by oglekler. โ€‹View the logs.


13 months ago

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


13 months ago

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


12 months ago

#23 @oglekler
12 months ago

  • Milestone changed from 6.4 to 6.5

I didn't have time to work on this patch and no one picked up this so far, so I am moving this ticket into 6.5 in hope that we will make a progress there.

This ticket was mentioned in โ€‹PR #5676 on โ€‹WordPress/wordpress-develop by โ€‹@rajinsharwar.


10 months ago
#24

  • Keywords has-patch added; needs-patch removed

PR for adding the initial draft for the Tooltip functionality.

Trac ticket: https://core.trac.wordpress.org/ticket/51006

#25 @rajinsharwar
10 months ago

Hi all, I tried to start the work on this feature to get things started. I know the code isn't perfect or not that good, but I hope this will provide a good benchmark for getting things rolling for this feature.

Demo: โ€‹https://prnt.sc/zkAl_zz_XwPo

Introduced a new function: add_tooltip()

It accepts a total of 3 parameters:

  • The 1st is a UNIQUE field ID, which will be used as the div ID of the tooltip container.
  • The 2nd is the tooltip-text which will be shown to the users upon click or click of Enter (For keyboard users)
  • The 3rd is an OPTIONAL parameter, which will be used as the Label for the Tooltip. If nothing passed, the default goes as "Help".

Example Usage:

add_tooltip('tooltip-1', $tagline_description);
add_tooltip('tooltip-2', 'This is a Text for the Tooltip');

#26 @joedolson
8 months ago

Thanks for getting started on this @rajinsharwar!

I'm wondering if the PHP function is necessary. I feel like this would be more easily implemented if it was done entirely in the JS, and just looked for appropriate data attribute, then generated the appropriate HTML as needed.

The JS and CSS should be something we can add to common.js and common.css, as the intended implementation should be fairly broad, and there's no intention to make this available on the front-end.

This ticket was mentioned in โ€‹PR #5928 on โ€‹WordPress/wordpress-develop by โ€‹@rajinsharwar.


8 months ago
#27

Adding Tooltip in Admin via only JS and CSS.

Trac ticket: https://core.trac.wordpress.org/ticket/51006

#28 @rajinsharwar
8 months ago

  • Keywords 2nd-opinion added

Updated changes: โ€‹https://screenpal.com/watch/cZV0cIVJycu

Thanks for your feedback @joedolson, and I appreciate your suggestion. The reason I thought of going over with a function is that we can use this both in the frontend and backend. In #55343, a proposal was raised for adding a Tooltip to "Remember Me" of the wp-login.php. So, if we choose to go with only a JS approach, in that case, we might need to have it in separate files and load those both in the admin panel and in the wp-login.php. So, my opinion is to have a PHP function that can be called from both the Frontend and Admin panel and also to enqueue those scripts wherever there is a tooltip on the screen, not on all pages.

Still, if we choose to go with the JS way, and have those scripts and styles only in the admin, I have submitted the (PR 5928)โ€‹https://github.com/WordPress/wordpress-develop/pull/5928 as well, which includes this change :). It's now up to what we choose to go with. Requesting suggestions on this, so maybe we can try to get this land before Beta 1 in February.

Example Usage of the new PR:

<div class="tooltip-container" data-tooltip-text="<?php _e( $tooltip_description ) ?>"></div>
<div class="tooltip-container" data-tooltip-text="<?php _e( 'This is another Text for the Tooltip' ) ?>"></div>

Adding 2nd opinion for suggestions.

โ€‹@rajinsharwar commented on โ€‹PR #5928:


8 months ago
#29

Updated the PR based on the feedback @mukeshpanchal27 :)

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


8 months ago

#31 @joedolson
8 months ago

After discussing in the accessibility bug scrub, we're thinking that having the markup generated in the PHP function is more compelling. Let's pursue that further.

We'd also like to try and make use of some of the logic that already exists in the Gutenberg tooltip implementation, particularly about calculating tooltip position. This might require some coordination.

This ticket was mentioned in โ€‹Slack in #core by rajinsharwar. โ€‹View the logs.


8 months ago

This ticket was mentioned in โ€‹Slack in #core by rajinsharwar. โ€‹View the logs.


7 months ago

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


7 months ago

#35 @swissspidy
7 months ago

  • Milestone changed from 6.5 to 6.6

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


4 months ago

#37 @joedolson
4 months ago

  • Milestone changed from 6.6 to Future Release

Moving this to future release. Still intend to work on for 6.7, but we feel that we won't have time for it in this release.

#38 @oglekler
4 months ago

Realted tickets: #58312 and #55343

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


2 months ago

#40 @rajinsharwar
2 months ago

  • Milestone changed from Future Release to 6.7

Hi all, I would like to add it to the 6.7 release to get the appropriate attention to this feature. I have also made some improvements to the existing PR: 5676 ( As it was preferred to go with the PHP option to render the tooltip ). I will be adding improvements over time to this issue, also if anyone feels this is not going in the correct direction, feel free to share that!

#41 @rajinsharwar
2 months ago

As an update here's what I have done to the current tooltips.

  1. Added on-hover toggle instead of on-click.
  2. The toggle can be focused with the Tab key, and also unfocused with Escape.
  3. The toggle is also clickable for mobile devices.
  4. From the PHP function, we can now pass the $default_position, in which position we want the tooltip by default. Accepted values, "top", "bottom", "right", and "left", and default value as right.
  5. The tooltip's popup will not adjust its position automatically based on screen size. For example, if the default is left, and there is space on the left, the tooltip automatically changes its position to the right.
  6. If the same tooltip-id is being used to render the tooltip for duplicate elements, the tooltips still function without conflicts. ( As far as I have tested. If I have missed any, feel free to share ).
  7. As each tooltip has individual IDs, extenders, or even in the core, appropriate IDs can be targeted to apply/override the styles.

Example usage:

<?php add_tooltip('tooltip-2', 'This is a Text for the Tooltip', 'Help', 'left'); ?>
<?php add_tooltip('tooltip-3', 'This is another top Text for the Tooltip', 'Helpme', 'top'); ?>

I do have a nerdy question, I am wondering what's the correct way to add new JS files in the core? Like, I have added in the Grunt build file and in the script loader. Still, after running dev:build, the .js file from the src\js\_enqueues\wp\wp-tooltip.js is not coming in the src\wp-includes\js\wp-tooltip.js. Not sure if I did this wrong or how should I do it correctly.

Version 0, edited 2 months ago by rajinsharwar (next)

โ€‹@rajinsharwar commented on โ€‹PR #5676:


2 months ago
#42

  1. Added validations and _doing_it_wrong fro the arguments passed.
  2. Added a new filter that can be used to change the Tooltip icon image. This is similar to the one we have in add_menu() function. We can now pass the URL, or the SVG, or the dashicon class, or even the "none" to style using CSS.

Example usage:

add_filter( 'wp_tooltip_icon', 'my_filter', 10, 2 );

function my_filter( $icon_url, $field_id ) {
    $icon_url = "";

    return $icon_url;
}

This will show an SVG now in the tooltip.

Example:

https://github.com/user-attachments/assets/2a6783ed-ab70-4c4a-bfe4-9c7aaa7f8f12

  1. Added a new action hook that's fired just before the tooltip is rendered in HTML.
  2. Loading the styles and scripts for the tooltip before it's rendered to not show a slightly broken tooltip.

Screenshots:

https://github.com/user-attachments/assets/3a476567-85c0-4647-abd0-c8b10a62d124

Using Tab navigation:

https://github.com/user-attachments/assets/0733888d-59ac-4f96-abe7-c04500a4df4b

This ticket was mentioned in โ€‹Slack in #accessibility by joedolson. โ€‹View the logs.


6 weeks ago

Note: See TracTickets for help on using tickets.