WordPress.org

Make WordPress Core

Ticket #19394: 19394-3.patch

File 19394-3.patch, 17.2 KB (added by azaozz, 2 years ago)

Merged 19394.diff and 19394-2.patch

  • wp-admin/menu-header.php

     
    4141        foreach ( $menu as $key => $item ) { 
    4242                $admin_is_parent = false; 
    4343                $class = array(); 
     44                $aria_attributes = 'tabindex="1" role="menuitem"'; 
    4445 
    4546                if ( $first ) { 
    4647                        $class[] = 'wp-first-item'; 
     
    5354                        $submenu_items = $submenu[$item[2]]; 
    5455                } 
    5556 
    56                 if ( ( $parent_file && $item[2] == $parent_file ) || ( empty($typenow) && $self == $item[2] ) ) 
     57                if ( ( $parent_file && $item[2] == $parent_file ) || ( empty($typenow) && $self == $item[2] ) ) { 
    5758                        $class[] = ! empty( $submenu_items ) ? 'wp-has-current-submenu wp-menu-open' : 'current'; 
    58                 else 
     59                } else { 
    5960                        $class[] = 'wp-not-current-submenu'; 
     61                        if ( ! empty( $submenu_items ) ) 
     62                                $aria_attributes .= ' aria-haspopup="true"';     
     63                } 
    6064 
    6165                if ( ! empty( $item[4] ) ) 
    6266                        $class[] = $item[4]; 
    6367 
    6468                $class = $class ? ' class="' . join( ' ', $class ) . '"' : ''; 
    65                 $tabindex = ' tabindex="1"'; 
    6669                $id = ! empty( $item[5] ) ? ' id="' . preg_replace( '|[^a-zA-Z0-9_:.]|', '-', $item[5] ) . '"' : ''; 
    6770                $img = ''; 
    6871                if ( ! empty( $item[6] ) ) 
     
    8386                                $menu_file = substr( $menu_file, 0, $pos ); 
    8487                        if ( ! empty( $menu_hook ) || ( ('index.php' != $submenu_items[0][2]) && file_exists( WP_PLUGIN_DIR . "/$menu_file" ) ) ) { 
    8588                                $admin_is_parent = true; 
    86                                 echo "<div class='wp-menu-image'><a href='admin.php?page={$submenu_items[0][2]}'>$img</a></div>$arrow<a href='admin.php?page={$submenu_items[0][2]}'$class$tabindex>$title</a>"; 
     89                                echo "<div class='wp-menu-image'><a href='admin.php?page={$submenu_items[0][2]}'>$img</a></div>$arrow<a href='admin.php?page={$submenu_items[0][2]}'$class $aria_attributes>$title</a>"; 
    8790                        } else { 
    88                                 echo "\n\t<div class='wp-menu-image'><a href='{$submenu_items[0][2]}'>$img</a></div>$arrow<a href='{$submenu_items[0][2]}'$class$tabindex>$title</a>"; 
     91                                echo "\n\t<div class='wp-menu-image'><a href='{$submenu_items[0][2]}'>$img</a></div>$arrow<a href='{$submenu_items[0][2]}'$class $aria_attributes>$title</a>"; 
    8992                        } 
    9093                } elseif ( ! empty( $item[2] ) && current_user_can( $item[1] ) ) { 
    9194                        $menu_hook = get_plugin_page_hook( $item[2], 'admin.php' ); 
     
    9497                                $menu_file = substr( $menu_file, 0, $pos ); 
    9598                        if ( ! empty( $menu_hook ) || ( ('index.php' != $item[2]) && file_exists( WP_PLUGIN_DIR . "/$menu_file" ) ) ) { 
    9699                                $admin_is_parent = true; 
    97                                 echo "\n\t<div class='wp-menu-image'><a href='admin.php?page={$item[2]}'>$img</a></div>$arrow<a href='admin.php?page={$item[2]}'$class$tabindex>{$item[0]}</a>"; 
     100                                echo "\n\t<div class='wp-menu-image'><a href='admin.php?page={$item[2]}'>$img</a></div>$arrow<a href='admin.php?page={$item[2]}'$class $aria_attributes>{$item[0]}</a>"; 
    98101                        } else { 
    99                                 echo "\n\t<div class='wp-menu-image'><a href='{$item[2]}'>$img</a></div>$arrow<a href='{$item[2]}'$class$tabindex>{$item[0]}</a>"; 
     102                                echo "\n\t<div class='wp-menu-image'><a href='{$item[2]}'>$img</a></div>$arrow<a href='{$item[2]}'$class $aria_attributes>{$item[0]}</a>"; 
    100103                        } 
    101104                } 
    102105 
    103106                if ( ! empty( $submenu_items ) ) { 
    104                         echo "\n\t<div class='wp-submenu'><div class='wp-submenu-wrap'>"; 
     107                        echo "\n\t<div class='wp-submenu' role='menu'><div class='wp-submenu-wrap'>"; 
    105108                        echo "<div class='wp-submenu-head'>{$item[0]}</div><ul>"; 
    106109                        $first = true; 
    107110                        foreach ( $submenu_items as $sub_key => $sub_item ) { 
     
    151154                                                $sub_item_url = add_query_arg( array('page' => $sub_item[2]), 'admin.php' ); 
    152155 
    153156                                        $sub_item_url = esc_url( $sub_item_url ); 
    154                                         echo "<li$class><a href='$sub_item_url'$class$tabindex>$title</a></li>"; 
     157                                        echo "<li$class><a href='$sub_item_url'$class $aria_attributes>$title</a></li>"; 
    155158                                } else { 
    156                                         echo "<li$class><a href='{$sub_item[2]}'$class$tabindex>$title</a></li>"; 
     159                                        echo "<li$class><a href='{$sub_item[2]}'$class $aria_attributes>$title</a></li>"; 
    157160                                } 
    158161                        } 
    159162                        echo "</ul></div></div>"; 
     
    171174<div id="adminmenuback"></div> 
    172175<div id="adminmenuwrap"> 
    173176<div id="adminmenushadow"></div> 
    174 <ul id="adminmenu"> 
     177<ul id="adminmenu" role="navigation"> 
    175178 
    176179<?php 
    177180 
  • wp-includes/class-wp-admin-bar.php

     
    179179                } 
    180180 
    181181                ?> 
    182                 <div id="wpadminbar" class="<?php echo $class; ?>"> 
    183                         <div class="quicklinks"> 
     182                <div id="wpadminbar" class="<?php echo $class; ?>" role="navigation"> 
     183                        <div class="quicklinks" role="menubar"> 
    184184                                <?php foreach ( $this->root->children as $group ) { 
    185185                                        $this->render_group( $group, 'ab-top-menu' ); 
    186186                                } ?> 
     
    218218                        if ( ! empty( $node->meta['class'] ) ) 
    219219                                $class .= ' ' . $node->meta['class']; 
    220220 
    221                         ?><ul id="<?php echo esc_attr( "wp-admin-bar-{$node->id}" ); ?>" class="<?php echo esc_attr( $class ); ?>"><?php 
     221                        ?><ul id="<?php echo esc_attr( "wp-admin-bar-{$node->id}" ); ?>" class="<?php echo esc_attr( $class ); ?>" role="menu"><?php 
    222222                                foreach ( $node->children as $item ) { 
    223223                                        $this->render_item( $item ); 
    224224                                } 
     
    226226 
    227227                // Wrap the subgroups in a div and render each individual subgroup. 
    228228                elseif ( ! $is_single_group ): 
    229                         ?><div id="<?php echo esc_attr( "wp-admin-bar-{$node->id}-container" ); ?>" class="ab-group-container"><?php 
     229                        ?><div id="<?php echo esc_attr( "wp-admin-bar-{$node->id}-container" ); ?>" class="ab-group-container" role="menu"><?php 
    230230                                foreach ( $groups as $group ) { 
    231231                                        $this->render_group( $group, $class ); 
    232232                                } 
     
    240240 
    241241                $is_parent = (bool) $node->children; 
    242242                $has_link  = (bool) $node->href; 
     243                $tabindex = isset($node->meta['tabindex']) ? (int) $node->meta['tabindex'] : 10; 
    243244 
    244                 $menuclass = $is_parent ? 'menupop' : ''; 
     245                $menuclass = ''; 
     246                $aria_attributes = 'tabindex="' . $tabindex . '" role="menuitem"'; 
     247 
     248                if ( $is_parent ) { 
     249                        $menuclass = 'menupop'; 
     250                        $aria_attributes .= ' aria-haspopup="true"'; 
     251                } 
     252 
    245253                if ( ! empty( $node->meta['class'] ) ) 
    246254                        $menuclass .= ' ' . $node->meta['class']; 
    247255 
    248                 $tabindex = !empty($node->meta['tabindex']) ? $node->meta['tabindex'] : 10; 
    249256                ?> 
    250257 
    251258                <li id="<?php echo esc_attr( "wp-admin-bar-{$node->id}" ); ?>" class="<?php echo esc_attr( $menuclass ); ?>"><?php 
    252259                        if ( $has_link ): 
    253                                 ?><a class="ab-item" tabindex="<?php echo (int) $tabindex; ?>" href="<?php echo esc_url( $node->href ) ?>"<?php 
     260                                ?><a class="ab-item" <?php echo $aria_attributes; ?> href="<?php echo esc_url( $node->href ) ?>"<?php 
    254261                                        if ( ! empty( $node->meta['onclick'] ) ) : 
    255262                                                ?> onclick="<?php echo esc_js( $node->meta['onclick'] ); ?>"<?php 
    256263                                        endif; 
     
    262269                                endif; 
    263270                                ?>><?php 
    264271                        else: 
    265                                 ?><div class="ab-item ab-empty-item" tabindex="<?php echo (int) $tabindex; ?>"><?php 
     272                                ?><div class="ab-item ab-empty-item" <?php echo $aria_attributes; ?>><?php 
    266273                        endif; 
    267274 
    268275                        echo $node->title; 
  • wp-includes/js/admin-bar.dev.js

     
    3737 
    3838                        e.stopPropagation(); 
    3939                        e.preventDefault(); 
     40 
    4041                        target.parent().toggleClass('hover'); 
    41  
    4242                        target.siblings('.ab-sub-wrapper').find('.ab-item').each(refresh); 
    4343                }).each(refresh); 
    4444 
     45                $('#wpadminbar .ab-item').bind('keydown.adminbar', function(e){ 
     46                        if ( e.which != 27 ) 
     47                                return; 
     48 
     49                        var target = $(e.target); 
     50 
     51                        e.stopPropagation(); 
     52                        e.preventDefault(); 
     53 
     54                        target.closest('.hover').removeClass('hover').children('.ab-item').focus(); 
     55                        target.siblings('.ab-sub-wrapper').find('.ab-item').each(refresh); 
     56                }); 
     57 
    4558        }); 
    4659} else { 
    4760        (function(d, w) { 
  • wp-includes/js/admin-bar.js

     
    1 if(typeof(jQuery)!="undefined"){if(typeof(jQuery.fn.hoverIntent)=="undefined"){(function(b){b.fn.hoverIntent=function(p,r){var g={sensitivity:7,interval:100,timeout:0};g=b.extend(g,r?{over:p,out:r}:p);var a,f,t,v;var u=function(c){a=c.pageX;f=c.pageY};var w=function(c,d){d.hoverIntent_t=clearTimeout(d.hoverIntent_t);if((Math.abs(t-a)+Math.abs(v-f))<g.sensitivity){b(d).unbind("mousemove",u);d.hoverIntent_s=1;return g.over.apply(d,[c])}else{t=a;v=f;d.hoverIntent_t=setTimeout(function(){w(c,d)},g.interval)}};var s=function(c,d){d.hoverIntent_t=clearTimeout(d.hoverIntent_t);d.hoverIntent_s=0;return g.out.apply(d,[c])};var x=function(e){var d=this;var c=(e.type=="mouseover"?e.fromElement:e.toElement)||e.relatedTarget;while(c&&c!=this){try{c=c.parentNode}catch(e){c=this}}if(c==this){if(b.browser.mozilla){if(e.type=="mouseout"){d.mtout=setTimeout(function(){q(e,d)},30)}else{if(d.mtout){d.mtout=clearTimeout(d.mtout)}}}return}else{if(d.mtout){d.mtout=clearTimeout(d.mtout)}q(e,d)}};var q=function(e,d){var c=jQuery.extend({},e);if(d.hoverIntent_t){d.hoverIntent_t=clearTimeout(d.hoverIntent_t)}if(e.type=="mouseover"){t=c.pageX;v=c.pageY;b(d).bind("mousemove",u);if(d.hoverIntent_s!=1){d.hoverIntent_t=setTimeout(function(){w(c,d)},g.interval)}}else{b(d).unbind("mousemove",u);if(d.hoverIntent_s==1){d.hoverIntent_t=setTimeout(function(){s(c,d)},g.timeout)}}};return this.mouseover(x).mouseout(x)}})(jQuery)}jQuery(document).ready(function(b){var a=function(c,e){var f=b(e),d=f.attr("tabindex");if(d){f.attr("tabindex","0").attr("tabindex",d)}};b("#wpadminbar").removeClass("nojq").removeClass("nojs").find("li.menupop").hoverIntent({over:function(c){b(this).addClass("hover")},out:function(c){b(this).removeClass("hover")},timeout:180,sensitivity:7,interval:100});b("#wp-admin-bar-get-shortlink").click(function(c){c.preventDefault();b(this).addClass("selected").children(".shortlink-input").blur(function(){b(this).parents("#wp-admin-bar-get-shortlink").removeClass("selected")}).focus().select()});b("#wpadminbar li.menupop > .ab-item").bind("keydown.adminbar",function(d){if(d.which!=13){return}var c=b(d.target);d.stopPropagation();d.preventDefault();c.parent().toggleClass("hover");c.siblings(".ab-sub-wrapper").find(".ab-item").each(a)}).each(a)})}else{(function(i,k){var c=function(n,m,d){if(n.addEventListener){n.addEventListener(m,d,false)}else{if(n.attachEvent){n.attachEvent("on"+m,function(){return d.call(n,window.event)})}}},e,f=new RegExp("\\bhover\\b","g"),a=[],j=new RegExp("\\bselected\\b","g"),g=function(m){var d=a.length;while(d--){if(a[d]&&m==a[d][1]){return a[d][0]}}return false},h=function(s){var n,d,q,m,p,r,u=[],o=0;while(s&&s!=e&&s!=i){if("LI"==s.nodeName.toUpperCase()){u[u.length]=s;d=g(s);if(d){clearTimeout(d)}s.className=s.className?(s.className.replace(f,"")+" hover"):"hover";m=s}s=s.parentNode}if(m&&m.parentNode){p=m.parentNode;if(p&&"UL"==p.nodeName.toUpperCase()){n=p.childNodes.length;while(n--){r=p.childNodes[n];if(r!=m){r.className=r.className?r.className.replace(j,""):""}}}}n=a.length;while(n--){q=false;o=u.length;while(o--){if(u[o]==a[n][1]){q=true}}if(!q){a[n][1].className=a[n][1].className?a[n][1].className.replace(f,""):""}}},l=function(d){while(d&&d!=e&&d!=i){if("LI"==d.nodeName.toUpperCase()){(function(m){var n=setTimeout(function(){m.className=m.className?m.className.replace(f,""):""},500);a[a.length]=[n,m]})(d)}d=d.parentNode}},b=function(p){var n,d,o,m=p.target||p.srcElement;while(true){if(!m||m==i||m==e){return}if(m.id&&m.id=="wp-admin-bar-get-shortlink"){break}m=m.parentNode}if(p.preventDefault){p.preventDefault()}p.returnValue=false;if(-1==m.className.indexOf("selected")){m.className+=" selected"}for(n=0,d=m.childNodes.length;n<d;n++){o=m.childNodes[n];if(o.className&&-1!=o.className.indexOf("shortlink-input")){o.focus();o.select();o.onblur=function(){m.className=m.className?m.className.replace(j,""):""};break}}return false};c(k,"load",function(){e=i.getElementById("wpadminbar");if(i.body&&e){i.body.appendChild(e);if(e.className){e.className=e.className.replace(/nojs/,"")}c(e,"mouseover",function(d){h(d.target||d.srcElement)});c(e,"mouseout",function(d){l(d.target||d.srcElement)});c(e,"click",b)}if(k.location.hash){k.scrollBy(0,-32)}})})(document,window)}; 
    2  No newline at end of file 
     1if(typeof(jQuery)!="undefined"){if(typeof(jQuery.fn.hoverIntent)=="undefined"){(function(b){b.fn.hoverIntent=function(p,r){var g={sensitivity:7,interval:100,timeout:0};g=b.extend(g,r?{over:p,out:r}:p);var a,f,t,v;var u=function(c){a=c.pageX;f=c.pageY};var w=function(c,d){d.hoverIntent_t=clearTimeout(d.hoverIntent_t);if((Math.abs(t-a)+Math.abs(v-f))<g.sensitivity){b(d).unbind("mousemove",u);d.hoverIntent_s=1;return g.over.apply(d,[c])}else{t=a;v=f;d.hoverIntent_t=setTimeout(function(){w(c,d)},g.interval)}};var s=function(c,d){d.hoverIntent_t=clearTimeout(d.hoverIntent_t);d.hoverIntent_s=0;return g.out.apply(d,[c])};var x=function(e){var d=this;var c=(e.type=="mouseover"?e.fromElement:e.toElement)||e.relatedTarget;while(c&&c!=this){try{c=c.parentNode}catch(e){c=this}}if(c==this){if(b.browser.mozilla){if(e.type=="mouseout"){d.mtout=setTimeout(function(){q(e,d)},30)}else{if(d.mtout){d.mtout=clearTimeout(d.mtout)}}}return}else{if(d.mtout){d.mtout=clearTimeout(d.mtout)}q(e,d)}};var q=function(e,d){var c=jQuery.extend({},e);if(d.hoverIntent_t){d.hoverIntent_t=clearTimeout(d.hoverIntent_t)}if(e.type=="mouseover"){t=c.pageX;v=c.pageY;b(d).bind("mousemove",u);if(d.hoverIntent_s!=1){d.hoverIntent_t=setTimeout(function(){w(c,d)},g.interval)}}else{b(d).unbind("mousemove",u);if(d.hoverIntent_s==1){d.hoverIntent_t=setTimeout(function(){s(c,d)},g.timeout)}}};return this.mouseover(x).mouseout(x)}})(jQuery)}jQuery(document).ready(function(b){var a=function(c,e){var f=b(e),d=f.attr("tabindex");if(d){f.attr("tabindex","0").attr("tabindex",d)}};b("#wpadminbar").removeClass("nojq").removeClass("nojs").find("li.menupop").hoverIntent({over:function(c){b(this).addClass("hover")},out:function(c){b(this).removeClass("hover")},timeout:180,sensitivity:7,interval:100});b("#wp-admin-bar-get-shortlink").click(function(c){c.preventDefault();b(this).addClass("selected").children(".shortlink-input").blur(function(){b(this).parents("#wp-admin-bar-get-shortlink").removeClass("selected")}).focus().select()});b("#wpadminbar li.menupop > .ab-item").bind("keydown.adminbar",function(d){if(d.which!=13){return}var c=b(d.target);d.stopPropagation();d.preventDefault();c.parent().toggleClass("hover");c.siblings(".ab-sub-wrapper").find(".ab-item").each(a)}).each(a);b("#wpadminbar .ab-item").bind("keydown.adminbar",function(d){if(d.which!=27){return}var c=b(d.target);d.stopPropagation();d.preventDefault();c.closest(".hover").removeClass("hover").children(".ab-item").focus();c.siblings(".ab-sub-wrapper").find(".ab-item").each(a)})})}else{(function(i,k){var c=function(n,m,d){if(n.addEventListener){n.addEventListener(m,d,false)}else{if(n.attachEvent){n.attachEvent("on"+m,function(){return d.call(n,window.event)})}}},e,f=new RegExp("\\bhover\\b","g"),a=[],j=new RegExp("\\bselected\\b","g"),g=function(m){var d=a.length;while(d--){if(a[d]&&m==a[d][1]){return a[d][0]}}return false},h=function(s){var n,d,q,m,p,r,u=[],o=0;while(s&&s!=e&&s!=i){if("LI"==s.nodeName.toUpperCase()){u[u.length]=s;d=g(s);if(d){clearTimeout(d)}s.className=s.className?(s.className.replace(f,"")+" hover"):"hover";m=s}s=s.parentNode}if(m&&m.parentNode){p=m.parentNode;if(p&&"UL"==p.nodeName.toUpperCase()){n=p.childNodes.length;while(n--){r=p.childNodes[n];if(r!=m){r.className=r.className?r.className.replace(j,""):""}}}}n=a.length;while(n--){q=false;o=u.length;while(o--){if(u[o]==a[n][1]){q=true}}if(!q){a[n][1].className=a[n][1].className?a[n][1].className.replace(f,""):""}}},l=function(d){while(d&&d!=e&&d!=i){if("LI"==d.nodeName.toUpperCase()){(function(m){var n=setTimeout(function(){m.className=m.className?m.className.replace(f,""):""},500);a[a.length]=[n,m]})(d)}d=d.parentNode}},b=function(p){var n,d,o,m=p.target||p.srcElement;while(true){if(!m||m==i||m==e){return}if(m.id&&m.id=="wp-admin-bar-get-shortlink"){break}m=m.parentNode}if(p.preventDefault){p.preventDefault()}p.returnValue=false;if(-1==m.className.indexOf("selected")){m.className+=" selected"}for(n=0,d=m.childNodes.length;n<d;n++){o=m.childNodes[n];if(o.className&&-1!=o.className.indexOf("shortlink-input")){o.focus();o.select();o.onblur=function(){m.className=m.className?m.className.replace(j,""):""};break}}return false};c(k,"load",function(){e=i.getElementById("wpadminbar");if(i.body&&e){i.body.appendChild(e);if(e.className){e.className=e.className.replace(/nojs/,"")}c(e,"mouseover",function(d){h(d.target||d.srcElement)});c(e,"mouseout",function(d){l(d.target||d.srcElement)});c(e,"click",b)}if(k.location.hash){k.scrollBy(0,-32)}})})(document,window)}; 
     2 No newline at end of file 
  • wp-includes/script-loader.php

     
    260260 
    261261        $scripts->add( 'user-profile', "/wp-admin/js/user-profile$suffix.js", array( 'jquery', 'password-strength-meter' ), '20110628', 1 ); 
    262262 
    263         $scripts->add( 'admin-bar', "/wp-includes/js/admin-bar$suffix.js", false, '20111127', 1 ); 
     263        $scripts->add( 'admin-bar', "/wp-includes/js/admin-bar$suffix.js", false, '20111129', 1 ); 
    264264 
    265265        $scripts->add( 'wplink', "/wp-includes/js/wplink$suffix.js", array( 'jquery', 'wpdialogs' ), '20111128', 1 ); 
    266266        $scripts->localize( 'wplink', 'wpLinkL10n', array(