Вход Регистрация
Файл: ui/js/jquery-ui-1.10.0.custom.js
Строк: 5553
<?php
/*! jQuery UI - v1.10.0 - 2013-01-29
* http://jqueryui.com
* Includes: jquery.ui.core.js, jquery.ui.widget.js, jquery.ui.mouse.js, jquery.ui.draggable.js, jquery.ui.droppable.js, jquery.ui.sortable.js, jquery.ui.slider.js
* Copyright (c) 2013 jQuery Foundation and other contributors Licensed MIT */

(function( $, undefined ) {

var 
uuid 0,
    
runiqueId = /^ui-id-d+$/;

// prevent duplicate loading
// this is only a problem because we proxy existing functions
// and we don't want to double proxy them
$.ui = $.ui || {};
if ( $.
ui.version ) {
    return;
}

$.
extend( $.ui, {
    
version"1.10.0",

    
keyCode: {
        
BACKSPACE8,
        
COMMA188,
        
DELETE46,
        
DOWN40,
        
END35,
        
ENTER13,
        
ESCAPE27,
        
HOME36,
        
LEFT37,
        
NUMPAD_ADD107,
        
NUMPAD_DECIMAL110,
        
NUMPAD_DIVIDE111,
        
NUMPAD_ENTER108,
        
NUMPAD_MULTIPLY106,
        
NUMPAD_SUBTRACT109,
        
PAGE_DOWN34,
        
PAGE_UP33,
        
PERIOD190,
        
RIGHT39,
        
SPACE32,
        
TAB9,
        
UP38
    
}
});

// plugins
$.fn.extend({
    
_focus: $.fn.focus,
    
focus: function( delay, fn ) {
        return 
typeof delay === "number" ?
            
this.each(function() {
                var 
elem this;
                
setTimeout(function() {
                    $( 
elem ).focus();
                    if ( fn ) {
                        fn.
callelem );
                    }
                }, 
delay );
            }) :
            
this._focus.applythisarguments );
    },

    
scrollParent: function() {
        var 
scrollParent;
        if (($.
ui.ie && (/(static|relative)/).test(this.css("position"))) || (/absolute/).test(this.css("position"))) {
            
scrollParent this.parents().filter(function() {
                return (/(
relative|absolute|fixed)/).test($.css(this,"position")) && (/(auto|scroll)/).test($.css(this,"overflow")+$.css(this,"overflow-y")+$.css(this,"overflow-x"));
            }).
eq(0);
        } else {
            
scrollParent this.parents().filter(function() {
                return (/(
auto|scroll)/).test($.css(this,"overflow")+$.css(this,"overflow-y")+$.css(this,"overflow-x"));
            }).
eq(0);
        }

        return (/
fixed/).test(this.css("position")) || !scrollParent.length ? $(document) : scrollParent;
    },

    
zIndex: function( zIndex ) {
        if ( 
zIndex !== undefined ) {
            return 
this.css"zIndex"zIndex );
        }

        if ( 
this.length ) {
            var 
elem = $( this] ), positionvalue;
            while ( 
elem.length && elem] !== document ) {
                
// 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
                
position elem.css"position" );
                if ( 
position === "absolute" || position === "relative" || position === "fixed" ) {
                    
// 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>
                    
value parseIntelem.css"zIndex" ), 10 );
                    if ( !
isNaNvalue ) && value !== ) {
                        return 
value;
                    }
                }
                
elem elem.parent();
            }
        }

        return 
0;
    },

    
uniqueId: function() {
        return 
this.each(function() {
            if ( !
this.id ) {
                
this.id "ui-id-" + (++uuid);
            }
        });
    },

    
removeUniqueId: function() {
        return 
this.each(function() {
            if ( 
runiqueId.testthis.id ) ) {
                $( 
this ).removeAttr"id" );
            }
        });
    }
});

// selectors
function focusableelementisTabIndexNotNaN ) {
    var 
mapmapNameimg,
        
nodeName element.nodeName.toLowerCase();
    if ( 
"area" === nodeName ) {
        
map element.parentNode;
        
mapName map.name;
        if ( !
element.href || !mapName || map.nodeName.toLowerCase() !== "map" ) {
            return 
false;
        }
        
img = $( "img[usemap=#" mapName "]" )[0];
        return !!
img && visibleimg );
    }
    return ( /
input|select|textarea|button|object/.testnodeName ) ?
        !
element.disabled :
        
"a" === nodeName ?
            
element.href || isTabIndexNotNaN :
            
isTabIndexNotNaN) &&
        
// the element and all of its ancestors must be visible
        
visibleelement );
}

function 
visibleelement ) {
    return $.
expr.filters.visibleelement ) &&
        !$( 
element ).parents().addBack().filter(function() {
            return $.
cssthis"visibility" ) === "hidden";
        }).
length;
}

$.
extend( $.expr":" ], {
    
data: $.expr.createPseudo ?
        $.
expr.createPseudo(function( dataName ) {
            return function( 
elem ) {
                return !!$.
dataelemdataName );
            };
        }) :
        
// support: jQuery <1.8
        
function( elemimatch ) {
            return !!$.
dataelemmatch] );
        },

    
focusable: function( element ) {
        return 
focusableelement, !isNaN( $.attrelement"tabindex" ) ) );
    },

    
tabbable: function( element ) {
        var 
tabIndex = $.attrelement"tabindex" ),
            
isTabIndexNaN isNaNtabIndex );
        return ( 
isTabIndexNaN || tabIndex >= ) && focusableelement, !isTabIndexNaN );
    }
});

// support: jQuery <1.8
if ( !$( "<a>" ).outerWidth).jquery ) {
    $.
each( [ "Width""Height" ], function( iname ) {
        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 
reduceelemsizebordermargin ) {
            $.
eachside, function() {
                
size -= parseFloat( $.csselem"padding" this ) ) || 0;
                if ( 
border ) {
                    
size -= parseFloat( $.csselem"border" this "Width" ) ) || 0;
                }
                if ( 
margin ) {
                    
size -= parseFloat( $.csselem"margin" this ) ) || 0;
                }
            });
            return 
size;
        }

        $.fn[ 
"inner" name ] = function( size ) {
            if ( 
size === undefined ) {
                return 
orig"inner" name ].callthis );
            }

            return 
this.each(function() {
                $( 
this ).csstypereducethissize ) + "px" );
            });
        };

        $.fn[ 
"outer" name] = function( sizemargin ) {
            if ( 
typeof size !== "number" ) {
                return 
orig"outer" name ].callthissize );
            }

            return 
this.each(function() {
                $( 
this).csstypereducethissizetruemargin ) + "px" );
            });
        };
    });
}

// support: jQuery <1.8
if ( !$.fn.addBack ) {
    $.fn.
addBack = function( selector ) {
        return 
this.addselector == null ?
            
this.prevObject this.prevObject.filterselector )
        );
    };
}

// support: jQuery 1.6.1, 1.6.2 (http://bugs.jquery.com/ticket/9413)
if ( $( "<a>" ).data"a-b""a" ).removeData"a-b" ).data"a-b" ) ) {
    $.fn.
removeData = (function( removeData ) {
        return function( 
key ) {
            if ( 
arguments.length ) {
                return 
removeData.callthis, $.camelCasekey ) );
            } else {
                return 
removeData.callthis );
            }
        };
    })( $.fn.
removeData );
}





// deprecated
$.ui.ie = !!/msie [w.]+/.execnavigator.userAgent.toLowerCase() );

$.
support.selectstart "onselectstart" in document.createElement"div" );
$.fn.
extend({
    
disableSelection: function() {
        return 
this.bind( ( $.support.selectstart "selectstart" "mousedown" ) +
            
".ui-disableSelection", function( event ) {
                
event.preventDefault();
            });
    },

    
enableSelection: function() {
        return 
this.unbind".ui-disableSelection" );
    }
});

$.
extend( $.ui, {
    
// $.ui.plugin is deprecated.  Use the proxy pattern instead.
    
plugin: {
        
add: function( moduleoptionset ) {
            var 
i,
                
proto = $.uimodule ].prototype;
            for ( 
i in set ) {
                
proto.plugins] = proto.plugins] || [];
                
proto.plugins].push( [ optionset] ] );
            }
        },
        
call: function( instancenameargs ) {
            var 
i,
                
set instance.pluginsname ];
            if ( !
set || !instance.element].parentNode || instance.element].parentNode.nodeType === 11 ) {
                return;
            }

            for ( 
0set.lengthi++ ) {
                if ( 
instance.optionsset][ ] ] ) {
                    
set][ ].applyinstance.elementargs );
                }
            }
        }
    },

    
// only used by resizable
    
hasScroll: function( el) {

        
//If overflow is hidden, the element might have extra content, but the user wants to hide it
        
if ( $( el ).css"overflow" ) === "hidden") {
            return 
false;
        }

        var 
scroll = ( && === "left" ) ? "scrollLeft" "scrollTop",
            
has false;

        if ( 
elscroll ] > ) {
            return 
true;
        }

        
// 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
        
elscroll ] = 1;
        
has = ( elscroll ] > );
        
elscroll ] = 0;
        return 
has;
    }
});

})( 
jQuery );
(function( $, 
undefined ) {

var 
uuid 0,
    
slice = Array.prototype.slice,
    
_cleanData = $.cleanData;
$.
cleanData = function( elems ) {
    for ( var 
0elem; (elem elems[i]) != nulli++ ) {
        try {
            $( 
elem ).triggerHandler"remove" );
        
// http://bugs.jquery.com/ticket/8235
        
} catch( ) {}
    }
    
_cleanDataelems );
};

$.
widget = function( namebaseprototype ) {
    var 
fullNameexistingConstructorconstructorbasePrototype,
        
// proxiedPrototype allows the provided prototype to remain unmodified
        // so that it can be used as a mixin for multiple widgets (#8876)
        
proxiedPrototype = {},
        namespace = 
name.split"." )[ ];

    
name name.split"." )[ ];
    
fullName = namespace + "-" name;

    if ( !
prototype ) {
        
prototype base;
        
base = $.Widget;
    }

    
// create selector for plugin
    
$.expr":" ][ fullName.toLowerCase() ] = function( elem ) {
        return !!$.
dataelemfullName );
    };

    $[ namespace ] = $[ namespace ] || {};
    
existingConstructor = $[ namespace ][ name ];
    
constructor = $[ namespace ][ name ] = function( optionselement ) {
        
// allow instantiation without "new" keyword
        
if ( !this._createWidget ) {
            return new 
constructoroptionselement );
        }

        
// allow instantiation without initializing for simple inheritance
        // must use "new" keyword (the code above always passes args)
        
if ( arguments.length ) {
            
this._createWidgetoptionselement );
        }
    };
    
// extend with the existing constructor to carry over any static properties
    
$.extendconstructorexistingConstructor, {
        
versionprototype.version,
        
// copy the object used to create the prototype in case we need to
        // redefine the widget later
        
_proto: $.extend( {}, prototype ),
        
// track widgets that inherit from this widget in case this widget is
        // redefined after a widget inherits from it
        
_childConstructors: []
    });

    
basePrototype = new base();
    
// we need to make the options hash a property directly on the new instance
    // otherwise we'll modify the options hash on the prototype that we're
    // inheriting from
    
basePrototype.options = $.widget.extend( {}, basePrototype.options );
    $.
eachprototype, function( propvalue ) {
        if ( !$.
isFunctionvalue ) ) {
            
proxiedPrototypeprop ] = value;
            return;
        }
        
proxiedPrototypeprop ] = (function() {
            var 
_super = function() {
                    return 
base.prototypeprop ].applythisarguments );
                },
                
_superApply = function( args ) {
                    return 
base.prototypeprop ].applythisargs );
                };
            return function() {
                var 
__super this._super,
                    
__superApply this._superApply,
                    
returnValue;

                
this._super _super;
                
this._superApply _superApply;

                
returnValue value.applythisarguments );

                
this._super __super;
                
this._superApply __superApply;

                return 
returnValue;
            };
        })();
    });
    
constructor.prototype = $.widget.extendbasePrototype, {
        
// TODO: remove support for widgetEventPrefix
        // always use the name + a colon as the prefix, e.g., draggable:start
        // don't prefix for widgets that aren't DOM-based
        
widgetEventPrefixexistingConstructor basePrototype.widgetEventPrefix name
    
}, proxiedPrototype, {
        
constructorconstructor,
        namespace: namespace,
        
widgetNamename,
        
widgetFullNamefullName
    
});

    
// If this widget is being redefined then we need to find all widgets that
    // are inheriting from it and redefine all of them so that they inherit from
    // the new version of this widget. We're essentially trying to replace one
    // level in the prototype chain.
    
if ( existingConstructor ) {
        $.
eachexistingConstructor._childConstructors, function( ichild ) {
            var 
childPrototype child.prototype;

            
// redefine the child widget using the same prototype that was
            // originally used, but inherit from the new version of the base
            
$.widgetchildPrototype.namespace + "." childPrototype.widgetNameconstructorchild._proto );
        });
        
// remove the list of existing child constructors from the old constructor
        // so the old child constructors can be garbage collected
        
delete existingConstructor._childConstructors;
    } else {
        
base._childConstructors.pushconstructor );
    }

    $.
widget.bridgenameconstructor );
};

$.
widget.extend = function( target ) {
    var 
input slice.callarguments),
        
inputIndex 0,
        
inputLength input.length,
        
key,
        
value;
    for ( ; 
inputIndex inputLengthinputIndex++ ) {
        for ( 
key in inputinputIndex ] ) {
            
value inputinputIndex ][ key ];
            if ( 
inputinputIndex ].hasOwnPropertykey ) && value !== undefined ) {
                
// Clone objects
                
if ( $.isPlainObjectvalue ) ) {
                    
targetkey ] = $.isPlainObjecttargetkey ] ) ?
                        $.
widget.extend( {}, targetkey ], value ) :
                        
// Don't extend strings, arrays, etc. with objects
                        
$.widget.extend( {}, value );
                
// Copy everything else by reference
                
} else {
                    
targetkey ] = value;
                }
            }
        }
    }
    return 
target;
};

$.
widget.bridge = function( nameobject ) {
    var 
fullName object.prototype.widgetFullName || name;
    $.fn[ 
name ] = function( options ) {
        var 
isMethodCall typeof options === "string",
            
args slice.callarguments),
            
returnValue this;

        
// allow multiple hashes to be passed on init
        
options = !isMethodCall && args.length ?
            $.
widget.extend.applynull, [ options ].concat(args) ) :
            
options;

        if ( 
isMethodCall ) {
            
this.each(function() {
                var 
methodValue,
                    
instance = $.datathisfullName );
                if ( !
instance ) {
                    return $.
error"cannot call methods on " name " prior to initialization; " +
                        
"attempted to call method '" options "'" );
                }
                if ( !$.
isFunctioninstance[options] ) || options.charAt) === "_" ) {
                    return $.
error"no such method '" options "' for " name " widget instance" );
                }
                
methodValue instanceoptions ].applyinstanceargs );
                if ( 
methodValue !== instance && methodValue !== undefined ) {
                    
returnValue methodValue && methodValue.jquery ?
                        
returnValue.pushStackmethodValue.get() ) :
                        
methodValue;
                    return 
false;
                }
            });
        } else {
            
this.each(function() {
                var 
instance = $.datathisfullName );
                if ( 
instance ) {
                    
instance.optionoptions || {} )._init();
                } else {
                    $.
datathisfullName, new objectoptionsthis ) );
                }
            });
        }

        return 
returnValue;
    };
};

$.
Widget = function( /* options, element */ ) {};
$.
Widget._childConstructors = [];

$.
Widget.prototype = {
    
widgetName"widget",
    
widgetEventPrefix"",
    
defaultElement"<div>",
    
options: {
        
disabledfalse,

        
// callbacks
        
createnull
    
},
    
_createWidget: function( optionselement ) {
        
element = $( element || this.defaultElement || this )[ ];
        
this.element = $( element );
        
this.uuid uuid++;
        
this.eventNamespace "." this.widgetName this.uuid;
        
this.options = $.widget.extend( {},
            
this.options,
            
this._getCreateOptions(),
            
options );

        
this.bindings = $();
        
this.hoverable = $();
        
this.focusable = $();

        if ( 
element !== this ) {
            $.
dataelementthis.widgetFullNamethis );
            
this._ontruethis.element, {
                
remove: function( event ) {
                    if ( 
event.target === element ) {
                        
this.destroy();
                    }
                }
            });
            
this.document = $( element.style ?
                
// element within the document
                
element.ownerDocument :
                
// element is window or document
                
element.document || element );
            
this.window = $( this.document[0].defaultView || this.document[0].parentWindow );
        }

        
