2009-11-13 04:00:12 +00:00
|
|
|
|
/*!
|
2008-06-04 02:34:33 +00:00
|
|
|
|
* jQuery UI @VERSION
|
|
|
|
|
*
|
2010-07-14 19:45:45 +00:00
|
|
|
|
* Copyright 2010, AUTHORS.txt (http://jqueryui.com/about)
|
2010-07-09 13:01:04 +00:00
|
|
|
|
* Dual licensed under the MIT or GPL Version 2 licenses.
|
|
|
|
|
* http://jquery.org/license
|
2008-06-04 02:34:33 +00:00
|
|
|
|
*
|
|
|
|
|
* http://docs.jquery.com/UI
|
|
|
|
|
*/
|
2010-07-13 13:57:58 +00:00
|
|
|
|
(function( $, undefined ) {
|
2010-05-20 00:33:23 +00:00
|
|
|
|
|
|
|
|
|
// prevent duplicate loading
|
|
|
|
|
// this is only a problem because we proxy existing functions
|
|
|
|
|
// and we don't want to double proxy them
|
|
|
|
|
$.ui = $.ui || {};
|
2010-07-22 23:26:37 +00:00
|
|
|
|
if ( $.ui.version ) {
|
2010-05-20 00:33:23 +00:00
|
|
|
|
return;
|
|
|
|
|
}
|
2008-06-04 02:34:33 +00:00
|
|
|
|
|
2008-11-03 14:23:13 +00:00
|
|
|
|
//Helper functions and ui object
|
2010-07-22 23:26:37 +00:00
|
|
|
|
$.extend( $.ui, {
|
2008-11-03 14:23:13 +00:00
|
|
|
|
version: "@VERSION",
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2008-11-03 14:23:13 +00:00
|
|
|
|
// $.ui.plugin is deprecated. Use the proxy pattern instead.
|
|
|
|
|
plugin: {
|
2010-07-22 23:26:37 +00:00
|
|
|
|
add: function( module, option, set ) {
|
|
|
|
|
var proto = $.ui[ module ].prototype;
|
|
|
|
|
for ( var i in set ) {
|
|
|
|
|
proto.plugins[ i ] = proto.plugins[ i ] || [];
|
|
|
|
|
proto.plugins[ i ].push( [ option, set[ i ] ] );
|
2008-11-03 14:23:13 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
2010-07-22 23:26:37 +00:00
|
|
|
|
call: function( instance, name, args ) {
|
|
|
|
|
var set = instance.plugins[ name ];
|
|
|
|
|
if ( !set || !instance.element[ 0 ].parentNode ) {
|
|
|
|
|
return;
|
|
|
|
|
}
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
for ( var i = 0; i < set.length; i++ ) {
|
|
|
|
|
if ( instance.options[ set[ i ][ 0 ] ] ) {
|
|
|
|
|
set[ i ][ 1 ].apply( instance.element, args );
|
2008-11-03 14:23:13 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
2008-11-12 03:57:23 +00:00
|
|
|
|
}
|
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
contains: function( a, b ) {
|
|
|
|
|
return document.compareDocumentPosition ?
|
|
|
|
|
a.compareDocumentPosition( b ) & 16 :
|
|
|
|
|
a !== b && a.contains( b );
|
2008-11-03 14:23:13 +00:00
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
hasScroll: function( el, a ) {
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2008-11-03 14:23:13 +00:00
|
|
|
|
//If overflow is hidden, the element might have extra content, but the user wants to hide it
|
2010-07-22 23:26:37 +00:00
|
|
|
|
if ( $( el ).css( "overflow" ) === "hidden") {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
var scroll = ( a && a === "left" ) ? "scrollLeft" : "scrollTop",
|
2008-11-03 14:23:13 +00:00
|
|
|
|
has = false;
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
if ( el[ scroll ] > 0 ) {
|
|
|
|
|
return true;
|
|
|
|
|
}
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2008-11-03 14:23:13 +00:00
|
|
|
|
// TODO: determine which cases actually cause this to happen
|
|
|
|
|
// if the element doesn't have the scroll set, see if it's possible to
|
|
|
|
|
// set the scroll
|
2010-07-22 23:26:37 +00:00
|
|
|
|
el[ scroll ] = 1;
|
|
|
|
|
has = ( el[ scroll ] > 0 );
|
|
|
|
|
el[ scroll ] = 0;
|
2008-11-03 14:23:13 +00:00
|
|
|
|
return has;
|
2008-11-10 05:16:22 +00:00
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
isOverAxis: function( x, reference, size ) {
|
2008-11-21 18:41:19 +00:00
|
|
|
|
//Determines when x coordinate is over "b" element axis
|
2010-07-22 23:26:37 +00:00
|
|
|
|
return ( x > reference ) && ( x < ( reference + size ) );
|
2008-11-10 05:16:22 +00:00
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
isOver: function( y, x, top, left, height, width ) {
|
2008-11-10 06:42:23 +00:00
|
|
|
|
//Determines when x, y coordinates is over "b" element
|
2010-07-22 23:26:37 +00:00
|
|
|
|
return $.ui.isOverAxis( y, top, height ) && $.ui.isOverAxis( x, left, width );
|
2008-12-14 06:11:37 +00:00
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
keyCode: {
|
2010-03-26 16:40:46 +00:00
|
|
|
|
ALT: 18,
|
2008-12-14 06:11:37 +00:00
|
|
|
|
BACKSPACE: 8,
|
|
|
|
|
CAPS_LOCK: 20,
|
|
|
|
|
COMMA: 188,
|
2010-04-23 16:56:52 +00:00
|
|
|
|
COMMAND: 91,
|
|
|
|
|
COMMAND_LEFT: 91, // COMMAND
|
|
|
|
|
COMMAND_RIGHT: 93,
|
2008-12-14 06:11:37 +00:00
|
|
|
|
CONTROL: 17,
|
|
|
|
|
DELETE: 46,
|
|
|
|
|
DOWN: 40,
|
|
|
|
|
END: 35,
|
|
|
|
|
ENTER: 13,
|
|
|
|
|
ESCAPE: 27,
|
|
|
|
|
HOME: 36,
|
|
|
|
|
INSERT: 45,
|
|
|
|
|
LEFT: 37,
|
2010-04-23 16:56:52 +00:00
|
|
|
|
MENU: 93, // COMMAND_RIGHT
|
2008-12-14 06:11:37 +00:00
|
|
|
|
NUMPAD_ADD: 107,
|
|
|
|
|
NUMPAD_DECIMAL: 110,
|
|
|
|
|
NUMPAD_DIVIDE: 111,
|
|
|
|
|
NUMPAD_ENTER: 108,
|
|
|
|
|
NUMPAD_MULTIPLY: 106,
|
|
|
|
|
NUMPAD_SUBTRACT: 109,
|
|
|
|
|
PAGE_DOWN: 34,
|
|
|
|
|
PAGE_UP: 33,
|
|
|
|
|
PERIOD: 190,
|
|
|
|
|
RIGHT: 39,
|
|
|
|
|
SHIFT: 16,
|
|
|
|
|
SPACE: 32,
|
|
|
|
|
TAB: 9,
|
2010-04-23 16:56:52 +00:00
|
|
|
|
UP: 38,
|
|
|
|
|
WINDOWS: 91 // COMMAND
|
2008-11-03 14:23:13 +00:00
|
|
|
|
}
|
2010-05-20 00:33:23 +00:00
|
|
|
|
});
|
2008-11-03 14:23:13 +00:00
|
|
|
|
|
|
|
|
|
//jQuery plugins
|
2008-09-22 20:52:48 +00:00
|
|
|
|
$.fn.extend({
|
2009-04-18 13:04:07 +00:00
|
|
|
|
_focus: $.fn.focus,
|
2010-07-22 23:26:37 +00:00
|
|
|
|
focus: function( delay, fn ) {
|
|
|
|
|
return typeof delay === "number" ?
|
|
|
|
|
this.each(function() {
|
2009-04-18 13:04:07 +00:00
|
|
|
|
var elem = this;
|
|
|
|
|
setTimeout(function() {
|
2010-07-22 23:26:37 +00:00
|
|
|
|
$( elem ).focus();
|
|
|
|
|
if ( fn ) {
|
|
|
|
|
fn.call( elem );
|
|
|
|
|
}
|
|
|
|
|
}, delay );
|
|
|
|
|
}) :
|
|
|
|
|
this._focus.apply( this, arguments );
|
2009-04-18 13:04:07 +00:00
|
|
|
|
},
|
2010-07-22 23:26:37 +00:00
|
|
|
|
|
2008-11-03 14:23:13 +00:00
|
|
|
|
enableSelection: function() {
|
|
|
|
|
return this
|
2010-07-22 23:26:37 +00:00
|
|
|
|
.attr( "unselectable", "off" )
|
|
|
|
|
.css( "MozUserSelect", "" );
|
2008-11-03 14:23:13 +00:00
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2008-11-03 14:23:13 +00:00
|
|
|
|
disableSelection: function() {
|
|
|
|
|
return this
|
2010-07-22 23:26:37 +00:00
|
|
|
|
.attr( "unselectable", "on" )
|
|
|
|
|
.css( "MozUserSelect", "none" );
|
2008-11-10 14:32:25 +00:00
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2008-11-10 14:32:25 +00:00
|
|
|
|
scrollParent: function() {
|
2008-11-23 17:42:24 +00:00
|
|
|
|
var scrollParent;
|
2010-07-22 23:26:37 +00:00
|
|
|
|
if (($.browser.msie && (/(static|relative)/).test(this.css('position'))) || (/absolute/).test(this.css('position'))) {
|
2008-11-23 17:42:24 +00:00
|
|
|
|
scrollParent = this.parents().filter(function() {
|
|
|
|
|
return (/(relative|absolute|fixed)/).test($.curCSS(this,'position',1)) && (/(auto|scroll)/).test($.curCSS(this,'overflow',1)+$.curCSS(this,'overflow-y',1)+$.curCSS(this,'overflow-x',1));
|
|
|
|
|
}).eq(0);
|
|
|
|
|
} else {
|
|
|
|
|
scrollParent = this.parents().filter(function() {
|
|
|
|
|
return (/(auto|scroll)/).test($.curCSS(this,'overflow',1)+$.curCSS(this,'overflow-y',1)+$.curCSS(this,'overflow-x',1));
|
|
|
|
|
}).eq(0);
|
|
|
|
|
}
|
2008-11-28 15:43:32 +00:00
|
|
|
|
|
2008-11-23 17:42:24 +00:00
|
|
|
|
return (/fixed/).test(this.css('position')) || !scrollParent.length ? $(document) : scrollParent;
|
2009-08-05 13:30:55 +00:00
|
|
|
|
},
|
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
zIndex: function( zIndex ) {
|
|
|
|
|
if ( zIndex !== undefined ) {
|
|
|
|
|
return this.css( "zIndex", zIndex );
|
2009-08-05 13:30:55 +00:00
|
|
|
|
}
|
2010-07-22 23:26:37 +00:00
|
|
|
|
|
|
|
|
|
if ( this.length ) {
|
|
|
|
|
var elem = $( this[ 0 ] ), position, value;
|
|
|
|
|
while ( elem.length && elem[ 0 ] !== document ) {
|
2010-01-29 18:38:21 +00:00
|
|
|
|
// Ignore z-index if position is set to a value where z-index is ignored by the browser
|
|
|
|
|
// This makes behavior of this function consistent across browsers
|
|
|
|
|
// WebKit always returns auto if the element is positioned
|
2010-07-22 23:26:37 +00:00
|
|
|
|
position = elem.css( "position" );
|
|
|
|
|
if ( position === "absolute" || position === "relative" || position === "fixed" ) {
|
2010-01-29 18:38:21 +00:00
|
|
|
|
// IE returns 0 when zIndex is not specified
|
|
|
|
|
// other browsers return a string
|
|
|
|
|
// we ignore the case of nested elements with an explicit value of 0
|
|
|
|
|
// <div style="z-index: -10;"><div style="z-index: 0;"></div></div>
|
2010-07-22 23:26:37 +00:00
|
|
|
|
value = parseInt( elem.css( "zIndex" ) );
|
|
|
|
|
if ( !isNaN( value ) && value != 0 ) {
|
2010-01-29 18:38:21 +00:00
|
|
|
|
return value;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
elem = elem.parent();
|
2009-08-05 13:30:55 +00:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return 0;
|
2008-09-22 20:52:48 +00:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
2010-07-22 02:17:52 +00:00
|
|
|
|
$.each( [ "Width", "Height" ], function( i, name ) {
|
|
|
|
|
var side = name === "Width" ? [ "Left", "Right" ] : [ "Top", "Bottom" ],
|
|
|
|
|
type = name.toLowerCase(),
|
|
|
|
|
orig = {
|
|
|
|
|
innerWidth: $.fn.innerWidth,
|
|
|
|
|
innerHeight: $.fn.innerHeight,
|
|
|
|
|
outerWidth: $.fn.outerWidth,
|
|
|
|
|
outerHeight: $.fn.outerHeight
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
function reduce( elem, size, border, margin ) {
|
|
|
|
|
$.each( side, function() {
|
2010-07-22 23:26:37 +00:00
|
|
|
|
size -= parseFloat( $.curCSS( elem, "padding" + this, true) ) || 0;
|
2010-07-22 02:17:52 +00:00
|
|
|
|
if ( border ) {
|
2010-07-22 23:26:37 +00:00
|
|
|
|
size -= parseFloat( $.curCSS( elem, "border" + this + "Width", true) ) || 0;
|
2010-07-22 02:17:52 +00:00
|
|
|
|
}
|
|
|
|
|
if ( margin ) {
|
2010-07-22 23:26:37 +00:00
|
|
|
|
size -= parseFloat( $.curCSS( elem, "margin" + this, true) ) || 0;
|
2010-07-22 02:17:52 +00:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
return size;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$.fn[ "inner" + name ] = function( size ) {
|
|
|
|
|
if ( size === undefined ) {
|
|
|
|
|
return orig[ "inner" + name ].call( this );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return this.each(function() {
|
|
|
|
|
$.style( this, type, reduce( this, size ) + "px" );
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
$.fn[ "outer" + name] = function( size, margin ) {
|
|
|
|
|
if ( typeof size !== "number" ) {
|
|
|
|
|
return orig[ "outer" + name ].call( this, size );
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return this.each(function() {
|
|
|
|
|
$.style( this, type, reduce( this, size, true, margin ) + "px" );
|
|
|
|
|
});
|
|
|
|
|
};
|
|
|
|
|
});
|
2008-11-03 14:23:13 +00:00
|
|
|
|
|
|
|
|
|
//Additional selectors
|
2010-07-22 14:33:42 +00:00
|
|
|
|
function visible( element ) {
|
2010-07-22 23:26:37 +00:00
|
|
|
|
return !$( element ).parents().andSelf().filter(function() {
|
2010-07-22 14:33:42 +00:00
|
|
|
|
return $.curCSS( this, "visibility" ) === "hidden" ||
|
|
|
|
|
$.expr.filters.hidden( this );
|
|
|
|
|
}).length;
|
|
|
|
|
}
|
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
$.extend( $.expr[ ":" ], {
|
|
|
|
|
data: function( elem, i, match ) {
|
|
|
|
|
return !!$.data( elem, match[ 3 ] );
|
2008-11-03 14:23:13 +00:00
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
focusable: function( element ) {
|
2009-01-21 03:25:02 +00:00
|
|
|
|
var nodeName = element.nodeName.toLowerCase(),
|
2010-07-22 23:26:37 +00:00
|
|
|
|
tabIndex = $.attr( element, "tabindex" );
|
2010-07-22 14:33:42 +00:00
|
|
|
|
if ( "area" === nodeName ) {
|
|
|
|
|
var map = element.parentNode,
|
|
|
|
|
mapName = map.name,
|
|
|
|
|
img;
|
|
|
|
|
if ( !element.href || !mapName || map.nodeName.toLowerCase() !== "map" ) {
|
|
|
|
|
return false;
|
|
|
|
|
}
|
|
|
|
|
img = $( "img[usemap=#" + mapName + "]" )[0];
|
|
|
|
|
return !!img && visible( img );
|
|
|
|
|
}
|
2010-07-22 23:26:37 +00:00
|
|
|
|
return ( /input|select|textarea|button|object/.test( nodeName )
|
2009-01-21 03:25:02 +00:00
|
|
|
|
? !element.disabled
|
2010-07-22 23:26:37 +00:00
|
|
|
|
: "a" == nodeName
|
|
|
|
|
? element.href || !isNaN( tabIndex )
|
|
|
|
|
: !isNaN( tabIndex ))
|
2009-01-21 03:25:02 +00:00
|
|
|
|
// the element and all of its ancestors must be visible
|
2010-07-22 14:33:42 +00:00
|
|
|
|
&& visible( element );
|
2009-01-21 03:25:02 +00:00
|
|
|
|
},
|
2008-11-18 02:55:25 +00:00
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
tabbable: function( element ) {
|
|
|
|
|
var tabIndex = $.attr( element, "tabindex" );
|
|
|
|
|
return ( isNaN( tabIndex ) || tabIndex >= 0 ) && $( element ).is( ":focusable" );
|
2008-11-03 14:23:13 +00:00
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
2010-07-22 23:26:37 +00:00
|
|
|
|
})( jQuery );
|