| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159 | /*! * jQuery UI Progressbar 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/progressbar/ */(function( factory ) {	if ( typeof define === "function" && define.amd ) {		// AMD. Register as an anonymous module.		define([			"jquery",			"./core",			"./widget"		], factory );	} else {		// Browser globals		factory( jQuery );	}}(function( $ ) {return $.widget( "ui.progressbar", {	version: "1.11.4",	options: {		max: 100,		value: 0,		change: null,		complete: null	},	min: 0,	_create: function() {		// Constrain initial value		this.oldValue = this.options.value = this._constrainedValue();		this.element			.addClass( "ui-progressbar ui-widget ui-widget-content ui-corner-all" )			.attr({				// Only set static values, aria-valuenow and aria-valuemax are				// set inside _refreshValue()				role: "progressbar",				"aria-valuemin": this.min			});		this.valueDiv = $( "<div class='ui-progressbar-value ui-widget-header ui-corner-left'></div>" )			.appendTo( this.element );		this._refreshValue();	},	_destroy: function() {		this.element			.removeClass( "ui-progressbar ui-widget ui-widget-content ui-corner-all" )			.removeAttr( "role" )			.removeAttr( "aria-valuemin" )			.removeAttr( "aria-valuemax" )			.removeAttr( "aria-valuenow" );		this.valueDiv.remove();	},	value: function( newValue ) {		if ( newValue === undefined ) {			return this.options.value;		}		this.options.value = this._constrainedValue( newValue );		this._refreshValue();	},	_constrainedValue: function( newValue ) {		if ( newValue === undefined ) {			newValue = this.options.value;		}		this.indeterminate = newValue === false;		// sanitize value		if ( typeof newValue !== "number" ) {			newValue = 0;		}		return this.indeterminate ? false :			Math.min( this.options.max, Math.max( this.min, newValue ) );	},	_setOptions: function( options ) {		// Ensure "value" option is set after other values (like max)		var value = options.value;		delete options.value;		this._super( options );		this.options.value = this._constrainedValue( value );		this._refreshValue();	},	_setOption: function( key, value ) {		if ( key === "max" ) {			// Don't allow a max less than min			value = Math.max( this.min, value );		}		if ( key === "disabled" ) {			this.element				.toggleClass( "ui-state-disabled", !!value )				.attr( "aria-disabled", value );		}		this._super( key, value );	},	_percentage: function() {		return this.indeterminate ? 100 : 100 * ( this.options.value - this.min ) / ( this.options.max - this.min );	},	_refreshValue: function() {		var value = this.options.value,			percentage = this._percentage();		this.valueDiv			.toggle( this.indeterminate || value > this.min )			.toggleClass( "ui-corner-right", value === this.options.max )			.width( percentage.toFixed(0) + "%" );		this.element.toggleClass( "ui-progressbar-indeterminate", this.indeterminate );		if ( this.indeterminate ) {			this.element.removeAttr( "aria-valuenow" );			if ( !this.overlayDiv ) {				this.overlayDiv = $( "<div class='ui-progressbar-overlay'></div>" ).appendTo( this.valueDiv );			}		} else {			this.element.attr({				"aria-valuemax": this.options.max,				"aria-valuenow": value			});			if ( this.overlayDiv ) {				this.overlayDiv.remove();				this.overlayDiv = null;			}		}		if ( this.oldValue !== value ) {			this.oldValue = value;			this._trigger( "change" );		}		if ( value === this.options.max ) {			this._trigger( "complete" );		}	}});}));
 |