this._create();
        
this._trigger"create"nullthis._getCreateEventData() );
        
this._init();
    },
    
_getCreateOptions: $.noop,
    
_getCreateEventData: $.noop,
    
_create: $.noop,
    
_init: $.noop,

    
destroy: function() {
        
this._destroy();
        
// we can probably remove the unbind calls in 2.0
        // all event bindings should go through this._on()
        
this.element
            
.unbindthis.eventNamespace )
            
// 1.9 BC for #7810
            // TODO remove dual storage
            
.removeDatathis.widgetName )
            .
removeDatathis.widgetFullName )
            
// support: jquery <1.6.3
            // http://bugs.jquery.com/ticket/9413
            
.removeData( $.camelCasethis.widgetFullName ) );
        
this.widget()
            .
unbindthis.eventNamespace )
            .
removeAttr"aria-disabled" )
            .
removeClass(
                
this.widgetFullName "-disabled " +
                
"ui-state-disabled" );

        
// clean up events and states
        
this.bindings.unbindthis.eventNamespace );
        
this.hoverable.removeClass"ui-state-hover" );
        
this.focusable.removeClass"ui-state-focus" );
    },
    
_destroy: $.noop,

    
widget: function() {
        return 
this.element;
    },

    
option: function( keyvalue ) {
        var 
options key,
            
parts,
            
curOption,
            
i;

        if ( 
arguments.length === ) {
            
// don't return a reference to the internal hash
            
return $.widget.extend( {}, this.options );
        }

        if ( 
typeof key === "string" ) {
            
// handle nested keys, e.g., "foo.bar" => { foo: { bar: ___ } }
            
options = {};
            
parts key.split"." );
            
key parts.shift();
            if ( 
parts.length ) {
                
curOption optionskey ] = $.widget.extend( {}, this.optionskey ] );
                for ( 
0parts.length 1i++ ) {
                    
curOptionparts] ] = curOptionparts] ] || {};
                    
curOption curOptionparts] ];
                }
                
key parts.pop();
                if ( 
value === undefined ) {
                    return 
curOptionkey ] === undefined null curOptionkey ];
                }
                
curOptionkey ] = value;
            } else {
                if ( 
value === undefined ) {
                    return 
this.optionskey ] === undefined null this.optionskey ];
                }
                
optionskey ] = value;
            }
        }

        
this._setOptionsoptions );

        return 
this;
    },
    
_setOptions: function( options ) {
        var 
key;

        for ( 
key in options ) {
            
this._setOptionkeyoptionskey ] );
        }

        return 
this;
    },
    
_setOption: function( keyvalue ) {
        
this.optionskey ] = value;

        if ( 
key === "disabled" ) {
            
this.widget()
                .
toggleClassthis.widgetFullName "-disabled ui-state-disabled", !!value )
                .
attr"aria-disabled"value );
            
this.hoverable.removeClass"ui-state-hover" );
            
this.focusable.removeClass"ui-state-focus" );
        }

        return 
this;
    },

    
enable: function() {
        return 
this._setOption"disabled"false );
    },
    
disable: function() {
        return 
this._setOption"disabled"true );
    },

    
_on: function( suppressDisabledCheckelementhandlers ) {
        var 
delegateElement,
            
instance this;

        
// no suppressDisabledCheck flag, shuffle arguments
        
if ( typeof suppressDisabledCheck !== "boolean" ) {
            
handlers element;
            
element suppressDisabledCheck;
            
suppressDisabledCheck false;
        }

        
// no element argument, shuffle and use this.element
        
if ( !handlers ) {
            
handlers element;
            
element this.element;
            
delegateElement this.widget();
        } else {
            
// accept selectors, DOM elements
            
element delegateElement = $( element );
            
this.bindings this.bindings.addelement );
        }

        $.
eachhandlers, function( eventhandler ) {
            function 
handlerProxy() {
                
// allow widgets to customize the disabled handling
                // - disabled as an array instead of boolean
                // - disabled class as method for disabling individual parts
                
if ( !suppressDisabledCheck &&
                        ( 
instance.options.disabled === true ||
                            $( 
this ).hasClass"ui-state-disabled" ) ) ) {
                    return;
                }
                return ( 
typeof handler === "string" instancehandler ] : handler )
                    .
applyinstancearguments );
            }

            
// copy the guid so direct unbinding works
            
if ( typeof handler !== "string" ) {
                
handlerProxy.guid handler.guid =
                    
handler.guid || handlerProxy.guid || $.guid++;
            }

            var 
match event.match( /^(w+)s*(.*)$/ ),
                
eventName match[1] + instance.eventNamespace,
                
selector match[2];
            if ( 
selector ) {
                
delegateElement.delegateselectoreventNamehandlerProxy );
            } else {
                
element.bindeventNamehandlerProxy );
            }
        });
    },

    
_off: function( elementeventName ) {
        
eventName = (eventName || "").split" " ).jointhis.eventNamespace " " ) + this.eventNamespace;
        
element.unbindeventName ).undelegateeventName );
    },

    
_delay: function( handlerdelay ) {
        function 
handlerProxy() {
            return ( 
typeof handler === "string" instancehandler ] : handler )
                .
applyinstancearguments );
        }
        var 
instance this;
        return 
setTimeouthandlerProxydelay || );
    },

    
_hoverable: function( element ) {
        
this.hoverable this.hoverable.addelement );
        
this._onelement, {
            
mouseenter: function( event ) {
                $( 
event.currentTarget ).addClass"ui-state-hover" );
            },
            
mouseleave: function( event ) {
                $( 
event.currentTarget ).removeClass"ui-state-hover" );
            }
        });
    },

    
_focusable: function( element ) {
        
this.focusable this.focusable.addelement );
        
this._onelement, {
            
focusin: function( event ) {
                $( 
event.currentTarget ).addClass"ui-state-focus" );
            },
            
focusout: function( event ) {
                $( 
event.currentTarget ).removeClass"ui-state-focus" );
            }
        });
    },

    
_trigger: function( typeeventdata ) {
        var 
proporig,
            
callback this.optionstype ];

        
data data || {};
        
event = $.Eventevent );
        
event.type = ( type === this.widgetEventPrefix ?
            
type :
            
this.widgetEventPrefix type ).toLowerCase();
        
// the original event may come from any element
        // so we need to reset the target on the new event
        
event.target this.element];

        
// copy original event properties over to the new event
        
orig event.originalEvent;
        if ( 
orig ) {
            for ( 
prop in orig ) {
                if ( !( 
prop in event ) ) {
                    
eventprop ] = origprop ];
                }
            }
        }

        
this.element.triggereventdata );
        return !( $.
isFunctioncallback ) &&
            
callback.applythis.element[0], [ event ].concatdata ) ) === false ||
            
event.isDefaultPrevented() );
    }
};

