Ticket #20614: 20614-6.patch
File 20614-6.patch, 8.1 KB (added by , 12 years ago) |
---|
-
wp-admin/js/common.js
195 195 } 196 196 }); 197 197 198 $('li.wp-has-submenu', menu).hoverIntent({ 199 over: function(e){ 200 var b, h, o, f, m = $(this).find('.wp-submenu'), menutop, wintop, maxtop, top = parseInt( m.css('top'), 10 ); 198 if ( 'ontouchstart' in window || /IEMobile\/[7-9]/.test(navigator.userAgent) ) { // touch screen device 199 // close any open submenus when touch/click is not on the menu 200 $(document.body).on('click.wp-mobile-hover', function(e) { 201 if ( !$(e.target).closest('#adminmenu').length ) 202 menu.find('li.wp-has-submenu.opensub').removeClass('opensub'); 203 }); 201 204 202 if ( isNaN(top) || top > -5 ) // meaning the submenu is visible203 return;205 menu.find('li.wp-has-submenu').on('click.wp-mobile-hover', function(e) { 206 var el = $(this); 204 207 205 menutop = $(this).offset().top; 206 wintop = $(window).scrollTop(); 207 maxtop = menutop - wintop - 30; // max = make the top of the sub almost touch admin bar 208 if ( !el.hasClass('opensub') ) { 209 e.preventDefault(); 210 menu.find('li.wp-has-submenu.opensub').removeClass('opensub'); 211 el.addClass('opensub'); 212 } 213 }); 214 } else { 215 menu.find('li.wp-has-submenu').hoverIntent({ 216 over: function(e){ 217 var b, h, o, f, m = $(this).find('.wp-submenu'), menutop, wintop, maxtop, top = parseInt( m.css('top'), 10 ); 208 218 209 b = menutop + m.height() + 1; // Bottom offset of the menu 210 h = $('#wpwrap').height(); // Height of the entire page 211 o = 60 + b - h; 212 f = $(window).height() + wintop - 15; // The fold 219 if ( isNaN(top) || top > -5 ) // meaning the submenu is visible 220 return; 213 221 214 if ( f < (b - o) ) 215 o = b - f; 222 menutop = $(this).offset().top; 223 wintop = $(window).scrollTop(); 224 maxtop = menutop - wintop - 30; // max = make the top of the sub almost touch admin bar 216 225 217 if ( o > maxtop ) 218 o = maxtop; 226 b = menutop + m.height() + 1; // Bottom offset of the menu 227 h = $('#wpwrap').height(); // Height of the entire page 228 o = 60 + b - h; 229 f = $(window).height() + wintop - 15; // The fold 219 230 220 if ( o > 1 ) 221 m.css('margin-top', '-'+o+'px'); 222 else 223 m.css('margin-top', ''); 231 if ( f < (b - o) ) 232 o = b - f; 224 233 225 menu.find('li.menu-top').removeClass('opensub'); 226 $(this).addClass('opensub'); 227 }, 228 out: function(){ 229 $(this).removeClass('opensub').find('.wp-submenu').css('margin-top', ''); 230 }, 231 timeout: 200, 232 sensitivity: 7, 233 interval: 90 234 }); 234 if ( o > maxtop ) 235 o = maxtop; 235 236 236 menu.on('focus.adminmenu', '.wp-submenu a', function(e){ 237 $(e.target).closest('li.menu-top').addClass('opensub'); 238 }).on('blur.adminmenu', '.wp-submenu a', function(e){ 239 $(e.target).closest('li.menu-top').removeClass('opensub'); 240 }); 237 if ( o > 1 ) 238 m.css('margin-top', '-'+o+'px'); 239 else 240 m.css('margin-top', ''); 241 241 242 menu.find('li.menu-top').removeClass('opensub'); 243 $(this).addClass('opensub'); 244 }, 245 out: function(){ 246 $(this).removeClass('opensub').find('.wp-submenu').css('margin-top', ''); 247 }, 248 timeout: 200, 249 sensitivity: 7, 250 interval: 90 251 }); 252 253 menu.on('focus.adminmenu', '.wp-submenu a', function(e){ 254 $(e.target).closest('li.menu-top').addClass('opensub'); 255 }).on('blur.adminmenu', '.wp-submenu a', function(e){ 256 $(e.target).closest('li.menu-top').removeClass('opensub'); 257 }); 258 } 259 242 260 // Move .updated and .error alert boxes. Don't move boxes designed to be inline. 243 261 $('div.wrap h2:first').nextAll('div.updated, div.error').addClass('below-h2'); 244 262 $('div.updated, div.error').not('.below-h2, .inline').insertAfter( $('div.wrap h2:first') ); -
wp-includes/js/admin-bar.js
4 4 (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); 5 5 6 6 jQuery(document).ready(function($){ 7 var refresh = function(i, el){ // force the browser to refresh the tabbing index 7 var adminbar = $('#wpadminbar'), refresh; 8 9 refresh = function(i, el){ // force the browser to refresh the tabbing index 8 10 var node = $(el), tab = node.attr('tabindex'); 9 11 if ( tab ) 10 12 node.attr('tabindex', '0').attr('tabindex', tab); 11 13 }; 12 14 13 $('#wpadminbar').removeClass('nojq').removeClass('nojs').find('li.menupop').hoverIntent({ 14 over: function(e){ 15 $(this).addClass('hover'); 16 }, 17 out: function(e){ 18 $(this).removeClass('hover'); 19 }, 20 timeout: 180, 21 sensitivity: 7, 22 interval: 100 23 }); 15 adminbar.removeClass('nojq').removeClass('nojs'); 16 17 if ( 'ontouchstart' in window || /IEMobile\/[7-9]/.test(navigator.userAgent) ) { // touch screen device 18 // close any open drop-downs when the click/touch is not on the toolbar 19 $(document.body).on('click.wp-mobile-hover', function(e) { 20 if ( !$(e.target).closest('#wpadminbar').length ) 21 adminbar.find('li.menupop.hover').removeClass('hover'); 22 }); 24 23 24 adminbar.find('li.menupop').on('click.wp-mobile-hover', function(e) { 25 var el = $(this); 26 27 if ( !el.hasClass('hover') ) { 28 e.preventDefault(); 29 adminbar.find('li.menupop.hover').removeClass('hover'); 30 el.addClass('hover'); 31 } 32 }); 33 } else { 34 adminbar.find('li.menupop').hoverIntent({ 35 over: function(e){ 36 $(this).addClass('hover'); 37 }, 38 out: function(e){ 39 $(this).removeClass('hover'); 40 }, 41 timeout: 180, 42 sensitivity: 7, 43 interval: 100 44 }); 45 } 46 25 47 $('#wp-admin-bar-get-shortlink').click(function(e){ 26 48 e.preventDefault(); 27 49 $(this).addClass('selected').children('.shortlink-input').blur(function(){ … … 84 106 } else { 85 107 (function(d, w) { 86 108 var addEvent = function( obj, type, fn ) { 87 if ( obj.addEventListener)109 if ( obj.addEventListener ) 88 110 obj.addEventListener(type, fn, false); 89 else if ( obj.attachEvent)111 else if ( obj.attachEvent ) 90 112 obj.attachEvent('on' + type, function() { return fn.call(obj, window.event);}); 91 113 }, 92 114 … … 98 120 */ 99 121 getTOID = function(el) { 100 122 var i = q.length; 101 while ( i-- )123 while ( i-- ) { 102 124 if ( q[i] && el == q[i][1] ) 103 125 return q[i][0]; 126 } 104 127 return false; 105 128 }, 106 129 … … 110 133 ancestorLength = 0; 111 134 112 135 while ( t && t != aB && t != d ) { 113 if ( 'LI' == t.nodeName.toUpperCase() ) {136 if ( 'LI' == t.nodeName.toUpperCase() ) { 114 137 ancestors[ ancestors.length ] = t; 115 138 id = getTOID(t); 116 139 if ( id ) … … 151 174 152 175 removeHoverClass = function(t) { 153 176 while ( t && t != aB && t != d ) { 154 if ( 'LI' == t.nodeName.toUpperCase() ) {177 if ( 'LI' == t.nodeName.toUpperCase() ) { 155 178 (function(t) { 156 179 var to = setTimeout(function() { 157 180 t.className = t.className ? t.className.replace(hc, '') : '';