Make the responsive menu usable with a mouse, fix non-folded and :focus styles, toggle the submenus on touchend/click. Fixes #26086.

git-svn-id: https://develop.svn.wordpress.org/trunk@26516 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
Andrew Ozz 2013-12-02 03:18:40 +00:00
parent 8eedbe32ac
commit eb2767a578
2 changed files with 42 additions and 4 deletions

View File

@ -11823,6 +11823,14 @@ li#wp-admin-bar-menu-toggle {
display: block; display: block;
} }
.auto-fold #adminmenu a.menu-top:focus + .wp-submenu,
.auto-fold #adminmenu .wp-has-current-submenu a.menu-top:focus + .wp-submenu {
position: relative;
left: -1px;
right: 0;
top: 0;
}
/* Remove submenu headers and adjust sub meu*/ /* Remove submenu headers and adjust sub meu*/
#adminmenu .wp-submenu .wp-submenu-head { #adminmenu .wp-submenu .wp-submenu-head {
display: none; display: none;

View File

@ -251,6 +251,11 @@ $(document).ready( function() {
if ( isNaN(top) || top > -5 ) // meaning the submenu is visible if ( isNaN(top) || top > -5 ) // meaning the submenu is visible
return; return;
if ( menu.data('wp-responsive') ) {
// The menu is in responsive mode, bail
return;
}
menutop = $(this).offset().top; menutop = $(this).offset().top;
wintop = $(window).scrollTop(); wintop = $(window).scrollTop();
maxtop = menutop - wintop - 30; // max = make the top of the sub almost touch admin bar maxtop = menutop - wintop - 30; // max = make the top of the sub almost touch admin bar
@ -275,6 +280,11 @@ $(document).ready( function() {
$(this).addClass('opensub'); $(this).addClass('opensub');
}, },
out: function(){ out: function(){
if ( menu.data('wp-responsive') ) {
// The menu is in responsive mode, bail
return;
}
$(this).removeClass('opensub').find('.wp-submenu').css('margin-top', ''); $(this).removeClass('opensub').find('.wp-submenu').css('margin-top', '');
}, },
timeout: 200, timeout: 200,
@ -283,8 +293,18 @@ $(document).ready( function() {
}); });
menu.on('focus.adminmenu', '.wp-submenu a', function(e){ menu.on('focus.adminmenu', '.wp-submenu a', function(e){
if ( menu.data('wp-responsive') ) {
// The menu is in responsive mode, bail
return;
}
$(e.target).closest('li.menu-top').addClass('opensub'); $(e.target).closest('li.menu-top').addClass('opensub');
}).on('blur.adminmenu', '.wp-submenu a', function(e){ }).on('blur.adminmenu', '.wp-submenu a', function(e){
if ( menu.data('wp-responsive') ) {
// The menu is in responsive mode, bail
return;
}
$(e.target).closest('li.menu-top').removeClass('opensub'); $(e.target).closest('li.menu-top').removeClass('opensub');
}); });
@ -541,18 +561,28 @@ $(document).ready( function() {
// Add menu events // Add menu events
$adminmenu.on( 'touchstart.wp-responsive', 'li.wp-has-submenu > a', function() { $adminmenu.on( 'touchstart.wp-responsive', 'li.wp-has-submenu > a', function() {
scrollStart = $window.scrollTop(); scrollStart = $window.scrollTop();
}).on( 'touchend.wp-responsive', 'li.wp-has-submenu > a', function( event ) { }).on( 'touchend.wp-responsive click.wp-responsive', 'li.wp-has-submenu > a', function( event ) {
if ( ! $adminmenu.data('wp-responsive') || $window.scrollTop() !== scrollStart ) { if ( ! $adminmenu.data('wp-responsive') ||
( event.type === 'touchend' && $window.scrollTop() !== scrollStart ) ) {
return; return;
} }
$( this ).find( 'li.wp-has-submenu' ).removeClass( 'selected' ); $( this ).parent( 'li' ).toggleClass( 'selected' );
$( this ).parent( 'li' ).addClass( 'selected' );
event.preventDefault(); event.preventDefault();
}); });
self.trigger(); self.trigger();
$document.on( 'wp-window-resized.wp-responsive', $.proxy( this.trigger, this ) ); $document.on( 'wp-window-resized.wp-responsive', $.proxy( this.trigger, this ) );
// This needs to run later as UI Sortable may be initialized later on $(document).ready()
$window.on( 'load.wp-responsive', function() {
var width = navigator.userAgent.indexOf('AppleWebKit/') > -1 ? $window.width() : window.innerWidth;
if ( width <= 782 ) {
self.disableSortables();
}
});
}, },
activate: function() { activate: function() {