$.
each( { show"fadeIn"hide"fadeOut" }, function( methoddefaultEffect ) {
    $.
Widget.prototype"_" method ] = function( elementoptionscallback ) {
        if ( 
typeof options === "string" ) {
            
options = { effectoptions };
        }
        var 
hasOptions,
            
effectName = !options ?
                
method :
                
options === true || typeof options === "number" ?
                    
defaultEffect :
                    
options.effect || defaultEffect;
        
options options || {};
        if ( 
typeof options === "number" ) {
            
options = { durationoptions };
        }
        
hasOptions = !$.isEmptyObjectoptions );
        
options.complete callback;
        if ( 
options.delay ) {
            
element.delayoptions.delay );
        }
        if ( 
hasOptions && $.effects && $.effects.effecteffectName ] ) {
            
elementmethod ]( options );
        } else if ( 
effectName !== method && elementeffectName ] ) {
            
elementeffectName ]( options.durationoptions.easingcallback );
        } else {
            
element.queue(function( next ) {
                $( 
this )[ method ]();
                if ( 
callback ) {
                    
callback.callelement] );
                }
                
next();
            });
        }
    };
});

})( 
jQuery );
(function( $, 
undefined ) {

var 
mouseHandled false;
$( 
document ).mouseup( function() {
    
mouseHandled false;
});

$.
widget("ui.mouse", {
    
version"1.10.0",
    
options: {
        
cancel"input,textarea,button,select,option",
        
distance1,
        
delay0
    
},
    
_mouseInit: function() {
        var 
that this;

        
this.element
            
.bind("mousedown."+this.widgetName, function(event) {
                return 
that._mouseDown(event);
            })
            .
bind("click."+this.widgetName, function(event) {
                if (
true === $.data(event.targetthat.widgetName ".preventClickEvent")) {
                    $.
removeData(event.targetthat.widgetName ".preventClickEvent");
                    
event.stopImmediatePropagation();
                    return 
false;
                }
            });

        
this.started false;
    },

    
// TODO: make sure destroying one instance of mouse doesn't mess with
    // other instances of mouse
    
_mouseDestroy: function() {
        
this.element.unbind("."+this.widgetName);
        if ( 
this._mouseMoveDelegate ) {
            $(
document)
                .
unbind("mousemove."+this.widgetNamethis._mouseMoveDelegate)
                .
unbind("mouseup."+this.widgetNamethis._mouseUpDelegate);
        }
    },

    
_mouseDown: function(event) {
        
// don't let more than one widget handle mouseStart
        
if( mouseHandled ) { return; }

        
// we may have missed mouseup (out of window)
        
(this._mouseStarted && this._mouseUp(event));

        
this._mouseDownEvent event;

        var 
that this,
            
btnIsLeft = (event.which === 1),
            
// event.target.nodeName works around a bug in IE 8 with
            // disabled inputs (#7620)
            
elIsCancel = (typeof this.options.cancel === "string" && event.target.nodeName ? $(event.target).closest(this.options.cancel).length false);
        if (!
btnIsLeft || elIsCancel || !this._mouseCapture(event)) {
            return 
true;
        }

        
this.mouseDelayMet = !this.options.delay;
        if (!
this.mouseDelayMet) {
            
this._mouseDelayTimer setTimeout(function() {
                
that.mouseDelayMet true;
            }, 
this.options.delay);
        }

        if (
this._mouseDistanceMet(event) && this._mouseDelayMet(event)) {
            
this._mouseStarted = (this._mouseStart(event) !== false);
            if (!
this._mouseStarted) {
                
event.preventDefault();
                return 
true;
            }
        }

        
// Click event may never have fired (Gecko & Opera)
        
if (true === $.data(event.targetthis.widgetName ".preventClickEvent")) {
            $.
removeData(event.targetthis.widgetName ".preventClickEvent");
        }

        
// these delegates are required to keep context
        
this._mouseMoveDelegate = function(event) {
            return 
that._mouseMove(event);
        };
        
this._mouseUpDelegate = function(event) {
            return 
that._mouseUp(event);
        };
        $(
document)
            .
bind("mousemove."+this.widgetNamethis._mouseMoveDelegate)
            .
bind("mouseup."+this.widgetNamethis._mouseUpDelegate);

        
event.preventDefault();

        
mouseHandled true;
        return 
true;
    },

    
_mouseMove: function(event) {
        
// IE mouseup check - mouseup happened when mouse was out of window
        
if ($.ui.ie && ( !document.documentMode || document.documentMode ) && !event.button) {
            return 
this._mouseUp(event);
        }

        if (
this._mouseStarted) {
            
this._mouseDrag(event);
            return 
event.preventDefault();
        }

        if (
this._mouseDistanceMet(event) && this._mouseDelayMet(event)) {
            
this._mouseStarted =
                (
this._mouseStart(this._mouseDownEventevent) !== false);
            (
this._mouseStarted this._mouseDrag(event) : this._mouseUp(event));
        }

        return !
this._mouseStarted;
    },

    
_mouseUp: function(event) {
        $(
document)
            .
unbind("mousemove."+this.widgetNamethis._mouseMoveDelegate)
            .
unbind("mouseup."+this.widgetNamethis._mouseUpDelegate);

        if (
this._mouseStarted) {
            
this._mouseStarted false;

            if (
event.target === this._mouseDownEvent.target) {
                $.
data(event.targetthis.widgetName ".preventClickEvent"true);
            }

            
this._mouseStop(event);
        }

        return 
false;
    },

    
_mouseDistanceMet: function(event) {
        return (
Math.max(
                
Math.abs(this._mouseDownEvent.pageX event.pageX),
                
Math.abs(this._mouseDownEvent.pageY event.pageY)
            ) >= 
this.options.distance
        
);
    },

    
_mouseDelayMet: function(/* event */) {
        return 
this.mouseDelayMet;
    },

    
// These are placeholder methods, to be overriden by extending plugin
    
_mouseStart: function(/* event */) {},
    
_mouseDrag: function(/* event */) {},
    
_mouseStop: function(/* event */) {},
    
_mouseCapture: function(/* event */) { return true; }
});

})(
jQuery);
(function( $, 
undefined ) {

$.
widget("ui.draggable", $.ui.mouse, {
    
version"1.10.0",
    
widgetEventPrefix"drag",
    
options: {
        
addClassestrue,
        
appendTo"parent",
        
axisfalse,
        
connectToSortablefalse,
        
containmentfalse,
        
cursor"auto",
        
cursorAtfalse,
        
gridfalse,
        
handlefalse,
        
helper"original",
        
iframeFixfalse,
        
opacityfalse,
        
refreshPositionsfalse,
        
revertfalse,
        
revertDuration500,
        
scope"default",
        
scrolltrue,
        
scrollSensitivity20,
        
scrollSpeed20,
        
snapfalse,
        
snapMode"both",
        
snapTolerance20,
        
stackfalse,
        
zIndexfalse,

        
// callbacks
        
dragnull,
        
startnull,
        
stopnull
    
},
    
_create: function() {

        if (
this.options.helper === "original" && !(/^(?:r|a|f)/).test(this.element.css("position"))) {
            
this.element[0].style.position "relative";
        }
        if (
this.options.addClasses){
            
this.element.addClass("ui-draggable");
        }
        if (
this.options.disabled){
            
this.element.addClass("ui-draggable-disabled");
        }

        
this._mouseInit();

    },

    
_destroy: function() {
        
this.element.removeClass"ui-draggable ui-draggable-dragging ui-draggable-disabled" );
        
this._mouseDestroy();
    },

    
_mouseCapture: function(event) {

        var 
this.options;

        
// among others, prevent a drag on a resizable-handle
        
if (this.helper || o.disabled || $(event.target).closest(".ui-resizable-handle").length 0) {
            return 
false;
        }

        
//Quit if we're not on a valid handle
        
this.handle this._getHandle(event);
        if (!
this.handle) {
            return 
false;
        }

        $(
o.iframeFix === true "iframe" o.iframeFix).each(function() {
            $(
"<div class='ui-draggable-iframeFix' style='background: #fff;'></div>")
            .
css({
                
widththis.offsetWidth+"px"heightthis.offsetHeight+"px",
                
position"absolute"opacity"0.001"zIndex1000
            
})
            .
css($(this).offset())
            .
appendTo("body");
        });

        return 
true;

    },

    
_mouseStart: function(event) {

        var 
this.options;

        
//Create and append the visible helper
        
this.helper this._createHelper(event);

        
this.helper.addClass("ui-draggable-dragging");

        
//Cache the helper size
        
this._cacheHelperProportions();

        
//If ddmanager is used for droppables, set the global draggable
        
if($.ui.ddmanager) {
            $.
ui.ddmanager.current this;
        }

        
/*
         * - Position generation -
         * This block generates everything position related - it's the core of draggables.
         */

        //Cache the margins of the original element
        
this._cacheMargins();

        
//Store the helper's css position
        
this.cssPosition this.helper.css("position");
        
this.scrollParent this.helper.scrollParent();

        
//The element's absolute position on the page minus margins
        
this.offset this.positionAbs this.element.offset();
        
this.offset = {
            
topthis.offset.top this.margins.top,
            
leftthis.offset.left this.margins.left
        
};

        $.
extend(this.offset, {
            
click: { //Where the click happened, relative to the element
                
leftevent.pageX this.offset.left,
                
topevent.pageY this.offset.top
            
},
            
parentthis._getParentOffset(),
            
relativethis._getRelativeOffset() //This is a relative to absolute position minus the actual position calculation - only used for relative positioned helper
        
});

        
//Generate the original position
        
this.originalPosition this.position this._generatePosition(event);
        
this.originalPageX event.pageX;
        
this.originalPageY event.pageY;

        
//Adjust the mouse offset relative to the helper if "cursorAt" is supplied
        
(o.cursorAt && this._adjustOffsetFromHelper(o.cursorAt));

        
//Set a containment if given in the options
        
if(o.containment) {
            
this._setContainment();
        }

        
//Trigger event + callbacks
        
if(this._trigger("start"event) === false) {
            
this._clear();
            return 
false;
        }

        
//Recache the helper size
        
this._cacheHelperProportions();

        
//Prepare the droppable offsets
        
if ($.ui.ddmanager && !o.dropBehaviour) {
            $.
ui.ddmanager.prepareOffsets(thisevent);
        }


        
this._mouseDrag(eventtrue); //Execute the drag once - this causes the helper not to be visible before getting its correct position

        //If the ddmanager is used for droppables, inform the manager that dragging has started (see #5003)
        
if ( $.ui.ddmanager ) {
            $.
ui.ddmanager.dragStart(thisevent);
        }

        return 
true;
    },

    
_mouseDrag: function(eventnoPropagation) {

        
//Compute the helpers position
        
this.position this._generatePosition(event);
        
this.positionAbs this._convertPositionTo("absolute");

        
//Call plugins and callbacks and use the resulting position if something is returned
        
if (!noPropagation) {
            var 
ui this._uiHash();
            if(
this._trigger("drag"eventui) === false) {
                
this._mouseUp({});
                return 
false;
            }
            
this.position ui.position;
        }

        if(!
this.options.axis || this.options.axis !== "y") {
            
this.helper[0].style.left this.position.left+"px";
        }
        if(!
this.options.axis || this.options.axis !== "x") {
            
this.helper[0].style.top this.position.top+"px";
        }
        if($.
ui.ddmanager) {
            $.
ui.ddmanager.drag(thisevent);
        }

        return 
false;
    },

    
_mouseStop: function(event) {

        
//If we are using droppables, inform the manager about the drop
        
var element,
            
that this,
            
elementInDom false,
            
dropped false;
        if ($.
ui.ddmanager && !this.options.dropBehaviour) {
            
dropped = $.ui.ddmanager.drop(thisevent);
        }

        
//if a drop comes from outside (a sortable)
        
if(this.dropped) {
            
dropped this.dropped;
            
this.dropped false;
        }

        
//if the original element is no longer in the DOM don't bother to continue (see #8269)
        
element this.element[0];
        while ( 
element && (element element.parentNode) ) {
            if (
element === document ) {
                
elementInDom true;
            }
        }
        if ( !
elementInDom && this.options.helper === "original" ) {
            return 
false;
        }

        if((
this.options.revert === "invalid" && !dropped) || (this.options.revert === "valid" && dropped) || this.options.revert === true || ($.isFunction(this.options.revert) && this.options.revert.call(this.elementdropped))) {
            $(
this.helper).animate(this.originalPositionparseInt(this.options.revertDuration10), function() {
                if(
that._trigger("stop"event) !== false) {
                    
that._clear();
                }
            });
        } else {
            if(
this._trigger("stop"event) !== false) {
                
this._clear();
            }
        }

        return 
false;
    },

    
_mouseUp: function(event) {
        
//Remove frame helpers
        
$("div.ui-draggable-iframeFix").each(function() {
            
this.parentNode.removeChild(this);
        });

        
//If the ddmanager is used for droppables, inform the manager that dragging has stopped (see #5003)
        
if( $.ui.ddmanager ) {
            $.
ui.ddmanager.dragStop(thisevent);
        }

        return $.
ui.mouse.prototype._mouseUp.call(thisevent);
    },

    
cancel: function() {

        if(
this.helper.is(".ui-draggable-dragging")) {
            
this._mouseUp({});
        } else {
            
this._clear();
        }

        return 
this;

    },

    
_getHandle: function(event) {

        var 
handle = !this.options.handle || !$(this.options.handlethis.element).length true false;
        $(
this.options.handlethis.element)
            .
find("*")
            .
addBack()
            .
each(function() {
                if(
this === event.target) {
                    
handle true;
                }
            });

        return 
handle;

    },

    
_createHelper: function(event) {

        var 
this.options,
            
helper = $.isFunction(o.helper) ? $(o.helper.apply(this.element[0], [event])) : (o.helper === "clone" this.element.clone().removeAttr("id") : this.element);

        if(!
helper.parents("body").length) {
            
helper.appendTo((o.appendTo === "parent" this.element[0].parentNode o.appendTo));
        }

        if(
helper[0] !== this.element[0] && !(/(fixed|absolute)/).test(helper.css("position"))) {
            
helper.css("position""absolute");
        }

        return 
helper;

    },

    
_adjustOffsetFromHelper: function(obj) {
        if (
typeof obj === "string") {
            
obj obj.split(" ");
        }
        if ($.
isArray(obj)) {
            
obj = {left: +obj[0], top: +obj[1] || 0};
        }
        if (
"left" in obj) {
            
this.offset.click.left obj.left this.margins.left;
        }
        if (
"right" in obj) {
            
this.offset.click.left this.helperProportions.width obj.right this.margins.left;
        }
        if (
"top" in obj) {
            
this.offset.click.top obj.top this.margins.top;
        }
        if (
"bottom" in obj) {
            
this.offset.click.top this.helperProportions.height obj.bottom this.margins.top;
        }
    },

    
_getParentOffset: function() {

        
//Get the offsetParent and cache its position
        
this.offsetParent this.helper.offsetParent();
        var 
po this.offsetParent.offset();

        
// This is a special case where we need to modify a offset calculated on start, since the following happened:
        // 1. The position of the helper is absolute, so it's position is calculated based on the next positioned parent
        // 2. The actual offset parent is a child of the scroll parent, and the scroll parent isn't the document, which means that
        //    the scroll is included in the initial calculation of the offset of the parent, and never recalculated upon drag
        
if(this.cssPosition === "absolute" && this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) {
            
po.left += this.scrollParent.scrollLeft();
            
po.top += this.scrollParent.scrollTop();
        }

        
//This needs to be actually done for all browsers, since pageX/pageY includes this information
        //Ugly IE fix
        
if((this.offsetParent[0] === document.body) ||
            (
this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() === "html" && $.ui.ie)) {
            
po = { top0left};
        }

        return {
            
toppo.top + (parseInt(this.offsetParent.css("borderTopWidth"),10) || 0),
            
leftpo.left + (parseInt(this.offsetParent.css("borderLeftWidth"),10) || 0)
        };

    },

    
_getRelativeOffset: function() {

        if(
this.cssPosition === "relative") {
            var 
this.element.position();
            return {
                
topp.top - (parseInt(this.helper.css("top"),10) || 0) + this.scrollParent.scrollTop(),
                
leftp.left - (parseInt(this.helper.css("left"),10) || 0) + this.scrollParent.scrollLeft()
            };
        } else {
            return { 
top0left};
        }

    },

    
_cacheMargins: function() {
        
this.margins = {
            
left: (parseInt(this.element.css("marginLeft"),10) || 0),
            
top: (parseInt(this.element.css("marginTop"),10) || 0),
            
right: (parseInt(this.element.css("marginRight"),10) || 0),
            
bottom: (parseInt(this.element.css("marginBottom"),10) || 0)
        };
    },

    
_cacheHelperProportions: function() {
        
this.helperProportions = {
            
widththis.helper.outerWidth(),
            
heightthis.helper.outerHeight()
        };
    },

    
_setContainment: function() {

        var 
overcce,
            
this.options;

        if(
o.containment === "parent") {
            
o.containment this.helper[0].parentNode;
        }
        if(
o.containment === "document" || o.containment === "window") {
            
this.containment = [
                
o.containment === "document" : $(window).scrollLeft() - this.offset.relative.left this.offset.parent.left,
                
o.containment === "document" : $(window).scrollTop() - this.offset.relative.top this.offset.parent.top,
                (
o.containment === "document" : $(window).scrollLeft()) + $(o.containment === "document" document window).width() - this.helperProportions.width this.margins.left,
                (
o.containment === "document" : $(window).scrollTop()) + ($(o.containment === "document" document window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height this.margins.top
            
];
        }

        if(!(/^(
document|window|parent)$/).test(o.containment) && o.containment.constructor !== Array) {
            
= $(o.containment);
            
ce c[0];

            if(!
ce) {
                return;
            }

            
over = ($(ce).css("overflow") !== "hidden");

            
this.containment = [
                (
parseInt($(ce).css("borderLeftWidth"),10) || 0) + (parseInt($(ce).css("paddingLeft"),10) || 0),
                (
parseInt($(ce).css("borderTopWidth"),10) || 0) + (parseInt($(ce).css("paddingTop"),10) || 0),
                (
over Math.max(ce.scrollWidth,ce.offsetWidth) : ce.offsetWidth) - (parseInt($(ce).css("borderLeftWidth"),10) || 0) - (parseInt($(ce).css("paddingRight"),10) || 0) - this.helperProportions.width this.margins.left this.margins.right,
                (
over Math.max(ce.scrollHeight,ce.offsetHeight) : ce.offsetHeight) - (parseInt($(ce).css("borderTopWidth"),10) || 0) - (parseInt($(ce).css("paddingBottom"),10) || 0) - this.helperProportions.height this.margins.top  this.margins.bottom
            
];
            
this.relative_container c;

        } else if(
o.containment.constructor === Array) {
            
this.containment o.containment;
        }

    },

    
_convertPositionTo: function(dpos) {

        if(!
pos) {
            
pos this.position;
        }

        var 
mod === "absolute" : -1,
            
scroll this.cssPosition === "absolute" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent this.scrollParentscrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);

        return {
            
top: (
                
pos.top    +                                                                // The absolute mouse position
                
this.offset.relative.top mod +                                        // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.top mod -                                        // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode scroll.scrollTop() ) ) * mod)
            ),
            
left: (
                
pos.left +                                                                // The absolute mouse position
                
this.offset.relative.left mod +                                        // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.left mod    -                                        // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : scrollIsRootNode scroll.scrollLeft() ) * mod)
            )
        };

    },

    
_generatePosition: function(event) {

        var 
containmentcotopleft,
            
this.options,
            
scroll this.cssPosition === "absolute" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent this.scrollParent,
            
scrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName),
            
pageX event.pageX,
            
pageY event.pageY;

        
/*
         * - Position constraining -
         * Constrain the position to a mix of grid, containment.
         */

        
if(this.originalPosition) { //If we are not dragging yet, we won't check for options
            
if(this.containment) {
            if (
this.relative_container){
                
co this.relative_container.offset();
                
containment = [ this.containment[0] + co.left,
                    
this.containment[1] + co.top,
                    
this.containment[2] + co.left,
                    
this.containment[3] + co.top ];
            }
            else {
                
containment this.containment;
            }

                if(
event.pageX this.offset.click.left containment[0]) {
                    
pageX containment[0] + this.offset.click.left;
                }
                if(
event.pageY this.offset.click.top containment[1]) {
                    
pageY containment[1] + this.offset.click.top;
                }
                if(
event.pageX this.offset.click.left containment[2]) {
                    
pageX containment[2] + this.offset.click.left;
                }
                if(
event.pageY this.offset.click.top containment[3]) {
                    
pageY containment[3] + this.offset.click.top;
                }
            }

            if(
o.grid) {
                
//Check for grid elements set to 0 to prevent divide by 0 error causing invalid argument errors in IE (see ticket #6950)
                
top o.grid[1] ? this.originalPageY Math.round((pageY this.originalPageY) / o.grid[1]) * o.grid[1] : this.originalPageY;
                
pageY containment ? ((top this.offset.click.top >= containment[1] || top this.offset.click.top containment[3]) ? top : ((top this.offset.click.top >= containment[1]) ? top o.grid[1] : top o.grid[1])) : top;

                
left o.grid[0] ? this.originalPageX Math.round((pageX this.originalPageX) / o.grid[0]) * o.grid[0] : this.originalPageX;
                
pageX containment ? ((left this.offset.click.left >= containment[0] || left this.offset.click.left containment[2]) ? left : ((left this.offset.click.left >= containment[0]) ? left o.grid[0] : left o.grid[0])) : left;
            }

        }

        return {
            
top: (
                
pageY -                                                                    // The absolute mouse position
                
this.offset.click.top    -                                                // Click offset (relative to the element)
                
this.offset.relative.top -                                                // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.top +                                                // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode scroll.scrollTop() ) ))
            ),
            
left: (
                
pageX -                                                                    // The absolute mouse position
                
this.offset.click.left -                                                // Click offset (relative to the element)
                
this.offset.relative.left -                                                // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.left +                                                // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : scrollIsRootNode scroll.scrollLeft() ))
            )
        };

    },

    
_clear: function() {
        
this.helper.removeClass("ui-draggable-dragging");
        if(
this.helper[0] !== this.element[0] && !this.cancelHelperRemoval) {
            
this.helper.remove();
        }
        
this.helper null;
        
this.cancelHelperRemoval false;
    },

    
// From now on bulk stuff - mainly helpers

    
_trigger: function(typeeventui) {
        
ui ui || this._uiHash();
        $.
ui.plugin.call(thistype, [eventui]);
        
//The absolute position has to be recalculated after plugins
        
if(type === "drag") {
            
this.positionAbs this._convertPositionTo("absolute");
        }
        return $.
Widget.prototype._trigger.call(thistypeeventui);
    },

    
plugins: {},

    
_uiHash: function() {
        return {
            
helperthis.helper,
            
positionthis.position,
            
originalPositionthis.originalPosition,
            
offsetthis.positionAbs
        
};
    }

});

$.
ui.plugin.add("draggable""connectToSortable", {
    
start: function(eventui) {

        var 
inst = $(this).data("ui-draggable"), inst.options,
            
uiSortable = $.extend({}, ui, { iteminst.element });
        
inst.sortables = [];
        $(
o.connectToSortable).each(function() {
            var 
sortable = $.data(this"ui-sortable");
            if (
sortable && !sortable.options.disabled) {
                
inst.sortables.push({
                    
instancesortable,
                    
shouldRevertsortable.options.revert
                
});
                
sortable.refreshPositions();    // Call the sortable's refreshPositions at drag start to refresh the containerCache since the sortable container cache is used in drag and needs to be up to date (this will ensure it's initialised as well as being kept in step with any changes that might have happened on the page).
                
sortable._trigger("activate"eventuiSortable);
            }
        });

    },
    
stop: function(eventui) {

        
//If we are still over the sortable, we fake the stop event of the sortable, but also remove helper
        
var inst = $(this).data("ui-draggable"),
            
uiSortable = $.extend({}, ui, { iteminst.element });

        $.
each(inst.sortables, function() {
            if(
this.instance.isOver) {

                
this.instance.isOver 0;

                
inst.cancelHelperRemoval true//Don't remove the helper in the draggable instance
                
this.instance.cancelHelperRemoval false//Remove it in the sortable instance (so sortable plugins like revert still work)

                //The sortable revert is supported, and we have to set a temporary dropped variable on the draggable to support revert: "valid/invalid"
                
if(this.shouldRevert) {
                    
this.instance.options.revert true;
                }

                
//Trigger the stop of the sortable
                
this.instance._mouseStop(event);

                
this.instance.options.helper this.instance.options._helper;

                
//If the helper has been the original item, restore properties in the sortable
                
if(inst.options.helper === "original") {
                    
this.instance.currentItem.css({ top"auto"left"auto" });
                }

            } else {
                
this.instance.cancelHelperRemoval false//Remove the helper in the sortable instance
                
this.instance._trigger("deactivate"eventuiSortable);
            }

        });

    },
    
drag: function(eventui) {

        var 
inst = $(this).data("ui-draggable"), that this;

        $.
each(inst.sortables, function() {

            var 
innermostIntersecting false,
                
thisSortable this;

            
//Copy over some variables to allow calling the sortable's native _intersectsWith
            
this.instance.positionAbs inst.positionAbs;
            
this.instance.helperProportions inst.helperProportions;
            
this.instance.offset.click inst.offset.click;

            if(
this.instance._intersectsWith(this.instance.containerCache)) {
                
innermostIntersecting true;
                $.
each(inst.sortables, function () {
                    
this.instance.positionAbs inst.positionAbs;
                    
this.instance.helperProportions inst.helperProportions;
                    
this.instance.offset.click inst.offset.click;
                    if (
this !== thisSortable &&
                        
this.instance._intersectsWith(this.instance.containerCache) &&
                        $.
ui.contains(thisSortable.instance.element[0], this.instance.element[0])
                    ) {
                        
innermostIntersecting false;
                    }
                    return 
innermostIntersecting;
                });
            }


            if(
innermostIntersecting) {
                
//If it intersects, we use a little isOver variable and set it once, so our move-in stuff gets fired only once
                
if(!this.instance.isOver) {

                    
this.instance.isOver 1;
                    
//Now we fake the start of dragging for the sortable instance,
                    //by cloning the list group item, appending it to the sortable and using it as inst.currentItem
                    //We can then fire the start event of the sortable with our passed browser event, and our own helper (so it doesn't create a new one)
                    
this.instance.currentItem = $(that).clone().removeAttr("id").appendTo(this.instance.element).data("ui-sortable-item"true);
                    
this.instance.options._helper this.instance.options.helper//Store helper option to later restore it
                    
this.instance.options.helper = function() { return ui.helper[0]; };

                    
event.target this.instance.currentItem[0];
                    
this.instance._mouseCapture(eventtrue);
                    
this.instance._mouseStart(eventtruetrue);

                    
//Because the browser event is way off the new appended portlet, we modify a couple of variables to reflect the changes
                    
this.instance.offset.click.top inst.offset.click.top;
                    
this.instance.offset.click.left inst.offset.click.left;
                    
this.instance.offset.parent.left -= inst.offset.parent.left this.instance.offset.parent.left;
                    
this.instance.offset.parent.top -= inst.offset.parent.top this.instance.offset.parent.top;

                    
inst._trigger("toSortable"event);
                    
inst.dropped this.instance.element//draggable revert needs that
                    //hack so receive/update callbacks work (mostly)
                    
inst.currentItem inst.element;
                    
this.instance.fromOutside inst;

                }

                
//Provided we did all the previous steps, we can fire the drag event of the sortable on every draggable drag, when it intersects with the sortable
                
if(this.instance.currentItem) {
                    
this.instance._mouseDrag(event);
                }

            } else {

                
//If it doesn't intersect with the sortable, and it intersected before,
                //we fake the drag stop of the sortable, but make sure it doesn't remove the helper by using cancelHelperRemoval
                
if(this.instance.isOver) {

                    
this.instance.isOver 0;
                    
this.instance.cancelHelperRemoval true;

                    
//Prevent reverting on this forced stop
                    
this.instance.options.revert false;

                    
// The out event needs to be triggered independently
                    
this.instance._trigger("out"eventthis.instance._uiHash(this.instance));

                    
this.instance._mouseStop(eventtrue);
                    
this.instance.options.helper this.instance.options._helper;

                    
//Now we remove our currentItem, the list group clone again, and the placeholder, and animate the helper back to it's original size
                    
this.instance.currentItem.remove();
                    if(
this.instance.placeholder) {
                        
this.instance.placeholder.remove();
                    }

                    
inst._trigger("fromSortable"event);
                    
inst.dropped false//draggable revert needs that
                
}

            }

        });

    }
});

$.
ui.plugin.add("draggable""cursor", {
    
start: function() {
        var 
= $("body"), = $(this).data("ui-draggable").options;
        if (
t.css("cursor")) {
            
o._cursor t.css("cursor");
        }
        
t.css("cursor"o.cursor);
    },
    
stop: function() {
        var 
= $(this).data("ui-draggable").options;
        if (
o._cursor) {
            $(
"body").css("cursor"o._cursor);
        }
    }
});

$.
ui.plugin.add("draggable""opacity", {
    
start: function(eventui) {
        var 
= $(ui.helper), = $(this).data("ui-draggable").options;
        if(
t.css("opacity")) {
            
o._opacity t.css("opacity");
        }
        
t.css("opacity"o.opacity);
    },
    
stop: function(eventui) {
        var 
= $(this).data("ui-draggable").options;
        if(
o._opacity) {
            $(
ui.helper).css("opacity"o._opacity);
        }
    }
});

$.
ui.plugin.add("draggable""scroll", {
    
start: function() {
        var 
= $(this).data("ui-draggable");
        if(
i.scrollParent[0] !== document && i.scrollParent[0].tagName !== "HTML") {
            
i.overflowOffset i.scrollParent.offset();
        }
    },
    
drag: function( event ) {

        var 
= $(this).data("ui-draggable"), i.optionsscrolled false;

        if(
i.scrollParent[0] !== document && i.scrollParent[0].tagName !== "HTML") {

            if(!
o.axis || o.axis !== "x") {
                if((
i.overflowOffset.top i.scrollParent[0].offsetHeight) - event.pageY o.scrollSensitivity) {
                    
i.scrollParent[0].scrollTop scrolled i.scrollParent[0].scrollTop o.scrollSpeed;
                } else if(
event.pageY i.overflowOffset.top o.scrollSensitivity) {
                    
i.scrollParent[0].scrollTop scrolled i.scrollParent[0].scrollTop o.scrollSpeed;
                }
            }

            if(!
o.axis || o.axis !== "y") {
                if((
i.overflowOffset.left i.scrollParent[0].offsetWidth) - event.pageX o.scrollSensitivity) {
                    
i.scrollParent[0].scrollLeft scrolled i.scrollParent[0].scrollLeft o.scrollSpeed;
                } else if(
event.pageX i.overflowOffset.left o.scrollSensitivity) {
                    
i.scrollParent[0].scrollLeft scrolled i.scrollParent[0].scrollLeft o.scrollSpeed;
                }
            }

        } else {

            if(!
o.axis || o.axis !== "x") {
                if(
event.pageY - $(document).scrollTop() < o.scrollSensitivity) {
                    
scrolled = $(document).scrollTop($(document).scrollTop() - o.scrollSpeed);
                } else if($(
window).height() - (event.pageY - $(document).scrollTop()) < o.scrollSensitivity) {
                    
scrolled = $(document).scrollTop($(document).scrollTop() + o.scrollSpeed);
                }
            }

            if(!
o.axis || o.axis !== "y") {
                if(
event.pageX - $(document).scrollLeft() < o.scrollSensitivity) {
                    
scrolled = $(document).scrollLeft($(document).scrollLeft() - o.scrollSpeed);
                } else if($(
window).width() - (event.pageX - $(document).scrollLeft()) < o.scrollSensitivity) {
                    
scrolled = $(document).scrollLeft($(document).scrollLeft() + o.scrollSpeed);
                }
            }

        }

        if(
scrolled !== false && $.ui.ddmanager && !o.dropBehaviour) {
            $.
ui.ddmanager.prepareOffsets(ievent);
        }

    }
});

$.
ui.plugin.add("draggable""snap", {
    
start: function() {

        var 
= $(this).data("ui-draggable"),
            
i.options;

        
i.snapElements = [];

        $(
o.snap.constructor !== String ? ( o.snap.items || ":data(ui-draggable)" ) : o.snap).each(function() {
            var 
$t = $(this),
                
$o $t.offset();
            if(
this !== i.element[0]) {
                
i.snapElements.push({
                    
itemthis,
                    
width$t.outerWidth(), height$t.outerHeight(),
                    
top$o.topleft$o.left
                
});
            }
        });

    },
    
drag: function(eventui) {

        var 
tsbslsrslrtbifirst,
            
inst = $(this).data("ui-draggable"),
            
inst.options,
            
o.snapTolerance,
            
x1 ui.offset.leftx2 x1 inst.helperProportions.width,
            
y1 ui.offset.topy2 y1 inst.helperProportions.height;

        for (
inst.snapElements.length 1>= 0i--){

            
inst.snapElements[i].left;
            
inst.snapElements[i].width;
            
inst.snapElements[i].top;
            
inst.snapElements[i].height;

            
//Yes, I know, this is insane ;)
            
if(!((l-x1 && x1 r+&& t-y1 && y1 b+d) || (l-x1 && x1 r+&& t-y2 && y2 b+d) || (l-x2 && x2 r+&& t-y1 && y1 b+d) || (l-x2 && x2 r+&& t-y2 && y2 b+d))) {
                if(
inst.snapElements[i].snapping) {
                    (
inst.options.snap.release && inst.options.snap.release.call(inst.elementevent, $.extend(inst._uiHash(), { snapIteminst.snapElements[i].item })));
                }
                
inst.snapElements[i].snapping false;
                continue;
            }

            if(
o.snapMode !== "inner") {
                
ts Math.abs(y2) <= d;
                
bs Math.abs(y1) <= d;
                
ls Math.abs(x2) <= d;
                
rs Math.abs(x1) <= d;
                if(
ts) {
                    
ui.position.top inst._convertPositionTo("relative", { topinst.helperProportions.heightleft}).top inst.margins.top;
                }
                if(
bs) {
                    
ui.position.top inst._convertPositionTo("relative", { topbleft}).top inst.margins.top;
                }
                if(
ls) {
                    
ui.position.left inst._convertPositionTo("relative", { top0leftinst.helperProportions.width }).left inst.margins.left;
                }
                if(
rs) {
                    
ui.position.left inst._convertPositionTo("relative", { top0left}).left inst.margins.left;
                }
            }

            
first = (ts || bs || ls || rs);

            if(
o.snapMode !== "outer") {
                
ts Math.abs(y1) <= d;
                
bs Math.abs(y2) <= d;
                
ls Math.abs(x1) <= d;
                
rs Math.abs(x2) <= d;
                if(
ts) {
                    
ui.position.top inst._convertPositionTo("relative", { toptleft}).top inst.margins.top;
                }
                if(
bs) {
                    
ui.position.top inst._convertPositionTo("relative", { topinst.helperProportions.heightleft}).top inst.margins.top;
                }
                if(
ls) {
                    
ui.position.left inst._convertPositionTo("relative", { top0left}).left inst.margins.left;
                }
                if(
rs) {
                    
ui.position.left inst._convertPositionTo("relative", { top0leftinst.helperProportions.width }).left inst.margins.left;
                }
            }

            if(!
inst.snapElements[i].snapping && (ts || bs || ls || rs || first)) {
                (
inst.options.snap.snap && inst.options.snap.snap.call(inst.elementevent, $.extend(inst._uiHash(), { snapIteminst.snapElements[i].item })));
            }
            
inst.snapElements[i].snapping = (ts || bs || ls || rs || first);

        }

    }
});

$.
ui.plugin.add("draggable""stack", {
    
start: function() {

        var 
min,
            
= $(this).data("ui-draggable").options,
            
group = $.makeArray($(o.stack)).sort(function(a,b) {
                return (
parseInt($(a).css("zIndex"),10) || 0) - (parseInt($(b).css("zIndex"),10) || 0);
            });

        if (!
group.length) { return; }

        
min parseInt(group[0].style.zIndex10) || 0;
        $(
group).each(function(i) {
            
this.style.zIndex min i;
        });

        
this[0].style.zIndex min group.length;

    }
});

$.
ui.plugin.add("draggable""zIndex", {
    
start: function(eventui) {
        var 
= $(ui.helper), = $(this).data("ui-draggable").options;
        if(
t.css("zIndex")) {
            
o._zIndex t.css("zIndex");
        }
        
t.css("zIndex"o.zIndex);
    },
    
stop: function(eventui) {
        var 
= $(this).data("ui-draggable").options;
        if(
o._zIndex) {
            $(
ui.helper).css("zIndex"o._zIndex);
        }
    }
});

})(
jQuery);
(function( $, 
undefined ) {

function 
isOverAxisxreferencesize ) {
    return ( 
reference ) && ( < ( reference size ) );
}

$.
widget("ui.droppable", {
    
version"1.10.0",
    
widgetEventPrefix"drop",
    
options: {
        
accept"*",
        
activeClassfalse,
        
addClassestrue,
        
greedyfalse,
        
hoverClassfalse,
        
scope"default",
        
tolerance"intersect",

        
// callbacks
        
activatenull,
        
deactivatenull,
        
dropnull,
        
outnull,
        
overnull
    
},
    
_create: function() {

        var 
this.options,
            
accept o.accept;

        
this.isover false;
        
this.isout true;

        
this.accept = $.isFunction(accept) ? accept : function(d) {
            return 
d.is(accept);
        };

        
//Store the droppable's proportions
        
this.proportions = { widththis.element[0].offsetWidthheightthis.element[0].offsetHeight };

        
// Add the reference and positions to the manager
        
$.ui.ddmanager.droppables[o.scope] = $.ui.ddmanager.droppables[o.scope] || [];
        $.
ui.ddmanager.droppables[o.scope].push(this);

        (
o.addClasses && this.element.addClass("ui-droppable"));

    },

    
_destroy: function() {
        var 
0,
            
drop = $.ui.ddmanager.droppables[this.options.scope];

        for ( ; 
drop.lengthi++ ) {
            if ( 
drop[i] === this ) {
                
drop.splice(i1);
            }
        }

        
this.element.removeClass("ui-droppable ui-droppable-disabled");
    },

    
_setOption: function(keyvalue) {

        if(
key === "accept") {
            
this.accept = $.isFunction(value) ? value : function(d) {
                return 
d.is(value);
            };
        }
        $.
Widget.prototype._setOption.apply(thisarguments);
    },

    
_activate: function(event) {
        var 
draggable = $.ui.ddmanager.current;
        if(
this.options.activeClass) {
            
this.element.addClass(this.options.activeClass);
        }
        if(
draggable){
            
this._trigger("activate"eventthis.ui(draggable));
        }
    },

    
_deactivate: function(event) {
        var 
draggable = $.ui.ddmanager.current;
        if(
this.options.activeClass) {
            
this.element.removeClass(this.options.activeClass);
        }
        if(
draggable){
            
this._trigger("deactivate"eventthis.ui(draggable));
        }
    },

    
_over: function(event) {

        var 
draggable = $.ui.ddmanager.current;

        
// Bail if draggable and droppable are same element
        
if (!draggable || (draggable.currentItem || draggable.element)[0] === this.element[0]) {
            return;
        }

        if (
this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
            if(
this.options.hoverClass) {
                
this.element.addClass(this.options.hoverClass);
            }
            
this._trigger("over"eventthis.ui(draggable));
        }

    },

    
_out: function(event) {

        var 
draggable = $.ui.ddmanager.current;

        
// Bail if draggable and droppable are same element
        
if (!draggable || (draggable.currentItem || draggable.element)[0] === this.element[0]) {
            return;
        }

        if (
this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
            if(
this.options.hoverClass) {
                
this.element.removeClass(this.options.hoverClass);
            }
            
this._trigger("out"eventthis.ui(draggable));
        }

    },

    
_drop: function(event,custom) {

        var 
draggable custom || $.ui.ddmanager.current,
            
childrenIntersection false;

        
// Bail if draggable and droppable are same element
        
if (!draggable || (draggable.currentItem || draggable.element)[0] === this.element[0]) {
            return 
false;
        }

        
this.element.find(":data(ui-droppable)").not(".ui-draggable-dragging").each(function() {
            var 
inst = $.data(this"ui-droppable");
            if(
                
inst.options.greedy &&
                !
inst.options.disabled &&
                
inst.options.scope === draggable.options.scope &&
                
inst.accept.call(inst.element[0], (draggable.currentItem || draggable.element)) &&
                $.
ui.intersect(draggable, $.extend(inst, { offsetinst.element.offset() }), inst.options.tolerance)
            ) { 
childrenIntersection true; return false; }
        });
        if(
childrenIntersection) {
            return 
false;
        }

        if(
this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
            if(
this.options.activeClass) {
                
this.element.removeClass(this.options.activeClass);
            }
            if(
this.options.hoverClass) {
                
this.element.removeClass(this.options.hoverClass);
            }
            
this._trigger("drop"eventthis.ui(draggable));
            return 
this.element;
        }

        return 
false;

    },

    
ui: function(c) {
        return {
            
draggable: (c.currentItem || c.element),
            
helperc.helper,
            
positionc.position,
            
offsetc.positionAbs
        
};
    }

});

$.
ui.intersect = function(draggabledroppabletoleranceMode) {

    if (!
droppable.offset) {
        return 
false;
    }

    var 
draggableLeftdraggableTop,
        
x1 = (draggable.positionAbs || draggable.position.absolute).leftx2 x1 draggable.helperProportions.width,
        
y1 = (draggable.positionAbs || draggable.position.absolute).topy2 y1 draggable.helperProportions.height,
        
droppable.offset.leftdroppable.proportions.width,
        
droppable.offset.topdroppable.proportions.height;

    switch (
toleranceMode) {
        case 
"fit":
            return (
<= x1 && x2 <= && <= y1 && y2 <= b);
        case 
"intersect":
            return (
x1 + (draggable.helperProportions.width 2) && // Right Half
                
x2 - (draggable.helperProportions.width 2) < && // Left Half
                
y1 + (draggable.helperProportions.height 2) && // Bottom Half
                
y2 - (draggable.helperProportions.height 2) < ); // Top Half
        
case "pointer":
            
draggableLeft = ((draggable.positionAbs || draggable.position.absolute).left + (draggable.clickOffset || draggable.offset.click).left);
            
draggableTop = ((draggable.positionAbs || draggable.position.absolute).top + (draggable.clickOffset || draggable.offset.click).top);
            return 
isOverAxisdraggableToptdroppable.proportions.height ) && isOverAxisdraggableLeftldroppable.proportions.width );
        case 
"touch":
            return (
                (
y1 >= && y1 <= b) ||    // Top edge touching
                
(y2 >= && y2 <= b) ||    // Bottom edge touching
                
(y1 && y2 b)        // Surrounded vertically
            
) && (
                (
x1 >= && x1 <= r) ||    // Left edge touching
                
(x2 >= && x2 <= r) ||    // Right edge touching
                
(x1 && x2 r)        // Surrounded horizontally
            
);
        default:
            return 
false;
        }

};

