Make the admin menu and toolbar work well on mobile devices, props georgestephanis, see #20614
git-svn-id: http://core.svn.wordpress.org/trunk@22262 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
parent
5e958d50c9
commit
1dad05c508
|
@ -195,7 +195,24 @@ $(document).ready( function() {
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
$('li.wp-has-submenu', menu).hoverIntent({
|
if ( 'ontouchstart' in window || /IEMobile\/[1-9]/.test(navigator.userAgent) ) { // touch screen device
|
||||||
|
// close any open submenus when touch/click is not on the menu
|
||||||
|
$(document.body).on('click.wp-mobile-hover', function(e) {
|
||||||
|
if ( !$(e.target).closest('#adminmenu').length )
|
||||||
|
menu.find('li.wp-has-submenu.opensub').removeClass('opensub');
|
||||||
|
});
|
||||||
|
|
||||||
|
menu.find('li.wp-has-submenu').on('click.wp-mobile-hover', function(e) {
|
||||||
|
var el = $(this);
|
||||||
|
|
||||||
|
if ( !el.hasClass('opensub') ) {
|
||||||
|
e.preventDefault();
|
||||||
|
menu.find('li.wp-has-submenu.opensub').removeClass('opensub');
|
||||||
|
el.addClass('opensub');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
menu.find('li.wp-has-submenu').hoverIntent({
|
||||||
over: function(e){
|
over: function(e){
|
||||||
var b, h, o, f, m = $(this).find('.wp-submenu'), menutop, wintop, maxtop, top = parseInt( m.css('top'), 10 );
|
var b, h, o, f, m = $(this).find('.wp-submenu'), menutop, wintop, maxtop, top = parseInt( m.css('top'), 10 );
|
||||||
|
|
||||||
|
@ -238,6 +255,7 @@ $(document).ready( function() {
|
||||||
}).on('blur.adminmenu', '.wp-submenu a', function(e){
|
}).on('blur.adminmenu', '.wp-submenu a', function(e){
|
||||||
$(e.target).closest('li.menu-top').removeClass('opensub');
|
$(e.target).closest('li.menu-top').removeClass('opensub');
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Move .updated and .error alert boxes. Don't move boxes designed to be inline.
|
// Move .updated and .error alert boxes. Don't move boxes designed to be inline.
|
||||||
$('div.wrap h2:first').nextAll('div.updated, div.error').addClass('below-h2');
|
$('div.wrap h2:first').nextAll('div.updated, div.error').addClass('below-h2');
|
||||||
|
|
|
@ -4,13 +4,34 @@ if ( typeof(jQuery) != 'undefined' ) {
|
||||||
(function(a){a.fn.hoverIntent=function(l,j){var m={sensitivity:7,interval:100,timeout:0};m=a.extend(m,j?{over:l,out:j}:l);var o,n,h,d;var e=function(f){o=f.pageX;n=f.pageY};var c=function(g,f){f.hoverIntent_t=clearTimeout(f.hoverIntent_t);if((Math.abs(h-o)+Math.abs(d-n))<m.sensitivity){a(f).unbind("mousemove",e);f.hoverIntent_s=1;return m.over.apply(f,[g])}else{h=o;d=n;f.hoverIntent_t=setTimeout(function(){c(g,f)},m.interval)}};var i=function(g,f){f.hoverIntent_t=clearTimeout(f.hoverIntent_t);f.hoverIntent_s=0;return m.out.apply(f,[g])};var b=function(q){var f=this;var g=(q.type=="mouseover"?q.fromElement:q.toElement)||q.relatedTarget;while(g&&g!=this){try{g=g.parentNode}catch(q){g=this}}if(g==this){if(a.browser.mozilla){if(q.type=="mouseout"){f.mtout=setTimeout(function(){k(q,f)},30)}else{if(f.mtout){f.mtout=clearTimeout(f.mtout)}}}return}else{if(f.mtout){f.mtout=clearTimeout(f.mtout)}k(q,f)}};var k=function(p,f){var g=jQuery.extend({},p);if(f.hoverIntent_t){f.hoverIntent_t=clearTimeout(f.hoverIntent_t)}if(p.type=="mouseover"){h=g.pageX;d=g.pageY;a(f).bind("mousemove",e);if(f.hoverIntent_s!=1){f.hoverIntent_t=setTimeout(function(){c(g,f)},m.interval)}}else{a(f).unbind("mousemove",e);if(f.hoverIntent_s==1){f.hoverIntent_t=setTimeout(function(){i(g,f)},m.timeout)}}};return this.mouseover(b).mouseout(b)}})(jQuery);
|
(function(a){a.fn.hoverIntent=function(l,j){var m={sensitivity:7,interval:100,timeout:0};m=a.extend(m,j?{over:l,out:j}:l);var o,n,h,d;var e=function(f){o=f.pageX;n=f.pageY};var c=function(g,f){f.hoverIntent_t=clearTimeout(f.hoverIntent_t);if((Math.abs(h-o)+Math.abs(d-n))<m.sensitivity){a(f).unbind("mousemove",e);f.hoverIntent_s=1;return m.over.apply(f,[g])}else{h=o;d=n;f.hoverIntent_t=setTimeout(function(){c(g,f)},m.interval)}};var i=function(g,f){f.hoverIntent_t=clearTimeout(f.hoverIntent_t);f.hoverIntent_s=0;return m.out.apply(f,[g])};var b=function(q){var f=this;var g=(q.type=="mouseover"?q.fromElement:q.toElement)||q.relatedTarget;while(g&&g!=this){try{g=g.parentNode}catch(q){g=this}}if(g==this){if(a.browser.mozilla){if(q.type=="mouseout"){f.mtout=setTimeout(function(){k(q,f)},30)}else{if(f.mtout){f.mtout=clearTimeout(f.mtout)}}}return}else{if(f.mtout){f.mtout=clearTimeout(f.mtout)}k(q,f)}};var k=function(p,f){var g=jQuery.extend({},p);if(f.hoverIntent_t){f.hoverIntent_t=clearTimeout(f.hoverIntent_t)}if(p.type=="mouseover"){h=g.pageX;d=g.pageY;a(f).bind("mousemove",e);if(f.hoverIntent_s!=1){f.hoverIntent_t=setTimeout(function(){c(g,f)},m.interval)}}else{a(f).unbind("mousemove",e);if(f.hoverIntent_s==1){f.hoverIntent_t=setTimeout(function(){i(g,f)},m.timeout)}}};return this.mouseover(b).mouseout(b)}})(jQuery);
|
||||||
|
|
||||||
jQuery(document).ready(function($){
|
jQuery(document).ready(function($){
|
||||||
var refresh = function(i, el){ // force the browser to refresh the tabbing index
|
var adminbar = $('#wpadminbar'), refresh;
|
||||||
|
|
||||||
|
refresh = function(i, el){ // force the browser to refresh the tabbing index
|
||||||
var node = $(el), tab = node.attr('tabindex');
|
var node = $(el), tab = node.attr('tabindex');
|
||||||
if ( tab )
|
if ( tab )
|
||||||
node.attr('tabindex', '0').attr('tabindex', tab);
|
node.attr('tabindex', '0').attr('tabindex', tab);
|
||||||
};
|
};
|
||||||
|
|
||||||
$('#wpadminbar').removeClass('nojq').removeClass('nojs').find('li.menupop').hoverIntent({
|
adminbar.removeClass('nojq').removeClass('nojs');
|
||||||
|
|
||||||
|
if ( 'ontouchstart' in window || /IEMobile\/[1-9]/.test(navigator.userAgent) ) { // touch screen device
|
||||||
|
// close any open drop-downs when the click/touch is not on the toolbar
|
||||||
|
$(document.body).on('click.wp-mobile-hover', function(e) {
|
||||||
|
if ( !$(e.target).closest('#wpadminbar').length )
|
||||||
|
adminbar.find('li.menupop.hover').removeClass('hover');
|
||||||
|
});
|
||||||
|
|
||||||
|
adminbar.find('li.menupop').on('click.wp-mobile-hover', function(e) {
|
||||||
|
var el = $(this);
|
||||||
|
|
||||||
|
if ( !el.hasClass('hover') ) {
|
||||||
|
e.preventDefault();
|
||||||
|
adminbar.find('li.menupop.hover').removeClass('hover');
|
||||||
|
el.addClass('hover');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
adminbar.find('li.menupop').hoverIntent({
|
||||||
over: function(e){
|
over: function(e){
|
||||||
$(this).addClass('hover');
|
$(this).addClass('hover');
|
||||||
},
|
},
|
||||||
|
@ -21,6 +42,7 @@ if ( typeof(jQuery) != 'undefined' ) {
|
||||||
sensitivity: 7,
|
sensitivity: 7,
|
||||||
interval: 100
|
interval: 100
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
$('#wp-admin-bar-get-shortlink').click(function(e){
|
$('#wp-admin-bar-get-shortlink').click(function(e){
|
||||||
e.preventDefault();
|
e.preventDefault();
|
||||||
|
@ -98,9 +120,10 @@ if ( typeof(jQuery) != 'undefined' ) {
|
||||||
*/
|
*/
|
||||||
getTOID = function(el) {
|
getTOID = function(el) {
|
||||||
var i = q.length;
|
var i = q.length;
|
||||||
while( i-- )
|
while ( i-- ) {
|
||||||
if ( q[i] && el == q[i][1] )
|
if ( q[i] && el == q[i][1] )
|
||||||
return q[i][0];
|
return q[i][0];
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue