Accessibility: Improve the "Hello Dolly" accessibility.

- adds a visually hidden text to give context to the lyrics
- the text is `Quote from Hello Dolly song, by Jerry Herman:`
- adds a `lang` HTML attribute (when the admin language is not English) to better support assistive technologies 
- adds a `dir` HTML attribute to better support the LTR English lyrics with RTL languages 
- CSS adjustments

Props audrasjb, SergeyBiryukov, danieltj, birgire, karmatosed, desrosj, afercia.
Fixes #43632.


git-svn-id: https://develop.svn.wordpress.org/trunk@44929 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrea Fercia 2019-03-18 17:18:46 +00:00
parent 82be24c885
commit d26542632e
2 changed files with 35 additions and 19 deletions

View File

@ -1,14 +1,14 @@
<?php <?php
/** /**
* @package Hello_Dolly * @package Hello_Dolly
* @version 1.7.1 * @version 1.7.2
*/ */
/* /*
Plugin Name: Hello Dolly Plugin Name: Hello Dolly
Plugin URI: http://wordpress.org/plugins/hello-dolly/ Plugin URI: http://wordpress.org/plugins/hello-dolly/
Description: This is not just a plugin, it symbolizes the hope and enthusiasm of an entire generation summed up in two words sung most famously by Louis Armstrong: Hello, Dolly. When activated you will randomly see a lyric from <cite>Hello, Dolly</cite> in the upper right of your admin screen on every page. Description: This is not just a plugin, it symbolizes the hope and enthusiasm of an entire generation summed up in two words sung most famously by Louis Armstrong: Hello, Dolly. When activated you will randomly see a lyric from <cite>Hello, Dolly</cite> in the upper right of your admin screen on every page.
Author: Matt Mullenweg Author: Matt Mullenweg
Version: 1.7.1 Version: 1.7.2
Author URI: http://ma.tt/ Author URI: http://ma.tt/
*/ */
@ -42,43 +42,59 @@ Dolly, never go away
Promise, you'll never go away Promise, you'll never go away
Dolly'll never go away again"; Dolly'll never go away again";
// Here we split it into lines // Here we split it into lines.
$lyrics = explode( "\n", $lyrics ); $lyrics = explode( "\n", $lyrics );
// And then randomly choose a line // And then randomly choose a line.
return wptexturize( $lyrics[ mt_rand( 0, count( $lyrics ) - 1 ) ] ); return wptexturize( $lyrics[ mt_rand( 0, count( $lyrics ) - 1 ) ] );
} }
// This just echoes the chosen line, we'll position it later // This just echoes the chosen line, we'll position it later.
function hello_dolly() { function hello_dolly() {
$chosen = hello_dolly_get_lyric(); $chosen = hello_dolly_get_lyric();
echo "<p id='dolly'>$chosen</p>"; $lang = '';
if ( 'en_' !== substr( get_user_locale(), 0, 3 ) ) {
$lang = ' lang="en"';
} }
// Now we set that function up to execute when the admin_notices action is called printf(
'<p id="dolly"><span class="screen-reader-text">%s </span><span dir="ltr"%s>%s</span></p>',
__( 'Quote from Hello Dolly song, by Jerry Herman:' ),
$lang,
$chosen
);
}
// Now we set that function up to execute when the admin_notices action is called.
add_action( 'admin_notices', 'hello_dolly' ); add_action( 'admin_notices', 'hello_dolly' );
// We need some CSS to position the paragraph // We need some CSS to position the paragraph.
function dolly_css() { function dolly_css() {
// This makes sure that the positioning is also good for right-to-left languages
$x = is_rtl() ? 'left' : 'right';
echo " echo "
<style type='text/css'> <style type='text/css'>
#dolly { #dolly {
float: $x; float: right;
padding-$x: 15px; padding: 5px 10px;
padding-top: 5px;
margin: 0; margin: 0;
font-size: 11px; font-size: 12px;
line-height: 1.6666;
}
.rtl #dolly {
float: left;
} }
.block-editor-page #dolly { .block-editor-page #dolly {
display: none; display: none;
} }
@media screen and (max-width: 782px) {
#dolly,
.rtl #dolly {
float: none;
padding-left: 0;
padding-right: 0;
}
}
</style> </style>
"; ";
} }
add_action( 'admin_head', 'dolly_css' ); add_action( 'admin_head', 'dolly_css' );

View File

@ -158,7 +158,7 @@ class Tests_Ajax_Update_Plugin extends WP_Ajax_UnitTestCase {
'plugin' => 'hello.php', 'plugin' => 'hello.php',
'pluginName' => 'Hello Dolly', 'pluginName' => 'Hello Dolly',
'errorMessage' => 'Plugin update failed.', 'errorMessage' => 'Plugin update failed.',
'oldVersion' => 'Version 1.7.1', 'oldVersion' => 'Version 1.7.2',
'newVersion' => '', 'newVersion' => '',
'debug' => array( 'The plugin is at the latest version.' ), 'debug' => array( 'The plugin is at the latest version.' ),
), ),