/*
    This manager tracks offsets of draggables and droppables
*/
$.ui.ddmanager = {
    
currentnull,
    
droppables: { "default": [] },
    
prepareOffsets: function(tevent) {

        var 
ij,
            
= $.ui.ddmanager.droppables[t.options.scope] || [],
            
type event event.type null// workaround for #2317
            
list = (t.currentItem || t.element).find(":data(ui-droppable)").addBack();

        
droppablesLoop: for (0m.lengthi++) {

            
//No disabled and non-accepted
            
if(m[i].options.disabled || (&& !m[i].accept.call(m[i].element[0],(t.currentItem || t.element)))) {
                continue;
            }

            
// Filter out elements in the current dragged item
            
for (j=0< list.lengthj++) {
                if(list[
j] === m[i].element[0]) {
                    
m[i].proportions.height 0;
                    continue 
droppablesLoop;
                }
            }

            
m[i].visible m[i].element.css("display") !== "none";
            if(!
m[i].visible) {
                continue;
            }

            
//Activate the droppable if used directly from draggables
            
if(type === "mousedown") {
                
m[i]._activate.call(m[i], event);
            }

            
m[i].offset m[i].element.offset();
            
m[i].proportions = { widthm[i].element[0].offsetWidthheightm[i].element[0].offsetHeight };

        }

    },
    
drop: function(draggableevent) {

        var 
dropped false;
        $.
each($.ui.ddmanager.droppables[draggable.options.scope] || [], function() {

            if(!
this.options) {
                return;
            }
            if (!
this.options.disabled && this.visible && $.ui.intersect(draggablethisthis.options.tolerance)) {
                
dropped this._drop.call(thisevent) || dropped;
            }

            if (!
this.options.disabled && this.visible && this.accept.call(this.element[0],(draggable.currentItem || draggable.element))) {
                
this.isout true;
                
this.isover false;
                
this._deactivate.call(thisevent);
            }

        });
        return 
dropped;

    },
    
dragStart: function( draggableevent ) {
        
//Listen for scrolling so that if the dragging causes scrolling the position of the droppables can be recalculated (see #5003)
        
draggable.element.parentsUntil"body" ).bind"scroll.droppable", function() {
            if( !
draggable.options.refreshPositions ) {
                $.
ui.ddmanager.prepareOffsetsdraggableevent );
            }
        });
    },
    
