| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572 | /*! jQuery UI - v1.11.4+CommonJS - 2015-08-28* http://jqueryui.com* Includes: widget.js* Copyright 2015 jQuery Foundation and other contributors; Licensed MIT */(function( factory ) {	if ( typeof define === "function" && define.amd ) {		// AMD. Register as an anonymous module.		define([ "jquery" ], factory );	} else if ( typeof exports === "object" ) {		// Node/CommonJS		factory( require( "jquery" ) );	} else {		// Browser globals		factory( jQuery );	}}(function( $ ) {/*! * jQuery UI Widget 1.11.4 * http://jqueryui.com * * Copyright jQuery Foundation and other contributors * Released under the MIT license. * http://jquery.org/license * * http://api.jqueryui.com/jQuery.widget/ */var widget_uuid = 0,	widget_slice = Array.prototype.slice;$.cleanData = (function( orig ) {	return function( elems ) {		var events, elem, i;		for ( i = 0; (elem = elems[i]) != null; i++ ) {			try {				// Only trigger remove when necessary to save time				events = $._data( elem, "events" );				if ( events && events.remove ) {					$( elem ).triggerHandler( "remove" );				}			// http://bugs.jquery.com/ticket/8235			} catch ( e ) {}		}		orig( elems );	};})( $.cleanData );$.widget = function( name, base, prototype ) {	var fullName, existingConstructor, constructor, basePrototype,		// proxiedPrototype allows the provided prototype to remain unmodified		// so that it can be used as a mixin for multiple widgets (#8876)		proxiedPrototype = {},		namespace = name.split( "." )[ 0 ];	name = name.split( "." )[ 1 ];	fullName = namespace + "-" + name;	if ( !prototype ) {		prototype = base;		base = $.Widget;	}	// create selector for plugin	$.expr[ ":" ][ fullName.toLowerCase() ] = function( elem ) {		return !!$.data( elem, fullName );	};	$[ namespace ] = $[ namespace ] || {};	existingConstructor = $[ namespace ][ name ];	constructor = $[ namespace ][ name ] = function( options, element ) {		// allow instantiation without "new" keyword		if ( !this._createWidget ) {			return new constructor( options, element );		}		// allow instantiation without initializing for simple inheritance		// must use "new" keyword (the code above always passes args)		if ( arguments.length ) {			this._createWidget( options, element );		}	};	// extend with the existing constructor to carry over any static properties	$.extend( constructor, existingConstructor, {		version: prototype.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 );	$.each( prototype, function( prop, value ) {		if ( !$.isFunction( value ) ) {			proxiedPrototype[ prop ] = value;			return;		}		proxiedPrototype[ prop ] = (function() {			var _super = function() {					return base.prototype[ prop ].apply( this, arguments );				},				_superApply = function( args ) {					return base.prototype[ prop ].apply( this, args );				};			return function() {				var __super = this._super,					__superApply = this._superApply,					returnValue;				this._super = _super;				this._superApply = _superApply;				returnValue = value.apply( this, arguments );				this._super = __super;				this._superApply = __superApply;				return returnValue;			};		})();	});	constructor.prototype = $.widget.extend( basePrototype, {		// 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		widgetEventPrefix: existingConstructor ? (basePrototype.widgetEventPrefix || name) : name	}, proxiedPrototype, {		constructor: constructor,		namespace: namespace,		widgetName: name,		widgetFullName: fullName	});	// 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 ) {		$.each( existingConstructor._childConstructors, function( i, child ) {			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			$.widget( childPrototype.namespace + "." + childPrototype.widgetName, constructor, child._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.push( constructor );	}	$.widget.bridge( name, constructor );	return constructor;};$.widget.extend = function( target ) {	var input = widget_slice.call( arguments, 1 ),		inputIndex = 0,		inputLength = input.length,		key,		value;	for ( ; inputIndex < inputLength; inputIndex++ ) {		for ( key in input[ inputIndex ] ) {			value = input[ inputIndex ][ key ];			if ( input[ inputIndex ].hasOwnProperty( key ) && value !== undefined ) {				// Clone objects				if ( $.isPlainObject( value ) ) {					target[ key ] = $.isPlainObject( target[ key ] ) ?						$.widget.extend( {}, target[ key ], value ) :						// Don't extend strings, arrays, etc. with objects						$.widget.extend( {}, value );				// Copy everything else by reference				} else {					target[ key ] = value;				}			}		}	}	return target;};$.widget.bridge = function( name, object ) {	var fullName = object.prototype.widgetFullName || name;	$.fn[ name ] = function( options ) {		var isMethodCall = typeof options === "string",			args = widget_slice.call( arguments, 1 ),			returnValue = this;		if ( isMethodCall ) {			this.each(function() {				var methodValue,					instance = $.data( this, fullName );				if ( options === "instance" ) {					returnValue = instance;					return false;				}				if ( !instance ) {					return $.error( "cannot call methods on " + name + " prior to initialization; " +						"attempted to call method '" + options + "'" );				}				if ( !$.isFunction( instance[options] ) || options.charAt( 0 ) === "_" ) {					return $.error( "no such method '" + options + "' for " + name + " widget instance" );				}				methodValue = instance[ options ].apply( instance, args );				if ( methodValue !== instance && methodValue !== undefined ) {					returnValue = methodValue && methodValue.jquery ?						returnValue.pushStack( methodValue.get() ) :						methodValue;					return false;				}			});		} else {			// Allow multiple hashes to be passed on init			if ( args.length ) {				options = $.widget.extend.apply( null, [ options ].concat(args) );			}			this.each(function() {				var instance = $.data( this, fullName );				if ( instance ) {					instance.option( options || {} );					if ( instance._init ) {						instance._init();					}				} else {					$.data( this, fullName, new object( options, this ) );				}			});		}		return returnValue;	};};$.Widget = function( /* options, element */ ) {};$.Widget._childConstructors = [];$.Widget.prototype = {	widgetName: "widget",	widgetEventPrefix: "",	defaultElement: "<div>",	options: {		disabled: false,		// callbacks		create: null	},	_createWidget: function( options, element ) {		element = $( element || this.defaultElement || this )[ 0 ];		this.element = $( element );		this.uuid = widget_uuid++;		this.eventNamespace = "." + this.widgetName + this.uuid;		this.bindings = $();		this.hoverable = $();		this.focusable = $();		if ( element !== this ) {			$.data( element, this.widgetFullName, this );			this._on( true, this.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.options = $.widget.extend( {},			this.options,			this._getCreateOptions(),			options );		this._create();		this._trigger( "create", null, this._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			.unbind( this.eventNamespace )			.removeData( this.widgetFullName )			// support: jquery <1.6.3			// http://bugs.jquery.com/ticket/9413			.removeData( $.camelCase( this.widgetFullName ) );		this.widget()			.unbind( this.eventNamespace )			.removeAttr( "aria-disabled" )			.removeClass(				this.widgetFullName + "-disabled " +				"ui-state-disabled" );		// clean up events and states		this.bindings.unbind( this.eventNamespace );		this.hoverable.removeClass( "ui-state-hover" );		this.focusable.removeClass( "ui-state-focus" );	},	_destroy: $.noop,	widget: function() {		return this.element;	},	option: function( key, value ) {		var options = key,			parts,			curOption,			i;		if ( arguments.length === 0 ) {			// 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 = options[ key ] = $.widget.extend( {}, this.options[ key ] );				for ( i = 0; i < parts.length - 1; i++ ) {					curOption[ parts[ i ] ] = curOption[ parts[ i ] ] || {};					curOption = curOption[ parts[ i ] ];				}				key = parts.pop();				if ( arguments.length === 1 ) {					return curOption[ key ] === undefined ? null : curOption[ key ];				}				curOption[ key ] = value;			} else {				if ( arguments.length === 1 ) {					return this.options[ key ] === undefined ? null : this.options[ key ];				}				options[ key ] = value;			}		}		this._setOptions( options );		return this;	},	_setOptions: function( options ) {		var key;		for ( key in options ) {			this._setOption( key, options[ key ] );		}		return this;	},	_setOption: function( key, value ) {		this.options[ key ] = value;		if ( key === "disabled" ) {			this.widget()				.toggleClass( this.widgetFullName + "-disabled", !!value );			// If the widget is becoming disabled, then nothing is interactive			if ( value ) {				this.hoverable.removeClass( "ui-state-hover" );				this.focusable.removeClass( "ui-state-focus" );			}		}		return this;	},	enable: function() {		return this._setOptions({ disabled: false });	},	disable: function() {		return this._setOptions({ disabled: true });	},	_on: function( suppressDisabledCheck, element, handlers ) {		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 {			element = delegateElement = $( element );			this.bindings = this.bindings.add( element );		}		$.each( handlers, function( event, handler ) {			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" ? instance[ handler ] : handler )					.apply( instance, arguments );			}			// 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.delegate( selector, eventName, handlerProxy );			} else {				element.bind( eventName, handlerProxy );			}		});	},	_off: function( element, eventName ) {		eventName = (eventName || "").split( " " ).join( this.eventNamespace + " " ) +			this.eventNamespace;		element.unbind( eventName ).undelegate( eventName );		// Clear the stack to avoid memory leaks (#10056)		this.bindings = $( this.bindings.not( element ).get() );		this.focusable = $( this.focusable.not( element ).get() );		this.hoverable = $( this.hoverable.not( element ).get() );	},	_delay: function( handler, delay ) {		function handlerProxy() {			return ( typeof handler === "string" ? instance[ handler ] : handler )				.apply( instance, arguments );		}		var instance = this;		return setTimeout( handlerProxy, delay || 0 );	},	_hoverable: function( element ) {		this.hoverable = this.hoverable.add( element );		this._on( element, {			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.add( element );		this._on( element, {			focusin: function( event ) {				$( event.currentTarget ).addClass( "ui-state-focus" );			},			focusout: function( event ) {				$( event.currentTarget ).removeClass( "ui-state-focus" );			}		});	},	_trigger: function( type, event, data ) {		var prop, orig,			callback = this.options[ type ];		data = data || {};		event = $.Event( event );		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[ 0 ];		// copy original event properties over to the new event		orig = event.originalEvent;		if ( orig ) {			for ( prop in orig ) {				if ( !( prop in event ) ) {					event[ prop ] = orig[ prop ];				}			}		}		this.element.trigger( event, data );		return !( $.isFunction( callback ) &&			callback.apply( this.element[0], [ event ].concat( data ) ) === false ||			event.isDefaultPrevented() );	}};$.each( { show: "fadeIn", hide: "fadeOut" }, function( method, defaultEffect ) {	$.Widget.prototype[ "_" + method ] = function( element, options, callback ) {		if ( typeof options === "string" ) {			options = { effect: options };		}		var hasOptions,			effectName = !options ?				method :				options === true || typeof options === "number" ?					defaultEffect :					options.effect || defaultEffect;		options = options || {};		if ( typeof options === "number" ) {			options = { duration: options };		}		hasOptions = !$.isEmptyObject( options );		options.complete = callback;		if ( options.delay ) {			element.delay( options.delay );		}		if ( hasOptions && $.effects && $.effects.effect[ effectName ] ) {			element[ method ]( options );		} else if ( effectName !== method && element[ effectName ] ) {			element[ effectName ]( options.duration, options.easing, callback );		} else {			element.queue(function( next ) {				$( this )[ method ]();				if ( callback ) {					callback.call( element[ 0 ] );				}				next();			});		}	};});var widget = $.widget;}));
 |