3782 obj = type; |
3998 obj = type; |
3783 type = undefined; |
3999 type = undefined; |
3784 } |
4000 } |
3785 type = type || "fx"; |
4001 type = type || "fx"; |
3786 |
4002 |
3787 while( i-- ) { |
4003 while ( i-- ) { |
3788 tmp = data_priv.get( elements[ i ], type + "queueHooks" ); |
4004 tmp = data_priv.get( elements[ i ], type + "queueHooks" ); |
3789 if ( tmp && tmp.empty ) { |
4005 if ( tmp && tmp.empty ) { |
3790 count++; |
4006 count++; |
3791 tmp.empty.add( resolve ); |
4007 tmp.empty.add( resolve ); |
3792 } |
4008 } |
3793 } |
4009 } |
3794 resolve(); |
4010 resolve(); |
3795 return defer.promise( obj ); |
4011 return defer.promise( obj ); |
3796 } |
4012 } |
3797 }); |
4013 }); |
|
4014 var pnum = (/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/).source; |
|
4015 |
|
4016 var cssExpand = [ "Top", "Right", "Bottom", "Left" ]; |
|
4017 |
|
4018 var isHidden = function( elem, el ) { |
|
4019 // isHidden might be called from jQuery#filter function; |
|
4020 // in that case, element will be second argument |
|
4021 elem = el || elem; |
|
4022 return jQuery.css( elem, "display" ) === "none" || !jQuery.contains( elem.ownerDocument, elem ); |
|
4023 }; |
|
4024 |
|
4025 var rcheckableType = (/^(?:checkbox|radio)$/i); |
|
4026 |
|
4027 |
|
4028 |
|
4029 (function() { |
|
4030 var fragment = document.createDocumentFragment(), |
|
4031 div = fragment.appendChild( document.createElement( "div" ) ), |
|
4032 input = document.createElement( "input" ); |
|
4033 |
|
4034 // Support: Safari<=5.1 |
|
4035 // Check state lost if the name is set (#11217) |
|
4036 // Support: Windows Web Apps (WWA) |
|
4037 // `name` and `type` must use .setAttribute for WWA (#14901) |
|
4038 input.setAttribute( "type", "radio" ); |
|
4039 input.setAttribute( "checked", "checked" ); |
|
4040 input.setAttribute( "name", "t" ); |
|
4041 |
|
4042 div.appendChild( input ); |
|
4043 |
|
4044 // Support: Safari<=5.1, Android<4.2 |
|
4045 // Older WebKit doesn't clone checked state correctly in fragments |
|
4046 support.checkClone = div.cloneNode( true ).cloneNode( true ).lastChild.checked; |
|
4047 |
|
4048 // Support: IE<=11+ |
|
4049 // Make sure textarea (and checkbox) defaultValue is properly cloned |
|
4050 div.innerHTML = "<textarea>x</textarea>"; |
|
4051 support.noCloneChecked = !!div.cloneNode( true ).lastChild.defaultValue; |
|
4052 })(); |
|
4053 var strundefined = typeof undefined; |
|
4054 |
|
4055 |
|
4056 |
|
4057 support.focusinBubbles = "onfocusin" in window; |
|
4058 |
|
4059 |
|
4060 var |
|
4061 rkeyEvent = /^key/, |
|
4062 rmouseEvent = /^(?:mouse|pointer|contextmenu)|click/, |
|
4063 rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, |
|
4064 rtypenamespace = /^([^.]*)(?:\.(.+)|)$/; |
|
4065 |
|
4066 function returnTrue() { |
|
4067 return true; |
|
4068 } |
|
4069 |
|
4070 function returnFalse() { |
|
4071 return false; |
|
4072 } |
|
4073 |
|
4074 function safeActiveElement() { |
|
4075 try { |
|
4076 return document.activeElement; |
|
4077 } catch ( err ) { } |
|
4078 } |
|
4079 |
|
4080 /* |
|
4081 * Helper functions for managing events -- not part of the public interface. |
|
4082 * Props to Dean Edwards' addEvent library for many of the ideas. |
|
4083 */ |
|
4084 jQuery.event = { |
|
4085 |
|
4086 global: {}, |
|
4087 |
|
4088 add: function( elem, types, handler, data, selector ) { |
|
4089 |
|
4090 var handleObjIn, eventHandle, tmp, |
|
4091 events, t, handleObj, |
|
4092 special, handlers, type, namespaces, origType, |
|
4093 elemData = data_priv.get( elem ); |
|
4094 |
|
4095 // Don't attach events to noData or text/comment nodes (but allow plain objects) |
|
4096 if ( !elemData ) { |
|
4097 return; |
|
4098 } |
|
4099 |
|
4100 // Caller can pass in an object of custom data in lieu of the handler |
|
4101 if ( handler.handler ) { |
|
4102 handleObjIn = handler; |
|
4103 handler = handleObjIn.handler; |
|
4104 selector = handleObjIn.selector; |
|
4105 } |
|
4106 |
|
4107 // Make sure that the handler has a unique ID, used to find/remove it later |
|
4108 if ( !handler.guid ) { |
|
4109 handler.guid = jQuery.guid++; |
|
4110 } |
|
4111 |
|
4112 // Init the element's event structure and main handler, if this is the first |
|
4113 if ( !(events = elemData.events) ) { |
|
4114 events = elemData.events = {}; |
|
4115 } |
|
4116 if ( !(eventHandle = elemData.handle) ) { |
|
4117 eventHandle = elemData.handle = function( e ) { |
|
4118 // Discard the second event of a jQuery.event.trigger() and |
|
4119 // when an event is called after a page has unloaded |
|
4120 return typeof jQuery !== strundefined && jQuery.event.triggered !== e.type ? |
|
4121 jQuery.event.dispatch.apply( elem, arguments ) : undefined; |
|
4122 }; |
|
4123 } |
|
4124 |
|
4125 // Handle multiple events separated by a space |
|
4126 types = ( types || "" ).match( rnotwhite ) || [ "" ]; |
|
4127 t = types.length; |
|
4128 while ( t-- ) { |
|
4129 tmp = rtypenamespace.exec( types[t] ) || []; |
|
4130 type = origType = tmp[1]; |
|
4131 namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
|
4132 |
|
4133 // There *must* be a type, no attaching namespace-only handlers |
|
4134 if ( !type ) { |
|
4135 continue; |
|
4136 } |
|
4137 |
|
4138 // If event changes its type, use the special event handlers for the changed type |
|
4139 special = jQuery.event.special[ type ] || {}; |
|
4140 |
|
4141 // If selector defined, determine special event api type, otherwise given type |
|
4142 type = ( selector ? special.delegateType : special.bindType ) || type; |
|
4143 |
|
4144 // Update special based on newly reset type |
|
4145 special = jQuery.event.special[ type ] || {}; |
|
4146 |
|
4147 // handleObj is passed to all event handlers |
|
4148 handleObj = jQuery.extend({ |
|
4149 type: type, |
|
4150 origType: origType, |
|
4151 data: data, |
|
4152 handler: handler, |
|
4153 guid: handler.guid, |
|
4154 selector: selector, |
|
4155 needsContext: selector && jQuery.expr.match.needsContext.test( selector ), |
|
4156 namespace: namespaces.join(".") |
|
4157 }, handleObjIn ); |
|
4158 |
|
4159 // Init the event handler queue if we're the first |
|
4160 if ( !(handlers = events[ type ]) ) { |
|
4161 handlers = events[ type ] = []; |
|
4162 handlers.delegateCount = 0; |
|
4163 |
|
4164 // Only use addEventListener if the special events handler returns false |
|
4165 if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { |
|
4166 if ( elem.addEventListener ) { |
|
4167 elem.addEventListener( type, eventHandle, false ); |
|
4168 } |
|
4169 } |
|
4170 } |
|
4171 |
|
4172 if ( special.add ) { |
|
4173 special.add.call( elem, handleObj ); |
|
4174 |
|
4175 if ( !handleObj.handler.guid ) { |
|
4176 handleObj.handler.guid = handler.guid; |
|
4177 } |
|
4178 } |
|
4179 |
|
4180 // Add to the element's handler list, delegates in front |
|
4181 if ( selector ) { |
|
4182 handlers.splice( handlers.delegateCount++, 0, handleObj ); |
|
4183 } else { |
|
4184 handlers.push( handleObj ); |
|
4185 } |
|
4186 |
|
4187 // Keep track of which events have ever been used, for event optimization |
|
4188 jQuery.event.global[ type ] = true; |
|
4189 } |
|
4190 |
|
4191 }, |
|
4192 |
|
4193 // Detach an event or set of events from an element |
|
4194 remove: function( elem, types, handler, selector, mappedTypes ) { |
|
4195 |
|
4196 var j, origCount, tmp, |
|
4197 events, t, handleObj, |
|
4198 special, handlers, type, namespaces, origType, |
|
4199 elemData = data_priv.hasData( elem ) && data_priv.get( elem ); |
|
4200 |
|
4201 if ( !elemData || !(events = elemData.events) ) { |
|
4202 return; |
|
4203 } |
|
4204 |
|
4205 // Once for each type.namespace in types; type may be omitted |
|
4206 types = ( types || "" ).match( rnotwhite ) || [ "" ]; |
|
4207 t = types.length; |
|
4208 while ( t-- ) { |
|
4209 tmp = rtypenamespace.exec( types[t] ) || []; |
|
4210 type = origType = tmp[1]; |
|
4211 namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
|
4212 |
|
4213 // Unbind all events (on this namespace, if provided) for the element |
|
4214 if ( !type ) { |
|
4215 for ( type in events ) { |
|
4216 jQuery.event.remove( elem, type + types[ t ], handler, selector, true ); |
|
4217 } |
|
4218 continue; |
|
4219 } |
|
4220 |
|
4221 special = jQuery.event.special[ type ] || {}; |
|
4222 type = ( selector ? special.delegateType : special.bindType ) || type; |
|
4223 handlers = events[ type ] || []; |
|
4224 tmp = tmp[2] && new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ); |
|
4225 |
|
4226 // Remove matching events |
|
4227 origCount = j = handlers.length; |
|
4228 while ( j-- ) { |
|
4229 handleObj = handlers[ j ]; |
|
4230 |
|
4231 if ( ( mappedTypes || origType === handleObj.origType ) && |
|
4232 ( !handler || handler.guid === handleObj.guid ) && |
|
4233 ( !tmp || tmp.test( handleObj.namespace ) ) && |
|
4234 ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) { |
|
4235 handlers.splice( j, 1 ); |
|
4236 |
|
4237 if ( handleObj.selector ) { |
|
4238 handlers.delegateCount--; |
|
4239 } |
|
4240 if ( special.remove ) { |
|
4241 special.remove.call( elem, handleObj ); |
|
4242 } |
|
4243 } |
|
4244 } |
|
4245 |
|
4246 // Remove generic event handler if we removed something and no more handlers exist |
|
4247 // (avoids potential for endless recursion during removal of special event handlers) |
|
4248 if ( origCount && !handlers.length ) { |
|
4249 if ( !special.teardown || special.teardown.call( elem, namespaces, elemData.handle ) === false ) { |
|
4250 jQuery.removeEvent( elem, type, elemData.handle ); |
|
4251 } |
|
4252 |
|
4253 delete events[ type ]; |
|
4254 } |
|
4255 } |
|
4256 |
|
4257 // Remove the expando if it's no longer used |
|
4258 if ( jQuery.isEmptyObject( events ) ) { |
|
4259 delete elemData.handle; |
|
4260 data_priv.remove( elem, "events" ); |
|
4261 } |
|
4262 }, |
|
4263 |
|
4264 trigger: function( event, data, elem, onlyHandlers ) { |
|
4265 |
|
4266 var i, cur, tmp, bubbleType, ontype, handle, special, |
|
4267 eventPath = [ elem || document ], |
|
4268 type = hasOwn.call( event, "type" ) ? event.type : event, |
|
4269 namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : []; |
|
4270 |
|
4271 cur = tmp = elem = elem || document; |
|
4272 |
|
4273 // Don't do events on text and comment nodes |
|
4274 if ( elem.nodeType === 3 || elem.nodeType === 8 ) { |
|
4275 return; |
|
4276 } |
|
4277 |
|
4278 // focus/blur morphs to focusin/out; ensure we're not firing them right now |
|
4279 if ( rfocusMorph.test( type + jQuery.event.triggered ) ) { |
|
4280 return; |
|
4281 } |
|
4282 |
|
4283 if ( type.indexOf(".") >= 0 ) { |
|
4284 // Namespaced trigger; create a regexp to match event type in handle() |
|
4285 namespaces = type.split("."); |
|
4286 type = namespaces.shift(); |
|
4287 namespaces.sort(); |
|
4288 } |
|
4289 ontype = type.indexOf(":") < 0 && "on" + type; |
|
4290 |
|
4291 // Caller can pass in a jQuery.Event object, Object, or just an event type string |
|
4292 event = event[ jQuery.expando ] ? |
|
4293 event : |
|
4294 new jQuery.Event( type, typeof event === "object" && event ); |
|
4295 |
|
4296 // Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true) |
|
4297 event.isTrigger = onlyHandlers ? 2 : 3; |
|
4298 event.namespace = namespaces.join("."); |
|
4299 event.namespace_re = event.namespace ? |
|
4300 new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) : |
|
4301 null; |
|
4302 |
|
4303 // Clean up the event in case it is being reused |
|
4304 event.result = undefined; |
|
4305 if ( !event.target ) { |
|
4306 event.target = elem; |
|
4307 } |
|
4308 |
|
4309 // Clone any incoming data and prepend the event, creating the handler arg list |
|
4310 data = data == null ? |
|
4311 [ event ] : |
|
4312 jQuery.makeArray( data, [ event ] ); |
|
4313 |
|
4314 // Allow special events to draw outside the lines |
|
4315 special = jQuery.event.special[ type ] || {}; |
|
4316 if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) { |
|
4317 return; |
|
4318 } |
|
4319 |
|
4320 // Determine event propagation path in advance, per W3C events spec (#9951) |
|
4321 // Bubble up to document, then to window; watch for a global ownerDocument var (#9724) |
|
4322 if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) { |
|
4323 |
|
4324 bubbleType = special.delegateType || type; |
|
4325 if ( !rfocusMorph.test( bubbleType + type ) ) { |
|
4326 cur = cur.parentNode; |
|
4327 } |
|
4328 for ( ; cur; cur = cur.parentNode ) { |
|
4329 eventPath.push( cur ); |
|
4330 tmp = cur; |
|
4331 } |
|
4332 |
|
4333 // Only add window if we got to document (e.g., not plain obj or detached DOM) |
|
4334 if ( tmp === (elem.ownerDocument || document) ) { |
|
4335 eventPath.push( tmp.defaultView || tmp.parentWindow || window ); |
|
4336 } |
|
4337 } |
|
4338 |
|
4339 // Fire handlers on the event path |
|
4340 i = 0; |
|
4341 while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) { |
|
4342 |
|
4343 event.type = i > 1 ? |
|
4344 bubbleType : |
|
4345 special.bindType || type; |
|
4346 |
|
4347 // jQuery handler |
|
4348 handle = ( data_priv.get( cur, "events" ) || {} )[ event.type ] && data_priv.get( cur, "handle" ); |
|
4349 if ( handle ) { |
|
4350 handle.apply( cur, data ); |
|
4351 } |
|
4352 |
|
4353 // Native handler |
|
4354 handle = ontype && cur[ ontype ]; |
|
4355 if ( handle && handle.apply && jQuery.acceptData( cur ) ) { |
|
4356 event.result = handle.apply( cur, data ); |
|
4357 if ( event.result === false ) { |
|
4358 event.preventDefault(); |
|
4359 } |
|
4360 } |
|
4361 } |
|
4362 event.type = type; |
|
4363 |
|
4364 // If nobody prevented the default action, do it now |
|
4365 if ( !onlyHandlers && !event.isDefaultPrevented() ) { |
|
4366 |
|
4367 if ( (!special._default || special._default.apply( eventPath.pop(), data ) === false) && |
|
4368 jQuery.acceptData( elem ) ) { |
|
4369 |
|
4370 // Call a native DOM method on the target with the same name name as the event. |
|
4371 // Don't do default actions on window, that's where global variables be (#6170) |
|
4372 if ( ontype && jQuery.isFunction( elem[ type ] ) && !jQuery.isWindow( elem ) ) { |
|
4373 |
|
4374 // Don't re-trigger an onFOO event when we call its FOO() method |
|
4375 tmp = elem[ ontype ]; |
|
4376 |
|
4377 if ( tmp ) { |
|
4378 elem[ ontype ] = null; |
|
4379 } |
|
4380 |
|
4381 // Prevent re-triggering of the same event, since we already bubbled it above |
|
4382 jQuery.event.triggered = type; |
|
4383 elem[ type ](); |
|
4384 jQuery.event.triggered = undefined; |
|
4385 |
|
4386 if ( tmp ) { |
|
4387 elem[ ontype ] = tmp; |
|
4388 } |
|
4389 } |
|
4390 } |
|
4391 } |
|
4392 |
|
4393 return event.result; |
|
4394 }, |
|
4395 |
|
4396 dispatch: function( event ) { |
|
4397 |
|
4398 // Make a writable jQuery.Event from the native event object |
|
4399 event = jQuery.event.fix( event ); |
|
4400 |
|
4401 var i, j, ret, matched, handleObj, |
|
4402 handlerQueue = [], |
|
4403 args = slice.call( arguments ), |
|
4404 handlers = ( data_priv.get( this, "events" ) || {} )[ event.type ] || [], |
|
4405 special = jQuery.event.special[ event.type ] || {}; |
|
4406 |
|
4407 // Use the fix-ed jQuery.Event rather than the (read-only) native event |
|
4408 args[0] = event; |
|
4409 event.delegateTarget = this; |
|
4410 |
|
4411 // Call the preDispatch hook for the mapped type, and let it bail if desired |
|
4412 if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) { |
|
4413 return; |
|
4414 } |
|
4415 |
|
4416 // Determine handlers |
|
4417 handlerQueue = jQuery.event.handlers.call( this, event, handlers ); |
|
4418 |
|
4419 // Run delegates first; they may want to stop propagation beneath us |
|
4420 i = 0; |
|
4421 while ( (matched = handlerQueue[ i++ ]) && !event.isPropagationStopped() ) { |
|
4422 event.currentTarget = matched.elem; |
|
4423 |
|
4424 j = 0; |
|
4425 while ( (handleObj = matched.handlers[ j++ ]) && !event.isImmediatePropagationStopped() ) { |
|
4426 |
|
4427 // Triggered event must either 1) have no namespace, or 2) have namespace(s) |
|
4428 // a subset or equal to those in the bound event (both can have no namespace). |
|
4429 if ( !event.namespace_re || event.namespace_re.test( handleObj.namespace ) ) { |
|
4430 |
|
4431 event.handleObj = handleObj; |
|
4432 event.data = handleObj.data; |
|
4433 |
|
4434 ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || handleObj.handler ) |
|
4435 .apply( matched.elem, args ); |
|
4436 |
|
4437 if ( ret !== undefined ) { |
|
4438 if ( (event.result = ret) === false ) { |
|
4439 event.preventDefault(); |
|
4440 event.stopPropagation(); |
|
4441 } |
|
4442 } |
|
4443 } |
|
4444 } |
|
4445 } |
|
4446 |
|
4447 // Call the postDispatch hook for the mapped type |
|
4448 if ( special.postDispatch ) { |
|
4449 special.postDispatch.call( this, event ); |
|
4450 } |
|
4451 |
|
4452 return event.result; |
|
4453 }, |
|
4454 |
|
4455 handlers: function( event, handlers ) { |
|
4456 var i, matches, sel, handleObj, |
|
4457 handlerQueue = [], |
|
4458 delegateCount = handlers.delegateCount, |
|
4459 cur = event.target; |
|
4460 |
|
4461 // Find delegate handlers |
|
4462 // Black-hole SVG <use> instance trees (#13180) |
|
4463 // Avoid non-left-click bubbling in Firefox (#3861) |
|
4464 if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) { |
|
4465 |
|
4466 for ( ; cur !== this; cur = cur.parentNode || this ) { |
|
4467 |
|
4468 // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) |
|
4469 if ( cur.disabled !== true || event.type !== "click" ) { |
|
4470 matches = []; |
|
4471 for ( i = 0; i < delegateCount; i++ ) { |
|
4472 handleObj = handlers[ i ]; |
|
4473 |
|
4474 // Don't conflict with Object.prototype properties (#13203) |
|
4475 sel = handleObj.selector + " "; |
|
4476 |
|
4477 if ( matches[ sel ] === undefined ) { |
|
4478 matches[ sel ] = handleObj.needsContext ? |
|
4479 jQuery( sel, this ).index( cur ) >= 0 : |
|
4480 jQuery.find( sel, this, null, [ cur ] ).length; |
|
4481 } |
|
4482 if ( matches[ sel ] ) { |
|
4483 matches.push( handleObj ); |
|
4484 } |
|
4485 } |
|
4486 if ( matches.length ) { |
|
4487 handlerQueue.push({ elem: cur, handlers: matches }); |
|
4488 } |
|
4489 } |
|
4490 } |
|
4491 } |
|
4492 |
|
4493 // Add the remaining (directly-bound) handlers |
|
4494 if ( delegateCount < handlers.length ) { |
|
4495 handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) }); |
|
4496 } |
|
4497 |
|
4498 return handlerQueue; |
|
4499 }, |
|
4500 |
|
4501 // Includes some event props shared by KeyEvent and MouseEvent |
|
4502 props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), |
|
4503 |
|
4504 fixHooks: {}, |
|
4505 |
|
4506 keyHooks: { |
|
4507 props: "char charCode key keyCode".split(" "), |
|
4508 filter: function( event, original ) { |
|
4509 |
|
4510 // Add which for key events |
|
4511 if ( event.which == null ) { |
|
4512 event.which = original.charCode != null ? original.charCode : original.keyCode; |
|
4513 } |
|
4514 |
|
4515 return event; |
|
4516 } |
|
4517 }, |
|
4518 |
|
4519 mouseHooks: { |
|
4520 props: "button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "), |
|
4521 filter: function( event, original ) { |
|
4522 var eventDoc, doc, body, |
|
4523 button = original.button; |
|
4524 |
|
4525 // Calculate pageX/Y if missing and clientX/Y available |
|
4526 if ( event.pageX == null && original.clientX != null ) { |
|
4527 eventDoc = event.target.ownerDocument || document; |
|
4528 doc = eventDoc.documentElement; |
|
4529 body = eventDoc.body; |
|
4530 |
|
4531 event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft || body && body.clientLeft || 0 ); |
|
4532 event.pageY = original.clientY + ( doc && doc.scrollTop || body && body.scrollTop || 0 ) - ( doc && doc.clientTop || body && body.clientTop || 0 ); |
|
4533 } |
|
4534 |
|
4535 // Add which for click: 1 === left; 2 === middle; 3 === right |
|
4536 // Note: button is not normalized, so don't use it |
|
4537 if ( !event.which && button !== undefined ) { |
|
4538 event.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) ); |
|
4539 } |
|
4540 |
|
4541 return event; |
|
4542 } |
|
4543 }, |
|
4544 |
|
4545 fix: function( event ) { |
|
4546 if ( event[ jQuery.expando ] ) { |
|
4547 return event; |
|
4548 } |
|
4549 |
|
4550 // Create a writable copy of the event object and normalize some properties |
|
4551 var i, prop, copy, |
|
4552 type = event.type, |
|
4553 originalEvent = event, |
|
4554 fixHook = this.fixHooks[ type ]; |
|
4555 |
|
4556 if ( !fixHook ) { |
|
4557 this.fixHooks[ type ] = fixHook = |
|
4558 rmouseEvent.test( type ) ? this.mouseHooks : |
|
4559 rkeyEvent.test( type ) ? this.keyHooks : |
|
4560 {}; |
|
4561 } |
|
4562 copy = fixHook.props ? this.props.concat( fixHook.props ) : this.props; |
|
4563 |
|
4564 event = new jQuery.Event( originalEvent ); |
|
4565 |
|
4566 i = copy.length; |
|
4567 while ( i-- ) { |
|
4568 prop = copy[ i ]; |
|
4569 event[ prop ] = originalEvent[ prop ]; |
|
4570 } |
|
4571 |
|
4572 // Support: Cordova 2.5 (WebKit) (#13255) |
|
4573 // All events should have a target; Cordova deviceready doesn't |
|
4574 if ( !event.target ) { |
|
4575 event.target = document; |
|
4576 } |
|
4577 |
|
4578 // Support: Safari 6.0+, Chrome<28 |
|
4579 // Target should not be a text node (#504, #13143) |
|
4580 if ( event.target.nodeType === 3 ) { |
|
4581 event.target = event.target.parentNode; |
|
4582 } |
|
4583 |
|
4584 return fixHook.filter ? fixHook.filter( event, originalEvent ) : event; |
|
4585 }, |
|
4586 |
|
4587 special: { |
|
4588 load: { |
|
4589 // Prevent triggered image.load events from bubbling to window.load |
|
4590 noBubble: true |
|
4591 }, |
|
4592 focus: { |
|
4593 // Fire native event if possible so blur/focus sequence is correct |
|
4594 trigger: function() { |
|
4595 if ( this !== safeActiveElement() && this.focus ) { |
|
4596 this.focus(); |
|
4597 return false; |
|
4598 } |
|
4599 }, |
|
4600 delegateType: "focusin" |
|
4601 }, |
|
4602 blur: { |
|
4603 trigger: function() { |
|
4604 if ( this === safeActiveElement() && this.blur ) { |
|
4605 this.blur(); |
|
4606 return false; |
|
4607 } |
|
4608 }, |
|
4609 delegateType: "focusout" |
|
4610 }, |
|
4611 click: { |
|
4612 // For checkbox, fire native event so checked state will be right |
|
4613 trigger: function() { |
|
4614 if ( this.type === "checkbox" && this.click && jQuery.nodeName( this, "input" ) ) { |
|
4615 this.click(); |
|
4616 return false; |
|
4617 } |
|
4618 }, |
|
4619 |
|
4620 // For cross-browser consistency, don't fire native .click() on links |
|
4621 _default: function( event ) { |
|
4622 return jQuery.nodeName( event.target, "a" ); |
|
4623 } |
|
4624 }, |
|
4625 |
|
4626 beforeunload: { |
|
4627 postDispatch: function( event ) { |
|
4628 |
|
4629 // Support: Firefox 20+ |
|
4630 // Firefox doesn't alert if the returnValue field is not set. |
|
4631 if ( event.result !== undefined && event.originalEvent ) { |
|
4632 event.originalEvent.returnValue = event.result; |
|
4633 } |
|
4634 } |
|
4635 } |
|
4636 }, |
|
4637 |
|
4638 simulate: function( type, elem, event, bubble ) { |
|
4639 // Piggyback on a donor event to simulate a different one. |
|
4640 // Fake originalEvent to avoid donor's stopPropagation, but if the |
|
4641 // simulated event prevents default then we do the same on the donor. |
|
4642 var e = jQuery.extend( |
|
4643 new jQuery.Event(), |
|
4644 event, |
|
4645 { |
|
4646 type: type, |
|
4647 isSimulated: true, |
|
4648 originalEvent: {} |
|
4649 } |
|
4650 ); |
|
4651 if ( bubble ) { |
|
4652 jQuery.event.trigger( e, null, elem ); |
|
4653 } else { |
|
4654 jQuery.event.dispatch.call( elem, e ); |
|
4655 } |
|
4656 if ( e.isDefaultPrevented() ) { |
|
4657 event.preventDefault(); |
|
4658 } |
|
4659 } |
|
4660 }; |
|
4661 |
|
4662 jQuery.removeEvent = function( elem, type, handle ) { |
|
4663 if ( elem.removeEventListener ) { |
|
4664 elem.removeEventListener( type, handle, false ); |
|
4665 } |
|
4666 }; |
|
4667 |
|
4668 jQuery.Event = function( src, props ) { |
|
4669 // Allow instantiation without the 'new' keyword |
|
4670 if ( !(this instanceof jQuery.Event) ) { |
|
4671 return new jQuery.Event( src, props ); |
|
4672 } |
|
4673 |
|
4674 // Event object |
|
4675 if ( src && src.type ) { |
|
4676 this.originalEvent = src; |
|
4677 this.type = src.type; |
|
4678 |
|
4679 // Events bubbling up the document may have been marked as prevented |
|
4680 // by a handler lower down the tree; reflect the correct value. |
|
4681 this.isDefaultPrevented = src.defaultPrevented || |
|
4682 src.defaultPrevented === undefined && |
|
4683 // Support: Android<4.0 |
|
4684 src.returnValue === false ? |
|
4685 returnTrue : |
|
4686 returnFalse; |
|
4687 |
|
4688 // Event type |
|
4689 } else { |
|
4690 this.type = src; |
|
4691 } |
|
4692 |
|
4693 // Put explicitly provided properties onto the event object |
|
4694 if ( props ) { |
|
4695 jQuery.extend( this, props ); |
|
4696 } |
|
4697 |
|
4698 // Create a timestamp if incoming event doesn't have one |
|
4699 this.timeStamp = src && src.timeStamp || jQuery.now(); |
|
4700 |
|
4701 // Mark it as fixed |
|
4702 this[ jQuery.expando ] = true; |
|
4703 }; |
|
4704 |
|
4705 // jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding |
|
4706 // http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html |
|
4707 jQuery.Event.prototype = { |
|
4708 isDefaultPrevented: returnFalse, |
|
4709 isPropagationStopped: returnFalse, |
|
4710 isImmediatePropagationStopped: returnFalse, |
|
4711 |
|
4712 preventDefault: function() { |
|
4713 var e = this.originalEvent; |
|
4714 |
|
4715 this.isDefaultPrevented = returnTrue; |
|
4716 |
|
4717 if ( e && e.preventDefault ) { |
|
4718 e.preventDefault(); |
|
4719 } |
|
4720 }, |
|
4721 stopPropagation: function() { |
|
4722 var e = this.originalEvent; |
|
4723 |
|
4724 this.isPropagationStopped = returnTrue; |
|
4725 |
|
4726 if ( e && e.stopPropagation ) { |
|
4727 e.stopPropagation(); |
|
4728 } |
|
4729 }, |
|
4730 stopImmediatePropagation: function() { |
|
4731 var e = this.originalEvent; |
|
4732 |
|
4733 this.isImmediatePropagationStopped = returnTrue; |
|
4734 |
|
4735 if ( e && e.stopImmediatePropagation ) { |
|
4736 e.stopImmediatePropagation(); |
|
4737 } |
|
4738 |
|
4739 this.stopPropagation(); |
|
4740 } |
|
4741 }; |
|
4742 |
|
4743 // Create mouseenter/leave events using mouseover/out and event-time checks |
|
4744 // Support: Chrome 15+ |
|
4745 jQuery.each({ |
|
4746 mouseenter: "mouseover", |
|
4747 mouseleave: "mouseout", |
|
4748 pointerenter: "pointerover", |
|
4749 pointerleave: "pointerout" |
|
4750 }, function( orig, fix ) { |
|
4751 jQuery.event.special[ orig ] = { |
|
4752 delegateType: fix, |
|
4753 bindType: fix, |
|
4754 |
|
4755 handle: function( event ) { |
|
4756 var ret, |
|
4757 target = this, |
|
4758 related = event.relatedTarget, |
|
4759 handleObj = event.handleObj; |
|
4760 |
|
4761 // For mousenter/leave call the handler if related is outside the target. |
|
4762 // NB: No relatedTarget if the mouse left/entered the browser window |
|
4763 if ( !related || (related !== target && !jQuery.contains( target, related )) ) { |
|
4764 event.type = handleObj.origType; |
|
4765 ret = handleObj.handler.apply( this, arguments ); |
|
4766 event.type = fix; |
|
4767 } |
|
4768 return ret; |
|
4769 } |
|
4770 }; |
|
4771 }); |
|
4772 |
|
4773 // Support: Firefox, Chrome, Safari |
|
4774 // Create "bubbling" focus and blur events |
|
4775 if ( !support.focusinBubbles ) { |
|
4776 jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { |
|
4777 |
|
4778 // Attach a single capturing handler on the document while someone wants focusin/focusout |
|
4779 var handler = function( event ) { |
|
4780 jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ), true ); |
|
4781 }; |
|
4782 |
|
4783 jQuery.event.special[ fix ] = { |
|
4784 setup: function() { |
|
4785 var doc = this.ownerDocument || this, |
|
4786 attaches = data_priv.access( doc, fix ); |
|
4787 |
|
4788 if ( !attaches ) { |
|
4789 doc.addEventListener( orig, handler, true ); |
|
4790 } |
|
4791 data_priv.access( doc, fix, ( attaches || 0 ) + 1 ); |
|
4792 }, |
|
4793 teardown: function() { |
|
4794 var doc = this.ownerDocument || this, |
|
4795 attaches = data_priv.access( doc, fix ) - 1; |
|
4796 |
|
4797 if ( !attaches ) { |
|
4798 doc.removeEventListener( orig, handler, true ); |
|
4799 data_priv.remove( doc, fix ); |
|
4800 |
|
4801 } else { |
|
4802 data_priv.access( doc, fix, attaches ); |
|
4803 } |
|
4804 } |
|
4805 }; |
|
4806 }); |
|
4807 } |
|
4808 |
|
4809 jQuery.fn.extend({ |
|
4810 |
|
4811 on: function( types, selector, data, fn, /*INTERNAL*/ one ) { |
|
4812 var origFn, type; |
|
4813 |
|
4814 // Types can be a map of types/handlers |
|
4815 if ( typeof types === "object" ) { |
|
4816 // ( types-Object, selector, data ) |
|
4817 if ( typeof selector !== "string" ) { |
|
4818 // ( types-Object, data ) |
|
4819 data = data || selector; |
|
4820 selector = undefined; |
|
4821 } |
|
4822 for ( type in types ) { |
|
4823 this.on( type, selector, data, types[ type ], one ); |
|
4824 } |
|
4825 return this; |
|
4826 } |
|
4827 |
|
4828 if ( data == null && fn == null ) { |
|
4829 // ( types, fn ) |
|
4830 fn = selector; |
|
4831 data = selector = undefined; |
|
4832 } else if ( fn == null ) { |
|
4833 if ( typeof selector === "string" ) { |
|
4834 // ( types, selector, fn ) |
|
4835 fn = data; |
|
4836 data = undefined; |
|
4837 } else { |
|
4838 // ( types, data, fn ) |
|
4839 fn = data; |
|
4840 data = selector; |
|
4841 selector = undefined; |
|
4842 } |
|
4843 } |
|
4844 if ( fn === false ) { |
|
4845 fn = returnFalse; |
|
4846 } else if ( !fn ) { |
|
4847 return this; |
|
4848 } |
|
4849 |
|
4850 if ( one === 1 ) { |
|
4851 origFn = fn; |
|
4852 fn = function( event ) { |
|
4853 // Can use an empty set, since event contains the info |
|
4854 jQuery().off( event ); |
|
4855 return origFn.apply( this, arguments ); |
|
4856 }; |
|
4857 // Use same guid so caller can remove using origFn |
|
4858 fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); |
|
4859 } |
|
4860 return this.each( function() { |
|
4861 jQuery.event.add( this, types, fn, data, selector ); |
|
4862 }); |
|
4863 }, |
|
4864 one: function( types, selector, data, fn ) { |
|
4865 return this.on( types, selector, data, fn, 1 ); |
|
4866 }, |
|
4867 off: function( types, selector, fn ) { |
|
4868 var handleObj, type; |
|
4869 if ( types && types.preventDefault && types.handleObj ) { |
|
4870 // ( event ) dispatched jQuery.Event |
|
4871 handleObj = types.handleObj; |
|
4872 jQuery( types.delegateTarget ).off( |
|
4873 handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, |
|
4874 handleObj.selector, |
|
4875 handleObj.handler |
|
4876 ); |
|
4877 return this; |
|
4878 } |
|
4879 if ( typeof types === "object" ) { |
|
4880 // ( types-object [, selector] ) |
|
4881 for ( type in types ) { |
|
4882 this.off( type, selector, types[ type ] ); |
|
4883 } |
|
4884 return this; |
|
4885 } |
|
4886 if ( selector === false || typeof selector === "function" ) { |
|
4887 // ( types [, fn] ) |
|
4888 fn = selector; |
|
4889 selector = undefined; |
|
4890 } |
|
4891 if ( fn === false ) { |
|
4892 fn = returnFalse; |
|
4893 } |
|
4894 return this.each(function() { |
|
4895 jQuery.event.remove( this, types, fn, selector ); |
|
4896 }); |
|
4897 }, |
|
4898 |
|
4899 trigger: function( type, data ) { |
|
4900 return this.each(function() { |
|
4901 jQuery.event.trigger( type, data, this ); |
|
4902 }); |
|
4903 }, |
|
4904 triggerHandler: function( type, data ) { |
|
4905 var elem = this[0]; |
|
4906 if ( elem ) { |
|
4907 return jQuery.event.trigger( type, data, elem, true ); |
|
4908 } |
|
4909 } |
|
4910 }); |
|
4911 |
|
4912 |
|
4913 var |
|
4914 rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi, |
|
4915 rtagName = /<([\w:]+)/, |
|
4916 rhtml = /<|&#?\w+;/, |
|
4917 rnoInnerhtml = /<(?:script|style|link)/i, |
|
4918 // checked="checked" or checked |
|
4919 rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i, |
|
4920 rscriptType = /^$|\/(?:java|ecma)script/i, |
|
4921 rscriptTypeMasked = /^true\/(.*)/, |
|
4922 rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g, |
|
4923 |
|
4924 // We have to close these tags to support XHTML (#13200) |
|
4925 wrapMap = { |
|
4926 |
|
4927 // Support: IE9 |
|
4928 option: [ 1, "<select multiple='multiple'>", "</select>" ], |
|
4929 |
|
4930 thead: [ 1, "<table>", "</table>" ], |
|
4931 col: [ 2, "<table><colgroup>", "</colgroup></table>" ], |
|
4932 tr: [ 2, "<table><tbody>", "</tbody></table>" ], |
|
4933 td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ], |
|
4934 |
|
4935 _default: [ 0, "", "" ] |
|
4936 }; |
|
4937 |
|
4938 // Support: IE9 |
|
4939 wrapMap.optgroup = wrapMap.option; |
|
4940 |
|
4941 wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; |
|
4942 wrapMap.th = wrapMap.td; |
|
4943 |
|
4944 // Support: 1.x compatibility |
|
4945 // Manipulating tables requires a tbody |
|
4946 function manipulationTarget( elem, content ) { |
|
4947 return jQuery.nodeName( elem, "table" ) && |
|
4948 jQuery.nodeName( content.nodeType !== 11 ? content : content.firstChild, "tr" ) ? |
|
4949 |
|
4950 elem.getElementsByTagName("tbody")[0] || |
|
4951 elem.appendChild( elem.ownerDocument.createElement("tbody") ) : |
|
4952 elem; |
|
4953 } |
|
4954 |
|
4955 // Replace/restore the type attribute of script elements for safe DOM manipulation |
|
4956 function disableScript( elem ) { |
|
4957 elem.type = (elem.getAttribute("type") !== null) + "/" + elem.type; |
|
4958 return elem; |
|
4959 } |
|
4960 function restoreScript( elem ) { |
|
4961 var match = rscriptTypeMasked.exec( elem.type ); |
|
4962 |
|
4963 if ( match ) { |
|
4964 elem.type = match[ 1 ]; |
|
4965 } else { |
|
4966 elem.removeAttribute("type"); |
|
4967 } |
|
4968 |
|
4969 return elem; |
|
4970 } |
|
4971 |
|
4972 // Mark scripts as having already been evaluated |
|
4973 function setGlobalEval( elems, refElements ) { |
|
4974 var i = 0, |
|
4975 l = elems.length; |
|
4976 |
|
4977 for ( ; i < l; i++ ) { |
|
4978 data_priv.set( |
|
4979 elems[ i ], "globalEval", !refElements || data_priv.get( refElements[ i ], "globalEval" ) |
|
4980 ); |
|
4981 } |
|
4982 } |
|
4983 |
|
4984 function cloneCopyEvent( src, dest ) { |
|
4985 var i, l, type, pdataOld, pdataCur, udataOld, udataCur, events; |
|
4986 |
|
4987 if ( dest.nodeType !== 1 ) { |
|
4988 return; |
|
4989 } |
|
4990 |
|
4991 // 1. Copy private data: events, handlers, etc. |
|
4992 if ( data_priv.hasData( src ) ) { |
|
4993 pdataOld = data_priv.access( src ); |
|
4994 pdataCur = data_priv.set( dest, pdataOld ); |
|
4995 events = pdataOld.events; |
|
4996 |
|
4997 if ( events ) { |
|
4998 delete pdataCur.handle; |
|
4999 pdataCur.events = {}; |
|
5000 |
|
5001 for ( type in events ) { |
|
5002 for ( i = 0, l = events[ type ].length; i < l; i++ ) { |
|
5003 jQuery.event.add( dest, type, events[ type ][ i ] ); |
|
5004 } |
|
5005 } |
|
5006 } |
|
5007 } |
|
5008 |
|
5009 // 2. Copy user data |
|
5010 if ( data_user.hasData( src ) ) { |
|
5011 udataOld = data_user.access( src ); |
|
5012 udataCur = jQuery.extend( {}, udataOld ); |
|
5013 |
|
5014 data_user.set( dest, udataCur ); |
|
5015 } |
|
5016 } |
|
5017 |
|
5018 function getAll( context, tag ) { |
|
5019 var ret = context.getElementsByTagName ? context.getElementsByTagName( tag || "*" ) : |
|
5020 context.querySelectorAll ? context.querySelectorAll( tag || "*" ) : |
|
5021 []; |
|
5022 |
|
5023 return tag === undefined || tag && jQuery.nodeName( context, tag ) ? |
|
5024 jQuery.merge( [ context ], ret ) : |
|
5025 ret; |
|
5026 } |
|
5027 |
|
5028 // Fix IE bugs, see support tests |
|
5029 function fixInput( src, dest ) { |
|
5030 var nodeName = dest.nodeName.toLowerCase(); |
|
5031 |
|
5032 // Fails to persist the checked state of a cloned checkbox or radio button. |
|
5033 if ( nodeName === "input" && rcheckableType.test( src.type ) ) { |
|
5034 dest.checked = src.checked; |
|
5035 |
|
5036 // Fails to return the selected option to the default selected state when cloning options |
|
5037 } else if ( nodeName === "input" || nodeName === "textarea" ) { |
|
5038 dest.defaultValue = src.defaultValue; |
|
5039 } |
|
5040 } |
|
5041 |
|
5042 jQuery.extend({ |
|
5043 clone: function( elem, dataAndEvents, deepDataAndEvents ) { |
|
5044 var i, l, srcElements, destElements, |
|
5045 clone = elem.cloneNode( true ), |
|
5046 inPage = jQuery.contains( elem.ownerDocument, elem ); |
|
5047 |
|
5048 // Fix IE cloning issues |
|
5049 if ( !support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) && |
|
5050 !jQuery.isXMLDoc( elem ) ) { |
|
5051 |
|
5052 // We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2 |
|
5053 destElements = getAll( clone ); |
|
5054 srcElements = getAll( elem ); |
|
5055 |
|
5056 for ( i = 0, l = srcElements.length; i < l; i++ ) { |
|
5057 fixInput( srcElements[ i ], destElements[ i ] ); |
|
5058 } |
|
5059 } |
|
5060 |
|
5061 // Copy the events from the original to the clone |
|
5062 if ( dataAndEvents ) { |
|
5063 if ( deepDataAndEvents ) { |
|
5064 srcElements = srcElements || getAll( elem ); |
|
5065 destElements = destElements || getAll( clone ); |
|
5066 |
|
5067 for ( i = 0, l = srcElements.length; i < l; i++ ) { |
|
5068 cloneCopyEvent( srcElements[ i ], destElements[ i ] ); |
|
5069 } |
|
5070 } else { |
|
5071 cloneCopyEvent( elem, clone ); |
|
5072 } |
|
5073 } |
|
5074 |
|
5075 // Preserve script evaluation history |
|
5076 destElements = getAll( clone, "script" ); |
|
5077 if ( destElements.length > 0 ) { |
|
5078 setGlobalEval( destElements, !inPage && getAll( elem, "script" ) ); |
|
5079 } |
|
5080 |
|
5081 // Return the cloned set |
|
5082 return clone; |
|
5083 }, |
|
5084 |
|
5085 buildFragment: function( elems, context, scripts, selection ) { |
|
5086 var elem, tmp, tag, wrap, contains, j, |
|
5087 fragment = context.createDocumentFragment(), |
|
5088 nodes = [], |
|
5089 i = 0, |
|
5090 l = elems.length; |
|
5091 |
|
5092 for ( ; i < l; i++ ) { |
|
5093 elem = elems[ i ]; |
|
5094 |
|
5095 if ( elem || elem === 0 ) { |
|
5096 |
|
5097 // Add nodes directly |
|
5098 if ( jQuery.type( elem ) === "object" ) { |
|
5099 // Support: QtWebKit, PhantomJS |
|
5100 // push.apply(_, arraylike) throws on ancient WebKit |
|
5101 jQuery.merge( nodes, elem.nodeType ? [ elem ] : elem ); |
|
5102 |
|
5103 // Convert non-html into a text node |
|
5104 } else if ( !rhtml.test( elem ) ) { |
|
5105 nodes.push( context.createTextNode( elem ) ); |
|
5106 |
|
5107 // Convert html into DOM nodes |
|
5108 } else { |
|
5109 tmp = tmp || fragment.appendChild( context.createElement("div") ); |
|
5110 |
|
5111 // Deserialize a standard representation |
|
5112 tag = ( rtagName.exec( elem ) || [ "", "" ] )[ 1 ].toLowerCase(); |
|
5113 wrap = wrapMap[ tag ] || wrapMap._default; |
|
5114 tmp.innerHTML = wrap[ 1 ] + elem.replace( rxhtmlTag, "<$1></$2>" ) + wrap[ 2 ]; |
|
5115 |
|
5116 // Descend through wrappers to the right content |
|
5117 j = wrap[ 0 ]; |
|
5118 while ( j-- ) { |
|
5119 tmp = tmp.lastChild; |
|
5120 } |
|
5121 |
|
5122 // Support: QtWebKit, PhantomJS |
|
5123 // push.apply(_, arraylike) throws on ancient WebKit |
|
5124 jQuery.merge( nodes, tmp.childNodes ); |
|
5125 |
|
5126 // Remember the top-level container |
|
5127 tmp = fragment.firstChild; |
|
5128 |
|
5129 // Ensure the created nodes are orphaned (#12392) |
|
5130 tmp.textContent = ""; |
|
5131 } |
|
5132 } |
|
5133 } |
|
5134 |
|
5135 // Remove wrapper from fragment |
|
5136 fragment.textContent = ""; |
|
5137 |
|
5138 i = 0; |
|
5139 while ( (elem = nodes[ i++ ]) ) { |
|
5140 |
|
5141 // #4087 - If origin and destination elements are the same, and this is |
|
5142 // that element, do not do anything |
|
5143 if ( selection && jQuery.inArray( elem, selection ) !== -1 ) { |
|
5144 continue; |
|
5145 } |
|
5146 |
|
5147 contains = jQuery.contains( elem.ownerDocument, elem ); |
|
5148 |
|
5149 // Append to fragment |
|
5150 tmp = getAll( fragment.appendChild( elem ), "script" ); |
|
5151 |
|
5152 // Preserve script evaluation history |
|
5153 if ( contains ) { |
|
5154 setGlobalEval( tmp ); |
|
5155 } |
|
5156 |
|
5157 // Capture executables |
|
5158 if ( scripts ) { |
|
5159 j = 0; |
|
5160 while ( (elem = tmp[ j++ ]) ) { |
|
5161 if ( rscriptType.test( elem.type || "" ) ) { |
|
5162 scripts.push( elem ); |
|
5163 } |
|
5164 } |
|
5165 } |
|
5166 } |
|
5167 |
|
5168 return fragment; |
|
5169 }, |
|
5170 |
|
5171 cleanData: function( elems ) { |
|
5172 var data, elem, type, key, |
|
5173 special = jQuery.event.special, |
|
5174 i = 0; |
|
5175 |
|
5176 for ( ; (elem = elems[ i ]) !== undefined; i++ ) { |
|
5177 if ( jQuery.acceptData( elem ) ) { |
|
5178 key = elem[ data_priv.expando ]; |
|
5179 |
|
5180 if ( key && (data = data_priv.cache[ key ]) ) { |
|
5181 if ( data.events ) { |
|
5182 for ( type in data.events ) { |
|
5183 if ( special[ type ] ) { |
|
5184 jQuery.event.remove( elem, type ); |
|
5185 |
|
5186 // This is a shortcut to avoid jQuery.event.remove's overhead |
|
5187 } else { |
|
5188 jQuery.removeEvent( elem, type, data.handle ); |
|
5189 } |
|
5190 } |
|
5191 } |
|
5192 if ( data_priv.cache[ key ] ) { |
|
5193 // Discard any remaining `private` data |
|
5194 delete data_priv.cache[ key ]; |
|
5195 } |
|
5196 } |
|
5197 } |
|
5198 // Discard any remaining `user` data |
|
5199 delete data_user.cache[ elem[ data_user.expando ] ]; |
|
5200 } |
|
5201 } |
|
5202 }); |
|
5203 |
|
5204 jQuery.fn.extend({ |
|
5205 text: function( value ) { |
|
5206 return access( this, function( value ) { |
|
5207 return value === undefined ? |
|
5208 jQuery.text( this ) : |
|
5209 this.empty().each(function() { |
|
5210 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { |
|
5211 this.textContent = value; |
|
5212 } |
|
5213 }); |
|
5214 }, null, value, arguments.length ); |
|
5215 }, |
|
5216 |
|
5217 append: function() { |
|
5218 return this.domManip( arguments, function( elem ) { |
|
5219 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { |
|
5220 var target = manipulationTarget( this, elem ); |
|
5221 target.appendChild( elem ); |
|
5222 } |
|
5223 }); |
|
5224 }, |
|
5225 |
|
5226 prepend: function() { |
|
5227 return this.domManip( arguments, function( elem ) { |
|
5228 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { |
|
5229 var target = manipulationTarget( this, elem ); |
|
5230 target.insertBefore( elem, target.firstChild ); |
|
5231 } |
|
5232 }); |
|
5233 }, |
|
5234 |
|
5235 before: function() { |
|
5236 return this.domManip( arguments, function( elem ) { |
|
5237 if ( this.parentNode ) { |
|
5238 this.parentNode.insertBefore( elem, this ); |
|
5239 } |
|
5240 }); |
|
5241 }, |
|
5242 |
|
5243 after: function() { |
|
5244 return this.domManip( arguments, function( elem ) { |
|
5245 if ( this.parentNode ) { |
|
5246 this.parentNode.insertBefore( elem, this.nextSibling ); |
|
5247 } |
|
5248 }); |
|
5249 }, |
|
5250 |
|
5251 remove: function( selector, keepData /* Internal Use Only */ ) { |
|
5252 var elem, |
|
5253 elems = selector ? jQuery.filter( selector, this ) : this, |
|
5254 i = 0; |
|
5255 |
|
5256 for ( ; (elem = elems[i]) != null; i++ ) { |
|
5257 if ( !keepData && elem.nodeType === 1 ) { |
|
5258 jQuery.cleanData( getAll( elem ) ); |
|
5259 } |
|
5260 |
|
5261 if ( elem.parentNode ) { |
|
5262 if ( keepData && jQuery.contains( elem.ownerDocument, elem ) ) { |
|
5263 setGlobalEval( getAll( elem, "script" ) ); |
|
5264 } |
|
5265 elem.parentNode.removeChild( elem ); |
|
5266 } |
|
5267 } |
|
5268 |
|
5269 return this; |
|
5270 }, |
|
5271 |
|
5272 empty: function() { |
|
5273 var elem, |
|
5274 i = 0; |
|
5275 |
|
5276 for ( ; (elem = this[i]) != null; i++ ) { |
|
5277 if ( elem.nodeType === 1 ) { |
|
5278 |
|
5279 // Prevent memory leaks |
|
5280 jQuery.cleanData( getAll( elem, false ) ); |
|
5281 |
|
5282 // Remove any remaining nodes |
|
5283 elem.textContent = ""; |
|
5284 } |
|
5285 } |
|
5286 |
|
5287 return this; |
|
5288 }, |
|
5289 |
|
5290 clone: function( dataAndEvents, deepDataAndEvents ) { |
|
5291 dataAndEvents = dataAndEvents == null ? false : dataAndEvents; |
|
5292 deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents; |
|
5293 |
|
5294 return this.map(function() { |
|
5295 return jQuery.clone( this, dataAndEvents, deepDataAndEvents ); |
|
5296 }); |
|
5297 }, |
|
5298 |
|
5299 html: function( value ) { |
|
5300 return access( this, function( value ) { |
|
5301 var elem = this[ 0 ] || {}, |
|
5302 i = 0, |
|
5303 l = this.length; |
|
5304 |
|
5305 if ( value === undefined && elem.nodeType === 1 ) { |
|
5306 return elem.innerHTML; |
|
5307 } |
|
5308 |
|
5309 // See if we can take a shortcut and just use innerHTML |
|
5310 if ( typeof value === "string" && !rnoInnerhtml.test( value ) && |
|
5311 !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) { |
|
5312 |
|
5313 value = value.replace( rxhtmlTag, "<$1></$2>" ); |
|
5314 |
|
5315 try { |
|
5316 for ( ; i < l; i++ ) { |
|
5317 elem = this[ i ] || {}; |
|
5318 |
|
5319 // Remove element nodes and prevent memory leaks |
|
5320 if ( elem.nodeType === 1 ) { |
|
5321 jQuery.cleanData( getAll( elem, false ) ); |
|
5322 elem.innerHTML = value; |
|
5323 } |
|
5324 } |
|
5325 |
|
5326 elem = 0; |
|
5327 |
|
5328 // If using innerHTML throws an exception, use the fallback method |
|
5329 } catch( e ) {} |
|
5330 } |
|
5331 |
|
5332 if ( elem ) { |
|
5333 this.empty().append( value ); |
|
5334 } |
|
5335 }, null, value, arguments.length ); |
|
5336 }, |
|
5337 |
|
5338 replaceWith: function() { |
|
5339 var arg = arguments[ 0 ]; |
|
5340 |
|
5341 // Make the changes, replacing each context element with the new content |
|
5342 this.domManip( arguments, function( elem ) { |
|
5343 arg = this.parentNode; |
|
5344 |
|
5345 jQuery.cleanData( getAll( this ) ); |
|
5346 |
|
5347 if ( arg ) { |
|
5348 arg.replaceChild( elem, this ); |
|
5349 } |
|
5350 }); |
|
5351 |
|
5352 // Force removal if there was no new content (e.g., from empty arguments) |
|
5353 return arg && (arg.length || arg.nodeType) ? this : this.remove(); |
|
5354 }, |
|
5355 |
|
5356 detach: function( selector ) { |
|
5357 return this.remove( selector, true ); |
|
5358 }, |
|
5359 |
|
5360 domManip: function( args, callback ) { |
|
5361 |
|
5362 // Flatten any nested arrays |
|
5363 args = concat.apply( [], args ); |
|
5364 |
|
5365 var fragment, first, scripts, hasScripts, node, doc, |
|
5366 i = 0, |
|
5367 l = this.length, |
|
5368 set = this, |
|
5369 iNoClone = l - 1, |
|
5370 value = args[ 0 ], |
|
5371 isFunction = jQuery.isFunction( value ); |
|
5372 |
|
5373 // We can't cloneNode fragments that contain checked, in WebKit |
|
5374 if ( isFunction || |
|
5375 ( l > 1 && typeof value === "string" && |
|
5376 !support.checkClone && rchecked.test( value ) ) ) { |
|
5377 return this.each(function( index ) { |
|
5378 var self = set.eq( index ); |
|
5379 if ( isFunction ) { |
|
5380 args[ 0 ] = value.call( this, index, self.html() ); |
|
5381 } |
|
5382 self.domManip( args, callback ); |
|
5383 }); |
|
5384 } |
|
5385 |
|
5386 if ( l ) { |
|
5387 fragment = jQuery.buildFragment( args, this[ 0 ].ownerDocument, false, this ); |
|
5388 first = fragment.firstChild; |
|
5389 |
|
5390 if ( fragment.childNodes.length === 1 ) { |
|
5391 fragment = first; |
|
5392 } |
|
5393 |
|
5394 if ( first ) { |
|
5395 scripts = jQuery.map( getAll( fragment, "script" ), disableScript ); |
|
5396 hasScripts = scripts.length; |
|
5397 |
|
5398 // Use the original fragment for the last item instead of the first because it can end up |
|
5399 // being emptied incorrectly in certain situations (#8070). |
|
5400 for ( ; i < l; i++ ) { |
|
5401 node = fragment; |
|
5402 |
|
5403 if ( i !== iNoClone ) { |
|
5404 node = jQuery.clone( node, true, true ); |
|
5405 |
|
5406 // Keep references to cloned scripts for later restoration |
|
5407 if ( hasScripts ) { |
|
5408 // Support: QtWebKit |
|
5409 // jQuery.merge because push.apply(_, arraylike) throws |
|
5410 jQuery.merge( scripts, getAll( node, "script" ) ); |
|
5411 } |
|
5412 } |
|
5413 |
|
5414 callback.call( this[ i ], node, i ); |
|
5415 } |
|
5416 |
|
5417 if ( hasScripts ) { |
|
5418 doc = scripts[ scripts.length - 1 ].ownerDocument; |
|
5419 |
|
5420 // Reenable scripts |
|
5421 jQuery.map( scripts, restoreScript ); |
|
5422 |
|
5423 // Evaluate executable scripts on first document insertion |
|
5424 for ( i = 0; i < hasScripts; i++ ) { |
|
5425 node = scripts[ i ]; |
|
5426 if ( rscriptType.test( node.type || "" ) && |
|
5427 !data_priv.access( node, "globalEval" ) && jQuery.contains( doc, node ) ) { |
|
5428 |
|
5429 if ( node.src ) { |
|
5430 // Optional AJAX dependency, but won't run scripts if not present |
|
5431 if ( jQuery._evalUrl ) { |
|
5432 jQuery._evalUrl( node.src ); |
|
5433 } |
|
5434 } else { |
|
5435 jQuery.globalEval( node.textContent.replace( rcleanScript, "" ) ); |
|
5436 } |
|
5437 } |
|
5438 } |
|
5439 } |
|
5440 } |
|
5441 } |
|
5442 |
|
5443 return this; |
|
5444 } |
|
5445 }); |
|
5446 |
|
5447 jQuery.each({ |
|
5448 appendTo: "append", |
|
5449 prependTo: "prepend", |
|
5450 insertBefore: "before", |
|
5451 insertAfter: "after", |
|
5452 replaceAll: "replaceWith" |
|
5453 }, function( name, original ) { |
|
5454 jQuery.fn[ name ] = function( selector ) { |
|
5455 var elems, |
|
5456 ret = [], |
|
5457 insert = jQuery( selector ), |
|
5458 last = insert.length - 1, |
|
5459 i = 0; |
|
5460 |
|
5461 for ( ; i <= last; i++ ) { |
|
5462 elems = i === last ? this : this.clone( true ); |
|
5463 jQuery( insert[ i ] )[ original ]( elems ); |
|
5464 |
|
5465 // Support: QtWebKit |
|
5466 // .get() because push.apply(_, arraylike) throws |
|
5467 push.apply( ret, elems.get() ); |
|
5468 } |
|
5469 |
|
5470 return this.pushStack( ret ); |
|
5471 }; |
|
5472 }); |
|
5473 |
|
5474 |
|
5475 var iframe, |
|
5476 elemdisplay = {}; |
|
5477 |
|
5478 /** |
|
5479 * Retrieve the actual display of a element |
|
5480 * @param {String} name nodeName of the element |
|
5481 * @param {Object} doc Document object |
|
5482 */ |
|
5483 // Called only from within defaultDisplay |
|
5484 function actualDisplay( name, doc ) { |
|
5485 var style, |
|
5486 elem = jQuery( doc.createElement( name ) ).appendTo( doc.body ), |
|
5487 |
|
5488 // getDefaultComputedStyle might be reliably used only on attached element |
|
5489 display = window.getDefaultComputedStyle && ( style = window.getDefaultComputedStyle( elem[ 0 ] ) ) ? |
|
5490 |
|
5491 // Use of this method is a temporary fix (more like optimization) until something better comes along, |
|
5492 // since it was removed from specification and supported only in FF |
|
5493 style.display : jQuery.css( elem[ 0 ], "display" ); |
|
5494 |
|
5495 // We don't have any data stored on the element, |
|
5496 // so use "detach" method as fast way to get rid of the element |
|
5497 elem.detach(); |
|
5498 |
|
5499 return display; |
|
5500 } |
|
5501 |
|
5502 /** |
|
5503 * Try to determine the default display value of an element |
|
5504 * @param {String} nodeName |
|
5505 */ |
|
5506 function defaultDisplay( nodeName ) { |
|
5507 var doc = document, |
|
5508 display = elemdisplay[ nodeName ]; |
|
5509 |
|
5510 if ( !display ) { |
|
5511 display = actualDisplay( nodeName, doc ); |
|
5512 |
|
5513 // If the simple way fails, read from inside an iframe |
|
5514 if ( display === "none" || !display ) { |
|
5515 |
|
5516 // Use the already-created iframe if possible |
|
5517 iframe = (iframe || jQuery( "<iframe frameborder='0' width='0' height='0'/>" )).appendTo( doc.documentElement ); |
|
5518 |
|
5519 // Always write a new HTML skeleton so Webkit and Firefox don't choke on reuse |
|
5520 doc = iframe[ 0 ].contentDocument; |
|
5521 |
|
5522 // Support: IE |
|
5523 doc.write(); |
|
5524 doc.close(); |
|
5525 |
|
5526 display = actualDisplay( nodeName, doc ); |
|
5527 iframe.detach(); |
|
5528 } |
|
5529 |
|
5530 // Store the correct default display |
|
5531 elemdisplay[ nodeName ] = display; |
|
5532 } |
|
5533 |
|
5534 return display; |
|
5535 } |
|
5536 var rmargin = (/^margin/); |
|
5537 |
|
5538 var rnumnonpx = new RegExp( "^(" + pnum + ")(?!px)[a-z%]+$", "i" ); |
|
5539 |
|
5540 var getStyles = function( elem ) { |
|
5541 // Support: IE<=11+, Firefox<=30+ (#15098, #14150) |
|
5542 // IE throws on elements created in popups |
|
5543 // FF meanwhile throws on frame elements through "defaultView.getComputedStyle" |
|
5544 if ( elem.ownerDocument.defaultView.opener ) { |
|
5545 return elem.ownerDocument.defaultView.getComputedStyle( elem, null ); |
|
5546 } |
|
5547 |
|
5548 return window.getComputedStyle( elem, null ); |
|
5549 }; |
|
5550 |
|
5551 |
|
5552 |
|
5553 function curCSS( elem, name, computed ) { |
|
5554 var width, minWidth, maxWidth, ret, |
|
5555 style = elem.style; |
|
5556 |
|
5557 computed = computed || getStyles( elem ); |
|
5558 |
|
5559 // Support: IE9 |
|
5560 // getPropertyValue is only needed for .css('filter') (#12537) |
|
5561 if ( computed ) { |
|
5562 ret = computed.getPropertyValue( name ) || computed[ name ]; |
|
5563 } |
|
5564 |
|
5565 if ( computed ) { |
|
5566 |
|
5567 if ( ret === "" && !jQuery.contains( elem.ownerDocument, elem ) ) { |
|
5568 ret = jQuery.style( elem, name ); |
|
5569 } |
|
5570 |
|
5571 // Support: iOS < 6 |
|
5572 // A tribute to the "awesome hack by Dean Edwards" |
|
5573 // iOS < 6 (at least) returns percentage for a larger set of values, but width seems to be reliably pixels |
|
5574 // this is against the CSSOM draft spec: http://dev.w3.org/csswg/cssom/#resolved-values |
|
5575 if ( rnumnonpx.test( ret ) && rmargin.test( name ) ) { |
|
5576 |
|
5577 // Remember the original values |
|
5578 width = style.width; |
|
5579 minWidth = style.minWidth; |
|
5580 maxWidth = style.maxWidth; |
|
5581 |
|
5582 // Put in the new values to get a computed value out |
|
5583 style.minWidth = style.maxWidth = style.width = ret; |
|
5584 ret = computed.width; |
|
5585 |
|
5586 // Revert the changed values |
|
5587 style.width = width; |
|
5588 style.minWidth = minWidth; |
|
5589 style.maxWidth = maxWidth; |
|
5590 } |
|
5591 } |
|
5592 |
|
5593 return ret !== undefined ? |
|
5594 // Support: IE |
|
5595 // IE returns zIndex value as an integer. |
|
5596 ret + "" : |
|
5597 ret; |
|
5598 } |
|
5599 |
|
5600 |
|
5601 function addGetHookIf( conditionFn, hookFn ) { |
|
5602 // Define the hook, we'll check on the first run if it's really needed. |
|
5603 return { |
|
5604 get: function() { |
|
5605 if ( conditionFn() ) { |
|
5606 // Hook not needed (or it's not possible to use it due |
|
5607 // to missing dependency), remove it. |
|
5608 delete this.get; |
|
5609 return; |
|
5610 } |
|
5611 |
|
5612 // Hook needed; redefine it so that the support test is not executed again. |
|
5613 return (this.get = hookFn).apply( this, arguments ); |
|
5614 } |
|
5615 }; |
|
5616 } |
|
5617 |
|
5618 |
|
5619 (function() { |
|
5620 var pixelPositionVal, boxSizingReliableVal, |
|
5621 docElem = document.documentElement, |
|
5622 container = document.createElement( "div" ), |
|
5623 div = document.createElement( "div" ); |
|
5624 |
|
5625 if ( !div.style ) { |
|
5626 return; |
|
5627 } |
|
5628 |
|
5629 // Support: IE9-11+ |
|
5630 // Style of cloned element affects source element cloned (#8908) |
|
5631 div.style.backgroundClip = "content-box"; |
|
5632 div.cloneNode( true ).style.backgroundClip = ""; |
|
5633 support.clearCloneStyle = div.style.backgroundClip === "content-box"; |
|
5634 |
|
5635 container.style.cssText = "border:0;width:0;height:0;top:0;left:-9999px;margin-top:1px;" + |
|
5636 "position:absolute"; |
|
5637 container.appendChild( div ); |
|
5638 |
|
5639 // Executing both pixelPosition & boxSizingReliable tests require only one layout |
|
5640 // so they're executed at the same time to save the second computation. |
|
5641 function computePixelPositionAndBoxSizingReliable() { |
|
5642 div.style.cssText = |
|
5643 // Support: Firefox<29, Android 2.3 |
|
5644 // Vendor-prefix box-sizing |
|
5645 "-webkit-box-sizing:border-box;-moz-box-sizing:border-box;" + |
|
5646 "box-sizing:border-box;display:block;margin-top:1%;top:1%;" + |
|
5647 "border:1px;padding:1px;width:4px;position:absolute"; |
|
5648 div.innerHTML = ""; |
|
5649 docElem.appendChild( container ); |
|
5650 |
|
5651 var divStyle = window.getComputedStyle( div, null ); |
|
5652 pixelPositionVal = divStyle.top !== "1%"; |
|
5653 boxSizingReliableVal = divStyle.width === "4px"; |
|
5654 |
|
5655 docElem.removeChild( container ); |
|
5656 } |
|
5657 |
|
5658 // Support: node.js jsdom |
|
5659 // Don't assume that getComputedStyle is a property of the global object |
|
5660 if ( window.getComputedStyle ) { |
|
5661 jQuery.extend( support, { |
|
5662 pixelPosition: function() { |
|
5663 |
|
5664 // This test is executed only once but we still do memoizing |
|
5665 // since we can use the boxSizingReliable pre-computing. |
|
5666 // No need to check if the test was already performed, though. |
|
5667 computePixelPositionAndBoxSizingReliable(); |
|
5668 return pixelPositionVal; |
|
5669 }, |
|
5670 boxSizingReliable: function() { |
|
5671 if ( boxSizingReliableVal == null ) { |
|
5672 computePixelPositionAndBoxSizingReliable(); |
|
5673 } |
|
5674 return boxSizingReliableVal; |
|
5675 }, |
|
5676 reliableMarginRight: function() { |
|
5677 |
|
5678 // Support: Android 2.3 |
|
5679 // Check if div with explicit width and no margin-right incorrectly |
|
5680 // gets computed margin-right based on width of container. (#3333) |
|
5681 // WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right |
|
5682 // This support function is only executed once so no memoizing is needed. |
|
5683 var ret, |
|
5684 marginDiv = div.appendChild( document.createElement( "div" ) ); |
|
5685 |
|
5686 // Reset CSS: box-sizing; display; margin; border; padding |
|
5687 marginDiv.style.cssText = div.style.cssText = |
|
5688 // Support: Firefox<29, Android 2.3 |
|
5689 // Vendor-prefix box-sizing |
|
5690 "-webkit-box-sizing:content-box;-moz-box-sizing:content-box;" + |
|
5691 "box-sizing:content-box;display:block;margin:0;border:0;padding:0"; |
|
5692 marginDiv.style.marginRight = marginDiv.style.width = "0"; |
|
5693 div.style.width = "1px"; |
|
5694 docElem.appendChild( container ); |
|
5695 |
|
5696 ret = !parseFloat( window.getComputedStyle( marginDiv, null ).marginRight ); |
|
5697 |
|
5698 docElem.removeChild( container ); |
|
5699 div.removeChild( marginDiv ); |
|
5700 |
|
5701 return ret; |
|
5702 } |
|
5703 }); |
|
5704 } |
|
5705 })(); |
|
5706 |
|
5707 |
|
5708 // A method for quickly swapping in/out CSS properties to get correct calculations. |
|
5709 jQuery.swap = function( elem, options, callback, args ) { |
|
5710 var ret, name, |
|
5711 old = {}; |
|
5712 |
|
5713 // Remember the old values, and insert the new ones |
|
5714 for ( name in options ) { |
|
5715 old[ name ] = elem.style[ name ]; |
|
5716 elem.style[ name ] = options[ name ]; |
|
5717 } |
|
5718 |
|
5719 ret = callback.apply( elem, args || [] ); |
|
5720 |
|
5721 // Revert the old values |
|
5722 for ( name in options ) { |
|
5723 elem.style[ name ] = old[ name ]; |
|
5724 } |
|
5725 |
|
5726 return ret; |
|
5727 }; |
|
5728 |
|
5729 |
|
5730 var |
|
5731 // Swappable if display is none or starts with table except "table", "table-cell", or "table-caption" |
|
5732 // See here for display values: https://developer.mozilla.org/en-US/docs/CSS/display |
|
5733 rdisplayswap = /^(none|table(?!-c[ea]).+)/, |
|
5734 rnumsplit = new RegExp( "^(" + pnum + ")(.*)$", "i" ), |
|
5735 rrelNum = new RegExp( "^([+-])=(" + pnum + ")", "i" ), |
|
5736 |
|
5737 cssShow = { position: "absolute", visibility: "hidden", display: "block" }, |
|
5738 cssNormalTransform = { |
|
5739 letterSpacing: "0", |
|
5740 fontWeight: "400" |
|
5741 }, |
|
5742 |
|
5743 cssPrefixes = [ "Webkit", "O", "Moz", "ms" ]; |
|
5744 |
|
5745 // Return a css property mapped to a potentially vendor prefixed property |
|
5746 function vendorPropName( style, name ) { |
|
5747 |
|
5748 // Shortcut for names that are not vendor prefixed |
|
5749 if ( name in style ) { |
|
5750 return name; |
|
5751 } |
|
5752 |
|
5753 // Check for vendor prefixed names |
|
5754 var capName = name[0].toUpperCase() + name.slice(1), |
|
5755 origName = name, |
|
5756 i = cssPrefixes.length; |
|
5757 |
|
5758 while ( i-- ) { |
|
5759 name = cssPrefixes[ i ] + capName; |
|
5760 if ( name in style ) { |
|
5761 return name; |
|
5762 } |
|
5763 } |
|
5764 |
|
5765 return origName; |
|
5766 } |
|
5767 |
|
5768 function setPositiveNumber( elem, value, subtract ) { |
|
5769 var matches = rnumsplit.exec( value ); |
|
5770 return matches ? |
|
5771 // Guard against undefined "subtract", e.g., when used as in cssHooks |
|
5772 Math.max( 0, matches[ 1 ] - ( subtract || 0 ) ) + ( matches[ 2 ] || "px" ) : |
|
5773 value; |
|
5774 } |
|
5775 |
|
5776 function augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) { |
|
5777 var i = extra === ( isBorderBox ? "border" : "content" ) ? |
|
5778 // If we already have the right measurement, avoid augmentation |
|
5779 4 : |
|
5780 // Otherwise initialize for horizontal or vertical properties |
|
5781 name === "width" ? 1 : 0, |
|
5782 |
|
5783 val = 0; |
|
5784 |
|
5785 for ( ; i < 4; i += 2 ) { |
|
5786 // Both box models exclude margin, so add it if we want it |
|
5787 if ( extra === "margin" ) { |
|
5788 val += jQuery.css( elem, extra + cssExpand[ i ], true, styles ); |
|
5789 } |
|
5790 |
|
5791 if ( isBorderBox ) { |
|
5792 // border-box includes padding, so remove it if we want content |
|
5793 if ( extra === "content" ) { |
|
5794 val -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); |
|
5795 } |
|
5796 |
|
5797 // At this point, extra isn't border nor margin, so remove border |
|
5798 if ( extra !== "margin" ) { |
|
5799 val -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); |
|
5800 } |
|
5801 } else { |
|
5802 // At this point, extra isn't content, so add padding |
|
5803 val += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); |
|
5804 |
|
5805 // At this point, extra isn't content nor padding, so add border |
|
5806 if ( extra !== "padding" ) { |
|
5807 val += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); |
|
5808 } |
|
5809 } |
|
5810 } |
|
5811 |
|
5812 return val; |
|
5813 } |
|
5814 |
|
5815 function getWidthOrHeight( elem, name, extra ) { |
|
5816 |
|
5817 // Start with offset property, which is equivalent to the border-box value |
|
5818 var valueIsBorderBox = true, |
|
5819 val = name === "width" ? elem.offsetWidth : elem.offsetHeight, |
|
5820 styles = getStyles( elem ), |
|
5821 isBorderBox = jQuery.css( elem, "boxSizing", false, styles ) === "border-box"; |
|
5822 |
|
5823 // Some non-html elements return undefined for offsetWidth, so check for null/undefined |
|
5824 // svg - https://bugzilla.mozilla.org/show_bug.cgi?id=649285 |
|
5825 // MathML - https://bugzilla.mozilla.org/show_bug.cgi?id=491668 |
|
5826 if ( val <= 0 || val == null ) { |
|
5827 // Fall back to computed then uncomputed css if necessary |
|
5828 val = curCSS( elem, name, styles ); |
|
5829 if ( val < 0 || val == null ) { |
|
5830 val = elem.style[ name ]; |
|
5831 } |
|
5832 |
|
5833 // Computed unit is not pixels. Stop here and return. |
|
5834 if ( rnumnonpx.test(val) ) { |
|
5835 return val; |
|
5836 } |
|
5837 |
|
5838 // Check for style in case a browser which returns unreliable values |
|
5839 // for getComputedStyle silently falls back to the reliable elem.style |
|
5840 valueIsBorderBox = isBorderBox && |
|
5841 ( support.boxSizingReliable() || val === elem.style[ name ] ); |
|
5842 |
|
5843 // Normalize "", auto, and prepare for extra |
|
5844 val = parseFloat( val ) || 0; |
|
5845 } |
|
5846 |
|
5847 // Use the active box-sizing model to add/subtract irrelevant styles |
|
5848 return ( val + |
|
5849 augmentWidthOrHeight( |
|
5850 elem, |
|
5851 name, |
|
5852 extra || ( isBorderBox ? "border" : "content" ), |
|
5853 valueIsBorderBox, |
|
5854 styles |
|
5855 ) |
|
5856 ) + "px"; |
|
5857 } |
|
5858 |
|
5859 function showHide( elements, show ) { |
|
5860 var display, elem, hidden, |
|
5861 values = [], |
|
5862 index = 0, |
|
5863 length = elements.length; |
|
5864 |
|
5865 for ( ; index < length; index++ ) { |
|
5866 elem = elements[ index ]; |
|
5867 if ( !elem.style ) { |
|
5868 continue; |
|
5869 } |
|
5870 |
|
5871 values[ index ] = data_priv.get( elem, "olddisplay" ); |
|
5872 display = elem.style.display; |
|
5873 if ( show ) { |
|
5874 // Reset the inline display of this element to learn if it is |
|
5875 // being hidden by cascaded rules or not |
|
5876 if ( !values[ index ] && display === "none" ) { |
|
5877 elem.style.display = ""; |
|
5878 } |
|
5879 |
|
5880 // Set elements which have been overridden with display: none |
|
5881 // in a stylesheet to whatever the default browser style is |
|
5882 // for such an element |
|
5883 if ( elem.style.display === "" && isHidden( elem ) ) { |
|
5884 values[ index ] = data_priv.access( elem, "olddisplay", defaultDisplay(elem.nodeName) ); |
|
5885 } |
|
5886 } else { |
|
5887 hidden = isHidden( elem ); |
|
5888 |
|
5889 if ( display !== "none" || !hidden ) { |
|
5890 data_priv.set( elem, "olddisplay", hidden ? display : jQuery.css( elem, "display" ) ); |
|
5891 } |
|
5892 } |
|
5893 } |
|
5894 |
|
5895 // Set the display of most of the elements in a second loop |
|
5896 // to avoid the constant reflow |
|
5897 for ( index = 0; index < length; index++ ) { |
|
5898 elem = elements[ index ]; |
|
5899 if ( !elem.style ) { |
|
5900 continue; |
|
5901 } |
|
5902 if ( !show || elem.style.display === "none" || elem.style.display === "" ) { |
|
5903 elem.style.display = show ? values[ index ] || "" : "none"; |
|
5904 } |
|
5905 } |
|
5906 |
|
5907 return elements; |
|
5908 } |
|
5909 |
|
5910 jQuery.extend({ |
|
5911 |
|
5912 // Add in style property hooks for overriding the default |
|
5913 // behavior of getting and setting a style property |
|
5914 cssHooks: { |
|
5915 opacity: { |
|
5916 get: function( elem, computed ) { |
|
5917 if ( computed ) { |
|
5918 |
|
5919 // We should always get a number back from opacity |
|
5920 var ret = curCSS( elem, "opacity" ); |
|
5921 return ret === "" ? "1" : ret; |
|
5922 } |
|
5923 } |
|
5924 } |
|
5925 }, |
|
5926 |
|
5927 // Don't automatically add "px" to these possibly-unitless properties |
|
5928 cssNumber: { |
|
5929 "columnCount": true, |
|
5930 "fillOpacity": true, |
|
5931 "flexGrow": true, |
|
5932 "flexShrink": true, |
|
5933 "fontWeight": true, |
|
5934 "lineHeight": true, |
|
5935 "opacity": true, |
|
5936 "order": true, |
|
5937 "orphans": true, |
|
5938 "widows": true, |
|
5939 "zIndex": true, |
|
5940 "zoom": true |
|
5941 }, |
|
5942 |
|
5943 // Add in properties whose names you wish to fix before |
|
5944 // setting or getting the value |
|
5945 cssProps: { |
|
5946 "float": "cssFloat" |
|
5947 }, |
|
5948 |
|
5949 // Get and set the style property on a DOM Node |
|
5950 style: function( elem, name, value, extra ) { |
|
5951 |
|
5952 // Don't set styles on text and comment nodes |
|
5953 if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) { |
|
5954 return; |
|
5955 } |
|
5956 |
|
5957 // Make sure that we're working with the right name |
|
5958 var ret, type, hooks, |
|
5959 origName = jQuery.camelCase( name ), |
|
5960 style = elem.style; |
|
5961 |
|
5962 name = jQuery.cssProps[ origName ] || ( jQuery.cssProps[ origName ] = vendorPropName( style, origName ) ); |
|
5963 |
|
5964 // Gets hook for the prefixed version, then unprefixed version |
|
5965 hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; |
|
5966 |
|
5967 // Check if we're setting a value |
|
5968 if ( value !== undefined ) { |
|
5969 type = typeof value; |
|
5970 |
|
5971 // Convert "+=" or "-=" to relative numbers (#7345) |
|
5972 if ( type === "string" && (ret = rrelNum.exec( value )) ) { |
|
5973 value = ( ret[1] + 1 ) * ret[2] + parseFloat( jQuery.css( elem, name ) ); |
|
5974 // Fixes bug #9237 |
|
5975 type = "number"; |
|
5976 } |
|
5977 |
|
5978 // Make sure that null and NaN values aren't set (#7116) |
|
5979 if ( value == null || value !== value ) { |
|
5980 return; |
|
5981 } |
|
5982 |
|
5983 // If a number, add 'px' to the (except for certain CSS properties) |
|
5984 if ( type === "number" && !jQuery.cssNumber[ origName ] ) { |
|
5985 value += "px"; |
|
5986 } |
|
5987 |
|
5988 // Support: IE9-11+ |
|
5989 // background-* props affect original clone's values |
|
5990 if ( !support.clearCloneStyle && value === "" && name.indexOf( "background" ) === 0 ) { |
|
5991 style[ name ] = "inherit"; |
|
5992 } |
|
5993 |
|
5994 // If a hook was provided, use that value, otherwise just set the specified value |
|
5995 if ( !hooks || !("set" in hooks) || (value = hooks.set( elem, value, extra )) !== undefined ) { |
|
5996 style[ name ] = value; |
|
5997 } |
|
5998 |
|
5999 } else { |
|
6000 // If a hook was provided get the non-computed value from there |
|
6001 if ( hooks && "get" in hooks && (ret = hooks.get( elem, false, extra )) !== undefined ) { |
|
6002 return ret; |
|
6003 } |
|
6004 |
|
6005 // Otherwise just get the value from the style object |
|
6006 return style[ name ]; |
|
6007 } |
|
6008 }, |
|
6009 |
|
6010 css: function( elem, name, extra, styles ) { |
|
6011 var val, num, hooks, |
|
6012 origName = jQuery.camelCase( name ); |
|
6013 |
|
6014 // Make sure that we're working with the right name |
|
6015 name = jQuery.cssProps[ origName ] || ( jQuery.cssProps[ origName ] = vendorPropName( elem.style, origName ) ); |
|
6016 |
|
6017 // Try prefixed name followed by the unprefixed name |
|
6018 hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; |
|
6019 |
|
6020 // If a hook was provided get the computed value from there |
|
6021 if ( hooks && "get" in hooks ) { |
|
6022 val = hooks.get( elem, true, extra ); |
|
6023 } |
|
6024 |
|
6025 // Otherwise, if a way to get the computed value exists, use that |
|
6026 if ( val === undefined ) { |
|
6027 val = curCSS( elem, name, styles ); |
|
6028 } |
|
6029 |
|
6030 // Convert "normal" to computed value |
|
6031 if ( val === "normal" && name in cssNormalTransform ) { |
|
6032 val = cssNormalTransform[ name ]; |
|
6033 } |
|
6034 |
|
6035 // Make numeric if forced or a qualifier was provided and val looks numeric |
|
6036 if ( extra === "" || extra ) { |
|
6037 num = parseFloat( val ); |
|
6038 return extra === true || jQuery.isNumeric( num ) ? num || 0 : val; |
|
6039 } |
|
6040 return val; |
|
6041 } |
|
6042 }); |
|
6043 |
|
6044 jQuery.each([ "height", "width" ], function( i, name ) { |
|
6045 jQuery.cssHooks[ name ] = { |
|
6046 get: function( elem, computed, extra ) { |
|
6047 if ( computed ) { |
|
6048 |
|
6049 // Certain elements can have dimension info if we invisibly show them |
|
6050 // but it must have a current display style that would benefit |
|
6051 return rdisplayswap.test( jQuery.css( elem, "display" ) ) && elem.offsetWidth === 0 ? |
|
6052 jQuery.swap( elem, cssShow, function() { |
|
6053 return getWidthOrHeight( elem, name, extra ); |
|
6054 }) : |
|
6055 getWidthOrHeight( elem, name, extra ); |
|
6056 } |
|
6057 }, |
|
6058 |
|
6059 set: function( elem, value, extra ) { |
|
6060 var styles = extra && getStyles( elem ); |
|
6061 return setPositiveNumber( elem, value, extra ? |
|
6062 augmentWidthOrHeight( |
|
6063 elem, |
|
6064 name, |
|
6065 extra, |
|
6066 jQuery.css( elem, "boxSizing", false, styles ) === "border-box", |
|
6067 styles |
|
6068 ) : 0 |
|
6069 ); |
|
6070 } |
|
6071 }; |
|
6072 }); |
|
6073 |
|
6074 // Support: Android 2.3 |
|
6075 jQuery.cssHooks.marginRight = addGetHookIf( support.reliableMarginRight, |
|
6076 function( elem, computed ) { |
|
6077 if ( computed ) { |
|
6078 return jQuery.swap( elem, { "display": "inline-block" }, |
|
6079 curCSS, [ elem, "marginRight" ] ); |
|
6080 } |
|
6081 } |
|
6082 ); |
|
6083 |
|
6084 // These hooks are used by animate to expand properties |
|
6085 jQuery.each({ |
|
6086 margin: "", |
|
6087 padding: "", |
|
6088 border: "Width" |
|
6089 }, function( prefix, suffix ) { |
|
6090 jQuery.cssHooks[ prefix + suffix ] = { |
|
6091 expand: function( value ) { |
|
6092 var i = 0, |
|
6093 expanded = {}, |
|
6094 |
|
6095 // Assumes a single number if not a string |
|
6096 parts = typeof value === "string" ? value.split(" ") : [ value ]; |
|
6097 |
|
6098 for ( ; i < 4; i++ ) { |
|
6099 expanded[ prefix + cssExpand[ i ] + suffix ] = |
|
6100 parts[ i ] || parts[ i - 2 ] || parts[ 0 ]; |
|
6101 } |
|
6102 |
|
6103 return expanded; |
|
6104 } |
|
6105 }; |
|
6106 |
|
6107 if ( !rmargin.test( prefix ) ) { |
|
6108 jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber; |
|
6109 } |
|
6110 }); |
|
6111 |
|
6112 jQuery.fn.extend({ |
|
6113 css: function( name, value ) { |
|
6114 return access( this, function( elem, name, value ) { |
|
6115 var styles, len, |
|
6116 map = {}, |
|
6117 i = 0; |
|
6118 |
|
6119 if ( jQuery.isArray( name ) ) { |
|
6120 styles = getStyles( elem ); |
|
6121 len = name.length; |
|
6122 |
|
6123 for ( ; i < len; i++ ) { |
|
6124 map[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles ); |
|
6125 } |
|
6126 |
|
6127 return map; |
|
6128 } |
|
6129 |
|
6130 return value !== undefined ? |
|
6131 jQuery.style( elem, name, value ) : |
|
6132 jQuery.css( elem, name ); |
|
6133 }, name, value, arguments.length > 1 ); |
|
6134 }, |
|
6135 show: function() { |
|
6136 return showHide( this, true ); |
|
6137 }, |
|
6138 hide: function() { |
|
6139 return showHide( this ); |
|
6140 }, |
|
6141 toggle: function( state ) { |
|
6142 if ( typeof state === "boolean" ) { |
|
6143 return state ? this.show() : this.hide(); |
|
6144 } |
|
6145 |
|
6146 return this.each(function() { |
|
6147 if ( isHidden( this ) ) { |
|
6148 jQuery( this ).show(); |
|
6149 } else { |
|
6150 jQuery( this ).hide(); |
|
6151 } |
|
6152 }); |
|
6153 } |
|
6154 }); |
|
6155 |
|
6156 |
|
6157 function Tween( elem, options, prop, end, easing ) { |
|
6158 return new Tween.prototype.init( elem, options, prop, end, easing ); |
|
6159 } |
|
6160 jQuery.Tween = Tween; |
|
6161 |
|
6162 Tween.prototype = { |
|
6163 constructor: Tween, |
|
6164 init: function( elem, options, prop, end, easing, unit ) { |
|
6165 this.elem = elem; |
|
6166 this.prop = prop; |
|
6167 this.easing = easing || "swing"; |
|
6168 this.options = options; |
|
6169 this.start = this.now = this.cur(); |
|
6170 this.end = end; |
|
6171 this.unit = unit || ( jQuery.cssNumber[ prop ] ? "" : "px" ); |
|
6172 }, |
|
6173 cur: function() { |
|
6174 var hooks = Tween.propHooks[ this.prop ]; |
|
6175 |
|
6176 return hooks && hooks.get ? |
|
6177 hooks.get( this ) : |
|
6178 Tween.propHooks._default.get( this ); |
|
6179 }, |
|
6180 run: function( percent ) { |
|
6181 var eased, |
|
6182 hooks = Tween.propHooks[ this.prop ]; |
|
6183 |
|
6184 if ( this.options.duration ) { |
|
6185 this.pos = eased = jQuery.easing[ this.easing ]( |
|
6186 percent, this.options.duration * percent, 0, 1, this.options.duration |
|
6187 ); |
|
6188 } else { |
|
6189 this.pos = eased = percent; |
|
6190 } |
|
6191 this.now = ( this.end - this.start ) * eased + this.start; |
|
6192 |
|
6193 if ( this.options.step ) { |
|
6194 this.options.step.call( this.elem, this.now, this ); |
|
6195 } |
|
6196 |
|
6197 if ( hooks && hooks.set ) { |
|
6198 hooks.set( this ); |
|
6199 } else { |
|
6200 Tween.propHooks._default.set( this ); |
|
6201 } |
|
6202 return this; |
|
6203 } |
|
6204 }; |
|
6205 |
|
6206 Tween.prototype.init.prototype = Tween.prototype; |
|
6207 |
|
6208 Tween.propHooks = { |
|
6209 _default: { |
|
6210 get: function( tween ) { |
|
6211 var result; |
|
6212 |
|
6213 if ( tween.elem[ tween.prop ] != null && |
|
6214 (!tween.elem.style || tween.elem.style[ tween.prop ] == null) ) { |
|
6215 return tween.elem[ tween.prop ]; |
|
6216 } |
|
6217 |
|
6218 // Passing an empty string as a 3rd parameter to .css will automatically |
|
6219 // attempt a parseFloat and fallback to a string if the parse fails. |
|
6220 // Simple values such as "10px" are parsed to Float; |
|
6221 // complex values such as "rotate(1rad)" are returned as-is. |
|
6222 result = jQuery.css( tween.elem, tween.prop, "" ); |
|
6223 // Empty strings, null, undefined and "auto" are converted to 0. |
|
6224 return !result || result === "auto" ? 0 : result; |
|
6225 }, |
|
6226 set: function( tween ) { |
|
6227 // Use step hook for back compat. |
|
6228 // Use cssHook if its there. |
|
6229 // Use .style if available and use plain properties where available. |
|
6230 if ( jQuery.fx.step[ tween.prop ] ) { |
|
6231 jQuery.fx.step[ tween.prop ]( tween ); |
|
6232 } else if ( tween.elem.style && ( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null || jQuery.cssHooks[ tween.prop ] ) ) { |
|
6233 jQuery.style( tween.elem, tween.prop, tween.now + tween.unit ); |
|
6234 } else { |
|
6235 tween.elem[ tween.prop ] = tween.now; |
|
6236 } |
|
6237 } |
|
6238 } |
|
6239 }; |
|
6240 |
|
6241 // Support: IE9 |
|
6242 // Panic based approach to setting things on disconnected nodes |
|
6243 Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = { |
|
6244 set: function( tween ) { |
|
6245 if ( tween.elem.nodeType && tween.elem.parentNode ) { |
|
6246 tween.elem[ tween.prop ] = tween.now; |
|
6247 } |
|
6248 } |
|
6249 }; |
|
6250 |
|
6251 jQuery.easing = { |
|
6252 linear: function( p ) { |
|
6253 return p; |
|
6254 }, |
|
6255 swing: function( p ) { |
|
6256 return 0.5 - Math.cos( p * Math.PI ) / 2; |
|
6257 } |
|
6258 }; |
|
6259 |
|
6260 jQuery.fx = Tween.prototype.init; |
|
6261 |
|
6262 // Back Compat <1.8 extension point |
|
6263 jQuery.fx.step = {}; |
|
6264 |
|
6265 |
|
6266 |
|
6267 |
|
6268 var |
|
6269 fxNow, timerId, |
|
6270 rfxtypes = /^(?:toggle|show|hide)$/, |
|
6271 rfxnum = new RegExp( "^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i" ), |
|
6272 rrun = /queueHooks$/, |
|
6273 animationPrefilters = [ defaultPrefilter ], |
|
6274 tweeners = { |
|
6275 "*": [ function( prop, value ) { |
|
6276 var tween = this.createTween( prop, value ), |
|
6277 target = tween.cur(), |
|
6278 parts = rfxnum.exec( value ), |
|
6279 unit = parts && parts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ), |
|
6280 |
|
6281 // Starting value computation is required for potential unit mismatches |
|
6282 start = ( jQuery.cssNumber[ prop ] || unit !== "px" && +target ) && |
|
6283 rfxnum.exec( jQuery.css( tween.elem, prop ) ), |
|
6284 scale = 1, |
|
6285 maxIterations = 20; |
|
6286 |
|
6287 if ( start && start[ 3 ] !== unit ) { |
|
6288 // Trust units reported by jQuery.css |
|
6289 unit = unit || start[ 3 ]; |
|
6290 |
|
6291 // Make sure we update the tween properties later on |
|
6292 parts = parts || []; |
|
6293 |
|
6294 // Iteratively approximate from a nonzero starting point |
|
6295 start = +target || 1; |
|
6296 |
|
6297 do { |
|
6298 // If previous iteration zeroed out, double until we get *something*. |
|
6299 // Use string for doubling so we don't accidentally see scale as unchanged below |
|
6300 scale = scale || ".5"; |
|
6301 |
|
6302 // Adjust and apply |
|
6303 start = start / scale; |
|
6304 jQuery.style( tween.elem, prop, start + unit ); |
|
6305 |
|
6306 // Update scale, tolerating zero or NaN from tween.cur(), |
|
6307 // break the loop if scale is unchanged or perfect, or if we've just had enough |
|
6308 } while ( scale !== (scale = tween.cur() / target) && scale !== 1 && --maxIterations ); |
|
6309 } |
|
6310 |
|
6311 // Update tween properties |
|
6312 if ( parts ) { |
|
6313 start = tween.start = +start || +target || 0; |
|
6314 tween.unit = unit; |
|
6315 // If a +=/-= token was provided, we're doing a relative animation |
|
6316 tween.end = parts[ 1 ] ? |
|
6317 start + ( parts[ 1 ] + 1 ) * parts[ 2 ] : |
|
6318 +parts[ 2 ]; |
|
6319 } |
|
6320 |
|
6321 return tween; |
|
6322 } ] |
|
6323 }; |
|
6324 |
|
6325 // Animations created synchronously will run synchronously |
|
6326 function createFxNow() { |
|
6327 setTimeout(function() { |
|
6328 fxNow = undefined; |
|
6329 }); |
|
6330 return ( fxNow = jQuery.now() ); |
|
6331 } |
|
6332 |
|
6333 // Generate parameters to create a standard animation |
|
6334 function genFx( type, includeWidth ) { |
|
6335 var which, |
|
6336 i = 0, |
|
6337 attrs = { height: type }; |
|
6338 |
|
6339 // If we include width, step value is 1 to do all cssExpand values, |
|
6340 // otherwise step value is 2 to skip over Left and Right |
|
6341 includeWidth = includeWidth ? 1 : 0; |
|
6342 for ( ; i < 4 ; i += 2 - includeWidth ) { |
|
6343 which = cssExpand[ i ]; |
|
6344 attrs[ "margin" + which ] = attrs[ "padding" + which ] = type; |
|
6345 } |
|
6346 |
|
6347 if ( includeWidth ) { |
|
6348 attrs.opacity = attrs.width = type; |
|
6349 } |
|
6350 |
|
6351 return attrs; |
|
6352 } |
|
6353 |
|
6354 function createTween( value, prop, animation ) { |
|
6355 var tween, |
|
6356 collection = ( tweeners[ prop ] || [] ).concat( tweeners[ "*" ] ), |
|
6357 index = 0, |
|
6358 length = collection.length; |
|
6359 for ( ; index < length; index++ ) { |
|
6360 if ( (tween = collection[ index ].call( animation, prop, value )) ) { |
|
6361 |
|
6362 // We're done with this property |
|
6363 return tween; |
|
6364 } |
|
6365 } |
|
6366 } |
|
6367 |
|
6368 function defaultPrefilter( elem, props, opts ) { |
|
6369 /* jshint validthis: true */ |
|
6370 var prop, value, toggle, tween, hooks, oldfire, display, checkDisplay, |
|
6371 anim = this, |
|
6372 orig = {}, |
|
6373 style = elem.style, |
|
6374 hidden = elem.nodeType && isHidden( elem ), |
|
6375 dataShow = data_priv.get( elem, "fxshow" ); |
|
6376 |
|
6377 // Handle queue: false promises |
|
6378 if ( !opts.queue ) { |
|
6379 hooks = jQuery._queueHooks( elem, "fx" ); |
|
6380 if ( hooks.unqueued == null ) { |
|
6381 hooks.unqueued = 0; |
|
6382 oldfire = hooks.empty.fire; |
|
6383 hooks.empty.fire = function() { |
|
6384 if ( !hooks.unqueued ) { |
|
6385 oldfire(); |
|
6386 } |
|
6387 }; |
|
6388 } |
|
6389 hooks.unqueued++; |
|
6390 |
|
6391 anim.always(function() { |
|
6392 // Ensure the complete handler is called before this completes |
|
6393 anim.always(function() { |
|
6394 hooks.unqueued--; |
|
6395 if ( !jQuery.queue( elem, "fx" ).length ) { |
|
6396 hooks.empty.fire(); |
|
6397 } |
|
6398 }); |
|
6399 }); |
|
6400 } |
|
6401 |
|
6402 // Height/width overflow pass |
|
6403 if ( elem.nodeType === 1 && ( "height" in props || "width" in props ) ) { |
|
6404 // Make sure that nothing sneaks out |
|
6405 // Record all 3 overflow attributes because IE9-10 do not |
|
6406 // change the overflow attribute when overflowX and |
|
6407 // overflowY are set to the same value |
|
6408 opts.overflow = [ style.overflow, style.overflowX, style.overflowY ]; |
|
6409 |
|
6410 // Set display property to inline-block for height/width |
|
6411 // animations on inline elements that are having width/height animated |
|
6412 display = jQuery.css( elem, "display" ); |
|
6413 |
|
6414 // Test default display if display is currently "none" |
|
6415 checkDisplay = display === "none" ? |
|
6416 data_priv.get( elem, "olddisplay" ) || defaultDisplay( elem.nodeName ) : display; |
|
6417 |
|
6418 if ( checkDisplay === "inline" && jQuery.css( elem, "float" ) === "none" ) { |
|
6419 style.display = "inline-block"; |
|
6420 } |
|
6421 } |
|
6422 |
|
6423 if ( opts.overflow ) { |
|
6424 style.overflow = "hidden"; |
|
6425 anim.always(function() { |
|
6426 style.overflow = opts.overflow[ 0 ]; |
|
6427 style.overflowX = opts.overflow[ 1 ]; |
|
6428 style.overflowY = opts.overflow[ 2 ]; |
|
6429 }); |
|
6430 } |
|
6431 |
|
6432 // show/hide pass |
|
6433 for ( prop in props ) { |
|
6434 value = props[ prop ]; |
|
6435 if ( rfxtypes.exec( value ) ) { |
|
6436 delete props[ prop ]; |
|
6437 toggle = toggle || value === "toggle"; |
|
6438 if ( value === ( hidden ? "hide" : "show" ) ) { |
|
6439 |
|
6440 // If there is dataShow left over from a stopped hide or show and we are going to proceed with show, we should pretend to be hidden |
|
6441 if ( value === "show" && dataShow && dataShow[ prop ] !== undefined ) { |
|
6442 hidden = true; |
|
6443 } else { |
|
6444 continue; |
|
6445 } |
|
6446 } |
|
6447 orig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop ); |
|
6448 |
|
6449 // Any non-fx value stops us from restoring the original display value |
|
6450 } else { |
|
6451 display = undefined; |
|
6452 } |
|
6453 } |
|
6454 |
|
6455 if ( !jQuery.isEmptyObject( orig ) ) { |
|
6456 if ( dataShow ) { |
|
6457 if ( "hidden" in dataShow ) { |
|
6458 hidden = dataShow.hidden; |
|
6459 } |
|
6460 } else { |
|
6461 dataShow = data_priv.access( elem, "fxshow", {} ); |
|
6462 } |
|
6463 |
|
6464 // Store state if its toggle - enables .stop().toggle() to "reverse" |
|
6465 if ( toggle ) { |
|
6466 dataShow.hidden = !hidden; |
|
6467 } |
|
6468 if ( hidden ) { |
|
6469 jQuery( elem ).show(); |
|
6470 } else { |
|
6471 anim.done(function() { |
|
6472 jQuery( elem ).hide(); |
|
6473 }); |
|
6474 } |
|
6475 anim.done(function() { |
|
6476 var prop; |
|
6477 |
|
6478 data_priv.remove( elem, "fxshow" ); |
|
6479 for ( prop in orig ) { |
|
6480 jQuery.style( elem, prop, orig[ prop ] ); |
|
6481 } |
|
6482 }); |
|
6483 for ( prop in orig ) { |
|
6484 tween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim ); |
|
6485 |
|
6486 if ( !( prop in dataShow ) ) { |
|
6487 dataShow[ prop ] = tween.start; |
|
6488 if ( hidden ) { |
|
6489 tween.end = tween.start; |
|
6490 tween.start = prop === "width" || prop === "height" ? 1 : 0; |
|
6491 } |
|
6492 } |
|
6493 } |
|
6494 |
|
6495 // If this is a noop like .hide().hide(), restore an overwritten display value |
|
6496 } else if ( (display === "none" ? defaultDisplay( elem.nodeName ) : display) === "inline" ) { |
|
6497 style.display = display; |
|
6498 } |
|
6499 } |
|
6500 |
|
6501 function propFilter( props, specialEasing ) { |
|
6502 var index, name, easing, value, hooks; |
|
6503 |
|
6504 // camelCase, specialEasing and expand cssHook pass |
|
6505 for ( index in props ) { |
|
6506 name = jQuery.camelCase( index ); |
|
6507 easing = specialEasing[ name ]; |
|
6508 value = props[ index ]; |
|
6509 if ( jQuery.isArray( value ) ) { |
|
6510 easing = value[ 1 ]; |
|
6511 value = props[ index ] = value[ 0 ]; |
|
6512 } |
|
6513 |
|
6514 if ( index !== name ) { |
|
6515 props[ name ] = value; |
|
6516 delete props[ index ]; |
|
6517 } |
|
6518 |
|
6519 hooks = jQuery.cssHooks[ name ]; |
|
6520 if ( hooks && "expand" in hooks ) { |
|
6521 value = hooks.expand( value ); |
|
6522 delete props[ name ]; |
|
6523 |
|
6524 // Not quite $.extend, this won't overwrite existing keys. |
|
6525 // Reusing 'index' because we have the correct "name" |
|
6526 for ( index in value ) { |
|
6527 if ( !( index in props ) ) { |
|
6528 props[ index ] = value[ index ]; |
|
6529 specialEasing[ index ] = easing; |
|
6530 } |
|
6531 } |
|
6532 } else { |
|
6533 specialEasing[ name ] = easing; |
|
6534 } |
|
6535 } |
|
6536 } |
|
6537 |
|
6538 function Animation( elem, properties, options ) { |
|
6539 var result, |
|
6540 stopped, |
|
6541 index = 0, |
|
6542 length = animationPrefilters.length, |
|
6543 deferred = jQuery.Deferred().always( function() { |
|
6544 // Don't match elem in the :animated selector |
|
6545 delete tick.elem; |
|
6546 }), |
|
6547 tick = function() { |
|
6548 if ( stopped ) { |
|
6549 return false; |
|
6550 } |
|
6551 var currentTime = fxNow || createFxNow(), |
|
6552 remaining = Math.max( 0, animation.startTime + animation.duration - currentTime ), |
|
6553 // Support: Android 2.3 |
|
6554 // Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497) |
|
6555 temp = remaining / animation.duration || 0, |
|
6556 percent = 1 - temp, |
|
6557 index = 0, |
|
6558 length = animation.tweens.length; |
|
6559 |
|
6560 for ( ; index < length ; index++ ) { |
|
6561 animation.tweens[ index ].run( percent ); |
|
6562 } |
|
6563 |
|
6564 deferred.notifyWith( elem, [ animation, percent, remaining ]); |
|
6565 |
|
6566 if ( percent < 1 && length ) { |
|
6567 return remaining; |
|
6568 } else { |
|
6569 deferred.resolveWith( elem, [ animation ] ); |
|
6570 return false; |
|
6571 } |
|
6572 }, |
|
6573 animation = deferred.promise({ |
|
6574 elem: elem, |
|
6575 props: jQuery.extend( {}, properties ), |
|
6576 opts: jQuery.extend( true, { specialEasing: {} }, options ), |
|
6577 originalProperties: properties, |
|
6578 originalOptions: options, |
|
6579 startTime: fxNow || createFxNow(), |
|
6580 duration: options.duration, |
|
6581 tweens: [], |
|
6582 createTween: function( prop, end ) { |
|
6583 var tween = jQuery.Tween( elem, animation.opts, prop, end, |
|
6584 animation.opts.specialEasing[ prop ] || animation.opts.easing ); |
|
6585 animation.tweens.push( tween ); |
|
6586 return tween; |
|
6587 }, |
|
6588 stop: function( gotoEnd ) { |
|
6589 var index = 0, |
|
6590 // If we are going to the end, we want to run all the tweens |
|
6591 // otherwise we skip this part |
|
6592 length = gotoEnd ? animation.tweens.length : 0; |
|
6593 if ( stopped ) { |
|
6594 return this; |
|
6595 } |
|
6596 stopped = true; |
|
6597 for ( ; index < length ; index++ ) { |
|
6598 animation.tweens[ index ].run( 1 ); |
|
6599 } |
|
6600 |
|
6601 // Resolve when we played the last frame; otherwise, reject |
|
6602 if ( gotoEnd ) { |
|
6603 deferred.resolveWith( elem, [ animation, gotoEnd ] ); |
|
6604 } else { |
|
6605 deferred.rejectWith( elem, [ animation, gotoEnd ] ); |
|
6606 } |
|
6607 return this; |
|
6608 } |
|
6609 }), |
|
6610 props = animation.props; |
|
6611 |
|
6612 propFilter( props, animation.opts.specialEasing ); |
|
6613 |
|
6614 for ( ; index < length ; index++ ) { |
|
6615 result = animationPrefilters[ index ].call( animation, elem, props, animation.opts ); |
|
6616 if ( result ) { |
|
6617 return result; |
|
6618 } |
|
6619 } |
|
6620 |
|
6621 jQuery.map( props, createTween, animation ); |
|
6622 |
|
6623 if ( jQuery.isFunction( animation.opts.start ) ) { |
|
6624 animation.opts.start.call( elem, animation ); |
|
6625 } |
|
6626 |
|
6627 jQuery.fx.timer( |
|
6628 jQuery.extend( tick, { |
|
6629 elem: elem, |
|
6630 anim: animation, |
|
6631 queue: animation.opts.queue |
|
6632 }) |
|
6633 ); |
|
6634 |
|
6635 // attach callbacks from options |
|
6636 return animation.progress( animation.opts.progress ) |
|
6637 .done( animation.opts.done, animation.opts.complete ) |
|
6638 .fail( animation.opts.fail ) |
|
6639 .always( animation.opts.always ); |
|
6640 } |
|
6641 |
|
6642 jQuery.Animation = jQuery.extend( Animation, { |
|
6643 |
|
6644 tweener: function( props, callback ) { |
|
6645 if ( jQuery.isFunction( props ) ) { |
|
6646 callback = props; |
|
6647 props = [ "*" ]; |
|
6648 } else { |
|
6649 props = props.split(" "); |
|
6650 } |
|
6651 |
|
6652 var prop, |
|
6653 index = 0, |
|
6654 length = props.length; |
|
6655 |
|
6656 for ( ; index < length ; index++ ) { |
|
6657 prop = props[ index ]; |
|
6658 tweeners[ prop ] = tweeners[ prop ] || []; |
|
6659 tweeners[ prop ].unshift( callback ); |
|
6660 } |
|
6661 }, |
|
6662 |
|
6663 prefilter: function( callback, prepend ) { |
|
6664 if ( prepend ) { |
|
6665 animationPrefilters.unshift( callback ); |
|
6666 } else { |
|
6667 animationPrefilters.push( callback ); |
|
6668 } |
|
6669 } |
|
6670 }); |
|
6671 |
|
6672 jQuery.speed = function( speed, easing, fn ) { |
|
6673 var opt = speed && typeof speed === "object" ? jQuery.extend( {}, speed ) : { |
|
6674 complete: fn || !fn && easing || |
|
6675 jQuery.isFunction( speed ) && speed, |
|
6676 duration: speed, |
|
6677 easing: fn && easing || easing && !jQuery.isFunction( easing ) && easing |
|
6678 }; |
|
6679 |
|
6680 opt.duration = jQuery.fx.off ? 0 : typeof opt.duration === "number" ? opt.duration : |
|
6681 opt.duration in jQuery.fx.speeds ? jQuery.fx.speeds[ opt.duration ] : jQuery.fx.speeds._default; |
|
6682 |
|
6683 // Normalize opt.queue - true/undefined/null -> "fx" |
|
6684 if ( opt.queue == null || opt.queue === true ) { |
|
6685 opt.queue = "fx"; |
|
6686 } |
|
6687 |
|
6688 // Queueing |
|
6689 opt.old = opt.complete; |
|
6690 |
|
6691 opt.complete = function() { |
|
6692 if ( jQuery.isFunction( opt.old ) ) { |
|
6693 opt.old.call( this ); |
|
6694 } |
|
6695 |
|
6696 if ( opt.queue ) { |
|
6697 jQuery.dequeue( this, opt.queue ); |
|
6698 } |
|
6699 }; |
|
6700 |
|
6701 return opt; |
|
6702 }; |
|
6703 |
|
6704 jQuery.fn.extend({ |
|
6705 fadeTo: function( speed, to, easing, callback ) { |
|
6706 |
|
6707 // Show any hidden elements after setting opacity to 0 |
|
6708 return this.filter( isHidden ).css( "opacity", 0 ).show() |
|
6709 |
|
6710 // Animate to the value specified |
|
6711 .end().animate({ opacity: to }, speed, easing, callback ); |
|
6712 }, |
|
6713 animate: function( prop, speed, easing, callback ) { |
|
6714 var empty = jQuery.isEmptyObject( prop ), |
|
6715 optall = jQuery.speed( speed, easing, callback ), |
|
6716 doAnimation = function() { |
|
6717 // Operate on a copy of prop so per-property easing won't be lost |
|
6718 var anim = Animation( this, jQuery.extend( {}, prop ), optall ); |
|
6719 |
|
6720 // Empty animations, or finishing resolves immediately |
|
6721 if ( empty || data_priv.get( this, "finish" ) ) { |
|
6722 anim.stop( true ); |
|
6723 } |
|
6724 }; |
|
6725 doAnimation.finish = doAnimation; |
|
6726 |
|
6727 return empty || optall.queue === false ? |
|
6728 this.each( doAnimation ) : |
|
6729 this.queue( optall.queue, doAnimation ); |
|
6730 }, |
|
6731 stop: function( type, clearQueue, gotoEnd ) { |
|
6732 var stopQueue = function( hooks ) { |
|
6733 var stop = hooks.stop; |
|
6734 delete hooks.stop; |
|
6735 stop( gotoEnd ); |
|
6736 }; |
|
6737 |
|
6738 if ( typeof type !== "string" ) { |
|
6739 gotoEnd = clearQueue; |
|
6740 clearQueue = type; |
|
6741 type = undefined; |
|
6742 } |
|
6743 if ( clearQueue && type !== false ) { |
|
6744 this.queue( type || "fx", [] ); |
|
6745 } |
|
6746 |
|
6747 return this.each(function() { |
|
6748 var dequeue = true, |
|
6749 index = type != null && type + "queueHooks", |
|
6750 timers = jQuery.timers, |
|
6751 data = data_priv.get( this ); |
|
6752 |
|
6753 if ( index ) { |
|
6754 if ( data[ index ] && data[ index ].stop ) { |
|
6755 stopQueue( data[ index ] ); |
|
6756 } |
|
6757 } else { |
|
6758 for ( index in data ) { |
|
6759 if ( data[ index ] && data[ index ].stop && rrun.test( index ) ) { |
|
6760 stopQueue( data[ index ] ); |
|
6761 } |
|
6762 } |
|
6763 } |
|
6764 |
|
6765 for ( index = timers.length; index--; ) { |
|
6766 if ( timers[ index ].elem === this && (type == null || timers[ index ].queue === type) ) { |
|
6767 timers[ index ].anim.stop( gotoEnd ); |
|
6768 dequeue = false; |
|
6769 timers.splice( index, 1 ); |
|
6770 } |
|
6771 } |
|
6772 |
|
6773 // Start the next in the queue if the last step wasn't forced. |
|
6774 // Timers currently will call their complete callbacks, which |
|
6775 // will dequeue but only if they were gotoEnd. |
|
6776 if ( dequeue || !gotoEnd ) { |
|
6777 jQuery.dequeue( this, type ); |
|
6778 } |
|
6779 }); |
|
6780 }, |
|
6781 finish: function( type ) { |
|
6782 if ( type !== false ) { |
|
6783 type = type || "fx"; |
|
6784 } |
|
6785 return this.each(function() { |
|
6786 var index, |
|
6787 data = data_priv.get( this ), |
|
6788 queue = data[ type + "queue" ], |
|
6789 hooks = data[ type + "queueHooks" ], |
|
6790 timers = jQuery.timers, |
|
6791 length = queue ? queue.length : 0; |
|
6792 |
|
6793 // Enable finishing flag on private data |
|
6794 data.finish = true; |
|
6795 |
|
6796 // Empty the queue first |
|
6797 jQuery.queue( this, type, [] ); |
|
6798 |
|
6799 if ( hooks && hooks.stop ) { |
|
6800 hooks.stop.call( this, true ); |
|
6801 } |
|
6802 |
|
6803 // Look for any active animations, and finish them |
|
6804 for ( index = timers.length; index--; ) { |
|
6805 if ( timers[ index ].elem === this && timers[ index ].queue === type ) { |
|
6806 timers[ index ].anim.stop( true ); |
|
6807 timers.splice( index, 1 ); |
|
6808 } |
|
6809 } |
|
6810 |
|
6811 // Look for any animations in the old queue and finish them |
|
6812 for ( index = 0; index < length; index++ ) { |
|
6813 if ( queue[ index ] && queue[ index ].finish ) { |
|
6814 queue[ index ].finish.call( this ); |
|
6815 } |
|
6816 } |
|
6817 |
|
6818 // Turn off finishing flag |
|
6819 delete data.finish; |
|
6820 }); |
|
6821 } |
|
6822 }); |
|
6823 |
|
6824 jQuery.each([ "toggle", "show", "hide" ], function( i, name ) { |
|
6825 var cssFn = jQuery.fn[ name ]; |
|
6826 jQuery.fn[ name ] = function( speed, easing, callback ) { |
|
6827 return speed == null || typeof speed === "boolean" ? |
|
6828 cssFn.apply( this, arguments ) : |
|
6829 this.animate( genFx( name, true ), speed, easing, callback ); |
|
6830 }; |
|
6831 }); |
|
6832 |
|
6833 // Generate shortcuts for custom animations |
|
6834 jQuery.each({ |
|
6835 slideDown: genFx("show"), |
|
6836 slideUp: genFx("hide"), |
|
6837 slideToggle: genFx("toggle"), |
|
6838 fadeIn: { opacity: "show" }, |
|
6839 fadeOut: { opacity: "hide" }, |
|
6840 fadeToggle: { opacity: "toggle" } |
|
6841 }, function( name, props ) { |
|
6842 jQuery.fn[ name ] = function( speed, easing, callback ) { |
|
6843 return this.animate( props, speed, easing, callback ); |
|
6844 }; |
|
6845 }); |
|
6846 |
|
6847 jQuery.timers = []; |
|
6848 jQuery.fx.tick = function() { |
|
6849 var timer, |
|
6850 i = 0, |
|
6851 timers = jQuery.timers; |
|
6852 |
|
6853 fxNow = jQuery.now(); |
|
6854 |
|
6855 for ( ; i < timers.length; i++ ) { |
|
6856 timer = timers[ i ]; |
|
6857 // Checks the timer has not already been removed |
|
6858 if ( !timer() && timers[ i ] === timer ) { |
|
6859 timers.splice( i--, 1 ); |
|
6860 } |
|
6861 } |
|
6862 |
|
6863 if ( !timers.length ) { |
|
6864 jQuery.fx.stop(); |
|
6865 } |
|
6866 fxNow = undefined; |
|
6867 }; |
|
6868 |
|
6869 jQuery.fx.timer = function( timer ) { |
|
6870 jQuery.timers.push( timer ); |
|
6871 if ( timer() ) { |
|
6872 jQuery.fx.start(); |
|
6873 } else { |
|
6874 jQuery.timers.pop(); |
|
6875 } |
|
6876 }; |
|
6877 |
|
6878 jQuery.fx.interval = 13; |
|
6879 |
|
6880 jQuery.fx.start = function() { |
|
6881 if ( !timerId ) { |
|
6882 timerId = setInterval( jQuery.fx.tick, jQuery.fx.interval ); |
|
6883 } |
|
6884 }; |
|
6885 |
|
6886 jQuery.fx.stop = function() { |
|
6887 clearInterval( timerId ); |
|
6888 timerId = null; |
|
6889 }; |
|
6890 |
|
6891 jQuery.fx.speeds = { |
|
6892 slow: 600, |
|
6893 fast: 200, |
|
6894 // Default speed |
|
6895 _default: 400 |
|
6896 }; |
|
6897 |
|
6898 |
|
6899 // Based off of the plugin by Clint Helfers, with permission. |
|
6900 // http://blindsignals.com/index.php/2009/07/jquery-delay/ |
|
6901 jQuery.fn.delay = function( time, type ) { |
|
6902 time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time; |
|
6903 type = type || "fx"; |
|
6904 |
|
6905 return this.queue( type, function( next, hooks ) { |
|
6906 var timeout = setTimeout( next, time ); |
|
6907 hooks.stop = function() { |
|
6908 clearTimeout( timeout ); |
|
6909 }; |
|
6910 }); |
|
6911 }; |
|
6912 |
|
6913 |
|
6914 (function() { |
|
6915 var input = document.createElement( "input" ), |
|
6916 select = document.createElement( "select" ), |
|
6917 opt = select.appendChild( document.createElement( "option" ) ); |
|
6918 |
|
6919 input.type = "checkbox"; |
|
6920 |
|
6921 // Support: iOS<=5.1, Android<=4.2+ |
|
6922 // Default value for a checkbox should be "on" |
|
6923 support.checkOn = input.value !== ""; |
|
6924 |
|
6925 // Support: IE<=11+ |
|
6926 // Must access selectedIndex to make default options select |
|
6927 support.optSelected = opt.selected; |
|
6928 |
|
6929 // Support: Android<=2.3 |
|
6930 // Options inside disabled selects are incorrectly marked as disabled |
|
6931 select.disabled = true; |
|
6932 support.optDisabled = !opt.disabled; |
|
6933 |
|
6934 // Support: IE<=11+ |
|
6935 // An input loses its value after becoming a radio |
|
6936 input = document.createElement( "input" ); |
|
6937 input.value = "t"; |
|
6938 input.type = "radio"; |
|
6939 support.radioValue = input.value === "t"; |
|
6940 })(); |
|
6941 |
|
6942 |
3798 var nodeHook, boolHook, |
6943 var nodeHook, boolHook, |
3799 rclass = /[\t\r\n\f]/g, |
6944 attrHandle = jQuery.expr.attrHandle; |
3800 rreturn = /\r/g, |
|
3801 rfocusable = /^(?:input|select|textarea|button)$/i; |
|
3802 |
6945 |
3803 jQuery.fn.extend({ |
6946 jQuery.fn.extend({ |
3804 attr: function( name, value ) { |
6947 attr: function( name, value ) { |
3805 return jQuery.access( this, jQuery.attr, name, value, arguments.length > 1 ); |
6948 return access( this, jQuery.attr, name, value, arguments.length > 1 ); |
3806 }, |
6949 }, |
3807 |
6950 |
3808 removeAttr: function( name ) { |
6951 removeAttr: function( name ) { |
3809 return this.each(function() { |
6952 return this.each(function() { |
3810 jQuery.removeAttr( this, name ); |
6953 jQuery.removeAttr( this, name ); |
3811 }); |
6954 }); |
3812 }, |
|
3813 |
|
3814 prop: function( name, value ) { |
|
3815 return jQuery.access( this, jQuery.prop, name, value, arguments.length > 1 ); |
|
3816 }, |
|
3817 |
|
3818 removeProp: function( name ) { |
|
3819 return this.each(function() { |
|
3820 delete this[ jQuery.propFix[ name ] || name ]; |
|
3821 }); |
|
3822 }, |
|
3823 |
|
3824 addClass: function( value ) { |
|
3825 var classes, elem, cur, clazz, j, |
|
3826 i = 0, |
|
3827 len = this.length, |
|
3828 proceed = typeof value === "string" && value; |
|
3829 |
|
3830 if ( jQuery.isFunction( value ) ) { |
|
3831 return this.each(function( j ) { |
|
3832 jQuery( this ).addClass( value.call( this, j, this.className ) ); |
|
3833 }); |
|
3834 } |
|
3835 |
|
3836 if ( proceed ) { |
|
3837 // The disjunction here is for better compressibility (see removeClass) |
|
3838 classes = ( value || "" ).match( core_rnotwhite ) || []; |
|
3839 |
|
3840 for ( ; i < len; i++ ) { |
|
3841 elem = this[ i ]; |
|
3842 cur = elem.nodeType === 1 && ( elem.className ? |
|
3843 ( " " + elem.className + " " ).replace( rclass, " " ) : |
|
3844 " " |
|
3845 ); |
|
3846 |
|
3847 if ( cur ) { |
|
3848 j = 0; |
|
3849 while ( (clazz = classes[j++]) ) { |
|
3850 if ( cur.indexOf( " " + clazz + " " ) < 0 ) { |
|
3851 cur += clazz + " "; |
|
3852 } |
|
3853 } |
|
3854 elem.className = jQuery.trim( cur ); |
|
3855 |
|
3856 } |
|
3857 } |
|
3858 } |
|
3859 |
|
3860 return this; |
|
3861 }, |
|
3862 |
|
3863 removeClass: function( value ) { |
|
3864 var classes, elem, cur, clazz, j, |
|
3865 i = 0, |
|
3866 len = this.length, |
|
3867 proceed = arguments.length === 0 || typeof value === "string" && value; |
|
3868 |
|
3869 if ( jQuery.isFunction( value ) ) { |
|
3870 return this.each(function( j ) { |
|
3871 jQuery( this ).removeClass( value.call( this, j, this.className ) ); |
|
3872 }); |
|
3873 } |
|
3874 if ( proceed ) { |
|
3875 classes = ( value || "" ).match( core_rnotwhite ) || []; |
|
3876 |
|
3877 for ( ; i < len; i++ ) { |
|
3878 elem = this[ i ]; |
|
3879 // This expression is here for better compressibility (see addClass) |
|
3880 cur = elem.nodeType === 1 && ( elem.className ? |
|
3881 ( " " + elem.className + " " ).replace( rclass, " " ) : |
|
3882 "" |
|
3883 ); |
|
3884 |
|
3885 if ( cur ) { |
|
3886 j = 0; |
|
3887 while ( (clazz = classes[j++]) ) { |
|
3888 // Remove *all* instances |
|
3889 while ( cur.indexOf( " " + clazz + " " ) >= 0 ) { |
|
3890 cur = cur.replace( " " + clazz + " ", " " ); |
|
3891 } |
|
3892 } |
|
3893 elem.className = value ? jQuery.trim( cur ) : ""; |
|
3894 } |
|
3895 } |
|
3896 } |
|
3897 |
|
3898 return this; |
|
3899 }, |
|
3900 |
|
3901 toggleClass: function( value, stateVal ) { |
|
3902 var type = typeof value; |
|
3903 |
|
3904 if ( typeof stateVal === "boolean" && type === "string" ) { |
|
3905 return stateVal ? this.addClass( value ) : this.removeClass( value ); |
|
3906 } |
|
3907 |
|
3908 if ( jQuery.isFunction( value ) ) { |
|
3909 return this.each(function( i ) { |
|
3910 jQuery( this ).toggleClass( value.call(this, i, this.className, stateVal), stateVal ); |
|
3911 }); |
|
3912 } |
|
3913 |
|
3914 return this.each(function() { |
|
3915 if ( type === "string" ) { |
|
3916 // toggle individual class names |
|
3917 var className, |
|
3918 i = 0, |
|
3919 self = jQuery( this ), |
|
3920 classNames = value.match( core_rnotwhite ) || []; |
|
3921 |
|
3922 while ( (className = classNames[ i++ ]) ) { |
|
3923 // check each className given, space separated list |
|
3924 if ( self.hasClass( className ) ) { |
|
3925 self.removeClass( className ); |
|
3926 } else { |
|
3927 self.addClass( className ); |
|
3928 } |
|
3929 } |
|
3930 |
|
3931 // Toggle whole class name |
|
3932 } else if ( type === core_strundefined || type === "boolean" ) { |
|
3933 if ( this.className ) { |
|
3934 // store className if set |
|
3935 data_priv.set( this, "__className__", this.className ); |
|
3936 } |
|
3937 |
|
3938 // If the element has a class name or if we're passed "false", |
|
3939 // then remove the whole classname (if there was one, the above saved it). |
|
3940 // Otherwise bring back whatever was previously saved (if anything), |
|
3941 // falling back to the empty string if nothing was stored. |
|
3942 this.className = this.className || value === false ? "" : data_priv.get( this, "__className__" ) || ""; |
|
3943 } |
|
3944 }); |
|
3945 }, |
|
3946 |
|
3947 hasClass: function( selector ) { |
|
3948 var className = " " + selector + " ", |
|
3949 i = 0, |
|
3950 l = this.length; |
|
3951 for ( ; i < l; i++ ) { |
|
3952 if ( this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) >= 0 ) { |
|
3953 return true; |
|
3954 } |
|
3955 } |
|
3956 |
|
3957 return false; |
|
3958 }, |
|
3959 |
|
3960 val: function( value ) { |
|
3961 var hooks, ret, isFunction, |
|
3962 elem = this[0]; |
|
3963 |
|
3964 if ( !arguments.length ) { |
|
3965 if ( elem ) { |
|
3966 hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; |
|
3967 |
|
3968 if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { |
|
3969 return ret; |
|
3970 } |
|
3971 |
|
3972 ret = elem.value; |
|
3973 |
|
3974 return typeof ret === "string" ? |
|
3975 // handle most common string cases |
|
3976 ret.replace(rreturn, "") : |
|
3977 // handle cases where value is null/undef or number |
|
3978 ret == null ? "" : ret; |
|
3979 } |
|
3980 |
|
3981 return; |
|
3982 } |
|
3983 |
|
3984 isFunction = jQuery.isFunction( value ); |
|
3985 |
|
3986 return this.each(function( i ) { |
|
3987 var val; |
|
3988 |
|
3989 if ( this.nodeType !== 1 ) { |
|
3990 return; |
|
3991 } |
|
3992 |
|
3993 if ( isFunction ) { |
|
3994 val = value.call( this, i, jQuery( this ).val() ); |
|
3995 } else { |
|
3996 val = value; |
|
3997 } |
|
3998 |
|
3999 // Treat null/undefined as ""; convert numbers to string |
|
4000 if ( val == null ) { |
|
4001 val = ""; |
|
4002 } else if ( typeof val === "number" ) { |
|
4003 val += ""; |
|
4004 } else if ( jQuery.isArray( val ) ) { |
|
4005 val = jQuery.map(val, function ( value ) { |
|
4006 return value == null ? "" : value + ""; |
|
4007 }); |
|
4008 } |
|
4009 |
|
4010 hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; |
|
4011 |
|
4012 // If set returns undefined, fall back to normal setting |
|
4013 if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { |
|
4014 this.value = val; |
|
4015 } |
|
4016 }); |
|
4017 } |
6955 } |
4018 }); |
6956 }); |
4019 |
6957 |
4020 jQuery.extend({ |
6958 jQuery.extend({ |
4021 valHooks: { |
|
4022 option: { |
|
4023 get: function( elem ) { |
|
4024 // attributes.value is undefined in Blackberry 4.7 but |
|
4025 // uses .value. See #6932 |
|
4026 var val = elem.attributes.value; |
|
4027 return !val || val.specified ? elem.value : elem.text; |
|
4028 } |
|
4029 }, |
|
4030 select: { |
|
4031 get: function( elem ) { |
|
4032 var value, option, |
|
4033 options = elem.options, |
|
4034 index = elem.selectedIndex, |
|
4035 one = elem.type === "select-one" || index < 0, |
|
4036 values = one ? null : [], |
|
4037 max = one ? index + 1 : options.length, |
|
4038 i = index < 0 ? |
|
4039 max : |
|
4040 one ? index : 0; |
|
4041 |
|
4042 // Loop through all the selected options |
|
4043 for ( ; i < max; i++ ) { |
|
4044 option = options[ i ]; |
|
4045 |
|
4046 // IE6-9 doesn't update selected after form reset (#2551) |
|
4047 if ( ( option.selected || i === index ) && |
|
4048 // Don't return options that are disabled or in a disabled optgroup |
|
4049 ( jQuery.support.optDisabled ? !option.disabled : option.getAttribute("disabled") === null ) && |
|
4050 ( !option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" ) ) ) { |
|
4051 |
|
4052 // Get the specific value for the option |
|
4053 value = jQuery( option ).val(); |
|
4054 |
|
4055 // We don't need an array for one selects |
|
4056 if ( one ) { |
|
4057 return value; |
|
4058 } |
|
4059 |
|
4060 // Multi-Selects return an array |
|
4061 values.push( value ); |
|
4062 } |
|
4063 } |
|
4064 |
|
4065 return values; |
|
4066 }, |
|
4067 |
|
4068 set: function( elem, value ) { |
|
4069 var optionSet, option, |
|
4070 options = elem.options, |
|
4071 values = jQuery.makeArray( value ), |
|
4072 i = options.length; |
|
4073 |
|
4074 while ( i-- ) { |
|
4075 option = options[ i ]; |
|
4076 if ( (option.selected = jQuery.inArray( jQuery(option).val(), values ) >= 0) ) { |
|
4077 optionSet = true; |
|
4078 } |
|
4079 } |
|
4080 |
|
4081 // force browsers to behave consistently when non-matching value is set |
|
4082 if ( !optionSet ) { |
|
4083 elem.selectedIndex = -1; |
|
4084 } |
|
4085 return values; |
|
4086 } |
|
4087 } |
|
4088 }, |
|
4089 |
|
4090 attr: function( elem, name, value ) { |
6959 attr: function( elem, name, value ) { |
4091 var hooks, ret, |
6960 var hooks, ret, |
4092 nType = elem.nodeType; |
6961 nType = elem.nodeType; |
4093 |
6962 |
4094 // don't get/set attributes on text, comment and attribute nodes |
6963 // don't get/set attributes on text, comment and attribute nodes |
4095 if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
6964 if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { |
4096 return; |
6965 return; |
4097 } |
6966 } |
4098 |
6967 |
4099 // Fallback to prop when attributes are not supported |
6968 // Fallback to prop when attributes are not supported |
4100 if ( typeof elem.getAttribute === core_strundefined ) { |
6969 if ( typeof elem.getAttribute === strundefined ) { |
4101 return jQuery.prop( elem, name, value ); |
6970 return jQuery.prop( elem, name, value ); |
4102 } |
6971 } |
4103 |
6972 |
4104 // All attributes are lowercase |
6973 // All attributes are lowercase |
4105 // Grab necessary hook if one is defined |
6974 // Grab necessary hook if one is defined |
4278 "contentEditable" |
7159 "contentEditable" |
4279 ], function() { |
7160 ], function() { |
4280 jQuery.propFix[ this.toLowerCase() ] = this; |
7161 jQuery.propFix[ this.toLowerCase() ] = this; |
4281 }); |
7162 }); |
4282 |
7163 |
|
7164 |
|
7165 |
|
7166 |
|
7167 var rclass = /[\t\r\n\f]/g; |
|
7168 |
|
7169 jQuery.fn.extend({ |
|
7170 addClass: function( value ) { |
|
7171 var classes, elem, cur, clazz, j, finalValue, |
|
7172 proceed = typeof value === "string" && value, |
|
7173 i = 0, |
|
7174 len = this.length; |
|
7175 |
|
7176 if ( jQuery.isFunction( value ) ) { |
|
7177 return this.each(function( j ) { |
|
7178 jQuery( this ).addClass( value.call( this, j, this.className ) ); |
|
7179 }); |
|
7180 } |
|
7181 |
|
7182 if ( proceed ) { |
|
7183 // The disjunction here is for better compressibility (see removeClass) |
|
7184 classes = ( value || "" ).match( rnotwhite ) || []; |
|
7185 |
|
7186 for ( ; i < len; i++ ) { |
|
7187 elem = this[ i ]; |
|
7188 cur = elem.nodeType === 1 && ( elem.className ? |
|
7189 ( " " + elem.className + " " ).replace( rclass, " " ) : |
|
7190 " " |
|
7191 ); |
|
7192 |
|
7193 if ( cur ) { |
|
7194 j = 0; |
|
7195 while ( (clazz = classes[j++]) ) { |
|
7196 if ( cur.indexOf( " " + clazz + " " ) < 0 ) { |
|
7197 cur += clazz + " "; |
|
7198 } |
|
7199 } |
|
7200 |
|
7201 // only assign if different to avoid unneeded rendering. |
|
7202 finalValue = jQuery.trim( cur ); |
|
7203 if ( elem.className !== finalValue ) { |
|
7204 elem.className = finalValue; |
|
7205 } |
|
7206 } |
|
7207 } |
|
7208 } |
|
7209 |
|
7210 return this; |
|
7211 }, |
|
7212 |
|
7213 removeClass: function( value ) { |
|
7214 var classes, elem, cur, clazz, j, finalValue, |
|
7215 proceed = arguments.length === 0 || typeof value === "string" && value, |
|
7216 i = 0, |
|
7217 len = this.length; |
|
7218 |
|
7219 if ( jQuery.isFunction( value ) ) { |
|
7220 return this.each(function( j ) { |
|
7221 jQuery( this ).removeClass( value.call( this, j, this.className ) ); |
|
7222 }); |
|
7223 } |
|
7224 if ( proceed ) { |
|
7225 classes = ( value || "" ).match( rnotwhite ) || []; |
|
7226 |
|
7227 for ( ; i < len; i++ ) { |
|
7228 elem = this[ i ]; |
|
7229 // This expression is here for better compressibility (see addClass) |
|
7230 cur = elem.nodeType === 1 && ( elem.className ? |
|
7231 ( " " + elem.className + " " ).replace( rclass, " " ) : |
|
7232 "" |
|
7233 ); |
|
7234 |
|
7235 if ( cur ) { |
|
7236 j = 0; |
|
7237 while ( (clazz = classes[j++]) ) { |
|
7238 // Remove *all* instances |
|
7239 while ( cur.indexOf( " " + clazz + " " ) >= 0 ) { |
|
7240 cur = cur.replace( " " + clazz + " ", " " ); |
|
7241 } |
|
7242 } |
|
7243 |
|
7244 // Only assign if different to avoid unneeded rendering. |
|
7245 finalValue = value ? jQuery.trim( cur ) : ""; |
|
7246 if ( elem.className !== finalValue ) { |
|
7247 elem.className = finalValue; |
|
7248 } |
|
7249 } |
|
7250 } |
|
7251 } |
|
7252 |
|
7253 return this; |
|
7254 }, |
|
7255 |
|
7256 toggleClass: function( value, stateVal ) { |
|
7257 var type = typeof value; |
|
7258 |
|
7259 if ( typeof stateVal === "boolean" && type === "string" ) { |
|
7260 return stateVal ? this.addClass( value ) : this.removeClass( value ); |
|
7261 } |
|
7262 |
|
7263 if ( jQuery.isFunction( value ) ) { |
|
7264 return this.each(function( i ) { |
|
7265 jQuery( this ).toggleClass( value.call(this, i, this.className, stateVal), stateVal ); |
|
7266 }); |
|
7267 } |
|
7268 |
|
7269 return this.each(function() { |
|
7270 if ( type === "string" ) { |
|
7271 // Toggle individual class names |
|
7272 var className, |
|
7273 i = 0, |
|
7274 self = jQuery( this ), |
|
7275 classNames = value.match( rnotwhite ) || []; |
|
7276 |
|
7277 while ( (className = classNames[ i++ ]) ) { |
|
7278 // Check each className given, space separated list |
|
7279 if ( self.hasClass( className ) ) { |
|
7280 self.removeClass( className ); |
|
7281 } else { |
|
7282 self.addClass( className ); |
|
7283 } |
|
7284 } |
|
7285 |
|
7286 // Toggle whole class name |
|
7287 } else if ( type === strundefined || type === "boolean" ) { |
|
7288 if ( this.className ) { |
|
7289 // store className if set |
|
7290 data_priv.set( this, "__className__", this.className ); |
|
7291 } |
|
7292 |
|
7293 // If the element has a class name or if we're passed `false`, |
|
7294 // then remove the whole classname (if there was one, the above saved it). |
|
7295 // Otherwise bring back whatever was previously saved (if anything), |
|
7296 // falling back to the empty string if nothing was stored. |
|
7297 this.className = this.className || value === false ? "" : data_priv.get( this, "__className__" ) || ""; |
|
7298 } |
|
7299 }); |
|
7300 }, |
|
7301 |
|
7302 hasClass: function( selector ) { |
|
7303 var className = " " + selector + " ", |
|
7304 i = 0, |
|
7305 l = this.length; |
|
7306 for ( ; i < l; i++ ) { |
|
7307 if ( this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) >= 0 ) { |
|
7308 return true; |
|
7309 } |
|
7310 } |
|
7311 |
|
7312 return false; |
|
7313 } |
|
7314 }); |
|
7315 |
|
7316 |
|
7317 |
|
7318 |
|
7319 var rreturn = /\r/g; |
|
7320 |
|
7321 jQuery.fn.extend({ |
|
7322 val: function( value ) { |
|
7323 var hooks, ret, isFunction, |
|
7324 elem = this[0]; |
|
7325 |
|
7326 if ( !arguments.length ) { |
|
7327 if ( elem ) { |
|
7328 hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; |
|
7329 |
|
7330 if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { |
|
7331 return ret; |
|
7332 } |
|
7333 |
|
7334 ret = elem.value; |
|
7335 |
|
7336 return typeof ret === "string" ? |
|
7337 // Handle most common string cases |
|
7338 ret.replace(rreturn, "") : |
|
7339 // Handle cases where value is null/undef or number |
|
7340 ret == null ? "" : ret; |
|
7341 } |
|
7342 |
|
7343 return; |
|
7344 } |
|
7345 |
|
7346 isFunction = jQuery.isFunction( value ); |
|
7347 |
|
7348 return this.each(function( i ) { |
|
7349 var val; |
|
7350 |
|
7351 if ( this.nodeType !== 1 ) { |
|
7352 return; |
|
7353 } |
|
7354 |
|
7355 if ( isFunction ) { |
|
7356 val = value.call( this, i, jQuery( this ).val() ); |
|
7357 } else { |
|
7358 val = value; |
|
7359 } |
|
7360 |
|
7361 // Treat null/undefined as ""; convert numbers to string |
|
7362 if ( val == null ) { |
|
7363 val = ""; |
|
7364 |
|
7365 } else if ( typeof val === "number" ) { |
|
7366 val += ""; |
|
7367 |
|
7368 } else if ( jQuery.isArray( val ) ) { |
|
7369 val = jQuery.map( val, function( value ) { |
|
7370 return value == null ? "" : value + ""; |
|
7371 }); |
|
7372 } |
|
7373 |
|
7374 hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; |
|
7375 |
|
7376 // If set returns undefined, fall back to normal setting |
|
7377 if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { |
|
7378 this.value = val; |
|
7379 } |
|
7380 }); |
|
7381 } |
|
7382 }); |
|
7383 |
|
7384 jQuery.extend({ |
|
7385 valHooks: { |
|
7386 option: { |
|
7387 get: function( elem ) { |
|
7388 var val = jQuery.find.attr( elem, "value" ); |
|
7389 return val != null ? |
|
7390 val : |
|
7391 // Support: IE10-11+ |
|
7392 // option.text throws exceptions (#14686, #14858) |
|
7393 jQuery.trim( jQuery.text( elem ) ); |
|
7394 } |
|
7395 }, |
|
7396 select: { |
|
7397 get: function( elem ) { |
|
7398 var value, option, |
|
7399 options = elem.options, |
|
7400 index = elem.selectedIndex, |
|
7401 one = elem.type === "select-one" || index < 0, |
|
7402 values = one ? null : [], |
|
7403 max = one ? index + 1 : options.length, |
|
7404 i = index < 0 ? |
|
7405 max : |
|
7406 one ? index : 0; |
|
7407 |
|
7408 // Loop through all the selected options |
|
7409 for ( ; i < max; i++ ) { |
|
7410 option = options[ i ]; |
|
7411 |
|
7412 // IE6-9 doesn't update selected after form reset (#2551) |
|
7413 if ( ( option.selected || i === index ) && |
|
7414 // Don't return options that are disabled or in a disabled optgroup |
|
7415 ( support.optDisabled ? !option.disabled : option.getAttribute( "disabled" ) === null ) && |
|
7416 ( !option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" ) ) ) { |
|
7417 |
|
7418 // Get the specific value for the option |
|
7419 value = jQuery( option ).val(); |
|
7420 |
|
7421 // We don't need an array for one selects |
|
7422 if ( one ) { |
|
7423 return value; |
|
7424 } |
|
7425 |
|
7426 // Multi-Selects return an array |
|
7427 values.push( value ); |
|
7428 } |
|
7429 } |
|
7430 |
|
7431 return values; |
|
7432 }, |
|
7433 |
|
7434 set: function( elem, value ) { |
|
7435 var optionSet, option, |
|
7436 options = elem.options, |
|
7437 values = jQuery.makeArray( value ), |
|
7438 i = options.length; |
|
7439 |
|
7440 while ( i-- ) { |
|
7441 option = options[ i ]; |
|
7442 if ( (option.selected = jQuery.inArray( option.value, values ) >= 0) ) { |
|
7443 optionSet = true; |
|
7444 } |
|
7445 } |
|
7446 |
|
7447 // Force browsers to behave consistently when non-matching value is set |
|
7448 if ( !optionSet ) { |
|
7449 elem.selectedIndex = -1; |
|
7450 } |
|
7451 return values; |
|
7452 } |
|
7453 } |
|
7454 } |
|
7455 }); |
|
7456 |
4283 // Radios and checkboxes getter/setter |
7457 // Radios and checkboxes getter/setter |
4284 jQuery.each([ "radio", "checkbox" ], function() { |
7458 jQuery.each([ "radio", "checkbox" ], function() { |
4285 jQuery.valHooks[ this ] = { |
7459 jQuery.valHooks[ this ] = { |
4286 set: function( elem, value ) { |
7460 set: function( elem, value ) { |
4287 if ( jQuery.isArray( value ) ) { |
7461 if ( jQuery.isArray( value ) ) { |
4288 return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) >= 0 ); |
7462 return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) >= 0 ); |
4289 } |
7463 } |
4290 } |
7464 } |
4291 }; |
7465 }; |
4292 if ( !jQuery.support.checkOn ) { |
7466 if ( !support.checkOn ) { |
4293 jQuery.valHooks[ this ].get = function( elem ) { |
7467 jQuery.valHooks[ this ].get = function( elem ) { |
4294 // Support: Webkit |
|
4295 // "" is returned instead of "on" if a value isn't specified |
|
4296 return elem.getAttribute("value") === null ? "on" : elem.value; |
7468 return elem.getAttribute("value") === null ? "on" : elem.value; |
4297 }; |
7469 }; |
4298 } |
7470 } |
4299 }); |
7471 }); |
4300 var rkeyEvent = /^key/, |
7472 |
4301 rmouseEvent = /^(?:mouse|contextmenu)|click/, |
7473 |
4302 rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, |
7474 |
4303 rtypenamespace = /^([^.]*)(?:\.(.+)|)$/; |
7475 |
4304 |
7476 // Return jQuery for attributes-only inclusion |
4305 function returnTrue() { |
7477 |
4306 return true; |
7478 |
4307 } |
|
4308 |
|
4309 function returnFalse() { |
|
4310 return false; |
|
4311 } |
|
4312 |
|
4313 function safeActiveElement() { |
|
4314 try { |
|
4315 return document.activeElement; |
|
4316 } catch ( err ) { } |
|
4317 } |
|
4318 |
|
4319 /* |
|
4320 * Helper functions for managing events -- not part of the public interface. |
|
4321 * Props to Dean Edwards' addEvent library for many of the ideas. |
|
4322 */ |
|
4323 jQuery.event = { |
|
4324 |
|
4325 global: {}, |
|
4326 |
|
4327 add: function( elem, types, handler, data, selector ) { |
|
4328 |
|
4329 var handleObjIn, eventHandle, tmp, |
|
4330 events, t, handleObj, |
|
4331 special, handlers, type, namespaces, origType, |
|
4332 elemData = data_priv.get( elem ); |
|
4333 |
|
4334 // Don't attach events to noData or text/comment nodes (but allow plain objects) |
|
4335 if ( !elemData ) { |
|
4336 return; |
|
4337 } |
|
4338 |
|
4339 // Caller can pass in an object of custom data in lieu of the handler |
|
4340 if ( handler.handler ) { |
|
4341 handleObjIn = handler; |
|
4342 handler = handleObjIn.handler; |
|
4343 selector = handleObjIn.selector; |
|
4344 } |
|
4345 |
|
4346 // Make sure that the handler has a unique ID, used to find/remove it later |
|
4347 if ( !handler.guid ) { |
|
4348 handler.guid = jQuery.guid++; |
|
4349 } |
|
4350 |
|
4351 // Init the element's event structure and main handler, if this is the first |
|
4352 if ( !(events = elemData.events) ) { |
|
4353 events = elemData.events = {}; |
|
4354 } |
|
4355 if ( !(eventHandle = elemData.handle) ) { |
|
4356 eventHandle = elemData.handle = function( e ) { |
|
4357 // Discard the second event of a jQuery.event.trigger() and |
|
4358 // when an event is called after a page has unloaded |
|
4359 return typeof jQuery !== core_strundefined && (!e || jQuery.event.triggered !== e.type) ? |
|
4360 jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : |
|
4361 undefined; |
|
4362 }; |
|
4363 // Add elem as a property of the handle fn to prevent a memory leak with IE non-native events |
|
4364 eventHandle.elem = elem; |
|
4365 } |
|
4366 |
|
4367 // Handle multiple events separated by a space |
|
4368 types = ( types || "" ).match( core_rnotwhite ) || [""]; |
|
4369 t = types.length; |
|
4370 while ( t-- ) { |
|
4371 tmp = rtypenamespace.exec( types[t] ) || []; |
|
4372 type = origType = tmp[1]; |
|
4373 namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
|
4374 |
|
4375 // There *must* be a type, no attaching namespace-only handlers |
|
4376 if ( !type ) { |
|
4377 continue; |
|
4378 } |
|
4379 |
|
4380 // If event changes its type, use the special event handlers for the changed type |
|
4381 special = jQuery.event.special[ type ] || {}; |
|
4382 |
|
4383 // If selector defined, determine special event api type, otherwise given type |
|
4384 type = ( selector ? special.delegateType : special.bindType ) || type; |
|
4385 |
|
4386 // Update special based on newly reset type |
|
4387 special = jQuery.event.special[ type ] || {}; |
|
4388 |
|
4389 // handleObj is passed to all event handlers |
|
4390 handleObj = jQuery.extend({ |
|
4391 type: type, |
|
4392 origType: origType, |
|
4393 data: data, |
|
4394 handler: handler, |
|
4395 guid: handler.guid, |
|
4396 selector: selector, |
|
4397 needsContext: selector && jQuery.expr.match.needsContext.test( selector ), |
|
4398 namespace: namespaces.join(".") |
|
4399 }, handleObjIn ); |
|
4400 |
|
4401 // Init the event handler queue if we're the first |
|
4402 if ( !(handlers = events[ type ]) ) { |
|
4403 handlers = events[ type ] = []; |
|
4404 handlers.delegateCount = 0; |
|
4405 |
|
4406 // Only use addEventListener if the special events handler returns false |
|
4407 if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { |
|
4408 if ( elem.addEventListener ) { |
|
4409 elem.addEventListener( type, eventHandle, false ); |
|
4410 } |
|
4411 } |
|
4412 } |
|
4413 |
|
4414 if ( special.add ) { |
|
4415 special.add.call( elem, handleObj ); |
|
4416 |
|
4417 if ( !handleObj.handler.guid ) { |
|
4418 handleObj.handler.guid = handler.guid; |
|
4419 } |
|
4420 } |
|
4421 |
|
4422 // Add to the element's handler list, delegates in front |
|
4423 if ( selector ) { |
|
4424 handlers.splice( handlers.delegateCount++, 0, handleObj ); |
|
4425 } else { |
|
4426 handlers.push( handleObj ); |
|
4427 } |
|
4428 |
|
4429 // Keep track of which events have ever been used, for event optimization |
|
4430 jQuery.event.global[ type ] = true; |
|
4431 } |
|
4432 |
|
4433 // Nullify elem to prevent memory leaks in IE |
|
4434 elem = null; |
|
4435 }, |
|
4436 |
|
4437 // Detach an event or set of events from an element |
|
4438 remove: function( elem, types, handler, selector, mappedTypes ) { |
|
4439 |
|
4440 var j, origCount, tmp, |
|
4441 events, t, handleObj, |
|
4442 special, handlers, type, namespaces, origType, |
|
4443 elemData = data_priv.hasData( elem ) && data_priv.get( elem ); |
|
4444 |
|
4445 if ( !elemData || !(events = elemData.events) ) { |
|
4446 return; |
|
4447 } |
|
4448 |
|
4449 // Once for each type.namespace in types; type may be omitted |
|
4450 types = ( types || "" ).match( core_rnotwhite ) || [""]; |
|
4451 t = types.length; |
|
4452 while ( t-- ) { |
|
4453 tmp = rtypenamespace.exec( types[t] ) || []; |
|
4454 type = origType = tmp[1]; |
|
4455 namespaces = ( tmp[2] || "" ).split( "." ).sort(); |
|
4456 |
|
4457 // Unbind all events (on this namespace, if provided) for the element |
|
4458 if ( !type ) { |
|
4459 for ( type in events ) { |
|
4460 jQuery.event.remove( elem, type + types[ t ], handler, selector, true ); |
|
4461 } |
|
4462 continue; |
|
4463 } |
|
4464 |
|
4465 special = jQuery.event.special[ type ] || {}; |
|
4466 type = ( selector ? special.delegateType : special.bindType ) || type; |
|
4467 handlers = events[ type ] || []; |
|
4468 tmp = tmp[2] && new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ); |
|
4469 |
|
4470 // Remove matching events |
|
4471 origCount = j = handlers.length; |
|
4472 while ( j-- ) { |
|
4473 handleObj = handlers[ j ]; |
|
4474 |
|
4475 if ( ( mappedTypes || origType === handleObj.origType ) && |
|
4476 ( !handler || handler.guid === handleObj.guid ) && |
|
4477 ( !tmp || tmp.test( handleObj.namespace ) ) && |
|
4478 ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) { |
|
4479 handlers.splice( j, 1 ); |
|
4480 |
|
4481 if ( handleObj.selector ) { |
|
4482 handlers.delegateCount--; |
|
4483 } |
|
4484 if ( special.remove ) { |
|
4485 special.remove.call( elem, handleObj ); |
|
4486 } |
|
4487 } |
|
4488 } |
|
4489 |
|
4490 // Remove generic event handler if we removed something and no more handlers exist |
|
4491 // (avoids potential for endless recursion during removal of special event handlers) |
|
4492 if ( origCount && !handlers.length ) { |
|
4493 if ( !special.teardown || special.teardown.call( elem, namespaces, elemData.handle ) === false ) { |
|
4494 jQuery.removeEvent( elem, type, elemData.handle ); |
|
4495 } |
|
4496 |
|
4497 delete events[ type ]; |
|
4498 } |
|
4499 } |
|
4500 |
|
4501 // Remove the expando if it's no longer used |
|
4502 if ( jQuery.isEmptyObject( events ) ) { |
|
4503 delete elemData.handle; |
|
4504 data_priv.remove( elem, "events" ); |
|
4505 } |
|
4506 }, |
|
4507 |
|
4508 trigger: function( event, data, elem, onlyHandlers ) { |
|
4509 |
|
4510 var i, cur, tmp, bubbleType, ontype, handle, special, |
|
4511 eventPath = [ elem || document ], |
|
4512 type = core_hasOwn.call( event, "type" ) ? event.type : event, |
|
4513 namespaces = core_hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : []; |
|
4514 |
|
4515 cur = tmp = elem = elem || document; |
|
4516 |
|
4517 // Don't do events on text and comment nodes |
|
4518 if ( elem.nodeType === 3 || elem.nodeType === 8 ) { |
|
4519 return; |
|
4520 } |
|
4521 |
|
4522 // focus/blur morphs to focusin/out; ensure we're not firing them right now |
|
4523 if ( rfocusMorph.test( type + jQuery.event.triggered ) ) { |
|
4524 return; |
|
4525 } |
|
4526 |
|
4527 if ( type.indexOf(".") >= 0 ) { |
|
4528 // Namespaced trigger; create a regexp to match event type in handle() |
|
4529 namespaces = type.split("."); |
|
4530 type = namespaces.shift(); |
|
4531 namespaces.sort(); |
|
4532 } |
|
4533 ontype = type.indexOf(":") < 0 && "on" + type; |
|
4534 |
|
4535 // Caller can pass in a jQuery.Event object, Object, or just an event type string |
|
4536 event = event[ jQuery.expando ] ? |
|
4537 event : |
|
4538 new jQuery.Event( type, typeof event === "object" && event ); |
|
4539 |
|
4540 // Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true) |
|
4541 event.isTrigger = onlyHandlers ? 2 : 3; |
|
4542 event.namespace = namespaces.join("."); |
|
4543 event.namespace_re = event.namespace ? |
|
4544 new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) : |
|
4545 null; |
|
4546 |
|
4547 // Clean up the event in case it is being reused |
|
4548 event.result = undefined; |
|
4549 if ( !event.target ) { |
|
4550 event.target = elem; |
|
4551 } |
|
4552 |
|
4553 // Clone any incoming data and prepend the event, creating the handler arg list |
|
4554 data = data == null ? |
|
4555 [ event ] : |
|
4556 jQuery.makeArray( data, [ event ] ); |
|
4557 |
|
4558 // Allow special events to draw outside the lines |
|
4559 special = jQuery.event.special[ type ] || {}; |
|
4560 if ( !onlyHandlers && special.trigger && special.trigger.apply( elem, data ) === false ) { |
|
4561 return; |
|
4562 } |
|
4563 |
|
4564 // Determine event propagation path in advance, per W3C events spec (#9951) |
|
4565 // Bubble up to document, then to window; watch for a global ownerDocument var (#9724) |
|
4566 if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) { |
|
4567 |
|
4568 bubbleType = special.delegateType || type; |
|
4569 if ( !rfocusMorph.test( bubbleType + type ) ) { |
|
4570 cur = cur.parentNode; |
|
4571 } |
|
4572 for ( ; cur; cur = cur.parentNode ) { |
|
4573 eventPath.push( cur ); |
|
4574 tmp = cur; |
|
4575 } |
|
4576 |
|
4577 // Only add window if we got to document (e.g., not plain obj or detached DOM) |
|
4578 if ( tmp === (elem.ownerDocument || document) ) { |
|
4579 eventPath.push( tmp.defaultView || tmp.parentWindow || window ); |
|
4580 } |
|
4581 } |
|
4582 |
|
4583 // Fire handlers on the event path |
|
4584 i = 0; |
|
4585 while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) { |
|
4586 |
|
4587 event.type = i > 1 ? |
|
4588 bubbleType : |
|
4589 special.bindType || type; |
|
4590 |
|
4591 // jQuery handler |
|
4592 handle = ( data_priv.get( cur, "events" ) || {} )[ event.type ] && data_priv.get( cur, "handle" ); |
|
4593 if ( handle ) { |
|
4594 handle.apply( cur, data ); |
|
4595 } |
|
4596 |
|
4597 // Native handler |
|
4598 handle = ontype && cur[ ontype ]; |
|
4599 if ( handle && jQuery.acceptData( cur ) && handle.apply && handle.apply( cur, data ) === false ) { |
|
4600 event.preventDefault(); |
|
4601 } |
|
4602 } |
|
4603 event.type = type; |
|
4604 |
|
4605 // If nobody prevented the default action, do it now |
|
4606 if ( !onlyHandlers && !event.isDefaultPrevented() ) { |
|
4607 |
|
4608 if ( (!special._default || special._default.apply( eventPath.pop(), data ) === false) && |
|
4609 jQuery.acceptData( elem ) ) { |
|
4610 |
|
4611 // Call a native DOM method on the target with the same name name as the event. |
|
4612 // Don't do default actions on window, that's where global variables be (#6170) |
|
4613 if ( ontype && jQuery.isFunction( elem[ type ] ) && !jQuery.isWindow( elem ) ) { |
|
4614 |
|
4615 // Don't re-trigger an onFOO event when we call its FOO() method |
|
4616 tmp = elem[ ontype ]; |
|
4617 |
|
4618 if ( tmp ) { |
|
4619 elem[ ontype ] = null; |
|
4620 } |
|
4621 |
|
4622 // Prevent re-triggering of the same event, since we already bubbled it above |
|
4623 jQuery.event.triggered = type; |
|
4624 elem[ type ](); |
|
4625 jQuery.event.triggered = undefined; |
|
4626 |
|
4627 if ( tmp ) { |
|
4628 elem[ ontype ] = tmp; |
|
4629 } |
|
4630 } |
|
4631 } |
|
4632 } |
|
4633 |
|
4634 return event.result; |
|
4635 }, |
|
4636 |
|
4637 dispatch: function( event ) { |
|
4638 |
|
4639 // Make a writable jQuery.Event from the native event object |
|
4640 event = jQuery.event.fix( event ); |
|
4641 |
|
4642 var i, j, ret, matched, handleObj, |
|
4643 handlerQueue = [], |
|
4644 args = core_slice.call( arguments ), |
|
4645 handlers = ( data_priv.get( this, "events" ) || {} )[ event.type ] || [], |
|
4646 special = jQuery.event.special[ event.type ] || {}; |
|
4647 |
|
4648 // Use the fix-ed jQuery.Event rather than the (read-only) native event |
|
4649 args[0] = event; |
|
4650 event.delegateTarget = this; |
|
4651 |
|
4652 // Call the preDispatch hook for the mapped type, and let it bail if desired |
|
4653 if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) { |
|
4654 return; |
|
4655 } |
|
4656 |
|
4657 // Determine handlers |
|
4658 handlerQueue = jQuery.event.handlers.call( this, event, handlers ); |
|
4659 |
|
4660 // Run delegates first; they may want to stop propagation beneath us |
|
4661 i = 0; |
|
4662 while ( (matched = handlerQueue[ i++ ]) && !event.isPropagationStopped() ) { |
|
4663 event.currentTarget = matched.elem; |
|
4664 |
|
4665 j = 0; |
|
4666 while ( (handleObj = matched.handlers[ j++ ]) && !event.isImmediatePropagationStopped() ) { |
|
4667 |
|
4668 // Triggered event must either 1) have no namespace, or |
|
4669 // 2) have namespace(s) a subset or equal to those in the bound event (both can have no namespace). |
|
4670 if ( !event.namespace_re || event.namespace_re.test( handleObj.namespace ) ) { |
|
4671 |
|
4672 event.handleObj = handleObj; |
|
4673 event.data = handleObj.data; |
|
4674 |
|
4675 ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || handleObj.handler ) |
|
4676 .apply( matched.elem, args ); |
|
4677 |
|
4678 if ( ret !== undefined ) { |
|
4679 if ( (event.result = ret) === false ) { |
|
4680 event.preventDefault(); |
|
4681 event.stopPropagation(); |
|
4682 } |
|
4683 } |
|
4684 } |
|
4685 } |
|
4686 } |
|
4687 |
|
4688 // Call the postDispatch hook for the mapped type |
|
4689 if ( special.postDispatch ) { |
|
4690 special.postDispatch.call( this, event ); |
|
4691 } |
|
4692 |
|
4693 return event.result; |
|
4694 }, |
|
4695 |
|
4696 handlers: function( event, handlers ) { |
|
4697 var i, matches, sel, handleObj, |
|
4698 handlerQueue = [], |
|
4699 delegateCount = handlers.delegateCount, |
|
4700 cur = event.target; |
|
4701 |
|
4702 // Find delegate handlers |
|
4703 // Black-hole SVG <use> instance trees (#13180) |
|
4704 // Avoid non-left-click bubbling in Firefox (#3861) |
|
4705 if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) { |
|
4706 |
|
4707 for ( ; cur !== this; cur = cur.parentNode || this ) { |
|
4708 |
|
4709 // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) |
|
4710 if ( cur.disabled !== true || event.type !== "click" ) { |
|
4711 matches = []; |
|
4712 for ( i = 0; i < delegateCount; i++ ) { |
|
4713 handleObj = handlers[ i ]; |
|
4714 |
|
4715 // Don't conflict with Object.prototype properties (#13203) |
|
4716 sel = handleObj.selector + " "; |
|
4717 |
|
4718 if ( matches[ sel ] === undefined ) { |
|
4719 matches[ sel ] = handleObj.needsContext ? |
|
4720 jQuery( sel, this ).index( cur ) >= 0 : |
|
4721 jQuery.find( sel, this, null, [ cur ] ).length; |
|
4722 } |
|
4723 if ( matches[ sel ] ) { |
|
4724 matches.push( handleObj ); |
|
4725 } |
|
4726 } |
|
4727 if ( matches.length ) { |
|
4728 handlerQueue.push({ elem: cur, handlers: matches }); |
|
4729 } |
|
4730 } |
|
4731 } |
|
4732 } |
|
4733 |
|
4734 // Add the remaining (directly-bound) handlers |
|
4735 if ( delegateCount < handlers.length ) { |
|
4736 handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) }); |
|
4737 } |
|
4738 |
|
4739 return handlerQueue; |
|
4740 }, |
|
4741 |
|
4742 // Includes some event props shared by KeyEvent and MouseEvent |
|
4743 props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), |
|
4744 |
|
4745 fixHooks: {}, |
|
4746 |
|
4747 keyHooks: { |
|
4748 props: "char charCode key keyCode".split(" "), |
|
4749 filter: function( event, original ) { |
|
4750 |
|
4751 // Add which for key events |
|
4752 if ( event.which == null ) { |
|
4753 event.which = original.charCode != null ? original.charCode : original.keyCode; |
|
4754 } |
|
4755 |
|
4756 return event; |
|
4757 } |
|
4758 }, |
|
4759 |
|
4760 mouseHooks: { |
|
4761 props: "button buttons clientX clientY offsetX offsetY pageX pageY screenX screenY toElement".split(" "), |
|
4762 filter: function( event, original ) { |
|
4763 var eventDoc, doc, body, |
|
4764 button = original.button; |
|
4765 |
|
4766 // Calculate pageX/Y if missing and clientX/Y available |
|
4767 if ( event.pageX == null && original.clientX != null ) { |
|
4768 eventDoc = event.target.ownerDocument || document; |
|
4769 doc = eventDoc.documentElement; |
|
4770 body = eventDoc.body; |
|
4771 |
|
4772 event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft || body && body.clientLeft || 0 ); |
|
4773 event.pageY = original.clientY + ( doc && doc.scrollTop || body && body.scrollTop || 0 ) - ( doc && doc.clientTop || body && body.clientTop || 0 ); |
|
4774 } |
|
4775 |
|
4776 // Add which for click: 1 === left; 2 === middle; 3 === right |
|
4777 // Note: button is not normalized, so don't use it |
|
4778 if ( !event.which && button !== undefined ) { |
|
4779 event.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) ); |
|
4780 } |
|
4781 |
|
4782 return event; |
|
4783 } |
|
4784 }, |
|
4785 |
|
4786 fix: function( event ) { |
|
4787 if ( event[ jQuery.expando ] ) { |
|
4788 return event; |
|
4789 } |
|
4790 |
|
4791 // Create a writable copy of the event object and normalize some properties |
|
4792 var i, prop, copy, |
|
4793 type = event.type, |
|
4794 originalEvent = event, |
|
4795 fixHook = this.fixHooks[ type ]; |
|
4796 |
|
4797 if ( !fixHook ) { |
|
4798 this.fixHooks[ type ] = fixHook = |
|
4799 rmouseEvent.test( type ) ? this.mouseHooks : |
|
4800 rkeyEvent.test( type ) ? this.keyHooks : |
|
4801 {}; |
|
4802 } |
|
4803 copy = fixHook.props ? this.props.concat( fixHook.props ) : this.props; |
|
4804 |
|
4805 event = new jQuery.Event( originalEvent ); |
|
4806 |
|
4807 i = copy.length; |
|
4808 while ( i-- ) { |
|
4809 prop = copy[ i ]; |
|
4810 event[ prop ] = originalEvent[ prop ]; |
|
4811 } |
|
4812 |
|
4813 // Support: Cordova 2.5 (WebKit) (#13255) |
|
4814 // All events should have a target; Cordova deviceready doesn't |
|
4815 if ( !event.target ) { |
|
4816 event.target = document; |
|
4817 } |
|
4818 |
|
4819 // Support: Safari 6.0+, Chrome < 28 |
|
4820 // Target should not be a text node (#504, #13143) |
|
4821 if ( event.target.nodeType === 3 ) { |
|
4822 event.target = event.target.parentNode; |
|
4823 } |
|
4824 |
|
4825 return fixHook.filter? fixHook.filter( event, originalEvent ) : event; |
|
4826 }, |
|
4827 |
|
4828 special: { |
|
4829 load: { |
|
4830 // Prevent triggered image.load events from bubbling to window.load |
|
4831 noBubble: true |
|
4832 }, |
|
4833 focus: { |
|
4834 // Fire native event if possible so blur/focus sequence is correct |
|
4835 trigger: function() { |
|
4836 if ( this !== safeActiveElement() && this.focus ) { |
|
4837 this.focus(); |
|
4838 return false; |
|
4839 } |
|
4840 }, |
|
4841 delegateType: "focusin" |
|
4842 }, |
|
4843 blur: { |
|
4844 trigger: function() { |
|
4845 if ( this === safeActiveElement() && this.blur ) { |
|
4846 this.blur(); |
|
4847 return false; |
|
4848 } |
|
4849 }, |
|
4850 delegateType: "focusout" |
|
4851 }, |
|
4852 click: { |
|
4853 // For checkbox, fire native event so checked state will be right |
|
4854 trigger: function() { |
|
4855 if ( this.type === "checkbox" && this.click && jQuery.nodeName( this, "input" ) ) { |
|
4856 this.click(); |
|
4857 return false; |
|
4858 } |
|
4859 }, |
|
4860 |
|
4861 // For cross-browser consistency, don't fire native .click() on links |
|
4862 _default: function( event ) { |
|
4863 return jQuery.nodeName( event.target, "a" ); |
|
4864 } |
|
4865 }, |
|
4866 |
|
4867 beforeunload: { |
|
4868 postDispatch: function( event ) { |
|
4869 |
|
4870 // Support: Firefox 20+ |
|
4871 // Firefox doesn't alert if the returnValue field is not set. |
|
4872 if ( event.result !== undefined ) { |
|
4873 event.originalEvent.returnValue = event.result; |
|
4874 } |
|
4875 } |
|
4876 } |
|
4877 }, |
|
4878 |
|
4879 simulate: function( type, elem, event, bubble ) { |
|
4880 // Piggyback on a donor event to simulate a different one. |
|
4881 // Fake originalEvent to avoid donor's stopPropagation, but if the |
|
4882 // simulated event prevents default then we do the same on the donor. |
|
4883 var e = jQuery.extend( |
|
4884 new jQuery.Event(), |
|
4885 event, |
|
4886 { |
|
4887 type: type, |
|
4888 isSimulated: true, |
|
4889 originalEvent: {} |
|
4890 } |
|
4891 ); |
|
4892 if ( bubble ) { |
|
4893 jQuery.event.trigger( e, null, elem ); |
|
4894 } else { |
|
4895 jQuery.event.dispatch.call( elem, e ); |
|
4896 } |
|
4897 if ( e.isDefaultPrevented() ) { |
|
4898 event.preventDefault(); |
|
4899 } |
|
4900 } |
|
4901 }; |
|
4902 |
|
4903 jQuery.removeEvent = function( elem, type, handle ) { |
|
4904 if ( elem.removeEventListener ) { |
|
4905 elem.removeEventListener( type, handle, false ); |
|
4906 } |
|
4907 }; |
|
4908 |
|
4909 jQuery.Event = function( src, props ) { |
|
4910 // Allow instantiation without the 'new' keyword |
|
4911 if ( !(this instanceof jQuery.Event) ) { |
|
4912 return new jQuery.Event( src, props ); |
|
4913 } |
|
4914 |
|
4915 // Event object |
|
4916 if ( src && src.type ) { |
|
4917 this.originalEvent = src; |
|
4918 this.type = src.type; |
|
4919 |
|
4920 // Events bubbling up the document may have been marked as prevented |
|
4921 // by a handler lower down the tree; reflect the correct value. |
|
4922 this.isDefaultPrevented = ( src.defaultPrevented || |
|
4923 src.getPreventDefault && src.getPreventDefault() ) ? returnTrue : returnFalse; |
|
4924 |
|
4925 // Event type |
|
4926 } else { |
|
4927 this.type = src; |
|
4928 } |
|
4929 |
|
4930 // Put explicitly provided properties onto the event object |
|
4931 if ( props ) { |
|
4932 jQuery.extend( this, props ); |
|
4933 } |
|
4934 |
|
4935 // Create a timestamp if incoming event doesn't have one |
|
4936 this.timeStamp = src && src.timeStamp || jQuery.now(); |
|
4937 |
|
4938 // Mark it as fixed |
|
4939 this[ jQuery.expando ] = true; |
|
4940 }; |
|
4941 |
|
4942 // jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding |
|
4943 // http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html |
|
4944 jQuery.Event.prototype = { |
|
4945 isDefaultPrevented: returnFalse, |
|
4946 isPropagationStopped: returnFalse, |
|
4947 isImmediatePropagationStopped: returnFalse, |
|
4948 |
|
4949 preventDefault: function() { |
|
4950 var e = this.originalEvent; |
|
4951 |
|
4952 this.isDefaultPrevented = returnTrue; |
|
4953 |
|
4954 if ( e && e.preventDefault ) { |
|
4955 e.preventDefault(); |
|
4956 } |
|
4957 }, |
|
4958 stopPropagation: function() { |
|
4959 var e = this.originalEvent; |
|
4960 |
|
4961 this.isPropagationStopped = returnTrue; |
|
4962 |
|
4963 if ( e && e.stopPropagation ) { |
|
4964 e.stopPropagation(); |
|
4965 } |
|
4966 }, |
|
4967 stopImmediatePropagation: function() { |
|
4968 this.isImmediatePropagationStopped = returnTrue; |
|
4969 this.stopPropagation(); |
|
4970 } |
|
4971 }; |
|
4972 |
|
4973 // Create mouseenter/leave events using mouseover/out and event-time checks |
|
4974 // Support: Chrome 15+ |
|
4975 jQuery.each({ |
|
4976 mouseenter: "mouseover", |
|
4977 mouseleave: "mouseout" |
|
4978 }, function( orig, fix ) { |
|
4979 jQuery.event.special[ orig ] = { |
|
4980 delegateType: fix, |
|
4981 bindType: fix, |
|
4982 |
|
4983 handle: function( event ) { |
|
4984 var ret, |
|
4985 target = this, |
|
4986 related = event.relatedTarget, |
|
4987 handleObj = event.handleObj; |
|
4988 |
|
4989 // For mousenter/leave call the handler if related is outside the target. |
|
4990 // NB: No relatedTarget if the mouse left/entered the browser window |
|
4991 if ( !related || (related !== target && !jQuery.contains( target, related )) ) { |
|
4992 event.type = handleObj.origType; |
|
4993 ret = handleObj.handler.apply( this, arguments ); |
|
4994 event.type = fix; |
|
4995 } |
|
4996 return ret; |
|
4997 } |
|
4998 }; |
|
4999 }); |
|
5000 |
|
5001 // Create "bubbling" focus and blur events |
|
5002 // Support: Firefox, Chrome, Safari |
|
5003 if ( !jQuery.support.focusinBubbles ) { |
|
5004 jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { |
|
5005 |
|
5006 // Attach a single capturing handler while someone wants focusin/focusout |
|
5007 var attaches = 0, |
|
5008 handler = function( event ) { |
|
5009 jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ), true ); |
|
5010 }; |
|
5011 |
|
5012 jQuery.event.special[ fix ] = { |
|
5013 setup: function() { |
|
5014 if ( attaches++ === 0 ) { |
|
5015 document.addEventListener( orig, handler, true ); |
|
5016 } |
|
5017 }, |
|
5018 teardown: function() { |
|
5019 if ( --attaches === 0 ) { |
|
5020 document.removeEventListener( orig, handler, true ); |
|
5021 } |
|
5022 } |
|
5023 }; |
|
5024 }); |
|
5025 } |
|
5026 |
|
5027 jQuery.fn.extend({ |
|
5028 |
|
5029 on: function( types, selector, data, fn, /*INTERNAL*/ one ) { |
|
5030 var origFn, type; |
|
5031 |
|
5032 // Types can be a map of types/handlers |
|
5033 if ( typeof types === "object" ) { |
|
5034 // ( types-Object, selector, data ) |
|
5035 if ( typeof selector !== "string" ) { |
|
5036 // ( types-Object, data ) |
|
5037 data = data || selector; |
|
5038 selector = undefined; |
|
5039 } |
|
5040 for ( type in types ) { |
|
5041 this.on( type, selector, data, types[ type ], one ); |
|
5042 } |
|
5043 return this; |
|
5044 } |
|
5045 |
|
5046 if ( data == null && fn == null ) { |
|
5047 // ( types, fn ) |
|
5048 fn = selector; |
|
5049 data = selector = undefined; |
|
5050 } else if ( fn == null ) { |
|
5051 if ( typeof selector === "string" ) { |
|
5052 // ( types, selector, fn ) |
|
5053 fn = data; |
|
5054 data = undefined; |
|
5055 } else { |
|
5056 // ( types, data, fn ) |
|
5057 fn = data; |
|
5058 data = selector; |
|
5059 selector = undefined; |
|
5060 } |
|
5061 } |
|
5062 if ( fn === false ) { |
|
5063 fn = returnFalse; |
|
5064 } else if ( !fn ) { |
|
5065 return this; |
|
5066 } |
|
5067 |
|
5068 if ( one === 1 ) { |
|
5069 origFn = fn; |
|
5070 fn = function( event ) { |
|
5071 // Can use an empty set, since event contains the info |
|
5072 jQuery().off( event ); |
|
5073 return origFn.apply( this, arguments ); |
|
5074 }; |
|
5075 // Use same guid so caller can remove using origFn |
|
5076 fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); |
|
5077 } |
|
5078 return this.each( function() { |
|
5079 jQuery.event.add( this, types, fn, data, selector ); |
|
5080 }); |
|
5081 }, |
|
5082 one: function( types, selector, data, fn ) { |
|
5083 return this.on( types, selector, data, fn, 1 ); |
|
5084 }, |
|
5085 off: function( types, selector, fn ) { |
|
5086 var handleObj, type; |
|
5087 if ( types && types.preventDefault && types.handleObj ) { |
|
5088 // ( event ) dispatched jQuery.Event |
|
5089 handleObj = types.handleObj; |
|
5090 jQuery( types.delegateTarget ).off( |
|
5091 handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, |
|
5092 handleObj.selector, |
|
5093 handleObj.handler |
|
5094 ); |
|
5095 return this; |
|
5096 } |
|
5097 if ( typeof types === "object" ) { |
|
5098 // ( types-object [, selector] ) |
|
5099 for ( type in types ) { |
|
5100 this.off( type, selector, types[ type ] ); |
|
5101 } |
|
5102 return this; |
|
5103 } |
|
5104 if ( selector === false || typeof selector === "function" ) { |
|
5105 // ( types [, fn] ) |
|
5106 fn = selector; |
|
5107 selector = undefined; |
|
5108 } |
|
5109 if ( fn === false ) { |
|
5110 fn = returnFalse; |
|
5111 } |
|
5112 return this.each(function() { |
|
5113 jQuery.event.remove( this, types, fn, selector ); |
|
5114 }); |
|
5115 }, |
|
5116 |
|
5117 trigger: function( type, data ) { |
|
5118 return this.each(function() { |
|
5119 jQuery.event.trigger( type, data, this ); |
|
5120 }); |
|
5121 }, |
|
5122 triggerHandler: function( type, data ) { |
|
5123 var elem = this[0]; |
|
5124 if ( elem ) { |
|
5125 return jQuery.event.trigger( type, data, elem, true ); |
|
5126 } |
|
5127 } |
|
5128 }); |
|
5129 var isSimple = /^.[^:#\[\.,]*$/, |
|
5130 rparentsprev = /^(?:parents|prev(?:Until|All))/, |
|
5131 rneedsContext = jQuery.expr.match.needsContext, |
|
5132 // methods guaranteed to produce a unique set when starting from a unique set |
|
5133 guaranteedUnique = { |
|
5134 children: true, |
|
5135 contents: true, |
|
5136 next: true, |
|
5137 prev: true |
|
5138 }; |
|
5139 |
|
5140 jQuery.fn.extend({ |
|
5141 find: function( selector ) { |
|
5142 var i, |
|
5143 ret = [], |
|
5144 self = this, |
|
5145 len = self.length; |
|
5146 |
|
5147 if ( typeof selector !== "string" ) { |
|
5148 return this.pushStack( jQuery( selector ).filter(function() { |
|
5149 for ( i = 0; i < len; i++ ) { |
|
5150 if ( jQuery.contains( self[ i ], this ) ) { |
|
5151 return true; |
|
5152 } |
|
5153 } |
|
5154 }) ); |
|
5155 } |
|
5156 |
|
5157 for ( i = 0; i < len; i++ ) { |
|
5158 jQuery.find( selector, self[ i ], ret ); |
|
5159 } |
|
5160 |
|
5161 // Needed because $( selector, context ) becomes $( context ).find( selector ) |
|
5162 ret = this.pushStack( len > 1 ? jQuery.unique( ret ) : ret ); |
|
5163 ret.selector = this.selector ? this.selector + " " + selector : selector; |
|
5164 return ret; |
|
5165 }, |
|
5166 |
|
5167 has: function( target ) { |
|
5168 var targets = jQuery( target, this ), |
|
5169 l = targets.length; |
|
5170 |
|
5171 return this.filter(function() { |
|
5172 var i = 0; |
|
5173 for ( ; i < l; i++ ) { |
|
5174 if ( jQuery.contains( this, targets[i] ) ) { |
|
5175 return true; |
|
5176 } |
|
5177 } |
|
5178 }); |
|
5179 }, |
|
5180 |
|
5181 not: function( selector ) { |
|
5182 return this.pushStack( winnow(this, selector || [], true) ); |
|
5183 }, |
|
5184 |
|
5185 filter: function( selector ) { |
|
5186 return this.pushStack( winnow(this, selector || [], false) ); |
|
5187 }, |
|
5188 |
|
5189 is: function( selector ) { |
|
5190 return !!winnow( |
|
5191 this, |
|
5192 |
|
5193 // If this is a positional/relative selector, check membership in the returned set |
|
5194 // so $("p:first").is("p:last") won't return true for a doc with two "p". |
|
5195 typeof selector === "string" && rneedsContext.test( selector ) ? |
|
5196 jQuery( selector ) : |
|
5197 selector || [], |
|
5198 false |
|
5199 ).length; |
|
5200 }, |
|
5201 |
|
5202 closest: function( selectors, context ) { |
|
5203 var cur, |
|
5204 i = 0, |
|
5205 l = this.length, |
|
5206 matched = [], |
|
5207 pos = ( rneedsContext.test( selectors ) || typeof selectors !== "string" ) ? |
|
5208 jQuery( selectors, context || this.context ) : |
|
5209 0; |
|
5210 |
|
5211 for ( ; i < l; i++ ) { |
|
5212 for ( cur = this[i]; cur && cur !== context; cur = cur.parentNode ) { |
|
5213 // Always skip document fragments |
|
5214 if ( cur.nodeType < 11 && (pos ? |
|
5215 pos.index(cur) > -1 : |
|
5216 |
|
5217 // Don't pass non-elements to Sizzle |
|
5218 cur.nodeType === 1 && |
|
5219 jQuery.find.matchesSelector(cur, selectors)) ) { |
|
5220 |
|
5221 cur = matched.push( cur ); |
|
5222 break; |
|
5223 } |
|
5224 } |
|
5225 } |
|
5226 |
|
5227 return this.pushStack( matched.length > 1 ? jQuery.unique( matched ) : matched ); |
|
5228 }, |
|
5229 |
|
5230 // Determine the position of an element within |
|
5231 // the matched set of elements |
|
5232 index: function( elem ) { |
|
5233 |
|
5234 // No argument, return index in parent |
|
5235 if ( !elem ) { |
|
5236 return ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1; |
|
5237 } |
|
5238 |
|
5239 // index in selector |
|
5240 if ( typeof elem === "string" ) { |
|
5241 return core_indexOf.call( jQuery( elem ), this[ 0 ] ); |
|
5242 } |
|
5243 |
|
5244 // Locate the position of the desired element |
|
5245 return core_indexOf.call( this, |
|
5246 |
|
5247 // If it receives a jQuery object, the first element is used |
|
5248 elem.jquery ? elem[ 0 ] : elem |
|
5249 ); |
|
5250 }, |
|
5251 |
|
5252 add: function( selector, context ) { |
|
5253 var set = typeof selector === "string" ? |
|
5254 jQuery( selector, context ) : |
|
5255 jQuery.makeArray( selector && selector.nodeType ? [ selector ] : selector ), |
|
5256 all = jQuery.merge( this.get(), set ); |
|
5257 |
|
5258 return this.pushStack( jQuery.unique(all) ); |
|
5259 }, |
|
5260 |
|
5261 addBack: function( selector ) { |
|
5262 return this.add( selector == null ? |
|
5263 this.prevObject : this.prevObject.filter(selector) |
|
5264 ); |
|
5265 } |
|
5266 }); |
|
5267 |
|
5268 function sibling( cur, dir ) { |
|
5269 while ( (cur = cur[dir]) && cur.nodeType !== 1 ) {} |
|
5270 |
|
5271 return cur; |
|
5272 } |
|
5273 |
|
5274 jQuery.each({ |
|
5275 parent: function( elem ) { |
|
5276 var parent = elem.parentNode; |
|
5277 return parent && parent.nodeType !== 11 ? parent : null; |
|
5278 }, |
|
5279 parents: function( elem ) { |
|
5280 return jQuery.dir( elem, "parentNode" ); |
|
5281 }, |
|
5282 parentsUntil: function( elem, i, until ) { |
|
5283 return jQuery.dir( elem, "parentNode", until ); |
|
5284 }, |
|
5285 next: function( elem ) { |
|
5286 return sibling( elem, "nextSibling" ); |
|
5287 }, |
|
5288 prev: function( elem ) { |
|
5289 return sibling( elem, "previousSibling" ); |
|
5290 }, |
|
5291 nextAll: function( elem ) { |
|
5292 return jQuery.dir( elem, "nextSibling" ); |
|
5293 }, |
|
5294 prevAll: function( elem ) { |
|
5295 return jQuery.dir( elem, "previousSibling" ); |
|
5296 }, |
|
5297 nextUntil: function( elem, i, until ) { |
|
5298 return jQuery.dir( elem, "nextSibling", until ); |
|
5299 }, |
|
5300 prevUntil: function( elem, i, until ) { |
|
5301 return jQuery.dir( elem, "previousSibling", until ); |
|
5302 }, |
|
5303 siblings: function( elem ) { |
|
5304 return jQuery.sibling( ( elem.parentNode || {} ).firstChild, elem ); |
|
5305 }, |
|
5306 children: function( elem ) { |
|
5307 return jQuery.sibling( elem.firstChild ); |
|
5308 }, |
|
5309 contents: function( elem ) { |
|
5310 return elem.contentDocument || jQuery.merge( [], elem.childNodes ); |
|
5311 } |
|
5312 }, function( name, fn ) { |
|
5313 jQuery.fn[ name ] = function( until, selector ) { |
|
5314 var matched = jQuery.map( this, fn, until ); |
|
5315 |
|
5316 if ( name.slice( -5 ) !== "Until" ) { |
|
5317 selector = until; |
|
5318 } |
|
5319 |
|
5320 if ( selector && typeof selector === "string" ) { |
|
5321 matched = jQuery.filter( selector, matched ); |
|
5322 } |
|
5323 |
|
5324 if ( this.length > 1 ) { |
|
5325 // Remove duplicates |
|
5326 if ( !guaranteedUnique[ name ] ) { |
|
5327 jQuery.unique( matched ); |
|
5328 } |
|
5329 |
|
5330 // Reverse order for parents* and prev-derivatives |
|
5331 if ( rparentsprev.test( name ) ) { |
|
5332 matched.reverse(); |
|
5333 } |
|
5334 } |
|
5335 |
|
5336 return this.pushStack( matched ); |
|
5337 }; |
|
5338 }); |
|
5339 |
|
5340 jQuery.extend({ |
|
5341 filter: function( expr, elems, not ) { |
|
5342 var elem = elems[ 0 ]; |
|
5343 |
|
5344 if ( not ) { |
|
5345 expr = ":not(" + expr + ")"; |
|
5346 } |
|
5347 |
|
5348 return elems.length === 1 && elem.nodeType === 1 ? |
|
5349 jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [] : |
|
5350 jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) { |
|
5351 return elem.nodeType === 1; |
|
5352 })); |
|
5353 }, |
|
5354 |
|
5355 dir: function( elem, dir, until ) { |
|
5356 var matched = [], |
|
5357 truncate = until !== undefined; |
|
5358 |
|
5359 while ( (elem = elem[ dir ]) && elem.nodeType !== 9 ) { |
|
5360 if ( elem.nodeType === 1 ) { |
|
5361 if ( truncate && jQuery( elem ).is( until ) ) { |
|
5362 break; |
|
5363 } |
|
5364 matched.push( elem ); |
|
5365 } |
|
5366 } |
|
5367 return matched; |
|
5368 }, |
|
5369 |
|
5370 sibling: function( n, elem ) { |
|
5371 var matched = []; |
|
5372 |
|
5373 for ( ; n; n = n.nextSibling ) { |
|
5374 if ( n.nodeType === 1 && n !== elem ) { |
|
5375 matched.push( n ); |
|
5376 } |
|
5377 } |
|
5378 |
|
5379 return matched; |
|
5380 } |
|
5381 }); |
|
5382 |
|
5383 // Implement the identical functionality for filter and not |
|
5384 function winnow( elements, qualifier, not ) { |
|
5385 if ( jQuery.isFunction( qualifier ) ) { |
|
5386 return jQuery.grep( elements, function( elem, i ) { |
|
5387 /* jshint -W018 */ |
|
5388 return !!qualifier.call( elem, i, elem ) !== not; |
|
5389 }); |
|
5390 |
|
5391 } |
|
5392 |
|
5393 if ( qualifier.nodeType ) { |
|
5394 return jQuery.grep( elements, function( elem ) { |
|
5395 return ( elem === qualifier ) !== not; |
|
5396 }); |
|
5397 |
|
5398 } |
|
5399 |
|
5400 if ( typeof qualifier === "string" ) { |
|
5401 if ( isSimple.test( qualifier ) ) { |
|
5402 return jQuery.filter( qualifier, elements, not ); |
|
5403 } |
|
5404 |
|
5405 qualifier = jQuery.filter( qualifier, elements ); |
|
5406 } |
|
5407 |
|
5408 return jQuery.grep( elements, function( elem ) { |
|
5409 return ( core_indexOf.call( qualifier, elem ) >= 0 ) !== not; |
|
5410 }); |
|
5411 } |
|
5412 var rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi, |
|
5413 rtagName = /<([\w:]+)/, |
|
5414 rhtml = /<|&#?\w+;/, |
|
5415 rnoInnerhtml = /<(?:script|style|link)/i, |
|
5416 manipulation_rcheckableType = /^(?:checkbox|radio)$/i, |
|
5417 // checked="checked" or checked |
|
5418 rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i, |
|
5419 rscriptType = /^$|\/(?:java|ecma)script/i, |
|
5420 rscriptTypeMasked = /^true\/(.*)/, |
|
5421 rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g, |
|
5422 |
|
5423 // We have to close these tags to support XHTML (#13200) |
|
5424 wrapMap = { |
|
5425 |
|
5426 // Support: IE 9 |
|
5427 option: [ 1, "<select multiple='multiple'>", "</select>" ], |
|
5428 |
|
5429 thead: [ 1, "<table>", "</table>" ], |
|
5430 col: [ 2, "<table><colgroup>", "</colgroup></table>" ], |
|
5431 tr: [ 2, "<table><tbody>", "</tbody></table>" ], |
|
5432 td: [ 3, "<table><tbody><tr>", "</tr></tbody></table>" ], |
|
5433 |
|
5434 _default: [ 0, "", "" ] |
|
5435 }; |
|
5436 |
|
5437 // Support: IE 9 |
|
5438 wrapMap.optgroup = wrapMap.option; |
|
5439 |
|
5440 wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; |
|
5441 wrapMap.th = wrapMap.td; |
|
5442 |
|
5443 jQuery.fn.extend({ |
|
5444 text: function( value ) { |
|
5445 return jQuery.access( this, function( value ) { |
|
5446 return value === undefined ? |
|
5447 jQuery.text( this ) : |
|
5448 this.empty().append( ( this[ 0 ] && this[ 0 ].ownerDocument || document ).createTextNode( value ) ); |
|
5449 }, null, value, arguments.length ); |
|
5450 }, |
|
5451 |
|
5452 append: function() { |
|
5453 return this.domManip( arguments, function( elem ) { |
|
5454 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { |
|
5455 var target = manipulationTarget( this, elem ); |
|
5456 target.appendChild( elem ); |
|
5457 } |
|
5458 }); |
|
5459 }, |
|
5460 |
|
5461 prepend: function() { |
|
5462 return this.domManip( arguments, function( elem ) { |
|
5463 if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { |
|
5464 var target = manipulationTarget( this, elem ); |
|
5465 target.insertBefore( elem, target.firstChild ); |
|
5466 } |
|
5467 }); |
|
5468 }, |
|
5469 |
|
5470 before: function() { |
|
5471 return this.domManip( arguments, function( elem ) { |
|
5472 if ( this.parentNode ) { |
|
5473 this.parentNode.insertBefore( elem, this ); |
|
5474 } |
|
5475 }); |
|
5476 }, |
|
5477 |
|
5478 after: function() { |
|
5479 return this.domManip( arguments, function( elem ) { |
|
5480 if ( this.parentNode ) { |
|
5481 this.parentNode.insertBefore( elem, this.nextSibling ); |
|
5482 } |
|
5483 }); |
|
5484 }, |
|
5485 |
|
5486 // keepData is for internal use only--do not document |
|
5487 remove: function( selector, keepData ) { |
|
5488 var elem, |
|
5489 elems = selector ? jQuery.filter( selector, this ) : this, |
|
5490 i = 0; |
|
5491 |
|
5492 for ( ; (elem = elems[i]) != null; i++ ) { |
|
5493 if ( !keepData && elem.nodeType === 1 ) { |
|
5494 jQuery.cleanData( getAll( elem ) ); |
|
5495 } |
|
5496 |
|
5497 if ( elem.parentNode ) { |
|
5498 if ( keepData && jQuery.contains( elem.ownerDocument, elem ) ) { |
|
5499 setGlobalEval( getAll( elem, "script" ) ); |
|
5500 } |
|
5501 elem.parentNode.removeChild( elem ); |
|
5502 } |
|
5503 } |
|
5504 |
|
5505 return this; |
|
5506 }, |
|
5507 |
|
5508 empty: function() { |
|
5509 var elem, |
|
5510 i = 0; |
|
5511 |
|
5512 for ( ; (elem = this[i]) != null; i++ ) { |
|
5513 if ( elem.nodeType === 1 ) { |
|
5514 |
|
5515 // Prevent memory leaks |
|
5516 jQuery.cleanData( getAll( elem, false ) ); |
|
5517 |
|
5518 // Remove any remaining nodes |
|
5519 elem.textContent = ""; |
|
5520 } |
|
5521 } |
|
5522 |
|
5523 return this; |
|
5524 }, |
|
5525 |
|
5526 clone: function( dataAndEvents, deepDataAndEvents ) { |
|
5527 dataAndEvents = dataAndEvents == null ? false : dataAndEvents; |
|
5528 deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents; |
|
5529 |
|
5530 return this.map( function () { |
|
5531 return jQuery.clone( this, dataAndEvents, deepDataAndEvents ); |
|
5532 }); |
|
5533 }, |
|
5534 |
|
5535 html: function( value ) { |
|
5536 return jQuery.access( this, function( value ) { |
|
5537 var elem = this[ 0 ] || {}, |
|
5538 i = 0, |
|
5539 l = this.length; |
|
5540 |
|
5541 if ( value === undefined && elem.nodeType === 1 ) { |
|
5542 return elem.innerHTML; |
|
5543 } |
|
5544 |
|
5545 // See if we can take a shortcut and just use innerHTML |
|
5546 if ( typeof value === "string" && !rnoInnerhtml.test( value ) && |
|
5547 !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) { |
|
5548 |
|
5549 value = value.replace( rxhtmlTag, "<$1></$2>" ); |
|
5550 |
|
5551 try { |
|
5552 for ( ; i < l; i++ ) { |
|
5553 elem = this[ i ] || {}; |
|
5554 |
|
5555 // Remove element nodes and prevent memory leaks |
|
5556 if ( elem.nodeType === 1 ) { |
|
5557 jQuery.cleanData( getAll( elem, false ) ); |
|
5558 elem.innerHTML = value; |
|
5559 } |
|
5560 } |
|
5561 |
|
5562 elem = 0; |
|
5563 |
|
5564 // If using innerHTML throws an exception, use the fallback method |
|
5565 } catch( e ) {} |
|
5566 } |
|
5567 |
|
5568 if ( elem ) { |
|
5569 this.empty().append( value ); |
|
5570 } |
|
5571 }, null, value, arguments.length ); |
|
5572 }, |
|
5573 |
|
5574 replaceWith: function() { |
|
5575 var |
|
5576 // Snapshot the DOM in case .domManip sweeps something relevant into its fragment |
|
5577 args = jQuery.map( this, function( elem ) { |
|
5578 return [ elem.nextSibling, elem.parentNode ]; |
|
5579 }), |
|
5580 i = 0; |
|
5581 |
|
5582 // Make the changes, replacing each context element with the new content |
|
5583 this.domManip( arguments, function( elem ) { |
|
5584 var next = args[ i++ ], |
|
5585 parent = args[ i++ ]; |
|
5586 |
|
5587 if ( parent ) { |
|
5588 // Don't use the snapshot next if it has moved (#13810) |
|
5589 if ( next && next.parentNode !== parent ) { |
|
5590 next = this.nextSibling; |
|
5591 } |
|
5592 jQuery( this ).remove(); |
|
5593 parent.insertBefore( elem, next ); |
|
5594 } |
|
5595 // Allow new content to include elements from the context set |
|
5596 }, true ); |
|
5597 |
|
5598 // Force removal if there was no new content (e.g., from empty arguments) |
|
5599 return i ? this : this.remove(); |
|
5600 }, |
|
5601 |
|
5602 detach: function( selector ) { |
|
5603 return this.remove( selector, true ); |
|
5604 }, |
|
5605 |
|
5606 domManip: function( args, callback, allowIntersection ) { |
|
5607 |
|
5608 // Flatten any nested arrays |
|
5609 args = core_concat.apply( [], args ); |
|
5610 |
|
5611 var fragment, first, scripts, hasScripts, node, doc, |
|
5612 i = 0, |
|
5613 l = this.length, |
|
5614 set = this, |
|
5615 iNoClone = l - 1, |
|
5616 value = args[ 0 ], |
|
5617 isFunction = jQuery.isFunction( value ); |
|
5618 |
|
5619 // We can't cloneNode fragments that contain checked, in WebKit |
|
5620 if ( isFunction || !( l <= 1 || typeof value !== "string" || jQuery.support.checkClone || !rchecked.test( value ) ) ) { |
|
5621 return this.each(function( index ) { |
|
5622 var self = set.eq( index ); |
|
5623 if ( isFunction ) { |
|
5624 args[ 0 ] = value.call( this, index, self.html() ); |
|
5625 } |
|
5626 self.domManip( args, callback, allowIntersection ); |
|
5627 }); |
|
5628 } |
|
5629 |
|
5630 if ( l ) { |
|
5631 fragment = jQuery.buildFragment( args, this[ 0 ].ownerDocument, false, !allowIntersection && this ); |
|
5632 first = fragment.firstChild; |
|
5633 |
|
5634 if ( fragment.childNodes.length === 1 ) { |
|
5635 fragment = first; |
|
5636 } |
|
5637 |
|
5638 if ( first ) { |
|
5639 scripts = jQuery.map( getAll( fragment, "script" ), disableScript ); |
|
5640 hasScripts = scripts.length; |
|
5641 |
|
5642 // Use the original fragment for the last item instead of the first because it can end up |
|
5643 // being emptied incorrectly in certain situations (#8070). |
|
5644 for ( ; i < l; i++ ) { |
|
5645 node = fragment; |
|
5646 |
|
5647 if ( i !== iNoClone ) { |
|
5648 node = jQuery.clone( node, true, true ); |
|
5649 |
|
5650 // Keep references to cloned scripts for later restoration |
|
5651 if ( hasScripts ) { |
|
5652 // Support: QtWebKit |
|
5653 // jQuery.merge because core_push.apply(_, arraylike) throws |
|
5654 jQuery.merge( scripts, getAll( node, "script" ) ); |
|
5655 } |
|
5656 } |
|
5657 |
|
5658 callback.call( this[ i ], node, i ); |
|
5659 } |
|
5660 |
|
5661 if ( hasScripts ) { |
|
5662 doc = scripts[ scripts.length - 1 ].ownerDocument; |
|
5663 |
|
5664 // Reenable scripts |
|
5665 jQuery.map( scripts, restoreScript ); |
|
5666 |
|
5667 // Evaluate executable scripts on first document insertion |
|
5668 for ( i = 0; i < hasScripts; i++ ) { |
|
5669 node = scripts[ i ]; |
|
5670 if ( rscriptType.test( node.type || "" ) && |
|
5671 !data_priv.access( node, "globalEval" ) && jQuery.contains( doc, node ) ) { |
|
5672 |
|
5673 if ( node.src ) { |
|
5674 // Hope ajax is available... |
|
5675 jQuery._evalUrl( node.src ); |
|
5676 } else { |
|
5677 jQuery.globalEval( node.textContent.replace( rcleanScript, "" ) ); |
|
5678 } |
|
5679 } |
|
5680 } |
|
5681 } |
|
5682 } |
|
5683 } |
|
5684 |
|
5685 return this; |
|
5686 } |
|
5687 }); |
|
5688 |
|
5689 jQuery.each({ |
|
5690 appendTo: "append", |
|
5691 prependTo: "prepend", |
|
5692 insertBefore: "before", |
|
5693 insertAfter: "after", |
|
5694 replaceAll: "replaceWith" |
|
5695 }, function( name, original ) { |
|
5696 jQuery.fn[ name ] = function( selector ) { |
|
5697 var elems, |
|
5698 ret = [], |
|
5699 insert = jQuery( selector ), |
|
5700 last = insert.length - 1, |
|
5701 i = 0; |
|
5702 |
|
5703 for ( ; i <= last; i++ ) { |
|
5704 elems = i === last ? this : this.clone( true ); |
|
5705 jQuery( insert[ i ] )[ original ]( elems ); |
|
5706 |
|
5707 // Support: QtWebKit |
|
5708 // .get() because core_push.apply(_, arraylike) throws |
|
5709 core_push.apply( ret, elems.get() ); |
|
5710 } |
|
5711 |
|
5712 return this.pushStack( ret ); |
|
5713 }; |
|
5714 }); |
|
5715 |
|
5716 jQuery.extend({ |
|
5717 clone: function( elem, dataAndEvents, deepDataAndEvents ) { |
|
5718 var i, l, srcElements, destElements, |
|
5719 clone = elem.cloneNode( true ), |
|
5720 inPage = jQuery.contains( elem.ownerDocument, elem ); |
|
5721 |
|
5722 // Support: IE >= 9 |
|
5723 // Fix Cloning issues |
|
5724 if ( !jQuery.support.noCloneChecked && ( elem.nodeType === 1 || elem.nodeType === 11 ) && !jQuery.isXMLDoc( elem ) ) { |
|
5725 |
|
5726 // We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2 |
|
5727 destElements = getAll( clone ); |
|
5728 srcElements = getAll( elem ); |
|
5729 |
|
5730 for ( i = 0, l = srcElements.length; i < l; i++ ) { |
|
5731 fixInput( srcElements[ i ], destElements[ i ] ); |
|
5732 } |
|
5733 } |
|
5734 |
|
5735 // Copy the events from the original to the clone |
|
5736 if ( dataAndEvents ) { |
|
5737 if ( deepDataAndEvents ) { |
|
5738 srcElements = srcElements || getAll( elem ); |
|
5739 destElements = destElements || getAll( clone ); |
|
5740 |
|
5741 for ( i = 0, l = srcElements.length; i < l; i++ ) { |
|
5742 cloneCopyEvent( srcElements[ i ], destElements[ i ] ); |
|
5743 } |
|
5744 } else { |
|
5745 cloneCopyEvent( elem, clone ); |
|
5746 } |
|
5747 } |
|
5748 |
|
5749 // Preserve script evaluation history |
|
5750 destElements = getAll( clone, "script" ); |
|
5751 if ( destElements.length > 0 ) { |
|
5752 setGlobalEval( destElements, !inPage && getAll( elem, "script" ) ); |
|
5753 } |
|
5754 |
|
5755 // Return the cloned set |
|
5756 return clone; |
|
5757 }, |
|
5758 |
|
5759 buildFragment: function( elems, context, scripts, selection ) { |
|
5760 var elem, tmp, tag, wrap, contains, j, |
|
5761 i = 0, |
|
5762 l = elems.length, |
|
5763 fragment = context.createDocumentFragment(), |
|
5764 nodes = []; |
|
5765 |
|
5766 for ( ; i < l; i++ ) { |
|
5767 elem = elems[ i ]; |
|
5768 |
|
5769 if ( elem || elem === 0 ) { |
|
5770 |
|
5771 // Add nodes directly |
|
5772 if ( jQuery.type( elem ) === "object" ) { |
|
5773 // Support: QtWebKit |
|
5774 // jQuery.merge because core_push.apply(_, arraylike) throws |
|
5775 jQuery.merge( nodes, elem.nodeType ? [ elem ] : elem ); |
|
5776 |
|
5777 // Convert non-html into a text node |
|
5778 } else if ( !rhtml.test( elem ) ) { |
|
5779 nodes.push( context.createTextNode( elem ) ); |
|
5780 |
|
5781 // Convert html into DOM nodes |
|
5782 } else { |
|
5783 tmp = tmp || fragment.appendChild( context.createElement("div") ); |
|
5784 |
|
5785 // Deserialize a standard representation |
|
5786 tag = ( rtagName.exec( elem ) || ["", ""] )[ 1 ].toLowerCase(); |
|
5787 wrap = wrapMap[ tag ] || wrapMap._default; |
|
5788 tmp.innerHTML = wrap[ 1 ] + elem.replace( rxhtmlTag, "<$1></$2>" ) + wrap[ 2 ]; |
|
5789 |
|
5790 // Descend through wrappers to the right content |
|
5791 j = wrap[ 0 ]; |
|
5792 while ( j-- ) { |
|
5793 tmp = tmp.lastChild; |
|
5794 } |
|
5795 |
|
5796 // Support: QtWebKit |
|
5797 // jQuery.merge because core_push.apply(_, arraylike) throws |
|
5798 jQuery.merge( nodes, tmp.childNodes ); |
|
5799 |
|
5800 // Remember the top-level container |
|
5801 tmp = fragment.firstChild; |
|
5802 |
|
5803 // Fixes #12346 |
|
5804 // Support: Webkit, IE |
|
5805 tmp.textContent = ""; |
|
5806 } |
|
5807 } |
|
5808 } |
|
5809 |
|
5810 // Remove wrapper from fragment |
|
5811 fragment.textContent = ""; |
|
5812 |
|
5813 i = 0; |
|
5814 while ( (elem = nodes[ i++ ]) ) { |
|
5815 |
|
5816 // #4087 - If origin and destination elements are the same, and this is |
|
5817 // that element, do not do anything |
|
5818 if ( selection && jQuery.inArray( elem, selection ) !== -1 ) { |
|
5819 continue; |
|
5820 } |
|
5821 |
|
5822 contains = jQuery.contains( elem.ownerDocument, elem ); |
|
5823 |
|
5824 // Append to fragment |
|
5825 tmp = getAll( fragment.appendChild( elem ), "script" ); |
|
5826 |
|
5827 // Preserve script evaluation history |
|
5828 if ( contains ) { |
|
5829 setGlobalEval( tmp ); |
|
5830 } |
|
5831 |
|
5832 // Capture executables |
|
5833 if ( scripts ) { |
|
5834 j = 0; |
|
5835 while ( (elem = tmp[ j++ ]) ) { |
|
5836 if ( rscriptType.test( elem.type || "" ) ) { |
|
5837 scripts.push( elem ); |
|
5838 } |
|
5839 } |
|
5840 } |
|
5841 } |
|
5842 |
|
5843 return fragment; |
|
5844 }, |
|
5845 |
|
5846 cleanData: function( elems ) { |
|
5847 var data, elem, events, type, key, j, |
|
5848 special = jQuery.event.special, |
|
5849 i = 0; |
|
5850 |
|
5851 for ( ; (elem = elems[ i ]) !== undefined; i++ ) { |
|
5852 if ( Data.accepts( elem ) ) { |
|
5853 key = elem[ data_priv.expando ]; |
|
5854 |
|
5855 if ( key && (data = data_priv.cache[ key ]) ) { |
|
5856 events = Object.keys( data.events || {} ); |
|
5857 if ( events.length ) { |
|
5858 for ( j = 0; (type = events[j]) !== undefined; j++ ) { |
|
5859 if ( special[ type ] ) { |
|
5860 jQuery.event.remove( elem, type ); |
|
5861 |
|
5862 // This is a shortcut to avoid jQuery.event.remove's overhead |
|
5863 } else { |
|
5864 jQuery.removeEvent( elem, type, data.handle ); |
|
5865 } |
|
5866 } |
|
5867 } |
|
5868 if ( data_priv.cache[ key ] ) { |
|
5869 // Discard any remaining `private` data |
|
5870 delete data_priv.cache[ key ]; |
|
5871 } |
|
5872 } |
|
5873 } |
|
5874 // Discard any remaining `user` data |
|
5875 delete data_user.cache[ elem[ data_user.expando ] ]; |
|
5876 } |
|
5877 }, |
|
5878 |
|
5879 _evalUrl: function( url ) { |
|
5880 return jQuery.ajax({ |
|
5881 url: url, |
|
5882 type: "GET", |
|
5883 dataType: "script", |
|
5884 async: false, |
|
5885 global: false, |
|
5886 "throws": true |
|
5887 }); |
|
5888 } |
|
5889 }); |
|
5890 |
|
5891 // Support: 1.x compatibility |
|
5892 // Manipulating tables requires a tbody |
|
5893 function manipulationTarget( elem, content ) { |
|
5894 return jQuery.nodeName( elem, "table" ) && |
|
5895 jQuery.nodeName( content.nodeType === 1 ? content : content.firstChild, "tr" ) ? |
|
5896 |
|
5897 elem.getElementsByTagName("tbody")[0] || |
|
5898 elem.appendChild( elem.ownerDocument.createElement("tbody") ) : |
|
5899 elem; |
|
5900 } |
|
5901 |
|
5902 // Replace/restore the type attribute of script elements for safe DOM manipulation |
|
5903 function disableScript( elem ) { |
|
5904 elem.type = (elem.getAttribute("type") !== null) + "/" + elem.type; |
|
5905 return elem; |
|
5906 } |
|
5907 function restoreScript( elem ) { |
|
5908 var match = rscriptTypeMasked.exec( elem.type ); |
|
5909 |
|
5910 if ( match ) { |
|
5911 elem.type = match[ 1 ]; |
|
5912 } else { |
|
5913 elem.removeAttribute("type"); |
|
5914 } |
|
5915 |
|
5916 return elem; |
|
5917 } |
|
5918 |
|
5919 // Mark scripts as having already been evaluated |
|
5920 function setGlobalEval( elems, refElements ) { |
|
5921 var l = elems.length, |
|
5922 i = 0; |
|
5923 |
|
5924 for ( ; i < l; i++ ) { |
|
5925 data_priv.set( |
|
5926 elems[ i ], "globalEval", !refElements || data_priv.get( refElements[ i ], "globalEval" ) |
|
5927 ); |
|
5928 } |
|
5929 } |
|
5930 |
|
5931 function cloneCopyEvent( src, dest ) { |
|
5932 var i, l, type, pdataOld, pdataCur, udataOld, udataCur, events; |
|
5933 |
|
5934 if ( dest.nodeType !== 1 ) { |
|
5935 return; |
|
5936 } |
|
5937 |
|
5938 // 1. Copy private data: events, handlers, etc. |
|
5939 if ( data_priv.hasData( src ) ) { |
|
5940 pdataOld = data_priv.access( src ); |
|
5941 pdataCur = data_priv.set( dest, pdataOld ); |
|
5942 events = pdataOld.events; |
|
5943 |
|
5944 if ( events ) { |
|
5945 delete pdataCur.handle; |
|
5946 pdataCur.events = {}; |
|
5947 |
|
5948 for ( type in events ) { |
|
5949 for ( i = 0, l = events[ type ].length; i < l; i++ ) { |
|
5950 jQuery.event.add( dest, type, events[ type ][ i ] ); |
|
5951 } |
|
5952 } |
|
5953 } |
|
5954 } |
|
5955 |
|
5956 // 2. Copy user data |
|
5957 if ( data_user.hasData( src ) ) { |
|
5958 udataOld = data_user.access( src ); |
|
5959 udataCur = jQuery.extend( {}, udataOld ); |
|
5960 |
|
5961 data_user.set( dest, udataCur ); |
|
5962 } |
|
5963 } |
|
5964 |
|
5965 |
|
5966 function getAll( context, tag ) { |
|
5967 var ret = context.getElementsByTagName ? context.getElementsByTagName( tag || "*" ) : |
|
5968 context.querySelectorAll ? context.querySelectorAll( tag || "*" ) : |
|
5969 []; |
|
5970 |
|
5971 return tag === undefined || tag && jQuery.nodeName( context, tag ) ? |
|
5972 jQuery.merge( [ context ], ret ) : |
|
5973 ret; |
|
5974 } |
|
5975 |
|
5976 // Support: IE >= 9 |
|
5977 function fixInput( src, dest ) { |
|
5978 var nodeName = dest.nodeName.toLowerCase(); |
|
5979 |
|
5980 // Fails to persist the checked state of a cloned checkbox or radio button. |
|
5981 if ( nodeName === "input" && manipulation_rcheckableType.test( src.type ) ) { |
|
5982 dest.checked = src.checked; |
|
5983 |
|
5984 // Fails to return the selected option to the default selected state when cloning options |
|
5985 } else if ( nodeName === "input" || nodeName === "textarea" ) { |
|
5986 dest.defaultValue = src.defaultValue; |
|
5987 } |
|
5988 } |
|
5989 jQuery.fn.extend({ |
|
5990 wrapAll: function( html ) { |
|
5991 var wrap; |
|
5992 |
|
5993 if ( jQuery.isFunction( html ) ) { |
|
5994 return this.each(function( i ) { |
|
5995 jQuery( this ).wrapAll( html.call(this, i) ); |
|
5996 }); |
|
5997 } |
|
5998 |
|
5999 if ( this[ 0 ] ) { |
|
6000 |
|
6001 // The elements to wrap the target around |
|
6002 wrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true ); |
|
6003 |
|
6004 if ( this[ 0 ].parentNode ) { |
|
6005 wrap.insertBefore( this[ 0 ] ); |
|
6006 } |
|
6007 |
|
6008 wrap.map(function() { |
|
6009 var elem = this; |
|
6010 |
|
6011 while ( elem.firstElementChild ) { |
|
6012 elem = elem.firstElementChild; |
|
6013 } |
|
6014 |
|
6015 return elem; |
|
6016 }).append( this ); |
|
6017 } |
|
6018 |
|
6019 return this; |
|
6020 }, |
|
6021 |
|
6022 wrapInner: function( html ) { |
|
6023 if ( jQuery.isFunction( html ) ) { |
|
6024 return this.each(function( i ) { |
|
6025 jQuery( this ).wrapInner( html.call(this, i) ); |
|
6026 }); |
|
6027 } |
|
6028 |
|
6029 return this.each(function() { |
|
6030 var self = jQuery( this ), |
|
6031 contents = self.contents(); |
|
6032 |
|
6033 if ( contents.length ) { |
|
6034 contents.wrapAll( html ); |
|
6035 |
|
6036 } else { |
|
6037 self.append( html ); |
|
6038 } |
|
6039 }); |
|
6040 }, |
|
6041 |
|
6042 wrap: function( html ) { |
|
6043 var isFunction = jQuery.isFunction( html ); |
|
6044 |
|
6045 return this.each(function( i ) { |
|
6046 jQuery( this ).wrapAll( isFunction ? html.call(this, i) : html ); |
|
6047 }); |
|
6048 }, |
|
6049 |
|
6050 unwrap: function() { |
|
6051 return this.parent().each(function() { |
|
6052 if ( !jQuery.nodeName( this, "body" ) ) { |
|
6053 jQuery( this ).replaceWith( this.childNodes ); |
|
6054 } |
|
6055 }).end(); |
|
6056 } |
|
6057 }); |
|
6058 var curCSS, iframe, |
|
6059 // swappable if display is none or starts with table except "table", "table-cell", or "table-caption" |
|
6060 // see here for display values: https://developer.mozilla.org/en-US/docs/CSS/display |
|
6061 rdisplayswap = /^(none|table(?!-c[ea]).+)/, |
|
6062 rmargin = /^margin/, |
|
6063 rnumsplit = new RegExp( "^(" + core_pnum + ")(.*)$", "i" ), |
|
6064 rnumnonpx = new RegExp( "^(" + core_pnum + ")(?!px)[a-z%]+$", "i" ), |
|
6065 rrelNum = new RegExp( "^([+-])=(" + core_pnum + ")", "i" ), |
|
6066 elemdisplay = { BODY: "block" }, |
|
6067 |
|
6068 cssShow = { position: "absolute", visibility: "hidden", display: "block" }, |
|
6069 cssNormalTransform = { |
|
6070 letterSpacing: 0, |
|
6071 fontWeight: 400 |
|
6072 }, |
|
6073 |
|
6074 cssExpand = [ "Top", "Right", "Bottom", "Left" ], |
|
6075 cssPrefixes = [ "Webkit", "O", "Moz", "ms" ]; |
|
6076 |
|
6077 // return a css property mapped to a potentially vendor prefixed property |
|
6078 function vendorPropName( style, name ) { |
|
6079 |
|
6080 // shortcut for names that are not vendor prefixed |
|
6081 if ( name in style ) { |
|
6082 return name; |
|
6083 } |
|
6084 |
|
6085 // check for vendor prefixed names |
|
6086 var capName = name.charAt(0).toUpperCase() + name.slice(1), |
|
6087 origName = name, |
|
6088 i = cssPrefixes.length; |
|
6089 |
|
6090 while ( i-- ) { |
|
6091 name = cssPrefixes[ i ] + capName; |
|
6092 if ( name in style ) { |
|
6093 return name; |
|
6094 } |
|
6095 } |
|
6096 |
|
6097 return origName; |
|
6098 } |
|
6099 |
|
6100 function isHidden( elem, el ) { |
|
6101 // isHidden might be called from jQuery#filter function; |
|
6102 // in that case, element will be second argument |
|
6103 elem = el || elem; |
|
6104 return jQuery.css( elem, "display" ) === "none" || !jQuery.contains( elem.ownerDocument, elem ); |
|
6105 } |
|
6106 |
|
6107 // NOTE: we've included the "window" in window.getComputedStyle |
|
6108 // because jsdom on node.js will break without it. |
|
6109 function getStyles( elem ) { |
|
6110 return window.getComputedStyle( elem, null ); |
|
6111 } |
|
6112 |
|
6113 function showHide( elements, show ) { |
|
6114 var display, elem, hidden, |
|
6115 values = [], |
|
6116 index = 0, |
|
6117 length = elements.length; |
|
6118 |
|
6119 for ( ; index < length; index++ ) { |
|
6120 elem = elements[ index ]; |
|
6121 if ( !elem.style ) { |
|
6122 continue; |
|
6123 } |
|
6124 |
|
6125 values[ index ] = data_priv.get( elem, "olddisplay" ); |
|
6126 display = elem.style.display; |
|
6127 if ( show ) { |
|
6128 // Reset the inline display of this element to learn if it is |
|
6129 // being hidden by cascaded rules or not |
|
6130 if ( !values[ index ] && display === "none" ) { |
|
6131 elem.style.display = ""; |
|
6132 } |
|
6133 |
|
6134 // Set elements which have been overridden with display: none |
|
6135 // in a stylesheet to whatever the default browser style is |
|
6136 // for such an element |
|
6137 if ( elem.style.display === "" && isHidden( elem ) ) { |
|
6138 values[ index ] = data_priv.access( elem, "olddisplay", css_defaultDisplay(elem.nodeName) ); |
|
6139 } |
|
6140 } else { |
|
6141 |
|
6142 if ( !values[ index ] ) { |
|
6143 hidden = isHidden( elem ); |
|
6144 |
|
6145 if ( display && display !== "none" || !hidden ) { |
|
6146 data_priv.set( elem, "olddisplay", hidden ? display : jQuery.css(elem, "display") ); |
|
6147 } |
|
6148 } |
|
6149 } |
|
6150 } |
|
6151 |
|
6152 // Set the display of most of the elements in a second loop |
|
6153 // to avoid the constant reflow |
|
6154 for ( index = 0; index < length; index++ ) { |
|
6155 elem = elements[ index ]; |
|
6156 if ( !elem.style ) { |
|
6157 continue; |
|
6158 } |
|
6159 if ( !show || elem.style.display === "none" || elem.style.display === "" ) { |
|
6160 elem.style.display = show ? values[ index ] || "" : "none"; |
|
6161 } |
|
6162 } |
|
6163 |
|
6164 return elements; |
|
6165 } |
|
6166 |
|
6167 jQuery.fn.extend({ |
|
6168 css: function( name, value ) { |
|
6169 return jQuery.access( this, function( elem, name, value ) { |
|
6170 var styles, len, |
|
6171 map = {}, |
|
6172 i = 0; |
|
6173 |
|
6174 if ( jQuery.isArray( name ) ) { |
|
6175 styles = getStyles( elem ); |
|
6176 len = name.length; |
|
6177 |
|
6178 for ( ; i < len; i++ ) { |
|
6179 map[ name[ i ] ] = jQuery.css( elem, name[ i ], false, styles ); |
|
6180 } |
|
6181 |
|
6182 return map; |
|
6183 } |
|
6184 |
|
6185 return value !== undefined ? |
|
6186 jQuery.style( elem, name, value ) : |
|
6187 jQuery.css( elem, name ); |
|
6188 }, name, value, arguments.length > 1 ); |
|
6189 }, |
|
6190 show: function() { |
|
6191 return showHide( this, true ); |
|
6192 }, |
|
6193 hide: function() { |
|
6194 return showHide( this ); |
|
6195 }, |
|
6196 toggle: function( state ) { |
|
6197 if ( typeof state === "boolean" ) { |
|
6198 return state ? this.show() : this.hide(); |
|
6199 } |
|
6200 |
|
6201 return this.each(function() { |
|
6202 if ( isHidden( this ) ) { |
|
6203 jQuery( this ).show(); |
|
6204 } else { |
|
6205 jQuery( this ).hide(); |
|
6206 } |
|
6207 }); |
|
6208 } |
|
6209 }); |
|
6210 |
|
6211 jQuery.extend({ |
|
6212 // Add in style property hooks for overriding the default |
|
6213 // behavior of getting and setting a style property |
|
6214 cssHooks: { |
|
6215 opacity: { |
|
6216 get: function( elem, computed ) { |
|
6217 if ( computed ) { |
|
6218 // We should always get a number back from opacity |
|
6219 var ret = curCSS( elem, "opacity" ); |
|
6220 return ret === "" ? "1" : ret; |
|
6221 } |
|
6222 } |
|
6223 } |
|
6224 }, |
|
6225 |
|
6226 // Don't automatically add "px" to these possibly-unitless properties |
|
6227 cssNumber: { |
|
6228 "columnCount": true, |
|
6229 "fillOpacity": true, |
|
6230 "fontWeight": true, |
|
6231 "lineHeight": true, |
|
6232 "opacity": true, |
|
6233 "order": true, |
|
6234 "orphans": true, |
|
6235 "widows": true, |
|
6236 "zIndex": true, |
|
6237 "zoom": true |
|
6238 }, |
|
6239 |
|
6240 // Add in properties whose names you wish to fix before |
|
6241 // setting or getting the value |
|
6242 cssProps: { |
|
6243 // normalize float css property |
|
6244 "float": "cssFloat" |
|
6245 }, |
|
6246 |
|
6247 // Get and set the style property on a DOM Node |
|
6248 style: function( elem, name, value, extra ) { |
|
6249 // Don't set styles on text and comment nodes |
|
6250 if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) { |
|
6251 return; |
|
6252 } |
|
6253 |
|
6254 // Make sure that we're working with the right name |
|
6255 var ret, type, hooks, |
|
6256 origName = jQuery.camelCase( name ), |
|
6257 style = elem.style; |
|
6258 |
|
6259 name = jQuery.cssProps[ origName ] || ( jQuery.cssProps[ origName ] = vendorPropName( style, origName ) ); |
|
6260 |
|
6261 // gets hook for the prefixed version |
|
6262 // followed by the unprefixed version |
|
6263 hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; |
|
6264 |
|
6265 // Check if we're setting a value |
|
6266 if ( value !== undefined ) { |
|
6267 type = typeof value; |
|
6268 |
|
6269 // convert relative number strings (+= or -=) to relative numbers. #7345 |
|
6270 if ( type === "string" && (ret = rrelNum.exec( value )) ) { |
|
6271 value = ( ret[1] + 1 ) * ret[2] + parseFloat( jQuery.css( elem, name ) ); |
|
6272 // Fixes bug #9237 |
|
6273 type = "number"; |
|
6274 } |
|
6275 |
|
6276 // Make sure that NaN and null values aren't set. See: #7116 |
|
6277 if ( value == null || type === "number" && isNaN( value ) ) { |
|
6278 return; |
|
6279 } |
|
6280 |
|
6281 // If a number was passed in, add 'px' to the (except for certain CSS properties) |
|
6282 if ( type === "number" && !jQuery.cssNumber[ origName ] ) { |
|
6283 value += "px"; |
|
6284 } |
|
6285 |
|
6286 // Fixes #8908, it can be done more correctly by specifying setters in cssHooks, |
|
6287 // but it would mean to define eight (for every problematic property) identical functions |
|
6288 if ( !jQuery.support.clearCloneStyle && value === "" && name.indexOf("background") === 0 ) { |
|
6289 style[ name ] = "inherit"; |
|
6290 } |
|
6291 |
|
6292 // If a hook was provided, use that value, otherwise just set the specified value |
|
6293 if ( !hooks || !("set" in hooks) || (value = hooks.set( elem, value, extra )) !== undefined ) { |
|
6294 style[ name ] = value; |
|
6295 } |
|
6296 |
|
6297 } else { |
|
6298 // If a hook was provided get the non-computed value from there |
|
6299 if ( hooks && "get" in hooks && (ret = hooks.get( elem, false, extra )) !== undefined ) { |
|
6300 return ret; |
|
6301 } |
|
6302 |
|
6303 // Otherwise just get the value from the style object |
|
6304 return style[ name ]; |
|
6305 } |
|
6306 }, |
|
6307 |
|
6308 css: function( elem, name, extra, styles ) { |
|
6309 var val, num, hooks, |
|
6310 origName = jQuery.camelCase( name ); |
|
6311 |
|
6312 // Make sure that we're working with the right name |
|
6313 name = jQuery.cssProps[ origName ] || ( jQuery.cssProps[ origName ] = vendorPropName( elem.style, origName ) ); |
|
6314 |
|
6315 // gets hook for the prefixed version |
|
6316 // followed by the unprefixed version |
|
6317 hooks = jQuery.cssHooks[ name ] || jQuery.cssHooks[ origName ]; |
|
6318 |
|
6319 // If a hook was provided get the computed value from there |
|
6320 if ( hooks && "get" in hooks ) { |
|
6321 val = hooks.get( elem, true, extra ); |
|
6322 } |
|
6323 |
|
6324 // Otherwise, if a way to get the computed value exists, use that |
|
6325 if ( val === undefined ) { |
|
6326 val = curCSS( elem, name, styles ); |
|
6327 } |
|
6328 |
|
6329 //convert "normal" to computed value |
|
6330 if ( val === "normal" && name in cssNormalTransform ) { |
|
6331 val = cssNormalTransform[ name ]; |
|
6332 } |
|
6333 |
|
6334 // Return, converting to number if forced or a qualifier was provided and val looks numeric |
|
6335 if ( extra === "" || extra ) { |
|
6336 num = parseFloat( val ); |
|
6337 return extra === true || jQuery.isNumeric( num ) ? num || 0 : val; |
|
6338 } |
|
6339 return val; |
|
6340 } |
|
6341 }); |
|
6342 |
|
6343 curCSS = function( elem, name, _computed ) { |
|
6344 var width, minWidth, maxWidth, |
|
6345 computed = _computed || getStyles( elem ), |
|
6346 |
|
6347 // Support: IE9 |
|
6348 // getPropertyValue is only needed for .css('filter') in IE9, see #12537 |
|
6349 ret = computed ? computed.getPropertyValue( name ) || computed[ name ] : undefined, |
|
6350 style = elem.style; |
|
6351 |
|
6352 if ( computed ) { |
|
6353 |
|
6354 if ( ret === "" && !jQuery.contains( elem.ownerDocument, elem ) ) { |
|
6355 ret = jQuery.style( elem, name ); |
|
6356 } |
|
6357 |
|
6358 // Support: Safari 5.1 |
|
6359 // A tribute to the "awesome hack by Dean Edwards" |
|
6360 // Safari 5.1.7 (at least) returns percentage for a larger set of values, but width seems to be reliably pixels |
|
6361 // this is against the CSSOM draft spec: http://dev.w3.org/csswg/cssom/#resolved-values |
|
6362 if ( rnumnonpx.test( ret ) && rmargin.test( name ) ) { |
|
6363 |
|
6364 // Remember the original values |
|
6365 width = style.width; |
|
6366 minWidth = style.minWidth; |
|
6367 maxWidth = style.maxWidth; |
|
6368 |
|
6369 // Put in the new values to get a computed value out |
|
6370 style.minWidth = style.maxWidth = style.width = ret; |
|
6371 ret = computed.width; |
|
6372 |
|
6373 // Revert the changed values |
|
6374 style.width = width; |
|
6375 style.minWidth = minWidth; |
|
6376 style.maxWidth = maxWidth; |
|
6377 } |
|
6378 } |
|
6379 |
|
6380 return ret; |
|
6381 }; |
|
6382 |
|
6383 |
|
6384 function setPositiveNumber( elem, value, subtract ) { |
|
6385 var matches = rnumsplit.exec( value ); |
|
6386 return matches ? |
|
6387 // Guard against undefined "subtract", e.g., when used as in cssHooks |
|
6388 Math.max( 0, matches[ 1 ] - ( subtract || 0 ) ) + ( matches[ 2 ] || "px" ) : |
|
6389 value; |
|
6390 } |
|
6391 |
|
6392 function augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) { |
|
6393 var i = extra === ( isBorderBox ? "border" : "content" ) ? |
|
6394 // If we already have the right measurement, avoid augmentation |
|
6395 4 : |
|
6396 // Otherwise initialize for horizontal or vertical properties |
|
6397 name === "width" ? 1 : 0, |
|
6398 |
|
6399 val = 0; |
|
6400 |
|
6401 for ( ; i < 4; i += 2 ) { |
|
6402 // both box models exclude margin, so add it if we want it |
|
6403 if ( extra === "margin" ) { |
|
6404 val += jQuery.css( elem, extra + cssExpand[ i ], true, styles ); |
|
6405 } |
|
6406 |
|
6407 if ( isBorderBox ) { |
|
6408 // border-box includes padding, so remove it if we want content |
|
6409 if ( extra === "content" ) { |
|
6410 val -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); |
|
6411 } |
|
6412 |
|
6413 // at this point, extra isn't border nor margin, so remove border |
|
6414 if ( extra !== "margin" ) { |
|
6415 val -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); |
|
6416 } |
|
6417 } else { |
|
6418 // at this point, extra isn't content, so add padding |
|
6419 val += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); |
|
6420 |
|
6421 // at this point, extra isn't content nor padding, so add border |
|
6422 if ( extra !== "padding" ) { |
|
6423 val += jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); |
|
6424 } |
|
6425 } |
|
6426 } |
|
6427 |
|
6428 return val; |
|
6429 } |
|
6430 |
|
6431 function getWidthOrHeight( elem, name, extra ) { |
|
6432 |
|
6433 // Start with offset property, which is equivalent to the border-box value |
|
6434 var valueIsBorderBox = true, |
|
6435 val = name === "width" ? elem.offsetWidth : elem.offsetHeight, |
|
6436 styles = getStyles( elem ), |
|
6437 isBorderBox = jQuery.support.boxSizing && jQuery.css( elem, "boxSizing", false, styles ) === "border-box"; |
|
6438 |
|
6439 // some non-html elements return undefined for offsetWidth, so check for null/undefined |
|
6440 // svg - https://bugzilla.mozilla.org/show_bug.cgi?id=649285 |
|
6441 // MathML - https://bugzilla.mozilla.org/show_bug.cgi?id=491668 |
|
6442 if ( val <= 0 || val == null ) { |
|
6443 // Fall back to computed then uncomputed css if necessary |
|
6444 val = curCSS( elem, name, styles ); |
|
6445 if ( val < 0 || val == null ) { |
|
6446 val = elem.style[ name ]; |
|
6447 } |
|
6448 |
|
6449 // Computed unit is not pixels. Stop here and return. |
|
6450 if ( rnumnonpx.test(val) ) { |
|
6451 return val; |
|
6452 } |
|
6453 |
|
6454 // we need the check for style in case a browser which returns unreliable values |
|
6455 // for getComputedStyle silently falls back to the reliable elem.style |
|
6456 valueIsBorderBox = isBorderBox && ( jQuery.support.boxSizingReliable || val === elem.style[ name ] ); |
|
6457 |
|
6458 // Normalize "", auto, and prepare for extra |
|
6459 val = parseFloat( val ) || 0; |
|
6460 } |
|
6461 |
|
6462 // use the active box-sizing model to add/subtract irrelevant styles |
|
6463 return ( val + |
|
6464 augmentWidthOrHeight( |
|
6465 elem, |
|
6466 name, |
|
6467 extra || ( isBorderBox ? "border" : "content" ), |
|
6468 valueIsBorderBox, |
|
6469 styles |
|
6470 ) |
|
6471 ) + "px"; |
|
6472 } |
|
6473 |
|
6474 // Try to determine the default display value of an element |
|
6475 function css_defaultDisplay( nodeName ) { |
|
6476 var doc = document, |
|
6477 display = elemdisplay[ nodeName ]; |
|
6478 |
|
6479 if ( !display ) { |
|
6480 display = actualDisplay( nodeName, doc ); |
|
6481 |
|
6482 // If the simple way fails, read from inside an iframe |
|
6483 if ( display === "none" || !display ) { |
|
6484 // Use the already-created iframe if possible |
|
6485 iframe = ( iframe || |
|
6486 jQuery("<iframe frameborder='0' width='0' height='0'/>") |
|
6487 .css( "cssText", "display:block !important" ) |
|
6488 ).appendTo( doc.documentElement ); |
|
6489 |
|
6490 // Always write a new HTML skeleton so Webkit and Firefox don't choke on reuse |
|
6491 doc = ( iframe[0].contentWindow || iframe[0].contentDocument ).document; |
|
6492 doc.write("<!doctype html><html><body>"); |
|
6493 doc.close(); |
|
6494 |
|
6495 display = actualDisplay( nodeName, doc ); |
|
6496 iframe.detach(); |
|
6497 } |
|
6498 |
|
6499 // Store the correct default display |
|
6500 elemdisplay[ nodeName ] = display; |
|
6501 } |
|
6502 |
|
6503 return display; |
|
6504 } |
|
6505 |
|
6506 // Called ONLY from within css_defaultDisplay |
|
6507 function actualDisplay( name, doc ) { |
|
6508 var elem = jQuery( doc.createElement( name ) ).appendTo( doc.body ), |
|
6509 display = jQuery.css( elem[0], "display" ); |
|
6510 elem.remove(); |
|
6511 return display; |
|
6512 } |
|
6513 |
|
6514 jQuery.each([ "height", "width" ], function( i, name ) { |
|
6515 jQuery.cssHooks[ name ] = { |
|
6516 get: function( elem, computed, extra ) { |
|
6517 if ( computed ) { |
|
6518 // certain elements can have dimension info if we invisibly show them |
|
6519 // however, it must have a current display style that would benefit from this |
|
6520 return elem.offsetWidth === 0 && rdisplayswap.test( jQuery.css( elem, "display" ) ) ? |
|
6521 jQuery.swap( elem, cssShow, function() { |
|
6522 return getWidthOrHeight( elem, name, extra ); |
|
6523 }) : |
|
6524 getWidthOrHeight( elem, name, extra ); |
|
6525 } |
|
6526 }, |
|
6527 |
|
6528 set: function( elem, value, extra ) { |
|
6529 var styles = extra && getStyles( elem ); |
|
6530 return setPositiveNumber( elem, value, extra ? |
|
6531 augmentWidthOrHeight( |
|
6532 elem, |
|
6533 name, |
|
6534 extra, |
|
6535 jQuery.support.boxSizing && jQuery.css( elem, "boxSizing", false, styles ) === "border-box", |
|
6536 styles |
|
6537 ) : 0 |
|
6538 ); |
|
6539 } |
|
6540 }; |
|
6541 }); |
|
6542 |
|
6543 // These hooks cannot be added until DOM ready because the support test |
|
6544 // for it is not run until after DOM ready |
|
6545 jQuery(function() { |
|
6546 // Support: Android 2.3 |
|
6547 if ( !jQuery.support.reliableMarginRight ) { |
|
6548 jQuery.cssHooks.marginRight = { |
|
6549 get: function( elem, computed ) { |
|
6550 if ( computed ) { |
|
6551 // Support: Android 2.3 |
|
6552 // WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right |
|
6553 // Work around by temporarily setting element display to inline-block |
|
6554 return jQuery.swap( elem, { "display": "inline-block" }, |
|
6555 curCSS, [ elem, "marginRight" ] ); |
|
6556 } |
|
6557 } |
|
6558 }; |
|
6559 } |
|
6560 |
|
6561 // Webkit bug: https://bugs.webkit.org/show_bug.cgi?id=29084 |
|
6562 // getComputedStyle returns percent when specified for top/left/bottom/right |
|
6563 // rather than make the css module depend on the offset module, we just check for it here |
|
6564 if ( !jQuery.support.pixelPosition && jQuery.fn.position ) { |
|
6565 jQuery.each( [ "top", "left" ], function( i, prop ) { |
|
6566 jQuery.cssHooks[ prop ] = { |
|
6567 get: function( elem, computed ) { |
|
6568 if ( computed ) { |
|
6569 computed = curCSS( elem, prop ); |
|
6570 // if curCSS returns percentage, fallback to offset |
|
6571 return rnumnonpx.test( computed ) ? |
|
6572 jQuery( elem ).position()[ prop ] + "px" : |
|
6573 computed; |
|
6574 } |
|
6575 } |
|
6576 }; |
|
6577 }); |
|
6578 } |
|
6579 |
|
6580 }); |
|
6581 |
|
6582 if ( jQuery.expr && jQuery.expr.filters ) { |
|
6583 jQuery.expr.filters.hidden = function( elem ) { |
|
6584 // Support: Opera <= 12.12 |
|
6585 // Opera reports offsetWidths and offsetHeights less than zero on some elements |
|
6586 return elem.offsetWidth <= 0 && elem.offsetHeight <= 0; |
|
6587 }; |
|
6588 |
|
6589 jQuery.expr.filters.visible = function( elem ) { |
|
6590 return !jQuery.expr.filters.hidden( elem ); |
|
6591 }; |
|
6592 } |
|
6593 |
|
6594 // These hooks are used by animate to expand properties |
|
6595 jQuery.each({ |
|
6596 margin: "", |
|
6597 padding: "", |
|
6598 border: "Width" |
|
6599 }, function( prefix, suffix ) { |
|
6600 jQuery.cssHooks[ prefix + suffix ] = { |
|
6601 expand: function( value ) { |
|
6602 var i = 0, |
|
6603 expanded = {}, |
|
6604 |
|
6605 // assumes a single number if not a string |
|
6606 parts = typeof value === "string" ? value.split(" ") : [ value ]; |
|
6607 |
|
6608 for ( ; i < 4; i++ ) { |
|
6609 expanded[ prefix + cssExpand[ i ] + suffix ] = |
|
6610 parts[ i ] || parts[ i - 2 ] || parts[ 0 ]; |
|
6611 } |
|
6612 |
|
6613 return expanded; |
|
6614 } |
|
6615 }; |
|
6616 |
|
6617 if ( !rmargin.test( prefix ) ) { |
|
6618 jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber; |
|
6619 } |
|
6620 }); |
|
6621 var r20 = /%20/g, |
|
6622 rbracket = /\[\]$/, |
|
6623 rCRLF = /\r?\n/g, |
|
6624 rsubmitterTypes = /^(?:submit|button|image|reset|file)$/i, |
|
6625 rsubmittable = /^(?:input|select|textarea|keygen)/i; |
|
6626 |
|
6627 jQuery.fn.extend({ |
|
6628 serialize: function() { |
|
6629 return jQuery.param( this.serializeArray() ); |
|
6630 }, |
|
6631 serializeArray: function() { |
|
6632 return this.map(function(){ |
|
6633 // Can add propHook for "elements" to filter or add form elements |
|
6634 var elements = jQuery.prop( this, "elements" ); |
|
6635 return elements ? jQuery.makeArray( elements ) : this; |
|
6636 }) |
|
6637 .filter(function(){ |
|
6638 var type = this.type; |
|
6639 // Use .is(":disabled") so that fieldset[disabled] works |
|
6640 return this.name && !jQuery( this ).is( ":disabled" ) && |
|
6641 rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) && |
|
6642 ( this.checked || !manipulation_rcheckableType.test( type ) ); |
|
6643 }) |
|
6644 .map(function( i, elem ){ |
|
6645 var val = jQuery( this ).val(); |
|
6646 |
|
6647 return val == null ? |
|
6648 null : |
|
6649 jQuery.isArray( val ) ? |
|
6650 jQuery.map( val, function( val ){ |
|
6651 return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; |
|
6652 }) : |
|
6653 { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; |
|
6654 }).get(); |
|
6655 } |
|
6656 }); |
|
6657 |
|
6658 //Serialize an array of form elements or a set of |
|
6659 //key/values into a query string |
|
6660 jQuery.param = function( a, traditional ) { |
|
6661 var prefix, |
|
6662 s = [], |
|
6663 add = function( key, value ) { |
|
6664 // If value is a function, invoke it and return its value |
|
6665 value = jQuery.isFunction( value ) ? value() : ( value == null ? "" : value ); |
|
6666 s[ s.length ] = encodeURIComponent( key ) + "=" + encodeURIComponent( value ); |
|
6667 }; |
|
6668 |
|
6669 // Set traditional to true for jQuery <= 1.3.2 behavior. |
|
6670 if ( traditional === undefined ) { |
|
6671 traditional = jQuery.ajaxSettings && jQuery.ajaxSettings.traditional; |
|
6672 } |
|
6673 |
|
6674 // If an array was passed in, assume that it is an array of form elements. |
|
6675 if ( jQuery.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) { |
|
6676 // Serialize the form elements |
|
6677 jQuery.each( a, function() { |
|
6678 add( this.name, this.value ); |
|
6679 }); |
|
6680 |
|
6681 } else { |
|
6682 // If traditional, encode the "old" way (the way 1.3.2 or older |
|
6683 // did it), otherwise encode params recursively. |
|
6684 for ( prefix in a ) { |
|
6685 buildParams( prefix, a[ prefix ], traditional, add ); |
|
6686 } |
|
6687 } |
|
6688 |
|
6689 // Return the resulting serialization |
|
6690 return s.join( "&" ).replace( r20, "+" ); |
|
6691 }; |
|
6692 |
|
6693 function buildParams( prefix, obj, traditional, add ) { |
|
6694 var name; |
|
6695 |
|
6696 if ( jQuery.isArray( obj ) ) { |
|
6697 // Serialize array item. |
|
6698 jQuery.each( obj, function( i, v ) { |
|
6699 if ( traditional || rbracket.test( prefix ) ) { |
|
6700 // Treat each array item as a scalar. |
|
6701 add( prefix, v ); |
|
6702 |
|
6703 } else { |
|
6704 // Item is non-scalar (array or object), encode its numeric index. |
|
6705 buildParams( prefix + "[" + ( typeof v === "object" ? i : "" ) + "]", v, traditional, add ); |
|
6706 } |
|
6707 }); |
|
6708 |
|
6709 } else if ( !traditional && jQuery.type( obj ) === "object" ) { |
|
6710 // Serialize object item. |
|
6711 for ( name in obj ) { |
|
6712 buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add ); |
|
6713 } |
|
6714 |
|
6715 } else { |
|
6716 // Serialize scalar item. |
|
6717 add( prefix, obj ); |
|
6718 } |
|
6719 } |
|
6720 jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblclick " + |
7479 jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblclick " + |
6721 "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + |
7480 "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + |
6722 "change select submit keydown keypress keyup error contextmenu").split(" "), function( i, name ) { |
7481 "change select submit keydown keypress keyup error contextmenu").split(" "), function( i, name ) { |
6723 |
7482 |
6724 // Handle event binding |
7483 // Handle event binding |
7739 |
8787 |
7740 // Delegate to script |
8788 // Delegate to script |
7741 return "script"; |
8789 return "script"; |
7742 } |
8790 } |
7743 }); |
8791 }); |
7744 jQuery.ajaxSettings.xhr = function() { |
8792 |
7745 try { |
8793 |
7746 return new XMLHttpRequest(); |
8794 |
7747 } catch( e ) {} |
8795 |
|
8796 // data: string of html |
|
8797 // context (optional): If specified, the fragment will be created in this context, defaults to document |
|
8798 // keepScripts (optional): If true, will include scripts passed in the html string |
|
8799 jQuery.parseHTML = function( data, context, keepScripts ) { |
|
8800 if ( !data || typeof data !== "string" ) { |
|
8801 return null; |
|
8802 } |
|
8803 if ( typeof context === "boolean" ) { |
|
8804 keepScripts = context; |
|
8805 context = false; |
|
8806 } |
|
8807 context = context || document; |
|
8808 |
|
8809 var parsed = rsingleTag.exec( data ), |
|
8810 scripts = !keepScripts && []; |
|
8811 |
|
8812 // Single tag |
|
8813 if ( parsed ) { |
|
8814 return [ context.createElement( parsed[1] ) ]; |
|
8815 } |
|
8816 |
|
8817 parsed = jQuery.buildFragment( [ data ], context, scripts ); |
|
8818 |
|
8819 if ( scripts && scripts.length ) { |
|
8820 jQuery( scripts ).remove(); |
|
8821 } |
|
8822 |
|
8823 return jQuery.merge( [], parsed.childNodes ); |
7748 }; |
8824 }; |
7749 |
8825 |
7750 var xhrSupported = jQuery.ajaxSettings.xhr(), |
8826 |
7751 xhrSuccessStatus = { |
8827 // Keep a copy of the old load method |
7752 // file protocol always yields status code 0, assume 200 |
8828 var _load = jQuery.fn.load; |
7753 0: 200, |
8829 |
7754 // Support: IE9 |
8830 /** |
7755 // #1450: sometimes IE returns 1223 when it should be 204 |
8831 * Load a url into a page |
7756 1223: 204 |
8832 */ |
7757 }, |
8833 jQuery.fn.load = function( url, params, callback ) { |
7758 // Support: IE9 |
8834 if ( typeof url !== "string" && _load ) { |
7759 // We need to keep track of outbound xhr and abort them manually |
8835 return _load.apply( this, arguments ); |
7760 // because IE is not smart enough to do it all by itself |
8836 } |
7761 xhrId = 0, |
8837 |
7762 xhrCallbacks = {}; |
8838 var selector, type, response, |
7763 |
8839 self = this, |
7764 if ( window.ActiveXObject ) { |
8840 off = url.indexOf(" "); |
7765 jQuery( window ).on( "unload", function() { |
8841 |
7766 for( var key in xhrCallbacks ) { |
8842 if ( off >= 0 ) { |
7767 xhrCallbacks[ key ](); |
8843 selector = jQuery.trim( url.slice( off ) ); |
7768 } |
8844 url = url.slice( 0, off ); |
7769 xhrCallbacks = undefined; |
8845 } |
7770 }); |
8846 |
7771 } |
8847 // If it's a function |
7772 |
8848 if ( jQuery.isFunction( params ) ) { |
7773 jQuery.support.cors = !!xhrSupported && ( "withCredentials" in xhrSupported ); |
8849 |
7774 jQuery.support.ajax = xhrSupported = !!xhrSupported; |
8850 // We assume that it's the callback |
7775 |
8851 callback = params; |
7776 jQuery.ajaxTransport(function( options ) { |
8852 params = undefined; |
7777 var callback; |
8853 |
7778 // Cross domain only allowed if supported through XMLHttpRequest |
8854 // Otherwise, build a param string |
7779 if ( jQuery.support.cors || xhrSupported && !options.crossDomain ) { |
8855 } else if ( params && typeof params === "object" ) { |
7780 return { |
8856 type = "POST"; |
7781 send: function( headers, complete ) { |
8857 } |
7782 var i, id, |
8858 |
7783 xhr = options.xhr(); |
8859 // If we have elements to modify, make the request |
7784 xhr.open( options.type, options.url, options.async, options.username, options.password ); |
8860 if ( self.length > 0 ) { |
7785 // Apply custom fields if provided |
8861 jQuery.ajax({ |
7786 if ( options.xhrFields ) { |
8862 url: url, |
7787 for ( i in options.xhrFields ) { |
8863 |
7788 xhr[ i ] = options.xhrFields[ i ]; |
8864 // if "type" variable is undefined, then "GET" method will be used |
7789 } |
8865 type: type, |
7790 } |
8866 dataType: "html", |
7791 // Override mime type if needed |
8867 data: params |
7792 if ( options.mimeType && xhr.overrideMimeType ) { |
8868 }).done(function( responseText ) { |
7793 xhr.overrideMimeType( options.mimeType ); |
8869 |
7794 } |
8870 // Save response for use in complete callback |
7795 // X-Requested-With header |
8871 response = arguments; |
7796 // For cross-domain requests, seeing as conditions for a preflight are |
8872 |
7797 // akin to a jigsaw puzzle, we simply never set it to be sure. |
8873 self.html( selector ? |
7798 // (it can always be set on a per-request basis or even using ajaxSetup) |
8874 |
7799 // For same-domain requests, won't change header if already provided. |
8875 // If a selector was specified, locate the right elements in a dummy div |
7800 if ( !options.crossDomain && !headers["X-Requested-With"] ) { |
8876 // Exclude scripts to avoid IE 'Permission Denied' errors |
7801 headers["X-Requested-With"] = "XMLHttpRequest"; |
8877 jQuery("<div>").append( jQuery.parseHTML( responseText ) ).find( selector ) : |
7802 } |
8878 |
7803 // Set headers |
8879 // Otherwise use the full result |
7804 for ( i in headers ) { |
8880 responseText ); |
7805 xhr.setRequestHeader( i, headers[ i ] ); |
8881 |
7806 } |
8882 }).complete( callback && function( jqXHR, status ) { |
7807 // Callback |
8883 self.each( callback, response || [ jqXHR.responseText, status, jqXHR ] ); |
7808 callback = function( type ) { |
|
7809 return function() { |
|
7810 if ( callback ) { |
|
7811 delete xhrCallbacks[ id ]; |
|
7812 callback = xhr.onload = xhr.onerror = null; |
|
7813 if ( type === "abort" ) { |
|
7814 xhr.abort(); |
|
7815 } else if ( type === "error" ) { |
|
7816 complete( |
|
7817 // file protocol always yields status 0, assume 404 |
|
7818 xhr.status || 404, |
|
7819 xhr.statusText |
|
7820 ); |
|
7821 } else { |
|
7822 complete( |
|
7823 xhrSuccessStatus[ xhr.status ] || xhr.status, |
|
7824 xhr.statusText, |
|
7825 // Support: IE9 |
|
7826 // #11426: When requesting binary data, IE9 will throw an exception |
|
7827 // on any attempt to access responseText |
|
7828 typeof xhr.responseText === "string" ? { |
|
7829 text: xhr.responseText |
|
7830 } : undefined, |
|
7831 xhr.getAllResponseHeaders() |
|
7832 ); |
|
7833 } |
|
7834 } |
|
7835 }; |
|
7836 }; |
|
7837 // Listen to events |
|
7838 xhr.onload = callback(); |
|
7839 xhr.onerror = callback("error"); |
|
7840 // Create the abort callback |
|
7841 callback = xhrCallbacks[( id = xhrId++ )] = callback("abort"); |
|
7842 // Do send the request |
|
7843 // This may raise an exception which is actually |
|
7844 // handled in jQuery.ajax (so no try/catch here) |
|
7845 xhr.send( options.hasContent && options.data || null ); |
|
7846 }, |
|
7847 abort: function() { |
|
7848 if ( callback ) { |
|
7849 callback(); |
|
7850 } |
|
7851 } |
|
7852 }; |
|
7853 } |
|
7854 }); |
|
7855 var fxNow, timerId, |
|
7856 rfxtypes = /^(?:toggle|show|hide)$/, |
|
7857 rfxnum = new RegExp( "^(?:([+-])=|)(" + core_pnum + ")([a-z%]*)$", "i" ), |
|
7858 rrun = /queueHooks$/, |
|
7859 animationPrefilters = [ defaultPrefilter ], |
|
7860 tweeners = { |
|
7861 "*": [function( prop, value ) { |
|
7862 var tween = this.createTween( prop, value ), |
|
7863 target = tween.cur(), |
|
7864 parts = rfxnum.exec( value ), |
|
7865 unit = parts && parts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ), |
|
7866 |
|
7867 // Starting value computation is required for potential unit mismatches |
|
7868 start = ( jQuery.cssNumber[ prop ] || unit !== "px" && +target ) && |
|
7869 rfxnum.exec( jQuery.css( tween.elem, prop ) ), |
|
7870 scale = 1, |
|
7871 maxIterations = 20; |
|
7872 |
|
7873 if ( start && start[ 3 ] !== unit ) { |
|
7874 // Trust units reported by jQuery.css |
|
7875 unit = unit || start[ 3 ]; |
|
7876 |
|
7877 // Make sure we update the tween properties later on |
|
7878 parts = parts || []; |
|
7879 |
|
7880 // Iteratively approximate from a nonzero starting point |
|
7881 start = +target || 1; |
|
7882 |
|
7883 do { |
|
7884 // If previous iteration zeroed out, double until we get *something* |
|
7885 // Use a string for doubling factor so we don't accidentally see scale as unchanged below |
|
7886 scale = scale || ".5"; |
|
7887 |
|
7888 // Adjust and apply |
|
7889 start = start / scale; |
|
7890 jQuery.style( tween.elem, prop, start + unit ); |
|
7891 |
|
7892 // Update scale, tolerating zero or NaN from tween.cur() |
|
7893 // And breaking the loop if scale is unchanged or perfect, or if we've just had enough |
|
7894 } while ( scale !== (scale = tween.cur() / target) && scale !== 1 && --maxIterations ); |
|
7895 } |
|
7896 |
|
7897 // Update tween properties |
|
7898 if ( parts ) { |
|
7899 start = tween.start = +start || +target || 0; |
|
7900 tween.unit = unit; |
|
7901 // If a +=/-= token was provided, we're doing a relative animation |
|
7902 tween.end = parts[ 1 ] ? |
|
7903 start + ( parts[ 1 ] + 1 ) * parts[ 2 ] : |
|
7904 +parts[ 2 ]; |
|
7905 } |
|
7906 |
|
7907 return tween; |
|
7908 }] |
|
7909 }; |
|
7910 |
|
7911 // Animations created synchronously will run synchronously |
|
7912 function createFxNow() { |
|
7913 setTimeout(function() { |
|
7914 fxNow = undefined; |
|
7915 }); |
|
7916 return ( fxNow = jQuery.now() ); |
|
7917 } |
|
7918 |
|
7919 function createTween( value, prop, animation ) { |
|
7920 var tween, |
|
7921 collection = ( tweeners[ prop ] || [] ).concat( tweeners[ "*" ] ), |
|
7922 index = 0, |
|
7923 length = collection.length; |
|
7924 for ( ; index < length; index++ ) { |
|
7925 if ( (tween = collection[ index ].call( animation, prop, value )) ) { |
|
7926 |
|
7927 // we're done with this property |
|
7928 return tween; |
|
7929 } |
|
7930 } |
|
7931 } |
|
7932 |
|
7933 function Animation( elem, properties, options ) { |
|
7934 var result, |
|
7935 stopped, |
|
7936 index = 0, |
|
7937 length = animationPrefilters.length, |
|
7938 deferred = jQuery.Deferred().always( function() { |
|
7939 // don't match elem in the :animated selector |
|
7940 delete tick.elem; |
|
7941 }), |
|
7942 tick = function() { |
|
7943 if ( stopped ) { |
|
7944 return false; |
|
7945 } |
|
7946 var currentTime = fxNow || createFxNow(), |
|
7947 remaining = Math.max( 0, animation.startTime + animation.duration - currentTime ), |
|
7948 // archaic crash bug won't allow us to use 1 - ( 0.5 || 0 ) (#12497) |
|
7949 temp = remaining / animation.duration || 0, |
|
7950 percent = 1 - temp, |
|
7951 index = 0, |
|
7952 length = animation.tweens.length; |
|
7953 |
|
7954 for ( ; index < length ; index++ ) { |
|
7955 animation.tweens[ index ].run( percent ); |
|
7956 } |
|
7957 |
|
7958 deferred.notifyWith( elem, [ animation, percent, remaining ]); |
|
7959 |
|
7960 if ( percent < 1 && length ) { |
|
7961 return remaining; |
|
7962 } else { |
|
7963 deferred.resolveWith( elem, [ animation ] ); |
|
7964 return false; |
|
7965 } |
|
7966 }, |
|
7967 animation = deferred.promise({ |
|
7968 elem: elem, |
|
7969 props: jQuery.extend( {}, properties ), |
|
7970 opts: jQuery.extend( true, { specialEasing: {} }, options ), |
|
7971 originalProperties: properties, |
|
7972 originalOptions: options, |
|
7973 startTime: fxNow || createFxNow(), |
|
7974 duration: options.duration, |
|
7975 tweens: [], |
|
7976 createTween: function( prop, end ) { |
|
7977 var tween = jQuery.Tween( elem, animation.opts, prop, end, |
|
7978 animation.opts.specialEasing[ prop ] || animation.opts.easing ); |
|
7979 animation.tweens.push( tween ); |
|
7980 return tween; |
|
7981 }, |
|
7982 stop: function( gotoEnd ) { |
|
7983 var index = 0, |
|
7984 // if we are going to the end, we want to run all the tweens |
|
7985 // otherwise we skip this part |
|
7986 length = gotoEnd ? animation.tweens.length : 0; |
|
7987 if ( stopped ) { |
|
7988 return this; |
|
7989 } |
|
7990 stopped = true; |
|
7991 for ( ; index < length ; index++ ) { |
|
7992 animation.tweens[ index ].run( 1 ); |
|
7993 } |
|
7994 |
|
7995 // resolve when we played the last frame |
|
7996 // otherwise, reject |
|
7997 if ( gotoEnd ) { |
|
7998 deferred.resolveWith( elem, [ animation, gotoEnd ] ); |
|
7999 } else { |
|
8000 deferred.rejectWith( elem, [ animation, gotoEnd ] ); |
|
8001 } |
|
8002 return this; |
|
8003 } |
|
8004 }), |
|
8005 props = animation.props; |
|
8006 |
|
8007 propFilter( props, animation.opts.specialEasing ); |
|
8008 |
|
8009 for ( ; index < length ; index++ ) { |
|
8010 result = animationPrefilters[ index ].call( animation, elem, props, animation.opts ); |
|
8011 if ( result ) { |
|
8012 return result; |
|
8013 } |
|
8014 } |
|
8015 |
|
8016 jQuery.map( props, createTween, animation ); |
|
8017 |
|
8018 if ( jQuery.isFunction( animation.opts.start ) ) { |
|
8019 animation.opts.start.call( elem, animation ); |
|
8020 } |
|
8021 |
|
8022 jQuery.fx.timer( |
|
8023 jQuery.extend( tick, { |
|
8024 elem: elem, |
|
8025 anim: animation, |
|
8026 queue: animation.opts.queue |
|
8027 }) |
|
8028 ); |
|
8029 |
|
8030 // attach callbacks from options |
|
8031 return animation.progress( animation.opts.progress ) |
|
8032 .done( animation.opts.done, animation.opts.complete ) |
|
8033 .fail( animation.opts.fail ) |
|
8034 .always( animation.opts.always ); |
|
8035 } |
|
8036 |
|
8037 function propFilter( props, specialEasing ) { |
|
8038 var index, name, easing, value, hooks; |
|
8039 |
|
8040 // camelCase, specialEasing and expand cssHook pass |
|
8041 for ( index in props ) { |
|
8042 name = jQuery.camelCase( index ); |
|
8043 easing = specialEasing[ name ]; |
|
8044 value = props[ index ]; |
|
8045 if ( jQuery.isArray( value ) ) { |
|
8046 easing = value[ 1 ]; |
|
8047 value = props[ index ] = value[ 0 ]; |
|
8048 } |
|
8049 |
|
8050 if ( index !== name ) { |
|
8051 props[ name ] = value; |
|
8052 delete props[ index ]; |
|
8053 } |
|
8054 |
|
8055 hooks = jQuery.cssHooks[ name ]; |
|
8056 if ( hooks && "expand" in hooks ) { |
|
8057 value = hooks.expand( value ); |
|
8058 delete props[ name ]; |
|
8059 |
|
8060 // not quite $.extend, this wont overwrite keys already present. |
|
8061 // also - reusing 'index' from above because we have the correct "name" |
|
8062 for ( index in value ) { |
|
8063 if ( !( index in props ) ) { |
|
8064 props[ index ] = value[ index ]; |
|
8065 specialEasing[ index ] = easing; |
|
8066 } |
|
8067 } |
|
8068 } else { |
|
8069 specialEasing[ name ] = easing; |
|
8070 } |
|
8071 } |
|
8072 } |
|
8073 |
|
8074 jQuery.Animation = jQuery.extend( Animation, { |
|
8075 |
|
8076 tweener: function( props, callback ) { |
|
8077 if ( jQuery.isFunction( props ) ) { |
|
8078 callback = props; |
|
8079 props = [ "*" ]; |
|
8080 } else { |
|
8081 props = props.split(" "); |
|
8082 } |
|
8083 |
|
8084 var prop, |
|
8085 index = 0, |
|
8086 length = props.length; |
|
8087 |
|
8088 for ( ; index < length ; index++ ) { |
|
8089 prop = props[ index ]; |
|
8090 tweeners[ prop ] = tweeners[ prop ] || []; |
|
8091 tweeners[ prop ].unshift( callback ); |
|
8092 } |
|
8093 }, |
|
8094 |
|
8095 prefilter: function( callback, prepend ) { |
|
8096 if ( prepend ) { |
|
8097 animationPrefilters.unshift( callback ); |
|
8098 } else { |
|
8099 animationPrefilters.push( callback ); |
|
8100 } |
|
8101 } |
|
8102 }); |
|
8103 |
|
8104 function defaultPrefilter( elem, props, opts ) { |
|
8105 /* jshint validthis: true */ |
|
8106 var prop, value, toggle, tween, hooks, oldfire, |
|
8107 anim = this, |
|
8108 orig = {}, |
|
8109 style = elem.style, |
|
8110 hidden = elem.nodeType && isHidden( elem ), |
|
8111 dataShow = data_priv.get( elem, "fxshow" ); |
|
8112 |
|
8113 // handle queue: false promises |
|
8114 if ( !opts.queue ) { |
|
8115 hooks = jQuery._queueHooks( elem, "fx" ); |
|
8116 if ( hooks.unqueued == null ) { |
|
8117 hooks.unqueued = 0; |
|
8118 oldfire = hooks.empty.fire; |
|
8119 hooks.empty.fire = function() { |
|
8120 if ( !hooks.unqueued ) { |
|
8121 oldfire(); |
|
8122 } |
|
8123 }; |
|
8124 } |
|
8125 hooks.unqueued++; |
|
8126 |
|
8127 anim.always(function() { |
|
8128 // doing this makes sure that the complete handler will be called |
|
8129 // before this completes |
|
8130 anim.always(function() { |
|
8131 hooks.unqueued--; |
|
8132 if ( !jQuery.queue( elem, "fx" ).length ) { |
|
8133 hooks.empty.fire(); |
|
8134 } |
|
8135 }); |
|
8136 }); |
8884 }); |
8137 } |
8885 } |
8138 |
8886 |
8139 // height/width overflow pass |
8887 return this; |
8140 if ( elem.nodeType === 1 && ( "height" in props || "width" in props ) ) { |
|
8141 // Make sure that nothing sneaks out |
|
8142 // Record all 3 overflow attributes because IE9-10 do not |
|
8143 // change the overflow attribute when overflowX and |
|
8144 // overflowY are set to the same value |
|
8145 opts.overflow = [ style.overflow, style.overflowX, style.overflowY ]; |
|
8146 |
|
8147 // Set display property to inline-block for height/width |
|
8148 // animations on inline elements that are having width/height animated |
|
8149 if ( jQuery.css( elem, "display" ) === "inline" && |
|
8150 jQuery.css( elem, "float" ) === "none" ) { |
|
8151 |
|
8152 style.display = "inline-block"; |
|
8153 } |
|
8154 } |
|
8155 |
|
8156 if ( opts.overflow ) { |
|
8157 style.overflow = "hidden"; |
|
8158 anim.always(function() { |
|
8159 style.overflow = opts.overflow[ 0 ]; |
|
8160 style.overflowX = opts.overflow[ 1 ]; |
|
8161 style.overflowY = opts.overflow[ 2 ]; |
|
8162 }); |
|
8163 } |
|
8164 |
|
8165 |
|
8166 // show/hide pass |
|
8167 for ( prop in props ) { |
|
8168 value = props[ prop ]; |
|
8169 if ( rfxtypes.exec( value ) ) { |
|
8170 delete props[ prop ]; |
|
8171 toggle = toggle || value === "toggle"; |
|
8172 if ( value === ( hidden ? "hide" : "show" ) ) { |
|
8173 |
|
8174 // If there is dataShow left over from a stopped hide or show and we are going to proceed with show, we should pretend to be hidden |
|
8175 if ( value === "show" && dataShow && dataShow[ prop ] !== undefined ) { |
|
8176 hidden = true; |
|
8177 } else { |
|
8178 continue; |
|
8179 } |
|
8180 } |
|
8181 orig[ prop ] = dataShow && dataShow[ prop ] || jQuery.style( elem, prop ); |
|
8182 } |
|
8183 } |
|
8184 |
|
8185 if ( !jQuery.isEmptyObject( orig ) ) { |
|
8186 if ( dataShow ) { |
|
8187 if ( "hidden" in dataShow ) { |
|
8188 hidden = dataShow.hidden; |
|
8189 } |
|
8190 } else { |
|
8191 dataShow = data_priv.access( elem, "fxshow", {} ); |
|
8192 } |
|
8193 |
|
8194 // store state if its toggle - enables .stop().toggle() to "reverse" |
|
8195 if ( toggle ) { |
|
8196 dataShow.hidden = !hidden; |
|
8197 } |
|
8198 if ( hidden ) { |
|
8199 jQuery( elem ).show(); |
|
8200 } else { |
|
8201 anim.done(function() { |
|
8202 jQuery( elem ).hide(); |
|
8203 }); |
|
8204 } |
|
8205 anim.done(function() { |
|
8206 var prop; |
|
8207 |
|
8208 data_priv.remove( elem, "fxshow" ); |
|
8209 for ( prop in orig ) { |
|
8210 jQuery.style( elem, prop, orig[ prop ] ); |
|
8211 } |
|
8212 }); |
|
8213 for ( prop in orig ) { |
|
8214 tween = createTween( hidden ? dataShow[ prop ] : 0, prop, anim ); |
|
8215 |
|
8216 if ( !( prop in dataShow ) ) { |
|
8217 dataShow[ prop ] = tween.start; |
|
8218 if ( hidden ) { |
|
8219 tween.end = tween.start; |
|
8220 tween.start = prop === "width" || prop === "height" ? 1 : 0; |
|
8221 } |
|
8222 } |
|
8223 } |
|
8224 } |
|
8225 } |
|
8226 |
|
8227 function Tween( elem, options, prop, end, easing ) { |
|
8228 return new Tween.prototype.init( elem, options, prop, end, easing ); |
|
8229 } |
|
8230 jQuery.Tween = Tween; |
|
8231 |
|
8232 Tween.prototype = { |
|
8233 constructor: Tween, |
|
8234 init: function( elem, options, prop, end, easing, unit ) { |
|
8235 this.elem = elem; |
|
8236 this.prop = prop; |
|
8237 this.easing = easing || "swing"; |
|
8238 this.options = options; |
|
8239 this.start = this.now = this.cur(); |
|
8240 this.end = end; |
|
8241 this.unit = unit || ( jQuery.cssNumber[ prop ] ? "" : "px" ); |
|
8242 }, |
|
8243 cur: function() { |
|
8244 var hooks = Tween.propHooks[ this.prop ]; |
|
8245 |
|
8246 return hooks && hooks.get ? |
|
8247 hooks.get( this ) : |
|
8248 Tween.propHooks._default.get( this ); |
|
8249 }, |
|
8250 run: function( percent ) { |
|
8251 var eased, |
|
8252 hooks = Tween.propHooks[ this.prop ]; |
|
8253 |
|
8254 if ( this.options.duration ) { |
|
8255 this.pos = eased = jQuery.easing[ this.easing ]( |
|
8256 percent, this.options.duration * percent, 0, 1, this.options.duration |
|
8257 ); |
|
8258 } else { |
|
8259 this.pos = eased = percent; |
|
8260 } |
|
8261 this.now = ( this.end - this.start ) * eased + this.start; |
|
8262 |
|
8263 if ( this.options.step ) { |
|
8264 this.options.step.call( this.elem, this.now, this ); |
|
8265 } |
|
8266 |
|
8267 if ( hooks && hooks.set ) { |
|
8268 hooks.set( this ); |
|
8269 } else { |
|
8270 Tween.propHooks._default.set( this ); |
|
8271 } |
|
8272 return this; |
|
8273 } |
|
8274 }; |
8888 }; |
8275 |
8889 |
8276 Tween.prototype.init.prototype = Tween.prototype; |
8890 |
8277 |
8891 |
8278 Tween.propHooks = { |
8892 |
8279 _default: { |
8893 // Attach a bunch of functions for handling common AJAX events |
8280 get: function( tween ) { |
8894 jQuery.each( [ "ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend" ], function( i, type ) { |
8281 var result; |
8895 jQuery.fn[ type ] = function( fn ) { |
8282 |
8896 return this.on( type, fn ); |
8283 if ( tween.elem[ tween.prop ] != null && |
|
8284 (!tween.elem.style || tween.elem.style[ tween.prop ] == null) ) { |
|
8285 return tween.elem[ tween.prop ]; |
|
8286 } |
|
8287 |
|
8288 // passing an empty string as a 3rd parameter to .css will automatically |
|
8289 // attempt a parseFloat and fallback to a string if the parse fails |
|
8290 // so, simple values such as "10px" are parsed to Float. |
|
8291 // complex values such as "rotate(1rad)" are returned as is. |
|
8292 result = jQuery.css( tween.elem, tween.prop, "" ); |
|
8293 // Empty strings, null, undefined and "auto" are converted to 0. |
|
8294 return !result || result === "auto" ? 0 : result; |
|
8295 }, |
|
8296 set: function( tween ) { |
|
8297 // use step hook for back compat - use cssHook if its there - use .style if its |
|
8298 // available and use plain properties where available |
|
8299 if ( jQuery.fx.step[ tween.prop ] ) { |
|
8300 jQuery.fx.step[ tween.prop ]( tween ); |
|
8301 } else if ( tween.elem.style && ( tween.elem.style[ jQuery.cssProps[ tween.prop ] ] != null || jQuery.cssHooks[ tween.prop ] ) ) { |
|
8302 jQuery.style( tween.elem, tween.prop, tween.now + tween.unit ); |
|
8303 } else { |
|
8304 tween.elem[ tween.prop ] = tween.now; |
|
8305 } |
|
8306 } |
|
8307 } |
|
8308 }; |
|
8309 |
|
8310 // Support: IE9 |
|
8311 // Panic based approach to setting things on disconnected nodes |
|
8312 |
|
8313 Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = { |
|
8314 set: function( tween ) { |
|
8315 if ( tween.elem.nodeType && tween.elem.parentNode ) { |
|
8316 tween.elem[ tween.prop ] = tween.now; |
|
8317 } |
|
8318 } |
|
8319 }; |
|
8320 |
|
8321 jQuery.each([ "toggle", "show", "hide" ], function( i, name ) { |
|
8322 var cssFn = jQuery.fn[ name ]; |
|
8323 jQuery.fn[ name ] = function( speed, easing, callback ) { |
|
8324 return speed == null || typeof speed === "boolean" ? |
|
8325 cssFn.apply( this, arguments ) : |
|
8326 this.animate( genFx( name, true ), speed, easing, callback ); |
|
8327 }; |
8897 }; |
8328 }); |
8898 }); |
8329 |
8899 |
8330 jQuery.fn.extend({ |
8900 |
8331 fadeTo: function( speed, to, easing, callback ) { |
8901 |
8332 |
8902 |
8333 // show any hidden elements after setting opacity to 0 |
8903 jQuery.expr.filters.animated = function( elem ) { |
8334 return this.filter( isHidden ).css( "opacity", 0 ).show() |
8904 return jQuery.grep(jQuery.timers, function( fn ) { |
8335 |
8905 return elem === fn.elem; |
8336 // animate to the value specified |
8906 }).length; |
8337 .end().animate({ opacity: to }, speed, easing, callback ); |
8907 }; |
8338 }, |
8908 |
8339 animate: function( prop, speed, easing, callback ) { |
8909 |
8340 var empty = jQuery.isEmptyObject( prop ), |
8910 |
8341 optall = jQuery.speed( speed, easing, callback ), |
8911 |
8342 doAnimation = function() { |
8912 var docElem = window.document.documentElement; |
8343 // Operate on a copy of prop so per-property easing won't be lost |
8913 |
8344 var anim = Animation( this, jQuery.extend( {}, prop ), optall ); |
8914 /** |
8345 |
8915 * Gets a window from an element |
8346 // Empty animations, or finishing resolves immediately |
8916 */ |
8347 if ( empty || data_priv.get( this, "finish" ) ) { |
8917 function getWindow( elem ) { |
8348 anim.stop( true ); |
8918 return jQuery.isWindow( elem ) ? elem : elem.nodeType === 9 && elem.defaultView; |
8349 } |
|
8350 }; |
|
8351 doAnimation.finish = doAnimation; |
|
8352 |
|
8353 return empty || optall.queue === false ? |
|
8354 this.each( doAnimation ) : |
|
8355 this.queue( optall.queue, doAnimation ); |
|
8356 }, |
|
8357 stop: function( type, clearQueue, gotoEnd ) { |
|
8358 var stopQueue = function( hooks ) { |
|
8359 var stop = hooks.stop; |
|
8360 delete hooks.stop; |
|
8361 stop( gotoEnd ); |
|
8362 }; |
|
8363 |
|
8364 if ( typeof type !== "string" ) { |
|
8365 gotoEnd = clearQueue; |
|
8366 clearQueue = type; |
|
8367 type = undefined; |
|
8368 } |
|
8369 if ( clearQueue && type !== false ) { |
|
8370 this.queue( type || "fx", [] ); |
|
8371 } |
|
8372 |
|
8373 return this.each(function() { |
|
8374 var dequeue = true, |
|
8375 index = type != null && type + "queueHooks", |
|
8376 timers = jQuery.timers, |
|
8377 data = data_priv.get( this ); |
|
8378 |
|
8379 if ( index ) { |
|
8380 if ( data[ index ] && data[ index ].stop ) { |
|
8381 stopQueue( data[ index ] ); |
|
8382 } |
|
8383 } else { |
|
8384 for ( index in data ) { |
|
8385 if ( data[ index ] && data[ index ].stop && rrun.test( index ) ) { |
|
8386 stopQueue( data[ index ] ); |
|
8387 } |
|
8388 } |
|
8389 } |
|
8390 |
|
8391 for ( index = timers.length; index--; ) { |
|
8392 if ( timers[ index ].elem === this && (type == null || timers[ index ].queue === type) ) { |
|
8393 timers[ index ].anim.stop( gotoEnd ); |
|
8394 dequeue = false; |
|
8395 timers.splice( index, 1 ); |
|
8396 } |
|
8397 } |
|
8398 |
|
8399 // start the next in the queue if the last step wasn't forced |
|
8400 // timers currently will call their complete callbacks, which will dequeue |
|
8401 // but only if they were gotoEnd |
|
8402 if ( dequeue || !gotoEnd ) { |
|
8403 jQuery.dequeue( this, type ); |
|
8404 } |
|
8405 }); |
|
8406 }, |
|
8407 finish: function( type ) { |
|
8408 if ( type !== false ) { |
|
8409 type = type || "fx"; |
|
8410 } |
|
8411 return this.each(function() { |
|
8412 var index, |
|
8413 data = data_priv.get( this ), |
|
8414 queue = data[ type + "queue" ], |
|
8415 hooks = data[ type + "queueHooks" ], |
|
8416 timers = jQuery.timers, |
|
8417 length = queue ? queue.length : 0; |
|
8418 |
|
8419 // enable finishing flag on private data |
|
8420 data.finish = true; |
|
8421 |
|
8422 // empty the queue first |
|
8423 jQuery.queue( this, type, [] ); |
|
8424 |
|
8425 if ( hooks && hooks.stop ) { |
|
8426 hooks.stop.call( this, true ); |
|
8427 } |
|
8428 |
|
8429 // look for any active animations, and finish them |
|
8430 for ( index = timers.length; index--; ) { |
|
8431 if ( timers[ index ].elem === this && timers[ index ].queue === type ) { |
|
8432 timers[ index ].anim.stop( true ); |
|
8433 timers.splice( index, 1 ); |
|
8434 } |
|
8435 } |
|
8436 |
|
8437 // look for any animations in the old queue and finish them |
|
8438 for ( index = 0; index < length; index++ ) { |
|
8439 if ( queue[ index ] && queue[ index ].finish ) { |
|
8440 queue[ index ].finish.call( this ); |
|
8441 } |
|
8442 } |
|
8443 |
|
8444 // turn off finishing flag |
|
8445 delete data.finish; |
|
8446 }); |
|
8447 } |
|
8448 }); |
|
8449 |
|
8450 // Generate parameters to create a standard animation |
|
8451 function genFx( type, includeWidth ) { |
|
8452 var which, |
|
8453 attrs = { height: type }, |
|
8454 i = 0; |
|
8455 |
|
8456 // if we include width, step value is 1 to do all cssExpand values, |
|
8457 // if we don't include width, step value is 2 to skip over Left and Right |
|
8458 includeWidth = includeWidth? 1 : 0; |
|
8459 for( ; i < 4 ; i += 2 - includeWidth ) { |
|
8460 which = cssExpand[ i ]; |
|
8461 attrs[ "margin" + which ] = attrs[ "padding" + which ] = type; |
|
8462 } |
|
8463 |
|
8464 if ( includeWidth ) { |
|
8465 attrs.opacity = attrs.width = type; |
|
8466 } |
|
8467 |
|
8468 return attrs; |
|
8469 } |
8919 } |
8470 |
8920 |
8471 // Generate shortcuts for custom animations |
|
8472 jQuery.each({ |
|
8473 slideDown: genFx("show"), |
|
8474 slideUp: genFx("hide"), |
|
8475 slideToggle: genFx("toggle"), |
|
8476 fadeIn: { opacity: "show" }, |
|
8477 fadeOut: { opacity: "hide" }, |
|
8478 fadeToggle: { opacity: "toggle" } |
|
8479 }, function( name, props ) { |
|
8480 jQuery.fn[ name ] = function( speed, easing, callback ) { |
|
8481 return this.animate( props, speed, easing, callback ); |
|
8482 }; |
|
8483 }); |
|
8484 |
|
8485 jQuery.speed = function( speed, easing, fn ) { |
|
8486 var opt = speed && typeof speed === "object" ? jQuery.extend( {}, speed ) : { |
|
8487 complete: fn || !fn && easing || |
|
8488 jQuery.isFunction( speed ) && speed, |
|
8489 duration: speed, |
|
8490 easing: fn && easing || easing && !jQuery.isFunction( easing ) && easing |
|
8491 }; |
|
8492 |
|
8493 opt.duration = jQuery.fx.off ? 0 : typeof opt.duration === "number" ? opt.duration : |
|
8494 opt.duration in jQuery.fx.speeds ? jQuery.fx.speeds[ opt.duration ] : jQuery.fx.speeds._default; |
|
8495 |
|
8496 // normalize opt.queue - true/undefined/null -> "fx" |
|
8497 if ( opt.queue == null || opt.queue === true ) { |
|
8498 opt.queue = "fx"; |
|
8499 } |
|
8500 |
|
8501 // Queueing |
|
8502 opt.old = opt.complete; |
|
8503 |
|
8504 opt.complete = function() { |
|
8505 if ( jQuery.isFunction( opt.old ) ) { |
|
8506 opt.old.call( this ); |
|
8507 } |
|
8508 |
|
8509 if ( opt.queue ) { |
|
8510 jQuery.dequeue( this, opt.queue ); |
|
8511 } |
|
8512 }; |
|
8513 |
|
8514 return opt; |
|
8515 }; |
|
8516 |
|
8517 jQuery.easing = { |
|
8518 linear: function( p ) { |
|
8519 return p; |
|
8520 }, |
|
8521 swing: function( p ) { |
|
8522 return 0.5 - Math.cos( p*Math.PI ) / 2; |
|
8523 } |
|
8524 }; |
|
8525 |
|
8526 jQuery.timers = []; |
|
8527 jQuery.fx = Tween.prototype.init; |
|
8528 jQuery.fx.tick = function() { |
|
8529 var timer, |
|
8530 timers = jQuery.timers, |
|
8531 i = 0; |
|
8532 |
|
8533 fxNow = jQuery.now(); |
|
8534 |
|
8535 for ( ; i < timers.length; i++ ) { |
|
8536 timer = timers[ i ]; |
|
8537 // Checks the timer has not already been removed |
|
8538 if ( !timer() && timers[ i ] === timer ) { |
|
8539 timers.splice( i--, 1 ); |
|
8540 } |
|
8541 } |
|
8542 |
|
8543 if ( !timers.length ) { |
|
8544 jQuery.fx.stop(); |
|
8545 } |
|
8546 fxNow = undefined; |
|
8547 }; |
|
8548 |
|
8549 jQuery.fx.timer = function( timer ) { |
|
8550 if ( timer() && jQuery.timers.push( timer ) ) { |
|
8551 jQuery.fx.start(); |
|
8552 } |
|
8553 }; |
|
8554 |
|
8555 jQuery.fx.interval = 13; |
|
8556 |
|
8557 jQuery.fx.start = function() { |
|
8558 if ( !timerId ) { |
|
8559 timerId = setInterval( jQuery.fx.tick, jQuery.fx.interval ); |
|
8560 } |
|
8561 }; |
|
8562 |
|
8563 jQuery.fx.stop = function() { |
|
8564 clearInterval( timerId ); |
|
8565 timerId = null; |
|
8566 }; |
|
8567 |
|
8568 jQuery.fx.speeds = { |
|
8569 slow: 600, |
|
8570 fast: 200, |
|
8571 // Default speed |
|
8572 _default: 400 |
|
8573 }; |
|
8574 |
|
8575 // Back Compat <1.8 extension point |
|
8576 jQuery.fx.step = {}; |
|
8577 |
|
8578 if ( jQuery.expr && jQuery.expr.filters ) { |
|
8579 jQuery.expr.filters.animated = function( elem ) { |
|
8580 return jQuery.grep(jQuery.timers, function( fn ) { |
|
8581 return elem === fn.elem; |
|
8582 }).length; |
|
8583 }; |
|
8584 } |
|
8585 jQuery.fn.offset = function( options ) { |
|
8586 if ( arguments.length ) { |
|
8587 return options === undefined ? |
|
8588 this : |
|
8589 this.each(function( i ) { |
|
8590 jQuery.offset.setOffset( this, options, i ); |
|
8591 }); |
|
8592 } |
|
8593 |
|
8594 var docElem, win, |
|
8595 elem = this[ 0 ], |
|
8596 box = { top: 0, left: 0 }, |
|
8597 doc = elem && elem.ownerDocument; |
|
8598 |
|
8599 if ( !doc ) { |
|
8600 return; |
|
8601 } |
|
8602 |
|
8603 docElem = doc.documentElement; |
|
8604 |
|
8605 // Make sure it's not a disconnected DOM node |
|
8606 if ( !jQuery.contains( docElem, elem ) ) { |
|
8607 return box; |
|
8608 } |
|
8609 |
|
8610 // If we don't have gBCR, just use 0,0 rather than error |
|
8611 // BlackBerry 5, iOS 3 (original iPhone) |
|
8612 if ( typeof elem.getBoundingClientRect !== core_strundefined ) { |
|
8613 box = elem.getBoundingClientRect(); |
|
8614 } |
|
8615 win = getWindow( doc ); |
|
8616 return { |
|
8617 top: box.top + win.pageYOffset - docElem.clientTop, |
|
8618 left: box.left + win.pageXOffset - docElem.clientLeft |
|
8619 }; |
|
8620 }; |
|
8621 |
|
8622 jQuery.offset = { |
8921 jQuery.offset = { |
8623 |
|
8624 setOffset: function( elem, options, i ) { |
8922 setOffset: function( elem, options, i ) { |
8625 var curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition, |
8923 var curPosition, curLeft, curCSSTop, curTop, curOffset, curCSSLeft, calculatePosition, |
8626 position = jQuery.css( elem, "position" ), |
8924 position = jQuery.css( elem, "position" ), |
8627 curElem = jQuery( elem ), |
8925 curElem = jQuery( elem ), |
8628 props = {}; |
8926 props = {}; |