drag: function(draggableevent) {

        
//If you have a highly dynamic page, you might try this option. It renders positions every time you move the mouse.
        
if(draggable.options.refreshPositions) {
            $.
ui.ddmanager.prepareOffsets(draggableevent);
        }

        
//Run through all droppables and check their positions based on specific tolerance options
        
$.each($.ui.ddmanager.droppables[draggable.options.scope] || [], function() {

            if(
this.options.disabled || this.greedyChild || !this.visible) {
                return;
            }

            var 
parentInstancescopeparent,
                
intersects = $.ui.intersect(draggablethisthis.options.tolerance),
                
= !intersects && this.isover "isout" : (intersects && !this.isover "isover" null);
            if(!
c) {
                return;
            }

            if (
this.options.greedy) {
                
// find droppable parents with same scope
                
scope this.options.scope;
                
parent this.element.parents(":data(ui-droppable)").filter(function () {
                    return $.
data(this"ui-droppable").options.scope === scope;
                });

                if (
parent.length) {
                    
parentInstance = $.data(parent[0], "ui-droppable");
                    
parentInstance.greedyChild = (=== "isover");
                }
            }

            
// we just moved into a greedy child
            
if (parentInstance && === "isover") {
                
parentInstance.isover false;
                
parentInstance.isout true;
                
parentInstance._out.call(parentInstanceevent);
            }

            
this[c] = true;
            
this[=== "isout" "isover" "isout"] = false;
            
this[=== "isover" "_over" "_out"].call(thisevent);

            
// we just moved out of a greedy child
            
if (parentInstance && === "isout") {
                
parentInstance.isout false;
                
parentInstance.isover true;
                
parentInstance._over.call(parentInstanceevent);
            }
        });

    },
    
dragStop: function( draggableevent ) {
        
draggable.element.parentsUntil"body" ).unbind"scroll.droppable" );
        
//Call prepareOffsets one final time since IE does not fire return scroll events when overflow was caused by drag (see #5003)
        
if( !draggable.options.refreshPositions ) {
            $.
ui.ddmanager.prepareOffsetsdraggableevent );
        }
    }
};

})(
jQuery);
(function( $, 
undefined ) {

/*jshint loopfunc: true */

function isOverAxisxreferencesize ) {
    return ( 
reference ) && ( < ( reference size ) );
}

$.
widget("ui.sortable", $.ui.mouse, {
    
version"1.10.0",
    
widgetEventPrefix"sort",
    
readyfalse,
    
options: {
        
appendTo"parent",
        
axisfalse,
        
connectWithfalse,
        
containmentfalse,
        
cursor"auto",
        
cursorAtfalse,
        
dropOnEmptytrue,
        
forcePlaceholderSizefalse,
        
forceHelperSizefalse,
        
gridfalse,
        
handlefalse,
        
helper"original",
        
items"> *",
        
opacityfalse,
        
placeholderfalse,
        
revertfalse,
        
scrolltrue,
        
scrollSensitivity20,
        
scrollSpeed20,
        
scope"default",
        
tolerance"intersect",
        
zIndex1000,

        
// callbacks
        
activatenull,
        
beforeStopnull,
        
changenull,
        
deactivatenull,
        
outnull,
        
overnull,
        
receivenull,
        
removenull,
        
sortnull,
        
startnull,
        
stopnull,
        
updatenull
    
},
    
_create: function() {

        var 
this.options;
        
this.containerCache = {};
        
this.element.addClass("ui-sortable");

        
//Get the items
        
this.refresh();

        
//Let's determine if the items are being displayed horizontally
        
this.floating this.items.length o.axis === "x" || (/left|right/).test(this.items[0].item.css("float")) || (/inline|table-cell/).test(this.items[0].item.css("display")) : false;

        
//Let's determine the parent's offset
        
this.offset this.element.offset();

        
//Initialize mouse events for interaction
        
this._mouseInit();

        
//We're ready to go
        
this.ready true;

    },

    
_destroy: function() {
        
this.element
            
.removeClass("ui-sortable ui-sortable-disabled");
        
this._mouseDestroy();

        for ( var 
this.items.length 1>= 0i-- ) {
            
this.items[i].item.removeData(this.widgetName "-item");
        }

        return 
this;
    },

    
_setOption: function(keyvalue){
        if ( 
key === "disabled" ) {
            
this.optionskey ] = value;

            
this.widget().toggleClass"ui-sortable-disabled", !!value );
        } else {
            
// Don't call widget base _setOption for disable as it adds ui-state-disabled class
            
$.Widget.prototype._setOption.apply(thisarguments);
        }
    },

    
_mouseCapture: function(eventoverrideHandle) {
        var 
currentItem null,
            
validHandle false,
            
that this;

        if (
this.reverting) {
            return 
false;
        }

        if(
this.options.disabled || this.options.type === "static") {
            return 
false;
        }

        
//We have to refresh the items data once first
        
this._refreshItems(event);

        
//Find out if the clicked node (or one of its parents) is a actual item in this.items
        
$(event.target).parents().each(function() {
            if($.
data(thisthat.widgetName "-item") === that) {
                
currentItem = $(this);
                return 
false;
            }
        });
        if($.
data(event.targetthat.widgetName "-item") === that) {
            
currentItem = $(event.target);
        }

        if(!
currentItem) {
            return 
false;
        }
        if(
this.options.handle && !overrideHandle) {
            $(
this.options.handlecurrentItem).find("*").addBack().each(function() {
                if(
this === event.target) {
                    
validHandle true;
                }
            });
            if(!
validHandle) {
                return 
false;
            }
        }

        
this.currentItem currentItem;
        
this._removeCurrentsFromItems();
        return 
true;

    },

    
_mouseStart: function(eventoverrideHandlenoActivation) {

        var 
i,
            
this.options;

        
this.currentContainer this;

        
//We only need to call refreshPositions, because the refreshItems call has been moved to mouseCapture
        
this.refreshPositions();

        
//Create and append the visible helper
        
this.helper this._createHelper(event);

        
//Cache the helper size
        
this._cacheHelperProportions();

        
/*
         * - Position generation -
         * This block generates everything position related - it's the core of draggables.
         */

        //Cache the margins of the original element
        
this._cacheMargins();

        
//Get the next scrolling parent
        
this.scrollParent this.helper.scrollParent();

        
//The element's absolute position on the page minus margins
        
this.offset this.currentItem.offset();
        
this.offset = {
            
topthis.offset.top this.margins.top,
            
leftthis.offset.left this.margins.left
        
};

        $.
extend(this.offset, {
            
click: { //Where the click happened, relative to the element
                
leftevent.pageX this.offset.left,
                
topevent.pageY this.offset.top
            
},
            
parentthis._getParentOffset(),
            
relativethis._getRelativeOffset() //This is a relative to absolute position minus the actual position calculation - only used for relative positioned helper
        
});

        
// Only after we got the offset, we can change the helper's position to absolute
        // TODO: Still need to figure out a way to make relative sorting possible
        
this.helper.css("position""absolute");
        
this.cssPosition this.helper.css("position");

        
//Generate the original position
        
this.originalPosition this._generatePosition(event);
        
this.originalPageX event.pageX;
        
this.originalPageY event.pageY;

        
//Adjust the mouse offset relative to the helper if "cursorAt" is supplied
        
(o.cursorAt && this._adjustOffsetFromHelper(o.cursorAt));

        
//Cache the former DOM position
        
this.domPosition = { prevthis.currentItem.prev()[0], parentthis.currentItem.parent()[0] };

        
//If the helper is not the original, hide the original so it's not playing any role during the drag, won't cause anything bad this way
        
if(this.helper[0] !== this.currentItem[0]) {
            
this.currentItem.hide();
        }

        
//Create the placeholder
        
this._createPlaceholder();

        
//Set a containment if given in the options
        
if(o.containment) {
            
this._setContainment();
        }

        if(
o.cursor) { // cursor option
            
if ($("body").css("cursor")) {
                
this._storedCursor = $("body").css("cursor");
            }
            $(
"body").css("cursor"o.cursor);
        }

        if(
o.opacity) { // opacity option
            
if (this.helper.css("opacity")) {
                
this._storedOpacity this.helper.css("opacity");
            }
            
this.helper.css("opacity"o.opacity);
        }

        if(
o.zIndex) { // zIndex option
            
if (this.helper.css("zIndex")) {
                
this._storedZIndex this.helper.css("zIndex");
            }
            
this.helper.css("zIndex"o.zIndex);
        }

        
//Prepare scrolling
        
if(this.scrollParent[0] !== document && this.scrollParent[0].tagName !== "HTML") {
            
this.overflowOffset this.scrollParent.offset();
        }

        
//Call callbacks
        
this._trigger("start"eventthis._uiHash());

        
//Recache the helper size
        
if(!this._preserveHelperProportions) {
            
this._cacheHelperProportions();
        }


        
//Post "activate" events to possible containers
        
if( !noActivation ) {
            for ( 
this.containers.length 1>= 0i-- ) {
                
this.containers]._trigger"activate"eventthis._uiHashthis ) );
            }
        }

        
//Prepare possible droppables
        
if($.ui.ddmanager) {
            $.
ui.ddmanager.current this;
        }

        if ($.
ui.ddmanager && !o.dropBehaviour) {
            $.
ui.ddmanager.prepareOffsets(thisevent);
        }

        
this.dragging true;

        
this.helper.addClass("ui-sortable-helper");
        
this._mouseDrag(event); //Execute the drag once - this causes the helper not to be visible before getting its correct position
        
return true;

    },

    
_mouseDrag: function(event) {
        var 
iitemitemElementintersection,
            
this.options,
            
scrolled false;

        
//Compute the helpers position
        
this.position this._generatePosition(event);
        
this.positionAbs this._convertPositionTo("absolute");

        if (!
this.lastPositionAbs) {
            
this.lastPositionAbs this.positionAbs;
        }

        
//Do scrolling
        
if(this.options.scroll) {
            if(
this.scrollParent[0] !== document && this.scrollParent[0].tagName !== "HTML") {

                if((
this.overflowOffset.top this.scrollParent[0].offsetHeight) - event.pageY o.scrollSensitivity) {
                    
this.scrollParent[0].scrollTop scrolled this.scrollParent[0].scrollTop o.scrollSpeed;
                } else if(
event.pageY this.overflowOffset.top o.scrollSensitivity) {
                    
this.scrollParent[0].scrollTop scrolled this.scrollParent[0].scrollTop o.scrollSpeed;
                }

                if((
this.overflowOffset.left this.scrollParent[0].offsetWidth) - event.pageX o.scrollSensitivity) {
                    
this.scrollParent[0].scrollLeft scrolled this.scrollParent[0].scrollLeft o.scrollSpeed;
                } else if(
event.pageX this.overflowOffset.left o.scrollSensitivity) {
                    
this.scrollParent[0].scrollLeft scrolled this.scrollParent[0].scrollLeft o.scrollSpeed;
                }

            } else {

                if(
event.pageY - $(document).scrollTop() < o.scrollSensitivity) {
                    
scrolled = $(document).scrollTop($(document).scrollTop() - o.scrollSpeed);
                } else if($(
window).height() - (event.pageY - $(document).scrollTop()) < o.scrollSensitivity) {
                    
scrolled = $(document).scrollTop($(document).scrollTop() + o.scrollSpeed);
                }

                if(
event.pageX - $(document).scrollLeft() < o.scrollSensitivity) {
                    
scrolled = $(document).scrollLeft($(document).scrollLeft() - o.scrollSpeed);
                } else if($(
window).width() - (event.pageX - $(document).scrollLeft()) < o.scrollSensitivity) {
                    
scrolled = $(document).scrollLeft($(document).scrollLeft() + o.scrollSpeed);
                }

            }

            if(
scrolled !== false && $.ui.ddmanager && !o.dropBehaviour) {
                $.
ui.ddmanager.prepareOffsets(thisevent);
            }
        }

        
//Regenerate the absolute position used for position checks
        
this.positionAbs this._convertPositionTo("absolute");

        
//Set the helper position
        
if(!this.options.axis || this.options.axis !== "y") {
            
this.helper[0].style.left this.position.left+"px";
        }
        if(!
this.options.axis || this.options.axis !== "x") {
            
this.helper[0].style.top this.position.top+"px";
        }

        
//Rearrange
        
for (this.items.length 1>= 0i--) {

            
//Cache variables and intersection, continue if no intersection
            
item this.items[i];
            
itemElement item.item[0];
            
intersection this._intersectsWithPointer(item);
            if (!
intersection) {
                continue;
            }

            
// Only put the placeholder inside the current Container, skip all
            // items form other containers. This works because when moving
            // an item from one container to another the
            // currentContainer is switched before the placeholder is moved.
            //
            // Without this moving items in "sub-sortables" can cause the placeholder to jitter
            // beetween the outer and inner container.
            
if (item.instance !== this.currentContainer) {
                continue;
            }

            
// cannot intersect with itself
            // no useless actions that have been done before
            // no action if the item moved is the parent of the item checked
            
if (itemElement !== this.currentItem[0] &&
                
this.placeholder[intersection === "next" "prev"]()[0] !== itemElement &&
                !$.
contains(this.placeholder[0], itemElement) &&
                (
this.options.type === "semi-dynamic" ? !$.contains(this.element[0], itemElement) : true)
            ) {

                
this.direction intersection === "down" "up";

                if (
this.options.tolerance === "pointer" || this._intersectsWithSides(item)) {
                    
this._rearrange(eventitem);
                } else {
                    break;
                }

                
this._trigger("change"eventthis._uiHash());
                break;
            }
        }

        
//Post events to containers
        
this._contactContainers(event);

        
//Interconnect with droppables
        
if($.ui.ddmanager) {
            $.
ui.ddmanager.drag(thisevent);
        }

        
//Call callbacks
        
this._trigger("sort"eventthis._uiHash());

        
this.lastPositionAbs this.positionAbs;
        return 
false;

    },

    
