Вход Регистрация
Файл: ui/js/jquery-ui-1.9.2.custom.js
Строк: 4879
<?php
/*! jQuery UI - v1.9.2 - 2013-01-07
* 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
* 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.9.2",

    
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().andSelf().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
$(function() {
    var 
body document.body,
        
div body.appendChilddiv document.createElement"div" ) );

    
// access offsetHeight before setting the style to prevent a layout bug
    // in IE 9 which causes the element to continue to take up space even
    // after it is removed from the DOM (#8026)
    
div.offsetHeight;

    $.
extenddiv.style, {
        
minHeight"100px",
        
height"auto",
        
padding0,
        
borderWidth0
    
});

    $.
support.minHeight div.offsetHeight === 100;
    $.
support.selectstart "onselectstart" in div;

    
// set display to none to avoid a layout bug in IE
    // http://dev.jquery.com/ticket/4014
    
body.removeChilddiv ).style.display "none";
});

// 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.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

(function() {
    var 
uaMatch = /msie ([w.]+)/.execnavigator.userAgent.toLowerCase() ) || [];
    $.
ui.ie uaMatch.length true false;
    $.
ui.ie6 parseFloatuaMatch], 10 ) === 6;
})();

$.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 );
                }
            }
        }
    },

    
contains: $.contains,

    
// 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;
    },

    
// these are odd functions, fix the API or move into individual plugins
    
isOverAxis: function( xreferencesize ) {
        
//Determines when x coordinate is over "b" element axis
        
return ( reference ) && ( < ( reference size ) );
    },
    
isOver: function( yxtopleftheightwidth ) {
        
//Determines when x, y coordinates is over "b" element
        
return $.ui.isOverAxisytopheight ) && $.ui.isOverAxisxleftwidth );
    }
});

})( 
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,
        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 ) ) {
            
prototypeprop ] = (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
    
}, prototype, {
        
constructorconstructor,
        namespace: namespace,
        
widgetNamename,
        
// TODO remove widgetBaseClass, see #8155
        
widgetBaseClassfullName,
        
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 ) {
            
// 1.9 BC for #7810
            // TODO remove dual storage
            
$.dataelementthis.widgetNamethis );
            $.
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 ] || $.uiBackCompat !== false && $.effectseffectName ] ) ) {
            
elementmethod ]( options );
        } else if ( 
effectName !== method && elementeffectName ] ) {
            
elementeffectName ]( options.durationoptions.easingcallback );
        } else {
            
element.queue(function( next ) {
                $( 
this )[ method ]();
                if ( 
callback ) {
                    
callback.callelement] );
                }
                
next();
            });
        }
    };
});

// DEPRECATED
if ( $.uiBackCompat !== false ) {
    $.
Widget.prototype._getCreateOptions = function() {
        return $.
metadata && $.metadata.getthis.element[0] )[ this.widgetName ];
    };
}

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

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

$.
widget("ui.mouse", {
    
version"1.9.2",
    
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 >= 9) && !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.9.2",
    
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
    
},
    
_create: function() {

        if (
this.options.helper == 'original' && !(/^(?:r|a|f)/).test(this.element.css("position")))
            
this.element[0].style.position 'relative';

        (
this.options.addClasses && this.element.addClass("ui-draggable"));
        (
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).is('.ui-resizable-handle'))
            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 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)
        
var element this.element[0], elementInDom false;
        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))) {
            var 
that this;
            $(
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("*")
            .
andSelf()
            .
each(function() {
                if(
this == event.targethandle true;
            });

        return 
handle;

    },

    
_createHelper: function(event) {

        var 
this.options;
        var 
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();
        }

        if((
this.offsetParent[0] == document.body//This needs to be actually done for all browsers, since pageX/pageY includes this information
        
|| (this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() == 'html' && $.ui.ie)) //Ugly IE fix
            
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 
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) {
            var 
= $(o.containment);
            var 
ce c[0]; if(!ce) return;
            var 
co c.offset();
            var 
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(!
pospos this.position;
        var 
mod == "absolute" : -1;
        var 
this.optionsscroll 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 
this.optionsscroll 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);
        var 
pageX event.pageX;
        var 
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
            
var containment;
            if(
this.containment) {
            if (
this.relative_container){
                var 
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)
                
var 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;

                var 
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.cancelHelperRemovalthis.helper.remove();
        
//if($.ui.ddmanager) $.ui.ddmanager.current = null;
        
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]);
        if(
type == "drag"this.positionAbs this._convertPositionTo("absolute"); //The absolute position has to be recalculated after plugins
        
return $.Widget.prototype._trigger.call(thistypeeventui);
    },

    
plugins: {},

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

});

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

        var 
inst = $(this).data("draggable"), inst.options,
            
uiSortable = $.extend({}, ui, { iteminst.element });
        
inst.sortables = [];
        $(
o.connectToSortable).each(function() {
            var 
sortable = $.data(this'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("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.shouldRevertthis.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("draggable"), that this;

        var 
checkPos = function(o) {
            var 
dyClick this.offset.click.topdxClick this.offset.click.left;
            var 
helperTop this.positionAbs.tophelperLeft this.positionAbs.left;
            var 
itemHeight o.heightitemWidth o.width;
            var 
itemTop o.topitemLeft o.left;

            return $.
ui.isOver(helperTop dyClickhelperLeft dxClickitemTopitemLeftitemHeightitemWidth);
        };

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

            var 
innermostIntersecting false;
            var 
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("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.currentItemthis.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.placeholderthis.instance.placeholder.remove();

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

            };

        });

    }
});

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

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

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

        var 
= $(this).data("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(eventui) {

        var 
= $(this).data("draggable"), i.options;
        
i.snapElements = [];

        $(
o.snap.constructor != String ? ( o.snap.items || ':data(draggable)' ) : o.snap).each(function() {
            var 
$t = $(this); var $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 
inst = $(this).data("draggable"), inst.options;
        var 
o.snapTolerance;

        var 
x1 ui.offset.leftx2 x1 inst.helperProportions.width,
            
y1 ui.offset.topy2 y1 inst.helperProportions.height;

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

            var 
inst.snapElements[i].leftinst.snapElements[i].width,
                
inst.snapElements[i].topinst.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') {
                var 
ts Math.abs(y2) <= d;
                var 
bs Math.abs(y1) <= d;
                var 
ls Math.abs(x2) <= d;
                var 
rs Math.abs(x1) <= d;
                if(
tsui.position.top inst._convertPositionTo("relative", { topinst.helperProportions.heightleft}).top inst.margins.top;
                if(
bsui.position.top inst._convertPositionTo("relative", { topbleft}).top inst.margins.top;
                if(
lsui.position.left inst._convertPositionTo("relative", { top0leftinst.helperProportions.width }).left inst.margins.left;
                if(
rsui.position.left inst._convertPositionTo("relative", { top0left}).left inst.margins.left;
            }

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

            if(
o.snapMode != 'outer') {
                var 
ts Math.abs(y1) <= d;
                var 
bs Math.abs(y2) <= d;
                var 
ls Math.abs(x1) <= d;
                var 
rs Math.abs(x2) <= d;
                if(
tsui.position.top inst._convertPositionTo("relative", { toptleft}).top inst.margins.top;
                if(
bsui.position.top inst._convertPositionTo("relative", { topinst.helperProportions.heightleft}).top inst.margins.top;
                if(
lsui.position.left inst._convertPositionTo("relative", { top0left}).left inst.margins.left;
                if(
rsui.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(eventui) {

        var 
= $(this).data("draggable").options;

        var 
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; }

        var 
min parseInt(group[0].style.zIndex) || 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("draggable").options;
        if(
t.css("zIndex")) o._zIndex t.css("zIndex");
        
t.css('zIndex'o.zIndex);
    },
    
stop: function(eventui) {
        var 
= $(this).data("draggable").options;
        if(
o._zIndex) $(ui.helper).css('zIndex'o._zIndex);
    }
});

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

$.
widget("ui.droppable", {
    
version"1.9.2",
    
widgetEventPrefix"drop",
    
options: {
        
accept'*',
        
activeClassfalse,
        
addClassestrue,
        
greedyfalse,
        
hoverClassfalse,
        
scope'default',
        
tolerance'intersect'
    
},
    
_create: function() {

        var 
this.optionsaccept o.accept;
        
this.isover 0this.isout 1;

        
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 
drop = $.ui.ddmanager.droppables[this.options.scope];
        for ( var 
0drop.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.activeClassthis.element.addClass(this.options.activeClass);
        (
draggable && this._trigger('activate'eventthis.ui(draggable)));
    },

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

    
_over: function(event) {

        var 
draggable = $.ui.ddmanager.current;
        if (!
draggable || (draggable.currentItem || draggable.element)[0] == this.element[0]) return; // Bail if draggable and droppable are same element

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

    },

    
_out: function(event) {

        var 
draggable = $.ui.ddmanager.current;
        if (!
draggable || (draggable.currentItem || draggable.element)[0] == this.element[0]) return; // Bail if draggable and droppable are same element

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

    },

    
_drop: function(event,custom) {

        var 
draggable custom || $.ui.ddmanager.current;
        if (!
draggable || (draggable.currentItem || draggable.element)[0] == this.element[0]) return false// Bail if draggable and droppable are same element

        
var childrenIntersection false;
        
this.element.find(":data(droppable)").not(".ui-draggable-dragging").each(function() {
            var 
inst = $.data(this'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.activeClassthis.element.removeClass(this.options.activeClass);
            if(
this.options.hoverClassthis.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 
x1 = (draggable.positionAbs || draggable.position.absolute).leftx2 x1 draggable.helperProportions.width,
        
y1 = (draggable.positionAbs || draggable.position.absolute).topy2 y1 draggable.helperProportions.height;
    var 
droppable.offset.leftdroppable.proportions.width,
        
droppable.offset.topdroppable.proportions.height;

    switch (
toleranceMode) {
        case 
'fit':
            return (
<= x1 && x2 <= r
                
&& <= y1 && y2 <= b);
            break;
        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
            
break;
        case 
'pointer':
            var 
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),
                
isOver = $.ui.isOver(draggableTopdraggableLefttldroppable.proportions.heightdroppable.proportions.width);
            return 
isOver;
            break;
        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
                
);
            break;
        default:
            return 
false;
            break;
        }

};

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

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

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

            if(
m[i].options.disabled || (&& !m[i].accept.call(m[i].element[0],(t.currentItem || t.element)))) continue;    //No disabled and non-accepted
            
for (var j=0< list.lengthj++) { if(list[j] == m[i].element[0]) { m[i].proportions.height 0; continue droppablesLoop; } }; //Filter out elements in the current dragged item
            
m[i].visible m[i].element.css("display") != "none"; if(!m[i].visible) continue;                                     //If the element is not visible, continue

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

            
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 1this.isover 0;
                
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 
intersects = $.ui.intersect(draggablethisthis.options.tolerance);

            var 
= !intersects && this.isover == 'isout' : (intersects && this.isover == 'isover' null);
            if(!
c) return;

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

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

            
// we just moved into a greedy child
            
if (parentInstance && == 'isover') {
                
parentInstance['isover'] = 0;
                
parentInstance['isout'] = 1;
                
parentInstance._out.call(parentInstanceevent);
            }

            
this[c] = 1this[== 'isout' 'isover' 'isout'] = 0;
            
this[== "isover" "_over" "_out"].call(thisevent);

            
// we just moved out of a greedy child
            
if (parentInstance && == 'isout') {
                
parentInstance['isout'] = 0;
                
parentInstance['isover'] = 1;
                
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 ) {

$.
widget("ui.sortable", $.ui.mouse, {
    
version"1.9.2",
    
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
    
},
    
_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 
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
        
var currentItem nullnodes = $(event.target).parents().each(function() {
            if($.
data(thisthat.widgetName '-item') == that) {
                
currentItem = $(this);
                return 
false;
            }
        });
        if($.
data(event.targetthat.widgetName '-item') == thatcurrentItem = $(event.target);

        if(!
currentItem) return false;
        if(
this.options.handle && !overrideHandle) {
            var 
validHandle false;

            $(
this.options.handlecurrentItem).find("*").andSelf().each(function() { if(this == event.targetvalidHandle true; });
            if(!
validHandle) return false;
        }

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

    },

    
_mouseStart: function(eventoverrideHandlenoActivation) {

        var 
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 (var 
this.containers.length 1>= 0i--) { this.containers[i]._trigger("activate"eventthis._uiHash(this)); }
        }

        
//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) {

        
//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) {
            var 
this.optionsscrolled false;
            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 (var this.items.length 1>= 0i--) {

            
//Cache variables and intersection, continue if no intersection
            
var 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;

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

                
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;
            var 
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].parentNodethis.placeholder[0].parentNode.removeChild(this.placeholder[0]);
            if(
this.options.helper != "original" && this.helper && this.helper[0].parentNodethis.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);
        var 
str = []; || {};

        $(
items).each(function() {
            var 
res = ($(o.item || this).attr(o.attribute || 'id') || '').match(o.expression || (/(.+)[-=_](.+)/));
            if(
resstr.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);
        var 
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;

        var 
item.left,
            
item.width,
            
item.top,
            
item.height;

        var 
dyClick this.offset.click.top,
            
dxClick this.offset.click.left;

        var 
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') || $.ui.isOverAxis(this.positionAbs.top this.offset.click.topitem.topitem.height),
            
isOverElementWidth = (this.options.axis === 'y') || $.ui.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 = $.ui.isOverAxis(this.positionAbs.top this.offset.click.topitem.top + (item.height/2), item.height),
            
isOverRightHalf = $.ui.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 
items = [];
        var 
queries = [];
        var 
connectWith this._connectWith();

        if(
connectWith && connected) {
            for (var 
connectWith.length 1>= 0i--){
                var 
cur = $(connectWith[i]);
                for (var 
cur.length 1>= 0j--){
                    var 
inst = $.data(cur[j], this.widgetName);
                    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 (var 
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 
items this.items;
        var 
queries = [[$.isFunction(this.options.items) ? this.options.items.call(this.element[0], event, { itemthis.currentItem }) : $(this.options.itemsthis.element), this]];
        var 
connectWith this._connectWith();

        if(
connectWith && this.ready) { //Shouldn't be run the first time through due to massive slow-down
            
for (var connectWith.length 1>= 0i--){
                var 
cur = $(connectWith[i]);
                for (var 
cur.length 1>= 0j--){
                    var 
inst = $.data(cur[j], this.widgetName);
                    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 (var 
queries.length 1>= 0i--) {
            var 
targetData queries[i][1];
            var 
_queries queries[i][0];

            for (var 
j=0queriesLength _queries.lengthqueriesLengthj++) {
                var 
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();
        }

        for (var 
this.items.length 1>= 0i--){
            var 
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;

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

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

            var 
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 (var 
this.containers.length 1>= 0i--){
                var 
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 
that.options;

        if(!
o.placeholder || o.placeholder.constructor == String) {
            var 
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) {

        
// get innermost container that intersects with item
        
var innermostContainer nullinnermostIndex null;


        for (var 
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
            
var dist 10000; var itemWithLeastDistance null;
            var 
posProperty this.containers[innermostIndex].floating 'left' 'top';
            var 
sizeProperty this.containers[innermostIndex].floating 'width' 'height';
            var 
base this.positionAbs[posProperty] + this.offset.click[posProperty];
            for (var 
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;
                var 
cur this.items[j].item.offset()[posProperty];
                var 
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";
                }
            }

            if(!
itemWithLeastDistance && !this.options.dropOnEmpty//Check if dropOnEmpty is enabled
                
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;
        var 
helper = $.isFunction(o.helper) ? $(o.helper.apply(this.element[0], [eventthis.currentItem])) : (o.helper == 'clone' this.currentItem.clone() : this.currentItem);

        if(!
helper.parents('body').length//Add the helper to the DOM if that didn't happen already
            
$(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.forceHelperSizehelper.width(this.currentItem.width());
        if(
helper[0].style.height == '' || o.forceHelperSizehelper.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();
        }

        if((
this.offsetParent[0] == document.body//This needs to be actually done for all browsers, since pageX/pageY includes this information
        
|| (this.offsetParent[0].tagName && this.offsetParent[0].tagName.toLowerCase() == 'html' && $.ui.ie)) //Ugly IE fix
            
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 
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)) {
            var 
ce = $(o.containment)[0];
            var 
co = $(o.containment).offset();
            var 
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(!
pospos this.position;
        var 
mod == "absolute" : -1;
        var 
this.optionsscroll 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 
this.optionsscroll 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();
        }

        var 
pageX event.pageX;
        var 
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(
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) {
                var 
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;

                var 
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.counterthis.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 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().lengththis.placeholder.before(this.currentItem);
        
this._noFinalSort null;

        if(
this.helper[0] == this.currentItem[0]) {
            for(var 
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 && !noPropagationdelayedTriggers.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]) && !noPropagationdelayedTriggers.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 (var this.containers.length 1>= 0i--){
            if(!
noPropagationdelayedTriggers.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); //Reset cursor
        
if(this._storedOpacitythis.helper.css("opacity"this._storedOpacity); //Reset opacity
        
if(this._storedZIndexthis.helper.css("zIndex"this._storedZIndex == 'auto' '' this._storedZIndex); //Reset z-index

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

            
this.fromOutside false;
            return 
false;
        }

        if(!
noPropagationthis._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 (var 
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);
?>
Онлайн: 0
Реклама