/[projects]/misc/horsensspejder-web/jquery/jquery-ui-1.10.3/ui/jquery.ui.widget.js
ViewVC logotype

Contents of /misc/horsensspejder-web/jquery/jquery-ui-1.10.3/ui/jquery.ui.widget.js

Parent Directory Parent Directory | Revision Log Revision Log


Revision 2125 - (show annotations) (download) (as text)
Wed Mar 12 19:30:05 2014 UTC (10 years, 3 months ago) by torben
File MIME type: application/javascript
File size: 15069 byte(s)
initial import
1 /*!
2 * jQuery UI Widget 1.10.3
3 * http://jqueryui.com
4 *
5 * Copyright 2013 jQuery Foundation and other contributors
6 * Released under the MIT license.
7 * http://jquery.org/license
8 *
9 * http://api.jqueryui.com/jQuery.widget/
10 */
11 (function( $, undefined ) {
12
13 var uuid = 0,
14 slice = Array.prototype.slice,
15 _cleanData = $.cleanData;
16 $.cleanData = function( elems ) {
17 for ( var i = 0, elem; (elem = elems[i]) != null; i++ ) {
18 try {
19 $( elem ).triggerHandler( "remove" );
20 // http://bugs.jquery.com/ticket/8235
21 } catch( e ) {}
22 }
23 _cleanData( elems );
24 };
25
26 $.widget = function( name, base, prototype ) {
27 var fullName, existingConstructor, constructor, basePrototype,
28 // proxiedPrototype allows the provided prototype to remain unmodified
29 // so that it can be used as a mixin for multiple widgets (#8876)
30 proxiedPrototype = {},
31 namespace = name.split( "." )[ 0 ];
32
33 name = name.split( "." )[ 1 ];
34 fullName = namespace + "-" + name;
35
36 if ( !prototype ) {
37 prototype = base;
38 base = $.Widget;
39 }
40
41 // create selector for plugin
42 $.expr[ ":" ][ fullName.toLowerCase() ] = function( elem ) {
43 return !!$.data( elem, fullName );
44 };
45
46 $[ namespace ] = $[ namespace ] || {};
47 existingConstructor = $[ namespace ][ name ];
48 constructor = $[ namespace ][ name ] = function( options, element ) {
49 // allow instantiation without "new" keyword
50 if ( !this._createWidget ) {
51 return new constructor( options, element );
52 }
53
54 // allow instantiation without initializing for simple inheritance
55 // must use "new" keyword (the code above always passes args)
56 if ( arguments.length ) {
57 this._createWidget( options, element );
58 }
59 };
60 // extend with the existing constructor to carry over any static properties
61 $.extend( constructor, existingConstructor, {
62 version: prototype.version,
63 // copy the object used to create the prototype in case we need to
64 // redefine the widget later
65 _proto: $.extend( {}, prototype ),
66 // track widgets that inherit from this widget in case this widget is
67 // redefined after a widget inherits from it
68 _childConstructors: []
69 });
70
71 basePrototype = new base();
72 // we need to make the options hash a property directly on the new instance
73 // otherwise we'll modify the options hash on the prototype that we're
74 // inheriting from
75 basePrototype.options = $.widget.extend( {}, basePrototype.options );
76 $.each( prototype, function( prop, value ) {
77 if ( !$.isFunction( value ) ) {
78 proxiedPrototype[ prop ] = value;
79 return;
80 }
81 proxiedPrototype[ prop ] = (function() {
82 var _super = function() {
83 return base.prototype[ prop ].apply( this, arguments );
84 },
85 _superApply = function( args ) {
86 return base.prototype[ prop ].apply( this, args );
87 };
88 return function() {
89 var __super = this._super,
90 __superApply = this._superApply,
91 returnValue;
92
93 this._super = _super;
94 this._superApply = _superApply;
95
96 returnValue = value.apply( this, arguments );
97
98 this._super = __super;
99 this._superApply = __superApply;
100
101 return returnValue;
102 };
103 })();
104 });
105 constructor.prototype = $.widget.extend( basePrototype, {
106 // TODO: remove support for widgetEventPrefix
107 // always use the name + a colon as the prefix, e.g., draggable:start
108 // don't prefix for widgets that aren't DOM-based
109 widgetEventPrefix: existingConstructor ? basePrototype.widgetEventPrefix : name
110 }, proxiedPrototype, {
111 constructor: constructor,
112 namespace: namespace,
113 widgetName: name,
114 widgetFullName: fullName
115 });
116
117 // If this widget is being redefined then we need to find all widgets that
118 // are inheriting from it and redefine all of them so that they inherit from
119 // the new version of this widget. We're essentially trying to replace one
120 // level in the prototype chain.
121 if ( existingConstructor ) {
122 $.each( existingConstructor._childConstructors, function( i, child ) {
123 var childPrototype = child.prototype;
124
125 // redefine the child widget using the same prototype that was
126 // originally used, but inherit from the new version of the base
127 $.widget( childPrototype.namespace + "." + childPrototype.widgetName, constructor, child._proto );
128 });
129 // remove the list of existing child constructors from the old constructor
130 // so the old child constructors can be garbage collected
131 delete existingConstructor._childConstructors;
132 } else {
133 base._childConstructors.push( constructor );
134 }
135
136 $.widget.bridge( name, constructor );
137 };
138
139 $.widget.extend = function( target ) {
140 var input = slice.call( arguments, 1 ),
141 inputIndex = 0,
142 inputLength = input.length,
143 key,
144 value;
145 for ( ; inputIndex < inputLength; inputIndex++ ) {
146 for ( key in input[ inputIndex ] ) {
147 value = input[ inputIndex ][ key ];
148 if ( input[ inputIndex ].hasOwnProperty( key ) && value !== undefined ) {
149 // Clone objects
150 if ( $.isPlainObject( value ) ) {
151 target[ key ] = $.isPlainObject( target[ key ] ) ?
152 $.widget.extend( {}, target[ key ], value ) :
153 // Don't extend strings, arrays, etc. with objects
154 $.widget.extend( {}, value );
155 // Copy everything else by reference
156 } else {
157 target[ key ] = value;
158 }
159 }
160 }
161 }
162 return target;
163 };
164
165 $.widget.bridge = function( name, object ) {
166 var fullName = object.prototype.widgetFullName || name;
167 $.fn[ name ] = function( options ) {
168 var isMethodCall = typeof options === "string",
169 args = slice.call( arguments, 1 ),
170 returnValue = this;
171
172 // allow multiple hashes to be passed on init
173 options = !isMethodCall && args.length ?
174 $.widget.extend.apply( null, [ options ].concat(args) ) :
175 options;
176
177 if ( isMethodCall ) {
178 this.each(function() {
179 var methodValue,
180 instance = $.data( this, fullName );
181 if ( !instance ) {
182 return $.error( "cannot call methods on " + name + " prior to initialization; " +
183 "attempted to call method '" + options + "'" );
184 }
185 if ( !$.isFunction( instance[options] ) || options.charAt( 0 ) === "_" ) {
186 return $.error( "no such method '" + options + "' for " + name + " widget instance" );
187 }
188 methodValue = instance[ options ].apply( instance, args );
189 if ( methodValue !== instance && methodValue !== undefined ) {
190 returnValue = methodValue && methodValue.jquery ?
191 returnValue.pushStack( methodValue.get() ) :
192 methodValue;
193 return false;
194 }
195 });
196 } else {
197 this.each(function() {
198 var instance = $.data( this, fullName );
199 if ( instance ) {
200 instance.option( options || {} )._init();
201 } else {
202 $.data( this, fullName, new object( options, this ) );
203 }
204 });
205 }
206
207 return returnValue;
208 };
209 };
210
211 $.Widget = function( /* options, element */ ) {};
212 $.Widget._childConstructors = [];
213
214 $.Widget.prototype = {
215 widgetName: "widget",
216 widgetEventPrefix: "",
217 defaultElement: "<div>",
218 options: {
219 disabled: false,
220
221 // callbacks
222 create: null
223 },
224 _createWidget: function( options, element ) {
225 element = $( element || this.defaultElement || this )[ 0 ];
226 this.element = $( element );
227 this.uuid = uuid++;
228 this.eventNamespace = "." + this.widgetName + this.uuid;
229 this.options = $.widget.extend( {},
230 this.options,
231 this._getCreateOptions(),
232 options );
233
234 this.bindings = $();
235 this.hoverable = $();
236 this.focusable = $();
237
238 if ( element !== this ) {
239 $.data( element, this.widgetFullName, this );
240 this._on( true, this.element, {
241 remove: function( event ) {
242 if ( event.target === element ) {
243 this.destroy();
244 }
245 }
246 });
247 this.document = $( element.style ?
248 // element within the document
249 element.ownerDocument :
250 // element is window or document
251 element.document || element );
252 this.window = $( this.document[0].defaultView || this.document[0].parentWindow );
253 }
254
255 this._create();
256 this._trigger( "create", null, this._getCreateEventData() );
257 this._init();
258 },
259 _getCreateOptions: $.noop,
260 _getCreateEventData: $.noop,
261 _create: $.noop,
262 _init: $.noop,
263
264 destroy: function() {
265 this._destroy();
266 // we can probably remove the unbind calls in 2.0
267 // all event bindings should go through this._on()
268 this.element
269 .unbind( this.eventNamespace )
270 // 1.9 BC for #7810
271 // TODO remove dual storage
272 .removeData( this.widgetName )
273 .removeData( this.widgetFullName )
274 // support: jquery <1.6.3
275 // http://bugs.jquery.com/ticket/9413
276 .removeData( $.camelCase( this.widgetFullName ) );
277 this.widget()
278 .unbind( this.eventNamespace )
279 .removeAttr( "aria-disabled" )
280 .removeClass(
281 this.widgetFullName + "-disabled " +
282 "ui-state-disabled" );
283
284 // clean up events and states
285 this.bindings.unbind( this.eventNamespace );
286 this.hoverable.removeClass( "ui-state-hover" );
287 this.focusable.removeClass( "ui-state-focus" );
288 },
289 _destroy: $.noop,
290
291 widget: function() {
292 return this.element;
293 },
294
295 option: function( key, value ) {
296 var options = key,
297 parts,
298 curOption,
299 i;
300
301 if ( arguments.length === 0 ) {
302 // don't return a reference to the internal hash
303 return $.widget.extend( {}, this.options );
304 }
305
306 if ( typeof key === "string" ) {
307 // handle nested keys, e.g., "foo.bar" => { foo: { bar: ___ } }
308 options = {};
309 parts = key.split( "." );
310 key = parts.shift();
311 if ( parts.length ) {
312 curOption = options[ key ] = $.widget.extend( {}, this.options[ key ] );
313 for ( i = 0; i < parts.length - 1; i++ ) {
314 curOption[ parts[ i ] ] = curOption[ parts[ i ] ] || {};
315 curOption = curOption[ parts[ i ] ];
316 }
317 key = parts.pop();
318 if ( value === undefined ) {
319 return curOption[ key ] === undefined ? null : curOption[ key ];
320 }
321 curOption[ key ] = value;
322 } else {
323 if ( value === undefined ) {
324 return this.options[ key ] === undefined ? null : this.options[ key ];
325 }
326 options[ key ] = value;
327 }
328 }
329
330 this._setOptions( options );
331
332 return this;
333 },
334 _setOptions: function( options ) {
335 var key;
336
337 for ( key in options ) {
338 this._setOption( key, options[ key ] );
339 }
340
341 return this;
342 },
343 _setOption: function( key, value ) {
344 this.options[ key ] = value;
345
346 if ( key === "disabled" ) {
347 this.widget()
348 .toggleClass( this.widgetFullName + "-disabled ui-state-disabled", !!value )
349 .attr( "aria-disabled", value );
350 this.hoverable.removeClass( "ui-state-hover" );
351 this.focusable.removeClass( "ui-state-focus" );
352 }
353
354 return this;
355 },
356
357 enable: function() {
358 return this._setOption( "disabled", false );
359 },
360 disable: function() {
361 return this._setOption( "disabled", true );
362 },
363
364 _on: function( suppressDisabledCheck, element, handlers ) {
365 var delegateElement,
366 instance = this;
367
368 // no suppressDisabledCheck flag, shuffle arguments
369 if ( typeof suppressDisabledCheck !== "boolean" ) {
370 handlers = element;
371 element = suppressDisabledCheck;
372 suppressDisabledCheck = false;
373 }
374
375 // no element argument, shuffle and use this.element
376 if ( !handlers ) {
377 handlers = element;
378 element = this.element;
379 delegateElement = this.widget();
380 } else {
381 // accept selectors, DOM elements
382 element = delegateElement = $( element );
383 this.bindings = this.bindings.add( element );
384 }
385
386 $.each( handlers, function( event, handler ) {
387 function handlerProxy() {
388 // allow widgets to customize the disabled handling
389 // - disabled as an array instead of boolean
390 // - disabled class as method for disabling individual parts
391 if ( !suppressDisabledCheck &&
392 ( instance.options.disabled === true ||
393 $( this ).hasClass( "ui-state-disabled" ) ) ) {
394 return;
395 }
396 return ( typeof handler === "string" ? instance[ handler ] : handler )
397 .apply( instance, arguments );
398 }
399
400 // copy the guid so direct unbinding works
401 if ( typeof handler !== "string" ) {
402 handlerProxy.guid = handler.guid =
403 handler.guid || handlerProxy.guid || $.guid++;
404 }
405
406 var match = event.match( /^(\w+)\s*(.*)$/ ),
407 eventName = match[1] + instance.eventNamespace,
408 selector = match[2];
409 if ( selector ) {
410 delegateElement.delegate( selector, eventName, handlerProxy );
411 } else {
412 element.bind( eventName, handlerProxy );
413 }
414 });
415 },
416
417 _off: function( element, eventName ) {
418 eventName = (eventName || "").split( " " ).join( this.eventNamespace + " " ) + this.eventNamespace;
419 element.unbind( eventName ).undelegate( eventName );
420 },
421
422 _delay: function( handler, delay ) {
423 function handlerProxy() {
424 return ( typeof handler === "string" ? instance[ handler ] : handler )
425 .apply( instance, arguments );
426 }
427 var instance = this;
428 return setTimeout( handlerProxy, delay || 0 );
429 },
430
431 _hoverable: function( element ) {
432 this.hoverable = this.hoverable.add( element );
433 this._on( element, {
434 mouseenter: function( event ) {
435 $( event.currentTarget ).addClass( "ui-state-hover" );
436 },
437 mouseleave: function( event ) {
438 $( event.currentTarget ).removeClass( "ui-state-hover" );
439 }
440 });
441 },
442
443 _focusable: function( element ) {
444 this.focusable = this.focusable.add( element );
445 this._on( element, {
446 focusin: function( event ) {
447 $( event.currentTarget ).addClass( "ui-state-focus" );
448 },
449 focusout: function( event ) {
450 $( event.currentTarget ).removeClass( "ui-state-focus" );
451 }
452 });
453 },
454
455 _trigger: function( type, event, data ) {
456 var prop, orig,
457 callback = this.options[ type ];
458
459 data = data || {};
460 event = $.Event( event );
461 event.type = ( type === this.widgetEventPrefix ?
462 type :
463 this.widgetEventPrefix + type ).toLowerCase();
464 // the original event may come from any element
465 // so we need to reset the target on the new event
466 event.target = this.element[ 0 ];
467
468 // copy original event properties over to the new event
469 orig = event.originalEvent;
470 if ( orig ) {
471 for ( prop in orig ) {
472 if ( !( prop in event ) ) {
473 event[ prop ] = orig[ prop ];
474 }
475 }
476 }
477
478 this.element.trigger( event, data );
479 return !( $.isFunction( callback ) &&
480 callback.apply( this.element[0], [ event ].concat( data ) ) === false ||
481 event.isDefaultPrevented() );
482 }
483 };
484
485 $.each( { show: "fadeIn", hide: "fadeOut" }, function( method, defaultEffect ) {
486 $.Widget.prototype[ "_" + method ] = function( element, options, callback ) {
487 if ( typeof options === "string" ) {
488 options = { effect: options };
489 }
490 var hasOptions,
491 effectName = !options ?
492 method :
493 options === true || typeof options === "number" ?
494 defaultEffect :
495 options.effect || defaultEffect;
496 options = options || {};
497 if ( typeof options === "number" ) {
498 options = { duration: options };
499 }
500 hasOptions = !$.isEmptyObject( options );
501 options.complete = callback;
502 if ( options.delay ) {
503 element.delay( options.delay );
504 }
505 if ( hasOptions && $.effects && $.effects.effect[ effectName ] ) {
506 element[ method ]( options );
507 } else if ( effectName !== method && element[ effectName ] ) {
508 element[ effectName ]( options.duration, options.easing, callback );
509 } else {
510 element.queue(function( next ) {
511 $( this )[ method ]();
512 if ( callback ) {
513 callback.call( element[ 0 ] );
514 }
515 next();
516 });
517 }
518 };
519 });
520
521 })( jQuery );

  ViewVC Help
Powered by ViewVC 1.1.20