_mouseStop: function(eventnoPropagation) {

        if(!
event) {
            return;
        }

        
//If we are using droppables, inform the manager about the drop
        
if ($.ui.ddmanager && !this.options.dropBehaviour) {
            $.
ui.ddmanager.drop(thisevent);
        }

        if(
this.options.revert) {
            var 
that this,
                
cur this.placeholder.offset();

            
this.reverting true;

            $(
this.helper).animate({
                
leftcur.left this.offset.parent.left this.margins.left + (this.offsetParent[0] === document.body this.offsetParent[0].scrollLeft),
                
topcur.top this.offset.parent.top this.margins.top + (this.offsetParent[0] === document.body this.offsetParent[0].scrollTop)
            }, 
parseInt(this.options.revert10) || 500, function() {
                
that._clear(event);
            });
        } else {
            
this._clear(eventnoPropagation);
        }

        return 
false;

    },

    
cancel: function() {

        if(
this.dragging) {

            
this._mouseUp({ targetnull });

            if(
this.options.helper === "original") {
                
this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper");
            } else {
                
this.currentItem.show();
            }

            
//Post deactivating events to containers
            
for (var this.containers.length 1>= 0i--){
                
this.containers[i]._trigger("deactivate"nullthis._uiHash(this));
                if(
this.containers[i].containerCache.over) {
                    
this.containers[i]._trigger("out"nullthis._uiHash(this));
                    
this.containers[i].containerCache.over 0;
                }
            }

        }

        if (
this.placeholder) {
            
//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!
            
if(this.placeholder[0].parentNode) {
                
this.placeholder[0].parentNode.removeChild(this.placeholder[0]);
            }
            if(
this.options.helper !== "original" && this.helper && this.helper[0].parentNode) {
                
this.helper.remove();
            }

            $.
extend(this, {
                
helpernull,
                
draggingfalse,
                
revertingfalse,
                
_noFinalSortnull
            
});

            if(
this.domPosition.prev) {
                $(
this.domPosition.prev).after(this.currentItem);
            } else {
                $(
this.domPosition.parent).prepend(this.currentItem);
            }
        }

        return 
this;

    },

    
serialize: function(o) {

        var 
items this._getItemsAsjQuery(&& o.connected),
            
str = [];
        
|| {};

        $(
items).each(function() {
            var 
res = ($(o.item || this).attr(o.attribute || "id") || "").match(o.expression || (/(.+)[-=_](.+)/));
            if (
res) {
                
str.push((o.key || res[1]+"[]")+"="+(o.key && o.expression res[1] : res[2]));
            }
        });

        if(!
str.length && o.key) {
            
str.push(o.key "=");
        }

        return 
str.join("&");

    },

    
toArray: function(o) {

        var 
items this._getItemsAsjQuery(&& o.connected),
            
ret = [];

        
|| {};

        
items.each(function() { ret.push($(o.item || this).attr(o.attribute || "id") || ""); });
        return 
ret;

    },

    
/* Be careful with the following core functions */
    
_intersectsWith: function(item) {

        var 
x1 this.positionAbs.left,
            
x2 x1 this.helperProportions.width,
            
y1 this.positionAbs.top,
            
y2 y1 this.helperProportions.height,
            
item.left,
            
item.width,
            
item.top,
            
item.height,
            
dyClick this.offset.click.top,
            
dxClick this.offset.click.left,
            
isOverElement = (y1 dyClick) > && (y1 dyClick) < && (x1 dxClick) > && (x1 dxClick) < r;

        if ( 
this.options.tolerance === "pointer" ||
            
this.options.forcePointerForContainers ||
            (
this.options.tolerance !== "pointer" && this.helperProportions[this.floating "width" "height"] > item[this.floating "width" "height"])
        ) {
            return 
isOverElement;
        } else {

            return (
x1 + (this.helperProportions.width 2) && // Right Half
                
x2 - (this.helperProportions.width 2) < && // Left Half
                
y1 + (this.helperProportions.height 2) && // Bottom Half
                
y2 - (this.helperProportions.height 2) < ); // Top Half

        
}
    },

    
_intersectsWithPointer: function(item) {

        var 
isOverElementHeight = (this.options.axis === "x") || isOverAxis(this.positionAbs.top this.offset.click.topitem.topitem.height),
            
isOverElementWidth = (this.options.axis === "y") || isOverAxis(this.positionAbs.left this.offset.click.leftitem.leftitem.width),
            
isOverElement isOverElementHeight && isOverElementWidth,
            
verticalDirection this._getDragVerticalDirection(),
            
horizontalDirection this._getDragHorizontalDirection();

        if (!
isOverElement) {
            return 
false;
        }

        return 
this.floating ?
            ( ((
horizontalDirection && horizontalDirection === "right") || verticalDirection === "down") ? )
            : ( 
verticalDirection && (verticalDirection === "down" 1) );

    },

    
_intersectsWithSides: function(item) {

        var 
isOverBottomHalf isOverAxis(this.positionAbs.top this.offset.click.topitem.top + (item.height/2), item.height),
            
isOverRightHalf isOverAxis(this.positionAbs.left this.offset.click.leftitem.left + (item.width/2), item.width),
            
verticalDirection this._getDragVerticalDirection(),
            
horizontalDirection this._getDragHorizontalDirection();

        if (
this.floating && horizontalDirection) {
            return ((
horizontalDirection === "right" && isOverRightHalf) || (horizontalDirection === "left" && !isOverRightHalf));
        } else {
            return 
verticalDirection && ((verticalDirection === "down" && isOverBottomHalf) || (verticalDirection === "up" && !isOverBottomHalf));
        }

    },

    
_getDragVerticalDirection: function() {
        var 
delta this.positionAbs.top this.lastPositionAbs.top;
        return 
delta !== && (delta "down" "up");
    },

    
_getDragHorizontalDirection: function() {
        var 
delta this.positionAbs.left this.lastPositionAbs.left;
        return 
delta !== && (delta "right" "left");
    },

    
refresh: function(event) {
        
this._refreshItems(event);
        
this.refreshPositions();
        return 
this;
    },

    
_connectWith: function() {
        var 
options this.options;
        return 
options.connectWith.constructor === String ? [options.connectWith] : options.connectWith;
    },

    
_getItemsAsjQuery: function(connected) {

        var 
ijcurinst,
            
items = [],
            
queries = [],
            
connectWith this._connectWith();

        if(
connectWith && connected) {
            for (
connectWith.length 1>= 0i--){
                
cur = $(connectWith[i]);
                for ( 
cur.length 1>= 0j--){
                    
inst = $.data(cur[j], this.widgetFullName);
                    if(
inst && inst !== this && !inst.options.disabled) {
                        
queries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element) : $(inst.options.itemsinst.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), inst]);
                    }
                }
            }
        }

        
