mirror of
https://github.com/TracksApp/tracks.git
synced 2026-01-06 17:28:50 +01:00
fix timing issues on failing scenarios. Fix deprecated jquery functions and update jqueryui
Signed-off-by: Reinier Balt <lrbalt@gmail.com>
This commit is contained in:
parent
e4cdf75f8c
commit
1d359b22d4
39 changed files with 715 additions and 600 deletions
132
vendor/assets/javascripts/superfish.js
vendored
132
vendor/assets/javascripts/superfish.js
vendored
|
|
@ -1,13 +1,12 @@
|
|||
|
||||
/*
|
||||
* Superfish v1.4.8 - jQuery menu widget
|
||||
* Copyright (c) 2008 Joel Birch
|
||||
* Superfish v1.5.3 - jQuery menu widget
|
||||
* Copyright (c) 2013 Joel Birch
|
||||
*
|
||||
* Dual licensed under the MIT and GPL licenses:
|
||||
* http://www.opensource.org/licenses/mit-license.php
|
||||
* http://www.gnu.org/licenses/gpl.html
|
||||
*
|
||||
* CHANGELOG: http://users.tpg.com.au/j_birch/plugins/superfish/changelog.txt
|
||||
*/
|
||||
|
||||
;(function($){
|
||||
|
|
@ -15,71 +14,110 @@
|
|||
|
||||
var sf = $.fn.superfish,
|
||||
c = sf.c,
|
||||
$arrow = $(['<span class="',c.arrowClass,'"> »</span>'].join('')),
|
||||
over = function(){
|
||||
$arrow = $('<span class="'+c.arrowClass+'"> »</span>'),
|
||||
over = function(e){
|
||||
var $$ = $(this), menu = getMenu($$);
|
||||
if (e.type === 'mouseenter' || e.type==='focusin'){
|
||||
$$.children('a').data('follow',true);
|
||||
}
|
||||
clearTimeout(menu.sfTimer);
|
||||
$$.showSuperfishUl().siblings().hideSuperfishUl();
|
||||
},
|
||||
out = function(){
|
||||
out = function(e){
|
||||
var $$ = $(this), menu = getMenu($$), o = sf.op;
|
||||
clearTimeout(menu.sfTimer);
|
||||
menu.sfTimer=setTimeout(function(){
|
||||
var close = function(){
|
||||
o.retainPath=($.inArray($$[0],o.$path)>-1);
|
||||
$$.hideSuperfishUl();
|
||||
if (o.$path.length && $$.parents(['li.',o.hoverClass].join('')).length<1){over.call(o.$path);}
|
||||
},o.delay);
|
||||
if (o.$path.length && $$.parents('li.'+o.hoverClass).length<1){
|
||||
o.onIdle.call();
|
||||
$.proxy(over,o.$path,e)();
|
||||
}
|
||||
};
|
||||
if (e.type !== 'mouseleave' && e.type !== 'focusout'){
|
||||
close();
|
||||
} else {
|
||||
clearTimeout(menu.sfTimer);
|
||||
menu.sfTimer=setTimeout(close,o.delay);
|
||||
}
|
||||
if (e.type === 'mouseleave' || e.type === 'focusout'){
|
||||
$$.children('a').data('follow',false);
|
||||
}
|
||||
},
|
||||
getMenu = function($menu){
|
||||
var menu = $menu.parents(['ul.',c.menuClass,':first'].join(''))[0];
|
||||
getMenu = function($child){
|
||||
if ($child.hasClass(c.menuClass)){
|
||||
$.error('Superfish requires you to update to a version of hoverIntent that supports event-delegation, such as this one: https://github.com/joeldbirch/onHoverIntent');
|
||||
}
|
||||
var menu = $child.closest('.'+c.menuClass)[0];
|
||||
sf.op = sf.o[menu.serial];
|
||||
return menu;
|
||||
},
|
||||
applyHandlers = function($menu){
|
||||
var targets = 'li:has(ul)';
|
||||
if (!sf.op.useClick){
|
||||
if ($.fn.hoverIntent && !sf.op.disableHI){
|
||||
$menu.hoverIntent(over, out, targets);
|
||||
} else {
|
||||
$menu.on('mouseenter', targets, over);
|
||||
$menu.on('mouseleave', targets, out);
|
||||
}
|
||||
}
|
||||
$menu.on('focusin', targets, over);
|
||||
$menu.on('focusout', targets, out);
|
||||
$menu.on('click', 'a', clickHandler);
|
||||
},
|
||||
clickHandler = function(e){
|
||||
var $a = $(this);
|
||||
var $submenu = $a.next('ul');
|
||||
var follow = $a.data('follow');
|
||||
|
||||
if ( $submenu.length && (sf.op.useClick || !follow) ){
|
||||
e.preventDefault();
|
||||
if ($submenu.is(':visible')){
|
||||
$.proxy(out,$(this).parent(),e)();
|
||||
} else {
|
||||
$.proxy(over,$(this).parent(),e)();
|
||||
}
|
||||
}
|
||||
},
|
||||
addArrows = function($li,o){
|
||||
if (o.autoArrows) {
|
||||
$li.children('a').each(function() {
|
||||
addArrow( $(this) );
|
||||
});
|
||||
}
|
||||
},
|
||||
addArrow = function($a){ $a.addClass(c.anchorClass).append($arrow.clone()); };
|
||||
|
||||
return this.each(function() {
|
||||
return this.addClass(c.menuClass).each(function() {
|
||||
var s = this.serial = sf.o.length;
|
||||
var o = $.extend({},sf.defaults,op);
|
||||
o.$path = $('li.'+o.pathClass,this).slice(0,o.pathLevels).each(function(){
|
||||
$(this).addClass([o.hoverClass,c.bcClass].join(' '))
|
||||
var $$ = $(this);
|
||||
var $liHasUl = $$.find('li:has(ul)');
|
||||
o.$path = $$.find('li.'+o.pathClass).slice(0,o.pathLevels).each(function(){
|
||||
$(this).addClass(o.hoverClass+' '+c.bcClass)
|
||||
.filter('li:has(ul)').removeClass(o.pathClass);
|
||||
});
|
||||
sf.o[s] = sf.op = o;
|
||||
|
||||
$('li:has(ul)',this)[($.fn.hoverIntent && !o.disableHI) ? 'hoverIntent' : 'hover'](over,out).each(function() {
|
||||
if (o.autoArrows) addArrow( $('>a:first-child',this) );
|
||||
})
|
||||
.not('.'+c.bcClass)
|
||||
.hideSuperfishUl();
|
||||
addArrows($liHasUl,o);
|
||||
applyHandlers($$);
|
||||
|
||||
$liHasUl.not('.'+c.bcClass).hideSuperfishUl();
|
||||
|
||||
var $a = $('a',this);
|
||||
$a.each(function(i){
|
||||
var $li = $a.eq(i).parents('li');
|
||||
$a.eq(i).focus(function(){over.call($li);}).blur(function(){out.call($li);});
|
||||
});
|
||||
o.onInit.call(this);
|
||||
|
||||
}).each(function() {
|
||||
var menuClasses = [c.menuClass];
|
||||
if (sf.op.dropShadows && !($.browser.msie && $.browser.version < 7)) menuClasses.push(c.shadowClass);
|
||||
$(this).addClass(menuClasses.join(' '));
|
||||
});
|
||||
};
|
||||
|
||||
var sf = $.fn.superfish;
|
||||
sf.o = [];
|
||||
sf.op = {};
|
||||
sf.IE7fix = function(){
|
||||
var o = sf.op;
|
||||
if ($.browser.msie && $.browser.version > 6 && o.dropShadows && o.animation.opacity!=undefined)
|
||||
this.toggleClass(sf.c.shadowClass+'-off');
|
||||
};
|
||||
|
||||
sf.c = {
|
||||
bcClass : 'sf-breadcrumb',
|
||||
menuClass : 'sf-js-enabled',
|
||||
anchorClass : 'sf-with-ul',
|
||||
arrowClass : 'sf-sub-indicator',
|
||||
shadowClass : 'sf-shadow'
|
||||
arrowClass : 'sf-sub-indicator'
|
||||
};
|
||||
sf.defaults = {
|
||||
hoverClass : 'sfHover',
|
||||
|
|
@ -87,33 +125,39 @@
|
|||
pathLevels : 1,
|
||||
delay : 800,
|
||||
animation : {opacity:'show'},
|
||||
animationOut: {opacity:'hide'},
|
||||
speed : 'normal',
|
||||
speedOut : 'fast',
|
||||
autoArrows : true,
|
||||
dropShadows : true,
|
||||
disableHI : false, // true disables hoverIntent detection
|
||||
useClick : false,
|
||||
onInit : function(){}, // callback functions
|
||||
onBeforeShow: function(){},
|
||||
onShow : function(){},
|
||||
onHide : function(){}
|
||||
onHide : function(){},
|
||||
onIdle : function(){}
|
||||
};
|
||||
$.fn.extend({
|
||||
hideSuperfishUl : function(){
|
||||
var o = sf.op,
|
||||
not = (o.retainPath===true) ? o.$path : '';
|
||||
o.retainPath = false;
|
||||
var $ul = $(['li.',o.hoverClass].join(''),this).add(this).not(not).removeClass(o.hoverClass)
|
||||
.find('>ul').hide().css('visibility','hidden');
|
||||
o.onHide.call($ul);
|
||||
var $ul = $('li.'+o.hoverClass,this).add(this).not(not)
|
||||
.find('>ul').stop().animate(o.animationOut,o.speedOut,function(){
|
||||
$ul = $(this);
|
||||
$ul.css('visibility','hidden').parent().removeClass(o.hoverClass);
|
||||
o.onHide.call($ul);
|
||||
});
|
||||
return this;
|
||||
},
|
||||
showSuperfishUl : function(){
|
||||
var o = sf.op,
|
||||
sh = sf.c.shadowClass+'-off',
|
||||
$ul = this.addClass(o.hoverClass)
|
||||
.find('>ul:hidden').css('visibility','visible');
|
||||
sf.IE7fix.call($ul);
|
||||
o.onBeforeShow.call($ul);
|
||||
$ul.animate(o.animation,o.speed,function(){ sf.IE7fix.call($ul); o.onShow.call($ul); });
|
||||
$ul.stop().animate(o.animation,o.speed,function(){
|
||||
o.onShow.call($ul);
|
||||
});
|
||||
return this;
|
||||
}
|
||||
});
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue