mirror of
https://github.com/Combodo/iTop.git
synced 2026-05-19 15:22:17 +02:00
No longer needed, implementation replaced by jquery.popupmenu.js
SVN:trunk[409]
This commit is contained in:
@@ -1,171 +0,0 @@
|
||||
/*
|
||||
* jdMenu 1.4.1 (2008-03-31)
|
||||
*
|
||||
* Copyright (c) 2006,2007 Jonathan Sharp (http://jdsharp.us)
|
||||
* Dual licensed under the MIT (MIT-LICENSE.txt)
|
||||
* and GPL (GPL-LICENSE.txt) licenses.
|
||||
*
|
||||
* http://jdsharp.us/
|
||||
*
|
||||
* Built upon jQuery 1.2.1 (http://jquery.com)
|
||||
* This also requires the jQuery dimensions >= 1.2 plugin
|
||||
*/
|
||||
|
||||
// This initializes the menu
|
||||
$(function() {
|
||||
$('ul.jd_menu').jdMenu();
|
||||
});
|
||||
|
||||
(function($){
|
||||
function addEvents(ul) {
|
||||
var settings = $.data( $(ul).parents().andSelf().filter('ul.jd_menu')[0], 'jdMenuSettings' );
|
||||
$('> li', ul)
|
||||
.bind('mouseenter.jdmenu mouseleave.jdmenu', function(evt) {
|
||||
$(this).toggleClass('jdm_hover');
|
||||
var ul = $('> ul', this);
|
||||
if ( ul.length == 1 ) {
|
||||
clearTimeout( this.$jdTimer );
|
||||
var enter = ( evt.type == 'mouseenter' );
|
||||
var fn = ( enter ? showMenu : hideMenu );
|
||||
this.$jdTimer = setTimeout(function() {
|
||||
fn( ul[0], settings.onAnimate, settings.isVertical );
|
||||
}, enter ? settings.showDelay : settings.hideDelay );
|
||||
}
|
||||
})
|
||||
.bind('click.jdmenu', function(evt) {
|
||||
var ul = $('> ul', this);
|
||||
if ( ul.length == 1 &&
|
||||
( settings.disableLinks == true || $(this).hasClass('accessible') ) ) {
|
||||
showMenu( ul, settings.onAnimate, settings.isVertical );
|
||||
return false;
|
||||
}
|
||||
|
||||
// The user clicked the li and we need to trigger a click for the a
|
||||
if ( evt.target == this ) {
|
||||
var link = $('> a', evt.target).not('.accessible');
|
||||
if ( link.length > 0 ) {
|
||||
var a = link[0];
|
||||
if ( !a.onclick ) {
|
||||
window.open( a.href, a.target || '_self' );
|
||||
} else {
|
||||
$(a).trigger('click');
|
||||
}
|
||||
}
|
||||
}
|
||||
if ( settings.disableLinks ||
|
||||
( !settings.disableLinks && !$(this).parent().hasClass('jd_menu') ) ) {
|
||||
$(this).parent().jdMenuHide();
|
||||
evt.stopPropagation();
|
||||
}
|
||||
})
|
||||
.find('> a')
|
||||
.bind('focus.jdmenu blur.jdmenu', function(evt) {
|
||||
var p = $(this).parents('li:eq(0)');
|
||||
if ( evt.type == 'focus' ) {
|
||||
p.addClass('jdm_hover');
|
||||
} else {
|
||||
p.removeClass('jdm_hover');
|
||||
}
|
||||
})
|
||||
.filter('.accessible')
|
||||
.bind('click.jdmenu', function(evt) {
|
||||
evt.preventDefault();
|
||||
});
|
||||
}
|
||||
|
||||
function showMenu(ul, animate, vertical) {
|
||||
var ul = $(ul);
|
||||
if ( ul.is(':visible') ) {
|
||||
return;
|
||||
}
|
||||
ul.bgiframe();
|
||||
var li = ul.parent();
|
||||
ul .trigger('jdMenuShow')
|
||||
.positionBy({ target: li[0],
|
||||
targetPos: ( vertical === true || !li.parent().hasClass('jd_menu') ? 1 : 3 ),
|
||||
elementPos: 0,
|
||||
hideAfterPosition: true
|
||||
});
|
||||
if ( !ul.hasClass('jdm_events') ) {
|
||||
ul.addClass('jdm_events');
|
||||
addEvents(ul);
|
||||
}
|
||||
li .addClass('jdm_active')
|
||||
// Hide any adjacent menus
|
||||
.siblings('li').find('> ul:eq(0):visible')
|
||||
.each(function(){
|
||||
hideMenu( this );
|
||||
});
|
||||
if ( animate === undefined ) {
|
||||
ul.show();
|
||||
} else {
|
||||
animate.apply( ul[0], [true] );
|
||||
}
|
||||
}
|
||||
|
||||
function hideMenu(ul, animate) {
|
||||
var ul = $(ul);
|
||||
$('.bgiframe', ul).remove();
|
||||
ul .filter(':not(.jd_menu)')
|
||||
.find('> li > ul:eq(0):visible')
|
||||
.each(function() {
|
||||
hideMenu( this );
|
||||
})
|
||||
.end();
|
||||
if ( animate === undefined ) {
|
||||
ul.hide()
|
||||
} else {
|
||||
animate.apply( ul[0], [false] );
|
||||
}
|
||||
|
||||
ul .trigger('jdMenuHide')
|
||||
.parents('li:eq(0)')
|
||||
.removeClass('jdm_active jdm_hover')
|
||||
.end()
|
||||
.find('> li')
|
||||
.removeClass('jdm_active jdm_hover');
|
||||
}
|
||||
|
||||
// Public methods
|
||||
$.fn.jdMenu = function(settings) {
|
||||
// Future settings: activateDelay
|
||||
var settings = $.extend({ // Time in ms before menu shows
|
||||
showDelay: 200,
|
||||
// Time in ms before menu hides
|
||||
hideDelay: 500,
|
||||
// Should items that contain submenus not
|
||||
// respond to clicks
|
||||
disableLinks: true
|
||||
// This callback allows for you to animate menus
|
||||
//onAnimate: null
|
||||
}, settings);
|
||||
if ( !$.isFunction( settings.onAnimate ) ) {
|
||||
settings.onAnimate = undefined;
|
||||
}
|
||||
return this.filter('ul.jd_menu').each(function() {
|
||||
$.data( this,
|
||||
'jdMenuSettings',
|
||||
$.extend({ isVertical: $(this).hasClass('jd_menu_vertical') }, settings)
|
||||
);
|
||||
addEvents(this);
|
||||
});
|
||||
};
|
||||
|
||||
$.fn.jdMenuUnbind = function() {
|
||||
$('ul.jdm_events', this)
|
||||
.unbind('.jdmenu')
|
||||
.find('> a').unbind('.jdmenu');
|
||||
};
|
||||
$.fn.jdMenuHide = function() {
|
||||
return this.filter('ul').each(function(){
|
||||
hideMenu( this );
|
||||
});
|
||||
};
|
||||
|
||||
// Private methods and logic
|
||||
$(window)
|
||||
// Bind a click event to hide all visible menus when the document is clicked
|
||||
.bind('click.jdmenu', function(){
|
||||
$('ul.jd_menu ul:visible').jdMenuHide();
|
||||
});
|
||||
})(jQuery);
|
||||
Reference in New Issue
Block a user