queries.push([$.isFunction(this.options.items) ? this.options.items.call(this.elementnull, { optionsthis.optionsitemthis.currentItem }) : $(this.options.itemsthis.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"), this]);

        for (
queries.length 1>= 0i--){
            
queries[i][0].each(function() {
                
items.push(this);
            });
        }

        return $(
items);

    },

    
_removeCurrentsFromItems: function() {

        var list = 
this.currentItem.find(":data(" this.widgetName "-item)");

        
this.items = $.grep(this.items, function (item) {
            for (var 
j=0< list.lengthj++) {
                if(list[
j] === item.item[0]) {
                    return 
false;
                }
            }
            return 
true;
        });

    },

    
_refreshItems: function(event) {

        
this.items = [];
        
this.containers = [this];

        var 
ijcurinsttargetData_queriesitemqueriesLength,
            
items this.items,
            
queries = [[$.isFunction(this.options.items) ? this.options.items.call(this.element[0], event, { itemthis.currentItem }) : $(this.options.itemsthis.element), this]],
            
connectWith this._connectWith();

        if(
connectWith && this.ready) { //Shouldn't be run the first time through due to massive slow-down
            
for (connectWith.length 1>= 0i--){
                
cur = $(connectWith[i]);
                for (
cur.length 1>= 0j--){
                    
inst = $.data(cur[j], this.widgetFullName);
                    if(
inst && inst !== this && !inst.options.disabled) {
                        
queries.push([$.isFunction(inst.options.items) ? inst.options.items.call(inst.element[0], event, { itemthis.currentItem }) : $(inst.options.itemsinst.element), inst]);
                        
this.containers.push(inst);
                    }
                }
            }
        }

        for (
queries.length 1>= 0i--) {
            
targetData queries[i][1];
            
_queries queries[i][0];

            for (
j=0queriesLength _queries.lengthqueriesLengthj++) {
                
item = $(_queries[j]);

                
item.data(this.widgetName "-item"targetData); // Data for target checking (mouse manager)

                
items.push({
                    
itemitem,
                    
instancetargetData,
                    
width0height0,
                    
left0top0
                
});
            }
        }

    },

    
refreshPositions: function(fast) {

        
//This has to be redone because due to the item being moved out/into the offsetParent, the offsetParent's position will change
        
if(this.offsetParent && this.helper) {
            
this.offset.parent this._getParentOffset();
        }

        var 
iitemtp;

        for (
this.items.length 1>= 0i--){
            
item this.items[i];

            
//We ignore calculating positions of all connected containers when we're not over them
            
if(item.instance !== this.currentContainer && this.currentContainer && item.item[0] !== this.currentItem[0]) {
                continue;
            }

            
this.options.toleranceElement ? $(this.options.toleranceElementitem.item) : item.item;

            if (!
fast) {
                
item.width t.outerWidth();
                
item.height t.outerHeight();
            }

            
t.offset();
            
item.left p.left;
            
item.top p.top;
        }

        if(
this.options.custom && this.options.custom.refreshContainers) {
            
this.options.custom.refreshContainers.call(this);
        } else {
            for (
this.containers.length 1>= 0i--){
                
this.containers[i].element.offset();
                
this.containers[i].containerCache.left p.left;
                
this.containers[i].containerCache.top p.top;
                
this.containers[i].containerCache.width    this.containers[i].element.outerWidth();
                
this.containers[i].containerCache.height this.containers[i].element.outerHeight();
            }
        }

        return 
this;
    },

    
_createPlaceholder: function(that) {
        
that that || this;
        var 
className,
            
that.options;

        if(!
o.placeholder || o.placeholder.constructor === String) {
            
className o.placeholder;
            
o.placeholder = {
                
element: function() {

                    var 
el = $(document.createElement(that.currentItem[0].nodeName))
                        .
addClass(className || that.currentItem[0].className+" ui-sortable-placeholder")
                        .
removeClass("ui-sortable-helper")[0];

                    if(!
className) {
                        
el.style.visibility "hidden";
                    }

                    return 
el;
                },
                
update: function(containerp) {

                    
// 1. If a className is set as 'placeholder option, we don't force sizes - the class is responsible for that
                    // 2. The option 'forcePlaceholderSize can be enabled to force it even if a class name is specified
                    
if(className && !o.forcePlaceholderSize) {
                        return;
                    }

                    
//If the element doesn't have a actual height by itself (without styles coming from a stylesheet), it receives the inline height from the dragged item
                    
if(!p.height()) { p.height(that.currentItem.innerHeight() - parseInt(that.currentItem.css("paddingTop")||010) - parseInt(that.currentItem.css("paddingBottom")||010)); }
                    if(!
p.width()) { p.width(that.currentItem.innerWidth() - parseInt(that.currentItem.css("paddingLeft")||010) - parseInt(that.currentItem.css("paddingRight")||010)); }
                }
            };
        }

        
//Create the placeholder
        
that.placeholder = $(o.placeholder.element.call(that.elementthat.currentItem));

        
//Append it after the actual current item
        
that.currentItem.after(that.placeholder);

        
//Update the size of the placeholder (TODO: Logic to fuzzy, see line 316/317)
        
o.placeholder.update(thatthat.placeholder);

    },

    
_contactContainers: function(event) {
        var 
ijdistitemWithLeastDistanceposPropertysizePropertybasecurnearBottom,
            
innermostContainer null,
            
innermostIndex null;

        
// get innermost container that intersects with item
        
for (this.containers.length 1>= 0i--) {

            
// never consider a container that's located within the item itself
            
if($.contains(this.currentItem[0], this.containers[i].element[0])) {
                continue;
            }

            if(
this._intersectsWith(this.containers[i].containerCache)) {

                
// if we've already found a container and it's more "inner" than this, then continue
                
if(innermostContainer && $.contains(this.containers[i].element[0], innermostContainer.element[0])) {
                    continue;
                }

                
innermostContainer this.containers[i];
                
innermostIndex i;

            } else {
                
// container doesn't intersect. trigger "out" event if necessary
                
if(this.containers[i].containerCache.over) {
                    
this.containers[i]._trigger("out"eventthis._uiHash(this));
                    
this.containers[i].containerCache.over 0;
                }
            }

        }

        
// if no intersecting containers found, return
        
if(!innermostContainer) {
            return;
        }

        
// move the item into the container if it's not there already
        
if(this.containers.length === 1) {
            
this.containers[innermostIndex]._trigger("over"eventthis._uiHash(this));
            
this.containers[innermostIndex].containerCache.over 1;
        } else {

            
//When entering a new container, we will find the item with the least distance and append our item near it
            
dist 10000;
            
itemWithLeastDistance null;
            
posProperty this.containers[innermostIndex].floating "left" "top";
            
sizeProperty this.containers[innermostIndex].floating "width" "height";
            
base this.positionAbs[posProperty] + this.offset.click[posProperty];
            for (
this.items.length 1>= 0j--) {
                if(!$.
contains(this.containers[innermostIndex].element[0], this.items[j].item[0])) {
                    continue;
                }
                if(
this.items[j].item[0] === this.currentItem[0]) {
                    continue;
                }
                
cur this.items[j].item.offset()[posProperty];
                
nearBottom false;
                if(
Math.abs(cur base) > Math.abs(cur this.items[j][sizeProperty] - base)){
                    
nearBottom true;
                    
cur += this.items[j][sizeProperty];
                }

                if(
Math.abs(cur base) < dist) {
                    
dist Math.abs(cur base); itemWithLeastDistance this.items[j];
                    
this.direction nearBottom "up""down";
                }
            }

            
//Check if dropOnEmpty is enabled
            
if(!itemWithLeastDistance && !this.options.dropOnEmpty) {
                return;
            }

            
this.currentContainer this.containers[innermostIndex];
            
itemWithLeastDistance this._rearrange(eventitemWithLeastDistancenulltrue) : this._rearrange(eventnullthis.containers[innermostIndex].elementtrue);
            
this._trigger("change"eventthis._uiHash());
            
this.containers[innermostIndex]._trigger("change"eventthis._uiHash(this));

            
//Update the placeholder
            
this.options.placeholder.update(this.currentContainerthis.placeholder);

            
this.containers[innermostIndex]._trigger("over"eventthis._uiHash(this));
            
this.containers[innermostIndex].containerCache.over 1;
        }


    },

    
_createHelper: function(event) {

        var 
this.options,
            
helper = $.isFunction(o.helper) ? $(o.helper.apply(this.element[0], [eventthis.currentItem])) : (o.helper === "clone" this.currentItem.clone() : this.currentItem);

        
//Add the helper to the DOM if that didn't happen already
        
if(!helper.parents("body").length) {
            $(
o.appendTo !== "parent" o.appendTo this.currentItem[0].parentNode)[0].appendChild(helper[0]);
        }

        if(
helper[0] === this.currentItem[0]) {
            
this._storedCSS = { widththis.currentItem[0].style.widthheightthis.currentItem[0].style.heightpositionthis.currentItem.css("position"), topthis.currentItem.css("top"), leftthis.currentItem.css("left") };
        }

        if(!
helper[0].style.width || o.forceHelperSize) {
            
helper.width(this.currentItem.width());
        }
        if(!
helper[0].style.height || o.forceHelperSize) {
            
helper.height(this.currentItem.height());
        }

        return 
helper;

    },

    
_adjustOffsetFromHelper: function(obj) {
        if (
typeof obj === "string") {
            
obj obj.split(" ");
        }
        if ($.
isArray(obj)) {
            
obj = {left: +obj[0], top: +obj[1] || 0};
        }
        if (
"left" in obj) {
            
this.offset.click.left obj.left this.margins.left;
        }
        if (
"right" in obj) {
            
this.offset.click.left this.helperProportions.width obj.right this.margins.left;
        }
        if (
"top" in obj) {
            
this.offset.click.top obj.top this.margins.top;
        }
        if (
"bottom" in obj) {
            
this.offset.click.top this.helperProportions.height obj.bottom this.margins.top;
        }
    },

    
_getParentOffset: function() {


        
//Get the offsetParent and cache its position
        
this.offsetParent this.helper.offsetParent();
        var 
po this.offsetParent.offset();

        
// This is a special case where we need to modify a offset calculated on start, since the following happened:
        // 1. The position of the helper is absolute, so it's position is calculated based on the next positioned parent
        // 2. The actual offset parent is a child of the scroll parent, and the scroll parent isn't the document, which means that
        //    the scroll is included in the initial calculation of the offset of the parent, and never recalculated upon drag
        
if(this.cssPosition === "absolute" && this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) {
            
po.left += this.scrollParent.scrollLeft();
            
po.top += this.scrollParent.scrollTop();
        }

        
// This needs to be actually done for all browsers, since pageX/pageY includes this information
        // with an ugly IE fix
        
if( this.offsetParent[0] === document.body || (this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() === "html" && $.ui.ie)) {
            
po = { top0left};
        }

        return {
            
toppo.top + (parseInt(this.offsetParent.css("borderTopWidth"),10) || 0),
            
leftpo.left + (parseInt(this.offsetParent.css("borderLeftWidth"),10) || 0)
        };

    },

    
_getRelativeOffset: function() {

        if(
this.cssPosition === "relative") {
            var 
this.currentItem.position();
            return {
                
topp.top - (parseInt(this.helper.css("top"),10) || 0) + this.scrollParent.scrollTop(),
                
leftp.left - (parseInt(this.helper.css("left"),10) || 0) + this.scrollParent.scrollLeft()
            };
        } else {
            return { 
top0left};
        }

    },

    
_cacheMargins: function() {
        
this.margins = {
            
left: (parseInt(this.currentItem.css("marginLeft"),10) || 0),
            
top: (parseInt(this.currentItem.css("marginTop"),10) || 0)
        };
    },

    
_cacheHelperProportions: function() {
        
this.helperProportions = {
            
widththis.helper.outerWidth(),
            
heightthis.helper.outerHeight()
        };
    },

    
_setContainment: function() {

        var 
cecoover,
            
this.options;
        if(
o.containment === "parent") {
            
o.containment this.helper[0].parentNode;
        }
        if(
o.containment === "document" || o.containment === "window") {
            
this.containment = [
                
this.offset.relative.left this.offset.parent.left,
                
this.offset.relative.top this.offset.parent.top,
                $(
o.containment === "document" document window).width() - this.helperProportions.width this.margins.left,
                ($(
o.containment === "document" document window).height() || document.body.parentNode.scrollHeight) - this.helperProportions.height this.margins.top
            
];
        }

        if(!(/^(
document|window|parent)$/).test(o.containment)) {
            
ce = $(o.containment)[0];
            
co = $(o.containment).offset();
            
over = ($(ce).css("overflow") !== "hidden");

            
this.containment = [
                
co.left + (parseInt($(ce).css("borderLeftWidth"),10) || 0) + (parseInt($(ce).css("paddingLeft"),10) || 0) - this.margins.left,
                
co.top + (parseInt($(ce).css("borderTopWidth"),10) || 0) + (parseInt($(ce).css("paddingTop"),10) || 0) - this.margins.top,
                
co.left+(over Math.max(ce.scrollWidth,ce.offsetWidth) : ce.offsetWidth) - (parseInt($(ce).css("borderLeftWidth"),10) || 0) - (parseInt($(ce).css("paddingRight"),10) || 0) - this.helperProportions.width this.margins.left,
                
co.top+(over Math.max(ce.scrollHeight,ce.offsetHeight) : ce.offsetHeight) - (parseInt($(ce).css("borderTopWidth"),10) || 0) - (parseInt($(ce).css("paddingBottom"),10) || 0) - this.helperProportions.height this.margins.top
            
];
        }

    },

    
_convertPositionTo: function(dpos) {

        if(!
pos) {
            
pos this.position;
        }
        var 
mod === "absolute" : -1,
            
scroll this.cssPosition === "absolute" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent this.scrollParent,
            
scrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);

        return {
            
top: (
                
pos.top    +                                                                // The absolute mouse position
                
this.offset.relative.top mod +                                        // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.top mod -                                            // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode scroll.scrollTop() ) ) * mod)
            ),
            
left: (
                
pos.left +                                                                // The absolute mouse position
                
this.offset.relative.left mod +                                        // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.left mod    -                                        // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : scrollIsRootNode scroll.scrollLeft() ) * mod)
            )
        };

    },

    
_generatePosition: function(event) {

        var 
topleft,
            
this.options,
            
pageX event.pageX,
            
pageY event.pageY,
            
scroll this.cssPosition === "absolute" && !(this.scrollParent[0] !== document && $.contains(this.scrollParent[0], this.offsetParent[0])) ? this.offsetParent this.scrollParentscrollIsRootNode = (/(html|body)/i).test(scroll[0].tagName);

        
// This is another very weird special case that only happens for relative elements:
        // 1. If the css position is relative
        // 2. and the scroll parent is the document or similar to the offset parent
        // we have to refresh the relative offset during the scroll so there are no jumps
        
if(this.cssPosition === "relative" && !(this.scrollParent[0] !== document && this.scrollParent[0] !== this.offsetParent[0])) {
            
this.offset.relative this._getRelativeOffset();
        }

        
/*
         * - Position constraining -
         * Constrain the position to a mix of grid, containment.
         */

        
if(this.originalPosition) { //If we are not dragging yet, we won't check for options

            
if(this.containment) {
                if(
event.pageX this.offset.click.left this.containment[0]) {
                    
pageX this.containment[0] + this.offset.click.left;
                }
                if(
event.pageY this.offset.click.top this.containment[1]) {
                    
pageY this.containment[1] + this.offset.click.top;
                }
                if(
event.pageX this.offset.click.left this.containment[2]) {
                    
pageX this.containment[2] + this.offset.click.left;
                }
                if(
event.pageY this.offset.click.top this.containment[3]) {
                    
pageY this.containment[3] + this.offset.click.top;
                }
            }

            if(
o.grid) {
                
top this.originalPageY Math.round((pageY this.originalPageY) / o.grid[1]) * o.grid[1];
                
pageY this.containment ? ( (top this.offset.click.top >= this.containment[1] && top this.offset.click.top <= this.containment[3]) ? top : ((top this.offset.click.top >= this.containment[1]) ? top o.grid[1] : top o.grid[1])) : top;

                
left this.originalPageX Math.round((pageX this.originalPageX) / o.grid[0]) * o.grid[0];
                
pageX this.containment ? ( (left this.offset.click.left >= this.containment[0] && left this.offset.click.left <= this.containment[2]) ? left : ((left this.offset.click.left >= this.containment[0]) ? left o.grid[0] : left o.grid[0])) : left;
            }

        }

        return {
            
top: (
                
pageY -                                                                // The absolute mouse position
                
this.offset.click.top -                                                    // Click offset (relative to the element)
                
this.offset.relative.top    -                                            // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.top +                                                // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollTop() : ( scrollIsRootNode scroll.scrollTop() ) ))
            ),
            
left: (
                
pageX -                                                                // The absolute mouse position
                
this.offset.click.left -                                                // Click offset (relative to the element)
                
this.offset.relative.left    -                                            // Only for relative positioned nodes: Relative offset from element to offset parent
                
this.offset.parent.left +                                                // The offsetParent's offset without borders (offset + border)
                
( ( this.cssPosition === "fixed" ? -this.scrollParent.scrollLeft() : scrollIsRootNode scroll.scrollLeft() ))
            )
        };

    },

    
_rearrange: function(eventiahardRefresh) {

        
a[0].appendChild(this.placeholder[0]) : i.item[0].parentNode.insertBefore(this.placeholder[0], (this.direction === "down" i.item[0] : i.item[0].nextSibling));

        
//Various things done here to improve the performance:
        // 1. we create a setTimeout, that calls refreshPositions
        // 2. on the instance, we have a counter variable, that get's higher after every append
        // 3. on the local scope, we copy the counter variable, and check in the timeout, if it's still the same
        // 4. this lets only the last addition to the timeout stack through
        
this.counter this.counter ? ++this.counter 1;
        var 
counter this.counter;

        
this._delay(function() {
            if(
counter === this.counter) {
                
this.refreshPositions(!hardRefresh); //Precompute after each DOM insertion, NOT on mousemove
            
}
        });

    },

    
_clear: function(eventnoPropagation) {

        
this.reverting false;
        
// We delay all events that have to be triggered to after the point where the placeholder has been removed and
        // everything else normalized again
        
var i,
            
delayedTriggers = [];

        
// We first have to update the dom position of the actual currentItem
        // Note: don't do it if the current item is already removed (by a user), or it gets reappended (see #4088)
        
if(!this._noFinalSort && this.currentItem.parent().length) {
            
this.placeholder.before(this.currentItem);
        }
        
this._noFinalSort null;

        if(
this.helper[0] === this.currentItem[0]) {
            for(
i in this._storedCSS) {
                if(
this._storedCSS[i] === "auto" || this._storedCSS[i] === "static") {
                    
this._storedCSS[i] = "";
                }
            }
            
this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper");
        } else {
            
this.currentItem.show();
        }

        if(
this.fromOutside && !noPropagation) {
            
delayedTriggers.push(function(event) { this._trigger("receive"eventthis._uiHash(this.fromOutside)); });
        }
        if((
this.fromOutside || this.domPosition.prev !== this.currentItem.prev().not(".ui-sortable-helper")[0] || this.domPosition.parent !== this.currentItem.parent()[0]) && !noPropagation) {
            
delayedTriggers.push(function(event) { this._trigger("update"eventthis._uiHash()); }); //Trigger update callback if the DOM position has changed
        
}

        
// Check if the items Container has Changed and trigger appropriate
        // events.
        
if (this !== this.currentContainer) {
            if(!
noPropagation) {
                
delayedTriggers.push(function(event) { this._trigger("remove"eventthis._uiHash()); });
                
delayedTriggers.push((function(c) { return function(event) { c._trigger("receive"eventthis._uiHash(this)); };  }).call(thisthis.currentContainer));
                
delayedTriggers.push((function(c) { return function(event) { c._trigger("update"eventthis._uiHash(this));  }; }).call(thisthis.currentContainer));
            }
        }


        
//Post events to containers
        
for (this.containers.length 1>= 0i--){
            if(!
noPropagation) {
                
delayedTriggers.push((function(c) { return function(event) { c._trigger("deactivate"eventthis._uiHash(this)); };  }).call(thisthis.containers[i]));
            }
            if(
this.containers[i].containerCache.over) {
                
delayedTriggers.push((function(c) { return function(event) { c._trigger("out"eventthis._uiHash(this)); };  }).call(thisthis.containers[i]));
                
this.containers[i].containerCache.over 0;
            }
        }

        
//Do what was originally in plugins
        
if(this._storedCursor) {
            $(
"body").css("cursor"this._storedCursor);
        }
        if(
this._storedOpacity) {
            
this.helper.css("opacity"this._storedOpacity);
        }
        if(
this._storedZIndex) {
            
this.helper.css("zIndex"this._storedZIndex === "auto" "" this._storedZIndex);
        }

        
this.dragging false;
        if(
this.cancelHelperRemoval) {
            if(!
noPropagation) {
                
this._trigger("beforeStop"eventthis._uiHash());
                for (
i=0delayedTriggers.lengthi++) {
                    
delayedTriggers[i].call(thisevent);
                } 
//Trigger all delayed events
                
this._trigger("stop"eventthis._uiHash());
            }

            
this.fromOutside false;
            return 
false;
        }

        if(!
noPropagation) {
            
this._trigger("beforeStop"eventthis._uiHash());
        }

        
//$(this.placeholder[0]).remove(); would have been the jQuery way - unfortunately, it unbinds ALL events from the original node!
        
this.placeholder[0].parentNode.removeChild(this.placeholder[0]);

        if(
this.helper[0] !== this.currentItem[0]) {
            
this.helper.remove();
        }
        
this.helper null;

        if(!
noPropagation) {
            for (
i=0delayedTriggers.lengthi++) {
                
delayedTriggers[i].call(thisevent);
            } 
//Trigger all delayed events
            
this._trigger("stop"eventthis._uiHash());
        }

        
this.fromOutside false;
        return 
true;

    },

    
_trigger: function() {
        if ($.
Widget.prototype._trigger.apply(thisarguments) === false) {
            
this.cancel();
        }
    },

    
_uiHash: function(_inst) {
        var 
inst _inst || this;
        return {
            
helperinst.helper,
            
placeholderinst.placeholder || $([]),
            
positioninst.position,
            
originalPositioninst.originalPosition,
            
offsetinst.positionAbs,
            
iteminst.currentItem,
            
sender_inst _inst.element null
        
};
    }

});

})(
jQuery);
(function( $, 
undefined ) {

// number of pages in a slider
// (how many times can you page up/down to go through the whole range)
var numPages 5;

$.
widget"ui.slider", $.ui.mouse, {
    
version"1.10.0",
    
widgetEventPrefix"slide",

    
options: {
        
animatefalse,
        
distance0,
        
max100,
        
min0,
        
orientation"horizontal",
        
rangefalse,
        
step1,
        
value0,
        
valuesnull,

        
// callbacks
        
changenull,
        
slidenull,
        
startnull,
        
stopnull
    
},

    
_create: function() {
        var 
ihandleCount,
            
this.options,
            
existingHandles this.element.find".ui-slider-handle" ).addClass"ui-state-default ui-corner-all" ),
            
handle "<a class='ui-slider-handle ui-state-default ui-corner-all' href='#'></a>",
            
handles = [];

        
this._keySliding false;
        
this._mouseSliding false;
        
this._animateOff true;
        
this._handleIndex null;
        
this._detectOrientation();
        
this._mouseInit();

        
this.element
            
.addClass"ui-slider" +
                
" ui-slider-" this.orientation +
                
" ui-widget" +
                
" ui-widget-content" +
                
" ui-corner-all");

        
this.range = $([]);

        if ( 
o.range ) {
            if ( 
o.range === true ) {
                if ( !
o.values ) {
                    
o.values = [ this._valueMin(), this._valueMin() ];
                } else if ( 
o.values.length && o.values.length !== ) {
                    
o.values = [ o.values[0], o.values[0] ];
                } else if ( $.
isArrayo.values ) ) {
                    
o.values o.values.slice(0);
                }
            }

            
this.range = $( "<div></div>" )
                .
appendTothis.element )
                .
addClass"ui-slider-range" +
                
// note: this isn't the most fittingly semantic framework class for this element,
                // but worked best visually with a variety of themes
                
" ui-widget-header" +
                ( ( 
o.range === "min" || o.range === "max" ) ? " ui-slider-range-" o.range "" ) );
        }

        
handleCount = ( o.values && o.values.length ) || 1;

        for ( 
existingHandles.lengthhandleCounti++ ) {
            
handles.pushhandle );
        }

        
this.handles existingHandles.add( $( handles.join"" ) ).appendTothis.element ) );

        
this.handle this.handles.eq);

        
this.handles.addthis.range ).filter"a" )
            .
click(function( event ) {
                
event.preventDefault();
            })
            .
mouseenter(function() {
                if ( !
o.disabled ) {
                    $( 
this ).addClass"ui-state-hover" );
                }
            })
            .
mouseleave(function() {
                $( 
this ).removeClass"ui-state-hover" );
            })
            .
focus(function() {
                if ( !
o.disabled ) {
                    $( 
".ui-slider .ui-state-focus" ).removeClass"ui-state-focus" );
                    $( 
this ).addClass"ui-state-focus" );
                } else {
                    $( 
this ).blur();
                }
            })
            .
blur(function() {
                $( 
this ).removeClass"ui-state-focus" );
            });

        
this.handles.each(function( ) {
            $( 
this ).data"ui-slider-handle-index");
        });

        
this._setOption"disabled"o.disabled );

        
this._onthis.handlesthis._handleEvents );

        
this._refreshValue();

        
this._animateOff false;
    },

    
_destroy: function() {
        
this.handles.remove();
        
this.range.remove();

        
this.element
            
.removeClass"ui-slider" +
                
" ui-slider-horizontal" +
                
" ui-slider-vertical" +
                
" ui-widget" +
                
" ui-widget-content" +
                
" ui-corner-all" );

        
this._mouseDestroy();
    },

    
_mouseCapture: function( event ) {
        var 
positionnormValuedistanceclosestHandleindexallowedoffsetmouseOverHandle,
            
that this,
            
this.options;

        if ( 
o.disabled ) {
            return 
false;
        }

        
this.elementSize = {
            
widththis.element.outerWidth(),
            
heightthis.element.outerHeight()
        };
        
this.elementOffset this.element.offset();

        
position = { xevent.pageXyevent.pageY };
        
normValue this._normValueFromMouseposition );
        
distance this._valueMax() - this._valueMin() + 1;
        
this.handles.each(function( ) {
            var 
thisDistance Math.absnormValue that.values(i) );
            if (( 
distance thisDistance ) ||
                ( 
distance === thisDistance &&
                    (
=== that._lastChangedValue || that.values(i) === o.min ))) {
                
distance thisDistance;
                
closestHandle = $( this );
                
index i;
            }
        });

        
allowed this._starteventindex );
        if ( 
allowed === false ) {
            return 
false;
        }
        
this._mouseSliding true;

        
this._handleIndex index;

        
closestHandle
            
.addClass"ui-state-active" )
            .
focus();

        
offset closestHandle.offset();
        
mouseOverHandle = !$( event.target ).parents().addBack().is".ui-slider-handle" );
        
this._clickOffset mouseOverHandle ? { left0top} : {
            
leftevent.pageX offset.left - ( closestHandle.width() / ),
            
topevent.pageY offset.top -
                ( 
closestHandle.height() / ) -
                ( 
parseIntclosestHandle.css("borderTopWidth"), 10 ) || ) -
                ( 
parseIntclosestHandle.css("borderBottomWidth"), 10 ) || 0) +
                ( 
parseIntclosestHandle.css("marginTop"), 10 ) || 0)
        };

        if ( !
this.handles.hasClass"ui-state-hover" ) ) {
            
this._slideeventindexnormValue );
        }
        
this._animateOff true;
        return 
true;
    },

    
_mouseStart: function() {
        return 
true;
    },

    
_mouseDrag: function( event ) {
        var 
position = { xevent.pageXyevent.pageY },
            
normValue this._normValueFromMouseposition );

        
this._slideeventthis._handleIndexnormValue );

        return 
false;
    },

    
_mouseStop: function( event ) {
        
this.handles.removeClass"ui-state-active" );
        
this._mouseSliding false;

        
this._stopeventthis._handleIndex );
        
this._changeeventthis._handleIndex );

        
this._handleIndex null;
        
this._clickOffset null;
        
this._animateOff false;

        return 
false;
    },

    
_detectOrientation: function() {
        
this.orientation = ( this.options.orientation === "vertical" ) ? "vertical" "horizontal";
    },

    
_normValueFromMouse: function( position ) {
        var 
pixelTotal,
            
pixelMouse,
            
percentMouse,
            
valueTotal,
            
valueMouse;

        if ( 
this.orientation === "horizontal" ) {
            
pixelTotal this.elementSize.width;
            
pixelMouse position.this.elementOffset.left - ( this._clickOffset this._clickOffset.left );
        } else {
            
pixelTotal this.elementSize.height;
            
pixelMouse position.this.elementOffset.top - ( this._clickOffset this._clickOffset.top );
        }

        
percentMouse = ( pixelMouse pixelTotal );
        if ( 
percentMouse ) {
            
percentMouse 1;
        }
        if ( 
percentMouse ) {
            
percentMouse 0;
        }
        if ( 
this.orientation === "vertical" ) {
            
percentMouse percentMouse;
        }

        
valueTotal this._valueMax() - this._valueMin();
        
valueMouse this._valueMin() + percentMouse valueTotal;

        return 
this._trimAlignValuevalueMouse );
    },

    
_start: function( eventindex ) {
        var 
uiHash = {
            
handlethis.handlesindex ],
            
valuethis.value()
        };
        if ( 
this.options.values && this.options.values.length ) {
            
uiHash.value this.valuesindex );
            
uiHash.values this.values();
        }
        return 
this._trigger"start"eventuiHash );
    },

    
_slide: function( eventindexnewVal ) {
        var 
otherVal,
            
newValues,
            
allowed;

        if ( 
this.options.values && this.options.values.length ) {
            
otherVal this.valuesindex );

            if ( ( 
this.options.values.length === && this.options.range === true ) &&
                    ( ( 
index === && newVal otherVal) || ( index === && newVal otherVal ) )
                ) {
                
newVal otherVal;
            }

            if ( 
newVal !== this.valuesindex ) ) {
                
newValues this.values();
                
newValuesindex ] = newVal;
                
// A slide can be canceled by returning false from the slide callback
                
allowed this._trigger"slide"event, {
                    
handlethis.handlesindex ],
                    
valuenewVal,
                    
valuesnewValues
                
} );
                
otherVal this.valuesindex );
                if ( 
allowed !== false ) {
                    
this.valuesindexnewValtrue );
                }
            }
        } else {
            if ( 
newVal !== this.value() ) {
                
// A slide can be canceled by returning false from the slide callback
                
allowed this._trigger"slide"event, {
                    
handlethis.handlesindex ],
                    
valuenewVal
                
} );
                if ( 
allowed !== false ) {
                    
this.valuenewVal );
                }
            }
        }
    },

    
_stop: function( eventindex ) {
        var 
uiHash = {
            
handlethis.handlesindex ],
            
valuethis.value()
        };
        if ( 
this.options.values && this.options.values.length ) {
            
uiHash.value this.valuesindex );
            
uiHash.values this.values();
        }

        
this._trigger"stop"eventuiHash );
    },

    
_change: function( eventindex ) {
        if ( !
this._keySliding && !this._mouseSliding ) {
            var 
uiHash = {
                
handlethis.handlesindex ],
                
valuethis.value()
            };
            if ( 
this.options.values && this.options.values.length ) {
                
uiHash.value this.valuesindex );
                
uiHash.values this.values();
            }

            
//store the last changed value index for reference when handles overlap
            
this._lastChangedValue index;

            
this._trigger"change"eventuiHash );
        }
    },

    
value: function( newValue ) {
        if ( 
arguments.length ) {
            
this.options.value this._trimAlignValuenewValue );
            
this._refreshValue();
            
this._changenull);
            return;
        }

        return 
this._value();
    },

    
values: function( indexnewValue ) {
        var 
vals,
            
newValues,
            
i;

        if ( 
arguments.length ) {
            
this.options.valuesindex ] = this._trimAlignValuenewValue );
            
this._refreshValue();
            
this._changenullindex );
            return;
        }

        if ( 
arguments.length ) {
            if ( $.
isArrayarguments] ) ) {
                
vals this.options.values;
                
newValues arguments];
                for ( 
0vals.length+= ) {
                    
vals] = this._trimAlignValuenewValues] );
                    
this._changenull);
                }
                
this._refreshValue();
            } else {
                if ( 
this.options.values && this.options.values.length ) {
                    return 
this._valuesindex );
                } else {
                    return 
this.value();
                }
            }
        } else {
            return 
this._values();
        }
    },

    
_setOption: function( keyvalue ) {
        var 
i,
            
valsLength 0;

        if ( $.
isArraythis.options.values ) ) {
            
valsLength this.options.values.length;
        }

        $.
Widget.prototype._setOption.applythisarguments );

        switch ( 
key ) {
            case 
"disabled":
                if ( 
value ) {
                    
this.handles.filter".ui-state-focus" ).blur();
                    
this.handles.removeClass"ui-state-hover" );
                    
this.handles.prop"disabled"true );
                } else {
                    
this.handles.prop"disabled"false );
                }
                break;
            case 
"orientation":
                
this._detectOrientation();
                
this.element
                    
.removeClass"ui-slider-horizontal ui-slider-vertical" )
                    .
addClass"ui-slider-" this.orientation );
                
this._refreshValue();
                break;
            case 
"value":
                
this._animateOff true;
                
this._refreshValue();
                
this._changenull);
                
this._animateOff false;
                break;
            case 
"values":
                
this._animateOff true;
                
this._refreshValue();
                for ( 
0valsLength+= ) {
                    
this._changenull);
                }
                
this._animateOff false;
                break;
            case 
"min":
            case 
"max":
                
this._animateOff true;
                
this._refreshValue();
                
this._animateOff false;
                break;
        }
    },

    
//internal value getter
    // _value() returns value trimmed by min and max, aligned by step
    
_value: function() {
        var 
val this.options.value;
        
val this._trimAlignValueval );

        return 
val;
    },

    
//internal values getter
    // _values() returns array of values trimmed by min and max, aligned by step
    // _values( index ) returns single value trimmed by min and max, aligned by step
    
_values: function( index ) {
        var 
val,
            
vals,
            
i;

        if ( 
arguments.length ) {
            
val this.options.valuesindex ];
            
val this._trimAlignValueval );

            return 
val;
        } else {
            
// .slice() creates a copy of the array
            // this copy gets trimmed by min and max and then returned
            
vals this.options.values.slice();
            for ( 
0vals.lengthi+= 1) {
                
vals] = this._trimAlignValuevals] );
            }

            return 
vals;
        }
    },

    
// returns the step-aligned value that val is closest to, between (inclusive) min and max
    
_trimAlignValue: function( val ) {
        if ( 
val <= this._valueMin() ) {
            return 
this._valueMin();
        }
        if ( 
val >= this._valueMax() ) {
            return 
this._valueMax();
        }
        var 
step = ( this.options.step ) ? this.options.step 1,
            
valModStep = (val this._valueMin()) % step,
            
alignValue val valModStep;

        if ( 
Math.abs(valModStep) * >= step ) {
            
alignValue += ( valModStep ) ? step : ( -step );
        }

        
// Since JavaScript has problems with large floats, round
        // the final value to 5 digits after the decimal point (see #4124)
        
return parseFloatalignValue.toFixed(5) );
    },

    
_valueMin: function() {
        return 
this.options.min;
    },

    
_valueMax: function() {
        return 
this.options.max;
    },

    
_refreshValue: function() {
        var 
lastValPercentvalPercentvaluevalueMinvalueMax,
            
oRange this.options.range,
            
this.options,
            
that this,
            
animate = ( !this._animateOff ) ? o.animate false,
            
_set = {};

        if ( 
this.options.values && this.options.values.length ) {
            
this.handles.each(function( ) {
                
valPercent = ( that.values(i) - that._valueMin() ) / ( that._valueMax() - that._valueMin() ) * 100;
                
_setthat.orientation === "horizontal" "left" "bottom" ] = valPercent "%";
                $( 
this ).stop1)[ animate "animate" "css" ]( _seto.animate );
                if ( 
that.options.range === true ) {
                    if ( 
that.orientation === "horizontal" ) {
                        if ( 
=== ) {
                            
that.range.stop1)[ animate "animate" "css" ]( { leftvalPercent "%" }, o.animate );
                        }
                        if ( 
=== ) {
                            
that.rangeanimate "animate" "css" ]( { width: ( valPercent lastValPercent ) + "%" }, { queuefalsedurationo.animate } );
                        }
                    } else {
                        if ( 
=== ) {
                            
that.range.stop1)[ animate "animate" "css" ]( { bottom: ( valPercent ) + "%" }, o.animate );
                        }
                        if ( 
=== ) {
                            
that.rangeanimate "animate" "css" ]( { height: ( valPercent lastValPercent ) + "%" }, { queuefalsedurationo.animate } );
                        }
                    }
                }
                
lastValPercent valPercent;
            });
        } else {
            
value this.value();
            
valueMin this._valueMin();
            
valueMax this._valueMax();
            
valPercent = ( valueMax !== valueMin ) ?
                    ( 
value valueMin ) / ( valueMax valueMin ) * 100 :
                    
0;
            
_setthis.orientation === "horizontal" "left" "bottom" ] = valPercent "%";
            
this.handle.stop1)[ animate "animate" "css" ]( _seto.animate );

            if ( 
oRange === "min" && this.orientation === "horizontal" ) {
                
this.range.stop1)[ animate "animate" "css" ]( { widthvalPercent "%" }, o.animate );
            }
            if ( 
oRange === "max" && this.orientation === "horizontal" ) {
                
this.rangeanimate "animate" "css" ]( { width: ( 100 valPercent ) + "%" }, { queuefalsedurationo.animate } );
            }
            if ( 
oRange === "min" && this.orientation === "vertical" ) {
                
this.range.stop1)[ animate "animate" "css" ]( { heightvalPercent "%" }, o.animate );
            }
            if ( 
oRange === "max" && this.orientation === "vertical" ) {
                
this.rangeanimate "animate" "css" ]( { height: ( 100 valPercent ) + "%" }, { queuefalsedurationo.animate } );
            }
        }
    },

    
_handleEvents: {
        
keydown: function( event ) {
            
/*jshint maxcomplexity:25*/
            
var allowedcurValnewValstep,
                
index = $( event.target ).data"ui-slider-handle-index" );

            switch ( 
event.keyCode ) {
                case $.
ui.keyCode.HOME:
                case $.
ui.keyCode.END:
                case $.
ui.keyCode.PAGE_UP:
                case $.
ui.keyCode.PAGE_DOWN:
                case $.
ui.keyCode.UP:
                case $.
ui.keyCode.RIGHT:
                case $.
ui.keyCode.DOWN:
                case $.
ui.keyCode.LEFT:
                    
event.preventDefault();
                    if ( !
this._keySliding ) {
                        
this._keySliding true;
                        $( 
event.target ).addClass"ui-state-active" );
                        
allowed this._starteventindex );
                        if ( 
allowed === false ) {
                            return;
                        }
                    }
                    break;
            }

            
step this.options.step;
            if ( 
this.options.values && this.options.values.length ) {
                
curVal newVal this.valuesindex );
            } else {
                
curVal newVal this.value();
            }

            switch ( 
event.keyCode ) {
                case $.
ui.keyCode.HOME:
                    
newVal this._valueMin();
                    break;
                case $.
ui.keyCode.END:
                    
newVal this._valueMax();
                    break;
                case $.
ui.keyCode.PAGE_UP:
                    
newVal this._trimAlignValuecurVal + ( (this._valueMax() - this._valueMin()) / numPages ) );
                    break;
                case $.
ui.keyCode.PAGE_DOWN:
                    
newVal this._trimAlignValuecurVal - ( (this._valueMax() - this._valueMin()) / numPages ) );
                    break;
                case $.
ui.keyCode.UP:
                case $.
ui.keyCode.RIGHT:
                    if ( 
curVal === this._valueMax() ) {
                        return;
                    }
                    
newVal this._trimAlignValuecurVal step );
                    break;
                case $.
ui.keyCode.DOWN:
                case $.
ui.keyCode.LEFT:
                    if ( 
curVal === this._valueMin() ) {
                        return;
                    }
                    
newVal this._trimAlignValuecurVal step );
                    break;
            }

            
this._slideeventindexnewVal );
        },
        
keyup: function( event ) {
            var 
index = $( event.target ).data"ui-slider-handle-index" );

            if ( 
this._keySliding ) {
                
this._keySliding false;
                
this._stopeventindex );
                
this._changeeventindex );
                $( 
event.target ).removeClass"ui-state-active" );
            }
        }
    }

});

}(
jQuery));
?>
Онлайн: 0
Реклама